Class: OmniAuth::Strategies::WSFed::SAML1Token

Inherits:
Object
  • Object
show all
Defined in:
lib/omniauth/strategies/wsfed/saml_1_token.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(document) ⇒ SAML1Token

Returns a new instance of SAML1Token.



8
9
10
# File 'lib/omniauth/strategies/wsfed/saml_1_token.rb', line 8

def initialize(document)
  @document = document
end

Instance Attribute Details

#documentObject

Returns the value of attribute document.



6
7
8
# File 'lib/omniauth/strategies/wsfed/saml_1_token.rb', line 6

def document
  @document
end

Instance Method Details

#audienceObject



12
13
14
15
# File 'lib/omniauth/strategies/wsfed/saml_1_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, '//wsa:EndpointReference/wsa:Address').text
end

#claimsObject



21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
# File 'lib/omniauth/strategies/wsfed/saml_1_token.rb', line 21

def claims
  stmt_element = REXML::XPath.first(document, '//saml:Assertion/saml:AttributeStatement')

  return {} if stmt_element.nil?

  {}.tap do |result|
    stmt_element.each_element('saml:Attribute') do |attr_element|
      name  = attr_element.attributes['AttributeName']

      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

#issuerObject



17
18
19
# File 'lib/omniauth/strategies/wsfed/saml_1_token.rb', line 17

def issuer
  REXML::XPath.first(document, '//saml:Assertion').attributes['Issuer']
end