snaptrade 1.8.0 → 1.10.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (293) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile +10 -10
  3. data/Gemfile.lock +11 -13
  4. data/README.md +218 -218
  5. data/docs/APIStatusApi.md +57 -57
  6. data/docs/AccountInformationApi.md +535 -535
  7. data/docs/AuthenticationApi.md +314 -314
  8. data/docs/ConnectionsApi.md +265 -265
  9. data/docs/ErrorLogsApi.md +68 -68
  10. data/docs/OptionsApi.md +378 -378
  11. data/docs/ReferenceDataApi.md +595 -595
  12. data/docs/TradingApi.md +478 -478
  13. data/docs/TransactionsAndReportingApi.md +183 -183
  14. data/lib/snaptrade/api/account_information_api.rb +801 -801
  15. data/lib/snaptrade/api/api_status_api.rb +98 -98
  16. data/lib/snaptrade/api/authentication_api.rb +481 -481
  17. data/lib/snaptrade/api/connections_api.rb +398 -398
  18. data/lib/snaptrade/api/error_logs_api.rb +112 -112
  19. data/lib/snaptrade/api/options_api.rb +591 -591
  20. data/lib/snaptrade/api/reference_data_api.rb +894 -894
  21. data/lib/snaptrade/api/trading_api.rb +741 -741
  22. data/lib/snaptrade/api/transactions_and_reporting_api.rb +283 -283
  23. data/lib/snaptrade/api_client.rb +427 -427
  24. data/lib/snaptrade/api_client_custom.rb +32 -32
  25. data/lib/snaptrade/api_error.rb +6 -6
  26. data/lib/snaptrade/configuration.rb +334 -334
  27. data/lib/snaptrade/models/account.rb +6 -6
  28. data/lib/snaptrade/models/account_holdings.rb +251 -251
  29. data/lib/snaptrade/models/account_holdings_account.rb +263 -263
  30. data/lib/snaptrade/models/account_order_record.rb +6 -6
  31. data/lib/snaptrade/models/account_order_record_status.rb +6 -6
  32. data/lib/snaptrade/models/account_simple.rb +6 -6
  33. data/lib/snaptrade/models/account_sync_status.rb +6 -6
  34. data/lib/snaptrade/models/action.rb +6 -6
  35. data/lib/snaptrade/models/auth_type.rb +6 -6
  36. data/lib/snaptrade/models/authentication_login_snap_trade_user200_response.rb +6 -6
  37. data/lib/snaptrade/models/balance.rb +6 -6
  38. data/lib/snaptrade/models/brokerage.rb +6 -6
  39. data/lib/snaptrade/models/brokerage_authorization.rb +6 -6
  40. data/lib/snaptrade/models/brokerage_authorization_type.rb +6 -6
  41. data/lib/snaptrade/models/brokerage_authorization_type_read_only.rb +6 -6
  42. data/lib/snaptrade/models/brokerage_authorization_type_read_only_brokerage.rb +6 -6
  43. data/lib/snaptrade/models/brokerage_authorization_type_read_only_type.rb +6 -6
  44. data/lib/snaptrade/models/brokerage_authorization_type_type.rb +6 -6
  45. data/lib/snaptrade/models/brokerage_symbol.rb +6 -6
  46. data/lib/snaptrade/models/brokerage_type.rb +6 -6
  47. data/lib/snaptrade/models/calculated_trade.rb +6 -6
  48. data/lib/snaptrade/models/cash_restriction.rb +6 -6
  49. data/lib/snaptrade/models/connection_type.rb +6 -6
  50. data/lib/snaptrade/models/connections_session_events200_response_inner.rb +6 -6
  51. data/lib/snaptrade/models/currency.rb +6 -6
  52. data/lib/snaptrade/models/delete_user_response.rb +6 -6
  53. data/lib/snaptrade/models/dividend_at_date.rb +6 -6
  54. data/lib/snaptrade/models/encrypted_response.rb +6 -6
  55. data/lib/snaptrade/models/encrypted_response_encrypted_message_data.rb +6 -6
  56. data/lib/snaptrade/models/exchange.rb +6 -6
  57. data/lib/snaptrade/models/exchange_rate_pairs.rb +6 -6
  58. data/lib/snaptrade/models/excluded_asset.rb +6 -6
  59. data/lib/snaptrade/models/jwt.rb +6 -6
  60. data/lib/snaptrade/models/login_redirect_uri.rb +6 -6
  61. data/lib/snaptrade/models/manual_trade.rb +6 -6
  62. data/lib/snaptrade/models/manual_trade_and_impact.rb +6 -6
  63. data/lib/snaptrade/models/manual_trade_balance.rb +6 -6
  64. data/lib/snaptrade/models/manual_trade_form.rb +6 -6
  65. data/lib/snaptrade/models/manual_trade_symbol.rb +6 -6
  66. data/lib/snaptrade/models/model400_failed_request_response.rb +6 -6
  67. data/lib/snaptrade/models/model401_failed_request_response.rb +6 -6
  68. data/lib/snaptrade/models/model403_failed_request_response.rb +6 -6
  69. data/lib/snaptrade/models/model404_failed_request_response.rb +6 -6
  70. data/lib/snaptrade/models/model_asset_class.rb +6 -6
  71. data/lib/snaptrade/models/model_asset_class_details.rb +6 -6
  72. data/lib/snaptrade/models/model_asset_class_target.rb +6 -6
  73. data/lib/snaptrade/models/model_portfolio.rb +6 -6
  74. data/lib/snaptrade/models/model_portfolio_asset_class.rb +6 -6
  75. data/lib/snaptrade/models/model_portfolio_details.rb +6 -6
  76. data/lib/snaptrade/models/model_portfolio_security.rb +6 -6
  77. data/lib/snaptrade/models/model_type.rb +6 -6
  78. data/lib/snaptrade/models/monthly_dividends.rb +6 -6
  79. data/lib/snaptrade/models/net_contributions.rb +6 -6
  80. data/lib/snaptrade/models/net_dividend.rb +6 -6
  81. data/lib/snaptrade/models/option_chain_inner.rb +6 -6
  82. data/lib/snaptrade/models/option_chain_inner_chain_per_root_inner.rb +6 -6
  83. data/lib/snaptrade/models/option_chain_inner_chain_per_root_inner_chain_per_strike_price_inner.rb +6 -6
  84. data/lib/snaptrade/models/option_leg.rb +6 -6
  85. data/lib/snaptrade/models/option_leg_action.rb +6 -6
  86. data/lib/snaptrade/models/option_strategy.rb +6 -6
  87. data/lib/snaptrade/models/option_strategy_legs_inner.rb +6 -6
  88. data/lib/snaptrade/models/options_get_option_strategy_request.rb +6 -6
  89. data/lib/snaptrade/models/options_holdings.rb +6 -6
  90. data/lib/snaptrade/models/options_place_option_strategy_request.rb +6 -6
  91. data/lib/snaptrade/models/options_position.rb +6 -6
  92. data/lib/snaptrade/models/options_symbol.rb +6 -6
  93. data/lib/snaptrade/models/order_strategy_execute_body_order_type.rb +6 -6
  94. data/lib/snaptrade/models/order_strategy_execute_body_time_in_force.rb +6 -6
  95. data/lib/snaptrade/models/order_type.rb +6 -6
  96. data/lib/snaptrade/models/partner_data.rb +6 -6
  97. data/lib/snaptrade/models/past_value.rb +6 -6
  98. data/lib/snaptrade/models/performance_custom.rb +6 -6
  99. data/lib/snaptrade/models/portfolio_group.rb +6 -6
  100. data/lib/snaptrade/models/portfolio_group_info.rb +6 -6
  101. data/lib/snaptrade/models/portfolio_group_position.rb +6 -6
  102. data/lib/snaptrade/models/portfolio_group_settings.rb +6 -6
  103. data/lib/snaptrade/models/position.rb +6 -6
  104. data/lib/snaptrade/models/position_symbol.rb +6 -6
  105. data/lib/snaptrade/models/redirect_tokenand_pin.rb +6 -6
  106. data/lib/snaptrade/models/security_type.rb +6 -6
  107. data/lib/snaptrade/models/session_event.rb +6 -6
  108. data/lib/snaptrade/models/session_event_type.rb +6 -6
  109. data/lib/snaptrade/models/snap_trade_api_disclaimer_accept_status.rb +6 -6
  110. data/lib/snaptrade/models/snap_trade_holdings_account.rb +6 -6
  111. data/lib/snaptrade/models/snap_trade_holdings_account_account_id.rb +6 -6
  112. data/lib/snaptrade/models/snap_trade_holdings_total_value.rb +6 -6
  113. data/lib/snaptrade/models/snap_trade_login_user_request_body.rb +6 -6
  114. data/lib/snaptrade/models/snap_trade_register_user_request_body.rb +6 -6
  115. data/lib/snaptrade/models/state.rb +6 -6
  116. data/lib/snaptrade/models/status.rb +6 -6
  117. data/lib/snaptrade/models/strategy_impact.rb +6 -6
  118. data/lib/snaptrade/models/strategy_impact_legs_inner.rb +6 -6
  119. data/lib/snaptrade/models/strategy_order_place.rb +6 -6
  120. data/lib/snaptrade/models/strategy_order_place_orders_inner.rb +6 -6
  121. data/lib/snaptrade/models/strategy_order_place_orders_inner_legs_inner.rb +6 -6
  122. data/lib/snaptrade/models/strategy_order_record.rb +6 -6
  123. data/lib/snaptrade/models/strategy_order_record_order_type.rb +6 -6
  124. data/lib/snaptrade/models/strategy_order_record_status.rb +6 -6
  125. data/lib/snaptrade/models/strategy_order_record_time_in_force.rb +6 -6
  126. data/lib/snaptrade/models/strategy_quotes.rb +6 -6
  127. data/lib/snaptrade/models/strategy_quotes_greek.rb +6 -6
  128. data/lib/snaptrade/models/strategy_type.rb +6 -6
  129. data/lib/snaptrade/models/sub_period_return_rate.rb +6 -6
  130. data/lib/snaptrade/models/symbol.rb +6 -6
  131. data/lib/snaptrade/models/symbol_query.rb +6 -6
  132. data/lib/snaptrade/models/symbols_quotes_inner.rb +6 -6
  133. data/lib/snaptrade/models/target_asset.rb +6 -6
  134. data/lib/snaptrade/models/time_in_force.rb +6 -6
  135. data/lib/snaptrade/models/trade.rb +6 -6
  136. data/lib/snaptrade/models/trade_action.rb +6 -6
  137. data/lib/snaptrade/models/trade_execution_status.rb +6 -6
  138. data/lib/snaptrade/models/trade_execution_status_action.rb +6 -6
  139. data/lib/snaptrade/models/trade_impact.rb +6 -6
  140. data/lib/snaptrade/models/trading_cancel_user_account_order_request.rb +6 -6
  141. data/lib/snaptrade/models/trading_place_oco_order_request.rb +6 -6
  142. data/lib/snaptrade/models/transactions_status.rb +6 -6
  143. data/lib/snaptrade/models/type.rb +6 -6
  144. data/lib/snaptrade/models/underlying_symbol.rb +6 -6
  145. data/lib/snaptrade/models/universal_activity.rb +6 -6
  146. data/lib/snaptrade/models/universal_symbol.rb +6 -6
  147. data/lib/snaptrade/models/universal_symbol_ticker.rb +6 -6
  148. data/lib/snaptrade/models/us_exchange.rb +6 -6
  149. data/lib/snaptrade/models/user_error_log.rb +6 -6
  150. data/lib/snaptrade/models/user_i_dand_secret.rb +6 -6
  151. data/lib/snaptrade/models/user_settings.rb +6 -6
  152. data/lib/snaptrade/version.rb +13 -13
  153. data/lib/snaptrade.rb +211 -211
  154. data/snaptrade.gemspec +41 -41
  155. data/spec/api/account_information_api_spec.rb +135 -135
  156. data/spec/api/api_status_api_spec.rb +42 -42
  157. data/spec/api/authentication_api_spec.rb +88 -88
  158. data/spec/api/connections_api_spec.rb +82 -82
  159. data/spec/api/error_logs_api_spec.rb +43 -43
  160. data/spec/api/options_api_spec.rb +101 -101
  161. data/spec/api/reference_data_api_spec.rb +150 -150
  162. data/spec/api/trading_api_spec.rb +112 -112
  163. data/spec/api/transactions_and_reporting_api_spec.rb +67 -67
  164. data/spec/api_client_spec.rb +193 -193
  165. data/spec/configuration_spec.rb +6 -6
  166. data/spec/getting_started_spec.rb +108 -108
  167. data/spec/models/account_holdings_account_spec.rb +54 -54
  168. data/spec/models/account_holdings_spec.rb +48 -48
  169. data/spec/models/account_order_record_spec.rb +132 -132
  170. data/spec/models/account_order_record_status_spec.rb +24 -24
  171. data/spec/models/account_simple_spec.rb +48 -48
  172. data/spec/models/account_spec.rb +84 -84
  173. data/spec/models/account_sync_status_spec.rb +30 -30
  174. data/spec/models/action_spec.rb +24 -24
  175. data/spec/models/auth_type_spec.rb +24 -24
  176. data/spec/models/authentication_login_snap_trade_user200_response_spec.rb +27 -27
  177. data/spec/models/balance_spec.rb +36 -36
  178. data/spec/models/brokerage_authorization_spec.rb +78 -78
  179. data/spec/models/brokerage_authorization_type_read_only_brokerage_spec.rb +42 -42
  180. data/spec/models/brokerage_authorization_type_read_only_spec.rb +48 -48
  181. data/spec/models/brokerage_authorization_type_read_only_type_spec.rb +24 -24
  182. data/spec/models/brokerage_authorization_type_spec.rb +30 -30
  183. data/spec/models/brokerage_authorization_type_type_spec.rb +24 -24
  184. data/spec/models/brokerage_spec.rb +132 -132
  185. data/spec/models/brokerage_symbol_spec.rb +54 -54
  186. data/spec/models/brokerage_type_spec.rb +36 -36
  187. data/spec/models/calculated_trade_spec.rb +36 -36
  188. data/spec/models/cash_restriction_spec.rb +54 -54
  189. data/spec/models/connection_type_spec.rb +24 -24
  190. data/spec/models/connections_session_events200_response_inner_spec.rb +66 -66
  191. data/spec/models/currency_spec.rb +42 -42
  192. data/spec/models/delete_user_response_spec.rb +36 -36
  193. data/spec/models/dividend_at_date_spec.rb +42 -42
  194. data/spec/models/encrypted_response_encrypted_message_data_spec.rb +42 -42
  195. data/spec/models/encrypted_response_spec.rb +36 -36
  196. data/spec/models/exchange_rate_pairs_spec.rb +42 -42
  197. data/spec/models/exchange_spec.rb +72 -72
  198. data/spec/models/excluded_asset_spec.rb +30 -30
  199. data/spec/models/jwt_spec.rb +30 -30
  200. data/spec/models/login_redirect_uri_spec.rb +36 -36
  201. data/spec/models/manual_trade_and_impact_spec.rb +42 -42
  202. data/spec/models/manual_trade_balance_spec.rb +42 -42
  203. data/spec/models/manual_trade_form_spec.rb +72 -72
  204. data/spec/models/manual_trade_spec.rb +72 -72
  205. data/spec/models/manual_trade_symbol_spec.rb +60 -60
  206. data/spec/models/model400_failed_request_response_spec.rb +36 -36
  207. data/spec/models/model401_failed_request_response_spec.rb +36 -36
  208. data/spec/models/model403_failed_request_response_spec.rb +36 -36
  209. data/spec/models/model404_failed_request_response_spec.rb +36 -36
  210. data/spec/models/model_asset_class_details_spec.rb +36 -36
  211. data/spec/models/model_asset_class_spec.rb +36 -36
  212. data/spec/models/model_asset_class_target_spec.rb +30 -30
  213. data/spec/models/model_portfolio_asset_class_spec.rb +36 -36
  214. data/spec/models/model_portfolio_details_spec.rb +42 -42
  215. data/spec/models/model_portfolio_security_spec.rb +36 -36
  216. data/spec/models/model_portfolio_spec.rb +42 -42
  217. data/spec/models/model_type_spec.rb +24 -24
  218. data/spec/models/monthly_dividends_spec.rb +36 -36
  219. data/spec/models/net_contributions_spec.rb +42 -42
  220. data/spec/models/net_dividend_spec.rb +42 -42
  221. data/spec/models/option_chain_inner_chain_per_root_inner_chain_per_strike_price_inner_spec.rb +42 -42
  222. data/spec/models/option_chain_inner_chain_per_root_inner_spec.rb +42 -42
  223. data/spec/models/option_chain_inner_spec.rb +54 -54
  224. data/spec/models/option_leg_action_spec.rb +24 -24
  225. data/spec/models/option_leg_spec.rb +42 -42
  226. data/spec/models/option_strategy_legs_inner_spec.rb +48 -48
  227. data/spec/models/option_strategy_spec.rb +54 -54
  228. data/spec/models/options_get_option_strategy_request_spec.rb +42 -42
  229. data/spec/models/options_holdings_spec.rb +60 -60
  230. data/spec/models/options_place_option_strategy_request_spec.rb +42 -42
  231. data/spec/models/options_position_spec.rb +66 -66
  232. data/spec/models/options_symbol_spec.rb +90 -90
  233. data/spec/models/order_strategy_execute_body_order_type_spec.rb +24 -24
  234. data/spec/models/order_strategy_execute_body_time_in_force_spec.rb +24 -24
  235. data/spec/models/order_type_spec.rb +24 -24
  236. data/spec/models/partner_data_spec.rb +96 -96
  237. data/spec/models/past_value_spec.rb +42 -42
  238. data/spec/models/performance_custom_spec.rb +138 -138
  239. data/spec/models/portfolio_group_info_spec.rb +90 -90
  240. data/spec/models/portfolio_group_position_spec.rb +42 -42
  241. data/spec/models/portfolio_group_settings_spec.rb +54 -54
  242. data/spec/models/portfolio_group_spec.rb +36 -36
  243. data/spec/models/position_spec.rb +60 -60
  244. data/spec/models/position_symbol_spec.rb +60 -60
  245. data/spec/models/redirect_tokenand_pin_spec.rb +36 -36
  246. data/spec/models/security_type_spec.rb +48 -48
  247. data/spec/models/session_event_spec.rb +66 -66
  248. data/spec/models/session_event_type_spec.rb +24 -24
  249. data/spec/models/snap_trade_api_disclaimer_accept_status_spec.rb +36 -36
  250. data/spec/models/snap_trade_holdings_account_account_id_spec.rb +78 -78
  251. data/spec/models/snap_trade_holdings_account_spec.rb +72 -72
  252. data/spec/models/snap_trade_holdings_total_value_spec.rb +36 -36
  253. data/spec/models/snap_trade_login_user_request_body_spec.rb +54 -54
  254. data/spec/models/snap_trade_register_user_request_body_spec.rb +36 -36
  255. data/spec/models/state_spec.rb +24 -24
  256. data/spec/models/status_spec.rb +42 -42
  257. data/spec/models/strategy_impact_legs_inner_spec.rb +66 -66
  258. data/spec/models/strategy_impact_spec.rb +90 -90
  259. data/spec/models/strategy_order_place_orders_inner_legs_inner_spec.rb +66 -66
  260. data/spec/models/strategy_order_place_orders_inner_spec.rb +282 -282
  261. data/spec/models/strategy_order_place_spec.rb +36 -36
  262. data/spec/models/strategy_order_record_order_type_spec.rb +24 -24
  263. data/spec/models/strategy_order_record_spec.rb +90 -90
  264. data/spec/models/strategy_order_record_status_spec.rb +24 -24
  265. data/spec/models/strategy_order_record_time_in_force_spec.rb +24 -24
  266. data/spec/models/strategy_quotes_greek_spec.rb +54 -54
  267. data/spec/models/strategy_quotes_spec.rb +60 -60
  268. data/spec/models/strategy_type_spec.rb +24 -24
  269. data/spec/models/sub_period_return_rate_spec.rb +42 -42
  270. data/spec/models/symbol_query_spec.rb +30 -30
  271. data/spec/models/symbol_spec.rb +66 -66
  272. data/spec/models/symbols_quotes_inner_spec.rb +60 -60
  273. data/spec/models/target_asset_spec.rb +60 -60
  274. data/spec/models/time_in_force_spec.rb +24 -24
  275. data/spec/models/trade_action_spec.rb +24 -24
  276. data/spec/models/trade_execution_status_action_spec.rb +24 -24
  277. data/spec/models/trade_execution_status_spec.rb +78 -78
  278. data/spec/models/trade_impact_spec.rb +54 -54
  279. data/spec/models/trade_spec.rb +72 -72
  280. data/spec/models/trading_cancel_user_account_order_request_spec.rb +30 -30
  281. data/spec/models/trading_place_oco_order_request_spec.rb +36 -36
  282. data/spec/models/transactions_status_spec.rb +36 -36
  283. data/spec/models/type_spec.rb +24 -24
  284. data/spec/models/underlying_symbol_spec.rb +66 -66
  285. data/spec/models/universal_activity_spec.rb +120 -120
  286. data/spec/models/universal_symbol_spec.rb +72 -72
  287. data/spec/models/universal_symbol_ticker_spec.rb +72 -72
  288. data/spec/models/us_exchange_spec.rb +78 -78
  289. data/spec/models/user_error_log_spec.rb +60 -60
  290. data/spec/models/user_i_dand_secret_spec.rb +36 -36
  291. data/spec/models/user_settings_spec.rb +84 -84
  292. data/spec/spec_helper.rb +6 -6
  293. metadata +113 -113
