Chilkat Online Tools

PureBasic / Binance spot API / New OCO (TRADE)

Back to Collection Items

IncludeFile "CkHttp.pb"
IncludeFile "CkHttpResponse.pb"

Procedure ChilkatExample()

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

    http.i = CkHttp::ckCreate()
    If http.i = 0
        Debug "Failed to create object."
        ProcedureReturn
    EndIf

    success.i

    CkHttp::ckSetRequestHeader(http,"Content-Type","application/json")
    CkHttp::ckSetRequestHeader(http,"X-MBX-APIKEY","{{binance-api-key}}")

    resp.i = CkHttp::ckQuickRequest(http,"POST","https://domain.com/api/v3/order/oco?symbol=BNBUSDT&side=SELL&quantity=&price=&stopPrice=×tamp={{timestamp}}&signature={{signature}}")
    If CkHttp::ckLastMethodSuccess(http) = 0
        Debug CkHttp::ckLastErrorText(http)
        CkHttp::ckDispose(http)
        ProcedureReturn
    EndIf

    Debug Str(CkHttpResponse::ckStatusCode(resp))
    Debug CkHttpResponse::ckBodyStr(resp)
    CkHttpResponse::ckDispose(resp)



    CkHttp::ckDispose(http)


    ProcedureReturn
EndProcedure

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": [
  ]
}