Skip to content
Last update: April 22, 2024

Event Bus

The Event Bus module allows you to be notified of new Virto Commerce events or changes via the message queue of your choice. It triggers asynchronous background processes in response to platform events, delivering predefined messages or resource changes as payloads. This facilitates event-driven reactive programming using a publish-subscribe model, where publishers emit events without expectations, and subscribers choose which events to handle.

The event description is based on the CloudEvents specification, which provides a standardized way to describe event data.

Source code

Download

Key Features

The Event Bus module provides:

  • Notification on new events from any module.
  • Support for multiple destination providers.
  • Custom destination provider support (contact us for new destinations).
  • Configurability via API and application configuration (appsettings.json, environment variables, etc.).
  • Additional event filtering with JsonPath expressions.
  • Preprocessing event data with Liquid templates for fine-tuning payload for destination providers.
  • High performance.
  • Predefined destination provider: Azure Event Grid with CloudEvents-based data format.

The diagram below illustrates the functionality of the Event Bus module:

Key entities

Example Uses for Event Bus

  • Serverless Application Architectures: Use Azure Event Grid to trigger serverless functions instantly for tasks like currency exchange when a new price is added to a price list.

  • Approval Process Automation: Utilize Azure Event Grid to notify Azure Automation of new orders or customer registrations, streamlining approval processes by automatically checking configurations, updating metadata, changing statuses, or sending email notifications.

  • Application Integration: Connect your app to other services by sending Virto Commerce event data to Event Grid, leveraging its reliable delivery, advanced routing, and seamless integration with Azure. Alternatively, integrate Event Grid with Logic Apps for code-free data processing across diverse environments.