data:image/s3,"s3://crabby-images/2523c/2523ce4b8b64bade795ffc89574cfc29f35428d3" alt="Deno 2.2 Improves Dependency Management and Expands Node.js Compatibility"
Security News
Deno 2.2 Improves Dependency Management and Expands Node.js Compatibility
Deno 2.2 enhances Node.js compatibility, improves dependency management, adds OpenTelemetry support, and expands linting and task automation for developers.
oomq
to mimics the API of EventEmitter and hides the fact that the events are handled through AMQP server. So instead of doing:
var q = 'tasks';
var open = require('amqplib').connect('amqp://localhost');
// Publisher
open.then((conn) => {
return conn.createChannel();
}).then((ch) => {
return ch.assertQueue(q).then((ok) => {
const payload = {
some: 'sent value',
};
return ch.sendToQueue(q, Buffer.from(JSON.stringify(payload)));
});
}).catch(console.warn);
// Consumer
open.then((conn) => {
return conn.createChannel();
}).then(function(ch) {
return ch.assertQueue(q).then(function(ok) {
return ch.consume(q, (msg) => {
if (msg !== null) {
const payload = JSON.parse(msg.content);
console.log(payload.some);
ch.ack(msg);
}
});
});
}).catch(console.warn);
one would write:
const q = 'tasks';
const {
EventEmitter,
events,
} = require('../');
const emitter = new EventEmitter('amqp://localhost');
// Publisher
const event = events.JSONEvent.create({
some: 'sent value',
});
emitter.emit(event)
.catch(console.warn);
// Consumer
emitter.on(events.JSONEvent, q, (content) => {
console.log('got value:', content.some);
process.exit(0);
}).catch(console.warn);
It aims to avoid common pitfalls of building an event-driven architecture through:
create
function) for them;It doesn't aim to:
npm install oomq --save
interface OnOptions {
/**
* AMQP prefetch parameter.
* @type {number}
*/
prefetch?: number;
/**
* AMQP autoDelete queue parameter.
* @type {boolean}
*/
autoDelete?: boolean;
/**
* Use passed queue name exactly instead
* of using it in conjunction with the event type.
* @type {boolean}
*/
forceExactQueueName?: boolean;
/**
* Don't bind exchange specified in the event type.
* Option is useful together with `forceExactQueueName` if binding
* exchange is not required.
* @type {boolean}
*/
noBind?: boolean;
};
interface EmitOptions {
/**
* Use sendToQueue instead of publishing to an exchange.
* @type {[type]}
*/
queue?: string;
}
type HandlerFunction = (content?: any, message?) => Promise<any>;
url
: AMQP server connection string.options
: default options for on
calls.Event
: Event type to listen to.queue
: Queue identifier. This with stringified name of event type makes the actual queue name in the amqp server.handler
: Handler function which is expected to return a promise. Errors from handler
are thrown. If events are expected to be retried on failure, catch them inside the handler and resolve with emitter.REQUEUE_EVENT
symbol instead.event
: Instance of event to be emitted.There are several examples of usage in examples folder. In simplest form:
const {
EventEmitter,
} = require('oomq');
const emitter = new EventEmitter('amqp://localhost');
// emitter.emit( ... );
emitter.close(); // Will close the channel and connection used by the emitter
After closing the connection with emitter.close()
the client is no longer usable. Publishing events will throw and consumers will be stopped.
oomq
doesn't define any event types in your system, but provides mechanisms for that. It does not enforce the serialization(protobuf, JSON) nor the structure. That makes getting off ground with oomq
a bit more work. Generally you'd either:
Every all the events have to inherit from Event
Example of defining a event type that handles serialization: JSONEVENT.ts. Example of defining a event type that handles validation and event structure: Product event.
FAQs
Object oriented message queue client
The npm package oomq receives a total of 1 weekly downloads. As such, oomq popularity was classified as not popular.
We found that oomq demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer 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
Deno 2.2 enhances Node.js compatibility, improves dependency management, adds OpenTelemetry support, and expands linting and task automation for developers.
Security News
React's CRA deprecation announcement sparked community criticism over framework recommendations, leading to quick updates acknowledging build tools like Vite as valid alternatives.
Security News
Ransomware payment rates hit an all-time low in 2024 as law enforcement crackdowns, stronger defenses, and shifting policies make attacks riskier and less profitable.