For a deeper look into our Elektron API, look into:

Overview |  Quickstart |  Documentation |  Downloads |  Tutorials |  Articles

question

Upvotes
Accepted
8 12 13 18

NIP needs to download the dictionary before the service is UP

I'm developing a Non Interactive Publisher with the Electron API.

I publish to and ADN into a service named "MY_PUB".

In order to publish, I need a dictionary. I want to download this dictionary from the ADH (or from an ADS). But if my NIP is not already publishing, the service MY_PUB is absent on the ADH and I have the below error message:

12:44:14.777 [pool-9-thread-1] INFO c.h.f.t.s.ReutersPlatformService - Dictionary status message received: provider=Provider_2_4, serviceName=MY_PUB, itemName=RWFFld, itemState=Closed / Suspect / None / 'Service name of 'MY_PUB' is not found.'
12:44:14.778 [pool-9-thread-1] INFO c.h.f.t.s.ReutersPlatformService - Dictionary status message received: provider=Provider_2_4, serviceName=MY_PUB, itemName=RWFEnum, itemState=Closed / Suspect / None / 'Service name of 'MY_PUB' is not found.'

How am I supposed to download the dictionary?

elektronrefinitiv-realtimeelektron-sdktrepelektron-data-dictionary
icon clock
10 |1500

Up to 2 attachments (including images) can be used with a maximum of 512.0 KiB each and 1.0 MiB total.

@nicolas.roux

Hi,

Thank you for your participation in the forum.

Is the reply below satisfactory in answering your question?

If yes please click the 'Accept' text next to the most appropriate reply. This will guide all community members who have a similar question.

Otherwise please post again offering further insight into your question.

Thanks,

AHS

Hello @nicolas.roux

Thank you for your participation in the forum. Is the reply below satisfactory in resolving your query?

If so please can you click the 'Accept' text next to the appropriate reply. This will guide all community members who have a similar question.

Thanks,

AHS

Hi,

Please be informed that a reply has been verified as correct in answering the question, and has been marked as such.

Thanks,

AHS

Upvotes
Accepted
25.3k 87 12 25

Hi @nicolas.roux

Unless you want to explicitly query the Dictionary and check the list of field present in the dictionary, you should not need to download the dictionary in order to publish data from your NI Provider.

For instance, if i take the simplest NIProvider example100, modify it with your Service Name, amend the EMAConfig.xml <Directory_1> entry to reflect your servicename and run it - it should just work. This is because EMA is downloading the dictionary behind the scenes to use when it does all the encoding etc for you behind the scenes.

You will note from the example100 source code that it does not download the dictionary.

icon clock
10 |1500

Up to 2 attachments (including images) can be used with a maximum of 512.0 KiB each and 1.0 MiB total.

Upvotes
17.2k 82 39 63

Hi @nicolas.roux,

As a provider, your application defines the fields it publishes to the infrastructure. You will need to acquire an appropriate dictionary from your TREP administrator as a text file that you will load and parse within your application. You can refer to the details outlined within the EMA NI Provider - Publishing our first Market Price tutorial.

In order for you to download the dictionary within your application, I believe you my be able act as a consumer to your infrastructure to download the dictionary.

icon clock
10 |1500

Up to 2 attachments (including images) can be used with a maximum of 512.0 KiB each and 1.0 MiB total.

What is the best practice regarding the dictionary?

I thought that I was supposed to download the dictionary from the ADH/ADS in order to get the latest version. Then use it with my NIP.

But according to your answer, I'm supposed to get a dictionary from my TREP admin. Copy it locally. Then use it with my NIP. Is that correct?

Isn't it a problem if the dictionary changes on the TREP infrastructure, while I'm still using an old local copy with my NYP?

Write an Answer

Hint: Notify or tag a user in this post by typing @username.

Up to 2 attachments (including images) can be used with a maximum of 512.0 KiB each and 1.0 MiB total.