Event over HTTP

The in-memory event system allows functions to communicate with each other in the same application memory space.

In composable architecture, applications are modular components in a network. Some transactions may require the services of more than one application. "Event over HTTP" extends the event system beyond a single application.

The Event API service (event.api.service) is a built-in function in the system.

The Event API endpoint

To enable "Event over HTTP", you must first turn on the REST automation engine with the following parameters in the application.properties file:

server.port=8086

and then add the following entry in the "rest.yaml" endpoint definition file. If not, update "rest.yaml" accordingly. The "timeout" value is set to 60 seconds to fit common use cases.

  - service: [ "event.api.service" ]
    methods: [ 'POST' ]
    url: "/api/event"
    timeout: 60s
    tracing: true

This will expose the Event API endpoint at port 8086 and URL "/api/event".

In kubernetes, The Event API endpoint of each application is reachable through internal DNS and there is no need to create "ingress" for this purpose.

Test drive Event API

You may now test drive the Event API service.

First, build and run the lambda-example application in port 8086.

cd examples/dist
node hello-world.js

Second, build and run the rpc-to-service application.

cd examples/dist/extra
node rpc-to-service.js

The rpc-to-service application will connect to the hello world application and make requests to the "hello.world" service there.

$ node rpc-to-service.js
INFO Event system started - ed28f069afc34647b7afc5e762522e9f (platform.js:441)
INFO PRIVATE distributed.tracing registered (platform.js:215)
INFO PRIVATE async.http.request registered with 200 instances (platform.js:218)
INFO Platform ed28f069afc34647b7afc5e762522e9f ready (main:rpc-to-service.js:10)
INFO Payload match? true (main:rpc-to-service.js:20)
INFO Received 1 (main:rpc-to-service.js:21)
INFO Payload match? true (main:rpc-to-service.js:20)
INFO Received 2 (main:rpc-to-service.js:21)
INFO Payload match? true (main:rpc-to-service.js:20)
INFO Received 3 (main:rpc-to-service.js:21)
INFO Demo application completed (main:rpc-to-service.js:29)

In the rpc-to-service application, it makes the requests using the "await po.remoteRequest()" API.

Since the rpc-to-service is not a service itself, it runs as a standalone command line application. It provides the "tracing" metadata in the PostOffice like this:

const REMOTE_EVENT_ENDPOINT = 'http://127.0.0.1:8086/api/event';
const po = new PostOffice({ 'my_route': 'rpc.demo', 'my_trace_id': '200', 'my_trace_path': '/api/remote/rpc' });
...
const result = await po.remoteRequest(req, REMOTE_EVENT_ENDPOINT);

This illustrates that you can write both command line application or service application using the Mercury-nodejs toolkit.

Advantages

The Event API exposes all public functions of an application instance to the network using a single REST endpoint.

The advantages of Event API includes:

  1. Convenient - you do not need to write or configure individual endpoint for each service
  2. Efficient - events are transported in binary format from one application to another
  3. Secure - you can protect the Event API endpoint with an authentication service

The following configuration adds authentication service to the Event API endpoint:

  - service: [ "event.api.service" ]
    methods: [ 'POST' ]
    url: "/api/event"
    timeout: 60s
    authentication: "v1.api.auth"
    tracing: true

This enforces every incoming request to the Event API endpoint to be authenticated by the "v1.api.auth" service before passing to the Event API service. You can plug in your own authentication service. For example, OAuth 2.0 "bearer token" validation.

Please refer to Chapter-3 - REST automation for details.

Chapter-4 Home Chapter-6
Event orchestration Table of Contents API overview