snaptrade 2.0.86 → 2.0.88

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (35) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile.lock +1 -1
  3. data/README.md +376 -304
  4. data/lib/snaptrade/api/trading_api.rb +831 -14
  5. data/lib/snaptrade/models/cryptocurrency_pair.rb +12 -2
  6. data/lib/snaptrade/models/{crypto_spot_quote.rb → cryptocurrency_pair_quote.rb} +3 -3
  7. data/lib/snaptrade/models/manual_trade_form_bracket.rb +13 -19
  8. data/lib/snaptrade/models/manual_trade_replace_form.rb +285 -0
  9. data/lib/snaptrade/models/{crypto_spot_order_preview.rb → simple_order_preview.rb} +5 -5
  10. data/lib/snaptrade/models/{crypto_spot_order_preview_estimated_fee.rb → simple_order_preview_estimated_fee.rb} +3 -3
  11. data/lib/snaptrade/models/{crypto_spot_order_request_body_time_in_force.rb → simple_order_request_body_time_in_force.rb} +3 -3
  12. data/lib/snaptrade/models/{trading_crypto_spot_cancel_order_request.rb → trading_instrument.rb} +21 -16
  13. data/lib/snaptrade/models/trading_instrument_type.rb +38 -0
  14. data/lib/snaptrade/models/{trading_crypto_spot_place_order_request.rb → trading_place_simple_order_request.rb} +14 -14
  15. data/lib/snaptrade/models/{trading_crypto_spot_symbols200_response.rb → trading_search_cryptocurrency_pair_instruments200_response.rb} +3 -3
  16. data/lib/snaptrade/version.rb +1 -1
  17. data/lib/snaptrade.rb +9 -10
  18. data/spec/api/trading_api_spec.rb +93 -0
  19. data/spec/models/{crypto_spot_quote_spec.rb → cryptocurrency_pair_quote_spec.rb} +6 -6
  20. data/spec/models/cryptocurrency_pair_spec.rb +6 -0
  21. data/spec/models/manual_trade_form_bracket_spec.rb +3 -3
  22. data/spec/models/manual_trade_replace_form_spec.rb +59 -0
  23. data/spec/models/{crypto_spot_order_preview_estimated_fee_spec.rb → simple_order_preview_estimated_fee_spec.rb} +6 -6
  24. data/spec/models/{crypto_spot_order_preview_spec.rb → simple_order_preview_spec.rb} +6 -6
  25. data/spec/models/simple_order_request_body_time_in_force_spec.rb +23 -0
  26. data/spec/models/trading_instrument_spec.rb +35 -0
  27. data/spec/models/trading_instrument_type_spec.rb +23 -0
  28. data/spec/models/{trading_crypto_spot_place_order_request_spec.rb → trading_place_simple_order_request_spec.rb} +7 -7
  29. data/spec/models/trading_search_cryptocurrency_pair_instruments200_response_spec.rb +29 -0
  30. metadata +29 -26
  31. data/lib/snaptrade/api/crypto_spot_trading_api.rb +0 -698
  32. data/spec/api/crypto_spot_trading_api_spec.rb +0 -107
  33. data/spec/models/crypto_spot_order_request_body_time_in_force_spec.rb +0 -23
  34. data/spec/models/trading_crypto_spot_cancel_order_request_spec.rb +0 -29
  35. data/spec/models/trading_crypto_spot_symbols200_response_spec.rb +0 -29
data/README.md CHANGED
@@ -6,7 +6,7 @@
6
6
 
7
7
  Connect brokerage accounts to your app for live positions and trading
8
8
 
