Topic
IC4NOTICE: developerWorks Community will be offline May 29-30, 2015 while we upgrade to the latest version of IBM Connections. For more information, read our upgrade FAQ.
4 replies Latest Post - ‏2012-10-29T12:39:01Z by SystemAdmin
SystemAdmin
SystemAdmin
6772 Posts
ACCEPTED ANSWER

Pinned topic transform encoded http request header with saml asssertion and do AAA

‏2009-03-31T14:02:02Z |
I want to transform a http request with saml assertion in the header or body and do AAA. This is what I am trying to do , but having trouble.

1) covert query param to xml ( using advanced option in policy).

2) I could see the xml representation of the request in probe.
<request>
<url>/</url>
<base-url>/</base-url>
<args src="url" />
<args src="body">
<arg name="SAMLResponse"><?xml version="1.0" encoding="UTF-8"?>
<samlp:Response IssueInstant="2009-03-31T13:27:46Z" MajorVersion="1" MinorVersion="0" ResponseID="b8d55591-1df7-11de-858b-f1f9aeb23434" xmlns:samlp="urn:oasis:names:tc:SAML:1.0:protocol"><ds:Signature xmlns:ds="http://www.w3.org/2000/09/xmldsig#"><ds:SignedInfo><ds:CanonicalizationMethod Algorithm="http://www.w3.org/TR/2001/REC-xml-c14n-20010315"/><ds:SignatureMethod Algorithm="http://www.w3.org/2000/09/xmldsig#rsa-sha1"/><ds:Reference URI=""><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/TR/2001/REC-xml-c14n-20010315"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>aYMKdZbDCExiP9ieQaZOkojG/os=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>YZn3jWEXYm6x9o+0SwSokcaeoodrgV6jThyNk2TVNq616AMYMH5aW9yJEjmMxAekIvl5FBHJ
XSlWBRxWERHpT9/sVKhW00M3wpc/H39PXVO+gbgE+elycMs06k5hZnbCBu82TTCDSkLmy2mW
ByXyLVVe+ttCg3G8V2QRHzMMUYY=</ds:SignatureValue><ds:KeyInfo><ds:KeyName>Public key of certificate</ds:KeyName><ds:KeyValue><ds:RSAKeyValue><ds:Modulus>jJSN8r1OcBvz9MXStUrGhkttdsasP/Xk6UfKvTDBqgvQfk9gINa99yqfa4hw8uwbg1uZE0fg
QHc4Wo608thtLLGiGjszuXZHVRK541v5bSRQVRmBf1OQk2kl0Py07Qe3Ifs8VuyFaj4oltWt
DWrMC6pSpC5I89YEO1otHyrcRUc=</ds:Modulus><ds:Exponent>AQAB</ds:Exponent></ds:RSAKeyValue></ds:KeyValue><ds:X509Data><ds:X509Certificate>MIICQzCCAaygAwIBAgIEScodUzANBgkqhkiG9w0BAQQFADBmMQswCQYDVQQGEwJVUzELMAkG
A1UECBMCTlkxDzANBgNVBAcTBkFsYmFueTEMMAoGA1UEChMDRE9MMQwwCgYDVQQLEwNQJlQx
HTAbBgNVBAMTFERURiBTYW1sIENlcnRpZmljYXRlMB4XDTA5MDMyNTEyMDIyN1oXDTEwMDMy
NTEyMDIyN1owZjELMAkGA1UEBhMCVVMxCzAJBgNVBAgTAk5ZMQ8wDQYDVQQHEwZBbGJhbnkx
DDAKBgNVBAoTA0RPTDEMMAoGA1UECxMDUCZUMR0wGwYDVQQDExREVEYgU2FtbCBDZXJ0aWZp
Y2F0ZTCBnzANBgkqhkiG9w0BAQEFAAOBjQAwgYkCgYEAjJSN8r1OcBvz9MXStUrGhkttdsas
P/Xk6UfKvTDBqgvQfk9gINa99yqfa4hw8uwbg1uZE0fgQHc4Wo608thtLLGiGjszuXZHVRK5
41v5bSRQVRmBf1OQk2kl0Py07Qe3Ifs8VuyFaj4oltWtDWrMC6pSpC5I89YEO1otHyrcRUcC
AwEAATANBgkqhkiG9w0BAQQFAAOBgQCE7jVIHcvaJLf0BeTCnRe41bC/CvM/7Sh4BwK8rYh3
ASkHQ9AFDVSUnnk6phTlr/UqWoPtLoYY8vVqwFRUbFKcMcXs4xQ7pF1xlIDDesgqJm/cNB1L
J6lO1zk+BNk02b03ylX+RyX73cdiOTk5g9g86LfnjaUeHQzjl/c+XKOFVQ==</ds:X509Certificate></ds:X509Data></ds:KeyInfo></ds:Signature><samlp:Status><samlp:StatusCode Value="samlp:Success"/></samlp:Status><saml:Assertion AssertionID="b8d55590-1df7-11de-858b-f1f9aeb23434" IssueInstant="2009-03-31T13:27:46Z" Issuer="http://labor.ny.gov" MajorVersion="1" MinorVersion="0" xmlns:saml="urn:oasis:names:tc:SAML:1.0:assertion"><saml:Conditions NotBefore="2009-03-31T13:27:46Z" NotOnOrAfter="2009-04-01T13:27:46Z"/><saml:AuthenticationStatement AuthenticationInstant="2009-03-31T13:27:46Z" AuthenticationMethod="urn:oasis:names:tc:SAML:1.0:am:password"><saml:Subject><saml:NameIdentifier>ndpar3</saml:NameIdentifier><saml:SubjectConfirmation><saml:ConfirmationMethod>urn:oasis:names:tc:SAML:1.0:cm:bearer</saml:ConfirmationMethod></saml:SubjectConfirmation></saml:Subject><saml:SubjectLocality IPAddress="10.72.92.25"/></saml:AuthenticationStatement><saml:AttributeStatement><saml:Subject><saml:NameIdentifier>ndpar3</saml:NameIdentifier><saml:SubjectConfirmation><saml:ConfirmationMethod>urn:oasis:names:tc:SAML:1.0:cm:bearer</saml:ConfirmationMethod></saml:SubjectConfirmation></saml:Subject><saml:Attribute AttributeName="PhoneNumber" AttributeNamespace="http://labor.ny.gov"><saml:AttributeValue>5185555555</saml:AttributeValue></saml:Attribute><saml:Attribute AttributeName="UserMiddleName" AttributeNamespace="http://labor.ny.gov"><saml:AttributeValue>G</saml:AttributeValue></saml:Attribute><saml:Attribute AttributeName="UserLastName" AttributeNamespace="http://labor.ny.gov"><saml:AttributeValue>YYYY</saml:AttributeValue></saml:Attribute><saml:Attribute AttributeName="EmailAddress" AttributeNamespace="http://labor.ny.gov"><saml:AttributeValue>Test@test.com</saml:AttributeValue></saml:Attribute><saml:Attribute AttributeName="UserFirstName" AttributeNamespace="http://labor.ny.gov"><saml:AttributeValue>XXX</saml:AttributeValue></saml:Attribute><saml:Attribute AttributeName="ExternalCustomerId" AttributeNamespace="http://labor.ny.gov"><saml:AttributeValue>010093456</saml:AttributeValue></saml:Attribute><saml:Attribute AttributeName="UserRole" AttributeNamespace="http://labor.ny.gov"><saml:AttributeValue>Business</saml:AttributeValue></saml:Attribute><saml:Attribute AttributeName="ExternalCustomerType" AttributeNamespace="http://labor.ny.gov"><saml:AttributeValue>Business</saml:AttributeValue></saml:Attribute><saml:Attribute AttributeName="FEIN" AttributeNamespace="http://labor.ny.gov"><saml:AttributeValue>1234567</saml:AttributeValue></saml:Attribute><saml:Attribute AttributeName="LegalName" AttributeNamespace="http://labor.ny.gov"><saml:AttributeValue>ABC Inc</saml:AttributeValue></saml:Attribute></saml:AttributeStatement><ds:Signature xmlns:ds="http://www.w3.org/2000/09/xmldsig#"><ds:SignedInfo><ds:CanonicalizationMethod Algorithm="http://www.w3.org/TR/2001/REC-xml-c14n-20010315"/><ds:SignatureMethod Algorithm="http://www.w3.org/2000/09/xmldsig#rsa-sha1"/><ds:Reference URI="#xpointer(/samlp:Response[1]/saml:Assertion[1])"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/TR/2001/REC-xml-c14n-20010315"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>kOif2uziEkFATSWFpzJ5ct7IvuA=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>emUCrn9CgPwtDBvU4M6vW+ZRxj+1t7/OtZfqAnTeJXyd1xnMW2F/SAXJ05c6MTWwdgb5KJ9E
BK/Y2iLc/jmv9WmCgpJTCa5T9aLGuNhB1stE5jozRfKVfRWNkzhoyXOvDkldlNH3PjBQpk0v
nrTHIr/nbs3ROysHuybOXPugj98=</ds:SignatureValue><ds:KeyInfo><ds:KeyName>Public key of certificate</ds:KeyName><ds:KeyValue><ds:RSAKeyValue><ds:Modulus>jJSN8r1OcBvz9MXStUrGhkttdsasP/Xk6UfKvTDBqgvQfk9gINa99yqfa4hw8uwbg1uZE0fg
QHc4Wo608thtLLGiGjszuXZHVRK541v5bSRQVRmBf1OQk2kl0Py07Qe3Ifs8VuyFaj4oltWt
DWrMC6pSpC5I89YEO1otHyrcRUc=</ds:Modulus><ds:Exponent>AQAB</ds:Exponent></ds:RSAKeyValue></ds:KeyValue><ds:X509Data><ds:X509Certificate>MIICQzCCAaygAwIBAgIEScodUzANBgkqhkiG9w0BAQQFADBmMQswCQYDVQQGEwJVUzELMAkG
A1UECBMCTlkxDzANBgNVBAcTBkFsYmFueTEMMAoGA1UEChMDRE9MMQwwCgYDVQQLEwNQJlQx
HTAbBgNVBAMTFERURiBTYW1sIENlcnRpZmljYXRlMB4XDTA5MDMyNTEyMDIyN1oXDTEwMDMy
NTEyMDIyN1owZjELMAkGA1UEBhMCVVMxCzAJBgNVBAgTAk5ZMQ8wDQYDVQQHEwZBbGJhbnkx
DDAKBgNVBAoTA0RPTDEMMAoGA1UECxMDUCZUMR0wGwYDVQQDExREVEYgU2FtbCBDZXJ0aWZp
Y2F0ZTCBnzANBgkqhkiG9w0BAQEFAAOBjQAwgYkCgYEAjJSN8r1OcBvz9MXStUrGhkttdsas
P/Xk6UfKvTDBqgvQfk9gINa99yqfa4hw8uwbg1uZE0fgQHc4Wo608thtLLGiGjszuXZHVRK5
41v5bSRQVRmBf1OQk2kl0Py07Qe3Ifs8VuyFaj4oltWtDWrMC6pSpC5I89YEO1otHyrcRUcC
AwEAATANBgkqhkiG9w0BAQQFAAOBgQCE7jVIHcvaJLf0BeTCnRe41bC/CvM/7Sh4BwK8rYh3
ASkHQ9AFDVSUnnk6phTlr/UqWoPtLoYY8vVqwFRUbFKcMcXs4xQ7pF1xlIDDesgqJm/cNB1L
J6lO1zk+BNk02b03ylX+RyX73cdiOTk5g9g86LfnjaUeHQzjl/c+XKOFVQ==</ds:X509Certificate></ds:X509Data></ds:KeyInfo></ds:Signature></saml:Assertion></samlp:Response>
</arg>
<arg name="TARGET_TO_USE_WITH_SAML">http://64.132.182.143:8080</arg>
</args>
</request>

