Configuring Identity Server as IdP for SSO
The Single Sign-On (SSO) with SAML 2.0 feature in the API Manager is implemented according to the SAML 2.0 browser-based SSO support that is facilitated by WSO2 Identity Server (WSO2 IS). This feature is available in any WSO2 IS version from 4.1.0 onwards. We use WSO2 IS 5.2.0 in this guide. WSO2 Identity Server acts as an identity service provider (IdP) of systems enabled with single sign-on, while the Web applications act as SSO service providers. Using this feature, you can configure SSO across the API Publisher and Store. After configuring, you can access the API Store or API Publisher in a single authentication attempt.
The topics below explain the configurations.
Sharing the user store
Initially, configure your user store(s), if you have not done so already, by following the instructions in Configuring User Stores. Thereafter, point both WSO2 Identity Server and WSO2 API Manager to your user stores(s) using the instructions given below. You do this to make sure that a user who tries to log in to the API Manager console, the API Store or the Publisher is authorized. When a user tries to log in to either of the three applications, s/he is redirected to the configured identity provider (WSO2 IS in this case) where s/he provides the login credentials to be authenticated. In addition to this, the user should also be authorized by the system as some user roles do not have permission to perform certain actions. For the purpose of authorization, the IS and API Manager need to have a shared user store and user management database (by default, this is the H2 database in the <API-M_HOME>/repository/conf/user-mgt.xml
 file) where the user's role and permissions are stored.
For example, let's share a JDBC user store (MySQL) with both the WSO2 Identity Server and WSO2 API Manager as follows:
If you are using a secondary user store, you need to share all the user stores with the WSO2 Identity Server and WSO2 API Manager.
Download WSO2 API Manager 2.0.0 from here and unzip it.Â
<APIM_HOME>
refers to the root folder where WSO2 APIM was unzipped.Create a MySQL database (e.g., 410_um_db) and run theÂ
<API-M_HOME>/dbscripts/mysql.sql
 script on it to create the required tables.Â
If you are using a different database type, find the relevant script from theÂ<API-M_HOME>/dbscripts
 directory.From WSO2 Carbon Kernel 4.4.6 onwards there are two MySQL DB scripts available in the product distribution. Click here to identify as to which version of the MySQL script to use.
Open theÂ
<API-M_HOME>/repository/conf/datasources/master-datasources.xml
 file and add the datasource configuration for the database that you use for the shared user store and user management information. For example, you can share as single user store as follows. If you are sharing multiple datasources, you need to define a datasource for each of the user stores that you are working with, so that they can be shared.Example<datasource> <name>WSO2_UM_DB</name> <description>The datasource used for registry and user manager</description> <jndiConfig> <name>jdbc/WSO2UMDB</name> </jndiConfig> <definition type="RDBMS"> <configuration> <url>jdbc:mysql://localhost:3306/410_um_db</url> <username>username</username> <password>password</password> <driverClassName>com.mysql.jdbc.Driver</driverClassName> <maxActive>50</maxActive> <maxWait>60000</maxWait> <testOnBorrow>true</testOnBorrow> <validationQuery>SELECT 1</validationQuery> <validationInterval>30000</validationInterval> </configuration> </definition> </datasource>
Modify the username and password parameters of above configuration with your mysql database credentials.
Download WSO2 Identity Server (WSO2 IS) 5.2.0 from here and unzip it.Â
<IS_HOME>
 refers to the root folder where WSO2 IS was unzipped.If you plan on using WSO2 IS as Key Manager as well, you can download the WSO2 Identity Server 5.2.0 as a Key Manager pack, which has Key Manager features pre-packaged with WSO2 IS, from here.
Add the same datasource configuration above toÂ
<IS_HOME>/repository/conf/datasources/master-datasources.xml
 file.Copy the database driver JAR file to theÂ
<IS_HOME>/repository/components/lib
 andÂ<API-M_HOME>/repository/components/lib
 directories.Open theÂ
<API-M_HOME>/repository/conf/user-mgt.xml
 file. TheÂdataSource
 property points to the default H2 database. Change it to the jndiConfig name given above (i.e.,Âjdbc/WSO2UMDB
) based on each of your datasources. This changes the datasource reference that is pointing to the default H2 database.<Realm> <Configuration> ... <Property name="dataSource">jdbc/WSO2UMDB</Property> </Configuration> ... </Realm>
- Add the same configuration above to theÂ
<IS_HOME>/repository/conf/user-mgt.xml
 file. The Identity Server has an embedded LDAP user store by default. As this is enabled by default, follow the instructions in Internal JDBC User Store Configuration to disable the default LDAP and enable the JDBC user store instead.
