The tool works in Mac/Linux/Windows platform and is distributed using NPM.
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.1/install.sh | bash
source ~/.bashrc
nvm install 18
npm i -g @techgreedy/singularity
If you are using a root user, you may encounter some permission error during installation. If so, use below commands to work around:
chown -R $(whoami) ~/
npm config set unsafe-perm true
npm config set user 0
The tool works as a daemon service running in the background while providing the CLI to interact with the service. To initialize the service repository:
export SINGULARITY_PATH=/the/path/to/the/repo
singularity init
A default config.toml
will be copied over to the repo. By default, it will enable all modules with reasonable settings.
Now you may Start the daemon service by running
singularity daemon
The data preparation module will scan and convert a local folder recursively into CAR files ready to be onboarded to Filecoin Network.
You need to specify three arguments - the name of the dataset, the path of the dataset and the output directory for CAR files.
singularity prep create MyData ~/dataset/folder ~/outDir
You can then check the progress of deal preparation by running
singularity prep list
singularity prep status MyData
To look into what each CAR file is composed of, you can run
singularity prep generation-status --dataset MyData <index>
You can also pause, resume or retry the scanning or generation jobs using
singularity prep pause
singularity prep resume
singularity prep retry
The easiest way to distribute CAR file to storage providers is via an HTTP server. You can set it up with nginx
:
sudo apt install nginx
Edit /etc/nginx/sites-available/default
and add below lines
server {
...
location / {
root /home/user/outDir;
}
...
}
You need to hand pick storage providers by yourself. A good place to find them is Filecoin Slack channel, ESPA Slack channel.
Most storage providers today are interested in taking verified deals, so you need to familiar yourself with Filecoin Plus. You can get some small amount of datacap in Filecoin Plus Registry.
Reference: Lite node
Download lotus binary from lotus release page
Start lite-node using below command
FULLNODE_API_INFO="wss://api.chain.love" lotus daemon --lite
Import your wallet key into lotus lite node
lotus wallet import
Check if the wallet address has been successfully imported, then you should be able to make deals using your imported wallet address
lotus wallet list
If you are customizing the LOTUS_PATH
,
you need to make sure the singularity daemon uses the same environment variable.
Since we are doing this for the first time, we'd like to only start with a few deals to test the flow. The below command sends out 10 deals from 'MyData' dataset to storage provider 'f01111'. The client address is the wallet address that you'd like to propose deals from.
# singularity repl start -m <n> <dataset_id> <storage_providers> <client_address>
singularity repl start -m 10 MyData f01111 f1...
On the storage provider side, they can use auto-import.sh to import those deals automatically. Of course you'll have to tell them where to download those CAR files.
If the storage provider is using boost market node and you've already setup your HTTP server, you can add the HTTP link prefix in the below command so the boost market node will take care of the file download.
singularity repl start -m 10 -u "http://my.datset.org/car/" MyData f01111 f1...
Once everything works smoothly on both side, you can start making deals automatically with to a speed agreed by both parties, i.e.
singularity repl start -m 10 -c '0 * * * *' -x 1000 -xp 100 MyData f01111 f1...
This command creates a schedule to send 10 deals each hour for up to 1000 deals in total with up to 100 pending deals.
You can also setup a Deal Making API to grant full control of deal making speed to storage providers. See Deal Making API for more details.
Retrieval is as simple as ipfs get <RootCid>/path/to/file/or/folder
.
You can check the RootCid
from the result of singularity prep list
.
Note that the storage providers need to setup booster-bitswap and you'll need to use ipfs version 0.18.0 or above to make this to work.
Read more documentation and configuration at README.md
Create a bug report or request a feature