Storing a file
Storage Client
Alice is a Storage User and wants to store an image of her lovely Polkadot logo polkadot.svg
in the Polka Storage parachain.
Alice knows that she needs to prepare an image for storage and get its CID. To do so, she first converts it into a CARv2 archive and gets the piece cid.
ð§ Currently, the maximum supported piece size is 2048 bytes!
$ mater-cli convert -q --overwrite polkadot.svg polkadot.car
bafkreihoxd7eg2domoh2fxqae35t7ihbonyzcdzh5baevxzrzkaakevuvy
$ polka-storage-provider-client proofs commp polkadot.car
{
"cid": "baga6ea4seaqabpfwrqjcwrb4pxmo2d3dyrgj24kt4vqqqcbjoph4flpj2e5lyoq",
"size": 2048
}
Proposing a deal
Afterwards, it's time to propose a deal, currently â i.e. while the network isn't live â any deals will be accepted by Charlie (the Storage Provider).
Alice fills out the deal form according to a JSON template (polka-logo-deal.json
):
{
"piece_cid": "baga6ea4seaqabpfwrqjcwrb4pxmo2d3dyrgj24kt4vqqqcbjoph4flpj2e5lyoq",
"piece_size": 2048,
"client": "5GrwvaEF5zXb26Fz9rcQpDWS57CtERHpNehXCPcNoHGKutQY",
"provider": "5FLSigC9HGRKVhB9FiEo4Y3koPsNmBmLJbpXg2mp1hXcS59Y",
"label": "",
"start_block": 200,
"end_block": 250,
"storage_price_per_block": 500,
"provider_collateral": 1000100200,
"state": "Published"
}
piece_cid
â is thecid
field from the previous step, where she calculated the piece commitment. It uniquely identifies the piece.piece_size
â is thesize
field from the previous step, where she calculated the piece commitment. It is the size of the processed piece, not the original file!client
â is the client's (i.e. the reader's) public key, encoded in bs58 format. For more information on how to generate your own keypair, read the Polka Storage Provider CLI/client
/wallet
.provider
â is the storage provider's public key, encoded in bs58 format. If you don't know your storage provider's public key, you can query it usingpolka-storage-provider-client
'sinfo
command.label
â is an arbitrary string to be associated with the deal.start_block
â is the deal's start block, it MUST be positive and lower thanend_block
.end_block
â is the deal's end block, it must be positive and larger thanstart_block
.storage_price_per_block
â the storage price over the duration of a single block â e.g. if your deal is 20 blocks long, it will cost20 * storage_price_per_block
in total.provider_collateral
â the price to pay by the storage provider if they fail to uphold the deal.state
â the deal state, onlyPublished
is accepted.
The start_block
and end_block
fields may need to be changed depending on the current block you are on.
The values 200
and 250
are solely for demonstration purposes and we encourage you to try other values!
Variables subject to change depending on the chains state
start_block
- The start block must be after the current block. Check the polka storage node logs or use the polkadot.js UI for the current block and adjust the start_block value accordingly.
end_block
- The end block must be between 50 and 1800 blocks after start_block
.
See the Storage Provider Constants and the Market Constant for more information about the configuration variables
When the deal is ready, she proposes it:
$ polka-storage-provider-client propose-deal --rpc-server-url "http://localhost:8000" "@polka-logo-deal.json"
bagaaierab543mpropvi5mnmtptytnnlbr2j7vea7lowcugrqt7epanybw7ta
The storage provider replied with a CID â the CID of the deal Alice just sent â she needs to keep this CID for the next steps!
Once the server has replied with the CID, she's ready to upload the file.
This can be done with just any tool that can upload a file over HTTP.
The server supports both multipart forms and PUT
.
$ curl --upload-file "polkadot.svg" "http://localhost:8001/upload/bagaaierab543mpropvi5mnmtptytnnlbr2j7vea7lowcugrqt7epanybw7ta"
baga6ea4seaqabpfwrqjcwrb4pxmo2d3dyrgj24kt4vqqqcbjoph4flpj2e5lyoq
Publishing the deal
Before Alice publishes a deal, she must ensure that she has the necessary funds available in the market escrow, to be able to pay for the deal:
$ storagext-cli --sr25519-key "//Alice" market add-balance 25000000000
[0x6489âĶa2c0] Balance Added: { account: 5GrwvaEF5zXb26Fz9rcQpDWS57CtERHpNehXCPcNoHGKutQY, amount: 25000000000 }
Finally, she can publish the deal by submitting her deal proposal along with your signature to the storage provider.
To sign her deal proposal she runs:
$ polka-storage-provider-client sign-deal --sr25519-key "//Alice" @polka-logo-deal.json
{
"deal_proposal": {
"piece_cid": "baga6ea4seaqabpfwrqjcwrb4pxmo2d3dyrgj24kt4vqqqcbjoph4flpj2e5lyoq",
"piece_size": 2048,
"client": "5GrwvaEF5zXb26Fz9rcQpDWS57CtERHpNehXCPcNoHGKutQY",
"provider": "5FLSigC9HGRKVhB9FiEo4Y3koPsNmBmLJbpXg2mp1hXcS59Y",
"label": "",
"start_block": 200,
"end_block": 250,
"storage_price_per_block": 500,
"provider_collateral": 1000100200,
"state": "Published"
},
"client_signature": {
"Sr25519": "7eb8597441711984b7352bd4a118eac57341296724c20d98a76ff8d01ee64038f6a9881e492a98c3a190e7b600a8313d72e9f0edacb3e6df6b0b4507dabb9580"
}
}
Hint: you can write the following command to just get the file:
polka-storage-provider-client sign-deal --sr25519-key "//Alice" @polka-logo-deal.json > signed-logo-deal.json
All that's left is to publish the deal:
$ polka-storage-provider-client publish-deal --rpc-server-url "http://localhost:8000" @signed-logo-deal.json
Successfully published deal of id: 0
On Alice's side, that's it!
Note that you must sign and submit the deals before the
start_block
!Currently, the storage provider does not reject deal proposals on the basis of how early or late they are, however, this may change! â ïļ â for example, if a storage provider knows that they won't have enough time to process your file for proof submission, they may refuse your proposal on the basis that if they accept it, they may fail the deadline.
Additional Notes
- As other parts of this project, file retrieval is actively being worked on! ð§
- Files stored in storage providers are public, as such, we suggest you encrypt your files. While file encryption is a broad enough topic, if you not sure about which tools to use, we suggest you keep it simple by compressing your file in a format such as 7zip and using its encryption features. If 7zip doesn't cut it, you may want to take a look into age or VeraCrypt.