By: Darrell Breeden user 18 Jan 2021 at 8:29 a.m. CST

5 Responses
Darrell Breeden gravatar
## Summary Gluu 4.2 is deployed into Kubernetes and is working fine for traditional authenticaiton. SAML provider is added to gluu-passport for our Okta provider. `passport_saml` successfully initiates the login with Okta, but after the login at Okta is handed back to passport, an error is generated. ## Expected Behavior User would have been mapped, created in gluu and logged in ## Actual Behavior `An error has occurred` along with: ``` 2021-01-15T16:55:14.574Z [ERROR] Unknown Error: TypeError: Cannot read property 'RelayState' of undefined 2021-01-15T16:55:14.574Z [ERROR] TypeError: Cannot read property 'RelayState' of undefined at Object.process (/opt/gluu/node/passport/server/idp-initiated.js:94:25) at processIdpInitiated (/opt/gluu/node/passport/server/routes.js:146:15) at Layer.handle [as handle_request] (/opt/gluu/node/passport/node_modules/express/lib/router/layer.js:95:5) at next (/opt/gluu/node/passport/node_modules/express/lib/router/route.js:137:13) at complete (/opt/gluu/node/passport/node_modules/passport/lib/middleware/authenticate.js:268:13) at /opt/gluu/node/passport/node_modules/passport/lib/middleware/authenticate.js:275:15 at pass (/opt/gluu/node/passport/node_modules/passport/lib/authenticator.js:431:14) at Authenticator.transformAuthInfo (/opt/gluu/node/passport/node_modules/passport/lib/authenticator.js:453:5) at /opt/gluu/node/passport/node_modules/passport/lib/middleware/authenticate.js:272:22 at /opt/gluu/node/passport/node_modules/passport/lib/http/request.js:52:7 at /opt/gluu/node/passport/node_modules/passport/lib/sessionmanager.js:26:5 at pass (/opt/gluu/node/passport/node_modules/passport/lib/authenticator.js:277:43) at serialized (/opt/gluu/node/passport/node_modules/passport/lib/authenticator.js:286:7) at passport.serializeUser (/opt/gluu/node/passport/server/app.js:52:2) at pass (/opt/gluu/node/passport/node_modules/passport/lib/authenticator.js:294:9) at Authenticator.serializeUser (/opt/gluu/node/passport/node_modules/passport/lib/authenticator.js:299:5) at SessionManager.logIn (/opt/gluu/node/passport/node_modules/passport/lib/sessionmanager.js:14:8) at IncomingMessage.req.login.req.logIn (/opt/gluu/node/passport/node_modules/passport/lib/http/request.js:50:33) at Strategy.strategy.success (/opt/gluu/node/passport/node_modules/passport/lib/middleware/authenticate.js:253:13) at verified (/opt/gluu/node/passport/node_modules/passport-saml/lib/passport-saml/strategy.js:63:14) at processProfile (/opt/gluu/node/passport/server/providers.js:30:9) at Strategy.uncurried (/opt/gluu/node/passport/server/providers.js:65:10) ``` ## Details ### Full Log Stack ``` 2021-01-15T16:55:08.189Z [INFO] ::ffff:10.0.2.124 - GET /passport/auth/mrg-okta-saml/eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJqd3QiOiJmOGFjM2VmOS01YjcxLTRiMzYtOTdhMi02Y2Q4ZWQ5ODRhMTUiLCJpYXQiOjE2MTA3Mjk3MDgsImV4cCI6MTYxMDcyOTgyOH0.iQQwzHZX87pvmE-NIXsbuNzPQMVy-RUQaE_ehRdyfHg HTTP/1.1 302 0 - 2.430 ms 2021-01-15T16:55:14.543Z [VERBOSE] Authenticating request against mrg-okta-saml 2021-01-15T16:55:14.573Z [INFO] Applying mapping 'saml_ldap_profile' to profile 2021-01-15T16:55:14.573Z [DEBUG] Resulting profile data is { "provider": "mrg-okta-saml" } 2021-01-15T16:55:14.573Z [DEBUG] RelayState value: MRGSAML1 2021-01-15T16:55:14.573Z [DEBUG] SAML reponse in body: <?xml version="1.0" encoding="UTF-8"?><saml2p:Response Destination="https://idpdev.metworx.com/passport/auth/saml/mrg-okta-saml/callback" ID="id86946749068847971643688940" InResponseTo="_b2fb5e19bba6419f1e2a" IssueInstant="2021-01-15T16:55:14.380Z" Version="2.0" xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol"><saml2:Issuer Format="urn:oasis:names:tc:SAML:2.0:nameid-format:entity" xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">http://www.okta.com/exk77zhnhdU4VLMtn357</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="#id86946749068847971643688940"><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>HFWMALTcL4soTthjG/kGXFlvU9/d9+CzzICLEzpgbI4=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>I1FUctBN4hR17liwnfTGXd1naocGZV1mzE4nh5g9+shvG0896GVddEGyS3VSHn6Xq0Gc+gn5y3T3jR1ipLbJoiqYubNvb1iertrH1L4G5TP2ClUcuON+RKUzV5m4ffCz5a25rFFxxP/6d+684isKjlAnv/fC+hgOJ5EI+W6H6v/KW2xKa+02SB/bKWnFHaQgRzXB5nQEFoYpMFgTMaatYjMvAGQnIIaJHTBE4Gqds30AYVJ6ugQ6GyMmcT/BVmNbUgsOM/xsCIbSdp5S87t+4+m+AdfwNVHS9pGTlYhzGT1kf2uSaqfUoBkZY2M2ckufB87BWZqHhoNXCsA+o597sA==</ds:SignatureValue><ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDoDCCAoigAwIBAgIGAWzedx8ZMA0GCSqGSIb3DQEBCwUAMIGQMQswCQYDVQQGEwJVUzETMBEG
A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU
MBIGA1UECwwLU1NPUHJvdmlkZXIxETAPBgNVBAMMCG1ldHJ1bXJnMRwwGgYJKoZIhvcNAQkBFg1p
bmZvQG9rdGEuY29tMB4XDTE5MDgyOTE3Mzk0NFoXDTI5MDgyOTE3NDA0NFowgZAxCzAJBgNVBAYT
AlVTMRMwEQYDVQQIDApDYWxpZm9ybmlhMRYwFAYDVQQHDA1TYW4gRnJhbmNpc2NvMQ0wCwYDVQQK
DARPa3RhMRQwEgYDVQQLDAtTU09Qcm92aWRlcjERMA8GA1UEAwwIbWV0cnVtcmcxHDAaBgkqhkiG
9w0BCQEWDWluZm9Ab2t0YS5jb20wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCdo+Ga
QuY3YB7PPN4soIpGhDNw8lGwukqHL6kZKKL8jgamFHk/S3p4RpS8NY0HrLGqY8mKhk0Mxw6s0dBi
XofNGqDYMQ7zr1R4H8JQMy+Q2U6kaBPpR8gdOgoLr5yZbpKi/IdejXotcVQ4Al/2wC+QPEzwzoJ+
A7vmboCM6Q7Q4cGvA1/w6eAN5+1TU4YKagcEN45UXe87MdofUHiGsIelr/dcWy2lqBrgNd86JgMD
lXohjWr9FZnuk7sWXRgDVrECNQVl159lnDhODG3ugUdNh3pXM9/5ax7Xpg/imF8Ytczb/9s+HUvc
MRwap5jZxt0SADvrojR1US6cvcPO12ybAgMBAAEwDQYJKoZIhvcNAQELBQADggEBAJbemUx9Aa8e
0tLkUvpWXux953XB1NmHutcpU6HRtgvE+47pO1PIsUmJ28Vynl2sATKyLB4kC7aZK9ckeFL8q6v7
h4KQBF1l552c8X83vU0Lnp+u4Yr9cGKQbQV1Mj+HVjA8jHcc0/5ofpaM5Ir0BBxmIkYHYFZ07VhU
wYkhNm+Cm5UEesYH9tyrYsa6alMMunZbAtuSJRJsZv3iFTEfLJc+ajvCh0sazXxP5SETPYZuG3o4
EXqqXsH4dYD6/ErEZUpT+QcXeTe/ql6tgKdfBGdN3L1FgmRKYhLx93slqPqxjZMLLWLUvEmJ9CDA
rl2RYVWuT135UQhCZzXuR0ZYoLs=</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:Assertion ID="id86946749069834501681454596" IssueInstant="2021-01-15T16:55:14.380Z" Version="2.0" xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion"><saml2:Issuer Format="urn:oasis:names:tc:SAML:2.0:nameid-format:entity" xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">http://www.okta.com/exk77zhnhdU4VLMtn357</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="#id86946749069834501681454596"><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>Co0wTeK2MV/MxcwliKqIlfrcgJgsT3UGalTynNlFnD0=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>OigBiE5bmcY05r1HNpMMFgSdaCEvt3Coq9s1u1k6MzSyhmzaMQ70lOIHOgE6F99pX5NTdeo7CG1Tw+fb7cjbxL+nXM9jz9Gm4RJeZrebGCb/iHhDm+v++BvWHFLNUBZLvgqI5rRaRNbEz6YKiyM15rGpx93jYEsrSIMJODT8ZfwbBzoiP475BMD3wqf10jEZygYICLz/0XFRoZD1iAXQmxjaPiTjkkGwa8z6jkJkvbXNERADLq7f0bGMylMmreIDFoEUoWoBHbVmyFj2EV1mtPDq9LNNUIx9q7e9UO60cSjxegknl4uPhnAA7sNL4QSqrEM4TjmTgZQn7GBsVX0T3w==</ds:SignatureValue><ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDoDCCAoigAwIBAgIGAWzedx8ZMA0GCSqGSIb3DQEBCwUAMIGQMQswCQYDVQQGEwJVUzETMBEG
A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU
MBIGA1UECwwLU1NPUHJvdmlkZXIxETAPBgNVBAMMCG1ldHJ1bXJnMRwwGgYJKoZIhvcNAQkBFg1p
bmZvQG9rdGEuY29tMB4XDTE5MDgyOTE3Mzk0NFoXDTI5MDgyOTE3NDA0NFowgZAxCzAJBgNVBAYT
AlVTMRMwEQYDVQQIDApDYWxpZm9ybmlhMRYwFAYDVQQHDA1TYW4gRnJhbmNpc2NvMQ0wCwYDVQQK
DARPa3RhMRQwEgYDVQQLDAtTU09Qcm92aWRlcjERMA8GA1UEAwwIbWV0cnVtcmcxHDAaBgkqhkiG
9w0BCQEWDWluZm9Ab2t0YS5jb20wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCdo+Ga
QuY3YB7PPN4soIpGhDNw8lGwukqHL6kZKKL8jgamFHk/S3p4RpS8NY0HrLGqY8mKhk0Mxw6s0dBi
XofNGqDYMQ7zr1R4H8JQMy+Q2U6kaBPpR8gdOgoLr5yZbpKi/IdejXotcVQ4Al/2wC+QPEzwzoJ+
A7vmboCM6Q7Q4cGvA1/w6eAN5+1TU4YKagcEN45UXe87MdofUHiGsIelr/dcWy2lqBrgNd86JgMD
lXohjWr9FZnuk7sWXRgDVrECNQVl159lnDhODG3ugUdNh3pXM9/5ax7Xpg/imF8Ytczb/9s+HUvc
MRwap5jZxt0SADvrojR1US6cvcPO12ybAgMBAAEwDQYJKoZIhvcNAQELBQADggEBAJbemUx9Aa8e
0tLkUvpWXux953XB1NmHutcpU6HRtgvE+47pO1PIsUmJ28Vynl2sATKyLB4kC7aZK9ckeFL8q6v7
h4KQBF1l552c8X83vU0Lnp+u4Yr9cGKQbQV1Mj+HVjA8jHcc0/5ofpaM5Ir0BBxmIkYHYFZ07VhU
wYkhNm+Cm5UEesYH9tyrYsa6alMMunZbAtuSJRJsZv3iFTEfLJc+ajvCh0sazXxP5SETPYZuG3o4
EXqqXsH4dYD6/ErEZUpT+QcXeTe/ql6tgKdfBGdN3L1FgmRKYhLx93slqPqxjZMLLWLUvEmJ9CDA
rl2RYVWuT135UQhCZzXuR0ZYoLs=</ds:X509Certificate></ds:X509Data></ds:KeyInfo></ds:Signature><saml2:Subject xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion"><saml2:NameID Format="urn:oasis:names:tc:SAML:2.0:nameid-format:transient">darrellb@metrumrg.com</saml2:NameID><saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer"><saml2:SubjectConfirmationData InResponseTo="_b2fb5e19bba6419f1e2a" NotOnOrAfter="2021-01-15T17:00:14.380Z" Recipient="https://idpdev.metworx.com/passport/auth/saml/mrg-okta-saml/callback"/></saml2:SubjectConfirmation></saml2:Subject><saml2:Conditions NotBefore="2021-01-15T16:50:14.380Z" NotOnOrAfter="2021-01-15T17:00:14.380Z" xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion"><saml2:AudienceRestriction><saml2:Audience>mrg-okta-saml</saml2:Audience></saml2:AudienceRestriction></saml2:Conditions><saml2:AuthnStatement AuthnInstant="2021-01-15T16:55:13.618Z" SessionIndex="_b2fb5e19bba6419f1e2a" xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion"><saml2:AuthnContext><saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef></saml2:AuthnContext></saml2:AuthnStatement></saml2:Assertion></saml2p:Response> 2021-01-15T16:55:14.574Z [ERROR] Unknown Error: TypeError: Cannot read property 'RelayState' of undefined 2021-01-15T16:55:14.574Z [ERROR] TypeError: Cannot read property 'RelayState' of undefined at Object.process (/opt/gluu/node/passport/server/idp-initiated.js:94:25) at processIdpInitiated (/opt/gluu/node/passport/server/routes.js:146:15) at Layer.handle [as handle_request] (/opt/gluu/node/passport/node_modules/express/lib/router/layer.js:95:5) at next (/opt/gluu/node/passport/node_modules/express/lib/router/route.js:137:13) at complete (/opt/gluu/node/passport/node_modules/passport/lib/middleware/authenticate.js:268:13) at /opt/gluu/node/passport/node_modules/passport/lib/middleware/authenticate.js:275:15 at pass (/opt/gluu/node/passport/node_modules/passport/lib/authenticator.js:431:14) at Authenticator.transformAuthInfo (/opt/gluu/node/passport/node_modules/passport/lib/authenticator.js:453:5) at /opt/gluu/node/passport/node_modules/passport/lib/middleware/authenticate.js:272:22 at /opt/gluu/node/passport/node_modules/passport/lib/http/request.js:52:7 at /opt/gluu/node/passport/node_modules/passport/lib/sessionmanager.js:26:5 at pass (/opt/gluu/node/passport/node_modules/passport/lib/authenticator.js:277:43) at serialized (/opt/gluu/node/passport/node_modules/passport/lib/authenticator.js:286:7) at passport.serializeUser (/opt/gluu/node/passport/server/app.js:52:2) at pass (/opt/gluu/node/passport/node_modules/passport/lib/authenticator.js:294:9) at Authenticator.serializeUser (/opt/gluu/node/passport/node_modules/passport/lib/authenticator.js:299:5) at SessionManager.logIn (/opt/gluu/node/passport/node_modules/passport/lib/sessionmanager.js:14:8) at IncomingMessage.req.login.req.logIn (/opt/gluu/node/passport/node_modules/passport/lib/http/request.js:50:33) at Strategy.strategy.success (/opt/gluu/node/passport/node_modules/passport/lib/middleware/authenticate.js:253:13) at verified (/opt/gluu/node/passport/node_modules/passport-saml/lib/passport-saml/strategy.js:63:14) at processProfile (/opt/gluu/node/passport/server/providers.js:30:9) at Strategy.uncurried (/opt/gluu/node/passport/server/providers.js:65:10) ``` I haven't been able to make heads or tails of what is undefined. The RelayState is present in the logs from either route.js or idp-initiated.js. It's kind of hard to tell which since they have the exact same log messages. Secondly the Relay state is clearly present in the debug logs and the body of the SAML response is present as it's being displayed. I'm wondering if there's something small I'm missing.

By Darrell Breeden user 19 Jan 2021 at 10:41 a.m. CST

Darrell Breeden gravatar
The problem is coming from ```js function process(req, res, next) { let user = req.user, relayState = req.body.RelayState ``` When process is called, the req is present but the `body` field does not exist as a member of the request

By Darrell Breeden user 19 Jan 2021 at 10:46 a.m. CST

Darrell Breeden gravatar
```js function processIdpInitiated(req, res, next) { let user = req.user, relayState = req.body.RelayState logger.log2('debug', `RelayState value: ${relayState}`) logger.log2('debug', `SAML reponse in body:\n${req.body.SAMLResponse}`) abortIfProfileMissing(req, res, user) idpInitiated.process(user, relayState, global.iiconfig, res, next) } ``` When IDP Initiated requests start, user is processed as `req.user`. That's handed down as the request, which does not have a body. You can fairly easily fix this by setting the body onto it from the raw request: ```js let user = req.user, relayState = req.body.RelayState logger.log2('debug', `RelayState value: ${relayState}`) logger.log2('debug', `SAML reponse in body:\n${req.body.SAMLResponse}`) abortIfProfileMissing(req, res, user) user.body = req.body idpInitiated.process(user, relayState, global.iiconfig, res, next) ```

By Michael Schwartz Account Admin 24 Jan 2021 at 8:50 a.m. CST

Michael Schwartz gravatar
This support ticket is beyond the scope of community support. Please contact sales about a VIP support contract.

By Darrell Breeden user 26 Jan 2021 at 10:43 a.m. CST

Darrell Breeden gravatar
Just to clarify or add knowledge in case anyone comes across this, it was a rather large effort to go through and manually resolve the code issues myself, and the further I got into it, I realized it had to have already been solved. Our production environment was deployed on a newer version of gluu (4.2.1) and was completely unaffected. We were able to setup SAML integration both IDP Inititated and Gluu-Initiated without issue. As such, we'll simply tear down our development instance and re-deploy with 4.2.1. Basically we upgraded from 4.2.0 to 4.2.1

By Michael Schwartz Account Admin 26 Jan 2021 at 10:52 a.m. CST

Michael Schwartz gravatar
Thanks for the note.