Gemini Crypto Exchange Logo
Authentication

OAuth 2.0

In addition to the API key methods described in private APIs, Gemini supports OAuth 2.0 flows and adheres to the OAuth 2.0 Standards. Both authorization code and implicit OAuth flows are supported, however use of authorization code flows is strongly recommended for most use cases because of enhanced security and the ability to support features such as refresh tokens.

The first step in using Gemini OAuth is to create a new OAuth application which you can do via API Settings. You will be asked for some basic information including a name, description, background information, logo, and the scopes that you are requesting access to. We will provide you a client_id and a client_secret which are used to identify and secure your app.

Once your app is registered it will be reviewed by Gemini, and then set live for use. You may also follow the same process in our Sandbox Environment to build a test integration.

Please email trading@gemini.com with any questions. We will provide you a client_id and a client_secret. Your client_id will be used in all your requests to identify your app, and client_secret must be sent in all POST requests

Instead of API Keys OAuth 2.0 uses access tokens and, if using the authorization code grant flow, refresh tokens. Access tokens are short-lived (24 hour expiration) and are used in Gemini API calls while refresh tokens don't expire and are used solely to generate new access tokens.

Authorization Code Grant Flow

The OAuth 2.0 authorization code grant flow involves the user being directed to an authorization server which returns an authorization code that may then be exchanged for access and refresh tokens. Access tokens are short-lived (24 hour expiration) and are used as authentication against Gemini APIs, while refresh tokens never expire and are used to regenerate access tokens.

Authorization Request

Users should first be redirected to Gemini to authorize access to your application. The user will be prompted to login using a Gemini OAuth window.

GET https://exchange.gemini.com/auth

Example authorization request:

GET https://exchange.gemini.com/auth?client_id=my_id&response_type=code&redirect_uri=www.example.com/redirect&state=82350325&scope=balances:read,orders:create

URL Parameters

ParameterTypeDescription
client_idstringUnique id of your application. This is provided in your API settings
response_typestringThe literal string "code"
redirect_uristringThe URL users should be returned to when they authorize. Note, this URL must be included in your list of approved redirect_uris in your app registration
statestringA random string that will be returned to you in the response.
scopestringA comma separated list of scopes corresponding to the access you're requesting for your application. Note, these scopes must be included in your list of scopes in your app registration

Authorization Response

Example redirect_uri response after user login

https://www.example.com/redirect?code=90123465-86ee-44ef-b4e3-835cc89bc8a3&state=82350325

On successful authorization Gemini will redirect your user to the redirect_uri you supplied with additional parameters code and state. The parameter state should match the state you provided, otherwise you should not trust the response. code is a temporary code which you will then use to obtain access and refresh tokens.

Authorization Token Request

Once you have received a code you can exchange it for access and refresh tokens.

POST https://exchange.gemini.com/auth/token

ParameterTypeDescription
client_idstringUnique id of your application. This is provided in your API settings
client_secretstringSecret of your application. This is provided when you first register an app in API settings
codestringThe code you received from the authorization request
redirect_uristringThis must match the redirect_uri provided in the authorization request
grant_typestringThe literal string "authorization_code"

Example Token Request

{
    "client_id": "my_id",
    "client_secret": "my_secret",
    "code": "90123465-86ee-44ef-b4e3-835cc89bc8a3",
    "redirect_uri": "www.example.com/redirect",
    "grant_type": "authorization_code"
}
json

Authorization Token Response

FieldTypeDescription
access_tokenstringA short-lived token to use in API call authentication. Is valid until the expires_in time reaches 0
refresh_tokenstringA refresh token to be used to generate new access tokens
token_typestringThe literal string "bearer"
scopestringThe scopes the access token will have access to
expires_inintegerThe lifetime in seconds of the access token, as measured in seconds from the current time

Example Token Response

{
    "access_token": "d9af2411-3e85-41bb-89f4-cf53750f04df",
    "refresh_token": "215c5a89-6df7-457b-ba0b-70695da8c91f",
    "token_type": "Bearer",
    "scope": "balances:read,orders:create",
    "expires_in": 86399
}
json

Using Refresh Tokens

The access token you receive will be relatively short-lived (default 24 hours). Once an access token has expired you can use your refresh token to generate a new access token. Refresh tokens never expire, however they are one-time use only as your request for a new access token will also return a new refresh token.

Getting a new access token is similar to getting the initial access and refresh tokens with slightly different parameters

Refresh Token Request

POST https://exchange.gemini.com/auth/token

Example Token Request

{
    "client_id": "my_id",
    "client_secret": "my_secret",
    "refresh_token": "215c5a89-6df7-457b-ba0b-70695da8c91f",
    "grant_type":"refresh_token"
}
json
ParameterTypeDescription
client_idstringUnique id of your application
client_secretstringSecret of your application. This is provided when you first register an app in API settings
refresh_tokenstringYour refresh token
grant_typestringThe literal string "refresh_token"

Refresh Token Response

The response is the same as the initial token response – it will contain a new access token to query APIs and a new refresh token for when the access token expires.

ParameterTypeDescription
access_tokenstringA short-lived token to use in API call authentication
refresh_tokenstringA refresh token to be used to generate new access tokens
token_typestringThe literal string "bearer"
scopestringThe scopes the access token will have access to
expires_inintegerThe lifetime in seconds of the access token, as measured in seconds from the current time

Example Token Response

{
  "access_token": "c5e9459d-dc6f-4567-bce4-050ec965f22e",
  "expires_in": 86399,
  "scope": "balances:read,orders:create",
  "refresh_token": "ce0f14af-74dd-4767-a4e7-286e98b944c1",
  "token_type": "Bearer"
}
json

Implicit Grant Flow

