EntityRoleFilter
Namespace: urn:mace:shibboleth:2.0:metadata
Schema: http://shibboleth.net/schema/idp/shibboleth-metadata.xsd
Overview
The EntityRole
filter removes unwanted role descriptors from entity metadata. Depending on the size and composition of the input, metadata filtered in this way may have a significantly reduced memory footprint.
For example, suppose an IdP loads (and reloads) metadata from a remote HTTP source using a FileBackedHTTPMetadataProvider. Since the IdP is focused on the <md:SPSSODescriptor>
elements in the metadata aggregate, all other role descriptors may be removed. See below for an explicit example.
Filter order is important!
This filter changes the content of the metadata and so a filter of this type should appear after any SignatureValidationFilter in the overall sequence of filters.
Reference
Examples
The following example retains all <md:SPSSODescriptor>
elements in the input:
Retain SP roles unsafe-only
<MetadataFilter xsi:type="EntityRole" xmlns:md="urn:oasis:names:tc:SAML:2.0:metadata">
<RetainedRole>md:SPSSODescriptor</RetainedRole>
</MetadataFilter>
If a particular entity in the input contains no <md:SPSSODescriptor>
child element, all role descriptors are removed from the entity. If the value of the removeRolelessEntityDescriptors
attribute is true (which it is by default), the entity itself is removed as well.
If the value of the removeEmptyEntitiesDescriptors
attribute is true (which it is by default), any <md:EntitiesDescriptor>
element that contains neither an <md:EntityDescriptor>
element nor an <md:EntitiesDescriptor>
element is removed as well.