title |
---|
Requesting & Using API Keys |
Authentication and authorization for the Skip API are managed via API keys.
This document covers:
- Why you should use an API key
- How to get your key set up
- How to use the key in your requests
Historically, we used the client_id
passed as a request parameter to identify and authenticate integrators. This system has been fully deprecated. If you're currently using client_id
, you should transition to using an API key.
(We're making this transition because client_id
didn't abide by best practices for security, and we could only attach limited functionality to it, since it was passed in the request body instead of a header.)
Technically, you can access most of the basic functionality of the Skip API without an API key. But there are numerous benefits to authenticating yourself with a key:
- No rate limit: Integrators that do not pass a valid API key in their requests will be subject to a restrictive global rate limit, shared with all other unauthenticated users.
- Improved fee revenue share pricing: Unauthenticated integrators will be subject to a 25% revenue share on their fee revenue by default. Authenticated integrators who use API keys will be subject to a cheaper 20% revenue share by default.
- Access to privileged features: Integrators who authenticate with an API key will receive access to premium features that we cannot offer to the general public (e.g. Gas estimation APIs, universal balance query APIs, etc...)
- Metrics on your volume and revenue: Authenticated integrators will receive access to monthly statistics regarding their total swap and transfer volume and the amount of fee revenue they've earned. They will also receive transaction data for taxes annually.
Open a support ticket on our Discord and tell our customer support that you'd like an API key. **
Please provide the following information in your request to help us get to know your project:
- Your name (or pseudo-anon name) and contact info (ideally Telegram, but possibly Email, Signal, etc...)
- Your project name
- A brief, 1-2 sentence description of your project
The customer support team member at Skip will establish an official channel of communication between Skip and your project (e.g. an email thread or a telegram group etc...).
You should store the API key immediately when you create it. We do not store your raw API key in our server for security reasons, so we will not be able to access it for you if you lose it.
It is important to keep your API key private: Anyone with your API key can make requests to the Skip API as you, getting access to your rate limit, privileged features, and affecting your revenue and volume statistics.
You should pass your API key in every call to the Skip API using the authorization
HTTP header.
For example:
curl -X 'POST' \
'https://api.skip.money/v2/fungible/route' \
-H 'accept: application/json' \
-H 'authorization: <YOUR API KEY>' \
-H 'Content-Type: application/json' \
-d '{
"amount_in": "1000000",
"source_asset_denom": "uusdc",
"source_asset_chain_id": "axelar-dojo-1",
"dest_asset_denom": "uatom",
"dest_asset_chain_id": "cosmoshub-4",
"cumulative_affiliate_fee_bps": "0",
"allow_multi_tx": true,
"client_id": "skip-api-docs"
}'
For users of the @skip-router
Typescript library, the apiKey
can be included in the SkipRouterOptions
object when constructing a SkipRouter
. After you include it in construction, the SkipRouter
will handle passing it in the authorization
header of all requests.
For example:
import { SkipRouter, SKIP_API_URL } from "@skip-router/core";
const client = new SkipRouter({
apiKey: <YOUR API KEY>,
});
To keep your API key secure and private, we recommend that you proxy the API requests from the frontend to your own backend--where you can add your API key in the header before forwarding the request to Skip API.
The snippets below show you how to use Next.js/Vercel for this kind of proxying. It only takes a moment to set up.
pages/api/skip/[email protected]
// This handler runs server-side in Vercel and receive requests from the frontend
// sent to APP_URL/api/skip
import type { NextApiRequest } from "next";
import { PageConfig } from "next";
import { API_URL } from "@/constants/api";
export const config: PageConfig = {
api: {
externalResolver: true,
bodyParser: false,
},
runtime: "edge",
};
export default async function handler(req: NextApiRequest) {
try {
const splitter = "/api/skip/";
const [...args] = req.url!.split(splitter).pop()!.split("/");
const uri = [API_URL, ...args].join("/");
const headers = new Headers();
if (process.env.SKIP_API_KEY) {
headers.set("authorization", process.env.SKIP_API_KEY);
}
return fetch(uri, {
body: req.body,
method: req.method,
headers,
});
} catch (error) {
const data = JSON.stringify({ error });
return new Response(data, { status: 500 });
}
}
// This config maps the requests to APP_URL/api/skip to the handler we just defined
rewrites: async () => [
{
source: "/api/skip/(.*)",
destination: "/api/skip/handler",
},
],
// other config...
// This configures your router to make requests to your proxy service instead of
// the standard Skip API backend directly
import { SkipRouter } from "@skip-router/core";
const appUrl =
process.env.NEXT_PUBLIC_VERCEL_ENV === "preview" || process.env.NEXT_PUBLIC_VERCEL_ENV === "staging"
? typeof window !== "undefined"
? `https://${window.location.hostname}`
: process.env.NEXT_PUBLIC_VERCEL_URL
: "https://<YOUR APP URL>";
const client = new SkipRouter({
// you don't need to pass apiKey since you already have it in your proxy handler
apiURL: `${appUrl}/api/skip`,
});
// These are environment variables you set in Vercel
// to store your API key securely in the backend
SKIP_API_KEY=<YOUR API KEY>
Just return to your official communication channel with Skip (probably a Telegram channel) and request the data. We will be able to share monthly reports. Eventually, we will create a customer portal and dashboards, so you'll have access to all the data you need continuously in a self-service manner.
**Want to help us get better? Have questions or feedback?**You can reach us easily by joining our Discord and grabbing the "Skip API Developer" role.