Skip to content

XSUAA authentication and authorization service integration libraries and samples for authenticating users and services

License

Notifications You must be signed in to change notification settings

FWinkler79/cloud-security-xsuaa-integration

 
 

Repository files navigation

Description

Authentication services provided by the xsuaa service on SAP Cloud Platform or SAP HANA XS Advanced rely on usage of the OAuth 2.0 protocol and OAuth 2.0 access tokens.

Web Flow for Authentication

Typical UI5 applications consist of a server providing the HTML content and one or more application serving REST APIs used by the application. Web application use the OAuth Authorization Code Flow for interactive authentication:

  1. A user accesses the web application using a browser or mobile device
  2. The web application (in typical SAP Cloud Platform applications, this is an application router) acts as OAuth client and redirects to the OAuth server for authorization
  3. Upon authentication, the web application uses the code issued by the authorization server to request an access token
  4. The web application uses the access token to request data from the OAuth resource server. The OAuth resource server validates the token using online or offline validation.

OAuth 2.0 Authorization code flow

OAuth resource servers (as the one in step 4) require libraries for validating access tokens.

Token Validation for Java Spring Boot web applications

Spring Boot provides OAuth resource servers. Application developers requiring authentication and authorization information in their application use the libraries defined in spring-xsuaa to obtain token information like user name and scopes.

Requirements

  • Java 8
  • maven 3.3.9 or later
  • Spring Boot 2.1 and later

Sample

See spring-security-xsuaa-usage for an example.

Additional (test) utilities

  • spring-xsuaa-mock offers a Mock web server to provide token keys for offline token validation in case xsuaa service (OAuth resource-server) is not in place. Its use is only intended for unit tests and when running your Spring boot application on a Webserver locally.
  • spring-xsuaa-test offers test utilities to generate custom JWT tokens for the purpose of tests.

Download and Installation

Build results are published to maven central: https://search.maven.org/search?q=com.sap.cloud.security

To download and install the project, clone this repository via:

git clone https://github.com/SAP/cloud-security-xsuaa-integration
cd cloud-security-xsuaa-integration
mvn package

Note: Use this is you want to enhance this xsuaa integration libraries. The buid results are also available on maven central.

Limitations

Libraries and information provided here is around the topic of integrating with the xsuaa service. General integration into other OAuth authorization servers is not the primary focus.

How to obtain support

Open an issue in GitHub.

License

Copyright (c) 2018-2019 SAP SE or an SAP affiliate company. All rights reserved. This file is licensed under the Apache Software License, v. 2 except as noted otherwise in the LICENSE file [LICENSE.md].

About

XSUAA authentication and authorization service integration libraries and samples for authenticating users and services

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Java 100.0%