Skip to content

Commit c2fd1d6

Browse files
committed
Fix #23. Handle EncryptedAssertion that contains a EncryptedData that contains a KeyInfo with a reference, not the EncryptedKey to be used
1 parent dcc0b23 commit c2fd1d6

4 files changed

Lines changed: 51 additions & 3 deletions

File tree

core/src/main/java/com/onelogin/saml2/authn/SamlResponse.java

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -162,7 +162,7 @@ public boolean isValid(String requestId) {
162162

163163
String responseTag = "{" + Constants.NS_SAMLP + "}Response";
164164
String assertionTag = "{" + Constants.NS_SAML + "}Assertion";
165-
165+
166166
final boolean hasSignedResponse = signedElements.contains(responseTag);
167167
final boolean hasSignedAssertion = signedElements.contains(assertionTag);
168168

@@ -741,7 +741,7 @@ public ArrayList<String> processSignedElements() throws Exception {
741741
for (int i = 0; i < signNodes.getLength(); i++) {
742742
Node signNode = signNodes.item(i);
743743
String signedElement = "{" + signNode.getParentNode().getNamespaceURI() + "}" + signNode.getParentNode().getLocalName();
744-
744+
745745
String responseTag = "{" + Constants.NS_SAMLP + "}Response";
746746
String assertionTag = "{" + Constants.NS_SAML + "}Assertion";
747747

@@ -817,7 +817,7 @@ public boolean validateSignedElements(ArrayList<String> signedElements) throws E
817817

818818
String responseTag = "{" + Constants.NS_SAMLP + "}Response";
819819
String assertionTag = "{" + Constants.NS_SAML + "}Assertion";
820-
820+
821821
if ((occurrences.containsKey(responseTag) && occurrences.get(responseTag) > 1)
822822
|| (occurrences.containsKey(assertionTag) && occurrences.get(assertionTag) > 1)
823823
|| !occurrences.containsKey(responseTag) && !occurrences.containsKey(assertionTag)) {

core/src/main/java/com/onelogin/saml2/util/Util.java

Lines changed: 31 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -54,6 +54,7 @@
5454
import org.apache.commons.codec.binary.Base64;
5555
import org.apache.commons.codec.digest.DigestUtils;
5656
import org.apache.commons.lang3.StringUtils;
57+
import org.apache.xml.security.encryption.CipherData;
5758
import org.apache.xml.security.encryption.EncryptedData;
5859
import org.apache.xml.security.encryption.EncryptedKey;
5960
import org.apache.xml.security.encryption.XMLCipher;
@@ -899,6 +900,36 @@ public static void decryptElement(Element encryptedDataElement, PrivateKey input
899900

900901
XMLCipher xmlCipher = XMLCipher.getInstance();
901902
xmlCipher.init(XMLCipher.DECRYPT_MODE, null);
903+
904+
/* Check if we have encryptedData with a KeyInfo that contains a RetrievalMethod to obtain the EncryptedKey.
905+
xmlCipher is not able to handle that so we move the EncryptedKey inside the KeyInfo element and
906+
replacing the RetrievalMethod.
907+
*/
908+
909+
NodeList keyInfoInEncData = encryptedDataElement.getElementsByTagNameNS(Constants.NS_DS, "KeyInfo");
910+
if (keyInfoInEncData.getLength() == 0) {
911+
throw new Exception("No KeyInfo inside EncryptedData element");
912+
}
913+
914+
NodeList childs = keyInfoInEncData.item(0).getChildNodes();
915+
for (int i=0; i < childs.getLength(); i++) {
916+
if (childs.item(i).getLocalName() != null && childs.item(i).getLocalName().equals("RetrievalMethod")) {
917+
Element retrievalMethodElem = (Element)childs.item(i);
918+
if (!retrievalMethodElem.getAttribute("Type").equals("http://www.w3.org/2001/04/xmlenc#EncryptedKey")) {
919+
throw new Exception("Unsupported Retrieval Method found");
920+
}
921+
922+
String uri = retrievalMethodElem.getAttribute("URI").substring(1);
923+
924+
NodeList encryptedKeyNodes = ((Element) encryptedDataElement.getParentNode()).getElementsByTagNameNS(Constants.NS_XENC, "EncryptedKey");
925+
for (int j=0; j < encryptedKeyNodes.getLength(); j++) {
926+
if (((Element)encryptedKeyNodes.item(j)).getAttribute("Id").equals(uri)) {
927+
keyInfoInEncData.item(0).replaceChild(encryptedKeyNodes.item(j), childs.item(i));
928+
}
929+
}
930+
}
931+
}
932+
902933
xmlCipher.setKEK(inputKey);
903934
xmlCipher.doFinal(encryptedDataElement.getOwnerDocument(), encryptedDataElement, false);
904935
} catch (Exception e) {

core/src/test/java/com/onelogin/saml2/test/authn/AuthnResponseTest.java

Lines changed: 16 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -243,6 +243,22 @@ public void testGetNameIdData() throws Exception {
243243
assertTrue(samlResponse.getNameIdData().isEmpty());
244244
}
245245

246+
/**
247+
* Tests the decryptAssertion method of SamlResponse
248+
* Case: EncryptedAssertion with an encryptedData element with a KeyInfo
249+
* that contains a RetrievalMethod to obtain the EncryptedKey.
250+
*
251+
* @throws Exception
252+
*/
253+
@Test
254+
public void testEncryptedResponse() throws Exception {
255+
Saml2Settings settings = new SettingsBuilder().fromFile("config/config.decrypt.properties").build();
256+
257+
String samlResponseEncoded = Util.getFileAsString("data/responses/response_to_decrypt.xml.base64");
258+
SamlResponse samlResponse = new SamlResponse(settings, newHttpRequest(samlResponseEncoded));
259+
assertEquals("archit.neema@intellicus.com", samlResponse.getNameId());
260+
}
261+
246262
/**
247263
* Tests the getNameIdData method of SamlResponse
248264
* Case: No NameId
Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
<?xml version="1.0" encoding="UTF-8"?><saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="http://172.26.43.81:8080/java-saml-jspsample/acs.jsp" ID="id45536940652496442072802549" InResponseTo="ONELOGIN_cb9dc43a-1333-4ade-8f6d-9ebc6b3721c6" IssueInstant="2016-10-04T10:42:52.129Z" Version="2.0"><saml2:Issuer xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" Format="urn:oasis:names:tc:SAML:2.0:nameid-format:entity">http://www.okta.com/exkphex7xeowKh8zL1t6</saml2:Issuer><ds:Signature xmlns:ds="http://www.w3.org/2000/09/xmldsig#"><ds:SignedInfo><ds:CanonicalizationMethod Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/><ds:SignatureMethod Algorithm="http://www.w3.org/2001/04/xmldsig-more#rsa-sha256"/><ds:Reference URI="#id45536940652496442072802549"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2001/04/xmlenc#sha256"/><ds:DigestValue>a0OhNgSayvyJAq+6vIL9Swx08+URS4giyvQHZHqZ1ko=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>kXeT1jtc5n4CmIypzaPROYQN76y6bBBdi6e1ns32v3y+z/s0dcP2anLmGNO58JS1We8OJTV0PBHyobFLZNOHDcpVrJm58K0bWkwDT+YfKeiG1lztYjHoCQL5bFJanKzHTmwtxK4xZtwEs/vO9FbwKcjurfm0ta1SlcGBuW+nLekJGvxGq6qD5NXD1r6ec5tffDNYV4x3kpDaahnIaQA0MPpcluX2ez13eiMzBZeESXDRA2+tPDZxNF3DMeNUbbSe1NU7us22yogfHepYjjL499UmQ4VAwxJiPz/pqu4l728LboZg2FhIfSftSb9AOza6keU+ZgJ1ZzPopuQ1hy5uwA==</ds:SignatureValue><ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDrjCCApagAwIBAgIGAVdfs8R9MA0GCSqGSIb3DQEBBQUAMIGXMQswCQYDVQQGEwJVUzETMBEG
A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU
MBIGA1UECwwLU1NPUHJvdmlkZXIxGDAWBgNVBAMMD2ludGVsbGljdXNpbmRpYTEcMBoGCSqGSIb3
DQEJARYNaW5mb0Bva3RhLmNvbTAeFw0xNjA5MjUwNDU1MzlaFw0yNjA5MjUwNDU2MzlaMIGXMQsw
CQYDVQQGEwJVUzETMBEGA1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzEN
MAsGA1UECgwET2t0YTEUMBIGA1UECwwLU1NPUHJvdmlkZXIxGDAWBgNVBAMMD2ludGVsbGljdXNp
bmRpYTEcMBoGCSqGSIb3DQEJARYNaW5mb0Bva3RhLmNvbTCCASIwDQYJKoZIhvcNAQEBBQADggEP
ADCCAQoCggEBAKhbZZolJyZHHpSwSbhDbcrfOzsIijFrUuvfMtXeZQukp6tGIzsDqOQm7K7rCFUv
uAPFPUlGv6r191fe3TRH6t3VOkctJEgfFGTOwBPIUw/z6nFb+vD4ycawH6IMh/bD6ri60nHluVsj
czj1twa68OrKMAM5RCER10VGLhqudsGEPOkFP5hiCSPGZLrYyqgUSDJVvtRphdQLVIuXIBEC77D2
eSYn9qG8MaqXeVZvD70ao9UeBFIj2sTXbXCiQLmPIRgETA7jqsVUMErw7MpiWfsnp/PE7j5jKkmi
3iIr4gQnBwlrOvrXQ9QRGhhz6Le2ADnEoW6hyZs+EQWzNorM5ecCAwEAATANBgkqhkiG9w0BAQUF
AAOCAQEAiUXcaPuYNS/1r034ihRuu2dia4fipBMCeaSa1UN09K7Uszp7bnFjjJBiBrlLkVkfsA6k
bwQryHOhPUX6aPQmhcy3FY9WBJ8tv1FPCW0WU0KH2w5tqkUfSFK1hlWsutstclfZqYUV7zdMo996
11y0iPRMMgjADBeXO8YfeHWutCBnzgvRPZDJgJrGTVjA/8IOddDLKbeI9M/QCASLx3gkyvuJXI4v
xjJMAvrUHtWe1TmSLXI4/dGGoXfovr2iAW9F9/pX9pGq2CkIjnLhQmskAiRUtQpnSt8d2MUnJPd+
BrxcE6OdNU7GXM5NrvV6Y9ifsAZYpO9LKUkFCG1Otp7Cgg==</ds:X509Certificate></ds:X509Data></ds:KeyInfo></ds:Signature><saml2p:Status xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol"><saml2p:StatusCode Value="urn:oasis:names:tc:SAML:2.0:status:Success"/></saml2p:Status><saml2:EncryptedAssertion xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion"><xenc:EncryptedData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#" Id="_97f7b619241ab8309ee6964677639222" Type="http://www.w3.org/2001/04/xmlenc#Element"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes256-cbc" xmlns:xenc="http://www.w3.org/2001/04/xmlenc#"/><ds:KeyInfo xmlns:ds="http://www.w3.org/2000/09/xmldsig#"><ds:RetrievalMethod Type="http://www.w3.org/2001/04/xmlenc#EncryptedKey" URI="#_eb3bc687f97be0050c1f944055f49de7"/></ds:KeyInfo><xenc:CipherData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#"><xenc:CipherValue>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</xenc:CipherValue></xenc:CipherData></xenc:EncryptedData><xenc:EncryptedKey xmlns:xenc="http://www.w3.org/2001/04/xmlenc#" Id="_eb3bc687f97be0050c1f944055f49de7"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-1_5" xmlns:xenc="http://www.w3.org/2001/04/xmlenc#"/><ds:KeyInfo xmlns:ds="http://www.w3.org/2000/09/xmldsig#"><ds:X509Data><ds:X509Certificate>MIICQjCCAaugAwIBAgIBADANBgkqhkiG9w0BAQ0FADA+MQswCQYDVQQGEwJ1czELMAkGA1UECAwC
Q0ExDjAMBgNVBAoMBUtZVk9TMRIwEAYDVQQDDAlLWVZPU1RFU1QwHhcNMTYwOTMwMDkxNTE1WhcN
MTcwOTMwMDkxNTE1WjA+MQswCQYDVQQGEwJ1czELMAkGA1UECAwCQ0ExDjAMBgNVBAoMBUtZVk9T
MRIwEAYDVQQDDAlLWVZPU1RFU1QwgZ8wDQYJKoZIhvcNAQEBBQADgY0AMIGJAoGBAMgHww0rFliH
v/8yAfeWTgz3OIDbYGj13AWKxhKHHElmzViYYj6AcGX7iF406RVAFYDPabquY0Axopvx6oSQzelt
7eolRp8prCnJpQw0G99Bet6ke/qrRC4kj7FieEOF8PTVju9qfsIDJ12iLYOz6V2L/5KiXj1NKAeU
ipeU7pMjAgMBAAGjUDBOMB0GA1UdDgQWBBTV9oLgjYy9I7nnx3AgdER4HXJ7bjAfBgNVHSMEGDAW
gBTV9oLgjYy9I7nnx3AgdER4HXJ7bjAMBgNVHRMEBTADAQH/MA0GCSqGSIb3DQEBDQUAA4GBAIqG
GqznJxUtVvrVLigBOWRS8ZeIgIOoTPyS/8+N/eRNEsgg/fVinfHddRRl9aO3x1xxeYqydJX/LM7C
8CcY/XFMBJK3BNBV9+RIxsFwSruGIt4Zlj7mjiNl0AAUCnI9yCDX3YMVQkgobEhgOFKVNvFJ8N2L
JYinfV8V54nqh8/H</ds:X509Certificate></ds:X509Data></ds:KeyInfo><xenc:CipherData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#"><xenc:CipherValue>knsTaacXUn0tSXq5TXdGuVmgPmohYIdGiHjpDAWx/uw2ewTT3CxzK2WsDc9Tri6iAPJ3x22+BmaO/b3JKSnW534XuGJzBijB7n2u8eFeNkfevBwUK3XlIWJyn658bkEzCDdCkioEeDg/LACjwH4TeCiyPHCz1E0JHD0eKmL8sOg=</xenc:CipherValue></xenc:CipherData><xenc:ReferenceList><xenc:DataReference URI="#_97f7b619241ab8309ee6964677639222"/></xenc:ReferenceList></xenc:EncryptedKey></saml2:EncryptedAssertion></saml2p:Response>

0 commit comments

Comments
 (0)