ShopDev LMS- Multi Tenant
Title of Document | ShopDev LMS- Multi Tenant |
---|---|
Document status | status:DRAFT |
Document owner | @Muhammad Arslan Dogar |
Designer |
|
Tech lead |
|
Technical writers |
|
QA |
|
REVISION HISTORY | |||
DATE | VERSION | DESCRIPTION | AUTHOR |
Document Overview
The Product Requirements Document contains requirements for the Updated ShopDev Loyalty Management System. The document highlights:
i) LMS Current Capabilities
ii) New Features in LMS
LMS Current Capabilities Overview
The Loyalty Management System can be used to create an accrual and redemption module across programs, clubs and various partners. Modules that make up the LMS, include the Backend User, Program, Club, Partner, Point, Tier, Campaign and Members module. Infinite combinations of earn and burn rules can be created via the Visual Rule Builder.
API integrations allows user enrollment, balance enquiry, accrual and redemption in the system. Batch file processing via the Middleware’s ETL logic extracts files from certain systems and upload them onto the LMS.
The EEG Middleware will be integrated into the POS Operating System to enroll members, inquire about point balance and allow for accrual and redemption. In addition to this, the Receipt Interceptor Module will give point breakdowns on receipts in real time.
CONTRAINTS
The current LMS has following capabilities
Unable to add multiple Programs (i.e. Multi tenancy )
SOAP APIs only fulfills single program specific needs.
Current Hierarchy
The full PRD of Current LMS can be reviewed here
LMS Update Features
This section contains the description and requirement of new features added in LMS.
Objective
The update will make system capable of handling multiple instance on the program level. The user will be obligated to define the program and club level. The configuration will include Earn, Burn, Discount and Enroll rules. The user will also configure the tiers for the program. Along with this, API structure will also change. Currently, we are using SOAP API. In the updated version of LMS REST API will be used. The Front-end of the LMS will be totally revamped in this update. The current front-end is developed in Angular framework. The updated front-end will be developed in React framework. With new update LMS will be able to perform two new operations on Rewards and Offers Management
Requirements
Requirement | Requirement Description |
---|---|
Initial Setup | |
Set up Kubernetes Cluster | Clusters form the foundation of Google Kubernetes Engine, an open source platform from Google for running containers across clusters of servers. This will be the initial step of setting up the architecture |
Setup Istio Ingress Mesh | An istio service mesh needs to be set up to reduce the complexity of managing microservice deployments to providing a uniform way to secure, connect and monitor microservices |
Set up data schema and CloudSQL Database | This will be a fully managed database service allowing for easier administration of PostgreSQL databases in the cloud. The applications must be able to run from anywhere. |
Establish communication between Apache Ignite and CloudSQL | The cache layer and the Cloud DB must be able to read and write to one another and be in sync for better application performance |
Set up code repository | All code must be committed to the LMS project set up in Github |
Configure Staging Environment and deploy web application | The LMS admin web application will be deployed to a staging environment. - Functionality of the LMS web application is defined below |
Setup EEG Middleware Application | This middleware will sit on top of the EEG POS systems. - Functionality of the middleware is defined below |
React Front-End | |
UI/UX | A new UI/UX to be designed in Adobe Xd. The Design will be in accordance to the React UI kit. The kit will include along with old screens:
|
React Front-End | The UI/UX designed will be then converted into a working Front-End using React as the platform |
Multi-Tenant Capability (Compulsory Actions) | |
Create a Program | A user will set up an offer or program through the LMS Web application. The user can:
|
Add earn and burn rules for a program | A user can add earn and burn rules for a particular program:
|
Add tier definitions to a program | A user can add tier rules to a different program.
|
Add a club to a program | It is compulsory for user to create at least one club under a program to use the LMS.If the user has created clubs, these can be assigned to a particular program/offer by pressing the Add club button on the UI.
|
Login and Registration for Program Level Users | |
User Account Creation | LMS-admin user will have the ability to provision a Program account.
|
Email/Verification flow for account creation | On successful account creation, an email with a link to create password is triggered to the given user email address.
|
Set Password in Verification flow | The user can set a password for their new account on this page.
|
Forgot/Reset Password | The user can trigger the reset Password page flow in case the password is forgotten/needs to be reset.
|
Program and Entity Management | |
Create a Program (compulsory) | A user will set up an offer or program through the LMS Web application. The user can:
|
Add earn and burn rules for a program (compulsory) | A user can add earn and burn rules for a particular program:
|
Add tier definitions to a program (Compulsory ) | A user can add tier rules to a different program.
|
Add points and expiration rules to a program | A user can define the validity of points earned through various offers:
|
Add target member segment | If the user has created member segments, these can be assigned to a particular program/offer. Only assigned member segments can participate in the offer. - The user can also initiate the create member segment workflow from this screen (explained in more detail below)
|
Add a club to a program (Compulsory) | It is compulsory for user to create at least one club under a program to use the LMS.If the user has created clubs, these can be assigned to a particular program/offer by pressing the Add club button on the UI.
|
Add partners to a program | If the user has created partners, these can be assigned to a particular program.
|
Add club/partner specific rules for the program | The user can use pre-created partner and club rule set to apply to partners and clubs being added into the program. The user can also create partner and club specific rules during this workflow. These can include:
The pre-saved rules of the program/offer (base rules) can also be replicated across all clubs and partners in the program/offer. This is automatically done if no specific club and partner rules are assigned |
Create a corporate program | A user can create a corporate enrollment form through the corporate program module of the Web Application. The user can define:
|
Program Listing Module (Listing and Details Page) | This module will render a list of all programs existing within the LMS. At a high level, the data points will be:
Clicking on the program line item will render additional details including:
|
Create a club | A user can create a club. This can be done when creating a program/offer or separately through the Club Management module. A user can: - Create title of club
|
Partner Management | |
Create a partner | A user can create a Partner. This can be done when creating a program/offer or separately through the Partner Management module. A user can:
|
Partner Segmentation | The user can group various partners into a segment and associate one rule set across all partners within the segment. Segments can assigned to programs/offers or clubs |
Billing for Partners | The LMS system will produce a transactional report per partner. This report will include:
|
Points Management | |
Creating Points Rule Set | The user can create various points rule sets via the Points Management module of the web application. These rules will include defining the type of point (base, bonus and promotional) with its associated rule set: - Point earning rules (spend ratio, time of transaction,etc.)
The point rule set can be created specifically as part of this module or during the process of creating programs/offers, clubs or partners for rules specific to the entity |
Assigning Point rule sets | A user can assign a published point rule set to any entity (program, club or partner) |
Location Specific Points | When a location specific rule has been set on points against (for example) a partner, the LMS system will manage the points in a way where it will give a break down of how earned points can be used. It will show:
|
Point Expiry | Reward points earned will have a different expiry based on the transaction date. |
Periodical Warning for Points expiry | A user can set multiple warning messages at multiple time periods from expiry. A cron will be programmed which will trigger these messages to the member based on the time periods defined |
Breakage Reporting | This report will render the sum and value of all earned points that were not redeemed before expiration. It will be available as a UI utility in the Points Management module with applicable date/time filters |
Points Listing Page | A user can access this page to see every transaction where points were earned/redeemed
|
Configure goodwill points | A user will have the ability to configure goodwill points which will be automatically awarded to members on the basis of events. The user can define the event |
| (birthday, referral) and define the points awarded with each event |
Retro-claim | Member sends invoice and amount details via the mobile application, website or through the Contact Center.
|
Manual Extension of points expiry | An LMS user can manually extend the expiration date of any member points via a utility on the member details page (more details included in member management) |
Points transfer | An LMS user can transfer points from one member to another. When this action is carried, an email will be triggered to all involved members with a summary of the activity as well as the updated points balance and its associated expiration |
Points Redemption/Accrual |
|
Tier Management | |
Creating a Tier | A user will have the ability to create tier slabs and assign a rule set to each slab. Multiple tier slabs can exist within the LMS. To define a tier, the user will need to:
|
Creating a Tier rule set | A user can set the following rules for different tiers in a tier slab. These include:
The created tiers and their associated rule set can be applied to any entity in the LMS. Where earn/burn rules are different to the tier rule set and entity, the entity rule set will be overwritten by the tier rule or vice versa as specified by the user |
Upgrade/downgrade of member Tiers | The LMS system will automatically upgrade and downgrade members in their respective tiers based on the tier rule set configured. LMS users can also manually change the tiers of members via a drop down menu. Daily cron job checks member tier status eligibility |
Tier Listing and Reporting | A reporting module will show high level statistics on tier level. This will include: - Spend in tier
|
Automated Member Messaging for Tiers | Users can define tolerance levels and associated messages for tier upgrades and downgrades
|
Member Management | |
Enrolling a member | An LMS user can enroll a member into the system. The user will need the following:
The user can be enrolled in a club (UBE only) against a program/offer. The active rule set associated with the club is now applicable on the member. The enrollment tier can also be set against an LMS member. Once the member has been enrolled, the member loyalty number will be generated and a welcome email will be triggered to the new member. Alternatively, the system will also expose an enrollment API which connecting applications can leverage to enroll members into the LMS. |
Member Account |
|
Defining status against a member | The user can configure rule based statuses against each member. Dependent on the rules, these statuses will include:
Member is eligible for earn and burn.
"merge from account" to the "merge to account"
Blacklisted: Accounts will be blacklisted on proven fraudulent activity. Members cannot earn nor burn. Member accounts with the same name, email, mobile number, DOB, nationality cannot be never be created.
|
Capture additional member demographics data from 3rd Parties | The LMS system will expose an API making it possible to capture various member demographics using 3rd party applications. This can be in the form of a mobile app where the customer is simply inputting their preferences. |
Merge member accounts | Member accounts are merged via the Member management module on LMS. Accounts are merged on member requests or in the case of duplicate accounts. Accounts with exact data points such as email, name, DOB, nationality and phone number are considered duplicate accounts.
|
Member Segmentation | An LMS user can define various member segments based on data such as:
These segments can be saved by name and can be added to a program/offer directly for efficiency. Targeted offers can also be assigned to a particular member segment via campaigns |
Member Listing and Reporting | The member listing module will list the following data line item wise:
Clicking on a line item will open up the details page for that member which will include the following information
|
Rule Builder | |
Visual Rule Builder | The user will have the ability to create rules by using a a visual programming tool. The user will define a rule and then create an 'if' condition against it. Within the 'if' condition, the user can also define what entity the rule exists against. If no entity is defined, then a general rule will be created and will need to be applied across a particular entity. Once the 'if' condition has been specified, an action can also be set in the visual rule builder specifying what will happen when the 'if' condition is met. |
Creating Standard Rule Sets | The LMS user will have the ability to create rule sets using the visual rule builder. These rule sets can be saved and replicated across any entity within the LMS. The user can access these rule sets in the relevant module of the web application and then assign them across a created entity including program/offers, clubs and partners. |
New Blocks | The visual Rule Builder will now include New blocks to implement rule on product’s instance. Example of rules are here. |
Campaign Management | |
Creating a campaign | The user will have the ability to create a campaign on top of an existing program/offer. Based on the user's requirement, the campaign can also be applicable on a single or mix of entities within the program/offer including specific business unit, various tier or member segments. In this case, on the user's discretion, the campaign rule set will override the existing entity rule set. Billing rates for campaign points can be different than the regular accrual/redemption rates.
|
Campaign Rule Sets | A campaign will run for a specific set of time and will have a rule set associated with it. This rule set can comprise of:
The rule set can be created with the campaign or can be assigned from an existing rule set. |
Campaign Reporting | A basic reporting dashboard and report will be made available against a campaign once it has been created in the LMS. This report will contain base metrics such as
|
Rewards Management | |
Creating a Reward | The user will have the ability to create a reward on top of an existing program/offer. Based on the user's requirement, the reward can also be applicable on a single or mix of entities within the program/offer including specific business unit, various tier or member segments. In this case, on the user's discretion, the reward rule set will override the existing entity rule set. Billing rates for reward points can be different than the regular accrual/redemption rates.
|
Rewards Rule Sets | A reward will run for a specific set of time and will have a rule set associated with it. This rule set can comprise of:
The rule set can be created with the reward or can be assigned from an existing rule set. |
Reward Reporting | A basic reporting dashboard and report will be made available against a reward once it has been created in the LMS. This report will contain base metrics such as
|
Offers Management | |
Creating an Offer | The user will have the ability to create an Offer on top of an existing program/offer. Based on the user's requirement, the offer can also be applicable on a single or mix of entities within the program/offer including specific business unit, various tier or member segments. In this case, on the user's discretion, the offer rule set will override the existing entity rule set. Billing rates for offer points can be different than the regular accrual/redemption rates.
|
Rewards Rule Sets | A offer will run for a specific set of time and will have a rule set associated with it. This rule set can comprise of:
The rule set can be created with the offer or can be assigned from an existing rule set. |
Reward Reporting | A basic reporting dashboard and report will be made available against an offer once it has been created in the LMS. This report will contain base metrics such as
|
Integrations | |
Enroll API | The LMS will expose an enroll API which 3rd party applications can use to enroll members into the LMS. The API will need the member name, phone number and email and will generate a loyalty number as a response |
Enquire API | The LMS will expose an Enquire API which will need the Loyalty number to respond with the current point balance of the loyalty member |
Earn API | The LMS will expose an Earn API which will require the loyalty number as well as the eligible revenue on the transaction to convert this into earned points for the member. The service will respond with the following information: - Old balance
|
Redeem API | The LMS will expose a Redeem API which will require a loyalty number and value of transaction, an OTP and the points the loyalty member will want to redeem. If the loyalty member has sufficient points balance per members request, the API will respond with the following information
|
Batch File Processes | |
FTP Handler | An FTP handler will configured to extract batch files from certain systems. These files will include:
|
ETL Logic for Batch File Processing | Transformation logic will need to be built into the LMS to create final outputs from all input files and load them into the LMS |
Access Management | |
Roles and Permissions | The following roles will be made available in the LMS:
LMS users will only be able to see what they have been given access to. |
EEG Middleware/Receipt Interceptor | |
Middleware for Loyalty (EEG) | The middleware application will sit on the same machine as the POS system. There will be a UI which will allow for 4 options
|
Enroll via EEG Middleware | Members can enroll directly at cashier desk via the EEG middleware. The cashier simply needs to click on the enroll button, enter member details like name, phone and email and a loyalty number will be rendered on the screen on successful execution of command |
Enquire via EEG Middleware | Members can check their point balance via this middleware. The cashier will need to click the enquire button on the UI of the middleware and will need to enter the customer loyalty number they are enquiring about. On successful execution, the screen will render the updated points balance of the loyalty member as well as if any benefits are applicable on the transaction |
Earn via EEG Middleware | In this case, the cashier will need to enter the loyalty number and eligible transaction value by clicking the earn button on the UI of the middleware. On successful execution, the old balance, the points earned and the new balance will be made visible on the UI of the middleware.
Receipt Interceptor When cashier presses the print receipt button on the POS system, the middleware then intercepts the receipt and adds Accrual point breakdown (which was retrieved by the Enquiry API) onto the receipt. |
Redeem via EEG Middleware | The cashier will select the redeem option and the point balance will be shown on middleware UI after the loyalty number is entered. An OTP will also be sent to the member. Once the cashier has entered the points the member would like to redeem as well as the OTP, the middleware UI will render the new transaction value if balance is sufficient. The cashier will update the transaction value on the POS and loyalty members point balance and breakdown will be updated in the LMS for that transaction
Receipt Interceptor When cashier presses the print receipt button on the POS system, the middleware then intercepts the receipt and adds Redemption point breakdown (which was retrieved by the Enquiry API) onto the receipt. |
User stories and Permission
Role | Permission | So that |
---|---|---|
LMS Admin | Has access right to all modules in the every program instance of LMS:
| I can
|
Super Admin | Has access rights to all modules in a single program :
| I can
|
Admin | Has access rights to all modules, except User Management
| I can
|
Partners | Not supported |
|
Management | Can view metrics and KPIs:
| I can
|
Front-Line Manager | Access to EEG Middleware:
| I can
|
Member | A customer who has successfully enrolled into the loyalty program. Members can:
| I can
|
New Hierarchy
User interaction and design
UI/UX Design Here