Chilkat Online Tools

Objective-C / Binance spot API / New OCO (TRADE)

Back to Collection Items

#import <CkoHttp.h>
#import <CkoHttpResponse.h>

// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.

CkoHttp *http = [[CkoHttp alloc] init];
BOOL success;

[http SetRequestHeader: @"Content-Type" value: @"application/json"];
[http SetRequestHeader: @"X-MBX-APIKEY" value: @"{{binance-api-key}}"];

CkoHttpResponse *resp = [http QuickRequest: @"POST" url: @"https://domain.com/api/v3/order/oco?symbol=BNBUSDT&side=SELL&quantity=&price=&stopPrice=×tamp={{timestamp}}&signature={{signature}}"];
if (http.LastMethodSuccess == NO) {
    NSLog(@"%@",http.LastErrorText);
    return;
}

NSLog(@"%d",[resp.StatusCode intValue]);
NSLog(@"%@",resp.BodyStr);

Curl Command

curl -X POST
	-H "Content-Type: application/json"
	-H "X-MBX-APIKEY: {{binance-api-key}}"
https://domain.com/api/v3/order/oco?symbol=BNBUSDT&side=SELL&quantity=&price=&stopPrice=&timestamp={{timestamp}}&signature={{signature}}

Postman Collection Item JSON

{
  "name": "New OCO (TRADE)",
  "request": {
    "method": "POST",
    "header": [
      {
        "key": "Content-Type",
        "type": "text",
        "value": "application/json"
      },
      {
        "key": "X-MBX-APIKEY",
        "value": "{{binance-api-key}}",
        "type": "text"
      }
    ],
    "url": {
      "raw": "{{url}}/api/v3/order/oco?symbol=BNBUSDT&side=SELL&quantity=&price=&stopPrice=&timestamp={{timestamp}}&signature={{signature}}",
      "host": [
        "{{url}}"
      ],
      "path": [
        "api",
        "v3",
        "order",
        "oco"
      ],
      "query": [
        {
          "key": "symbol",
          "value": "BNBUSDT",
          "description": "Trading symbol, e.g. BNBUSDT"
        },
        {
          "key": "listClientOrderId",
          "value": "",
          "description": "A unique Id for the entire orderList",
          "disabled": true
        },
        {
          "key": "side",
          "value": "SELL"
        },
        {
          "key": "quantity",
          "value": ""
        },
        {
          "key": "limitClientOrderId",
          "value": "",
          "description": "A unique Id for the limit order",
          "disabled": true
        },
        {
          "key": "limitStrategyId",
          "value": "",
          "disabled": true
        },
        {
          "key": "limitStrategyType",
          "value": "",
          "description": "The value cannot be less than 1000000",
          "disabled": true
        },
        {
          "key": "price",
          "value": "",
          "description": "Order price"
        },
        {
          "key": "limitIcebergQty",
          "value": "",
          "disabled": true
        },
        {
          "key": "trailingDelta",
          "value": "",
          "disabled": true
        },
        {
          "key": "stopClientOrderId",
          "value": "",
          "description": "A unique Id for the stop loss/stop loss limit leg",
          "disabled": true
        },
        {
          "key": "stopPrice",
          "value": ""
        },
        {
          "key": "stopStrategyId",
          "value": "",
          "disabled": true
        },
        {
          "key": "stopStrategyType",
          "value": "",
          "description": "The value cannot be less than 1000000",
          "disabled": true
        },
        {
          "key": "stopLimitPrice",
          "value": "",
          "description": "If provided, stopLimitTimeInForce is required.",
          "disabled": true
        },
        {
          "key": "stopIcebergQty",
          "value": "",
          "disabled": true
        },
        {
          "key": "stopLimitTimeInForce",
          "value": "",
          "disabled": true
        },
        {
          "key": "newOrderRespType",
          "value": "",
          "description": "Set the response JSON.",
          "disabled": true
        },
        {
          "key": "recvWindow",
          "value": "5000",
          "description": "The value cannot be greater than 60000",
          "disabled": true
        },
        {
          "key": "timestamp",
          "value": "{{timestamp}}",
          "description": "UTC timestamp in ms"
        },
        {
          "key": "signature",
          "value": "{{signature}}",
          "description": "Signature"
        }
      ]
    },
    "description": "Send in a new OCO\n\n- Price Restrictions:\n  - `SELL`: Limit Price > Last Price > Stop Price\n  - `BUY`: Limit Price < Last Price < Stop Price\n- Quantity Restrictions:\n    - Both legs must have the same quantity\n    - `ICEBERG` quantities however do not have to be the same\n- Order Rate Limit\n    - `OCO` counts as 2 orders against the order rate limit.\n    \nWeight(IP): 1"
  },
  "response": [
  ]
}