Setup SAML2 based SSO with Laravel as Service Provider and WSO2 Identity Server as Identity Provider
January 9th, 2022
What is SAML2?
SAML2 (Security Assertion Markup Language 2.0) is a version of the SAML standard for exchanging authentication and authorization identities between security domain (app). SAML2 uses security tokens containing assertions and user information in XML-based document. SAML2 enabling web-based, cross-domain SSO, which helps to reduce administrative overhead to user, by reducing credential information input in each security domain.
In order to understand this tutorial, i think it’s necessary for you to familiarize with some basic concepts of SAML. Read about SAML here
What is Identity Server?
The Identity Server is a server that manages securely identities such as employees, suppliers, partners, customers, etc. (any type of information that can be stored in a database as an entity has an identity); and access between systems and applications, with the possibility of using a single access and without the need to repeat credentials every time a user needs to use a Service Provider.
WSO2 Identity Server is one of IAM product with API-driven, open-source, cloud-native feature. It is so easy to implement SSO authentication using WSO2 IS.
Laravel Setup
- Create new Laravel App (you can skip this if you had your project setup-ed)
- Install aacotroneo/laravel-saml2. library.
- Publish laravel-saml2 config file.
The command will add the files app/config/saml2_settings.php
& app/config/saml2/mytestidp1_idp_settings.php
, which you will need to customize.
- Define names of all the IDPs you want to configure in
app/config/saml2_settings.php
. The name of the IDP will show up in the URL used by the Saml2 routes the library makes, as well as internally in the filename for each IDP's config.
- Set
$this_idp_env_id = 'WSO2IS'
or any value, then you can set ENV vars starting withSAML2_WSO2IS_
respectively.
- In order to make single logout work properly, I need to extend Saml2Controller which provided by the library.
Laravel Fortify vs Manual Authentication
Laravel offers two different authentication mechanism. Using Laravel Fortify your life will be easier. Laravel Fortify is a frontend agnostic authentication backend implementation for Laravel. Fortify registers the routes and controllers needed to implement all of Laravel's authentication features, including login, registration, password reset, email verification, and more. Nonetheless, wether Fortify or manual authentication, it will not be that much different.
- (Optional) Install Laravel Jetstream. I use this starter pack for this article purpose (because i love this starter pack 🤣)
After installing the Jetstream package, you may execute the jetstream:install
Artisan command. This command accepts the name of the stack you prefer (livewire
or inertia
). I prefer livewire.
Then finalizing the installation
- Now we’re done setup Laravel Jetstream with Livewire.
WSO2 Identity Server Setup
Make sure you have JDK 8 or 11 installed in your server. If you have it installed you can continue to install WSO2 Identity server. Download the installer at Identity Server - On-Premise and in the Cloud
- Start the WSO2 Identity Server and go to https://localhost:9443/carbon to access management console.
- Create new Service Provider
Click register to add new service provider. The service provider screen will appear. We need to upload certificate. Follow the steps bellow.
- Go to the folder within the WSO2 Identity Server version /repository/resources/security
- Open a terminal and execute the following commands to export the keystone certificate.
- The exported certificate will be in binary format.
Convert the previous binary encrypted certificate to a PEM encrypted certificate.
Upload pem file to service provider.
Claim configuration : wso2 local claim will be used. Givenname and emailaddress need to be added.
Inbound Authentication Configuration: the responsibility of the inbound authenticator component is to identify and analyze all inbound authentication requests and then generate the corresponding response.
To configure Inbound Authentication, on SAML2 Web SSO Section click on the Configure button, which will redirect you to the form that will request the information necessary to establish the connection between WSO2 Identity Server and the application that has been previously generated.
Complete the form with the following information:
Field | Value | Description |
---|---|---|
Issuer | playgroundId | This is the <saml element: Issuer> containing the unique identifier of the service provider. This is also the sender value, specified in the SAML authentication request issued by the service provider. |
Assertion Consumer URLs | http://localhost/saml2/wso2is/metadata http://localhost/saml2/wso2is/sls http://localhost/saml2/wso2is/acl | This is the URL to which the browser should be redirected after successful authentication. |
Enable Response Signing | Selected | Sign the SAML2 responses returned after the authentication process. |
Enable Signature Validation in Authentication Requests and Logout Requests | Selected | This specifies whether the identity provider must validate the signature of the SAML2 authentication request and the SAML2 logout request sent by the service provider. |
Enable Single Logout | Selected | If single sign-off is enabled, the identity provider sends sign-off requests to all service providers. |
Enable Attribute Profile | Selected | The identity server provides support for a basic attribute profile where the identity provider can include the user’s attributes in the SAML statements as part of the attribute declaration. |
Always Include Attributes in the Response | Selected | The identity provider always includes the values of the attributes related to the selected statements in the SAML attribute declaration. |
Enable IdP Initiated SSO | Selected | When enabled, the service provider is not required to submit the SAML2 application. |
Enable idP Initiated SLO | Selected | When enabled, the service provider is not required to submit the SAML2 application. |
Then, click on the Update button to update the information in the Service Provider.
Connecting WSO2 Identity Server to Laravel Application
First, create new user in WSO2 Management Console. To create new user in WSO2 ,the following steps must be followed:
- Click on Add, under Users and Roles.
- Click on Add New User, on the page where the console was redirected.
- You will be asked to fill out a form which contains basic user information, such as Username and Password
Fill some field in User Profile
Create Event Listener to catch “logged in” event from WSO2 IS. Add this code to app\Providers\EventServiceProvider.php
- Create an action class to “synchronize” laravel user with WSO2 IS user. Create class in app/actions folder.
These classes will synchronize laravel user data with WSO2 IS user data every time user logged in to laravel application.
At this state, your laravel application should connected to WSO2 IS. BUT, we need some additional configuration to make laravel save authenticated session correctly by using “laravel way”. Edit saml2_config.php file and define “routesMiddleware”.
- Then create new middleware entry at app\Http\Kernel.php
Now this Laravel Application will generate session for authenticated user correctly. BUT We are not done yet. Many time your user maybe authenticated on other service provider in your organization. In this case laravel should ask WSO2 IS first wether the users is authenticated or not. If authenticated then we should bypass them.
- Create new middleware by using this command :
- Open the file and add code bellow :
- Then register this new middleware to app\Http\Kernel.php
- Apply the middleware to your routes/web.php.
Next, modify your login page. It should be just a landing page which as a button or link to redirect your app authentication to WSO2 IS login page. In this article i made it just like this :
Focus at route(’saml2_login’,[’wso2is’]). This route name is defined by laravel-saml library. Use this route with your defined “idpNames” in saml2_settings.php file. You must use route saml2_logout too to logout the app.
Results and Conclusions
As you walk along this tutorial, using laravel (jetstream) you can establish a connection using the SAML2 to WSO2 IS. It’s very simple and fast in development.
Clone bellow repository to see complete source code of this tutorial.