snaptrade 1.17.10 → 2.0.77

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (462) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile +1 -0
  3. data/Gemfile.lock +31 -28
  4. data/README.md +1995 -208
  5. data/lib/snaptrade/api/account_information_api.rb +535 -71
  6. data/lib/snaptrade/api/api_status_api.rb +6 -3
  7. data/lib/snaptrade/api/authentication_api.rb +180 -140
  8. data/lib/snaptrade/api/connections_api.rb +401 -41
  9. data/lib/snaptrade/api/options_api.rb +82 -39
  10. data/lib/snaptrade/api/reference_data_api.rb +181 -101
  11. data/lib/snaptrade/api/trading_api.rb +200 -228
  12. data/lib/snaptrade/api/transactions_and_reporting_api.rb +48 -33
  13. data/lib/snaptrade/api_client.rb +24 -14
  14. data/lib/snaptrade/api_error.rb +0 -1
  15. data/lib/snaptrade/configuration.rb +11 -29
  16. data/lib/snaptrade/models/account.rb +84 -29
  17. data/lib/snaptrade/models/account_balance.rb +1 -2
  18. data/lib/snaptrade/models/account_balance_total.rb +3 -9
  19. data/lib/snaptrade/models/account_holdings.rb +0 -1
  20. data/lib/snaptrade/models/account_holdings_account.rb +19 -4
  21. data/lib/snaptrade/models/account_order_record.rb +52 -33
  22. data/lib/snaptrade/models/{brokerage_symbol_option_symbol.rb → account_order_record_option_symbol.rb} +15 -27
  23. data/lib/snaptrade/models/account_order_record_status.rb +0 -1
  24. data/lib/snaptrade/models/{brokerage_symbol_symbol.rb → account_order_record_universal_symbol.rb} +33 -7
  25. data/lib/snaptrade/models/account_simple.rb +4 -2
  26. data/lib/snaptrade/models/account_sync_status.rb +14 -6
  27. data/lib/snaptrade/models/account_universal_activity.rb +371 -0
  28. data/lib/snaptrade/models/account_universal_activity_currency.rb +245 -0
  29. data/lib/snaptrade/models/{target_asset.rb → account_universal_activity_option_symbol.rb} +83 -59
  30. data/lib/snaptrade/models/{universal_symbol_ticker.rb → account_universal_activity_symbol.rb} +37 -16
  31. data/lib/snaptrade/models/{trade_action.rb → action_strict.rb} +3 -4
  32. data/lib/snaptrade/models/{trade_execution_status_action.rb → action_strict_with_options.rb} +8 -5
  33. data/lib/snaptrade/models/auth_type.rb +0 -1
  34. data/lib/snaptrade/models/authentication_login_snap_trade_user200_response.rb +0 -1
  35. data/lib/snaptrade/models/balance.rb +19 -8
  36. data/lib/snaptrade/models/{model_portfolio.rb → balance_currency.rb} +27 -19
  37. data/lib/snaptrade/models/brokerage.rb +57 -50
  38. data/lib/snaptrade/models/brokerage_authorization.rb +24 -21
  39. data/lib/snaptrade/models/{model_asset_class.rb → brokerage_authorization_disabled_confirmation.rb} +12 -20
  40. data/lib/snaptrade/models/{jwt.rb → brokerage_authorization_refresh_confirmation.rb} +12 -12
  41. data/lib/snaptrade/models/brokerage_authorization_type_read_only.rb +1 -2
  42. data/lib/snaptrade/models/brokerage_authorization_type_read_only_brokerage.rb +2 -3
  43. data/lib/snaptrade/models/brokerage_type.rb +1 -2
  44. data/lib/snaptrade/models/connection_portal_version.rb +3 -3
  45. data/lib/snaptrade/models/connection_type.rb +0 -1
  46. data/lib/snaptrade/models/connections_session_events200_response_inner.rb +1 -2
  47. data/lib/snaptrade/models/currency.rb +4 -2
  48. data/lib/snaptrade/models/delete_user_response.rb +13 -5
  49. data/lib/snaptrade/models/dividend_at_date.rb +0 -1
  50. data/lib/snaptrade/models/encrypted_response.rb +0 -1
  51. data/lib/snaptrade/models/encrypted_response_encrypted_message_data.rb +0 -1
  52. data/lib/snaptrade/models/exchange.rb +9 -2
  53. data/lib/snaptrade/models/exchange_rate_pairs.rb +0 -1
  54. data/lib/snaptrade/models/figi_instrument.rb +230 -0
  55. data/lib/snaptrade/models/holdings_status.rb +229 -0
  56. data/lib/snaptrade/models/login_redirect_uri.rb +3 -3
  57. data/lib/snaptrade/models/manual_trade.rb +10 -6
  58. data/lib/snaptrade/models/manual_trade_and_impact.rb +2 -3
  59. data/lib/snaptrade/models/manual_trade_balance.rb +3 -4
  60. data/lib/snaptrade/models/manual_trade_form.rb +56 -28
  61. data/lib/snaptrade/models/{model_asset_class_target.rb → manual_trade_form_notional_value.rb} +12 -15
  62. data/lib/snaptrade/models/{trade.rb → manual_trade_form_with_options.rb} +126 -43
  63. data/lib/snaptrade/models/{snap_trade_api_disclaimer_accept_status.rb → manual_trade_form_with_options_stop_loss.rb} +24 -18
  64. data/lib/snaptrade/models/manual_trade_form_with_options_take_profit.rb +223 -0
  65. data/lib/snaptrade/models/{trade_impact.rb → manual_trade_impact.rb} +20 -17
  66. data/lib/snaptrade/models/manual_trade_symbol.rb +19 -15
  67. data/lib/snaptrade/models/model400_failed_request_response.rb +0 -1
  68. data/lib/snaptrade/models/model401_failed_request_response.rb +0 -1
  69. data/lib/snaptrade/models/model402_brokerage_auth_already_disabled_exception.rb +228 -0
  70. data/lib/snaptrade/models/{amount.rb → model402_brokerage_auth_disabled_response.rb} +19 -18
  71. data/lib/snaptrade/models/model403_failed_request_response.rb +0 -1
  72. data/lib/snaptrade/models/model403_feature_not_enabled_response.rb +228 -0
  73. data/lib/snaptrade/models/model404_failed_request_response.rb +0 -1
  74. data/lib/snaptrade/models/{calculated_trade.rb → model425_failed_request_response.rb} +19 -20
  75. data/lib/snaptrade/models/model500_unexpected_exception_response.rb +0 -1
  76. data/lib/snaptrade/models/monthly_dividends.rb +1 -2
  77. data/lib/snaptrade/models/net_contributions.rb +1 -2
  78. data/lib/snaptrade/models/net_dividend.rb +0 -1
  79. data/lib/snaptrade/models/notional_value.rb +103 -0
  80. data/lib/snaptrade/models/{options_holdings.rb → option_brokerage_symbol.rb} +19 -50
  81. data/lib/snaptrade/models/option_chain_inner.rb +0 -1
  82. data/lib/snaptrade/models/option_chain_inner_chain_per_root_inner.rb +0 -1
  83. data/lib/snaptrade/models/option_chain_inner_chain_per_root_inner_chain_per_strike_price_inner.rb +0 -1
  84. data/lib/snaptrade/models/option_leg.rb +0 -1
  85. data/lib/snaptrade/models/option_leg_action.rb +0 -1
  86. data/lib/snaptrade/models/option_strategy.rb +0 -1
  87. data/lib/snaptrade/models/option_strategy_legs_inner.rb +0 -1
  88. data/lib/snaptrade/models/option_type.rb +0 -1
  89. data/lib/snaptrade/models/options_get_option_strategy_request.rb +0 -1
  90. data/lib/snaptrade/models/options_place_option_strategy_request.rb +4 -3
  91. data/lib/snaptrade/models/options_position.rb +20 -20
  92. data/lib/snaptrade/models/options_position_currency.rb +4 -1
  93. data/lib/snaptrade/models/options_symbol.rb +12 -25
  94. data/lib/snaptrade/models/{model_type.rb → order_class.rb} +6 -8
  95. data/lib/snaptrade/models/{order_type.rb → order_type_strict.rb} +5 -6
  96. data/lib/snaptrade/models/paginated_universal_activity.rb +228 -0
  97. data/lib/snaptrade/models/pagination_details.rb +228 -0
  98. data/lib/snaptrade/models/partner_data.rb +49 -50
  99. data/lib/snaptrade/models/past_value.rb +1 -2
  100. data/lib/snaptrade/models/performance_custom.rb +0 -1
  101. data/lib/snaptrade/models/position.rb +21 -20
  102. data/lib/snaptrade/models/position_symbol.rb +16 -12
  103. data/lib/snaptrade/models/{portfolio_group_position.rb → rate_of_return_object.rb} +26 -26
  104. data/lib/snaptrade/models/{brokerage_authorization_type.rb → rate_of_return_response.rb} +14 -11
  105. data/lib/snaptrade/models/{strategy_order_place.rb → recent_orders_response.rb} +7 -16
  106. data/lib/snaptrade/models/security_type.rb +5 -2
  107. data/lib/snaptrade/models/session_event.rb +1 -2
  108. data/lib/snaptrade/models/session_event_type.rb +11 -4
  109. data/lib/snaptrade/models/snap_trade_holdings_account.rb +0 -1
  110. data/lib/snaptrade/models/snap_trade_holdings_total_value.rb +3 -2
  111. data/lib/snaptrade/models/snap_trade_login_user_request_body.rb +10 -5
  112. data/lib/snaptrade/models/snap_trade_register_user_request_body.rb +1 -2
  113. data/lib/snaptrade/models/status.rb +0 -1
  114. data/lib/snaptrade/models/stop_loss.rb +227 -0
  115. data/lib/snaptrade/models/strategy_order_record.rb +5 -3
  116. data/lib/snaptrade/models/strategy_order_record_status.rb +0 -1
  117. data/lib/snaptrade/models/strategy_quotes.rb +0 -1
  118. data/lib/snaptrade/models/strategy_quotes_greek.rb +0 -1
  119. data/lib/snaptrade/models/strategy_type.rb +0 -1
  120. data/lib/snaptrade/models/sub_period_return_rate.rb +2 -3
  121. data/lib/snaptrade/models/symbol.rb +39 -14
  122. data/lib/snaptrade/models/{portfolio_group.rb → symbol_currency.rb} +24 -5
  123. data/lib/snaptrade/models/symbol_exchange.rb +296 -0
  124. data/lib/snaptrade/models/{model_portfolio_security.rb → symbol_figi_instrument.rb} +27 -41
  125. data/lib/snaptrade/models/symbol_query.rb +1 -2
  126. data/lib/snaptrade/models/symbols_quotes_inner.rb +15 -11
  127. data/lib/snaptrade/models/{excluded_asset.rb → take_profit.rb} +11 -12
  128. data/lib/snaptrade/models/{time_in_force.rb → time_in_force_strict.rb} +5 -6
  129. data/lib/snaptrade/models/{brokerage_authorization_type_type.rb → timeframe.rb} +9 -7
  130. data/lib/snaptrade/models/trading_cancel_user_account_order_request.rb +1 -1
  131. data/lib/snaptrade/models/transactions_status.rb +19 -8
  132. data/lib/snaptrade/models/type.rb +3 -4
  133. data/lib/snaptrade/models/underlying_symbol.rb +40 -6
  134. data/lib/snaptrade/models/{snap_trade_holdings_account_account_id.rb → underlying_symbol_exchange.rb} +55 -54
  135. data/lib/snaptrade/models/{brokerage_symbol.rb → underlying_symbol_type.rb} +28 -39
  136. data/lib/snaptrade/models/universal_activity.rb +91 -82
  137. data/lib/snaptrade/models/universal_symbol.rb +30 -5
  138. data/lib/snaptrade/models/us_exchange.rb +0 -1
  139. data/lib/snaptrade/models/user_i_dand_secret.rb +2 -4
  140. data/lib/snaptrade/models/validated_trade_body.rb +218 -0
  141. data/lib/snaptrade/version.rb +1 -2
  142. data/lib/snaptrade.rb +90 -66
  143. data/snaptrade.gemspec +0 -1
  144. data/spec/api/account_information_api_spec.rb +66 -13
  145. data/spec/api/api_status_api_spec.rb +0 -1
  146. data/spec/api/authentication_api_spec.rb +20 -20
  147. data/spec/api/connections_api_spec.rb +54 -9
  148. data/spec/api/options_api_spec.rb +11 -7
  149. data/spec/api/reference_data_api_spec.rb +24 -16
  150. data/spec/api/trading_api_spec.rb +17 -25
  151. data/spec/api/transactions_and_reporting_api_spec.rb +7 -8
  152. data/spec/api_client_spec.rb +0 -1
  153. data/spec/configuration_spec.rb +0 -1
  154. data/spec/models/account_balance_spec.rb +0 -1
  155. data/spec/models/account_balance_total_spec.rb +0 -1
  156. data/spec/models/account_holdings_account_spec.rb +6 -1
  157. data/spec/models/account_holdings_spec.rb +0 -1
  158. data/spec/models/{strategy_impact_legs_inner_spec.rb → account_order_record_option_symbol_spec.rb} +13 -14
  159. data/spec/models/account_order_record_spec.rb +12 -7
  160. data/spec/models/account_order_record_status_spec.rb +0 -1
  161. data/spec/models/{brokerage_symbol_symbol_spec.rb → account_order_record_universal_symbol_spec.rb} +18 -7
  162. data/spec/models/account_simple_spec.rb +0 -1
  163. data/spec/models/account_spec.rb +14 -9
  164. data/spec/models/account_sync_status_spec.rb +6 -1
  165. data/spec/models/account_universal_activity_currency_spec.rb +41 -0
  166. data/spec/models/{brokerage_symbol_option_symbol_spec.rb → account_universal_activity_option_symbol_spec.rb} +6 -19
  167. data/spec/models/{portfolio_group_info_spec.rb → account_universal_activity_spec.rb} +47 -18
  168. data/spec/models/{universal_symbol_ticker_spec.rb → account_universal_activity_symbol_spec.rb} +13 -8
  169. data/spec/models/action_strict_spec.rb +23 -0
  170. data/spec/models/action_strict_with_options_spec.rb +23 -0
  171. data/spec/models/auth_type_spec.rb +0 -1
  172. data/spec/models/authentication_login_snap_trade_user200_response_spec.rb +0 -1
  173. data/spec/models/{model_portfolio_spec.rb → balance_currency_spec.rb} +8 -9
  174. data/spec/models/balance_spec.rb +6 -1
  175. data/spec/models/brokerage_authorization_disabled_confirmation_spec.rb +29 -0
  176. data/spec/models/{brokerage_authorization_type_spec.rb → brokerage_authorization_refresh_confirmation_spec.rb} +7 -8
  177. data/spec/models/brokerage_authorization_spec.rb +6 -7
  178. data/spec/models/brokerage_authorization_type_read_only_brokerage_spec.rb +0 -1
  179. data/spec/models/brokerage_authorization_type_read_only_spec.rb +0 -1
  180. data/spec/models/brokerage_spec.rb +12 -19
  181. data/spec/models/brokerage_type_spec.rb +0 -1
  182. data/spec/models/connection_portal_version_spec.rb +0 -1
  183. data/spec/models/connection_type_spec.rb +0 -1
  184. data/spec/models/connections_session_events200_response_inner_spec.rb +0 -1
  185. data/spec/models/currency_spec.rb +0 -1
  186. data/spec/models/delete_user_response_spec.rb +6 -1
  187. data/spec/models/dividend_at_date_spec.rb +0 -1
  188. data/spec/models/encrypted_response_encrypted_message_data_spec.rb +0 -1
  189. data/spec/models/encrypted_response_spec.rb +0 -1
  190. data/spec/models/exchange_rate_pairs_spec.rb +0 -1
  191. data/spec/models/exchange_spec.rb +0 -1
  192. data/spec/models/{portfolio_group_spec.rb → figi_instrument_spec.rb} +8 -9
  193. data/spec/models/{calculated_trade_spec.rb → holdings_status_spec.rb} +8 -9
  194. data/spec/models/login_redirect_uri_spec.rb +0 -1
  195. data/spec/models/manual_trade_and_impact_spec.rb +0 -1
  196. data/spec/models/manual_trade_balance_spec.rb +0 -1
  197. data/spec/models/manual_trade_form_notional_value_spec.rb +23 -0
  198. data/spec/models/manual_trade_form_spec.rb +6 -7
  199. data/spec/models/{strategy_impact_spec.rb → manual_trade_form_with_options_spec.rb} +29 -18
  200. data/spec/models/{snap_trade_api_disclaimer_accept_status_spec.rb → manual_trade_form_with_options_stop_loss_spec.rb} +8 -9
  201. data/spec/models/manual_trade_form_with_options_take_profit_spec.rb +29 -0
  202. data/spec/models/{trade_impact_spec.rb → manual_trade_impact_spec.rb} +7 -8
  203. data/spec/models/manual_trade_spec.rb +0 -1
  204. data/spec/models/manual_trade_symbol_spec.rb +6 -7
  205. data/spec/models/model400_failed_request_response_spec.rb +0 -1
  206. data/spec/models/model401_failed_request_response_spec.rb +0 -1
  207. data/spec/models/model402_brokerage_auth_already_disabled_exception_spec.rb +35 -0
  208. data/spec/models/model402_brokerage_auth_disabled_response_spec.rb +35 -0
  209. data/spec/models/model403_failed_request_response_spec.rb +0 -1
  210. data/spec/models/{model_asset_class_details_spec.rb → model403_feature_not_enabled_response_spec.rb} +8 -9
  211. data/spec/models/model404_failed_request_response_spec.rb +0 -1
  212. data/spec/models/model425_failed_request_response_spec.rb +35 -0
  213. data/spec/models/model500_unexpected_exception_response_spec.rb +0 -1
  214. data/spec/models/monthly_dividends_spec.rb +0 -1
  215. data/spec/models/net_contributions_spec.rb +0 -1
  216. data/spec/models/net_dividend_spec.rb +0 -1
  217. data/spec/models/notional_value_spec.rb +26 -0
  218. data/spec/models/{model_portfolio_details_spec.rb → option_brokerage_symbol_spec.rb} +9 -10
  219. data/spec/models/option_chain_inner_chain_per_root_inner_chain_per_strike_price_inner_spec.rb +0 -1
  220. data/spec/models/option_chain_inner_chain_per_root_inner_spec.rb +0 -1
  221. data/spec/models/option_chain_inner_spec.rb +0 -1
  222. data/spec/models/option_leg_action_spec.rb +0 -1
  223. data/spec/models/option_leg_spec.rb +0 -1
  224. data/spec/models/option_strategy_legs_inner_spec.rb +0 -1
  225. data/spec/models/option_strategy_spec.rb +0 -1
  226. data/spec/models/option_type_spec.rb +0 -1
  227. data/spec/models/options_get_option_strategy_request_spec.rb +0 -1
  228. data/spec/models/options_place_option_strategy_request_spec.rb +0 -1
  229. data/spec/models/options_position_currency_spec.rb +0 -1
  230. data/spec/models/options_position_spec.rb +2 -3
  231. data/spec/models/options_symbol_spec.rb +0 -13
  232. data/spec/models/order_class_spec.rb +23 -0
  233. data/spec/models/order_type_strict_spec.rb +23 -0
  234. data/spec/models/{model_portfolio_asset_class_spec.rb → paginated_universal_activity_spec.rb} +8 -9
  235. data/spec/models/{model_asset_class_spec.rb → pagination_details_spec.rb} +8 -9
  236. data/spec/models/partner_data_spec.rb +12 -13
  237. data/spec/models/past_value_spec.rb +0 -1
  238. data/spec/models/performance_custom_spec.rb +0 -1
  239. data/spec/models/position_spec.rb +2 -3
  240. data/spec/models/position_symbol_spec.rb +3 -4
  241. data/spec/models/{portfolio_group_position_spec.rb → rate_of_return_object_spec.rb} +9 -10
  242. data/spec/models/rate_of_return_response_spec.rb +29 -0
  243. data/spec/models/recent_orders_response_spec.rb +29 -0
  244. data/spec/models/security_type_spec.rb +0 -1
  245. data/spec/models/session_event_spec.rb +0 -1
  246. data/spec/models/session_event_type_spec.rb +0 -1
  247. data/spec/models/snap_trade_holdings_account_spec.rb +0 -1
  248. data/spec/models/snap_trade_holdings_total_value_spec.rb +0 -1
  249. data/spec/models/snap_trade_login_user_request_body_spec.rb +0 -1
  250. data/spec/models/snap_trade_register_user_request_body_spec.rb +0 -1
  251. data/spec/models/status_spec.rb +0 -1
  252. data/spec/models/{amount_spec.rb → stop_loss_spec.rb} +8 -9
  253. data/spec/models/strategy_order_record_spec.rb +0 -1
  254. data/spec/models/strategy_order_record_status_spec.rb +0 -1
  255. data/spec/models/strategy_quotes_greek_spec.rb +0 -1
  256. data/spec/models/strategy_quotes_spec.rb +0 -1
  257. data/spec/models/strategy_type_spec.rb +0 -1
  258. data/spec/models/sub_period_return_rate_spec.rb +0 -1
  259. data/spec/models/symbol_currency_spec.rb +41 -0
  260. data/spec/models/{trade_spec.rb → symbol_exchange_spec.rb} +13 -14
  261. data/spec/models/symbol_figi_instrument_spec.rb +35 -0
  262. data/spec/models/symbol_query_spec.rb +0 -1
  263. data/spec/models/symbol_spec.rb +13 -2
  264. data/spec/models/symbols_quotes_inner_spec.rb +3 -4
  265. data/spec/models/{jwt_spec.rb → take_profit_spec.rb} +7 -8
  266. data/spec/models/time_in_force_strict_spec.rb +23 -0
  267. data/spec/models/timeframe_spec.rb +23 -0
  268. data/spec/models/trading_cancel_user_account_order_request_spec.rb +0 -1
  269. data/spec/models/transactions_status_spec.rb +6 -1
  270. data/spec/models/type_spec.rb +0 -1
  271. data/spec/models/{snap_trade_holdings_account_account_id_spec.rb → underlying_symbol_exchange_spec.rb} +13 -14
  272. data/spec/models/underlying_symbol_spec.rb +18 -1
  273. data/spec/models/{cash_restriction_spec.rb → underlying_symbol_type_spec.rb} +9 -16
  274. data/spec/models/universal_activity_spec.rb +15 -16
  275. data/spec/models/universal_symbol_spec.rb +12 -1
  276. data/spec/models/us_exchange_spec.rb +0 -1
  277. data/spec/models/user_i_dand_secret_spec.rb +0 -1
  278. data/spec/models/{excluded_asset_spec.rb → validated_trade_body_spec.rb} +7 -8
  279. data/spec/spec_helper.rb +0 -1
  280. metadata +203 -360
  281. data/docs/APIStatusApi.md +0 -57
  282. data/docs/Account.md +0 -38
  283. data/docs/AccountBalance.md +0 -18
  284. data/docs/AccountBalanceTotal.md +0 -20
  285. data/docs/AccountHoldings.md +0 -24
  286. data/docs/AccountHoldingsAccount.md +0 -26
  287. data/docs/AccountInformationApi.md +0 -544
  288. data/docs/AccountOrderRecord.md +0 -52
  289. data/docs/AccountOrderRecordStatus.md +0 -15
  290. data/docs/AccountSimple.md +0 -24
  291. data/docs/AccountSyncStatus.md +0 -18
  292. data/docs/Action.md +0 -15
  293. data/docs/Amount.md +0 -20
  294. data/docs/AuthType.md +0 -15
  295. data/docs/AuthenticationApi.md +0 -320
  296. data/docs/AuthenticationLoginSnapTradeUser200Response.md +0 -49
  297. data/docs/Balance.md +0 -20
  298. data/docs/Brokerage.md +0 -52
  299. data/docs/BrokerageAuthorization.md +0 -34
  300. data/docs/BrokerageAuthorizationType.md +0 -18
  301. data/docs/BrokerageAuthorizationTypeReadOnly.md +0 -24
  302. data/docs/BrokerageAuthorizationTypeReadOnlyBrokerage.md +0 -22
  303. data/docs/BrokerageAuthorizationTypeReadOnlyType.md +0 -15
  304. data/docs/BrokerageAuthorizationTypeType.md +0 -15
  305. data/docs/BrokerageSymbol.md +0 -28
  306. data/docs/BrokerageSymbolOptionSymbol.md +0 -34
  307. data/docs/BrokerageSymbolSymbol.md +0 -32
  308. data/docs/BrokerageType.md +0 -20
  309. data/docs/CalculatedTrade.md +0 -20
  310. data/docs/CashRestriction.md +0 -26
  311. data/docs/ConnectionPortalVersion.md +0 -15
  312. data/docs/ConnectionType.md +0 -15
  313. data/docs/ConnectionsApi.md +0 -265
  314. data/docs/ConnectionsSessionEvents200ResponseInner.md +0 -30
  315. data/docs/Currency.md +0 -22
  316. data/docs/DeleteUserResponse.md +0 -20
  317. data/docs/DividendAtDate.md +0 -22
  318. data/docs/EncryptedResponse.md +0 -20
  319. data/docs/EncryptedResponseEncryptedMessageData.md +0 -22
  320. data/docs/ErrorLogsApi.md +0 -68
  321. data/docs/Exchange.md +0 -32
  322. data/docs/ExchangeRatePairs.md +0 -22
  323. data/docs/ExcludedAsset.md +0 -18
  324. data/docs/JWT.md +0 -18
  325. data/docs/LoginRedirectURI.md +0 -20
  326. data/docs/ManualTrade.md +0 -32
  327. data/docs/ManualTradeAndImpact.md +0 -22
  328. data/docs/ManualTradeBalance.md +0 -22
  329. data/docs/ManualTradeForm.md +0 -34
  330. data/docs/ManualTradeSymbol.md +0 -28
  331. data/docs/Model400FailedRequestResponse.md +0 -20
  332. data/docs/Model401FailedRequestResponse.md +0 -20
  333. data/docs/Model403FailedRequestResponse.md +0 -20
  334. data/docs/Model404FailedRequestResponse.md +0 -20
  335. data/docs/Model500UnexpectedExceptionResponse.md +0 -22
  336. data/docs/ModelAssetClass.md +0 -20
  337. data/docs/ModelAssetClassDetails.md +0 -20
  338. data/docs/ModelAssetClassTarget.md +0 -18
  339. data/docs/ModelPortfolio.md +0 -22
  340. data/docs/ModelPortfolioAssetClass.md +0 -20
  341. data/docs/ModelPortfolioDetails.md +0 -22
  342. data/docs/ModelPortfolioSecurity.md +0 -20
  343. data/docs/ModelType.md +0 -15
  344. data/docs/MonthlyDividends.md +0 -20
  345. data/docs/NetContributions.md +0 -22
  346. data/docs/NetDividend.md +0 -22
  347. data/docs/OptionChainInner.md +0 -26
  348. data/docs/OptionChainInnerChainPerRootInner.md +0 -22
  349. data/docs/OptionChainInnerChainPerRootInnerChainPerStrikePriceInner.md +0 -22
  350. data/docs/OptionLeg.md +0 -22
  351. data/docs/OptionLegAction.md +0 -15
  352. data/docs/OptionStrategy.md +0 -26
  353. data/docs/OptionStrategyLegsInner.md +0 -24
  354. data/docs/OptionType.md +0 -15
  355. data/docs/OptionsApi.md +0 -390
  356. data/docs/OptionsGetOptionStrategyRequest.md +0 -22
  357. data/docs/OptionsHoldings.md +0 -28
  358. data/docs/OptionsPlaceOptionStrategyRequest.md +0 -22
  359. data/docs/OptionsPosition.md +0 -26
  360. data/docs/OptionsPositionCurrency.md +0 -22
  361. data/docs/OptionsSymbol.md +0 -34
  362. data/docs/OrderType.md +0 -15
  363. data/docs/PartnerData.md +0 -40
  364. data/docs/PastValue.md +0 -22
  365. data/docs/PerformanceCustom.md +0 -54
  366. data/docs/PortfolioGroup.md +0 -20
  367. data/docs/PortfolioGroupInfo.md +0 -38
  368. data/docs/PortfolioGroupPosition.md +0 -22
  369. data/docs/PortfolioGroupSettings.md +0 -26
  370. data/docs/Position.md +0 -28
  371. data/docs/PositionSymbol.md +0 -28
  372. data/docs/RedirectTokenandPin.md +0 -20
  373. data/docs/ReferenceDataApi.md +0 -597
  374. data/docs/SecurityType.md +0 -24
  375. data/docs/SessionEvent.md +0 -30
  376. data/docs/SessionEventType.md +0 -15
  377. data/docs/SnapTradeAPIDisclaimerAcceptStatus.md +0 -20
  378. data/docs/SnapTradeHoldingsAccount.md +0 -32
  379. data/docs/SnapTradeHoldingsAccountAccountId.md +0 -34
  380. data/docs/SnapTradeHoldingsTotalValue.md +0 -20
  381. data/docs/SnapTradeLoginUserRequestBody.md +0 -28
  382. data/docs/SnapTradeRegisterUserRequestBody.md +0 -18
  383. data/docs/State.md +0 -15
  384. data/docs/Status.md +0 -22
  385. data/docs/StrategyImpact.md +0 -38
  386. data/docs/StrategyImpactLegsInner.md +0 -30
  387. data/docs/StrategyOrderPlace.md +0 -20
  388. data/docs/StrategyOrderPlaceOrdersInner.md +0 -102
  389. data/docs/StrategyOrderPlaceOrdersInnerLegsInner.md +0 -30
  390. data/docs/StrategyOrderRecord.md +0 -38
  391. data/docs/StrategyOrderRecordStatus.md +0 -15
  392. data/docs/StrategyQuotes.md +0 -28
  393. data/docs/StrategyQuotesGreek.md +0 -26
  394. data/docs/StrategyType.md +0 -15
  395. data/docs/SubPeriodReturnRate.md +0 -22
  396. data/docs/Symbol.md +0 -30
  397. data/docs/SymbolQuery.md +0 -18
  398. data/docs/SymbolsQuotesInner.md +0 -28
  399. data/docs/TargetAsset.md +0 -28
  400. data/docs/TimeInForce.md +0 -15
  401. data/docs/Trade.md +0 -32
  402. data/docs/TradeAction.md +0 -15
  403. data/docs/TradeExecutionStatus.md +0 -34
  404. data/docs/TradeExecutionStatusAction.md +0 -15
  405. data/docs/TradeImpact.md +0 -26
  406. data/docs/TradingApi.md +0 -486
  407. data/docs/TradingCancelUserAccountOrderRequest.md +0 -18
  408. data/docs/TradingPlaceOCOOrderRequest.md +0 -20
  409. data/docs/TransactionsAndReportingApi.md +0 -183
  410. data/docs/TransactionsStatus.md +0 -20
  411. data/docs/Type.md +0 -15
  412. data/docs/USExchange.md +0 -34
  413. data/docs/UnderlyingSymbol.md +0 -30
  414. data/docs/UniversalActivity.md +0 -50
  415. data/docs/UniversalSymbol.md +0 -32
  416. data/docs/UniversalSymbolTicker.md +0 -32
  417. data/docs/UserErrorLog.md +0 -28
  418. data/docs/UserIDandSecret.md +0 -20
  419. data/docs/UserSettings.md +0 -36
  420. data/lib/snaptrade/api/error_logs_api.rb +0 -110
  421. data/lib/snaptrade/models/action.rb +0 -38
  422. data/lib/snaptrade/models/brokerage_authorization_type_read_only_type.rb +0 -38
  423. data/lib/snaptrade/models/cash_restriction.rb +0 -254
  424. data/lib/snaptrade/models/model_asset_class_details.rb +0 -228
  425. data/lib/snaptrade/models/model_portfolio_asset_class.rb +0 -250
  426. data/lib/snaptrade/models/model_portfolio_details.rb +0 -239
  427. data/lib/snaptrade/models/portfolio_group_info.rb +0 -326
  428. data/lib/snaptrade/models/portfolio_group_settings.rb +0 -277
  429. data/lib/snaptrade/models/redirect_tokenand_pin.rb +0 -227
  430. data/lib/snaptrade/models/state.rb +0 -41
  431. data/lib/snaptrade/models/strategy_impact.rb +0 -310
  432. data/lib/snaptrade/models/strategy_impact_legs_inner.rb +0 -271
  433. data/lib/snaptrade/models/strategy_order_place_orders_inner.rb +0 -597
  434. data/lib/snaptrade/models/strategy_order_place_orders_inner_legs_inner.rb +0 -271
  435. data/lib/snaptrade/models/trade_execution_status.rb +0 -296
  436. data/lib/snaptrade/models/trading_place_oco_order_request.rb +0 -230
  437. data/lib/snaptrade/models/user_error_log.rb +0 -263
  438. data/lib/snaptrade/models/user_settings.rb +0 -299
  439. data/spec/api/error_logs_api_spec.rb +0 -43
  440. data/spec/models/action_spec.rb +0 -24
  441. data/spec/models/brokerage_authorization_type_read_only_type_spec.rb +0 -24
  442. data/spec/models/brokerage_authorization_type_type_spec.rb +0 -24
  443. data/spec/models/brokerage_symbol_spec.rb +0 -60
  444. data/spec/models/model_asset_class_target_spec.rb +0 -30
  445. data/spec/models/model_portfolio_security_spec.rb +0 -36
  446. data/spec/models/model_type_spec.rb +0 -24
  447. data/spec/models/options_holdings_spec.rb +0 -60
  448. data/spec/models/order_type_spec.rb +0 -24
  449. data/spec/models/portfolio_group_settings_spec.rb +0 -54
  450. data/spec/models/redirect_tokenand_pin_spec.rb +0 -36
  451. data/spec/models/state_spec.rb +0 -24
  452. data/spec/models/strategy_order_place_orders_inner_legs_inner_spec.rb +0 -66
  453. data/spec/models/strategy_order_place_orders_inner_spec.rb +0 -282
  454. data/spec/models/strategy_order_place_spec.rb +0 -36
  455. data/spec/models/target_asset_spec.rb +0 -60
  456. data/spec/models/time_in_force_spec.rb +0 -24
  457. data/spec/models/trade_action_spec.rb +0 -24
  458. data/spec/models/trade_execution_status_action_spec.rb +0 -24
  459. data/spec/models/trade_execution_status_spec.rb +0 -78
  460. data/spec/models/trading_place_oco_order_request_spec.rb +0 -36
  461. data/spec/models/user_error_log_spec.rb +0 -60
  462. data/spec/models/user_settings_spec.rb +0 -84
