Skip to content

nodecloud/nodecloud-brakes

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

28 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

NodeCloud-Brakes

Usage

UserClient

import BrakeClient from "nodecloud-brakes";
import rp from "request-promise";

const SERVICE_NAME = "user-service";
const brake = new BrakeClient(SERVICE_NAME);

//set health check.
brake.healthCheck(() => {
  return rp({
      method: "get",
      url: `/health`,
      headers: {
          "Content-Type": "application/json"
      }
  });
});

brake.on("circuitOpen", () => {
    logger.warn(`The service: ${SERVICE_NAME}"s circuit is opened.`);
});

brake.on("circuitClosed", () => {
    logger.info(`The service: ${SERVICE_NAME}"s circuit is closed.`);
});

brake.fallback(err => {
    throw new Error("Cannot invoke downstream service. please try again soon.", err);
});

export function getUser(userId) {
    const request = {
        method: "get",
        url: `/v1/users/:userId`,
        params: {userId: userId},
        headers: {
            "Content-Type": "application/json"
        }
    };
    return brake.circuit({send: rp}).send(request);
}

You can use brake client to invoke resource api. The example is

import * as userClient from "./UserClient";

userClient.getUser(1).then(user => {
    console.log(user);
})

API

new BrakeClient(serviceName, options)

serviceName

The service name.

options

The options param is the same as brakes. We extend it, and support request handlers

  • options.handler.preHandle(request)
  • options.handler.postHandle(err, response)
  • options.handler.postCircuit(response);

brake.healthCheck(callback)

Set a callback, when the circuit is open, the callback will be used for checking the service"s health status, if the status is ok, the circuit will close.

brake.on(eventName, callback)

See brakes for detail.

brake.isOpen()

Return the circuit"s status.

brake.circuit(client, fallback, options) : {send(request)}

  • client: (required) an object implement send function.
  • fallback: (optional) fallback function.
  • options (optional) the same as brakes.

brake.fallback(callback)

  • fallback: (optional) the global fallback function.

Releases

No releases published

Packages

No packages published