Dear Learner,
due to dependecies or product updates, you could potentially run into some issues from time to time.
Before posting a question in our SAP BTP Learning Group, please go through this troubleshooting guide carefully.
First and foremost, make sure to check your cds version:
cds -v
It should print something similair like this:
@sap/cds: 6.1.3
@sap/cds-compiler: 3.1.2
@sap/cds-dk: 6.1.5
@sap/cds-dk (global): 6.1.5
@sap/cds-foss: 4.0.0
@sap/cds-mtx: -- missing --
@sap/eslint-plugin-cds: 2.5.0
...
If your @sap/cds
dependency is lower than 5.9.x, then please make sure to upgrade your cds packages:
npm i @sap/cds-dk && npm i @sap/cds && npm update
Verify your cds version again with cds -v
.
If your business partner search help is not working on the object page, then this is due to an issue with an OData parameter in the query.
In risk-service.js
adjust the event handler as follows:
this.on("READ", BusinessPartners, async (req) => {
// The API Sandbox returns alot of business partners with empty names.
// We don't want them in our application
req.query.where("LastName <> '' and FirstName <> '' ");
// --> ADD THIS LINE TO REMOVE THE COUNT PARAMETER
req.query.SELECT.count = false;
return await BPsrv.transaction(req).send({
query: req.query,
headers: {
apikey: process.env.apikey,
},
});
});
If you see an error like this in the SAP Business Application Studio for any of the required packages, then please follow the steps below:
npm ERR! code E404
npm ERR! 404 Not Found - GET http://nginx-redirector.repo-cache.svc.cluster.local/verror/-/verror-1.10.0.tgz
npm ERR! 404
npm ERR! 404 'https://registry.npmjs.org/verror/-/verror-1.10.0.tgz' is not in this registry.
npm ERR! 404 This package name is not valid, because
Please run the following in your terminal:
npm cache clear --force
npm config set registry http://registry.npmjs.org/
npm install
SAP NOTE: https://launchpad.support.sap.com/#/notes/2864831
Some learners also reported that there is currently an issue with the approuter:
Error Message: ```The redirect_uri has an invalid domain.```.
If you face this issue, you have add the oauth2-configuration
to your uaa-service
definition in the mta.yaml
file:
NOTE: Please change the oauth2-configuration redirect-uri to your approuter's url!
oauth2-configuration: # <-- add this
redirect-uris:
# example: - https://risk-management-approuter.cfapps.eu10-004.hana.ondemand.com/login/callback
- https://<approuter-route>/login/callback
The uaa
or nowadays auth
resource should like like this:
---
resources:
- name: risk-management-auth
type: org.cloudfoundry.managed-service
parameters:
service: xsuaa
service-plan: application
path: ./xs-security.json
config:
xsappname: risk-management-${org}-${space}
tenant-mode: dedicated
role-collections:
- name: 'RiskManager-${space}'
description: Manage Risks
role-template-references:
- $XSAPPNAME.RiskManager
- name: 'RiskViewer-${space}'
description: View Risks
role-template-references:
- $XSAPPNAME.RiskViewer
oauth2-configuration: # <-- add this
redirect-uris:
# example: - https://risk-management-approuter.cfapps.eu10-004.hana.ondemand.com/login/callback
- https://<approuter-route>/login/callback