Skip to content

Latest commit

 

History

History
390 lines (294 loc) · 8.76 KB

README.md

File metadata and controls

390 lines (294 loc) · 8.76 KB

Microservice Call

Build Status Coverage Status npm version

The MicroService Call module allows the communication between services.


Installation

npm install @janiscommerce/microservice-call

Configuration

MicroService Call uses Router Fetcher check its configuration here

Session

If an API Session is injected, it will inject janis-client and x-janis-user headers when possible.

Authentication

It will automatically inject the janis-api-key and janis-api-secret headers if JANIS_SERVICE_NAME and JANIS_SERVICE_SECRET environment variables are set.

🔑 Secrets

In case the JANIS_SERVICE_SECRET variable is not found, the package will get the secret using the JANIS_SERVICE_NAME environment variable. If the secret is found it will be used in the janis-api-secret header.

The Secrets are stored in AWS Secrets Manager and obtained with the package @janiscommerce/aws-secrets-manager


API

No Safe Mode

These methods WILL THROW AN ERROR when response statusCode is 400+.

  • call(service, namespace, method, requestData, requestHeaders, endpointParameters)

    Make a request to an microservice.

    Returns a Promise of MicroServiceCallResponse.

  • list(service, namespace, requestData, endpointParameters, pageSize)

    Since 4.0.0

    Make a LIST request to an microservice by entity.

    Returns a Promise of MicroServiceCallResponse, the body contains the full list of entity's objects (no need for pagination)

Safe Mode

Since 4.0.0

These methods WILL NOT THROW AN ERROR when response statusCode is 400+.

  • safeCall(service, namespace, method, requestData, requestHeaders, endpointParameters)

    Make a request to an microservice.

    Returns a Promise of MicroServiceCallResponse.

  • safeList(service, namespace, requestData, endpointParameters, pageSize)

    Make a LIST request to an microservice by entity.

    Returns a Promise of MicroServiceCallResponse, the body contains the full list of entity's objects (no need for pagination)

Extra

Since 4.0.0

  • shouldRetry(response)

    Indicates if should re-try the call. It is useful for Event-Listeners API to avoid unnecessary retries.

    Params: response {MicroServiceCallResponse | MicroServiceCallError}

    Returns a Boolean.

⚠️ After version 4.0.0, get, post, put, path, delete are REMOVED ⚠️

Parameters

The Parameters used in the API functions.

  • service
    • type: String
    • The name of the microservice.
  • namespace
    • type: String
    • The namespace of the microservice.
  • method
    • type: String
    • The method of microservice.
  • requestData
    • type: Object
    • The data that will send.
  • requestHeaders
    • type: Object
    • The headers of the request as key-value.
  • endpointParameters
    • type: Object
    • A key-value mapping between endpoint path variables and their replace value.
  • filters
    • type: Object
    • filters and/or orders available in destination Entity's Service.
    • example:
     { filters: { id: 'some-id', name:'some-name' }}
  • pageSize. Since 4.3.2
    • type: Number
    • The pageSize will be use to add the x-janis-page-size to the ApiList. The default value is 60.

Response Object

