Skip to main content

About the Swan API

Overview

Swan uses a GraphQL API, explained in more detail on About GraphQL.

With Swan's API, you can request data and perform actions on your accounts, cards, transactions, and more. In this communication process, the API consumer asks Swan to execute operations and Swan responds.

This sequence diagram shows the most basic interactions between Swan's API, your users, and you. Note that the flow changes when webhooks are involved.

Environments

Swan hosts two environments: Live and Sandbox. They are completely separate with different endpoints. This means that access tokens, user credentials, URLs, and more, won't work between environments. Projects are also environment-dependent.

In short, test in Sandbox, build in Live—and remember, you can't move anything between the two.

Calling the API

Endpoints

NameEndpoint
Server OAuth 2.0https://oauth.swan.io/oauth2
Sandboxhttps://api.swan.io/sandbox-partner/graphql
Sandbox (Testing API)https://api.swan.io/sandbox-partner-admin/graphql
Livehttps://api.swan.io/live-partner/graphql

Rate limiting

Swan imposes rate limits on the endpoints to protect the API.

The default limit for each IP is 2,000 requests every 5 minutes. If you send over 2,000 requests for a single endpoint, the API returns an HTTP 429 Too Many Requests error. This limit applies to all endpoints.

If you need to increase the rate limits for your use case, request it through email: integration@swan.io.

Sandbox operation limits

To keep the Sandbox secure, Swan enforces the following limits per operation:

  • Complexity: 1,000 fields per operation
  • Depth: 15 nested fields per operation
  • Concurrency: 5 top-level fields per operation (top-level fields are often referred to as queries and mutations)

If your operation exceeds any of these limits, the API returns an HTTP 400 Bad Request error. Call the API again, making sure the complexity, depth, and concurrency of your operation respect the maximum limits.

Backend communication

Swan is designed to communicate between the Swan backend and yours. For security reasons, Swan doesn't allow API calls originating from a frontend application; all calls must come from the backend.

If you try to call the API from the frontend, you'll get a Cross-Origin Resource Sharing (CORS) error.

Using cURL

You can test the Swan API using cURL or any other HTTP client.

The following example is a query to get the IDs and IBANs of all the accounts in your project. Replace $YOUR_ACCESS_TOKEN with a valid user or project access token before sending your request.

Request
curl -X POST https://api.swan.io/sandbox-partner/graphql \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer $YOUR_ACCESS_TOKEN' \
-d '{"query":"query MyQuery{ accounts { edges { node { id IBAN } } } }"}'
Response
{
"data": {
"accounts": {
"edges": [
{
"node": {
"id": "$YOUR_ID",
"IBAN": "$YOUR_IBAN"
}
}
]
}
}
}

Time-to-live

Swan's Partner Dashboard and the Web Banking user interface each have a time-to-live (TTL) after which the session is discontinued automatically.

  • Dashboard: 72 hours; sessions refresh every time you call the API.
  • Web Banking: 5 minutes; session tokens refresh as long as the page stays open.

Troubleshooting

If you experience an issue or a bug working with Swan's API, complete the following steps:

  1. Check the status page to see if there's planned maintenance or an outage that could impact services.
  2. Search the documentation with keywords about your specific problem. It could be an expected behavior or something else explained in the docs.
  3. Otherwise, submit a ticket through your Dashboard, or send an email to integration@swan.io.