Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@cap-js-community/event-queue

Package Overview
Dependencies
Maintainers
5
Versions
65
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@cap-js-community/event-queue

event queue for cds

  • 0.1.49
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
175
increased by230.19%
Maintainers
5
Weekly downloads
 
Created
Source

@cap-js-community/event-queue

npm version monthly downloads REUSE status CI Main

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.

Getting started

  • Run npm add @cap-community/event-queue in @sap/cds project
  • Initialize the event queue for example in the CAP server.js
  • Enhance or create ./srv/server.js:

By Code

const cds = require("@sap/cds");
const eventQueue = require("@sap/cds-event-queue");

cds.on("bootstrap", () => {
  eventQueue.initialize({
    configFilePath: "./srv/eventConfig.yml",
  });
});

module.exports = cds.server;

As cds-plugin

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"
    }
  }
}

Features

  • load balancing of event processing throughout app instances
  • managed transactions for event processing
  • async processing of processing intensive tasks for better UI responsiveness
  • push/pull mechanism for reducing delay between publish an event and processing
  • cluster published events during processing (e.g. for combining multiple E-Mail events to one E-Mail)

Initialize event queue configuration

PropertyDescription
configFilePathFilepath as a string for the event configuration file. The base path is the root directory of the project.
registerAsEventProcessorAllows 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.
runIntervalThe 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).
processEventsAfterPublishAllows 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.
tableNameEventQueueAllows '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.
tableNameEventLockAllows '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.
skipCsnCheckSpecifies whether to skip the CSN check. This might be useful for testing purposes.
parallelTenantProcessingSpecifies the limit as an integer on how many tenants are processed on a given app-instance in parallel. The default is 5.

Persistence

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 provided tables

Use the tables provided by this library. For that add the following to package.json of the project:

{
  "cds": {
    "requires": {
      "cds-event-queue": {
        "model": "@sap/cds-event-queue"
      }
    }
  }
}

Bring your own persistence

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"
    }
  }
}

Configure your events

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

Event Configurations

PropertyDescription
retryAttemptsFor infinite retries, maintain -1 as 'retryAttempts'. Default retry attempts is 3.
parallelEventProcessingHow many events of the same type and subType are parallel processed after clustering. Default value is 1 and limit is 10.
eventOutdatedCheckChecks if the db record for the event has been modified since the selection and right before the processing of the event. Default is true.
commitOnEventLevelAfter 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.
selectMaxChunkSizeNumber 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.
checkForNextChunkDetermines 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.

Support, Feedback, Contributing

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.

Code of Conduct

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.

Licensing

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

Package last updated on 05 Jul 2023

Did you know?

Socket

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.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc