Skip to content

Latest commit

 

History

History
 
 

Java

Refinitiv Real-Time SDK - Java Edition

This is the Refinitiv Real-Time SDK. This SDK encompasses these Real-Time APIs: Enterprise Message API (EMA) and the Enterprise Transport API (ETA).

The Enterprise Message API (EMA) is an ease of use, open source, OMM API. EMA is designed to provide clients rapid development of applications, minimizing lines of code and providing a broad range of flexibility. It provides flexible configuration with default values to simplify use and deployment. EMA is written on top of the Enterprise Transport API (ETA) utilizing the Value Added Reactor and Watchlist.

The Enterprise Transport API (ETA) is an open source Refinitiv low-level Transport and OMM encoder/decoder API. It is used by the Refinitiv Real-Time Distribution Systems and Refinitiv Real-Time for the optimal distribution of OMM/RWF data and allows applications to achieve the highest performance, highest throughput, and lowest latency. ETA fully supports all OMM constructs and messages. Applications may be written to core ETA, to ValueAdd/Reactor layer or to Watchlist layer.

Copyright (C) 2019-2020 Refinitiv. All rights reserved.

New In This Release

Please refer to the CHANGELOG file in this section to see what is new in this release of Refinitiv Real-Time SDK - Java Edition. Also in CHANGELOG is a list of issues fixed in this release and a history of features and fixes introduced per released version.

Supported Platforms, OSs, Compilers

Hardware/OS Requirements

  • HP Intel PC or AMD Opteron (64-bit)
  • CPUs must have high resolution timer frequencies greater than 1GHz.

Supported Java Version

The Refinitiv Real-Time-SDK supports Oracle JDK 1.8 & 1.11, OpenJDK 1.8 & 1.11.

Refinitiv fully supports the use of the EMA Java Edition developers kit on the core linux and windows platforms listed below.

Refinitiv will extend support to other platforms based on the following criteria:

  • EMA Java is used with a J2SE 8 compliant JVM
  • All problems must be reproducible on one of the core platforms listed below. Refinitiv support teams will only be able to reproduce problems on the core platforms.

Supported Platforms

The Refinitiv Real-Time-SDK provides support for multicast connections using JNI libraries. Also included are closed source libraries for reliable multicast support and value add cache. These libraries are available for the following platform and compiler combinations:

Windows

Platforms:

Windows Server 2012 Enterprise Edition or later 64-bit
Windows Server 2016 Enterprise Edition or later 64-bit
Microsoft Windows 7 Professional or later 64-bit
Microsoft Windows 8 Professional or later 64-bit
Microsoft Windows 8.1 Professional or later 64-bit
Microsoft Windows 10 Professional 64-bit

Compilers (only on OSs supported by Microsoft):

Microsoft Visual Studio 11.0 (2012) 64-bit (JNI Libraries)
Microsoft Visual Studio 12.0 (2013) 64-bit (JNI Libraries)
Microsoft Visual Studio 14.0 (2015) 64-bit (JNI Libraries)
Microsoft Visual Studio 15.0 (2017) 64-bit (JNI Libraries)
Linux

Platforms:

Red Hat Enterprise Linux 6.X Release 64bit, GCC 4.4.4 (JNI Libraries)
Oracle Linux Server 7.X 64-bit, GCC 4.8.2 (JNI Libraries)

Tested Versions

This release has been tested with the following:

Oracle Java SE 8 (JDK1.8)
Oracle Java SE 11 (JDK1.11)
Open JDK (1.8)
Open JDK (1.11)

Proxy Authentication Support

Proxies:

Authentication Schemes:

  • Basic
  • NTLM
  • NEGOTIATE/Kerberos

Encryption Support

This release supports encryption for TLS 1.2.

Generating a keystore file

The keystore file is used to contain your own private keys and public key certificates which is used for SSL/TLS handshake with server certificates to create an encrypted connection type. If you do not need to include your own private keys, the recommendation is to use the cacerts file as your keystore file. The cacerts file comes with your java installation. If you do need to create your own keystore file, please follow industry standard instructions.

Interoperability

RTSDK Java supports connectivity to the following platforms:

  • Refinitiv Real-Time Distribution System (RSSL/RWF connections) : ADS version 2.6 and higher, ADH version 2.6 and higher.
  • Refinitiv Real-Time: Refinitiv Real-Time Deployed, Refinitiv Real-Time Hosted, Refinitiv Direct Feed

NOTE: Connectivity to RDF-Direct is supported for Level 1 and Level 2 data.

This release has been tested with the following:

  • ADS 3.4.2
  • ADH 3.4.2
  • DACS 7.3

Documentation

Please refer to top level README.md and to Java/Eta/README.MD or Java/Ema/README.MD files to find more information. In this directory, please find the test plan with test results: RTSDK-Java-Edition_Test_Plan.xlsx

Installation & Build

Please refer to Installation Guides for ETA and EMA for detailed instructions. In this section are some basic details.

Install RTSDK

This section shows the required setup needed before you can build any of the Java APIs.

