Control webapps STORE AND OMS UI by using roles and action in manifest
How-to Guide
Author:
Fluent Commerce
Changed on:
14 Sept 2023
Key Points
- describes how to set up the user to see the “query” only page or “edit” entity page by using User Roles and UserAction in Manifest.
- The below example demonstrates where "Finance" users in "query" only mode on OMS data and "CustomerService" cancel orders and other user actions.
Steps
Create a new user Finance and assign to ROLE: FINANCE_USERS role
data:image/s3,"s3://crabby-images/0ed95/0ed959841104f4ca80c64112eeebe51ca281651f" alt="No alt provided"
Create a new user Customer Service and assigned to ROLE: CUSTOMER_SERVICE_USERS role
data:image/s3,"s3://crabby-images/84b40/84b4013e02db508cc18f381852601dbdcd9d4dbf" alt="No alt provided"
In my app reference setting (fc.mystique.manifest.oms3), include 2 fragment manifests, finance and customer service
data:image/s3,"s3://crabby-images/129ae/129ae80db269bd1c901d10c468bd2abcb1b59a22" alt="No alt provided"
In the customer service fragment manifest setting, apply CUSTOMER_SERVICE_USER into the roles:
data:image/s3,"s3://crabby-images/e1dbd/e1dbd4e1ea16b6fc2181bd2d6319e3db77943846" alt="No alt provided"
For each page that requires user action, set the action:TRUE:
data:image/s3,"s3://crabby-images/b0e26/b0e26c51b449b8f9af9adc4bb09f8d492cbe162f" alt="No alt provided"
Login in as customer service user:
data:image/s3,"s3://crabby-images/9c8c2/9c8c25e7f4ddabe4896df6ec3bc88c4d2ae2e6bb" alt="No alt provided"
The user will only see the screens with roles include CUSTOMER_SERVICE_USER:
data:image/s3,"s3://crabby-images/8b929/8b929d8f89e8629a635b562e60eec838590ba9fe" alt="No alt provided"
In the order page, the user action buttons are showing for customer service user
data:image/s3,"s3://crabby-images/49a1d/49a1dd95965e51c0a9456a3d6898d25c1b0da9c1" alt="No alt provided"
For finance manifest fragment, include the ROLES: FINANCE_USER
data:image/s3,"s3://crabby-images/ce3cc/ce3ccdaf474b48ae83d8a221ef81b30557dbb82d" alt="No alt provided"
In this fragment, ensure all action is FALSE as the finance user is read only.
data:image/s3,"s3://crabby-images/47a32/47a3209ba2947749eabd17048a8273833c924660" alt="No alt provided"
Login as finance user:
data:image/s3,"s3://crabby-images/409b3/409b3ce794f6269ae626ddfaaa41bb5afa26885f" alt="No alt provided"
Only manifest fragment with role FINANCE_USER are displayed:
data:image/s3,"s3://crabby-images/9da76/9da768cd6e0be1a2c20fd17680ce2452b37412ac" alt="No alt provided"
In the order detail screen, there are no user action buttons:
data:image/s3,"s3://crabby-images/3c621/3c6213acc2b0d17e54da7adc2008ba5e9f46c166" alt="No alt provided"
Result
By using User Roles and Manifest action:TRUE/FALSE, we can control user visibility.