The Embedded Discovery Service (EDS) allows a Service Provider to run a discovery service within their own site. As such the discovery service can look like any other page on the site and thus not be as jarring to a user as being redirected to a totally different, third-party, discovery service site. The EDS is a set of Javascript and CSS files, so installing it and using it is straight forward and does not require any additional software. Note: you must already have an installed and configured Shibboleth Service Provider, V2.4+, in order to use the EDS.
- Requirements
- Installation
- Enable EDS on Shibboleth SP
- Configuration
- Whitelist - How to allow IdPs to access the federated resource
- How to allow the access to IdPs by specifying their entityID
- How to allow the access to IdPs that support a specific Entity Category
- How to allow the access to IdPs that support SIRTFI
- Blacklist - How to disallow IdPs to access the federated resource
- How to disallow the access to IdPs by specifying their entityID
- How to disallow the access to IdPs that support a specific Entity Category
- Authors
- Credits
- Apache Server (>= 2.4)
- A working Shibboleth Service Provider (>= 2.4)
- Tested on: Debian/Ubuntu
-
sudo su - cd /usr/local/src wget https://shibboleth.net/downloads/embedded-discovery-service/latest/shibboleth-embedded-ds-1.3.0.tar.gz -O shibboleth-eds.tar.gz tar xzf shibboleth-eds.tar.gz cd shibboleth-embedded-ds-1.3.0 apt install make make install
-
Enable Discovery Service Web Page
mv /etc/shibboleth-ds/shibboleth-ds.conf /etc/apache2/conf-available/shibboleth-ds.conf
-
Enable the Discovery Service Page:
a2enconf shibboleth-ds.conf
-
Restart Apache to load the new web site:
systemctl restart apache2.service
-
Update "
shibboleth2.xml
" file to the new Discovery Service page:-
vim /etc/shibboleth/shibboleth2.xml
<SSO discoveryProtocol="SAMLDS" discoveryURL="https://###YOUR.SP.FQDN###/shibboleth-ds/index.html"> SAML2 </SSO> <!-- SAML and local-only logout. --> <Logout>SAML2 Local</Logout> <!-- ...other things ... --> <!-- JSON feed of discovery information. --> <Handler type="DiscoveryFeed" Location="/DiscoFeed"/>
-
-
Restart "shibd" service:
systemctl restart shibd.service
The behaviour of Shibboleth Embedded Discovery Service is controlled by IdPSelectUIParms
class contained. idpselect_config.js
.
In the most of cases you have to modify only this file to change the behaviour of Discovery Service.
Make sure to amend this.returnWhiteList
to reflect your server name (if you are using Shibboleth EDS < 1.3).
Make sure to amend this.redirectAllow
to reflect your server name (if you are using Shibboleth EDS >= 1.3).
Find here the EDS Configuration Options: https://wiki.shibboleth.net/confluence/display/EDS10/3.+Configuration
DOC: https://shibboleth.atlassian.net/wiki/spaces/SP3/pages/2063696201/IncludeMetadataFilter
- Modify "shibboleth2.xml":
-
vim /etc/shibboleth/shibboleth2.xml
-
Shibboleth SP <= v3.2:
<MetadataProvider type="XML" uri="http://www.garr.it/idem-metadata/idem-metadata-sha256.xml" backingFilePath="idem-metadata-sha256.xml"> <MetadataFilter type="Signature" certificate="/etc/shibboleth/idem_signer_2019.pem"/> <MetadataFilter type="RequireValidUntil" maxValidityInterval="864000" /> <MetadataFilter type="Whitelist"> <Include>https://entityid.idp1.allowed.it/shibboleth</Include> <Include>https://entityid.idp2.allowed.it/shibboleth</Include> <Include>https://entityid.idp3.allowed.it/shibboleth</Include> </MetadataFilter> </MetadataProvider>
-
Shibboleth SP > v3.2:
<MetadataProvider type="XML" uri="http://www.garr.it/idem-metadata/idem-metadata-sha256.xml" backingFilePath="idem-metadata-sha256.xml"> <MetadataFilter type="Signature" certificate="/etc/shibboleth/idem_signer_2019.pem"/> <MetadataFilter type="RequireValidUntil" maxValidityInterval="864000" /> <MetadataFilter type="Include"> <Include>https://entityid.idp1.allowed.it/shibboleth</Include> <Include>https://entityid.idp2.allowed.it/shibboleth</Include> <Include>https://entityid.idp3.allowed.it/shibboleth</Include> </MetadataFilter> </MetadataProvider>
-
-
Restart "shibd" service:
systemctl restart shibd.service
DOC: https://shibboleth.atlassian.net/wiki/spaces/SP3/pages/2063696201/IncludeMetadataFilter
- Modify "shibboleth2.xml":
-
vim /etc/shibboleth/shibboleth2.xml
-
Shibboleth SP <= 3.2:
<MetadataProvider type="XML" uri="http://www.garr.it/idem-metadata/idem-metadata-sha256.xml" backingFilePath="idem-metadata-sha256.xml"> <MetadataFilter type="Signature" certificate="/etc/shibboleth/idem_signer_2019.pem"/> <MetadataFilter type="RequireValidUntil" maxValidityInterval="864000" /> <MetadataFilter type="Whitelist" matcher="EntityAttributes"> <saml:Attribute Name="http://macedir.org/entity-category" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:uri"> <saml:AttributeValue>http://refeds.org/category/research-and-scholarship</saml:AttributeValue> </saml:Attribute> </MetadataFilter> </MetadataProvider>
-
Shibboleth SP > 3.2:
<MetadataProvider type="XML" uri="http://www.garr.it/idem-metadata/idem-metadata-sha256.xml" backingFilePath="idem-metadata-sha256.xml"> <MetadataFilter type="Signature" certificate="/etc/shibboleth/idem_signer_2019.pem"/> <MetadataFilter type="RequireValidUntil" maxValidityInterval="864000" /> <MetadataFilter type="Include" matcher="EntityAttributes"> <saml:Attribute Name="http://macedir.org/entity-category" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:uri"> <saml:AttributeValue>http://refeds.org/category/research-and-scholarship</saml:AttributeValue> </saml:Attribute> </MetadataFilter> </MetadataProvider>
-
-
Restart "shibd" service:
systemctl restart shibd.service
- Modify "shibboleth2.xml":
-
vim /etc/shibboleth/shibboleth2.xml
-
Shibboleth SP <= 3.2:
<MetadataProvider type="XML" uri="http://www.garr.it/idem-metadata/idem-metadata-sha256.xml" backingFilePath="idem-metadata-sha256.xml"> <MetadataFilter type="Signature" certificate="/etc/shibboleth/idem_signer_2019.pem"/> <MetadataFilter type="RequireValidUntil" maxValidityInterval="864000" /> <MetadataFilter type="Whitelist" matcher="EntityAttributes"> <saml:Attribute Name="urn:oasis:names:tc:SAML:attribute:assurancecertification" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:uri"> <saml:AttributeValue>https://refeds.org/sirtfi</saml:AttributeValue> </saml:Attribute> </MetadataFilter> </MetadataProvider>
-
Shibboleth SP > 3.2:
<MetadataProvider type="XML" uri="http://www.garr.it/idem-metadata/idem-metadata-sha256.xml" backingFilePath="idem-metadata-sha256.xml"> <MetadataFilter type="Signature" certificate="/etc/shibboleth/idem_signer_2019.pem"/> <MetadataFilter type="RequireValidUntil" maxValidityInterval="864000" /> <MetadataFilter type="Include" matcher="EntityAttributes"> <saml:Attribute Name="urn:oasis:names:tc:SAML:attribute:assurancecertification" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:uri"> <saml:AttributeValue>https://refeds.org/sirtfi</saml:AttributeValue> </saml:Attribute> </MetadataFilter> </MetadataProvider>
-
-
Restart "shibd" service:
systemctl restart shibd.service
-
Modify "shibboleth2.xml":
-
vim /etc/shibboleth/shibboleth2.xml
-
Shibboleth SP <= 3.2:
<MetadataProvider type="XML" uri="http://www.garr.it/idem-metadata/idem-metadata-sha256.xml" backingFilePath="idem-metadata-sha256.xml"> <MetadataFilter type="Signature" certificate="/etc/shibboleth/idem_signer_2019.pem"/> <MetadataFilter type="RequireValidUntil" maxValidityInterval="864000" /> <MetadataFilter type="Blacklist"> <Include>https://entityid.idp1.denied.it/shibboleth</Include> <Include>https://entityid.idp2.denied.it/shibboleth</Include> <Include>https://entityid.idp3.denied.it/shibboleth</Include> </MetadataFilter> </MetadataProvider>
-
Shibboleth SP > 3.2:
<MetadataProvider type="XML" uri="http://www.garr.it/idem-metadata/idem-metadata-sha256.xml" backingFilePath="idem-metadata-sha256.xml"> <MetadataFilter type="Signature" certificate="/etc/shibboleth/idem_signer_2019.pem"/> <MetadataFilter type="RequireValidUntil" maxValidityInterval="864000" /> <MetadataFilter type="Exclude"> <Include>https://entityid.idp1.denied.it/shibboleth</Include> <Include>https://entityid.idp2.denied.it/shibboleth</Include> <Include>https://entityid.idp3.denied.it/shibboleth</Include> </MetadataFilter> </MetadataProvider>
-
-
-
Restart "shibd" service:
systemctl restart shibd.service
-
Modify "shibboleth2.xml":
-
vim /etc/shibboleth/shibboleth2.xml
-
Shibboleth SP <= 3.2:
<MetadataProvider type="XML" uri="http://www.garr.it/idem-metadata/idem-metadata-sha256.xml" backingFilePath="idem-metadata-sha256.xml"> <MetadataFilter type="Signature" certificate="/etc/shibboleth/idem_signer_2019.pem"/> <MetadataFilter type="RequireValidUntil" maxValidityInterval="864000" /> <MetadataFilter type="Blacklist" matcher="EntityAttributes"> <saml:Attribute Name="http://macedir.org/entity-category" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:uri"> <saml:AttributeValue>https://federation.renater.fr/scope/commercial</saml:AttributeValue> </saml:Attribute> </MetadataFilter> </MetadataProvider>
-
Shibboleth SP > 3.2:
<MetadataProvider type="XML" uri="http://www.garr.it/idem-metadata/idem-metadata-sha256.xml" backingFilePath="idem-metadata-sha256.xml"> <MetadataFilter type="Signature" certificate="/etc/shibboleth/idem_signer_2019.pem"/> <MetadataFilter type="RequireValidUntil" maxValidityInterval="864000" /> <MetadataFilter type="Exclude" matcher="EntityAttributes"> <saml:Attribute Name="http://macedir.org/entity-category" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:uri"> <saml:AttributeValue>https://federation.renater.fr/scope/commercial</saml:AttributeValue> </saml:Attribute> </MetadataFilter> </MetadataProvider>
-
-
-
Restart "shibd" service:
systemctl restart shibd.service
- Marco Malavolti (marco.malavolti@garr.it)