In WSO2 API Manager, the default user store enabled is the JDBC User Store. By changing the default user store of WSO2 Identity server to JDBC User Store, we are pointing both WSO2 API Manager and WSO2 Identity Server to the same user store so that, their user stores are shared.
Sharing the registry space
In a multi-tenanted environment, by default, the Identity Server uses the key store of the super tenant to sign SAML responses. The API Store and Publishers are already registered as SPs in the super tenant. However, if you want the Identity Server to use the registry key store of the tenant that the user belongs to, you can create a common registry database and mount it on both the IS and the APIM.
Create a MySQL database (e.g., registry) and run theÂ
<IS_HOME>/dbscripts/mysql.sql
 script on it to create the required tables.Â
If you are using a different database type, find the relevant script from theÂ<IS_HOME>/dbscripts
 directory.From WSO2 Carbon Kernel 4.4.6 onwards there are two MySQL DB scripts available in the product distribution. Click here to identify as to which version of the MySQL script to use.
Add the following datasource configuration to both theÂ
<IS_HOME>/repository/conf/datasources/master-datasources.xml
 andÂ<API-M_HOME>/repository/conf/datasources/master-datasources.xml
 files.<datasource> <name>WSO2REG_DB</name> <description>The datasource used for registry</description> <jndiConfig> <name>jdbc/WSO2REG_DB</name> </jndiConfig> <definition type="RDBMS"> <configuration> <url>jdbc:mysql://localhost:3306/registry?autoReconnect=true&relaxAutoCommit=true&</url> <username>apiuser</username> <password>apimanager</password> <driverClassName>com.mysql.jdbc.Driver</driverClassName> <maxActive>50</maxActive> <maxWait>60000</maxWait> <testOnBorrow>true</testOnBorrow> <validationQuery>SELECT 1</validationQuery> <validationInterval>30000</validationInterval> </configuration> </definition> </datasource>Â
Modify the username and password parameters of above configuration with your mysql database credentials.
Create the registry mounts by inserting the following sections into theÂ
<IS_HOME>/repository/conf/registry.xml
 file.When doing this change, do not replace the existingÂ
<dbConfig>
for "wso2registry
". Simply add the following configuration to the existing configurations.<dbConfig name="govregistry"> <dataSource>jdbc/WSO2REG_DB</dataSource> </dbConfig> <remoteInstance url="https://localhost"> <id>gov</id> <dbConfig>govregistry</dbConfig> <readOnly>false</readOnly> <enableCache>true</enableCache> <registryRoot>/</registryRoot> </remoteInstance> <mount path="/_system/governance" overwrite="true"> <instanceId>gov</instanceId> <targetPath>/_system/governance</targetPath> </mount> <mount path="/_system/config" overwrite="true"> <instanceId>gov</instanceId> <targetPath>/_system/config</targetPath> </mount>
Refer Configuring registry.xml  for more details on configuration details and usage of registry.xml
Repeat the above step in theÂ
<API-M_HOME>/repository/conf/registry.xml
 file as well.
