| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 | 
							- [[servlet-saml2login-metadata]]
 
- = Producing `<saml2:SPSSODescriptor>` Metadata
 
- You can publish a metadata endpoint by adding the `Saml2MetadataFilter` to the filter chain, as you'll see below:
 
- [tabs]
 
- ======
 
- Java::
 
- +
 
- [source,java,role="primary"]
 
- ----
 
- DefaultRelyingPartyRegistrationResolver relyingPartyRegistrationResolver =
 
-         new DefaultRelyingPartyRegistrationResolver(this.relyingPartyRegistrationRepository);
 
- Saml2MetadataFilter filter = new Saml2MetadataFilter(
 
-         relyingPartyRegistrationResolver,
 
-         new OpenSamlMetadataResolver());
 
- http
 
-     // ...
 
-     .saml2Login(withDefaults())
 
-     .addFilterBefore(filter, Saml2WebSsoAuthenticationFilter.class);
 
- ----
 
- Kotlin::
 
- +
 
- [source,kotlin,role="secondary"]
 
- ----
 
- val relyingPartyRegistrationResolver: Converter<HttpServletRequest, RelyingPartyRegistration> =
 
-     DefaultRelyingPartyRegistrationResolver(this.relyingPartyRegistrationRepository)
 
- val filter = Saml2MetadataFilter(
 
-     relyingPartyRegistrationResolver,
 
-     OpenSamlMetadataResolver()
 
- )
 
- http {
 
-     //...
 
-     saml2Login { }
 
-     addFilterBefore<Saml2WebSsoAuthenticationFilter>(filter)
 
- }
 
- ----
 
- ======
 
- You can use this metadata endpoint to register your relying party with your asserting party.
 
- This is often as simple as finding the correct form field to supply the metadata endpoint.
 
- By default, the metadata endpoint is `+/saml2/service-provider-metadata/{registrationId}+`.
 
- You can change this by calling the `setRequestMatcher` method on the filter:
 
- [tabs]
 
- ======
 
- Java::
 
- +
 
- [source,java,role="primary"]
 
- ----
 
- filter.setRequestMatcher(new AntPathRequestMatcher("/saml2/metadata/{registrationId}", "GET"));
 
- ----
 
- Kotlin::
 
- +
 
- [source,kotlin,role="secondary"]
 
- ----
 
- filter.setRequestMatcher(AntPathRequestMatcher("/saml2/metadata/{registrationId}", "GET"))
 
- ----
 
- ======
 
- Or, if you have registered a custom relying party registration resolver in the constructor, then you can specify a path without a `registrationId` hint, like so:
 
- [tabs]
 
- ======
 
- Java::
 
- +
 
- [source,java,role="primary"]
 
- ----
 
- filter.setRequestMatcher(new AntPathRequestMatcher("/saml2/metadata", "GET"));
 
- ----
 
- Kotlin::
 
- +
 
- [source,kotlin,role="secondary"]
 
- ----
 
- filter.setRequestMatcher(AntPathRequestMatcher("/saml2/metadata", "GET"))
 
- ----
 
- ======
 
 
  |