'use strict'; var express = require( 'express' ); var bodyParser = require( 'body-parser' ); var passport = require( 'passport' ); var SamlStrategy = require( '../lib/passport-saml/index.js' ).Strategy; var request = require( 'request' ); var should = require( 'should' ); var zlib = require( 'zlib' ); var querystring = require( 'querystring' ); var parseString = require( 'xml2js' ).parseString; var SAML = require( '../lib/passport-saml/index.js' ).SAML; var fs = require( 'fs' ); var sinon = require('sinon'); // a certificate which is re-used by several tests var TEST_CERT = "MIIEFzCCAv+gAwIBAgIUFJsUjPM7AmWvNtEvULSHlTTMiLQwDQYJKoZIhvcNAQEFBQAwWDELMAkGA1UEBhMCVVMxETAPBgNVBAoMCFN1YnNwYWNlMRUwEwYDVQQLDAxPbmVMb2dpbiBJZFAxHzAdBgNVBAMMFk9uZUxvZ2luIEFjY291bnQgNDIzNDkwHhcNMTQwNTEzMTgwNjEyWhcNMTkwNTE0MTgwNjEyWjBYMQswCQYDVQQGEwJVUzERMA8GA1UECgwIU3Vic3BhY2UxFTATBgNVBAsMDE9uZUxvZ2luIElkUDEfMB0GA1UEAwwWT25lTG9naW4gQWNjb3VudCA0MjM0OTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKrAzJdY9FzFLt5blArJfPzgi87EnFGlTfcV5T1TUDwLBlDkY/0ZGKnMOpf3D7ie2C4pPFOImOogcM5kpDDL7qxTXZ1ewXVyjBdMu29NG2C6NzWeQTUMUji01EcHkC8o+Pts8ANiNOYcjxEeyhEyzJKgEizblYzMMKzdrOET6QuqWo3C83K+5+5dsjDn1ooKGRwj3HvgsYcFrQl9NojgQFjoobwsiE/7A+OJhLpBcy/nSVgnoJaMfrO+JsnukZPztbntLvOl56+Vra0N8n5NAYhaSayPiv/ayhjVgjfXd1tjMVTOiDknUOwizZuJ1Y3QH94vUtBgp0WBpBSs/xMyTs8CAwEAAaOB2DCB1TAMBgNVHRMBAf8EAjAAMB0GA1UdDgQWBBRQO4WpM5fWwxib49WTuJkfYDbxODCBlQYDVR0jBIGNMIGKgBRQO4WpM5fWwxib49WTuJkfYDbxOKFcpFowWDELMAkGA1UEBhMCVVMxETAPBgNVBAoMCFN1YnNwYWNlMRUwEwYDVQQLDAxPbmVMb2dpbiBJZFAxHzAdBgNVBAMMFk9uZUxvZ2luIEFjY291bnQgNDIzNDmCFBSbFIzzOwJlrzbRL1C0h5U0zIi0MA4GA1UdDwEB/wQEAwIHgDANBgkqhkiG9w0BAQUFAAOCAQEACdDAAoaZFCEY5pmfwbKuKrXtO5iE8lWtiCPjCZEUuT6bXRNcqrdnuV/EAfX9WQoXjalPi0eM78zKmbvRGSTUHwWw49RHjFfeJUKvHNeNnFgTXDjEPNhMvh69kHm453lFRmB+kk6yjtXRZaQEwS8Uuo2Ot+krgNbl6oTBZJ0AHH1MtZECDloms1Km7zsK8wAi5i8TVIKkVr5b2VlhrLgFMvzZ5ViAxIMGB6w47yY4QGQB/5Q8ya9hBs9vkn+wubA+yr4j14JXZ7blVKDSTYva65Ea+PqHyrp+Wnmnbw2ObS7iWexiTy1jD3G0R2avDBFjM8Fj5DbfufsE1b0U10RTtg=="; describe( 'passport-saml /', function() { describe('captured saml responses /', function () { var fakeClock; var capturedChecks = [ { name: 'Okta -- valid config should succeed', samlResponse: { SAMLResponse: 'PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c2FtbDJwOlJlc3BvbnNlIHhtbG5zOnNhbWwycD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOnByb3RvY29sIiBEZXN0aW5hdGlvbj0iaHR0cDovL2xvY2FsaG9zdC9icm93c2VyU2FtbExvZ2luIiBJRD0iaWQzMzcxMDA5NzQ3ODg2OTIzMjIwMzA1Njc3ODMiIEluUmVzcG9uc2VUbz0iXzVjMzg1YWJiMTc3MzViN2FhOGQxIiBJc3N1ZUluc3RhbnQ9IjIwMTQtMDUtMjdUMjM6Mjc6MzUuNDI2WiIgVmVyc2lvbj0iMi4wIj48c2FtbDI6SXNzdWVyIHhtbG5zOnNhbWwyPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIiBGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpuYW1laWQtZm9ybWF0OmVudGl0eSI+aHR0cDovL3d3dy5va3RhLmNvbS9rdmpqNDZsc0RRRVFZVURCWklZVzwvc2FtbDI6SXNzdWVyPjxkczpTaWduYXR1cmUgeG1sbnM6ZHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyMiPjxkczpTaWduZWRJbmZvPjxkczpDYW5vbmljYWxpemF0aW9uTWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8xMC94bWwtZXhjLWMxNG4jIi8+PGRzOlNpZ25hdHVyZU1ldGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyNyc2Etc2hhMSIvPjxkczpSZWZlcmVuY2UgVVJJPSIjaWQzMzcxMDA5NzQ3ODg2OTIzMjIwMzA1Njc3ODMiPjxkczpUcmFuc2Zvcm1zPjxkczpUcmFuc2Zvcm0gQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjZW52ZWxvcGVkLXNpZ25hdHVyZSIvPjxkczpUcmFuc2Zvcm0gQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzEwL3htbC1leGMtYzE0biMiLz48L2RzOlRyYW5zZm9ybXM+PGRzOkRpZ2VzdE1ldGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyNzaGExIi8+PGRzOkRpZ2VzdFZhbHVlPjRSNUNjYUVEQ3dPSCtudnVHSkY3TWRBelpIdz08L2RzOkRpZ2VzdFZhbHVlPjwvZHM6UmVmZXJlbmNlPjwvZHM6U2lnbmVkSW5mbz48ZHM6U2lnbmF0dXJlVmFsdWU+TzlycW1TUTJQd1NaZDFBeklRUDUySkY5VHBaSkJUNENpdnAxTUZZN3FzODdrU2RFQ3dNbWFWTDE2NFI4dUlCbzdscXUwOFRaTGZYeGF6ak5uRDhnV05BOWRuK2d5cFc1ZWo4S3EzK1J3cUxZUzM1M3pCeVpWcy9MSUxQZVJCK0tUS2RsbTVJSDcxdWhwbUp4a3k0T0gwNWdDSWExYnRFaXpKV1h3d1lleXpBPTwvZHM6U2lnbmF0dXJlVmFsdWU+PGRzOktleUluZm8+PGRzOlg1MDlEYXRhPjxkczpYNTA5Q2VydGlmaWNhdGU+TUlJQ29UQ0NBZ3FnQXdJQkFnSUdBVVk4elZQWU1BMEdDU3FHU0liM0RRRUJCUVVBTUlHVE1Rc3dDUVlEVlFRR0V3SlZVekVUTUJFRwpBMVVFQ0F3S1EyRnNhV1p2Y201cFlURVdNQlFHQTFVRUJ3d05VMkZ1SUVaeVlXNWphWE5qYnpFTk1Bc0dBMVVFQ2d3RVQydDBZVEVVCk1CSUdBMVVFQ3d3TFUxTlBVSEp2ZG1sa1pYSXhGREFTQmdOVkJBTU1DM04xWW5Od1lXTmxjM2N4TVJ3d0dnWUpLb1pJaHZjTkFRa0IKRmcxcGJtWnZRRzlyZEdFdVkyOXRNQjRYRFRFME1EVXlOekE0TWpreU4xb1hEVFEwTURVeU56QTRNekF5TjFvd2daTXhDekFKQmdOVgpCQVlUQWxWVE1STXdFUVlEVlFRSURBcERZV3hwWm05eWJtbGhNUll3RkFZRFZRUUhEQTFUWVc0Z1JuSmhibU5wYzJOdk1RMHdDd1lEClZRUUtEQVJQYTNSaE1SUXdFZ1lEVlFRTERBdFRVMDlRY205MmFXUmxjakVVTUJJR0ExVUVBd3dMYzNWaWMzQmhZMlZ6ZHpFeEhEQWEKQmdrcWhraUc5dzBCQ1FFV0RXbHVabTlBYjJ0MFlTNWpiMjB3Z1o4d0RRWUpLb1pJaHZjTkFRRUJCUUFEZ1kwQU1JR0pBb0dCQUtZWAovVWRWOUhMWGJOS3YweWM2WUpCdHpkV051R1RQSVhXVlBDYjBPc1J2UjU0bHErMFNMUFFHSlMzOWZsV0tpcXRVaUV1c3VpaDZHZExmCk52RkFWTEdQcUJUV1E0TGM3cjUrekQ1cW5INkxpVE0xS0NiYUYzdXUyUCtUK3V0c0dxRlVaYXdBOUZFVk5Ma0lDZTM2WDF5RTQwWCsKL2pNeWd5aWVRUE1lSkFCdkFnTUJBQUV3RFFZSktvWklodmNOQVFFRkJRQURnWUVBSFNXUEc0eTFiTnlKeVNnYkZxRGNTLzZNVU5JcgpTZmtRWUl4eklHUTM3cXk1cUFXMTVZa0JVaVc5VHNHSlJjcmd1c1ZyWklpYTE4ZVl6ODRabjdGeVVaTk1GbzI0TDdsNkJTMFdDaXRJClFTY0JDS0I0UVdBL2Ixc3pxczdFdHBPY1BQMDFUWU5xMnJhcytWcVIzYVdBWExYMm9LZkNsVi9TVXdzelJmNVU4NVk9PC9kczpYNTA5Q2VydGlmaWNhdGU+PC9kczpYNTA5RGF0YT48L2RzOktleUluZm8+PC9kczpTaWduYXR1cmU+PHNhbWwycDpTdGF0dXMgeG1sbnM6c2FtbDJwPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiPjxzYW1sMnA6U3RhdHVzQ29kZSBWYWx1ZT0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOnN0YXR1czpTdWNjZXNzIi8+PC9zYW1sMnA6U3RhdHVzPjxzYW1sMjpBc3NlcnRpb24geG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iIElEPSJpZDMzNzEwMDk3NDc4OTQ5MTAwNjY2NTIyNTEyIiBJc3N1ZUluc3RhbnQ9IjIwMTQtMDUtMjdUMjM6Mjc6MzUuNDI2WiIgVmVyc2lvbj0iMi4wIj48c2FtbDI6SXNzdWVyIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOm5hbWVpZC1mb3JtYXQ6ZW50aXR5IiB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiI+aHR0cDovL3d3dy5va3RhLmNvbS9rdmpqNDZsc0RRRVFZVURCWklZVzwvc2FtbDI6SXNzdWVyPjxkczpTaWduYXR1cmUgeG1sbnM6ZHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyMiPjxkczpTaWduZWRJbmZvPjxkczpDYW5vbmljYWxpemF0aW9uTWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8xMC94bWwtZXhjLWMxNG4jIi8+PGRzOlNpZ25hdHVyZU1ldGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyNyc2Etc2hhMSIvPjxkczpSZWZlcmVuY2UgVVJJPSIjaWQzMzcxMDA5NzQ3ODk0OTEwMDY2NjUyMjUxMiI+PGRzOlRyYW5zZm9ybXM+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyNlbnZlbG9wZWQtc2lnbmF0dXJlIi8+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvMTAveG1sLWV4Yy1jMTRuIyIvPjwvZHM6VHJhbnNmb3Jtcz48ZHM6RGlnZXN0TWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8wOS94bWxkc2lnI3NoYTEiLz48ZHM6RGlnZXN0VmFsdWU+UFM4dE5taVVZUXpRQVFURjh3RDFRT3dMazA0PTwvZHM6RGlnZXN0VmFsdWU+PC9kczpSZWZlcmVuY2U+PC9kczpTaWduZWRJbmZvPjxkczpTaWduYXR1cmVWYWx1ZT5XM3JiUkNFUmE1ZEtUcy9MSERwY0pEeUhjSzFESjczd2xhT3J2MXZWNmZxQ3FTTUNpclZLRVlLKzR2OG5WaThZNlZwcVJHd0trWFV2cUY0b0hKWjYzOE5YYVRiRVRjU1VXWjVUNXowbzBNVXhBL3RnL01zVzYvRlVRMXBqUWJhVlhJT3Mvc1EwVzluUXpmZkVZLzgrSkVJMldLY0I2UkZlVzVtTlkvdm9oUWM9PC9kczpTaWduYXR1cmVWYWx1ZT48ZHM6S2V5SW5mbz48ZHM6WDUwOURhdGE+PGRzOlg1MDlDZXJ0aWZpY2F0ZT5NSUlDb1RDQ0FncWdBd0lCQWdJR0FVWTh6VlBZTUEwR0NTcUdTSWIzRFFFQkJRVUFNSUdUTVFzd0NRWURWUVFHRXdKVlV6RVRNQkVHCkExVUVDQXdLUTJGc2FXWnZjbTVwWVRFV01CUUdBMVVFQnd3TlUyRnVJRVp5WVc1amFYTmpiekVOTUFzR0ExVUVDZ3dFVDJ0MFlURVUKTUJJR0ExVUVDd3dMVTFOUFVISnZkbWxrWlhJeEZEQVNCZ05WQkFNTUMzTjFZbk53WVdObGMzY3hNUnd3R2dZSktvWklodmNOQVFrQgpGZzFwYm1adlFHOXJkR0V1WTI5dE1CNFhEVEUwTURVeU56QTRNamt5TjFvWERUUTBNRFV5TnpBNE16QXlOMW93Z1pNeEN6QUpCZ05WCkJBWVRBbFZUTVJNd0VRWURWUVFJREFwRFlXeHBabTl5Ym1saE1SWXdGQVlEVlFRSERBMVRZVzRnUm5KaGJtTnBjMk52TVEwd0N3WUQKVlFRS0RBUlBhM1JoTVJRd0VnWURWUVFMREF0VFUwOVFjbTkyYVdSbGNqRVVNQklHQTFVRUF3d0xjM1ZpYzNCaFkyVnpkekV4SERBYQpCZ2txaGtpRzl3MEJDUUVXRFdsdVptOUFiMnQwWVM1amIyMHdnWjh3RFFZSktvWklodmNOQVFFQkJRQURnWTBBTUlHSkFvR0JBS1lYCi9VZFY5SExYYk5LdjB5YzZZSkJ0emRXTnVHVFBJWFdWUENiME9zUnZSNTRscSswU0xQUUdKUzM5ZmxXS2lxdFVpRXVzdWloNkdkTGYKTnZGQVZMR1BxQlRXUTRMYzdyNSt6RDVxbkg2TGlUTTFLQ2JhRjN1dTJQK1QrdXRzR3FGVVphd0E5RkVWTkxrSUNlMzZYMXlFNDBYKwovak15Z3lpZVFQTWVKQUJ2QWdNQkFBRXdEUVlKS29aSWh2Y05BUUVGQlFBRGdZRUFIU1dQRzR5MWJOeUp5U2diRnFEY1MvNk1VTklyClNma1FZSXh6SUdRMzdxeTVxQVcxNVlrQlVpVzlUc0dKUmNyZ3VzVnJaSWlhMThlWXo4NFpuN0Z5VVpOTUZvMjRMN2w2QlMwV0NpdEkKUVNjQkNLQjRRV0EvYjFzenFzN0V0cE9jUFAwMVRZTnEycmFzK1ZxUjNhV0FYTFgyb0tmQ2xWL1NVd3N6UmY1VTg1WT08L2RzOlg1MDlDZXJ0aWZpY2F0ZT48L2RzOlg1MDlEYXRhPjwvZHM6S2V5SW5mbz48L2RzOlNpZ25hdHVyZT48c2FtbDI6U3ViamVjdCB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiI+PHNhbWwyOk5hbWVJRCBGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjEuMTpuYW1laWQtZm9ybWF0OmVtYWlsQWRkcmVzcyI+YmVuQHN1YnNwYWNlc3cuY29tPC9zYW1sMjpOYW1lSUQ+PHNhbWwyOlN1YmplY3RDb25maXJtYXRpb24gTWV0aG9kPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6Y206YmVhcmVyIj48c2FtbDI6U3ViamVjdENvbmZpcm1hdGlvbkRhdGEgSW5SZXNwb25zZVRvPSJfNWMzODVhYmIxNzczNWI3YWE4ZDEiIE5vdE9uT3JBZnRlcj0iMjAxNC0wNS0yN1QyMzozMjozNS40MjZaIiBSZWNpcGllbnQ9Imh0dHA6Ly9sb2NhbGhvc3QvYnJvd3NlclNhbWxMb2dpbiIvPjwvc2FtbDI6U3ViamVjdENvbmZpcm1hdGlvbj48L3NhbWwyOlN1YmplY3Q+PHNhbWwyOkNvbmRpdGlvbnMgTm90QmVmb3JlPSIyMDE0LTA1LTI3VDIzOjIyOjM1LjQyNloiIE5vdE9uT3JBZnRlcj0iMjAxNC0wNS0yN1QyMzozMjozNS40MjZaIiB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiI+PHNhbWwyOkF1ZGllbmNlUmVzdHJpY3Rpb24+PHNhbWwyOkF1ZGllbmNlPmh0dHBzOi8vYWRtaW4uc3Vic3BhY2Vzdy5jb208L3NhbWwyOkF1ZGllbmNlPjwvc2FtbDI6QXVkaWVuY2VSZXN0cmljdGlvbj48L3NhbWwyOkNvbmRpdGlvbnM+PHNhbWwyOkF1dGhuU3RhdGVtZW50IEF1dGhuSW5zdGFudD0iMjAxNC0wNS0yN1QyMzoyNzozNS40MjZaIiBTZXNzaW9uSW5kZXg9Il81YzM4NWFiYjE3NzM1YjdhYThkMSIgeG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPjxzYW1sMjpBdXRobkNvbnRleHQ+PHNhbWwyOkF1dGhuQ29udGV4dENsYXNzUmVmPnVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphYzpjbGFzc2VzOlg1MDk8L3NhbWwyOkF1dGhuQ29udGV4dENsYXNzUmVmPjwvc2FtbDI6QXV0aG5Db250ZXh0Pjwvc2FtbDI6QXV0aG5TdGF0ZW1lbnQ+PC9zYW1sMjpBc3NlcnRpb24+PC9zYW1sMnA6UmVzcG9uc2U+', RelayState: '', }, config: { entryPoint: 'https://subspacesw1.okta.com/app/subspacesw_subspacetest_1/kvjj46lsDQEQYUDBZIYW/sso/saml', cert: 'MIICoTCCAgqgAwIBAgIGAUY8zVPYMA0GCSqGSIb3DQEBBQUAMIGTMQswCQYDVQQGEwJVUzETMBEGA1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEUMBIGA1UECwwLU1NPUHJvdmlkZXIxFDASBgNVBAMMC3N1YnNwYWNlc3cxMRwwGgYJKoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMB4XDTE0MDUyNzA4MjkyN1oXDTQ0MDUyNzA4MzAyN1owgZMxCzAJBgNVBAYTAlVTMRMwEQYDVQQIDApDYWxpZm9ybmlhMRYwFAYDVQQHDA1TYW4gRnJhbmNpc2NvMQ0wCwYDVQQKDARPa3RhMRQwEgYDVQQLDAtTU09Qcm92aWRlcjEUMBIGA1UEAwwLc3Vic3BhY2VzdzExHDAaBgkqhkiG9w0BCQEWDWluZm9Ab2t0YS5jb20wgZ8wDQYJKoZIhvcNAQEBBQADgY0AMIGJAoGBAKYX/UdV9HLXbNKv0yc6YJBtzdWNuGTPIXWVPCb0OsRvR54lq+0SLPQGJS39flWKiqtUiEusuih6GdLfNvFAVLGPqBTWQ4Lc7r5+zD5qnH6LiTM1KCbaF3uu2P+T+utsGqFUZawA9FEVNLkICe36X1yE40X+/jMygyieQPMeJABvAgMBAAEwDQYJKoZIhvcNAQEFBQADgYEAHSWPG4y1bNyJySgbFqDcS/6MUNIrSfkQYIxzIGQ37qy5qAW15YkBUiW9TsGJRcrgusVrZIia18eYz84Zn7FyUZNMFo24L7l6BS0WCitIQScBCKB4QWA/b1szqs7EtpOcPP01TYNq2ras+VqR3aWAXLX2oKfClV/SUwszRf5U85Y=' }, expectedStatusCode: 200, expectedNameIDStartsWith: 'ben', mockDate: '2014-05-27T23:29:35.426Z' }, { name: 'Okta -- valid encrypted response should succeed', samlResponse: { SAMLResponse: '<?xml version="1.0" encoding="UTF-8"?><saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://64f4094f.ngrok.io/sso/saml/callback" ID="id195238933970448223940497" InResponseTo="_c60537dad34fa4ecb613" IssueInstant="2016-08-19T01:13:38.139Z" 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/exk7xdi6axPfombzx0h7</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/2000/09/xmldsig#rsa-sha1"/><ds:Reference URI="#id195238933970448223940497"><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>zt7xnrL0uVkzk3u4xdKxUGFmluKjc8yyC9fojrx5qCo=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>eFes3TPB/eQeQPmPpObP4P3QZIJDc1cW02NT8reTJu0oedICNo/NBDxOk1bh81I39Lv/t1dE3Fwk0kgI3EK0WK4QZlIfvZB+NJOJTceoBRzmMtAxr9qYNEiGIlYxgpKPChoy8t3rYLWvBeZIsjJ8/bbdnuxcHV7mzoxY24wmaqnqq14nPI1AgIHcSgMTa/YjhRpZ2eSJ6MOE1M/40r/uoEIOX5c0UhHMFo8wbiv4+oi2O+dO9WakpC7V9puFzU49Qz0dzl1WhR0bZxTmSar6YF65s0fNCRz+HbykXwxVx8Z4M51EBG7SLuiPTUIN1MYTWeuhfYz1/Osf/pj1lqKbVA==</ds:SignatureValue><ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDoDCCAoigAwIBAgIGAVaZ04POMA0GCSqGSIb3DQEBBQUAMIGQMQswCQYDVQQGEwJVUzETMBEG
A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU
MBIGA1UECwwLU1NPUHJvdmlkZXIxETAPBgNVBAMMCGZyb250YXBwMRwwGgYJKoZIhvcNAQkBFg1p
bmZvQG9rdGEuY29tMB4XDTE2MDgxNzE4NDUzMVoXDTI2MDgxNzE4NDYzMVowgZAxCzAJBgNVBAYT
AlVTMRMwEQYDVQQIDApDYWxpZm9ybmlhMRYwFAYDVQQHDA1TYW4gRnJhbmNpc2NvMQ0wCwYDVQQK
DARPa3RhMRQwEgYDVQQLDAtTU09Qcm92aWRlcjERMA8GA1UEAwwIZnJvbnRhcHAxHDAaBgkqhkiG
9w0BCQEWDWluZm9Ab2t0YS5jb20wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCvplQO
NVwknRy1iBnaoZtsOz28A7XW2tRpFW+0La7RJexbziIwEy1bPZENhfwjPZA1oHHZqi5l315BxXKW
JqmmNmbDCFDo+/FYFCoHXliiLm9vqDbR1br6ByqeY0GfxyTPKHZxb2FSes30TffDknpMQd/8kA9Y
WaW5xDlu2ivWJI+sfcOJOMd6t+gcfXj58a5fP8Mwm6Y220KeZSvrVpEV2KDp9hln7fhhoxHZ7K/B
YbidqdwLzeUQXpb6LIrxtKdug2FofS+ONs6yLIQRmrbCB7SVX1QA8JInMn+fzrGtZmFiHR0aFbyh
iO78v/ufDa6S+XpYyp2b6D4SnzeggnobAgMBAAEwDQYJKoZIhvcNAQEFBQADggEBAJ2wcFVffFHS
d9pj6RgoNHXZBsWp0HUZrNekiSbgomr4tSDefWtKb04nFIlRytfVs/k74wmbNiRCE8nDVBrBDFA/
+Tv/3PowZXHjXKBofUuScTP4/Tw1N/ywf7V+XY5kV3VmLBL6ax+ULJauR/YGIIMsIc/rS2D04aAc
ScU9pqVh2ML7nTH7gFqYrxypavmVk6K94vLjs0ggF2TGp7tXCRjeOlPPJS+MOJHJhTBWYFWvBLcl
U3zcri3ws7GqJMpeiHa7rMoHV0onxWsZTZW57ybaIWKLt1goAooC7hq0rx7oNlOvrys5lllhBySY
YC3ycqca/D0+GxXLcEr9QwP7TVw=</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="_9e8fd2ce4ad0212c98e7091ca8765fb4" 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="#_2aea7a651dbb687902c483432ed85780"/></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="_2aea7a651dbb687902c483432ed85780"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p" xmlns:xenc="http://www.w3.org/2001/04/xmlenc#"><ds:DigestMethod xmlns:ds="http://www.w3.org/2000/09/xmldsig#" Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/></xenc:EncryptionMethod><ds:KeyInfo xmlns:ds="http://www.w3.org/2000/09/xmldsig#"><ds:X509Data><ds:X509Certificate>MIIEsDCCApigAwIBAgIBADANBgkqhkiG9w0BAQUFADATMREwDwYDVQQDEwgxMC4wLjEuNDAeFw0x
NDA1MDgwMDU0MTlaFw0xNDA1MDgwMDU0MTlaMBMxETAPBgNVBAMTCDEwLjAuMS40MIICIjANBgkq
hkiG9w0BAQEFAAOCAg8AMIICCgKCAgEA5hqjaroJpB+aR8FME7hQ9nMV0h7MpKtmgFLcK3vwP67f
eAK+xdt17i8RyUhxil9FCFR5K08Wjwo3NiHZqHqEKitw+IJSndjLSsoNgKEIaiFSug2eV1oYElz0
6DBXTxc8iq/LazndqTUom51Ode9yI9AGa88cDM5iOqq9mhuGuvwuLtoyU78Ld+s1Ea6Mgf7L8M7f
ZVO7Ncu+FgIzI6Gt035ohYCLBmOoM7o0uj7DcMEvKOMFziwF40wYmyp3hCLlq3qwkM9pTVJltuz0
Bt1vqDdrq3kTheA9JHMayRz3I/BZxAV3iRd4hzLKTkegD8ToTGU10Gme+ZAr1w/erc5hVrM0/XBm
HQlnI5d31GU/mfIkm0XPTGRSpPy7E+dUvj9djvm/VqDdojf3uuwirGeLMRlO9P/lCerTktW3g27S
V8gn3ETm2Mm7rkNqf24KJpDv0tKDosgbdaHr2IEYD4RpqySp8kd25BhzushqKRkS8Xu5t7HAlVSH
wiFhuLqrr4dUfkB8kZeM/ycfZLCn7oNUDFdgjGYSVMpakL97sC9slAW4/8UtXXZxLqcyq/YxdpCy
sPYP1hsAp+VgPC7GI6CyiNojKPOptMqLZRYnViKxlOiWBJBzUBRUVuac8LXrMiDw8btWGa1Gh5vT
huFUKsvmRoeuk7eyXEN9J7j6+fTYjnsCAwEAAaMPMA0wCwYDVR0PBAQDAgTwMA0GCSqGSIb3DQEB
BQUAA4ICAQDAPFUo0Pga7vB4Ijy9u3qpWLQSCd4xfw8l92iq3JqLVXBx8Gf9XVy6GzbXWIe6pmQI
zmom/CWQvh6o7kc0F4y4ftsWfqnq3k0+HcX4Heu1PN2HSnUUPNsk5Adggd3129MHIdfaKb8bSuLJ
vSMeMaycrmsb+gEF6JFP8kGWOP4xQYjAVODcFbOyAfEuVAhujw0bqlLHT+El4vlfBrtdU+MZztIq
QkGDW7cmm86ZGiBr/ga97BCnOCrgZXlrgmia8SmF7Rfa48/Xzh7bDmPfgmHglL5JxhpRX2IoPY5X
ItmR8IaYKhOBOrO/qercJ6Z3rQ6fIrs8HrYgeTO/uE9ww6WRWCWDaCR4oWDVwjKzGfP1oJtAIQ+U
NjOddH5otDawXJRlQWpr72qT7+WOK/yzJhN0xmXDkmt5psMY/CDn4kXMM0xaRpfYOn5Sc1oelQ+h
Im8/rHVK/0krhCDOniqj+L/ne2SoyoXYgS6o0NlkNhtTHmjjosE7HV6JfAUgq2D9dq00JO967I3P
0VF6F8lcdaq0tovJhKWRjrrigYd756/3aT2B83JWA1RA9niXmrXfnAPZrNCfWvj+X2alUN/izdIq
Rts0UpWToVUr0ozWgmbmp5ZOGYOQh+lNcAp3V9lOrdbZVSITM47RYGBZaZNDA2PbDzC13MS/EjTE
vSkonwtlCg==</ds:X509Certificate></ds:X509Data></ds:KeyInfo><xenc:CipherData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#"><xenc:CipherValue>n0Gr3IkRIdch6QTxlL2QZCnQPF3txOHGmzR/+No11RTRf6+s0XPlo+DjaWuEWp2Ht2WdFnTus9FbpHatQWbIR5IWTAqk7vWIiaMm0WzkFuOGXkb/6rExqGNbv8Q9IPuLeo9USN9cke1yDYE+av6x2SVsR32trH5pBWUrbCBWJF5l2UtGVSpXEpuAVzziQXCY0rqymvfRVaFlhV1S2odWUmKeNX/VJ5rn0NZtNYvZ5eqaYbc6zTCk10EdR0zs5zP1fBlX2kCTO3vVj5hG+5yMGoDTw9lXYpYP3mQZDDqeShCrsJz+O63iSJ1fGjvwaIfyA0xv+N7c+Gr5fXuS4trZ3qOFbLyM+MKsVUCI4mpNflPtX61/JmMEqAdSkxTZtVmcsCl6r6UhIYU3fD9/IhaVd6mHUo1RyXeg99Y55A39zUUm5eb71lT/jf7nWJueb5IfHkXLCA1VWAdieWhSlsm+0TwVJDNSa9hqF0oVK/AKq6DWm6e+URerk1y4Rlp6Pkj0oXArRxvBEM2WOEAAbqvwrzWmJR0gigA7U0pxbzFrdh77s9VnFAPsT6h6zZf+mkuwRHAHxfi5uDsSW7El7qWf28uvxJyu1/AcmSG44qJM1zVaJT2Ve6mvEbKNYRz+aBg5MHmaqgcBo6U7wRMzluO4iRn5IIVux9FE69yEamibLSU=</xenc:CipherValue></xenc:CipherData><xenc:ReferenceList><xenc:DataReference URI="#_9e8fd2ce4ad0212c98e7091ca8765fb4"/></xenc:ReferenceList></xenc:EncryptedKey></saml2:EncryptedAssertion></saml2p:Response>', RelayState: '', }, config: { entryPoint: 'https://frontapp.oktapreview.com/app/frontdev584714_front_1/exk7xdi6axPfombzx0h7/sso/saml', cert: 'MIIDoDCCAoigAwIBAgIGAVaZ04POMA0GCSqGSIb3DQEBBQUAMIGQMQswCQYDVQQGEwJVUzETMBEGA1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEUMBIGA1UECwwLU1NPUHJvdmlkZXIxETAPBgNVBAMMCGZyb250YXBwMRwwGgYJKoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMB4XDTE2MDgxNzE4NDUzMVoXDTI2MDgxNzE4NDYzMVowgZAxCzAJBgNVBAYTAlVTMRMwEQYDVQQIDApDYWxpZm9ybmlhMRYwFAYDVQQHDA1TYW4gRnJhbmNpc2NvMQ0wCwYDVQQKDARPa3RhMRQwEgYDVQQLDAtTU09Qcm92aWRlcjERMA8GA1UEAwwIZnJvbnRhcHAxHDAaBgkqhkiG9w0BCQEWDWluZm9Ab2t0YS5jb20wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCvplQONVwknRy1iBnaoZtsOz28A7XW2tRpFW+0La7RJexbziIwEy1bPZENhfwjPZA1oHHZqi5l315BxXKWJqmmNmbDCFDo+/FYFCoHXliiLm9vqDbR1br6ByqeY0GfxyTPKHZxb2FSes30TffDknpMQd/8kA9YWaW5xDlu2ivWJI+sfcOJOMd6t+gcfXj58a5fP8Mwm6Y220KeZSvrVpEV2KDp9hln7fhhoxHZ7K/BYbidqdwLzeUQXpb6LIrxtKdug2FofS+ONs6yLIQRmrbCB7SVX1QA8JInMn+fzrGtZmFiHR0aFbyhiO78v/ufDa6S+XpYyp2b6D4SnzeggnobAgMBAAEwDQYJKoZIhvcNAQEFBQADggEBAJ2wcFVffFHSd9pj6RgoNHXZBsWp0HUZrNekiSbgomr4tSDefWtKb04nFIlRytfVs/k74wmbNiRCE8nDVBrBDFA/+Tv/3PowZXHjXKBofUuScTP4/Tw1N/ywf7V+XY5kV3VmLBL6ax+ULJauR/YGIIMsIc/rS2D04aAcScU9pqVh2ML7nTH7gFqYrxypavmVk6K94vLjs0ggF2TGp7tXCRjeOlPPJS+MOJHJhTBWYFWvBLclU3zcri3ws7GqJMpeiHa7rMoHV0onxWsZTZW57ybaIWKLt1goAooC7hq0rx7oNlOvrys5lllhBySYYC3ycqca/D0+GxXLcEr9QwP7TVw=', decryptionPvk: fs.readFileSync(__dirname + '/static/testshib encryption pvk.pem') }, expectedStatusCode: 200, expectedNameIDStartsWith: 'xavier', mockDate: '2016-08-19T01:15:32.681Z' }, { name: 'Onelogin -- invalid cert (from Okta case) should fail', samlResponse: { SAMLResponse: 'PHNhbWxwOlJlc3BvbnNlIHhtbG5zOnNhbWw9InVybjpvYXNpczpuYW1lczp0\r\nYzpTQU1MOjIuMDphc3NlcnRpb24iIHhtbG5zOnNhbWxwPSJ1cm46b2FzaXM6\r\nbmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiIElEPSJSNjg5YjA3MzNiY2Nj\r\nYTIyYTEzN2UzNjU0ODMwMzEyMzMyOTQwYjFiZSIgVmVyc2lvbj0iMi4wIiBJ\r\nc3N1ZUluc3RhbnQ9IjIwMTQtMDUtMjhUMDA6MTY6MDhaIiBEZXN0aW5hdGlv\r\nbj0ie3JlY2lwaWVudH0iIEluUmVzcG9uc2VUbz0iX2E2ZmM0NmJlODRlMWUz\r\nY2YzYzUwIj48c2FtbDpJc3N1ZXI+aHR0cHM6Ly9hcHAub25lbG9naW4uY29t\r\nL3NhbWwvbWV0YWRhdGEvMzcxNzU1PC9zYW1sOklzc3Vlcj48c2FtbHA6U3Rh\r\ndHVzPjxzYW1scDpTdGF0dXNDb2RlIFZhbHVlPSJ1cm46b2FzaXM6bmFtZXM6\r\ndGM6U0FNTDoyLjA6c3RhdHVzOlN1Y2Nlc3MiLz48L3NhbWxwOlN0YXR1cz48\r\nc2FtbDpBc3NlcnRpb24geG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIw\r\nMDEvWE1MU2NoZW1hIiB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIw\r\nMDEvWE1MU2NoZW1hLWluc3RhbmNlIiBWZXJzaW9uPSIyLjAiIElEPSJwZngz\r\nYjYzYzdiZS1mZTg2LTYyZmQtOGNiNS0xNmFiNjI3M2VmYWEiIElzc3VlSW5z\r\ndGFudD0iMjAxNC0wNS0yOFQwMDoxNjowOFoiPjxzYW1sOklzc3Vlcj5odHRw\r\nczovL2FwcC5vbmVsb2dpbi5jb20vc2FtbC9tZXRhZGF0YS8zNzE3NTU8L3Nh\r\nbWw6SXNzdWVyPjxkczpTaWduYXR1cmUgeG1sbnM6ZHM9Imh0dHA6Ly93d3cu\r\ndzMub3JnLzIwMDAvMDkveG1sZHNpZyMiPjxkczpTaWduZWRJbmZvPjxkczpD\r\nYW5vbmljYWxpemF0aW9uTWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53\r\nMy5vcmcvMjAwMS8xMC94bWwtZXhjLWMxNG4jIi8+PGRzOlNpZ25hdHVyZU1l\r\ndGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1s\r\nZHNpZyNyc2Etc2hhMSIvPjxkczpSZWZlcmVuY2UgVVJJPSIjcGZ4M2I2M2M3\r\nYmUtZmU4Ni02MmZkLThjYjUtMTZhYjYyNzNlZmFhIj48ZHM6VHJhbnNmb3Jt\r\ncz48ZHM6VHJhbnNmb3JtIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcv\r\nMjAwMC8wOS94bWxkc2lnI2VudmVsb3BlZC1zaWduYXR1cmUiLz48ZHM6VHJh\r\nbnNmb3JtIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8xMC94\r\nbWwtZXhjLWMxNG4jIi8+PC9kczpUcmFuc2Zvcm1zPjxkczpEaWdlc3RNZXRo\r\nb2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRz\r\naWcjc2hhMSIvPjxkczpEaWdlc3RWYWx1ZT5EQ25QVFFZQmIxaEtzcGJlNmZn\r\nMVUzcTh4bjQ9PC9kczpEaWdlc3RWYWx1ZT48L2RzOlJlZmVyZW5jZT48L2Rz\r\nOlNpZ25lZEluZm8+PGRzOlNpZ25hdHVyZVZhbHVlPmUwK2FGb21BMCtKQVkw\r\nZjl0S3F6SXVxSVZTU3c3TGlGVXNuZUVES1BCV2RpVHoxc01kZ3IvMnkxZTkr\r\ncmphUzJtUm1DaS92U1FMWTN6VFl6MGhwNm5KTlUxOStUV29YbzlrSFF5V1Q0\r\nS2tlUUw0WHMvZ1ovQW9LQzIwaUhWS3RwUHBzMElRME1sL3FSb291U2l0dDZT\r\nZi9XRHoyTFYvcFdjSDJoeDV0djN4U3czNmhLMk5RYzdxdzdyMW1FWG52Y2pY\r\nUmVZbzhyclZmN1hIR0d4Tm9SSUVJQ1VJaTExMHV2c1dlbVNYZjBaMGR5YjBG\r\nVllPV3VTc1FNRGx6TnBoZUFEQmlmRk80VVRmU0VoRlp2bjhrVkNHWlVJd3Ji\r\nT2haMmQvK1lFdGd5dVRnK3F0c2xnZnk0ZHdkNFR2RWNmdVJ6UVRhemVlZnBy\r\nU0Z5aVFja0FYT2pjdz09PC9kczpTaWduYXR1cmVWYWx1ZT48ZHM6S2V5SW5m\r\nbz48ZHM6WDUwOURhdGE+PGRzOlg1MDlDZXJ0aWZpY2F0ZT5NSUlFRnpDQ0F2\r\nK2dBd0lCQWdJVUZKc1VqUE03QW1Xdk50RXZVTFNIbFRUTWlMUXdEUVlKS29a\r\nSWh2Y05BUUVGQlFBd1dERUxNQWtHQTFVRUJoTUNWVk14RVRBUEJnTlZCQW9N\r\nQ0ZOMVluTndZV05sTVJVd0V3WURWUVFMREF4UGJtVk1iMmRwYmlCSlpGQXhI\r\nekFkQmdOVkJBTU1Gazl1WlV4dloybHVJRUZqWTI5MWJuUWdOREl6TkRrd0ho\r\nY05NVFF3TlRFek1UZ3dOakV5V2hjTk1Ua3dOVEUwTVRnd05qRXlXakJZTVFz\r\nd0NRWURWUVFHRXdKVlV6RVJNQThHQTFVRUNnd0lVM1ZpYzNCaFkyVXhGVEFU\r\nQmdOVkJBc01ERTl1WlV4dloybHVJRWxrVURFZk1CMEdBMVVFQXd3V1QyNWxU\r\nRzluYVc0Z1FXTmpiM1Z1ZENBME1qTTBPVENDQVNJd0RRWUpLb1pJaHZjTkFR\r\nRUJCUUFEZ2dFUEFEQ0NBUW9DZ2dFQkFLckF6SmRZOUZ6Rkx0NWJsQXJKZlB6\r\nZ2k4N0VuRkdsVGZjVjVUMVRVRHdMQmxEa1kvMFpHS25NT3BmM0Q3aWUyQzRw\r\nUEZPSW1Pb2djTTVrcERETDdxeFRYWjFld1hWeWpCZE11MjlORzJDNk56V2VR\r\nVFVNVWppMDFFY0hrQzhvK1B0czhBTmlOT1ljanhFZXloRXl6SktnRWl6YmxZ\r\nek1NS3pkck9FVDZRdXFXbzNDODNLKzUrNWRzakRuMW9vS0dSd2ozSHZnc1lj\r\nRnJRbDlOb2pnUUZqb29id3NpRS83QStPSmhMcEJjeS9uU1Znbm9KYU1mck8r\r\nSnNudWtaUHp0Ym50THZPbDU2K1ZyYTBOOG41TkFZaGFTYXlQaXYvYXloalZn\r\namZYZDF0ak1WVE9pRGtuVU93aXpadUoxWTNRSDk0dlV0QmdwMFdCcEJTcy94\r\nTXlUczhDQXdFQUFhT0IyRENCMVRBTUJnTlZIUk1CQWY4RUFqQUFNQjBHQTFV\r\nZERnUVdCQlJRTzRXcE01Zld3eGliNDlXVHVKa2ZZRGJ4T0RDQmxRWURWUjBq\r\nQklHTk1JR0tnQlJRTzRXcE01Zld3eGliNDlXVHVKa2ZZRGJ4T0tGY3BGb3dX\r\nREVMTUFrR0ExVUVCaE1DVlZNeEVUQVBCZ05WQkFvTUNGTjFZbk53WVdObE1S\r\nVXdFd1lEVlFRTERBeFBibVZNYjJkcGJpQkpaRkF4SHpBZEJnTlZCQU1NRms5\r\ndVpVeHZaMmx1SUVGalkyOTFiblFnTkRJek5EbUNGQlNiRkl6ek93SmxyemJS\r\nTDFDMGg1VTB6SWkwTUE0R0ExVWREd0VCL3dRRUF3SUhnREFOQmdrcWhraUc5\r\ndzBCQVFVRkFBT0NBUUVBQ2REQUFvYVpGQ0VZNXBtZndiS3VLclh0TzVpRThs\r\nV3RpQ1BqQ1pFVXVUNmJYUk5jcXJkbnVWL0VBZlg5V1FvWGphbFBpMGVNNzh6\r\nS21idlJHU1RVSHdXdzQ5UkhqRmZlSlVLdkhOZU5uRmdUWERqRVBOaE12aDY5\r\na0htNDUzbEZSbUIra2s2eWp0WFJaYVFFd1M4VXVvMk90K2tyZ05ibDZvVEJa\r\nSjBBSEgxTXRaRUNEbG9tczFLbTd6c0s4d0FpNWk4VFZJS2tWcjViMlZsaHJM\r\nZ0ZNdnpaNVZpQXhJTUdCNnc0N3lZNFFHUUIvNVE4eWE5aEJzOXZrbit3dWJB\r\nK3lyNGoxNEpYWjdibFZLRFNUWXZhNjVFYStQcUh5cnArV25tbmJ3Mk9iUzdp\r\nV2V4aVR5MWpEM0cwUjJhdkRCRmpNOEZqNURiZnVmc0UxYjBVMTBSVHRnPT08\r\nL2RzOlg1MDlDZXJ0aWZpY2F0ZT48L2RzOlg1MDlEYXRhPjwvZHM6S2V5SW5m\r\nbz48L2RzOlNpZ25hdHVyZT48c2FtbDpTdWJqZWN0PjxzYW1sOk5hbWVJRCBG\r\nb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpuYW1laWQtZm9y\r\nbWF0OnRyYW5zaWVudCI+cGxvZXJAc3Vic3BhY2Vzdy5jb208L3NhbWw6TmFt\r\nZUlEPjxzYW1sOlN1YmplY3RDb25maXJtYXRpb24gTWV0aG9kPSJ1cm46b2Fz\r\naXM6bmFtZXM6dGM6U0FNTDoyLjA6Y206YmVhcmVyIj48c2FtbDpTdWJqZWN0\r\nQ29uZmlybWF0aW9uRGF0YSBOb3RPbk9yQWZ0ZXI9IjIwMTQtMDUtMjhUMDA6\r\nMTk6MDhaIiBSZWNpcGllbnQ9IntyZWNpcGllbnR9IiBJblJlc3BvbnNlVG89\r\nIl9hNmZjNDZiZTg0ZTFlM2NmM2M1MCIvPjwvc2FtbDpTdWJqZWN0Q29uZmly\r\nbWF0aW9uPjwvc2FtbDpTdWJqZWN0PjxzYW1sOkNvbmRpdGlvbnMgTm90QmVm\r\nb3JlPSIyMDE0LTA1LTI4VDAwOjEzOjA4WiIgTm90T25PckFmdGVyPSIyMDE0\r\nLTA1LTI4VDAwOjE5OjA4WiI+PHNhbWw6QXVkaWVuY2VSZXN0cmljdGlvbj48\r\nc2FtbDpBdWRpZW5jZT57YXVkaWVuY2V9PC9zYW1sOkF1ZGllbmNlPjwvc2Ft\r\nbDpBdWRpZW5jZVJlc3RyaWN0aW9uPjwvc2FtbDpDb25kaXRpb25zPjxzYW1s\r\nOkF1dGhuU3RhdGVtZW50IEF1dGhuSW5zdGFudD0iMjAxNC0wNS0yOFQwMDox\r\nNjowN1oiIFNlc3Npb25Ob3RPbk9yQWZ0ZXI9IjIwMTQtMDUtMjlUMDA6MTY6\r\nMDhaIiBTZXNzaW9uSW5kZXg9Il8zMGE0YWY1MC1jODJiLTAxMzEtZjhiNS03\r\nODJiY2I1NmZjYWEiPjxzYW1sOkF1dGhuQ29udGV4dD48c2FtbDpBdXRobkNv\r\nbnRleHRDbGFzc1JlZj51cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YWM6\r\nY2xhc3NlczpQYXNzd29yZFByb3RlY3RlZFRyYW5zcG9ydDwvc2FtbDpBdXRo\r\nbkNvbnRleHRDbGFzc1JlZj48L3NhbWw6QXV0aG5Db250ZXh0Pjwvc2FtbDpB\r\ndXRoblN0YXRlbWVudD48L3NhbWw6QXNzZXJ0aW9uPjwvc2FtbHA6UmVzcG9u\r\nc2U+Cgo=\r\n' }, config: { entryPoint: 'https://subspacesw1.okta.com/app/subspacesw_subspacetest_1/kvjj46lsDQEQYUDBZIYW/sso/saml', cert: 'MIICoTCCAgqgAwIBAgIGAUY8zVPYMA0GCSqGSIb3DQEBBQUAMIGTMQswCQYDVQQGEwJVUzETMBEGA1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEUMBIGA1UECwwLU1NPUHJvdmlkZXIxFDASBgNVBAMMC3N1YnNwYWNlc3cxMRwwGgYJKoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMB4XDTE0MDUyNzA4MjkyN1oXDTQ0MDUyNzA4MzAyN1owgZMxCzAJBgNVBAYTAlVTMRMwEQYDVQQIDApDYWxpZm9ybmlhMRYwFAYDVQQHDA1TYW4gRnJhbmNpc2NvMQ0wCwYDVQQKDARPa3RhMRQwEgYDVQQLDAtTU09Qcm92aWRlcjEUMBIGA1UEAwwLc3Vic3BhY2VzdzExHDAaBgkqhkiG9w0BCQEWDWluZm9Ab2t0YS5jb20wgZ8wDQYJKoZIhvcNAQEBBQADgY0AMIGJAoGBAKYX/UdV9HLXbNKv0yc6YJBtzdWNuGTPIXWVPCb0OsRvR54lq+0SLPQGJS39flWKiqtUiEusuih6GdLfNvFAVLGPqBTWQ4Lc7r5+zD5qnH6LiTM1KCbaF3uu2P+T+utsGqFUZawA9FEVNLkICe36X1yE40X+/jMygyieQPMeJABvAgMBAAEwDQYJKoZIhvcNAQEFBQADgYEAHSWPG4y1bNyJySgbFqDcS/6MUNIrSfkQYIxzIGQ37qy5qAW15YkBUiW9TsGJRcrgusVrZIia18eYz84Zn7FyUZNMFo24L7l6BS0WCitIQScBCKB4QWA/b1szqs7EtpOcPP01TYNq2ras+VqR3aWAXLX2oKfClV/SUwszRf5U85Y=' }, expectedStatusCode: 500, mockDate: '2014-05-28T00:16:08Z' }, { name: 'Onelogin -- valid config should succeed', samlResponse: { SAMLResponse: 'PHNhbWxwOlJlc3BvbnNlIHhtbG5zOnNhbWw9InVybjpvYXNpczpuYW1lczp0\r\nYzpTQU1MOjIuMDphc3NlcnRpb24iIHhtbG5zOnNhbWxwPSJ1cm46b2FzaXM6\r\nbmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiIElEPSJSNjg5YjA3MzNiY2Nj\r\nYTIyYTEzN2UzNjU0ODMwMzEyMzMyOTQwYjFiZSIgVmVyc2lvbj0iMi4wIiBJ\r\nc3N1ZUluc3RhbnQ9IjIwMTQtMDUtMjhUMDA6MTY6MDhaIiBEZXN0aW5hdGlv\r\nbj0ie3JlY2lwaWVudH0iIEluUmVzcG9uc2VUbz0iX2E2ZmM0NmJlODRlMWUz\r\nY2YzYzUwIj48c2FtbDpJc3N1ZXI+aHR0cHM6Ly9hcHAub25lbG9naW4uY29t\r\nL3NhbWwvbWV0YWRhdGEvMzcxNzU1PC9zYW1sOklzc3Vlcj48c2FtbHA6U3Rh\r\ndHVzPjxzYW1scDpTdGF0dXNDb2RlIFZhbHVlPSJ1cm46b2FzaXM6bmFtZXM6\r\ndGM6U0FNTDoyLjA6c3RhdHVzOlN1Y2Nlc3MiLz48L3NhbWxwOlN0YXR1cz48\r\nc2FtbDpBc3NlcnRpb24geG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIw\r\nMDEvWE1MU2NoZW1hIiB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIw\r\nMDEvWE1MU2NoZW1hLWluc3RhbmNlIiBWZXJzaW9uPSIyLjAiIElEPSJwZngz\r\nYjYzYzdiZS1mZTg2LTYyZmQtOGNiNS0xNmFiNjI3M2VmYWEiIElzc3VlSW5z\r\ndGFudD0iMjAxNC0wNS0yOFQwMDoxNjowOFoiPjxzYW1sOklzc3Vlcj5odHRw\r\nczovL2FwcC5vbmVsb2dpbi5jb20vc2FtbC9tZXRhZGF0YS8zNzE3NTU8L3Nh\r\nbWw6SXNzdWVyPjxkczpTaWduYXR1cmUgeG1sbnM6ZHM9Imh0dHA6Ly93d3cu\r\ndzMub3JnLzIwMDAvMDkveG1sZHNpZyMiPjxkczpTaWduZWRJbmZvPjxkczpD\r\nYW5vbmljYWxpemF0aW9uTWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53\r\nMy5vcmcvMjAwMS8xMC94bWwtZXhjLWMxNG4jIi8+PGRzOlNpZ25hdHVyZU1l\r\ndGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1s\r\nZHNpZyNyc2Etc2hhMSIvPjxkczpSZWZlcmVuY2UgVVJJPSIjcGZ4M2I2M2M3\r\nYmUtZmU4Ni02MmZkLThjYjUtMTZhYjYyNzNlZmFhIj48ZHM6VHJhbnNmb3Jt\r\ncz48ZHM6VHJhbnNmb3JtIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcv\r\nMjAwMC8wOS94bWxkc2lnI2VudmVsb3BlZC1zaWduYXR1cmUiLz48ZHM6VHJh\r\nbnNmb3JtIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8xMC94\r\nbWwtZXhjLWMxNG4jIi8+PC9kczpUcmFuc2Zvcm1zPjxkczpEaWdlc3RNZXRo\r\nb2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRz\r\naWcjc2hhMSIvPjxkczpEaWdlc3RWYWx1ZT5EQ25QVFFZQmIxaEtzcGJlNmZn\r\nMVUzcTh4bjQ9PC9kczpEaWdlc3RWYWx1ZT48L2RzOlJlZmVyZW5jZT48L2Rz\r\nOlNpZ25lZEluZm8+PGRzOlNpZ25hdHVyZVZhbHVlPmUwK2FGb21BMCtKQVkw\r\nZjl0S3F6SXVxSVZTU3c3TGlGVXNuZUVES1BCV2RpVHoxc01kZ3IvMnkxZTkr\r\ncmphUzJtUm1DaS92U1FMWTN6VFl6MGhwNm5KTlUxOStUV29YbzlrSFF5V1Q0\r\nS2tlUUw0WHMvZ1ovQW9LQzIwaUhWS3RwUHBzMElRME1sL3FSb291U2l0dDZT\r\nZi9XRHoyTFYvcFdjSDJoeDV0djN4U3czNmhLMk5RYzdxdzdyMW1FWG52Y2pY\r\nUmVZbzhyclZmN1hIR0d4Tm9SSUVJQ1VJaTExMHV2c1dlbVNYZjBaMGR5YjBG\r\nVllPV3VTc1FNRGx6TnBoZUFEQmlmRk80VVRmU0VoRlp2bjhrVkNHWlVJd3Ji\r\nT2haMmQvK1lFdGd5dVRnK3F0c2xnZnk0ZHdkNFR2RWNmdVJ6UVRhemVlZnBy\r\nU0Z5aVFja0FYT2pjdz09PC9kczpTaWduYXR1cmVWYWx1ZT48ZHM6S2V5SW5m\r\nbz48ZHM6WDUwOURhdGE+PGRzOlg1MDlDZXJ0aWZpY2F0ZT5NSUlFRnpDQ0F2\r\nK2dBd0lCQWdJVUZKc1VqUE03QW1Xdk50RXZVTFNIbFRUTWlMUXdEUVlKS29a\r\nSWh2Y05BUUVGQlFBd1dERUxNQWtHQTFVRUJoTUNWVk14RVRBUEJnTlZCQW9N\r\nQ0ZOMVluTndZV05sTVJVd0V3WURWUVFMREF4UGJtVk1iMmRwYmlCSlpGQXhI\r\nekFkQmdOVkJBTU1Gazl1WlV4dloybHVJRUZqWTI5MWJuUWdOREl6TkRrd0ho\r\nY05NVFF3TlRFek1UZ3dOakV5V2hjTk1Ua3dOVEUwTVRnd05qRXlXakJZTVFz\r\nd0NRWURWUVFHRXdKVlV6RVJNQThHQTFVRUNnd0lVM1ZpYzNCaFkyVXhGVEFU\r\nQmdOVkJBc01ERTl1WlV4dloybHVJRWxrVURFZk1CMEdBMVVFQXd3V1QyNWxU\r\nRzluYVc0Z1FXTmpiM1Z1ZENBME1qTTBPVENDQVNJd0RRWUpLb1pJaHZjTkFR\r\nRUJCUUFEZ2dFUEFEQ0NBUW9DZ2dFQkFLckF6SmRZOUZ6Rkx0NWJsQXJKZlB6\r\nZ2k4N0VuRkdsVGZjVjVUMVRVRHdMQmxEa1kvMFpHS25NT3BmM0Q3aWUyQzRw\r\nUEZPSW1Pb2djTTVrcERETDdxeFRYWjFld1hWeWpCZE11MjlORzJDNk56V2VR\r\nVFVNVWppMDFFY0hrQzhvK1B0czhBTmlOT1ljanhFZXloRXl6SktnRWl6YmxZ\r\nek1NS3pkck9FVDZRdXFXbzNDODNLKzUrNWRzakRuMW9vS0dSd2ozSHZnc1lj\r\nRnJRbDlOb2pnUUZqb29id3NpRS83QStPSmhMcEJjeS9uU1Znbm9KYU1mck8r\r\nSnNudWtaUHp0Ym50THZPbDU2K1ZyYTBOOG41TkFZaGFTYXlQaXYvYXloalZn\r\namZYZDF0ak1WVE9pRGtuVU93aXpadUoxWTNRSDk0dlV0QmdwMFdCcEJTcy94\r\nTXlUczhDQXdFQUFhT0IyRENCMVRBTUJnTlZIUk1CQWY4RUFqQUFNQjBHQTFV\r\nZERnUVdCQlJRTzRXcE01Zld3eGliNDlXVHVKa2ZZRGJ4T0RDQmxRWURWUjBq\r\nQklHTk1JR0tnQlJRTzRXcE01Zld3eGliNDlXVHVKa2ZZRGJ4T0tGY3BGb3dX\r\nREVMTUFrR0ExVUVCaE1DVlZNeEVUQVBCZ05WQkFvTUNGTjFZbk53WVdObE1S\r\nVXdFd1lEVlFRTERBeFBibVZNYjJkcGJpQkpaRkF4SHpBZEJnTlZCQU1NRms5\r\ndVpVeHZaMmx1SUVGalkyOTFiblFnTkRJek5EbUNGQlNiRkl6ek93SmxyemJS\r\nTDFDMGg1VTB6SWkwTUE0R0ExVWREd0VCL3dRRUF3SUhnREFOQmdrcWhraUc5\r\ndzBCQVFVRkFBT0NBUUVBQ2REQUFvYVpGQ0VZNXBtZndiS3VLclh0TzVpRThs\r\nV3RpQ1BqQ1pFVXVUNmJYUk5jcXJkbnVWL0VBZlg5V1FvWGphbFBpMGVNNzh6\r\nS21idlJHU1RVSHdXdzQ5UkhqRmZlSlVLdkhOZU5uRmdUWERqRVBOaE12aDY5\r\na0htNDUzbEZSbUIra2s2eWp0WFJaYVFFd1M4VXVvMk90K2tyZ05ibDZvVEJa\r\nSjBBSEgxTXRaRUNEbG9tczFLbTd6c0s4d0FpNWk4VFZJS2tWcjViMlZsaHJM\r\nZ0ZNdnpaNVZpQXhJTUdCNnc0N3lZNFFHUUIvNVE4eWE5aEJzOXZrbit3dWJB\r\nK3lyNGoxNEpYWjdibFZLRFNUWXZhNjVFYStQcUh5cnArV25tbmJ3Mk9iUzdp\r\nV2V4aVR5MWpEM0cwUjJhdkRCRmpNOEZqNURiZnVmc0UxYjBVMTBSVHRnPT08\r\nL2RzOlg1MDlDZXJ0aWZpY2F0ZT48L2RzOlg1MDlEYXRhPjwvZHM6S2V5SW5m\r\nbz48L2RzOlNpZ25hdHVyZT48c2FtbDpTdWJqZWN0PjxzYW1sOk5hbWVJRCBG\r\nb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpuYW1laWQtZm9y\r\nbWF0OnRyYW5zaWVudCI+cGxvZXJAc3Vic3BhY2Vzdy5jb208L3NhbWw6TmFt\r\nZUlEPjxzYW1sOlN1YmplY3RDb25maXJtYXRpb24gTWV0aG9kPSJ1cm46b2Fz\r\naXM6bmFtZXM6dGM6U0FNTDoyLjA6Y206YmVhcmVyIj48c2FtbDpTdWJqZWN0\r\nQ29uZmlybWF0aW9uRGF0YSBOb3RPbk9yQWZ0ZXI9IjIwMTQtMDUtMjhUMDA6\r\nMTk6MDhaIiBSZWNpcGllbnQ9IntyZWNpcGllbnR9IiBJblJlc3BvbnNlVG89\r\nIl9hNmZjNDZiZTg0ZTFlM2NmM2M1MCIvPjwvc2FtbDpTdWJqZWN0Q29uZmly\r\nbWF0aW9uPjwvc2FtbDpTdWJqZWN0PjxzYW1sOkNvbmRpdGlvbnMgTm90QmVm\r\nb3JlPSIyMDE0LTA1LTI4VDAwOjEzOjA4WiIgTm90T25PckFmdGVyPSIyMDE0\r\nLTA1LTI4VDAwOjE5OjA4WiI+PHNhbWw6QXVkaWVuY2VSZXN0cmljdGlvbj48\r\nc2FtbDpBdWRpZW5jZT57YXVkaWVuY2V9PC9zYW1sOkF1ZGllbmNlPjwvc2Ft\r\nbDpBdWRpZW5jZVJlc3RyaWN0aW9uPjwvc2FtbDpDb25kaXRpb25zPjxzYW1s\r\nOkF1dGhuU3RhdGVtZW50IEF1dGhuSW5zdGFudD0iMjAxNC0wNS0yOFQwMDox\r\nNjowN1oiIFNlc3Npb25Ob3RPbk9yQWZ0ZXI9IjIwMTQtMDUtMjlUMDA6MTY6\r\nMDhaIiBTZXNzaW9uSW5kZXg9Il8zMGE0YWY1MC1jODJiLTAxMzEtZjhiNS03\r\nODJiY2I1NmZjYWEiPjxzYW1sOkF1dGhuQ29udGV4dD48c2FtbDpBdXRobkNv\r\nbnRleHRDbGFzc1JlZj51cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YWM6\r\nY2xhc3NlczpQYXNzd29yZFByb3RlY3RlZFRyYW5zcG9ydDwvc2FtbDpBdXRo\r\nbkNvbnRleHRDbGFzc1JlZj48L3NhbWw6QXV0aG5Db250ZXh0Pjwvc2FtbDpB\r\ndXRoblN0YXRlbWVudD48L3NhbWw6QXNzZXJ0aW9uPjwvc2FtbHA6UmVzcG9u\r\nc2U+Cgo=\r\n' }, config: { entryPoint: 'https://app.onelogin.com/trust/saml2/http-post/sso/371755', cert: TEST_CERT, }, expectedStatusCode: 200, expectedNameIDStartsWith: 'ploer', mockDate: '2014-05-28T00:16:08Z' }, { name: 'Testshib -- valid encrypted response should succeed', samlResponse: { SAMLResponse: '<?xml version="1.0" encoding="UTF-8"?><saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="http://localhost/browserSamlLogin" ID="_7f9e95c711654aa41b326f8b847f7a13" InResponseTo="_3138d675d6ed416d43d6" IssueInstant="2014-06-02T17:48:56.820Z" 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">https://idp.testshib.org/idp/shibboleth</saml2:Issuer><saml2p:Status><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="_fbb14743510a6292f8750efde39ba726" Type="http://www.w3.org/2001/04/xmlenc#Element"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes128-cbc" xmlns:xenc="http://www.w3.org/2001/04/xmlenc#"/><ds:KeyInfo xmlns:ds="http://www.w3.org/2000/09/xmldsig#"><xenc:EncryptedKey Id="_44a1099405dc8102ea1ffc7f94c2af92" xmlns:xenc="http://www.w3.org/2001/04/xmlenc#"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p" xmlns:xenc="http://www.w3.org/2001/04/xmlenc#"><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1" xmlns:ds="http://www.w3.org/2000/09/xmldsig#"/></xenc:EncryptionMethod><ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIEsDCCApigAwIBAgIBADANBgkqhkiG9w0BAQUFADATMREwDwYDVQQDEwgxMC4wLjEuNDAeFw0x
NDA1MDgwMDU0MTlaFw0xNDA1MDgwMDU0MTlaMBMxETAPBgNVBAMTCDEwLjAuMS40MIICIjANBgkq
hkiG9w0BAQEFAAOCAg8AMIICCgKCAgEA5hqjaroJpB+aR8FME7hQ9nMV0h7MpKtmgFLcK3vwP67f
eAK+xdt17i8RyUhxil9FCFR5K08Wjwo3NiHZqHqEKitw+IJSndjLSsoNgKEIaiFSug2eV1oYElz0
6DBXTxc8iq/LazndqTUom51Ode9yI9AGa88cDM5iOqq9mhuGuvwuLtoyU78Ld+s1Ea6Mgf7L8M7f
ZVO7Ncu+FgIzI6Gt035ohYCLBmOoM7o0uj7DcMEvKOMFziwF40wYmyp3hCLlq3qwkM9pTVJltuz0
Bt1vqDdrq3kTheA9JHMayRz3I/BZxAV3iRd4hzLKTkegD8ToTGU10Gme+ZAr1w/erc5hVrM0/XBm
HQlnI5d31GU/mfIkm0XPTGRSpPy7E+dUvj9djvm/VqDdojf3uuwirGeLMRlO9P/lCerTktW3g27S
V8gn3ETm2Mm7rkNqf24KJpDv0tKDosgbdaHr2IEYD4RpqySp8kd25BhzushqKRkS8Xu5t7HAlVSH
wiFhuLqrr4dUfkB8kZeM/ycfZLCn7oNUDFdgjGYSVMpakL97sC9slAW4/8UtXXZxLqcyq/YxdpCy
sPYP1hsAp+VgPC7GI6CyiNojKPOptMqLZRYnViKxlOiWBJBzUBRUVuac8LXrMiDw8btWGa1Gh5vT
huFUKsvmRoeuk7eyXEN9J7j6+fTYjnsCAwEAAaMPMA0wCwYDVR0PBAQDAgTwMA0GCSqGSIb3DQEB
BQUAA4ICAQDAPFUo0Pga7vB4Ijy9u3qpWLQSCd4xfw8l92iq3JqLVXBx8Gf9XVy6GzbXWIe6pmQI
zmom/CWQvh6o7kc0F4y4ftsWfqnq3k0+HcX4Heu1PN2HSnUUPNsk5Adggd3129MHIdfaKb8bSuLJ
vSMeMaycrmsb+gEF6JFP8kGWOP4xQYjAVODcFbOyAfEuVAhujw0bqlLHT+El4vlfBrtdU+MZztIq
QkGDW7cmm86ZGiBr/ga97BCnOCrgZXlrgmia8SmF7Rfa48/Xzh7bDmPfgmHglL5JxhpRX2IoPY5X
ItmR8IaYKhOBOrO/qercJ6Z3rQ6fIrs8HrYgeTO/uE9ww6WRWCWDaCR4oWDVwjKzGfP1oJtAIQ+U
NjOddH5otDawXJRlQWpr72qT7+WOK/yzJhN0xmXDkmt5psMY/CDn4kXMM0xaRpfYOn5Sc1oelQ+h
Im8/rHVK/0krhCDOniqj+L/ne2SoyoXYgS6o0NlkNhtTHmjjosE7HV6JfAUgq2D9dq00JO967I3P
0VF6F8lcdaq0tovJhKWRjrrigYd756/3aT2B83JWA1RA9niXmrXfnAPZrNCfWvj+X2alUN/izdIq
Rts0UpWToVUr0ozWgmbmp5ZOGYOQh+lNcAp3V9lOrdbZVSITM47RYGBZaZNDA2PbDzC13MS/EjTE
vSkonwtlCg==</ds:X509Certificate></ds:X509Data></ds:KeyInfo><xenc:CipherData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#"><xenc:CipherValue>QOTLhfiNCSh6Gn5dPZd5B0wHBEPMgHliWxzLJvx9QMlczSWujgiJwwlw7c8PvSMKMeu1h8am7tdE0rp2wRiIBczzGNXTnnqhS571s0PKohQ7HxeTWgF1I2btW2Y0sIBl6V/juxnPUB1wIHPqwLaYovCzzyVyekByYjb6YJuxCOGLF/u9105/ScIt1wXckCkMINqf4uGZOAM8fJA1sAoew6CrruPnNjECZcaqSAf6EP/x0b0iu/zVQOOY0tY1TQBjLD1Q9QhKo6MhB/gXM/pinxJu3xQqA5HXKsTgVJiwIYBBWppqsoVVQdFQq+bY29ZGX9sM+0skglbVBnts8CBqMttHJLS54MFrxi2tcLu8uszNk4azj5NvlY2Qfi2SLgol3ZM/C4b0DDFKLWsf8+YdhFh6yOoYd7cfgxde9j+F+Tr6Szsyyrn73NuOwHIXuv7a1dwnKzH3ohWfAJ3ukrSmfjEckEDd6i1Adbj0XeHX0ClfiM+B+G9whCaWEHxTb/tcxuW17Icpxq2HjFBRc4nEHhTK9TpprJ8QObBSgjnelH63z2lRIQVsyXP6fWd8gqa4mdCuZPk7ajit56vPqrPYRMrG557EZR92Vn6efrkgClkhRq4VjOlMFMfX6CJUpsInGTyHJtjtX/GU55dboWjTKtndqxC256Km2e3sVOfT9Js=</xenc:CipherValue></xenc:CipherData></xenc:EncryptedKey></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></saml2:EncryptedAssertion></saml2p:Response>' }, config: { entryPoint: 'https://idp.testshib.org/idp/profile/SAML2/Redirect/SSO', cert: 'MIIEDjCCAvagAwIBAgIBADANBgkqhkiG9w0BAQUFADBnMQswCQYDVQQGEwJVUzEVMBMGA1UECBMMUGVubnN5bHZhbmlhMRMwEQYDVQQHEwpQaXR0c2J1cmdoMREwDwYDVQQKEwhUZXN0U2hpYjEZMBcGA1UEAxMQaWRwLnRlc3RzaGliLm9yZzAeFw0wNjA4MzAyMTEyMjVaFw0xNjA4MjcyMTEyMjVaMGcxCzAJBgNVBAYTAlVTMRUwEwYDVQQIEwxQZW5uc3lsdmFuaWExEzARBgNVBAcTClBpdHRzYnVyZ2gxETAPBgNVBAoTCFRlc3RTaGliMRkwFwYDVQQDExBpZHAudGVzdHNoaWIub3JnMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEArYkCGuTmJp9eAOSGHwRJo1SNatB5ZOKqDM9ysg7CyVTDClcpu93gSP10nH4gkCZOlnESNgttg0r+MqL8tfJC6ybddEFB3YBo8PZajKSe3OQ01Ow3yT4I+Wdg1tsTpSge9gEz7SrC07EkYmHuPtd71CHiUaCWDv+xVfUQX0aTNPFmDixzUjoYzbGDrtAyCqA8f9CN2txIfJnpHE6q6CmKcoLADS4UrNPlhHSzd614kR/JYiks0K4kbRqCQF0Dv0P5Di+rEfefC6glV8ysC8dB5/9nb0yh/ojRuJGmgMWHgWk6h0ihjihqiu4jACovUZ7vVOCgSE5Ipn7OIwqd93zp2wIDAQABo4HEMIHBMB0GA1UdDgQWBBSsBQ869nh83KqZr5jArr4/7b+QazCBkQYDVR0jBIGJMIGGgBSsBQ869nh83KqZr5jArr4/7b+Qa6FrpGkwZzELMAkGA1UEBhMCVVMxFTATBgNVBAgTDFBlbm5zeWx2YW5pYTETMBEGA1UEBxMKUGl0dHNidXJnaDERMA8GA1UEChMIVGVzdFNoaWIxGTAXBgNVBAMTEGlkcC50ZXN0c2hpYi5vcmeCAQAwDAYDVR0TBAUwAwEB/zANBgkqhkiG9w0BAQUFAAOCAQEAjR29PhrCbk8qLN5MFfSVk98t3CT9jHZoYxd8QMRLI4j7iYQxXiGJTT1FXs1nd4Rha9un+LqTfeMMYqISdDDI6tv8iNpkOAvZZUosVkUo93pv1T0RPz35hcHHYq2yee59HJOco2bFlcsH8JBXRSRrJ3Q7Eut+z9uo80JdGNJ4/SJy5UorZ8KazGj16lfJhOBXldgrhppQBb0Nq6HKHguqmwRfJ+WkxemZXzhediAjGeka8nz8JjwxpUjAiSWYKLtJhGEaTqCYxCCX2Dw+dOTqUzHOZ7WKv4JXPK5G/Uhr8K/qhmFT2nIQi538n6rVYLeWj8Bbnl+ev0peYzxFyF5sQA==', identifierFormat: 'urn:oasis:names:tc:SAML:2.0:nameid-format:transient', decryptionPvk: fs.readFileSync(__dirname + '/static/testshib encryption pvk.pem') }, expectedStatusCode: 200, mockDate: '2014-06-02T17:48:56.820Z' } ]; var server; function testForCheck(check) { return function (done) { var pp = new passport.Authenticator(); var app = express(); app.use(bodyParser.urlencoded({extended: false})); app.use(pp.initialize()); var config = check.config; config.callbackUrl = 'http://localhost:3033/login'; var profile = null; pp.use(new SamlStrategy(config, function (_profile, done) { profile = _profile; done(null, { id: profile.nameID }); }) ); var userSerialized = false; pp.serializeUser(function(user, done) { userSerialized = true; done(null, user); }); fakeClock = sinon.useFakeTimers(Date.parse(check.mockDate)); app.post('/login', pp.authenticate("saml"), function (req, res) { res.status(200).send("200 OK"); }); app.use(function (err, req, res, next) { // console.log( err.stack ); res.status(500).send('500 Internal Server Error'); }); server = app.listen(3033, function () { var requestOpts = { url: 'http://localhost:3033/login', method: 'POST', form: check.samlResponse }; request(requestOpts, function (err, response, body) { should.not.exist(err); response.statusCode.should.equal(check.expectedStatusCode); if (response.statusCode == 200) { userSerialized.should.be.true; if (check.expectedNameIDStartsWith) profile.nameID.should.startWith(check.expectedNameIDStartsWith); } done(); }); }); }; } function testPassReqToCallback(check) { return function (done) { var pp = new passport.Authenticator(); var app = express(); app.use(bodyParser.urlencoded({extended: false})); app.use(pp.initialize()); var config = check.config; config.callbackUrl = 'http://localhost:3033/login'; config.passReqToCallback = true; var passedRequest = null; pp.use(new SamlStrategy(config, function (req, _profile, done) { passedRequest = req; done(null, { id: _profile.nameID }); }) ); pp.serializeUser(function(user, done) { done(null, user); }); fakeClock = sinon.useFakeTimers(Date.parse(check.mockDate)); app.post('/login', pp.authenticate("saml"), function (req, res) { res.status(200).send("200 OK"); }); app.use(function (err, req, res, next) { // console.log( err.stack ); res.status(500).send('500 Internal Server Error'); }); server = app.listen(3033, function () { var requestOpts = { url: 'http://localhost:3033/login', method: 'POST', form: check.samlResponse }; request(requestOpts, function (err, response, body) { should.not.exist(err); response.statusCode.should.equal(check.expectedStatusCode); if (response.statusCode == 200) { should.exist(passedRequest); passedRequest.url.should.eql('/login'); passedRequest.method.should.eql('POST'); should(passedRequest.body).match(check.samlResponse); } else { should.not.exist(passedRequest); } done(); }); }); }; } for( var i = 0; i < capturedChecks.length; i++ ) { var check = capturedChecks[i]; it(check.name, testForCheck(check)); it(check.name + ' passReqToCallback', testPassReqToCallback(check)); } afterEach(function (done) { fakeClock.restore(); server.close(done); }); }); describe( 'captured SAML requests /', function() { var capturedChecks = [ { name: "Empty Config", config: {}, result: { 'samlp:AuthnRequest': { '$': { 'xmlns:samlp': 'urn:oasis:names:tc:SAML:2.0:protocol', Version: '2.0', ProtocolBinding: 'urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST', AssertionConsumerServiceURL: 'http://localhost:3033/login', Destination: 'https://wwwexampleIdp.com/saml'}, 'saml:Issuer': [ { _: 'onelogin_saml', '$': { 'xmlns:saml': 'urn:oasis:names:tc:SAML:2.0:assertion' } } ], 'samlp:NameIDPolicy': [ { '$': { 'xmlns:samlp': 'urn:oasis:names:tc:SAML:2.0:protocol', Format: 'urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress', AllowCreate: 'true' } } ], 'samlp:RequestedAuthnContext': [ { '$': { 'xmlns:samlp': 'urn:oasis:names:tc:SAML:2.0:protocol', Comparison: 'exact' }, 'saml:AuthnContextClassRef': [ { _: 'urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport', '$': { 'xmlns:saml': 'urn:oasis:names:tc:SAML:2.0:assertion' } } ] } ] } } }, { name: "Empty Config w/ HTTP-POST binding", config: { authnRequestBinding: 'HTTP-POST' }, result: { 'samlp:AuthnRequest': { '$': { 'xmlns:samlp': 'urn:oasis:names:tc:SAML:2.0:protocol', Version: '2.0', ProtocolBinding: 'urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST', AssertionConsumerServiceURL: 'http://localhost:3033/login', Destination: 'https://wwwexampleIdp.com/saml'}, 'saml:Issuer': [ { _: 'onelogin_saml', '$': { 'xmlns:saml': 'urn:oasis:names:tc:SAML:2.0:assertion' } } ], 'samlp:NameIDPolicy': [ { '$': { 'xmlns:samlp': 'urn:oasis:names:tc:SAML:2.0:protocol', Format: 'urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress', AllowCreate: 'true' } } ], 'samlp:RequestedAuthnContext': [ { '$': { 'xmlns:samlp': 'urn:oasis:names:tc:SAML:2.0:protocol', Comparison: 'exact' }, 'saml:AuthnContextClassRef': [ { _: 'urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport', '$': { 'xmlns:saml': 'urn:oasis:names:tc:SAML:2.0:assertion' } } ] } ] } } }, { name: "Config #2", config: { issuer: 'http://exampleSp.com/saml', identifierFormat: 'alternateIdentifier', passive: true, attributeConsumingServiceIndex: 123, forceAuthn: false }, result: { 'samlp:AuthnRequest': { '$': { 'xmlns:samlp': 'urn:oasis:names:tc:SAML:2.0:protocol', Version: '2.0', ProtocolBinding: 'urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST', AssertionConsumerServiceURL: 'http://localhost:3033/login', AttributeConsumingServiceIndex: '123', Destination: 'https://wwwexampleIdp.com/saml', IsPassive: 'true'}, 'saml:Issuer': [ { _: 'http://exampleSp.com/saml', '$': { 'xmlns:saml': 'urn:oasis:names:tc:SAML:2.0:assertion' } } ], 'samlp:NameIDPolicy': [ { '$': { 'xmlns:samlp': 'urn:oasis:names:tc:SAML:2.0:protocol', Format: 'alternateIdentifier', AllowCreate: 'true' } } ], 'samlp:RequestedAuthnContext': [ { '$': { 'xmlns:samlp': 'urn:oasis:names:tc:SAML:2.0:protocol', Comparison: 'exact' }, 'saml:AuthnContextClassRef': [ { _: 'urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport', '$': { 'xmlns:saml': 'urn:oasis:names:tc:SAML:2.0:assertion' } } ] } ] } } }, { name: "Uncompressed config #2", config: { issuer: 'http://exampleSp.com/saml', identifierFormat: 'alternateIdentifier', passive: true, attributeConsumingServiceIndex: 123, skipRequestCompression: true }, result: { 'samlp:AuthnRequest': { '$': { 'xmlns:samlp': 'urn:oasis:names:tc:SAML:2.0:protocol', Version: '2.0', ProtocolBinding: 'urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST', AssertionConsumerServiceURL: 'http://localhost:3033/login', AttributeConsumingServiceIndex: '123', Destination: 'https://wwwexampleIdp.com/saml', IsPassive: 'true' }, 'saml:Issuer': [ { _: 'http://exampleSp.com/saml', '$': { 'xmlns:saml': 'urn:oasis:names:tc:SAML:2.0:assertion' } } ], 'samlp:NameIDPolicy': [ { '$': { 'xmlns:samlp': 'urn:oasis:names:tc:SAML:2.0:protocol', Format: 'alternateIdentifier', AllowCreate: 'true' } } ], 'samlp:RequestedAuthnContext': [ { '$': { 'xmlns:samlp': 'urn:oasis:names:tc:SAML:2.0:protocol', Comparison: 'exact' }, 'saml:AuthnContextClassRef': [ { _: 'urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport', '$': { 'xmlns:saml': 'urn:oasis:names:tc:SAML:2.0:assertion' } } ] } ] } } }, { name: "Config #3", config: { issuer: 'http://exampleSp.com/saml', identifierFormat: 'alternateIdentifier', passive: true, attributeConsumingServiceIndex: 123, skipRequestCompression: true, disableRequestedAuthnContext: true, forceAuthn: true }, result: { 'samlp:AuthnRequest': { '$': { 'xmlns:samlp': 'urn:oasis:names:tc:SAML:2.0:protocol', Version: '2.0', ProtocolBinding: 'urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST', AssertionConsumerServiceURL: 'http://localhost:3033/login', AttributeConsumingServiceIndex: '123', Destination: 'https://wwwexampleIdp.com/saml', IsPassive: 'true', ForceAuthn: 'true' }, 'saml:Issuer': [ { _: 'http://exampleSp.com/saml', '$': { 'xmlns:saml': 'urn:oasis:names:tc:SAML:2.0:assertion' } } ], 'samlp:NameIDPolicy': [ { '$': { 'xmlns:samlp': 'urn:oasis:names:tc:SAML:2.0:protocol', Format: 'alternateIdentifier', AllowCreate: 'true' } } ] } } }, { name: "Config with AuthnContext", config: { issuer: 'http://exampleSp.com/saml', identifierFormat: 'alternateIdentifier', passive: true, attributeConsumingServiceIndex: 123, authnContext: 'myAuthnContext' }, result: { 'samlp:AuthnRequest': { '$': { 'xmlns:samlp': 'urn:oasis:names:tc:SAML:2.0:protocol', Version: '2.0', ProtocolBinding: 'urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST', AssertionConsumerServiceURL: 'http://localhost:3033/login', AttributeConsumingServiceIndex: '123', Destination: 'https://wwwexampleIdp.com/saml', IsPassive: 'true'}, 'saml:Issuer': [ { _: 'http://exampleSp.com/saml', '$': { 'xmlns:saml': 'urn:oasis:names:tc:SAML:2.0:assertion' } } ], 'samlp:NameIDPolicy': [ { '$': { 'xmlns:samlp': 'urn:oasis:names:tc:SAML:2.0:protocol', Format: 'alternateIdentifier', AllowCreate: 'true' } } ], 'samlp:RequestedAuthnContext': [ { '$': { 'xmlns:samlp': 'urn:oasis:names:tc:SAML:2.0:protocol', Comparison: 'exact' }, 'saml:AuthnContextClassRef': [ { _: 'myAuthnContext', '$': { 'xmlns:saml': 'urn:oasis:names:tc:SAML:2.0:assertion' } } ] } ] } } }, { name: "Config with ProviderName", config: { issuer: 'http://exampleSp.com/saml', identifierFormat: 'alternateIdentifier', providerName: 'myProviderName' }, result: { 'samlp:AuthnRequest': { '$': { 'xmlns:samlp': 'urn:oasis:names:tc:SAML:2.0:protocol', Version: '2.0', ProtocolBinding: 'urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST', ProviderName: 'myProviderName', AssertionConsumerServiceURL: 'http://localhost:3033/login', Destination: 'https://wwwexampleIdp.com/saml'}, 'saml:Issuer': [ { _: 'http://exampleSp.com/saml', '$': { 'xmlns:saml': 'urn:oasis:names:tc:SAML:2.0:assertion' } } ], 'samlp:NameIDPolicy': [ { '$': { 'xmlns:samlp': 'urn:oasis:names:tc:SAML:2.0:protocol', Format: 'alternateIdentifier', AllowCreate: 'true' } } ], 'samlp:RequestedAuthnContext': [ { '$': { 'xmlns:samlp': 'urn:oasis:names:tc:SAML:2.0:protocol', Comparison: 'exact' }, 'saml:AuthnContextClassRef': [ { _: 'urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport', '$': { 'xmlns:saml': 'urn:oasis:names:tc:SAML:2.0:assertion' } } ] } ] } } } ]; var server; function testForCheck( check ) { return function( done ) { var app = express(); app.use( bodyParser.urlencoded({extended: false}) ); app.use( passport.initialize() ); var config = check.config; config.callbackUrl = 'http://localhost:3033/login'; config.entryPoint = 'https://wwwexampleIdp.com/saml'; var profile = null; passport.use( new SamlStrategy( config, function(_profile, done) { profile = _profile; done(null, { id: profile.nameID } ); }) ); app.get( '/login', passport.authenticate( "saml", { samlFallback: 'login-request', session: false } ), function(req, res) { res.status(200).send("200 OK"); }); app.use( function( err, req, res, next ) { console.log( err.stack ); res.status(500).send('500 Internal Server Error'); }); server = app.listen( 3033, function() { var requestOpts = { url: 'http://localhost:3033/login', method: 'get', followRedirect: false }; request(requestOpts, function(err, response, body) { should.not.exist(err); var encodedSamlRequest; if ( check.config.authnRequestBinding === "HTTP-POST" ) { response.statusCode.should.equal(200); body.should.match(/[^]*/); encodedSamlRequest = body.match( /https://app.onelogin.com/saml/metadata/371755DCnPTQYBb1hKspbe6fg1U3q8xn4=e0+aFomA0+JAY0f9tKqzIuqIVSSw7LiFUsneEDKPBWdiTz1sMdgr/2y1e9+rjaS2mRmCi/vSQLY3zTYz0hp6nJNU19+TWoXo9kHQyWT4KkeQL4Xs/gZ/AoKC20iHVKtpPps0IQ0Ml/qRoouSitt6Sf/WDz2LV/pWcH2hx5tv3xSw36hK2NQc7qw7r1mEXnvcjXReYo8rrVf7XHGGxNoRIEICUIi110uvsWemSXf0Z0dyb0FVYOWuSsQMDlzNpheADBifFO4UTfSEhFZvn8kVCGZUIwrbOhZ2d/+YEtgyuTg+qtslgfy4dwd4TvEcfuRzQTazeefprSFyiQckAXOjcw=='+TEST_CERT+'ploer@subspacesw.com{audience}urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport' + ''; var base64xml = new Buffer( xml ).toString('base64'); var container = { SAMLResponse: base64xml }; var samlObj = new SAML( samlConfig ); samlObj.validatePostResponse( container, function( err, profile, logout ) { should.not.exist( err ); profile.nameID.should.startWith( 'ploer' ); done(); }); }); it( 'onelogin xml document with altered assertion should fail', function( done ) { var xml = 'https://app.onelogin.com/saml/metadata/371755' + 'https://app.onelogin.com/saml/metadata/371755DCnPTQYBb1hKspbe6fg1U3q8xn4=e0+aFomA0+JAY0f9tKqzIuqIVSSw7LiFUsneEDKPBWdiTz1sMdgr/2y1e9+rjaS2mRmCi/vSQLY3zTYz0hp6nJNU19+TWoXo9kHQyWT4KkeQL4Xs/gZ/AoKC20iHVKtpPps0IQ0Ml/qRoouSitt6Sf/WDz2LV/pWcH2hx5tv3xSw36hK2NQc7qw7r1mEXnvcjXReYo8rrVf7XHGGxNoRIEICUIi110uvsWemSXf0Z0dyb0FVYOWuSsQMDlzNpheADBifFO4UTfSEhFZvn8kVCGZUIwrbOhZ2d/+YEtgyuTg+qtslgfy4dwd4TvEcfuRzQTazeefprSFyiQckAXOjcw=='+TEST_CERT+'ben@subspacesw.com{audience}urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport' + ''; var base64xml = new Buffer( xml ).toString('base64'); var container = { SAMLResponse: base64xml }; var samlObj = new SAML( samlConfig ); samlObj.validatePostResponse( container, function( err, profile, logout ) { should.exist( err ); err.message.should.match( 'Invalid signature' ); done(); }); }); it( 'onelogin xml document with duplicate altered assertion should fail', function( done ) { var xml = 'https://app.onelogin.com/saml/metadata/371755' + 'https://app.onelogin.com/saml/metadata/371755DCnPTQYBb1hKspbe6fg1U3q8xn4=e0+aFomA0+JAY0f9tKqzIuqIVSSw7LiFUsneEDKPBWdiTz1sMdgr/2y1e9+rjaS2mRmCi/vSQLY3zTYz0hp6nJNU19+TWoXo9kHQyWT4KkeQL4Xs/gZ/AoKC20iHVKtpPps0IQ0Ml/qRoouSitt6Sf/WDz2LV/pWcH2hx5tv3xSw36hK2NQc7qw7r1mEXnvcjXReYo8rrVf7XHGGxNoRIEICUIi110uvsWemSXf0Z0dyb0FVYOWuSsQMDlzNpheADBifFO4UTfSEhFZvn8kVCGZUIwrbOhZ2d/+YEtgyuTg+qtslgfy4dwd4TvEcfuRzQTazeefprSFyiQckAXOjcw=='+TEST_CERT+'ploer@subspacesw.com{audience}urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport' + 'https://app.onelogin.com/saml/metadata/371755DCnPTQYBb1hKspbe6fg1U3q8xn4=e0+aFomA0+JAY0f9tKqzIuqIVSSw7LiFUsneEDKPBWdiTz1sMdgr/2y1e9+rjaS2mRmCi/vSQLY3zTYz0hp6nJNU19+TWoXo9kHQyWT4KkeQL4Xs/gZ/AoKC20iHVKtpPps0IQ0Ml/qRoouSitt6Sf/WDz2LV/pWcH2hx5tv3xSw36hK2NQc7qw7r1mEXnvcjXReYo8rrVf7XHGGxNoRIEICUIi110uvsWemSXf0Z0dyb0FVYOWuSsQMDlzNpheADBifFO4UTfSEhFZvn8kVCGZUIwrbOhZ2d/+YEtgyuTg+qtslgfy4dwd4TvEcfuRzQTazeefprSFyiQckAXOjcw=='+TEST_CERT+'ben@subspacesw.com{audience}urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport' + ''; var base64xml = new Buffer( xml ).toString('base64'); var container = { SAMLResponse: base64xml }; var samlObj = new SAML( samlConfig ); samlObj.validatePostResponse( container, function( err, profile, logout ) { should.exist( err ); err.message.should.match( 'Invalid signature' ); done(); }); }); it( 'onelogin xml document with extra unsigned & altered assertion should fail', function( done ) { var xml = 'https://app.onelogin.com/saml/metadata/371755' + 'https://app.onelogin.com/saml/metadata/371755ben@subspacesw.com{audience}urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport' + 'https://app.onelogin.com/saml/metadata/371755DCnPTQYBb1hKspbe6fg1U3q8xn4=e0+aFomA0+JAY0f9tKqzIuqIVSSw7LiFUsneEDKPBWdiTz1sMdgr/2y1e9+rjaS2mRmCi/vSQLY3zTYz0hp6nJNU19+TWoXo9kHQyWT4KkeQL4Xs/gZ/AoKC20iHVKtpPps0IQ0Ml/qRoouSitt6Sf/WDz2LV/pWcH2hx5tv3xSw36hK2NQc7qw7r1mEXnvcjXReYo8rrVf7XHGGxNoRIEICUIi110uvsWemSXf0Z0dyb0FVYOWuSsQMDlzNpheADBifFO4UTfSEhFZvn8kVCGZUIwrbOhZ2d/+YEtgyuTg+qtslgfy4dwd4TvEcfuRzQTazeefprSFyiQckAXOjcw=='+TEST_CERT+'ploer@subspacesw.com{audience}urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport' + ''; var base64xml = new Buffer( xml ).toString('base64'); var container = { SAMLResponse: base64xml }; var samlObj = new SAML( samlConfig ); samlObj.validatePostResponse( container, function( err, profile, logout ) { should.exist( err ); err.message.should.match( 'Invalid signature' ); done(); }); }); it( 'onelogin xml document with extra nexted assertion should fail', function( done ) { var xml = 'https://app.onelogin.com/saml/metadata/371755' + 'https://app.onelogin.com/saml/metadata/371755DCnPTQYBb1hKspbe6fg1U3q8xn4=e0+aFomA0+JAY0f9tKqzIuqIVSSw7LiFUsneEDKPBWdiTz1sMdgr/2y1e9+rjaS2mRmCi/vSQLY3zTYz0hp6nJNU19+TWoXo9kHQyWT4KkeQL4Xs/gZ/AoKC20iHVKtpPps0IQ0Ml/qRoouSitt6Sf/WDz2LV/pWcH2hx5tv3xSw36hK2NQc7qw7r1mEXnvcjXReYo8rrVf7XHGGxNoRIEICUIi110uvsWemSXf0Z0dyb0FVYOWuSsQMDlzNpheADBifFO4UTfSEhFZvn8kVCGZUIwrbOhZ2d/+YEtgyuTg+qtslgfy4dwd4TvEcfuRzQTazeefprSFyiQckAXOjcw=='+TEST_CERT+'' + '' + 'https://app.onelogin.com/saml/metadata/371755ploer@subspacesw.com{audience}urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport' + '' + 'ploer@subspacesw.com{audience}urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport' + ''; var base64xml = new Buffer( xml ).toString('base64'); var container = { SAMLResponse: base64xml }; var samlObj = new SAML( samlConfig ); samlObj.validatePostResponse( container, function( err, profile, logout ) { should.exist( err ); err.message.should.match( 'Invalid signature' ); done(); }); }); }); }); describe( 'getAuthorizeUrl request signature checks /', function() { var fakeClock; beforeEach(function(){ fakeClock = sinon.useFakeTimers(Date.parse('2014-05-28T00:13:09Z')); }); afterEach(function(){ fakeClock.restore(); }); it( 'acme_tools request signed with sha256', function( done ) { var samlConfig = { entryPoint: 'https://adfs.acme_tools.com/adfs/ls/', issuer: 'acme_tools_com', callbackUrl: 'https://relyingparty/adfs/postResponse', privateCert: fs.readFileSync(__dirname + '/static/acme_tools_com.key', 'utf-8'), authnContext: 'http://schemas.microsoft.com/ws/2008/06/identity/authenticationmethod/password', identifierFormat: null, signatureAlgorithm: 'sha256', additionalParams: { customQueryStringParam: 'CustomQueryStringParamValue' } }; var samlObj = new SAML( samlConfig ); samlObj.generateUniqueID = function () { return '12345678901234567890' }; samlObj.getAuthorizeUrl({}, function(err, url) { var qry = require('querystring').parse(require('url').parse(url).query); qry.SigAlg.should.match('http://www.w3.org/2001/04/xmldsig-more#rsa-sha256'); qry.Signature.should.match('SL85w0h6Pt7ejplGrR4OOTh4Zo9zs/MQHZep27kSzs4+U/0QdQi7hg5T0TKqCSRBZpVtspMpw+i6F0tZrFot0dIJgeCgkvMA2Tllwt6K0DbKWOiNXW5S2M9tUZktdJVfjr2D5e0SG4jQIwa4PVONgNQEKFxydIqwxVh9NGYeDeMUGq5/4QpMDLgYOvLfShyvhlzmqeUs7LBlZbKJLCeXZi/Z5bnF+QOAugtKuh0G6kFOS0CmKVLIW/4XicLHmggUBDlt0VJaskxUx2amHSNUoYe3Z9/9TeZqc7IswNUOEiq/oy0DLhokLnBEj+dBRMlgkAHp/gaWcc1Vp/1jSlVAvg=='); qry.customQueryStringParam.should.match('CustomQueryStringParamValue'); done(); }); }); it( 'acme_tools request signed with sha1', function( done ) { var samlConfig = { entryPoint: 'https://adfs.acme_tools.com/adfs/ls/', issuer: 'acme_tools_com', callbackUrl: 'https://relyingparty/adfs/postResponse', privateCert: fs.readFileSync(__dirname + '/static/acme_tools_com.key', 'utf-8'), authnContext: 'http://schemas.microsoft.com/ws/2008/06/identity/authenticationmethod/password', identifierFormat: null, signatureAlgorithm: 'sha1', additionalParams: { customQueryStringParam: 'CustomQueryStringParamValue' } }; var samlObj = new SAML( samlConfig ); samlObj.generateUniqueID = function () { return '12345678901234567890' }; samlObj.getAuthorizeUrl({}, function(err, url) { var qry = require('querystring').parse(require('url').parse(url).query); qry.SigAlg.should.match('http://www.w3.org/2000/09/xmldsig#rsa-sha1'); qry.Signature.should.match('VnYOXVDiIaio+Vt8D2XXVwdyvwhDcdvgrQSkeq85G+MfU31yK9fvYEPFARK5pF1uJakMsYrKzVBv7HLCFcYuztpuIZloMFvFkado0MxFK4A/QFZn+EYDJE8ddLSvrW3iyuoxyVBSnH0+KLzDiI81B28YZNU3NFJIKCKzQSGIllJ7Vgw6KjH/BmE5DY0eSeUCEe6OygHgazjSrNIWQQjww5nSGIqAQl94OVanZtQBrYIUtik+d1lAhnginG0UnPccstenxEMAun2uMGp9hVqroWQvWRbX/xspRpjPOrIkvv63FzEgmRObXVNqpzDICJRUSlhTLdXAm2hb+ScYocO6EQ=='); qry.customQueryStringParam.should.match('CustomQueryStringParamValue'); done(); }); }); }); describe( 'getAdditionalParams checks /', function() { it ( 'should not pass any additional params by default', function( done ) { var samlConfig = { entryPoint: 'https://app.onelogin.com/trust/saml2/http-post/sso/371755', }; var samlObj = new SAML( samlConfig ); ['logout', 'authorize'].forEach( function( operation ) { var additionalParams = samlObj.getAdditionalParams({}, operation); additionalParams.should.be.empty }); done(); }); it ( 'should not pass any additional params by default apart from the RelayState in request query', function( done ) { var samlConfig = { entryPoint: 'https://app.onelogin.com/trust/saml2/http-post/sso/371755', }; var samlObj = new SAML( samlConfig ); ['logout', 'authorize'].forEach( function( operation ) { var additionalParams = samlObj.getAdditionalParams({query:{RelayState: "test"}}, operation); Object.keys(additionalParams).should.have.length(1); additionalParams.should.containEql({'RelayState': 'test'}); }); done(); }); it ( 'should not pass any additional params by default apart from the RelayState in request body', function( done ) { var samlConfig = { entryPoint: 'https://app.onelogin.com/trust/saml2/http-post/sso/371755', }; var samlObj = new SAML( samlConfig ); ['logout', 'authorize'].forEach( function( operation ) { var additionalParams = samlObj.getAdditionalParams({body:{RelayState: "test"}}, operation); Object.keys(additionalParams).should.have.length(1); additionalParams.should.containEql({'RelayState': 'test'}); }); done(); }); it ( 'should pass additional params with all operations if set in additionalParams', function( done ) { var samlConfig = { entryPoint: 'https://app.onelogin.com/trust/saml2/http-post/sso/371755', additionalParams: { 'queryParam': 'queryParamValue' } }; var samlObj = new SAML( samlConfig ); ['logout', 'authorize'].forEach( function( operation ) { var additionalParams = samlObj.getAdditionalParams({}, operation); Object.keys(additionalParams).should.have.length(1); additionalParams.should.containEql({'queryParam': 'queryParamValue'}); }); done(); }); it ( 'should pass additional params with "authorize" operations if set in additionalAuthorizeParams', function( done ) { var samlConfig = { entryPoint: 'https://app.onelogin.com/trust/saml2/http-post/sso/371755', additionalAuthorizeParams: { 'queryParam': 'queryParamValue' } }; var samlObj = new SAML( samlConfig ); var additionalAuthorizeParams = samlObj.getAdditionalParams({}, 'authorize'); Object.keys(additionalAuthorizeParams).should.have.length(1); additionalAuthorizeParams.should.containEql({'queryParam': 'queryParamValue'}); var additionalLogoutParams = samlObj.getAdditionalParams({}, 'logout'); additionalLogoutParams.should.be.empty; done(); }); it ( 'should pass additional params with "logout" operations if set in additionalLogoutParams', function( done ) { var samlConfig = { entryPoint: 'https://app.onelogin.com/trust/saml2/http-post/sso/371755', additionalLogoutParams: { 'queryParam': 'queryParamValue' } }; var samlObj = new SAML( samlConfig ); var additionalAuthorizeParams = samlObj.getAdditionalParams({}, 'authorize'); additionalAuthorizeParams.should.be.empty; var additionalLogoutParams = samlObj.getAdditionalParams({}, 'logout'); Object.keys(additionalLogoutParams).should.have.length(1); additionalLogoutParams.should.containEql({'queryParam': 'queryParamValue'}); done(); }); it ( 'should merge additionalLogoutParams and additionalAuthorizeParams with additionalParams', function( done ) { var samlConfig = { entryPoint: 'https://app.onelogin.com/trust/saml2/http-post/sso/371755', additionalParams: { 'queryParam1': 'queryParamValue' }, additionalAuthorizeParams: { 'queryParam2': 'queryParamValueAuthorize' }, additionalLogoutParams: { 'queryParam2': 'queryParamValueLogout' } }; var samlObj = new SAML( samlConfig ); var additionalAuthorizeParams = samlObj.getAdditionalParams({}, 'authorize'); Object.keys(additionalAuthorizeParams).should.have.length(2); additionalAuthorizeParams.should.containEql({'queryParam1': 'queryParamValue', 'queryParam2': 'queryParamValueAuthorize'}); var additionalLogoutParams = samlObj.getAdditionalParams({}, 'logout'); Object.keys(additionalLogoutParams).should.have.length(2); additionalLogoutParams.should.containEql({'queryParam1': 'queryParamValue', 'queryParam2': 'queryParamValueLogout'}); done(); }); it ( 'should prioritize additionalLogoutParams and additionalAuthorizeParams over additionalParams', function( done ) { var samlConfig = { entryPoint: 'https://app.onelogin.com/trust/saml2/http-post/sso/371755', additionalParams: { 'queryParam': 'queryParamValue' }, additionalAuthorizeParams: { 'queryParam': 'queryParamValueAuthorize' }, additionalLogoutParams: { 'queryParam': 'queryParamValueLogout' } }; var samlObj = new SAML( samlConfig ); var additionalAuthorizeParams = samlObj.getAdditionalParams({}, 'authorize'); Object.keys(additionalAuthorizeParams).should.have.length(1); additionalAuthorizeParams.should.containEql({'queryParam': 'queryParamValueAuthorize'}); var additionalLogoutParams = samlObj.getAdditionalParams({}, 'logout'); Object.keys(additionalLogoutParams).should.have.length(1); additionalLogoutParams.should.containEql({'queryParam': 'queryParamValueLogout'}); done(); }); }); describe( 'InResponseTo validation checks /', function(){ var fakeClock = null; afterEach(function() { if (fakeClock) { fakeClock.restore(); fakeClock = null; } }); it( 'onelogin xml document with InResponseTo from request should validate', function( done ) { var requestId = '_a6fc46be84e1e3cf3c50'; var xml = 'https://app.onelogin.com/saml/metadata/371755' + 'https://app.onelogin.com/saml/metadata/371755DCnPTQYBb1hKspbe6fg1U3q8xn4=e0+aFomA0+JAY0f9tKqzIuqIVSSw7LiFUsneEDKPBWdiTz1sMdgr/2y1e9+rjaS2mRmCi/vSQLY3zTYz0hp6nJNU19+TWoXo9kHQyWT4KkeQL4Xs/gZ/AoKC20iHVKtpPps0IQ0Ml/qRoouSitt6Sf/WDz2LV/pWcH2hx5tv3xSw36hK2NQc7qw7r1mEXnvcjXReYo8rrVf7XHGGxNoRIEICUIi110uvsWemSXf0Z0dyb0FVYOWuSsQMDlzNpheADBifFO4UTfSEhFZvn8kVCGZUIwrbOhZ2d/+YEtgyuTg+qtslgfy4dwd4TvEcfuRzQTazeefprSFyiQckAXOjcw=='+TEST_CERT+'ploer@subspacesw.com{audience}urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport' + ''; var base64xml = new Buffer( xml ).toString('base64'); var container = { SAMLResponse: base64xml }; var samlConfig = { entryPoint: 'https://app.onelogin.com/trust/saml2/http-post/sso/371755', cert: TEST_CERT, validateInResponseTo: true }; var samlObj = new SAML( samlConfig ); fakeClock = sinon.useFakeTimers(Date.parse('2014-05-28T00:13:09Z')); // Mock the SAML request being passed through Passport-SAML samlObj.cacheProvider.save(requestId, new Date().toISOString(), function(){}); samlObj.validatePostResponse( container, function( err, profile, logout ) { should.not.exist( err ); profile.nameID.should.startWith( 'ploer' ); samlObj.cacheProvider.get(requestId, function(err, value){ should.not.exist(value); done(); }); }); }); it( 'onelogin xml document without InResponseTo from request should fail', function( done ) { var requestId = '_a6fc46be84e1e3cf3c50'; var xml = 'https://app.onelogin.com/saml/metadata/371755' + 'https://app.onelogin.com/saml/metadata/371755DCnPTQYBb1hKspbe6fg1U3q8xn4=e0+aFomA0+JAY0f9tKqzIuqIVSSw7LiFUsneEDKPBWdiTz1sMdgr/2y1e9+rjaS2mRmCi/vSQLY3zTYz0hp6nJNU19+TWoXo9kHQyWT4KkeQL4Xs/gZ/AoKC20iHVKtpPps0IQ0Ml/qRoouSitt6Sf/WDz2LV/pWcH2hx5tv3xSw36hK2NQc7qw7r1mEXnvcjXReYo8rrVf7XHGGxNoRIEICUIi110uvsWemSXf0Z0dyb0FVYOWuSsQMDlzNpheADBifFO4UTfSEhFZvn8kVCGZUIwrbOhZ2d/+YEtgyuTg+qtslgfy4dwd4TvEcfuRzQTazeefprSFyiQckAXOjcw=='+TEST_CERT+'ploer@subspacesw.com{audience}urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport' + ''; var base64xml = new Buffer( xml ).toString('base64'); var container = { SAMLResponse: base64xml }; var samlConfig = { entryPoint: 'https://app.onelogin.com/trust/saml2/http-post/sso/371755', cert: TEST_CERT, validateInResponseTo: true }; var samlObj = new SAML( samlConfig ); fakeClock = sinon.useFakeTimers(Date.parse('2014-05-28T00:13:09Z')); samlObj.validatePostResponse( container, function( err, profile, logout ) { should.exist( err ); err.message.should.match( 'InResponseTo is not valid' ); done(); }); }); it( 'xml document with SubjectConfirmation InResponseTo from request should be valid', function(done){ var requestId = '_dfab47d5d46374cd4b71'; var xml = 'Verizon IDP HubQecaVjMY/2M4VMJsakvX8uh2Mrg=QTJ//ZHEQRe9/nA5qTkhECZc2u6M1dHzTkujKBedskLSRPL8LRBb4Yftla0zu848sYvLd3SXzEysYu/jrAjaVDevYZIAdyj/3HCw8pS0ZnQDaCgYuAkH4JmYxBfW1Sc9Kr0vbR58ihwWOZd4xHIn/b8xLs8WNsyTHix2etrLGznioLwTOBO3+SgjwSiSP9NUhrlOvolbuu/6xhLi37/L08JaBvOw3o0k4V8xS87SFczhm4f6wvQM5mP6sZAreoNcWZqQM7vIHFjL0/H9vTaLAN8+fQOc81xFtateTKwFQlJMUmdWKZ8L7ns0Uf1xASQjXtSAACbXI+PuVLjz8nnm3g==MIIC7TCCAdmgAwIBAgIQuIdqos+9yKBC4oygbhtdfzAJBgUrDgMCHQUAMBIxEDAOBgNVBAMTB1Rlc3RTVFMwHhcNMTQwNDE2MTIyMTEwWhcNMzkxMjMxMjM1OTU5WjASMRAwDgYDVQQDEwdUZXN0U1RTMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAmhReamVYbeOWwrrAvHPvS9KKBwv4Tj7wOSGDXbNgfjhSvVyXsnpYRcuoJkvE8b9tCjFTbXCfbhnaVrpoXaWFtP1YvUIZvCJGdOOTXltMNDlNIaFmsIsomza8IyOHXe+3xHWVtxO8FG3qnteSkkVIQuAvBqpPfQtxrXCZOlbQZm7q69QIQ64JvLJfRwHN1EywMBVwbJgrV8gBdE3RITI76coSOK13OBTlGtB0kGKLDrF2JW+5mB+WnFR7GlXUj+V0R9WStBomVipJEwr6Q3fU0deKZ5lLw0+qJ0T6APInwN5TIN/AbFCHd51aaf3zEP+tZacQ9fbZqy9XBAtL2pCAJQIDAQABo0cwRTBDBgNVHQEEPDA6gBDECazhZ8Ar+ULXb0YTs5MvoRQwEjEQMA4GA1UEAxMHVGVzdFNUU4IQuIdqos+9yKBC4oygbhtdfzAJBgUrDgMCHQUAA4IBAQAioMSOU9QFw+yhVxGUNK0p/ghVsHnYdeOE3vSRhmFPsetBt8S35sI4QwnQNiuiEYqp++FabiHgePOiqq5oeY6ekJik1qbs7fgwnaQXsxxSucHvc4BU81x24aKy6jeJzxmFxo3mh6y/OI1peCMSH48iUzmhnoSulp0+oAs3gMEFI0ONbgAA/XoAHaVEsrPj10i3gkztoGdpH0DYUe9rABOJxX/3mNF+dCVJG7t7BoSlNAWlSDErKciNNax1nBskFqNWNIKzUKBIb+GVKkIB2QpATMQB6Oe7inUdT9kkZ/Q7oPBATZk+3mFsIoWr8QRFSqvToOhun7EY2/VtuiV1d932Verizon IDP HubUIS/jochen-workUIS/jochen-workUIS usere9aba0c4-ece8-4b44-9526-d24418aa95dctestorgTest User::1'; var base64xml = new Buffer( xml ).toString('base64'); var container = { SAMLResponse: base64xml }; var samlConfig = { entryPoint: 'https://app.onelogin.com/trust/saml2/http-post/sso/371755', cert: 'MIIC7TCCAdmgAwIBAgIQuIdqos+9yKBC4oygbhtdfzAJBgUrDgMCHQUAMBIxEDAOBgNVBAMTB1Rlc3RTVFMwHhcNMTQwNDE2MTIyMTEwWhcNMzkxMjMxMjM1OTU5WjASMRAwDgYDVQQDEwdUZXN0U1RTMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAmhReamVYbeOWwrrAvHPvS9KKBwv4Tj7wOSGDXbNgfjhSvVyXsnpYRcuoJkvE8b9tCjFTbXCfbhnaVrpoXaWFtP1YvUIZvCJGdOOTXltMNDlNIaFmsIsomza8IyOHXe+3xHWVtxO8FG3qnteSkkVIQuAvBqpPfQtxrXCZOlbQZm7q69QIQ64JvLJfRwHN1EywMBVwbJgrV8gBdE3RITI76coSOK13OBTlGtB0kGKLDrF2JW+5mB+WnFR7GlXUj+V0R9WStBomVipJEwr6Q3fU0deKZ5lLw0+qJ0T6APInwN5TIN/AbFCHd51aaf3zEP+tZacQ9fbZqy9XBAtL2pCAJQIDAQABo0cwRTBDBgNVHQEEPDA6gBDECazhZ8Ar+ULXb0YTs5MvoRQwEjEQMA4GA1UEAxMHVGVzdFNUU4IQuIdqos+9yKBC4oygbhtdfzAJBgUrDgMCHQUAA4IBAQAioMSOU9QFw+yhVxGUNK0p/ghVsHnYdeOE3vSRhmFPsetBt8S35sI4QwnQNiuiEYqp++FabiHgePOiqq5oeY6ekJik1qbs7fgwnaQXsxxSucHvc4BU81x24aKy6jeJzxmFxo3mh6y/OI1peCMSH48iUzmhnoSulp0+oAs3gMEFI0ONbgAA/XoAHaVEsrPj10i3gkztoGdpH0DYUe9rABOJxX/3mNF+dCVJG7t7BoSlNAWlSDErKciNNax1nBskFqNWNIKzUKBIb+GVKkIB2QpATMQB6Oe7inUdT9kkZ/Q7oPBATZk+3mFsIoWr8QRFSqvToOhun7EY2/VtuiV1d932', validateInResponseTo: true }; var samlObj = new SAML( samlConfig ); fakeClock = sinon.useFakeTimers(Date.parse('2014-06-05T12:07:07.662Z')); // Mock the SAML request being passed through Passport-SAML samlObj.cacheProvider.save(requestId, new Date().toISOString(), function(){}); samlObj.validatePostResponse( container, function( err, profile, logout ) { should.not.exist( err ); profile.nameID.should.startWith( 'UIS/jochen-work' ); samlObj.cacheProvider.get(requestId, function(err, value){ should.not.exist(value); done(); }); }); }); it( 'xml document with multiple AttributeStatements should have all attributes present on profile', function(done){ var requestId = '_dfab47d5d46374cd4b71'; var xml = 'Verizon IDP HubVerizon IDP HubUIS/jochen-workUIS/jochen-workUIS usere9aba0c4-ece8-4b44-9526-d24418aa95dctestorgTest User::1qD+sVCaEdy1dTJoUQdo6o+tYsuU=aLl+1yT7zdT4WnRXKh9cx7WWZnUi/NoxMJWhXP5d+Zu9A4/fjKApSywimU0MTTQxYpvZLjOZPsSwmvc1boJOlXveDsL7A3YWi/f7/zqlVWOfXLE8TVLqUE4jtLsJHFWIJXmh8CI0loqQNf6QcYi9BwCK82FhhXC+qWA5WCZIIWUUMxjxnPbunQ7mninEeW568wqyhb9pLV8QkThzZrZINCqxNvWyGuK/XGPx7ciD6ywbBkdOjlDbwRMaKQ9YeCzZGGzJwOe/NuCXj+oUyzfmzUCobIIR0HYLc4B5UplL7XIKQzpOA2lDDsLe6ZzdTv1qjxSm+dlVfo24onmiPlQUgA=='; var base64xml = new Buffer( xml ).toString('base64'); var container = { SAMLResponse: base64xml }; var samlConfig = { entryPoint: 'https://app.onelogin.com/trust/saml2/http-post/sso/371755', cert: 'MIIDtTCCAp2gAwIBAgIJAKg4VeVcIDz1MA0GCSqGSIb3DQEBBQUAMEUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpTb21lLVN0YXRlMSEwHwYDVQQKExhJbnRlcm5ldCBXaWRnaXRzIFB0eSBMdGQwHhcNMTUwODEzMDE1NDIwWhcNMTUwOTEyMDE1NDIwWjBFMQswCQYDVQQGEwJVUzETMBEGA1UECBMKU29tZS1TdGF0ZTEhMB8GA1UEChMYSW50ZXJuZXQgV2lkZ2l0cyBQdHkgTHRkMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAxG3ouM7U+fXbJt69X1H6d4UNg/uRr06pFuU9RkfIwNC+yaXyptqB3ynXKsL7BFt4DCd0fflRvJAx3feJIDp16wN9GDVHcufWMYPhh2j5HcTW/j9JoIJzGhJyvO00YKBt+hHy83iN1SdChKv5y0iSyiPP5GnqFw+ayyHoM6hSO0PqBou1Xb0ZSIE+DHosBnvVna5w2AiPY4xrJl9yZHZ4Q7DfMiYTgstjETio4bX+6oLiBnYktn7DjdEslqhffVme4PuBxNojI+uCeg/sn4QVLd/iogMJfDWNuLD8326Mi/FE9cCRvFlvAiMSaebMI3zPaySsxTK7Zgj5TpEbmbHI9wIDAQABo4GnMIGkMB0GA1UdDgQWBBSVGgvoW4MhMuzBGce29PY8vSzHFzB1BgNVHSMEbjBsgBSVGgvoW4MhMuzBGce29PY8vSzHF6FJpEcwRTELMAkGA1UEBhMCVVMxEzARBgNVBAgTClNvbWUtU3RhdGUxITAfBgNVBAoTGEludGVybmV0IFdpZGdpdHMgUHR5IEx0ZIIJAKg4VeVcIDz1MAwGA1UdEwQFMAMBAf8wDQYJKoZIhvcNAQEFBQADggEBAJu1rqs+anD74dbdwgd3CnqnQsQDJiEXmBhG2leaGt3ve9b/9gKaJg2pyb2NyppDe1uLqh6nNXDuzg1oNZrPz5pJL/eCXPl7FhxhMUi04TtLf8LeNTCIWYZiFuO4pmhohHcv8kRvYR1+6SkLTC8j/TZerm7qvesSiTQFNapa1eNdVQ8nFwVkEtWl+JzKEM1BlRcn42sjJkijeFp7DpI7pU+PnYeiaXpRv5pJo8ogM1iFxN+SnfEs0EuQ7fhKIG9aHKi7bKZ7L6SyX7MDIGLeulEU6lf5D9BfXNmcMambiS0pXhL2QXajt96UBq8FT2KNXY8XNtR4y6MyyCzhaiZZcc8=', validateInResponseTo: true }; var samlObj = new SAML( samlConfig ); fakeClock = sinon.useFakeTimers(Date.parse('2014-06-05T12:07:07.662Z')); // Mock the SAML request being passed through Passport-SAML samlObj.cacheProvider.save(requestId, new Date().toISOString(), function(){}); samlObj.validatePostResponse( container, function( err, profile, logout ) { should.not.exist( err ); profile.nameID.should.startWith( 'UIS/jochen-work' ); profile['vz::identity'].should.equal( 'UIS/jochen-work' ); profile['vz::subjecttype'].should.equal( 'UIS user' ); profile['vz::account'].should.equal( 'e9aba0c4-ece8-4b44-9526-d24418aa95dc' ); profile['vz::org'].should.equal( 'testorg' ); profile['vz::name'].should.equal( 'Test User' ); profile['net::ip'].should.equal( '::1' ); samlObj.cacheProvider.get(requestId, function(err, value){ should.not.exist(value); done(); }); }); }); describe( 'InResponseTo server cache expiration tests /', function() { it( 'should expire a cached request id after the time', function(done){ var requestId = '_dfab47d5d46374cd4b71'; var samlConfig = { validateInResponseTo: true, requestIdExpirationPeriodMs: 100 }; var samlObj = new SAML( samlConfig ); // Mock the SAML request being passed through Passport-SAML samlObj.cacheProvider.save(requestId, new Date().toISOString(), function(){}); setTimeout(function(){ samlObj.cacheProvider.get(requestId, function(err, value){ should.not.exist(value); done(); }); }, 300); }); it( 'should expire many cached request ids after the time', function(done){ var expiredRequestId1 = '_dfab47d5d46374cd4b71'; var expiredRequestId2 = '_dfab47d5d46374cd4b72'; var requestId = '_dfab47d5d46374cd4b73'; var samlConfig = { validateInResponseTo: true, requestIdExpirationPeriodMs: 100 }; var samlObj = new SAML( samlConfig ); samlObj.cacheProvider.save(expiredRequestId1, new Date().toISOString(), function(){}); samlObj.cacheProvider.save(expiredRequestId2, new Date().toISOString(), function(){}); setTimeout(function(){ // Add one more that shouldn't expire samlObj.cacheProvider.save(requestId, new Date().toISOString(), function(){}); samlObj.cacheProvider.get(expiredRequestId1, function(err, value){ should.not.exist(value); }); samlObj.cacheProvider.get(expiredRequestId2, function(err, value){ should.not.exist(value); }); samlObj.cacheProvider.get(requestId, function(err, value){ should.exist(value); }); // Let the expiration timer run again and we should have no more cached setTimeout(function(){ samlObj.cacheProvider.get(requestId, function(err, value){ should.not.exist(value); done(); }); }, 300) }, 300); }); }); }); describe( 'assertion condition checks /', function() { var samlConfig = { entryPoint: 'https://app.onelogin.com/trust/saml2/http-post/sso/371755', cert: TEST_CERT, }; var fakeClock; beforeEach(function() { fakeClock = sinon.useFakeTimers(Date.parse('2014-05-28T00:13:09Z')); }); afterEach(function() { fakeClock.restore(); }); it( 'onelogin xml document with current time after NotBefore time should validate', function( done ) { var xml = 'https://app.onelogin.com/saml/metadata/371755' + 'https://app.onelogin.com/saml/metadata/371755DCnPTQYBb1hKspbe6fg1U3q8xn4=e0+aFomA0+JAY0f9tKqzIuqIVSSw7LiFUsneEDKPBWdiTz1sMdgr/2y1e9+rjaS2mRmCi/vSQLY3zTYz0hp6nJNU19+TWoXo9kHQyWT4KkeQL4Xs/gZ/AoKC20iHVKtpPps0IQ0Ml/qRoouSitt6Sf/WDz2LV/pWcH2hx5tv3xSw36hK2NQc7qw7r1mEXnvcjXReYo8rrVf7XHGGxNoRIEICUIi110uvsWemSXf0Z0dyb0FVYOWuSsQMDlzNpheADBifFO4UTfSEhFZvn8kVCGZUIwrbOhZ2d/+YEtgyuTg+qtslgfy4dwd4TvEcfuRzQTazeefprSFyiQckAXOjcw=='+TEST_CERT+'ploer@subspacesw.com{audience}urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport' + ''; var base64xml = new Buffer( xml ).toString('base64'); var container = { SAMLResponse: base64xml }; var samlObj = new SAML( samlConfig ); // Fake the current date to be within the valid time range fakeClock = sinon.useFakeTimers(Date.parse('2014-05-28T00:13:09Z')); samlObj.validatePostResponse( container, function( err, profile, logout ) { should.not.exist( err ); profile.nameID.should.startWith( 'ploer' ); done(); }); }); it( 'onelogin xml document with current time equal to NotBefore (plus default clock skew) time should validate', function( done ) { var xml = 'https://app.onelogin.com/saml/metadata/371755' + 'https://app.onelogin.com/saml/metadata/371755DCnPTQYBb1hKspbe6fg1U3q8xn4=e0+aFomA0+JAY0f9tKqzIuqIVSSw7LiFUsneEDKPBWdiTz1sMdgr/2y1e9+rjaS2mRmCi/vSQLY3zTYz0hp6nJNU19+TWoXo9kHQyWT4KkeQL4Xs/gZ/AoKC20iHVKtpPps0IQ0Ml/qRoouSitt6Sf/WDz2LV/pWcH2hx5tv3xSw36hK2NQc7qw7r1mEXnvcjXReYo8rrVf7XHGGxNoRIEICUIi110uvsWemSXf0Z0dyb0FVYOWuSsQMDlzNpheADBifFO4UTfSEhFZvn8kVCGZUIwrbOhZ2d/+YEtgyuTg+qtslgfy4dwd4TvEcfuRzQTazeefprSFyiQckAXOjcw=='+TEST_CERT+'ploer@subspacesw.com{audience}urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport' + ''; var base64xml = new Buffer( xml ).toString('base64'); var container = { SAMLResponse: base64xml }; var samlObj = new SAML( samlConfig ); // Fake the current date to be within the valid time range fakeClock = sinon.useFakeTimers(Date.parse('2014-05-28T00:13:08Z')); samlObj.validatePostResponse( container, function( err, profile, logout ) { should.not.exist( err ); profile.nameID.should.startWith( 'ploer' ); done(); }); }); it( 'onelogin xml document with current time before NotBefore time should fail', function( done ) { var xml = 'https://app.onelogin.com/saml/metadata/371755' + 'https://app.onelogin.com/saml/metadata/371755DCnPTQYBb1hKspbe6fg1U3q8xn4=e0+aFomA0+JAY0f9tKqzIuqIVSSw7LiFUsneEDKPBWdiTz1sMdgr/2y1e9+rjaS2mRmCi/vSQLY3zTYz0hp6nJNU19+TWoXo9kHQyWT4KkeQL4Xs/gZ/AoKC20iHVKtpPps0IQ0Ml/qRoouSitt6Sf/WDz2LV/pWcH2hx5tv3xSw36hK2NQc7qw7r1mEXnvcjXReYo8rrVf7XHGGxNoRIEICUIi110uvsWemSXf0Z0dyb0FVYOWuSsQMDlzNpheADBifFO4UTfSEhFZvn8kVCGZUIwrbOhZ2d/+YEtgyuTg+qtslgfy4dwd4TvEcfuRzQTazeefprSFyiQckAXOjcw=='+TEST_CERT+'ploer@subspacesw.com{audience}urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport' + ''; var base64xml = new Buffer( xml ).toString('base64'); var container = { SAMLResponse: base64xml }; var samlObj = new SAML( samlConfig ); // Fake the current date to be after the valid time range fakeClock = sinon.useFakeTimers(Date.parse('2014-05-28T00:13:07Z')); samlObj.validatePostResponse( container, function( err, profile, logout ) { should.exist( err ); err.message.should.match( 'SAML assertion not yet valid' ); done(); }); }); it( 'onelogin xml document with current time equal to NotOnOrAfter (minus default clock skew) time should fail', function( done ) { var xml = 'https://app.onelogin.com/saml/metadata/371755' + 'https://app.onelogin.com/saml/metadata/371755DCnPTQYBb1hKspbe6fg1U3q8xn4=e0+aFomA0+JAY0f9tKqzIuqIVSSw7LiFUsneEDKPBWdiTz1sMdgr/2y1e9+rjaS2mRmCi/vSQLY3zTYz0hp6nJNU19+TWoXo9kHQyWT4KkeQL4Xs/gZ/AoKC20iHVKtpPps0IQ0Ml/qRoouSitt6Sf/WDz2LV/pWcH2hx5tv3xSw36hK2NQc7qw7r1mEXnvcjXReYo8rrVf7XHGGxNoRIEICUIi110uvsWemSXf0Z0dyb0FVYOWuSsQMDlzNpheADBifFO4UTfSEhFZvn8kVCGZUIwrbOhZ2d/+YEtgyuTg+qtslgfy4dwd4TvEcfuRzQTazeefprSFyiQckAXOjcw=='+TEST_CERT+'ploer@subspacesw.com{audience}urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport' + ''; var base64xml = new Buffer( xml ).toString('base64'); var container = { SAMLResponse: base64xml }; var samlObj = new SAML( samlConfig ); // Fake the current date to be after the valid time range fakeClock = sinon.useFakeTimers(Date.parse('2014-05-28T00:19:08Z')); samlObj.validatePostResponse( container, function( err, profile, logout ) { should.exist( err ); err.message.should.match( 'SAML assertion expired' ); done(); }); }); it( 'onelogin xml document with current time after NotOnOrAfter time (minus default clock skew) should fail', function( done ) { var xml = 'https://app.onelogin.com/saml/metadata/371755' + 'https://app.onelogin.com/saml/metadata/371755DCnPTQYBb1hKspbe6fg1U3q8xn4=e0+aFomA0+JAY0f9tKqzIuqIVSSw7LiFUsneEDKPBWdiTz1sMdgr/2y1e9+rjaS2mRmCi/vSQLY3zTYz0hp6nJNU19+TWoXo9kHQyWT4KkeQL4Xs/gZ/AoKC20iHVKtpPps0IQ0Ml/qRoouSitt6Sf/WDz2LV/pWcH2hx5tv3xSw36hK2NQc7qw7r1mEXnvcjXReYo8rrVf7XHGGxNoRIEICUIi110uvsWemSXf0Z0dyb0FVYOWuSsQMDlzNpheADBifFO4UTfSEhFZvn8kVCGZUIwrbOhZ2d/+YEtgyuTg+qtslgfy4dwd4TvEcfuRzQTazeefprSFyiQckAXOjcw=='+TEST_CERT+'ploer@subspacesw.com{audience}urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport' + ''; var base64xml = new Buffer( xml ).toString('base64'); var container = { SAMLResponse: base64xml }; var samlObj = new SAML( samlConfig ); // Fake the current date to be after the valid time range fakeClock = sinon.useFakeTimers(Date.parse('2014-05-28T00:19:09Z')); samlObj.validatePostResponse( container, function( err, profile, logout ) { should.exist( err ); err.message.should.match( 'SAML assertion expired' ); done(); }); }); it( 'onelogin xml document with current time after NotOnOrAfter time with accepted clock skew equal to -1 should pass', function( done ) { var xml = 'https://app.onelogin.com/saml/metadata/371755' + 'https://app.onelogin.com/saml/metadata/371755DCnPTQYBb1hKspbe6fg1U3q8xn4=e0+aFomA0+JAY0f9tKqzIuqIVSSw7LiFUsneEDKPBWdiTz1sMdgr/2y1e9+rjaS2mRmCi/vSQLY3zTYz0hp6nJNU19+TWoXo9kHQyWT4KkeQL4Xs/gZ/AoKC20iHVKtpPps0IQ0Ml/qRoouSitt6Sf/WDz2LV/pWcH2hx5tv3xSw36hK2NQc7qw7r1mEXnvcjXReYo8rrVf7XHGGxNoRIEICUIi110uvsWemSXf0Z0dyb0FVYOWuSsQMDlzNpheADBifFO4UTfSEhFZvn8kVCGZUIwrbOhZ2d/+YEtgyuTg+qtslgfy4dwd4TvEcfuRzQTazeefprSFyiQckAXOjcw=='+TEST_CERT+'ploer@subspacesw.com{audience}urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport' + ''; var base64xml = new Buffer( xml ).toString('base64'); var container = { SAMLResponse: base64xml }; var samlConfig = { entryPoint: 'https://app.onelogin.com/trust/saml2/http-post/sso/371755', cert: TEST_CERT, acceptedClockSkewMs: -1 }; var samlObj = new SAML( samlConfig ); // Fake the current date to be after the valid time range fakeClock = sinon.useFakeTimers(Date.parse('2014-05-28T00:20:09Z')); samlObj.validatePostResponse( container, function( err, profile, logout ) { should.not.exist( err ); profile.nameID.should.startWith( 'ploer' ); done(); }); }); }); }); describe('validatePostRequest()', function() { var samlObj; beforeEach(function() { samlObj = new SAML({ cert: fs.readFileSync(__dirname + '/static/cert.pem', 'ascii') }); }); it('errors if bad xml', function(done) { var body = { SAMLRequest: "asdf" }; samlObj.validatePostRequest(body, function(err) { should.exist(err); done(); }); }); it('errors if bad signature', function(done) { var body = { SAMLRequest: fs.readFileSync(__dirname + '/static/logout_request_with_bad_signature.xml', 'base64') }; samlObj.validatePostRequest(body, function(err) { should.exist(err); err.should.eql(new Error('Invalid signature')); done(); }); }); it('returns profile for valid signature', function(done) { var body = { SAMLRequest: fs.readFileSync(__dirname + '/static/logout_request_with_good_signature.xml', 'base64') }; samlObj.validatePostRequest(body, function(err, profile) { should.not.exist(err); profile.should.eql({ ID: 'pfxd4d369e8-9ea1-780c-aff8-a1d11a9862a1', issuer: 'http://sp.example.com/demo1/metadata.php', nameID: 'ONELOGIN_f92cc1834efc0f73e9c09f482fce80037a6251e7', nameIDFormat: 'urn:oasis:names:tc:SAML:2.0:nameid-format:transient' }); done(); }); }); it('returns profile for valid signature including session index', function(done) { var body = { SAMLRequest: fs.readFileSync(__dirname + '/static/logout_request_with_session_index.xml', 'base64') }; samlObj.validatePostRequest(body, function(err, profile) { should.not.exist(err); profile.should.eql({ ID: 'pfxd4d369e8-9ea1-780c-aff8-a1d11a9862a1', issuer: 'http://sp.example.com/demo1/metadata.php', nameID: 'ONELOGIN_f92cc1834efc0f73e9c09f482fce80037a6251e7', nameIDFormat: 'urn:oasis:names:tc:SAML:2.0:nameid-format:transient', sessionIndex: '1' }); done(); }); }); it('errors if bad privateCert to requestToURL', function(done){ var samlObj = new SAML({ entryPoint: "foo", privateCert: "-----BEGIN CERTIFICATE-----\n"+ "8mvhvrcCOiJ3mjgKNN1F31jOBJuZNmq0U7n9v+Z+3NfyU/0E9jkrnFvm5ks+p8kl\n" + "BjuBk9RAkazsU9l02XMS/VxOOIifxKC7R9bDtx0hjolYxgqxPIO5s4rmjj0rLzvo\n" + "vQTTTx/tB5e+hbdx922QSeTjP4DO4ms6cIexcH+ZEUOJ3wXiHToJW83SXLRtwPI9\n" + "JbWKeS9nWPnzcedbDNZkGtohW5vf32BHuvLsWcl6eFXRSkdX/7+rgpXmDRB7caQ+\n" + "2SXVY7ORily7LTKg1cFmuKHDzKTGFIp5/GU6dwIDAQABAoIBAArgFQ+Uk4UN4diY\n" + "gJWCAaQlTVmP0UEHZQt/NmJrc9ZVduuhOP0hH6gF53nREHz5UQb4nXB2Ksa3MtYD\n" + "Z1vhJcu/T7pvmib4q+Ij6oAmlyeL/xwVY3IUURMxX3tCdPItlk4PEFELKeqQOiIS\n" + "7B0DYxWfJbMle3c95w5ruYEr2A+fHCKVSlDpg7uPd9VQ6t7bGMZZvc9tDSC1qPXQ\n" + "Gd/WOMXxi+t/TpyVZ6tOcEekQzAMLmWElUUPx3TJ0ur0Zl2LZ7IvQEXXias4lUHV\n" + "fnH3akDCMmdhlJSVqUfplrh85zAOh6fLloZagphj/Kpgfw1TZ+njSDYqSLYE0NZ1\n" + "j+83feECgYEA2aNGgbc+t6QLrJJ63l9Mz541lVV3IUAxZ5ACqOnMkQVuLoa5IMwM\n" + "oENIo38ptfHQqjQ9x8/tEINFqOHnQuOJ/+1xP9f0Me+0clRDCqjGYqNYgmakKyD7\n" + "vey/q6kwHk679RVGiI1p+HdoA+CbEKWHJiRxE0RhAA3G3wGAq7kpJocCgYEAxp4/\n" + "tCft+eHVRivspfDN//axc2TR6qWP9E1ueGvbiXPXv0Puag0W9cER/df/s5jW4Rqg\n" + "CE8649HPUZ0FJT+YaeKgu2Sw9SMcGl4/uyHzg7KnXIeYyQZJPqQkKyXmIix8cw3+\n" + "HBGRtwX5nOy0DgFdaMiH0F08peNI9QHKKTBoWJECgYEAyymJ1ekzWMaAR1Zt8EvS\n" + "LjWoG4EuthFwjRZ4BSpLVk1Vb4VAKAeS+cAVfNpmG3xip6Ag0/ebe0CvtFk9QsmZ\n" + "txj2EP0M7div/9H8y2SF3OpS41fhhIlDtyXcPuivDHu/Jaf4sdwgwlrk9EmlN0Lu\n" + "CIMYMz4vtpclwGNss+EjMt0CgYEAqepD0Vm/iuCaVhfJsgSaFvnywSdlNfpBdtyv\n" + "PzH2dFa4IZZ55hwgoklznNgmlnyQh68BbVpqpO+fDtDnz//h4ePRYb84a96Hcj9j\n" + "AjJ/YxF5f/04xfEsw/wkPQ2FHYM1TDCSTWzyXcMs0gTl3H1qbfPvzF+XPMt+ZKwN\n" + "SMNy4SECgYB3ig6t+XVfNkw8oBOh0Gx37XKbmImXsA8ucDAX9KUbMIvD03XCEf34\n" + "jF3SNJh0SmHoT62vc+cJqPxMDP6E7Q1nZxsEyaAkKr2H4dSM4SlRm0VB+bS+jXsz\n" + "PCiRGSm8eupuxfix05LMMreo4mC7e3Ir4JhdCsXxAMZIvbNyXcvUMA==\n" + "-----END CERTIFICATE-----\n" }); var request = 'onelogin_samlurn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport'; samlObj.requestToUrl(request, null, 'authorize', {}, function(err) { should.exist(err); err.message.should.eql('error:0906D06C:PEM routines:PEM_read_bio:no start line'); done(); }); }); }); });