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);
})
The service name.
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);
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.
See brakes for detail.
Return the circuit"s status.
- client: (required) an object implement send function.
- fallback: (optional) fallback function.
- options (optional) the same as brakes.
- fallback: (optional) the global fallback function.