Skip to content

Build docker image with pre-populated Engage Defaults and can be customised with customer-specific settings and used by Provisioner and this is part of Digital Engage product (Engagements Capability).

License

Notifications You must be signed in to change notification settings

Backbase/engagements-data

Repository files navigation

Repository Overview

  • This project is a collection with out-of-the box engagements data
  • This project helps to build docker image with pre-populated Engagements data (your own set of customized Engage Defaults) and can be customized with customer-specific settings
  • This project uses technologies broadly used in Backbase, like Docker

Repository Description

This repository contains collections with out-of-the box engagements data. These collections contain the following data:

  • Events with general notifications
  • Templates (general notifications and custom engagements)
  • Repositories (for AWS S3 and Azure Blob Storage)

Project Structure

This repository has the following structure:

β”œβ”€β”€ .github                       
β”‚   β”œβ”€β”€ actions                                                 # All GitHub Actions files
β”‚   β”œβ”€β”€ ISSUE_TEMPLATE                                          # Templates for 'major','minor','patch' releases
β”‚   └── workflows                                               # GitHub Actions workflows for CI
└── collections                   
    β”œβ”€β”€ retail                                                  # Retail collection
    β”‚   β”œβ”€β”€ general-notifications                               # General notifications related collection
    β”‚   β”‚   β”œβ”€β”€ event-general-notifications     
    β”‚   β”‚   β”‚   β”œβ”€β”€ {event-general-notifications-name}              
    β”‚   β”‚   β”‚   β”‚   β”œβ”€β”€ {general-notification-name}             # The folder to store channel specific data for general notifications   
    β”‚   β”‚   β”‚   β”‚   β”‚   β”œβ”€β”€ in-app-notification                         
    β”‚   β”‚   β”‚   β”‚   β”‚   β”‚   β”œβ”€β”€ {locale}                        # The folder to store locale-specific engagement templates
    β”‚   β”‚   β”‚   β”‚   β”‚   β”‚   β”‚   └── engagement-template.json    # The engagement template that contains default messages with the Handlebars expressions
    β”‚   β”‚   β”‚   β”‚   β”‚   β”‚   └── in-app_channel-settings.json    # The channel settings for in-app notification channels per locale
    β”‚   β”‚   β”‚   β”‚   β”‚   └── push
    β”‚   β”‚   β”‚   β”‚   β”‚       β”œβ”€β”€ {locale} 
    β”‚   β”‚   β”‚   β”‚   β”‚       β”‚   └── engagement-template.json 
    β”‚   β”‚   β”‚   β”‚   β”‚       └── in-app_channel-settings.json     
    β”‚   β”‚   β”‚   β”‚   └── event-general-notifications.json        # The event with one or more general-notification definitions
    β”‚   β”‚   β”‚   └── ... 
    β”‚   β”‚   β”œβ”€β”€ templates                                       # The folder to store templates
    β”‚   β”‚   β”‚   β”œβ”€β”€ {template-name}
    β”‚   β”‚   β”‚   β”‚   β”œβ”€β”€ content-schema.json                     # A structure of an engagement template based on a given template
    β”‚   β”‚   β”‚   β”‚   └── template.json                           # A template definition
    β”‚   β”‚   β”‚   └── ...
    β”‚   β”‚   └── placeholders                                    # The folder to store placeholder group
    β”‚   β”‚       β”œβ”€β”€ {placeholder-group-name}
    β”‚   β”‚       β”‚   └── placeholders.json                       # A placeholder group configuration
    β”‚   β”‚       └── ...
    β”‚   β”œβ”€β”€ custom-engagements                                  # Custom engagements related collection
    β”‚   β”‚    └── templates                                      # The folder to store templates
    β”‚   β”‚        β”œβ”€β”€ {template-name}
    β”‚   β”‚        β”‚   β”œβ”€β”€ content-schema.json                    # A structure of an engagement template based on a given template (Specifies the path to image as {{contextRoot}}/assets/apple-pay.png)
    β”‚   β”‚        β”‚   β”œβ”€β”€ template.json                          # A template definition
    β”‚   β”‚        β”‚   └── assets                                 # Folder that contains all assets (index.html, image.png, thumbnail.png)
    β”‚   β”‚        β”‚       β”œβ”€β”€ index.html                         # HTML file with embedded styling, expressions and templating language placeholders that should match the layoutPath property specified in the content schema
    β”‚   β”‚        β”‚       β”œβ”€β”€ image.png                          # Images that are used within the template
    β”‚   β”‚        β”‚       └── thumbnail.png                      # A representation of the rendered version of your template (recommended size: 164 x 217)
    β”‚   β”‚        └── ...
    β”‚   β”œβ”€β”€ engagement-types                                    # The folder to store engagement types definition
    β”‚   β”‚    └── engagement-types                               
    β”‚   β”‚        └── engagement-types.json
    β”‚   └── repositories                                        # The folder with a repository definition.
    β”‚        β”œβ”€β”€ {repositories-type}                            #  Contains a repository that has a cloud storage (AWS S3 or Azure) as the underlying storage
    β”‚        β”‚    β”œβ”€β”€ {repository-name}
    β”‚        β”‚    β”‚   β”œβ”€β”€ format.txt                            # Applicable package format
    β”‚        β”‚    β”‚   β”œβ”€β”€ package.txt                           # List of items to be imported into a repository
    β”‚        β”‚    β”‚   └── repository.xml                        # A repository definitions
    β”‚        β”‚    └── ...
    β”‚        └── ...
    └── business                                                # Business collection
        β”œβ”€β”€ general-notifications                               # General notifications related collection
        β”‚   β”œβ”€β”€ event-general-notifications     
        β”‚   β”‚   β”œβ”€β”€ {event-general-notifications-name}              
        β”‚   β”‚   β”‚   β”œβ”€β”€ {general-notification-name}             # The folder to store channel specific data for general notifications   
        β”‚   β”‚   β”‚   β”‚   β”œβ”€β”€ in-app-notification                         
        β”‚   β”‚   β”‚   β”‚   β”‚   β”œβ”€β”€ {locale}                        # The folder to store locale-specific engagement templates
        β”‚   β”‚   β”‚   β”‚   β”‚   β”‚   └── engagement-template.json    # The engagement template that contains default messages with the Handlebars expressions
        β”‚   β”‚   β”‚   β”‚   β”‚   └── in-app_channel-settings.json    # The channel settings for in-app notification channels per locale
        β”‚   β”‚   β”‚   β”‚   └── push
        β”‚   β”‚   β”‚   β”‚       β”œβ”€β”€ {locale} 
        β”‚   β”‚   β”‚   β”‚       β”‚   └── engagement-template.json 
        β”‚   β”‚   β”‚   β”‚       └── in-app_channel-settings.json     
        β”‚   β”‚   β”‚   └── event-general-notifications.json        # The event with one or more general-notification definitions
        β”‚   β”‚   └── ... 
        β”‚   β”œβ”€β”€ templates                                       # The folder to store templates
        β”‚   β”‚   β”œβ”€β”€ {template-name}
        β”‚   β”‚   β”‚   β”œβ”€β”€ content-schema.json                     # A structure of an engagement template based on a given template
        β”‚   β”‚   β”‚   └── template.json                           # A template definition
        β”‚   β”‚   └── ...
        β”‚   └── placeholders                                    # The folder to store placeholder group
        β”‚       β”œβ”€β”€ {placeholder-group-name}
        β”‚       β”‚   └── placeholders.json                       # A placeholder group configuration
        β”‚       └── ...
        └── repositories                                        # The folder with a repository definition.
             β”œβ”€β”€ {repositories-type}                            #  Contains a repository that has a cloud storage (AWS S3 or Azure) as the underlying storage
             β”‚    β”œβ”€β”€ {repository-name}
             β”‚    β”‚   β”œβ”€β”€ format.txt                            # Applicable package format
             β”‚    β”‚   β”œβ”€β”€ package.txt                           # List of items to be imported into a repository
             β”‚    β”‚   └── repository.xml                        # A repository definitions
             β”‚    └── ...
             └── ...
    └── oneruntime                                              # Oeruntime collection
        └── general-notifications                               # General notifications related collection
            └── event-general-notifications     
                β”œβ”€β”€ {event-general-notifications-name}              
                β”‚   β”œβ”€β”€ {general-notification-name}             # The folder to store channel specific data for general notifications.  
                β”‚   β”‚   β”œβ”€β”€ in-app-notification                         
                β”‚   β”‚   β”‚   β”œβ”€β”€ {locale}                        # The folder to store locale-specific engagement templates
                β”‚   β”‚   β”‚   β”‚   └── engagement-template.json    # The engagement template that contains default messages with the Handlebars expressions
                β”‚   β”‚   β”‚   └── in-app_channel-settings.json    # The channel settings for in-app notification channels per locale
                β”‚   β”‚   └── push
                β”‚   β”‚       β”œβ”€β”€ {locale} 
                β”‚   β”‚       β”‚   └── engagement-template.json 
                β”‚   β”‚       └── in-app_channel-settings.json     
                β”‚   └── event-general-notifications.json        # The event with one or more general-notification definitions
                └── ... 

Repository definition configuration

For customers that only use Headless General Notification and will not migrate to Premium license Backbase recommends using private instead of protected repository definition for engagement-template-general-notification repository.

Example:

<ns2:repositories
  xmlns:ns2="http://www.backbase.com/content/model/1.0">
  <ns2:repository>
    <ns2:repositoryId>engagement-template-notification</ns2:repositoryId>
    <ns2:name>Engagement Template General Notification Repository</ns2:name>
    <ns2:description>Repository to store engagement templates for engagements where engagement is general notification</ns2:description>
    <ns2:isPrivate>true</ns2:isPrivate>
    <ns2:implementation>s3</ns2:implementation>
    <ns2:c3RepositoryId>engagement-template-notification</ns2:c3RepositoryId>
    <ns2:versioningEnabled>false</ns2:versioningEnabled>
  </ns2:repository>
</ns2:repositories>

Event General Notifications

A general notification template defines the structure of a general notification sent to bank customers, including its name, description, title, engagement type, channel, and corresponding placeholder groups.

{
  "eventClassName": "com.backbase.dbs.messages.pandp.event.spec.v4.MessageReceivedEvent",
  "id": "message-received",
  "eventBusinessName": "Message Received",
  "recipientType": "internal",
  "extractor": "#this['recipient']",
  "generalNotifications": [
    ...
  ]
}

More information on how to create a custom Event General Notification.

UI Notification Preferences

There are two types of recipients of Genera Notifications Notifications. internal - This recipient type requires the event to include the user’s internalId to be present in the trigger event. subscription - This type of GN requires the user to opt in via a notification preference.

If your GN is of type subscription you need to build a UI (Android, IOS, Web) that uses the pre-existing backend API, allowing users to opt-in to your GN.

More information on how to build notification preferences UI for OOTB general notification.


Project dependencies

  • Engagements Capability
  • Provisioning Capability
  • Document Storage Capability
  • Provisioner

SDLC

Create Engagements data package

To create new or modify existing General Notification you'll have to modify JSON files (event definition, templates, and content-schema, etc). Once changes to those files are pushed to the version control system, pipeline would automatically build provisioning packages and package them to the docker image:

Process of Engagements data creation! Once projects clone the repo, the docker image should be built with the pipeline described above. Docker image will contain out-of-the-box Engagements data package, that can be used from day 1.

More information on how to create custom General notifications.

Deploy Engagements data package

Engagements data and Provisioner images should be deployed to the environment. These 2 containers have shared volume. Provisioner would scan folders defined in its configuration and send provisioning packages found in those folders to Provisioning service. Provisioning service would distribute it to corresponding destinations (Engagement, Content Enricher)

More information on how to provision Engagements data.


How to build

Building Engagements data collection (your own set of customized Engage Defaults) is easy, just run the following maven command:

mvn clean install

Generated collections will be located under target/assembly folder. In order to create docker image locally use docker profile:

mvn clean install -Pdocker

NOTE: applicable only for UNIX-based machines.


Community Documentation


Release Workflow

  1. Clone the Engagements Data project from the GitHub repository.
  2. Create a feature/* branch based on the master branch.
  3. Create new or edit existing General Notifications or Message Center template definitions by copying and modifying the existing JSON and HTML files in your branch, for example, event definition, templates, content schema.

    Backbase recommends using the feature/ and hotfix/ prefixes in branch names during development. This will trigger the corresponding out-of-the-box workflows.

  4. Create a pull request based on your branch.

Every time the pipeline is run, the Docker image is built but not pushed into the Docker container registry. To push to Elastic Container Registry, credentials must be configured in pom.xml and .github/workflows.

Property name Example Description
project.version β€’ 0.1.0 is used in the master branch This property may vary depending on the branch you are working on. The deployment pipeline automatically changes the version property depending on the branch.
backbase-bom.version 2022.11 This is defined in the parent pom.xml file and matches the released Backbase version.

To build the Docker image, take one of the following actions:

  1. Merge your pull request to the master branch.

The format of the project.version property is X.Y.Z.

  1. The Engage Defaults collection is packaged and the Docker image is created, for example engagements-data-retail:2022.11-0.10.0 and engagements-data-sme:2022.11-0.10.0.

This is not pushed to the Docker container registry, unless you configure credentials in pom.xml and .github/workflows.

  1. After the PR is merged to the master branch, project.version is automatically increased based on the type of the source branch:
  • Minor release: a pull request is raised from the feature/* branch.
  • Hotfix release: a pull request is raised from the hofitx/* branch.

The hotfix/* branch is only available for the latest version on the master branch.


Contributions

Please create a feature branch from develop and a PR with your contributions. Commit messages should follow semantic commit messages

About

Build docker image with pre-populated Engage Defaults and can be customised with customer-specific settings and used by Provisioner and this is part of Digital Engage product (Engagements Capability).

Topics

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published