Obtain the source from this repository on GitHub. It will contain all of the required source to build RTSDK as detailed below. In addition, this repository depends on a Binary Pack found in the release assets section that is auto pulled by a build. The BinaryPack contains libraries for the closed source portions of the product, permitting users to build and link all dependent libraries to have a fully functional product. For releases prior to RTSDK 1.3.0.L1, ONLY, a Binary Pack may be obtained by cloning RTSDK GitHub repo with --recursive to include submodule found in a BinaryPack repository.

Refinitiv Real-Time SDK package may also be downloaded from Refinitiv Developer Portal.

Refinitiv Real-Time SDK package is also available on MyRefinitiv.com. Search for: "Elektron SDK".

Building RTSDK

Using Gradle:

Gradle is now used to build RTSDK. Gradle can be downloaded from https://gradle.org NOTE: Starting release ESDK 1.3.1, please use Gradle version 5.X which supports JDK1.11 and no longer supports JDK1.7.

Refer to the RTSDK Java Installation Guide for more detailed Gradle build instructions than what is described below.

Navigate to RTSDK/Java and issue the appropriate Gradle command as follows:

Windows: gradlew.bat jar
Linux: ./gradlew jar

This command builds the jar files.

Running examples

To run an example, issue the appropriate command as follows:

Windows: gradlew.bat runExampleName  --args='<arguments>'
Linux: ./gradlew runExampleName --args='<arguments>'

Issue the following command to get a list of all example names.

ETA Windows: gradlew.bat Eta:Applications:Examples:tasks --all
ETA Linux: ./gradlew Eta:Applications:Examples:tasks --all
EMA Windows: gradlew.bat Ema:Examples:tasks --all
EMA Linux: ./gradlew Ema:Examples:tasks --all

ETA example, the following command runs the VAConsumer example.

Windows: gradlew.bat runVaConsumer --args='-c localhost:14002 DIRECT_FEED mp:TRI'
Linux: ./gradlew runVaConsumer --args='-c localhost:14002 DIRECT_FEED mp:TRI'

EMA example, the following command runs the example270__SymbolList example.

Windows: gradlew.bat runconsumer270
Linux: ./gradlew runconsumer270

Running examples with Debug

To debug a encrypted consumer connection, you can add the following JVM argument:

-Djavax.net.debug=all

This provides SSL/TLS details that can be useful if SSL/TLS handshake failed

Obtaining the Refinitiv Field Dictionaries

The Refinitiv RDMFieldDictionary and enumtype.def files are present in this GitHub repo under Java/etc. In addition, the most current version can be downloaded from MyRefinitiv.com. Search for "Service Pack" and choose the latest version of TREP Templates Service Pack.

Maven Central

For ease of product use, as of the RTSDK 1.2 release, Refinitiv maintains its RTSDK Jar files on Maven Central.

You can download RTSDK libraries and dependencies from Maven Central using several different tools, specific procedural instructions are not included here. Maven uses the following syntax to specify RTSDK dependencies (this is sample code) :

<dependency>
	<groupId>com.thomsonreuters.ema</groupId>
	<artifactId>ema</artifactId>
	<version>3.5.1.0</version>
</dependency>

<dependency>
	<groupId>com.thomsonreuters.upa</groupId>
	<artifactId>upa</artifactId>
	<version>3.5.1.0</version>
</dependency>

<dependency>
	<groupId>com.thomsonreuters.upa.valueadd</groupId>
	<artifactId>upaValueAdd</artifactId>
	<version>3.5.1.0</version>
</dependency>

<dependency>
	<groupId>com.thomsonreuters.upa.valueadd.cache</groupId>
	<artifactId>upaValueAddCache</artifactId>
	<version>3.5.1.0</version>
</dependency>

<dependency>
	<groupId>com.thomsonreuters.upa.ansi</groupId>
	<artifactId>ansipage</artifactId>
	<version>3.5.1.0</version>
</dependency>

Gradle uses the following syntax to specify RTSDK dependencies:

compile group: 'com.thomsonreuters.ema', name: 'ema', version: '3.5.1.0'
compile group: 'com.thomsonreuters.upa', name: 'upa', version: '3.5.1.0'
compile group: 'com.thomsonreuters.upa.valueadd', name: 'upaValueAdd', version: '3.5.1.0'
compile group: 'com.thomsonreuters.upa.valueadd.cache', name: 'upaValueAddCache', version: '3.5.1.0'
    compile group: 'com.thomsonreuters.upa.ansi', name: 'ansipage', version: '3.5.1.0'

Developing

If you discover any issues with this project, please feel free to create an Issue.

If you have coding suggestions that you would like to provide for review, please create a Pull Request.

We will review issues and pull requests to determine any appropriate changes.

Contributing

In the event you would like to contribute to this repository, it is required that you read and sign the following:

Please email a signed and scanned copy to [email protected]. If you require that a signed agreement has to be physically mailed to us, please email the request for a mailing address and we will get back to you on where you can send the signed documents.

Notes:

  • For more details on each API, please see the corresponding readme file in their top level directory.
  • This section contains APIs that are subject to proprietary and open source licenses. Please make sure to read the readme files within each API flavor directory for clarification.
  • Please make sure to review the LICENSE.md file.
  • Java unit tests may use Mockito for creation of mock objects. Mockito is distributed under the MIT license.