data/README.md CHANGED
@@ -1,223 +1,2010 @@
1
- # snaptrade
1
+ <div align="center">
2
+
3
+ [![Visit SnapTrade](./header.png)](https://snaptrade.com)
4
+
5
+ # [SnapTrade](https://snaptrade.com)<a id="snaptrade"></a>
2
6
 
3
7
  Connect brokerage accounts to your app for live positions and trading
4
8
 
5
- For more information, please visit [https://snaptrade.com/](https://snaptrade.com/)
9
+ [![npm](https://img.shields.io/badge/gem-v2.0.77-blue)](https://rubygems.org/gems/snaptrade/versions/2.0.77)
10
+ [![More Info](https://img.shields.io/badge/More%20Info-Click%20Here-orange)](https://snaptrade.com/)
11
+
12
+ </div>
13
+
14
+ ## Table of Contents<a id="table-of-contents"></a>
6
15
 
7
- ## Installation
16
+ <!-- toc -->
17
+
18
+ - [Installation](#installation)
19
+ - [Getting Started](#getting-started)
20
+ - [Raw HTTP Response](#raw-http-response)
21
+ - [Reference](#reference)
22
+ * [`snaptrade.account_information.get_account_activities`](#snaptradeaccount_informationget_account_activities)
23
+ * [`snaptrade.account_information.get_all_user_holdings`](#snaptradeaccount_informationget_all_user_holdings)
24
+ * [`snaptrade.account_information.get_user_account_balance`](#snaptradeaccount_informationget_user_account_balance)
25
+ * [`snaptrade.account_information.get_user_account_details`](#snaptradeaccount_informationget_user_account_details)
26
+ * [`snaptrade.account_information.get_user_account_orders`](#snaptradeaccount_informationget_user_account_orders)
27
+ * [`snaptrade.account_information.get_user_account_positions`](#snaptradeaccount_informationget_user_account_positions)
28
+ * [`snaptrade.account_information.get_user_account_recent_orders`](#snaptradeaccount_informationget_user_account_recent_orders)
29
+ * [`snaptrade.account_information.get_user_account_return_rates`](#snaptradeaccount_informationget_user_account_return_rates)
30
+ * [`snaptrade.account_information.get_user_holdings`](#snaptradeaccount_informationget_user_holdings)
31
+ * [`snaptrade.account_information.list_user_accounts`](#snaptradeaccount_informationlist_user_accounts)
32
+ * [`snaptrade.account_information.update_user_account`](#snaptradeaccount_informationupdate_user_account)
33
+ * [`snaptrade.api_status.check`](#snaptradeapi_statuscheck)
34
+ * [`snaptrade.authentication.delete_snap_trade_user`](#snaptradeauthenticationdelete_snap_trade_user)
35
+ * [`snaptrade.authentication.list_snap_trade_users`](#snaptradeauthenticationlist_snap_trade_users)
36
+ * [`snaptrade.authentication.login_snap_trade_user`](#snaptradeauthenticationlogin_snap_trade_user)
37
+ * [`snaptrade.authentication.register_snap_trade_user`](#snaptradeauthenticationregister_snap_trade_user)
38
+ * [`snaptrade.authentication.reset_snap_trade_user_secret`](#snaptradeauthenticationreset_snap_trade_user_secret)
39
+ * [`snaptrade.connections.detail_brokerage_authorization`](#snaptradeconnectionsdetail_brokerage_authorization)
40
+ * [`snaptrade.connections.disable_brokerage_authorization`](#snaptradeconnectionsdisable_brokerage_authorization)
41
+ * [`snaptrade.connections.list_brokerage_authorizations`](#snaptradeconnectionslist_brokerage_authorizations)
42
+ * [`snaptrade.connections.refresh_brokerage_authorization`](#snaptradeconnectionsrefresh_brokerage_authorization)
43
+ * [`snaptrade.connections.remove_brokerage_authorization`](#snaptradeconnectionsremove_brokerage_authorization)
44
+ * [`snaptrade.connections.return_rates`](#snaptradeconnectionsreturn_rates)
45
+ * [`snaptrade.connections.session_events`](#snaptradeconnectionssession_events)
46
+ * [`snaptrade.options.get_option_strategy`](#snaptradeoptionsget_option_strategy)
47
+ * [`snaptrade.options.get_options_chain`](#snaptradeoptionsget_options_chain)
48
+ * [`snaptrade.options.get_options_strategy_quote`](#snaptradeoptionsget_options_strategy_quote)
49
+ * [`snaptrade.options.list_option_holdings`](#snaptradeoptionslist_option_holdings)
50
+ * [`snaptrade.options.place_option_strategy`](#snaptradeoptionsplace_option_strategy)
51
+ * [`snaptrade.reference_data.get_currency_exchange_rate_pair`](#snaptradereference_dataget_currency_exchange_rate_pair)
52
+ * [`snaptrade.reference_data.get_partner_info`](#snaptradereference_dataget_partner_info)
53
+ * [`snaptrade.reference_data.get_security_types`](#snaptradereference_dataget_security_types)
54
+ * [`snaptrade.reference_data.get_stock_exchanges`](#snaptradereference_dataget_stock_exchanges)
55
+ * [`snaptrade.reference_data.get_symbols`](#snaptradereference_dataget_symbols)
56
+ * [`snaptrade.reference_data.get_symbols_by_ticker`](#snaptradereference_dataget_symbols_by_ticker)
57
+ * [`snaptrade.reference_data.list_all_brokerage_authorization_type`](#snaptradereference_datalist_all_brokerage_authorization_type)
58
+ * [`snaptrade.reference_data.list_all_brokerages`](#snaptradereference_datalist_all_brokerages)
59
+ * [`snaptrade.reference_data.list_all_currencies`](#snaptradereference_datalist_all_currencies)
60
+ * [`snaptrade.reference_data.list_all_currencies_rates`](#snaptradereference_datalist_all_currencies_rates)
61
+ * [`snaptrade.reference_data.symbol_search_user_account`](#snaptradereference_datasymbol_search_user_account)
62
+ * [`snaptrade.trading.cancel_user_account_order`](#snaptradetradingcancel_user_account_order)
63
+ * [`snaptrade.trading.get_order_impact`](#snaptradetradingget_order_impact)
64
+ * [`snaptrade.trading.get_user_account_quotes`](#snaptradetradingget_user_account_quotes)
65
+ * [`snaptrade.trading.place_force_order`](#snaptradetradingplace_force_order)
66
+ * [`snaptrade.trading.place_order`](#snaptradetradingplace_order)
67
+ * [`snaptrade.transactions_and_reporting.get_activities`](#snaptradetransactions_and_reportingget_activities)
68
+ * [`snaptrade.transactions_and_reporting.get_reporting_custom_range`](#snaptradetransactions_and_reportingget_reporting_custom_range)
69
+
70
+ <!-- tocstop -->
71
+
72
+ ## Installation<a id="installation"></a>
8
73
 
9
74
  Add to Gemfile:
10
75
 
11
76
  ```ruby
12
- gem 'snaptrade', '~> 1.17.10'
77
+ gem 'snaptrade', '~> 2.0.77'
13
78
  ```
14
79
 
15
- ## Getting Started
80
+ ## Getting Started<a id="getting-started"></a>
16
81
 
17
82
  ```ruby
18
83
  require 'snaptrade'
19
84
 
20
- SnapTrade.client_id = "YOUR_CLIENT_ID"
21
- SnapTrade.consumer_key = "YOUR_CONSUMER_KEY"
22
-
23
- user_id = "John.doe@snaptrade.com"
24
- user_secret = "USERSECRET123"
25
- brokerage_authorizations = "917c8734-8470-4a3e-a18f-57c3f2ee6631"
26
-
27
- begin
28
- # List all accounts for the user, plus balances, positions, and orders for each account.
29
- result = SnapTrade::AccountInformation.get_all_user_holdings(
30
- user_id: user_id,
31
- user_secret: user_secret,
32
- brokerage_authorizations: brokerage_authorizations,
33
- )
34
- p result
35
- rescue SnapTrade::ApiError => e
36
- puts "Exception when calling SnapTrade::AccountInformation.get_all_user_holdings: #{e}"
37
- end
38
- ```
39
-
40
- ## Documentation for API Endpoints
41
-
42
- All URIs are relative to *https://api.snaptrade.com/api/v1*
43
-
44
- Class | Method | HTTP request | Description
45
- ------------ | ------------- | ------------- | -------------
46
- *SnapTrade::AccountInformationApi* | [**get_all_user_holdings**](docs/AccountInformationApi.md#get_all_user_holdings) | **GET** /holdings | List all accounts for the user, plus balances, positions, and orders for each account.
47
- *SnapTrade::AccountInformationApi* | [**get_user_account_balance**](docs/AccountInformationApi.md#get_user_account_balance) | **GET** /accounts/{accountId}/balances | List account balances
48
- *SnapTrade::AccountInformationApi* | [**get_user_account_details**](docs/AccountInformationApi.md#get_user_account_details) | **GET** /accounts/{accountId} | Return details of a specific investment account
49
- *SnapTrade::AccountInformationApi* | [**get_user_account_orders**](docs/AccountInformationApi.md#get_user_account_orders) | **GET** /accounts/{accountId}/orders | List account orders
50
- *SnapTrade::AccountInformationApi* | [**get_user_account_positions**](docs/AccountInformationApi.md#get_user_account_positions) | **GET** /accounts/{accountId}/positions | List account positions
51
- *SnapTrade::AccountInformationApi* | [**get_user_holdings**](docs/AccountInformationApi.md#get_user_holdings) | **GET** /accounts/{accountId}/holdings | List balances, positions and orders for the specified account
52
- *SnapTrade::AccountInformationApi* | [**list_user_accounts**](docs/AccountInformationApi.md#list_user_accounts) | **GET** /accounts | List accounts
53
- *SnapTrade::AccountInformationApi* | [**update_user_account**](docs/AccountInformationApi.md#update_user_account) | **PUT** /accounts/{accountId} | Update details of an investment account
54
- *SnapTrade::APIStatusApi* | [**check**](docs/APIStatusApi.md#check) | **GET** / | Get API Status
55
- *SnapTrade::AuthenticationApi* | [**delete_snap_trade_user**](docs/AuthenticationApi.md#delete_snap_trade_user) | **DELETE** /snapTrade/deleteUser | Delete SnapTrade user
56
- *SnapTrade::AuthenticationApi* | [**get_user_jwt**](docs/AuthenticationApi.md#get_user_jwt) | **GET** /snapTrade/encryptedJWT | Generate encrypted JWT token
57
- *SnapTrade::AuthenticationApi* | [**list_snap_trade_users**](docs/AuthenticationApi.md#list_snap_trade_users) | **GET** /snapTrade/listUsers | List SnapTrade users
58
- *SnapTrade::AuthenticationApi* | [**login_snap_trade_user**](docs/AuthenticationApi.md#login_snap_trade_user) | **POST** /snapTrade/login | Login user & generate connection link
59
- *SnapTrade::AuthenticationApi* | [**register_snap_trade_user**](docs/AuthenticationApi.md#register_snap_trade_user) | **POST** /snapTrade/registerUser | Create SnapTrade user
60
- *SnapTrade::ConnectionsApi* | [**detail_brokerage_authorization**](docs/ConnectionsApi.md#detail_brokerage_authorization) | **GET** /authorizations/{authorizationId} | Get brokerage authorization details
61
- *SnapTrade::ConnectionsApi* | [**list_brokerage_authorizations**](docs/ConnectionsApi.md#list_brokerage_authorizations) | **GET** /authorizations | List all brokerage authorizations for the user
62
- *SnapTrade::ConnectionsApi* | [**remove_brokerage_authorization**](docs/ConnectionsApi.md#remove_brokerage_authorization) | **DELETE** /authorizations/{authorizationId} | Delete brokerage authorization
63
- *SnapTrade::ConnectionsApi* | [**session_events**](docs/ConnectionsApi.md#session_events) | **GET** /sessionEvents | List all session events for the partner
64
- *SnapTrade::ErrorLogsApi* | [**list_user_errors**](docs/ErrorLogsApi.md#list_user_errors) | **GET** /snapTrade/listUserErrors | Retrieve error logs on behalf of your SnapTrade users
65
- *SnapTrade::OptionsApi* | [**get_option_strategy**](docs/OptionsApi.md#get_option_strategy) | **POST** /accounts/{accountId}/optionStrategy | Creates an option strategy object that will be used to place an option strategy order
66
- *SnapTrade::OptionsApi* | [**get_options_chain**](docs/OptionsApi.md#get_options_chain) | **GET** /accounts/{accountId}/optionsChain | Get the options chain
67
- *SnapTrade::OptionsApi* | [**get_options_strategy_quote**](docs/OptionsApi.md#get_options_strategy_quote) | **GET** /accounts/{accountId}/optionStrategy/{optionStrategyId} | Get latest market data of option strategy
68
- *SnapTrade::OptionsApi* | [**list_option_holdings**](docs/OptionsApi.md#list_option_holdings) | **GET** /accounts/{accountId}/options | Get the options holdings in the account
69
- *SnapTrade::OptionsApi* | [**place_option_strategy**](docs/OptionsApi.md#place_option_strategy) | **POST** /accounts/{accountId}/optionStrategy/{optionStrategyId}/execute | Place an option strategy order on the brokerage
70
- *SnapTrade::ReferenceDataApi* | [**get_currency_exchange_rate_pair**](docs/ReferenceDataApi.md#get_currency_exchange_rate_pair) | **GET** /currencies/rates/{currencyPair} | Return the exchange rate of a currency pair
71
- *SnapTrade::ReferenceDataApi* | [**get_partner_info**](docs/ReferenceDataApi.md#get_partner_info) | **GET** /snapTrade/partners | Get metadata related to Snaptrade partner
72
- *SnapTrade::ReferenceDataApi* | [**get_security_types**](docs/ReferenceDataApi.md#get_security_types) | **GET** /securityTypes | List of all security types
73
- *SnapTrade::ReferenceDataApi* | [**get_stock_exchanges**](docs/ReferenceDataApi.md#get_stock_exchanges) | **GET** /exchanges | List exchanges
74
- *SnapTrade::ReferenceDataApi* | [**get_symbols**](docs/ReferenceDataApi.md#get_symbols) | **POST** /symbols | Search for symbols
75
- *SnapTrade::ReferenceDataApi* | [**get_symbols_by_ticker**](docs/ReferenceDataApi.md#get_symbols_by_ticker) | **GET** /symbols/{ticker} | Get details of a symbol by the ticker
76
- *SnapTrade::ReferenceDataApi* | [**list_all_brokerage_authorization_type**](docs/ReferenceDataApi.md#list_all_brokerage_authorization_type) | **GET** /brokerageAuthorizationTypes | List of all brokerage authorization types
77
- *SnapTrade::ReferenceDataApi* | [**list_all_brokerages**](docs/ReferenceDataApi.md#list_all_brokerages) | **GET** /brokerages | List brokerages
78
- *SnapTrade::ReferenceDataApi* | [**list_all_currencies**](docs/ReferenceDataApi.md#list_all_currencies) | **GET** /currencies | List currencies
79
- *SnapTrade::ReferenceDataApi* | [**list_all_currencies_rates**](docs/ReferenceDataApi.md#list_all_currencies_rates) | **GET** /currencies/rates | List currency exchange rates
80
- *SnapTrade::ReferenceDataApi* | [**symbol_search_user_account**](docs/ReferenceDataApi.md#symbol_search_user_account) | **POST** /accounts/{accountId}/symbols | Search for symbols available in an account
81
- *SnapTrade::TradingApi* | [**cancel_user_account_order**](docs/TradingApi.md#cancel_user_account_order) | **POST** /accounts/{accountId}/orders/cancel | Cancel open order in account
82
- *SnapTrade::TradingApi* | [**get_order_impact**](docs/TradingApi.md#get_order_impact) | **POST** /trade/impact | Check impact of trades on account.
83
- *SnapTrade::TradingApi* | [**get_user_account_quotes**](docs/TradingApi.md#get_user_account_quotes) | **GET** /accounts/{accountId}/quotes | Get symbol quotes
84
- *SnapTrade::TradingApi* | [**place_force_order**](docs/TradingApi.md#place_force_order) | **POST** /trade/place | Place a trade with NO validation.
85
- *SnapTrade::TradingApi* | [**place_oco_order**](docs/TradingApi.md#place_oco_order) | **POST** /trade/oco | Place a OCO (One Cancels Other) order
86
- *SnapTrade::TradingApi* | [**place_order**](docs/TradingApi.md#place_order) | **POST** /trade/{tradeId} | Place order
87
- *SnapTrade::TransactionsAndReportingApi* | [**get_activities**](docs/TransactionsAndReportingApi.md#get_activities) | **GET** /activities | Get transaction history for a user
88
- *SnapTrade::TransactionsAndReportingApi* | [**get_reporting_custom_range**](docs/TransactionsAndReportingApi.md#get_reporting_custom_range) | **GET** /performance/custom | Get performance information for a specific timeframe
89
-
90
-
91
- ## Documentation for Models
92
-
93
- - [SnapTrade::Account](docs/Account.md)
94
- - [SnapTrade::AccountBalance](docs/AccountBalance.md)
95
- - [SnapTrade::AccountBalanceTotal](docs/AccountBalanceTotal.md)
96
- - [SnapTrade::AccountHoldings](docs/AccountHoldings.md)
97
- - [SnapTrade::AccountHoldingsAccount](docs/AccountHoldingsAccount.md)
98
- - [SnapTrade::AccountOrderRecord](docs/AccountOrderRecord.md)
99
- - [SnapTrade::AccountOrderRecordStatus](docs/AccountOrderRecordStatus.md)
100
- - [SnapTrade::AccountSimple](docs/AccountSimple.md)
101
- - [SnapTrade::AccountSyncStatus](docs/AccountSyncStatus.md)
102
- - [SnapTrade::Action](docs/Action.md)
103
- - [SnapTrade::Amount](docs/Amount.md)
104
- - [SnapTrade::AuthType](docs/AuthType.md)
105
- - [SnapTrade::AuthenticationLoginSnapTradeUser200Response](docs/AuthenticationLoginSnapTradeUser200Response.md)
106
- - [SnapTrade::Balance](docs/Balance.md)
107
- - [SnapTrade::Brokerage](docs/Brokerage.md)
108
- - [SnapTrade::BrokerageAuthorization](docs/BrokerageAuthorization.md)
109
- - [SnapTrade::BrokerageAuthorizationType](docs/BrokerageAuthorizationType.md)
110
- - [SnapTrade::BrokerageAuthorizationTypeReadOnly](docs/BrokerageAuthorizationTypeReadOnly.md)
111
- - [SnapTrade::BrokerageAuthorizationTypeReadOnlyBrokerage](docs/BrokerageAuthorizationTypeReadOnlyBrokerage.md)
112
- - [SnapTrade::BrokerageAuthorizationTypeReadOnlyType](docs/BrokerageAuthorizationTypeReadOnlyType.md)
113
- - [SnapTrade::BrokerageAuthorizationTypeType](docs/BrokerageAuthorizationTypeType.md)
114
- - [SnapTrade::BrokerageSymbol](docs/BrokerageSymbol.md)
115
- - [SnapTrade::BrokerageSymbolOptionSymbol](docs/BrokerageSymbolOptionSymbol.md)
116
- - [SnapTrade::BrokerageSymbolSymbol](docs/BrokerageSymbolSymbol.md)
117
- - [SnapTrade::BrokerageType](docs/BrokerageType.md)
118
- - [SnapTrade::CalculatedTrade](docs/CalculatedTrade.md)
119
- - [SnapTrade::CashRestriction](docs/CashRestriction.md)
120
- - [SnapTrade::ConnectionPortalVersion](docs/ConnectionPortalVersion.md)
121
- - [SnapTrade::ConnectionType](docs/ConnectionType.md)
122
- - [SnapTrade::ConnectionsSessionEvents200ResponseInner](docs/ConnectionsSessionEvents200ResponseInner.md)
123
- - [SnapTrade::Currency](docs/Currency.md)
124
- - [SnapTrade::DeleteUserResponse](docs/DeleteUserResponse.md)
125
- - [SnapTrade::DividendAtDate](docs/DividendAtDate.md)
126
- - [SnapTrade::EncryptedResponse](docs/EncryptedResponse.md)
127
- - [SnapTrade::EncryptedResponseEncryptedMessageData](docs/EncryptedResponseEncryptedMessageData.md)
128
- - [SnapTrade::Exchange](docs/Exchange.md)
129
- - [SnapTrade::ExchangeRatePairs](docs/ExchangeRatePairs.md)
130
- - [SnapTrade::ExcludedAsset](docs/ExcludedAsset.md)
131
- - [SnapTrade::JWT](docs/JWT.md)
132
- - [SnapTrade::LoginRedirectURI](docs/LoginRedirectURI.md)
133
- - [SnapTrade::ManualTrade](docs/ManualTrade.md)
134
- - [SnapTrade::ManualTradeAndImpact](docs/ManualTradeAndImpact.md)
135
- - [SnapTrade::ManualTradeBalance](docs/ManualTradeBalance.md)
136
- - [SnapTrade::ManualTradeForm](docs/ManualTradeForm.md)
137
- - [SnapTrade::ManualTradeSymbol](docs/ManualTradeSymbol.md)
138
- - [SnapTrade::Model400FailedRequestResponse](docs/Model400FailedRequestResponse.md)
139
- - [SnapTrade::Model401FailedRequestResponse](docs/Model401FailedRequestResponse.md)
140
- - [SnapTrade::Model403FailedRequestResponse](docs/Model403FailedRequestResponse.md)
141
- - [SnapTrade::Model404FailedRequestResponse](docs/Model404FailedRequestResponse.md)
142
- - [SnapTrade::Model500UnexpectedExceptionResponse](docs/Model500UnexpectedExceptionResponse.md)
143
- - [SnapTrade::ModelAssetClass](docs/ModelAssetClass.md)
144
- - [SnapTrade::ModelAssetClassDetails](docs/ModelAssetClassDetails.md)
145
- - [SnapTrade::ModelAssetClassTarget](docs/ModelAssetClassTarget.md)
146
- - [SnapTrade::ModelPortfolio](docs/ModelPortfolio.md)
147
- - [SnapTrade::ModelPortfolioAssetClass](docs/ModelPortfolioAssetClass.md)
148
- - [SnapTrade::ModelPortfolioDetails](docs/ModelPortfolioDetails.md)
149
- - [SnapTrade::ModelPortfolioSecurity](docs/ModelPortfolioSecurity.md)
150
- - [SnapTrade::ModelType](docs/ModelType.md)
151
- - [SnapTrade::MonthlyDividends](docs/MonthlyDividends.md)
152
- - [SnapTrade::NetContributions](docs/NetContributions.md)
153
- - [SnapTrade::NetDividend](docs/NetDividend.md)
154
- - [SnapTrade::OptionChainInner](docs/OptionChainInner.md)
155
- - [SnapTrade::OptionChainInnerChainPerRootInner](docs/OptionChainInnerChainPerRootInner.md)
156
- - [SnapTrade::OptionChainInnerChainPerRootInnerChainPerStrikePriceInner](docs/OptionChainInnerChainPerRootInnerChainPerStrikePriceInner.md)
157
- - [SnapTrade::OptionLeg](docs/OptionLeg.md)
158
- - [SnapTrade::OptionLegAction](docs/OptionLegAction.md)
159
- - [SnapTrade::OptionStrategy](docs/OptionStrategy.md)
160
- - [SnapTrade::OptionStrategyLegsInner](docs/OptionStrategyLegsInner.md)
161
- - [SnapTrade::OptionType](docs/OptionType.md)
162
- - [SnapTrade::OptionsGetOptionStrategyRequest](docs/OptionsGetOptionStrategyRequest.md)
163
- - [SnapTrade::OptionsHoldings](docs/OptionsHoldings.md)
164
- - [SnapTrade::OptionsPlaceOptionStrategyRequest](docs/OptionsPlaceOptionStrategyRequest.md)
165
- - [SnapTrade::OptionsPosition](docs/OptionsPosition.md)
166
- - [SnapTrade::OptionsPositionCurrency](docs/OptionsPositionCurrency.md)
167
- - [SnapTrade::OptionsSymbol](docs/OptionsSymbol.md)
168
- - [SnapTrade::OrderType](docs/OrderType.md)
169
- - [SnapTrade::PartnerData](docs/PartnerData.md)
170
- - [SnapTrade::PastValue](docs/PastValue.md)
171
- - [SnapTrade::PerformanceCustom](docs/PerformanceCustom.md)
172
- - [SnapTrade::PortfolioGroup](docs/PortfolioGroup.md)
173
- - [SnapTrade::PortfolioGroupInfo](docs/PortfolioGroupInfo.md)
174
- - [SnapTrade::PortfolioGroupPosition](docs/PortfolioGroupPosition.md)
175
- - [SnapTrade::PortfolioGroupSettings](docs/PortfolioGroupSettings.md)
176
- - [SnapTrade::Position](docs/Position.md)
177
- - [SnapTrade::PositionSymbol](docs/PositionSymbol.md)
178
- - [SnapTrade::RedirectTokenandPin](docs/RedirectTokenandPin.md)
179
- - [SnapTrade::SecurityType](docs/SecurityType.md)
180
- - [SnapTrade::SessionEvent](docs/SessionEvent.md)
181
- - [SnapTrade::SessionEventType](docs/SessionEventType.md)
182
- - [SnapTrade::SnapTradeAPIDisclaimerAcceptStatus](docs/SnapTradeAPIDisclaimerAcceptStatus.md)
183
- - [SnapTrade::SnapTradeHoldingsAccount](docs/SnapTradeHoldingsAccount.md)
184
- - [SnapTrade::SnapTradeHoldingsAccountAccountId](docs/SnapTradeHoldingsAccountAccountId.md)
185
- - [SnapTrade::SnapTradeHoldingsTotalValue](docs/SnapTradeHoldingsTotalValue.md)
186
- - [SnapTrade::SnapTradeLoginUserRequestBody](docs/SnapTradeLoginUserRequestBody.md)
187
- - [SnapTrade::SnapTradeRegisterUserRequestBody](docs/SnapTradeRegisterUserRequestBody.md)
188
- - [SnapTrade::State](docs/State.md)
189
- - [SnapTrade::Status](docs/Status.md)
190
- - [SnapTrade::StrategyImpact](docs/StrategyImpact.md)
191
- - [SnapTrade::StrategyImpactLegsInner](docs/StrategyImpactLegsInner.md)
192
- - [SnapTrade::StrategyOrderPlace](docs/StrategyOrderPlace.md)
193
- - [SnapTrade::StrategyOrderPlaceOrdersInner](docs/StrategyOrderPlaceOrdersInner.md)
194
- - [SnapTrade::StrategyOrderPlaceOrdersInnerLegsInner](docs/StrategyOrderPlaceOrdersInnerLegsInner.md)
195
- - [SnapTrade::StrategyOrderRecord](docs/StrategyOrderRecord.md)
196
- - [SnapTrade::StrategyOrderRecordStatus](docs/StrategyOrderRecordStatus.md)
197
- - [SnapTrade::StrategyQuotes](docs/StrategyQuotes.md)
198
- - [SnapTrade::StrategyQuotesGreek](docs/StrategyQuotesGreek.md)
199
- - [SnapTrade::StrategyType](docs/StrategyType.md)
200
- - [SnapTrade::SubPeriodReturnRate](docs/SubPeriodReturnRate.md)
201
- - [SnapTrade::Symbol](docs/Symbol.md)
202
- - [SnapTrade::SymbolQuery](docs/SymbolQuery.md)
203
- - [SnapTrade::SymbolsQuotesInner](docs/SymbolsQuotesInner.md)
204
- - [SnapTrade::TargetAsset](docs/TargetAsset.md)
205
- - [SnapTrade::TimeInForce](docs/TimeInForce.md)
206
- - [SnapTrade::Trade](docs/Trade.md)
207
- - [SnapTrade::TradeAction](docs/TradeAction.md)
208
- - [SnapTrade::TradeExecutionStatus](docs/TradeExecutionStatus.md)
209
- - [SnapTrade::TradeExecutionStatusAction](docs/TradeExecutionStatusAction.md)
210
- - [SnapTrade::TradeImpact](docs/TradeImpact.md)
211
- - [SnapTrade::TradingCancelUserAccountOrderRequest](docs/TradingCancelUserAccountOrderRequest.md)
212
- - [SnapTrade::TradingPlaceOCOOrderRequest](docs/TradingPlaceOCOOrderRequest.md)
213
- - [SnapTrade::TransactionsStatus](docs/TransactionsStatus.md)
214
- - [SnapTrade::Type](docs/Type.md)
215
- - [SnapTrade::USExchange](docs/USExchange.md)
216
- - [SnapTrade::UnderlyingSymbol](docs/UnderlyingSymbol.md)
217
- - [SnapTrade::UniversalActivity](docs/UniversalActivity.md)
218
- - [SnapTrade::UniversalSymbol](docs/UniversalSymbol.md)
219
- - [SnapTrade::UniversalSymbolTicker](docs/UniversalSymbolTicker.md)
220
- - [SnapTrade::UserErrorLog](docs/UserErrorLog.md)
221
- - [SnapTrade::UserIDandSecret](docs/UserIDandSecret.md)
222
- - [SnapTrade::UserSettings](docs/UserSettings.md)
85
+ configuration = SnapTrade::Configuration.new
86
+ configuration.client_id = ENV["SNAPTRADE_CLIENT_ID"]
87
+ configuration.consumer_key = ENV["SNAPTRADE_CONSUMER_KEY"]
88
+ snaptrade = SnapTrade::Client.new(configuration)
89
+ result = snaptrade.account_information.get_account_activities(
90
+ account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
91
+ user_id: "snaptrade-user-123",
92
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
93
+ start_date: "2022-01-24",
94
+ end_date: "2022-01-24",
95
+ offset: 0,
96
+ limit: 1,
97
+ type: "BUY,SELL,DIVIDEND",
98
+ )
99
+ p result
100
+ ```
101
+
102
+ ## Raw HTTP Response<a id="raw-http-response"></a>
103
+
104
+ To access the raw HTTP response, suffix any method with `_with_http_info`.
105
+
106
+ ```ruby
107
+ result = snaptrade.account_information.get_account_activities_with_http_info(
108
+ account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
109
+ user_id: "snaptrade-user-123",
110
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
111
+ start_date: "2022-01-24",
112
+ end_date: "2022-01-24",
113
+ offset: 0,
114
+ limit: 1,
115
+ type: "BUY,SELL,DIVIDEND",
116
+ )
117
+ p result[0] # [PaginatedUniversalActivity] Deserialized data
118
+ p.result[1] # [Integer] HTTP status code
119
+ p.result[2] # [Hash] HTTP headers
120
+ p.result[3] # [Faraday::Response] Raw HTTP response
121
+ ```
122
+
123
+ ## Reference<a id="reference"></a>
124
+
125
+
126
+ ### `snaptrade.account_information.get_account_activities`<a id="snaptradeaccount_informationget_account_activities"></a>
127
+
128
+ Returns all historical transactions for the specified account.
129
+
130
+ 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.
131
+
132
+ Transaction are returned in reverse chronological order, using the `trade_date` field.
133
+
134
+ The data returned here is always cached and refreshed once a day.
135
+
136
+
137
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
138
+
139
+ ```ruby
140
+ result = snaptrade.account_information.get_account_activities(
141
+ account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
142
+ user_id: "snaptrade-user-123",
143
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
144
+ start_date: "2022-01-24",
145
+ end_date: "2022-01-24",
146
+ offset: 0,
147
+ limit: 1,
148
+ type: "BUY,SELL,DIVIDEND",
149
+ )
150
+ p result
151
+ ```
152
+
153
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
154
+
155
+ ##### account_id: `String`<a id="account_id-string"></a>
156
+ ##### user_id: `String`<a id="user_id-string"></a>
157
+ ##### user_secret: `String`<a id="user_secret-string"></a>
158
+ ##### start_date: `Date`<a id="start_date-date"></a>
159
+ The start date (inclusive) of the transaction history to retrieve. If not
160
+ provided, the default is the first transaction known to SnapTrade based on
161
+ `trade_date`.
162
+
163
+ ##### end_date: `Date`<a id="end_date-date"></a>
164
+ The end date (inclusive) of the transaction history to retrieve. If not
165
+ provided, the default is the last transaction known to SnapTrade based on
166
+ `trade_date`.
167
+
168
+ ##### offset: `Integer`<a id="offset-integer"></a>
169
+ An integer that specifies the starting point of the paginated results. Default
170
+ is 0.
171
+
172
+ ##### limit: `Integer`<a id="limit-integer"></a>
173
+ An integer that specifies the maximum number of transactions to return. Default
174
+ of 1000.
175
+
176
+ ##### type: `String`<a id="type-string"></a>
177
+ Optional comma separated list of transaction types to filter by. SnapTrade does
178
+ a best effort to categorize brokerage transaction types into a common set of
179
+ values. Here are some of the most popular values: - `BUY` - Asset bought. -
180
+ `SELL` - Asset sold. - `DIVIDEND` - Dividend payout. - `CONTRIBUTION` - Cash
181
+ contribution. - `WITHDRAWAL` - Cash withdrawal. - `REI` - Dividend reinvestment.
182
+ - `STOCK_DIVIDEND` - A type of dividend where a company distributes shares
183
+ instead of cash - `INTEREST` - Interest deposited into the account. - `FEE` -
184
+ Fee withdrawn from the account. - `OPTIONEXPIRATION` - Option expiration event.
185
+ - `OPTIONASSIGNMENT` - Option assignment event. - `OPTIONEXERCISE` - Option
186
+ exercise event. - `TRANSFER` - Transfer of assets from one account to another
187
+
188
+ #### 🔄 Return<a id="🔄-return"></a>
189
+
190
+ [PaginatedUniversalActivity](./lib/snaptrade/models/paginated_universal_activity.rb)
191
+
192
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
193
+
194
+ `/accounts/{accountId}/activities` `GET`
195
+
196
+ [🔙 **Back to Table of Contents**](#table-of-contents)
197
+
198
+ ---
199
+
200
+
201
+ ### `snaptrade.account_information.get_all_user_holdings`<a id="snaptradeaccount_informationget_all_user_holdings"></a>
202
+ ![Deprecated](https://img.shields.io/badge/deprecated-yellow)
203
+
204
+ **Deprecated, please use the account-specific holdings endpoint instead.**
205
+
206
+ List all accounts for the user, plus balances, positions, and orders for each
207
+ account.
208
+
209
+
210
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
211
+
212
+ ```ruby
213
+ result = snaptrade.account_information.get_all_user_holdings(
214
+ user_id: "snaptrade-user-123",
215
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
216
+ brokerage_authorizations: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
217
+ )
218
+ p result
219
+ ```
220
+
221
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
222
+
223
+ ##### user_id: `String`<a id="user_id-string"></a>
224
+ ##### user_secret: `String`<a id="user_secret-string"></a>
225
+ ##### brokerage_authorizations: `String`<a id="brokerage_authorizations-string"></a>
226
+ Optional. Comma separated list of authorization IDs (only use if filtering is
227
+ needed on one or more authorizations).
228
+
229
+ #### 🔄 Return<a id="🔄-return"></a>
230
+
231
+ [AccountHoldings](./lib/snaptrade/models/account_holdings.rb)
232
+
233
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
234
+
235
+ `/holdings` `GET`
236
+
237
+ [🔙 **Back to Table of Contents**](#table-of-contents)
238
+
239
+ ---
240
+
241
+
242
+ ### `snaptrade.account_information.get_user_account_balance`<a id="snaptradeaccount_informationget_user_account_balance"></a>
243
+
244
+ 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](https://www.questrade.com/learning/questrade-basics/balances-and-reports/understanding-your-account-balances).
245
+
246
+ The data returned here is cached. How long the data is cached for varies by brokerage. Check the [brokerage integrations doc](https://snaptrade.notion.site/66793431ad0b416489eaabaf248d0afb?v=d16c4c97b8d5438bbb2d8581ac53b11e) and look for "Cache Expiry Time" to see the exact value for a specific brokerage. **If you need real-time data, please use the [manual refresh](/reference/Connections/Connections_refreshBrokerageAuthorization) endpoint**.
247
+
248
+
249
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
250
+
251
+ ```ruby
252
+ result = snaptrade.account_information.get_user_account_balance(
253
+ user_id: "snaptrade-user-123",
254
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
255
+ account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
256
+ )
257
+ p result
258
+ ```
259
+
260
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
261
+
262
+ ##### user_id: `String`<a id="user_id-string"></a>
263
+ ##### user_secret: `String`<a id="user_secret-string"></a>
264
+ ##### account_id: `String`<a id="account_id-string"></a>
265
+ #### 🔄 Return<a id="🔄-return"></a>
266
+
267
+ [Balance](./lib/snaptrade/models/balance.rb)
268
+
269
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
270
+
271
+ `/accounts/{accountId}/balances` `GET`
272
+
273
+ [🔙 **Back to Table of Contents**](#table-of-contents)
274
+
275
+ ---
276
+
277
+
278
+ ### `snaptrade.account_information.get_user_account_details`<a id="snaptradeaccount_informationget_user_account_details"></a>
279
+
280
+ Returns account detail known to SnapTrade for the specified account.
281
+
282
+ The data returned here is always cached and refreshed once a day. **If you need real-time data, please use the [manual refresh](/reference/Connections/Connections_refreshBrokerageAuthorization) endpoint**.
283
+
284
+
285
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
286
+
287
+ ```ruby
288
+ result = snaptrade.account_information.get_user_account_details(
289
+ user_id: "snaptrade-user-123",
290
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
291
+ account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
292
+ )
293
+ p result
294
+ ```
295
+
296
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
297
+
298
+ ##### user_id: `String`<a id="user_id-string"></a>
299
+ ##### user_secret: `String`<a id="user_secret-string"></a>
300
+ ##### account_id: `String`<a id="account_id-string"></a>
301
+ #### 🔄 Return<a id="🔄-return"></a>
302
+
303
+ [Account](./lib/snaptrade/models/account.rb)
304
+
305
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
306
+
307
+ `/accounts/{accountId}` `GET`
308
+
309
+ [🔙 **Back to Table of Contents**](#table-of-contents)
310
+
311
+ ---
312
+
313
+
314
+ ### `snaptrade.account_information.get_user_account_orders`<a id="snaptradeaccount_informationget_user_account_orders"></a>
315
+
316
+ Returns a list of recent orders in the specified account.
317
+
318
+ The data returned here is cached. How long the data is cached for varies by brokerage. Check the [brokerage integrations doc](https://snaptrade.notion.site/66793431ad0b416489eaabaf248d0afb?v=d16c4c97b8d5438bbb2d8581ac53b11e) and look for "Cache Expiry Time" to see the exact value for a specific brokerage. **If you need real-time data, please use the [manual refresh](/reference/Connections/Connections_refreshBrokerageAuthorization) endpoint**.
319
+
320
+
321
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
322
+
323
+ ```ruby
324
+ result = snaptrade.account_information.get_user_account_orders(
325
+ user_id: "snaptrade-user-123",
326
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
327
+ account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
328
+ state: "all",
329
+ days: 30,
330
+ )
331
+ p result
332
+ ```
333
+
334
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
335
+
336
+ ##### user_id: `String`<a id="user_id-string"></a>
337
+ ##### user_secret: `String`<a id="user_secret-string"></a>
338
+ ##### account_id: `String`<a id="account_id-string"></a>
339
+ ##### state: `String`<a id="state-string"></a>
340
+ defaults value is set to \"all\"
341
+
342
+ ##### days: `Integer`<a id="days-integer"></a>
343
+ Number of days in the past to fetch the most recent orders. Defaults to the last
344
+ 30 days if no value is passed in.
345
+
346
+ #### 🔄 Return<a id="🔄-return"></a>
347
+
348
+ [AccountOrderRecord](./lib/snaptrade/models/account_order_record.rb)
349
+
350
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
351
+
352
+ `/accounts/{accountId}/orders` `GET`
353
+
354
+ [🔙 **Back to Table of Contents**](#table-of-contents)
355
+
356
+ ---
357
+
358
+
359
+ ### `snaptrade.account_information.get_user_account_positions`<a id="snaptradeaccount_informationget_user_account_positions"></a>
360
+
361
+ Returns a list of stock/ETF/crypto/mutual fund positions in the specified account. For option positions, please use the [options endpoint](/reference/Options/Options_listOptionHoldings).
362
+
363
+ The data returned here is cached. How long the data is cached for varies by brokerage. Check the [brokerage integrations doc](https://snaptrade.notion.site/66793431ad0b416489eaabaf248d0afb?v=d16c4c97b8d5438bbb2d8581ac53b11e) and look for "Cache Expiry Time" to see the exact value for a specific brokerage. **If you need real-time data, please use the [manual refresh](/reference/Connections/Connections_refreshBrokerageAuthorization) endpoint**.
364
+
365
+
366
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
367
+
368
+ ```ruby
369
+ result = snaptrade.account_information.get_user_account_positions(
370
+ user_id: "snaptrade-user-123",
371
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
372
+ account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
373
+ )
374
+ p result
375
+ ```
376
+
377
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
378
+
379
+ ##### user_id: `String`<a id="user_id-string"></a>
380
+ ##### user_secret: `String`<a id="user_secret-string"></a>
381
+ ##### account_id: `String`<a id="account_id-string"></a>
382
+ #### 🔄 Return<a id="🔄-return"></a>
383
+
384
+ [Position](./lib/snaptrade/models/position.rb)
385
+
386
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
387
+
388
+ `/accounts/{accountId}/positions` `GET`
389
+
390
+ [🔙 **Back to Table of Contents**](#table-of-contents)
391
+
392
+ ---
393
+
394
+
395
+ ### `snaptrade.account_information.get_user_account_recent_orders`<a id="snaptradeaccount_informationget_user_account_recent_orders"></a>
396
+
397
+ A lightweight endpoint that returns a list of orders executed in the last 24 hours in the specified account.
398
+ 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
399
+ Differs from /orders in that it is realtime, and only checks the last 24 hours as opposed to the last 30 days
400
+ By default only returns executed orders, but that can be changed by setting *only_executed* to false
401
+ **Please contact support for access as this endpoint is not enabled by default.**
402
+
403
+
404
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
405
+
406
+ ```ruby
407
+ result = snaptrade.account_information.get_user_account_recent_orders(
408
+ user_id: "snaptrade-user-123",
409
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
410
+ account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
411
+ only_executed: true,
412
+ )
413
+ p result
414
+ ```
415
+
416
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
417
+
418
+ ##### user_id: `String`<a id="user_id-string"></a>
419
+ ##### user_secret: `String`<a id="user_secret-string"></a>
420
+ ##### account_id: `String`<a id="account_id-string"></a>
421
+ ##### only_executed: `Boolean`<a id="only_executed-boolean"></a>
422
+ Defaults to true. Indicates if request should fetch only executed orders. Set to
423
+ false to retrieve non executed orders as well
424
+
425
+ #### 🔄 Return<a id="🔄-return"></a>
426
+
427
+ [RecentOrdersResponse](./lib/snaptrade/models/recent_orders_response.rb)
428
+
429
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
430
+
431
+ `/accounts/{accountId}/recentOrders` `GET`
432
+
433
+ [🔙 **Back to Table of Contents**](#table-of-contents)
434
+
435
+ ---
436
+
437
+
438
+ ### `snaptrade.account_information.get_user_account_return_rates`<a id="snaptradeaccount_informationget_user_account_return_rates"></a>
439
+
440
+ 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"
441
+
442
+
443
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
444
+
445
+ ```ruby
446
+ result = snaptrade.account_information.get_user_account_return_rates(
447
+ user_id: "snaptrade-user-123",
448
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
449
+ account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
450
+ )
451
+ p result
452
+ ```
453
+
454
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
455
+
456
+ ##### user_id: `String`<a id="user_id-string"></a>
457
+ ##### user_secret: `String`<a id="user_secret-string"></a>
458
+ ##### account_id: `String`<a id="account_id-string"></a>
459
+ #### 🔄 Return<a id="🔄-return"></a>
460
+
461
+ [RateOfReturnResponse](./lib/snaptrade/models/rate_of_return_response.rb)
462
+
463
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
464
+
465
+ `/accounts/{accountId}/returnRates` `GET`
466
+
467
+ [🔙 **Back to Table of Contents**](#table-of-contents)
468
+
469
+ ---
470
+
471
+
472
+ ### `snaptrade.account_information.get_user_holdings`<a id="snaptradeaccount_informationget_user_holdings"></a>
473
+
474
+ 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](/reference/Account%20Information/AccountInformation_getUserAccountBalance), [positions](/reference/Account%20Information/AccountInformation_getUserAccountPositions) and [orders](/reference/Account%20Information/AccountInformation_getUserAccountOrders) endpoints. __The finer-grained APIs are preferred. They are easier to work with, faster, and have better error handling than this coarse-grained API.__
475
+
476
+ The data returned here is cached. How long the data is cached for varies by brokerage. Check the [brokerage integrations doc](https://snaptrade.notion.site/66793431ad0b416489eaabaf248d0afb?v=d16c4c97b8d5438bbb2d8581ac53b11e) and look for "Cache Expiry Time" to see the exact value for a specific brokerage. **If you need real-time data, please use the [manual refresh](/reference/Connections/Connections_refreshBrokerageAuthorization) endpoint**.
477
+
478
+
479
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
480
+
481
+ ```ruby
482
+ result = snaptrade.account_information.get_user_holdings(
483
+ account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
484
+ user_id: "snaptrade-user-123",
485
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
486
+ )
487
+ p result
488
+ ```
489
+
490
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
491
+
492
+ ##### account_id: `String`<a id="account_id-string"></a>
493
+ ##### user_id: `String`<a id="user_id-string"></a>
494
+ ##### user_secret: `String`<a id="user_secret-string"></a>
495
+ #### 🔄 Return<a id="🔄-return"></a>
496
+
497
+ [AccountHoldingsAccount](./lib/snaptrade/models/account_holdings_account.rb)
498
+
499
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
500
+
501
+ `/accounts/{accountId}/holdings` `GET`
502
+
503
+ [🔙 **Back to Table of Contents**](#table-of-contents)
504
+
505
+ ---
506
+
507
+
508
+ ### `snaptrade.account_information.list_user_accounts`<a id="snaptradeaccount_informationlist_user_accounts"></a>
509
+
510
+ Returns all brokerage accounts across all connections known to SnapTrade for the authenticated user.
511
+
512
+ The data returned here is always cached and refreshed once a day. **If you need real-time data, please use the [manual refresh](/reference/Connections/Connections_refreshBrokerageAuthorization) endpoint**.
513
+
514
+
515
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
516
+
517
+ ```ruby
518
+ result = snaptrade.account_information.list_user_accounts(
519
+ user_id: "snaptrade-user-123",
520
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
521
+ )
522
+ p result
523
+ ```
524
+
525
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
526
+
527
+ ##### user_id: `String`<a id="user_id-string"></a>
528
+ ##### user_secret: `String`<a id="user_secret-string"></a>
529
+ #### 🔄 Return<a id="🔄-return"></a>
530
+
531
+ [Account](./lib/snaptrade/models/account.rb)
532
+
533
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
534
+
535
+ `/accounts` `GET`
536
+
537
+ [🔙 **Back to Table of Contents**](#table-of-contents)
538
+
539
+ ---
540
+
541
+
542
+ ### `snaptrade.account_information.update_user_account`<a id="snaptradeaccount_informationupdate_user_account"></a>
543
+
544
+ Updates various properties of a specified account.
545
+
546
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
547
+
548
+ ```ruby
549
+ result = snaptrade.account_information.update_user_account(
550
+ user_id: "snaptrade-user-123",
551
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
552
+ account_id: "accountId_example",
553
+ )
554
+ p result
555
+ ```
556
+
557
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
558
+
559
+ ##### user_id: `String`<a id="user_id-string"></a>
560
+ ##### user_secret: `String`<a id="user_secret-string"></a>
561
+ ##### account_id: `String`<a id="account_id-string"></a>
562
+ The ID of the account to update.
563
+
564
+ #### 🔄 Return<a id="🔄-return"></a>
565
+
566
+ [Account](./lib/snaptrade/models/account.rb)
567
+
568
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
569
+
570
+ `/accounts/{accountId}` `PUT`
571
+
572
+ [🔙 **Back to Table of Contents**](#table-of-contents)
573
+
574
+ ---
575
+
576
+
577
+ ### `snaptrade.api_status.check`<a id="snaptradeapi_statuscheck"></a>
578
+
579
+ Check whether the API is operational and verify timestamps.
580
+
581
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
582
+
583
+ ```ruby
584
+ result = snaptrade.api_status.check
585
+ p result
586
+ ```
587
+
588
+ #### 🔄 Return<a id="🔄-return"></a>
589
+
590
+ [Status](./lib/snaptrade/models/status.rb)
591
+
592
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
593
+
594
+ `/` `GET`
595
+
596
+ [🔙 **Back to Table of Contents**](#table-of-contents)
597
+
598
+ ---
599
+
600
+
601
+ ### `snaptrade.authentication.delete_snap_trade_user`<a id="snaptradeauthenticationdelete_snap_trade_user"></a>
602
+
603
+ 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.
604
+
605
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
606
+
607
+ ```ruby
608
+ result = snaptrade.authentication.delete_snap_trade_user(
609
+ user_id: "snaptrade-user-123",
610
+ )
611
+ p result
612
+ ```
613
+
614
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
615
+
616
+ ##### user_id: `String`<a id="user_id-string"></a>
617
+ #### 🔄 Return<a id="🔄-return"></a>
618
+
619
+ [DeleteUserResponse](./lib/snaptrade/models/delete_user_response.rb)
620
+
621
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
622
+
623
+ `/snapTrade/deleteUser` `DELETE`
624
+
625
+ [🔙 **Back to Table of Contents**](#table-of-contents)
626
+
627
+ ---
628
+
629
+
630
+ ### `snaptrade.authentication.list_snap_trade_users`<a id="snaptradeauthenticationlist_snap_trade_users"></a>
631
+
632
+ Returns a list of all registered user IDs. Please note that the response is not currently paginated.
633
+
634
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
635
+
636
+ ```ruby
637
+ result = snaptrade.authentication.list_snap_trade_users
638
+ p result
639
+ ```
640
+
641
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
642
+
643
+ `/snapTrade/listUsers` `GET`
644
+
645
+ [🔙 **Back to Table of Contents**](#table-of-contents)
646
+
647
+ ---
648
+
649
+
650
+ ### `snaptrade.authentication.login_snap_trade_user`<a id="snaptradeauthenticationlogin_snap_trade_user"></a>
651
+
652
+ Authenticates a SnapTrade user and returns the Connection Portal URL used for connecting brokerage accounts. Please check [this guide](/docs/implement-connection-portal) for how to integrate the Connection Portal into your app.
653
+
654
+ Please note that the returned URL expires in 5 minutes.
655
+
656
+
657
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
658
+
659
+ ```ruby
660
+ result = snaptrade.authentication.login_snap_trade_user(
661
+ user_id: "snaptrade-user-123",
662
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
663
+ broker: "ALPACA",
664
+ immediate_redirect: true,
665
+ custom_redirect: "https://snaptrade.com",
666
+ reconnect: "8b5f262d-4bb9-365d-888a-202bd3b15fa1",
667
+ connection_type: "read",
668
+ connection_portal_version: "v4",
669
+ )
670
+ p result
671
+ ```
672
+
673
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
674
+
675
+ ##### user_id: `String`<a id="user_id-string"></a>
676
+ ##### user_secret: `String`<a id="user_secret-string"></a>
677
+ ##### broker: `String`<a id="broker-string"></a>
678
+ Slug of the brokerage to connect the user to. See [the integrations
679
+ page](https://snaptrade.notion.site/66793431ad0b416489eaabaf248d0afb?v=3cfea70ef4254afc89704e47275a7a9a&pvs=4)
680
+ for a list of supported brokerages and their slugs.
681
+
682
+ ##### immediateRedirect: `Boolean`<a id="immediateredirect-boolean"></a>
683
+ When set to `true`, user will be redirected back to the partner's site instead
684
+ of the connection portal. This parameter is ignored if the connection portal is
685
+ loaded inside an iframe. See the [guide on ways to integrate the connection
686
+ portal](/docs/implement-connection-portal) for more information.
687
+
688
+ ##### customRedirect: `String`<a id="customredirect-string"></a>
689
+ URL to redirect the user to after the user connects their brokerage account.
690
+ This parameter is ignored if the connection portal is loaded inside an iframe.
691
+ See the [guide on ways to integrate the connection
692
+ portal](/docs/implement-connection-portal) for more information.
693
+
694
+ ##### reconnect: `String`<a id="reconnect-string"></a>
695
+ The UUID of the brokerage connection to be reconnected. This parameter should be
696
+ left empty unless you are reconnecting a disabled connection. See the [guide on
697
+ fixing broken connections](/docs/fix-broken-connections) for more information.
698
+
699
+ ##### connectionType: [`ConnectionType`](./lib/snaptrade/models/connection_type.rb)<a id="connectiontype-connectiontypelibsnaptrademodelsconnection_typerb"></a>
700
+ Sets whether the connection should be read-only or trade-enabled. Defaults to
701
+ read-only if not specified.
702
+
703
+ ##### connectionPortalVersion: [`ConnectionPortalVersion`](./lib/snaptrade/models/connection_portal_version.rb)<a id="connectionportalversion-connectionportalversionlibsnaptrademodelsconnection_portal_versionrb"></a>
704
+ Sets the connection portal version to render. Currently only v4 is supported and
705
+ is the default. All other versions are deprecated and will automatically be set
706
+ to v4.
707
+
708
+ #### 🔄 Return<a id="🔄-return"></a>
709
+
710
+ [AuthenticationLoginSnapTradeUser200Response](./lib/snaptrade/models/authentication_login_snap_trade_user200_response.rb)
711
+
712
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
713
+
714
+ `/snapTrade/login` `POST`
715
+
716
+ [🔙 **Back to Table of Contents**](#table-of-contents)
717
+
718
+ ---
719
+
720
+
721
+ ### `snaptrade.authentication.register_snap_trade_user`<a id="snaptradeauthenticationregister_snap_trade_user"></a>
722
+
723
+ 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.
724
+ Most SnapTrade operations require a user ID and user secret to be passed in as parameters.
725
+
726
+
727
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
728
+
729
+ ```ruby
730
+ result = snaptrade.authentication.register_snap_trade_user(
731
+ user_id: "snaptrade-user-123",
732
+ )
733
+ p result
734
+ ```
735
+
736
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
737
+
738
+ ##### userId: `String`<a id="userid-string"></a>
739
+ SnapTrade User ID. This is chosen by the API partner and can be any string that
740
+ is a) unique to the user, and b) immutable for the user. It is recommended to
741
+ NOT use email addresses for this property because they are usually not
742
+ immutable.
743
+
744
+ #### 🔄 Return<a id="🔄-return"></a>
745
+
746
+ [UserIDandSecret](./lib/snaptrade/models/user_i_dand_secret.rb)
747
+
748
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
749
+
750
+ `/snapTrade/registerUser` `POST`
751
+
752
+ [🔙 **Back to Table of Contents**](#table-of-contents)
753
+
754
+ ---
755
+
756
+
757
+ ### `snaptrade.authentication.reset_snap_trade_user_secret`<a id="snaptradeauthenticationreset_snap_trade_user_secret"></a>
758
+
759
+ 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.
760
+
761
+
762
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
763
+
764
+ ```ruby
765
+ result = snaptrade.authentication.reset_snap_trade_user_secret(
766
+ user_id: "snaptrade-user-123",
767
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
768
+ )
769
+ p result
770
+ ```
771
+
772
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
773
+
774
+ ##### userId: `String`<a id="userid-string"></a>
775
+ SnapTrade User ID. This is chosen by the API partner and can be any string that
776
+ is a) unique to the user, and b) immutable for the user. It is recommended to
777
+ NOT use email addresses for this property because they are usually not
778
+ immutable.
779
+
780
+ ##### userSecret: `String`<a id="usersecret-string"></a>
781
+ SnapTrade User Secret. This is a randomly generated string and should be stored
782
+ securely. If compromised, please rotate it via the [rotate user secret
783
+ endpoint](/reference/Authentication/Authentication_resetSnapTradeUserSecret).
784
+
785
+ #### 🔄 Return<a id="🔄-return"></a>
786
+
787
+ [UserIDandSecret](./lib/snaptrade/models/user_i_dand_secret.rb)
788
+
789
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
790
+
791
+ `/snapTrade/resetUserSecret` `POST`
792
+
793
+ [🔙 **Back to Table of Contents**](#table-of-contents)
794
+
795
+ ---
796
+
797
+
798
+ ### `snaptrade.connections.detail_brokerage_authorization`<a id="snaptradeconnectionsdetail_brokerage_authorization"></a>
799
+
800
+ Returns a single connection for the specified ID.
801
+
802
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
803
+
804
+ ```ruby
805
+ result = snaptrade.connections.detail_brokerage_authorization(
806
+ authorization_id: "87b24961-b51e-4db8-9226-f198f6518a89",
807
+ user_id: "snaptrade-user-123",
808
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
809
+ )
810
+ p result
811
+ ```
812
+
813
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
814
+
815
+ ##### authorization_id: `String`<a id="authorization_id-string"></a>
816
+ ##### user_id: `String`<a id="user_id-string"></a>
817
+ ##### user_secret: `String`<a id="user_secret-string"></a>
818
+ #### 🔄 Return<a id="🔄-return"></a>
819
+
820
+ [BrokerageAuthorization](./lib/snaptrade/models/brokerage_authorization.rb)
821
+
822
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
823
+
824
+ `/authorizations/{authorizationId}` `GET`
825
+
826
+ [🔙 **Back to Table of Contents**](#table-of-contents)
827
+
828
+ ---
829
+
830
+
831
+ ### `snaptrade.connections.disable_brokerage_authorization`<a id="snaptradeconnectionsdisable_brokerage_authorization"></a>
832
+
833
+ Manually force the specified connection to become disabled. This should only be used for testing a reconnect flow, and never used on production connections.
834
+ Will trigger a disconnect as if it happened naturally, and send a [`CONNECTION_BROKEN` webhook](/docs/webhooks#webhooks-connection_broken) for the connection.
835
+
836
+ *Please contact us in order to use this endpoint as it is disabled by default.*
837
+
838
+
839
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
840
+
841
+ ```ruby
842
+ result = snaptrade.connections.disable_brokerage_authorization(
843
+ authorization_id: "87b24961-b51e-4db8-9226-f198f6518a89",
844
+ user_id: "snaptrade-user-123",
845
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
846
+ )
847
+ p result
848
+ ```
849
+
850
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
851
+
852
+ ##### authorization_id: `String`<a id="authorization_id-string"></a>
853
+ ##### user_id: `String`<a id="user_id-string"></a>
854
+ ##### user_secret: `String`<a id="user_secret-string"></a>
855
+ #### 🔄 Return<a id="🔄-return"></a>
856
+
857
+ [BrokerageAuthorizationDisabledConfirmation](./lib/snaptrade/models/brokerage_authorization_disabled_confirmation.rb)
858
+
859
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
860
+
861
+ `/authorizations/{authorizationId}/disable` `POST`
862
+
863
+ [🔙 **Back to Table of Contents**](#table-of-contents)
864
+
865
+ ---
866
+
867
+
868
+ ### `snaptrade.connections.list_brokerage_authorizations`<a id="snaptradeconnectionslist_brokerage_authorizations"></a>
869
+
870
+ 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.
871
+
872
+ A connection is usually tied to a single login at a brokerage. A single connection can contain multiple brokerage accounts.
873
+
874
+ 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.
875
+
876
+
877
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
878
+
879
+ ```ruby
880
+ result = snaptrade.connections.list_brokerage_authorizations(
881
+ user_id: "snaptrade-user-123",
882
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
883
+ )
884
+ p result
885
+ ```
886
+
887
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
888
+
889
+ ##### user_id: `String`<a id="user_id-string"></a>
890
+ ##### user_secret: `String`<a id="user_secret-string"></a>
891
+ #### 🔄 Return<a id="🔄-return"></a>
892
+
893
+ [BrokerageAuthorization](./lib/snaptrade/models/brokerage_authorization.rb)
894
+
895
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
896
+
897
+ `/authorizations` `GET`
898
+
899
+ [🔙 **Back to Table of Contents**](#table-of-contents)
900
+
901
+ ---
902
+
903
+
904
+ ### `snaptrade.connections.refresh_brokerage_authorization`<a id="snaptradeconnectionsrefresh_brokerage_authorization"></a>
905
+
906
+ Trigger a holdings update for all accounts under this connection. Updates will be queued asynchronously. [`ACCOUNT_HOLDINGS_UPDATED` webhook](/docs/webhooks#webhooks-account_holdings_updated) will be sent once the sync completes for each account under the connection.
907
+ This endpoint will also trigger a transaction sync for the past day if one has not yet occured.
908
+
909
+ *Please contact support for access as this endpoint is not enabled by default.*
910
+
911
+
912
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
913
+
914
+ ```ruby
915
+ result = snaptrade.connections.refresh_brokerage_authorization(
916
+ authorization_id: "87b24961-b51e-4db8-9226-f198f6518a89",
917
+ user_id: "snaptrade-user-123",
918
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
919
+ )
920
+ p result
921
+ ```
922
+
923
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
924
+
925
+ ##### authorization_id: `String`<a id="authorization_id-string"></a>
926
+ ##### user_id: `String`<a id="user_id-string"></a>
927
+ ##### user_secret: `String`<a id="user_secret-string"></a>
928
+ #### 🔄 Return<a id="🔄-return"></a>
929
+
930
+ [BrokerageAuthorizationRefreshConfirmation](./lib/snaptrade/models/brokerage_authorization_refresh_confirmation.rb)
931
+
932
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
933
+
934
+ `/authorizations/{authorizationId}/refresh` `POST`
935
+
936
+ [🔙 **Back to Table of Contents**](#table-of-contents)
937
+
938
+ ---
939
+
940
+
941
+ ### `snaptrade.connections.remove_brokerage_authorization`<a id="snaptradeconnectionsremove_brokerage_authorization"></a>
942
+
943
+ Deletes the connection specified by the ID. This will also delete all accounts and holdings associated with the connection. This action is irreversible. This endpoint is synchronous, a 204 response indicates that the connection has been successfully deleted.
944
+
945
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
946
+
947
+ ```ruby
948
+ snaptrade.connections.remove_brokerage_authorization(
949
+ authorization_id: "87b24961-b51e-4db8-9226-f198f6518a89",
950
+ user_id: "snaptrade-user-123",
951
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
952
+ )
953
+ ```
954
+
955
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
956
+
957
+ ##### authorization_id: `String`<a id="authorization_id-string"></a>
958
+ ##### user_id: `String`<a id="user_id-string"></a>
959
+ ##### user_secret: `String`<a id="user_secret-string"></a>
960
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
961
+
962
+ `/authorizations/{authorizationId}` `DELETE`
963
+
964
+ [🔙 **Back to Table of Contents**](#table-of-contents)
965
+
966
+ ---
967
+
968
+
969
+ ### `snaptrade.connections.return_rates`<a id="snaptradeconnectionsreturn_rates"></a>
970
+
971
+ 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"
972
+
973
+
974
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
975
+
976
+ ```ruby
977
+ result = snaptrade.connections.return_rates(
978
+ user_id: "snaptrade-user-123",
979
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
980
+ authorization_id: "87b24961-b51e-4db8-9226-f198f6518a89",
981
+ )
982
+ p result
983
+ ```
984
+
985
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
986
+
987
+ ##### user_id: `String`<a id="user_id-string"></a>
988
+ ##### user_secret: `String`<a id="user_secret-string"></a>
989
+ ##### authorization_id: `String`<a id="authorization_id-string"></a>
990
+ #### 🔄 Return<a id="🔄-return"></a>
991
+
992
+ [RateOfReturnResponse](./lib/snaptrade/models/rate_of_return_response.rb)
993
+
994
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
995
+
996
+ `/authorizations/{authorizationId}/returnRates` `GET`
997
+
998
+ [🔙 **Back to Table of Contents**](#table-of-contents)
999
+
1000
+ ---
1001
+
1002
+
1003
+ ### `snaptrade.connections.session_events`<a id="snaptradeconnectionssession_events"></a>
1004
+
1005
+ Returns a list of session events associated with a user.
1006
+
1007
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1008
+
1009
+ ```ruby
1010
+ result = snaptrade.connections.session_events(
1011
+ partner_client_id: "SNAPTRADETEST",
1012
+ user_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631,65e839a3-9103-4cfb-9b72-2071ef80c5f2",
1013
+ session_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631,65e839a3-9103-4cfb-9b72-2071ef80c5f2",
1014
+ )
1015
+ p result
1016
+ ```
1017
+
1018
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1019
+
1020
+ ##### partner_client_id: `String`<a id="partner_client_id-string"></a>
1021
+ ##### user_id: `String`<a id="user_id-string"></a>
1022
+ Optional comma separated list of user IDs used to filter the request on specific
1023
+ users
1024
+
1025
+ ##### session_id: `String`<a id="session_id-string"></a>
1026
+ Optional comma separated list of session IDs used to filter the request on
1027
+ specific users
1028
+
1029
+ #### 🔄 Return<a id="🔄-return"></a>
1030
+
1031
+ [ConnectionsSessionEvents200ResponseInner](./lib/snaptrade/models/connections_session_events200_response_inner.rb)
1032
+
1033
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1034
+
1035
+ `/sessionEvents` `GET`
1036
+
1037
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1038
+
1039
+ ---
1040
+
1041
+
1042
+ ### `snaptrade.options.get_option_strategy`<a id="snaptradeoptionsget_option_strategy"></a>
1043
+
1044
+ Creates an option strategy object that will be used to place an option strategy order.
1045
+
1046
+
1047
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1048
+
1049
+ ```ruby
1050
+ result = snaptrade.options.get_option_strategy(
1051
+ underlying_symbol_id: "2bcd7cc3-e922-4976-bce1-9858296801c3",
1052
+ legs: [
1053
+ {
1054
+ "action" => "BUY_TO_OPEN",
1055
+ "option_symbol_id" => "SPY220819P00200000",
1056
+ "quantity" => 1,
1057
+ }
1058
+ ],
1059
+ strategy_type: "CUSTOM",
1060
+ user_id: "snaptrade-user-123",
1061
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
1062
+ account_id: "accountId_example",
1063
+ )
1064
+ p result
1065
+ ```
1066
+
1067
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1068
+
1069
+ ##### underlying_symbol_id: `String`<a id="underlying_symbol_id-string"></a>
1070
+ ##### legs: Array<[`OptionLeg`](./lib/snaptrade/models/option_leg.rb)><a id="legs-array"></a>
1071
+ ##### strategy_type: [`StrategyType`](./lib/snaptrade/models/strategy_type.rb)<a id="strategy_type-strategytypelibsnaptrademodelsstrategy_typerb"></a>
1072
+ ##### user_id: `String`<a id="user_id-string"></a>
1073
+ ##### user_secret: `String`<a id="user_secret-string"></a>
1074
+ ##### account_id: `String`<a id="account_id-string"></a>
1075
+ The ID of the account to create the option strategy object in.
1076
+
1077
+ #### 🔄 Return<a id="🔄-return"></a>
1078
+
1079
+ [StrategyQuotes](./lib/snaptrade/models/strategy_quotes.rb)
1080
+
1081
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1082
+
1083
+ `/accounts/{accountId}/optionStrategy` `POST`
1084
+
1085
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1086
+
1087
+ ---
1088
+
1089
+
1090
+ ### `snaptrade.options.get_options_chain`<a id="snaptradeoptionsget_options_chain"></a>
1091
+
1092
+ Returns the option chain for the specified symbol in the specified account.
1093
+
1094
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1095
+
1096
+ ```ruby
1097
+ result = snaptrade.options.get_options_chain(
1098
+ user_id: "snaptrade-user-123",
1099
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
1100
+ account_id: "accountId_example",
1101
+ symbol: "symbol_example",
1102
+ )
1103
+ p result
1104
+ ```
1105
+
1106
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1107
+
1108
+ ##### user_id: `String`<a id="user_id-string"></a>
1109
+ ##### user_secret: `String`<a id="user_secret-string"></a>
1110
+ ##### account_id: `String`<a id="account_id-string"></a>
1111
+ The ID of the account to get the options chain from.
1112
+
1113
+ ##### symbol: `String`<a id="symbol-string"></a>
1114
+ Universal symbol ID if symbol
1115
+
1116
+ #### 🔄 Return<a id="🔄-return"></a>
1117
+
1118
+ [OptionChainInner](./lib/snaptrade/models/option_chain_inner.rb)
1119
+
1120
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1121
+
1122
+ `/accounts/{accountId}/optionsChain` `GET`
1123
+
1124
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1125
+
1126
+ ---
1127
+
1128
+
1129
+ ### `snaptrade.options.get_options_strategy_quote`<a id="snaptradeoptionsget_options_strategy_quote"></a>
1130
+
1131
+ Returns a Strategy Quotes object which has latest market data of the specified option strategy.
1132
+
1133
+
1134
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1135
+
1136
+ ```ruby
1137
+ result = snaptrade.options.get_options_strategy_quote(
1138
+ user_id: "snaptrade-user-123",
1139
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
1140
+ account_id: "accountId_example",
1141
+ option_strategy_id: "2bcd7cc3-e922-4976-bce1-9858296801c3",
1142
+ )
1143
+ p result
1144
+ ```
1145
+
1146
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1147
+
1148
+ ##### user_id: `String`<a id="user_id-string"></a>
1149
+ ##### user_secret: `String`<a id="user_secret-string"></a>
1150
+ ##### account_id: `String`<a id="account_id-string"></a>
1151
+ The ID of the account the strategy will be placed in.
1152
+
1153
+ ##### option_strategy_id: `String`<a id="option_strategy_id-string"></a>
1154
+ Option strategy id obtained from response when creating option strategy object
1155
+
1156
+ #### 🔄 Return<a id="🔄-return"></a>
1157
+
1158
+ [StrategyQuotes](./lib/snaptrade/models/strategy_quotes.rb)
1159
+
1160
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1161
+
1162
+ `/accounts/{accountId}/optionStrategy/{optionStrategyId}` `GET`
1163
+
1164
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1165
+
1166
+ ---
1167
+
1168
+
1169
+ ### `snaptrade.options.list_option_holdings`<a id="snaptradeoptionslist_option_holdings"></a>
1170
+
1171
+ Returns a list of option positions in the specified account. For stock/ETF/crypto/mutual fund positions, please use the [positions endpoint](/reference/Account%20Information/AccountInformation_getUserAccountPositions).
1172
+
1173
+ The data returned here is cached. How long the data is cached for varies by brokerage. Check the [brokerage integrations doc](https://snaptrade.notion.site/66793431ad0b416489eaabaf248d0afb?v=d16c4c97b8d5438bbb2d8581ac53b11e) and look for "Cache Expiry Time" to see the exact value for a specific brokerage. **If you need real-time data, please use the [manual refresh](/reference/Connections/Connections_refreshBrokerageAuthorization) endpoint**.
1174
+
1175
+
1176
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1177
+
1178
+ ```ruby
1179
+ result = snaptrade.options.list_option_holdings(
1180
+ user_id: "snaptrade-user-123",
1181
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
1182
+ account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
1183
+ )
1184
+ p result
1185
+ ```
1186
+
1187
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1188
+
1189
+ ##### user_id: `String`<a id="user_id-string"></a>
1190
+ ##### user_secret: `String`<a id="user_secret-string"></a>
1191
+ ##### account_id: `String`<a id="account_id-string"></a>
1192
+ #### 🔄 Return<a id="🔄-return"></a>
1193
+
1194
+ [OptionsPosition](./lib/snaptrade/models/options_position.rb)
1195
+
1196
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1197
+
1198
+ `/accounts/{accountId}/options` `GET`
1199
+
1200
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1201
+
1202
+ ---
1203
+
1204
+
1205
+ ### `snaptrade.options.place_option_strategy`<a id="snaptradeoptionsplace_option_strategy"></a>
1206
+
1207
+ Places the option strategy order and returns the order record received from the brokerage.
1208
+
1209
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1210
+
1211
+ ```ruby
1212
+ result = snaptrade.options.place_option_strategy(
1213
+ order_type: "Market",
1214
+ time_in_force: "FOK",
1215
+ user_id: "snaptrade-user-123",
1216
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
1217
+ account_id: "2bcd7cc3-e922-4976-bce1-9858296801c3",
1218
+ option_strategy_id: "2bcd7cc3-e922-4976-bce1-9858296801c3",
1219
+ price: 31.33,
1220
+ )
1221
+ p result
1222
+ ```
1223
+
1224
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1225
+
1226
+ ##### order_type: [`OrderTypeStrict`](./lib/snaptrade/models/order_type_strict.rb)<a id="order_type-ordertypestrictlibsnaptrademodelsorder_type_strictrb"></a>
1227
+ The type of order to place. - For `Limit` and `StopLimit` orders, the `price`
1228
+ field is required. - For `Stop` and `StopLimit` orders, the `stop` field is
1229
+ required.
1230
+
1231
+ ##### time_in_force: [`TimeInForceStrict`](./lib/snaptrade/models/time_in_force_strict.rb)<a id="time_in_force-timeinforcestrictlibsnaptrademodelstime_in_force_strictrb"></a>
1232
+ The Time in Force type for the order. This field indicates how long the order
1233
+ will remain active before it is executed or expires. Here are the supported
1234
+ values: - `Day` - Day. The order is valid only for the trading day on which it
1235
+ is placed. - `GTC` - Good Til Canceled. The order is valid until it is executed
1236
+ or canceled. - `FOK` - Fill Or Kill. The order must be executed in its entirety
1237
+ immediately or be canceled completely.
1238
+
1239
+ ##### user_id: `String`<a id="user_id-string"></a>
1240
+ ##### user_secret: `String`<a id="user_secret-string"></a>
1241
+ ##### account_id: `String`<a id="account_id-string"></a>
1242
+ The ID of the account to execute the strategy in.
1243
+
1244
+ ##### option_strategy_id: `String`<a id="option_strategy_id-string"></a>
1245
+ Option strategy id obtained from response when creating option strategy object
1246
+
1247
+ ##### price: `Float`<a id="price-float"></a>
1248
+ Trade Price if limit or stop limit order
1249
+
1250
+ #### 🔄 Return<a id="🔄-return"></a>
1251
+
1252
+ [StrategyOrderRecord](./lib/snaptrade/models/strategy_order_record.rb)
1253
+
1254
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1255
+
1256
+ `/accounts/{accountId}/optionStrategy/{optionStrategyId}/execute` `POST`
1257
+
1258
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1259
+
1260
+ ---
1261
+
1262
+
1263
+ ### `snaptrade.reference_data.get_currency_exchange_rate_pair`<a id="snaptradereference_dataget_currency_exchange_rate_pair"></a>
1264
+
1265
+ Returns an Exchange Rate Pair object for the specified Currency Pair.
1266
+
1267
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1268
+
1269
+ ```ruby
1270
+ result = snaptrade.reference_data.get_currency_exchange_rate_pair(
1271
+ currency_pair: "currencyPair_example",
1272
+ )
1273
+ p result
1274
+ ```
1275
+
1276
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1277
+
1278
+ ##### currency_pair: `String`<a id="currency_pair-string"></a>
1279
+ A currency pair based on currency code for example, {CAD-USD}
1280
+
1281
+ #### 🔄 Return<a id="🔄-return"></a>
1282
+
1283
+ [ExchangeRatePairs](./lib/snaptrade/models/exchange_rate_pairs.rb)
1284
+
1285
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1286
+
1287
+ `/currencies/rates/{currencyPair}` `GET`
1288
+
1289
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1290
+
1291
+ ---
1292
+
1293
+
1294
+ ### `snaptrade.reference_data.get_partner_info`<a id="snaptradereference_dataget_partner_info"></a>
1295
+
1296
+ Returns configurations for your SnapTrade Client ID, including allowed brokerages and data access.
1297
+
1298
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1299
+
1300
+ ```ruby
1301
+ result = snaptrade.reference_data.get_partner_info
1302
+ p result
1303
+ ```
1304
+
1305
+ #### 🔄 Return<a id="🔄-return"></a>
1306
+
1307
+ [PartnerData](./lib/snaptrade/models/partner_data.rb)
1308
+
1309
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1310
+
1311
+ `/snapTrade/partners` `GET`
1312
+
1313
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1314
+
1315
+ ---
1316
+
1317
+
1318
+ ### `snaptrade.reference_data.get_security_types`<a id="snaptradereference_dataget_security_types"></a>
1319
+
1320
+ Return all available security types supported by SnapTrade.
1321
+
1322
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1323
+
1324
+ ```ruby
1325
+ result = snaptrade.reference_data.get_security_types
1326
+ p result
1327
+ ```
1328
+
1329
+ #### 🔄 Return<a id="🔄-return"></a>
1330
+
1331
+ [SecurityType](./lib/snaptrade/models/security_type.rb)
1332
+
1333
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1334
+
1335
+ `/securityTypes` `GET`
1336
+
1337
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1338
+
1339
+ ---
1340
+
1341
+
1342
+ ### `snaptrade.reference_data.get_stock_exchanges`<a id="snaptradereference_dataget_stock_exchanges"></a>
1343
+
1344
+ Returns a list of all supported Exchanges.
1345
+
1346
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1347
+
1348
+ ```ruby
1349
+ result = snaptrade.reference_data.get_stock_exchanges
1350
+ p result
1351
+ ```
1352
+
1353
+ #### 🔄 Return<a id="🔄-return"></a>
1354
+
1355
+ [Exchange](./lib/snaptrade/models/exchange.rb)
1356
+
1357
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1358
+
1359
+ `/exchanges` `GET`
1360
+
1361
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1362
+
1363
+ ---
1364
+
1365
+
1366
+ ### `snaptrade.reference_data.get_symbols`<a id="snaptradereference_dataget_symbols"></a>
1367
+
1368
+ 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.
1369
+
1370
+
1371
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1372
+
1373
+ ```ruby
1374
+ result = snaptrade.reference_data.get_symbols(
1375
+ substring: "AAPL",
1376
+ )
1377
+ p result
1378
+ ```
1379
+
1380
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1381
+
1382
+ ##### substring: `String`<a id="substring-string"></a>
1383
+ The search query for symbols.
1384
+
1385
+ #### 🔄 Return<a id="🔄-return"></a>
1386
+
1387
+ [UniversalSymbol](./lib/snaptrade/models/universal_symbol.rb)
1388
+
1389
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1390
+
1391
+ `/symbols` `POST`
1392
+
1393
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1394
+
1395
+ ---
1396
+
1397
+
1398
+ ### `snaptrade.reference_data.get_symbols_by_ticker`<a id="snaptradereference_dataget_symbols_by_ticker"></a>
1399
+
1400
+ 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](https://help.yahoo.com/kb/SLN2310.html)(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.
1401
+
1402
+
1403
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1404
+
1405
+ ```ruby
1406
+ result = snaptrade.reference_data.get_symbols_by_ticker(
1407
+ query: "query_example",
1408
+ )
1409
+ p result
1410
+ ```
1411
+
1412
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1413
+
1414
+ ##### query: `String`<a id="query-string"></a>
1415
+ The ticker or Universal Symbol ID to look up the symbol with.
1416
+
1417
+ #### 🔄 Return<a id="🔄-return"></a>
1418
+
1419
+ [UniversalSymbol](./lib/snaptrade/models/universal_symbol.rb)
1420
+
1421
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1422
+
1423
+ `/symbols/{query}` `GET`
1424
+
1425
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1426
+
1427
+ ---
1428
+
1429
+
1430
+ ### `snaptrade.reference_data.list_all_brokerage_authorization_type`<a id="snaptradereference_datalist_all_brokerage_authorization_type"></a>
1431
+
1432
+ Returns a list of all defined Brokerage authorization Type objects.
1433
+
1434
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1435
+
1436
+ ```ruby
1437
+ result = snaptrade.reference_data.list_all_brokerage_authorization_type(
1438
+ brokerage: "QUESTRADE,ALPACA",
1439
+ )
1440
+ p result
1441
+ ```
1442
+
1443
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1444
+
1445
+ ##### brokerage: `String`<a id="brokerage-string"></a>
1446
+ Comma separated value of brokerage slugs
1447
+
1448
+ #### 🔄 Return<a id="🔄-return"></a>
1449
+
1450
+ [BrokerageAuthorizationTypeReadOnly](./lib/snaptrade/models/brokerage_authorization_type_read_only.rb)
1451
+
1452
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1453
+
1454
+ `/brokerageAuthorizationTypes` `GET`
1455
+
1456
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1457
+
1458
+ ---
1459
+
1460
+
1461
+ ### `snaptrade.reference_data.list_all_brokerages`<a id="snaptradereference_datalist_all_brokerages"></a>
1462
+
1463
+ Returns a list of all defined Brokerage objects.
1464
+
1465
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1466
+
1467
+ ```ruby
1468
+ result = snaptrade.reference_data.list_all_brokerages
1469
+ p result
1470
+ ```
1471
+
1472
+ #### 🔄 Return<a id="🔄-return"></a>
1473
+
1474
+ [Brokerage](./lib/snaptrade/models/brokerage.rb)
1475
+
1476
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1477
+
1478
+ `/brokerages` `GET`
1479
+
1480
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1481
+
1482
+ ---
1483
+
1484
+
1485
+ ### `snaptrade.reference_data.list_all_currencies`<a id="snaptradereference_datalist_all_currencies"></a>
1486
+
1487
+ Returns a list of all defined Currency objects.
1488
+
1489
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1490
+
1491
+ ```ruby
1492
+ result = snaptrade.reference_data.list_all_currencies
1493
+ p result
1494
+ ```
1495
+
1496
+ #### 🔄 Return<a id="🔄-return"></a>
1497
+
1498
+ [Currency](./lib/snaptrade/models/currency.rb)
1499
+
1500
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1501
+
1502
+ `/currencies` `GET`
1503
+
1504
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1505
+
1506
+ ---
1507
+
1508
+
1509
+ ### `snaptrade.reference_data.list_all_currencies_rates`<a id="snaptradereference_datalist_all_currencies_rates"></a>
1510
+
1511
+ Returns a list of all Exchange Rate Pairs for all supported Currencies.
1512
+
1513
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1514
+
1515
+ ```ruby
1516
+ result = snaptrade.reference_data.list_all_currencies_rates
1517
+ p result
1518
+ ```
1519
+
1520
+ #### 🔄 Return<a id="🔄-return"></a>
1521
+
1522
+ [ExchangeRatePairs](./lib/snaptrade/models/exchange_rate_pairs.rb)
1523
+
1524
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1525
+
1526
+ `/currencies/rates` `GET`
1527
+
1528
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1529
+
1530
+ ---
1531
+
1532
+
1533
+ ### `snaptrade.reference_data.symbol_search_user_account`<a id="snaptradereference_datasymbol_search_user_account"></a>
1534
+
1535
+ 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.
1536
+
1537
+ The search results are further limited to the symbols supported by the brokerage for which the account is under.
1538
+
1539
+
1540
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1541
+
1542
+ ```ruby
1543
+ result = snaptrade.reference_data.symbol_search_user_account(
1544
+ user_id: "snaptrade-user-123",
1545
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
1546
+ account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
1547
+ substring: "AAPL",
1548
+ )
1549
+ p result
1550
+ ```
1551
+
1552
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1553
+
1554
+ ##### user_id: `String`<a id="user_id-string"></a>
1555
+ ##### user_secret: `String`<a id="user_secret-string"></a>
1556
+ ##### account_id: `String`<a id="account_id-string"></a>
1557
+ ##### substring: `String`<a id="substring-string"></a>
1558
+ The search query for symbols.
1559
+
1560
+ #### 🔄 Return<a id="🔄-return"></a>
1561
+
1562
+ [UniversalSymbol](./lib/snaptrade/models/universal_symbol.rb)
1563
+
1564
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1565
+
1566
+ `/accounts/{accountId}/symbols` `POST`
1567
+
1568
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1569
+
1570
+ ---
1571
+
1572
+
1573
+ ### `snaptrade.trading.cancel_user_account_order`<a id="snaptradetradingcancel_user_account_order"></a>
1574
+
1575
+ Attempts to cancel an open order with the brokerage. If the order is no longer cancellable, the request will be rejected.
1576
+
1577
+
1578
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1579
+
1580
+ ```ruby
1581
+ result = snaptrade.trading.cancel_user_account_order(
1582
+ user_id: "snaptrade-user-123",
1583
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
1584
+ account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
1585
+ brokerage_order_id: "66a033fa-da74-4fcf-b527-feefdec9257e",
1586
+ )
1587
+ p result
1588
+ ```
1589
+
1590
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1591
+
1592
+ ##### user_id: `String`<a id="user_id-string"></a>
1593
+ ##### user_secret: `String`<a id="user_secret-string"></a>
1594
+ ##### account_id: `String`<a id="account_id-string"></a>
1595
+ ##### brokerage_order_id: `String`<a id="brokerage_order_id-string"></a>
1596
+ Order ID returned by brokerage. This is the unique identifier for the order in
1597
+ the brokerage system.
1598
+
1599
+ #### 🔄 Return<a id="🔄-return"></a>
1600
+
1601
+ [AccountOrderRecord](./lib/snaptrade/models/account_order_record.rb)
1602
+
1603
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1604
+
1605
+ `/accounts/{accountId}/orders/cancel` `POST`
1606
+
1607
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1608
+
1609
+ ---
1610
+
1611
+
1612
+ ### `snaptrade.trading.get_order_impact`<a id="snaptradetradingget_order_impact"></a>
1613
+
1614
+ Simulates an order and its impact on the account. This endpoint does not place the order with the brokerage. If successful, it returns a `Trade` object and the ID of the object can be used to place the order with the brokerage using the [place checked order endpoint](/reference/Trading/Trading_placeOrder). Please note that the `Trade` object returned expires after 5 minutes. Any order placed using an expired `Trade` will be rejected.
1615
+
1616
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1617
+
1618
+ ```ruby
1619
+ result = snaptrade.trading.get_order_impact(
1620
+ account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
1621
+ action: "BUY",
1622
+ universal_symbol_id: "2bcd7cc3-e922-4976-bce1-9858296801c3",
1623
+ order_type: "Market",
1624
+ time_in_force: "FOK",
1625
+ user_id: "snaptrade-user-123",
1626
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
1627
+ price: 31.33,
1628
+ stop: 31.33,
1629
+ units: 10.5,
1630
+ notional_value: None,
1631
+ )
1632
+ p result
1633
+ ```
1634
+
1635
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1636
+
1637
+ ##### account_id: `String`<a id="account_id-string"></a>
1638
+ Unique identifier for the connected brokerage account. This is the UUID used to
1639
+ reference the account in SnapTrade.
1640
+
1641
+ ##### action: [`ActionStrict`](./lib/snaptrade/models/action_strict.rb)<a id="action-actionstrictlibsnaptrademodelsaction_strictrb"></a>
1642
+ The action describes the intent or side of a trade. This is either `BUY` or
1643
+ `SELL`.
1644
+
1645
+ ##### universal_symbol_id: `String`<a id="universal_symbol_id-string"></a>
1646
+ Unique identifier for the symbol within SnapTrade. This is the ID used to
1647
+ reference the symbol in SnapTrade API calls.
1648
+
1649
+ ##### order_type: [`OrderTypeStrict`](./lib/snaptrade/models/order_type_strict.rb)<a id="order_type-ordertypestrictlibsnaptrademodelsorder_type_strictrb"></a>
1650
+ The type of order to place. - For `Limit` and `StopLimit` orders, the `price`
1651
+ field is required. - For `Stop` and `StopLimit` orders, the `stop` field is
1652
+ required.
1653
+
1654
+ ##### time_in_force: [`TimeInForceStrict`](./lib/snaptrade/models/time_in_force_strict.rb)<a id="time_in_force-timeinforcestrictlibsnaptrademodelstime_in_force_strictrb"></a>
1655
+ The Time in Force type for the order. This field indicates how long the order
1656
+ will remain active before it is executed or expires. Here are the supported
1657
+ values: - `Day` - Day. The order is valid only for the trading day on which it
1658
+ is placed. - `GTC` - Good Til Canceled. The order is valid until it is executed
1659
+ or canceled. - `FOK` - Fill Or Kill. The order must be executed in its entirety
1660
+ immediately or be canceled completely.
1661
+
1662
+ ##### user_id: `String`<a id="user_id-string"></a>
1663
+ ##### user_secret: `String`<a id="user_secret-string"></a>
1664
+ ##### price: `Float`<a id="price-float"></a>
1665
+ The limit price for `Limit` and `StopLimit` orders.
1666
+
1667
+ ##### stop: `Float`<a id="stop-float"></a>
1668
+ The price at which a stop order is triggered for `Stop` and `StopLimit` orders.
1669
+
1670
+ ##### units: [`Float`](./lib/snaptrade/models/float.rb)<a id="units-floatlibsnaptrademodelsfloatrb"></a>
1671
+ ##### notional_value: [`ManualTradeFormNotionalValue`](./lib/snaptrade/models/manual_trade_form_notional_value.rb)<a id="notional_value-manualtradeformnotionalvaluelibsnaptrademodelsmanual_trade_form_notional_valuerb"></a>
1672
+ #### 🔄 Return<a id="🔄-return"></a>
1673
+
1674
+ [ManualTradeAndImpact](./lib/snaptrade/models/manual_trade_and_impact.rb)
1675
+
1676
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1677
+
1678
+ `/trade/impact` `POST`
1679
+
1680
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1681
+
1682
+ ---
1683
+
1684
+
1685
+ ### `snaptrade.trading.get_user_account_quotes`<a id="snaptradetradingget_user_account_quotes"></a>
1686
+
1687
+ Returns quotes from the brokerage for the specified symbols and account. The quotes returned can be delayed depending on the brokerage the account belongs to. It is highly recommended that you use your own market data provider for real-time quotes instead of relying on this endpoint. This endpoint does not work for options quotes.
1688
+
1689
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1690
+
1691
+ ```ruby
1692
+ result = snaptrade.trading.get_user_account_quotes(
1693
+ user_id: "snaptrade-user-123",
1694
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
1695
+ symbols: "symbols_example",
1696
+ account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
1697
+ use_ticker: true,
1698
+ )
1699
+ p result
1700
+ ```
1701
+
1702
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1703
+
1704
+ ##### user_id: `String`<a id="user_id-string"></a>
1705
+ ##### user_secret: `String`<a id="user_secret-string"></a>
1706
+ ##### symbols: `String`<a id="symbols-string"></a>
1707
+ List of Universal Symbol IDs or tickers to get quotes for. When providing
1708
+ multiple values, use a comma as separator
1709
+
1710
+ ##### account_id: `String`<a id="account_id-string"></a>
1711
+ ##### use_ticker: `Boolean`<a id="use_ticker-boolean"></a>
1712
+ Should be set to `True` if `symbols` are comprised of tickers. Defaults to
1713
+ `False` if not provided.
1714
+
1715
+ #### 🔄 Return<a id="🔄-return"></a>
1716
+
1717
+ [SymbolsQuotesInner](./lib/snaptrade/models/symbols_quotes_inner.rb)
1718
+
1719
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1720
+
1721
+ `/accounts/{accountId}/quotes` `GET`
1722
+
1723
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1724
+
1725
+ ---
1726
+
1727
+
1728
+ ### `snaptrade.trading.place_force_order`<a id="snaptradetradingplace_force_order"></a>
1729
+
1730
+ Places a brokerage order in the specified account. The order could be rejected by the brokerage if it is invalid or if the account does not have sufficient funds.
1731
+
1732
+ This endpoint does not compute the impact to the account balance from the order and any potential commissions before submitting the order to the brokerage. If that is desired, you can use the [check order impact endpoint](/reference/Trading/Trading_getOrderImpact).
1733
+
1734
+ It's recommended to trigger a manual refresh of the account after placing an order to ensure the account is up to date. You can use the [manual refresh](/reference/Connections/Connections_refreshBrokerageAuthorization) endpoint for this.
1735
+
1736
+
1737
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1738
+
1739
+ ```ruby
1740
+ result = snaptrade.trading.place_force_order(
1741
+ account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
1742
+ action: "BUY",
1743
+ order_type: "Market",
1744
+ time_in_force: "FOK",
1745
+ user_id: "snaptrade-user-123",
1746
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
1747
+ universal_symbol_id: "2bcd7cc3-e922-4976-bce1-9858296801c3",
1748
+ symbol: "AAPL 131124C00240000",
1749
+ price: 31.33,
1750
+ stop: 31.33,
1751
+ units: 10.5,
1752
+ notional_value: None,
1753
+ order_class: "BRACKET",
1754
+ stop_loss: {
1755
+ "stop_price" => "48.55",
1756
+ "limit_price" => "48.50",
1757
+ },
1758
+ take_profit: {
1759
+ "limit_price" => "49.95",
1760
+ },
1761
+ )
1762
+ p result
1763
+ ```
1764
+
1765
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1766
+
1767
+ ##### account_id: `String`<a id="account_id-string"></a>
1768
+ Unique identifier for the connected brokerage account. This is the UUID used to
1769
+ reference the account in SnapTrade.
1770
+
1771
+ ##### action: [`ActionStrictWithOptions`](./lib/snaptrade/models/action_strict_with_options.rb)<a id="action-actionstrictwithoptionslibsnaptrademodelsaction_strict_with_optionsrb"></a>
1772
+ The action describes the intent or side of a trade. This is either `BUY` or
1773
+ `SELL` for Equity symbols or `BUY_TO_OPEN`, `BUY_TO_CLOSE`, `SELL_TO_OPEN` or
1774
+ `SELL_TO_CLOSE` for Options.
1775
+
1776
+ ##### order_type: [`OrderTypeStrict`](./lib/snaptrade/models/order_type_strict.rb)<a id="order_type-ordertypestrictlibsnaptrademodelsorder_type_strictrb"></a>
1777
+ The type of order to place. - For `Limit` and `StopLimit` orders, the `price`
1778
+ field is required. - For `Stop` and `StopLimit` orders, the `stop` field is
1779
+ required.
1780
+
1781
+ ##### time_in_force: [`TimeInForceStrict`](./lib/snaptrade/models/time_in_force_strict.rb)<a id="time_in_force-timeinforcestrictlibsnaptrademodelstime_in_force_strictrb"></a>
1782
+ The Time in Force type for the order. This field indicates how long the order
1783
+ will remain active before it is executed or expires. Here are the supported
1784
+ values: - `Day` - Day. The order is valid only for the trading day on which it
1785
+ is placed. - `GTC` - Good Til Canceled. The order is valid until it is executed
1786
+ or canceled. - `FOK` - Fill Or Kill. The order must be executed in its entirety
1787
+ immediately or be canceled completely.
1788
+
1789
+ ##### user_id: `String`<a id="user_id-string"></a>
1790
+ ##### user_secret: `String`<a id="user_secret-string"></a>
1791
+ ##### universal_symbol_id: [`String`](./lib/snaptrade/models/string.rb)<a id="universal_symbol_id-stringlibsnaptrademodelsstringrb"></a>
1792
+ The universal symbol ID of the security to trade. Must be 'null' if `symbol` is
1793
+ provided, otherwise must be provided.
1794
+
1795
+ ##### symbol: `String`<a id="symbol-string"></a>
1796
+ The security's trading ticker symbol. This currently only support Options
1797
+ symbols in the 21 character OCC format. For example \"AAPL 131124C00240000\"
1798
+ represents a call option on AAPL expiring on 2024-11-13 with a strike price of
1799
+ $240. For more information on the OCC format, see
1800
+ [here](https://en.wikipedia.org/wiki/Option_symbol#OCC_format). If 'symbol' is
1801
+ provided, then 'universal_symbol_id' must be 'null'.
1802
+
1803
+ ##### price: `Float`<a id="price-float"></a>
1804
+ The limit price for `Limit` and `StopLimit` orders.
1805
+
1806
+ ##### stop: `Float`<a id="stop-float"></a>
1807
+ The price at which a stop order is triggered for `Stop` and `StopLimit` orders.
1808
+
1809
+ ##### units: [`Float`](./lib/snaptrade/models/float.rb)<a id="units-floatlibsnaptrademodelsfloatrb"></a>
1810
+ For Equity orders, this represents the number of shares for the order. This can
1811
+ be a decimal for fractional orders. Must be `null` if `notional_value` is
1812
+ provided. If placing an Option order, this field represents the number of
1813
+ contracts to buy or sell. (e.g., 1 contract = 100 shares).
1814
+
1815
+ ##### notional_value: [`ManualTradeFormNotionalValue`](./lib/snaptrade/models/manual_trade_form_notional_value.rb)<a id="notional_value-manualtradeformnotionalvaluelibsnaptrademodelsmanual_trade_form_notional_valuerb"></a>
1816
+ ##### order_class: [`OrderClass`](./lib/snaptrade/models/order_class.rb)<a id="order_class-orderclasslibsnaptrademodelsorder_classrb"></a>
1817
+ The class of order intended to be placed. Defaults to SIMPLE for regular, one
1818
+ legged trades. Set to BRACKET if looking to place a bracket
1819
+ (One-triggers-a-one-cancels-the-other) order, then specify take profit and stop
1820
+ loss conditions. Bracket orders currently only supported on Alpaca, Tradier, and
1821
+ Tradestation, contact us for more details
1822
+
1823
+ ##### stop_loss: [`ManualTradeFormWithOptionsStopLoss`](./lib/snaptrade/models/manual_trade_form_with_options_stop_loss.rb)<a id="stop_loss-manualtradeformwithoptionsstoplosslibsnaptrademodelsmanual_trade_form_with_options_stop_lossrb"></a>
1824
+ ##### take_profit: [`ManualTradeFormWithOptionsTakeProfit`](./lib/snaptrade/models/manual_trade_form_with_options_take_profit.rb)<a id="take_profit-manualtradeformwithoptionstakeprofitlibsnaptrademodelsmanual_trade_form_with_options_take_profitrb"></a>
1825
+ #### 🔄 Return<a id="🔄-return"></a>
1826
+
1827
+ [AccountOrderRecord](./lib/snaptrade/models/account_order_record.rb)
1828
+
1829
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1830
+
1831
+ `/trade/place` `POST`
1832
+
1833
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1834
+
1835
+ ---
1836
+
1837
+
1838
+ ### `snaptrade.trading.place_order`<a id="snaptradetradingplace_order"></a>
1839
+
1840
+ Places the previously checked order with the brokerage. The `tradeId` is obtained from the [check order impact endpoint](/reference/Trading/Trading_getOrderImpact). If you prefer to place the order without checking for impact first, you can use the [place order endpoint](/reference/Trading/Trading_placeForceOrder).
1841
+
1842
+ It's recommended to trigger a manual refresh of the account after placing an order to ensure the account is up to date. You can use the [manual refresh](/reference/Connections/Connections_refreshBrokerageAuthorization) endpoint for this.
1843
+
1844
+
1845
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1846
+
1847
+ ```ruby
1848
+ result = snaptrade.trading.place_order(
1849
+ trade_id: "139e307a-82f7-4402-b39e-4da7baa87758",
1850
+ user_id: "snaptrade-user-123",
1851
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
1852
+ wait_to_confirm: true,
1853
+ )
1854
+ p result
1855
+ ```
1856
+
1857
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1858
+
1859
+ ##### trade_id: `String`<a id="trade_id-string"></a>
1860
+ Obtained from calling the [check order impact
1861
+ endpoint](/reference/Trading/Trading_getOrderImpact)
1862
+
1863
+ ##### user_id: `String`<a id="user_id-string"></a>
1864
+ ##### user_secret: `String`<a id="user_secret-string"></a>
1865
+ ##### wait_to_confirm: `Boolean`<a id="wait_to_confirm-boolean"></a>
1866
+ Optional, defaults to true. Determines if a wait is performed to check on order
1867
+ status. If false, latency will be reduced but orders returned will be more
1868
+ likely to be of status `PENDING` as we will not wait to check on the status
1869
+ before responding to the request.
1870
+
1871
+ #### 🔄 Return<a id="🔄-return"></a>
1872
+
1873
+ [AccountOrderRecord](./lib/snaptrade/models/account_order_record.rb)
1874
+
1875
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1876
+
1877
+ `/trade/{tradeId}` `POST`
1878
+
1879
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1880
+
1881
+ ---
1882
+
1883
+
1884
+ ### `snaptrade.transactions_and_reporting.get_activities`<a id="snaptradetransactions_and_reportingget_activities"></a>
1885
+
1886
+ Returns all historical transactions for the specified user and filtering criteria. It's recommended to use `startDate` and `endDate` to paginate through the data, as the response may be very large for accounts with a long history and/or a lot of activity. There's a max number of 10000 transactions returned per request.
1887
+
1888
+ There is no guarantee to the ordering of the transactions returned. Please sort the transactions based on the `trade_date` field if you need them in a specific order.
1889
+
1890
+ The data returned here is always cached and refreshed once a day.
1891
+
1892
+
1893
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1894
+
1895
+ ```ruby
1896
+ result = snaptrade.transactions_and_reporting.get_activities(
1897
+ user_id: "snaptrade-user-123",
1898
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
1899
+ start_date: "2022-01-24",
1900
+ end_date: "2022-01-24",
1901
+ accounts: "917c8734-8470-4a3e-a18f-57c3f2ee6631,65e839a3-9103-4cfb-9b72-2071ef80c5f2",
1902
+ brokerage_authorizations: "917c8734-8470-4a3e-a18f-57c3f2ee6631,65e839a3-9103-4cfb-9b72-2071ef80c5f2",
1903
+ type: "BUY,SELL,DIVIDEND",
1904
+ )
1905
+ p result
1906
+ ```
1907
+
1908
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1909
+
1910
+ ##### user_id: `String`<a id="user_id-string"></a>
1911
+ ##### user_secret: `String`<a id="user_secret-string"></a>
1912
+ ##### start_date: `Date`<a id="start_date-date"></a>
1913
+ The start date (inclusive) of the transaction history to retrieve. If not
1914
+ provided, the default is the first transaction known to SnapTrade based on
1915
+ `trade_date`.
1916
+
1917
+ ##### end_date: `Date`<a id="end_date-date"></a>
1918
+ The end date (inclusive) of the transaction history to retrieve. If not
1919
+ provided, the default is the last transaction known to SnapTrade based on
1920
+ `trade_date`.
1921
+
1922
+ ##### accounts: `String`<a id="accounts-string"></a>
1923
+ Optional comma separated list of SnapTrade Account IDs used to filter the
1924
+ request to specific accounts. If not provided, the default is all known
1925
+ brokerage accounts for the user. The `brokerageAuthorizations` parameter takes
1926
+ precedence over this parameter.
1927
+
1928
+ ##### brokerage_authorizations: `String`<a id="brokerage_authorizations-string"></a>
1929
+ Optional comma separated list of SnapTrade Connection (Brokerage Authorization)
1930
+ IDs used to filter the request to only accounts that belong to those
1931
+ connections. If not provided, the default is all connections for the user. This
1932
+ parameter takes precedence over the `accounts` parameter.
1933
+
1934
+ ##### type: `String`<a id="type-string"></a>
1935
+ Optional comma separated list of transaction types to filter by. SnapTrade does
1936
+ a best effort to categorize brokerage transaction types into a common set of
1937
+ values. Here are some of the most popular values: - `BUY` - Asset bought. -
1938
+ `SELL` - Asset sold. - `DIVIDEND` - Dividend payout. - `CONTRIBUTION` - Cash
1939
+ contribution. - `WITHDRAWAL` - Cash withdrawal. - `REI` - Dividend reinvestment.
1940
+ - `INTEREST` - Interest deposited into the account. - `FEE` - Fee withdrawn from
1941
+ the account. - `OPTIONEXPIRATION` - Option expiration event. -
1942
+ `OPTIONASSIGNMENT` - Option assignment event. - `OPTIONEXERCISE` - Option
1943
+ exercise event. - `TRANSFER` - Transfer of assets from one account to another
1944
+
1945
+ #### 🔄 Return<a id="🔄-return"></a>
1946
+
1947
+ [UniversalActivity](./lib/snaptrade/models/universal_activity.rb)
1948
+
1949
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1950
+
1951
+ `/activities` `GET`
1952
+
1953
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1954
+
1955
+ ---
1956
+
1957
+
1958
+ ### `snaptrade.transactions_and_reporting.get_reporting_custom_range`<a id="snaptradetransactions_and_reportingget_reporting_custom_range"></a>
1959
+ ![Deprecated](https://img.shields.io/badge/deprecated-yellow)
1960
+
1961
+ Returns performance information (contributions, dividends, rate of return, etc) for a specific timeframe. Please note that Total Equity Timeframe and Rate of Returns are experimental features. Please contact support@snaptrade.com if you notice any inconsistencies.
1962
+
1963
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1964
+
1965
+ ```ruby
1966
+ result = snaptrade.transactions_and_reporting.get_reporting_custom_range(
1967
+ start_date: "2022-01-24",
1968
+ end_date: "2022-01-24",
1969
+ user_id: "snaptrade-user-123",
1970
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
1971
+ accounts: "917c8734-8470-4a3e-a18f-57c3f2ee6631,65e839a3-9103-4cfb-9b72-2071ef80c5f2",
1972
+ detailed: true,
1973
+ frequency: "monthly",
1974
+ )
1975
+ p result
1976
+ ```
1977
+
1978
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1979
+
1980
+ ##### start_date: `Date`<a id="start_date-date"></a>
1981
+ ##### end_date: `Date`<a id="end_date-date"></a>
1982
+ ##### user_id: `String`<a id="user_id-string"></a>
1983
+ ##### user_secret: `String`<a id="user_secret-string"></a>
1984
+ ##### accounts: `String`<a id="accounts-string"></a>
1985
+ Optional comma separated list of account IDs used to filter the request on
1986
+ specific accounts
1987
+
1988
+ ##### detailed: `Boolean`<a id="detailed-boolean"></a>
1989
+ Optional, increases frequency of data points for the total value and
1990
+ contribution charts if set to true
1991
+
1992
+ ##### frequency: `String`<a id="frequency-string"></a>
1993
+ Optional frequency for the rate of return chart (defaults to monthly). Possible
1994
+ values are daily, weekly, monthly, quarterly, yearly.
1995
+
1996
+ #### 🔄 Return<a id="🔄-return"></a>
1997
+
1998
+ [PerformanceCustom](./lib/snaptrade/models/performance_custom.rb)
1999
+
2000
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
2001
+
2002
+ `/performance/custom` `GET`
2003
+
2004
+ [🔙 **Back to Table of Contents**](#table-of-contents)
2005
+
2006
+ ---
2007
+
223
2008
 
2009
+ ## Author<a id="author"></a>
2010
+ This TypeScript package is automatically generated by [Konfig](https://konfigthis.com)