Margin Service API - Transaction - Add
Description
This request allows the Client to add or create a new transaction in CME CORE. The Client must submit the required attributes (specified below) for a new transaction, then the server validates the request. If the request is invalid, the server returns a status and an error message/code and if the request is valid, an internal identifier for the request along with the status are returned.
Multiple transactions can be added within one message. If processingMode="COMPLETE"
then all transactions must pass validation, or none will be added. If processingMode="PARTIAL"
then transactions that are invalid will not be added, but any valid transactions will be unaffected. Should this happen, the response will have have /transactionRpt@status="SUCCESS_WITH_ERRORS"
and /transactionRpt/transaction/error@code
and /transactionRpt/transaction/error@msg
present for each transaction that failed.
Request
XPath | Name | Type | Required | Notes |
---|---|---|---|---|
| Requesting User ID | No | ||
| Processing Mode | No | ||
| Portfolio ID | Yes | ||
| Transaction Type | Yes | ||
| Payload Encoding | Yes | ||
| Payload Format | Yes | ||
| String Payload | Yes |
Response
XPath | Name | Type | Required | Notes |
---|---|---|---|---|
| Status | Yes | ||
| Error Code | No | ||
| Error Message | No | ||
| Create Time | Yes | ||
| ID | Yes | ||
| Portfolio ID | Yes | ||
| Entity Status | Yes | ||
| Transaction Type | Yes | ||
| Update Time | Yes | ||
| Error Code | No | ||
| Error Message | No | ||
| Payload Encoding | Yes | ||
| Payload Format | Yes | ||
| String Payload | Yes |
Errors
HTTP Status Codes
Code | Description |
---|---|
| The server was not able to process the request. More information (if available) will be provided in the error message. |
Using Your Own Id to Identify Invalid Trades
If you supply your own id (Client ID) for each trade, the Margin Services API returns the invalid trades and corresponding reason.
Examples:
Format | Example Requests and Responses |
---|---|
Invalid all in one request | <?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<ns2:marginReq xmlns:ns2="http://cmegroup.com/schema/core/1.2">
<margin>
<transactions>
<transaction type="TRADE">
<payload format="CSV" encoding="STRING">
<string>
Firm ID,Account ID,Client ID,Product Type ,Currency,Effective Date,Maturity Date,Notional,Direction,Fixed Rate,Leg1 Index,Leg1 IndexTenor,Leg1 Payfreq,Leg1 CompMethod,Leg2 Index,Leg2 IndexTenor,Leg2 Payfreq,Leg2 CompMethod,Leg1 Spread,Leg2 Spread
Test,1234,Test Trade 1,Vanilla,USD,9/6/2011,9/6/2021,"10,000,000",P,0.03123,N/A,N/A,3M,NONE,USD-LIBOR,3M,6M,FLAT,N/A,N/A
Test,1234,Test Trade 2,ZERO_COUPON,USD,9/6/2011,9/6/2021,"10,000,000",P,20,N/A,N/A,6M,NONE,USD-LIBOR-BBA,3M,3M,NONE,N/A,N/A
Test,1234,Test Trade 3,Vanilla,USD,9/6/2011,9/6/2021,"10,000,000",P,0.03123,N/A,N/A,3M,NONE,USD-LIBOR-BBA,3M,6M,FLAT,N/A,N/A
</string>
</payload>
</transaction>
</transactions>
</margin>
</ns2:marginReq> |
Invalid all in one response | <?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<ns2:marginRpt xmlns:ns2="http://cmegroup.com/schema/core/1.2" status="ERROR">
<error msg="null: Client Id: Test Trade 1 : leg2index='USD-LIBOR' is not an allowed value.,null: Client Id: Test Trade 2 : leg1fixedRate=Fixed rate must be less than 1." code="400"/>
</ns2:marginRpt> |
Invalid CSV Request | <?xml version="1.0" encoding="UTF-8" standalone="yes"?><ns2:transactionReq xmlns:ns2="http://cmegroup.com/schema/core/1.2" reqUserId="userid">
<transaction portfolioId="${marginPortfolio}" type="TRADE">
<payload encoding="STRING" format="CSV">
<string>
Firm ID,Account ID,ClearedTradeId,Product Type ,Currency,Effective Date,Maturity Date,Notional,Direction,Fixed Rate,Leg1 Index,
Leg1 IndexTenor,Leg1 Payfreq,Leg1 CompMethod,Leg2 Index,Leg2 IndexTenor,Leg2 Payfreq,Leg2 CompMethod,Leg1
Spread,Leg2 Spread
Test,1234,Test Trade 1,Vanilla,USD,9/6/2011,9/6/2021,"10,000,000",P,0.03123,N/A,N/A,6M,NONE,USD-LIBOR-BBA,3M,6M,FLAT,N/A,N/A
Test,1234,Test Trade 2,OIS,USD,9/6/2011,9/6/2021,"10,000,000",P,0.03123,N/A,N/A,1T,NONE,USD-Federal-H.15-OIS-COMPOUND,N/A,1T,NONE,N/A,N/A
Test,1234,Test Trade 3,ZERO_COUPON,USD,9/6/2011,9/6/2021,"10,000,000",P,0.03123,N/A,N/A,6M,NONE,USD-LIBOR-BBA,3M,3M,NONE,N/A,N/A
</string>
</payload>
</transaction>
</ns2:transactionReq> |
Invalid CSV Response | |
Invalid FPML Request | |
Invalid FPML Response |
Examples
Basic
Request
Response
Multiple Transactions in FpML Format
Request
Response
Add Bulk Transactions Request
Add Bulk Transactions Response
Examples by Product in FpML and FIXML Formats
Basis Swap
FRA Request
FRA Response
OIS (Overnight Index Swap)
Vanilla IRS
Vanilla VNS (Variable Notional Swap)
Zero Coupon
Zero Coupon for BRL
Vanilla Swaptions FPML Request Schema 1.3
Vanilla Swaptions FPML Response Schema 1.3
Examples by Product in FixML Format
Futures Request
Futures Response
FX (Forex)
FX Cleared Confirm
FX Options FIXML
FX Options Cleared Confirm
Examples by Product in csv Format
Vanilla IRS (Interest Rate Swap) Request
Vanilla IRS ( Interest Rate Swap) Response
Vanilla VNS (Variable Notional Swap) Request
Vanilla VNS (Variable Notional Swap) Response
ZCS with BRL Request
ZCS with BRL Response
Vanilla Swaptions CSV Example Request
Vanilla Swaptions Example Response
Delta Ladder Request
Delta Ladder Response
FX (Forex) Request
FX (Forex) Response
FX Option CSV Request
FX Options TR Request
Futures & Options CSV Requests
Example 1: Simple CSV Portfolio CSV
CORE API minimally requires the below attributes to build futures and options transactions. Note CORE will auto-fill attributes when able - for instance if a user supplies a valid Globex Ticket Symbol (Ticker Symbol attribute), other product attributes can be left blank. It is expected users leave the Product Name attribute blank.
Example 2: Risk API CSV Portfolio
Risk API CSV or JSON format (see also below) are the expected SPAN 2 input payload formats. These formats are supported for futures and options only and are also compatible with the deployable margin software program.
Additional details around building a Risk API format payload can be found here.
Please note CORE API seperates transactions into multiple portfolios when the Account ID or Firm ID do not match.
Examples by Product in JSON Format
Risk API JSON or CSV format are the expected SPAN 2 input payload formats. These formats are supported for futures and options only and are also compatible with the deployable margin software program.
Additional details around building a Risk API format payload can be found here.
Please note CORE API seperates transactions into multiple portfolios when the Account ID or Firm ID do not match.
Futures and Options Request
Futures and Options Response
Please note the response format for CORE API is FIXML regardles of inbound transaction type. CORE API assigns transaction and porfolio IDs to the newly created portfolio. The portfolio ID must be supplied in subsequent Margin actions.
Examples Adding Multiple Rates Products in One Request
These examples show the REQUEST to ADD TRANSACTIONS to an existing portfolio. The RESPONSE is the subsequent MARGIN RESPONSE when you send a MARGIN GET. The flow of the calls would be:
Add Portfolio (if not using an existing one)
Add Transactions (like in the below request examples)
Calculate Margin (take the margin request id from this for your margin get call)
Get Margin (the responses below are from the margin get call)
Delta Ladder and Futures Request
Delta Ladder and Futures Response
Delta Ladder and IRS Request
Delta Ladder and IRS Response
IRS and Futures Request
IRS and Futures Response
Delta Ladder, IRS and Futures Request
Delta Ladder, IRS and Futures Response
How was your Client Systems Wiki Experience? Submit Feedback
Copyright © 2024 CME Group Inc. All rights reserved.