Skip to content
Permalink
main
Switch branches/tags

Name already in use

A tag already exists with the provided branch name. Many Git commands accept both tag and branch names, so creating this branch may cause unexpected behavior. Are you sure you want to create this branch?
Go to file
Latest commit 9bef3e5 Apr 16, 2024 History
From commit hash ukf/ukf-testbed/1a81732a7c90d839c48a97e408b302903423c8e5

See ukf/ukf-meta#416 for details
1 contributor

Users who have contributed to this file

83 lines (72 sloc) 3.45 KB
<?xml version="1.0" encoding="UTF-8"?>
<!--
check_saml1.xsl
Checking ruleset containing rules associated with the SAML 1.x specification.
Author: Ian A. Young <ian@iay.org.uk>
-->
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:md="urn:oasis:names:tc:SAML:2.0:metadata"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="urn:oasis:names:tc:SAML:2.0:metadata">
<!--
Common support functions.
-->
<xsl:import href="check_framework.xsl"/>
<!--
A service provider claiming to support SAML 1.1 should include an appropriate POST AssertionConsumerService.
-->
<xsl:template match="md:EntityDescriptor/md:SPSSODescriptor[contains(@protocolSupportEnumeration, 'urn:oasis:names:tc:SAML:1.1:protocol')]
[not(md:AssertionConsumerService[@Binding = 'urn:oasis:names:tc:SAML:1.0:profiles:browser-post'])]">
<xsl:call-template name="error">
<xsl:with-param name="m">no POST support on SAML 1.1 SP</xsl:with-param>
</xsl:call-template>
</xsl:template>
<!--
An IdP with a SAML 1.1 AttributeAuthority needs an AttributeService with an appropriate Binding.
-->
<xsl:template match="md:AttributeAuthorityDescriptor
[contains(@protocolSupportEnumeration, 'urn:oasis:names:tc:SAML:1.1:protocol') and
not(md:AttributeService[@Binding='urn:oasis:names:tc:SAML:1.0:bindings:SOAP-binding'])]
">
<xsl:call-template name="error">
<xsl:with-param name="m">SAML 1.1 AttributeAuthority missing appropriately bound AttributeService</xsl:with-param>
</xsl:call-template>
</xsl:template>
<!--
Use of SAML 1.0 bindings requires SAML 1.1 in protocolSupportEnumeration.
-->
<xsl:template match="md:IDPSSODescriptor
[not(contains(@protocolSupportEnumeration, 'urn:oasis:names:tc:SAML:1.1:protocol')) and
md:*/@Binding[starts-with(., 'urn:oasis:names:tc:SAML:1.0:')]]">
<xsl:call-template name="error">
<xsl:with-param name="m">
<xsl:text>SAML 1.0 binding requires SAML 1.1 token in IDPSSODescriptor/@protocolSupportEnumeration</xsl:text>
</xsl:with-param>
</xsl:call-template>
</xsl:template>
<!--
Use of SAML 1.0 bindings requires SAML 1.1 in protocolSupportEnumeration.
-->
<xsl:template match="md:AttributeAuthorityDescriptor
[not(contains(@protocolSupportEnumeration, 'urn:oasis:names:tc:SAML:1.1:protocol')) and
md:*/@Binding[starts-with(., 'urn:oasis:names:tc:SAML:1.0:')]]">
<xsl:call-template name="error">
<xsl:with-param name="m">
<xsl:text>SAML 1.0 binding requires SAML 1.1 token in AttributeAuthorityDescriptor/@protocolSupportEnumeration</xsl:text>
</xsl:with-param>
</xsl:call-template>
</xsl:template>
<!--
Use of SAML 1.0 bindings requires SAML 1.1 in protocolSupportEnumeration.
-->
<xsl:template match="md:SPSSODescriptor
[not(contains(@protocolSupportEnumeration, 'urn:oasis:names:tc:SAML:1.1:protocol')) and
md:*/@Binding[starts-with(., 'urn:oasis:names:tc:SAML:1.0:')]]">
<xsl:call-template name="error">
<xsl:with-param name="m">
<xsl:text>SAML 1.0 binding requires SAML 1.1 token in SPSSODescriptor/@protocolSupportEnumeration</xsl:text>
</xsl:with-param>
</xsl:call-template>
</xsl:template>
</xsl:stylesheet>