Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
@cap-js-community/event-queue
Advanced tools
The Event-Queue is a framework built on top of CAP Node.js, specifically designed to enable efficient and streamlined asynchronous event processing in a multi-tenancy environment. With a strong emphasis on load balancing, this package ensures optimal distribution of workload across all available application instances. By offering managed tenant-specific transactions, similar to CAP handlers, the Event-Queue framework simplifies event and asynchronous processing, thereby enhancing the overall performance of your application.
npm add @cap-community/event-queue
in @sap/cds
project./srv/server.js
:const cds = require("@sap/cds");
const eventQueue = require("@cap-js-community/event-queue");
cds.on("bootstrap", () => {
eventQueue.initialize({
configFilePath: "./srv/eventConfig.yml",
});
});
module.exports = cds.server;
Extend the cds section of your package.json. Reference to the cds-plugin section in the capire documentation about the cds-plugin concept. https://cap.cloud.sap/docs/releases/march23#new-cds-plugin-technique
{
"cds": {
"eventQueue": {
"plugin": true,
"configFilePath": "./srv/eventQueueConfig.yml"
}
}
}
Property | Description |
---|---|
configFilePath | Filepath as a string for the event configuration file. The base path is the root directory of the project. |
registerAsEventProcessor | Allows enabling/disabling the registration of the app instance as an event processor. The interval is based on the runInterval parameter. Based on this interval, all events for all tenants will be processed. The default value is true . |
runInterval | The interval specified in seconds, indicating how often events are processed for all tenants. If processEventsAfterPublish is true, in most situations, only erroneous events are processed during this run. All other events are automatically processed after they have been published (see the parameter processEventsAfterPublish ). |
processEventsAfterPublish | Allows enabling/disabling the automatic processing of events after they have been published. The behavior depends on whether a Redis service is bound to the app. With Redis, the processing will happen on any available app instance. If Redis is not bound, the processing will happen on the same instance where the event was published. |
tableNameEventQueue | Allows 'Bring your own table'. This is the name of the event queue table. The required fields for this table can be found in the db-folder. |
tableNameEventLock | Allows 'Bring your own table'. This is the name of the event lock table. The required fields for this table can be found in the db-folder. |
skipCsnCheck | Specifies whether to skip the CSN check. This might be useful for testing purposes. |
parallelTenantProcessing | Specifies the limit as an integer on how many tenants are processed on a given app-instance in parallel. The default is 5. |
This library needs two tables two work as designed. The event tables contains the data and state about the events for processing. The second table is for keeping track of semantic locks. This table is used if no redis-instance is available. There are two options for getting the required tables into the project.
Use the tables provided by this library. For that add the following to package.json
of the project:
{
"cds": {
"requires": {
"cds-event-queue": {
"model": "@cap-js-community/event-queue"
}
}
}
}
The table names can be specified during the initialization of the event queue. It's important that the provided tables have the same named fields and types as the default tables.
Own tables can have additional fields but need to meet the minimal requirements. During initialization, the CDS CSN for the provided table names is checked to ensure they meet the requirements. If you want to skip this check, you can achieve it by using skipCsnCheck (refer to the "Initialize Event Queue Configuration" section).
{
"cds": {
"eventQueue": {
"plugin": true,
"configFilePath": "./srv/eventQueueConfig.yml",
"tableNameEventQueue": "sap.custom.EventQueue",
"tableNameEventLock": "sap.custom.EventLock"
}
}
}
Events are configured in a configuration yml file. In this file all relevant information about how events should be processed can be maintained.
events:
- type: Notifications
subType: Email
impl: ./test/asset/EventQueueTest
Property | Description |
---|---|
retryAttempts | For infinite retries, maintain -1 as 'retryAttempts'. Default retry attempts is 3. |
parallelEventProcessing | How many events of the same type and subType are parallel processed after clustering. Default value is 1 and limit is 10. |
eventOutdatedCheck | Checks if the db record for the event has been modified since the selection and right before the processing of the event. Default is true. |
commitOnEventLevel | After processing an event, the associated transaction is committed and the associated status is committed with the same transaction. This should be used if events should be processed atomically. Default is false. |
selectMaxChunkSize | Number of events which are selected at once. Default is 100. If it should be checked if there are more open events available, set the parameter checkForNextChunk to true. |
checkForNextChunk | Determines if after processing a chunk (the size depends on the value of selectMaxChunkSize), a next chunk is being processed if there are more open events and the processing time has not already exceeded 5 minutes. Default is false. |
This project is open to feature requests/suggestions, bug reports etc. via GitHub issues. Contribution and feedback are encouraged and always welcome. For more information about how to contribute, the project structure, as well as additional contribution information, see our Contribution Guidelines.
We as members, contributors, and leaders pledge to make participation in our community a harassment-free experience for everyone. By participating in this project, you agree to abide by its Code of Conduct at all times.
Copyright 2023 SAP SE or an SAP affiliate company and @cap-js-community/event-queue contributors
. Please see
our LICENSE for copyright and license information. Detailed information including third-party components and
their licensing/copyright information is
available via the REUSE tool.
FAQs
An event queue that enables secure transactional processing of asynchronous and periodic events, featuring instant event processing with Redis Pub/Sub and load distribution across all application instances.
The npm package @cap-js-community/event-queue receives a total of 173 weekly downloads. As such, @cap-js-community/event-queue popularity was classified as not popular.
We found that @cap-js-community/event-queue demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 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
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.