Response of Microservice

  • MicroServiceCallResponse: type: Object

    • statusCode:
      • type: Number
      • The status code of the response.
    • statusMessage:
      • type: String
      • The status message of the response.
    • headers:
      • type: Object
      • The headers of the response.
    • body:
      • type: Object, Array or String (if it's "")
      • The body of the response

Errors

The errors are informed with a MicroServiceCallError.

  • MicroServiceCallError:
    • code:
      • type: Number
      • The status code of the error.
    • message:
      • type: String
      • The message of the error.
    • name:
      • type: String
      • The name of the Error
    • statusCode:
      • type: Number
      • The status code of the response.

Codes

The codes are the following:

Code Description
2 Microservice Failed
3 Request Library Errors
4 Janis Secret is missing

Usage

No Safe Mode

Making a regular call using the method call().
const MicroServiceCall = require('@janiscommerce/microservice-call');

const ms = new MicroServiceCall();

// Make a GET request to ms "sac" with the namespace "claim-type" and method "get".
try {
	const response = await ms.call('sac', 'claim-type', 'get', null, null, {
		foo: 'bar'
	});
	/*
		Response example
		{
			headers: {}, // The headers of the response.
			statusCode: 200,
			statusMessage: 'Ok',
			body: {
				foo: 'bar',
				id: 'foo-id',
				other: 100
			}
		}
	*/

} catch(error){
	/*
		Error Response Example:
		{
			name: 'MicroServiceCallError'
			message: 'Could not found claim',
			code: 2,
			statusCode: 404
		}
	*/

	if(ms.shouldRetry(error)) // false
		throw new Error('Should Retry')

	// Do something
}
Making a regular list call using the method list().
const MicroServiceCall = require('@janiscommerce/microservice-call');

const ms = new MicroServiceCall();

// Make a LIST request to ms "catalog" with the namespace "brand" with status filter
try {
	const filters = {
		status: 'active'
	};

	const response = await ms.list('catalog', 'brand', { filters });
	/*
		Response example
		{
			headers: {}, // The headers of the response.
			statusCode: 200,
			statusMessage: 'Ok',
			body: [
				{
					id: 'brand-1',
					referenceId: 'reference-id-1',
					name: 'Brand One'
				},
				{
					id: 'brand-2',
					referenceId: 'reference-id-2',
					name: 'Brand Two'
				},
				// 1997 objects ...
				{
					id: 'brand-2000',
					referenceId: 'reference-id-2000',
					name: 'Brand Two Thousands'
				}
			]
		}
	*/

} catch(err){
	/*
		Error Response Example:
		{
			name: 'MicroServiceCallError'
			message: 'Database Fails',
			code: 2,
			statusCode: 500
		}
	*/

	if(ms.shouldRetry(error)) // true
		throw new Error('Service Call Fails. Should Retry')

	// Do something
}

Safe Mode

Making a "safe" call using the method safeCall().
const MicroServiceCall = require('@janiscommerce/microservice-call');

const ms = new MicroServiceCall();

// Make a GET request to ms "pricing" with the namespace "base-price" and method "get".

const response = await ms.safeCall('pricing', 'base-price', 'get', null, null, {
	foo: 'bar'
});
/*
	Response example
	{
		headers: {}, // The headers of the response.
		statusCode: 504,
		statusMessage: null,
		body: {
			message: 'Timeout'
		}
	}
*/

if(ms.shouldRetry(response)) // true
	throw new Error('Should Retry')

// Do something


// Make a POST request to ms "wms" with the namespace "stock" and method "post".

const response = await ms.safeCall('wms', 'stock', 'post', { name: 'stock-1', quantity: 1 });
/*
	Response example
	{
		headers: {}, // The headers of the response.
		statusCode: 200,
			statusMessage: 'Ok',
			body: {
				id: 'stock-id-1'
			}
	}
*/

if(ms.shouldRetry(response)) // false
	throw new Error('Should Retry')

// Do something
Making a "safe" list call using the method safeList().
const MicroServiceCall = require('@janiscommerce/microservice-call');

const ms = new MicroServiceCall();

// Make a LIST request to ms "commerce" with the namespace "seller" with status filter

const filters = {
	status: 'active'
};

const response = await ms.safeList('commerce', 'seller', { filters });
/*
	Response example
	{
		headers: {}, // The headers of the response.
		statusCode: 200,
		statusMessage: 'Ok',
		body: [
			{
				id: 'seller-1',
				referenceId: 'reference-id-1',
				name: 'Seller One'
			},
			{
				id: 'seller-2',
				referenceId: 'reference-id-2',
				name: 'Seller Two'
			},
			// 1997 objects ...
			{
				id: 'seller-2000',
				referenceId: 'reference-id-2000',
				name: 'Seller Two Thousands'
			}
		]
	}
*/

if(ms.shouldRetry(error)) // false
	throw new Error('Service Call Fails. Should Retry')

// Do something