This is a SAML discovery service written in PHP.
It follows Identity Provider Discovery Service Protocol and Profile because mod_auth_mellon seems to support that. So why not?
- Logo support, extracted from (eduGAIN) metadata;
- Most browsers are supported;
- JS not required (works perfectly well with JS disabled);
- Keyboard navigation using
<TAB>to select (next/previous) IdP;
- Filter (keyword) support, i.e. only show entries that (string) match the filter you provide, also without JS.
The discovery service is tested with the following browsers:
- Firefox (latest)
- Google Chrome (latest);
- Safari on iOS (latest);
- Internet Explorer 11;
A generator script that takes SAML metadata file(s) and extracts the IdPs based on the entityIDs that are set in the configuration file. It writes out two files:
- A stripped down SAML metadata file containing only the required entries for use by mod_auth_mellon;
- A JSON file containing information about the IdPs for use by the discovery service.
The stripped down SAML metadata file is needed because mod_auth_mellon, at least the version shipped with CentOS 7, is unusably slow if you use e.g. the entire eduGAIN metadata file.
A service that used the JSON file to display a discovery page where the user can select their IdP. See the screenshots.
With logos (optional):
In case you want to override the default template, it usually suffices to copy
config/views/base.php and modify it there, e.g. adding
additional CSS files.
The software is written in PHP, and requires PHP >= 5.4 together with the imagick PECL extension. This extension is available on RHEL/CentOS (EPEL) and Debian.
contrib/ directory contains some scripts to download SAML metadata from
eduGAIN, verify the signature and place it in the
All (source) metadata files you want to use should be placed in the
config/metadata directory and have a
Specify the entityIDs of the IdPs you want to support in the
To run the generator, make sure the metadata files are located in the
config/metadata directory and a writable
data/ directory exists.
$ php bin/generate.php
This will generate the JSON and XML file mentioned above, and download and scale/compress all IdP logos if enabled, and if they are available in the metadata file.
I found some other options when investigating how to do SAML discovery:
They were not really what I wanted.
$ git clone https://git.tuxed.net/fkooman/php-saml-ds $ cd php-saml-ds $ composer install $ cp config/config.php.example config/config.php
Now, you need to configure something in
config/config.php and add some
metadata files to read from in
$ mkdir config/metadata $ curl -L -o config/metadata/SURFconext.xml https://engine.surfconext.nl/authentication/proxy/idps-metadata
data/ directory and run the
generator script that creates a JSON
and SAML metadata file and (optionally) fetches the logos specified in the
$ mkdir data $ php bin/generate.php
Create a symlink, so the logos are available under the
$ (cd web && ln -s ../data/logo)
Now, you can start the PHP built-in web server:
$ php -S localhost:8080 -t web/
Browse to http://localhost:8080/index.php and provide the following query parameters:
entityID MUST match one of the registered SPs in your