In addition to the authorization code flow, Gemini also supports the OAuth 2.0 implicit grant flow. This is a simplified version of the authorization code flow and is not recommended for most applications. This OAuth flow is not available by default, please reach out to trading@gemini.com to request access to the implicit grant flow.

When the access_token expires you must request a new one using either the implicit flow or authorization code flow.

Send request to following URL with URL parameters

GET https://exchange.gemini.com/auth

First direct users to Gemini like the example below

GET https://exchange.gemini.com/auth?response_type=token&client_id=my_id&redirect_uri=https://example.com/redirect?scope=Trader&state=7j87

URL Parameters

ParameterTypeDescription
response_typestringThe literal string "token"
client_idstringUnique id of your application. This is provided in your API settings
redirect_uristringThe URL users should be returned to when they authorize. Note, this URL must be included in your list of approved redirect_uris in your app registration
statestringA random string that will be returned to you in the response.
scopestringA comma separated list of scopes corresponding to the access you're requesting for your application. Note, these scopes must be included in your list of scopes in your app registration

Users will then be sent to Gemini login with their credentials. Once they do they will be sent to the redirect_uri provided.

Authorization Response (URL Parameters)

Example redirect_uri response after user login

https://example.com/redirect#access_token=3b7661f0-f156-498a-ad17-0fa4025ec907&state=7j87&token_type=bearer&scope=Trader&expires_in=83534

On successful authorization Gemini will redirect your user to the redirect_uri you supplied with additional parameters code and state. The parameter state should match the state you provided, otherwise you should not trust the response. access_token is the access token which you will use to make API calls on behalf of the user.

FieldTypeDescription
access_tokenstringA short-lived token to use in API call authentication. Is valid until the expires_in time reaches 0
token_typestringThe literal string "bearer"
scopestringThe scopes the access token will have access to
expires_inintegerThe lifetime in seconds of the access token, as measured in seconds from the current time

Using Access Tokens

Once you have an access token you can use it to call any Gemini API.

Most of the examples for the private APIs in these docs make use of API keys and corresponding headers, to use an access token simply update your header:

HeaderDescription
AuthorizationThe literal string "Bearer " concatenated to your temporary access_token
X-GEMINI-PAYLOADThe base64-encoded JSON payload (the payloads on OAuth do not require a nonce)
import requests
import json
import base64

url = "https://api.gemini.com/v1/mytrades"
access_token = "Bearer d9af2411-3e85-41bb-89f4-cf53750f04df"

payload = {
    "request": "/v1/mytrades",
    "symbol": "btcusd"
}
encoded_payload = json.dumps(payload).encode()
b64 = base64.b64encode(encoded_payload)

request_headers = { 
    "Authorization": access_token,
    "X-GEMINI-PAYLOAD": b64
}

response = requests.post(url,
                        data=None,
                        headers=request_headers,
                        verify=False)

my_trades = response.json()
python
import requests
import json
import base64

url = "https://api.gemini.com/v1/orders/history"
access_token = "Bearer d9af2411-3e85-41bb-89f4-cf53750f04df"

payload = {
    "request": "/v1/orders/history",
    "symbol": "btcusd"
}
encoded_payload = json.dumps(payload).encode()
b64 = base64.b64encode(encoded_payload)

request_headers = { 
    "Authorization": access_token,
    "X-GEMINI-PAYLOAD": b64
}

response = requests.post(url,
                        data=None,
                        headers=request_headers,
                        verify=False)

my_orders = response.json()
python

OAuth Scopes

Gemini uses a role-based system for its API. All OAuth applications are limited to the scopes in the following chart:

EndpointURIScope
Get Deposit Addresses/v1/addresses/:networkaddresses:read, addresses:create
New Deposit Address/v1/deposit/:network/newAddressaddresses:create
List Approved Addresses/v1/approvedAddresses/account/:networkaddresses:read
Remove Approved Address/v1/approvedAddresses/:network/removeaddresses:create
Get Available Balances/v1/balancesbalances:read
Get Notional Balancesv1/notionalbalances/:currencybalances:read
Add A Bank/v1/payments/addbankbanks:create
Add A Bank CAD/v1/payments/addbank/cadbanks:create
View Payment Methods/v1/payments/methodsbanks:read, banks:create
New Clearing Order/v1/clearing/newclearing:create
Cancel Clearing Order/v1/clearing/cancelclearing:create
Confirm Clearing Order/v1/clearing/confirmclearing:create
Clearing Order Status/v1/clearing/statusclearing:read
Clearing Order List/v1/clearing/listclearing:read
Clearing Broker List/v1/clearing/broker/listclearing:read
Clearing Trades/v1/clearing/tradesclearing:read
Withdraw Crypto Funds/v1/withdraw/:currencycrypto:send
List Past Trades/v1/mytradeshistory:read
Get Orders History/v1/orders/historyhistory:read
Get Notional Volume/v1/notionalvolumehistory:read
Get Trade Volume/v1/tradevolumehistory:read
Transfers/v1/transfershistory:read
Custody Account Fees/v1/custodyaccountfeeshistory:read
Create New Order/v1/order/neworders:create
Cancel Order/v1/order/cancelorders:create
Cancel All Session Orders/v1/order/cancel/sessionorders:create
Cancel All Active Orders/v1/order/cancel/allorders:create
Wrap Order/v1/wrap/:symbolorders:create
Get Instant Quote/v1/instant/quoteorders:create
Execute Instant Order/v1/instant/executeorders:create
Get Order Status/v1/order/statusorders:read
Get Active Orders/v1/ordersorders:read
Account Detail/v1/accountaccount:read

API keys use different roles for to access Gemini APIs. Please see roles for descriptions of each role and scope for API keys.

Revoke OAuth Token

See Revoke OAuth Token Endpoint

Revision History

DateNotes
2020/08/20Initial OAuth documentation