Class: OmniAuth::Strategies::WSFed::SAML2Token
- Inherits:
-
Object
- Object
- OmniAuth::Strategies::WSFed::SAML2Token
- Defined in:
- lib/omniauth/strategies/wsfed/saml_2_token.rb
Instance Attribute Summary collapse
-
#document ⇒ Object
Returns the value of attribute document.
Instance Method Summary collapse
- #audience ⇒ Object
- #claims ⇒ Object
-
#initialize(document) ⇒ SAML2Token
constructor
A new instance of SAML2Token.
- #issuer ⇒ Object
Constructor Details
#initialize(document) ⇒ SAML2Token
Returns a new instance of SAML2Token.
8 9 10 |
# File 'lib/omniauth/strategies/wsfed/saml_2_token.rb', line 8 def initialize(document) @document = document end |
Instance Attribute Details
#document ⇒ Object
Returns the value of attribute document.
6 7 8 |
# File 'lib/omniauth/strategies/wsfed/saml_2_token.rb', line 6 def document @document end |
Instance Method Details
#audience ⇒ Object
12 13 14 15 |
# 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 ⇒ Object
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_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 ⇒ Object
17 18 19 |
# File 'lib/omniauth/strategies/wsfed/saml_2_token.rb', line 17 def issuer REXML::XPath.first(document, '//Assertion/Issuer').text end |