Delta is a deal-making service that enables users to make deals with Storage Providers. It is an application that allows users to upload files to the Filecoin network and get them stored by Storage Providers.
In this section, we will walk you through the steps to use a Delta node to make deals.
If you are looking for a running Delta node, you can use node.delta.store
.
If you want to stand up your own node, you can follow the instructions in this document.
In order to create a successful deal, Delta requires the following information metadata
request:
API_KEY
. This is used to authenticate the request. This is attached to the Authentication Header of the request.- The content to be stored or the piece-commitment of the content.
data file or cid
: The content to be stored. This can be a file or a directory.piece-commitment
: The piece-commitment of the content. This is the pre-computed piece cid, piece size (padded and unpadded) and file size.
- The
miner
to store the content.- If you don't have a miner, you can use the following to get a miner:
- run the SP miner selection cli tool
./delta sp selection --size-in-bytes=34359738368
. Get theaddress
field from the response. - run the SP miner selection api
curl --location --request GET 'https://simple-sp-selection.onrender.com/api/providers?size_bytes=34359738368'
, get theaddress
field from the response. - check out
https://data.storage.market/api/providers
to get a list of miners.
- run the SP miner selection cli tool
- If you don't have a miner, you can use the following to get a miner:
- The connection mode to use to make the deal. This is either
e2e
orimport
.e2e
mode (online deal) is used to make deals with miners that support thee2e
connection mode.import
mode (offline) is used to make deals with miners that support theimport
connection mode.
Here's the complete structure of the metadata
request.
{
"cid": "bafybeidty2dovweduzsne3kkeeg3tllvxd6nc2ifh6ztexvy4krc5pe7om",
"miner":"f01963614",
"wallet": {
"address":"f1mmb3lx7lnzkwsvhridvpugnuzo4mq2xjmawvnfi"
},
"piece_commitment": {
"piece_cid": "baga6ea4seaqhfvwbdypebhffobtxjyp4gunwgwy2ydanlvbe6uizm5hlccxqmeq",
"padded_piece_size": 4294967296
},
"connection_mode": "import",
"size": 2500366291,
"remove_unsealed_copy":true,
"skip_ipni_announce": true
}
Create a deal for a content by sending a POST
request to the /api/v1/deal/end-to-end
endpoint. The data
request is the content to be stored. The metadata
request is the information required to make the deal.
curl --location --request POST 'http://localhost:1414/api/v1/deal/end-to-end' \
--header 'Authorization: Bearer [API_KEY]' \
--form 'data=@"my-file"' \
--form 'metadata="{\"miner\":\"f01963614\",\"connection_mode\":\"e2e\"}"'
A few things to note here:
- The
data
request is the content to be stored. This can be a file or a directory. - The
metadata
request is the information required to make the deal. This is a JSON object. At minimum, it should contain theminer
andconnection_mode
fields. Theminer
field is the miner to store the content. Theconnection_mode
field is the connection mode to use to make the deal. This is eithere2e
orimport
. - If no
wallet
is specified, Delta will use the default wallet that it generated when it was started.
The response will look like this:
{
"status": "success",
"message": "Deal request received. Please take note of the content_id. You can use the content_id to check the status of the deal.",
"content_id": 1,
"deal_request_meta": {
"cid": "bafybeib6l6odanq5zrspbw4c7fys4jspshgwzuuhotnpljsivhdythw6xu",
"miner": "f02031042",
"wallet": {
"address": "f1mmb3lx7lnzkwsvhridvpugnuzo4mq2xjmawvnfi"
},
"piece_commitment": {},
"connection_mode": "e2e"
}
}
Take note of the content_id
field. This is the id of the content that was uploaded. This is used to get the status of the deal.
Create a deal for a pre-computed piece-commitment by sending a POST
request to the /api/v1/deal/imports
endpoint. The metadata
request is the information required to make the deal.
curl --location --request POST 'http://localhost:1414/api/v1/deal/imports' \
--header 'Authorization: Bearer [API_KEY]' \
--header 'Content-Type: application/json' \
--data-raw '[{
"cid": "bafybeidty2dovweduzsne3kkeeg3tllvxd6nc2ifh6ztexvy4krc5pe7om",
"miner":"f01963614",
"piece_commitment": {
"piece_cid": "baga6ea4seaqhfvwbdypebhffobtxjyp4gunwgwy2ydanlvbe6uizm5hlccxqmeq",
"padded_piece_size": 4294967296
},
"connection_mode": "import",
"size": 2500366291,
"remove_unsealed_copy":true,
"skip_ipni_announce": true
}]'
A few things to note here:
- The
metadata
request is the information required to make the deal. This is a JSON array. Each element in the array is a JSON object. At minimum, it should contain theminer
,piece_commitment.piece_cid
,piece_commitment.padded_piece_size
,size
andconnection_mode
fields. - The
miner
field is the miner that will store the content.- If you don't have a miner, you can use the following:
- run the SP miner selection cli tool
./delta sp selection --size-in-bytes=34359738368
. Get theaddress
field from the response. - run the SP miner selection api
curl --location --request GET 'https://simple-sp-selection.onrender.com/api/providers?size_bytes=34359738368'
, get theaddress
field from the response. - check out
https://data.storage.market/api/providers
to get a list of miners.
- run the SP miner selection cli tool
- If you don't have a miner, you can use the following:
- The
piece_commitment
field is the piece-commitment of the content.- This is the pre-computed piece cid, piece size (padded and unpadded) and file size.
- The
connection_mode
field is the connection mode to use to make the deal. This is animport
.
The response will look like this:
[
{
"status": "success",
"message": "Deal request received. Please take note of the content_id. You can use the content_id to check the status of the deal.",
"content_id": 1,
"deal_request_meta": {
"cid": "bafybeidylyizmuhqny6dj5vblzokmrmgyq5tocssps3nw3g22dnlty7bhy",
"miner": "f01963614",
"duration_in_days": 537,
"piece_commitment": {
"piece_cid": "baga6ea4seaqblmkqfesvijszk34r3j6oairnl4fhi2ehamt7f3knn3gwkyylmlq",
"padded_piece_size": 34359738368
},
"connection_mode": "import",
"size": 18010019221,
"start_epoch": 2730480,
"start_epoch_at_days": 3,
"remove_unsealed_copy": true,
"skip_ipni_announce": true
}
}
]
Take note of the content_id
field. This is the id of the content that was uploaded. This is used to get the status of the deal.
The wallet is one of the most important aspect of making a filecoin and the wallet holds the FIL and DataCap that's going to be used to transaction with the network.
Registering a wallet to a Delta node means that the wallet owner is TRUSTING the delta node to hold it's keys. This is a very important step and should be done with care.
To register a wallet to a live Delta node, we can use the /admin/wallet/register-hex
endpoint. This endpoint is only available on the admin port.
curl --location --request POST 'http://localhost:1414/admin/wallet/register-hex' \
--header 'Authorization: Bearer [API_KEY]' \
--header 'Content-Type: application/json' \
--data-raw '{"hex_key":"<HEX FROM LOTUS / BOOSTD WALLET EXPORT>"}'
The response will look like this:
{
"message": "Successfully imported a wallet address. Please take note of the following information.",
"wallet_addr": "f1mmb3lx7lnzkwsvhridvpugnuzo4mq2xjmawvnfi",
"wallet_uuid": "4d4589d0-c7a2-11ed-b245-9e0bf0c70138"
}
We can now use the wallet_addr
value to make a deal.
Once a wallet is registered, we can add a wallet
field to the metadata
request to make a deal using that wallet.
{
"cid": "bafybeidty2dovweduzsne3kkeeg3tllvxd6nc2ifh6ztexvy4krc5pe7om",
"miner":"f01963614",
"wallet": {
"address":"f1mmb3lx7lnzkwsvhridvpugnuzo4mq2xjmawvnfi"
},
"piece_commitment": {
"piece_cid": "baga6ea4seaqhfvwbdypebhffobtxjyp4gunwgwy2ydanlvbe6uizm5hlccxqmeq",
"padded_piece_size": 4294967296
},
"connection_mode": "import",
"size": 2500366291,
"remove_unsealed_copy":true,
"skip_ipni_announce": true
}
Now that you can access a live Delta node, you are now ready to make a deal. You can now go to the following guides:
If you to run your own Delta
node, go to getting started running a delta node.