EMA - Batch request with specific fields
For better performance, I'm trying to request specific fields using a batch request. For example, I want to get only the BID and ASK fields from the EUR= and GBP= requests. I'm using this code:
ElementList customView = EmaFactory.createElementList();
OmmArray fields_array = EmaFactory.createOmmArray();
OmmArray batch_array = EmaFactory.createOmmArray();
fields_array.fixedWidth(2);
fields_array.add(EmaFactory.createOmmArrayEntry().intValue(22)); // BID
fields_array.add(EmaFactory.createOmmArrayEntry().intValue(25)); // ASK
batch_array.add(EmaFactory.createOmmArrayEntry().ascii('EUR='));
batch_array.add(EmaFactory.createOmmArrayEntry().ascii('GBP='));
customView.add(EmaFactory.createElementEntry().uintValue(EmaRdm.ENAME_VIEW_TYPE, 1));
customView.add(EmaFactory.createElementEntry().array(EmaRdm.ENAME_VIEW_DATA, fields_array));
customView.add(EmaFactory.createElementEntry().array(EmaRdm.ENAME_BATCH_ITEM_LIST, batch_array));
this.consumer.registerClient(EmaFactory.createReqMsg().serviceName(serviceName).payload(customView), this.appClient);
I'm having this Exception:
Exception Type='OmmInvalidUsageException', Text='Failed to open or modify item request. Reason: ReactorReturnCodes.FAILURE. Error text: Unexpected primitive type in array <17>'
Best Answer
-
I suspect this could be because you are using single quote rather than double quote for your RIC codes and also the order of adding the arrays to the ElemenList seems to matter.
so, for example the following works for me:
ElementList customView = EmaFactory.createElementList();
OmmArray fields_array = EmaFactory.createOmmArray();
OmmArray batch_array = EmaFactory.createOmmArray();
fields_array.fixedWidth(2);
fields_array.add(EmaFactory.createOmmArrayEntry().intValue(22)); // BID
fields_array.add(EmaFactory.createOmmArrayEntry().intValue(25)); // ASK
batch_array.add(EmaFactory.createOmmArrayEntry().ascii("EUR="));
batch_array.add(EmaFactory.createOmmArrayEntry().ascii("GBP="));
customView.add(EmaFactory.createElementEntry().array(EmaRdm.ENAME_BATCH_ITEM_LIST, batch_array));
customView.add(EmaFactory.createElementEntry().uintValue(EmaRdm.ENAME_VIEW_TYPE, 1));
customView.add(EmaFactory.createElementEntry().array(EmaRdm.ENAME_VIEW_DATA, fields_array));On my Java environment your code snippet wont get past compilation due to an invalid character constant error....
0
Answers
-
Good morning and thank you for you answer.
Your code actually worked! But not because of the quotes, since I'm using variables here whose values are loaded from somewhere else, not strings with quotes. But the problem appeared to be in the sequence of the last 3 lines. In my code I was setting the uintValue first, then the fields_array, and finally the batch_array. The sequence in your code worked and saved my day. Thank you again.0
Categories
- All Categories
- 6 AHS
- 37 Alpha
- 161 App Studio
- 4 Block Chain
- 4 Bot Platform
- 16 Connected Risk APIs
- 47 Data Fusion
- 30 Data Model Discovery
- 608 Datastream
- 1.3K DSS
- 577 Eikon COM
- 4.9K Eikon Data APIs
- 7 Electronic Trading
- Generic FIX
- 7 Local Bank Node API
- Trading API
- 2.7K Elektron
- 1.3K EMA
- 236 ETA
- 519 WebSocket API
- 33 FX Venues
- 10 FX Market Data
- 1 FX Post Trade
- 1 FX Trading - Matching
- 12 FX Trading – RFQ Maker
- 5 Intelligent Tagging
- 2 Legal One
- 20 Messenger Bot
- 2 Messenger Side by Side
- 9 ONESOURCE
- 7 Indirect Tax
- 59 Open Calais
- 264 Open PermID
- 39 Entity Search
- 2 Org ID
- PAM
- PAM - Logging
- 8.4K Private Comments
- 6 Product Insight
- Project Tracking
- ProView
- ProView Internal
- 20 RDMS
- 1.4K Refinitiv Data Platform
- 367 Refinitiv Data Platform Libraries
- 3 Refinitiv Due Diligence
- LSEG Due Diligence Portal API
- 3 Refinitiv Due Dilligence Centre
- Rose's Space
- 1.1K Screening
- 18 Qual-ID API
- 13 Screening Deployed
- 23 Screening Online
- 10 World-Check Customer Risk Screener
- 990 World-Check One
- 44 World-Check One Zero Footprint
- 45 Side by Side Integration API
- Test Space
- 3 Thomson One Smart
- 1.2K TR Internal
- Global Hackathon 2015
- 2 Specialists Who Code
- 10 TR Knowledge Graph
- 150 Transactions
- 142 REDI API
- 1.7K TREP APIs
- 4 CAT
- 21 DACS Station
- 117 Open DACS
- 1.1K RFA
- 103 UPA
- 172 TREP Infrastructure
- 224 TRKD
- 886 TRTH
- 5 Velocity Analytics
- 5 Wealth Management Web Services
- 59 Workspace SDK
- 9 Element Framework
- 5 Grid
- 13 World-Check Data File
- Yield Book Analytics
- 46 中文论坛