Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
ara-filesystem
Advanced tools
The Ara FileSystem, isolated and secure file systems backed by Ara identities.
The Ara Filesystem, standalone and secure filesystems backed by Ara identities.
[Stability][stability-index]: 2 - Stable. Stable. Compatibility with the npm ecosystem is a high priority.
Although the API is stable, this project is still in alpha development and is not yet ready to be used in a production environment.
$ npm install ara-filesystem --save
Important: Each CLI command that makes changes to the AFS requires the password of the owner identity (the one created with
aid create
). Do not forget this password, as it's the only way to update the AFS.
Run the create command with a valid owner identity.
$ afs create did:ara:df45010fee8baf67f91f5102b9562b14d5b49c972a007cd460b1aa77fd90eaf9
Store the mnemonic phrase in a safe place as it is the only recovery mechanism for your AFS.
Note: The
did:ara:
prefix is optional for all commands.
Adding files and/or directories can be done with the add
command.
$ afs add <did> <pathspec...>
Example:
$ afs add df45010fee8baf67f91f5102b9562b14d5b49c972a007cd460b1aa77fd90eaf9 my_video.mp4
$ afs remove <did> <pathspec...>
Example:
$ afs remove df45010fee8baf67f91f5102b9562b14d5b49c972a007cd460b1aa77fd90eaf9 my_video.mp4
A .afsignore
file can be used to specify any files or directories to ignore when adding to an AFS. Only a .afsignore
file located at the directory where the afs
command is run will be honored.
Each line in afsignore
specifies a pattern, similar to .npmignore
and .gitignore
files:
By default, .afs/
and .afsignore
are ignored.
An example .afsignore
file (taken from the .gitignore
link above):
# ignore all .a files
*.a
# but do track lib.a, even though you're ignoring .a files above
!lib.a
# only ignore the TODO file in the current directory, not subdir/TODO
/TODO
# ignore all files in any directory named build
build/
# ignore doc/notes.txt, but not doc/server/arch.txt
doc/*.txt
# ignore all .pdf files in the doc/ directory and any of its subdirectories
doc/**/*.pdf
Before you can commit to an AFS, a proxy contract representing that AFS must be deployed to the network.
$ afs deploy df45010fee8baf67f91f5102b9562b14d5b49c972a007cd460b1aa77fd90eaf9
Every change in the AFS saved to a local file on disc, much like staged commits. Changes must be commited before they are discoverable and published to the Ara network.
$ afs commit df45010fee8baf67f91f5102b9562b14d5b49c972a007cd460b1aa77fd90eaf9
Set the price of an AFS by passing in an AFS identity and price in ara tokens. For example, this sets the price of the AFS to 10 ara tokens:
$ afs set-price df45010fee8baf67f91f5102b9562b14d5b49c972a007cd460b1aa77fd90eaf9 10
To verify set price:
$ afs get-price df45010fee8baf67f91f5102b9562b14d5b49c972a007cd460b1aa77fd90eaf9
async create(opts)
If owner
is given, this function will create a new AFS with the owning identity owner
. If did
is given, it attempts to get a reference to a previously created AFS.
opts
did
- The DID
of an existing AFS
owner
- DID
of the owner of the AFS
to be createdpassword
- The password of the owner
of this AFS
; this is only required for writing to the AFS
.afsPassword
- The password of the AFS
; this is only required for writing to the AFS
.storage
- optional Storage function to use for the AFS
keyringOpts
- optional Keyring optionsReturns the AFS
object
.
To create a new AFS
:
const aid = require('ara-identity')
const { create } = require('ara-filesystem')
const identity = await aid.create({ context, password })
await writeIdentity(identity)
const { publicKey: owner } = identity
const { afs } = await create({ owner, password, afsPassword })
To obtain a reference to an existing AFS
:
const did = did:ara:df45010fee8baf67f91f5102b9562b14d5b49c972a007cd460b1aa77fd90eaf9
const { afs } = await create({ did })
Note: Either
did
orowner
is required, but not both.
async destroy(opts)
Destroys the local copy of an AFS
and unlists it from the blockchain (if owner), effectively removing it from the Ara network.
opts
did
- The DID
of the AFS
to be destroyedpassword
- The password of the owner of this AFS
afsPassword
- The password of the AFS
mnemonic
- The mnemonic for this AFS
keyringOpts
- optional Keyring optionsIf an estimate, returns the cost
(in ETH), otherwise returns the transaction receipt.
const { create, destroy } = require('ara-filesystem')
const { afs, mnemonic } = await create({ owner, password, afsPassword })
const { did } = afs
await destroy({
did,
mnemonic,
password,
afsPassword
})
async add(opts)
Adds one or more files to an existing AFS
.
opts
did
- The DID
of the AFS
to add files topassword
- The password of the AFS
force
- Force add the path(s)paths
- The path(s) of the files to addkeyringOpts
- optional Keyring optionsReturns the AFS
object
.
const { create, add } = require('ara-filesystem')
let { afs } = await create({ owner, password })
const { did } = afs
const paths = ['./index.js', './add.js', './picture.png']
afs = await add({
did,
paths,
password
})
async remove(opts)
Removes one or more files from an AFS
.
opts
did
- The DID
of the AFS
where the files are locatedpassword
- The password of the AFS
paths
- The path(s) of the files to removekeyringOpts
- optional Keyring optionsReturns the AFS
object
.
const { remove } = require('ara-filesystem')
const afs = await remove({
did,
paths,
password
})
async deploy(opts)
Deploys an AFS proxy to the network. Returns the Ethereum address of the deploy contract (if not an estimation).
opts
did
- DID
of the AFS
to deploypassword
- Owner's password for this AFS
afsPassword
- The password of the AFS
estimate
- optional Flag to check cost of deploy
keyringOpts
- optional Keyring optionsIf an estimate, returns the cost
(in ETH), otherwise returns the Ethereum address where the contract was deployed.
const { deploy } = require('ara-filesystem')
const address = await deploy({
afsPassword,
password,
did
})
// estimate deploy
const cost = await deploy({
estimate: true,
afsPassword,
password,
did
})
async commit(opts)
Commits any changes to an AFS
to the blockchain. Calling deploy
is required before any commits can occur.
opts
did
- The DID
of the AFS
to commitpassword
- The password of the owner of this AFS
afsPassword
- The password of the AFS
estimate
- optional Flag to check cost of commit
estimateDid
- optional DID
of a proxy which points to an estimate version of an AFS Standard (used for estimating cost without deploy
first)price
- optional Price in Ara tokens to set this AFS
keyringOpts
- optional Keyring optionsIf an estimate, returns the cost
(in ETH), otherwise returns the transaction receipt.
const { commit } = require('ara-filesystem')
const result = await commit({
afsPassword,
password,
price,
did
})
// estimate commit cost
const cost = await commit({
estimate: true,
afsPassword,
password,
price,
did
})
async setPrice(opts)
Sets the price in Ara tokens of an AFS
.
opts
did
- The DID
of the AFS
to set the price ofpassword
- The password of the owner of this AFS
afsPassword
- The password of the AFS
price
- The price (in Ara) to purchase this AFS
estimate
- optional Flag to check cost of setPrice
estimateDid
- optional DID
of a proxy which points to an estimate version of an AFS Standard (used for estimating cost without deploy
first)keyringOpts
- optional Keyring optionsIf an estimate, returns the cost
(in ETH), otherwise returns the transaction receipt.
const { setPrice } = require('ara-filesystem')
const price = 10
await setPrice({
afsPassword,
password,
price,
did
})
// estimate set price cost
const cost = await setPrice({
estimate: true,
afsPassword
password,
price,
did
})
async getPrice(opts)
Gets the price in Ara tokens of an AFS
.
opts
did
- The DID
of the AFS
to get the price ofIf an estimate, returns the cost
(in ETH) as a string
.
const { getPrice } = require('ara-filesystem')
const price = await getPrice({ did })
async unarchive(opts)
Stability: 2 Stable
Unarchives (unzips) an AFS
to a specified location.
opts
did
- The DID
of the AFS
to unarchivepath
- optional Path to the AFS
keyringOpts
- optional Keyring optionsconst { unarchive } = require('ara-filesystem')
await unarchive({
did,
path
})
async isUpdateAvailable(opts)
Compares local AFS
version to what has been published. Returns true
if the published AFS
version is greater than the local, otherwise false
.
opts
did
- The DID
of the AFS
to checkkeyringOpts
- optional Keyring optionsReturns a boolean
.
const { isUpdateAvailable } = require('ara-filesystem')
const available = await isUpdateAvailable({ did: 'df45010fee8baf67f91f5102b9562b14d5b49c972a007cd460b1aa77fd90eaf9' })
async metadata.writeFile(opts)
Writes a metadata JSON file to the metadata partition of an AFS
.
opts
did
- The DID
of the AFS
to write topassword
- The password of the owner of this AFS
afsPassword
- The password of the AFS
filepath
- The path of the metadata JSON file to copykeyringOpts
- optional Keyring optionsReturns the updated metadata object
.
const { metadata } = require('ara-filesystem')
const result = await metadata.writeFile({
did,
password,
filepath,
afsPassword
})
async metadata.writeKey(opts)
Writes a metadata key/value pair to the metadata partition of an AFS
.
opts
did
- The DID
of the AFS
to write topassword
- The password of the owner of this AFS
afsPassword
- The password of the AFS
key
- The key to writevalue
- The value to writekeyringOpts
- optional Keyring optionsReturns the updated metadata object
.
const { metadata } = require('ara-filesystem')
const key = 'foo'
const value = 'bar'
const result = await metadata.writeKey({
did,
key,
value,
password,
afsPassword
})
async metadata.writeKeys(opts)
Writes multiple key/value pairs to the metadata parition of an AFS
.
opts
did
- The DID
of the AFS
to write topassword
- The password of the owner of this AFS
afsPassword
- The password of the AFS
keys
- Object containing the key/value pairs to writekeyringOpts
- optional Keyring optionsReturns the updated metadata object
.
const { metadata } = require('ara-filesystem')
const keys = { foo: 'bar', hello: 'world' }
await metadata.writeKeys({
did,
keys,
password,
afsPassword
})
async metadata.readKey(opts)
Reads a metadata key from the metadata partition of an AFS
.
opts
did
- The DID
of the AFS
to read fromkey
- The key to writeReturns the value
of the metadata key
.
const { metadata } = require('ara-filesystem')
const result = await metadata.readKey({
did,
key
})
async metadata.delKey(opts)
Deletes a metadata key/value pair from the metadata partition of an AFS
.
opts
did
- The DID
of the AFS
to delete frompassword
- The password of the owner of this AFS
afsPassword
- The password of the AFS
key
- The key to writekeyringOpts
- optional Keyring optionsReturns the updated metadata object
.
const { metadata } = require('ara-filesystem')
await metadata.delKey({
did,
key,
password,
afsPassword
})
async metadata.clear(opts)
Empties all metadata contents of an AFS
.
opts
did
- The DID
of the AFS
whose metadata is to be emptiedpassword
- The password of the owner of this AFS
afsPassword
- The password of the AFS
const { metadata } = require('ara-filesystem')
await metadata.clear({ did, password, afsPassword })
async metadata.readFile(opts)
Reads all metadata from an AFS
.
opts
did
- The DID
of the AFS
to read fromReturns the updated metadata object
.
const { metadata } = require('ara-filesystem')
const contents = await metadata.readFile({ did })
ownership.estimateRequestGasCost(opts)
Gets the estimated gas cost of requesting ownership of an AFS.
Note: This function takes the same arguments as
ownership.request(opts)
Returns the cost
(in ETH) as a string
.
const { ownership } = require('ara-filesystem')
const cost = await ownership.estimateRequestGasCost(opts) // 0.015 ETH
ownership.estimateRevokeGasCost(opts)
Gets the estimated gas cost of revoking a previous ownership request.
Note: This function takes the same arguments as
ownership.revokeRequest(opts)
Returns the cost
(in ETH) as a string
.
const { ownership } = require('ara-filesystem')
const cost = await ownership.estimateRevokeGasCost(opts) // 0.015 ETH
ownership.estimateApproveGasCost(opts)
Gets the estimated gas cost of approving an ownership request.
Note: This function takes the same arguments as
ownership.approveTransfer(opts)
Returns the cost
(in ETH) as a string
.
const { ownership } = require('ara-filesystem')
const cost = await ownership.estimateApproveGasCost(opts) // 0.015 ETH
ownership.request(opts)
Requests the transfer of ownership of an AFS to requesterDid
. Must be approved by the current owner. This transaction will revert if a request is already active.
opts
requesterDid
- DID
of the requestercontentDid
- DID
of the AFS to request ownership forpassword
- password of the requesterestimate
- optional Flag to check cost of request
keyringOpts
- optional Keyring optionsReturns the transaction receipt as an object
.
const { ownership } = require('ara-filesystem')
const requesterDid = 'did:ara:a51aa651c5a28a7c0a8de007843a00dcd24f3cc893522d3fb093c2bb7a323785'
const password = 'pass'
const contentDid = 'did:ara:114045f3883a21735188bb02de024a4e1451cb96c5dcc80bdfa1b801ecf81b85'
const receipt = await ownership.request({ requesterDid, password, contentDid })
ownership.revokeRequest(opts)
Revokes a previous request for AFS ownership transfer. This transaction will revert if there isn't an active request.
opts
requesterDid
- DID
of the requestercontentDid
- DID
of the AFS to revoke ownership reequest forpassword
- password of the requesterestimate
- optional Flag to check cost of revokeRequest
keyringOpts
- optional Keyring optionsReturns the transaction receipt as an object
.
const { ownership } = require('ara-filesystem')
const requesterDid = 'did:ara:a51aa651c5a28a7c0a8de007843a00dcd24f3cc893522d3fb093c2bb7a323785'
const password = 'pass'
const contentDid = 'did:ara:114045f3883a21735188bb02de024a4e1451cb96c5dcc80bdfa1b801ecf81b85'
const receipt = await ownership.revokeRequest({ requesterDid, password, contentDid })
ownership.approveTransfer(opts)
Approves a pending transfer request, this officially transfers ownership for the given AFS. If not an estimate, this function will return an object containing a random password to be delivered to the identity claiming ownership, along with the transaction receipt.
opts
contentDid
- DID
of the content to change ownership forpassword
- Password of the staged ownerafsPassword
- The password of the AFS
newOwnerDid
- DID
of the owner to transfer ownership tomnemonic
- mnemonic associated with the AFSestimate
- optional Flag to check cost of approveTransfer
keyringOpts
- optional Keyring optionsReturns object
:
receipt
- transaction receiptpassword
- randomly generated passwordconst { ownership } = require('ara-filesystem')
const contentDid = 'did:ara:a51aa651c5a28a7c0a8de007843a00dcd24f3cc893522d3fb093c2bb7a323785'
const password = 'pass'
const afsPassword = 'password'
const newOwnerDid = 'did:ara:7dc039cfb220029c371d0f4aabf4a956ed0062d66c447df7b4595d7e11187271'
const mnemonic = 'cargo diary bracket crumble stable chief grief grab frost seven wet repeat'
const result = await ownership.approveTransfer({ contentDid, password, afsPassword, newOwnerDid, mnemonic })
ownership.claim(opts)
Fully claims ownership of an AFS after it has been transferred by the previous owner.
opts
currentPassword
- random password generated from the previous ownernewPassword
- new password for this AFS identitycontentDid
- DID
of the content to claim ownership formnemonic
- mnemonic associated with the AFS to claimkeyringOpts
- optional Keyring optionsconst { ownership } = require('ara-filesystem')
const contentDid = 'did:ara:a51aa651c5a28a7c0a8de007843a00dcd24f3cc893522d3fb093c2bb7a323785'
const currentPassword = 'generatedPassword'
const newPassword = 'secureNewPassword'
const mnemonic = 'cargo diary bracket crumble stable chief grief grab frost seven wet repeat'
await ownership.claim({
currentPassword,
newPassword,
contentDid,
mnemonic
})
Releases follow Semantic Versioning
LGPL-3.0
FAQs
The Ara FileSystem, isolated and secure file systems backed by Ara identities.
We found that ara-filesystem demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.