======Guideline for Service Owners ======
===== Connecting to our Identity Providers (IdPs) =====
We provide you with the flexibility to connect your services to our IdP solutions through two protocols: SAML and OIDC. These protocols ensure a secure and smooth integration, allowing for seamless authentication and authorization processes for your applications.
==== 1: Security Assertion Markup Language (SAML):====
SAML allows for secure single sign-on (SSO) and federation across different applications and platforms. It enables the exchange of user authentication and authorization information in a standardized way, ensuring smooth communication between your services and our IdPs.
=== GWDG Academic ID SAML Solutions: ===
== SimpleSAMLphp:==
SimpleSAMLphp (https://simplesamlphp.org) is an open-source software package for providing IAM functionalities and features. It is written in PHP and supports straightforward integration of new customizable modules. SimpleSAMLphp is often used to provide authentication and authorization services for web-based applications; however, it also supports native mobile apps and APIs using different protocols, including SAML, OIDC, and OAuth. It is designed to be easy to install and configure and can be used as a standalone application or as a module within other applications.
== Shibboleth:==
Shibboleth (https://www.shibboleth.net) is a type of open-source SAML implementation developed by the Shibboleth Consortium. It provides content personalization, secure authentication, and authorization and enables SSO functionality for accessing services in multiple domains. Shibboleth has been designed to be compatible with many organizational domains' infrastructures to support general FIM requirements.
=== Information We Need from You:===
To connect your services to our SAML SSO solution, we request the following information from you:
* SP Metadata (Mandatory): Provide us with the metadata of your service, which typically includes information about your organization, entity ID, and SAML endpoints.
* Authorization Policies (Optional): Provide us with the information and conditions on whom and how they can access your services. Example: Only students from the University "ABC" are authorized to access our resources.
Once you have collected this information, please submit it to our support team at sso-support@gwdg.de.
=== Information You Need from Us: ===
We will provide you with the necessary SAML metadata, which is an XML document containing important configuration details about the IdP you requested to connect. The metadata includes information such as URLs of endpoints, supported bindings, identifiers, and public keys.
Depending on your application framework or platform, you will need to locate the appropriate configuration file or settings where you can specify the IdP's metadata. This step ensures that your application recognizes and trusts our IdP. If your application doesn't have built-in SAML support, you can leverage external libraries specifically designed for SAML communication. These libraries provide pre-built functionalities and utilities for SAML authentication, simplifying the integration process. Choose a library that suits your programming language and framework.Please note that the specific implementation details may vary depending on your application framework, platform, and the chosen library. It is recommended to consult the documentation and resources specific to your application or chosen library for detailed instructions.
After completing the configuration, thoroughly test the integration by initiating SSO requests and validating the SAML responses. Ensure that the authentication flow is seamless and that user attributes and assertions are correctly processed.
==== 2: OpenID Connect (OIDC):====
In addition to SAML, we support OIDC as an alternative protocol for integrating your services with our IdPs. OIDC is an identity layer built on top of the OAuth 2.0 framework. It extends the OAuth 2.0 authorization protocol to provide an additional authentication protocol. OIDC allows third-party applications to verify the identity of end-users and obtain basic user profile information. It uses JSON web tokens (JWTs) to exchange information between the client application and the OpenID Provider (OP).
=== GWDG Academic ID OIDC Solution: ===
== Keycloak:==
Keycloak is a Red Hat-sponsored IAM solution supporting multiple protocols. Some important technologies and features supported by this open-source solution are:
* Extensible Customization: Keycloak allows for developing customizing IdM and AM solutions with minimum coding and straightforward deployment.
* Delegated Authentication: Keycloak can be configured to be connected to external IdPs supporting OIDC or SAML 2.0 protocols. In other words, user authentication can be managed through the Keycloak or external IdPs.
* Delegated IdM: Keycloak supports the management of user identities and admin access centrally. However, it also offers an easy solution for connecting to user directories such as Active Directory and LDAP that currently exist in a domain.
* Customized AM Mechanisms: Keycloak supports various AM mechanisms, including MFA, one-time password (OTP), and customized policies. Service owners can also request a combination of these mechanisms to authenticate and authorize users.
=== Information We Need from You:===
To connect your services to our OIDC solution, we require the following information from you:
* Base URIs (Mandatory): Provide the base URIs for your application. These URIs represent the main endpoints of your application where authentication and authorization will take place.
* Redirect URIs (Mandatory): Specify the redirect URIs that will be used for the authentication flow. After successful authentication, users will be redirected to these URIs with the required authorization code or access token.
* Scopes (Optional): Specify the scopes required for accessing user information. Scopes define the permissions and level of access your application needs, such as openid, profile, email, or custom scopes specific to your application.
* Authorization Flow (Optional): You have the flexibility to choose the desired authorization flow for your application. OIDC supports various flows, such as the Authorization Code Flow, Implicit Flow, and Hybrid Flow. Each flow has its own characteristics and security considerations. Select the appropriate flow based on your application's requirements.
* Authorization Policies (Optional): Refer to SAML.
=== Information You Need from Us: ===
Once you submit the required information, we will provide you with the necessary OIDC configuration details, including the client ID, client secret, authorization endpoint, token endpoint, and other relevant parameters. These details will enable you to configure your application and communicate with our OIDC provider.
Similar to the SAML connection, if your application doesn't have built-in support for OIDC, you can incorporate an OIDC client library or SDK suitable for your programming language and framework.
Please ensure that you follow the configuration steps carefully, handle received tokens securely within your application, and adhere to best practices for OIDC implementation.
==== Which Protocol Is the Best Choice for You? SAML or OIDC:====
When considering whether to choose SAML or OIDC for integrating your services with our IdM or IdP solutions, it's essential to evaluate the specific benefits each protocol offers. Here are some key arguments to help you make an informed decision:
* You need modern authentication and authorization features: OIDC builds upon OAuth 2.0 and offers additional features for modern identity management, including support for mobile and web applications, enhanced security, and flexible authorization mechanisms.
* Simplicity and ease of implementation: OIDC is often considered simpler to implement compared to SAML, making it a favorable choice if you prioritize ease of integration and maintenance.
* Industry adoption and compatibility: SAML has been widely adopted for many years and is well-established in various industries, making it a reliable choice for compatibility with existing systems and integration with partners or service providers who predominantly support SAML. If your organization operates in an industry where SAML is prevalent and requires seamless interoperability with other entities, choosing SAML can ensure smoother collaboration and integration.
* Compliance and regulatory considerations: Depending on your industry or jurisdiction, specific compliance or regulatory requirements may influence your choice of protocol. Some industries or regions have specific guidelines or regulations that dictate the use of certain protocols.
Ultimately, the best choice depends on factors such as your existing infrastructure, compatibility requirements, and specific use cases. If you are unsure which protocol is the most suitable for your needs, we recommend consulting with our team. We can assist you in assessing your application's specific requirements and guide you in making an informed decision.
===== Hosting IdPs =====
At GWDG, we offer comprehensive solutions for hosting IdPs, ensuring the secure storage and management of user identities. Our services include establishing and configuring IdPs tailored to your specific requirements. Whether you prefer cloud-hosted solutions or on-premises installations, we have the expertise to guide you through the process.
Our process for setting up IdPs and integrating them into your domains is straightforward. Here's an overview of how we can assist you:
* Evaluation: Our team will work closely with you to understand your requirements and recommend the most suitable IdP solution for your organization.
* Configuration: We will handle the configuration of the chosen IdP, ensuring it aligns with your domain settings and security policies.
* Integration: Our experts will guide you through the integration process, enabling seamless authentication between your applications and the IdP.
* Testing and Deployment: We will conduct thorough testing to ensure everything functions smoothly. Once validated, we will assist you in deploying the IdP into your production environment.
* Registration in DFN and Other Federations: We can also facilitate the registration of your IdP in the DFN (Deutsches Forschungsnetz) federation. This registration ensures your IdP can be part of a trusted network, allowing for seamless authentication across federated services.
* Ongoing Support and Maintenance: Our commitment doesn't end with the initial setup and integration. We provide ongoing support and maintenance services to ensure the continuous operation and security of your IdPs. Our team will be available to address any issues, implement updates, and optimize performance.
Our goal is to make the IdP setup and integration process as smooth as possible, empowering you to provide a secure and streamlined user experience. With our assistance, you can focus on delivering your core services while leaving the technical complexities to us.
If you have any questions or require further information, please don't hesitate to contact our support team. We are here to help you every step of the way.
===== Setting up your Service Provider (SP) =====
Integrating your service with the GWDG Single Sign-On (SSO) solution requires compatibility with SAML2, or OIDC authentication protocols. If your application already incorporates built-in support for these authentication protocols, you are well on your way. In such cases, you simply need to request and configure GWDG SSO settings within your application to establish connections with our Identity Providers (IdPs). However, If your application lacks built-in SSO support, you can integrate external libraries into your project and configure it to function as a Service Provider (SP). This section introduces an open-source library as an example for SAML2 authentication protocol, guiding you through its installation and configuration.
Two widely recognized options for SAML2 SSO integration into your application are the Apache module mod_shib paired with shibboleth SP and SimpleSamlPHP. The former follows a generic approach as it relies on the Apache webserver for authentication, while the latter is particularly well-suited for integration with PHP applications. Our focus here will be on explaining the basic steps involved in setting up your SP using Apache and mod_shib.
----
** Example: Installation Guideline**
This guide has been tested on Debian 8 and 9 but should work similar on ubuntu installations. For other distributions consult the official Shibboleth documentation.
1. Install packges: ''apt-get install libapache2-mod-shib2 libshibsp7 shibboleth-sp2-common''
2. Configure ''/etc/sbhibboleth/shibboleth2.xml''. You can use the default and configure the following values:
* entityID: Use your identifier for this SP e.g. ''entityID="https://sp.example.org/shibboleth"''
* SSO: The url of the metadata for the GWDG SSO instance which will be used to start an authentication workflow: ''SAML2''
* MetadataProvider: Where to fetch metadata for the SSO instance and where to cache it on disk: ''
''
3. Configure ''/etc/shibboleth/attribute-map.xml''. Adjust attribute mapping to your applications needs.
4. Configure apache to protect routes with shibboleth authentication. A protected location could look like this:
''
AuthType shibboleth
require valid-user
''
5. Restart apache and shibd: ''systemctl restart shibd.service; systemctl restart apache2.service;'' or ''/etc/init.d/shibd restart; /etc/init.d/apache2 restart'' (depending on your distribution and version)
6. Check if your metadata is available. It should be found at ''https://sp.example.org/Shibboleth.sso/Metadata''. If it looks valid, proceed to step 7. Please keep in mind that the official documentation says not to use the autogenerated Metadata. If you decide to follow this hint, make the metadata publicy available at another place and proceed to step 7.
7. Open an issue in this github project to have your metadata configured in the sso. Provide either the autoconfigured or hosted metadata link in there.
----
** Example: Configuration**
''/etc/shibboleth/shibboleth2.xml''
SAML2 SAML1
SAML2 Local
''/etc/shibboleth/attribute-map.xml''
**/etc/apache2/site-enabled/ssl.conf**
DocumentRoot /var/www/html
Options FollowSymLinks
AllowOverride None
Options Indexes FollowSymLinks
AllowOverride All
Order allow,deny
allow from all
# always fill env with shib variable
AuthType shibboleth
ShibRequestSetting requireSession false
Require shibboleth
AuthType shibboleth
ShibRequireSession On
ShibUseHeaders Off
ShibExportAssertion On
require valid-user
ServerName sp.example.org
UseCanonicalName On
SSLCertificateFile /etc/letsencrypt/live/sp.example.org/fullchain.pem
SSLCertificateKeyFile /etc/letsencrypt/live/sp.example.org/privkey.pem
Include /etc/letsencrypt/options-ssl-apache.conf