9
- [![npm](https://img.shields.io/badge/gem-v2.0.86-blue)](https://rubygems.org/gems/snaptrade/versions/2.0.86)
9
+ [![npm](https://img.shields.io/badge/gem-v2.0.88-blue)](https://rubygems.org/gems/snaptrade/versions/2.0.88)
10
10
  [![More Info](https://img.shields.io/badge/More%20Info-Click%20Here-orange)](https://snaptrade.com/)
11
11
 
12
12
  </div>
@@ -43,11 +43,6 @@ Connect brokerage accounts to your app for live positions and trading
43
43
  * [`snaptrade.connections.remove_brokerage_authorization`](#snaptradeconnectionsremove_brokerage_authorization)
44
44
  * [`snaptrade.connections.return_rates`](#snaptradeconnectionsreturn_rates)
45
45
  * [`snaptrade.connections.session_events`](#snaptradeconnectionssession_events)
46
- * [`snaptrade.crypto_spot_trading.crypto_spot_cancel_order`](#snaptradecrypto_spot_tradingcrypto_spot_cancel_order)
47
- * [`snaptrade.crypto_spot_trading.crypto_spot_place_order`](#snaptradecrypto_spot_tradingcrypto_spot_place_order)
48
- * [`snaptrade.crypto_spot_trading.crypto_spot_preview_order`](#snaptradecrypto_spot_tradingcrypto_spot_preview_order)
49
- * [`snaptrade.crypto_spot_trading.crypto_spot_quote`](#snaptradecrypto_spot_tradingcrypto_spot_quote)
50
- * [`snaptrade.crypto_spot_trading.crypto_spot_symbols`](#snaptradecrypto_spot_tradingcrypto_spot_symbols)
51
46
  * [`snaptrade.options.get_option_strategy`](#snaptradeoptionsget_option_strategy)
52
47
  * [`snaptrade.options.get_options_chain`](#snaptradeoptionsget_options_chain)
53
48
  * [`snaptrade.options.get_options_strategy_quote`](#snaptradeoptionsget_options_strategy_quote)
@@ -64,12 +59,18 @@ Connect brokerage accounts to your app for live positions and trading
64
59
  * [`snaptrade.reference_data.list_all_currencies`](#snaptradereference_datalist_all_currencies)
65
60
  * [`snaptrade.reference_data.list_all_currencies_rates`](#snaptradereference_datalist_all_currencies_rates)
66
61
  * [`snaptrade.reference_data.symbol_search_user_account`](#snaptradereference_datasymbol_search_user_account)
62
+ * [`snaptrade.trading.cancel_order`](#snaptradetradingcancel_order)
67
63
  * [`snaptrade.trading.cancel_user_account_order`](#snaptradetradingcancel_user_account_order)
64
+ * [`snaptrade.trading.get_cryptocurrency_pair_quote`](#snaptradetradingget_cryptocurrency_pair_quote)
68
65
  * [`snaptrade.trading.get_order_impact`](#snaptradetradingget_order_impact)
69
66
  * [`snaptrade.trading.get_user_account_quotes`](#snaptradetradingget_user_account_quotes)
70
67
  * [`snaptrade.trading.place_bracket_order`](#snaptradetradingplace_bracket_order)
71
68
  * [`snaptrade.trading.place_force_order`](#snaptradetradingplace_force_order)
72
69
  * [`snaptrade.trading.place_order`](#snaptradetradingplace_order)
70
+ * [`snaptrade.trading.place_simple_order`](#snaptradetradingplace_simple_order)
71
+ * [`snaptrade.trading.preview_simple_order`](#snaptradetradingpreview_simple_order)
72
+ * [`snaptrade.trading.replace_order`](#snaptradetradingreplace_order)
73
+ * [`snaptrade.trading.search_cryptocurrency_pair_instruments`](#snaptradetradingsearch_cryptocurrency_pair_instruments)
73
74
  * [`snaptrade.transactions_and_reporting.get_activities`](#snaptradetransactions_and_reportingget_activities)
74
75
  * [`snaptrade.transactions_and_reporting.get_reporting_custom_range`](#snaptradetransactions_and_reportingget_reporting_custom_range)
75
76
 
@@ -80,7 +81,7 @@ Connect brokerage accounts to your app for live positions and trading
80
81
  Add to Gemfile:
81
82
 
82
83
  ```ruby
83
- gem 'snaptrade', '~> 2.0.86'
84
+ gem 'snaptrade', '~> 2.0.88'
84
85
  ```
85
86
 
86
87
  ## Getting Started<a id="getting-started"></a>
@@ -1045,284 +1046,6 @@ specific users
1045
1046
  ---
1046
1047
 
1047
1048
 
1048
- ### `snaptrade.crypto_spot_trading.crypto_spot_cancel_order`<a id="snaptradecrypto_spot_tradingcrypto_spot_cancel_order"></a>
1049
-
1050
- Cancels a cryptocurrency spot order in the specified account.
1051
-
1052
-
1053
- #### 🛠️ Usage<a id="🛠️-usage"></a>
1054
-
1055
- ```ruby
1056
- result = snaptrade.crypto_spot_trading.crypto_spot_cancel_order(
1057
- brokerage_order_id: "66a033fa-da74-4fcf-b527-feefdec9257e",
1058
- user_id: "snaptrade-user-123",
1059
- user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
1060
- account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
1061
- )
1062
- p result
1063
- ```
1064
-
1065
- #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1066
-
1067
- ##### brokerage_order_id: `String`<a id="brokerage_order_id-string"></a>
1068
- Order ID returned by brokerage. This is the unique identifier for the order in
1069
- the brokerage system.
1070
-
1071
- ##### user_id: `String`<a id="user_id-string"></a>
1072
- ##### user_secret: `String`<a id="user_secret-string"></a>
1073
- ##### account_id: `String`<a id="account_id-string"></a>
1074
- #### 🔄 Return<a id="🔄-return"></a>
1075
-
1076
- [OrderUpdatedResponse](./lib/snaptrade/models/order_updated_response.rb)
1077
-
1078
- #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1079
-
1080
- `/accounts/{accountId}/trading/crypto/spot/cancelOrder` `POST`
1081
-
1082
- [🔙 **Back to Table of Contents**](#table-of-contents)
1083
-
1084
- ---
1085
-
1086
-
1087
- ### `snaptrade.crypto_spot_trading.crypto_spot_place_order`<a id="snaptradecrypto_spot_tradingcrypto_spot_place_order"></a>
1088
-
1089
- Places a spot cryptocurrency order in the specified account.
1090
- This endpoint does not compute the impact to the account balance from the order before submitting the order to the exchange.
1091
-
1092
-
1093
- #### 🛠️ Usage<a id="🛠️-usage"></a>
1094
-
1095
- ```ruby
1096
- result = snaptrade.crypto_spot_trading.crypto_spot_place_order(
1097
- symbol: {
1098
- "base" => "BTC",
1099
- "quote" => "USD",
1100
- },
1101
- side: "BUY",
1102
- type: "MARKET",
1103
- time_in_force: "GTC",
1104
- amount: "123.45",
1105
- user_id: "snaptrade-user-123",
1106
- user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
1107
- account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
1108
- limit_price: "123.45",
1109
- stop_price: "123.45",
1110
- post_only: false,
1111
- expiration_date: "2024-01-01T00:00:00Z",
1112
- )
1113
- p result
1114
- ```
1115
-
1116
- #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1117
-
1118
- ##### symbol: [`CryptocurrencyPair`](./lib/snaptrade/models/cryptocurrency_pair.rb)<a id="symbol-cryptocurrencypairlibsnaptrademodelscryptocurrency_pairrb"></a>
1119
- ##### side: [`ActionStrict`](./lib/snaptrade/models/action_strict.rb)<a id="side-actionstrictlibsnaptrademodelsaction_strictrb"></a>
1120
- The action describes the intent or side of a trade. This is either `BUY` or
1121
- `SELL`.
1122
-
1123
- ##### type: [`Type`](./lib/snaptrade/models/type.rb)<a id="type-typelibsnaptrademodelstyperb"></a>
1124
- The type of order to place.
1125
-
1126
- ##### time_in_force: [`CryptoSpotOrderRequestBodyTimeInForce`](./lib/snaptrade/models/crypto_spot_order_request_body_time_in_force.rb)<a id="time_in_force-cryptospotorderrequestbodytimeinforcelibsnaptrademodelscrypto_spot_order_request_body_time_in_forcerb"></a>
1127
- The Time in Force type for the order. This field indicates how long the order
1128
- will remain active before it is executed or expires. - `GTC` - Good Til
1129
- Canceled. The order is valid until it is executed or canceled. - `FOK` - Fill Or
1130
- Kill. The order must be executed in its entirety immediately or be canceled
1131
- completely. - `IOC` - Immediate Or Cancel. The order must be executed
1132
- immediately. Any portion of the order that cannot be filled immediately will be
1133
- canceled. - `GTD` - Good Til Date. The order is valid until the specified date.
1134
-
1135
- ##### amount: `Float`<a id="amount-float"></a>
1136
- The amount of the base currency to buy or sell.
1137
-
1138
- ##### user_id: `String`<a id="user_id-string"></a>
1139
- ##### user_secret: `String`<a id="user_secret-string"></a>
1140
- ##### account_id: `String`<a id="account_id-string"></a>
1141
- ##### limit_price: `Float`<a id="limit_price-float"></a>
1142
- The limit price. Required if the order type is LIMIT, STOP_LOSS_LIMIT or
1143
- TAKE_PROFIT_LIMIT.
1144
-
1145
- ##### stop_price: `Float`<a id="stop_price-float"></a>
1146
- The stop price. Required if the order type is STOP_LOSS_MARKET, STOP_LOSS_LIMIT,
1147
- TAKE_PROFIT_MARKET or TAKE_PROFIT_LIMIT.
1148
-
1149
- ##### post_only: `Boolean`<a id="post_only-boolean"></a>
1150
- Valid and required only for order type LIMIT. If true orders that would be
1151
- filled immediately are rejected to avoid incurring TAKER fees.
1152
-
1153
- ##### expiration_date: `Time`<a id="expiration_date-time"></a>
1154
- The expiration date of the order. Required if the time_in_force is GTD.
1155
-
1156
- #### 🔄 Return<a id="🔄-return"></a>
1157
-
1158
- [OrderUpdatedResponse](./lib/snaptrade/models/order_updated_response.rb)
1159
-
1160
- #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1161
-
1162
- `/accounts/{accountId}/trading/crypto/spot/placeOrder` `POST`
1163
-
1164
- [🔙 **Back to Table of Contents**](#table-of-contents)
1165
-
1166
- ---
1167
-
1168
-
1169
- ### `snaptrade.crypto_spot_trading.crypto_spot_preview_order`<a id="snaptradecrypto_spot_tradingcrypto_spot_preview_order"></a>
1170
-
1171
- Previews a cryptocurrency spot order using the specified account.
1172
-
1173
-
1174
- #### 🛠️ Usage<a id="🛠️-usage"></a>
1175
-
1176
- ```ruby
1177
- result = snaptrade.crypto_spot_trading.crypto_spot_preview_order(
1178
- symbol: {
1179
- "base" => "BTC",
1180
- "quote" => "USD",
1181
- },
1182
- side: "BUY",
1183
- type: "MARKET",
1184
- time_in_force: "GTC",
1185
- amount: "123.45",
1186
- user_id: "snaptrade-user-123",
1187
- user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
1188
- account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
1189
- limit_price: "123.45",
1190
- stop_price: "123.45",
1191
- post_only: false,
1192
- expiration_date: "2024-01-01T00:00:00Z",
1193
- )
1194
- p result
1195
- ```
1196
-
1197
- #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1198
-
1199
- ##### symbol: [`CryptocurrencyPair`](./lib/snaptrade/models/cryptocurrency_pair.rb)<a id="symbol-cryptocurrencypairlibsnaptrademodelscryptocurrency_pairrb"></a>
1200
- ##### side: [`ActionStrict`](./lib/snaptrade/models/action_strict.rb)<a id="side-actionstrictlibsnaptrademodelsaction_strictrb"></a>
1201
- The action describes the intent or side of a trade. This is either `BUY` or
1202
- `SELL`.
1203
-
1204
- ##### type: [`Type`](./lib/snaptrade/models/type.rb)<a id="type-typelibsnaptrademodelstyperb"></a>
1205
- The type of order to place.
1206
-
1207
- ##### time_in_force: [`CryptoSpotOrderRequestBodyTimeInForce`](./lib/snaptrade/models/crypto_spot_order_request_body_time_in_force.rb)<a id="time_in_force-cryptospotorderrequestbodytimeinforcelibsnaptrademodelscrypto_spot_order_request_body_time_in_forcerb"></a>
1208
- The Time in Force type for the order. This field indicates how long the order
1209
- will remain active before it is executed or expires. - `GTC` - Good Til
1210
- Canceled. The order is valid until it is executed or canceled. - `FOK` - Fill Or
1211
- Kill. The order must be executed in its entirety immediately or be canceled
1212
- completely. - `IOC` - Immediate Or Cancel. The order must be executed
1213
- immediately. Any portion of the order that cannot be filled immediately will be
1214
- canceled. - `GTD` - Good Til Date. The order is valid until the specified date.
1215
-
1216
- ##### amount: `Float`<a id="amount-float"></a>
1217
- The amount of the base currency to buy or sell.
1218
-
1219
- ##### user_id: `String`<a id="user_id-string"></a>
1220
- ##### user_secret: `String`<a id="user_secret-string"></a>
1221
- ##### account_id: `String`<a id="account_id-string"></a>
1222
- ##### limit_price: `Float`<a id="limit_price-float"></a>
1223
- The limit price. Required if the order type is LIMIT, STOP_LOSS_LIMIT or
1224
- TAKE_PROFIT_LIMIT.
1225
-
1226
- ##### stop_price: `Float`<a id="stop_price-float"></a>
1227
- The stop price. Required if the order type is STOP_LOSS_MARKET, STOP_LOSS_LIMIT,
1228
- TAKE_PROFIT_MARKET or TAKE_PROFIT_LIMIT.
1229
-
1230
- ##### post_only: `Boolean`<a id="post_only-boolean"></a>
1231
- Valid and required only for order type LIMIT. If true orders that would be
1232
- filled immediately are rejected to avoid incurring TAKER fees.
1233
-
1234
- ##### expiration_date: `Time`<a id="expiration_date-time"></a>
1235
- The expiration date of the order. Required if the time_in_force is GTD.
1236
-
1237
- #### 🔄 Return<a id="🔄-return"></a>
1238
-
1239
- [CryptoSpotOrderPreview](./lib/snaptrade/models/crypto_spot_order_preview.rb)
1240
-
1241
- #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1242
-
1243
- `/accounts/{accountId}/trading/crypto/spot/previewOrder` `POST`
1244
-
1245
- [🔙 **Back to Table of Contents**](#table-of-contents)
1246
-
1247
- ---
1248
-
1249
-
1250
- ### `snaptrade.crypto_spot_trading.crypto_spot_quote`<a id="snaptradecrypto_spot_tradingcrypto_spot_quote"></a>
1251
-
1252
- Gets a quote for the specified account.
1253
-
1254
-
1255
- #### 🛠️ Usage<a id="🛠️-usage"></a>
1256
-
1257
- ```ruby
1258
- result = snaptrade.crypto_spot_trading.crypto_spot_quote(
1259
- user_id: "snaptrade-user-123",
1260
- user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
1261
- account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
1262
- base: "BTC",
1263
- quote: "USD",
1264
- )
1265
- p result
1266
- ```
1267
-
1268
- #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1269
-
1270
- ##### user_id: `String`<a id="user_id-string"></a>
1271
- ##### user_secret: `String`<a id="user_secret-string"></a>
1272
- ##### account_id: `String`<a id="account_id-string"></a>
1273
- ##### base: `String`<a id="base-string"></a>
1274
- ##### quote: `String`<a id="quote-string"></a>
1275
- #### 🔄 Return<a id="🔄-return"></a>
1276
-
1277
- [CryptoSpotQuote](./lib/snaptrade/models/crypto_spot_quote.rb)
1278
-
1279
- #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1280
-
1281
- `/accounts/{accountId}/trading/crypto/spot/quote` `GET`
1282
-
1283
- [🔙 **Back to Table of Contents**](#table-of-contents)
1284
-
1285
- ---
1286
-
1287
-
1288
- ### `snaptrade.crypto_spot_trading.crypto_spot_symbols`<a id="snaptradecrypto_spot_tradingcrypto_spot_symbols"></a>
1289
-
1290
- Searches cryptocurrency spot symbols accessible to the specified account.
1291
-
1292
-
1293
- #### 🛠️ Usage<a id="🛠️-usage"></a>
1294
-
1295
- ```ruby
1296
- result = snaptrade.crypto_spot_trading.crypto_spot_symbols(
1297
- user_id: "snaptrade-user-123",
1298
- user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
1299
- account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
1300
- base: "BTC",
1301
- quote: "USD",
1302
- )
1303
- p result
1304
- ```
1305
-
1306
- #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1307
-
1308
- ##### user_id: `String`<a id="user_id-string"></a>
1309
- ##### user_secret: `String`<a id="user_secret-string"></a>
1310
- ##### account_id: `String`<a id="account_id-string"></a>
1311
- ##### base: `String`<a id="base-string"></a>
1312
- ##### quote: `String`<a id="quote-string"></a>
1313
- #### 🔄 Return<a id="🔄-return"></a>
1314
-
1315
- [TradingCryptoSpotSymbols200Response](./lib/snaptrade/models/trading_crypto_spot_symbols200_response.rb)
1316
-
1317
- #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1318
-
1319
- `/accounts/{accountId}/trading/crypto/spot/symbols` `GET`
1320
-
1321
- [🔙 **Back to Table of Contents**](#table-of-contents)
1322
-
1323
- ---
1324
-
1325
-
1326
1049
  ### `snaptrade.options.get_option_strategy`<a id="snaptradeoptionsget_option_strategy"></a>
1327
1050
 
1328
1051
  Creates an option strategy object that will be used to place an option strategy order.
@@ -1854,15 +1577,15 @@ The search query for symbols.
1854
1577
  ---
1855
1578
 
1856
1579
 
1857
- ### `snaptrade.trading.cancel_user_account_order`<a id="snaptradetradingcancel_user_account_order"></a>
1580
+ ### `snaptrade.trading.cancel_order`<a id="snaptradetradingcancel_order"></a>
1858
1581
 
1859
- Attempts to cancel an open order with the brokerage. If the order is no longer cancellable, the request will be rejected.
1582
+ Cancels an order in the specified account.
1860
1583
 
1861
1584
 
1862
1585
  #### 🛠️ Usage<a id="🛠️-usage"></a>
1863
1586
 
1864
1587
  ```ruby
1865
- result = snaptrade.trading.cancel_user_account_order(
1588
+ result = snaptrade.trading.cancel_order(
1866
1589
  user_id: "snaptrade-user-123",
1867
1590
  user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
1868
1591
  account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
@@ -1877,23 +1600,95 @@ p result
1877
1600
  ##### user_secret: `String`<a id="user_secret-string"></a>
1878
1601
  ##### account_id: `String`<a id="account_id-string"></a>
1879
1602
  ##### brokerage_order_id: `String`<a id="brokerage_order_id-string"></a>
1880
- Order ID returned by brokerage. This is the unique identifier for the order in
1881
- the brokerage system.
1882
-
1883
1603
  #### 🔄 Return<a id="🔄-return"></a>
1884
1604
 
1885
- [AccountOrderRecord](./lib/snaptrade/models/account_order_record.rb)
1605
+ [OrderUpdatedResponse](./lib/snaptrade/models/order_updated_response.rb)
1886
1606
 
1887
1607
  #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1888
1608
 
1889
- `/accounts/{accountId}/orders/cancel` `POST`
1609
+ `/accounts/{accountId}/trading/simple/{brokerageOrderId}/cancel` `POST`
1890
1610
 
1891
1611
  [🔙 **Back to Table of Contents**](#table-of-contents)
1892
1612
 
1893
1613
  ---
1894
1614
 
1895
1615
 
1896
- ### `snaptrade.trading.get_order_impact`<a id="snaptradetradingget_order_impact"></a>
1616
+ ### `snaptrade.trading.cancel_user_account_order`<a id="snaptradetradingcancel_user_account_order"></a>
1617
+
1618
+ Attempts to cancel an open order with the brokerage. If the order is no longer cancellable, the request will be rejected.
1619
+
1620
+
1621
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1622
+
1623
+ ```ruby
1624
+ result = snaptrade.trading.cancel_user_account_order(
1625
+ user_id: "snaptrade-user-123",
1626
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
1627
+ account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
1628
+ brokerage_order_id: "66a033fa-da74-4fcf-b527-feefdec9257e",
1629
+ )
1630
+ p result
1631
+ ```
1632
+
1633
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1634
+
1635
+ ##### user_id: `String`<a id="user_id-string"></a>
1636
+ ##### user_secret: `String`<a id="user_secret-string"></a>
1637
+ ##### account_id: `String`<a id="account_id-string"></a>
1638
+ ##### brokerage_order_id: `String`<a id="brokerage_order_id-string"></a>
1639
+ Order ID returned by brokerage. This is the unique identifier for the order in
1640
+ the brokerage system.
1641
+
1642
+ #### 🔄 Return<a id="🔄-return"></a>
1643
+
1644
+ [AccountOrderRecord](./lib/snaptrade/models/account_order_record.rb)
1645
+
1646
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1647
+
1648
+ `/accounts/{accountId}/orders/cancel` `POST`
1649
+
1650
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1651
+
1652
+ ---
1653
+
1654
+
1655
+ ### `snaptrade.trading.get_cryptocurrency_pair_quote`<a id="snaptradetradingget_cryptocurrency_pair_quote"></a>
1656
+
1657
+ Gets a quote for the specified account.
1658
+
1659
+
1660
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
1661
+
1662
+ ```ruby
1663
+ result = snaptrade.trading.get_cryptocurrency_pair_quote(
1664
+ user_id: "snaptrade-user-123",
1665
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
1666
+ account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
1667
+ instrument_symbol: "BTC-USD",
1668
+ )
1669
+ p result
1670
+ ```
1671
+
1672
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
1673
+
1674
+ ##### user_id: `String`<a id="user_id-string"></a>
1675
+ ##### user_secret: `String`<a id="user_secret-string"></a>
1676
+ ##### account_id: `String`<a id="account_id-string"></a>
1677
+ ##### instrument_symbol: `String`<a id="instrument_symbol-string"></a>
1678
+ #### 🔄 Return<a id="🔄-return"></a>
1679
+
1680
+ [CryptocurrencyPairQuote](./lib/snaptrade/models/cryptocurrency_pair_quote.rb)
1681
+
1682
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
1683
+
1684
+ `/accounts/{accountId}/trading/instruments/cryptocurrencyPairs/{instrumentSymbol}/quote` `GET`
1685
+
1686
+ [🔙 **Back to Table of Contents**](#table-of-contents)
1687
+
1688
+ ---
1689
+
1690
+
1691
+ ### `snaptrade.trading.get_order_impact`<a id="snaptradetradingget_order_impact"></a>
1897
1692
 
1898
1693
  Simulates an order and its impact on the account. This endpoint does not place the order with the brokerage. If successful, it returns a `Trade` object and the ID of the object can be used to place the order with the brokerage using the [place checked order endpoint](/reference/Trading/Trading_placeOrder). Please note that the `Trade` object returned expires after 5 minutes. Any order placed using an expired `Trade` will be rejected.
1899
1694
 
@@ -2019,9 +1814,11 @@ use. Only supported on certain brokerages
2019
1814
 
2020
1815
  ```ruby
2021
1816
  result = snaptrade.trading.place_bracket_order(
2022
- account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
2023
1817
  action: "BUY",
2024
- symbol: "AAPL",
1818
+ instrument: {
1819
+ "symbol" => "AAPL",
1820
+ "type" => "EQUITY",
1821
+ },
2025
1822
  order_type: "Market",
2026
1823
  time_in_force: "FOK",
2027
1824
  stop_loss: {
@@ -2031,8 +1828,10 @@ result = snaptrade.trading.place_bracket_order(
2031
1828
  take_profit: {
2032
1829
  "limit_price" => "49.95",
2033
1830
  },
1831
+ account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
2034
1832
  user_id: "snaptrade-user-123",
2035
1833
  user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
1834
+ symbol: "AAPL",
2036
1835
  price: 31.33,
2037
1836
  stop: 31.33,
2038
1837
  units: 10.5,
@@ -2042,18 +1841,12 @@ p result
2042
1841
 
2043
1842
  #### ⚙️ Parameters<a id="⚙️-parameters"></a>
2044
1843
 
2045
- ##### account_id: `String`<a id="account_id-string"></a>
2046
- Unique identifier for the connected brokerage account. This is the UUID used to
2047
- reference the account in SnapTrade.
2048
-
2049
1844
  ##### action: [`ActionStrictWithOptions`](./lib/snaptrade/models/action_strict_with_options.rb)<a id="action-actionstrictwithoptionslibsnaptrademodelsaction_strict_with_optionsrb"></a>
2050
1845
  The action describes the intent or side of a trade. This is either `BUY` or
2051
1846
  `SELL` for Equity symbols or `BUY_TO_OPEN`, `BUY_TO_CLOSE`, `SELL_TO_OPEN` or
2052
1847
  `SELL_TO_CLOSE` for Options.
2053
1848
 
2054
- ##### symbol: `String`<a id="symbol-string"></a>
2055
- The security's trading ticker symbol.
2056
-
1849
+ ##### instrument: [`TradingInstrument`](./lib/snaptrade/models/trading_instrument.rb)<a id="instrument-tradinginstrumentlibsnaptrademodelstrading_instrumentrb"></a>
2057
1850
  ##### order_type: [`OrderTypeStrict`](./lib/snaptrade/models/order_type_strict.rb)<a id="order_type-ordertypestrictlibsnaptrademodelsorder_type_strictrb"></a>
2058
1851
  The type of order to place. - For `Limit` and `StopLimit` orders, the `price`
2059
1852
  field is required. - For `Stop` and `StopLimit` orders, the `stop` field is
@@ -2069,8 +1862,14 @@ immediately or be canceled completely.
2069
1862
 
2070
1863
  ##### stop_loss: [`StopLoss`](./lib/snaptrade/models/stop_loss.rb)<a id="stop_loss-stoplosslibsnaptrademodelsstop_lossrb"></a>
2071
1864
  ##### take_profit: [`TakeProfit`](./lib/snaptrade/models/take_profit.rb)<a id="take_profit-takeprofitlibsnaptrademodelstake_profitrb"></a>
1865
+ ##### account_id: `String`<a id="account_id-string"></a>
1866
+ The ID of the account to execute the trade on.
1867
+
2072
1868
  ##### user_id: `String`<a id="user_id-string"></a>
2073
1869
  ##### user_secret: `String`<a id="user_secret-string"></a>
1870
+ ##### symbol: `String`<a id="symbol-string"></a>
1871
+ The security's trading ticker symbol.
1872
+
2074
1873
  ##### price: `Float`<a id="price-float"></a>
2075
1874
  The limit price for `Limit` and `StopLimit` orders.
2076
1875
 
@@ -2087,7 +1886,7 @@ Must be `null` if `notional_value` is provided.
2087
1886
 
2088
1887
  #### 🌐 Endpoint<a id="🌐-endpoint"></a>
2089
1888
 
2090
- `/trade/placeBracketOrder` `POST`
1889
+ `/accounts/{accountId}/trading/bracket` `POST`
2091
1890
 
2092
1891
  [🔙 **Back to Table of Contents**](#table-of-contents)
2093
1892
 
@@ -2233,6 +2032,279 @@ before responding to the request.
2233
2032
  ---
2234
2033
 
2235
2034
 
2035
+ ### `snaptrade.trading.place_simple_order`<a id="snaptradetradingplace_simple_order"></a>
2036
+
2037
+ Places an order in the specified account.
2038
+ This endpoint does not compute the impact to the account balance from the order before submitting the order.
2039
+
2040
+
2041
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
2042
+
2043
+ ```ruby
2044
+ result = snaptrade.trading.place_simple_order(
2045
+ instrument: {
2046
+ "symbol" => "AAPL",
2047
+ "type" => "EQUITY",
2048
+ },
2049
+ side: "BUY",
2050
+ type: "MARKET",
2051
+ time_in_force: "GTC",
2052
+ amount: "123.45",
2053
+ user_id: "snaptrade-user-123",
2054
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
2055
+ account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
2056
+ limit_price: "123.45",
2057
+ stop_price: "123.45",
2058
+ post_only: false,
2059
+ expiration_date: "2024-01-01T00:00:00Z",
2060
+ )
2061
+ p result
2062
+ ```
2063
+
2064
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
2065
+
2066
+ ##### instrument: [`TradingInstrument`](./lib/snaptrade/models/trading_instrument.rb)<a id="instrument-tradinginstrumentlibsnaptrademodelstrading_instrumentrb"></a>
2067
+ ##### side: [`ActionStrict`](./lib/snaptrade/models/action_strict.rb)<a id="side-actionstrictlibsnaptrademodelsaction_strictrb"></a>
2068
+ The action describes the intent or side of a trade. This is either `BUY` or
2069
+ `SELL`.
2070
+
2071
+ ##### type: [`Type`](./lib/snaptrade/models/type.rb)<a id="type-typelibsnaptrademodelstyperb"></a>
2072
+ The type of order to place.
2073
+
2074
+ ##### time_in_force: [`SimpleOrderRequestBodyTimeInForce`](./lib/snaptrade/models/simple_order_request_body_time_in_force.rb)<a id="time_in_force-simpleorderrequestbodytimeinforcelibsnaptrademodelssimple_order_request_body_time_in_forcerb"></a>
2075
+ The Time in Force type for the order. This field indicates how long the order
2076
+ will remain active before it is executed or expires. - `GTC` - Good Til
2077
+ Canceled. The order is valid until it is executed or canceled. - `FOK` - Fill Or
2078
+ Kill. The order must be executed in its entirety immediately or be canceled
2079
+ completely. - `IOC` - Immediate Or Cancel. The order must be executed
2080
+ immediately. Any portion of the order that cannot be filled immediately will be
2081
+ canceled. - `GTD` - Good Til Date. The order is valid until the specified date.
2082
+
2083
+ ##### amount: `Float`<a id="amount-float"></a>
2084
+ The amount of the base currency to buy or sell.
2085
+
2086
+ ##### user_id: `String`<a id="user_id-string"></a>
2087
+ ##### user_secret: `String`<a id="user_secret-string"></a>
2088
+ ##### account_id: `String`<a id="account_id-string"></a>
2089
+ ##### limit_price: `Float`<a id="limit_price-float"></a>
2090
+ The limit price. Required if the order type is LIMIT, STOP_LOSS_LIMIT or
2091
+ TAKE_PROFIT_LIMIT.
2092
+
2093
+ ##### stop_price: `Float`<a id="stop_price-float"></a>
2094
+ The stop price. Required if the order type is STOP_LOSS_MARKET, STOP_LOSS_LIMIT,
2095
+ TAKE_PROFIT_MARKET or TAKE_PROFIT_LIMIT.
2096
+
2097
+ ##### post_only: `Boolean`<a id="post_only-boolean"></a>
2098
+ Valid and required only for order type LIMIT. If true orders that would be
2099
+ filled immediately are rejected to avoid incurring TAKER fees.
2100
+
2101
+ ##### expiration_date: `Time`<a id="expiration_date-time"></a>
2102
+ The expiration date of the order. Required if the time_in_force is GTD.
2103
+
2104
+ #### 🔄 Return<a id="🔄-return"></a>
2105
+
2106
+ [OrderUpdatedResponse](./lib/snaptrade/models/order_updated_response.rb)
2107
+
2108
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
2109
+
2110
+ `/accounts/{accountId}/trading/simple` `POST`
2111
+
2112
+ [🔙 **Back to Table of Contents**](#table-of-contents)
2113
+
2114
+ ---
2115
+
2116
+
2117
+ ### `snaptrade.trading.preview_simple_order`<a id="snaptradetradingpreview_simple_order"></a>
2118
+
2119
+ Previews an order using the specified account.
2120
+
2121
+
2122
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
2123
+
2124
+ ```ruby
2125
+ result = snaptrade.trading.preview_simple_order(
2126
+ instrument: {
2127
+ "symbol" => "AAPL",
2128
+ "type" => "EQUITY",
2129
+ },
2130
+ side: "BUY",
2131
+ type: "MARKET",
2132
+ time_in_force: "GTC",
2133
+ amount: "123.45",
2134
+ user_id: "snaptrade-user-123",
2135
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
2136
+ account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
2137
+ limit_price: "123.45",
2138
+ stop_price: "123.45",
2139
+ post_only: false,
2140
+ expiration_date: "2024-01-01T00:00:00Z",
2141
+ )
2142
+ p result
2143
+ ```
2144
+
2145
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
2146
+
2147
+ ##### instrument: [`TradingInstrument`](./lib/snaptrade/models/trading_instrument.rb)<a id="instrument-tradinginstrumentlibsnaptrademodelstrading_instrumentrb"></a>
2148
+ ##### side: [`ActionStrict`](./lib/snaptrade/models/action_strict.rb)<a id="side-actionstrictlibsnaptrademodelsaction_strictrb"></a>
2149
+ The action describes the intent or side of a trade. This is either `BUY` or
2150
+ `SELL`.
2151
+
2152
+ ##### type: [`Type`](./lib/snaptrade/models/type.rb)<a id="type-typelibsnaptrademodelstyperb"></a>
2153
+ The type of order to place.
2154
+
2155
+ ##### time_in_force: [`SimpleOrderRequestBodyTimeInForce`](./lib/snaptrade/models/simple_order_request_body_time_in_force.rb)<a id="time_in_force-simpleorderrequestbodytimeinforcelibsnaptrademodelssimple_order_request_body_time_in_forcerb"></a>
2156
+ The Time in Force type for the order. This field indicates how long the order
2157
+ will remain active before it is executed or expires. - `GTC` - Good Til
2158
+ Canceled. The order is valid until it is executed or canceled. - `FOK` - Fill Or
2159
+ Kill. The order must be executed in its entirety immediately or be canceled
2160
+ completely. - `IOC` - Immediate Or Cancel. The order must be executed
2161
+ immediately. Any portion of the order that cannot be filled immediately will be
2162
+ canceled. - `GTD` - Good Til Date. The order is valid until the specified date.
2163
+
2164
+ ##### amount: `Float`<a id="amount-float"></a>
2165
+ The amount of the base currency to buy or sell.
2166
+
2167
+ ##### user_id: `String`<a id="user_id-string"></a>
2168
+ ##### user_secret: `String`<a id="user_secret-string"></a>
2169
+ ##### account_id: `String`<a id="account_id-string"></a>
2170
+ ##### limit_price: `Float`<a id="limit_price-float"></a>
2171
+ The limit price. Required if the order type is LIMIT, STOP_LOSS_LIMIT or
2172
+ TAKE_PROFIT_LIMIT.
2173
+
2174
+ ##### stop_price: `Float`<a id="stop_price-float"></a>
2175
+ The stop price. Required if the order type is STOP_LOSS_MARKET, STOP_LOSS_LIMIT,
2176
+ TAKE_PROFIT_MARKET or TAKE_PROFIT_LIMIT.
2177
+
2178
+ ##### post_only: `Boolean`<a id="post_only-boolean"></a>
2179
+ Valid and required only for order type LIMIT. If true orders that would be
2180
+ filled immediately are rejected to avoid incurring TAKER fees.
2181
+
2182
+ ##### expiration_date: `Time`<a id="expiration_date-time"></a>
2183
+ The expiration date of the order. Required if the time_in_force is GTD.
2184
+
2185
+ #### 🔄 Return<a id="🔄-return"></a>
2186
+
2187
+ [SimpleOrderPreview](./lib/snaptrade/models/simple_order_preview.rb)
2188
+
2189
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
2190
+
2191
+ `/accounts/{accountId}/trading/simple/preview` `POST`
2192
+
2193
+ [🔙 **Back to Table of Contents**](#table-of-contents)
2194
+
2195
+ ---
2196
+
2197
+
2198
+ ### `snaptrade.trading.replace_order`<a id="snaptradetradingreplace_order"></a>
2199
+
2200
+ Replaces an existing pending order with a new one. The way this works is brokerage dependent, but usually involves cancelling
2201
+ the existing order and placing a new one. The order's brokerage_order_id may or may not change, be sure to use the one
2202
+ returned in the response going forward. Only supported on some brokerages
2203
+
2204
+
2205
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
2206
+
2207
+ ```ruby
2208
+ result = snaptrade.trading.replace_order(
2209
+ action: "BUY",
2210
+ order_type: "Market",
2211
+ time_in_force: "FOK",
2212
+ account_id: "2bcd7cc3-e922-4976-bce1-9858296801c3",
2213
+ brokerage_order_id: "66a033fa-da74-4fcf-b527-feefdec9257e",
2214
+ user_id: "snaptrade-user-123",
2215
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
2216
+ price: 31.33,
2217
+ stop: 31.33,
2218
+ units: 10.5,
2219
+ )
2220
+ p result
2221
+ ```
2222
+
2223
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
2224
+
2225
+ ##### action: [`ActionStrict`](./lib/snaptrade/models/action_strict.rb)<a id="action-actionstrictlibsnaptrademodelsaction_strictrb"></a>
2226
+ The action describes the intent or side of a trade. This is either `BUY` or
2227
+ `SELL`.
2228
+
2229
+ ##### order_type: [`OrderTypeStrict`](./lib/snaptrade/models/order_type_strict.rb)<a id="order_type-ordertypestrictlibsnaptrademodelsorder_type_strictrb"></a>
2230
+ The type of order to place. - For `Limit` and `StopLimit` orders, the `price`
2231
+ field is required. - For `Stop` and `StopLimit` orders, the `stop` field is
2232
+ required.
2233
+
2234
+ ##### time_in_force: [`TimeInForceStrict`](./lib/snaptrade/models/time_in_force_strict.rb)<a id="time_in_force-timeinforcestrictlibsnaptrademodelstime_in_force_strictrb"></a>
2235
+ The Time in Force type for the order. This field indicates how long the order
2236
+ will remain active before it is executed or expires. Here are the supported
2237
+ values: - `Day` - Day. The order is valid only for the trading day on which it
2238
+ is placed. - `GTC` - Good Til Canceled. The order is valid until it is executed
2239
+ or canceled. - `FOK` - Fill Or Kill. The order must be executed in its entirety
2240
+ immediately or be canceled completely.
2241
+
2242
+ ##### account_id: `String`<a id="account_id-string"></a>
2243
+ The ID of the account to execute the trade on.
2244
+
2245
+ ##### brokerage_order_id: `String`<a id="brokerage_order_id-string"></a>
2246
+ The Brokerage Order ID of the order to replace.
2247
+
2248
+ ##### user_id: `String`<a id="user_id-string"></a>
2249
+ ##### user_secret: `String`<a id="user_secret-string"></a>
2250
+ ##### price: `Float`<a id="price-float"></a>
2251
+ The limit price for `Limit` and `StopLimit` orders.
2252
+
2253
+ ##### stop: `Float`<a id="stop-float"></a>
2254
+ The price at which a stop order is triggered for `Stop` and `StopLimit` orders.
2255
+
2256
+ ##### units: [`Float`](./lib/snaptrade/models/float.rb)<a id="units-floatlibsnaptrademodelsfloatrb"></a>
2257
+ #### 🔄 Return<a id="🔄-return"></a>
2258
+
2259
+ [AccountOrderRecord](./lib/snaptrade/models/account_order_record.rb)
2260
+
2261
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
2262
+
2263
+ `/accounts/{accountId}/trading/simple/{brokerageOrderId}/replace` `PATCH`
2264
+
2265
+ [🔙 **Back to Table of Contents**](#table-of-contents)
2266
+
2267
+ ---
2268
+
2269
+
2270
+ ### `snaptrade.trading.search_cryptocurrency_pair_instruments`<a id="snaptradetradingsearch_cryptocurrency_pair_instruments"></a>
2271
+
2272
+ Searches cryptocurrency pairs instruments accessible to the specified account.
2273
+
2274
+
2275
+ #### 🛠️ Usage<a id="🛠️-usage"></a>
2276
+
2277
+ ```ruby
2278
+ result = snaptrade.trading.search_cryptocurrency_pair_instruments(
2279
+ user_id: "snaptrade-user-123",
2280
+ user_secret: "adf2aa34-8219-40f7-a6b3-60156985cc61",
2281
+ account_id: "917c8734-8470-4a3e-a18f-57c3f2ee6631",
2282
+ base: "BTC",
2283
+ quote: "USD",
2284
+ )
2285
+ p result
2286
+ ```
2287
+
2288
+ #### ⚙️ Parameters<a id="⚙️-parameters"></a>
2289
+
2290
+ ##### user_id: `String`<a id="user_id-string"></a>
2291
+ ##### user_secret: `String`<a id="user_secret-string"></a>
2292
+ ##### account_id: `String`<a id="account_id-string"></a>
2293
+ ##### base: `String`<a id="base-string"></a>
2294
+ ##### quote: `String`<a id="quote-string"></a>
2295
+ #### 🔄 Return<a id="🔄-return"></a>
2296
+
2297
+ [TradingSearchCryptocurrencyPairInstruments200Response](./lib/snaptrade/models/trading_search_cryptocurrency_pair_instruments200_response.rb)
2298
+
2299
+ #### 🌐 Endpoint<a id="🌐-endpoint"></a>
2300
+
2301
+ `/accounts/{accountId}/trading/instruments/cryptocurrencyPairs` `GET`
2302
+
2303
+ [🔙 **Back to Table of Contents**](#table-of-contents)
2304
+
2305
+ ---
2306
+
2307
+
2236
2308
  ### `snaptrade.transactions_and_reporting.get_activities`<a id="snaptradetransactions_and_reportingget_activities"></a>
2237
2309
  ![Deprecated](https://img.shields.io/badge/deprecated-yellow)
2238
2310