Welcome to the Pinata Go CLI! This is still in active development so please let us know if you have any questions! :)
Note
If you are on Windows please use WSL when installing. If you get an error that it was not able to resolve the github host run git config --global --unset http.proxy
The easiest way to install is to copy and paste this script into your terminal
curl -fsSL https://cli.pinata.cloud/install-web3 | bash
To build and instal from source make sure you have Go installed on your computer and the following command returns a version:
go version
Then paste and run the following into your terminal:
git clone https://github.com/PinataCloud/pinata-go-cli && cd pinata-go-cli && go install .
As versions are released you can visit the Releases page and download the appropriate binary for your system, them move it into your bin folder.
For example, this is how I install the CLI for my Raspberry Pi
wget https://github.com/PinataCloud/pinata-go-cli/releases/download/v0.1.2/pinata-go-cli_Linux_arm64.tar.gz
tar -xzf files-cli_Linux_arm64.tar.gz
sudo mv pinata /usr/bin
The Pinata CLI is equipped with the majortiry of features on the Pinata API.
With the CLI installed you will first need to authenticate it with your Pinata JWT
pinata-web3 auth <your-jwt>
After authentication you can now upload using the upload
command or u
for short, then pass in the path to the file or folder you want to upload.
pinata-web3 upload ~/Pictures/somefolder/image.png
The following flags are also available to set the name or CID version of the upload.
--version value, -v value Set desired CID version to either 0 or 1. Default is 1. (default: 1)
--name value, -n value Add a name for the file you are uploading. By default it will use the filename on your system. (default: "nil")
--cid-only Use if you only want the CID returned after an upload (default: false)
You can list files with the list
command or the alias l
. The results are printed in raw JSON to help increase composability.
pinata-web3 list
By default it will retrieve the 10 latest files, but with the flags below you can get more results or fine tune your search.
--cid value, -c value Search files by CID (default: "null")
--amount value, -a value The number of files you would like to return, default 10 max 1000 (default: "10")
--name value, -n value The name of the file (default: "null")
--status value, -s value Status of the file. Options are 'pinned', 'unpinned', or 'all'. Default: 'pinned' (default: "pinned")
--pageOffset value, -p value Allows you to paginate through files. If your file amount is 10, then you could set the pageOffset to '10' to see the next 10 files. (default: "null")
If you ever need to you can delete a file by CID using the delete
command or alias d
followed by the file CID.
pinata-web3 delete QmVLwvmGehsrNEvhcCnnsw5RQNseohgEkFNN1848zNzdng
Separate from the upload
command which uploads files from your machine to Pinata, you can also pin a file already on the IPFS network by using the pin
command or alias p
followed by the CID. This will start a pin by CID request which will go into a queue.
pinata-web3 pin QmVLwvmGehsrNEvhcCnnsw5RQNseohgEkFNN1848zNzdng
To check the queue use the request
command.
As mentioned in the pin
command, when you submit an existing CID on IPFS to be pinned to your Pinata account, it goes into a request queue. From here it will go through multiple status'. For more info on these please consult the documentation.
pinata-web3 requests
You can use flags to help filter requests as well.
--cid value, -c value Search pin by CID requests by CID (default: "null")
--status value, -s value Search by status for pin by CID requests. See https://docs.pinata.cloud/reference/get_pinning-pinjobs for more info. (default: "null")
--pageOffset value, -p value Allows you to paginate through requests by number of requests. (default: "null")
If you have any questions please feel free to reach out to us!