This document is an overview of security-relevant information that applies to Identity Authentication, and contains recommendations about how administrators should secure it.
While this document is intended to support administrators and security responsible specialists to use Identity Authentication in a secure manner, there may be further elements to consider depending on usage, integrations as well as applicable industry or local legal regulations.
For more information, see Updates and Notifications.
For more information, see Updates and Notifications.
Before you secure Identity Authentication, protect the cloud application that trusts Identity Authentication.For more information about protecting SAP BTP applications, see Security, Neo Environment.
SAP BTP Security Recommendations collects information which helps you to secure the configuration and operation of SAP BTP services in your landscape.
For more information, see Security Recommendations - Identity Authentication and Security Recommendations - Identity Provisioning and Monitoring with SAP Cloud ALM.
Identity Authentication is fully web browser based application, with all access over HTTPS. Every page of the Identity Authentication application is currently delivered via Transport Layer Security (TLS). Access to Identity Authentication is encrypted-in-transit over HTTPS using 256-bit TLS encryption.
By default, the Identity Provisioning uses secure communication channels. Still, when connecting to customer systems, you decide (define) what the communication channel to be.
-
Always use secure protocols when specifying your connection details (in the cockpit → Destinations section, in the Identity Provisioning UI → Properties tab).
-
Always re-enter the values of the configured credential properties when you update the
URL
or host name of an existing provisoning system in the Properties tab of the Identity Provisioning UI. The only exception to this are the credential properties of systems that are created with a connectivity destination. -
Avoid using property
TrustAll
in productive scenarios. When it's set to true, the SSL server certificate is not verified, and thus the server is not authenticated.
Set user permissions in accordance with the scenario you are configuring. For more information, see Scenarios.
You have the following options:
- For a business-to-consumer scenario, allow Public user application access.
- For a business-to-business scenario, allow Private user application access.
- For a business-to-employee scenario, allow Internal user application access.
For more information about the settings for user application access, see Configure User Access to the Application.
You can also define rules for authentication according to different risk factors. For more information, see Configure Risk-Based Authentication for an Application.
Identity Authentication protects your users during authentication in the following ways:
-
With SAML 2.0 or OpenID Connect
Identity Authentication supports the single sign-on (SSO) mechanism. Every user with an account is able to use SSO for the cloud applications that use Identity Authentication.
-
With an application certificate
The Identity Authentication authentication interfaces that receive REST API calls are protected, since they require an application certificate. Use the certificate when implementing REST APIs for your application. For more information, see the REST API configurations in Development.
Applications configured in Identity Authentication can manage business user authorizations for applications. For such applications, the Authorization tab shows a list of authorization policies created by the application. You can also create custom authorization policies. These authorization policies are stored as user groups. You can assign authorization policies to business users with the admin console, but you can also use a SCIM API.
Identity Authentication does not store plain text passwords in the database, but only their iterated random-salted secure hash values. The random salt is at least 512 bits, and it is different for each password. Only generic hash functions are used with minimum 512 bits key length. No default passwords are delivered, used, or accepted anywhere.
Identity Authentication can use also passwords from on-premise systems for user authentication. These passwords are not stored by Identity Authentication. It sends the user ID and the password for authentication to the on-premise system via the Transport Layer Security (TLS) connection. The management of these passwords depends on the integrated on-premise system that supports them, for example Microsoft Active Directory.
Identity Authentication supports three levels of password security. You should use the highest level of security that matches the requirements of your application. The passwords are managed based on password policy rules. For more information, see Configuring Password Policies.
When using Identity Provisioning to configure a provisioning system, always set credentials (such as passwords, private keys and OAuth secrets) as Credential properties. When you add a credential property, its value is displayed as an encrypted string. For better security, the encrypted string is always displayed as 40 characters, no matter how long your real password is.
Session cookies in Identity Authentication are protected with a Transport Layer Security (TLS) and with the Secure and HttpOnly attributes. You don't need to make any additional configurations for Identity Authentication.
Identity Authentication is setup in a fenced network, separated from the SAP internal network.
Customer applications run in a shared environment where the business data is isolated from each other, the SAP BTP services uses a shared SAP BTP infrastructure. The internal traffic is controlled by firewalls. SAP administrative access is done via terminal service that requires strong authentication.
All communication channels are protected with TLS, and you should configure the cloud application to use TLS and to check the SAML 2.0 signature.
Data storage security is about how Identity Authentication protects its own database. Data storage security is ensured by the isolated tenant that each customer receives. Only tenant-specific requests can access the tenant's database. These requests are performed by a tenant service, which works with a dependency injection framework and makes sure that all the services, for example the persistence service and the mail service, are injected with the instances dedicated to the given tenant.
In Identity Provisioning, no personal or sensitive information about the provisioned entities is saved. To check whether any changes have been made to an entity after the initial provisioning, Identity Provisioning uses strong hashed algorithm for the provisioned entities.
If a provisioning job repeatedly fails and you need problem investigation, you can enable detailed entity tracing. That means, the Identity Provisioning service will log the complete information (general, personal and sensitive data) of your provisioned entities. For example, if "groups": XXX are not an array but have a string value instead; or an attribute that must have a string value, has an integer value instead. Tracing such data could help you identify potential incorrect attribute values for a certain entity, which you can correct in the source system or via the transformation functions.
To activate entity tracing, proceed as follows:
-
In your source system, set property ips.trace.failed.entity.content to true.
-
Run again the provisioning job.
-
Open the Job Logs section, select your job, and under Failed Entities, choose an entity and find the log information about it.
-
If you cannot resolve the problem, contact the Identity Provisioning support.
The operators may need the full trace content, so they can ask you to set the property in your target system as well, and once again run the provisioning job.
You can download a CSV file with a history of operations performed by administrators. For more information, see Export Change Logs with a History of Administration Operations.
You can retrieve the statistics on the number of user logon request per month. This number is counted on each single authentication managed via Identity Authentication. For more information, see View Usage Statistics.
Related Information