- 04 Sep 2024
- 13 Minutes To Read
- Print
- DarkLight
- PDF
Introduction
- Updated On 04 Sep 2024
- 13 Minutes To Read
- Print
- DarkLight
- PDF
Event Driven Functions allow you to run a custom code whenever events are happening in the Mambu application. In custom code you can perform actions like calling Mambu APIs or even any other external APIs.
Event Driven Functions integrates with Mambu Streaming API and supports all events types which are supported by the Streaming API: Event Triggers for Notifications - Notifications Different to Streaming APIs, Event Driven Functions do not require any additional infrastructure to process the events and allows you to concentrate on developing custom business logic rather than hosting your own application.
The guide bellow will walk you through the main Event Driven Functions concepts and commands.
Events streaming needs to be enabled for Event Driven functions. If you would like to request early access to this feature, please get in touch with your Mambu Customer Success Manager or contact us through Mambu Support to discuss your requirements.
The total size of the input payload (which comprises of data from all the events in a batch) to your custom function should not exceed 6mb. This is a hard limit, and any payload exceeding this size will not be processed.
Workflow to set up Event Driven functions
In order to setup Event Driven function, you need to:
- Create an event streaming notification template for the target event via admin UI.
- Generate a sample function using Mambu CLI and then implement the custom business logic.
- Create secrets necessary for your functions.
- Build and deploy the function.
- Create a function Subscription for the target event.
- Monitor your function to verify that events are being processed as expected.
Create event streaming notification templates
Event streaming notification template defines conditions when the event will be triggered as well as the payload which will be sent to the function. Please follow “Creating event streaming notification templates” section in the Streaming API documentation.
Note down the topic name which will be automatically generated when creating the template.
if you are also using Streaming APIs directly, the events produced by the newly created template will also be visible to Streaming API consumers. If needed, you can filter out such events in your application code based on the template_name field.
Create the project scaffolding for Event Driven Dunction
The Mambu Functions CLI allows you to easily create all the files you need to start working on your new Event Driven Function with the command:
mambu functions generate --functionDirectory=./your-function --functionName=your-function --template=STREAMING_EVENTS
Example | Description | Required |
---|---|---|
mambu functions generate | This part of the command is always required. | YES |
-t or --template | The templates to use for an extension point. Templates are ready-to-use implementations for an extension point that allow you to start writing code immediately for common processes. For more information, see the Extensions Point page. To create a project for the Event Driven Function, specify STREAMING_EVENTS. NOTE: this parameter is not related to event streaming notification template described above. | YES |
-d or --functionDirectory | The local directory to use for your Mambu Function. | YES |
-n or --functionName | The name of the Mambu Function. The name can only contain letters, digits, and hyphens - and it can not be the same as a previously used name unless you use the update flag. | YES |
The command will generate a sample typescript project containing Event Driven Function for the following sample use case: applying a fee for each withdrawal on the deposits account. This can be further extended to other use cases. Please refer to the README file in the function directory for more details how to setup this specific example.
Main project files and directories:
- README.md - documentation how to configure and deploy the example project
- mambu-function.json - function’s manifest file. Specifies target file, function name, language etc.
- package.json - typescript project settings and depencies
- src/* - directory containing all function typescript source files
- test/* - directory containing function unit tests
- src/function.ts - typescript file with the main method which will be invoked by Mambu
After building the project, all function’s files and dependencies will be bundled to dist/bundle.js file. You should never modify this file directly since all the changes will be overwritten during next build.
For more details how to modify this project to suit your business needs, please check Development guidelines section below.
Building and deploying event-driven functions
Event Driven Function can be built and deployed the same way as any other Mambu Function. Please follow the general guide here.
Subscriptions
Similar to Streaming APIs, a Subscription is required for a function to start receiving the events. Subscription is effectively a mapping between a function and an event.
As soon as Subscription is created, Mambu application will start invoking your function when the target event happens and the conditions in the template are met. Each time your function is invoked, it will receive a batch of the events, rather than a single event. Batching behavior can be controlled, see Create Subscriptions and Update Subscriptions.
Subscription is not linked to a specific notification template. When Subscription is active, the function will be receiving one event for each template linked to the same event type. The best practice is to only have a single template per event type.
Create Subscription
To create the Subscription for Mambu Functions, run the command:
mambu functions create-subscription --functionName=your-function --subscriptionName=subscription-name --event=events-name
Example | Description | Required |
---|---|---|
mambu functions create-subscription | This part of the command is always required. | YES |
-n or --functionName | The name of the Mambu Function, which you’ve specified when creating the function.By default reads function name from the mambu-functions.json manifest file in the current directory or in --functionDirectory | NO |
-d or --functionDirectory | Directory where to look for mambu-functions.json manifest file in order to resolve function name. This parameter is only required if --functionName is not specified and manifest file is not in the current directory.Specifying both --functionName and --functionDirectory will result in error. | NO |
-s or --subscriptionName | Arbitrary Subscription name. The name will later be needed to manage the Subscription. | NO |
--event | Target event name. Should match the event which you’ve selected when creating streaming notification template in the previous step. List of available events: Event Triggers for Notifications - Notifications E.g. SAVINGS_WITHDRAWAL | YES |
--batchSize | Maximum number of events sent to the function during a single invocation. It must be an integer from 1 to 10,000, the default value is 500 and the batch payload size cannot exceed 6MB. | NO |
--batchWindow | Maximum number of seconds the system will wait for events until invoking the function. The function is invoked as soon as batchWindow seconds is lapsed since the last invocation or if there are at least batch size number of events in the topic, whichever comes first. Defaults to 0 - i.e. no wait, function is invoked as soon as the first event is received in the topic. It must be an integer from 0 to 300 and the batch payload size cannot exceed 6MB. | NO |
It might take up a few seconds for Subscription to be created.
Currently you can only create one Subscription per function.
One Subscription can only subscribe your function to one event type.
Get Subscription details and status
To check the configuration and the status of the Subscription, run the command:
mambu functions get-subscription --functionName your-function --subscriptionName subscription-name
Example | Description | Required |
---|---|---|
mambu functions get-subscription | This part of the command is always required. | YES |
-n or --functionName | The name of the Mambu Function, which you’ve specified when creating the function | YES |
-s or --subscriptionName | The name of the Subscription, which you’ve specified when creating the Subscription | YES |
List Subscriptions
To see the Subscription(s) that you have already created for the function, run the command:
mambu functions list-subscriptions --functionName your-function
Example | Description | Required |
---|---|---|
mambu functions list-subscriptions | This part of the command is always required. | YES |
-n or --functionName | The name of the Mambu Function, which you’ve specified when creating the function | YES |
Update Subscription
To update a Subscription that you have already created to Mambu Functions, run the command:
mambu functions update-subscription --functionName your-function --subscriptionName subscription-name --batchSize <value> --batchWindow <value>
Example | Description | Required |
---|---|---|
mambu functions update-subscription | This part of the command is always required. | YES |
-n or --functionName | The name of the Mambu Function, which you’ve specified when creating the function | YES |
-s or --subscriptionName | The name of the Subscription, which you’ve specified when creating the Subscription | YES |
--batchSize | Maximum number of events sent to the function during a single invocation. It must be an integer from 1 to 10,000 and the batch payload size cannot exceed 6MB. | YES |
--batchWindow | Maximum number of seconds the system will wait for events until invoking the function. The function is invoked as soon as batchWindow seconds is lapsed since the last invocation or if there are at least batch size number of events in the topic, whichever comes first. It must be an integer from 0 to 300 and the batch payload size cannot exceed 6MB. | YES |
You can not change Subscription’s event type (topic). In order to subscribe function to a different event, delete the existing Subscription and create a new one.
Delete Subscription
To delete a Subscription that you have already deployed to Mambu Functions, run the command:
mambu functions delete-subscription --functionName your-function --subscriptionName subscription-name
Example | Description | Required |
---|---|---|
mambu functions delete-subscription | This part of the command is always required. | YES |
-n or --functionName | The name of the Mambu Function, which you’ve specified when creating the function | YES |
-s or --subscriptionName | The name of the Subscription, which you’ve specified when creating the Subscription | YES |
-y or --yes | Skip a confirmation prompt and delete function immediately (we only recommend to use this option if using Mambu cli from automation scripts) | NO |
After subscription is deleted, there is still a limited amount of time when you can recreate the subscription with the same name and it will pick up events starting from the point when the previous subscription was stopped/deleted.
Disable Subscription
To temporarily stop a Subscription, run the command:
mambu functions disable-subscription --functionName your-function --subscriptionName subscription-name
Example | Description | Required |
---|---|---|
mambu functions disable-subscription | This part of the command is always required. | YES |
-n or --functionName | The name of the Mambu Function, which you’ve specified when creating the function | YES |
-s or --subscriptionName | The name of the Subscription, which you’ve specified when creating the Subscription | YES |
When subscription is stopped, Mambu application will not be sending the events to your function, but all the events will still be queued and sent to the function as soon as the Subscription is reenabled.
Events will only be kept in the queue for 4 days. After that period events will be lost. Hence we do not recommend keeping Subscription disabled for long period of time.
Enable Subscription
To enable a stopped Subscription, run the command:
mambu functions enable-subscription --functionName your-function --subscriptionName subscription-name
Example | Description | Required |
---|---|---|
mambu functions enable-subscription | This part of the command is always required. | YES |
-n or --functionName | The name of the Mambu Function, which you’ve specified when creating the function | YES |
-s or --subscriptionName | The name of the Subscription, which you’ve specified when creating the Subscription | YES |
When Subscription is reenabled, Mambu application will start sending all events, including those which happened while the Subscription was disabled, assuming they did not expire.
Secrets
For most use cases your function will need to have access to secret values like API tokens or passwords. Mambu Functions capability provides a mechanism to securely store your secrets and retrieve them in your function.
In addition, you can also store environment specific parameters as secrets (e.g. Mambu API url). That way you won’t need to change your code at all when deploying to different environments (sandbox, production).
Secrets you create are not linked to a specific function and can be reused in multiple functions.
- Never hardcode secrets or personally identifiable information (PII) data in your source code - use secrets management functionality instead.
- Note that there is a separate set of Mambu permissions which need to be enabled for your user to be able to manage secrets. See Permissions page for more details.
- You can create up to 50 secrets per tenant. Please reach out to Mambu support if you have a use case which requires increasing this (or other) limits.
Create Secret
To create a Secrets, run the command:
mambu functions create-secret --name secret-name --value secret-value
Example | Description | Required |
---|---|---|
mambu functions create-secret | This part of the command is always required. | YES |
--name | Secret name. You will need to use this name in order to retrieve the value in your function | YES |
--value | Secret value. The maximum size for a secret value is 64KB, equivalent to 65,536 bytes | YES |
If your functions require many secrets which are always used and rotated together, you can use a single secret entry and store all required secret values in a json string.
List Secrets
To see the Secrets that you have already created, run the command:
mambu functions list-secrets
Example | Description | Required |
---|---|---|
mambu functions list-secrets | This part of the command is always required. | YES |
The command will only return secret names and some additional metadata, but not the secret values. For security reasons, it’s not possible to retrieve secret values via CLI or API. Secret values can only be retrieved from inside your function.
For better security and to follow least privilege principal, avoid using List Secret API from within the function.
Update Secret
To update a Secret that you have already created, run the command:
mambu functions update-secret --name secret-name --value secret-value
Example | Description | Required |
---|---|---|
mambu functions update-secret | This part of the command is always required. | YES |
--name | Secret name. | YES |
--value | Secret value. | YES |
Previous value will be overwritten.
Delete Secret
To delete a Secrets that you have already created, run the command:
mambu functions delete-secret --name secret-name
Example | Description | Required |
---|---|---|
mambu functions delete-secret | This part of the command is always required. | YES |
--name | Secret name. | YES |
Removal of a secret may cause Denial Of Service for any Mambu Function which uses it. This operation will not verify if there are such usages, so please verify if none of your Mambu Functions use it before deleting the secret (calls to context.getSecret() will start throwing an exception).
For a few minutes after deleting a secret, you won’t be able to create another secret with the same name.
Retrieving Secret in your function
In order to retrieve a secret in your function, a
context.getSecret()
function can be used. context is a second parameter of you handler function. E.g.
export default async function handle(events: StreamingEvent[], context: Context): Promise<void> {
const secretValue = (await context.getSecret('secret-name')).value
}
context.getSecret() returns a promise with a Secret object. Secret contains two fields:
- name: string - secret name
- value: string - secret value
context.getSecret() is asynchronous and returns a Promise. In the example above await is used to retrieve Promise result.
Secrets you retrieve will be cached for a period of 5 minutes for optimal performance. When updating internal Mambu API keys we recommend to create a new key before the old one expires as well as to not delete the old one for a period of 5 minutes after updating the secret value. This ensures each function has a chance to pick up the new value.
Retries and Error handling
Event Driven Functions come with a built in retry mechanism.
When your event driven function starts throwing an exception, the following error handling strategy is applied:
- The whole batch of events will be retried multiple times. A random delay will be added between retries.
- If error rate remains high for a longer period of time, the Subscription of the function will be automatically stopped.
- An outbound Salesforce case will be created to notify you about a stopped Subscription. Mambu champions will be added to the case as main contacts.
After Subscription is stopped, you need to identify the underlying issue, resolve it and reenable the Subscription using enable-subscription cli command. In order to identify the issue, please check function logs. More details about logging can be found in Retrieving Function logs section.
Note that you have a limited amount of time to resolve the issue and restart Subscription before events start to expire. See Disable Subscription for more details.
Events consumed by Event Driven Functions are only available for 4 days post which they will be purged. Ensure that the function successfully processes the events within this duration.