- version: 1.0
- Last update: July, 2022
- Environment: Node.js, TypeScript, and Docker
- Prerequisite: Access to RDP credentials
Example Code Disclaimer: ALL EXAMPLE CODE IS PROVIDED ON AN “AS IS” AND “AS AVAILABLE” BASIS FOR ILLUSTRATIVE PURPOSES ONLY. REFINITIV MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND, EXPRESS OR IMPLIED, AS TO THE OPERATION OF THE EXAMPLE CODE, OR THE INFORMATION, CONTENT, OR MATERIALS USED IN CONNECTION WITH THE EXAMPLE CODE. YOU EXPRESSLY AGREE THAT YOUR USE OF THE EXAMPLE CODE IS AT YOUR SOLE RISK.
The Fetch API provides an interface for fetching resources asynchronously across the network using Promise. The Fetch API is wildly used by the frontend web developers for a while, but the Node.js just added this API as an experimental feature with Node version 17.5.0 in February 2022 for the backend developers.
This example project shows how to use the Node.js experimental native Fetch API with the Refinitiv Data Platform (RDP) APIs as the example HTTP REST APIs. The application source codes are implemented in the TypeScript language, and then run the application in a controlled environment such as Docker and devcontainer using the Node Docker Image. This helps to avoid mess-up your local development environment when experimenting with this feature.
Note: Please be informed that this demo project aims for Development and POC purposes only. The native Fetch API is still an experimental feature (As of April 2022) and is not recommended for Production use.
The JavaScript Fetch API is the modern successor of the XMLHttpRequest API for performing asynchronous HTTP requests. The API is supported by most modern web browsers today. It lets developers implement the HTTP request code using JavaScript Promise which is much simpler than the XMLHttpRequest's callback hell. The example codes are as follows:
Fetch API Promise example code:
fetch('http://example.com')
.then(response => response.json())
.then(data => console.log(data));
Fetch API async/await syntax example code:
async function getData() {
const response = await fetch('http://example.com')
const data = await response.json()
console.log(data)
}
While the frontend JavaScript web developers have been using the Fetch API since 2015, the API has not been included in the Node.js runtime environment. The backend JavaScript developers need to use the other libraries such as the deprecated request module, postman-request, Axios, Node Fetch module, etc to make the HTTP request with Promise on the Node server environment.
Introduction in Node version 17.5.0, the native Fetch API is now available as an experimental feature (thanks to Undici). The Node version 18.0.0 also enables this experimental fetch API on the global scope by default. The backend JavaScript developers do not need to install extra fetch-like modules anymore. The frontend developers will be familiar with the server-side HTTP request code in Node.js.
Example code from Node official page:
const res = await fetch('https://nodejs.org/api/documentation.json');
if (res.ok) {
const data = await res.json();
console.log(data);
}
To run this built-in API, you can run the native Fetch code with the --experimental-fetch
with Node.js 17.5.0 or just a node command with Node.js 18.0.0 when you run the Node application as follow:
$> node app.js //node 18.0.0
$> node --experimental-fetch app.js //node 17.5.0
This example project is focusing on Node version 18.0.0.
The Refinitiv Data Platform (RDP) APIs provide various Refinitiv data and content for developers via easy-to-use Web-based API.
RDP APIs give developers seamless and holistic access to all of the Refinitiv content such as Historical Pricing, Environmental Social and Governance (ESG), News, Research, etc, and commingled with their content, enriching, integrating, and distributing the data through a single interface, delivered wherever they need it. The RDP APIs delivery mechanisms are the following:
- Request - Response: RESTful web service (HTTP GET, POST, PUT or DELETE)
- Alert: delivery is a mechanism to receive asynchronous updates (alerts) to a subscription.
- Bulks: deliver substantial payloads, like the end-of-day pricing data for the whole venue.
- Streaming: deliver real-time delivery of messages.
This example project is focusing on the Request-Response: RESTful web service delivery method only.
For more detail regarding the Refinitiv Data Platform, please see the following APIs resources:
- Quick Start page.
- Tutorials page.
- RDP APIs: Introduction to the Request-Response API page.
- RDP APIs: Authorization - All about tokens page.
This demo project requires the following dependencies.
- RDP Access credentials.
- Visual Studio Code editor.
- Docker Desktop/Engine application.
- VS Code - Remote Development extension pack
- Internet connection.
Please contact your Refinitiv representative to help you to access the RDP account and services. You can find more detail regarding the RDP access credentials set up from the lease see the Getting Started for User ID section of the Getting Start with Refinitiv Data Platform article.
Please see the full details over the example implementation on the Development.md file.
This example project contains the following files and folders
- .devcontainer/devcontainer.json: An example devcontainer configuration file.
- .devcontainer/Dockerfile: An example Dockerfile.
- .devcontainer/.env.devcontainer.example: An example
.env.devcontainer
file. - .vscode: VS Code debugging configurations for compiling and running the example in VS Code devcontainer.
- src: The TypeScript source code folder.
- images: Project images folder.
- LICENSE.md: Project's license file.
- README.md: Project's README file.
- Dockerfile: Project standalone Dockerfile.
- .env.example: Project standalone example
.env
file.
The first step is to unzip or download the example project folder into a directory of your choice, then follow the steps below.
- Go to the project's .devcontainer folder and create a file name
.env.devcontainer
with the following content.RDP_BASE_URL=https://api.refinitiv.com RDP_AUTH_URL=/auth/oauth2/v1/token RDP_AUTH_REVOKE_URL=/auth/oauth2/v1/revoke RDP_SYMBOLOGY_URL=/discovery/symbology/v1/lookup RDP_USERNAME=<RDP UserName> RDP_PASSWORD=<RDP Password> RDP_APP_KEY=<RDP Client_ID>
- Start a Docker desktop or Docker engine on your machine.
- Install the VS Code - Remote Development extension pack.
- Open the VS Code Command Palette with the
F1
key, and then select the Remote-Containers: Reopen in Container command. - Once this build completes, VS Code automatically connects to the container, and automatics initializes the project for developers.
Now VS Code is ready for the RDP-TypeScript native Fetch API example inside this devcontainer. Developers can build and run the example by pressing the F5
button or selecting the Run then Start Debugging option from VS Code menu.
If you want to run the example with a Docker container manually, please follow the steps below.
- Start Docker
- create a file name
.env
in a project root folder with the following content.RDP_BASE_URL=https://api.refinitiv.com RDP_AUTH_URL=/auth/oauth2/v1/token RDP_AUTH_REVOKE_URL=/auth/oauth2/v1/revoke RDP_ESG_URL=/data/environmental-social-governance/v2/views/scores-full RDP_SYMBOLOGY_URL=/discovery/symbology/v1/lookup RDP_USERNAME=<RDP UserName> RDP_PASSWORD=<RDP Password> RDP_APP_KEY=<RDP Client_ID>
- Build a Docker image with the following command:
$> docker build . -t rdp_test_fetch
- Run a Docker container with the following command:
$> docker run -it --name rdp_test_fetch --env-file .env rdp_test_fetch --symbol <RIC> --newslimit <numbers of news limit>
- To stop and delete a Docker container, press
Ctrl+C
(or rundocker stop rdp_test_fetch
) then run the following command:$> docker rm rdp_test_fetch
The coming of the native Fetch API on Node.js is good news for all developers. This built-in API improves cross-platform familiarity for JavaScript/TypeScript developers, they do need to use a different approach for the frontend (web browsers) and backend (Node.js) HTTP request code anymore. This helps simplify the project and reduce the complexity of managing the 3rd party HTTP Request/Fetch modules.
At the same time, the Refinitiv Data Platform (RDP) APIs provide various Refinitiv data and content for developers via an easy-to-use Web-based API. The APIs are easy to integrate into any application and platform that supports the HTTP protocol and JSON message format.
Let me remind you again, this demo projects aim for Development and POC purposes only. The native Fetch API is still an experimental feature (As of April 2022) and is not recommended for Production use.
For further details, please check out the following resources:
- Refinitiv Data Platform APIs page on the Refinitiv Developer Community website.
- Refinitiv Data Platform APIs Playground page.
- Refinitiv Data Platform APIs: Introduction to the Request-Response API.
- Refinitiv Data Platform APIs: Authorization - All about tokens.
- Limitations and Guidelines for the RDP Authentication Service article.
- Getting Started with Refinitiv Data Platform article.
- Node version 18.0.0 page.
- Typescript TSC page.
- TypeScript Handbook page.
- The Fetch API is finally coming to Node.js blog post.
- Node.js 18 available with Fetch API enabled by default news.
- VS Code: Developing inside a Container page.
- VS Code: Remote development in Containers tutorial page.
For any questions related to Refinitiv Data Platform APIs, please use the RDP APIs Forum on the Developers Community Q&A page.