npm install -g @shadow-drive/cli
or yarn global add @shadow-drive/cli
The basic flow of Shadow Drive is as follows:
- Get some $SHDW in your wallet (you will need a command line wallet)
- Create your storage account with the create storage account command
- Upload your file(s) with the upload file or upload multiple files commands
- Optional: Mark your storage account as immutable to permanently lock your files in place with the make storage account immutable command
- Congratulations, you're now storing your files on Shadow Drive!
Example: shdw-drive help
This command will display all the available commands for the Shadow Drive CLI.
Example: shdw-drive create-storage-account --keypair ~/.config/solana/id.json --name "My Storage Account" --size 10MB
This command will create your storage account for you. You will be shown the estimated $SHDW amount required to create the storage account before continuing with submitting the transaction to Solana and the Shadow Drive Network.
Parameters:
- Keypair: Path to wallet that will create the storage account
- Name: What you want your storage account to be named. (Does not have to be unique)
- Size: Amount of storage you are requesting to create. Should be in a string like '1KB', '1MB', '1GB'. Only KB, MB, and GB storage delineations are supported currently.
Example: shdw-drive make-storage-account-immutable --keypair ~/.config/solana/id.json
This will permanently lock your storage account and all files within it. You will not be able to add/reduce storage on this account, delete the storage account, or edit/delete files under this storage account.
When running this command, you will be presented with a list of storage accounts that the wallet passed in, is an admin of, and has authority to make the account immutable.
The stake from the storage account that you mark as immutable will also be deducted and closed.
Parameters:
- Keypair: Path to the wallet that is an admin of the storage account you want to make immutable.
Example: shdw-drive delete-storage-account --keypair ~/.config/solana/id.json
If the storage account you select is not marked as immutable, you can request to delete the account. Once this request has been fully processed by a crank, your storage account and all files within it will be removed from the Shadow Drive Network. Any remaining stake in your storage account will be returned to you.
You will be presented with a list of storage accounts to choose from that you'd like to undo a deletion request for.
NOTE: Once you submit this request, you will have a grace period of the rest of the current Solana Epoch to undo this request. Once Solana's clock reaches the next epoch, you will not be able to undo this request and your account will be available for a crank to fully process the deletion.
Parameters:
- Keypair: Path to wallet that is an admin of the storage account you want to request for deletion
Example: shdw-drive undelete-storage-account --keypair ~/.config/solana/id.json
This will undo a storage account deletion request. When running this command, you will be presented with a list of accounts to choose from that have been requested to be deleted and are still within the grace period.
NOTE: There is a grace period between when you request for your storage account to be deleted and when it's actually deleted. Currently it is set to be within the Solana Epoch that you requested to delete your storage account. For example, if you requested to delete a storage account in Solana Epoch 306, once Solana's clock reaches epoch 307, you are no longer able to undo the deletion request and it will be available for a crank to fully process the deletion.
Parameters:
- Keypair: Path to the wallet that is an admin of the storage account you want to undo a deletion request for
Example: shdw-drive add-storage --keypair ~/.config/solana/id.json --size 10MB
This will add storage capacity to an existing storage account that you select when running this command. When running this command, you will be presented with a list of accounts to choose from.
Parameters:
- Keypair: Path to the wallet that is an admin of the storage account you want to add storage capacity to.
Example: shdw-drive reduce-storage --keypair ~/.config/solana/id.json --size 10MB
This will reduce the total storage capacity available for given storage account. When running this command, you will be presented with a list of accounts to choose from.
After reducing storage on a storage account, you can run claim-stake
to recover the $SHDW back to your wallet.
Parameters:
- Keypair: Path to the wallet that is an admin of the storage account you want to reduce storage on.
Example: shdw-drive claim-stake --keypair ~/.config/solana/id.json
This will claim any available stake as a result of the reduce storage
command. You will be presented with a list of storage accounts and the amount of stake claimable to choose from.
Parameters:
- Keypair: Path to the wallet that is an admin of the storage account you want to claim stake from.
Example: shdw-drive upload-file --keypair ~/.config/solana/id.json --file ~/Documents/something-important.md
This will upload a file at the supplied path. When uploading a file, you will be presented with a list of storage accounts to choose from and use as the account that stores your file.
Parameters:
- Keypair: Path to the wallet that is an admin of the storage account you want to upload to
- File: Path to the file you want to upload. This can be a relative or absolute path.
Note: If you get the error
Server response status message: failed to send transaction: Transaction simulation failed: Transaction leaves an account with a lower balance than rent-exempt minimum
it means you do not have the minimum amount of SOL required in your wallet for your account to be rent-exempted after the operation.
Send some SOL to your wallet and try again.
Example: shdw-drive upload-multiple-files --keypair ~/.config/solana/id.json --directory ~/Documents/my-expensive-jpgs/
This will allow you to upload all files in a given directory. If the file already exists, the upload for that file will be skipped and you will get back the finalized Shadow Drive URL in the response. When running this command, you will be presented with a list of storage accounts to choose from, and only the ones with enough storage for the entire directory supplied will be selectable.
The log of this command will be written to a .json
file in your current directory.
Parameters:
- Keypair: Path to the wallet that is an admin of the storage account you want to upload
- Directory: Path to the folder of files you want to upload.
It is possible some files will not upload - and this will be reflected in the .json
file mentioned above. The results are also printed to the terminal when the upload-multiple-files command completes. You can identify which files have failed to upload by searching for 'location: null' in the file.
To re-upload the files that failed to upload when you initially ran the command - simply rerun the same command. The command checks if a file has already been uploaded and then moves on to the files which haven't yet been uploaded.
The following command was used for this, with the folder containing files [0-10].gif & [0-10].json: shdw-drive upload-multiple-files --env mainnet-beta --keypair /home/ssc/.config/solana/test.json -d test_diamond/
Example: shdw-drive edit-file --keypair ~/.config/solana/id.json --file ~/Documents/something-important --url https://shdw-drive.genesysgo.net/abc123def456ghi789/something-important.md
This will replace a file that exists on Shadow Drive with the new file supplied.
NOTE: The file you are wanting to edit must be the same name of the file that already exists in your storage account. If it does not already exist on Shadow Drive, your request will fail. If the file you want to submit to Shadow Drive has a different name, you must perform a new upload request instead.
Parameters:
- Keypair: Path to the wallet that is an admin of the storage account the file was originally uploaded to
- File: New file you want to upload
- URL: The Shadow Drive URL of the file that currently exists
Example: shdw-drive delete-file --keypair ~/.config/solana/id.json --url https://shdw-drive.genesysgo.net/abc123def456ghi789/something-important.md
This will submit a request to delete the file supplied.
NOTE: Once you submit this request, you will have a grace period of the rest of the current Solana Epoch to undo this request. Once Solana's clock reaches the next epoch, you will not be able to undo this request and your file will be available for a crank to fully process the deletion.
Parameters:
- Keypair: Path to the wallet that is an admin of the storage account the file was originally uploaded to
- URL: The Shadow Drive URL of the file you're requesting to delete
Example: shdw-drive undelete-file --keypair ~/.config/solana/id.json --url https://shdw-drive.genesysgo.net/abc123def456ghi789/something-important.md
This will undo a deletion request for the file supplied if it's still within the grace period.
NOTE: There is a grace period between when you request for your storage account to be deleted and when it's actually deleted. Currently it is set to be within the Solana Epoch that you requested to delete your storage account. For example, if you requested to delete a storage account in Solana Epoch 306, once Solana's clock reaches epoch 307, you are no longer able to undo the deletion request and your file will be available for a crank to fully process the deletion.
Parameters:
- Keypair: Path to the wallet that is an admin of the storage account the file was originally uploaded to
- URL: The Shadow Drive URL of the file you're requesting to delete