Class: Saml::Kit::IdentityProviderMetadata

Inherits:
Metadata
  • Object
show all
Defined in:
lib/saml/kit/identity_provider_metadata.rb

Overview

This class is used to parse the IDPSSODescriptor from a SAML metadata document.

raw_xml = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<EntityDescriptor xmlns=\"urn:oasis:names:tc:SAML:2.0:metadata\" xmlns:ds=\"http://www.w3.org/2000/09/xmldsig#\" xmlns:saml=\"urn:oasis:names:tc:SAML:2.0:assertion\" ID=\"_cfa24e2f-0ec0-4ee3-abb8-b2fcfe394c1c\" entityID=\"\">\n  <IDPSSODescriptor WantAuthnRequestsSigned=\"true\" protocolSupportEnumeration=\"urn:oasis:names:tc:SAML:2.0:protocol\">\n    <SingleLogoutService Binding=\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST\" Location=\"https://www.example.com/logout\"/>\n    <NameIDFormat>urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress</NameIDFormat>\n    <SingleSignOnService Binding=\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST\" Location=\"https://www.example.com/login\"/>\n    <SingleSignOnService Binding=\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect\" Location=\"https://www.example.com/login\"/>\n    <saml:Attribute Name=\"id\"/>\n  </IDPSSODescriptor>\n</EntityDescriptor>\n"

 = Saml::Kit::.new(raw_xml)
puts .entity_id

It can also be used to generate IDP metadata.

 = Saml::Kit::.build do |builder|
  builder.entity_id = "my-entity-id"
end
puts .to_xml

For more details on generating metadata see Metadata.

Example:

Constant Summary

Constants inherited from Metadata

Metadata::METADATA_XSD, Metadata::NAMESPACES

Instance Attribute Summary

Attributes inherited from Metadata

#name

Instance Method Summary collapse

Methods inherited from Metadata

#certificates, #contact_person_company, #encryption_certificates, #entity_id, from, #logout_request_for, #matches?, #name_id_formats, #organization_name, #organization_url, #service_for, #services, #signature, #signing_certificates, #single_logout_service_for, #single_logout_services, #to_h, #to_s, #to_xml, #verify

Constructor Details

#initialize(xml) ⇒ IdentityProviderMetadata

Returns a new instance of IdentityProviderMetadata.



34
35
36
# File 'lib/saml/kit/identity_provider_metadata.rb', line 34

def initialize(xml)
  super('IDPSSODescriptor', xml)
end

Instance Method Details

#attributesObject

Returns each of the Attributes in the metadata.



59
60
61
62
63
64
65
66
# File 'lib/saml/kit/identity_provider_metadata.rb', line 59

def attributes
  document.find_all("/md:EntityDescriptor/md:#{name}/saml:Attribute").map do |item|
    {
      format: item.attribute('NameFormat').try(:value),
      name: item.attribute('Name').value,
    }
  end
end

#login_request_for(binding:, relay_state: nil, configuration: Saml::Kit.configuration) ⇒ Array

Creates a AuthnRequest document for the specified binding.

Parameters:

  • binding (Symbol)

    :http_post or :http_redirect.

  • relay_state (Object) (defaults to: nil)

    The RelayState to include the returned SAML params.

  • configuration (Saml::Kit::Configuration) (defaults to: Saml::Kit.configuration)

    the configuration to use for generating the request.

Returns:

  • (Array)

    The url and saml params encoded using the rules for the specified binding.



74
75
76
77
78
79
80
81
# File 'lib/saml/kit/identity_provider_metadata.rb', line 74

def (binding:, relay_state: nil, configuration: Saml::Kit.configuration)
  builder = Saml::Kit::AuthenticationRequest.builder(configuration: configuration) do |x|
    x.embed_signature = want_authn_requests_signed
    yield x if block_given?
  end
  request_binding = single_sign_on_service_for(binding: binding)
  request_binding.serialize(builder, relay_state: relay_state)
end

#single_sign_on_service_for(binding:) ⇒ Object

Returns a SingleSignOnService elements with the specified binding.

Parameters:

  • binding (Symbol)

    :http_post or :http_redirect.



54
55
56
# File 'lib/saml/kit/identity_provider_metadata.rb', line 54

def single_sign_on_service_for(binding:)
  service_for(binding: binding, type: 'SingleSignOnService')
end

#single_sign_on_servicesObject

Returns each of the SingleSignOnService elements.



47
48
49
# File 'lib/saml/kit/identity_provider_metadata.rb', line 47

def single_sign_on_services
  services('SingleSignOnService')
end

#want_authn_requests_signedObject

Returns the IDPSSODescriptor/@WantAuthnRequestsSigned attribute.



39
40
41
42
43
44
# File 'lib/saml/kit/identity_provider_metadata.rb', line 39

def want_authn_requests_signed
  xpath = "/md:EntityDescriptor/md:#{name}"
  attribute = document.find_by(xpath).attribute('WantAuthnRequestsSigned')
  return true if attribute.nil?
  attribute.text.casecmp('true').zero?
end