Pinata Docs
Search…
Authentication
To connect to the Pinata API, you will need to generate Pinata API Keys. Visit the Pinata API Keys page to generate new keys.
When you click "New API Key" you will be prompted to select permissions and the number of uses for the key you generate. Admin privileges, as you might expect, have access to all API endpoints. If you'd like to specify specific endpoints, you can do so by expanding the endpoint's parent route and toggling on the permission.
By default, all keys have unlimited use. However, if you'd like to limit the number of times a key can be used, you can do so by setting the Max Uses field.
By setting a Key Name, you will be able to easily identify the key and its purpose.
Any key can have its access revoked by clicking the Revoke button. Once a key has been revoked, it can no longer be utilized for any purpose.

Important

When you generate your keys, you will see a modal with the Pinata API Key, Pinata API Secret, and the JWT.
Your "Pinata API Key" acts as your public key for our REST API, and your "Pinata Secret API Key" acts as the password for your public key. The JWT is an encoded mix of the two. Be sure to keep your secret key private.
For added customer security, these keys are encrypted on Pinata's side and will only ever be displayed once, so write them down. If you lose these values you'll need to revoke the key and create a new one.

Connecting to the Pinata API

The base URL for Pinata requests is: https://api.pinata.cloud
You have two ways of connecting to the Pinata API:
  • Bearer Authentication
  • Custom Headers
To use the bearer authentication model, you will need the JWT that is generated when creating API keys. This token can be used as an Authorization header for all your API requests in the following format:
1
"Authorization": "Bearer YOUR_JWT"
Copied!
get
https://api.pinata.cloud
/data/testAuthentication
Test your API keys and your ability to connect to the Pinata API.

Custom Headers

If not using bearer authentication, your API requests will need to include two headers:
1
pinata_api_key: (put your personal pinata api key here)
2
pinata_secret_api_key: (put your personal pinata secret api key here)
Copied!
get
https://api.pinata.cloud
/data/testAuthentication
Test your API keys and your ability to connect to the Pinata API.
Going forward, all examples will use the JWT Bearer Authentication format for simplicity.

Testing Authentication

Let's try connecting to the Pinata API via the data/testAuthentication endpoint (This endpoint requires an admin key to call).
cURL
Node.js
Python
Go
1
curl --location --request GET 'https://api.pinata.cloud/data/testAuthentication' \
2
--header 'Authorization: Bearer PINATA_JWT'
Copied!
1
var axios = require('axios');
2
3
var config = {
4
method: 'get',
5
url: 'https://api.pinata.cloud/data/testAuthentication',
6
headers: {
7
'Authorization': 'Bearer PINATA_JWT'
8
}
9
};
10
11
const res = await axios(config)
12
13
console.log(res.data);ava
Copied!
1
import requests
2
url = "https://api.pinata.cloud/data/testAuthentication"
3
payload={} headers = { 'Authorization': 'Bearer PINATA_JWT' }
4
response = requests.request("GET", url, headers=headers, data=payload)
5
print(response.text)
Copied!
1
package main
2
import ( "fmt" "net/http" "io/ioutil" )
3
func main() {
4
url := "https://api.pinata.cloud/data/testAuthentication" method := "GET"
5
client := &http.Client { } req, err := http.NewRequest(method, url, nil)
6
if err != nil { fmt.Println(err) return } req.Header.Add("Authorization", "Bearer PINATA_JWT")
7
res, err := client.Do(req) if err != nil { fmt.Println(err) return } defer res.Body.Close()
8
body, err := ioutil.ReadAll(res.Body) if err != nil { fmt.Println(err) return } fmt.Println(string(body)) }GoJavaScript with Axios example:
Copied!

We want your feedback!

Have a suggestion? Have a complaint? Confused about something in the documentation? Just want to say hi?
We want to make Pinata the best product available. That involves listening to our users and addressing their needs.
Send us an email at [email protected] and we'll see how we can help.
Last modified 1mo ago