Client-side SDKs
At a high-level, you can use Privy’s client-side SDKs’ utility functions to sign requests like so:1
Construct your signature payload
Determine the request you intend to make to the Privy API and format it into the required
signature payload, including request headers, method, body, URL, etc.
2
Sign the request
Next, sign the payload using the SDK’s
generateAuthorizationSignature
method.3
Send the request payload and signature to your backend
Make a request to your server, including both the request payload and signature from step (1).
Your backend will proxy this request with the signature to Privy’s REST API.
4
Send the request to the Privy API
From your server, make a request to Privy’s REST API with your desired request payload. Include
the signature in the
privy-authorization-signature
header of the request.1. Construct and sign your request
Given your desired request to the Privy API, build a JSON payload with the following fields. Your application will sign this entire payload to authorize the request to the Privy API.Field | Type | Description | |||
---|---|---|---|---|---|
version | 1 | Authorization signature version. Currently, 1 is the only version. | |||
method | 'POST' | 'PUT' | 'PATCH' | 'DELETE' | HTTP method for the request. Signatures are not required on 'GET' requests. | |||
url | string | The full URL for the request. Should not include a trailing slash. | |||
body | JSON | JSON body for the request. | |||
headers | JSON | JSON object containing any Privy-specific headers, e.g. those that are prefixed with 'privy-' . This should not include any other headers, such as authentication headers, content-type , or trace headers. | |||
headers['privy-app-id'] | string | Privy app ID header (required). | |||
headers['privy-idempotency-key'] | string | Privy idempotency key header (optional). If the request does not contain an idempotency key, leave this field out of the payload. |
personal_sign
RPC request like so:
2. Sign your request
Next, use the React or React Native SDKs’generateAuthorizationSignature
method from the useAuthorizationSignature
hook to sign the request. Pass the payload from step (1) as a parameter to this method.
The method will sign the request with the current authenticated user’s signing key, and return a Promise
for the base64-encoded signature.
3. Send the request and signature to your backend
Next, make a request from your frontend to your backend including the request you intend to make to the Privy API and the corresponding signature from step (2). Your backend will proxy this request to the Privy API.4. Send the request to the Privy API
Finally, make your request to the Privy API and include the signature in theprivy-authorization-signature
header for your request. As an example, in NodeJS, you can make the request like so:
Server-side SDKs
Privy’s server SDKs offer two utilities for signing requests:- Formatting requests for authorization signatures. This accepts your desired request to the Privy API and formats it into the required signature payload to be signed.
- This utility is particularly helpful if your application signs requests via a separate service, e.g. an isolated KMS. Your primary server can format your request and generate the signature payload and call out to your signing service with the payload.
- Generating authorization signatures. This accepts a formatted signature payload and signs it with your provided signing key.
- This utility is particularly useful within a specific signing service. Within your signing service, you can import this function and use it to sign requests, and return the signature to your primary service.
Constructing your input
Both the formatting and signing functions of Privy’s SDKs require a JSON input with the following fields:Field | Type | Description | |||
---|---|---|---|---|---|
version | 1 | Authorization signature version. Currently, 1 is the only version. | |||
method | 'POST' | 'PUT' | 'PATCH' | 'DELETE' | HTTP method for the request. Signatures are not required on 'GET' requests. | |||
url | string | The full URL for the request. Should not include a trailing slash. | |||
body | JSON | JSON body for the request. | |||
headers | JSON | JSON object containing any Privy-specific headers, e.g. those that are prefixed with 'privy-' . This should not include any other headers, such as authentication headers, content-type , or trace headers. | |||
headers['privy-app-id'] | string | Privy app ID header (required). | |||
headers['privy-idempotency-key'] | string | Privy idempotency key header (optional). If the request does not contain an idempotency key, leave this field out of the payload. |
Formatting requests
Use the SDK’s formatting function to generate your signature payload. As a parameter to this function, pass the JSON object as defined above.Signing requests
To directly produce a signature over a request, use the SDK’s generate authorization signature method. As a parameter to this method, pass the JSON object as defined above.privy-authorization-signature
header when making the request to the Privy API.