@@ -1,801 +1,801 @@
1
- =begin
2
- #SnapTrade
3
-
4
- #Connect brokerage accounts to your app for live positions and trading
5
-
6
- The version of the OpenAPI document: 1.0.0
7
- Contact: api@snaptrade.com
8
-
9
- =end
10
-
11
- require 'cgi'
12
-
13
- module SnapTrade
14
- class AccountInformationApi
15
- attr_accessor :api_client
16
-
17
- def initialize(api_client = ApiClient.default)
18
- @api_client = api_client
19
- end
20
-
21
- # List all accounts for the user, plus balances and positions for each account.
22
- # @param user_id [String]
23
- # @param user_secret [String]
24
- # @param brokerage_authorizations [String] Optional. Comma seperated list of authorization IDs (only use if filtering is needed on one or more authorizations).
25
- # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
26
- def get_all_user_holdings(user_id:, user_secret:, brokerage_authorizations: SENTINEL, extra: {})
27
- extra[:brokerage_authorizations] = brokerage_authorizations if brokerage_authorizations != SENTINEL
28
-
29
- data, _status_code, _headers = get_all_user_holdings_with_http_info_impl(user_id, user_secret, extra)
30
- data
31
- end
32
-
33
- # List all accounts for the user, plus balances and positions for each account.
34
- # @param user_id [String]
35
- # @param user_secret [String]
36
- # @param brokerage_authorizations [String] Optional. Comma seperated list of authorization IDs (only use if filtering is needed on one or more authorizations).
37
- # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
38
- def get_all_user_holdings_with_http_info(user_id:, user_secret:, brokerage_authorizations: SENTINEL, extra: {})
39
- extra[:brokerage_authorizations] = brokerage_authorizations if brokerage_authorizations != SENTINEL
40
-
41
- get_all_user_holdings_with_http_info_impl(user_id, user_secret, extra)
42
- end
43
-
44
- # List all accounts for the user, plus balances and positions for each account.
45
- # @param user_id [String]
46
- # @param user_secret [String]
47
- # @param [Hash] opts the optional parameters
48
- # @option opts [String] :brokerage_authorizations Optional. Comma seperated list of authorization IDs (only use if filtering is needed on one or more authorizations).
49
- # @return [Array<AccountHoldings>]
50
- def get_all_user_holdings_impl(user_id, user_secret, opts = {})
51
- data, _status_code, _headers = get_all_user_holdings_with_http_info(user_id, user_secret, opts)
52
- data
53
- end
54
-
55
- # List all accounts for the user, plus balances and positions for each account.
56
- # @param user_id [String]
57
- # @param user_secret [String]
58
- # @param [Hash] opts the optional parameters
59
- # @option opts [String] :brokerage_authorizations Optional. Comma seperated list of authorization IDs (only use if filtering is needed on one or more authorizations).
60
- # @return [Array<(Array<AccountHoldings>, Integer, Hash)>] Array<AccountHoldings> data, response status code and response headers
61
- def get_all_user_holdings_with_http_info_impl(user_id, user_secret, opts = {})
62
- if @api_client.config.debugging
63
- @api_client.config.logger.debug 'Calling API: AccountInformationApi.get_all_user_holdings ...'
64
- end
65
- # verify the required parameter 'user_id' is set
66
- if @api_client.config.client_side_validation && user_id.nil?
67
- fail ArgumentError, "Missing the required parameter 'user_id' when calling AccountInformationApi.get_all_user_holdings"
68
- end
69
- # verify the required parameter 'user_secret' is set
70
- if @api_client.config.client_side_validation && user_secret.nil?
71
- fail ArgumentError, "Missing the required parameter 'user_secret' when calling AccountInformationApi.get_all_user_holdings"
72
- end
73
- # resource path
74
- local_var_path = '/holdings'
75
-
76
- # query parameters
77
- query_params = opts[:query_params] || {}
78
- query_params[:'userId'] = user_id
79
- query_params[:'userSecret'] = user_secret
80
- query_params[:'brokerage_authorizations'] = opts[:'brokerage_authorizations'] if !opts[:'brokerage_authorizations'].nil?
81
-
82
- # header parameters
83
- header_params = opts[:header_params] || {}
84
- # HTTP header 'Accept' (if needed)
85
- header_params['Accept'] = @api_client.select_header_accept(['application/json'])
86
-
87
- # form parameters
88
- form_params = opts[:form_params] || {}
89
-
90
- # http body (model)
91
- post_body = opts[:debug_body]
92
-
93
- # return_type
94
- return_type = opts[:debug_return_type] || 'Array<AccountHoldings>'
95
-
96
- # auth_names
97
- auth_names = opts[:debug_auth_names] || ['PartnerClientId', 'PartnerSignature', 'PartnerTimestamp']
98
-
99
- new_options = opts.merge(
100
- :operation => :"AccountInformationApi.get_all_user_holdings",
101
- :header_params => header_params,
102
- :query_params => query_params,
103
- :form_params => form_params,
104
- :body => post_body,
105
- :auth_names => auth_names,
106
- :return_type => return_type
107
- )
108
-
109
- data, status_code, headers, response = @api_client.call_api(:GET, local_var_path, new_options)
110
- if @api_client.config.debugging
111
- @api_client.config.logger.debug "API called: AccountInformationApi#get_all_user_holdings\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}"
112
- end
113
- return data, status_code, headers, response
114
- end
115
-
116
-
117
- # Get all cash balances of an investment account
118
- # @param user_id [String]
119
- # @param user_secret [String]
120
- # @param account_id [String] The ID of the account get positions.
121
- # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
122
- def get_user_account_balance(user_id:, user_secret:, account_id:, extra: {})
123
-
124
- data, _status_code, _headers = get_user_account_balance_with_http_info_impl(user_id, user_secret, account_id, extra)
125
- data
126
- end
127
-
128
- # Get all cash balances of an investment account
129
- # @param user_id [String]
130
- # @param user_secret [String]
131
- # @param account_id [String] The ID of the account get positions.
132
- # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
133
- def get_user_account_balance_with_http_info(user_id:, user_secret:, account_id:, extra: {})
134
-
135
- get_user_account_balance_with_http_info_impl(user_id, user_secret, account_id, extra)
136
- end
137
-
138
- # Get all cash balances of an investment account
139
- # @param user_id [String]
140
- # @param user_secret [String]
141
- # @param account_id [String] The ID of the account get positions.
142
- # @param [Hash] opts the optional parameters
143
- # @return [Array<Balance>]
144
- def get_user_account_balance_impl(user_id, user_secret, account_id, opts = {})
145
- data, _status_code, _headers = get_user_account_balance_with_http_info(user_id, user_secret, account_id, opts)
146
- data
147
- end
148
-
149
- # Get all cash balances of an investment account
150
- # @param user_id [String]
151
- # @param user_secret [String]
152
- # @param account_id [String] The ID of the account get positions.
153
- # @param [Hash] opts the optional parameters
154
- # @return [Array<(Array<Balance>, Integer, Hash)>] Array<Balance> data, response status code and response headers
155
- def get_user_account_balance_with_http_info_impl(user_id, user_secret, account_id, opts = {})
156
- if @api_client.config.debugging
157
- @api_client.config.logger.debug 'Calling API: AccountInformationApi.get_user_account_balance ...'
158
- end
159
- # verify the required parameter 'user_id' is set
160
- if @api_client.config.client_side_validation && user_id.nil?
161
- fail ArgumentError, "Missing the required parameter 'user_id' when calling AccountInformationApi.get_user_account_balance"
162
- end
163
- # verify the required parameter 'user_secret' is set
164
- if @api_client.config.client_side_validation && user_secret.nil?
165
- fail ArgumentError, "Missing the required parameter 'user_secret' when calling AccountInformationApi.get_user_account_balance"
166
- end
167
- # verify the required parameter 'account_id' is set
168
- if @api_client.config.client_side_validation && account_id.nil?
169
- fail ArgumentError, "Missing the required parameter 'account_id' when calling AccountInformationApi.get_user_account_balance"
170
- end
171
- # resource path
172
- local_var_path = '/accounts/{accountId}/balances'.sub('{' + 'accountId' + '}', CGI.escape(account_id.to_s))
173
-
174
- # query parameters
175
- query_params = opts[:query_params] || {}
176
- query_params[:'userId'] = user_id
177
- query_params[:'userSecret'] = user_secret
178
-
179
- # header parameters
180
- header_params = opts[:header_params] || {}
181
- # HTTP header 'Accept' (if needed)
182
- header_params['Accept'] = @api_client.select_header_accept(['*/*'])
183
-
184
- # form parameters
185
- form_params = opts[:form_params] || {}
186
-
187
- # http body (model)
188
- post_body = opts[:debug_body]
189
-
190
- # return_type
191
- return_type = opts[:debug_return_type] || 'Array<Balance>'
192
-
193
- # auth_names
194
- auth_names = opts[:debug_auth_names] || ['PartnerClientId', 'PartnerSignature', 'PartnerTimestamp']
195
-
196
- new_options = opts.merge(
197
- :operation => :"AccountInformationApi.get_user_account_balance",
198
- :header_params => header_params,
199
- :query_params => query_params,
200
- :form_params => form_params,
201
- :body => post_body,
202
- :auth_names => auth_names,
203
- :return_type => return_type
204
- )
205
-
206
- data, status_code, headers, response = @api_client.call_api(:GET, local_var_path, new_options)
207
- if @api_client.config.debugging
208
- @api_client.config.logger.debug "API called: AccountInformationApi#get_user_account_balance\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}"
209
- end
210
- return data, status_code, headers, response
211
- end
212
-
213
-
214
- # Return details of a specific investment account
215
- # @param user_id [String]
216
- # @param user_secret [String]
217
- # @param account_id [String] The ID of the account to get detail of.
218
- # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
219
- def get_user_account_details(user_id:, user_secret:, account_id:, extra: {})
220
-
221
- data, _status_code, _headers = get_user_account_details_with_http_info_impl(user_id, user_secret, account_id, extra)
222
- data
223
- end
224
-
225
- # Return details of a specific investment account
226
- # @param user_id [String]
227
- # @param user_secret [String]
228
- # @param account_id [String] The ID of the account to get detail of.
229
- # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
230
- def get_user_account_details_with_http_info(user_id:, user_secret:, account_id:, extra: {})
231
-
232
- get_user_account_details_with_http_info_impl(user_id, user_secret, account_id, extra)
233
- end
234
-
235
- # Return details of a specific investment account
236
- # @param user_id [String]
237
- # @param user_secret [String]
238
- # @param account_id [String] The ID of the account to get detail of.
239
- # @param [Hash] opts the optional parameters
240
- # @return [Array<Account>]
241
- def get_user_account_details_impl(user_id, user_secret, account_id, opts = {})
242
- data, _status_code, _headers = get_user_account_details_with_http_info(user_id, user_secret, account_id, opts)
243
- data
244
- end
245
-
246
- # Return details of a specific investment account
247
- # @param user_id [String]
248
- # @param user_secret [String]
249
- # @param account_id [String] The ID of the account to get detail of.
250
- # @param [Hash] opts the optional parameters
251
- # @return [Array<(Array<Account>, Integer, Hash)>] Array<Account> data, response status code and response headers
252
- def get_user_account_details_with_http_info_impl(user_id, user_secret, account_id, opts = {})
253
- if @api_client.config.debugging
254
- @api_client.config.logger.debug 'Calling API: AccountInformationApi.get_user_account_details ...'
255
- end
256
- # verify the required parameter 'user_id' is set
257
- if @api_client.config.client_side_validation && user_id.nil?
258
- fail ArgumentError, "Missing the required parameter 'user_id' when calling AccountInformationApi.get_user_account_details"
259
- end
260
- # verify the required parameter 'user_secret' is set
261
- if @api_client.config.client_side_validation && user_secret.nil?
262
- fail ArgumentError, "Missing the required parameter 'user_secret' when calling AccountInformationApi.get_user_account_details"
263
- end
264
- # verify the required parameter 'account_id' is set
265
- if @api_client.config.client_side_validation && account_id.nil?
266
- fail ArgumentError, "Missing the required parameter 'account_id' when calling AccountInformationApi.get_user_account_details"
267
- end
268
- # resource path
269
- local_var_path = '/accounts/{accountId}'.sub('{' + 'accountId' + '}', CGI.escape(account_id.to_s))
270
-
271
- # query parameters
272
- query_params = opts[:query_params] || {}
273
- query_params[:'userId'] = user_id
274
- query_params[:'userSecret'] = user_secret
275
-
276
- # header parameters
277
- header_params = opts[:header_params] || {}
278
- # HTTP header 'Accept' (if needed)
279
- header_params['Accept'] = @api_client.select_header_accept(['application/json'])
280
-
281
- # form parameters
282
- form_params = opts[:form_params] || {}
283
-
284
- # http body (model)
285
- post_body = opts[:debug_body]
286
-
287
- # return_type
288
- return_type = opts[:debug_return_type] || 'Array<Account>'
289
-
290
- # auth_names
291
- auth_names = opts[:debug_auth_names] || ['PartnerClientId', 'PartnerSignature', 'PartnerTimestamp']
292
-
293
- new_options = opts.merge(
294
- :operation => :"AccountInformationApi.get_user_account_details",
295
- :header_params => header_params,
296
- :query_params => query_params,
297
- :form_params => form_params,
298
- :body => post_body,
299
- :auth_names => auth_names,
300
- :return_type => return_type
301
- )
302
-
303
- data, status_code, headers, response = @api_client.call_api(:GET, local_var_path, new_options)
304
- if @api_client.config.debugging
305
- @api_client.config.logger.debug "API called: AccountInformationApi#get_user_account_details\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}"
306
- end
307
- return data, status_code, headers, response
308
- end
309
-
310
-
311
- # Get all history of orders placed in account
312
- # @param user_id [String]
313
- # @param user_secret [String]
314
- # @param account_id [String] The ID of the account get positions.
315
- # @param state [String] defaults value is set to \&quot;all\&quot;
316
- # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
317
- def get_user_account_orders(user_id:, user_secret:, account_id:, state: SENTINEL, extra: {})
318
- extra[:state] = state if state != SENTINEL
319
-
320
- data, _status_code, _headers = get_user_account_orders_with_http_info_impl(user_id, user_secret, account_id, extra)
321
- data
322
- end
323
-
324
- # Get all history of orders placed in account
325
- # @param user_id [String]
326
- # @param user_secret [String]
327
- # @param account_id [String] The ID of the account get positions.
328
- # @param state [String] defaults value is set to \&quot;all\&quot;
329
- # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
330
- def get_user_account_orders_with_http_info(user_id:, user_secret:, account_id:, state: SENTINEL, extra: {})
331
- extra[:state] = state if state != SENTINEL
332
-
333
- get_user_account_orders_with_http_info_impl(user_id, user_secret, account_id, extra)
334
- end
335
-
336
- # Get all history of orders placed in account
337
- # @param user_id [String]
338
- # @param user_secret [String]
339
- # @param account_id [String] The ID of the account get positions.
340
- # @param [Hash] opts the optional parameters
341
- # @option opts [String] :state defaults value is set to \&quot;all\&quot;
342
- # @return [Array<AccountOrderRecord>]
343
- def get_user_account_orders_impl(user_id, user_secret, account_id, opts = {})
344
- data, _status_code, _headers = get_user_account_orders_with_http_info(user_id, user_secret, account_id, opts)
345
- data
346
- end
347
-
348
- # Get all history of orders placed in account
349
- # @param user_id [String]
350
- # @param user_secret [String]
351
- # @param account_id [String] The ID of the account get positions.
352
- # @param [Hash] opts the optional parameters
353
- # @option opts [String] :state defaults value is set to \&quot;all\&quot;
354
- # @return [Array<(Array<AccountOrderRecord>, Integer, Hash)>] Array<AccountOrderRecord> data, response status code and response headers
355
- def get_user_account_orders_with_http_info_impl(user_id, user_secret, account_id, opts = {})
356
- if @api_client.config.debugging
357
- @api_client.config.logger.debug 'Calling API: AccountInformationApi.get_user_account_orders ...'
358
- end
359
- # verify the required parameter 'user_id' is set
360
- if @api_client.config.client_side_validation && user_id.nil?
361
- fail ArgumentError, "Missing the required parameter 'user_id' when calling AccountInformationApi.get_user_account_orders"
362
- end
363
- # verify the required parameter 'user_secret' is set
364
- if @api_client.config.client_side_validation && user_secret.nil?
365
- fail ArgumentError, "Missing the required parameter 'user_secret' when calling AccountInformationApi.get_user_account_orders"
366
- end
367
- # verify the required parameter 'account_id' is set
368
- if @api_client.config.client_side_validation && account_id.nil?
369
- fail ArgumentError, "Missing the required parameter 'account_id' when calling AccountInformationApi.get_user_account_orders"
370
- end
371
- allowable_values = ["all", "open", "executed"]
372
- if @api_client.config.client_side_validation && opts[:'state'] && !allowable_values.include?(opts[:'state'])
373
- fail ArgumentError, "invalid value for \"state\", must be one of #{allowable_values}"
374
- end
375
- # resource path
376
- local_var_path = '/accounts/{accountId}/orders'.sub('{' + 'accountId' + '}', CGI.escape(account_id.to_s))
377
-
378
- # query parameters
379
- query_params = opts[:query_params] || {}
380
- query_params[:'userId'] = user_id
381
- query_params[:'userSecret'] = user_secret
382
- query_params[:'state'] = opts[:'state'] if !opts[:'state'].nil?
383
-
384
- # header parameters
385
- header_params = opts[:header_params] || {}
386
- # HTTP header 'Accept' (if needed)
387
- header_params['Accept'] = @api_client.select_header_accept(['application/json'])
388
-
389
- # form parameters
390
- form_params = opts[:form_params] || {}
391
-
392
- # http body (model)
393
- post_body = opts[:debug_body]
394
-
395
- # return_type
396
- return_type = opts[:debug_return_type] || 'Array<AccountOrderRecord>'
397
-
398
- # auth_names
399
- auth_names = opts[:debug_auth_names] || ['PartnerClientId', 'PartnerSignature', 'PartnerTimestamp']
400
-
401
- new_options = opts.merge(
402
- :operation => :"AccountInformationApi.get_user_account_orders",
403
- :header_params => header_params,
404
- :query_params => query_params,
405
- :form_params => form_params,
406
- :body => post_body,
407
- :auth_names => auth_names,
408
- :return_type => return_type
409
- )
410
-
411
- data, status_code, headers, response = @api_client.call_api(:GET, local_var_path, new_options)
412
- if @api_client.config.debugging
413
- @api_client.config.logger.debug "API called: AccountInformationApi#get_user_account_orders\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}"
414
- end
415
- return data, status_code, headers, response
416
- end
417
-
418
-
419
- # Get all positions of an investment account
420
- # @param user_id [String]
421
- # @param user_secret [String]
422
- # @param account_id [String] The ID of the account get positions.
423
- # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
424
- def get_user_account_positions(user_id:, user_secret:, account_id:, extra: {})
425
-
426
- data, _status_code, _headers = get_user_account_positions_with_http_info_impl(user_id, user_secret, account_id, extra)
427
- data
428
- end
429
-
430
- # Get all positions of an investment account
431
- # @param user_id [String]
432
- # @param user_secret [String]
433
- # @param account_id [String] The ID of the account get positions.
434
- # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
435
- def get_user_account_positions_with_http_info(user_id:, user_secret:, account_id:, extra: {})
436
-
437
- get_user_account_positions_with_http_info_impl(user_id, user_secret, account_id, extra)
438
- end
439
-
440
- # Get all positions of an investment account
441
- # @param user_id [String]
442
- # @param user_secret [String]
443
- # @param account_id [String] The ID of the account get positions.
444
- # @param [Hash] opts the optional parameters
445
- # @return [Array<Position>]
446
- def get_user_account_positions_impl(user_id, user_secret, account_id, opts = {})
447
- data, _status_code, _headers = get_user_account_positions_with_http_info(user_id, user_secret, account_id, opts)
448
- data
449
- end
450
-
451
- # Get all positions of an investment account
452
- # @param user_id [String]
453
- # @param user_secret [String]
454
- # @param account_id [String] The ID of the account get positions.
455
- # @param [Hash] opts the optional parameters
456
- # @return [Array<(Array<Position>, Integer, Hash)>] Array<Position> data, response status code and response headers
457
- def get_user_account_positions_with_http_info_impl(user_id, user_secret, account_id, opts = {})
458
- if @api_client.config.debugging
459
- @api_client.config.logger.debug 'Calling API: AccountInformationApi.get_user_account_positions ...'
460
- end
461
- # verify the required parameter 'user_id' is set
462
- if @api_client.config.client_side_validation && user_id.nil?
463
- fail ArgumentError, "Missing the required parameter 'user_id' when calling AccountInformationApi.get_user_account_positions"
464
- end
465
- # verify the required parameter 'user_secret' is set
466
- if @api_client.config.client_side_validation && user_secret.nil?
467
- fail ArgumentError, "Missing the required parameter 'user_secret' when calling AccountInformationApi.get_user_account_positions"
468
- end
469
- # verify the required parameter 'account_id' is set
470
- if @api_client.config.client_side_validation && account_id.nil?
471
- fail ArgumentError, "Missing the required parameter 'account_id' when calling AccountInformationApi.get_user_account_positions"
472
- end
473
- # resource path
474
- local_var_path = '/accounts/{accountId}/positions'.sub('{' + 'accountId' + '}', CGI.escape(account_id.to_s))
475
-
476
- # query parameters
477
- query_params = opts[:query_params] || {}
478
- query_params[:'userId'] = user_id
479
- query_params[:'userSecret'] = user_secret
480
-
481
- # header parameters
482
- header_params = opts[:header_params] || {}
483
- # HTTP header 'Accept' (if needed)
484
- header_params['Accept'] = @api_client.select_header_accept(['*/*'])
485
-
486
- # form parameters
487
- form_params = opts[:form_params] || {}
488
-
489
- # http body (model)
490
- post_body = opts[:debug_body]
491
-
492
- # return_type
493
- return_type = opts[:debug_return_type] || 'Array<Position>'
494
-
495
- # auth_names
496
- auth_names = opts[:debug_auth_names] || ['PartnerClientId', 'PartnerSignature', 'PartnerTimestamp']
497
-
498
- new_options = opts.merge(
499
- :operation => :"AccountInformationApi.get_user_account_positions",
500
- :header_params => header_params,
501
- :query_params => query_params,
502
- :form_params => form_params,
503
- :body => post_body,
504
- :auth_names => auth_names,
505
- :return_type => return_type
506
- )
507
-
508
- data, status_code, headers, response = @api_client.call_api(:GET, local_var_path, new_options)
509
- if @api_client.config.debugging
510
- @api_client.config.logger.debug "API called: AccountInformationApi#get_user_account_positions\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}"
511
- end
512
- return data, status_code, headers, response
513
- end
514
-
515
-
516
- # List balances, positions and orders for the specified account.
517
- # @param account_id [String] The ID of the account to fetch holdings for.
518
- # @param user_id [String]
519
- # @param user_secret [String]
520
- # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
521
- def get_user_holdings(account_id:, user_id:, user_secret:, extra: {})
522
-
523
- data, _status_code, _headers = get_user_holdings_with_http_info_impl(account_id, user_id, user_secret, extra)
524
- data
525
- end
526
-
527
- # List balances, positions and orders for the specified account.
528
- # @param account_id [String] The ID of the account to fetch holdings for.
529
- # @param user_id [String]
530
- # @param user_secret [String]
531
- # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
532
- def get_user_holdings_with_http_info(account_id:, user_id:, user_secret:, extra: {})
533
-
534
- get_user_holdings_with_http_info_impl(account_id, user_id, user_secret, extra)
535
- end
536
-
537
- # List balances, positions and orders for the specified account.
538
- # @param account_id [String] The ID of the account to fetch holdings for.
539
- # @param user_id [String]
540
- # @param user_secret [String]
541
- # @param [Hash] opts the optional parameters
542
- # @return [AccountHoldingsAccount]
543
- def get_user_holdings_impl(account_id, user_id, user_secret, opts = {})
544
- data, _status_code, _headers = get_user_holdings_with_http_info(account_id, user_id, user_secret, opts)
545
- data
546
- end
547
-
548
- # List balances, positions and orders for the specified account.
549
- # @param account_id [String] The ID of the account to fetch holdings for.
550
- # @param user_id [String]
551
- # @param user_secret [String]
552
- # @param [Hash] opts the optional parameters
553
- # @return [Array<(AccountHoldingsAccount, Integer, Hash)>] AccountHoldingsAccount data, response status code and response headers
554
- def get_user_holdings_with_http_info_impl(account_id, user_id, user_secret, opts = {})
555
- if @api_client.config.debugging
556
- @api_client.config.logger.debug 'Calling API: AccountInformationApi.get_user_holdings ...'
557
- end
558
- # verify the required parameter 'account_id' is set
559
- if @api_client.config.client_side_validation && account_id.nil?
560
- fail ArgumentError, "Missing the required parameter 'account_id' when calling AccountInformationApi.get_user_holdings"
561
- end
562
- # verify the required parameter 'user_id' is set
563
- if @api_client.config.client_side_validation && user_id.nil?
564
- fail ArgumentError, "Missing the required parameter 'user_id' when calling AccountInformationApi.get_user_holdings"
565
- end
566
- # verify the required parameter 'user_secret' is set
567
- if @api_client.config.client_side_validation && user_secret.nil?
568
- fail ArgumentError, "Missing the required parameter 'user_secret' when calling AccountInformationApi.get_user_holdings"
569
- end
570
- # resource path
571
- local_var_path = '/accounts/{accountId}/holdings'.sub('{' + 'accountId' + '}', CGI.escape(account_id.to_s))
572
-
573
- # query parameters
574
- query_params = opts[:query_params] || {}
575
- query_params[:'userId'] = user_id
576
- query_params[:'userSecret'] = user_secret
577
-
578
- # header parameters
579
- header_params = opts[:header_params] || {}
580
- # HTTP header 'Accept' (if needed)
581
- header_params['Accept'] = @api_client.select_header_accept(['application/json'])
582
-
583
- # form parameters
584
- form_params = opts[:form_params] || {}
585
-
586
- # http body (model)
587
- post_body = opts[:debug_body]
588
-
589
- # return_type
590
- return_type = opts[:debug_return_type] || 'AccountHoldingsAccount'
591
-
592
- # auth_names
593
- auth_names = opts[:debug_auth_names] || ['PartnerClientId', 'PartnerSignature', 'PartnerTimestamp']
594
-
595
- new_options = opts.merge(
596
- :operation => :"AccountInformationApi.get_user_holdings",
597
- :header_params => header_params,
598
- :query_params => query_params,
599
- :form_params => form_params,
600
- :body => post_body,
601
- :auth_names => auth_names,
602
- :return_type => return_type
603
- )
604
-
605
- data, status_code, headers, response = @api_client.call_api(:GET, local_var_path, new_options)
606
- if @api_client.config.debugging
607
- @api_client.config.logger.debug "API called: AccountInformationApi#get_user_holdings\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}"
608
- end
609
- return data, status_code, headers, response
610
- end
611
-
612
-
613
- # List all investment accounts for the user
614
- # @param user_id [String]
615
- # @param user_secret [String]
616
- # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
617
- def list_user_accounts(user_id:, user_secret:, extra: {})
618
-
619
- data, _status_code, _headers = list_user_accounts_with_http_info_impl(user_id, user_secret, extra)
620
- data
621
- end
622
-
623
- # List all investment accounts for the user
624
- # @param user_id [String]
625
- # @param user_secret [String]
626
- # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
627
- def list_user_accounts_with_http_info(user_id:, user_secret:, extra: {})
628
-
629
- list_user_accounts_with_http_info_impl(user_id, user_secret, extra)
630
- end
631
-
632
- # List all investment accounts for the user
633
- # @param user_id [String]
634
- # @param user_secret [String]
635
- # @param [Hash] opts the optional parameters
636
- # @return [Array<Account>]
637
- def list_user_accounts_impl(user_id, user_secret, opts = {})
638
- data, _status_code, _headers = list_user_accounts_with_http_info(user_id, user_secret, opts)
639
- data
640
- end
641
-
642
- # List all investment accounts for the user
643
- # @param user_id [String]
644
- # @param user_secret [String]
645
- # @param [Hash] opts the optional parameters
646
- # @return [Array<(Array<Account>, Integer, Hash)>] Array<Account> data, response status code and response headers
647
- def list_user_accounts_with_http_info_impl(user_id, user_secret, opts = {})
648
- if @api_client.config.debugging
649
- @api_client.config.logger.debug 'Calling API: AccountInformationApi.list_user_accounts ...'
650
- end
651
- # verify the required parameter 'user_id' is set
652
- if @api_client.config.client_side_validation && user_id.nil?
653
- fail ArgumentError, "Missing the required parameter 'user_id' when calling AccountInformationApi.list_user_accounts"
654
- end
655
- # verify the required parameter 'user_secret' is set
656
- if @api_client.config.client_side_validation && user_secret.nil?
657
- fail ArgumentError, "Missing the required parameter 'user_secret' when calling AccountInformationApi.list_user_accounts"
658
- end
659
- # resource path
660
- local_var_path = '/accounts'
661
-
662
- # query parameters
663
- query_params = opts[:query_params] || {}
664
- query_params[:'userId'] = user_id
665
- query_params[:'userSecret'] = user_secret
666
-
667
- # header parameters
668
- header_params = opts[:header_params] || {}
669
- # HTTP header 'Accept' (if needed)
670
- header_params['Accept'] = @api_client.select_header_accept(['application/json'])
671
-
672
- # form parameters
673
- form_params = opts[:form_params] || {}
674
-
675
- # http body (model)
676
- post_body = opts[:debug_body]
677
-
678
- # return_type
679
- return_type = opts[:debug_return_type] || 'Array<Account>'
680
-
681
- # auth_names
682
- auth_names = opts[:debug_auth_names] || ['PartnerClientId', 'PartnerSignature', 'PartnerTimestamp']
683
-
684
- new_options = opts.merge(
685
- :operation => :"AccountInformationApi.list_user_accounts",
686
- :header_params => header_params,
687
- :query_params => query_params,
688
- :form_params => form_params,
689
- :body => post_body,
690
- :auth_names => auth_names,
691
- :return_type => return_type
692
- )
693
-
694
- data, status_code, headers, response = @api_client.call_api(:GET, local_var_path, new_options)
695
- if @api_client.config.debugging
696
- @api_client.config.logger.debug "API called: AccountInformationApi#list_user_accounts\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}"
697
- end
698
- return data, status_code, headers, response
699
- end
700
-
701
-
702
- # Update details of an investment account
703
- # @param user_id [String]
704
- # @param user_secret [String]
705
- # @param account_id [String] The ID of the account to update.
706
- # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
707
- def update_user_account(user_id:, user_secret:, account_id:, extra: {})
708
-
709
- data, _status_code, _headers = update_user_account_with_http_info_impl(user_id, user_secret, account_id, extra)
710
- data
711
- end
712
-
713
- # Update details of an investment account
714
- # @param user_id [String]
715
- # @param user_secret [String]
716
- # @param account_id [String] The ID of the account to update.
717
- # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
718
- def update_user_account_with_http_info(user_id:, user_secret:, account_id:, extra: {})
719
-
720
- update_user_account_with_http_info_impl(user_id, user_secret, account_id, extra)
721
- end
722
-
723
- # Update details of an investment account
724
- # @param user_id [String]
725
- # @param user_secret [String]
726
- # @param account_id [String] The ID of the account to update.
727
- # @param [Hash] opts the optional parameters
728
- # @return [Array<Account>]
729
- def update_user_account_impl(user_id, user_secret, account_id, opts = {})
730
- data, _status_code, _headers = update_user_account_with_http_info(user_id, user_secret, account_id, opts)
731
- data
732
- end
733
-
734
- # Update details of an investment account
735
- # @param user_id [String]
736
- # @param user_secret [String]
737
- # @param account_id [String] The ID of the account to update.
738
- # @param [Hash] opts the optional parameters
739
- # @return [Array<(Array<Account>, Integer, Hash)>] Array<Account> data, response status code and response headers
740
- def update_user_account_with_http_info_impl(user_id, user_secret, account_id, opts = {})
741
- if @api_client.config.debugging
742
- @api_client.config.logger.debug 'Calling API: AccountInformationApi.update_user_account ...'
743
- end
744
- # verify the required parameter 'user_id' is set
745
- if @api_client.config.client_side_validation && user_id.nil?
746
- fail ArgumentError, "Missing the required parameter 'user_id' when calling AccountInformationApi.update_user_account"
747
- end
748
- # verify the required parameter 'user_secret' is set
749
- if @api_client.config.client_side_validation && user_secret.nil?
750
- fail ArgumentError, "Missing the required parameter 'user_secret' when calling AccountInformationApi.update_user_account"
751
- end
752
- # verify the required parameter 'account_id' is set
753
- if @api_client.config.client_side_validation && account_id.nil?
754
- fail ArgumentError, "Missing the required parameter 'account_id' when calling AccountInformationApi.update_user_account"
755
- end
756
- # resource path
757
- local_var_path = '/accounts/{accountId}'.sub('{' + 'accountId' + '}', CGI.escape(account_id.to_s))
758
-
759
- # query parameters
760
- query_params = opts[:query_params] || {}
761
- query_params[:'userId'] = user_id
762
- query_params[:'userSecret'] = user_secret
763
-
764
- # header parameters
765
- header_params = opts[:header_params] || {}
766
- # HTTP header 'Accept' (if needed)
767
- header_params['Accept'] = @api_client.select_header_accept(['application/json'])
768
-
769
- # form parameters
770
- form_params = opts[:form_params] || {}
771
-
772
- # http body (model)
773
- post_body = opts[:debug_body]
774
-
775
- # return_type
776
- return_type = opts[:debug_return_type] || 'Array<Account>'
777
-
778
- # auth_names
779
- auth_names = opts[:debug_auth_names] || ['PartnerClientId', 'PartnerSignature', 'PartnerTimestamp']
780
-
781
- new_options = opts.merge(
782
- :operation => :"AccountInformationApi.update_user_account",
783
- :header_params => header_params,
784
- :query_params => query_params,
785
- :form_params => form_params,
786
- :body => post_body,
787
- :auth_names => auth_names,
788
- :return_type => return_type
789
- )
790
-
791
- data, status_code, headers, response = @api_client.call_api(:PUT, local_var_path, new_options)
792
- if @api_client.config.debugging
793
- @api_client.config.logger.debug "API called: AccountInformationApi#update_user_account\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}"
794
- end
795
- return data, status_code, headers, response
796
- end
797
- end
798
-
799
- # top-level client access to avoid having the user to insantiate their own API instances
800
- AccountInformation = AccountInformationApi::new
801
- end
1
+ =begin
2
+ #SnapTrade
3
+
4
+ #Connect brokerage accounts to your app for live positions and trading
5
+
6
+ The version of the OpenAPI document: 1.0.0
7
+ Contact: api@snaptrade.com
8
+
9
+ =end
10
+
11
+ require 'cgi'
12
+
13
+ module SnapTrade
14
+ class AccountInformationApi
15
+ attr_accessor :api_client
16
+
17
+ def initialize(api_client = ApiClient.default)
18
+ @api_client = api_client
19
+ end
20
+
21
+ # List all accounts for the user, plus balances, positions, and orders for each account.
22
+ # @param user_id [String]
23
+ # @param user_secret [String]
24
+ # @param brokerage_authorizations [String] Optional. Comma seperated list of authorization IDs (only use if filtering is needed on one or more authorizations).
25
+ # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
26
+ def get_all_user_holdings(user_id:, user_secret:, brokerage_authorizations: SENTINEL, extra: {})
27
+ extra[:brokerage_authorizations] = brokerage_authorizations if brokerage_authorizations != SENTINEL
28
+
29
+ data, _status_code, _headers = get_all_user_holdings_with_http_info_impl(user_id, user_secret, extra)
30
+ data
31
+ end
32
+
33
+ # List all accounts for the user, plus balances, positions, and orders for each account.
34
+ # @param user_id [String]
35
+ # @param user_secret [String]
36
+ # @param brokerage_authorizations [String] Optional. Comma seperated list of authorization IDs (only use if filtering is needed on one or more authorizations).
37
+ # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
38
+ def get_all_user_holdings_with_http_info(user_id:, user_secret:, brokerage_authorizations: SENTINEL, extra: {})
39
+ extra[:brokerage_authorizations] = brokerage_authorizations if brokerage_authorizations != SENTINEL
40
+
41
+ get_all_user_holdings_with_http_info_impl(user_id, user_secret, extra)
42
+ end
43
+
44
+ # List all accounts for the user, plus balances, positions, and orders for each account.
45
+ # @param user_id [String]
46
+ # @param user_secret [String]
47
+ # @param [Hash] opts the optional parameters
48
+ # @option opts [String] :brokerage_authorizations Optional. Comma seperated list of authorization IDs (only use if filtering is needed on one or more authorizations).
49
+ # @return [Array<AccountHoldings>]
50
+ def get_all_user_holdings_impl(user_id, user_secret, opts = {})
51
+ data, _status_code, _headers = get_all_user_holdings_with_http_info(user_id, user_secret, opts)
52
+ data
53
+ end
54
+
55
+ # List all accounts for the user, plus balances, positions, and orders for each account.
56
+ # @param user_id [String]
57
+ # @param user_secret [String]
58
+ # @param [Hash] opts the optional parameters
59
+ # @option opts [String] :brokerage_authorizations Optional. Comma seperated list of authorization IDs (only use if filtering is needed on one or more authorizations).
60
+ # @return [Array<(Array<AccountHoldings>, Integer, Hash)>] Array<AccountHoldings> data, response status code and response headers
61
+ def get_all_user_holdings_with_http_info_impl(user_id, user_secret, opts = {})
62
+ if @api_client.config.debugging
63
+ @api_client.config.logger.debug 'Calling API: AccountInformationApi.get_all_user_holdings ...'
64
+ end
65
+ # verify the required parameter 'user_id' is set
66
+ if @api_client.config.client_side_validation && user_id.nil?
67
+ fail ArgumentError, "Missing the required parameter 'user_id' when calling AccountInformationApi.get_all_user_holdings"
68
+ end
69
+ # verify the required parameter 'user_secret' is set
70
+ if @api_client.config.client_side_validation && user_secret.nil?
71
+ fail ArgumentError, "Missing the required parameter 'user_secret' when calling AccountInformationApi.get_all_user_holdings"
72
+ end
73
+ # resource path
74
+ local_var_path = '/holdings'
75
+
76
+ # query parameters
77
+ query_params = opts[:query_params] || {}
78
+ query_params[:'userId'] = user_id
79
+ query_params[:'userSecret'] = user_secret
80
+ query_params[:'brokerage_authorizations'] = opts[:'brokerage_authorizations'] if !opts[:'brokerage_authorizations'].nil?
81
+
82
+ # header parameters
83
+ header_params = opts[:header_params] || {}
84
+ # HTTP header 'Accept' (if needed)
85
+ header_params['Accept'] = @api_client.select_header_accept(['application/json'])
86
+
87
+ # form parameters
88
+ form_params = opts[:form_params] || {}
89
+
90
+ # http body (model)
91
+ post_body = opts[:debug_body]
92
+
93
+ # return_type
94
+ return_type = opts[:debug_return_type] || 'Array<AccountHoldings>'
95
+
96
+ # auth_names
97
+ auth_names = opts[:debug_auth_names] || ['PartnerClientId', 'PartnerSignature', 'PartnerTimestamp']
98
+
99
+ new_options = opts.merge(
100
+ :operation => :"AccountInformationApi.get_all_user_holdings",
101
+ :header_params => header_params,
102
+ :query_params => query_params,
103
+ :form_params => form_params,
104
+ :body => post_body,
105
+ :auth_names => auth_names,
106
+ :return_type => return_type
107
+ )
108
+
109
+ data, status_code, headers, response = @api_client.call_api(:GET, local_var_path, new_options)
110
+ if @api_client.config.debugging
111
+ @api_client.config.logger.debug "API called: AccountInformationApi#get_all_user_holdings\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}"
112
+ end
113
+ return data, status_code, headers, response
114
+ end
115
+
116
+
117
+ # List account balances
118
+ # @param user_id [String]
119
+ # @param user_secret [String]
120
+ # @param account_id [String] The ID of the account get positions.
121
+ # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
122
+ def get_user_account_balance(user_id:, user_secret:, account_id:, extra: {})
123
+
124
+ data, _status_code, _headers = get_user_account_balance_with_http_info_impl(user_id, user_secret, account_id, extra)
125
+ data
126
+ end
127
+
128
+ # List account balances
129
+ # @param user_id [String]
130
+ # @param user_secret [String]
131
+ # @param account_id [String] The ID of the account get positions.
132
+ # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
133
+ def get_user_account_balance_with_http_info(user_id:, user_secret:, account_id:, extra: {})
134
+
135
+ get_user_account_balance_with_http_info_impl(user_id, user_secret, account_id, extra)
136
+ end
137
+
138
+ # List account balances
139
+ # @param user_id [String]
140
+ # @param user_secret [String]
141
+ # @param account_id [String] The ID of the account get positions.
142
+ # @param [Hash] opts the optional parameters
143
+ # @return [Array<Balance>]
144
+ def get_user_account_balance_impl(user_id, user_secret, account_id, opts = {})
145
+ data, _status_code, _headers = get_user_account_balance_with_http_info(user_id, user_secret, account_id, opts)
146
+ data
147
+ end
148
+
149
+ # List account balances
150
+ # @param user_id [String]
151
+ # @param user_secret [String]
152
+ # @param account_id [String] The ID of the account get positions.
153
+ # @param [Hash] opts the optional parameters
154
+ # @return [Array<(Array<Balance>, Integer, Hash)>] Array<Balance> data, response status code and response headers
155
+ def get_user_account_balance_with_http_info_impl(user_id, user_secret, account_id, opts = {})
156
+ if @api_client.config.debugging
157
+ @api_client.config.logger.debug 'Calling API: AccountInformationApi.get_user_account_balance ...'
158
+ end
159
+ # verify the required parameter 'user_id' is set
160
+ if @api_client.config.client_side_validation && user_id.nil?
161
+ fail ArgumentError, "Missing the required parameter 'user_id' when calling AccountInformationApi.get_user_account_balance"
162
+ end
163
+ # verify the required parameter 'user_secret' is set
164
+ if @api_client.config.client_side_validation && user_secret.nil?
165
+ fail ArgumentError, "Missing the required parameter 'user_secret' when calling AccountInformationApi.get_user_account_balance"
166
+ end
167
+ # verify the required parameter 'account_id' is set
168
+ if @api_client.config.client_side_validation && account_id.nil?
169
+ fail ArgumentError, "Missing the required parameter 'account_id' when calling AccountInformationApi.get_user_account_balance"
170
+ end
171
+ # resource path
172
+ local_var_path = '/accounts/{accountId}/balances'.sub('{' + 'accountId' + '}', CGI.escape(account_id.to_s))
173
+
174
+ # query parameters
175
+ query_params = opts[:query_params] || {}
176
+ query_params[:'userId'] = user_id
177
+ query_params[:'userSecret'] = user_secret
178
+
179
+ # header parameters
180
+ header_params = opts[:header_params] || {}
181
+ # HTTP header 'Accept' (if needed)
182
+ header_params['Accept'] = @api_client.select_header_accept(['*/*'])
183
+
184
+ # form parameters
185
+ form_params = opts[:form_params] || {}
186
+
187
+ # http body (model)
188
+ post_body = opts[:debug_body]
189
+
190
+ # return_type
191
+ return_type = opts[:debug_return_type] || 'Array<Balance>'
192
+
193
+ # auth_names
194
+ auth_names = opts[:debug_auth_names] || ['PartnerClientId', 'PartnerSignature', 'PartnerTimestamp']
195
+
196
+ new_options = opts.merge(
197
+ :operation => :"AccountInformationApi.get_user_account_balance",
198
+ :header_params => header_params,
199
+ :query_params => query_params,
200
+ :form_params => form_params,
201
+ :body => post_body,
202
+ :auth_names => auth_names,
203
+ :return_type => return_type
204
+ )
205
+
206
+ data, status_code, headers, response = @api_client.call_api(:GET, local_var_path, new_options)
207
+ if @api_client.config.debugging
208
+ @api_client.config.logger.debug "API called: AccountInformationApi#get_user_account_balance\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}"
209
+ end
210
+ return data, status_code, headers, response
211
+ end
212
+
213
+
214
+ # Return details of a specific investment account
215
+ # @param user_id [String]
216
+ # @param user_secret [String]
217
+ # @param account_id [String] The ID of the account to get detail of.
218
+ # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
219
+ def get_user_account_details(user_id:, user_secret:, account_id:, extra: {})
220
+
221
+ data, _status_code, _headers = get_user_account_details_with_http_info_impl(user_id, user_secret, account_id, extra)
222
+ data
223
+ end
224
+
225
+ # Return details of a specific investment account
226
+ # @param user_id [String]
227
+ # @param user_secret [String]
228
+ # @param account_id [String] The ID of the account to get detail of.
229
+ # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
230
+ def get_user_account_details_with_http_info(user_id:, user_secret:, account_id:, extra: {})
231
+
232
+ get_user_account_details_with_http_info_impl(user_id, user_secret, account_id, extra)
233
+ end
234
+
235
+ # Return details of a specific investment account
236
+ # @param user_id [String]
237
+ # @param user_secret [String]
238
+ # @param account_id [String] The ID of the account to get detail of.
239
+ # @param [Hash] opts the optional parameters
240
+ # @return [Account]
241
+ def get_user_account_details_impl(user_id, user_secret, account_id, opts = {})
242
+ data, _status_code, _headers = get_user_account_details_with_http_info(user_id, user_secret, account_id, opts)
243
+ data
244
+ end
245
+
246
+ # Return details of a specific investment account
247
+ # @param user_id [String]
248
+ # @param user_secret [String]
249
+ # @param account_id [String] The ID of the account to get detail of.
250
+ # @param [Hash] opts the optional parameters
251
+ # @return [Array<(Account, Integer, Hash)>] Account data, response status code and response headers
252
+ def get_user_account_details_with_http_info_impl(user_id, user_secret, account_id, opts = {})
253
+ if @api_client.config.debugging
254
+ @api_client.config.logger.debug 'Calling API: AccountInformationApi.get_user_account_details ...'
255
+ end
256
+ # verify the required parameter 'user_id' is set
257
+ if @api_client.config.client_side_validation && user_id.nil?
258
+ fail ArgumentError, "Missing the required parameter 'user_id' when calling AccountInformationApi.get_user_account_details"
259
+ end
260
+ # verify the required parameter 'user_secret' is set
261
+ if @api_client.config.client_side_validation && user_secret.nil?
262
+ fail ArgumentError, "Missing the required parameter 'user_secret' when calling AccountInformationApi.get_user_account_details"
263
+ end
264
+ # verify the required parameter 'account_id' is set
265
+ if @api_client.config.client_side_validation && account_id.nil?
266
+ fail ArgumentError, "Missing the required parameter 'account_id' when calling AccountInformationApi.get_user_account_details"
267
+ end
268
+ # resource path
269
+ local_var_path = '/accounts/{accountId}'.sub('{' + 'accountId' + '}', CGI.escape(account_id.to_s))
270
+
271
+ # query parameters
272
+ query_params = opts[:query_params] || {}
273
+ query_params[:'userId'] = user_id
274
+ query_params[:'userSecret'] = user_secret
275
+
276
+ # header parameters
277
+ header_params = opts[:header_params] || {}
278
+ # HTTP header 'Accept' (if needed)
279
+ header_params['Accept'] = @api_client.select_header_accept(['application/json'])
280
+
281
+ # form parameters
282
+ form_params = opts[:form_params] || {}
283
+
284
+ # http body (model)
285
+ post_body = opts[:debug_body]
286
+
287
+ # return_type
288
+ return_type = opts[:debug_return_type] || 'Account'
289
+
290
+ # auth_names
291
+ auth_names = opts[:debug_auth_names] || ['PartnerClientId', 'PartnerSignature', 'PartnerTimestamp']
292
+
293
+ new_options = opts.merge(
294
+ :operation => :"AccountInformationApi.get_user_account_details",
295
+ :header_params => header_params,
296
+ :query_params => query_params,
297
+ :form_params => form_params,
298
+ :body => post_body,
299
+ :auth_names => auth_names,
300
+ :return_type => return_type
301
+ )
302
+
303
+ data, status_code, headers, response = @api_client.call_api(:GET, local_var_path, new_options)
304
+ if @api_client.config.debugging
305
+ @api_client.config.logger.debug "API called: AccountInformationApi#get_user_account_details\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}"
306
+ end
307
+ return data, status_code, headers, response
308
+ end
309
+
310
+
311
+ # Get all history of orders placed in account
312
+ # @param user_id [String]
313
+ # @param user_secret [String]
314
+ # @param account_id [String] The ID of the account get positions.
315
+ # @param state [String] defaults value is set to \&quot;all\&quot;
316
+ # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
317
+ def get_user_account_orders(user_id:, user_secret:, account_id:, state: SENTINEL, extra: {})
318
+ extra[:state] = state if state != SENTINEL
319
+
320
+ data, _status_code, _headers = get_user_account_orders_with_http_info_impl(user_id, user_secret, account_id, extra)
321
+ data
322
+ end
323
+
324
+ # Get all history of orders placed in account
325
+ # @param user_id [String]
326
+ # @param user_secret [String]
327
+ # @param account_id [String] The ID of the account get positions.
328
+ # @param state [String] defaults value is set to \&quot;all\&quot;
329
+ # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
330
+ def get_user_account_orders_with_http_info(user_id:, user_secret:, account_id:, state: SENTINEL, extra: {})
331
+ extra[:state] = state if state != SENTINEL
332
+
333
+ get_user_account_orders_with_http_info_impl(user_id, user_secret, account_id, extra)
334
+ end
335
+
336
+ # Get all history of orders placed in account
337
+ # @param user_id [String]
338
+ # @param user_secret [String]
339
+ # @param account_id [String] The ID of the account get positions.
340
+ # @param [Hash] opts the optional parameters
341
+ # @option opts [String] :state defaults value is set to \&quot;all\&quot;
342
+ # @return [Array<AccountOrderRecord>]
343
+ def get_user_account_orders_impl(user_id, user_secret, account_id, opts = {})
344
+ data, _status_code, _headers = get_user_account_orders_with_http_info(user_id, user_secret, account_id, opts)
345
+ data
346
+ end
347
+
348
+ # Get all history of orders placed in account
349
+ # @param user_id [String]
350
+ # @param user_secret [String]
351
+ # @param account_id [String] The ID of the account get positions.
352
+ # @param [Hash] opts the optional parameters
353
+ # @option opts [String] :state defaults value is set to \&quot;all\&quot;
354
+ # @return [Array<(Array<AccountOrderRecord>, Integer, Hash)>] Array<AccountOrderRecord> data, response status code and response headers
355
+ def get_user_account_orders_with_http_info_impl(user_id, user_secret, account_id, opts = {})
356
+ if @api_client.config.debugging
357
+ @api_client.config.logger.debug 'Calling API: AccountInformationApi.get_user_account_orders ...'
358
+ end
359
+ # verify the required parameter 'user_id' is set
360
+ if @api_client.config.client_side_validation && user_id.nil?
361
+ fail ArgumentError, "Missing the required parameter 'user_id' when calling AccountInformationApi.get_user_account_orders"
362
+ end
363
+ # verify the required parameter 'user_secret' is set
364
+ if @api_client.config.client_side_validation && user_secret.nil?
365
+ fail ArgumentError, "Missing the required parameter 'user_secret' when calling AccountInformationApi.get_user_account_orders"
366
+ end
367
+ # verify the required parameter 'account_id' is set
368
+ if @api_client.config.client_side_validation && account_id.nil?
369
+ fail ArgumentError, "Missing the required parameter 'account_id' when calling AccountInformationApi.get_user_account_orders"
370
+ end
371
+ allowable_values = ["all", "open", "executed"]
372
+ if @api_client.config.client_side_validation && opts[:'state'] && !allowable_values.include?(opts[:'state'])
373
+ fail ArgumentError, "invalid value for \"state\", must be one of #{allowable_values}"
374
+ end
375
+ # resource path
376
+ local_var_path = '/accounts/{accountId}/orders'.sub('{' + 'accountId' + '}', CGI.escape(account_id.to_s))
377
+
378
+ # query parameters
379
+ query_params = opts[:query_params] || {}
380
+ query_params[:'userId'] = user_id
381
+ query_params[:'userSecret'] = user_secret
382
+ query_params[:'state'] = opts[:'state'] if !opts[:'state'].nil?
383
+
384
+ # header parameters
385
+ header_params = opts[:header_params] || {}
386
+ # HTTP header 'Accept' (if needed)
387
+ header_params['Accept'] = @api_client.select_header_accept(['application/json'])
388
+
389
+ # form parameters
390
+ form_params = opts[:form_params] || {}
391
+
392
+ # http body (model)
393
+ post_body = opts[:debug_body]
394
+
395
+ # return_type
396
+ return_type = opts[:debug_return_type] || 'Array<AccountOrderRecord>'
397
+
398
+ # auth_names
399
+ auth_names = opts[:debug_auth_names] || ['PartnerClientId', 'PartnerSignature', 'PartnerTimestamp']
400
+
401
+ new_options = opts.merge(
402
+ :operation => :"AccountInformationApi.get_user_account_orders",
403
+ :header_params => header_params,
404
+ :query_params => query_params,
405
+ :form_params => form_params,
406
+ :body => post_body,
407
+ :auth_names => auth_names,
408
+ :return_type => return_type
409
+ )
410
+
411
+ data, status_code, headers, response = @api_client.call_api(:GET, local_var_path, new_options)
412
+ if @api_client.config.debugging
413
+ @api_client.config.logger.debug "API called: AccountInformationApi#get_user_account_orders\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}"
414
+ end
415
+ return data, status_code, headers, response
416
+ end
417
+
418
+
419
+ # List account positions
420
+ # @param user_id [String]
421
+ # @param user_secret [String]
422
+ # @param account_id [String] The ID of the account get positions.
423
+ # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
424
+ def get_user_account_positions(user_id:, user_secret:, account_id:, extra: {})
425
+
426
+ data, _status_code, _headers = get_user_account_positions_with_http_info_impl(user_id, user_secret, account_id, extra)
427
+ data
428
+ end
429
+
430
+ # List account positions
431
+ # @param user_id [String]
432
+ # @param user_secret [String]
433
+ # @param account_id [String] The ID of the account get positions.
434
+ # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
435
+ def get_user_account_positions_with_http_info(user_id:, user_secret:, account_id:, extra: {})
436
+
437
+ get_user_account_positions_with_http_info_impl(user_id, user_secret, account_id, extra)
438
+ end
439
+
440
+ # List account positions
441
+ # @param user_id [String]
442
+ # @param user_secret [String]
443
+ # @param account_id [String] The ID of the account get positions.
444
+ # @param [Hash] opts the optional parameters
445
+ # @return [Array<Position>]
446
+ def get_user_account_positions_impl(user_id, user_secret, account_id, opts = {})
447
+ data, _status_code, _headers = get_user_account_positions_with_http_info(user_id, user_secret, account_id, opts)
448
+ data
449
+ end
450
+
451
+ # List account positions
452
+ # @param user_id [String]
453
+ # @param user_secret [String]
454
+ # @param account_id [String] The ID of the account get positions.
455
+ # @param [Hash] opts the optional parameters
456
+ # @return [Array<(Array<Position>, Integer, Hash)>] Array<Position> data, response status code and response headers
457
+ def get_user_account_positions_with_http_info_impl(user_id, user_secret, account_id, opts = {})
458
+ if @api_client.config.debugging
459
+ @api_client.config.logger.debug 'Calling API: AccountInformationApi.get_user_account_positions ...'
460
+ end
461
+ # verify the required parameter 'user_id' is set
462
+ if @api_client.config.client_side_validation && user_id.nil?
463
+ fail ArgumentError, "Missing the required parameter 'user_id' when calling AccountInformationApi.get_user_account_positions"
464
+ end
465
+ # verify the required parameter 'user_secret' is set
466
+ if @api_client.config.client_side_validation && user_secret.nil?
467
+ fail ArgumentError, "Missing the required parameter 'user_secret' when calling AccountInformationApi.get_user_account_positions"
468
+ end
469
+ # verify the required parameter 'account_id' is set
470
+ if @api_client.config.client_side_validation && account_id.nil?
471
+ fail ArgumentError, "Missing the required parameter 'account_id' when calling AccountInformationApi.get_user_account_positions"
472
+ end
473
+ # resource path
474
+ local_var_path = '/accounts/{accountId}/positions'.sub('{' + 'accountId' + '}', CGI.escape(account_id.to_s))
475
+
476
+ # query parameters
477
+ query_params = opts[:query_params] || {}
478
+ query_params[:'userId'] = user_id
479
+ query_params[:'userSecret'] = user_secret
480
+
481
+ # header parameters
482
+ header_params = opts[:header_params] || {}
483
+ # HTTP header 'Accept' (if needed)
484
+ header_params['Accept'] = @api_client.select_header_accept(['*/*'])
485
+
486
+ # form parameters
487
+ form_params = opts[:form_params] || {}
488
+
489
+ # http body (model)
490
+ post_body = opts[:debug_body]
491
+
492
+ # return_type
493
+ return_type = opts[:debug_return_type] || 'Array<Position>'
494
+
495
+ # auth_names
496
+ auth_names = opts[:debug_auth_names] || ['PartnerClientId', 'PartnerSignature', 'PartnerTimestamp']
497
+
498
+ new_options = opts.merge(
499
+ :operation => :"AccountInformationApi.get_user_account_positions",
500
+ :header_params => header_params,
501
+ :query_params => query_params,
502
+ :form_params => form_params,
503
+ :body => post_body,
504
+ :auth_names => auth_names,
505
+ :return_type => return_type
506
+ )
507
+
508
+ data, status_code, headers, response = @api_client.call_api(:GET, local_var_path, new_options)
509
+ if @api_client.config.debugging
510
+ @api_client.config.logger.debug "API called: AccountInformationApi#get_user_account_positions\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}"
511
+ end
512
+ return data, status_code, headers, response
513
+ end
514
+
515
+
516
+ # List balances, positions and orders for the specified account.
517
+ # @param account_id [String] The ID of the account to fetch holdings for.
518
+ # @param user_id [String]
519
+ # @param user_secret [String]
520
+ # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
521
+ def get_user_holdings(account_id:, user_id:, user_secret:, extra: {})
522
+
523
+ data, _status_code, _headers = get_user_holdings_with_http_info_impl(account_id, user_id, user_secret, extra)
524
+ data
525
+ end
526
+
527
+ # List balances, positions and orders for the specified account.
528
+ # @param account_id [String] The ID of the account to fetch holdings for.
529
+ # @param user_id [String]
530
+ # @param user_secret [String]
531
+ # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
532
+ def get_user_holdings_with_http_info(account_id:, user_id:, user_secret:, extra: {})
533
+
534
+ get_user_holdings_with_http_info_impl(account_id, user_id, user_secret, extra)
535
+ end
536
+
537
+ # List balances, positions and orders for the specified account.
538
+ # @param account_id [String] The ID of the account to fetch holdings for.
539
+ # @param user_id [String]
540
+ # @param user_secret [String]
541
+ # @param [Hash] opts the optional parameters
542
+ # @return [AccountHoldingsAccount]
543
+ def get_user_holdings_impl(account_id, user_id, user_secret, opts = {})
544
+ data, _status_code, _headers = get_user_holdings_with_http_info(account_id, user_id, user_secret, opts)
545
+ data
546
+ end
547
+
548
+ # List balances, positions and orders for the specified account.
549
+ # @param account_id [String] The ID of the account to fetch holdings for.
550
+ # @param user_id [String]
551
+ # @param user_secret [String]
552
+ # @param [Hash] opts the optional parameters
553
+ # @return [Array<(AccountHoldingsAccount, Integer, Hash)>] AccountHoldingsAccount data, response status code and response headers
554
+ def get_user_holdings_with_http_info_impl(account_id, user_id, user_secret, opts = {})
555
+ if @api_client.config.debugging
556
+ @api_client.config.logger.debug 'Calling API: AccountInformationApi.get_user_holdings ...'
557
+ end
558
+ # verify the required parameter 'account_id' is set
559
+ if @api_client.config.client_side_validation && account_id.nil?
560
+ fail ArgumentError, "Missing the required parameter 'account_id' when calling AccountInformationApi.get_user_holdings"
561
+ end
562
+ # verify the required parameter 'user_id' is set
563
+ if @api_client.config.client_side_validation && user_id.nil?
564
+ fail ArgumentError, "Missing the required parameter 'user_id' when calling AccountInformationApi.get_user_holdings"
565
+ end
566
+ # verify the required parameter 'user_secret' is set
567
+ if @api_client.config.client_side_validation && user_secret.nil?
568
+ fail ArgumentError, "Missing the required parameter 'user_secret' when calling AccountInformationApi.get_user_holdings"
569
+ end
570
+ # resource path
571
+ local_var_path = '/accounts/{accountId}/holdings'.sub('{' + 'accountId' + '}', CGI.escape(account_id.to_s))
572
+
573
+ # query parameters
574
+ query_params = opts[:query_params] || {}
575
+ query_params[:'userId'] = user_id
576
+ query_params[:'userSecret'] = user_secret
577
+
578
+ # header parameters
579
+ header_params = opts[:header_params] || {}
580
+ # HTTP header 'Accept' (if needed)
581
+ header_params['Accept'] = @api_client.select_header_accept(['application/json'])
582
+
583
+ # form parameters
584
+ form_params = opts[:form_params] || {}
585
+
586
+ # http body (model)
587
+ post_body = opts[:debug_body]
588
+
589
+ # return_type
590
+ return_type = opts[:debug_return_type] || 'AccountHoldingsAccount'
591
+
592
+ # auth_names
593
+ auth_names = opts[:debug_auth_names] || ['PartnerClientId', 'PartnerSignature', 'PartnerTimestamp']
594
+
595
+ new_options = opts.merge(
596
+ :operation => :"AccountInformationApi.get_user_holdings",
597
+ :header_params => header_params,
598
+ :query_params => query_params,
599
+ :form_params => form_params,
600
+ :body => post_body,
601
+ :auth_names => auth_names,
602
+ :return_type => return_type
603
+ )
604
+
605
+ data, status_code, headers, response = @api_client.call_api(:GET, local_var_path, new_options)
606
+ if @api_client.config.debugging
607
+ @api_client.config.logger.debug "API called: AccountInformationApi#get_user_holdings\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}"
608
+ end
609
+ return data, status_code, headers, response
610
+ end
611
+
612
+
613
+ # List accounts
614
+ # @param user_id [String]
615
+ # @param user_secret [String]
616
+ # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
617
+ def list_user_accounts(user_id:, user_secret:, extra: {})
618
+
619
+ data, _status_code, _headers = list_user_accounts_with_http_info_impl(user_id, user_secret, extra)
620
+ data
621
+ end
622
+
623
+ # List accounts
624
+ # @param user_id [String]
625
+ # @param user_secret [String]
626
+ # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
627
+ def list_user_accounts_with_http_info(user_id:, user_secret:, extra: {})
628
+
629
+ list_user_accounts_with_http_info_impl(user_id, user_secret, extra)
630
+ end
631
+
632
+ # List accounts
633
+ # @param user_id [String]
634
+ # @param user_secret [String]
635
+ # @param [Hash] opts the optional parameters
636
+ # @return [Array<Account>]
637
+ def list_user_accounts_impl(user_id, user_secret, opts = {})
638
+ data, _status_code, _headers = list_user_accounts_with_http_info(user_id, user_secret, opts)
639
+ data
640
+ end
641
+
642
+ # List accounts
643
+ # @param user_id [String]
644
+ # @param user_secret [String]
645
+ # @param [Hash] opts the optional parameters
646
+ # @return [Array<(Array<Account>, Integer, Hash)>] Array<Account> data, response status code and response headers
647
+ def list_user_accounts_with_http_info_impl(user_id, user_secret, opts = {})
648
+ if @api_client.config.debugging
649
+ @api_client.config.logger.debug 'Calling API: AccountInformationApi.list_user_accounts ...'
650
+ end
651
+ # verify the required parameter 'user_id' is set
652
+ if @api_client.config.client_side_validation && user_id.nil?
653
+ fail ArgumentError, "Missing the required parameter 'user_id' when calling AccountInformationApi.list_user_accounts"
654
+ end
655
+ # verify the required parameter 'user_secret' is set
656
+ if @api_client.config.client_side_validation && user_secret.nil?
657
+ fail ArgumentError, "Missing the required parameter 'user_secret' when calling AccountInformationApi.list_user_accounts"
658
+ end
659
+ # resource path
660
+ local_var_path = '/accounts'
661
+
662
+ # query parameters
663
+ query_params = opts[:query_params] || {}
664
+ query_params[:'userId'] = user_id
665
+ query_params[:'userSecret'] = user_secret
666
+
667
+ # header parameters
668
+ header_params = opts[:header_params] || {}
669
+ # HTTP header 'Accept' (if needed)
670
+ header_params['Accept'] = @api_client.select_header_accept(['application/json'])
671
+
672
+ # form parameters
673
+ form_params = opts[:form_params] || {}
674
+
675
+ # http body (model)
676
+ post_body = opts[:debug_body]
677
+
678
+ # return_type
679
+ return_type = opts[:debug_return_type] || 'Array<Account>'
680
+
681
+ # auth_names
682
+ auth_names = opts[:debug_auth_names] || ['PartnerClientId', 'PartnerSignature', 'PartnerTimestamp']
683
+
684
+ new_options = opts.merge(
685
+ :operation => :"AccountInformationApi.list_user_accounts",
686
+ :header_params => header_params,
687
+ :query_params => query_params,
688
+ :form_params => form_params,
689
+ :body => post_body,
690
+ :auth_names => auth_names,
691
+ :return_type => return_type
692
+ )
693
+
694
+ data, status_code, headers, response = @api_client.call_api(:GET, local_var_path, new_options)
695
+ if @api_client.config.debugging
696
+ @api_client.config.logger.debug "API called: AccountInformationApi#list_user_accounts\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}"
697
+ end
698
+ return data, status_code, headers, response
699
+ end
700
+
701
+
702
+ # Update details of an investment account
703
+ # @param user_id [String]
704
+ # @param user_secret [String]
705
+ # @param account_id [String] The ID of the account to update.
706
+ # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
707
+ def update_user_account(user_id:, user_secret:, account_id:, extra: {})
708
+
709
+ data, _status_code, _headers = update_user_account_with_http_info_impl(user_id, user_secret, account_id, extra)
710
+ data
711
+ end
712
+
713
+ # Update details of an investment account
714
+ # @param user_id [String]
715
+ # @param user_secret [String]
716
+ # @param account_id [String] The ID of the account to update.
717
+ # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
718
+ def update_user_account_with_http_info(user_id:, user_secret:, account_id:, extra: {})
719
+
720
+ update_user_account_with_http_info_impl(user_id, user_secret, account_id, extra)
721
+ end
722
+
723
+ # Update details of an investment account
724
+ # @param user_id [String]
725
+ # @param user_secret [String]
726
+ # @param account_id [String] The ID of the account to update.
727
+ # @param [Hash] opts the optional parameters
728
+ # @return [Array<Account>]
729
+ def update_user_account_impl(user_id, user_secret, account_id, opts = {})
730
+ data, _status_code, _headers = update_user_account_with_http_info(user_id, user_secret, account_id, opts)
731
+ data
732
+ end
733
+
734
+ # Update details of an investment account
735
+ # @param user_id [String]
736
+ # @param user_secret [String]
737
+ # @param account_id [String] The ID of the account to update.
738
+ # @param [Hash] opts the optional parameters
739
+ # @return [Array<(Array<Account>, Integer, Hash)>] Array<Account> data, response status code and response headers
740
+ def update_user_account_with_http_info_impl(user_id, user_secret, account_id, opts = {})
741
+ if @api_client.config.debugging
742
+ @api_client.config.logger.debug 'Calling API: AccountInformationApi.update_user_account ...'
743
+ end
744
+ # verify the required parameter 'user_id' is set
745
+ if @api_client.config.client_side_validation && user_id.nil?
746
+ fail ArgumentError, "Missing the required parameter 'user_id' when calling AccountInformationApi.update_user_account"
747
+ end
748
+ # verify the required parameter 'user_secret' is set
749
+ if @api_client.config.client_side_validation && user_secret.nil?
750
+ fail ArgumentError, "Missing the required parameter 'user_secret' when calling AccountInformationApi.update_user_account"
751
+ end
752
+ # verify the required parameter 'account_id' is set
753
+ if @api_client.config.client_side_validation && account_id.nil?
754
+ fail ArgumentError, "Missing the required parameter 'account_id' when calling AccountInformationApi.update_user_account"
755
+ end
756
+ # resource path
757
+ local_var_path = '/accounts/{accountId}'.sub('{' + 'accountId' + '}', CGI.escape(account_id.to_s))
758
+
759
+ # query parameters
760
+ query_params = opts[:query_params] || {}
761
+ query_params[:'userId'] = user_id
762
+ query_params[:'userSecret'] = user_secret
763
+
764
+ # header parameters
765
+ header_params = opts[:header_params] || {}
766
+ # HTTP header 'Accept' (if needed)
767
+ header_params['Accept'] = @api_client.select_header_accept(['application/json'])
768
+
769
+ # form parameters
770
+ form_params = opts[:form_params] || {}
771
+
772
+ # http body (model)
773
+ post_body = opts[:debug_body]
774
+
775
+ # return_type
776
+ return_type = opts[:debug_return_type] || 'Array<Account>'
777
+
778
+ # auth_names
779
+ auth_names = opts[:debug_auth_names] || ['PartnerClientId', 'PartnerSignature', 'PartnerTimestamp']
780
+
781
+ new_options = opts.merge(
782
+ :operation => :"AccountInformationApi.update_user_account",
783
+ :header_params => header_params,
784
+ :query_params => query_params,
785
+ :form_params => form_params,
786
+ :body => post_body,
787
+ :auth_names => auth_names,
788
+ :return_type => return_type
789
+ )
790
+
791
+ data, status_code, headers, response = @api_client.call_api(:PUT, local_var_path, new_options)
792
+ if @api_client.config.debugging
793
+ @api_client.config.logger.debug "API called: AccountInformationApi#update_user_account\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}"
794
+ end
795
+ return data, status_code, headers, response
796
+ end
797
+ end
798
+
799
+ # top-level client access to avoid having the user to insantiate their own API instances
800
+ AccountInformation = AccountInformationApi::new
801
+ end