class OmniAuth::Strategies::WSFed::SAML2Token

Attributes

document[RW]

Public Class Methods

new(document) click to toggle source
# File lib/omniauth/strategies/wsfed/saml_2_token.rb, line 8
def initialize(document)
  @document = document
end

Public Instance Methods

audience() click to toggle source
# File lib/omniauth/strategies/wsfed/saml_2_token.rb, line 12
def audience
  applies_to = REXML::XPath.first(document, '//t:RequestSecurityTokenResponse/wsp:AppliesTo', { 't' => WS_TRUST, 'wsp' => WS_POLICY })
  REXML::XPath.first(applies_to, '//EndpointReference/Address').text
end
claims() click to toggle source
# File lib/omniauth/strategies/wsfed/saml_2_token.rb, line 21
def claims
  stmt_element = REXML::XPath.first(document, '//Assertion/AttributeStatement')

  return {} if stmt_element.nil?

  {}.tap do |result|
    stmt_element.elements.each do |attr_element|
      name  = attr_element.attributes['Name']

      if attr_element.elements.count > 1
        value = []
        attr_element.elements.each { |element| value << element.text }
      else
        value = attr_element.elements.first.text.to_s.lstrip.rstrip
      end

      result[name] = value
    end
  end
end
issuer() click to toggle source
# File lib/omniauth/strategies/wsfed/saml_2_token.rb, line 17
def issuer
  REXML::XPath.first(document, '//Assertion/Issuer').text
end