Exercise 5: Provide Authorizations to Users for non-Released Authorization Objects checked by the "Create Purchase Requisition" function module
In exercise 4, you've learned to integrate a custom wrapper into a RAP BO and implement a new action to call the custom wrapper during the save sequence phase of the RAP BO. You also learn how to expose an action via the service binding. To be able to develop the custom shopping cart RAP BO and the custom wrapper, your ABAP user should have full development authorization.
In this exercise we want to test two different authorization scenarios: the case in which we want authorizations to be checked upon the creation of a purchase requisition (so that only authorized users can perform this action), and the case in which we do not want any authorization check to be performed.
In a realistic scenario, the next step would be to develop a UI for your application, deploy it to your system, and maintain all the needed objects (i.e.: Business Catalogs, Business Roles, etc). However, in this tutorial we will follow a simplified approach and we will test the various authorization scenarios via the application preview available in ADT, without the need for UI development and deployment. For this reason, we need a user which is allowed to access the application preview via ADT: we create this user in the next step.
Reminder:
Don't forget to replace all occurences of the placeholder###
with your assigned group number in the exercise steps below.
You can use the ADT function Replace All (Ctrl+F) for the purpose.
If you don't have a group number, choose a 3-digit suffix and use it for all exercises.
- How to find out the needed authorization objects for a given BAPI
- How to handle authorizations via an authorization default variant for the check authorization use case
- How to suppress all authorization checks in the disable authorization check use case
In this exercise we want to test different authorization scenarios via the application preview, and therefore we need a user with restricted access. You will now create such a user, which we will refer to as 'shopping cart user'.
🔵 Click to expand
Logon on to your SAP S/4HANA system via the backend, using your developer user credentials and create a new user (transaction SU01
) with name Z_USER_###
.
data:image/s3,"s3://crabby-images/9301e/9301eb471c7b0c9793615fedc26c0d80739b8df6" alt="Create user"
Now, you will need to create a role for this user to be able to access the ADT and get the URL of any service binding preview.
Start transaction PFCG
and create a new role as a copy of the SAP_BC_ABAP_DEVELOPER_5
role template, according to Set Up Developer Extensibility documentation. This role is needed for preview testing. Input the template role name and click on the Copy Role icon:
data:image/s3,"s3://crabby-images/9854a/9854a82a7eed54e9c5293ec86098ec5747feff6b" alt="Create developer 5 role"
We suggest to name the role ZAP_BC_ABAP_DEVELOPER_5_###
. Click on Copy all:
data:image/s3,"s3://crabby-images/60ad5/60ad55abe4e517ba1659035657a211a68e254bcb" alt="Create developer 5 role"
Open the newly created role in edit mode, navigate to the Authorizations tab and click on Change Authorization Data. Click on the Status button (1) and confirm the pop-up to give the role full authorizations (2). Then Save it (3) and click on the Generate icon to generate the authorization profile (4) (confirm the pop-up window).
Then go back, navigate to the User tab and add the Z_USER_###
(1), Save (2) and click on the User Comparison button (3) (select Full Comparison in the pop-up window):
data:image/s3,"s3://crabby-images/28235/2823561f512215127caeb019f7bf09b8b627bd4d" alt="Create developer 5 role"
This role allows the user to access ADT and get the URL of any service binding preview. However, the user still lacks access to the actual service binding (i.e: it cannot use the application preview). This will be addressed in the next step.
For demonstration purposes and to keep this exercise as modular as possible, you will now create a new service binding on which you will perform the authorizations tests.
🔵 Click to expand
For that, connect to your system via ADT and navigate to the package Z_PURCHASE_REQ_###
containing the RAP BO, right click on the Service Definition ZUI_SHOPCART_###
and select New Service Binding, input the Name ZUI_SHOPCART_WRAPPER_O4_###
and a Description, and choose the Binding Type = OData V4 - UI
:
data:image/s3,"s3://crabby-images/55aac/55aac5b363735e85899e88b3926544a428116950" alt="Create service binding"
Click on Next, select a suitable transport request (or create a new one) and then click on Finish. Activate it. Publish the service binding (as shown in a previous exercise).
We will now use the shopping cart user created in the previous step to test out different authorization scenarios. First of all, to be able to test our service binding, the shopping cart user must have access to it. Logon on to your SAP S/4HANA system via the backend, using your developer user credentials, start transaction PFCG
and create a new single role, with name: ZR_SHOPCART_###
. In the Menu tab select Transaction --> Authorization Default
data:image/s3,"s3://crabby-images/3f2eb/3f2ebe3d20cdf1e201378b2589ee7a2638d360be" alt="Create service binding role"
As Authorization Default choose SAP GATEWAY OData V4 Backend Service Group & Assignments
(1) and input your service binding name (2) then click on Copy (3):
data:image/s3,"s3://crabby-images/74d77/74d777014a74acef48200c5b71d0ee5390b9afec" alt="Create service binding role - 2"
Save the role. Then navigate to the Authorizations tab, click on Change Authorization data and click on the Generate icon to generate the authorization profile. Add the Z_USER_###
in the User tab, save the role and then click on the User Comparison button.
With this role your user can now access the service binding and use the application preview to create entries in your shopping cart. But it still lacks authorizations to create a purchase requisition. To test this logon to ADT and open the service binding ZUI_SHOPCART_WRAPPER_O4_###
, right click on the ShoppingCart
entity and select Copy Fiori Elements App Preview URL
to copy the URL of the application preview.
data:image/s3,"s3://crabby-images/140b6/140b6123432207bbb20ba2b378ab62e78a63c998" alt="Open service binding"
Open the URL in a new browser so you will be prompted to login. Input the shopping cart user credentials:
data:image/s3,"s3://crabby-images/ab3ca/ab3caa260cd12fb6b12b5cfedff7bb91257c76b2" alt="Open service binding - 2"
The limited access of the shopping cart user allows it to access the service binding and create a new entry but it is not yet allowed to create a purchase requisition. You can test this out: create a new entry and then click on the Create PR via BAPI in SAVE
, you will get an error message:
data:image/s3,"s3://crabby-images/aa3f5/aa3f524c18e553e58fbd5a52a4ee5ecf4fbbf820" alt="Shopping cart user no authorization case"
In this authorization scenario you want authorization checks to be performed when creating a purchase requisition in your application, so that only authorized users can perform that action.
🔵 Click to expand
In the case of released objects you would add the released authorizations objects directly to the authorization defaults via transaction SU22
. This is however not possible for unreleased authorization objects:
data:image/s3,"s3://crabby-images/7f957/7f957c12295cd0ae57dd261917fa30f12c622c49" alt="Unreleased authorization objects cannot be added to su22"
The best practice in the case of unreleased authorization objects is to create an authorization default variant to hold the authorizations. You will now create such a variant for the wrapper service binding ZUI_SHOPCART_WRAPPER_O4_###
.
Log on to the system via SAP GUI using the developer user credentials and start transaction SU22
. In 'Type of Application' select SAP Gateway OData V4 Backend Service group and Assignments
and as 'Object Name' input the service binding ZUI_SHOPCART_WRAPPER_O4_###
then click on Execute:
data:image/s3,"s3://crabby-images/34585/3458559d7fc5ef64e0ef753096bba8add1fc1ac4" alt="Open service binding"
Open the service binding ZUI_SHOPCART_WRAPPER_O4_###
: there should be no authorization objects except for S_START
. Click on the Variant icon to create a new variant:
data:image/s3,"s3://crabby-images/acf6a/acf6a5920db0562cf8c068a76a5c4a3b9124a1f0" alt="Create variant"
Input the name ZUI_SHOPCART_WRAPPER_O4_###_V
and a description for the default variant (1) and then click on Save (2). You will be prompted to select a package: input the tier 2 package $Z_PURCHASE_REQ_TIER2_###
(3) and save it (4):
data:image/s3,"s3://crabby-images/3a19c/3a19cae566e4c303c5eec1e6ffefaa314664ba13" alt="Create variant - 2"
Select a suitable transport request (or create a new one if needed) and confirm.
Step 4: Check authorization use case - Maintain authorization defaults for the wrapper in default variant
You now want to find out the required authorizations for the BAPI_PR_CREATE
wrapper that is used in the wrapper service binding, and add them to your default variant.
You can use various authorization traces to find out the needed authorization objects for a given BAPI. For the scope of this tutorial, we will show the recommended approach using the system trace in the SU22
transaction, but we suggest you familiarise yourself with all the various available traces.
🔵 Click to expand
Go to the transaction SU22
and open the newly created authorization default variant. Switch to edit mode (1) and then click on Object -> Add Object from System Trace -> Local (2).
data:image/s3,"s3://crabby-images/466d2/466d21793090b507cf026cf6ed7f9ae9ad6f8738" alt="Activate trace"
Input the username for which you want to activate the trace (in this case: your developer user) and click on Activate Trace:
data:image/s3,"s3://crabby-images/9b721/9b7214f43b7ef38d5249db746464dd6389dc2c2f" alt="Activate trace - input user"
Do NOT close this window.
From ADT, open the preview of the wrapper service binding ZUI_SHOPCART_WRAPPER_O4_###
using the developer user credentials, create a new entry and create a purchase requisition by clicking on the Create PR via BAPI in SAVE
button. The needed authorizations will be picked up by the active trace.
Go back to the SU22
window you left open, click on Deactivate Trace and then click on Evaluate. Select all the authorization Objects that the trace found, and click on the Continue icon. The needed authorizations will be added.
data:image/s3,"s3://crabby-images/7bc96/7bc96ead075f8666588d1d2f1f543187a1d64722" alt="Activate trace - add authorizations - 5"
Save. Select all the newly added Authorization Objects and then click on the Trace button:
data:image/s3,"s3://crabby-images/de63b/de63b0d9439b0a6cc1e50348f2538712f69ed238" alt="Activate trace - add authorizations 6"
Now click on Evaluate Trace -> System Trace (STAUTHTRACE) -> Local:
data:image/s3,"s3://crabby-images/3394c/3394c8567de76f09ca42cb45f87699ab14168f35" alt="Activate trace - add authorizations 7"
Click on Evaluate and the needed field values will be displayed for the given selected authorization object (1). Select it (2) and click on Transfer (3): the needed field values will be added (4):
data:image/s3,"s3://crabby-images/a8f03/a8f035023fe6e2ad7672285acd20148648e52dd1" alt="Activate trace - add authorizations 8"
Repeat the process for all the non-released authorization objects and then click on the Continue icon in the right bottom corner. Save it.
Save it. Now start transaction SU24
and select SAP Gateway OData V4 Backend Service Group and Assignments
from the dropdown menu of the Type of Application
field. In the Object Name
field input your Service Binding name and click on the Execute
button. Select the newly created variant (1), switch to Edit mode (2), click on the SAP Data
icon (3), and then click on Copy SAP Data to SU24
icon in the Maintenance Status for Authorization Objects
tab (4).
data:image/s3,"s3://crabby-images/8a7c5/8a7c5294e99e874c6a4080a60aac251a6483593c" alt="Synchronized with SAP data"
This will copy the authorization objects, but you still need to copy the authorization defaults values for each object. To do this, click on the Synchronize with SAP data
icon for all the authorization objects (1) and then click on the Copy SAP Data to SU24
icon in the Authorization Default Values
tab (2).
data:image/s3,"s3://crabby-images/c6a8f/c6a8fca7f9a1e8b3b69db7edab6b25b5815142c0" alt="Synchronized with SAP data - 2"
Save it and select a suitable transport request (or create a new one if needed).
In the previous steps you found out the needed authorization objects to create a purchase requisition via the BAPI_PR_CREATE
wrapper, and you created a default variant for the service binding granting such authorizations. The last step is to add this default variant to the ZR_SHOPCART_###
role. Any user with this role will then be able to create a purchase requisition.
🔵 Click to expand
Start transaction PFCG
, and open the ZR_SHOPCART_###
role. Switch to Edit mode and in the Applications tab deselect the authorization default and select the default variant you created, then click on Save:
data:image/s3,"s3://crabby-images/820b1/820b167df7f802ea3dc3d890afcb67463ac664d7" alt="Create variant role - 4"
In the Authorizations tab click on Change Authorization Data and in the pop-up select all the options and click on Full Authorization then click on Save
.
data:image/s3,"s3://crabby-images/2c827/2c827577fa1c96b89343b76f4e2c8f964a5d5bc8" alt="Create variant role - 5"
you will see that all the authorization objects are automatically added and all the field values are set. Save and then click on the Generate icon to generate the authorization profile.
data:image/s3,"s3://crabby-images/6a521/6a521ac3e915981ed54f8d52f4a2224cbcf2c0c5" alt="Create variant role - 6"
Now the shopping cart user has the role assigned, which contains the authorization default variant for the service binding, granting the necessary authorizations to create a purchase requsition via the BAPI wrapper.
You can test it: open the service binding using the shopping cart user credentials (we suggest to open it in incognito mode, so that you will be prompted to log in) and try to create a purchase requisition by clicking on the Create PR via BAPI in SAVE
button, it should work without errors:
data:image/s3,"s3://crabby-images/c9dcc/c9dcc10d742c8605849638fdabc987a43ef94339" alt="Shopping cart user create PR with variant"
After the
DO CHECK
use case test is succesfully done, remove theZR_SHOPCART_###
role from theZ_USER_###
(this can be done in transactionSU01
) so that the shopping cart user is returned to its limited access state, and ready to be used in the next use case.
In this authorization scenario, you have decided that you do not want that any of the authorizations required for the BAPI call are checked when creating a purchase requisition in your application. So any user using the application should be able to create a purchase requisition, regardless of roles and authorizations. To achieve this you can set the check indicator of the authorization objects to Do not Check
in transaction SU24
.
🔵 Click to expand
You are setting the 'DO NOT CHECK' indicator in
SU24
for two reasons: first, as shown before it is not possible to add unreleased authorization objects inSU22
to applications with ABAP language version ABAP for Cloud Development, and second, it is not possible to set the 'DO NOT CHECK' indicator inSU22
for applications with ABAP language version ABAP for Cloud Development, as shown in the following screenshot:
data:image/s3,"s3://crabby-images/f1579/f157941b6e9667487dc9e29866a21792d568755a" alt="Do not check option su22 not available"
To keep this exericise clear and modular, we will create a new service binding to test this scenario. This service binding exposes exactly the same service as the previous one. Logon to ADT using the developer user credentials and navigate to the package Z_PURCHASE_REQ_###
. Right click on the service definition ZUI_SHOPCART_###
and select New Service Binding, input the Name ZUI_SHOPCART_WRP_NCK_O4_###
and a Description and select the Binding Type OData V4 - UI
:
data:image/s3,"s3://crabby-images/37ade/37ade397a7193f6fa11f26a6666a21bd7eb0a035" alt="Create Service Binding"
Click on Next. Select an existing transport request (or create a new one if needed) and click on Finish. Activate it. Publish the service binding as shown in a previous exercise of this series.
After the service binding has been published, logon to the backend of the system using the developer user credentials and, similar as what done in a previous step, create a new role (we suggest to name the role ZR_SHOPCART_NCK_###
) and add the newly created ZUI_SHOPCART_WRP_NCK_O4_###
service binding defaults in the Menu tab to gain access to the service. Assign the Z_USER_###
user to role (do not forget to generate the authorization profile and do the user comparison). The shopping cart user should now have only two roles: ZAP_BC_ABAP_DEVELOPER_5_###
and ZR_SHOPCART_NCK_###
:
data:image/s3,"s3://crabby-images/7e990/7e99063c9c4c7470750c070197bd6dff7e878f10" alt="Remove role"
At the moment, the newly created service binding ZUI_SHOPCART_WRP_NCK_O4_###
would still perform authorization checks when creating a purchase requisition. You can test this using the Z_USER_###
role: since this role does not have the required authorization, you will get an error when trying to create a purchase requsition from the service binding preview.
Now, we will modify the service binding so that no authorization check is performed. Start transaction SU24
and open the ZUI_SHOPCART_WRP_NCK_O4_###
service binding. Similar to what done in the previous step, for the check authorization use case, switch to edit mode and add all the needed authorization objects.
For the scope of this tutorial, you already found out the needed authorization objects in a previous step. You could also use the system trace directly from the
SU24
transaction to find the authorization objects that you need to add.
Then select all of them and click on Check Indicator -> Do Not Check:
data:image/s3,"s3://crabby-images/34b26/34b26d300951934fba35b24718d12d7bd0e253b6" alt="Do not check option"
Save it. Now the service binding will not perform authorization checks for all the authorization objects with a 'DO NOT CHECK' indicator. As a result, even users with limited access and no specific authorizations will be able to create a purchase requisition. You can test this with the Z_USER_###
user:
Now that you've learned...
- how to find out the needed authorization objects for a given BAPI,
- how to handle authorizations via an authorization default variant for the check authorization use case, and
- how to suppress all authorization checks in the disable authorization check use case,
you are done with this hands-on. Congratulations!
We hope you enjoyed the RAP640 hands-on exercises. Now you can go back to the RAP640 exercises overview on the entry page.