3) But now, I want to extract the encoded assertion from the xml and decode it and send to AAA. I am trying to use a custom xsl for that.
But the xsl doesn't seem to produce any output.
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
version="1.0"
xmlns:dp="http://www.datapower.com/extensions"
extension-element-prefixes="dp"
xmlns:str="http://exslt.org/strings">
<xsl:variable name="xmlBase64">
<xsl:value-of select="/request/args/arg"/>
</xsl:variable>
<xsl:variable name="decodedxml">
<dp:parse select="$xmlBase64" encoding="base-64"/>
<xsl:message>
<xsl:value-of select="concat('xmlBase64 node text=', $xmlBase64/doc/node/text())"/>
</xsl:message>
</xsl:variable>

</xsl:stylesheet>

Any help would be appreciated. I am new to xsl and datapower.
Updated on 2012-10-29T12:39:01Z at 2012-10-29T12:39:01Z by SystemAdmin
  • DaveHubbard
    DaveHubbard
    135 Posts
    ACCEPTED ANSWER

    Re: transform encoded http request header with saml asssertion and do AAA

    ‏2009-04-01T15:14:03Z  in response to SystemAdmin
    I'm not quite sure from your post what elements you have/haven't got working, but a few observations;

    1) Your xpath might need to include the attributes (as you have two args and two arg nodes), something like:

    
    <xsl:value-of select=
    "/request/args[@src='body']/arg[@name='SAMLResponse']"/>
    


    although it's possible the forum view gobbled up the "at" symbols

    2) I might also be tempted to:

    • output the content of this to log
    
    <xsl:message dp:priority=
    "debug">SAML [<xsl:value-of select
    "$xmlBase64" />]</xsl:message>
    

    • after the parse check the var://local/_extension/error variable (as per the Extension guide)
    • output the decoded node set as another message
    
    <xsl:message dp:priority=
    "debug">Decoded [<xsl:value-of select
    "$decodedxml" />]</xsl:message>
    


    3) Your final xsl:message may need be reset as above i.e. remove the text bit before the $xmlBase64/doc/node/text()
    It's possible that, as select may be looking for an xpath this won't work
    
    <xsl:message dp:priority=
    "debug">Text [<xsl:value-of select
    "$xmlBase64/doc/node/text()" />]</xsl:message>
    


    Note - as I've put in the dp:priority above you'll need to make sure that level is set on your logging for these to come out in the log.

    Regards
    Dave
  • SystemAdmin
    SystemAdmin
    6772 Posts
    ACCEPTED ANSWER

    Re: transform encoded http request header with saml asssertion and do AAA

    ‏2009-04-01T20:31:19Z  in response to SystemAdmin
    I didn't notice it, that the editor had removed all that. I had it right
    <xsl:value-of select="/request/args/arg" />
    • SystemAdmin
      SystemAdmin
      6772 Posts
      ACCEPTED ANSWER

      Re: transform encoded http request header with saml asssertion and do AAA

      ‏2012-10-29T12:39:01Z  in response to SystemAdmin
      > anigirish wrote:
      > I didn't notice it, that the editor had removed all that. I had it right
      > <xsl:value-of select="/request/args/arg" />

      Anigirish, were you able to get this to work? I'm doing something very similar, and I am also not getting any results in the probe. I tried the debug statements that David suggested, and I'm able to see the decode in the log, but I'm getting anything in the probe.
  • SystemAdmin
    SystemAdmin
    6772 Posts
    ACCEPTED ANSWER

    Re: transform encoded http request header with saml asssertion and do AAA

    ‏2009-04-01T20:39:25Z  in response to SystemAdmin
    The custom stylesheet does decode the assertion fine .But now I have a problem with the AAA step. It fails in au and az. I use Extract token from message option for AU (with * in xpath). I accept an assertion with valid signature. My decoded saml assetion from transform step looks like the attached file..Should I be passing only the assertion and not the saml response with assertion?