Skip to content

Commit 385219f

Browse files
committed
Allow empty NameID value when no strict or wantNameId is false
1 parent aee67d7 commit 385219f

File tree

3 files changed

+69
-3
lines changed

3 files changed

+69
-3
lines changed

src/Saml2/Response.php

+2-2
Original file line numberDiff line numberDiff line change
@@ -631,16 +631,16 @@ public function getNameIdData()
631631

632632
$nameIdData = array();
633633

634+
$security = $this->_settings->getSecurityData();
634635
if (!isset($nameId)) {
635-
$security = $this->_settings->getSecurityData();
636636
if ($security['wantNameId']) {
637637
throw new ValidationError(
638638
"NameID not found in the assertion of the Response",
639639
ValidationError::NO_NAMEID
640640
);
641641
}
642642
} else {
643-
if ($this->_settings->isStrict() && empty($nameId->nodeValue)) {
643+
if ($this->_settings->isStrict() && $security['wantNameId'] && empty($nameId->nodeValue)) {
644644
throw new ValidationError(
645645
"An empty NameID value found",
646646
ValidationError::EMPTY_NAMEID
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="pfxd188cea4-e29a-a008-5fe1-007d62ba7a97" Version="2.0" IssueInstant="2014-02-19T01:37:01Z" Destination="https://pitbulk.no-ip.org/newonelogin/demo1/index.php?acs" InResponseTo="ONELOGIN_5fe9d6e499b2f0913206aab3f7191729049bb807"><saml:Issuer>http://idp.example.com/</saml: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/2000/09/xmldsig#rsa-sha1"/>
  <ds:Reference URI="#pfxd188cea4-e29a-a008-5fe1-007d62ba7a97"><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/2000/09/xmldsig#sha1"/><ds:DigestValue>uHbmPREPaylys1/YtvZ/ukxI6qI=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>GhroxFYnua4XWbFX8rwfV1yaid1g0yhNp6+5P9aGSwNpBb16jaApIAplPYbYOaPDfon9GtuIFBolAt2osJ4APb8/wbyd3iBTI3yx6EYFDPjlqxNelDtmqXjoQfzpYGir4AKqNh92b/msWsTUEQET/qQZZLJ3jLSLW81xz8AvKfg=</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIICgTCCAeoCCQCbOlrWDdX7FTANBgkqhkiG9w0BAQUFADCBhDELMAkGA1UEBhMCTk8xGDAWBgNVBAgTD0FuZHJlYXMgU29sYmVyZzEMMAoGA1UEBxMDRm9vMRAwDgYDVQQKEwdVTklORVRUMRgwFgYDVQQDEw9mZWlkZS5lcmxhbmcubm8xITAfBgkqhkiG9w0BCQEWEmFuZHJlYXNAdW5pbmV0dC5ubzAeFw0wNzA2MTUxMjAxMzVaFw0wNzA4MTQxMjAxMzVaMIGEMQswCQYDVQQGEwJOTzEYMBYGA1UECBMPQW5kcmVhcyBTb2xiZXJnMQwwCgYDVQQHEwNGb28xEDAOBgNVBAoTB1VOSU5FVFQxGDAWBgNVBAMTD2ZlaWRlLmVybGFuZy5ubzEhMB8GCSqGSIb3DQEJARYSYW5kcmVhc0B1bmluZXR0Lm5vMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDivbhR7P516x/S3BqKxupQe0LONoliupiBOesCO3SHbDrl3+q9IbfnfmE04rNuMcPsIxB161TdDpIesLCn7c8aPHISKOtPlAeTZSnb8QAu7aRjZq3+PbrP5uW3TcfCGPtKTytHOge/OlJbo078dVhXQ14d1EDwXJW1rRXuUt4C8QIDAQABMA0GCSqGSIb3DQEBBQUAA4GBACDVfp86HObqY+e8BUoWQ9+VMQx1ASDohBjwOsg2WykUqRXF+dLfcUH9dWR63CtZIKFDbStNomPnQz7nbK+onygwBspVEbnHuUihZq3ZUdmumQqCw4Uvs/1Uvq3orOo/WJVhTyvLgFVK2QarQ4/67OZfHd7R+POBXhophSMv1ZOo</ds:X509Certificate></ds:X509Data></ds:KeyInfo></ds:Signature><samlp:Status><samlp:StatusCode Value="urn:oasis:names:tc:SAML:2.0:status:Success"/></samlp:Status><saml:Assertion xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="pfxa3528dfb-5ee4-e36e-1049-ba2b65269e24" Version="2.0" IssueInstant="2014-02-19T01:37:01Z"><saml:Issuer>http://idp.example.com/</saml: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/2000/09/xmldsig#rsa-sha1"/>
  <ds:Reference URI="#pfxa3528dfb-5ee4-e36e-1049-ba2b65269e24"><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/2000/09/xmldsig#sha1"/><ds:DigestValue>k8LwnazB1+aQHAL6TM+1IrCl5E4=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>ryqPbD54147sCad8vGpVlhgRMr5fUjYmKGr3zFAiYElZ3H04epNg2swuSk0Oo2988OyDMvaz8arjctUKldgxrhFt4aNRDaHe4Ly8L8v3HhzOOtq5srFgQkFi/yB45XViAg+2uXhOKP0NraN2Q+axeOQAoz2jn0UkFCxv/RzRypY=</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIICgTCCAeoCCQCbOlrWDdX7FTANBgkqhkiG9w0BAQUFADCBhDELMAkGA1UEBhMCTk8xGDAWBgNVBAgTD0FuZHJlYXMgU29sYmVyZzEMMAoGA1UEBxMDRm9vMRAwDgYDVQQKEwdVTklORVRUMRgwFgYDVQQDEw9mZWlkZS5lcmxhbmcubm8xITAfBgkqhkiG9w0BCQEWEmFuZHJlYXNAdW5pbmV0dC5ubzAeFw0wNzA2MTUxMjAxMzVaFw0wNzA4MTQxMjAxMzVaMIGEMQswCQYDVQQGEwJOTzEYMBYGA1UECBMPQW5kcmVhcyBTb2xiZXJnMQwwCgYDVQQHEwNGb28xEDAOBgNVBAoTB1VOSU5FVFQxGDAWBgNVBAMTD2ZlaWRlLmVybGFuZy5ubzEhMB8GCSqGSIb3DQEJARYSYW5kcmVhc0B1bmluZXR0Lm5vMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDivbhR7P516x/S3BqKxupQe0LONoliupiBOesCO3SHbDrl3+q9IbfnfmE04rNuMcPsIxB161TdDpIesLCn7c8aPHISKOtPlAeTZSnb8QAu7aRjZq3+PbrP5uW3TcfCGPtKTytHOge/OlJbo078dVhXQ14d1EDwXJW1rRXuUt4C8QIDAQABMA0GCSqGSIb3DQEBBQUAA4GBACDVfp86HObqY+e8BUoWQ9+VMQx1ASDohBjwOsg2WykUqRXF+dLfcUH9dWR63CtZIKFDbStNomPnQz7nbK+onygwBspVEbnHuUihZq3ZUdmumQqCw4Uvs/1Uvq3orOo/WJVhTyvLgFVK2QarQ4/67OZfHd7R+POBXhophSMv1ZOo</ds:X509Certificate></ds:X509Data></ds:KeyInfo></ds:Signature><saml:Subject><saml:NameID Format="urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress"/><saml:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer"><saml:SubjectConfirmationData NotOnOrAfter="2993-08-23T06:57:01Z" Recipient="https://pitbulk.no-ip.org/newonelogin/demo1/index.php?acs" InResponseTo="ONELOGIN_5fe9d6e499b2f0913206aab3f7191729049bb807"/></saml:SubjectConfirmation></saml:Subject><saml:Conditions NotBefore="2014-02-19T01:36:31Z" NotOnOrAfter="2993-08-23T06:57:01Z"><saml:AudienceRestriction><saml:Audience>http://stuff.com/endpoints/metadata.php</saml:Audience></saml:AudienceRestriction></saml:Conditions><saml:AuthnStatement AuthnInstant="2014-02-19T01:37:01Z" SessionNotOnOrAfter="2993-02-19T09:37:01Z" SessionIndex="_6273d77b8cde0c333ec79d22a9fa0003b9fe2d75cb"><saml:AuthnContext><saml:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:Password</saml:AuthnContextClassRef></saml:AuthnContext></saml:AuthnStatement><saml:AttributeStatement><saml:Attribute Name="uid" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic"><saml:AttributeValue xsi:type="xs:string">smartin</saml:AttributeValue></saml:Attribute><saml:Attribute Name="mail" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic"><saml:AttributeValue xsi:type="xs:string">smartin@yaco.es</saml:AttributeValue></saml:Attribute><saml:Attribute Name="cn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic"><saml:AttributeValue xsi:type="xs:string">Sixto3</saml:AttributeValue></saml:Attribute><saml:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic"><saml:AttributeValue xsi:type="xs:string">Martin2</saml:AttributeValue></saml:Attribute><saml:Attribute Name="eduPersonAffiliation" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic"><saml:AttributeValue xsi:type="xs:string">user</saml:AttributeValue><saml:AttributeValue xsi:type="xs:string">admin</saml:AttributeValue></saml:Attribute></saml:AttributeStatement></saml:Assertion></samlp:Response>

tests/src/OneLogin/Saml2/ResponseTest.php

+66-1
Original file line numberDiff line numberDiff line change
@@ -415,6 +415,71 @@ public function testGetNameIdData()
415415
} catch (ValidationError $e) {
416416
$this->assertStringContainsString('An empty NameID value found', $e->getMessage());
417417
}
418+
419+
$xml7 = file_get_contents(TEST_ROOT . '/data/responses/invalids/no_value_nameid.xml.base64');
420+
$response11 = new Response($this->_settings, $xml7);
421+
$nameIdData12 = $response11->getNameIdData();
422+
$expectedNameIdData10 = array(
423+
'Value' => "",
424+
'Format' => "urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress"
425+
);
426+
$this->assertEquals($expectedNameIdData10, $nameIdData12);
427+
428+
$settingsDir = TEST_ROOT .'/settings/';
429+
include $settingsDir.'settings1.php';
430+
431+
$settingsInfo['strict'] = true;
432+
$settingsInfo['security']['wantNameId'] = true;
433+
434+
$settings = new Settings($settingsInfo);
435+
$response12 = new Response($settings, $xml7);
436+
437+
try {
438+
$nameIdData13 = $response12->getNameIdData();
439+
$this->fail('ValidationError was not raised');
440+
} catch (ValidationError $e) {
441+
$this->assertStringContainsString('An empty NameID value found', $e->getMessage());
442+
}
443+
444+
$settingsInfo['security']['wantNameId'] = false;
445+
446+
$settings = new Settings($settingsInfo);
447+
$response13 = new Response($settings, $xml7);
448+
449+
$nameIdData14 = $response13->getNameIdData();
450+
451+
$expectedNameIdData11 = array(
452+
'Value' => "",
453+
'Format' => "urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress"
454+
);
455+
$this->assertEquals($expectedNameIdData11, $nameIdData14);
456+
457+
$settingsInfo['strict'] = false;
458+
$settingsInfo['security']['wantNameId'] = true;
459+
460+
$settings = new Settings($settingsInfo);
461+
$response14 = new Response($settings, $xml7);
462+
463+
$nameIdData15 = $response14->getNameIdData();
464+
465+
$expectedNameIdData12 = array(
466+
'Value' => "",
467+
'Format' => "urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress"
468+
);
469+
$this->assertEquals($expectedNameIdData12, $nameIdData15);
470+
471+
$settingsInfo['security']['wantNameId'] = false;
472+
473+
$settings = new Settings($settingsInfo);
474+
$response15 = new Response($settings, $xml7);
475+
476+
$nameIdData16 = $response15->getNameIdData();
477+
478+
$expectedNameIdData13 = array(
479+
'Value' => "",
480+
'Format' => "urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress"
481+
);
482+
$this->assertEquals($expectedNameIdData13, $nameIdData16);
418483
}
419484

420485
/**
@@ -643,7 +708,7 @@ public function testGetAttributes()
643708
}
644709

645710
/**
646-
* Tests the getAttributesWithFriendlyName method of the OneLogin_Saml2_Response
711+
* Tests the getAttributesWithFriendlyName method of the Response
647712
*
648713
* @covers OneLogin\Saml2\Response::getAttributesWithFriendlyName
649714
*/

0 commit comments

Comments
 (0)