Overview
This blog post will cover the step-by-step process for setting up SAP Cloud Platform (SCP) Business Rules in the Cloud Foundry (CF) environment using SAP Business Application Studio (BAS).
In this sample scenario, I will be creating an application using BAS that will allow users to access the Business Rules service in the CF environment and let consuming applications (such as a REST client) call the Business Rules REST API to invoke the rules.
At a high-level, the following topics will be covered:
- Enable SCP Business Rules service and BAS in the SCP Cloud Foundry environment
- Create Role Collections and assign to the user
- Create a Business Rules service instance and service key
- Create a project in BAS and configure Business Rules
- Create a sample Business Rules project
- Test the service with Postman
Prerequisites:
- You are a global administrator in your SCP global account (required for subscriptions)
- You are an org and space member (required for configuring entitlements and creating service instances)
- You are a security administrator (required for role assignments/creation)
NOTE: I am using a production account in the Australia, Sydney (ap10) region.
1. Enable SCP Business Rules service and BAS in the SCP Cloud Foundry environment
Configure Entitlement for the Business Rules Service
- Navigate to the organization > Entitlements > Configure Entitlements > Add Service Plan
data:image/s3,"s3://crabby-images/1d963/1d963bbacba2ad52318a64d9691605234790fe36" alt=""
- Select Business Rules Service and select a service plan (basic) > Add and Save
data:image/s3,"s3://crabby-images/77f51/77f5158c3c9df431c8055511d6612aaf9cae2aa0" alt=""
Subscribe to Business Application Studio
- Subscriptions > SAP Business Application Studio > Subscribe
data:image/s3,"s3://crabby-images/3e9f9/3e9f901e3e8eb0b20e12a448e0af10b4e744d4fd" alt=""
data:image/s3,"s3://crabby-images/e2cdd/e2cdd6c9235ea13626b23523532a7d9d8968beed" alt=""
2. Create Role Collections and assign to the User
Assign the relevant BAS Developer Role Collection
- Security > Role Collections > Business_Application_Studio_Developer
data:image/s3,"s3://crabby-images/8aab3/8aab3b15e2070fc32d7871901cfca987adb68aec" alt=""
- Edit > Add User (enter ID based on configured IdP. eg: email if using the default SAP ID service) > Save
data:image/s3,"s3://crabby-images/3309f/3309f565dbba4cff9c3102b939baf6378cf5208d" alt=""
Assign relevant Business Rules Roles/Role Collection
We need to add roles with the following application identifier: bpmrulebroker*.
There are two roles with such application identifier: RuleRepositorySuperUser and RuleRuntimeSuperUser.
There are two ways to assign these roles to your user:
1. If your account has a subscription to the Workflow Management service, these role collections will be automatically created. Assign your user to one of these role collections (if applicable):
data:image/s3,"s3://crabby-images/cc51b/cc51b089ecfc7cd4b4e5cea89f1aa2d9d2fe2c89" alt=""
data:image/s3,"s3://crabby-images/96e9f/96e9f37dac88165e27de72ba0b152010c69884c9" alt=""
2. Else, create a custom role collection and add the required roles (RuleRepositorySuperUser and RuleRuntimeSuperUser)
data:image/s3,"s3://crabby-images/d34ce/d34ce278dbdea5251df0e4be53627854db498b2b" alt=""
data:image/s3,"s3://crabby-images/655db/655dbd280e2af6f670ee4c78baba1369c3131dfb" alt=""
3. Create a Business Rules Service Instance and Service Key
Create a Business Rules Service instance
- Go to your space > Services > Service Instances > Create Instance
Service: Business Rules
Service Plan: basic
Instance Name: <any name>, in my case: businessrules
Leave Parameters blank (step 2), and ‘Create Instance’
data:image/s3,"s3://crabby-images/dae85/dae8513429f8a53a95e504b37e6a0ab9b02596c3" alt=""
Create a service key for the created service instance
This service key will be used later to call the business rules API
- Open the created service instance > Service keys (Create) > Enter a Service Key Name > Create
data:image/s3,"s3://crabby-images/59f5f/59f5f0fd6c466e9d95270c56b6229318f1b35be0" alt=""
- Open the created service key and copy the credentials in a separate file for now. We will use these credentials when testing the Business Rules service in Step 6.
data:image/s3,"s3://crabby-images/d7c39/d7c39ac6254c0ab0cee6a7d82e54e565e503db51" alt=""
data:image/s3,"s3://crabby-images/b563b/b563b901215a5bb666098e487bed1a5f083a7881" alt=""
4. Create a project in BAS and configure Business Rules
- Go to subscriptions > Business Application Studio > Go to Application
data:image/s3,"s3://crabby-images/585ae/585ae957e9af069f1f593663256998eb5c8f7e25" alt=""
Create a new Fiori workspace
data:image/s3,"s3://crabby-images/f674c/f674cfd5debb9cb08a557a7143ca3becab838eae" alt=""
Create a project from a template
I will be using a standalone SAP Fiori Free Style Project to generate the boilerplate code for the application.
The most important configuration objects are the approuter (xs-app.json) and the mta.yaml. We will remove modules that are not required for this demo.
NOTE: This step can be done in a different way (eg: manual creation of objects from a basic MTA project template).
- In your empty workspace > Create new project from a template
data:image/s3,"s3://crabby-images/dc703/dc703fac32ca7fdba826882135a14b4b58dfd7e7" alt=""
- Select SAP Fiori Freestyle Project
Target Environment: Cloud Foundry
Template: SAPUI5 Application
Project Name: <any>, rulesmanager in my case
HTML5 application runtime: Standalone Approuter
HTML5 module name: <any>
Do you want to add authentication: Yes
Enter a namespace: <any valid namespace>
Enable Karma Test: No
View Name: <any>
Add data service: No
data:image/s3,"s3://crabby-images/0b1a7/0b1a79588876b97db95156990f4ff3635b5aef88" alt=""
Configure the Business Rules service in the application
- After the project is created, open the mta.yaml file.
data:image/s3,"s3://crabby-images/b1dd3/b1dd3c285c3ac3282dd852dac84381cd42335ae7" alt=""
- Remove unrequired modules and resources (highlighted in yellow). You can also delete the generated HTML5 folder in the project
data:image/s3,"s3://crabby-images/c108b/c108b80e7a82c6ff3eb1e0c4e67461bad3e0ec0a" alt=""
- Add the created Business Rules Service instance (businessrules, Step 3) as a required resource
My mta.yaml file:
_schema-version: "3.2"
ID: rulesmanager
version: 0.0.1
modules:
- name: rulesmanager-approuter
type: approuter.nodejs
path: rulesmanager-approuter
requires:
- name: rulesmanager_html_repo_runtime
- name: uaa_rulesmanager
- name: businessrules
parameters:
disk-quota: 256M
memory: 256M
resources:
- name: rulesmanager_html_repo_runtime
type: org.cloudfoundry.managed-service
parameters:
service: html5-apps-repo
service-plan: app-runtime
- name: uaa_rulesmanager
type: com.sap.xs.uaa
parameters:
path: ./xs-security.json
service: xsuaa
service-name: rulesmanager-xsuaa-service
service-plan: application
- name: businessrules
type: org.cloudfoundry.existing-service
build-parameters:
before-all:
- builder: custom
commands:
- npm install
- Enter this configuration to the xs-app.json, of the approuter.
data:image/s3,"s3://crabby-images/f4719/f4719e8698867157fddef6b5f72741f266ceba19" alt=""
{
"welcomeFile": "comsapbpmrule.ruleeditor/index.html",
"authenticationMethod": "route",
"routes": [
]
}
Build and Deploy the Application
- Right click on the mta.yaml file > Build MTA
data:image/s3,"s3://crabby-images/f9720/f9720e4d7c445adbd230d1305141d4727ae124e1" alt=""
- Set the correct target CF space. To set the the correct space, run cf login in the BAS terminal or use the highlighted shortcut below.
data:image/s3,"s3://crabby-images/0e6af/0e6af4c5f7031d127fe030fce9ac00e9467cfb2c" alt=""
- Once the build is complete and the correct target has been set, open the mta_archives folder and deploy the generated MTAR archive to the CF space.
data:image/s3,"s3://crabby-images/8ec66/8ec6677a3646284a126752bb1d606f7726d10198" alt=""
After deployment, check Applications in the space and open the newly created application.
data:image/s3,"s3://crabby-images/861f4/861f40e2a9488967c274f0c8ca1e637d419064dd" alt=""
You should be able to see the Business Rules landing page.
data:image/s3,"s3://crabby-images/950e9/950e9791615c3bb09ea2c1581081147f8bdd143b" alt=""
5. Create a sample Business Rules project
Next, we will create sample Business Rules project. This is not the focus of the blog so I will just provide a summary of the steps required and some screenshots for reference.
The service we will be creating will read a User’s organization and return the Approver details based on the decision table.
Procedure:
- Create a project
- Create data objects (ie. define input/output structure)
- Create a rules service (which reference the data objects)
- Create rules/decision tables
- Create rulesets (and assign rules)
Create data objects (ie. define input/output structure)
data:image/s3,"s3://crabby-images/2c252/2c2528a8fd2815a51b5ac5792c81911e04e327c1" alt=""
data:image/s3,"s3://crabby-images/9fd7c/9fd7c264fd42f32c8a2462d3259839b5b43bf682" alt=""
data:image/s3,"s3://crabby-images/40bb9/40bb99c65cdf4a9b7f1daa5769d37d84c6e179c8" alt=""
NOTE: after creation each object must be Validated and Activated (ie: Status = Active).
Create a rules service (which assign the data objects as Input or Result)
data:image/s3,"s3://crabby-images/25b5f/25b5f714121f951e8ad3264be684fe7cea2e5401" alt=""
Create rules/decision tables
eg: if organization of the User is C then the approver group is SCPGroupC and the approver name is ApproverC
data:image/s3,"s3://crabby-images/884fe/884fe7986999fa142df56200c3a3cd915e58caf7" alt=""
data:image/s3,"s3://crabby-images/149b8/149b8cc0214aa0ae25f44106212fd1603ef7dd22" alt=""
Create rulesets (and assign rules and rule service)
data:image/s3,"s3://crabby-images/165a6/165a6031c1c44dc53d64859b0becc50f0777d78d" alt=""
After creating and activating all the entities, Activate the whole project.
data:image/s3,"s3://crabby-images/73e54/73e5450f00e5a72f242a4eef20695614963ab5f3" alt=""
6. Test the service with Postman
Once the Business Rules project is activated, we can test the rules service using a REST client such as Postman.
To do this, we will need the service key credentials which we created in Step 3.
NOTE: any value enclosed in <> should be taken in the service key credentials.
Operation: POST
URL: <rule_runtime_url>/rules-service/rest/v2/workingset-rule-services
Authorization
Type: OAuth 2.0
Token Name: any
Grant Type: Client Credentials
Access Token URL: <url>/oauth/token
Client ID: <clientid>
Client Secret: <clientsecret>
Client Authentication: Send as Basic Auth header
Get a new Access Token and use it
data:image/s3,"s3://crabby-images/37f9c/37f9cd54be0c10ceeecf559f04f681ddae89841b" alt=""
data:image/s3,"s3://crabby-images/75cf7/75cf7c315a781124711f38dd188c7da6bfaed5e7" alt=""
Body
data:image/s3,"s3://crabby-images/e7d15/e7d15a3282267aed82f1dde5c81b62c30ba62e08" alt=""
{
"RuleServiceId": "5641e858cf2341e6b380849d47aed340",
"Vocabulary": [
{
"User": {
"organization" : "C"
}
}
]
}
where
- “User” and “organization” is the Input structure and attribute respectively.
- RuleServiceId: ID of the rule service. (Add the ID to the visible columns as this is not visible by default)
data:image/s3,"s3://crabby-images/ca8cc/ca8ccb02f64e5290c429ff9890a32aeb5511b1d1" alt=""
Result:
As you can see, when we pass a User with ‘C’ as organization, we get the expected Approver per the decision table.
Hooray!
data:image/s3,"s3://crabby-images/cd3a7/cd3a7a6099d461f70f2add2c559032a782c4bc75" alt=""