Next, let us look at the SSO configurations.Â
Configuring WSO2 Identity Server as a SAML 2.0 SSO Identity Provider
Start WSO2 Identity Server.
./wso2server.sh -DportOffset=1
You also can change Port offset value by changing <Offset> 1 </Offset> under <Ports> inÂ
<IS_HOME>/repository/conf/carbon.xml file.
What is port offset?
The port offset feature allows you to run multiple WSO2 products, multiple instances of a WSO2 product, or multiple WSO2 product clusters on the same server or virtual machine (VM). The port offset defines the number by which all ports defined in the runtime, such as the HTTP/S ports, will be offset. For example, if the HTTPS port is defined as 9443 and the portOffset is 1, the effective HTTPS port will be 9444.Â
Sign in to the WSO2 IS Management Console UI (
https://localhost:9444/carbon).
If you use signin pages that are hosted externally to sign in to the Identity Server, give the absolute URLs of those login pages in the
authenticators.xml
andapplication-authenticators.xml
 files in the<IS_HOME>/repository/conf/identity
directory.- Select Add under the Service Providers menu.
Give a service provider name and click Register.
In a multi tenanted environment, for all tenants to be able to log in to the APIM Web applications, do the following:
Click the SaaS Application option that appears after registering the service provider.
If not, only users in the current tenant domain (the one you are defining the service provider in) will be allowed to log in to the Web application and you have to register new service providers for all Web applications (API Store and API Publisher in this case) from each tenant space separately. For example, let's say you have three tenants as TA, TB and TC and you register the service provider in TA only. If you tick the SaaS Application option, all users in TA, TB, TC tenant domains will be able to log in. Else, only users in TA will be able to log in.
Add the following inside the
<SSOService>
element in the<IS_HOME>/repository/conf/identity/identity.xml
file and restart the server.<SSOService> <UseAuthenticatedUserDomainCrypto>true</UseAuthenticatedUserDomainCrypto> ... </SSOService>
If not, you get an exception as SAML response signature verification fails.
- Because the servers in a multi-tenanted environment interact with all tenants, all nodes should share the same user store. Therefore, make sure you have a shared registry (JDBC mount, WSO2 Governance Registry etc.) instance across all nodes.
You are navigated to the detailed configuration page. Inside the Inbound Authentication Configuratio n section, expand SAML2 Web SSO Configuration and click Configure.
To enable tenant specific SSO with IS 5.2.0 for API_PUBLISHER and API_STORE, enable Use tenant domain in local subject identifier and Use user store domain in local subject identifier under the Local & Outbound Authentication Configuration section.
Provide the configurations to register the API Publisher as the SSO service provider. These sample values may change depending in your configuration.
- Issuer: API_PUBLISHER
- Assertion Consumer URL:Â
https://localhost:9443/publisher/jagg/jaggery_acs.jag
. Change the IP and port accordingly. This is the URL for the acs page in your running publisher app. Select the following options:
Enable Response Signing
Enable Single Logout
- Click Register once done.
For example:
Similarly, provide the configurations to register the API Store as the SSO service provider. These sample values may change depending in your configuration.
- Issuer: API_STORE
- Assertion Consumer URL:Â
https://localhost:9443/store/jagg/jaggery_acs.jag
. Change the IP and port accordingly. This is the URL for the acs page in your running store app. - Select the following options:
- Enable Response Signing
- Enable Single Logout
- Click Register once done.
- Make sure that theÂ
responseSigningEnabled
 element is set toÂtrue
 in both the following files:<API-M_HOME>/repository/deployment/server/jaggeryapps/publisher/site/conf/site.json
<API-M_HOME>/repository/deployment/server/jaggeryapps/store/site/conf/site.json
Configuring WSO2 API Manager apps as SAML 2.0 SSO service providers
- OpenÂ
<API-M_Home>/repository/deployment/server/jaggeryapps/publisher/site/conf/site.json
 and modify the following configurations found under ssoConfiguration.- enabled: Set this value to true to enable SSO in the application
- issuer: API_PUBLISHER. This value can change depending on the Issuer value defined in WSO2 IS SSO configuration above.
- identityProviderURL:Â https://localhost:9444/samlsso. Change the IP and port accordingly. This is the redirecting SSO URL in your running WSO2 IS server instance.
- keyStoreName: The keystore of the running IDP. As you use a remote instance of WSO2 IS here, you can import the public certificate of the IS keystore to the APIM and then point to the APIM keystore. The default keystore of the APIM isÂ
<API-M_HOME>/repository/resources/security/wso2carbon.jks
. Be sure to give the full path of the keystore here. - keyStorePassword: Password for the above keystore
- identityAlias: wso2carbon
Similarly, configure the API Store with SSO. The only difference in API Store SSO configurations is setting API_STORE as the issuer.
- Reduce the priority of theÂ
SAML2SSOAuthenticator
 configuration in theÂ<API-M_HOME>/repository/conf/security/authenticators.xml
 file.Â
You do this as a workaround for a known issue that will be fixed in a future release. TheÂSAML2SSOAuthenticator
 handler does not process only SAML authentication requests at the moment. If you set its priority higher than that of theÂBasicAuthenticator
 handler, theÂSAML2SSOAuthenticator
 tries to process the basic authentication requests as well. This causes login issues in the API Publisher/Store.
<Authenticator name="SAML2SSOAuthenticator" disabled="false"> <Priority>0</Priority> .... </Authenticator>
You can skip this step if you are using Identity Server 5.2.0 as the IDP.
- Access the API Publisher:Â
https://localhost:<port_number>/publisher
 (e.g.,Âhttps://localhost:9443/publisher
). Observe the request redirect to the WSO2 IS SAML2.0 based SSO login page. For example,
- Enter user credentials. If the user authentication is successful against WSO2 IS, it will redirect to the API Publisher Web application with the user already authenticated.
- Access the API Store application, click its Login link (top, right-hand corner) and verify that the same user is already authenticated in API Store.
Even with SSO enabled, if the user doesn't have sufficient privileges to access API Publisher/Store or any other application, s/he will not be authorized to access them.
To learn more about Single Sign-On with WSO2 Identity Server, see SAML 2.0 Web SSO in the WSO2 Identity Server documentation.