The Single Sign-On (SSO) module enables seamless Single Sign-On functionality for Backdrop CMS installations across multiple subdomains of the same main domain. It leverages Backdrop's native session management to authenticate users across shared environments.
Requirements
To ensure proper functionality, the following requirements must be met:
- To ensure the userbase and sessions are synchronized across all subdomains, configure each site to share specific database tables related to users and sessions. Below are example configurations that can be added to the
settings.php
file of each subdomain to point these tables to the main domain's database:
Backdrop CMS < 1.30.0 - Database settings example
$databases['default']['default'] = array( 'database' => 'subdomain_db', 'username' => 'username', 'password' => 'password', 'host' => 'localhost', 'driver' => 'mysql', 'prefix' => array( 'default' => '', // Local tables for this subdomain. 'users' => 'main_domain_db.', // Shared user table. 'sessions' => 'main_domain_db.', // Shared sessions table. 'users_roles' => 'main_domain_db.', // Shared user roles table. 'realname' => 'main_domain_db.', // Shared real name data. 'field_data_field_first_name' => 'main_domain_db.', // Shared first name field. 'field_revision_field_first_name' => 'main_domain_db.', // Shared first name field revisions. 'field_data_field_last_name' => 'main_domain_db.', // Shared last name field. 'field_revision_field_last_name' => 'main_domain_db.', // Shared last name field revisions. ), );
Backdrop CMS >= 1.30.0 - Database settings example
$database = array( 'database' => 'subdomain_db', 'username' => 'username', 'password' => 'password', 'host' => 'localhost', 'prefix' => array( 'default' => '', // Local tables for this subdomain. 'users' => 'main_domain_db.', // Shared user table. 'sessions' => 'main_domain_db.', // Shared sessions table. 'users_roles' => 'main_domain_db.', // Shared user roles table. 'realname' => 'main_domain_db.', // Shared real name data. 'field_data_field_first_name' => 'main_domain_db.', // Shared first name field. 'field_revision_field_first_name' => 'main_domain_db.', // Shared first name field revisions. 'field_data_field_last_name' => 'main_domain_db.', // Shared last name field. 'field_revision_field_last_name' => 'main_domain_db.', // Shared last name field revisions. ), );
- Cookie Domain Configuration:
- In the settings.php file for each subdomain, set the $cookie_domain variable to allow cookies to be shared across subdomains.
- Example:
$cookie_domain = '.example.com';
- Replace
example.com
with your actual main domain.
Installation
- Place the SSO Module in the modules directory of your Backdrop CMS installation.
- Enable the module in the Backdrop CMS admin interface under Admin > Modules.
- Ensure the
settings.php
file for each subdomain is properly configured as described above.
How It Works
- When a user logs in on one subdomain, Backdrop CMS creates a session entry in the shared
sessions
table and sets a session cookie. - When the user accesses another subdomain:
- The session cookie is read and validated against the shared sessions table.
- If the session is valid, the user is automatically logged in.
Known Limitations
- This module does not support cross-domain SSO (e.g., between example.com and example.net). It works only across subdomains of the same main domain (e.g., sub1.example.com and sub2.example.com).
Issues
Report bugs and feature requests in the Issue Queue:
https://github.com/backdrop-contrib/sso/issues.
Current Maintainers
Credits
License
This project is GPL v2 software. See the LICENSE.txt file in this directory for complete text.