Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
@byndyusoft/grpc-timeouts
Advanced tools
grpc-timeouts
is a small library that makes it easy to add customizable timeouts to your services. The library implements a circuit breaker pattern, which means that if the request exceeds the deadline, no further requests will be sent. If the deadline for a received request has expired, the request will not be processed and service instantly answers with code 4 (Deadline exceeded).
For new version use https://github.com/semantic-release/semantic-release description. We must set commit message fix(pencil): New feature in release
npm i @byndyusoft/grpc-timeouts
:warning: Make sure that CircuitBreaker interceptors is the last added interceptor, because it will interrupt further processing of the request!
const grpc = require("grpc")
const { CircuitBreaker } = require("@byndyusoft/grpc-timeouts");
const circuitBreaker = new CircuitBreaker();
/*...*/
// Client interceptor:
const client = new grpc.Client(address, credentials, {
interceptors: [circuitBreaker.clientInterceptor]
});
// Server interceptor: (with grpc-host-builder)
const server = new GrpcHostBuilder()
.addInterceptor(circuitBreaker.serverInterceptor)
.addService(myService)
.bind(grpcBind)
.build()
constructor([options: ICircuitBreakerOptions])
Options is an optional object with timeouts for methods (default timeout is 10 seconds).
IServerInterceptor
Server interceptor function.
IClientInterceptor
Client interceptor function.
An object with following keys:
[timeouts: ITimeouts]
- The longest time for the methods to respond[minResponseTimeouts: ITimeouts]
- The shortest time to wait for a response from the services{
timeouts: {
createOrder: 3000,
updateOrder: 500,
deleteOrder: 500,
getOrder: 300,
default: 5000 //default was 10000
},
minResponseTimeouts: {
createOrder: 280,
default: 50 //default was 0
}
}
An object which keys is camelCased method names and values is milliseconds.
This object also have default
field that can be reassigned.
(call: Object, methodDefinition: Object, next: Function) => Promise<Object>
A function that can be used as server interceptor.
(options: Object, next: Function) => grpc.InterceptingCall
A function that can be used as client interceptor.
@Byndyusoft/owners: https://github.com/orgs/Byndyusoft/teams/owners, github.maintain@byndyusoft.com
FAQs
A library for customizable gRPC timeouts
We found that @byndyusoft/grpc-timeouts demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 4 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.