Permalink
Cannot retrieve contributors at this time
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?
md-transforms/lib/security_contacts_legacy_list_csv.xsl
Go to fileThis commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
148 lines (127 sloc)
5.12 KB
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?xml version="1.0" encoding="UTF-8"?> | |
<!-- | |
Copyright 2016-2017 Internet2 | |
Licensed under the Apache License, Version 2.0 (the "License"); | |
you may not use this file except in compliance with the License. | |
You may obtain a copy of the License at | |
http://www.apache.org/licenses/LICENSE-2.0 | |
Unless required by applicable law or agreed to in writing, software | |
distributed under the License is distributed on an "AS IS" BASIS, | |
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |
See the License for the specific language governing permissions and | |
limitations under the License. | |
--> | |
<!-- | |
security_contacts_legacy_list_csv.xsl | |
This XSL transform takes a SAML metadata aggregate, matches on every | |
entity descriptor containing a legacy security contact, and produces | |
a CSV file with the following fields: | |
1. Organization Name: md:OrganizationName[@xml:lang='en'] | |
2. Display Name: mdui:DisplayName[@xml:lang='en'] | |
3. Entity ID: @entityID | |
4. Role: "IdP" or "SP" | |
Since all entities are registered by InCommon, all fields are nonempty | |
and well defined. In particular, every entity has either an IdP role | |
or an SP role but not both. | |
--> | |
<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:mdui="urn:oasis:names:tc:SAML:metadata:ui" | |
xmlns:icmd="http://id.incommon.org/metadata"> | |
<!-- search-and-replace constants --> | |
<xsl:variable name="double_quote" select="'"'"/> | |
<xsl:variable name="double_double_quote" select="'""'"/> | |
<!-- output is plain text --> | |
<xsl:output method="text"/> | |
<!-- output the heading line --> | |
<xsl:template match="/"> | |
<xsl:text>Organization Name,Display Name,Entity ID,Role</xsl:text> | |
<xsl:text>
</xsl:text> | |
<xsl:apply-templates/> | |
</xsl:template> | |
<!-- match all entity descriptors with a legacy security contact --> | |
<xsl:template match=" | |
/md:EntitiesDescriptor/md:EntityDescriptor[ | |
md:ContactPerson[ | |
@contactType='other' | |
and | |
@icmd:contactType='http://id.incommon.org/metadata/contactType/security' | |
] | |
] | |
"> | |
<!-- compute the normalized value of md:OrganizationName --> | |
<xsl:variable name="orgName" select="normalize-space(md:Organization/md:OrganizationName[@xml:lang='en'])"/> | |
<!-- escape literal double quotes in md:OrganizationName --> | |
<xsl:variable name="escapedOrgName"> | |
<xsl:call-template name="string-replace-all"> | |
<xsl:with-param name="string" select="$orgName"/> | |
<xsl:with-param name="search" select="$double_quote"/> | |
<xsl:with-param name="replace" select="$double_double_quote"/> | |
</xsl:call-template> | |
</xsl:variable> | |
<!-- output md:OrganizationName --> | |
<xsl:text>"</xsl:text> | |
<xsl:value-of select="$escapedOrgName"/> | |
<xsl:text>"</xsl:text> | |
<!-- compute the normalized value of mdui:DisplayName --> | |
<xsl:variable name="displayName" select="normalize-space(descendant::mdui:UIInfo/mdui:DisplayName[@xml:lang='en'])"/> | |
<!-- escape literal double quotes in mdui:DisplayName --> | |
<xsl:variable name="escapedDisplayName"> | |
<xsl:call-template name="string-replace-all"> | |
<xsl:with-param name="string" select="$displayName"/> | |
<xsl:with-param name="search" select="$double_quote"/> | |
<xsl:with-param name="replace" select="$double_double_quote"/> | |
</xsl:call-template> | |
</xsl:variable> | |
<!-- output mdui:DisplayName --> | |
<xsl:text>,"</xsl:text> | |
<xsl:value-of select="$escapedDisplayName"/> | |
<xsl:text>"</xsl:text> | |
<!-- output the entityID --> | |
<xsl:text>,</xsl:text> | |
<xsl:value-of select="@entityID"/> | |
<!-- output the role --> | |
<xsl:text>,</xsl:text> | |
<xsl:choose> | |
<xsl:when test="md:IDPSSODescriptor"> | |
<xsl:text>IdP</xsl:text> | |
</xsl:when> | |
<xsl:when test="md:SPSSODescriptor"> | |
<xsl:text>SP</xsl:text> | |
</xsl:when> | |
</xsl:choose> | |
<xsl:text>
</xsl:text> | |
</xsl:template> | |
<!-- | |
A named template that performs global (recursive) search-and-replace on a string | |
(similar to fn:replace(string, pattern, replace) in XSLT 2.0). | |
See: http://stackoverflow.com/questions/3067113/xslt-string-replace/3067130#3067130 | |
--> | |
<xsl:template name="string-replace-all"> | |
<xsl:param name="string"/> | |
<xsl:param name="search"/> | |
<xsl:param name="replace"/> | |
<xsl:choose> | |
<xsl:when test="$string = '' or $search = '' or not($search)"> | |
<!-- Prevent this routine from hanging --> | |
<xsl:value-of select="$string"/> | |
</xsl:when> | |
<xsl:when test="contains($string, $search)"> | |
<xsl:value-of select="substring-before($string, $search)"/> | |
<xsl:value-of select="$replace"/> | |
<xsl:call-template name="string-replace-all"> | |
<xsl:with-param name="string" select="substring-after($string, $search)"/> | |
<xsl:with-param name="search" select="$search"/> | |
<xsl:with-param name="replace" select="$replace"/> | |
</xsl:call-template> | |
</xsl:when> | |
<xsl:otherwise> | |
<xsl:value-of select="$string"/> | |
</xsl:otherwise> | |
</xsl:choose> | |
</xsl:template> | |
<xsl:template match="text()"> | |
<!-- do nothing --> | |
</xsl:template> | |
</xsl:stylesheet> |