Skip to content

Commit 55a2389

Browse files
committed
Support AES-128-GCM, AES-192-GCM, and AES-256-GCM encryptions
Support GCM algorithm encryption in assertion decryption. Resolves #541
1 parent 9f710c5 commit 55a2389

5 files changed

Lines changed: 37 additions & 0 deletions

lib/onelogin/ruby-saml/utils.rb

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -253,6 +253,9 @@ def self.retrieve_plaintext(cipher_text, symmetric_key, algorithm)
253253
when 'http://www.w3.org/2001/04/xmlenc#aes128-cbc' then cipher = OpenSSL::Cipher.new('AES-128-CBC').decrypt
254254
when 'http://www.w3.org/2001/04/xmlenc#aes192-cbc' then cipher = OpenSSL::Cipher.new('AES-192-CBC').decrypt
255255
when 'http://www.w3.org/2001/04/xmlenc#aes256-cbc' then cipher = OpenSSL::Cipher.new('AES-256-CBC').decrypt
256+
when 'http://www.w3.org/2009/xmlenc11#aes128-gcm' then auth_cipher = OpenSSL::Cipher.new('AES-128-GCM').decrypt
257+
when 'http://www.w3.org/2009/xmlenc11#aes192-gcm' then auth_cipher = OpenSSL::Cipher.new('AES-192-GCM').decrypt
258+
when 'http://www.w3.org/2009/xmlenc11#aes256-gcm' then auth_cipher = OpenSSL::Cipher.new('AES-256-GCM').decrypt
256259
when 'http://www.w3.org/2001/04/xmlenc#rsa-1_5' then rsa = symmetric_key
257260
when 'http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p' then oaep = symmetric_key
258261
end
@@ -263,6 +266,16 @@ def self.retrieve_plaintext(cipher_text, symmetric_key, algorithm)
263266
cipher.padding, cipher.key, cipher.iv = 0, symmetric_key, cipher_text[0..iv_len-1]
264267
assertion_plaintext = cipher.update(data)
265268
assertion_plaintext << cipher.final
269+
elsif auth_cipher
270+
iv_len, text_len, tag_len = auth_cipher.iv_len, cipher_text.length, 16
271+
data = cipher_text[iv_len..text_len-1-tag_len]
272+
auth_cipher.padding = 0
273+
auth_cipher.key = symmetric_key
274+
auth_cipher.iv = cipher_text[0..iv_len-1]
275+
auth_cipher.auth_data = ''
276+
auth_cipher.auth_tag = cipher_text[text_len-tag_len..-1]
277+
assertion_plaintext = auth_cipher.update(data)
278+
assertion_plaintext << auth_cipher.final
266279
elsif rsa
267280
rsa.private_decrypt(cipher_text)
268281
elsif oaep

test/response_test.rb

Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1572,6 +1572,27 @@ def generate_audience_error(expected, actual)
15721572
assert_equal "test", response.attributes[:uid]
15731573
assert_equal "_ce3d2948b4cf20146dee0a0b3dd6f69b6cf86f62d7", response.nameid
15741574
end
1575+
1576+
it "EncryptionMethod AES-128-GCM && Key Encryption Algorithm RSA-OAEP-MGF1P" do
1577+
unsigned_message_aes128gcm_encrypted_signed_assertion = read_response('unsigned_message_aes128gcm_encrypted_signed_assertion.xml.base64')
1578+
response = OneLogin::RubySaml::Response.new(unsigned_message_aes128gcm_encrypted_signed_assertion, :settings => settings)
1579+
assert_equal "test", response.attributes[:uid]
1580+
assert_equal "_ce3d2948b4cf20146dee0a0b3dd6f69b6cf86f62d7", response.nameid
1581+
end
1582+
1583+
it "EncryptionMethod AES-192-GCM && Key Encryption Algorithm RSA-OAEP-MGF1P" do
1584+
unsigned_message_aes192gcm_encrypted_signed_assertion = read_response('unsigned_message_aes192gcm_encrypted_signed_assertion.xml.base64')
1585+
response = OneLogin::RubySaml::Response.new(unsigned_message_aes192gcm_encrypted_signed_assertion, :settings => settings)
1586+
assert_equal "test", response.attributes[:uid]
1587+
assert_equal "_ce3d2948b4cf20146dee0a0b3dd6f69b6cf86f62d7", response.nameid
1588+
end
1589+
1590+
it "EncryptionMethod AES-256-GCM && Key Encryption Algorithm RSA-OAEP-MGF1P" do
1591+
unsigned_message_aes256gcm_encrypted_signed_assertion = read_response('unsigned_message_aes256gcm_encrypted_signed_assertion.xml.base64')
1592+
response = OneLogin::RubySaml::Response.new(unsigned_message_aes256gcm_encrypted_signed_assertion, :settings => settings)
1593+
assert_equal "test", response.attributes[:uid]
1594+
assert_equal "_ce3d2948b4cf20146dee0a0b3dd6f69b6cf86f62d7", response.nameid
1595+
end
15751596
end
15761597

15771598
end
Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
<?xml version="1.0"?>
<samlp:Response xmlns:samlp="urn:oasis:names:tc:SAML:2.0:protocol"
  xmlns:saml="urn:oasis:names:tc:SAML:2.0:assertion" ID="_8e8dc5f69a98cc4c1ff3427e5ce34606fd672f91e6" Version="2.0" IssueInstant="2014-07-17T01:01:48Z" Destination="http://sp.example.com/demo1/index.php?acs" InResponseTo="ONELOGIN_4fee3b046395c4e751011e97f8900b5273d56685">
  <saml:Issuer>http://idp.example.com/metadata.php</saml:Issuer>
  <samlp:Status>
    <samlp:StatusCode Value="urn:oasis:names:tc:SAML:2.0:status:Success"/>
  </samlp:Status>
  <saml:EncryptedAssertion>
    <xenc:EncryptedData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#"
      xmlns:ds="http://www.w3.org/2000/09/xmldsig#" Type="http://www.w3.org/2001/04/xmlenc#Element">
      <xenc:EncryptionMethod Algorithm="http://www.w3.org/2009/xmlenc11#aes128-gcm"/>
      <ds:KeyInfo xmlns:ds="http://www.w3.org/2000/09/xmldsig#">
        <xenc:EncryptedKey>
          <xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p"/>
          <xenc:CipherData>
            <xenc:CipherValue>EbYNojxeI/XseXaOKLiDjEdvFVQyaj86r3dydaOnSdHl+CfVdi1JJK3H7dDoLGs9 aYlwe/mqkA6eIvu1m5c7xT6scTzNllYjqjeiICTKZiGsohcLM1mKyfmfQJIyt8g0 I7R219WJGHNwnv0iu979oyoJD0xn73Hi6Vg1wCdMaKQ=</xenc:CipherValue>
          </xenc:CipherData>
        </xenc:EncryptedKey>
      </ds:KeyInfo>
      <xenc:CipherData>
        <xenc:CipherValue>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</xenc:CipherValue>
      </xenc:CipherData>
    </xenc:EncryptedData>
  </saml:EncryptedAssertion>
</samlp:Response>

0 commit comments

Comments
 (0)