snaptrade-typescript-sdk
v9.0.166
Published
Client for SnapTrade
Readme
SnapTrade
Connect brokerage accounts to your app for live positions and trading
Table of Contents
- Installation
- Getting Started
- Reference
snaptrade.accountInformation.getAccountActivitiessnaptrade.accountInformation.getAllUserHoldingssnaptrade.accountInformation.getUserAccountBalancesnaptrade.accountInformation.getUserAccountDetailssnaptrade.accountInformation.getUserAccountOrderDetailsnaptrade.accountInformation.getUserAccountOrderssnaptrade.accountInformation.getUserAccountPositionssnaptrade.accountInformation.getUserAccountRecentOrderssnaptrade.accountInformation.getUserAccountReturnRatessnaptrade.accountInformation.getUserHoldingssnaptrade.accountInformation.listUserAccountssnaptrade.accountInformation.updateUserAccountsnaptrade.apiStatus.checksnaptrade.authentication.deleteSnapTradeUsersnaptrade.authentication.listSnapTradeUserssnaptrade.authentication.loginSnapTradeUsersnaptrade.authentication.registerSnapTradeUsersnaptrade.authentication.resetSnapTradeUserSecretsnaptrade.connections.detailBrokerageAuthorizationsnaptrade.connections.disableBrokerageAuthorizationsnaptrade.connections.listBrokerageAuthorizationssnaptrade.connections.refreshBrokerageAuthorizationsnaptrade.connections.removeBrokerageAuthorizationsnaptrade.connections.returnRatessnaptrade.connections.sessionEventssnaptrade.experimentalEndpoints.getUserAccountOrderDetailV2snaptrade.experimentalEndpoints.getUserAccountOrdersV2snaptrade.experimentalEndpoints.getUserAccountRecentOrdersV2snaptrade.options.getOptionsChainsnaptrade.options.listOptionHoldingssnaptrade.referenceData.getCurrencyExchangeRatePairsnaptrade.referenceData.getPartnerInfosnaptrade.referenceData.getSecurityTypessnaptrade.referenceData.getStockExchangessnaptrade.referenceData.getSymbolssnaptrade.referenceData.getSymbolsByTickersnaptrade.referenceData.listAllBrokerageAuthorizationTypesnaptrade.referenceData.listAllBrokerageInstrumentssnaptrade.referenceData.listAllBrokeragessnaptrade.referenceData.listAllCurrenciessnaptrade.referenceData.listAllCurrenciesRatessnaptrade.referenceData.symbolSearchUserAccountsnaptrade.trading.cancelOrdersnaptrade.trading.cancelUserAccountOrdersnaptrade.trading.getCryptocurrencyPairQuotesnaptrade.trading.getOptionImpactsnaptrade.trading.getOrderImpactsnaptrade.trading.getUserAccountQuotessnaptrade.trading.placeBracketOrdersnaptrade.trading.placeCryptoOrdersnaptrade.trading.placeForceOrdersnaptrade.trading.placeMlegOrdersnaptrade.trading.placeOrdersnaptrade.trading.previewCryptoOrdersnaptrade.trading.replaceOrdersnaptrade.trading.searchCryptocurrencyPairInstrumentssnaptrade.transactionsAndReporting.getActivitiessnaptrade.transactionsAndReporting.getReportingCustomRange
Installation
npm i snaptrade-typescript-sdkpnpm i snaptrade-typescript-sdkyarn add snaptrade-typescript-sdkGetting Started
const { Snaptrade } = require("snaptrade-typescript-sdk");
async function main() {
// 1) Initialize a client with your clientID and consumerKey.
const snaptrade = new Snaptrade({
consumerKey: process.env.SNAPTRADE_CONSUMER_KEY,
clientId: process.env.SNAPTRADE_CLIENT_ID,
});
// 2) Check that the client is able to make a request to the API server.
const status = await snaptrade.apiStatus.check();
console.log("status:", status.data);
// 3) Create a new user on SnapTrade
const userId = uuid();
const { userSecret } = (
await snaptrade.authentication.registerSnapTradeUser({
userId,
})
).data;
// Note: A user secret is only generated once. It's required to access
// resources for certain endpoints.
console.log("userSecret:", userSecret);
// 4) Get a redirect URI. Users will need this to connect
const data = (
await snaptrade.authentication.loginSnapTradeUser({ userId, userSecret })
).data;
if (!("redirectURI" in data)) throw Error("Should have gotten redirect URI");
console.log("redirectURI:", data.redirectURI);
// 5) Obtaining account holdings data
const holdings = (
await snaptrade.accountInformation.getAllUserHoldings({
userId,
userSecret,
})
).data;
console.log("holdings:", holdings);
// 6) Deleting a user
const deleteResponse = (
await snaptrade.authentication.deleteSnapTradeUser({ userId })
).data;
console.log("deleteResponse:", deleteResponse);
}
// Should be replaced with function to get user ID
function getUserId() {
var d = new Date().getTime(); //Timestamp
var d2 =
(typeof performance !== "undefined" &&
performance.now &&
performance.now() * 1000) ||
0; //Time in microseconds since page-load or 0 if unsupported
return "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g, function (c) {
var r = Math.random() * 16; //random number between 0 and 16
if (d > 0) {
//Use timestamp until depleted
r = (d + r) % 16 | 0;
d = Math.floor(d / 16);
} else {
//Use microseconds since page-load if supported
r = (d2 + r) % 16 | 0;
d2 = Math.floor(d2 / 16);
}
return (c === "x" ? r : (r & 0x3) | 0x8).toString(16);
});
}
main();Reference
snaptrade.accountInformation.getAccountActivities
Returns all historical transactions for the specified account.
This endpoint is paginated with a default page size of 1000. The endpoint will return a maximum of 1000 transactions per request. See the query parameters for pagination options.
Transaction are returned in reverse chronological order, using the trade_date field.
The data returned here is always cached and refreshed once a day.
If the connection has become disabled, it can no longer access the latest data from the brokerage, but will continue to return the last available cached state. Please see this guide on how to fix a disabled connection.
🛠️ Usage
const getAccountActivitiesResponse =
await snaptrade.accountInformation.getAccountActivities({
accountId: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
startDate: "2022-01-24",
endDate: "2022-01-24",
type: "BUY,SELL,DIVIDEND",
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
});⚙️ Parameters
accountId: string
userId: string
userSecret: string
startDate: string | Date
The start date (inclusive) of the transaction history to retrieve. If not provided, the default is the first transaction known to SnapTrade based on trade_date.
endDate: string | Date
The end date (inclusive) of the transaction history to retrieve. If not provided, the default is the last transaction known to SnapTrade based on trade_date.
offset: number
An integer that specifies the starting point of the paginated results. Default is 0.
limit: number
An integer that specifies the maximum number of transactions to return. Default of 1000.
type: string
Optional comma separated list of transaction types to filter by. SnapTrade does a best effort to categorize brokerage transaction types into a common set of values. Here are some of the most popular values: - BUY - Asset bought. - SELL - Asset sold. - DIVIDEND - Dividend payout. - CONTRIBUTION - Cash contribution. - WITHDRAWAL - Cash withdrawal. - REI - Dividend reinvestment. - STOCK_DIVIDEND - A type of dividend where a company distributes shares instead of cash - INTEREST - Interest deposited into the account. - FEE - Fee withdrawn from the account. - TAX - A tax related fee. - OPTIONEXPIRATION - Option expiration event. - OPTIONASSIGNMENT - Option assignment event. - OPTIONEXERCISE - Option exercise event. - TRANSFER - Transfer of assets from one account to another. - SPLIT - A stock share split.
🔄 Return
🌐 Endpoint
/accounts/{accountId}/activities GET
snaptrade.accountInformation.getAllUserHoldings
Deprecated, please use the account-specific holdings endpoint instead.
List all accounts for the user, plus balances, positions, and orders for each account.
🛠️ Usage
const getAllUserHoldingsResponse =
await snaptrade.accountInformation.getAllUserHoldings({
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
brokerageAuthorizations: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
});⚙️ Parameters
userId: string
userSecret: string
brokerageAuthorizations: string
Optional. Comma separated list of authorization IDs (only use if filtering is needed on one or more authorizations).
🔄 Return
🌐 Endpoint
/holdings GET
snaptrade.accountInformation.getUserAccountBalance
Returns a list of balances for the account. Each element of the list has a distinct currency. Some brokerages like Questrade allows holding multiple currencies in the same account.
Check your API key on the Customer Dashboard billing page to see if you have real-time data access:
- If you do, this endpoint returns real-time data.
- If you don't, the data is cached and refreshed once a day. How long the data is cached for varies by brokerage. Check the brokerage integrations doc and look for "Cache Expiry Time" to see the exact value for a specific brokerage. If you need real-time, use the manual refresh endpoint.
If the connection has become disabled, it can no longer access the latest data from the brokerage, but will continue to return the last available cached state. Please see this guide on how to fix a disabled connection.
🛠️ Usage
const getUserAccountBalanceResponse =
await snaptrade.accountInformation.getUserAccountBalance({
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
accountId: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
});⚙️ Parameters
userId: string
userSecret: string
accountId: string
🔄 Return
🌐 Endpoint
/accounts/{accountId}/balances GET
snaptrade.accountInformation.getUserAccountDetails
Returns account detail known to SnapTrade for the specified account.
Check your API key on the Customer Dashboard billing page to see if you have real-time data access:
- If you do, this endpoint returns real-time data.
- If you don't, the data is cached and refreshed once a day. If you need real-time, use the manual refresh endpoint.
If the connection has become disabled, it can no longer access the latest data from the brokerage, but will continue to return the last available cached state. Please see this guide on how to fix a disabled connection.
🛠️ Usage
const getUserAccountDetailsResponse =
await snaptrade.accountInformation.getUserAccountDetails({
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
accountId: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
});⚙️ Parameters
userId: string
userSecret: string
accountId: string
🔄 Return
🌐 Endpoint
/accounts/{accountId} GET
snaptrade.accountInformation.getUserAccountOrderDetail
Returns the detail of a single order using the external order ID provided in the request body.
This endpoint only works for single-leg orders at this time. Support for multi-leg orders will be added in the future.
This endpoint is always realtime and does not rely on cached data.
This endpoint only returns orders placed through SnapTrade. In other words, orders placed outside of the SnapTrade network are not returned by this endpoint.
🛠️ Usage
const getUserAccountOrderDetailResponse =
await snaptrade.accountInformation.getUserAccountOrderDetail({
accountId: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
brokerage_order_id: "66a033fa-da74-4fcf-b527-feefdec9257e",
});⚙️ Parameters
brokerage_order_id: string
Order ID returned by brokerage. This is the unique identifier for the order in the brokerage system.
accountId: string
userId: string
userSecret: string
🔄 Return
🌐 Endpoint
/accounts/{accountId}/orders/details POST
snaptrade.accountInformation.getUserAccountOrders
Returns a list of recent orders in the specified account.
Check your API key on the Customer Dashboard billing page to see if you have real-time data access:
- If you do, this endpoint returns real-time data.
- If you don't, the data is cached and refreshed once a day. How long the data is cached for varies by brokerage. Check the brokerage integrations doc and look for "Cache Expiry Time" to see the exact value for a specific brokerage. If you need real-time, use the manual refresh endpoint.
If the connection has become disabled, it can no longer access the latest data from the brokerage, but will continue to return the last available cached state. Please see this guide on how to fix a disabled connection.
🛠️ Usage
const getUserAccountOrdersResponse =
await snaptrade.accountInformation.getUserAccountOrders({
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
state: "all",
days: 30,
accountId: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
});⚙️ Parameters
userId: string
userSecret: string
accountId: string
state: 'all' | 'open' | 'executed'
defaults value is set to "all"
days: number
Number of days in the past to fetch the most recent orders. Defaults to the last 30 days if no value is passed in.
🔄 Return
🌐 Endpoint
/accounts/{accountId}/orders GET
snaptrade.accountInformation.getUserAccountPositions
Returns a list of stock/ETF/crypto/mutual fund positions in the specified account. For option positions, please use the options endpoint.
Check your API key on the Customer Dashboard billing page to see if you have real-time data access:
- If you do, this endpoint returns real-time data.
- If you don't, the data is cached and refreshed once a day. How long the data is cached for varies by brokerage. Check the brokerage integrations doc and look for "Cache Expiry Time" to see the exact value for a specific brokerage. If you need real-time, use the manual refresh endpoint.
If the connection has become disabled, it can no longer access the latest data from the brokerage, but will continue to return the last available cached state. Please see this guide on how to fix a disabled connection.
🛠️ Usage
const getUserAccountPositionsResponse =
await snaptrade.accountInformation.getUserAccountPositions({
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
accountId: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
});⚙️ Parameters
userId: string
userSecret: string
accountId: string
🔄 Return
🌐 Endpoint
/accounts/{accountId}/positions GET
snaptrade.accountInformation.getUserAccountRecentOrders
A lightweight endpoint that returns the latest page of orders placed in the last 24 hours in the specified account. For most brokerages, the default page size is 100 meaning the endpoint will return a max of 100 orders. This endpoint is realtime and can be used to quickly check if account state has recently changed due to an execution, or check status of recently placed orders Differs from /orders in that it is always realtime, and only checks the last 24 hours By default only returns executed orders, but that can be changed by setting only_executed to false
🛠️ Usage
const getUserAccountRecentOrdersResponse =
await snaptrade.accountInformation.getUserAccountRecentOrders({
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
accountId: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
});⚙️ Parameters
userId: string
userSecret: string
accountId: string
onlyExecuted: boolean
Defaults to true. Indicates if request should fetch only executed orders. Set to false to retrieve non executed orders as well
🔄 Return
🌐 Endpoint
/accounts/{accountId}/recentOrders GET
snaptrade.accountInformation.getUserAccountReturnRates
Returns a list of rate of return percents for a given account. Will include timeframes available from the brokerage, for example "ALL", "1Y", "6M", "3M", "1M"
🛠️ Usage
const getUserAccountReturnRatesResponse =
await snaptrade.accountInformation.getUserAccountReturnRates({
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
accountId: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
});⚙️ Parameters
userId: string
userSecret: string
accountId: string
🔄 Return
🌐 Endpoint
/accounts/{accountId}/returnRates GET
snaptrade.accountInformation.getUserHoldings
Returns a list of balances, positions, and recent orders for the specified account. The data returned is similar to the data returned over the more fine-grained balances, positions and orders endpoints. The finer-grained APIs are preferred. They are easier to work with, faster, and have better error handling than this coarse-grained API.
Check your API key on the Customer Dashboard billing page to see if you have real-time data access:
- If you do, this endpoint returns real-time data.
- If you don't, the data is cached and refreshed once a day. How long the data is cached for varies by brokerage. Check the brokerage integrations doc and look for "Cache Expiry Time" to see the exact value for a specific brokerage. If you need real-time, use the manual refresh endpoint.
If the connection has become disabled, it can no longer access the latest data from the brokerage, but will continue to return the last available cached state. Please see this guide on how to fix a disabled connection.
🛠️ Usage
const getUserHoldingsResponse =
await snaptrade.accountInformation.getUserHoldings({
accountId: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
});⚙️ Parameters
accountId: string
userId: string
userSecret: string
🔄 Return
🌐 Endpoint
/accounts/{accountId}/holdings GET
snaptrade.accountInformation.listUserAccounts
Returns all brokerage accounts across all connections known to SnapTrade for the authenticated user.
Check your API key on the Customer Dashboard billing page to see if you have real-time data access:
- If you do, this endpoint returns real-time data.
- If you don't, the data is cached and refreshed once a day. If you need real-time, use the manual refresh endpoint.
🛠️ Usage
const listUserAccountsResponse =
await snaptrade.accountInformation.listUserAccounts({
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
});⚙️ Parameters
userId: string
userSecret: string
🔄 Return
🌐 Endpoint
/accounts GET
snaptrade.accountInformation.updateUserAccount
Updates various properties of a specified account.
🛠️ Usage
const updateUserAccountResponse =
await snaptrade.accountInformation.updateUserAccount({
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
accountId: "accountId_example",
});⚙️ Parameters
userId: string
userSecret: string
accountId: string
The ID of the account to update.
🔄 Return
🌐 Endpoint
/accounts/{accountId} PUT
snaptrade.apiStatus.check
Check whether the API is operational and verify timestamps.
🛠️ Usage
const checkResponse = await snaptrade.apiStatus.check();🔄 Return
🌐 Endpoint
/ GET
snaptrade.authentication.deleteSnapTradeUser
Deletes a registered user and all associated data. This action is irreversible. This API is asynchronous and will return a 200 status code if the request is accepted. The user and all associated data will be queued for deletion. Once deleted, a USER_DELETED webhook will be sent.
🛠️ Usage
const deleteSnapTradeUserResponse =
await snaptrade.authentication.deleteSnapTradeUser({
userId: "snaptrade-user-123",
});⚙️ Parameters
userId: string
🔄 Return
🌐 Endpoint
/snapTrade/deleteUser DELETE
snaptrade.authentication.listSnapTradeUsers
Returns a list of all registered user IDs. Please note that the response is not currently paginated.
🛠️ Usage
const listSnapTradeUsersResponse =
await snaptrade.authentication.listSnapTradeUsers();🌐 Endpoint
/snapTrade/listUsers GET
snaptrade.authentication.loginSnapTradeUser
Authenticates a SnapTrade user and returns the Connection Portal URL used for connecting brokerage accounts. Please check this guide for how to integrate the Connection Portal into your app.
Please note that the returned URL expires in 5 minutes.
🛠️ Usage
const loginSnapTradeUserResponse =
await snaptrade.authentication.loginSnapTradeUser({
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
broker: "ALPACA",
immediateRedirect: true,
customRedirect: "https://snaptrade.com",
reconnect: "8b5f262d-4bb9-365d-888a-202bd3b15fa1",
connectionType: "read",
showCloseButton: true,
darkMode: true,
connectionPortalVersion: "v4",
});⚙️ Parameters
userId: string
userSecret: string
broker: string
Slug of the brokerage to connect the user to. See the integrations page for a list of supported brokerages and their slugs.
immediateRedirect: boolean
When set to true, user will be redirected back to the partner\'s site instead of the connection portal. This parameter is ignored if the connection portal is loaded inside an iframe. See the guide on ways to integrate the connection portal for more information.
customRedirect: string
URL to redirect the user to after the user connects their brokerage account. This parameter is ignored if the connection portal is loaded inside an iframe. See the guide on ways to integrate the connection portal for more information.
reconnect: string
The UUID of the brokerage connection to be reconnected. This parameter should be left empty unless you are reconnecting a disabled connection. See the guide on fixing broken connections for more information.
connectionType: string
Determines connection permissions (default: read) - read: Data access only. - trade: Data and trading access. - trade-if-available: Attempts to establish a trading connection if the brokerage supports it, otherwise falls back to read-only access automatically.
showCloseButton: boolean
Controls whether the close (X) button is displayed in the connection portal. When false, you control closing behavior from your app. Defaults to true.
darkMode: boolean
Enable dark mode for the connection portal. Defaults to false.
connectionPortalVersion: string
Sets the connection portal version to render. Currently only v4 is supported and is the default. All other versions are deprecated and will automatically be set to v4.
🔄 Return
AuthenticationLoginSnapTradeUser200Response
🌐 Endpoint
/snapTrade/login POST
snaptrade.authentication.registerSnapTradeUser
Registers a new SnapTrade user under your Client ID. A user secret will be automatically generated for you and must be properly stored in your system. Most SnapTrade operations require a user ID and user secret to be passed in as parameters.
🛠️ Usage
const registerSnapTradeUserResponse =
await snaptrade.authentication.registerSnapTradeUser({
userId: "snaptrade-user-123",
});⚙️ Parameters
userId: string
SnapTrade User ID. This is chosen by the API partner and can be any string that is a) unique to the user, and b) immutable for the user. It is recommended to NOT use email addresses for this property because they are usually not immutable.
🔄 Return
🌐 Endpoint
/snapTrade/registerUser POST
snaptrade.authentication.resetSnapTradeUserSecret
Rotates the secret for a SnapTrade user. You might use this if userSecret is compromised. Please note that if you call this endpoint and fail to save the new secret, you'll no longer be able to access any data for this user, and your only option will be to delete and recreate the user, then ask them to reconnect.
🛠️ Usage
const resetSnapTradeUserSecretResponse =
await snaptrade.authentication.resetSnapTradeUserSecret({
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
});⚙️ Parameters
userId: string
SnapTrade User ID. This is chosen by the API partner and can be any string that is a) unique to the user, and b) immutable for the user. It is recommended to NOT use email addresses for this property because they are usually not immutable.
userSecret: string
SnapTrade User Secret. This is a randomly generated string and should be stored securely. If compromised, please rotate it via the rotate user secret endpoint.
🔄 Return
🌐 Endpoint
/snapTrade/resetUserSecret POST
snaptrade.connections.detailBrokerageAuthorization
Returns a single connection for the specified ID.
🛠️ Usage
const detailBrokerageAuthorizationResponse =
await snaptrade.connections.detailBrokerageAuthorization({
authorizationId: "87b24961-b51e-4db8-9226-f198f6518a89",
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
});⚙️ Parameters
authorizationId: string
userId: string
userSecret: string
🔄 Return
🌐 Endpoint
/authorizations/{authorizationId} GET
snaptrade.connections.disableBrokerageAuthorization
Manually force the specified connection to become disabled. This should only be used for testing a reconnect flow, and never used on production connections.
Will trigger a disconnect as if it happened naturally, and send a CONNECTION_BROKEN webhook for the connection.
This endpoint is available on test keys. If you would like it enabled on production keys as well, please contact support as it is disabled by default.
🛠️ Usage
const disableBrokerageAuthorizationResponse =
await snaptrade.connections.disableBrokerageAuthorization({
authorizationId: "87b24961-b51e-4db8-9226-f198f6518a89",
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
});⚙️ Parameters
authorizationId: string
userId: string
userSecret: string
🔄 Return
BrokerageAuthorizationDisabledConfirmation
🌐 Endpoint
/authorizations/{authorizationId}/disable POST
snaptrade.connections.listBrokerageAuthorizations
Returns a list of all connections for the specified user. Note that Connection and Brokerage Authorization are interchangeable, but the term Connection is preferred and used in the doc for consistency.
A connection is usually tied to a single login at a brokerage. A single connection can contain multiple brokerage accounts.
SnapTrade performs de-duping on connections for a given user. If the user has an existing connection with the brokerage, when connecting the brokerage with the same credentials, SnapTrade will return the existing connection instead of creating a new one.
🛠️ Usage
const listBrokerageAuthorizationsResponse =
await snaptrade.connections.listBrokerageAuthorizations({
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
});⚙️ Parameters
userId: string
userSecret: string
🔄 Return
🌐 Endpoint
/authorizations GET
snaptrade.connections.refreshBrokerageAuthorization
Trigger a holdings update for all accounts under this connection. Updates will be queued asynchronously. ACCOUNT_HOLDINGS_UPDATED webhook will be sent once the sync completes for each account under the connection.
This endpoint will also trigger a transaction sync for the past day if one has not yet occurred.
Because of the cost of refreshing a connection, each call to this endpoint incurs an additional charge. You can find the exact cost for your API key on the Customer Dashboard billing page
🛠️ Usage
const refreshBrokerageAuthorizationResponse =
await snaptrade.connections.refreshBrokerageAuthorization({
authorizationId: "87b24961-b51e-4db8-9226-f198f6518a89",
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
});⚙️ Parameters
authorizationId: string
userId: string
userSecret: string
🔄 Return
BrokerageAuthorizationRefreshConfirmation
🌐 Endpoint
/authorizations/{authorizationId}/refresh POST
snaptrade.connections.removeBrokerageAuthorization
Deletes the SnapTrade connection specified by the ID. This will also remove the accounts and holdings data associated with the connection from SnapTrade. This action is irreversible. This endpoint is synchronous, a 204 response indicates that the data has been successfully deleted.
🛠️ Usage
const removeBrokerageAuthorizationResponse =
await snaptrade.connections.removeBrokerageAuthorization({
authorizationId: "87b24961-b51e-4db8-9226-f198f6518a89",
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
});⚙️ Parameters
authorizationId: string
userId: string
userSecret: string
🌐 Endpoint
/authorizations/{authorizationId} DELETE
snaptrade.connections.returnRates
Returns a list of rate of return percents for a given connection. Will include timeframes available from the brokerage, for example "ALL", "1Y", "6M", "3M", "1M"
🛠️ Usage
const returnRatesResponse = await snaptrade.connections.returnRates({
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
authorizationId: "87b24961-b51e-4db8-9226-f198f6518a89",
});⚙️ Parameters
userId: string
userSecret: string
authorizationId: string
🔄 Return
🌐 Endpoint
/authorizations/{authorizationId}/returnRates GET
snaptrade.connections.sessionEvents
Returns a list of session events associated with a user.
🛠️ Usage
const sessionEventsResponse = await snaptrade.connections.sessionEvents({
partnerClientId: "SNAPTRADETEST",
userId:
"917c8734-8470-4a3e-a18f-57c3f2ee6631,65e839a3-9103-4cfb-9b72-2071ef80c5f2",
sessionId:
"917c8734-8470-4a3e-a18f-57c3f2ee6631,65e839a3-9103-4cfb-9b72-2071ef80c5f2",
});⚙️ Parameters
partnerClientId: string
userId: string
Optional comma separated list of user IDs used to filter the request on specific users
sessionId: string
Optional comma separated list of session IDs used to filter the request on specific users
🔄 Return
ConnectionsSessionEvents200ResponseInner
🌐 Endpoint
/sessionEvents GET
snaptrade.experimentalEndpoints.getUserAccountOrderDetailV2
Returns the detail of a single order using the brokerage order ID provided as a path parameter.
The V2 order response format includes all legs of the order in the legs list field.
If the order is single legged, legs will be a list of one leg.
This endpoint is always realtime and does not rely on cached data.
This endpoint only returns orders placed through SnapTrade. In other words, orders placed outside of the SnapTrade network are not returned by this endpoint.
🛠️ Usage
const getUserAccountOrderDetailV2Response =
await snaptrade.experimentalEndpoints.getUserAccountOrderDetailV2({
accountId: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
brokerageOrderId: "66a033fa-da74-4fcf-b527-feefdec9257e",
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
});⚙️ Parameters
accountId: string
brokerageOrderId: string
userId: string
userSecret: string
🔄 Return
🌐 Endpoint
/accounts/{accountId}/orders/details/v2/{brokerageOrderId} GET
snaptrade.experimentalEndpoints.getUserAccountOrdersV2
Returns a list of recent orders in the specified account.
The V2 order response format will include all legs of each order in the legs list field. If the order is single legged, legs will be a list of one leg.
If the connection has become disabled, it can no longer access the latest data from the brokerage, but will continue to return the last available cached state. Please see this guide on how to fix a disabled connection.
🛠️ Usage
const getUserAccountOrdersV2Response =
await snaptrade.experimentalEndpoints.getUserAccountOrdersV2({
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
state: "all",
days: 30,
accountId: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
});⚙️ Parameters
userId: string
userSecret: string
accountId: string
state: 'all' | 'open' | 'executed'
defaults value is set to "all"
days: number
Number of days in the past to fetch the most recent orders. Defaults to the last 30 days if no value is passed in.
🔄 Return
🌐 Endpoint
/accounts/{accountId}/orders/v2 GET
snaptrade.experimentalEndpoints.getUserAccountRecentOrdersV2
A lightweight endpoint that returns a list of orders executed in the last 24 hours in the specified account using the V2 order format. This endpoint is realtime and can be used to quickly check if account state has recently changed due to an execution, or check status of recently placed orders. Differs from /orders in that it is realtime, and only checks the last 24 hours as opposed to the last 30 days. By default only returns executed orders, but that can be changed by setting only_executed to false. Because of the cost of realtime requests, each call to this endpoint incurs an additional charge. You can find the exact cost for your API key on the Customer Dashboard billing page
🛠️ Usage
const getUserAccountRecentOrdersV2Response =
await snaptrade.experimentalEndpoints.getUserAccountRecentOrdersV2({
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
accountId: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
});⚙️ Parameters
userId: string
userSecret: string
accountId: string
onlyExecuted: boolean
Defaults to true. Indicates if request should fetch only executed orders. Set to false to retrieve non executed orders as well
🔄 Return
🌐 Endpoint
/accounts/{accountId}/recentOrders/v2 GET
snaptrade.options.getOptionsChain
Returns the option chain for the specified symbol in the specified account.
🛠️ Usage
const getOptionsChainResponse = await snaptrade.options.getOptionsChain({
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
accountId: "accountId_example",
symbol: "symbol_example",
});⚙️ Parameters
userId: string
userSecret: string
accountId: string
The ID of the account to get the options chain from.
symbol: string
Universal symbol ID if symbol
🔄 Return
🌐 Endpoint
/accounts/{accountId}/optionsChain GET
snaptrade.options.listOptionHoldings
Returns a list of option positions in the specified account. For stock/ETF/crypto/mutual fund positions, please use the positions endpoint.
Check your API key on the Customer Dashboard billing page to see if you have real-time data access:
- If you do, this endpoint returns real-time data.
- If you don't, the data is cached and refreshed once a day. How long the data is cached for varies by brokerage. Check the brokerage integrations doc and look for "Cache Expiry Time" to see the exact value for a specific brokerage. If you need real-time, use the manual refresh endpoint.
🛠️ Usage
const listOptionHoldingsResponse = await snaptrade.options.listOptionHoldings({
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
accountId: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
});⚙️ Parameters
userId: string
userSecret: string
accountId: string
🔄 Return
🌐 Endpoint
/accounts/{accountId}/options GET
snaptrade.referenceData.getCurrencyExchangeRatePair
Returns an Exchange Rate Pair object for the specified Currency Pair.
🛠️ Usage
const getCurrencyExchangeRatePairResponse =
await snaptrade.referenceData.getCurrencyExchangeRatePair({
currencyPair: "currencyPair_example",
});⚙️ Parameters
currencyPair: string
A currency pair based on currency code for example, {CAD-USD}
🔄 Return
🌐 Endpoint
/currencies/rates/{currencyPair} GET
snaptrade.referenceData.getPartnerInfo
Returns configurations for your SnapTrade Client ID, including allowed brokerages and data access.
🛠️ Usage
const getPartnerInfoResponse = await snaptrade.referenceData.getPartnerInfo();🔄 Return
🌐 Endpoint
/snapTrade/partners GET
snaptrade.referenceData.getSecurityTypes
Return all available security types supported by SnapTrade.
🛠️ Usage
const getSecurityTypesResponse =
await snaptrade.referenceData.getSecurityTypes();🔄 Return
🌐 Endpoint
/securityTypes GET
snaptrade.referenceData.getStockExchanges
Returns a list of all supported Exchanges.
🛠️ Usage
const getStockExchangesResponse =
await snaptrade.referenceData.getStockExchanges();🔄 Return
🌐 Endpoint
/exchanges GET
snaptrade.referenceData.getSymbols
Returns a list of Universal Symbol objects that match the given query. The matching takes into consideration both the ticker and the name of the symbol. Only the first 20 results are returned.
🛠️ Usage
const getSymbolsResponse = await snaptrade.referenceData.getSymbols({
substring: "AAPL",
});⚙️ Parameters
substring: string
The search query for symbols.
🔄 Return
🌐 Endpoint
/symbols POST
snaptrade.referenceData.getSymbolsByTicker
Returns the Universal Symbol object specified by the ticker or the Universal Symbol ID. When a ticker is specified, the first matching result is returned. We largely follow the Yahoo Finance ticker format(click on "Yahoo Finance Market Coverage and Data Delays"). For example, for securities traded on the Toronto Stock Exchange, the symbol has a '.TO' suffix. For securities traded on NASDAQ or NYSE, the symbol does not have a suffix. Please use the ticker with the proper suffix for the best results.
🛠️ Usage
const getSymbolsByTickerResponse =
await snaptrade.referenceData.getSymbolsByTicker({
query: "query_example",
});⚙️ Parameters
query: string
The ticker or Universal Symbol ID to look up the symbol with.
🔄 Return
🌐 Endpoint
/symbols/{query} GET
snaptrade.referenceData.listAllBrokerageAuthorizationType
Returns a list of all defined Brokerage authorization Type objects.
🛠️ Usage
const listAllBrokerageAuthorizationTypeResponse =
await snaptrade.referenceData.listAllBrokerageAuthorizationType({
brokerage: "QUESTRADE,ALPACA",
});⚙️ Parameters
brokerage: string
Comma separated value of brokerage slugs
🔄 Return
BrokerageAuthorizationTypeReadOnly
🌐 Endpoint
/brokerageAuthorizationTypes GET
snaptrade.referenceData.listAllBrokerageInstruments
Returns a list of all brokerage instruments available for a given brokerage. Not all brokerages support this. The ones that don't will return an empty list.
🛠️ Usage
const listAllBrokerageInstrumentsResponse =
await snaptrade.referenceData.listAllBrokerageInstruments({
slug: "QUESTRADE",
});⚙️ Parameters
slug: string
A short, unique identifier for the brokerage. It is usually the name of the brokerage in capital letters and will never change.
🔄 Return
🌐 Endpoint
/brokerages/{slug}/instruments GET
snaptrade.referenceData.listAllBrokerages
Returns a list of all defined Brokerage objects.
🛠️ Usage
const listAllBrokeragesResponse =
await snaptrade.referenceData.listAllBrokerages();🔄 Return
🌐 Endpoint
/brokerages GET
snaptrade.referenceData.listAllCurrencies
Returns a list of all defined Currency objects.
🛠️ Usage
const listAllCurrenciesResponse =
await snaptrade.referenceData.listAllCurrencies();🔄 Return
🌐 Endpoint
/currencies GET
snaptrade.referenceData.listAllCurrenciesRates
Returns a list of all Exchange Rate Pairs for all supported Currencies.
🛠️ Usage
const listAllCurrenciesRatesResponse =
await snaptrade.referenceData.listAllCurrenciesRates();🔄 Return
🌐 Endpoint
/currencies/rates GET
snaptrade.referenceData.symbolSearchUserAccount
Returns a list of Universal Symbol objects that match the given query. The matching takes into consideration both the ticker and the name of the symbol. Only the first 20 results are returned.
The search results are further limited to the symbols supported by the brokerage for which the account is under.
🛠️ Usage
const symbolSearchUserAccountResponse =
await snaptrade.referenceData.symbolSearchUserAccount({
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
accountId: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
substring: "AAPL",
});⚙️ Parameters
userId: string
userSecret: string
accountId: string
substring: string
The search query for symbols.
🔄 Return
🌐 Endpoint
/accounts/{accountId}/symbols POST
snaptrade.trading.cancelOrder
Cancels an order in the specified account. Accepts order IDs for all asset types.
🛠️ Usage
const cancelOrderResponse = await snaptrade.trading.cancelOrder({
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
accountId: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
brokerage_order_id: "66a033fa-da74-4fcf-b527-feefdec9257e",
});⚙️ Parameters
brokerage_order_id: string
Order ID returned by brokerage. This is the unique identifier for the order in the brokerage system.
userId: string
userSecret: string
accountId: string
🔄 Return
🌐 Endpoint
/accounts/{accountId}/trading/cancel POST
snaptrade.trading.cancelUserAccountOrder
**This endpoint is deprecated. Please switch to the new cancel order endpoint ** Attempts to cancel an open order with the brokerage. If the order is no longer cancellable, the request will be rejected.
🛠️ Usage
const cancelUserAccountOrderResponse =
await snaptrade.trading.cancelUserAccountOrder({
userId: "snaptrade-user-123",
userSecret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
accountId: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
brokerage_order_id: "66a033fa-da74-4fcf-b527-feefdec9257e",
});⚙️ Parameters
brokerage_order_id: string
Order ID returned by brokerage. This is the unique identifier for the order in the brokerage system.
userId: string
userSecret: string
accountId: string
🔄 Return
🌐 Endpoint
/accounts/{accountId}/orders/cancel POST
[🔙 **Back

