Chilkat Online Tools

DataFlex / Binance spot API / Margin Account New OCO (TRADE)

Back to Collection Items

Use ChilkatAx-win32.pkg

Procedure Test
    Handle hoHttp
    Boolean iSuccess
    Variant vResp
    Handle hoResp
    String sTemp1
    Integer iTemp1
    Boolean bTemp1

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

    Get Create (RefClass(cComChilkatHttp)) To hoHttp
    If (Not(IsComObjectCreated(hoHttp))) Begin
        Send CreateComObject of hoHttp
    End

    Send ComSetRequestHeader To hoHttp "Content-Type" "application/json"
    Send ComSetRequestHeader To hoHttp "X-MBX-APIKEY" "{{binance-api-key}}"

    Get ComQuickRequest Of hoHttp "POST" "https://domain.com/sapi/v1/margin/order/oco?symbol=BNBUSDT&side=SELL&quantity=&price=&stopPrice=×tamp={{timestamp}}&signature={{signature}}" To vResp
    If (IsComObject(vResp)) Begin
        Get Create (RefClass(cComChilkatHttpResponse)) To hoResp
        Set pvComObject Of hoResp To vResp
    End
    Get ComLastMethodSuccess Of hoHttp To bTemp1
    If (bTemp1 = False) Begin
        Get ComLastErrorText Of hoHttp To sTemp1
        Showln sTemp1
        Procedure_Return
    End

    Get ComStatusCode Of hoResp To iTemp1
    Showln iTemp1
    Get ComBodyStr Of hoResp To sTemp1
    Showln sTemp1
    Send Destroy of hoResp


End_Procedure

Curl Command

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

Postman Collection Item JSON

{
  "name": "Margin Account 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}}/sapi/v1/margin/order/oco?symbol=BNBUSDT&side=SELL&quantity=&price=&stopPrice=&timestamp={{timestamp}}&signature={{signature}}",
      "host": [
        "{{url}}"
      ],
      "path": [
        "sapi",
        "v1",
        "margin",
        "order",
        "oco"
      ],
      "query": [
        {
          "key": "symbol",
          "value": "BNBUSDT",
          "description": "Trading symbol, e.g. BNBUSDT"
        },
        {
          "key": "isIsolated",
          "value": "",
          "description": "* `TRUE` - For isolated margin\n* `FALSE` - Default, not for isolated margin",
          "disabled": true
        },
        {
          "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": "price",
          "value": "",
          "description": "Order price"
        },
        {
          "key": "limitIcebergQty",
          "value": "",
          "disabled": true
        },
        {
          "key": "stopClientOrderId",
          "value": "",
          "description": "A unique Id for the stop loss/stop loss limit leg",
          "disabled": true
        },
        {
          "key": "stopPrice",
          "value": ""
        },
        {
          "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": "sideEffectType",
          "value": "",
          "description": "Default `NO_SIDE_EFFECT`",
          "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 for a margin account\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(UID): 6"
  },
  "response": [
  ]
}