Repository: russellhaering/gosaml2 Branch: main Commit: 636e7dda202a Files: 166 Total size: 1.2 MB Directory structure: gitextract_zio5e6rg/ ├── .github/ │ ├── dependabot.yml │ └── workflows/ │ ├── scorecard.yml │ └── test.yml ├── .gitignore ├── LICENSE ├── README.md ├── SECURITY.md ├── attribute.go ├── authn_request.go ├── build_logout_response.go ├── build_request.go ├── build_request_test.go ├── decode_logout_request.go ├── decode_response.go ├── decode_response_test.go ├── go.mod ├── go.sum ├── internal/ │ └── fuzz/ │ ├── README.md │ └── fuzz_test.go ├── logout_request.go ├── oss-fuzz/ │ ├── Dockerfile │ ├── README.md │ ├── build.sh │ ├── fuzz_decode_response.options │ └── project.yaml ├── providertests/ │ ├── exercise.go │ ├── exercise_go_1_6.go │ ├── oktadev_test.go │ ├── onelogin_test.go │ ├── pingfed_test.go │ ├── providers_test.go │ ├── testdata/ │ │ ├── adfs_idp_signing_cert.pem │ │ ├── adfs_response.b64 │ │ ├── adfs_response_enc.b64 │ │ ├── auth0_cert.pem │ │ ├── auth0_response.xml │ │ ├── oam_cert.pem │ │ ├── oam_response.xml │ │ ├── okta_cert.pem │ │ ├── okta_response.xml │ │ ├── oktaenc_idp_signing_cert.pem │ │ ├── oktaenc_response.b64 │ │ ├── oktaenc_sp_encryption_cert.pem │ │ ├── oktaenc_sp_encryption_key.pem │ │ ├── oktaenc_sp_signing_cert.pem │ │ ├── oktaenc_sp_signing_key.pem │ │ ├── onelogin/ │ │ │ ├── idp.signing.cert │ │ │ ├── olgn09_response_01.b64 │ │ │ ├── olgn09_response_03.b64 │ │ │ ├── olgn09_response_04.b64 │ │ │ ├── olgn09_response_05.b64 │ │ │ ├── olgn09_response_06.b64 │ │ │ ├── olgn09_response_07.b64 │ │ │ ├── olgn09_response_08.b64 │ │ │ ├── olgn09_response_09.b64 │ │ │ ├── olgn09_response_11.b64 │ │ │ ├── olgn09_response_12.b64 │ │ │ ├── olgn09_response_13.b64 │ │ │ ├── olgn09_response_14.b64 │ │ │ ├── olgn09_response_15.b64 │ │ │ ├── olgn09_response_155.b64 │ │ │ ├── olgn09_response_156.b64 │ │ │ ├── olgn09_response_157.b64 │ │ │ ├── olgn09_response_158.b64 │ │ │ ├── olgn09_response_159.b64 │ │ │ ├── olgn09_response_16.b64 │ │ │ ├── olgn09_response_17.b64 │ │ │ ├── olgn09_response_18.b64 │ │ │ ├── olgn09_response_21.b64 │ │ │ ├── olgn09_response_22.b64 │ │ │ ├── olgn09_response_23.b64 │ │ │ ├── olgn09_response_24.b64 │ │ │ ├── olgn09_response_25.b64 │ │ │ ├── olgn09_response_26.b64 │ │ │ ├── olgn09_response_27.b64 │ │ │ ├── olgn09_response_28.b64 │ │ │ ├── olgn09_response_31.b64 │ │ │ ├── olgn09_response_33.b64 │ │ │ ├── olgn09_response_34.b64 │ │ │ ├── olgn09_response_36.b64 │ │ │ ├── olgn09_response_37.b64 │ │ │ ├── olgn09_response_38.b64 │ │ │ ├── olgn09_response_46.b64 │ │ │ ├── olgn09_response_47.b64 │ │ │ ├── olgn09_response_48.b64 │ │ │ ├── olgn09_response_50.b64 │ │ │ ├── olgn09_response_51.b64 │ │ │ ├── olgn09_response_52.b64 │ │ │ ├── olgn09_response_53.b64 │ │ │ ├── olgn09_response_54.b64 │ │ │ ├── olgn09_response_55.b64 │ │ │ ├── olgn09_response_56.b64 │ │ │ ├── olgn09_response_57.b64 │ │ │ ├── olgn09_response_58.b64 │ │ │ ├── olgn09_response_59.b64 │ │ │ ├── olgn09_response_81.b64 │ │ │ ├── olgn09_response_82.b64 │ │ │ ├── olgn09_response_83.b64 │ │ │ ├── olgn09_response_84.b64 │ │ │ ├── olgn09_response_85.b64 │ │ │ ├── olgn09_response_86.b64 │ │ │ ├── olgn09_response_87.b64 │ │ │ ├── olgn09_response_88.b64 │ │ │ ├── olgn09_response_89.b64 │ │ │ ├── olgn09_response_91.b64 │ │ │ ├── olgn09_response_92.b64 │ │ │ ├── olgn09_response_93.b64 │ │ │ ├── olgn09_response_94.b64 │ │ │ ├── olgn09_response_97.b64 │ │ │ ├── olgn09_response_98.b64 │ │ │ ├── olgn09_response_99.b64 │ │ │ ├── sp.encryption.cert │ │ │ ├── sp.encryption.key │ │ │ ├── sp.signing.cert │ │ │ └── sp.signing.key │ │ ├── onelogin_cert.pem │ │ ├── onelogin_response.xml │ │ ├── pingfed/ │ │ │ ├── idp.signing.cert │ │ │ ├── pfed11_response_01.b64 │ │ │ ├── pfed11_response_02.b64 │ │ │ ├── pfed11_response_03.b64 │ │ │ ├── pfed11_response_05.b64 │ │ │ ├── sp.encryption.cert │ │ │ ├── sp.encryption.key │ │ │ ├── sp.signing.cert │ │ │ └── sp.signing.key │ │ └── saml.oktadev.com/ │ │ ├── oktadev.pem │ │ ├── response_0 │ │ ├── response_1 │ │ ├── response_10 │ │ ├── response_11 │ │ ├── response_12 │ │ ├── response_13 │ │ ├── response_14 │ │ ├── response_15 │ │ ├── response_16 │ │ ├── response_2 │ │ ├── response_3 │ │ ├── response_4 │ │ ├── response_5 │ │ ├── response_6 │ │ ├── response_7 │ │ ├── response_8 │ │ └── response_9 │ └── utils.go ├── retrieve_assertion.go ├── run_test.sh ├── s2example/ │ └── demo.go ├── saml.go ├── saml_test.go ├── test_constants.go ├── testdata/ │ ├── assertion.xml │ ├── idp.crt │ ├── saml.post │ ├── saml.xml │ ├── saml_compressed.post │ ├── test.crt │ └── test.key ├── types/ │ ├── encrypted_assertion.go │ ├── encrypted_key.go │ ├── metadata.go │ └── response.go ├── uuid/ │ ├── uuid.go │ └── uuid_test.go ├── validate.go └── xml_constants.go ================================================ FILE CONTENTS ================================================ ================================================ FILE: .github/dependabot.yml ================================================ version: 2 updates: - package-ecosystem: "github-actions" directory: "/" schedule: interval: "weekly" - package-ecosystem: "gomod" directory: "/" schedule: interval: "weekly" ================================================ FILE: .github/workflows/scorecard.yml ================================================ name: Scorecard supply-chain security on: # For Branch-Protection check. Only the default branch is supported. See # https://github.com/ossf/scorecard/blob/main/docs/checks.md#branch-protection branch_protection_rule: # To guarantee Maintained check is occasionally updated. See # https://github.com/ossf/scorecard/blob/main/docs/checks.md#maintained schedule: - cron: '33 5 * * 2' push: branches: [ "main" ] # Declare default permissions as read only. permissions: read-all jobs: analysis: name: Scorecard analysis runs-on: ubuntu-latest permissions: # Needed to upload the results to code-scanning dashboard. security-events: write # Needed to publish results and get a badge (see publish_results below). id-token: write steps: - name: "Checkout code" uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 with: persist-credentials: false - name: "Run analysis" uses: ossf/scorecard-action@4eaacf0543bb3f2c246792bd56e8cdeffafb205a # v2.4.3 with: results_file: results.sarif results_format: sarif publish_results: true # Upload the results as artifacts (optional). Commenting out will disable uploads of run results in SARIF # format to the repository Actions tab. - name: "Upload artifact" uses: actions/upload-artifact@bbbca2ddaa5d8feaa63e36b76fdaad77386f024f # v7.0.0 with: name: SARIF file path: results.sarif retention-days: 5 # Upload the results to GitHub's code scanning dashboard. - name: "Upload to code-scanning" uses: github/codeql-action/upload-sarif@b1bff81932f5cdfc8695c7752dcee935dcd061c8 # v4.33.0 with: sarif_file: results.sarif ================================================ FILE: .github/workflows/test.yml ================================================ on: [push, pull_request] name: Test permissions: contents: read jobs: test: name: Test Go ${{ matrix.go }} runs-on: ubuntu-latest strategy: matrix: go: ['1.26', '1.25'] steps: - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 - name: Setup Go uses: actions/setup-go@4b73464bb391d4059bd26b0524d20df3927bd417 # v6.3.0 with: go-version: ${{ matrix.go }} - name: Test run: go test ./... ================================================ FILE: .gitignore ================================================ *.test ================================================ FILE: LICENSE ================================================ Apache License Version 2.0, January 2004 http://www.apache.org/licenses/ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION 1. Definitions. "License" shall mean the terms and conditions for use, reproduction, and distribution as defined by Sections 1 through 9 of this document. "Licensor" shall mean the copyright owner or entity authorized by the copyright owner that is granting the License. "Legal Entity" shall mean the union of the acting entity and all other entities that control, are controlled by, or are under common control with that entity. For the purposes of this definition, "control" means (i) the power, direct or indirect, to cause the direction or management of such entity, whether by contract or otherwise, or (ii) ownership of fifty percent (50%) or more of the outstanding shares, or (iii) beneficial ownership of such entity. "You" (or "Your") shall mean an individual or Legal Entity exercising permissions granted by this License. "Source" form shall mean the preferred form for making modifications, including but not limited to software source code, documentation source, and configuration files. "Object" form shall mean any form resulting from mechanical transformation or translation of a Source form, including but not limited to compiled object code, generated documentation, and conversions to other media types. "Work" shall mean the work of authorship, whether in Source or Object form, made available under the License, as indicated by a copyright notice that is included in or attached to the work (an example is provided in the Appendix below). "Derivative Works" shall mean any work, whether in Source or Object form, that is based on (or derived from) the Work and for which the editorial revisions, annotations, elaborations, or other modifications represent, as a whole, an original work of authorship. For the purposes of this License, Derivative Works shall not include works that remain separable from, or merely link (or bind by name) to the interfaces of, the Work and Derivative Works thereof. "Contribution" shall mean any work of authorship, including the original version of the Work and any modifications or additions to that Work or Derivative Works thereof, that is intentionally submitted to Licensor for inclusion in the Work by the copyright owner or by an individual or Legal Entity authorized to submit on behalf of the copyright owner. For the purposes of this definition, "submitted" means any form of electronic, verbal, or written communication sent to the Licensor or its representatives, including but not limited to communication on electronic mailing lists, source code control systems, and issue tracking systems that are managed by, or on behalf of, the Licensor for the purpose of discussing and improving the Work, but excluding communication that is conspicuously marked or otherwise designated in writing by the copyright owner as "Not a Contribution." "Contributor" shall mean Licensor and any individual or Legal Entity on behalf of whom a Contribution has been received by Licensor and subsequently incorporated within the Work. 2. Grant of Copyright License. Subject to the terms and conditions of this License, each Contributor hereby grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable copyright license to reproduce, prepare Derivative Works of, publicly display, publicly perform, sublicense, and distribute the Work and such Derivative Works in Source or Object form. 3. Grant of Patent License. Subject to the terms and conditions of this License, each Contributor hereby grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable (except as stated in this section) patent license to make, have made, use, offer to sell, sell, import, and otherwise transfer the Work, where such license applies only to those patent claims licensable by such Contributor that are necessarily infringed by their Contribution(s) alone or by combination of their Contribution(s) with the Work to which such Contribution(s) was submitted. If You institute patent litigation against any entity (including a cross-claim or counterclaim in a lawsuit) alleging that the Work or a Contribution incorporated within the Work constitutes direct or contributory patent infringement, then any patent licenses granted to You under this License for that Work shall terminate as of the date such litigation is filed. 4. Redistribution. You may reproduce and distribute copies of the Work or Derivative Works thereof in any medium, with or without modifications, and in Source or Object form, provided that You meet the following conditions: (a) You must give any other recipients of the Work or Derivative Works a copy of this License; and (b) You must cause any modified files to carry prominent notices stating that You changed the files; and (c) You must retain, in the Source form of any Derivative Works that You distribute, all copyright, patent, trademark, and attribution notices from the Source form of the Work, excluding those notices that do not pertain to any part of the Derivative Works; and (d) If the Work includes a "NOTICE" text file as part of its distribution, then any Derivative Works that You distribute must include a readable copy of the attribution notices contained within such NOTICE file, excluding those notices that do not pertain to any part of the Derivative Works, in at least one of the following places: within a NOTICE text file distributed as part of the Derivative Works; within the Source form or documentation, if provided along with the Derivative Works; or, within a display generated by the Derivative Works, if and wherever such third-party notices normally appear. The contents of the NOTICE file are for informational purposes only and do not modify the License. You may add Your own attribution notices within Derivative Works that You distribute, alongside or as an addendum to the NOTICE text from the Work, provided that such additional attribution notices cannot be construed as modifying the License. You may add Your own copyright statement to Your modifications and may provide additional or different license terms and conditions for use, reproduction, or distribution of Your modifications, or for any such Derivative Works as a whole, provided Your use, reproduction, and distribution of the Work otherwise complies with the conditions stated in this License. 5. Submission of Contributions. Unless You explicitly state otherwise, any Contribution intentionally submitted for inclusion in the Work by You to the Licensor shall be under the terms and conditions of this License, without any additional terms or conditions. Notwithstanding the above, nothing herein shall supersede or modify the terms of any separate license agreement you may have executed with Licensor regarding such Contributions. 6. Trademarks. This License does not grant permission to use the trade names, trademarks, service marks, or product names of the Licensor, except as required for reasonable and customary use in describing the origin of the Work and reproducing the content of the NOTICE file. 7. Disclaimer of Warranty. Unless required by applicable law or agreed to in writing, Licensor provides the Work (and each Contributor provides its Contributions) on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied, including, without limitation, any warranties or conditions of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A PARTICULAR PURPOSE. You are solely responsible for determining the appropriateness of using or redistributing the Work and assume any risks associated with Your exercise of permissions under this License. 8. Limitation of Liability. In no event and under no legal theory, whether in tort (including negligence), contract, or otherwise, unless required by applicable law (such as deliberate and grossly negligent acts) or agreed to in writing, shall any Contributor be liable to You for damages, including any direct, indirect, special, incidental, or consequential damages of any character arising as a result of this License or out of the use or inability to use the Work (including but not limited to damages for loss of goodwill, work stoppage, computer failure or malfunction, or any and all other commercial damages or losses), even if such Contributor has been advised of the possibility of such damages. 9. Accepting Warranty or Additional Liability. While redistributing the Work or Derivative Works thereof, You may choose to offer, and charge a fee for, acceptance of support, warranty, indemnity, or other liability obligations and/or rights consistent with this License. However, in accepting such obligations, You may act only on Your own behalf and on Your sole responsibility, not on behalf of any other Contributor, and only if You agree to indemnify, defend, and hold each Contributor harmless for any liability incurred by, or claims asserted against, such Contributor by reason of your accepting any such warranty or additional liability. ================================================ FILE: README.md ================================================ # gosaml2 [![Build Status](https://github.com/russellhaering/gosaml2/actions/workflows/test.yml/badge.svg?branch=main)](https://github.com/russellhaering/gosaml2/actions/workflows/test.yml?query=branch%3Amain) [![GoDoc](https://godoc.org/github.com/russellhaering/gosaml2?status.svg)](https://godoc.org/github.com/russellhaering/gosaml2) SAML 2.0 implemementation for Service Providers based on [etree](https://github.com/beevik/etree) and [goxmldsig](https://github.com/russellhaering/goxmldsig), a pure Go implementation of XML digital signatures. ## Installation Install `gosaml2` into your `$GOPATH` using `go get`: ``` go get github.com/russellhaering/gosaml2 ``` ## Example See [demo.go](s2example/demo.go). ## Supported Identity Providers This library is meant to be a generic SAML implementation. If you find a standards compliant identity provider that it doesn't work with please submit a bug or pull request. The following identity providers have been tested: * Okta * Auth0 * Shibboleth * Ipsilon * OneLogin * Azure Active Directory (Azure AD) ================================================ FILE: SECURITY.md ================================================ # Security Policy ## Reporting a Vulnerability Security vulnerabilities can be reported using GitHub's [private vulnerability reporting tool](https://github.com/russellhaering/gosaml2/security/advisories/new). ================================================ FILE: attribute.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package saml2 import "github.com/russellhaering/gosaml2/types" // Values is a convenience wrapper for a map of strings to Attributes, which // can be used for easy access to the string values of Attribute lists. type Values map[string]types.Attribute // Get is a safe method (nil maps will not panic) for returning the first value // for an attribute at a key, or the empty string if none exists. func (vals Values) Get(k string) string { if vals == nil { return "" } if v, ok := vals[k]; ok && len(v.Values) > 0 { return string(v.Values[0].Value) } return "" } //GetSize returns the number of values for an attribute at a key. //Returns '0' in case of error or if key is not found. func (vals Values) GetSize(k string) int { if vals == nil { return 0 } v, ok := vals[k] if ok { return len(v.Values) } return 0 } //GetAll returns all the values for an attribute at a key. //Returns an empty slice in case of error of if key is not found. func (vals Values) GetAll(k string) []string { var av []string if vals == nil { return av } if v, ok := vals[k]; ok && len(v.Values) > 0 { for i := 0; i < len(v.Values); i++ { av = append(av, string(v.Values[i].Value)) } } return av } ================================================ FILE: authn_request.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package saml2 import "time" // AuthNRequest is the go struct representation of an authentication request type AuthNRequest struct { ID string `xml:",attr"` Version string `xml:",attr"` ProtocolBinding string `xml:",attr"` AssertionConsumerServiceURL string `xml:",attr"` IssueInstant time.Time `xml:",attr"` Destination string `xml:",attr"` Issuer string } ================================================ FILE: build_logout_response.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package saml2 import ( "bytes" "encoding/base64" "html/template" "github.com/beevik/etree" "github.com/russellhaering/gosaml2/uuid" ) func (sp *SAMLServiceProvider) buildLogoutResponse(statusCodeValue string, reqID string, includeSig bool) (*etree.Document, error) { logoutResponse := &etree.Element{ Space: "samlp", Tag: "LogoutResponse", } logoutResponse.CreateAttr("xmlns:samlp", "urn:oasis:names:tc:SAML:2.0:protocol") logoutResponse.CreateAttr("xmlns:saml", "urn:oasis:names:tc:SAML:2.0:assertion") arId := uuid.NewV4() logoutResponse.CreateAttr("ID", "_"+arId.String()) logoutResponse.CreateAttr("Version", "2.0") logoutResponse.CreateAttr("IssueInstant", sp.Clock.Now().UTC().Format(issueInstantFormat)) logoutResponse.CreateAttr("Destination", sp.IdentityProviderSLOURL) logoutResponse.CreateAttr("InResponseTo", reqID) // NOTE(russell_h): In earlier versions we mistakenly sent the IdentityProviderIssuer // in the AuthnRequest. For backwards compatibility we will fall back to that // behavior when ServiceProviderIssuer isn't set. if sp.ServiceProviderIssuer != "" { logoutResponse.CreateElement("saml:Issuer").SetText(sp.ServiceProviderIssuer) } else { logoutResponse.CreateElement("saml:Issuer").SetText(sp.IdentityProviderIssuer) } status := logoutResponse.CreateElement("samlp:Status") statusCode := status.CreateElement("samlp:StatusCode") statusCode.CreateAttr("Value", statusCodeValue) doc := etree.NewDocument() // Only POST binding includes in (includeSig) if includeSig { signed, err := sp.SignLogoutResponse(logoutResponse) if err != nil { return nil, err } doc.SetRoot(signed) } else { doc.SetRoot(logoutResponse) } return doc, nil } func (sp *SAMLServiceProvider) BuildLogoutResponseDocument(status string, reqID string) (*etree.Document, error) { return sp.buildLogoutResponse(status, reqID, true) } func (sp *SAMLServiceProvider) BuildLogoutResponseDocumentNoSig(status string, reqID string) (*etree.Document, error) { return sp.buildLogoutResponse(status, reqID, false) } func (sp *SAMLServiceProvider) SignLogoutResponse(el *etree.Element) (*etree.Element, error) { ctx := sp.SigningContext() sig, err := ctx.ConstructSignature(el, true) if err != nil { return nil, err } ret := el.Copy() var children []etree.Token children = append(children, ret.Child[0]) // issuer is always first children = append(children, sig) // next is the signature children = append(children, ret.Child[1:]...) // then all other children ret.Child = children return ret, nil } func (sp *SAMLServiceProvider) buildLogoutResponseBodyPostFromDocument(relayState string, doc *etree.Document) ([]byte, error) { respBuf, err := doc.WriteToBytes() if err != nil { return nil, err } encodedRespBuf := base64.StdEncoding.EncodeToString(respBuf) var tmpl *template.Template var rv bytes.Buffer if relayState != "" { tmpl = template.Must(template.New("saml-post-form").Parse(`` + `
` + `` + `` + `` + `
` + `` + `` + ``)) data := struct { URL string SAMLResponse string RelayState string }{ URL: sp.IdentityProviderSLOURL, SAMLResponse: encodedRespBuf, RelayState: relayState, } if err = tmpl.Execute(&rv, data); err != nil { return nil, err } } else { tmpl = template.Must(template.New("saml-post-form").Parse(`` + `
` + `` + `` + `
` + `` + `` + ``)) data := struct { URL string SAMLResponse string }{ URL: sp.IdentityProviderSLOURL, SAMLResponse: encodedRespBuf, } if err = tmpl.Execute(&rv, data); err != nil { return nil, err } } return rv.Bytes(), nil } func (sp *SAMLServiceProvider) BuildLogoutResponseBodyPostFromDocument(relayState string, doc *etree.Document) ([]byte, error) { return sp.buildLogoutResponseBodyPostFromDocument(relayState, doc) } ================================================ FILE: build_request.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package saml2 import ( "bytes" "compress/flate" "encoding/base64" "fmt" "html/template" "net/http" "net/url" "github.com/beevik/etree" "github.com/russellhaering/gosaml2/uuid" ) const issueInstantFormat = "2006-01-02T15:04:05Z" func (sp *SAMLServiceProvider) buildAuthnRequest(includeSig bool) (*etree.Document, error) { authnRequest := &etree.Element{ Space: "samlp", Tag: "AuthnRequest", } authnRequest.CreateAttr("xmlns:samlp", "urn:oasis:names:tc:SAML:2.0:protocol") authnRequest.CreateAttr("xmlns:saml", "urn:oasis:names:tc:SAML:2.0:assertion") arId := uuid.NewV4() authnRequest.CreateAttr("ID", "_"+arId.String()) authnRequest.CreateAttr("Version", "2.0") authnRequest.CreateAttr("ProtocolBinding", "urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST") authnRequest.CreateAttr("AssertionConsumerServiceURL", sp.AssertionConsumerServiceURL) authnRequest.CreateAttr("IssueInstant", sp.Clock.Now().UTC().Format(issueInstantFormat)) authnRequest.CreateAttr("Destination", sp.IdentityProviderSSOURL) if sp.ForceAuthn { authnRequest.CreateAttr("ForceAuthn", "true") } if sp.IsPassive { authnRequest.CreateAttr("IsPassive", "true") } // NOTE(russell_h): In earlier versions we mistakenly sent the IdentityProviderIssuer // in the AuthnRequest. For backwards compatibility we will fall back to that // behavior when ServiceProviderIssuer isn't set. if sp.ServiceProviderIssuer != "" { authnRequest.CreateElement("saml:Issuer").SetText(sp.ServiceProviderIssuer) } else { authnRequest.CreateElement("saml:Issuer").SetText(sp.IdentityProviderIssuer) } nameIdPolicy := authnRequest.CreateElement("samlp:NameIDPolicy") nameIdPolicy.CreateAttr("AllowCreate", "true") if sp.NameIdFormat != "" { nameIdPolicy.CreateAttr("Format", sp.NameIdFormat) } if sp.RequestedAuthnContext != nil { requestedAuthnContext := authnRequest.CreateElement("samlp:RequestedAuthnContext") requestedAuthnContext.CreateAttr("Comparison", sp.RequestedAuthnContext.Comparison) for _, context := range sp.RequestedAuthnContext.Contexts { authnContextClassRef := requestedAuthnContext.CreateElement("saml:AuthnContextClassRef") authnContextClassRef.SetText(context) } } doc := etree.NewDocument() // Only POST binding includes in (includeSig) if sp.SignAuthnRequests && includeSig { signed, err := sp.SignAuthnRequest(authnRequest) if err != nil { return nil, err } doc.SetRoot(signed) } else { doc.SetRoot(authnRequest) } return doc, nil } func (sp *SAMLServiceProvider) BuildAuthRequestDocument() (*etree.Document, error) { return sp.buildAuthnRequest(true) } func (sp *SAMLServiceProvider) BuildAuthRequestDocumentNoSig() (*etree.Document, error) { return sp.buildAuthnRequest(false) } // SignAuthnRequest takes a document, builds a signature, creates another document // and inserts the signature in it. According to the schema, the position of the // signature is right after the Issuer [1] then all other children. // // [1] https://docs.oasis-open.org/security/saml/v2.0/saml-schema-protocol-2.0.xsd func (sp *SAMLServiceProvider) SignAuthnRequest(el *etree.Element) (*etree.Element, error) { ctx := sp.SigningContext() sig, err := ctx.ConstructSignature(el, true) if err != nil { return nil, err } ret := el.Copy() var children []etree.Token children = append(children, ret.Child[0]) // issuer is always first children = append(children, sig) // next is the signature children = append(children, ret.Child[1:]...) // then all other children ret.Child = children return ret, nil } // BuildAuthRequest builds for identity provider func (sp *SAMLServiceProvider) BuildAuthRequest() (string, error) { doc, err := sp.BuildAuthRequestDocument() if err != nil { return "", err } return doc.WriteToString() } func (sp *SAMLServiceProvider) buildAuthURLFromDocument(relayState, binding string, doc *etree.Document) (string, error) { parsedUrl, err := url.Parse(sp.IdentityProviderSSOURL) if err != nil { return "", err } authnRequest, err := doc.WriteToString() if err != nil { return "", err } buf := &bytes.Buffer{} fw, err := flate.NewWriter(buf, flate.DefaultCompression) if err != nil { return "", fmt.Errorf("flate NewWriter error: %v", err) } _, err = fw.Write([]byte(authnRequest)) if err != nil { return "", fmt.Errorf("flate.Writer Write error: %v", err) } err = fw.Close() if err != nil { return "", fmt.Errorf("flate.Writer Close error: %v", err) } qs := parsedUrl.Query() qs.Add("SAMLRequest", base64.StdEncoding.EncodeToString(buf.Bytes())) if relayState != "" { qs.Add("RelayState", relayState) } if sp.SignAuthnRequests && binding == BindingHttpRedirect { // Sign URL encoded query (see Section 3.4.4.1 DEFLATE Encoding of saml-bindings-2.0-os.pdf) ctx := sp.SigningContext() qs.Add("SigAlg", ctx.GetSignatureMethodIdentifier()) var rawSignature []byte if rawSignature, err = ctx.SignString(signatureInputString(qs.Get("SAMLRequest"), qs.Get("RelayState"), qs.Get("SigAlg"))); err != nil { return "", fmt.Errorf("unable to sign query string of redirect URL: %v", err) } // Now add base64 encoded Signature qs.Add("Signature", base64.StdEncoding.EncodeToString(rawSignature)) } //Here the parameters may appear in any order. parsedUrl.RawQuery = qs.Encode() return parsedUrl.String(), nil } func (sp *SAMLServiceProvider) BuildAuthURLFromDocument(relayState string, doc *etree.Document) (string, error) { return sp.buildAuthURLFromDocument(relayState, BindingHttpPost, doc) } func (sp *SAMLServiceProvider) BuildAuthURLRedirect(relayState string, doc *etree.Document) (string, error) { return sp.buildAuthURLFromDocument(relayState, BindingHttpRedirect, doc) } func (sp *SAMLServiceProvider) buildAuthBodyPostFromDocument(relayState string, doc *etree.Document) ([]byte, error) { reqBuf, err := doc.WriteToBytes() if err != nil { return nil, err } encodedReqBuf := base64.StdEncoding.EncodeToString(reqBuf) var tmpl *template.Template var rv bytes.Buffer if relayState != "" { tmpl = template.Must(template.New("saml-post-form").Parse(`` + `
` + `` + `` + `` + `
` + ``)) data := struct { URL string SAMLRequest string RelayState string }{ URL: sp.IdentityProviderSSOURL, SAMLRequest: encodedReqBuf, RelayState: relayState, } if err = tmpl.Execute(&rv, data); err != nil { return nil, err } } else { tmpl = template.Must(template.New("saml-post-form").Parse(`` + `
` + `` + `` + `
` + ``)) data := struct { URL string SAMLRequest string }{ URL: sp.IdentityProviderSSOURL, SAMLRequest: encodedReqBuf, } if err = tmpl.Execute(&rv, data); err != nil { return nil, err } } return rv.Bytes(), nil } //BuildAuthBodyPost builds the POST body to be sent to IDP. func (sp *SAMLServiceProvider) BuildAuthBodyPost(relayState string) ([]byte, error) { var doc *etree.Document var err error if sp.SignAuthnRequests { doc, err = sp.BuildAuthRequestDocument() } else { doc, err = sp.BuildAuthRequestDocumentNoSig() } if err != nil { return nil, err } return sp.buildAuthBodyPostFromDocument(relayState, doc) } //BuildAuthBodyPostFromDocument builds the POST body to be sent to IDP. //It takes the AuthnRequest xml as input. func (sp *SAMLServiceProvider) BuildAuthBodyPostFromDocument(relayState string, doc *etree.Document) ([]byte, error) { return sp.buildAuthBodyPostFromDocument(relayState, doc) } // BuildAuthURL builds redirect URL to be sent to principal func (sp *SAMLServiceProvider) BuildAuthURL(relayState string) (string, error) { doc, err := sp.BuildAuthRequestDocument() if err != nil { return "", err } return sp.BuildAuthURLFromDocument(relayState, doc) } // AuthRedirect takes a ResponseWriter and Request from an http interaction and // redirects to the SAMLServiceProvider's configured IdP, including the // relayState provided, if any. func (sp *SAMLServiceProvider) AuthRedirect(w http.ResponseWriter, r *http.Request, relayState string) (err error) { url, err := sp.BuildAuthURL(relayState) if err != nil { return err } http.Redirect(w, r, url, http.StatusFound) return nil } func (sp *SAMLServiceProvider) buildLogoutRequest(includeSig bool, nameID string, sessionIndex string) (*etree.Document, error) { logoutRequest := &etree.Element{ Space: "samlp", Tag: "LogoutRequest", } logoutRequest.CreateAttr("xmlns:samlp", "urn:oasis:names:tc:SAML:2.0:protocol") logoutRequest.CreateAttr("xmlns:saml", "urn:oasis:names:tc:SAML:2.0:assertion") arId := uuid.NewV4() logoutRequest.CreateAttr("ID", "_"+arId.String()) logoutRequest.CreateAttr("Version", "2.0") logoutRequest.CreateAttr("IssueInstant", sp.Clock.Now().UTC().Format(issueInstantFormat)) logoutRequest.CreateAttr("Destination", sp.IdentityProviderSLOURL) // NOTE(russell_h): In earlier versions we mistakenly sent the IdentityProviderIssuer // in the AuthnRequest. For backwards compatibility we will fall back to that // behavior when ServiceProviderIssuer isn't set. // TODO: Throw error in case Issuer is empty. if sp.ServiceProviderIssuer != "" { logoutRequest.CreateElement("saml:Issuer").SetText(sp.ServiceProviderIssuer) } else { logoutRequest.CreateElement("saml:Issuer").SetText(sp.IdentityProviderIssuer) } nameId := logoutRequest.CreateElement("saml:NameID") nameId.SetText(nameID) nameId.CreateAttr("Format", sp.NameIdFormat) //Section 3.7.1 - http://docs.oasis-open.org/security/saml/v2.0/saml-core-2.0-os.pdf says //SessionIndex is optional. If the IDP supports SLO then it must send SessionIndex as per //Section 4.1.4.2 of https://docs.oasis-open.org/security/saml/v2.0/saml-profiles-2.0-os.pdf. //As per section 4.4.3.1 of //docs.oasis-open.org/security/saml/v2.0/saml-profiles-2.0-os.pdf, //a LogoutRequest issued by Session Participant to Identity Provider, must contain //at least one SessionIndex element needs to be included. nameId = logoutRequest.CreateElement("samlp:SessionIndex") nameId.SetText(sessionIndex) doc := etree.NewDocument() if includeSig { signed, err := sp.SignLogoutRequest(logoutRequest) if err != nil { return nil, err } doc.SetRoot(signed) } else { doc.SetRoot(logoutRequest) } return doc, nil } func (sp *SAMLServiceProvider) SignLogoutRequest(el *etree.Element) (*etree.Element, error) { ctx := sp.SigningContext() sig, err := ctx.ConstructSignature(el, true) if err != nil { return nil, err } ret := el.Copy() var children []etree.Token children = append(children, ret.Child[0]) // issuer is always first children = append(children, sig) // next is the signature children = append(children, ret.Child[1:]...) // then all other children ret.Child = children return ret, nil } func (sp *SAMLServiceProvider) BuildLogoutRequestDocumentNoSig(nameID string, sessionIndex string) (*etree.Document, error) { return sp.buildLogoutRequest(false, nameID, sessionIndex) } func (sp *SAMLServiceProvider) BuildLogoutRequestDocument(nameID string, sessionIndex string) (*etree.Document, error) { return sp.buildLogoutRequest(true, nameID, sessionIndex) } //BuildLogoutBodyPostFromDocument builds the POST body to be sent to IDP. //It takes the LogoutRequest xml as input. func (sp *SAMLServiceProvider) BuildLogoutBodyPostFromDocument(relayState string, doc *etree.Document) ([]byte, error) { return sp.buildLogoutBodyPostFromDocument(relayState, doc) } func (sp *SAMLServiceProvider) buildLogoutBodyPostFromDocument(relayState string, doc *etree.Document) ([]byte, error) { reqBuf, err := doc.WriteToBytes() if err != nil { return nil, err } encodedReqBuf := base64.StdEncoding.EncodeToString(reqBuf) var tmpl *template.Template var rv bytes.Buffer if relayState != "" { tmpl = template.Must(template.New("saml-post-form").Parse(`` + `
` + `` + `` + `` + `
` + ``)) data := struct { URL string SAMLRequest string RelayState string }{ URL: sp.IdentityProviderSLOURL, SAMLRequest: encodedReqBuf, RelayState: relayState, } if err = tmpl.Execute(&rv, data); err != nil { return nil, err } } else { tmpl = template.Must(template.New("saml-post-form").Parse(`` + `
` + `` + `` + `
` + ``)) data := struct { URL string SAMLRequest string }{ URL: sp.IdentityProviderSLOURL, SAMLRequest: encodedReqBuf, } if err = tmpl.Execute(&rv, data); err != nil { return nil, err } } return rv.Bytes(), nil } func (sp *SAMLServiceProvider) BuildLogoutURLRedirect(relayState string, doc *etree.Document) (string, error) { return sp.buildLogoutURLFromDocument(relayState, BindingHttpRedirect, doc) } func (sp *SAMLServiceProvider) buildLogoutURLFromDocument(relayState, binding string, doc *etree.Document) (string, error) { parsedUrl, err := url.Parse(sp.IdentityProviderSLOURL) if err != nil { return "", err } logoutRequest, err := doc.WriteToString() if err != nil { return "", err } buf := &bytes.Buffer{} fw, err := flate.NewWriter(buf, flate.DefaultCompression) if err != nil { return "", fmt.Errorf("flate NewWriter error: %v", err) } _, err = fw.Write([]byte(logoutRequest)) if err != nil { return "", fmt.Errorf("flate.Writer Write error: %v", err) } err = fw.Close() if err != nil { return "", fmt.Errorf("flate.Writer Close error: %v", err) } qs := parsedUrl.Query() qs.Add("SAMLRequest", base64.StdEncoding.EncodeToString(buf.Bytes())) if relayState != "" { qs.Add("RelayState", relayState) } if binding == BindingHttpRedirect { // Sign URL encoded query (see Section 3.4.4.1 DEFLATE Encoding of saml-bindings-2.0-os.pdf) ctx := sp.SigningContext() qs.Add("SigAlg", ctx.GetSignatureMethodIdentifier()) var rawSignature []byte //qs.Encode() sorts the keys (See https://golang.org/pkg/net/url/#Values.Encode). //If RelayState parameter is present then RelayState parameter //will be put first by Encode(). Hence encode them separately and concatenate. //Signature string has to have parameters in the order - SAMLRequest=value&RelayState=value&SigAlg=value. //(See Section 3.4.4.1 saml-bindings-2.0-os.pdf). var orderedParams = []string{"SAMLRequest", "RelayState", "SigAlg"} var paramValueMap = make(map[string]string) paramValueMap["SAMLRequest"] = base64.StdEncoding.EncodeToString(buf.Bytes()) if relayState != "" { paramValueMap["RelayState"] = relayState } paramValueMap["SigAlg"] = ctx.GetSignatureMethodIdentifier() ss := "" for _, k := range orderedParams { v, ok := paramValueMap[k] if ok { //Add the value after URL encoding. u := url.Values{} u.Add(k, v) e := u.Encode() if ss != "" { ss += "&" + e } else { ss = e } } } //Now generate the signature on the string of ordered parameters. if rawSignature, err = ctx.SignString(ss); err != nil { return "", fmt.Errorf("unable to sign query string of redirect URL: %v", err) } // Now add base64 encoded Signature qs.Add("Signature", base64.StdEncoding.EncodeToString(rawSignature)) } //Here the parameters may appear in any order. parsedUrl.RawQuery = qs.Encode() return parsedUrl.String(), nil } // signatureInputString constructs the string to be fed into the signature algorithm, as described // in section 3.4.4.1 of // https://www.oasis-open.org/committees/download.php/56779/sstc-saml-bindings-errata-2.0-wd-06.pdf func signatureInputString(samlRequest, relayState, sigAlg string) string { var params [][2]string if relayState == "" { params = [][2]string{{"SAMLRequest", samlRequest}, {"SigAlg", sigAlg}} } else { params = [][2]string{{"SAMLRequest", samlRequest}, {"RelayState", relayState}, {"SigAlg", sigAlg}} } var buf bytes.Buffer for _, kv := range params { k, v := kv[0], kv[1] if buf.Len() > 0 { buf.WriteByte('&') } buf.WriteString(url.QueryEscape(k) + "=" + url.QueryEscape(v)) } return buf.String() } ================================================ FILE: build_request_test.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package saml2 import ( "bytes" "compress/flate" "encoding/base64" "encoding/xml" "fmt" "net/http" "net/http/httptest" "net/url" "testing" "time" "github.com/beevik/etree" "github.com/stretchr/testify/require" ) func TestRedirect(t *testing.T) { r := &http.Request{URL: &url.URL{Path: "/"}} w := httptest.NewRecorder() spURL := "https://sp.test" sp := SAMLServiceProvider{ AssertionConsumerServiceURL: spURL, AudienceURI: spURL, IdentityProviderIssuer: spURL, IdentityProviderSSOURL: "https://idp.test/saml/sso", SignAuthnRequests: false, } require.NoError(t, sp.AuthRedirect(w, r, "foobar")) require.Len(t, w.HeaderMap, 1, "wrong number of headers was set") require.Equal(t, http.StatusFound, w.Code, "wrong http status was set") u, err := url.Parse(w.HeaderMap.Get("Location")) require.NoError(t, err, "invalid url used for redirect") require.Equal(t, "idp.test", u.Host) require.Equal(t, "https", u.Scheme) require.Equal(t, "foobar", u.Query().Get("RelayState")) bs, err := base64.StdEncoding.DecodeString(u.Query().Get("SAMLRequest")) require.NoError(t, err, "error base64 decoding SAMLRequest query param") fr := flate.NewReader(bytes.NewReader(bs)) req := AuthNRequest{} require.NoError(t, xml.NewDecoder(fr).Decode(&req), "Error reading/decoding from flate-compressed URL") iss, err := url.Parse(req.Issuer) require.NoError(t, err, "error parsing request issuer URL") require.Equal(t, "sp.test", iss.Host) require.WithinDuration(t, time.Now(), req.IssueInstant, time.Second, "IssueInstant was not within the expected time frame") dst, err := url.Parse(req.Destination) require.NoError(t, err, "error parsing request destination") require.Equal(t, "https", dst.Scheme) require.Equal(t, "idp.test", dst.Host) //Require that the destination is the same as the redirected URL, except params require.Equal(t, fmt.Sprintf("%s://%s%s", u.Scheme, u.Host, u.Path), dst.String()) } func TestRequestedAuthnContextOmitted(t *testing.T) { spURL := "https://sp.test" sp := SAMLServiceProvider{ AssertionConsumerServiceURL: spURL, AudienceURI: spURL, IdentityProviderIssuer: spURL, IdentityProviderSSOURL: "https://idp.test/saml/sso", SignAuthnRequests: false, } request, err := sp.BuildAuthRequest() require.NoError(t, err) doc := etree.NewDocument() err = doc.ReadFromString(request) require.NoError(t, err) el := doc.FindElement("./AuthnRequest/RequestedAuthnContext") require.Nil(t, el) } func TestRequestedAuthnContextIncluded(t *testing.T) { spURL := "https://sp.test" sp := SAMLServiceProvider{ AssertionConsumerServiceURL: spURL, AudienceURI: spURL, IdentityProviderIssuer: spURL, IdentityProviderSSOURL: "https://idp.test/saml/sso", RequestedAuthnContext: &RequestedAuthnContext{ Comparison: AuthnPolicyMatchExact, Contexts: []string{ AuthnContextPasswordProtectedTransport, }, }, SignAuthnRequests: false, } request, err := sp.BuildAuthRequest() require.NoError(t, err) doc := etree.NewDocument() err = doc.ReadFromString(request) require.NoError(t, err) el := doc.FindElement("./AuthnRequest/RequestedAuthnContext") require.Equal(t, el.SelectAttrValue("Comparison", ""), "exact") require.Len(t, el.ChildElements(), 1) el = el.ChildElements()[0] require.Equal(t, el.Tag, "AuthnContextClassRef") require.Equal(t, el.Text(), AuthnContextPasswordProtectedTransport) } func TestForceAuthnOmitted(t *testing.T) { spURL := "https://sp.test" sp := SAMLServiceProvider{ AssertionConsumerServiceURL: spURL, AudienceURI: spURL, IdentityProviderIssuer: spURL, IdentityProviderSSOURL: "https://idp.test/saml/sso", } request, err := sp.BuildAuthRequest() require.NoError(t, err) doc := etree.NewDocument() err = doc.ReadFromString(request) require.NoError(t, err) attr := doc.Root().SelectAttr("ForceAuthn") require.Nil(t, attr) } func TestForceAuthnIncluded(t *testing.T) { spURL := "https://sp.test" sp := SAMLServiceProvider{ AssertionConsumerServiceURL: spURL, AudienceURI: spURL, IdentityProviderIssuer: spURL, IdentityProviderSSOURL: "https://idp.test/saml/sso", ForceAuthn: true, } request, err := sp.BuildAuthRequest() require.NoError(t, err) doc := etree.NewDocument() err = doc.ReadFromString(request) require.NoError(t, err) attr := doc.Root().SelectAttr("ForceAuthn") require.NotNil(t, attr) require.Equal(t, "true", attr.Value) } func TestIsPassiveOmitted(t *testing.T) { spURL := "https://sp.test" sp := SAMLServiceProvider{ AssertionConsumerServiceURL: spURL, AudienceURI: spURL, IdentityProviderIssuer: spURL, IdentityProviderSSOURL: "https://idp.test/saml/sso", } request, err := sp.BuildAuthRequest() require.NoError(t, err) doc := etree.NewDocument() err = doc.ReadFromString(request) require.NoError(t, err) attr := doc.Root().SelectAttr("IsPassive") require.Nil(t, attr) } func TestIsPassiveIncluded(t *testing.T) { spURL := "https://sp.test" sp := SAMLServiceProvider{ AssertionConsumerServiceURL: spURL, AudienceURI: spURL, IdentityProviderIssuer: spURL, IdentityProviderSSOURL: "https://idp.test/saml/sso", IsPassive: true, } request, err := sp.BuildAuthRequest() require.NoError(t, err) doc := etree.NewDocument() err = doc.ReadFromString(request) require.NoError(t, err) attr := doc.Root().SelectAttr("IsPassive") require.NotNil(t, attr) require.Equal(t, "true", attr.Value) } ================================================ FILE: decode_logout_request.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package saml2 import ( "encoding/base64" "fmt" dsig "github.com/russellhaering/goxmldsig" ) func (sp *SAMLServiceProvider) validateLogoutRequestAttributes(request *LogoutRequest) error { if request.Destination != "" && request.Destination != sp.ServiceProviderSLOURL { return ErrInvalidValue{ Key: DestinationAttr, Expected: sp.ServiceProviderSLOURL, Actual: request.Destination, } } if request.Version != "2.0" { return ErrInvalidValue{ Reason: ReasonUnsupported, Key: "SAML version", Expected: "2.0", Actual: request.Version, } } return nil } func (sp *SAMLServiceProvider) ValidateEncodedLogoutRequestPOST(encodedRequest string) (*LogoutRequest, error) { raw, err := base64.StdEncoding.DecodeString(encodedRequest) if err != nil { return nil, err } // Parse the raw request - parseResponse is generic _, el, err := parseResponse(raw, sp.MaximumDecompressedBodySize) if err != nil { return nil, err } var requestSignatureValidated bool if !sp.SkipSignatureValidation { el, err = sp.validateElementSignature(el) if err == dsig.ErrMissingSignature { return nil, fmt.Errorf("logout request is not signed") } else if err != nil { return nil, err } else if el == nil { return nil, fmt.Errorf("missing transformed logout request") } else { requestSignatureValidated = true } } decodedRequest := &LogoutRequest{} err = xmlUnmarshalElement(el, decodedRequest) if err != nil { return nil, fmt.Errorf("unable to unmarshal logout request: %v", err) } decodedRequest.SignatureValidated = requestSignatureValidated err = sp.ValidateDecodedLogoutRequest(decodedRequest) if err != nil { return nil, err } return decodedRequest, nil } ================================================ FILE: decode_response.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package saml2 import ( "bytes" "compress/flate" "crypto/tls" "crypto/x509" "encoding/base64" "fmt" "io" "encoding/xml" "github.com/beevik/etree" rtvalidator "github.com/mattermost/xml-roundtrip-validator" "github.com/russellhaering/gosaml2/types" dsig "github.com/russellhaering/goxmldsig" "github.com/russellhaering/goxmldsig/etreeutils" ) const ( defaultMaxDecompressedResponseSize = 5 * 1024 * 1024 ) func (sp *SAMLServiceProvider) validationContext() *dsig.ValidationContext { ctx := dsig.NewDefaultValidationContext(sp.IDPCertificateStore) ctx.Clock = sp.Clock return ctx } // validateResponseAttributes validates a SAML Response's tag and attributes. It does // not inspect child elements of the Response at all. func (sp *SAMLServiceProvider) validateResponseAttributes(response *types.Response) error { if response.Destination != "" && response.Destination != sp.AssertionConsumerServiceURL { return ErrInvalidValue{ Key: DestinationAttr, Expected: sp.AssertionConsumerServiceURL, Actual: response.Destination, } } if response.Version != "2.0" { return ErrInvalidValue{ Reason: ReasonUnsupported, Key: "SAML version", Expected: "2.0", Actual: response.Version, } } return nil } // validateLogoutResponseAttributes validates a SAML Response's tag and attributes. It does // not inspect child elements of the Response at all. func (sp *SAMLServiceProvider) validateLogoutResponseAttributes(response *types.LogoutResponse) error { if response.Destination != "" && response.Destination != sp.ServiceProviderSLOURL { return ErrInvalidValue{ Key: DestinationAttr, Expected: sp.ServiceProviderSLOURL, Actual: response.Destination, } } if response.Version != "2.0" { return ErrInvalidValue{ Reason: ReasonUnsupported, Key: "SAML version", Expected: "2.0", Actual: response.Version, } } return nil } func xmlUnmarshalElement(el *etree.Element, obj interface{}) error { doc := etree.NewDocument() doc.SetRoot(el) data, err := doc.WriteToBytes() if err != nil { return err } err = xml.Unmarshal(data, obj) if err != nil { return err } return nil } func (sp *SAMLServiceProvider) getDecryptCert() (*tls.Certificate, error) { if sp.SPKeyStore == nil { return nil, fmt.Errorf("no decryption certs available") } //This is the tls.Certificate we'll use to decrypt any encrypted assertions var decryptCert tls.Certificate switch crt := sp.SPKeyStore.(type) { case dsig.TLSCertKeyStore: // Get the tls.Certificate directly if possible decryptCert = tls.Certificate(crt) default: //Otherwise, construct one from the results of GetKeyPair pk, cert, err := sp.SPKeyStore.GetKeyPair() if err != nil { return nil, fmt.Errorf("error getting keypair: %v", err) } decryptCert = tls.Certificate{ Certificate: [][]byte{cert}, PrivateKey: pk, } } if sp.ValidateEncryptionCert { // Check Validity period of certificate if len(decryptCert.Certificate) < 1 || len(decryptCert.Certificate[0]) < 1 { return nil, fmt.Errorf("empty decryption cert") } else if cert, err := x509.ParseCertificate(decryptCert.Certificate[0]); err != nil { return nil, fmt.Errorf("invalid x509 decryption cert: %v", err) } else { now := sp.Clock.Now() if now.Before(cert.NotBefore) || now.After(cert.NotAfter) { return nil, fmt.Errorf("decryption cert is not valid at this time") } } } return &decryptCert, nil } func (sp *SAMLServiceProvider) decryptAssertions(el *etree.Element) error { var decryptCert *tls.Certificate decryptAssertion := func(ctx etreeutils.NSContext, encryptedElement *etree.Element) error { if encryptedElement.Parent() != el { return fmt.Errorf("found encrypted assertion with unexpected parent element: %s", encryptedElement.Parent().Tag) } detached, err := etreeutils.NSDetatch(ctx, encryptedElement) // make a detached copy if err != nil { return fmt.Errorf("unable to detach encrypted assertion: %v", err) } encryptedAssertion := &types.EncryptedAssertion{} err = xmlUnmarshalElement(detached, encryptedAssertion) if err != nil { return fmt.Errorf("unable to unmarshal encrypted assertion: %v", err) } if decryptCert == nil { decryptCert, err = sp.getDecryptCert() if err != nil { return fmt.Errorf("unable to get decryption certificate: %v", err) } } raw, derr := encryptedAssertion.DecryptBytes(decryptCert) if derr != nil { return fmt.Errorf("unable to decrypt encrypted assertion: %v", derr) } doc, _, err := parseResponse(raw, sp.MaximumDecompressedBodySize) if err != nil { return fmt.Errorf("unable to create element from decrypted assertion bytes: %v", err) } // Replace the original encrypted assertion with the decrypted one. if el.RemoveChild(encryptedElement) == nil { return fmt.Errorf("unable to remove encrypted assertion element") } el.AddChild(doc.Root()) return nil } if err := etreeutils.NSFindIterate(el, SAMLAssertionNamespace, EncryptedAssertionTag, decryptAssertion); err != nil { return err } else { return nil } } func (sp *SAMLServiceProvider) validateElementSignature(el *etree.Element) (*etree.Element, error) { return sp.validationContext().Validate(el) } // deprecated func (sp *SAMLServiceProvider) validateAssertionSignatures(el *etree.Element) error { signedAssertions := 0 unsignedAssertions := 0 validateAssertion := func(ctx etreeutils.NSContext, unverifiedAssertion *etree.Element) error { parent := unverifiedAssertion.Parent() if parent == nil { return fmt.Errorf("parent is nil") } if parent != el { return fmt.Errorf("found assertion with unexpected parent element: %s", unverifiedAssertion.Parent().Tag) } detached, err := etreeutils.NSDetatch(ctx, unverifiedAssertion) // make a detached copy if err != nil { return fmt.Errorf("unable to detach unverified assertion: %v", err) } assertion, err := sp.validationContext().Validate(detached) if err == dsig.ErrMissingSignature { unsignedAssertions++ return nil } else if err != nil { return err } // Replace the original unverified Assertion with the verified one. Note that // if the Response is not signed, only signed Assertions (and not the parent Response) can be trusted. if el.RemoveChild(unverifiedAssertion) == nil { return fmt.Errorf("unable to remove unverified assertion element") } el.AddChild(assertion) signedAssertions++ return nil } if err := etreeutils.NSFindIterate(el, SAMLAssertionNamespace, AssertionTag, validateAssertion); err != nil { return err } else if signedAssertions > 0 && unsignedAssertions > 0 { return fmt.Errorf("invalid to have both signed and unsigned assertions") } else if signedAssertions < 1 { return dsig.ErrMissingSignature } else { return nil } } // verifyAssertionSignaturesIfPresent iterates through assertions within a // signed Response and verifies any that carry their own signatures. Assertions // without signatures are left untouched (the Response envelope signature // covers them). This prevents XML wrapping attacks where assertion content is // tampered with inside a signed envelope. func (sp *SAMLServiceProvider) verifyAssertionSignaturesIfPresent(responseEl *etree.Element) error { verifyAssertion := func(ctx etreeutils.NSContext, assertionEl *etree.Element) error { if assertionEl.Parent() != responseEl { return nil } detached, err := etreeutils.NSDetatch(ctx, assertionEl) if err != nil { return fmt.Errorf("unable to detach assertion for signature verification: %v", err) } verified, err := sp.validationContext().Validate(detached) if err == dsig.ErrMissingSignature { // No signature on this assertion — that's fine, the Response // envelope signature covers it. return nil } else if err != nil { return fmt.Errorf("assertion signature verification failed: %v", err) } // Replace the unverified assertion with the signature-verified version. if responseEl.RemoveChild(assertionEl) == nil { return fmt.Errorf("unable to remove unverified assertion element") } responseEl.AddChild(verified) return nil } return etreeutils.NSFindIterate(responseEl, SAMLAssertionNamespace, AssertionTag, verifyAssertion) } // ValidateEncodedResponse both decodes and validates, based on SP // configuration, an encoded, signed response. It will also appropriately // decrypt a response if the assertion was encrypted func (sp *SAMLServiceProvider) ValidateEncodedResponse(encodedResponse string) (*types.Response, error) { raw, err := base64.StdEncoding.DecodeString(encodedResponse) if err != nil { return nil, err } // Parse the raw response doc, unverifiedResponse, err := parseResponse(raw, sp.MaximumDecompressedBodySize) if err != nil { return nil, err } var responseSignatureValidated bool // storing our final response to return back decodedResponse := &types.Response{} // user has decided to skip signature verification // just unmarshal the untrusted el if sp.SkipSignatureValidation { err = xmlUnmarshalElement(unverifiedResponse, decodedResponse) if err != nil { return nil, fmt.Errorf("unable to unmarshal response: %v", err) } decodedResponse.SignatureValidated = false err := sp.Validate(decodedResponse) if err != nil { return nil, err } return decodedResponse, nil } // first get SignedResponse, if any signedResponseEl, err := sp.validateElementSignature(unverifiedResponse) // continue for unsigned Response, maybe individual Assertions are still signed if err == dsig.ErrMissingSignature { // Unfortunately we just blew away our Response unverifiedResponse = doc.Root() } else if err != nil { return nil, err } else if signedResponseEl == nil { return nil, fmt.Errorf("missing transformed response") } else { // good case, no errors when verifying signature // 1. Response is signed // optionally decrypt each assertion err = sp.decryptAssertions(signedResponseEl) if err != nil { return nil, err } // Even though the Response envelope is signed, verify assertion // signatures when present. This prevents XML wrapping attacks // where an attacker tampers with assertion content within a // signed envelope. err = sp.verifyAssertionSignaturesIfPresent(signedResponseEl) if err != nil { return nil, err } responseSignatureValidated = true err = xmlUnmarshalElement(signedResponseEl, decodedResponse) if err != nil { return nil, fmt.Errorf("unable to unmarshal response: %v", err) } decodedResponse.SignatureValidated = responseSignatureValidated err := sp.Validate(decodedResponse) if err != nil { return nil, err } return decodedResponse, nil } // now we have a tricky case, // unsigned response but have some signed Assertions // unmarshal into decodedResponse, err = xmlUnmarshalElement(unverifiedResponse, decodedResponse) if err != nil { return nil, err } // keep in mind anything inside the Response is technically untrusted // however, we have to keep the relevant details such as StatusCode // We reset the underlying assertions & encrypted assertions to [] decodedResponse.SignatureValidated = false decodedResponse.Assertions = []types.Assertion{} decodedResponse.EncryptedAssertions = []types.EncryptedAssertion{} // first decrypt all assertions err = sp.decryptAssertions(unverifiedResponse) if err != nil { return nil, err } // iterate through each Assertion inside our etree unverifiedResponse addSignedAssertion := func(ctx etreeutils.NSContext, unverifiedAssertion *etree.Element) error { parent := unverifiedAssertion.Parent() if parent == nil { return fmt.Errorf("parent is nil") } if parent != unverifiedResponse { return fmt.Errorf("found assertion with unexpected parent element: %s", unverifiedAssertion.Parent().Tag) } detached, err := etreeutils.NSDetatch(ctx, unverifiedAssertion) // make a detached copy if err != nil { return fmt.Errorf("unable to detach unverified assertion: %v", err) } // signedAssertion after checking for errors signedAssertion, err := sp.validationContext().Validate(detached) if err != nil { return err // return any errors including unsignedAssertions } decodedAssertion := &types.Assertion{} err = xmlUnmarshalElement(signedAssertion, decodedAssertion) if err != nil { return fmt.Errorf("unable to unmarshal assertion: %v", err) } decodedAssertion.SignatureValidated = true // now add it to decodedResponse decodedResponse.Assertions = append(decodedResponse.Assertions, *decodedAssertion) return nil } // iterate through each Assertion through our unverified Response // our decodedResponse contains a empty list of Assertions // throughout iteration, we will add signed assertions to the decodedResponse if err := etreeutils.NSFindIterate(unverifiedResponse, SAMLAssertionNamespace, AssertionTag, addSignedAssertion); err != nil { return nil, err } err = sp.Validate(decodedResponse) if err != nil { return nil, err } return decodedResponse, nil } // DecodeUnverifiedBaseResponse decodes several attributes from a SAML response for the purpose // of determining how to validate the response. This is useful for Service Providers which // expose a single Assertion Consumer Service URL but consume Responses from many IdPs. func DecodeUnverifiedBaseResponse(encodedResponse string) (*types.UnverifiedBaseResponse, error) { raw, err := base64.StdEncoding.DecodeString(encodedResponse) if err != nil { return nil, err } var response *types.UnverifiedBaseResponse err = maybeDeflate(raw, defaultMaxDecompressedResponseSize, func(maybeXML []byte) error { response = &types.UnverifiedBaseResponse{} return xml.Unmarshal(maybeXML, response) }) if err != nil { return nil, err } return response, nil } // maybeDeflate invokes the passed decoder over the passed data. If an error is // returned, it then attempts to deflate the passed data before re-invoking // the decoder over the deflated data. func maybeDeflate(data []byte, maxSize int64, decoder func([]byte) error) error { err := decoder(data) if err == nil { return nil } // Default to 5MB max size if maxSize == 0 { maxSize = defaultMaxDecompressedResponseSize } lr := io.LimitReader(flate.NewReader(bytes.NewReader(data)), maxSize+1) deflated, err := io.ReadAll(lr) if err != nil { return err } if int64(len(deflated)) > maxSize { return fmt.Errorf("deflated response exceeds maximum size of %d bytes", maxSize) } return decoder(deflated) } // parseResponse is a helper function that was refactored out so that the XML parsing behavior can be isolated and unit tested func parseResponse(xml []byte, maxSize int64) (*etree.Document, *etree.Element, error) { var doc *etree.Document var rawXML []byte err := maybeDeflate(xml, maxSize, func(xml []byte) error { doc = etree.NewDocument() rawXML = xml return doc.ReadFromBytes(xml) }) if err != nil { return nil, nil, err } el := doc.Root() if el == nil { return nil, nil, fmt.Errorf("unable to parse response") } // Examine the response for attempts to exploit weaknesses in Go's encoding/xml err = rtvalidator.Validate(bytes.NewReader(rawXML)) if err != nil { return nil, nil, err } return doc, el, nil } // DecodeUnverifiedLogoutResponse decodes several attributes from a SAML Logout response, without doing any verifications. func DecodeUnverifiedLogoutResponse(encodedResponse string) (*types.LogoutResponse, error) { raw, err := base64.StdEncoding.DecodeString(encodedResponse) if err != nil { return nil, err } var response *types.LogoutResponse err = maybeDeflate(raw, defaultMaxDecompressedResponseSize, func(maybeXML []byte) error { response = &types.LogoutResponse{} return xml.Unmarshal(maybeXML, response) }) if err != nil { return nil, err } return response, nil } func (sp *SAMLServiceProvider) ValidateEncodedLogoutResponsePOST(encodedResponse string) (*types.LogoutResponse, error) { raw, err := base64.StdEncoding.DecodeString(encodedResponse) if err != nil { return nil, err } // Parse the raw response doc, el, err := parseResponse(raw, sp.MaximumDecompressedBodySize) if err != nil { return nil, err } var responseSignatureValidated bool if !sp.SkipSignatureValidation { el, err = sp.validateElementSignature(el) if err == dsig.ErrMissingSignature { // Unfortunately we just blew away our Response el = doc.Root() } else if err != nil { return nil, err } else if el == nil { return nil, fmt.Errorf("missing transformed logout response") } else { responseSignatureValidated = true } } decodedResponse := &types.LogoutResponse{} err = xmlUnmarshalElement(el, decodedResponse) if err != nil { return nil, fmt.Errorf("unable to unmarshal logout response: %v", err) } decodedResponse.SignatureValidated = responseSignatureValidated err = sp.ValidateDecodedLogoutResponse(decodedResponse) if err != nil { return nil, err } return decodedResponse, nil } ================================================ FILE: decode_response_test.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package saml2 import ( "bytes" "crypto/tls" "crypto/x509" "encoding/base64" "encoding/pem" "io/ioutil" "testing" "time" "github.com/jonboulle/clockwork" rtvalidator "github.com/mattermost/xml-roundtrip-validator" dsig "github.com/russellhaering/goxmldsig" "github.com/stretchr/testify/require" ) const ( idpCert = ` -----BEGIN CERTIFICATE----- MIIDODCCAiCgAwIBAgIUQH54kyyeacU69J2iwz9bzeLmMaswDQYJKoZIhvcNAQEL BQAwHTEbMBkGA1UEAwwSY29sbGVnZS5jY2N0Y2EuZWR1MB4XDTE1MDYwNDIyMTAz MVoXDTM1MDYwNDIyMTAzMVowHTEbMBkGA1UEAwwSY29sbGVnZS5jY2N0Y2EuZWR1 MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAlJhN20ng2VN/cTrWtqUI NaUsrHCkYXbm2y1PTN4b6fJI5hbvcv+LWCuLkLi3+iPGlBpcHHfrdJcyhmBHRHQ9 Sos3RIH5Lsn1IgjWe3hxQQmVeEi5xVxnw2YZGHaeX4YnI1TEBJwhtJmyitk74LHy bPGEqOJdApUnLz54L7I+252G/cOfEqUHMbxxtmHSc/9chF8bBxQ8OzIbJsByHnqi awQHwtsttre7n328gVqmf1VHE27cfAYiSjuK5pCsx/1kuJMBN+kg/3Gg9oi6aR50 WX1VUF3IBcnTDeiAXRz3PgsT8FlVZou6Ik9NT/Y5IHOZVGk64SRDaG8FuGxLexXr swIDAQABo3AwbjAdBgNVHQ4EFgQUjQwaAoY3u/iToIE3ADeNEW+Uu34wTQYDVR0R BEYwRIISY29sbGVnZS5jY2N0Y2EuZWR1hi5odHRwczovL2NvbGxlZ2UuY2NjdGNh LmVkdTo4NDQzL2lkcC9zaGliYm9sZXRoMA0GCSqGSIb3DQEBCwUAA4IBAQB26rdx phN1YKad3yDhLg6Y1ZwbmAjc+l4QB1KSL+cLqhDn5iMy4VdWh8HpSKRqCwofLtlw 3qOwospj+mJaguXRMpjYODRQaKRkTrCGxJhuNrQxDXL/b6FOEIJnUYenbPevuNgR Jc1VnREhWUUXT44KN5YUz9FEiG0BsBK8ecCPKBzTQ/hwaczhpqw6uqVMqxJaTGcn lCUHJAhVHiA8lWJ7vaNPsJ86xBFs/F76EwyFXIKQaruvcvChU7GNNSYdNJBa6HO9 9QWdGbr5aNQ4diunnBQdrdjgbQIwyhKTfbFWa2l5vbqEKDc0dwuPa6c25l8ruqxq CQ1CF8ZDDJ0XV6Ab -----END CERTIFICATE----- ` oktaCert = ` -----BEGIN CERTIFICATE----- MIIDPDCCAiQCCQDydJgOlszqbzANBgkqhkiG9w0BAQUFADBgMQswCQYDVQQGEwJVUzETMB EGA1UECBMKQ2FsaWZvcm5pYTEWMBQGA1UEBxMNU2FuIEZyYW5jaXNjbzEQMA4GA1UEChMH SmFua3lDbzESMBAGA1UEAxMJbG9jYWxob3N0MB4XDTE0MDMxMjE5NDYzM1oXDTI3MTExOT E5NDYzM1owYDELMAkGA1UEBhMCVVMxEzARBgNVBAgTCkNhbGlmb3JuaWExFjAUBgNVBAcT DVNhbiBGcmFuY2lzY28xEDAOBgNVBAoTB0phbmt5Q28xEjAQBgNVBAMTCWxvY2FsaG9zdD CCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAMGvJpRTTasRUSPqcbqCG+ZnTAur nu0vVpIG9lzExnh11o/BGmzu7lB+yLHcEdwrKBBmpepDBPCYxpVajvuEhZdKFx/Fdy6j5m H3rrW0Bh/zd36CoUNjbbhHyTjeM7FN2yF3u9lcyubuvOzr3B3gX66IwJlU46+wzcQVhSOl Mk2tXR+fIKQExFrOuK9tbX3JIBUqItpI+HnAow509CnM134svw8PTFLkR6/CcMqnDfDK1m 993PyoC1Y+N4X9XkhSmEQoAlAHPI5LHrvuujM13nvtoVYvKYoj7ScgumkpWNEvX652LfXO nKYlkB8ZybuxmFfIkzedQrbJsyOhfL03cMECAwEAATANBgkqhkiG9w0BAQUFAAOCAQEAeH wzqwnzGEkxjzSD47imXaTqtYyETZow7XwBc0ZaFS50qRFJUgKTAmKS1xQBP/qHpStsROT3 5DUxJAE6NY1Kbq3ZbCuhGoSlY0L7VzVT5tpu4EY8+Dq/u2EjRmmhoL7UkskvIZ2n1DdERt d+YUMTeqYl9co43csZwDno/IKomeN5qaPc39IZjikJ+nUC6kPFKeu/3j9rgHNlRtocI6S1 FdtFz9OZMQlpr0JbUt2T3xS/YoQJn6coDmJL5GTiiKM6cOe+Ur1VwzS1JEDbSS2TWWhzq8 ojLdrotYLGd9JOsoQhElmz+tMfCFQUFLExinPAyy7YHlSiVX13QH2XTu/iQQ== -----END CERTIFICATE----- ` oktaCert2 = ` -----BEGIN CERTIFICATE----- MIIDpDCCAoygAwIBAgIGAWxzAwX1MA0GCSqGSIb3DQEBCwUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi05MDUyNTExHDAaBgkqhkiG9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTkwODA4MjA1MzMzWhcNMjkwODA4MjA1NDMzWjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtOTA1MjUxMRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA m+ZZF6aEG6ehLLIV6RPA+i1z6ss3HBG2bZD3efwKCDDXYUkp59AE7JsjVHMtpJPHhzHuScuHDMlu HmkBQTW7j9XpnaRn8SfZXkwlCUHTo+HAC9lwbQxO4d4wnwgnm6FAjm1I/gbfFAobd8BR9pDxHuXE MQ0DtQu/W3WbDUrz/bhSxPJAoVy2koQn9G0y3unm7eRwYWHeuW6GdPWV2szTtDS0c3qtUXVF5Ugg iQYlwQu6xkfy4l8iGJL7ETa2BmJzwCFecMIct87SqNhYQwCBH54MBaHcaSsCKyimNvMY9B7RmC+H 4+awePPA1q3R/UQ3Pfom8mx6yDdKIWqlkG3MsQIDAQABMA0GCSqGSIb3DQEBCwUAA4IBAQAiURCZ P4oJWcf1o5nm4yG15UH01g/S6Y4OUWMi6BFJy9fCrJ0h/2BZKi68SQ0uMAbdK6anxCzq3Rr5MSzW OWPQ1Zljn3LGPsiTFdFca/GVRen5IYQ7Dr2Mvhtm+QVscEY9TDjtETbTAHEVEjwXmB21wtdIhizv sQS7wz0A8LV+Atpbev45RiV6COmB6T6vJuFQ7ZsDZMSHZriTYiETTJvHBGd7PtbCxYNc6LRB2JDb wlekRhVEjR0UhnM+nn2sqqbv7tDEPs63lZSDXCnR1PhscHrEuQ04rHI3OL0gCULVQFvJrj85IAZF 1QQuGUK8ozfOyFpQWAJUW71INnF/SLWv -----END CERTIFICATE----- ` badInput = `http://www.okta.com/exk133onomIuOW98z357dC1cm0pLLjIWZC6G2Pmf0JogmqHztp9W1euXPd/TUHo=YRSCFLIkIgjbbYLyfCIc8jsP2MUJPjn+nYWRdlVIDdXtYXXxklYqdBXQsxDwNcsOAIGS75PeVGryml3oBkUDg/MfK7z/fFPLXX7c7xgh7/DBAFlSXbwlJQxuXQ5eZcGesgG6nYRwU1hpW+yN7C2ODN9KHi5TUdiEhvy8vdlFSfxdy4Mn68nG/UZBqmHHIZdRG2/Hpcs29YyaVVZUCZ0w22b7zsPuOXHuStOSTQ6isxI2R268+ZNKERYaNMCAGX4zNlT3mHBV0NnZkbO3wmlOfKksL+Qx7L64xFc3PaervxWuPqh2FoWpTCqFdliLdvUfFDszKXJKhO0bj1U0aSrdzg==steven.james.johnstone@gmail.com37a8eec1ce19687d132fe29051dca629d164e2c4958ba141d5f4133a33f0688f.jazznetworks.comurn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransportStevenJohnstonesteven.james.johnstone@gmail.com` ) func testEncryptedAssertion(t *testing.T, validateEncryptionCert bool) { var err error cert, err := tls.LoadX509KeyPair("./testdata/test.crt", "./testdata/test.key") require.NoError(t, err, "could not load x509 key pair") block, _ := pem.Decode([]byte(idpCert)) idpCert, err := x509.ParseCertificate(block.Bytes) require.NoError(t, err, "couldn't parse idp cert pem block") sp := SAMLServiceProvider{ AssertionConsumerServiceURL: "https://saml2.test.astuart.co/sso/saml2", SPKeyStore: dsig.TLSCertKeyStore(cert), ValidateEncryptionCert: validateEncryptionCert, IDPCertificateStore: &dsig.MemoryX509CertificateStore{ Roots: []*x509.Certificate{idpCert}, }, Clock: dsig.NewFakeClockAt(time.Date(2016, 04, 28, 22, 00, 00, 00, time.UTC)), } bs, err := ioutil.ReadFile("./testdata/saml.post") require.NoError(t, err, "couldn't read post") _, err = sp.RetrieveAssertionInfo(string(bs)) if validateEncryptionCert { require.Error(t, err) require.Equal(t, "error validating response: unable to get decryption certificate: decryption cert is not valid at this time", err.Error()) } else { require.NoError(t, err, "Assertion info should be retrieved with no error") } } func TestEncryptedAssertion(t *testing.T) { testEncryptedAssertion(t, false) } func TestEncryptedAssertionInvalidCert(t *testing.T) { testEncryptedAssertion(t, true) } func TestCompressedResponse(t *testing.T) { bs, err := ioutil.ReadFile("./testdata/saml_compressed.post") require.NoError(t, err, "couldn't read compressed post") block, _ := pem.Decode([]byte(oktaCert)) idpCert, err := x509.ParseCertificate(block.Bytes) require.NoError(t, err, "couldn't parse okta cert pem block") sp := SAMLServiceProvider{ AssertionConsumerServiceURL: "https://f1f51ddc.ngrok.io/api/sso/saml2/acs/58cafd0573d4f375b8e70e8e", SPKeyStore: dsig.TLSCertKeyStore(cert), IDPCertificateStore: &dsig.MemoryX509CertificateStore{ Roots: []*x509.Certificate{idpCert}, }, Clock: dsig.NewFakeClock(clockwork.NewFakeClockAt(time.Date(2017, 3, 17, 20, 00, 0, 0, time.UTC))), } _, err = sp.RetrieveAssertionInfo(string(bs)) require.NoError(t, err, "Assertion info should be retrieved with no error") } func TestDecodeColonsInLocalNames(t *testing.T) { // Handling of double colons was improved in Go 1.7 such that this test no longer fails. // See: https://go-review.googlesource.com/c/go/+/277892 if rtvalidator.Validate(bytes.NewReader([]byte(``))) == nil { t.Skip() } _, _, err := parseResponse([]byte(``), 0) require.Error(t, err) } func TestDecodeDoubleColonInjectionAttackResponse(t *testing.T) { // Handling of double colons was improved in Go 1.7 such that this test no longer fails. // See: https://go-review.googlesource.com/c/go/+/277892 if rtvalidator.Validate(bytes.NewReader([]byte(``))) == nil { t.Skip() } _, _, err := parseResponse([]byte(doubleColonAssertionInjectionAttackResponse), 0) require.Error(t, err) } func TestMalFormedInput(t *testing.T) { block, _ := pem.Decode([]byte(oktaCert2)) idpCert, err := x509.ParseCertificate(block.Bytes) require.NoError(t, err, "couldn't parse okta cert pem block") certStore := dsig.MemoryX509CertificateStore{ Roots: []*x509.Certificate{idpCert}, } sp := &SAMLServiceProvider{ Clock: dsig.NewFakeClock(clockwork.NewFakeClockAt(time.Date(2019, 8, 12, 12, 00, 52, 718, time.UTC))), AssertionConsumerServiceURL: "https://saml2.test.astuart.co/sso/saml2", SignAuthnRequests: true, IDPCertificateStore: &certStore, ValidateEncryptionCert: true, } base64Input := base64.StdEncoding.EncodeToString([]byte(badInput)) _, err = sp.RetrieveAssertionInfo(base64Input) require.Errorf(t, err, "parent is nil") } func TestCompressionBombInput(t *testing.T) { bs, err := ioutil.ReadFile("./testdata/saml_compressed.post") require.NoError(t, err, "couldn't read compressed post") block, _ := pem.Decode([]byte(oktaCert)) idpCert, err := x509.ParseCertificate(block.Bytes) require.NoError(t, err, "couldn't parse okta cert pem block") sp := SAMLServiceProvider{ AssertionConsumerServiceURL: "https://f1f51ddc.ngrok.io/api/sso/saml2/acs/58cafd0573d4f375b8e70e8e", SPKeyStore: dsig.TLSCertKeyStore(cert), IDPCertificateStore: &dsig.MemoryX509CertificateStore{ Roots: []*x509.Certificate{idpCert}, }, Clock: dsig.NewFakeClock(clockwork.NewFakeClockAt(time.Date(2017, 3, 17, 20, 00, 0, 0, time.UTC))), MaximumDecompressedBodySize: 2048, } _, err = sp.RetrieveAssertionInfo(string(bs)) require.Error(t, err, "error validating response: deflated response exceeds maximum size of 2048 bytes") } ================================================ FILE: go.mod ================================================ module github.com/russellhaering/gosaml2 go 1.25.0 toolchain go1.26.1 require ( github.com/beevik/etree v1.6.0 github.com/jonboulle/clockwork v0.5.0 github.com/mattermost/xml-roundtrip-validator v0.1.0 github.com/russellhaering/goxmldsig v1.6.0 github.com/stretchr/testify v1.11.1 ) require ( github.com/davecgh/go-spew v1.1.1 // indirect github.com/kr/text v0.2.0 // indirect github.com/pmezard/go-difflib v1.0.0 // indirect gopkg.in/yaml.v3 v3.0.1 // indirect ) ================================================ FILE: go.sum ================================================ github.com/beevik/etree v1.6.0 h1:u8Kwy8pp9D9XeITj2Z0XtA5qqZEmtJtuXZRQi+j03eE= github.com/beevik/etree v1.6.0/go.mod h1:bh4zJxiIr62SOf9pRzN7UUYaEDa9HEKafK25+sLc0Gc= github.com/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E= github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c= github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= github.com/jonboulle/clockwork v0.5.0 h1:Hyh9A8u51kptdkR+cqRpT1EebBwTn1oK9YfGYbdFz6I= github.com/jonboulle/clockwork v0.5.0/go.mod h1:3mZlmanh0g2NDKO5TWZVJAfofYk64M7XN3SzBPjZF60= github.com/kr/pretty v0.3.0 h1:WgNl7dwNpEZ6jJ9k1snq4pZsg7DOEN8hP9Xw0Tsjwk0= github.com/kr/pretty v0.3.0/go.mod h1:640gp4NfQd8pI5XOwp5fnNeVWj67G7CFk/SaSQn7NBk= github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY= github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE= github.com/mattermost/xml-roundtrip-validator v0.1.0 h1:RXbVD2UAl7A7nOTR4u7E3ILa4IbtvKBHw64LDsmu9hU= github.com/mattermost/xml-roundtrip-validator v0.1.0/go.mod h1:qccnGMcpgwcNaBnxqpJpWWUiPNr5H3O8eDgGV9gT5To= github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= github.com/rogpeppe/go-internal v1.8.0 h1:FCbCCtXNOY3UtUuHUYaghJg4y7Fd14rXifAYUAtL9R8= github.com/rogpeppe/go-internal v1.8.0/go.mod h1:WmiCO8CzOY8rg0OYDC4/i/2WRWAB6poM+XZ2dLUbcbE= github.com/russellhaering/goxmldsig v1.6.0 h1:8fdWXEPh2k/NZNQBPFNoVfS3JmzS4ZprY/sAOpKQLks= github.com/russellhaering/goxmldsig v1.6.0/go.mod h1:TrnaquDcYxWXfJrOjeMBTX4mLBeYAqaHEyUeWPxZlBM= github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= github.com/stretchr/testify v1.6.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= github.com/stretchr/testify v1.11.1 h1:7s2iGBzp5EwR7/aIZr8ao5+dra3wiQyKjjFuvgVKu7U= github.com/stretchr/testify v1.11.1/go.mod h1:wZwfW3scLgRK+23gO65QZefKpKQRnfz6sD981Nm4B6U= gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c h1:Hei/4ADfdWqJk1ZMxUNpqntNwaWcugrBjAiHlqqRiVk= gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c/go.mod h1:JHkPIbrfpd72SG/EVd6muEfDQjcINNoR0C8j2r3qZ4Q= gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA= gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= ================================================ FILE: internal/fuzz/README.md ================================================ # Internal Fuzzing for gosaml2 This directory contains fuzzing targets for gosaml2 that are used with Go's built-in fuzzing functionality and OSS-Fuzz. ## Running Fuzzers Locally ```bash go test -fuzz=FuzzDecodeResponse ./internal/fuzz/ -fuzztime=30s go test -fuzz=FuzzLogoutResponse ./internal/fuzz/ -fuzztime=30s go test -fuzz=FuzzBuildRequest ./internal/fuzz/ -fuzztime=30s ``` ## OSS-Fuzz Integration These fuzzers use native Go fuzzing (`func Fuzz(f *testing.F)`) and are compiled by OSS-Fuzz using `compile_native_go_fuzzer`. Configuration files for the integration can be found in the `oss-fuzz` directory. ================================================ FILE: internal/fuzz/fuzz_test.go ================================================ // Copyright 2025 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package fuzz import ( "encoding/base64" "encoding/binary" "testing" saml2 "github.com/russellhaering/gosaml2" ) func FuzzDecodeResponse(f *testing.F) { f.Fuzz(func(t *testing.T, data []byte) { encodedResponse := base64.StdEncoding.EncodeToString(data) _, err := saml2.DecodeUnverifiedBaseResponse(encodedResponse) if err != nil { return } sp := &saml2.SAMLServiceProvider{} _, _ = sp.ValidateEncodedResponse(encodedResponse) }) } func FuzzLogoutResponse(f *testing.F) { f.Fuzz(func(t *testing.T, data []byte) { encodedResponse := base64.StdEncoding.EncodeToString(data) _, err := saml2.DecodeUnverifiedLogoutResponse(encodedResponse) if err != nil { return } sp := &saml2.SAMLServiceProvider{} _, _ = sp.ValidateEncodedLogoutResponsePOST(encodedResponse) }) } func FuzzBuildRequest(f *testing.F) { f.Fuzz(func(t *testing.T, data []byte) { if len(data) < 8 { return } idValue := binary.LittleEndian.Uint64(data[:8]) relayState := string(data[8:]) if len(relayState) == 0 { return } sp := &saml2.SAMLServiceProvider{ IdentityProviderSSOURL: "https://idp.example.com/sso", IdentityProviderIssuer: "https://idp.example.com/", AssertionConsumerServiceURL: "https://sp.example.com/acs", AudienceURI: "https://sp.example.com/audience", SignAuthnRequests: idValue%2 == 0, ForceAuthn: idValue%3 == 0, IsPassive: idValue%5 == 0, } _, _ = sp.BuildAuthURL(relayState) _, _ = sp.BuildAuthRequest() }) } ================================================ FILE: logout_request.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package saml2 import ( "encoding/xml" "github.com/russellhaering/gosaml2/types" "time" ) // LogoutRequest is the go struct representation of a logout request type LogoutRequest struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:protocol LogoutRequest"` ID string `xml:"ID,attr"` Version string `xml:"Version,attr"` //ProtocolBinding string `xml:",attr"` IssueInstant time.Time `xml:"IssueInstant,attr"` Destination string `xml:"Destination,attr"` Issuer *types.Issuer `xml:"Issuer"` NameID *types.NameID `xml:"NameID"` SignatureValidated bool `xml:"-"` // not read, not dumped } ================================================ FILE: oss-fuzz/Dockerfile ================================================ # Copyright 2025 Google LLC # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # # ################################################################################ FROM gcr.io/oss-fuzz-base/base-builder-go RUN apt-get update && apt-get install -y make cmake RUN git clone --depth 1 https://github.com/russellhaering/gosaml2 WORKDIR gosaml2 COPY build.sh $SRC/ COPY *.options $SRC/ ================================================ FILE: oss-fuzz/README.md ================================================ # OSS-Fuzz Integration for gosaml2 This directory contains the configuration files necessary for integrating gosaml2 with Google's [OSS-Fuzz](https://github.com/google/oss-fuzz) continuous fuzzing service. ## Files - `build.sh`: Build script that compiles the fuzzing targets and creates the seed corpora - `Dockerfile`: Defines the Docker container used for building the fuzzers - `project.yaml`: Project configuration for OSS-Fuzz - `fuzz_decode_response.options`: Fuzzer-specific options for the SAML response decoder ## Fuzzing Targets The actual fuzzing targets are implemented in the `internal/fuzz` directory: 1. `FuzzDecodeResponse`: Fuzzes SAML response decoding and validation 2. `FuzzLogoutResponse`: Fuzzes SAML logout response decoding 3. `FuzzBuildRequest`: Fuzzes SAML authentication request building 4. `FuzzXMLValidation`: Fuzzes XML validation to catch parsing vulnerabilities ## Testing Locally with Docker To test the OSS-Fuzz integration locally: ```bash # Clone OSS-Fuzz git clone https://github.com/google/oss-fuzz cd oss-fuzz # Build the image python infra/helper.py build_image gosaml2 # Build the fuzzers python infra/helper.py build_fuzzers gosaml2 # Run the fuzzers python infra/helper.py run_fuzzer gosaml2 fuzz_decode_response ``` ## Adding New Fuzzers To add a new fuzzer: 1. Add the fuzzer implementation to `internal/fuzz/` 2. Update `build.sh` to compile the new fuzzer and create its seed corpus 3. Create fuzzer options file if needed (e.g., `my_new_fuzzer.options`) ================================================ FILE: oss-fuzz/build.sh ================================================ #!/bin/bash -eu # Copyright 2025 Google LLC # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # ################################################################################ cd $SRC/gosaml2 # Build fuzzers compile_native_go_fuzzer github.com/russellhaering/gosaml2/internal/fuzz FuzzDecodeResponse fuzz_decode_response compile_native_go_fuzzer github.com/russellhaering/gosaml2/internal/fuzz FuzzLogoutResponse fuzz_logout_response compile_native_go_fuzzer github.com/russellhaering/gosaml2/internal/fuzz FuzzBuildRequest fuzz_build_request # Create seed corpus mkdir -p $OUT/fuzz_decode_response_seed_corpus # Use existing test data as seed corpus find ./testdata -name '*.b64' -o -name '*.xml' | while read f; do cp "$f" $OUT/fuzz_decode_response_seed_corpus/ done zip -j $OUT/fuzz_decode_response_seed_corpus.zip $OUT/fuzz_decode_response_seed_corpus/* rm -rf $OUT/fuzz_decode_response_seed_corpus # Create a minimal seed corpus for the logout response mkdir -p $OUT/fuzz_logout_response_seed_corpus # Find logout response files if they exist, otherwise use a subset of the general ones find ./testdata -name '*logout*' -o -name '*.b64' | head -n 5 | while read f; do cp "$f" $OUT/fuzz_logout_response_seed_corpus/ done zip -j $OUT/fuzz_logout_response_seed_corpus.zip $OUT/fuzz_logout_response_seed_corpus/* rm -rf $OUT/fuzz_logout_response_seed_corpus # Create a minimal seed corpus for build request mkdir -p $OUT/fuzz_build_request_seed_corpus echo "relayState" > $OUT/fuzz_build_request_seed_corpus/relaystate echo "state123456" > $OUT/fuzz_build_request_seed_corpus/state zip -j $OUT/fuzz_build_request_seed_corpus.zip $OUT/fuzz_build_request_seed_corpus/* rm -rf $OUT/fuzz_build_request_seed_corpus ================================================ FILE: oss-fuzz/fuzz_decode_response.options ================================================ [libfuzzer] max_len = 10240 ================================================ FILE: oss-fuzz/project.yaml ================================================ homepage: "https://github.com/russellhaering/gosaml2" primary_contact: "russell.haering@gmail.com" language: go main_repo: "https://github.com/russellhaering/gosaml2" fuzzing_engines: - libfuzzer sanitizers: - address architectures: - x86_64 ================================================ FILE: providertests/exercise.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // +build go1.7 package providertests import ( "testing" saml2 "github.com/russellhaering/gosaml2" "github.com/stretchr/testify/require" ) func ExerciseProviderTestScenarios(t *testing.T, scenarios []ProviderTestScenario) { for _, scenario := range scenarios { t.Run(scenario.ScenarioName, func(t *testing.T) { _, err := saml2.DecodeUnverifiedBaseResponse(scenario.Response) // DecodeUnverifiedBaseResponse is more permissive than RetrieveAssertionInfo. // If an error _is_ returned it should match, but it is OK for no error to be // returned even when one is expected during full validation. if err != nil { scenario.CheckError(t, err) } assertionInfo, err := scenario.ServiceProvider.RetrieveAssertionInfo(scenario.Response) if scenario.CheckError != nil { scenario.CheckError(t, err) } else { require.NoError(t, err) } if err == nil { if scenario.CheckWarningInfo != nil { scenario.CheckWarningInfo(t, assertionInfo.WarningInfo) } else { require.False(t, assertionInfo.WarningInfo.InvalidTime) require.False(t, assertionInfo.WarningInfo.NotInAudience) } } }) } } ================================================ FILE: providertests/exercise_go_1_6.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // +build !go1.7 package providertests import ( "testing" saml2 "github.com/russellhaering/gosaml2" "github.com/stretchr/testify/require" ) func ExerciseProviderTestScenarios(t *testing.T, scenarios []ProviderTestScenario) { for _, scenario := range scenarios { // DecodeUnverifiedBaseResponse is more permissive than RetrieveAssertionInfo. // If an error _is_ returned it should match, but it is OK for no error to be // returned even when one is expected during full validation. _, err := saml2.DecodeUnverifiedBaseResponse(scenario.Response) if err != nil { scenario.CheckError(t, err) } assertionInfo, err := scenario.ServiceProvider.RetrieveAssertionInfo(scenario.Response) if scenario.CheckError != nil { scenario.CheckError(t, err) } else { require.NoError(t, err) } if err == nil { if scenario.CheckWarningInfo != nil { scenario.CheckWarningInfo(t, assertionInfo.WarningInfo) } else { require.False(t, assertionInfo.WarningInfo.InvalidTime) require.False(t, assertionInfo.WarningInfo.NotInAudience) } } } } ================================================ FILE: providertests/oktadev_test.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package providertests import ( "fmt" "testing" "time" "github.com/jonboulle/clockwork" saml2 "github.com/russellhaering/gosaml2" dsig "github.com/russellhaering/goxmldsig" ) var oktaScenarioErrors = map[int]string{ 1: "error validating response: Missing signature referencing the top-level element", 3: "error validating response: Could not verify certificate against trusted certs", 4: "error validating response: Unrecognized Destination value, Expected: http://dba9a5fc.ngrok.io/v1/_saml_callback, Actual: fake.identifier.example.com", 5: "error validating response: Unrecognized Issuer value, Expected: http://example.com/saml/acs/example, Actual: fake.identifier.example.com", 7: "error validating response: missing Issuer element", 8: "error validating response: missing NotOnOrAfter attribute on SubjectConfirmationData element", 9: "missing NotOnOrAfter attribute on Conditions element", 10: "missing NotBefore attribute on Conditions element", 12: "error validating response: Missing signature referencing the top-level element", 13: "error validating response: Signature could not be verified", 14: "error validating response: Unrecognized StatusCode value, Expected: urn:oasis:names:tc:SAML:2.0:status:Success, Actual: Failure", 15: "error validating response: Unrecognized StatusCode value, Expected: urn:oasis:names:tc:SAML:2.0:status:Success, Actual: urn:oasis:names:tc:SAML:2.0:status:Requester", } var oktaScenarioWarnings = map[int]scenarioWarnings{ 6: scenarioWarnings{ NotInAudience: true, }, 11: scenarioWarnings{ InvalidTime: true, }, } func TestOktaDevCasesLocally(t *testing.T) { sp := &saml2.SAMLServiceProvider{ IdentityProviderSSOURL: "http://example.com/saml/acs/example", IdentityProviderIssuer: "http://example.com/saml/acs/example", AssertionConsumerServiceURL: "http://dba9a5fc.ngrok.io/v1/_saml_callback", AudienceURI: "http://example.com/saml/acs/example", IDPCertificateStore: LoadCertificateStore("./testdata/saml.oktadev.com/oktadev.pem"), Clock: dsig.NewFakeClock(clockwork.NewFakeClockAt(time.Date(2017, 4, 4, 17, 54, 0, 0, time.UTC))), } scenarios := []ProviderTestScenario{} for i := 0; i < 17; i++ { response := LoadRawResponse(fmt.Sprintf("./testdata/saml.oktadev.com/response_%d", i)) scenarios = append(scenarios, ProviderTestScenario{ ScenarioName: fmt.Sprintf("Scenario_%d", i), Response: response, ServiceProvider: sp, // Capture the value of i by passing it to a function. CheckError: scenarioErrorChecker(i, oktaScenarioErrors), CheckWarningInfo: scenarioWarningChecker(i, oktaScenarioWarnings), }) } ExerciseProviderTestScenarios(t, scenarios) } ================================================ FILE: providertests/onelogin_test.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package providertests import ( "fmt" "testing" saml2 "github.com/russellhaering/gosaml2" ) var oneLoginScenarioErrors = map[int]string{ // 99 - Response(Assertion) - no signature 99: "error validating response: Missing signature referencing the top-level element", // 98 - Response(encrypted(Assertion)) - no signature 98: "error validating response: Missing signature referencing the top-level element", // 01 - signed(Response(Assertion)) 1: "", // 03 - Response(signed(Assertion)) 3: "", // 04 - signed(Response(signed(Assertion))) 4: "", // 05 - Response(encrypted(signed(Assertion))), no encryption certificate included in Assertion. // OneLogin does not include SP encryption certificate by default. ADFS and PingFed also do not // include the SP encryption certificate and they do not provide an option to include it in Response. // OneLogin and PingFed also do not include DigestMethod (default to http://www.w3.org/2000/09/xmldsig#sha1). 5: "", // 06 - Response(encrypted(signed(Assertion))) 6: "", // 07 - signed(Response(encrypted(Assertion))) 7: "", // 08 - signed(Response(encrypted(signed(Assertion)))) 8: "", // 09 - signed(Response(encrypted(signed(Assertion)))), no encryption certificate included in Assertion. // OneLogin does not include SP encryption certificate by default. ADFS and PingFed also do not // include the SP encryption certificate and they do not provide an option to include it in Response. // OneLogin and PingFed also do not include DigestMethod (default to http://www.w3.org/2000/09/xmldsig#sha1). 9: "", // 11 - signed(Response(Assertion)) - 01 Assertion content changed slightly 11: "error validating response: Signature could not be verified", // 12 - signed(Response(Assertion)) - 01 Response content changed slightly 12: "error validating response: Signature could not be verified", // 13 - Response(signed(Assertion)) - 03 Assertion content changed slightly 13: "error validating response: Signature could not be verified", // 14 - signed(Response(signed(Assertion)) - 04 Assertion content changed slightly 14: "error validating response: Signature could not be verified", // 15 - signed(Response(signed(Assertion))) - 04 Response content changed slightly 15: "error validating response: Signature could not be verified", // 16 - Response(encrypted(signed(Assertion))) - 06 CipherValue of EncryptedKey changed slightly 16: "error validating response: unable to decrypt encrypted assertion: cannot decrypt, error retrieving private key: rsa internal error: crypto/rsa: decryption error", // 17 - signed(Response(encrypted(Assertion))) - 07 Response content changed slightly 17: "error validating response: Signature could not be verified", // 18 - signed(Response(encrypted(signed(Assertion)))) - 16 signed (signature valid, still cannot decrypt) 18: "error validating response: unable to decrypt encrypted assertion: cannot decrypt, error retrieving private key: rsa internal error: crypto/rsa: decryption error", // 81 - Response(Assertion) - 99 missing assertion and response signature 81: "error validating response: Missing signature referencing the top-level element", // 82 - Response(Assertion) - 99 missing assertion and response signature 82: "error validating response: Missing signature referencing the top-level element", // 91 - Response(Assertion) - 99 missing Response subject confirmation element // Note: gosaml2 is correctly checking signature before contents 91: "error validating response: Missing signature referencing the top-level element", // 92 - Response(Assertion) - 99 missing Response subject confirmation method // Note: gosaml2 is correctly checking signature before contents 92: "error validating response: Missing signature referencing the top-level element", // 21 - signed(Response(Assertion)) - 91 sign Response, IssueInstant before SigningCertTime 21: "error validating response: Cert is not valid at this time", // 22 - signed(Response(Assertion)) - 92 sign Response, IssueInstant after SigningCertTime 22: "error validating response: Cert is not valid at this time", // 93 - Response(signed(Assertion)) - 91 sign Assertion, IssueInstant before SigningCertTime 93: "error validating response: Cert is not valid at this time", // 94 - Response(signed(Assertion)) - 92 sign Assertion, IssueInstant after SigningCertTime 94: "error validating response: Cert is not valid at this time", // 83 - Response(signed(Assertion)) - 81 sign Assertion IssueInstant before EncryptionCertTime // (Success, EncryptionCertTime is not a factor in this case) 83: "", // 84 - Response(signed(Assertion)) - 82 sign Assertion, IssueInstant after EncryptionCertTime // (Success, EncryptionCertTime is not a factor in this case) 84: "", // 23 - Response(encrypted(signed(Assertion))) - 83 encrypt Assertion, IssueInstant before EncryptionCertTime 23: "error validating response: unable to get decryption certificate: decryption cert is not valid at this time", // 24 - Response(encrypted(signed(Assertion))) - 84 encrypt Assertion, IssueInstant after EncryptionCertTime 24: "error validating response: unable to get decryption certificate: decryption cert is not valid at this time", // 26 - signed(Response(Assertion)) - 01 with AtTime after IssueInstant 26: "error validating response: Expired NotOnOrAfter value, Expected: 2017-08-30T23:55:00Z, Actual: 2017-08-30T23:19:41.379Z", // 28 - Response(encrypted(signed(Assertion))) - 06 with AtTime after IssueInstant 28: "error validating response: Expired NotOnOrAfter value, Expected: 2017-08-30T23:55:00Z, Actual: 2017-08-30T23:19:41.379Z", // 31 - signed(Response(Assertion)) - 01 wrong IDP signing cert 31: "error validating response: Could not verify certificate against trusted certs", // 33 - Response(signed(Assertion)) - 03 wrong IDP signing cert 33: "error validating response: Could not verify certificate against trusted certs", // 34 - signed(Response(signed(Assertion))) - 04 wrong IDP signing cert 34: "error validating response: Could not verify certificate against trusted certs", // 36 - Response(encrypted(signed(Assertion))) - 06 wrong IDP signing cert, correct SP encryption cert 36: "error validating response: Could not verify certificate against trusted certs", // 37 - signed(Response(encrypted(Assertion))) - 07 wrong IDP signing cert, correct SP encryption cert 37: "error validating response: Could not verify certificate against trusted certs", // 38 - signed(Response(encrypted(signed(Assertion)))) - 08 wrong IDP signing cert, correct SP encryption cert 38: "error validating response: Could not verify certificate against trusted certs", // 97 - Response(encrypted(Assertion)) - 99 wrong SP encryption cert 97: "error validating response: unable to decrypt encrypted assertion: cannot decrypt, error retrieving private key: key decryption attempted with mismatched cert, SP cert(cd:f6:7c:e9), assertion cert(42:99:58:b8)", // 46 - Response(encrypted(signed(Assertion))) - 06 wrong SP encryption cert, correct IDP signing cert 46: "error validating response: unable to decrypt encrypted assertion: cannot decrypt, error retrieving private key: key decryption attempted with mismatched cert, SP cert(cd:f6:7c:e9), assertion cert(42:99:58:b8)", // 47 - signed(Response(encrypted(Assertion))) - 07 wrong SP encryption cert, correct IDP signing cert 47: "error validating response: unable to decrypt encrypted assertion: cannot decrypt, error retrieving private key: key decryption attempted with mismatched cert, SP cert(cd:f6:7c:e9), assertion cert(42:99:58:b8)", // 48 - signed(Response(encrypted(signed(Assertion)))) - 08 wrong SP encryption cert, correct IDP signing cert 48: "error validating response: unable to decrypt encrypted assertion: cannot decrypt, error retrieving private key: key decryption attempted with mismatched cert, SP cert(cd:f6:7c:e9), assertion cert(42:99:58:b8)", // 85 - Response(Assertion) - 99 empty Response Destination (empty is ok, Destination is optional) // Note: gosaml2 is correctly checking signature before contents 85: "error validating response: Missing signature referencing the top-level element", // 86 - Response(Assertion) - 99 wrong Response Destination (SP acs) // Note: gosaml2 is correctly checking signature before contents 86: "error validating response: Missing signature referencing the top-level element", // 87 - Response(Assertion) - 99 wrong Response Issuer (IDP endpoint id) // Note: gosaml2 is correctly checking signature before contents 87: "error validating response: Missing signature referencing the top-level element", // 88 - Response(Assertion) - 99 wrong Assertion Audience (SP entity id) // Note: gosaml2 is correctly checking signature before contents 88: "error validating response: Missing signature referencing the top-level element", // 89 - Response(Assertion) - 99 wrong Assertion Issuer (IDP endpoint id) // Note: gosaml2 is correctly checking signature before contents 89: "error validating response: Missing signature referencing the top-level element", // 50 - signed(Response(Assertion)) - 85 signed Response, empty Response Destination (success, optional) 50: "", // 51 - signed(Response(Assertion)) - 86 signed Response, wrong Response Destination (SP acs) 51: "error validating response: Unrecognized Destination value, Expected: https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z, Actual: https://saml.sp.nope/session/sso/saml/acs/incorrect", // 52 - signed(Response(Assertion)) - 87 signed Response, wrong Response Issuer (IDP endpoint id) 52: "error validating response: Unrecognized Issuer value, Expected: https://saml.idp.nope/h9gkjzvb3e, Actual: https://saml.idp.nope/incorrect", // 54 - signed(Response(Assertion)) - 89 signed Response, wrong Assertion Issuer (IDP endpoint id) 54: "error validating response: Unrecognized Issuer value, Expected: https://saml.idp.nope/h9gkjzvb3e, Actual: https://saml.idp.nope/incorrect", // 55 - Response(signed(Assertion)) - 85 signed Assertion, empty Response Destination (success, optional) 55: "", // 56 - Response(signed(Assertion)) - 86 signed Assertion, wrong Response Destination (SP acs) 56: "error validating response: Unrecognized Destination value, Expected: https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z, Actual: https://saml.sp.nope/session/sso/saml/acs/incorrect", // 57 - error validating response: Response(signed(Assertion)) - 87 signed Assertion, wrong Response Issuer (IDP endpoint id) 57: "error validating response: Unrecognized Issuer value, Expected: https://saml.idp.nope/h9gkjzvb3e, Actual: https://saml.idp.nope/incorrect", // 59 - Response(signed(Assertion)) - 89 signed Assertion, wrong Assertion Issuer (IDP endpoint id) 59: "error validating response: Unrecognized Issuer value, Expected: https://saml.idp.nope/h9gkjzvb3e, Actual: https://saml.idp.nope/incorrect", // 155 - Response(encrypted(signed(Assertion))) - 85 encrypted signed Assertion, empty Response Destination (success, optional) 155: "", // 156 - Response(encrypted(signed(Assertion))) - 86 encrypted signed Assertion, wrong Response Destination (SP acs) 156: "error validating response: Unrecognized Destination value, Expected: https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z, Actual: https://saml.sp.nope/session/sso/saml/acs/incorrect", // 157 - Response(encrypted(signed(Assertion))) - 87 encrypted signed Assertion, wrong Response Issuer (IDP endpoint id) 157: "error validating response: Unrecognized Issuer value, Expected: https://saml.idp.nope/h9gkjzvb3e, Actual: https://saml.idp.nope/incorrect", // 159 - Response(encrypted(signed(Assertion))) - 89 encrypted signed Assertion, wrong Assertion Issuer (IDP endpoint id) 159: "error validating response: Unrecognized Issuer value, Expected: https://saml.idp.nope/h9gkjzvb3e, Actual: https://saml.idp.nope/incorrect", } var oneLoginScenarioWarnings = map[int]scenarioWarnings{ // 25 - signed(Response(Assertion)) - 01 with AtTime before IssueInstant 25: scenarioWarnings{ InvalidTime: true, }, // 27 - Response(encrypted(signed(Assertion))) - 06 with AtTime before IssueInstant 27: scenarioWarnings{ InvalidTime: true, }, // 53 - signed(Response(Assertion)) - 88 signed Response, wrong Assertion Audience (SP entity id) 53: scenarioWarnings{ NotInAudience: true, }, // 58 - Response(signed(Assertion)) - 88 signed Assertion, wrong Assertion Audience (SP entity id) 58: scenarioWarnings{ NotInAudience: true, }, // 158 - Response(encrypted(signed(Assertion))) - 88 encrypted signed Assertion, wrong Assertion Audience (SP entity id) 158: scenarioWarnings{ NotInAudience: true, }, } var oneLoginAtTimes = map[int]string{ 25: "2017-08-30T23:00:00Z", 26: "2017-08-30T23:55:00Z", 27: "2017-08-30T23:00:00Z", 28: "2017-08-30T23:55:00Z", } func TestOneLoginCasesLocally(t *testing.T) { sp := &saml2.SAMLServiceProvider{ IdentityProviderSSOURL: "https://saml.idp.nope/h9gkjzvb3e", // not required for these tests IdentityProviderIssuer: "https://saml.idp.nope/h9gkjzvb3e", AssertionConsumerServiceURL: "https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z", AudienceURI: "https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z", IDPCertificateStore: LoadCertificateStore("./testdata/onelogin/idp.signing.cert"), SPKeyStore: LoadKeyStore("./testdata/onelogin/sp.encryption.cert", "./testdata/onelogin/sp.encryption.key"), SPSigningKeyStore: LoadKeyStore("./testdata/onelogin/sp.signing.cert", "./testdata/onelogin/sp.signing.key"), ValidateEncryptionCert: true, } scenarios := []ProviderTestScenario{} for _, idx := range scenarioIndexes(oneLoginScenarioErrors, oneLoginScenarioWarnings) { response := LoadRawResponse(fmt.Sprintf("./testdata/onelogin/olgn09_response_%02d.b64", idx)) scenarios = append(scenarios, ProviderTestScenario{ ScenarioName: fmt.Sprintf("Scenario_%02d", idx), Response: response, ServiceProvider: spAtTime(sp, getAtTime(idx, oneLoginAtTimes), response), CheckError: scenarioErrorChecker(idx, oneLoginScenarioErrors), CheckWarningInfo: scenarioWarningChecker(idx, oneLoginScenarioWarnings), }) } ExerciseProviderTestScenarios(t, scenarios) } ================================================ FILE: providertests/pingfed_test.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package providertests import ( "fmt" "testing" "github.com/russellhaering/gosaml2" ) var pingFedScenarioErrors = map[int]string{ // 01 - signed(Response(Assertion)) - no KeyInfo (no IDP signing certificate included) // By default, PingFed does not include the KeyInfo element (which would include the // IDP signing certificate) in Response. Most other IDPs include KeyInfo element. // gosaml2 is ok with this as long as the SP has only one IDP signing certificate // for this relationship (it does not have to guess at to which cert to use). // Note: Response.Destination is set. 01: "", // 02 - signed(Response(Assertion)) - with KeyInfo (including IDP signing certificate) // Same as pfed11_response_01 except KeyInfo is included. // Note: Response.Destination is set. 02: "", // 03 - Response(signed(Assertion)) // As with 01, KeyInfo element is not included (not a bug). Unlike 01, // Response.Destination is NOT set. Most IDPs (including PingOne) always includes Response.Destination. // PingFed only includes Response.Destination when the Response is signed. // SAML Core 2.0 defines Response.Destination as [Optional]. // Thus, PingFed is not in not including Destination. Before a fix, gosaml2 required // Response.Destination. gosaml2 now only checks the value of Response.Destination if it // is set (mandated by SAML Core 2.0). 03: "", // 05 - signed(Response(encrypted(Assertion))) - no encryption certificate included in Assertion. // PingFed and ADFS do not include the SP encryption certificate and do not provide an option to include it in Response. // OneLogin (see olgn09/olgn09_response_05.b64) also does not include SP encryption certificate by default. // OneLogin and PingFed also do not include DigestMethod (default to http://www.w3.org/2000/09/xmldsig#sha1). 05: "", } var pingFedScenarioWarnings = map[int]scenarioWarnings{} var pingFedAtTimes = map[int]string{} func TestPingFedCasesLocally(t *testing.T) { sp := &saml2.SAMLServiceProvider{ IdentityProviderSSOURL: "https://saml.test.nope:9031/eid/sxpmrhbkzn", // not required for these tests IdentityProviderIssuer: "https://saml.test.nope:9031/eid/sxpmrhbkzn", AssertionConsumerServiceURL: "https://saml.test.nope/session/sso/saml/acs/hp24dqnpvq", AudienceURI: "https://saml.test.nope/session/sso/saml/spentityid/hp24dqnpvq", IDPCertificateStore: LoadCertificateStore("./testdata/pingfed/idp.signing.cert"), SPKeyStore: LoadKeyStore("./testdata/pingfed/sp.encryption.cert", "./testdata/pingfed/sp.encryption.key"), SPSigningKeyStore: LoadKeyStore("./testdata/pingfed/sp.signing.cert", "./testdata/pingfed/sp.signing.key"), ValidateEncryptionCert: true, } scenarios := []ProviderTestScenario{} for _, idx := range scenarioIndexes(pingFedScenarioErrors, pingFedScenarioWarnings) { response := LoadRawResponse(fmt.Sprintf("./testdata/pingfed/pfed11_response_%02d.b64", idx)) scenarios = append(scenarios, ProviderTestScenario{ ScenarioName: fmt.Sprintf("Scenario_%02d", idx), Response: response, ServiceProvider: spAtTime(sp, getAtTime(idx, pingFedAtTimes), response), CheckError: scenarioErrorChecker(idx, pingFedScenarioErrors), CheckWarningInfo: scenarioWarningChecker(idx, pingFedScenarioWarnings), }) } ExerciseProviderTestScenarios(t, scenarios) } ================================================ FILE: providertests/providers_test.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package providertests import ( "testing" "time" "github.com/jonboulle/clockwork" "github.com/russellhaering/gosaml2" "github.com/russellhaering/goxmldsig" ) func TestValidateResponses(t *testing.T) { scenarios := []ProviderTestScenario{ { ScenarioName: "Auth0", Response: LoadXMLResponse("./testdata/auth0_response.xml"), ServiceProvider: &saml2.SAMLServiceProvider{ IdentityProviderSSOURL: "https://scaleft-test.auth0.com/samlp/rlXOZ4kOUTQaTV8icSXrfZUd1qtD1NhK", IdentityProviderIssuer: "urn:scaleft-test.auth0.com", AssertionConsumerServiceURL: "http://localhost:8080/v1/_saml_callback", AudienceURI: "urn:scaleft-test.auth0.com", IDPCertificateStore: LoadCertificateStore("./testdata/auth0_cert.pem"), Clock: dsig.NewFakeClock(clockwork.NewFakeClockAt(time.Date(2016, 7, 25, 18, 30, 0, 0, time.UTC))), }, }, { ScenarioName: "Adfs", Response: LoadRawResponse("./testdata/adfs_response.b64"), ServiceProvider: &saml2.SAMLServiceProvider{ IdentityProviderSSOURL: "https://do.not.need/this/not/sending/authn", IdentityProviderIssuer: "http://fs.spstest2.com/adfs/services/trust", AssertionConsumerServiceURL: "https://saml.test.nope/session/sso/saml/acs/dknhyszjl7", SignAuthnRequests: false, AudienceURI: "https://saml.test.nope/session/sso/saml/spentityid/dknhyszjl7", IDPCertificateStore: LoadCertificateStore("./testdata/adfs_idp_signing_cert.pem"), SPKeyStore: LoadKeyStore("./testdata/adfs_sp_encryption_cert.pem", "./testdata/adfs_sp_encryption_key.pem"), SPSigningKeyStore: LoadKeyStore("./testdata/adfs_sp_signing_cert.pem", "./testdata/adfs_sp_signing_key.pem"), Clock: dsig.NewFakeClock(clockwork.NewFakeClockAt(time.Date(2017, 9, 21, 23, 28, 0, 0, time.UTC))), }, }, { ScenarioName: "AdfsEncrypted", Response: LoadRawResponse("./testdata/adfs_response_enc.b64"), ServiceProvider: &saml2.SAMLServiceProvider{ IdentityProviderSSOURL: "https://do.not.need/this/not/sending/authn", IdentityProviderIssuer: "http://fs.spstest2.com/adfs/services/trust", AssertionConsumerServiceURL: "https://saml.test.nope/session/sso/saml/acs/dknhyszjl7", SignAuthnRequests: false, AudienceURI: "https://saml.test.nope/session/sso/saml/spentityid/dknhyszjl7", IDPCertificateStore: LoadCertificateStore("./testdata/adfs_idp_signing_cert.pem"), SPKeyStore: LoadKeyStore("./testdata/adfs_sp_encryption_cert.pem", "./testdata/adfs_sp_encryption_key.pem"), SPSigningKeyStore: LoadKeyStore("./testdata/adfs_sp_signing_cert.pem", "./testdata/adfs_sp_signing_key.pem"), Clock: dsig.NewFakeClock(clockwork.NewFakeClockAt(time.Date(2017, 9, 21, 23, 20, 0, 0, time.UTC))), }, }, { // Okta uses detached EncryptedKey element (sibling of EncryptedData). See: // https://www.w3.org/TR/2002/REC-xmlenc-core-20021210/Overview.html#sec-Extensions-to-KeyInfo ScenarioName: "OktaEncrypted", Response: LoadRawResponse("./testdata/oktaenc_response.b64"), ServiceProvider: &saml2.SAMLServiceProvider{ IdentityProviderSSOURL: "https://do.not.need/this/not/sending/authn", IdentityProviderIssuer: "http://www.okta.com/exkbb59wb20X96NY20h7", AssertionConsumerServiceURL: "https://saml.test.nope/session/sso/saml/acs/skv8dv26wh", SignAuthnRequests: false, AudienceURI: "https://saml.test.nope/session/sso/saml/spentityid/skv8dv26wh", IDPCertificateStore: LoadCertificateStore("./testdata/oktaenc_idp_signing_cert.pem"), SPKeyStore: LoadKeyStore("./testdata/oktaenc_sp_encryption_cert.pem", "./testdata/oktaenc_sp_encryption_key.pem"), SPSigningKeyStore: LoadKeyStore("./testdata/oktaenc_sp_signing_cert.pem", "./testdata/oktaenc_sp_signing_key.pem"), Clock: dsig.NewFakeClock(clockwork.NewFakeClockAt(time.Date(2017, 9, 06, 22, 14, 0, 0, time.UTC))), }, }, { ScenarioName: "Okta", Response: LoadXMLResponse("./testdata/okta_response.xml"), ServiceProvider: &saml2.SAMLServiceProvider{ IdentityProviderSSOURL: "https://dev-116807.oktapreview.com/app/scaleftdev116807_test_1/exk659aytfMeNI49v0h7/sso/saml", IdentityProviderIssuer: "http://www.okta.com/exk659aytfMeNI49v0h7", AssertionConsumerServiceURL: "http://localhost:8080/v1/_saml_callback", SignAuthnRequests: true, AudienceURI: "\"123\"", IDPCertificateStore: LoadCertificateStore("./testdata/okta_cert.pem"), Clock: dsig.NewFakeClock(clockwork.NewFakeClockAt(time.Date(2016, 7, 25, 23, 16, 0, 0, time.UTC))), }, }, { ScenarioName: "OneLogin", Response: LoadXMLResponse("./testdata/onelogin_response.xml"), ServiceProvider: &saml2.SAMLServiceProvider{ IdentityProviderSSOURL: "https://launchdarkly-dev.onelogin.com/trust/saml2/http-post/sso/634027", IdentityProviderIssuer: "https://app.onelogin.com/saml/metadata/634027", AssertionConsumerServiceURL: "http://884d40bf.ngrok.io/api/sso/saml2/acs/58af624473d4f375b8e70d81", IDPCertificateStore: LoadCertificateStore("./testdata/onelogin_cert.pem"), AudienceURI: "{audience}", SkipSignatureValidation: false, AllowMissingAttributes: true, Clock: dsig.NewFakeClock(clockwork.NewFakeClockAt(time.Date(2017, 3, 8, 7, 51, 0, 0, time.UTC))), }, }, { ScenarioName: "OracleAccessManager", Response: LoadXMLResponse("./testdata/oam_response.xml"), ServiceProvider: &saml2.SAMLServiceProvider{ IdentityProviderSSOURL: "https://deaoam-dev02.jpl.nasa.gov:14101/oam/fed", IdentityProviderIssuer: "https://deaoam-dev02.jpl.nasa.gov:14101/oam/fed", AssertionConsumerServiceURL: "http://127.0.0.1:5556/callback", IDPCertificateStore: LoadCertificateStore("./testdata/oam_cert.pem"), AudienceURI: "JSAuth", SkipSignatureValidation: false, AllowMissingAttributes: true, Clock: dsig.NewFakeClock(clockwork.NewFakeClockAt(time.Date(2016, 12, 12, 16, 55, 0, 0, time.UTC))), }, }, } ExerciseProviderTestScenarios(t, scenarios) } ================================================ FILE: providertests/testdata/adfs_idp_signing_cert.pem ================================================ -----BEGIN CERTIFICATE----- MIIC2jCCAcKgAwIBAgIQNdNUIOmoKrFJNQadPV+9sTANBgkqhkiG9w0BAQsFADAp MScwJQYDVQQDEx5BREZTIFNpZ25pbmcgLSBmcy5zcHN0ZXN0Mi5jb20wHhcNMTYx MTAyMjIyOTE1WhcNMTcxMTAyMjIyOTE1WjApMScwJQYDVQQDEx5BREZTIFNpZ25p bmcgLSBmcy5zcHN0ZXN0Mi5jb20wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEK AoIBAQCjjUuNwckrCQgaXAMzHLFMuxrG+dREwct+d5W6PlAxlh8jxijhWXeHMcpP naDLkPhI6J5hva+2r/kJcIuz3c9wAHVIl6oQdSeH4lwbrD/bfCnu0lOmjgey/cY2 lVTs4mfx1L7ejnUWd4ROfrHkhtFgqOYrJYir29ZOqojmCvaSQbqfjXAQmP8xvsFy Yw0FNSURrt2ZZ9HTY1T6eJIrEJi0csgI4579IzYNyttwOfuM8rDrin2gTNTVTOE/ lfXv2q7CGU67ErETCtmaJJvlqYmRLwT51Jxrf3KLTkAjxyE4uISTuzys/Y/ktxI6 LQ3eFD/oRfTtA1V3pj96nxbxk2z3AgMBAAEwDQYJKoZIhvcNAQELBQADggEBAEZ5 uUC+Djrx9XJlrGHwwhVShyDcEvloJzeZLnNvMC1Gfyq4enHaVE5ztnkLTvphym9+ W9waFlVPHlIAXv3CKz9xbFWDtaXvD229pOGThDBCKo8o2vucHCo8gn+dUq0ZS+TV LpqeNoTpjfI4FQZ7BwDoILza6xdXHmDukui1btNFYYwhHzgMx1x1cz4VvBj5D+WW f13uClD2dkeasoZ4M9KH15Oy128tXhmzCw7ymsv3KC20CvHiqwGnYcybZdcIKQUT aB3qCNW5ti44RxwmLF4tnuFONmPuH1Pet0Hnq6pWNBMsWNEPM9LRVoPLqDR3fmkL /mNtZZd4xG3Kgd1IbPc= -----END CERTIFICATE----- ================================================ FILE: providertests/testdata/adfs_response.b64 ================================================ PHNhbWxwOlJlc3BvbnNlIElEPSJfYjlkM2VhNzAtMmEwYy00MmI2LWI4ZjctNjU3YWRlYjJiYjA5IiBWZXJzaW9uPSIyLjAiIElzc3VlSW5zdGFudD0iMjAxNy0wOS0yMVQyMzoyNzowNi44MjhaIiBEZXN0aW5hdGlvbj0iaHR0cHM6Ly9zYW1sLnRlc3Qubm9wZS9zZXNzaW9uL3Nzby9zYW1sL2Fjcy9ka25oeXN6amw3IiBDb25zZW50PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6Y29uc2VudDp1bnNwZWNpZmllZCIgSW5SZXNwb25zZVRvPSJfNTk4OGJmNDUtMWNjOC00MjI4LWIzZTgtMWFhODU5MGU2M2QzIiB4bWxuczpzYW1scD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOnByb3RvY29sIj48SXNzdWVyIHhtbG5zPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIj5odHRwOi8vZnMuc3BzdGVzdDIuY29tL2FkZnMvc2VydmljZXMvdHJ1c3Q8L0lzc3Vlcj48c2FtbHA6U3RhdHVzPjxzYW1scDpTdGF0dXNDb2RlIFZhbHVlPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6c3RhdHVzOlN1Y2Nlc3MiIC8+PC9zYW1scDpTdGF0dXM+PEFzc2VydGlvbiBJRD0iX2ZkNjEwOGZkLWQyYmYtNDMyNy1hODFmLWMwM2I4ZmNhNzcwZCIgSXNzdWVJbnN0YW50PSIyMDE3LTA5LTIxVDIzOjI3OjA2LjgyOFoiIFZlcnNpb249IjIuMCIgeG1sbnM9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPjxJc3N1ZXI+aHR0cDovL2ZzLnNwc3Rlc3QyLmNvbS9hZGZzL3NlcnZpY2VzL3RydXN0PC9Jc3N1ZXI+PGRzOlNpZ25hdHVyZSB4bWxuczpkcz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8wOS94bWxkc2lnIyI+PGRzOlNpZ25lZEluZm8+PGRzOkNhbm9uaWNhbGl6YXRpb25NZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzEwL3htbC1leGMtYzE0biMiIC8+PGRzOlNpZ25hdHVyZU1ldGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvMDQveG1sZHNpZy1tb3JlI3JzYS1zaGEyNTYiIC8+PGRzOlJlZmVyZW5jZSBVUkk9IiNfZmQ2MTA4ZmQtZDJiZi00MzI3LWE4MWYtYzAzYjhmY2E3NzBkIj48ZHM6VHJhbnNmb3Jtcz48ZHM6VHJhbnNmb3JtIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8wOS94bWxkc2lnI2VudmVsb3BlZC1zaWduYXR1cmUiIC8+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvMTAveG1sLWV4Yy1jMTRuIyIgLz48L2RzOlRyYW5zZm9ybXM+PGRzOkRpZ2VzdE1ldGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvMDQveG1sZW5jI3NoYTI1NiIgLz48ZHM6RGlnZXN0VmFsdWU+cmJTd3EwZVZTWXFYdDFwQ095SThtT255K2h1Ukt3OU1LR0dxS21BUnFxcz08L2RzOkRpZ2VzdFZhbHVlPjwvZHM6UmVmZXJlbmNlPjwvZHM6U2lnbmVkSW5mbz48ZHM6U2lnbmF0dXJlVmFsdWU+Wm96L3dldWlEckVBVHEvVXFGb3hLbTUySUZmV2NZbzM1S1BxY0ttZE9RaW9TcWdnYnJlbElzM3dFSUFveUdxZHZKd1ZSNmlac2RsNlpTU0g0Z29nV01ydFV6QXRVT2IvMjVJMU1HWVBNZmJ4bVZTL0syQ0RmSUllV2wzU1hIT0o0YWxURldtR21wQ2NrZFpvUUgvR3M4ZUFzOHBxOXBLWUVlZFhkVzNSc0JpZTRzSFo3ME94aGhZS0VWY0RrUkJkQzNHQ1pqSk4yY3RENUJZeGhJMDVENnN1eU9rYlpHYVBCR1l2MkFzSDRDTmRXeHlaVDhEN21tejM3NElNOWorcUQ2U3RuNFZ0STZXRThCb3ByV1daSWRnYzZCRDgwSEhQR0k1WGo5UzZzRmxsSEtaSGlRckVtNnd4WnMyUVQ5T0JiMVNRcjQrMTNUSFgxWkpBbFUwMTZBPT08L2RzOlNpZ25hdHVyZVZhbHVlPjxLZXlJbmZvIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjIj48ZHM6WDUwOURhdGE+PGRzOlg1MDlDZXJ0aWZpY2F0ZT5NSUlDMmpDQ0FjS2dBd0lCQWdJUU5kTlVJT21vS3JGSk5RYWRQVis5c1RBTkJna3Foa2lHOXcwQkFRc0ZBREFwTVNjd0pRWURWUVFERXg1QlJFWlRJRk5wWjI1cGJtY2dMU0JtY3k1emNITjBaWE4wTWk1amIyMHdIaGNOTVRZeE1UQXlNakl5T1RFMVdoY05NVGN4TVRBeU1qSXlPVEUxV2pBcE1TY3dKUVlEVlFRREV4NUJSRVpUSUZOcFoyNXBibWNnTFNCbWN5NXpjSE4wWlhOME1pNWpiMjB3Z2dFaU1BMEdDU3FHU0liM0RRRUJBUVVBQTRJQkR3QXdnZ0VLQW9JQkFRQ2pqVXVOd2NrckNRZ2FYQU16SExGTXV4ckcrZFJFd2N0K2Q1VzZQbEF4bGg4anhpamhXWGVITWNwUG5hRExrUGhJNko1aHZhKzJyL2tKY0l1ejNjOXdBSFZJbDZvUWRTZUg0bHdickQvYmZDbnUwbE9tamdleS9jWTJsVlRzNG1meDFMN2VqblVXZDRST2ZySGtodEZncU9ZckpZaXIyOVpPcW9qbUN2YVNRYnFmalhBUW1QOHh2c0Z5WXcwRk5TVVJydDJaWjlIVFkxVDZlSklyRUppMGNzZ0k0NTc5SXpZTnl0dHdPZnVNOHJEcmluMmdUTlRWVE9FL2xmWHYycTdDR1U2N0VyRVRDdG1hSkp2bHFZbVJMd1Q1MUp4cmYzS0xUa0FqeHlFNHVJU1R1enlzL1kva3R4STZMUTNlRkQvb1JmVHRBMVYzcGo5Nm54YnhrMnozQWdNQkFBRXdEUVlKS29aSWh2Y05BUUVMQlFBRGdnRUJBRVo1dVVDK0Rqcng5WEpsckdId3doVlNoeURjRXZsb0p6ZVpMbk52TUMxR2Z5cTRlbkhhVkU1enRua0xUdnBoeW05K1c5d2FGbFZQSGxJQVh2M0NLejl4YkZXRHRhWHZEMjI5cE9HVGhEQkNLbzhvMnZ1Y0hDbzhnbitkVXEwWlMrVFZMcHFlTm9UcGpmSTRGUVo3QndEb0lMemE2eGRYSG1EdWt1aTFidE5GWVl3aEh6Z014MXgxY3o0VnZCajVEK1dXZjEzdUNsRDJka2Vhc29aNE05S0gxNU95MTI4dFhobXpDdzd5bXN2M0tDMjBDdkhpcXdHblljeWJaZGNJS1FVVGFCM3FDTlc1dGk0NFJ4d21MRjR0bnVGT05tUHVIMVBldDBIbnE2cFdOQk1zV05FUE05TFJWb1BMcURSM2Zta0wvbU50WlpkNHhHM0tnZDFJYlBjPTwvZHM6WDUwOUNlcnRpZmljYXRlPjwvZHM6WDUwOURhdGE+PC9LZXlJbmZvPjwvZHM6U2lnbmF0dXJlPjxTdWJqZWN0PjxOYW1lSUQgRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoxLjE6bmFtZWlkLWZvcm1hdDplbWFpbEFkZHJlc3MiPnBhdWxAc3BzdGVzdDIuY29tPC9OYW1lSUQ+PFN1YmplY3RDb25maXJtYXRpb24gTWV0aG9kPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6Y206YmVhcmVyIj48U3ViamVjdENvbmZpcm1hdGlvbkRhdGEgSW5SZXNwb25zZVRvPSJfNTk4OGJmNDUtMWNjOC00MjI4LWIzZTgtMWFhODU5MGU2M2QzIiBOb3RPbk9yQWZ0ZXI9IjIwMTctMDktMjFUMjM6MzI6MDYuODI4WiIgUmVjaXBpZW50PSJodHRwczovL3NhbWwudGVzdC5ub3BlL3Nlc3Npb24vc3NvL3NhbWwvYWNzL2Rrbmh5c3pqbDciIC8+PC9TdWJqZWN0Q29uZmlybWF0aW9uPjwvU3ViamVjdD48Q29uZGl0aW9ucyBOb3RCZWZvcmU9IjIwMTctMDktMjFUMjM6Mjc6MDYuODI2WiIgTm90T25PckFmdGVyPSIyMDE3LTA5LTIyVDAwOjI3OjA2LjgyNloiPjxBdWRpZW5jZVJlc3RyaWN0aW9uPjxBdWRpZW5jZT5odHRwczovL3NhbWwudGVzdC5ub3BlL3Nlc3Npb24vc3NvL3NhbWwvc3BlbnRpdHlpZC9ka25oeXN6amw3PC9BdWRpZW5jZT48L0F1ZGllbmNlUmVzdHJpY3Rpb24+PC9Db25kaXRpb25zPjxBdHRyaWJ1dGVTdGF0ZW1lbnQ+PEF0dHJpYnV0ZSBOYW1lPSJodHRwOi8vc2NoZW1hcy54bWxzb2FwLm9yZy93cy8yMDA1LzA1L2lkZW50aXR5L2NsYWltcy9naXZlbm5hbWUiPjxBdHRyaWJ1dGVWYWx1ZT5wYXVsPC9BdHRyaWJ1dGVWYWx1ZT48L0F0dHJpYnV0ZT48QXR0cmlidXRlIE5hbWU9Imh0dHA6Ly9zY2hlbWFzLnhtbHNvYXAub3JnL3dzLzIwMDUvMDUvaWRlbnRpdHkvY2xhaW1zL3N1cm5hbWUiPjxBdHRyaWJ1dGVWYWx1ZT5mcmFsZXk8L0F0dHJpYnV0ZVZhbHVlPjwvQXR0cmlidXRlPjwvQXR0cmlidXRlU3RhdGVtZW50PjxBdXRoblN0YXRlbWVudCBBdXRobkluc3RhbnQ9IjIwMTctMDktMjFUMjM6Mjc6MDYuNzY3WiIgU2Vzc2lvbkluZGV4PSJfZmQ2MTA4ZmQtZDJiZi00MzI3LWE4MWYtYzAzYjhmY2E3NzBkIj48QXV0aG5Db250ZXh0PjxBdXRobkNvbnRleHRDbGFzc1JlZj51cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YWM6Y2xhc3NlczpQYXNzd29yZFByb3RlY3RlZFRyYW5zcG9ydDwvQXV0aG5Db250ZXh0Q2xhc3NSZWY+PC9BdXRobkNvbnRleHQ+PC9BdXRoblN0YXRlbWVudD48L0Fzc2VydGlvbj48L3NhbWxwOlJlc3BvbnNlPg== ================================================ FILE: providertests/testdata/adfs_response_enc.b64 ================================================ <samlp:Response ID="_ae246d4e-b9e0-49e3-97a2-c2f236408b9e" Version="2.0" IssueInstant="2017-09-21T23:19:11.608Z" Destination="https://saml.test.nope/session/sso/saml/acs/dknhyszjl7" Consent="urn:oasis:names:tc:SAML:2.0:consent:unspecified" InResponseTo="_252d0129-1c83-496e-b039-ffc9cee11cca" xmlns:samlp="urn:oasis:names:tc:SAML:2.0:protocol"><Issuer xmlns="urn:oasis:names:tc:SAML:2.0:assertion">http://fs.spstest2.com/adfs/services/trust</Issuer><samlp:Status><samlp:StatusCode Value="urn:oasis:names:tc:SAML:2.0:status:Success" /></samlp:Status><EncryptedAssertion xmlns="urn:oasis:names:tc:SAML:2.0:assertion"><xenc:EncryptedData Type="http://www.w3.org/2001/04/xmlenc#Element" xmlns:xenc="http://www.w3.org/2001/04/xmlenc#"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes256-cbc" /><KeyInfo xmlns="http://www.w3.org/2000/09/xmldsig#"><e:EncryptedKey xmlns:e="http://www.w3.org/2001/04/xmlenc#"><e:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p"><DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1" /></e:EncryptionMethod><KeyInfo><ds:X509Data xmlns:ds="http://www.w3.org/2000/09/xmldsig#"><ds:X509IssuerSerial><ds:X509IssuerName>CN=saml.test.nope, O=SAML Test Nope., S=California, C=US</ds:X509IssuerName><ds:X509SerialNumber>16999231321919524843</ds:X509SerialNumber></ds:X509IssuerSerial></ds:X509Data></KeyInfo><e:CipherData><e:CipherValue>BN79Ybvf1hDGt0+OYOciQV5CZNwsy+ggmJqfb8QMpUeUIsbHOqO9Li+qFBjYn0iffWsD8MxqvUcUf9C7RbUvR8/tGHSwGAfDo8kSwB8CjLhc/82a90y3CJB9xlNdqrzNxxDnys45/bCF9/r7SUplmmSCIq7sALcOxqFxzUftClqqioQ/DmP6FFVXLuesQhx2kJxhf3/TPQnGe3Lb3EJmefxtIQbIriFoy3ZhQEKEybjQVL1ZXp3juwC2Ud56dKwwmep68GrmQNqtMHaojPKfEZgDLWVXBfyGZlz6pcFV/CZI4UrJwvM9NmIqOEllt6KrVuEahnqOiBx7k6/lgb1cIg==</e:CipherValue></e:CipherData></e:EncryptedKey></KeyInfo><xenc:CipherData><xenc:CipherValue>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</xenc:CipherValue></xenc:CipherData></xenc:EncryptedData></EncryptedAssertion></samlp:Response> ================================================ FILE: providertests/testdata/auth0_cert.pem ================================================ -----BEGIN CERTIFICATE----- MIIC9DCCAdygAwIBAgIJX9Qb0a2w33UjMA0GCSqGSIb3DQEBBQUAMCExHzAdBgNV BAMTFnNjYWxlZnQtdGVzdC5hdXRoMC5jb20wHhcNMTYwNzI1MTc0OTQ1WhcNMzAw NDAzMTc0OTQ1WjAhMR8wHQYDVQQDExZzY2FsZWZ0LXRlc3QuYXV0aDAuY29tMIIB IjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAx+MnMtsJsNjDD4YEsi//LeBD wbwqwYTJk8mUlTLuaSss2X4aPo2kGjuEjvTc0x4Mk9ZQ/CIPPX3J9N4AFQu88rRd pT+TTuY9AIiyt8sZ+b1qF9eewyLVchM6s9Ff2JqgDIfajym825GKAJL7hi6smFRT 6h+OyyHo8pJjXePldum4woSFW/H3y83meF51Wn9oMTRRVAlpsdRVOgmuQpBlw3ap eeRpAmqLYT7DH3j30umYu3+4+NcxtEC7s5+QAIenuORjjw+M+IB+HhYpy1AnblY6 4RRAD+EfESEC+AF/+G0zuA4q43s9IduYZp2GMzPzMlnhDlR5syiLGFtLZ+pwFQID AQABoy8wLTAMBgNVHRMEBTADAQH/MB0GA1UdDgQWBBSX/v06GyNh1an1f7O7KKER 6xNntTANBgkqhkiG9w0BAQUFAAOCAQEAgtITYCbzRo8l8Q3+EHFwASlmnSyRm8HW G41nmHLcC2lUqNvniSEf0kO65oMN2nxlq9JMeI7NxKNpTVL4OYX5+/0NqcxePayY /9/5jBRwqF+84USc8HG8z+BFh1rVW35eoE5ULeegUBPgDG9shQjSLyIkNvYqXQ7A tjMka8lkmdtU9XBlfYZC4YEmkeQOHkW5gmix5opajkj+Tih7HKsdhOgxZrl7/4Wm GOoyR2q3Ffg8fmNgDe2Sf8bGv7IoTeeYVHIurVFoQSLziICOBQSpk/y/NS3HdSBO ADRxhUn241jRTaEi06qcg/A9P4zulKR61mCVpEWv6ZveEyVm4XA4xQ== -----END CERTIFICATE----- ================================================ FILE: providertests/testdata/auth0_response.xml ================================================ urn:scaleft-test.auth0.comurn:scaleft-test.auth0.comgoogle-oauth2|117637692321743777825urn:scaleft-test.auth0.comgoogle-oauth2|117637692321743777825russell.haering@scaleft.comRussell HaeringRussellHaeringrussell.haering@scaleft.comgoogle-oauth2google-oauth2truetruehttps://lh3.googleusercontent.com/-XdUIqdMkCWA/AAAAAAAAAAI/AAAAAAAAAAA/4252rscbv5M/photo.jpgenrlXOZ4kOUTQaTV8icSXrfZUd1qtD1NhKMon Jul 25 2016 18:29:17 GMT+0000 (UTC)russell.haering[object Object]Mon Jul 25 2016 17:51:26 GMT+0000 (UTC)urn:oasis:names:tc:SAML:2.0:ac:classes:unspecifiedWpFHrL2L9I0IcJDC4cFrh54kqNM=j6jV5RJuDF+TVy2obGLcl1nGpNPXsIyjud4NXTSStVibuFvJ8VetYU9yv9MlyhyI9GC9pL73zHt3havhm3iCvwBcOLcgu9oX+s60N5HUt7eVnEBUdXt52hEZki61D3w+//e6l6gt5Di9109vLHfV1KgkuKPC3IfBK8Z52rL6KfmIrry5OEl0n2o0A8wAYDnZkkY07LTYvZFcQ2JQ/plYEi/y+4yGYSxhjcVyPs/h0xavjk7xFJ0b16kUshpYUSkZOUOamW2tdlADXOrossOV4iOCOB2VnT5WjOfviYzW2WE39fmiZ7ahSmxCCtsuHS/xhRq05mi4j3EDd3N/07isVg==MIIC9DCCAdygAwIBAgIJX9Qb0a2w33UjMA0GCSqGSIb3DQEBBQUAMCExHzAdBgNVBAMTFnNjYWxlZnQtdGVzdC5hdXRoMC5jb20wHhcNMTYwNzI1MTc0OTQ1WhcNMzAwNDAzMTc0OTQ1WjAhMR8wHQYDVQQDExZzY2FsZWZ0LXRlc3QuYXV0aDAuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAx+MnMtsJsNjDD4YEsi//LeBDwbwqwYTJk8mUlTLuaSss2X4aPo2kGjuEjvTc0x4Mk9ZQ/CIPPX3J9N4AFQu88rRdpT+TTuY9AIiyt8sZ+b1qF9eewyLVchM6s9Ff2JqgDIfajym825GKAJL7hi6smFRT6h+OyyHo8pJjXePldum4woSFW/H3y83meF51Wn9oMTRRVAlpsdRVOgmuQpBlw3apeeRpAmqLYT7DH3j30umYu3+4+NcxtEC7s5+QAIenuORjjw+M+IB+HhYpy1AnblY64RRAD+EfESEC+AF/+G0zuA4q43s9IduYZp2GMzPzMlnhDlR5syiLGFtLZ+pwFQIDAQABoy8wLTAMBgNVHRMEBTADAQH/MB0GA1UdDgQWBBSX/v06GyNh1an1f7O7KKER6xNntTANBgkqhkiG9w0BAQUFAAOCAQEAgtITYCbzRo8l8Q3+EHFwASlmnSyRm8HWG41nmHLcC2lUqNvniSEf0kO65oMN2nxlq9JMeI7NxKNpTVL4OYX5+/0NqcxePayY/9/5jBRwqF+84USc8HG8z+BFh1rVW35eoE5ULeegUBPgDG9shQjSLyIkNvYqXQ7AtjMka8lkmdtU9XBlfYZC4YEmkeQOHkW5gmix5opajkj+Tih7HKsdhOgxZrl7/4WmGOoyR2q3Ffg8fmNgDe2Sf8bGv7IoTeeYVHIurVFoQSLziICOBQSpk/y/NS3HdSBOADRxhUn241jRTaEi06qcg/A9P4zulKR61mCVpEWv6ZveEyVm4XA4xQ== ================================================ FILE: providertests/testdata/oam_cert.pem ================================================ -----BEGIN CERTIFICATE----- MIIB/jCCAWegAwIBAgIBCjANBgkqhkiG9w0BAQQFADAkMSIwIAYDVQQDExlkZWFv YW0tZGV2MDIuanBsLm5hc2EuZ292MB4XDTE2MDYzMDA0NTQxNloXDTI2MDYyODA0 NTQxNlowJDEiMCAGA1UEAxMZZGVhb2FtLWRldjAyLmpwbC5uYXNhLmdvdjCBnzAN BgkqhkiG9w0BAQEFAAOBjQAwgYkCgYEAht1N4lGdwUbl7YRyHwSCrnep6/e2I3+V eue0pSA/DGn8OuR/udM8UCja5utqlqJdq200ox4b4Mpz0Jg9kMckALtKe+1DgeES EIx9FpeuBdHlitYQNSbEr30HIG2nmeTOy4Vi5unBO54um3tNazcUTMA0/LJ6KQL8 LeZSlB/IxwUCAwEAAaNAMD4wDAYDVR0TAQH/BAIwADAPBgNVHQ8BAf8EBQMDB9gA MB0GA1UdDgQWBBRYo1YjfrNonauLzj6/AsueWFGSszANBgkqhkiG9w0BAQQFAAOB gQACq7GHK/Zsg0+qC0WWa2ZjmOXE6Dqk/xuooG49QT7ihABs7k9U27Fw3xKF6MkC 7pca1FwT82eZK1N3XKKpZe7Flu1fMKt2o/XSiBkDjWwUcChVnwGsUBe8hJFwFqg7 olNJn1kaVBJUqZIiXF9kS0d+1H55rStOd0CNXAzp9utr2A== -----END CERTIFICATE----- ================================================ FILE: providertests/testdata/oam_response.xml ================================================ https://deaoam-dev02.jpl.nasa.gov:14101/oam/fedhttps://deaoam-dev02.jpl.nasa.gov:14101/oam/fedz1HD/59hv6UOd5+jeG+ihaFWLgI=I99oG5kiOfIgbXYa21z/TOmzftTkFnXe9ObhBNSKit9kAhT93apYROqqXv4Ax96P144Ld7ERX1hgJsytK8LC2874Pk7QrSNm4zvW3x0D4GR4lM06CvJK/EhIur3TrCUJDPigvyP7TJitheCyBejwt0x0lqNP/OzR3tMbAIMRoho=pkieuJSAuthurn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport ================================================ FILE: providertests/testdata/okta_cert.pem ================================================ -----BEGIN CERTIFICATE----- MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5 QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4 2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+ LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC qRnqQ+TccSu/B6uONFsDEngGcXSKfB+a -----END CERTIFICATE----- ================================================ FILE: providertests/testdata/okta_response.xml ================================================ http://www.okta.com/exk659aytfMeNI49v0h7ABeBWHP23nfnxsyUWE5d59IIqQeXgHGol36mjFvWcA4=NfzCNa5SytP8OH0kq5yElIzhQrlAWdHWV6fdZA8+6SH8yrCPFMOwCsQRM0UriNDasPhodEQIRCzcZuaGNXqXiNXmEcoILXEFWsLPNg0dxHrrdbmKTz+QxKB+4PFAmgOwFIMMN7xwinMBJG3JEhBTjj8QRg9TbVUG/3GgTrlfzNpp9Db94nPOuhyMNStNGMFUEfCyMRQ5ZYK66ritnHFrMDBnu7oiCEV7xDIRf97kqHIDVenyntR56zDLu/ndCJfuP66Fahae1sU0U2bHJfM/64YWvI/OyywsNlZl1tANRXiNaKt6ukvDcz4CFI8aRER7RNbsEhinGMWxHUey0c3o5g==MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5 QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4 2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+ LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC qRnqQ+TccSu/B6uONFsDEngGcXSKfB+ahttp://www.okta.com/exk659aytfMeNI49v0h7jwweWw9Jrdw3X28IpBEQgQ5I0mwOeStoOSso1hjtqkg=BiFOSVvt5tIqMDwO5gcBehbTGaqe4S6gBmDxywqx0H1KL7vdz5v46L/0GxyfAZESwPu1zEMXSpt24wY+oTN2sMEuOAw2SK0OROucF3gWzYs6Uk7MtXg6uXq+jXRF76qdilWi5O2t270vwPYMOAG78C0DFhvtOA+aJI5Uc/SxbYPeN9/3/ymOhNNzZNSz8CfxwjhIGYjBao4mJd3Cb0I3N7ggHP9LhxUsRWDq7zWhKms0EOOfuiRw3VCdZh3E8wvbykos8M7Iy3m12XHK/JDJ2U88KPX2aMjgOrxBUBLwnySzzQ4+MPYGaWL6/4TQWp/NX2pm4L9rMuQguJj50/5p/A==MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5 QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4 2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+ LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC qRnqQ+TccSu/B6uONFsDEngGcXSKfB+arussellhaering"123"urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransportrussell.haering@scaleft.com ================================================ FILE: providertests/testdata/oktaenc_idp_signing_cert.pem ================================================ -----BEGIN CERTIFICATE----- MIIDrDCCApSgAwIBAgIGAVhBgiX+MA0GCSqGSIb3DQEBBQUAMIGWMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxFzAVBgNVBAMMDnNreXBvcnRzeXN0ZW1zMRwwGgYJKoZIhvcN AQkBFg1pbmZvQG9rdGEuY29tMB4XDTE2MTEwODAxMTUzOFoXDTI2MTEwODAxMTYzOFowgZYxCzAJ BgNVBAYTAlVTMRMwEQYDVQQIDApDYWxpZm9ybmlhMRYwFAYDVQQHDA1TYW4gRnJhbmNpc2NvMQ0w CwYDVQQKDARPa3RhMRQwEgYDVQQLDAtTU09Qcm92aWRlcjEXMBUGA1UEAwwOc2t5cG9ydHN5c3Rl bXMxHDAaBgkqhkiG9w0BCQEWDWluZm9Ab2t0YS5jb20wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAw ggEKAoIBAQCFRpdl2Wm6UtxSzZp+MCV5ljVm+Rg4dyFYxBz2DzCqGRCE5a47JnrkTSsaQGV2IrId GejmqpMcB3teziPeQ9IoBA4Grqc0FWUwh79d6vTH7A263XTtkyecq1D9qBwl4oDULcG2IbiQUcMM JRXgiknzOvHKH1p4TLaxQbmRO2qmHoZG0J0azWe2HgM/tzD9wBosRLu1EGV7ooS9xfS02kum2Qa/ CKydS2nWo/84R+s7hLPmbC3FsDc4U2XWmkFealgh8bZUZHZ6f7xTZkLqq7rvhw4p4pulrYqpnGgU bAsk/IHLiEzAjfz6movtU4B+CHEt3u/XDH8dW1O0aXpTIauVAgMBAAEwDQYJKoZIhvcNAQEFBQAD ggEBACZxU65IrSV3hT4/0DDG1P4kplvsfg/YYup8f6mgH38D1rdodiMW59mUBipw13qyempSgbRy UAukbpi3fpYb0Cob6Flo+FQR8+fpeUTePCIO+yD4mlqElAJR5a2J7ZWhycvAGOqvpaHHK+xrJCDD Y4c1hIOezAveGDskDS0cDcXknwQwdt2eQxGebRXaDSlvbjFPvpd2Y72x2PBxSoXaamdNRbiSUC0y APle2k24tMMfcm9A/FDDI8QOikV4vQeIjFjGr+yQf+eqBihaL8iDCojT8xXMU/mbDrQhrSWkqpnF sjls45t/votmhL8boe2A6Cx9yiAWltPISL7+L1ENa88= -----END CERTIFICATE----- ================================================ FILE: providertests/testdata/oktaenc_response.b64 ================================================ <?xml version="1.0" encoding="UTF-8"?><saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.test.nope/session/sso/saml/acs/skv8dv26wh" ID="id10373369530520110457987219" InResponseTo="_5260fc99-9c41-433b-8a31-b7a3e3a4e755" IssueInstant="2017-09-06T22:13:10.144Z" 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/exkbb59wb20X96NY20h7</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="#id10373369530520110457987219"><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>WfNdF4IplwiN8yhKhh/jCGcFzLE585TO+60ETpZu8oo=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>IfsWSVfr+Jm6RTS40kAvBdTpzpe3ITy20IOgh0VzVnZXAL1OWfVBasw6MvHep0t9GlxcnsHsvxuUPB0+zG37d43nds0zK8tiUp48kexd0ErxHzSH2JpVL6P7SAo/cGr9tQjlV1UyJbt52gdKmoRemzqU/pw5PwyjItM81r3zGeBuboEyzd00s0+ChVr0hhVHm+DO076JsHwUIF0dXMjLzKLlK3xRNs3wJAcXzW+INtg0ZoBPDQe5JQC22kELxJJrM8V1d1JGz2UT3OrMR38zZCfqTmIVonXLLgHxswdDzGqqbWLDOuPeGNqX39P3da+8E0ngIVuDhwb3vXmnceoXbw==</ds:SignatureValue><ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDrDCCApSgAwIBAgIGAVhBgiX+MA0GCSqGSIb3DQEBBQUAMIGWMQswCQYDVQQGEwJVUzETMBEG
A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU
MBIGA1UECwwLU1NPUHJvdmlkZXIxFzAVBgNVBAMMDnNreXBvcnRzeXN0ZW1zMRwwGgYJKoZIhvcN
AQkBFg1pbmZvQG9rdGEuY29tMB4XDTE2MTEwODAxMTUzOFoXDTI2MTEwODAxMTYzOFowgZYxCzAJ
BgNVBAYTAlVTMRMwEQYDVQQIDApDYWxpZm9ybmlhMRYwFAYDVQQHDA1TYW4gRnJhbmNpc2NvMQ0w
CwYDVQQKDARPa3RhMRQwEgYDVQQLDAtTU09Qcm92aWRlcjEXMBUGA1UEAwwOc2t5cG9ydHN5c3Rl
bXMxHDAaBgkqhkiG9w0BCQEWDWluZm9Ab2t0YS5jb20wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAw
ggEKAoIBAQCFRpdl2Wm6UtxSzZp+MCV5ljVm+Rg4dyFYxBz2DzCqGRCE5a47JnrkTSsaQGV2IrId
GejmqpMcB3teziPeQ9IoBA4Grqc0FWUwh79d6vTH7A263XTtkyecq1D9qBwl4oDULcG2IbiQUcMM
JRXgiknzOvHKH1p4TLaxQbmRO2qmHoZG0J0azWe2HgM/tzD9wBosRLu1EGV7ooS9xfS02kum2Qa/
CKydS2nWo/84R+s7hLPmbC3FsDc4U2XWmkFealgh8bZUZHZ6f7xTZkLqq7rvhw4p4pulrYqpnGgU
bAsk/IHLiEzAjfz6movtU4B+CHEt3u/XDH8dW1O0aXpTIauVAgMBAAEwDQYJKoZIhvcNAQEFBQAD
ggEBACZxU65IrSV3hT4/0DDG1P4kplvsfg/YYup8f6mgH38D1rdodiMW59mUBipw13qyempSgbRy
UAukbpi3fpYb0Cob6Flo+FQR8+fpeUTePCIO+yD4mlqElAJR5a2J7ZWhycvAGOqvpaHHK+xrJCDD
Y4c1hIOezAveGDskDS0cDcXknwQwdt2eQxGebRXaDSlvbjFPvpd2Y72x2PBxSoXaamdNRbiSUC0y
APle2k24tMMfcm9A/FDDI8QOikV4vQeIjFjGr+yQf+eqBihaL8iDCojT8xXMU/mbDrQhrSWkqpnF
sjls45t/votmhL8boe2A6Cx9yiAWltPISL7+L1ENa88=</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="_cff48f58a529632fa8ac3dfea083b788" 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="#_31b68752d2edd4d195e9d1bdab9d1a6b"/></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="_31b68752d2edd4d195e9d1bdab9d1a6b"><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>MIIDPjCCAiagAwIBAgIJAOvpZtJNtQ/rMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMw
EQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNh
bWwudGVzdC5ub3BlMCAXDTE3MDgxNDAxNDg1N1oYDzIxMTYwMzA4MDE0ODU3WjBVMQswCQYDVQQG
EwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYD
VQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKfUlciw
DPCJ9JXy1NsxKfqyOfLQXFKKGgNKKRLzLAWO43GgQYrV67QaAny5LvgOa81KQOX4IvjJy0nd/VrO
6jG9pTdMR9vFHT0Tu3W1QUsyPPSQqpKXwb2ZCSXNghYD5gBrNtmOxAOs1Azx5qmIzBJ4F0RkRivc
dbXSfBUBLpCn1M285c4tk5SEvoRgBeisLJJDB7hmylA1V6/+BN+N6b3M+ZZG//CTvOjJKgnwkMAL
zXbPbQWa0kpbMLDMz8Kr2pODLKb3rGmdf4P6A9aA41k6L4clTsNdcK7ZwJ2fGF79WGzE6RLyBX2U
S3gPHUXt/WMQZXyULO3exiTDsQXWFf8CAwEAAaMPMA0wCwYDVR0PBAQDAgQQMA0GCSqGSIb3DQEB
CwUAA4IBAQB3fQZz2qNAo/wohPNaR2uAakLt25cKrsbgn3XwO+X+DRH4nqMSZkHdLGr82xD3i33B
LSQwXzFecEN+CA8SlpNoIXHwk6D6V3uEBSjKemZtJFCJqe8d+5qt3GV50AKmtEt2Nc7B94TN8xB5
EmZladnTJWcBgSuuz1hLXQQ02dJ3dDq8FMlyR70S2DTtuPu0i2/f6KtrlmmNsU24Aq+fCzEG43Nq
ShOMeM5rDxLsSJCtjfMRwG8YeyNf6cCMSMxYAJfrTyj+AS8RtZQNGF7tX+exEWHOf1C9CBzHtKRC
lBRL6zDjlpPCIDwcMFi8NXvaiVclxIq3XdfqxiGBBEldkhgZ</ds:X509Certificate></ds:X509Data></ds:KeyInfo><xenc:CipherData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#"><xenc:CipherValue>hnCCrXAB+bHtA/4pJyPEYg1CDpAdF1yyrV4t7ZTkSD+BJiQcPzIb2U6E8/TyClCZ89ylb17Hmq69sMQjds3YIeTtBv5qsKAs1GQ4oBpCSQxQ6Dkre/qYuX0QNoiGM04yuB7933TWFB21lqTkCk42UwnFVTcLxKXxk3T7rhTMfInLayQVD+JSVVCqxLS5/TtahKXPeoQlCERR/6z4LWQ+LHiSi9urMLJKfNLt8A6liFhBnc9+3miZwth3GYDUdF+g6TI4wiNC7e4wonOwFcgSmujd0S5mnLbupyuPt4RCTf+L/udMkQpcUg5vfUNwg+GfuHC/cf436qbf0Jrc+KD3FQ==</xenc:CipherValue></xenc:CipherData><xenc:ReferenceList><xenc:DataReference URI="#_cff48f58a529632fa8ac3dfea083b788"/></xenc:ReferenceList></xenc:EncryptedKey></saml2:EncryptedAssertion></saml2p:Response> ================================================ FILE: providertests/testdata/oktaenc_sp_encryption_cert.pem ================================================ -----BEGIN CERTIFICATE----- MIIDPjCCAiagAwIBAgIJAOvpZtJNtQ/rMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNV BAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3Qg Tm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgxNDAxNDg1N1oY DzIxMTYwMzA4MDE0ODU3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZv cm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRl c3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKfUlciwDPCJ 9JXy1NsxKfqyOfLQXFKKGgNKKRLzLAWO43GgQYrV67QaAny5LvgOa81KQOX4IvjJ y0nd/VrO6jG9pTdMR9vFHT0Tu3W1QUsyPPSQqpKXwb2ZCSXNghYD5gBrNtmOxAOs 1Azx5qmIzBJ4F0RkRivcdbXSfBUBLpCn1M285c4tk5SEvoRgBeisLJJDB7hmylA1 V6/+BN+N6b3M+ZZG//CTvOjJKgnwkMALzXbPbQWa0kpbMLDMz8Kr2pODLKb3rGmd f4P6A9aA41k6L4clTsNdcK7ZwJ2fGF79WGzE6RLyBX2US3gPHUXt/WMQZXyULO3e xiTDsQXWFf8CAwEAAaMPMA0wCwYDVR0PBAQDAgQQMA0GCSqGSIb3DQEBCwUAA4IB AQB3fQZz2qNAo/wohPNaR2uAakLt25cKrsbgn3XwO+X+DRH4nqMSZkHdLGr82xD3 i33BLSQwXzFecEN+CA8SlpNoIXHwk6D6V3uEBSjKemZtJFCJqe8d+5qt3GV50AKm tEt2Nc7B94TN8xB5EmZladnTJWcBgSuuz1hLXQQ02dJ3dDq8FMlyR70S2DTtuPu0 i2/f6KtrlmmNsU24Aq+fCzEG43NqShOMeM5rDxLsSJCtjfMRwG8YeyNf6cCMSMxY AJfrTyj+AS8RtZQNGF7tX+exEWHOf1C9CBzHtKRClBRL6zDjlpPCIDwcMFi8NXva iVclxIq3XdfqxiGBBEldkhgZ -----END CERTIFICATE----- ================================================ FILE: providertests/testdata/oktaenc_sp_encryption_key.pem ================================================ -----BEGIN PRIVATE KEY----- MIIEvAIBADANBgkqhkiG9w0BAQEFAASCBKYwggSiAgEAAoIBAQCn1JXIsAzwifSV 8tTbMSn6sjny0FxSihoDSikS8ywFjuNxoEGK1eu0GgJ8uS74DmvNSkDl+CL4yctJ 3f1azuoxvaU3TEfbxR09E7t1tUFLMjz0kKqSl8G9mQklzYIWA+YAazbZjsQDrNQM 8eapiMwSeBdEZEYr3HW10nwVAS6Qp9TNvOXOLZOUhL6EYAXorCySQwe4ZspQNVev /gTfjem9zPmWRv/wk7zoySoJ8JDAC812z20FmtJKWzCwzM/Cq9qTgyym96xpnX+D +gPWgONZOi+HJU7DXXCu2cCdnxhe/VhsxOkS8gV9lEt4Dx1F7f1jEGV8lCzt3sYk w7EF1hX/AgMBAAECggEATD8qZWiGGGm0csNFrOdjGQALj6LVrrILK19v1aogX84Q yrhxzm9ti/8dDijbi9qRY0zOuyvGR5z1/HMb/Ttv7nUoMD05kEC3Dd5/FfTo2w7R 3pIyzDKh1E9IdqIs7W+L+Li8zI4twzWriM4FaxQ5ElL4zxt3PcoEuDwOH0TQMOsy P2gLEhzzkFp7TRoKzR87sM6lXoERsGKh7XNWjjS15/w+XHMaDverOOALwWDbv32N UCdVSAGBx4Ic4mZuJv+e3MH2SAja0J6NLMzCMtrzmfcgVECykMnELi1XftZYbgD+ KulSvHuamygS4KJppnAdly8950C8CxI7fp9QJV/8UQKBgQDUaT68z9e203L/XATr sa9CgZodWvjrLH7a2e5EvUPq8slmg2VqEYNjHzP4rCoOcLul6TwrlNInxqTIkIPR mRxBSrG24azfGRrOs34IMTXgqfMVVxbcSVK8OijHs94NTwYrRjMXeaAOnKjPH484 DALrEoEGcrjXmDDKBV9rb+a5XQKBgQDKRVkUvCoILjsA3jG6qaKBwKSZBFla2o6x YxgOZdeSG2NEuMt74yRHjgV6iogpvw9i/FSY9TAaZsoX0L3I5LWRtwEi3iXtEC9X qFlS9EPr9encpdd2vu1O6aWXW4IlUWbu3ecdb5UAxu44ObUQS6HiXEfcK8vufF5l WyilXNerCwKBgAMYYYSo1rDgVe2orp2soiwq7U7+M2Bh7ptLz7AKvgGfdhXbVk/8 X1jDbKN0BszdEa7yPiE4cvOHboFJsdINFB9TclGC6lz55a0banu+E9XpRBSMh1XA b8c0ZcG7OkIhY6qfxEDUUePEnqUeBZ1Ad45rX5vzcgQaQKPA/kn3gHo1AoGAU/05 wSdk2KLBs1mQEq9PoEsqzbMFm3k3WScJnSjiu3ON48JMFDQ8I04wrjKJ2bPRIswe IKlnAP9/mSX/OETntArmeOD/pJFc5ywrcwukjH0/T3S5pEAhb+wK629++hn0AOm5 hvqHR5xS3JvxuEN/g+vHlv/EnVGdLL8OgKOtlgMCgYBU/5WF/7dr89uYzjiBvedh HQCgwd+8aSs+raY5eTzJrJgqVbEMoxhco1GWzWYUjDVw88Y63k+fqIf1DQJFkWFi 9T1nppVDeofoLDLTrh/2oTAHIM2QL6kWwoHiD7b/scF5z/rC21KqobqroAh2R0CP J2waRoJgqT+P15Lq3PEcSA== -----END PRIVATE KEY----- ================================================ FILE: providertests/testdata/oktaenc_sp_signing_cert.pem ================================================ -----BEGIN CERTIFICATE----- MIIDPjCCAiagAwIBAgIJAKHPtM2MqZxXMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNV BAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3Qg Tm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oY DzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZv cm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRl c3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBALWw8EP/dSG0 yy7cL2sQvcRqiTrsVCWzQ5SGgZNGbFJXq36pshZ21H7gFPI/K2n6m4I3vNMCQtRJ JwfjyrPbuXpVaTMcmg8J3PGUVzaab+dZ28EQ7V9HEnzcVbEgu87xY/SB6SCiJbdI COZWlsgLUkgZS9CFkw5q6i29nL6nSZw/MmNr1hjJWvVvs1KwnGjB2aF6wYBQKKsY GxfZTJqKKBGXwIB5qnaWpVQgP6+H/84YCHLUEKk1hgh9AnR1xNVE6e64clcAE+O/ HWDS6QW658TJsw18TapzVbiUGou4TlxJZqEuJv3BfPX3EMsnp0uRurMtwgyzI/ZP CCHxSMJs4xECAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IB AQBRwSaE1AnhZU/GzMngLSG6WsOp1NksoEHZsJoIKxUJWdMj9s0Pb/QSGg/W/2UU CREt6xBd9rh3jv17AwH6+IAvq/zQn36UtOE0/0v85Tp/I6t8v96cTjkEgDHBWSqw qfPvnrokKUpDRv1cxCL0qh4oW7selKkI0VpZOgpKm87oi6POQJ/KOMfcewlH+DXt zN3Es8Xp8BAfRRIEk7i3PqZSrhWUguQgCOAOvkb0tGuPDsFLLJJBML7B7aYrS1Kw EyuowZiDCDSk49KpGOmKYv2ocIG65gr7+am/l2NN+6cxuCf/o9H8UL8qm0LUJdgh 5sVa0DJzIcuOjWsp2QxqTjr/ -----END CERTIFICATE----- ================================================ FILE: providertests/testdata/oktaenc_sp_signing_key.pem ================================================ -----BEGIN PRIVATE KEY----- MIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQC1sPBD/3UhtMsu 3C9rEL3Eaok67FQls0OUhoGTRmxSV6t+qbIWdtR+4BTyPytp+puCN7zTAkLUSScH 48qz27l6VWkzHJoPCdzxlFc2mm/nWdvBEO1fRxJ83FWxILvO8WP0gekgoiW3SAjm VpbIC1JIGUvQhZMOauotvZy+p0mcPzJja9YYyVr1b7NSsJxowdmhesGAUCirGBsX 2UyaiigRl8CAeap2lqVUID+vh//OGAhy1BCpNYYIfQJ0dcTVROnuuHJXABPjvx1g 0ukFuufEybMNfE2qc1W4lBqLuE5cSWahLib9wXz19xDLJ6dLkbqzLcIMsyP2Twgh 8UjCbOMRAgMBAAECggEAA/py2FpQm0NVK5qAo0yDizh19sdT9FtfgHINhkcFeiwX Qje/AYTqlDid3MwLTE/Dde94f/pNsk5Dv4V6W8PU5NvX6NmYefnST6va2QQ6rQsn p6uSNwLcYcWFTtKTqi1Y7fKmQyOpxcCbCUgeFxVAYPnE0jUKikdHB2dedkI9d2FV ZMSBAlNp5NQQTTojjdvfa3yxFqB/5Gh+tZZnnXm0BmtSHjWvXnpi62Nz8LHtKwtO qzS6650vhbC8GyuILeBkEa0Zvw2aUhRI0grCjWsbXJT66FrV+pIElOAQvyHP6hlX zC43ODdXSiFogVkF07umlqmopv4gDLgst8fjY61VfQKBgQDpVytmVrNXI9A2uDv/ 0RhCZpmBMgz8o3OQY0KRtZqupeVUGCTKk0zNqxsvUg31fa+DLYu+fYUDRVy58ST7 vTiXjKYllWY5LAacsqtA/1E4BghOuYfU12tGJcOUM1TZNkQ/s2to/fDL0HTjYX6T STqxoyg9zCnSYpF+u7gj91QuywKBgQDHVcUGiL69Tws3J6riKvFBtqrqcJaRu5OS t/U+kqM1m5/GOaBpZyropeusQgb/nZHIE/lEur7CHYcTi8PKF2lGxnqWOn31LVrc rM11r2pweDpCBBQqytNoE9vUzgfueXbPPgl+l1pTDA02u6EE45IHC1bPPbjDx29/ xhfAykD+EwKBgQCrVA3Rvqc/vFQNWYj0dJrTZnIfophWh806nycpxaYlxjl0XaXl 9/HUsWXsgNsu/XH5Z1/MJm2b0TocbSsyi+UZoXP89I1yPRk9xRJpTw5bjFJdO2y4 otNpViEcl/Qc6PODskGTfaFohU7OBa/ihUpLU/kgJuAuUaFy5HJ4NgnhsQKBgQCm q/K4SfKiu8r27TYXMizT83bp3AYqCJuWHDb1gQryshNgXaLhPyBDsyhhuju70/an Qvw0GamTCbl+AGlPO1ANm7u4jWPwc2H8DoklE+196SldNaffOASYi7JON4+uOOW8 13R84vTlZ7hMwYobWmUperO1STiKiuGSBwKpcvPw/QKBgBgqByvETHwewxnYoIsp yn3Fz1KM7MMnRil2sXVTdpS6lpF+iGs7iXc8sBnWKxFFQWnvvx6VvhXw6lCCnEQX 3LH177jH+s0jVQgD+YZLnYDBF347tU7W/dPz5Df7hgmuQhOU/UV9ihm4udutRFbR 4fd3j6wIcv2MZ0iDUVJ0UFYr -----END PRIVATE KEY----- ================================================ FILE: providertests/testdata/onelogin/idp.signing.cert ================================================ -----BEGIN CERTIFICATE----- MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNV BAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3Qg Tm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oY DzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZv cm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRl c3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWF WQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6 IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI7 9AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9 /ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHq LTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRt JtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IB AQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGk qfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkh u7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6 simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooF dD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYI LGu96alI6+eLeIwZKpKSbMj4 -----END CERTIFICATE----- ================================================ FILE: providertests/testdata/onelogin/olgn09_response_01.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="pfx3b05d1fe-3b5d-ba02-fbf7-2c525c73ef54" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx3b05d1fe-3b5d-ba02-fbf7-2c525c73ef54"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>XRwVv9AoG/qSqUDu5c2K9lHwbwM=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>Oaxrfk2c5hSplmWoljpOaFlnQQXSamBcktNMjcepP5WYlvX2ybl7aa0ew81ettjtUyE0ym2antWtzwJI4arL5dGfHfPPQn9XJ/CvZG7YCiWPTkfc4jwqsm9OS3kafv/A0IoLOsffA3rFezu8fuCLixL92KNlNhRN/bryF9a7Fz7As20kOmp82mBMGuvL/APFOssxShmxb0NRvCMJCJkRAp837FKx+rn8RF/PbiFVZinRfO1qgMEsV/emnnf6awYzd6EPqSYX9FQ5jsKZn64nXXWyDV9YuAtDylo2kbO/XWDQcVB08MSfP9X2RWVTF/2rY2mc3lE0IEptr1nL45MZ3Q==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="id70938295375467671318387720" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
        <saml2:Subject xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:NameID Format="urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-30T23:19:41.379Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-30T23:09:41.379Z" NotOnOrAfter="2017-08-30T23:19:41.379Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_03.b64 ================================================ <saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="id70938295375022572142875469" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
    <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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="pfx983f40be-62ea-ce1f-85e8-29e11b861a73" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx983f40be-62ea-ce1f-85e8-29e11b861a73"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>FpK4vLjcp0o0gXeDdWD5xZX+lDA=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>megUggdW9YNcROqPoC08HuCtUefLhWVKWcpr1B3koSdg3I5+nxXbZK5C51vzV5sz7F6jTG/IlbsQxiu4ktma+aFbVpzaTfWENdGsuTZ2aB/Y32m7zE4+5Tj5Jzq/mSUULPawdsOn8w7WsHte99H3XNzhd/UP5vuiQJgImwPlQi2jJTi4MWW+N7CPEVoos5amNQTTuar7SQVGNi1aAcoQ8SW2VDT52zR3vq2umQZ6uHBa8k+LxacZyoAYUrEyXsBkdPFTJzEUDGmc0ZyBOShMi0/DfpYk6slsk1d0PNQ0sBUNbgu8h39cvLnZIYewu1NoqvEX2CJHwbfH89KQZxBKLg==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-30T23:19:41.379Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-30T23:09:41.379Z" NotOnOrAfter="2017-08-30T23:19:41.379Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_04.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="pfxe3c1d034-6274-5d03-8230-27ee318e523b" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfxe3c1d034-6274-5d03-8230-27ee318e523b"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>RKqFJyqdYqdDMAcPKfQnR2cF3tw=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>6EJS7VtT9c5wiHmq6iT2rLb0xif46jKHBMhWJusEf/8sB6A0GDY/nfrNzdZVxjD4NooI1SW6nggXT7qTffWzWVxtfnVp/jIuFVArlol07LsYvlABOL60V8c32IvzVi9dBb39IxwmWIzINA9xg29vLiV7782SmXZUnO2Cp2LdYlqKAwEy/WlHCF1EYVMzJjxOrHz55hOWxSAk0Y7XeKRXgo+ULTvqJwvvd9wH2YVe8Y7YAXD9BhOZuNBNLMpo+sOElLcOnHa8/fgDC2nOxxtU8DURHjj/4JGjCSRBSe+Nh5UGVBWiNvhiDm5OhFtGcbz6Ts7B3HZz7IATcX4D196glQ==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="pfxa87c2b4f-595b-f787-d0ac-b6111cf71e27" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfxa87c2b4f-595b-f787-d0ac-b6111cf71e27"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>hv0Gdk9yVQTualh4clen5UfdAM0=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>OCHUWaVne1U0PXAidIco27H5saZflf2jgb2xvAw4WUGZiERktPbIudgEhkyN67/K2U2kP4zAB6Faf8KnkVck6XpBIHD2Js7Tlkn8Dlc7gKAsbNhvHSVzIPnLTzQG+HclXfA2B0vpZNX3yi+WY9KIsWgMvsItTjTEEnyIFj2dZAtQrXArQLsgtNkgoFipxix6q3Yt4yyRe71XWMseuo5eEtTXS8+EKqOQntWLhc8nt2Vzam+VuEEsOF+K9y+Qgo0CzQG5OnvzY1SwPnGrTrhp2/OST2InEyJOLxJB1f5I3CbF+Yykv2Jysc/Ji0yFZ2YJyMa/JtCxSkycMDcdUm8Maw==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-30T23:19:41.379Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-30T23:09:41.379Z" NotOnOrAfter="2017-08-30T23:19:41.379Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_05.b64 ================================================ <saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="id70938295375022572142875469" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
    <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" xmlns:xs="http://www.w3.org/2001/XMLSchema"><xenc:EncryptedData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#" xmlns:dsig="http://www.w3.org/2000/09/xmldsig#" Type="http://www.w3.org/2001/04/xmlenc#Element"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes256-cbc"/><dsig:KeyInfo xmlns:dsig="http://www.w3.org/2000/09/xmldsig#"><xenc:EncryptedKey><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p"/><xenc:CipherData><xenc:CipherValue>U+iuyHwuGdR2+7P8pAazGl0RWrceY1RrVE1o1MrUY2FueVJ7Sr3UZJ/lBHFk29xu63UWK1NaABNUx685dQko7ckq1Z2RdviptDqi2T/fyw+Tney2HTuM7ILfNfZP1PHbZBnUpRoryQpKHKwCQ0FEq++uAG5DhfVnM20nB251O0RyEwz1Nw/gGBRyDD08khzE5vomK2UaAvuFu+5a0IH3YM2Y2yfcT+LxyIGc1gdmJhgUuYEbXg8RazU6GzYlrqpIuM0DIySuGND0r0o93FL4C3iDxE4crb9cZxd/GJ8rdOlFDjWgriSx+8M7sU6W61HrQEufavGc6DV68fHd/eEH3Q==</xenc:CipherValue></xenc:CipherData></xenc:EncryptedKey></dsig:KeyInfo>
   <xenc:CipherData>
      <xenc:CipherValue>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</xenc:CipherValue>
   </xenc:CipherData>
</xenc:EncryptedData></saml2:EncryptedAssertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_06.b64 ================================================ <saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="id70938295375022572142875469" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
    <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" xmlns:xs="http://www.w3.org/2001/XMLSchema"><xenc:EncryptedData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#" xmlns:dsig="http://www.w3.org/2000/09/xmldsig#" Type="http://www.w3.org/2001/04/xmlenc#Element"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes256-cbc"/><dsig:KeyInfo xmlns:dsig="http://www.w3.org/2000/09/xmldsig#"><xenc:EncryptedKey><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p"><dsig:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/></xenc:EncryptionMethod><dsig:KeyInfo><dsig:X509Data><dsig:X509Certificate>MIIDPjCCAiagAwIBAgIJAOvpZtJNtQ/rMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgxNDAxNDg1N1oYDzIxMTYwMzA4MDE0ODU3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKfUlciwDPCJ9JXy1NsxKfqyOfLQXFKKGgNKKRLzLAWO43GgQYrV67QaAny5LvgOa81KQOX4IvjJy0nd/VrO6jG9pTdMR9vFHT0Tu3W1QUsyPPSQqpKXwb2ZCSXNghYD5gBrNtmOxAOs1Azx5qmIzBJ4F0RkRivcdbXSfBUBLpCn1M285c4tk5SEvoRgBeisLJJDB7hmylA1V6/+BN+N6b3M+ZZG//CTvOjJKgnwkMALzXbPbQWa0kpbMLDMz8Kr2pODLKb3rGmdf4P6A9aA41k6L4clTsNdcK7ZwJ2fGF79WGzE6RLyBX2US3gPHUXt/WMQZXyULO3exiTDsQXWFf8CAwEAAaMPMA0wCwYDVR0PBAQDAgQQMA0GCSqGSIb3DQEBCwUAA4IBAQB3fQZz2qNAo/wohPNaR2uAakLt25cKrsbgn3XwO+X+DRH4nqMSZkHdLGr82xD3i33BLSQwXzFecEN+CA8SlpNoIXHwk6D6V3uEBSjKemZtJFCJqe8d+5qt3GV50AKmtEt2Nc7B94TN8xB5EmZladnTJWcBgSuuz1hLXQQ02dJ3dDq8FMlyR70S2DTtuPu0i2/f6KtrlmmNsU24Aq+fCzEG43NqShOMeM5rDxLsSJCtjfMRwG8YeyNf6cCMSMxYAJfrTyj+AS8RtZQNGF7tX+exEWHOf1C9CBzHtKRClBRL6zDjlpPCIDwcMFi8NXvaiVclxIq3XdfqxiGBBEldkhgZ</dsig:X509Certificate></dsig:X509Data></dsig:KeyInfo><xenc:CipherData><xenc:CipherValue>Ds9FxMuIUjbgHoTKTJL4XI5yYQIZLfTTWm4tXSiGL7xXvFGsnhhVNoft+DWlhxoeavKa9WPYzp0zWtAByh86+lw2/Z5GmOTWeXLelm24FqNfsY8Uu/K6KB8oe37IsXsR2fmhMJYQu7bjbUZCN3ICmwYLWh5uCVab7K9to7r0acxMf61XZYC4lsZFD4q4d+ylEmmbw/8hUiLHh+qOHCqjfSkHAQ+YOBUa6ZGQMvY5P4ZFhJZZ1PDfLJE/K90S/Yd0bkNotJ+DAXr5Jo2c0t6Dps5VW43C1yjAmtwTsjTiUnOqRTfQFbgilbg2m021OxpaQZah9b056hYxbchCypftbQ==</xenc:CipherValue></xenc:CipherData></xenc:EncryptedKey></dsig:KeyInfo>
   <xenc:CipherData>
      <xenc:CipherValue>++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</xenc:CipherValue>
   </xenc:CipherData>
</xenc:EncryptedData></saml2:EncryptedAssertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_07.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="pfx6c88e66e-3c00-e477-6aac-5d5012f95e6a" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx6c88e66e-3c00-e477-6aac-5d5012f95e6a"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>qQGzbWqCY4GhdgT30iNiXDyIfoc=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>32cvW4+7EpuvIaZBhmGr4XTdqSH3qpMYdMtYjBM5SwaOD1uL6kSmPApxmR5b2ordnVv65yxQrm7D6u0uIvDV/UBDh7+jEnVJ0GYduvlbSLIzcNFrlB7AZOObj1BoefIxKttqdqLGrH0+6X2saiNBVttUJJooq6uigNfZjTnF6Lbnz2QxyAy3JxFoNvGCnfxafSnSugPbhookUHIobMvPhvbnZsEU/yDqL4zV+DAdrm1hw4So/W7+TjVtcI9qXsLzZ2Qqk/v/08wTGP/xFgYl9JPf7DxyHAT4tf3DA1hHXA6EZDwNJGdSqVrbETL20axXI8jMVheQ5NxcWEc7+V1obw==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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" xmlns:xs="http://www.w3.org/2001/XMLSchema"><xenc:EncryptedData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#" xmlns:dsig="http://www.w3.org/2000/09/xmldsig#" Type="http://www.w3.org/2001/04/xmlenc#Element"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes256-cbc"/><dsig:KeyInfo xmlns:dsig="http://www.w3.org/2000/09/xmldsig#"><xenc:EncryptedKey><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p"><dsig:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/></xenc:EncryptionMethod><dsig:KeyInfo><dsig:X509Data><dsig:X509Certificate>MIIDPjCCAiagAwIBAgIJAOvpZtJNtQ/rMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgxNDAxNDg1N1oYDzIxMTYwMzA4MDE0ODU3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKfUlciwDPCJ9JXy1NsxKfqyOfLQXFKKGgNKKRLzLAWO43GgQYrV67QaAny5LvgOa81KQOX4IvjJy0nd/VrO6jG9pTdMR9vFHT0Tu3W1QUsyPPSQqpKXwb2ZCSXNghYD5gBrNtmOxAOs1Azx5qmIzBJ4F0RkRivcdbXSfBUBLpCn1M285c4tk5SEvoRgBeisLJJDB7hmylA1V6/+BN+N6b3M+ZZG//CTvOjJKgnwkMALzXbPbQWa0kpbMLDMz8Kr2pODLKb3rGmdf4P6A9aA41k6L4clTsNdcK7ZwJ2fGF79WGzE6RLyBX2US3gPHUXt/WMQZXyULO3exiTDsQXWFf8CAwEAAaMPMA0wCwYDVR0PBAQDAgQQMA0GCSqGSIb3DQEBCwUAA4IBAQB3fQZz2qNAo/wohPNaR2uAakLt25cKrsbgn3XwO+X+DRH4nqMSZkHdLGr82xD3i33BLSQwXzFecEN+CA8SlpNoIXHwk6D6V3uEBSjKemZtJFCJqe8d+5qt3GV50AKmtEt2Nc7B94TN8xB5EmZladnTJWcBgSuuz1hLXQQ02dJ3dDq8FMlyR70S2DTtuPu0i2/f6KtrlmmNsU24Aq+fCzEG43NqShOMeM5rDxLsSJCtjfMRwG8YeyNf6cCMSMxYAJfrTyj+AS8RtZQNGF7tX+exEWHOf1C9CBzHtKRClBRL6zDjlpPCIDwcMFi8NXvaiVclxIq3XdfqxiGBBEldkhgZ</dsig:X509Certificate></dsig:X509Data></dsig:KeyInfo><xenc:CipherData><xenc:CipherValue>H4YBHMpLw0XfFItUGJhVuowAbffXuv8lgSw7VcnHnZNNYAwSC4tU92wiwowsa8vTSY6pZLc+XsFmncsrKFP9oazPJbr8pHjBfSktIhUdxBm6ESii3ICnoV+BZvioem909WMEYTooGiwA8HjaYED8ju0eO5kCMP4NoyDN1vVrhSitV8z5Dviiy7EjOcTHoq8oEPQCF4zQ1PeuoZqlP7ECbRPYhu6PR7MkOwrdq5iInZoz8Py2MxNxSiOfPyvsk80s8IPnMEV4Y5GgauS0bvmqS5DynEb9TrOk7X2a7j15x6wBTLw9ye4OpGZE8VaOxaqPebFWl6AQ3aJxui3frpjH+Q==</xenc:CipherValue></xenc:CipherData></xenc:EncryptedKey></dsig:KeyInfo>
   <xenc:CipherData>
      <xenc:CipherValue>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</xenc:CipherValue>
   </xenc:CipherData>
</xenc:EncryptedData></saml2:EncryptedAssertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_08.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="pfx08d84baa-d18b-0064-fdde-74cde6f1db39" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx08d84baa-d18b-0064-fdde-74cde6f1db39"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>QJruT/BcXOTormZKlZZeg2dJUkg=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>haoeVow9E928ifFSxN+ESCi+rjbpiEEqE0gvIGvIeVGw+qq+l5yz86B2S+vi9aceMISFa4v8bd1d3A/UXaMGjQQ9xuKwukJ5qdAWRv1+oVr3aZMU94ShZAYPCOPHeavTY9cq8eVhBtOHSh3UXX+I8ODF3IyUgCK3RCFOt4BvrVlYTeOY6qK+fknDaR6xEwSS+iOAN3+ioOklVxmjkWsx8iNVz442vpzqgnmpwmdpuAzrMImWHrFqDkYbthYSv+/EYIzRV2okP6TLCBnoFgBv1QRsNSz1QbOYws47hQIRxlLhFyTNkEu6kYtGP8Fhc+ZyJPPjU7jV1UkJpvCaAqVpcg==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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" xmlns:xs="http://www.w3.org/2001/XMLSchema"><xenc:EncryptedData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#" xmlns:dsig="http://www.w3.org/2000/09/xmldsig#" Type="http://www.w3.org/2001/04/xmlenc#Element"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes256-cbc"/><dsig:KeyInfo xmlns:dsig="http://www.w3.org/2000/09/xmldsig#"><xenc:EncryptedKey><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p"><dsig:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/></xenc:EncryptionMethod><dsig:KeyInfo><dsig:X509Data><dsig:X509Certificate>MIIDPjCCAiagAwIBAgIJAOvpZtJNtQ/rMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgxNDAxNDg1N1oYDzIxMTYwMzA4MDE0ODU3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKfUlciwDPCJ9JXy1NsxKfqyOfLQXFKKGgNKKRLzLAWO43GgQYrV67QaAny5LvgOa81KQOX4IvjJy0nd/VrO6jG9pTdMR9vFHT0Tu3W1QUsyPPSQqpKXwb2ZCSXNghYD5gBrNtmOxAOs1Azx5qmIzBJ4F0RkRivcdbXSfBUBLpCn1M285c4tk5SEvoRgBeisLJJDB7hmylA1V6/+BN+N6b3M+ZZG//CTvOjJKgnwkMALzXbPbQWa0kpbMLDMz8Kr2pODLKb3rGmdf4P6A9aA41k6L4clTsNdcK7ZwJ2fGF79WGzE6RLyBX2US3gPHUXt/WMQZXyULO3exiTDsQXWFf8CAwEAAaMPMA0wCwYDVR0PBAQDAgQQMA0GCSqGSIb3DQEBCwUAA4IBAQB3fQZz2qNAo/wohPNaR2uAakLt25cKrsbgn3XwO+X+DRH4nqMSZkHdLGr82xD3i33BLSQwXzFecEN+CA8SlpNoIXHwk6D6V3uEBSjKemZtJFCJqe8d+5qt3GV50AKmtEt2Nc7B94TN8xB5EmZladnTJWcBgSuuz1hLXQQ02dJ3dDq8FMlyR70S2DTtuPu0i2/f6KtrlmmNsU24Aq+fCzEG43NqShOMeM5rDxLsSJCtjfMRwG8YeyNf6cCMSMxYAJfrTyj+AS8RtZQNGF7tX+exEWHOf1C9CBzHtKRClBRL6zDjlpPCIDwcMFi8NXvaiVclxIq3XdfqxiGBBEldkhgZ</dsig:X509Certificate></dsig:X509Data></dsig:KeyInfo><xenc:CipherData><xenc:CipherValue>Ds9FxMuIUjbgHoTKTJL4XI5yYQIZLfTTWm4tXSiGL7xXvFGsnhhVNoft+DWlhxoeavKa9WPYzp0zWtAByh86+lw2/Z5GmOTWeXLelm24FqNfsY8Uu/K6KB8oe37IsXsR2fmhMJYQu7bjbUZCN3ICmwYLWh5uCVab7K9to7r0acxMf61XZYC4lsZFD4q4d+ylEmmbw/8hUiLHh+qOHCqjfSkHAQ+YOBUa6ZGQMvY5P4ZFhJZZ1PDfLJE/K90S/Yd0bkNotJ+DAXr5Jo2c0t6Dps5VW43C1yjAmtwTsjTiUnOqRTfQFbgilbg2m021OxpaQZah9b056hYxbchCypftbQ==</xenc:CipherValue></xenc:CipherData></xenc:EncryptedKey></dsig:KeyInfo>
   <xenc:CipherData>
      <xenc:CipherValue>++QTXufoEZHCas1PHIf5YHqMZggycYXDR5MmbAWc9iyAKFb47uwHjteJx0rmB7wUjbwUhYjlZuRkGrTQCRK05eLRieYazq71MtYVGULnWMjMLXmVbT2IGjVDNDqVTJzbHOAiB6eKZed1nHaMxkslKgG1GngcgIu4Uwh1jqZdKAyjAqlFrvUQlcwrXwYsF0x+wa2OKAIltUugl8ur+/UzdPLEdNRmGZCyaNC82E3g39jonxP6VVlgORplwssgUTTEws1P4CajQv61LpD8T+R4zB21t+6ShYANW8OK6/7Q3pbDAksNISh9JNUdSOC4Zos/2LfAx7RzRjUTu/ItRD3Fbk7FC5Du2XZ4SbOFY0tvTwLUECT8FZHtlOxNfanHElzXm9T6KOEWPpKo3BgLo82OPOzcAviy0hnnX65iywafm2oAc0Rm0UcF9fn9wQLT3wGVSS9+R4o0JncN4iUohyuI5wICX30Xg1tBNw/fESmG+N5bde1wH0dJcguDof8VOuv1zh4bnOtEAmitbz9dbJDH/X+/w0rDsg+LEAss3nFesR8rX9nyi7bYKrF2tKTrXqBdZBQ5rKH/W3WOgA5W7dyXiC30fB0L3stVX8AI+5pc9vXaqXk+abUww6k1RpxCvtNVhb0FXnyf4HRcRps8Dsc8I7WX5tHYW9aA7vdWO10H+fVF8rGK+FQR0HlX8iPDcboCB0U32HtFUmHYOyiDz8AqRS3u0+tccmm3rPeJQWVjUu+3gYMqZ+BiTEf/BEAhZcb9b2CSmzUCbiP+tpOXcRlexOf5HWJ0KkjcbUhwT5/Ted+XP8RxP0BCno59uiK9mdR5lP/4cO86xL3joy/5ao0OJBfXPGuwbGgnd3CigQ5Q7iybhFCcOhunQNRh/wKdl0LOoogPwTrzcohGM6lsjFZjW3vcbb+uxlFgstEYSH1CoFkHQ5uyIder8wkH4LhzpZV/ayXQtFtOX5JXPFujmmrgahQiZKv1P0UVa+9KFekLNqurMwOddcm3R+CQ1M1mU05gD+1A2pERxF0oA8sJ3EO/RR++av54vU8/xujM3paYjNAvJeyQOK5x0uqXS4tB+/bSPjDUuANDmPTv4OqL9k/gP+c30lO8144mkxQJ7Aplc+0sPJkuI/O6d5L0+F1DbotgHwg2MT51TIFakCjSuDS28NYbKm3iOSEEooo5NszVhrQ0kvu9H5zukYamc3Uq6trdHTRPANtjrtc6KHmqWAdo0iJIsubDUzmKnPGJ5FNc9DInYySfU9KkhF+sdLSt7ZE+IKznfhh0XYHupx0OQwkw5XlQBzelWmI7EmF1XEpwe2CpZno3SAihGru0UlVeFRfeArg83D9vbOugxCL00ti5c8Yah4Xs/WPhpLpHhpZCma2KHBU/k4wwMIZTcmuFMw2jjDSThc2z22DBopOIgvK138fZs2thXI2zCZcGxcRZHIUbSMV6irc8EoxUtbDJSEfwK8yBPDEryxU8leIsN3xBuLJXx5189l70AFUK/l6YvcYlSNPFFIzeLlnWOobRg8IOTVasN05cvXGLzQN84VfW+eSw3z9KnvGGTT9YnVgCmRbW1ZC4fsEngA0ckv37CGHcp8sW1V3/8962BfDA+va9DRJLlY8udxwOBbH8+Fi/JD6F1EpLwfr3Dyn7KrjRkaCk4Jb/q79MKh0wJctNGGx7WcvkhbH5TVFlpzqxoOgAzgO/WKoN6QWgaBOon0Xsf6gbwD5xm4x5FLNdYicSdO29X/m+Kcz8TzSvxM4TIMvbdhxeS2LL/q583sLniTRkFulpAZ7bhqvMYwEbls1R5lA1Id2SQgkFXCh/qSx9m8RU7Y6qg7gjHa5Vt7W5q/bAt2X6oWu+0jR5n7/glVVaMJcJmAD1kzNAVpv06aY5azyA91cyRVMMokw5jXuEcfA88BHB7uX5L4Enaab6Yo7OHkHmyq95NOJcweDU45A+tnM+Vlp6yAVCCdZJ8QQALTjj9saPujzUXJdD6zFSUx38JlFkWnVYU0+wYFRynShxUmiWQHZvrvVFUUU7l5l74Nz1GfXj0+3mL0BaI/YAyBrs6fI9cHjBYS3hDjC6F/CpnaFV8UWX+uujeZ0DhfEqL3phRKoxkrKx+5iAhka2IjhoJH6+VzkMR8MV2jnTlUMgDuGnAHpXEodGdMD71jWwFQzJ547yk+Yzl74+3uiWKCtkfHC52EW5vVzGe39NLL0sQSupBVW3xF+yQ7UCHekON0CsN/Vti2CTZFOsNW4+iXnaENuQtyN7XTmLKE3j5D5Dsc9BChHuvo7AWeb0dOt0MEqmkt/H5z/TJ2WVn6GzoqpBSdJajcAOEYHzt+5s6GdClSgISFM8Dwi9zzmYRGaAVDSjDWsjzVghq4c3+nktO5hZn7tHNx8DFNvNEPs6yBf0Z/SOx4ly9A0dnmckFqbWGJnUq8PUMfdClvl8STSmtAdR6iYLrH9hv9z3j3b/50d5nVO+2gAIurZvBJlTPNACXuP4rOxdD9wOdd1cKxZ0dfu0/2Vdjmxb/R7VQt3FhospeBCzeD5PYOSQOOWUsA/a3whwDS5bTcso0ubYgjFNFltdfME8MVlR0Rfn3vr0nO01WDhJTa61njqtHxSV4VkKCih/0NvNIeP4D7znJBmhXGJHYq7duUGqoFGLvPJAfwbQRsodn6rY1Tm28rvsY5Ej+ffQjyQGzaKY7e0nOGOlwIASUKDgHxsNEB8Zk+cKD2Vr8iPZ7pdzj68a+8h3ZbaGCGBAxNM7e9S5+c5n34ZEFVUg5Oe0V2Z/IVUFlkQASs4KsvwEZfKueHx4R+a2P49uJqn3AZBjc5CunlBmbD0pInRKBj0yMeH/Dg9R+5PC+gwM2cZjfQ1ZV3sW9bS5VxtODOBl/Zk/PQ3RGDkAiHYvGlhkzwbMo9lffuPzwFNFNYYqaW4gz1tnuBaNjx5LnQ00JAo14Ylk6X+7/jik0jwyoFwR0IVQTh2EPs+J2CbqTa419/LU5TsFRPM2FePH6MyH16+KWby1D2k3LGR2x8r4k4s3l47eznTPKILu1E7QHHQY06Tekwyhnm7e96joCpy+QVDidlXz6fzIxIi10or33Ud7rO7xO3lHHJrcWWo8PUhl6/xVQDx7MWihXnJExwHdSPmV3dEz0Oi6ZbQbvQeU9okdTutfNXNfTEsWwA4nsEu3UyINMhbb4aEJ7xGTxg2AQghzNWJ44KbmlJ4ouM2Xzlebw4R8H7BzZBwX/Z+Ud02uW6+4VI+QdjonUl2Jg7Fp7r5Mn+h+9e8pKSrHC6PEK/mmfp3q3+Krgm3t90htGCWT4VmLVl2IUDRmdd7caSGC1YVuKg4UcY+48u6m3x73Z850KJlRbwTo4amMR1HIyOCI+LO0EWvQY7w5bzy+SFb7kHztHZqRDIDRAP02HjiMifsTqTR+C7hEEupDchs7Jyt7WbUh9SVkaSZSn9nDmfcMo0eoNWUeSnKxfqmrA1Fdh73usowplDlzGExR8MVAcjeCbs18Xgw7+J54Gx3hX/+ajsTlBn44b8dMZ3vm0NIP36bmQCswt+diamBliVcn4+Bt9quI5Sl9buFndgYDWu+jL4/+eBAgAfWelEP62i11aV33ihCvLHXR6MgGXn0CuqYT4BMWZzeUs4J5cdqmjCC/LYI8dT9m/0/qAIxLl5oIw1fCu8ws7JuS9BUjfvYEGCNQ7Aus/h+lrWuN0RjXCq6xCG6E3LGJSSPLkg6DUuiW4Ipr1C0pG86ef8SCrCq0CgrKibnfNicnYaGDm3aFl4XWhKgSL3bUzxtx3owaT0FB8webLcagcwafca+SQww5FBt64n7s/rzZ2U9Td1yvEp1ZWN0L0sDjvxnmT+iCDvoUydE09A2I+2LDD63Zeu7fJ2iYKAzUrWTIp1CkAUJSRMYYrD6DseAC1aUqhTCsH7EGthZBHMQ3FJ1FwDN6KvHekx0WrZTVGaamJqrnYu9KRTsb0r+Hf0w7xg1towmy7MNSr7RlfMxn6YV2E4bcs6g7LMLiDIBv7XaqX1DOvmYv2kjL+wJFfUEzP8UD/xt/kjRSI8EDnHhX5gCVCMYi7ncKuV7h2GSvt8z8p7IyKWSPQ7MbP/V69CRlA4JA79fFldG8Ln/Xql2tcXdqjIos2CIu5O3vOWE7kFcj3iNBdsq7dpfuWUyNVt0zeMBSR6Q/FjfpQR0i+ukW4sy8X5bYBjAHWcB1F42N+iVp4Wy58SECVrtrKTOnVRk3yxMkOEgizKqg03460AQ79NiGbaH3HZO7Y3NP86JuTwjCFQTq1JInkZ1LVibBQAcwRIDwjx/l+O+y8Sf0VLWjHrLaqlwHRB3D6ew3ec1piNHXyob1TSTgFqLDGFm73Iv1JNrqxi7moly5IduoIH9nQosaT8Wyi5Jh+WGjBwfwZe3/56pRfig+WYhdrBqEIBMjYCVU5sls6oItsIfQMwk6bLwFgs9cVAKXwnsZIDCZyqO93ASRCkSfg7eAbyHZasFgao4bbhFy08+aEAESvf3F1oqNqZ67KusFM/6spKPF0w5WktowJzt7dGseyKSs7xfPUEgjBigJuKa/Zm6rCe3l8cZcN2qdYX4j9UXYh5HylEupk44rqls6mi0/4aDrDTW3LsqcHo3nPXdJMi8PRbHgVwTtNQpTMtdAY0WfdZg7BTgbpX9Fz9GbBIxA26jZq+iF2O/MziF4Qr+M+aye/mnTptxQ3rKEhNiDYHAEGxvmJDwOK6waaF5urfhjHtJ5g+qgFEQO2UdxXXrmjMNCzkm6nF1GNmPA588rZB29wINrYnV7+Nl4Vu2/WABE6NJ0HnatkpbPOelda2czA2yiQQnxsrRpCtyxfWEWB9eiFUJyV53rpCX1JjkY9qrsoZAXrQMLB92+ePCVVu37XirZQSBq8ibSRQIxabnef4LmxuJhGUfvCP9CpryS2bOYoNPnoMri6BoLefJQ5bInlqEj7Lm8m78eok0zU9TkJiph0e6HLfNg3cqnHDGr5bR1jw2mWt0/tYrfZ1pDnbPF0APAfk3tLOVLO57A66oyV6KLFDE9abe2bCsCqVg8SXpTzU8PJHAxJajHRa7QCSGWgx5mRgq6b4o/AWogOa+Q7y+8WgSvHCwDu4EWzDrvt87p5o9YuqkR3tc3PhOPCXEkOfL4dAYk5Oa96HQ5Jm9229tUpPBy4jTh+i+nGSKQqL8uWXBAps6hBEQE62ekxgcqt9QcCJ6bMha8H0VN928s3Ee77yJMFaq53+rB8LGdUqdzcHcrC9GMNZXJdXhQH5dXR1CH7hi/pRSQNDJqIzsrR+NQYZuEA20Hz5gTDjYqIeVAr4n7As4+nCnC4pzTsm3Co7qH5fWfQy+Pg4MctrE7vvIUHxjIzMAQS2bKQbVyAqickCP/8WYoP7AwLPNVmcQLNTeBWAOG0D4YFmQiD5RHSpubPtW4yMHyVE1SPJFOJN0Ok6/t2RT4eM3UBuAjqUyLshSSpYYRclL4rGb6pXryg7LhYYseDdMIdrBPEbqEggNTq++YeNaJEP02zbnSlnbe9wRNb9bJPJY5pjfMcQlEqvLz8zXJL3ZyunxJZzmWatYHHXvDZ+/yPkf/zM963D5wiiRtob3drDMEgmf0DgdVecG7Qbtz593KpR4RnvlHiwlhILNfzBbHnVJsvuSA2WDWuoX9iQakXen2dXLijTgDPxf7a3f/IENBFnYF0xFdRWiO0yT9MUJ8MF/0AWhX2XA7/qQqJl8CLJQmTtOcp+vgW93qKgUns9pVaRqEMUlxWxmDJKySzom//NjId3Yjx3sPGoBFWlbgmCmyVfC2M9r2Y0DNlS8bl8kVYEWXKoFaXds/gcB6KfYOvn9Ftt7EgCwfLe8IT1lYcXhKckoomu+Q9SfVaLDc7ziDaajFQCo8rL4L8xSHuP1Ofi+GV8kq2OZ+P+5MB/ihiUwdS6Xpyz3PsCjINdM8nlgTnkmq33PwlAbOnyiLfR000YfMiDkgJJgQlTImtB4Lz3Bb2BqK4iNc2kSCGQTPXn4bWBGUSwV0xcR66d3zLvJXlU0i1fwZRch4Nsz2ZtZkLN0PjJjoRTAghVIkYwcHsKV5kgMRMvd6TohjaXJnZ5E3xU7JNjxqW0pSiFJKh/Lm+paBiratErv8HJOfvFVEZRBK3gFMB96rqG86fAHvVynIIu2UuCkWYRjDQjwEqh1w8GuAeiWQMu1rS1yWmP56eayb+3hCk9GsuhpRHtq2MZyOm8sCdGgizEmGYLiMEC1MXh6xW3cRgJL+PTMhvCDti/XnGf9R51mP84mWpPOPlACN1dieDlnV3IHLTZLYlzPt3emSgVp3o+Wbbw05ExHSWc8ZGaIoS+RcS5CWmbB9K72lDRRv4FZWri3Jjk2/4mX8GV08XwzZU6wEoNdFbw0uQnFiAYhorX5i4arH9gTpWXZVGNJXalmZOXozyLadI++fQ1LK4VEw5mYy33vqwQM6Bzh4A0I1snK3L1kLp2CEtCosdP+jLL7Ho1TUhBqPwy10RLSYbG3wnVmN6BdkV8zSPsliUsjKQFmIO7ODOkyjZZQJSVmb0rtsqgDfdphhxMusgveCThSojmc7mM7UMmDbORavO1BZ+Prm/TIVLkB6N52hSMw8AgQdRlEuoSuCdNc6AirUCFH7rExYecRO6kRw4aXz5ziBHzoeB5Nl7tFklTHIzQ2triufTxPlhPvF6GmvX7JL7CKEjOc2ZeHLEsQMvqPF56EFAzGr1uwCtBcymk1Sos/Bl/q9pReqMq2GiEZfn71nGItNQNeQhbpI6opOe0xv5rkjKenM8a4TlBfD+7j6lxoPZ5y2Jgf6dRWcJsQD3d4+InvC9SL2V1Y0mePf3vsEbo6lXDPg1FN7HYuZgD2vyPIzRF0Fg3nNmnkqPI4lCbysG7j2Gu4CZPNDLFWW/bbE/+FdsN/FiZ8drUq6SsF0+xk2jq/g/YQnCtBN/42lIVEl3cfnatTsKqV5fzdzF1FyGs1BgjffHx7D745u4kaNp8KfWA5Urymzg5RcFkZP25mZ2MP77yDOYW4VdCW/EanvKHgrGVLAe3I31kkljEhgCFlZ2yjexspC3Dqse8Ha/y9fNS7z9T5OhzsNODV7DWiKmxwYp64LmqwpUBJ41Md/ps/uyYYvMf1YvpbsztniJVROcnrk/Snsveb2rS2sh63HNII7A1S5R18JD1PMQI5PTD8lN5aXIG9GBLXsK7xo7GUh8SOnOLd6pB9I7b0R8WsP05fXfIjaQtrCWkzB8sbj5rc4I3lZ7roLezU2yT64ON6UUzoCjXYo6iDHjuW4uxyvt/C+2DHRnuRYItiIphx2KEemWef4vVYvC9MhraisQc9by8DdNMUMl1bodbUj7ZlSyghSXBTccCof+Wxev3yd</xenc:CipherValue>
   </xenc:CipherData>
</xenc:EncryptedData></saml2:EncryptedAssertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_09.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="pfx09eab023-777a-cc46-d68f-d8bc3912c9f6" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx09eab023-777a-cc46-d68f-d8bc3912c9f6"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>UDbmr6842UpLZK4IN8sYIyj/NCw=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>dA+lemnWX9sYCUJQ+NqjrXv88zIYGYyREtXBSA+Z39NQsoHoB6VpPcyktPX+p2ziwB/5HeWFyVJ8cLdEMZys3CJXhbANQNMwZQoEEoOSw9IQFOlRNB/WSXPKCRL60fprTB6JnWo1Q/b4zrtd/gbJFGoiZMDswJw5slL8/22VIqKyz6+ZriBPCHCxZkD5jklp03f9xHrBlz1vRuSXXYANgkl0CkrX3Cp7gvBRH/TiNdniZirJqiP5nzQHFLyprzTF1n9KC3dbBxtG5In9cAOjebyaE3lAPIjUq2mtx6Iw6wKTmt8wkJsXi9GGHJ9Uh7tJuMfgnBpj96vQiY4nNo/isw==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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" xmlns:xs="http://www.w3.org/2001/XMLSchema"><xenc:EncryptedData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#" xmlns:dsig="http://www.w3.org/2000/09/xmldsig#" Type="http://www.w3.org/2001/04/xmlenc#Element"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes256-cbc"/><dsig:KeyInfo xmlns:dsig="http://www.w3.org/2000/09/xmldsig#"><xenc:EncryptedKey><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p"/><xenc:CipherData><xenc:CipherValue>U+iuyHwuGdR2+7P8pAazGl0RWrceY1RrVE1o1MrUY2FueVJ7Sr3UZJ/lBHFk29xu63UWK1NaABNUx685dQko7ckq1Z2RdviptDqi2T/fyw+Tney2HTuM7ILfNfZP1PHbZBnUpRoryQpKHKwCQ0FEq++uAG5DhfVnM20nB251O0RyEwz1Nw/gGBRyDD08khzE5vomK2UaAvuFu+5a0IH3YM2Y2yfcT+LxyIGc1gdmJhgUuYEbXg8RazU6GzYlrqpIuM0DIySuGND0r0o93FL4C3iDxE4crb9cZxd/GJ8rdOlFDjWgriSx+8M7sU6W61HrQEufavGc6DV68fHd/eEH3Q==</xenc:CipherValue></xenc:CipherData></xenc:EncryptedKey></dsig:KeyInfo>
   <xenc:CipherData>
      <xenc:CipherValue>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</xenc:CipherValue>
   </xenc:CipherData>
</xenc:EncryptedData></saml2:EncryptedAssertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_11.b64 ================================================ PD94bWwgdmVyc2lvbj0iMS4wIj8+CjxzYW1sMnA6UmVzcG9uc2UgeG1sbnM6c2FtbDJwPSJ1cm46 b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiIERlc3RpbmF0aW9uPSJodHRwczovL3Nh bWwuc3Aubm9wZS9zZXNzaW9uL3Nzby9zYW1sL2Fjcy9ycTVqd2t2Yjh6IiBJRD0icGZ4M2IwNWQx ZmUtM2I1ZC1iYTAyLWZiZjctMmM1MjVjNzNlZjU0IiBJblJlc3BvbnNlVG89ImlkLTUzMWIyYmYw MmFlMGE1ODhjMzAyMzQxNjNhZGJmZDlkNmJiZjA3NDciIElzc3VlSW5zdGFudD0iMjAxNy0wOC0z MFQyMzoxNDo0MS4zNzlaIiBWZXJzaW9uPSIyLjAiPgogICAgPHNhbWwyOklzc3VlciB4bWxuczpz YW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiIgRm9ybWF0PSJ1cm46 b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6bmFtZWlkLWZvcm1hdDplbnRpdHkiPmh0dHBzOi8vc2Ft bC5pZHAubm9wZS9oOWdranp2YjNlPC9zYW1sMjpJc3N1ZXI+PGRzOlNpZ25hdHVyZSB4bWxuczpk cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8wOS94bWxkc2lnIyI+CiAgPGRzOlNpZ25lZEluZm8+ PGRzOkNhbm9uaWNhbGl6YXRpb25NZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8y MDAxLzEwL3htbC1leGMtYzE0biMiLz4KICAgIDxkczpTaWduYXR1cmVNZXRob2QgQWxnb3JpdGht PSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjcnNhLXNoYTEiLz4KICA8ZHM6UmVm ZXJlbmNlIFVSST0iI3BmeDNiMDVkMWZlLTNiNWQtYmEwMi1mYmY3LTJjNTI1YzczZWY1NCI+PGRz OlRyYW5zZm9ybXM+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIw MDAvMDkveG1sZHNpZyNlbnZlbG9wZWQtc2lnbmF0dXJlIi8+PGRzOlRyYW5zZm9ybSBBbGdvcml0 aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvMTAveG1sLWV4Yy1jMTRuIyIvPjwvZHM6VHJhbnNm b3Jtcz48ZHM6RGlnZXN0TWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8w OS94bWxkc2lnI3NoYTEiLz48ZHM6RGlnZXN0VmFsdWU+WFJ3VnY5QW9HL3FTcVVEdTVjMks5bEh3 YndNPTwvZHM6RGlnZXN0VmFsdWU+PC9kczpSZWZlcmVuY2U+PC9kczpTaWduZWRJbmZvPjxkczpT aWduYXR1cmVWYWx1ZT5PYXhyZmsyYzVoU3BsbVdvbGpwT2FGbG5RUVhTYW1CY2t0Tk1qY2VwUDVX WWx2WDJ5Ymw3YWEwZXc4MWV0dGp0VXlFMHltMmFudFd0endKSTRhckw1ZEdmSGZQUFFuOVhKL0N2 Wkc3WUNpV1BUa2ZjNGp3cXNtOU9TM2thZnYvQTBJb0xPc2ZmQTNyRmV6dThmdUNMaXhMOTJLTmxO aFJOL2JyeUY5YTdGejdBczIwa09tcDgybUJNR3V2TC9BUEZPc3N4U2hteGIwTlJ2Q01KQ0prUkFw ODM3Rkt4K3JuOFJGL1BiaUZWWmluUmZPMXFnTUVzVi9lbW5uZjZhd1l6ZDZFUHFTWVg5RlE1anNL Wm42NG5YWFd5RFY5WXVBdER5bG8ya2JPL1hXRFFjVkIwOE1TZlA5WDJSV1ZURi8yclkybWMzbEUw SUVwdHIxbkw0NU1aM1E9PTwvZHM6U2lnbmF0dXJlVmFsdWU+CjxkczpLZXlJbmZvPjxkczpYNTA5 RGF0YT48ZHM6WDUwOUNlcnRpZmljYXRlPk1JSURQakNDQWlhZ0F3SUJBZ0lKQU1RZVduREpWYVR5 TUEwR0NTcUdTSWIzRFFFQkN3VUFNRlV4Q3pBSkJnTlZCQVlUQWxWVE1STXdFUVlEVlFRSUV3cERZ V3hwWm05eWJtbGhNUmd3RmdZRFZRUUtFdzlUUVUxTUlGUmxjM1FnVG05d1pTNHhGekFWQmdOVkJB TVREbk5oYld3dWRHVnpkQzV1YjNCbE1DQVhEVEUzTURnd09ERTNOREl5TjFvWUR6SXhNVGN3TnpF MU1UYzBNakkzV2pCVk1Rc3dDUVlEVlFRR0V3SlZVekVUTUJFR0ExVUVDQk1LUTJGc2FXWnZjbTVw WVRFWU1CWUdBMVVFQ2hNUFUwRk5UQ0JVWlhOMElFNXZjR1V1TVJjd0ZRWURWUVFERXc1ellXMXNM blJsYzNRdWJtOXdaVENDQVNJd0RRWUpLb1pJaHZjTkFRRUJCUUFEZ2dFUEFEQ0NBUW9DZ2dFQkFP d1ZWWEU2N2RXRldRR25GeVdMUXlhQXFjbytoYXJnSE5xNURXVGlRTTVFRzFHRUx0NVFxVzdYUUp3 Z3dmSUhpYzd6TUJEVTEzRjZJVXJoMzEwZ05tME55Z2c3RFdFUkVCTlp2VGRqZzk5OXBiUnl0NUln ZWloS2g1TkV3cEg5VEdYbmJvdzhRakk3OUFxc0I5SXJuMGZFdUxLYjFLT0YwRU10NVhxSm5XMm9x SnJ2VGRZZUdvaTdDa3BnOUo5ODZYTXFMTXA0OEdkOS9BVG84M0dIc083dytOS3MwbUF4Qi9UZmZo NmhyYklMdE1WTUVOUUI2bHYzZElyZG1RcVBHSjEyMHhPNmRtSHFMVGordE5Tamhrem5TS1hCREhU Lzd2R3QzUmEzOFA2bUdDS3JEQWxvQXoyWGRYSmNkaVk1N1B4ZVF2YzB6d1J0SnRPeHBoQTVXSE1D QXdFQUFhTVBNQTB3Q3dZRFZSMFBCQVFEQWdlQU1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQkFRQVEy UDlhVUJhTTFrQzBYSkY4NkE0YVlrcVJWdXlzcEpUNitET1lBL3BjaWZaM3pocFhQZTIrVFkyZ0tz R2txZlltYTdjaDZkcTR6VkVyRk13a244cU03UEQxa25LL1A4U1p1VVBDM0xUSDNFVEgrYmViMWxN OU5JQ09JdGtodTdSSXd3d3doQVpLUDUyL1d3MEY1OVBDdjFTUFpKMU5rRjhYV2FrNERmOGw0dW40 eHNYMWpjRmtGbFV4Q0RoNnNpbWRGT0szaWJNSFVaeHlHYnZLL013SmZLUW1NY2pvL2ZJYXVrdjEv MnRLWG5pbFNEaFFTMTE2MXlpWDdvb0ZkRCt5NTVLYUdGNU81MEsvOURXMzBFOVpnclNEbHRELzZh R3QxN1ZyWDV3bmtvVWI2OENxWWZVclJqaHBiUFlJTEd1OTZhbEk2K2VMZUl3WktwS1NiTWo0PC9k czpYNTA5Q2VydGlmaWNhdGU+PC9kczpYNTA5RGF0YT48L2RzOktleUluZm8+PC9kczpTaWduYXR1 cmU+CiAgICA8c2FtbDJwOlN0YXR1cyB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpT QU1MOjIuMDpwcm90b2NvbCI+CiAgICAgICAgPHNhbWwycDpTdGF0dXNDb2RlIFZhbHVlPSJ1cm46 b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6c3RhdHVzOlN1Y2Nlc3MiLz4KICAgIDwvc2FtbDJwOlN0 YXR1cz4KICAgIDxzYW1sMjpBc3NlcnRpb24geG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0 YzpTQU1MOjIuMDphc3NlcnRpb24iIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hN TFNjaGVtYSIgSUQ9ImlkNzA5MzgyOTUzNzU0Njc2NzEzMTgzODc3MjAiIElzc3VlSW5zdGFudD0i MjAxNy0wOC0zMFQyMzoxNDo0MC4zNzlaIiBWZXJzaW9uPSIyLjAiPgogICAgICAgIDxzYW1sMjpJ c3N1ZXIgeG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24i IEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOm5hbWVpZC1mb3JtYXQ6ZW50aXR5 Ij5odHRwczovL3NhbWwuaWRwLm5vcGUvaDlna2p6dmIzZTwvc2FtbDI6SXNzdWVyPgogICAgICAg IDxzYW1sMjpTdWJqZWN0IHhtbG5zOnNhbWwyPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6 YXNzZXJ0aW9uIj4KICAgICAgICAgICAgPHNhbWwyOk5hbWVJRCBGb3JtYXQ9InVybjpvYXNpczpu YW1lczp0YzpTQU1MOjEuMTpuYW1laWQtZm9ybWF0OmVtYWlsQWRkcmVzcyI+dXNlckBzYW1sLnNw Lm5vcGU8L3NhbWwyOk5hbWVJRD4KICAgICAgICAgICAgPHNhbWwyOlN1YmplY3RDb25maXJtYXRp b24gTWV0aG9kPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6Y206YmVhcmVyIj4KICAgICAg ICAgICAgICAgIDxzYW1sMjpTdWJqZWN0Q29uZmlybWF0aW9uRGF0YSBJblJlc3BvbnNlVG89Imlk LTUzMWIyYmYwMmFlMGE1ODhjMzAyMzQxNjNhZGJmZDlkNmJiZjA3NDciIE5vdE9uT3JBZnRlcj0i MjAxNy0wOC0zMFQyMzoxOTo0MS4zNzlaIiBSZWNpcGllbnQ9Imh0dHBzOi8vc2FtbC5zcC5ub3Bl L3Nlc3Npb24vc3NvL3NhbWwvYWNzL3JxNWp3a3ZiOHoiLz4KICAgICAgICAgICAgPC9zYW1sMjpT dWJqZWN0Q29uZmlybWF0aW9uPgogICAgICAgIDwvc2FtbDI6U3ViamVjdD4KICAgICAgICA8c2Ft bDI6Q29uZGl0aW9ucyB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFz c2VydGlvbiIgTm90QmVmb3JlPSIyMDE3LTA4LTMwVDIzOjA5OjQxLjM3OVoiIE5vdE9uT3JBZnRl cj0iMjAxNy0wOC0zMFQyMzoxOTo0MS4zNzlaIj4KICAgICAgICAgICAgPHNhbWwyOkF1ZGllbmNl UmVzdHJpY3Rpb24+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXVkaWVuY2U+aHR0cHM6Ly9zYW1s LnNwLm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9zcGVudGl0eWlkL3JxNWp3a3ZiOHo8L3NhbWwyOkF1 ZGllbmNlPgogICAgICAgICAgICA8L3NhbWwyOkF1ZGllbmNlUmVzdHJpY3Rpb24+CiAgICAgICAg PC9zYW1sMjpDb25kaXRpb25zPgogICAgICAgIDxzYW1sMjpBdXRoblN0YXRlbWVudCB4bWxuczpz YW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiIgQXV0aG5JbnN0YW50 PSIyMDE3LTA4LTMwVDIzOjE0OjQxLjM3OVoiIFNlc3Npb25JbmRleD0iaWQtNTMxYjJiZjAyYWUw YTU4OGMzMDIzNDE2M2FkYmZkOWQ2YmJmMDc0NyI+CiAgICAgICAgICAgIDxzYW1sMjpBdXRobkNv bnRleHQ+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXV0aG5Db250ZXh0Q2xhc3NSZWY+dXJuOm9h c2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFjOmNsYXNzZXM6UGFzc3dvcmRQcm90ZWN0ZWRUcmFuc3Bv cnQ8L3NhbWwyOkF1dGhuQ29udGV4dENsYXNzUmVmPgogICAgICAgICAgICA8L3NhbWwyOkF1dGhu Q29udGV4dD4KICAgICAgICA8L3NhbWwyOkF1dGhuU3RhdGVtZW50PgogICAgICAgIDxzYW1sMjpB dHRyaWJ1dGVTdGF0ZW1lbnQgeG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIu MDphc3NlcnRpb24iPgogICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlIE5hbWU9ImdpdmVuTmFt ZSIgTmFtZUZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmF0dHJuYW1lLWZvcm1h dDp1bnNwZWNpZmllZCI+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlVmFsdWUgeG1s bnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIiB4bWxuczp4c2k9Imh0dHA6 Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIiB4c2k6dHlwZT0ieHM6c3RyaW5n Ij5GaXJzdDwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAgICAgIDwvc2FtbDI6QXR0cmli dXRlPgogICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlIE5hbWU9InNuIiBOYW1lRm9ybWF0PSJ1 cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXR0cm5hbWUtZm9ybWF0OnVuc3BlY2lmaWVkIj4K ICAgICAgICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVWYWx1ZSB4bWxuczp4cz0iaHR0cDovL3d3 dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5vcmcvMjAw MS9YTUxTY2hlbWEtaW5zdGFuY2UiIHhzaTp0eXBlPSJ4czpzdHJpbmciPkxhc3Q8L3NhbWwyOkF0 dHJpYnV0ZVZhbHVlPgogICAgICAgICAgICA8L3NhbWwyOkF0dHJpYnV0ZT4KICAgICAgICAgICAg PHNhbWwyOkF0dHJpYnV0ZSBOYW1lPSJncm91cCIgTmFtZUZvcm1hdD0idXJuOm9hc2lzOm5hbWVz OnRjOlNBTUw6Mi4wOmF0dHJuYW1lLWZvcm1hdDp1bnNwZWNpZmllZCI+CiAgICAgICAgICAgICAg ICA8c2FtbDI6QXR0cmlidXRlVmFsdWUgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEv WE1MU2NoZW1hIiB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWlu c3RhbmNlIiB4c2k6dHlwZT0ieHM6c3RyaW5nIj5yZWQ8L3NhbWwyOkF0dHJpYnV0ZVZhbHVlPgog ICAgICAgICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8vd3d3 LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAx L1hNTFNjaGVtYS1pbnN0YW5jZSIgeHNpOnR5cGU9InhzOnN0cmluZyI+Z3JlZW48L3NhbWwyOkF0 dHJpYnV0ZVZhbHVlPgogICAgICAgICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZVZhbHVlIHhtbG5z OnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIgeG1sbnM6eHNpPSJodHRwOi8v d3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSIgeHNpOnR5cGU9InhzOnN0cmluZyI+ Ymx1ZTwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAgICAgIDwvc2FtbDI6QXR0cmlidXRl PgogICAgICAgIDwvc2FtbDI6QXR0cmlidXRlU3RhdGVtZW50PgogICAgPC9zYW1sMjpBc3NlcnRp b24+Cjwvc2FtbDJwOlJlc3BvbnNlPgo= ================================================ FILE: providertests/testdata/onelogin/olgn09_response_12.b64 ================================================ PD94bWwgdmVyc2lvbj0iMS4wIj8+CjxzYW1sMnA6UmVzcG9uc2UgeG1sbnM6c2FtbDJwPSJ1cm46 b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiIERlc3RpbmF0aW9uPSJodHRwczovL3Nh bWwuc3Aubm9wZS9zZXNzaW9uL3Nzby9zYW1sL2Fjcy9ycTVqd2t2Yjh6IiBJRD0icGZ4M2IwNWQx ZmUtM2I1ZC1iYTAyLWZiZjctMmM1MjVjNzNlZjU0IiBJblJlc3BvbnNlVG89ImlkLTUzMWIyYmYw MmFlMGE1ODhjMzAyMzQxNjNhZGJmZDlkNmJiZjA3NDciIElzc3VlSW5zdGFudD0iMjAxNy0wOC0z MFQyMzoxNDo0MC4zNzlaIiBWZXJzaW9uPSIyLjAiPgogICAgPHNhbWwyOklzc3VlciB4bWxuczpz YW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiIgRm9ybWF0PSJ1cm46 b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6bmFtZWlkLWZvcm1hdDplbnRpdHkiPmh0dHBzOi8vc2Ft bC5pZHAubm9wZS9oOWdranp2YjNlPC9zYW1sMjpJc3N1ZXI+PGRzOlNpZ25hdHVyZSB4bWxuczpk cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8wOS94bWxkc2lnIyI+CiAgPGRzOlNpZ25lZEluZm8+ PGRzOkNhbm9uaWNhbGl6YXRpb25NZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8y MDAxLzEwL3htbC1leGMtYzE0biMiLz4KICAgIDxkczpTaWduYXR1cmVNZXRob2QgQWxnb3JpdGht PSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjcnNhLXNoYTEiLz4KICA8ZHM6UmVm ZXJlbmNlIFVSST0iI3BmeDNiMDVkMWZlLTNiNWQtYmEwMi1mYmY3LTJjNTI1YzczZWY1NCI+PGRz OlRyYW5zZm9ybXM+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIw MDAvMDkveG1sZHNpZyNlbnZlbG9wZWQtc2lnbmF0dXJlIi8+PGRzOlRyYW5zZm9ybSBBbGdvcml0 aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvMTAveG1sLWV4Yy1jMTRuIyIvPjwvZHM6VHJhbnNm b3Jtcz48ZHM6RGlnZXN0TWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8w OS94bWxkc2lnI3NoYTEiLz48ZHM6RGlnZXN0VmFsdWU+WFJ3VnY5QW9HL3FTcVVEdTVjMks5bEh3 YndNPTwvZHM6RGlnZXN0VmFsdWU+PC9kczpSZWZlcmVuY2U+PC9kczpTaWduZWRJbmZvPjxkczpT aWduYXR1cmVWYWx1ZT5PYXhyZmsyYzVoU3BsbVdvbGpwT2FGbG5RUVhTYW1CY2t0Tk1qY2VwUDVX WWx2WDJ5Ymw3YWEwZXc4MWV0dGp0VXlFMHltMmFudFd0endKSTRhckw1ZEdmSGZQUFFuOVhKL0N2 Wkc3WUNpV1BUa2ZjNGp3cXNtOU9TM2thZnYvQTBJb0xPc2ZmQTNyRmV6dThmdUNMaXhMOTJLTmxO aFJOL2JyeUY5YTdGejdBczIwa09tcDgybUJNR3V2TC9BUEZPc3N4U2hteGIwTlJ2Q01KQ0prUkFw ODM3Rkt4K3JuOFJGL1BiaUZWWmluUmZPMXFnTUVzVi9lbW5uZjZhd1l6ZDZFUHFTWVg5RlE1anNL Wm42NG5YWFd5RFY5WXVBdER5bG8ya2JPL1hXRFFjVkIwOE1TZlA5WDJSV1ZURi8yclkybWMzbEUw SUVwdHIxbkw0NU1aM1E9PTwvZHM6U2lnbmF0dXJlVmFsdWU+CjxkczpLZXlJbmZvPjxkczpYNTA5 RGF0YT48ZHM6WDUwOUNlcnRpZmljYXRlPk1JSURQakNDQWlhZ0F3SUJBZ0lKQU1RZVduREpWYVR5 TUEwR0NTcUdTSWIzRFFFQkN3VUFNRlV4Q3pBSkJnTlZCQVlUQWxWVE1STXdFUVlEVlFRSUV3cERZ V3hwWm05eWJtbGhNUmd3RmdZRFZRUUtFdzlUUVUxTUlGUmxjM1FnVG05d1pTNHhGekFWQmdOVkJB TVREbk5oYld3dWRHVnpkQzV1YjNCbE1DQVhEVEUzTURnd09ERTNOREl5TjFvWUR6SXhNVGN3TnpF MU1UYzBNakkzV2pCVk1Rc3dDUVlEVlFRR0V3SlZVekVUTUJFR0ExVUVDQk1LUTJGc2FXWnZjbTVw WVRFWU1CWUdBMVVFQ2hNUFUwRk5UQ0JVWlhOMElFNXZjR1V1TVJjd0ZRWURWUVFERXc1ellXMXNM blJsYzNRdWJtOXdaVENDQVNJd0RRWUpLb1pJaHZjTkFRRUJCUUFEZ2dFUEFEQ0NBUW9DZ2dFQkFP d1ZWWEU2N2RXRldRR25GeVdMUXlhQXFjbytoYXJnSE5xNURXVGlRTTVFRzFHRUx0NVFxVzdYUUp3 Z3dmSUhpYzd6TUJEVTEzRjZJVXJoMzEwZ05tME55Z2c3RFdFUkVCTlp2VGRqZzk5OXBiUnl0NUln ZWloS2g1TkV3cEg5VEdYbmJvdzhRakk3OUFxc0I5SXJuMGZFdUxLYjFLT0YwRU10NVhxSm5XMm9x SnJ2VGRZZUdvaTdDa3BnOUo5ODZYTXFMTXA0OEdkOS9BVG84M0dIc083dytOS3MwbUF4Qi9UZmZo NmhyYklMdE1WTUVOUUI2bHYzZElyZG1RcVBHSjEyMHhPNmRtSHFMVGordE5Tamhrem5TS1hCREhU Lzd2R3QzUmEzOFA2bUdDS3JEQWxvQXoyWGRYSmNkaVk1N1B4ZVF2YzB6d1J0SnRPeHBoQTVXSE1D QXdFQUFhTVBNQTB3Q3dZRFZSMFBCQVFEQWdlQU1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQkFRQVEy UDlhVUJhTTFrQzBYSkY4NkE0YVlrcVJWdXlzcEpUNitET1lBL3BjaWZaM3pocFhQZTIrVFkyZ0tz R2txZlltYTdjaDZkcTR6VkVyRk13a244cU03UEQxa25LL1A4U1p1VVBDM0xUSDNFVEgrYmViMWxN OU5JQ09JdGtodTdSSXd3d3doQVpLUDUyL1d3MEY1OVBDdjFTUFpKMU5rRjhYV2FrNERmOGw0dW40 eHNYMWpjRmtGbFV4Q0RoNnNpbWRGT0szaWJNSFVaeHlHYnZLL013SmZLUW1NY2pvL2ZJYXVrdjEv MnRLWG5pbFNEaFFTMTE2MXlpWDdvb0ZkRCt5NTVLYUdGNU81MEsvOURXMzBFOVpnclNEbHRELzZh R3QxN1ZyWDV3bmtvVWI2OENxWWZVclJqaHBiUFlJTEd1OTZhbEk2K2VMZUl3WktwS1NiTWo0PC9k czpYNTA5Q2VydGlmaWNhdGU+PC9kczpYNTA5RGF0YT48L2RzOktleUluZm8+PC9kczpTaWduYXR1 cmU+CiAgICA8c2FtbDJwOlN0YXR1cyB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpT QU1MOjIuMDpwcm90b2NvbCI+CiAgICAgICAgPHNhbWwycDpTdGF0dXNDb2RlIFZhbHVlPSJ1cm46 b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6c3RhdHVzOlN1Y2Nlc3MiLz4KICAgIDwvc2FtbDJwOlN0 YXR1cz4KICAgIDxzYW1sMjpBc3NlcnRpb24geG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0 YzpTQU1MOjIuMDphc3NlcnRpb24iIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hN TFNjaGVtYSIgSUQ9ImlkNzA5MzgyOTUzNzU0Njc2NzEzMTgzODc3MjAiIElzc3VlSW5zdGFudD0i MjAxNy0wOC0zMFQyMzoxNDo0MS4zNzlaIiBWZXJzaW9uPSIyLjAiPgogICAgICAgIDxzYW1sMjpJ c3N1ZXIgeG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24i IEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOm5hbWVpZC1mb3JtYXQ6ZW50aXR5 Ij5odHRwczovL3NhbWwuaWRwLm5vcGUvaDlna2p6dmIzZTwvc2FtbDI6SXNzdWVyPgogICAgICAg IDxzYW1sMjpTdWJqZWN0IHhtbG5zOnNhbWwyPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6 YXNzZXJ0aW9uIj4KICAgICAgICAgICAgPHNhbWwyOk5hbWVJRCBGb3JtYXQ9InVybjpvYXNpczpu YW1lczp0YzpTQU1MOjEuMTpuYW1laWQtZm9ybWF0OmVtYWlsQWRkcmVzcyI+dXNlckBzYW1sLnNw Lm5vcGU8L3NhbWwyOk5hbWVJRD4KICAgICAgICAgICAgPHNhbWwyOlN1YmplY3RDb25maXJtYXRp b24gTWV0aG9kPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6Y206YmVhcmVyIj4KICAgICAg ICAgICAgICAgIDxzYW1sMjpTdWJqZWN0Q29uZmlybWF0aW9uRGF0YSBJblJlc3BvbnNlVG89Imlk LTUzMWIyYmYwMmFlMGE1ODhjMzAyMzQxNjNhZGJmZDlkNmJiZjA3NDciIE5vdE9uT3JBZnRlcj0i MjAxNy0wOC0zMFQyMzoxOTo0MS4zNzlaIiBSZWNpcGllbnQ9Imh0dHBzOi8vc2FtbC5zcC5ub3Bl L3Nlc3Npb24vc3NvL3NhbWwvYWNzL3JxNWp3a3ZiOHoiLz4KICAgICAgICAgICAgPC9zYW1sMjpT dWJqZWN0Q29uZmlybWF0aW9uPgogICAgICAgIDwvc2FtbDI6U3ViamVjdD4KICAgICAgICA8c2Ft bDI6Q29uZGl0aW9ucyB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFz c2VydGlvbiIgTm90QmVmb3JlPSIyMDE3LTA4LTMwVDIzOjA5OjQxLjM3OVoiIE5vdE9uT3JBZnRl cj0iMjAxNy0wOC0zMFQyMzoxOTo0MS4zNzlaIj4KICAgICAgICAgICAgPHNhbWwyOkF1ZGllbmNl UmVzdHJpY3Rpb24+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXVkaWVuY2U+aHR0cHM6Ly9zYW1s LnNwLm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9zcGVudGl0eWlkL3JxNWp3a3ZiOHo8L3NhbWwyOkF1 ZGllbmNlPgogICAgICAgICAgICA8L3NhbWwyOkF1ZGllbmNlUmVzdHJpY3Rpb24+CiAgICAgICAg PC9zYW1sMjpDb25kaXRpb25zPgogICAgICAgIDxzYW1sMjpBdXRoblN0YXRlbWVudCB4bWxuczpz YW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiIgQXV0aG5JbnN0YW50 PSIyMDE3LTA4LTMwVDIzOjE0OjQxLjM3OVoiIFNlc3Npb25JbmRleD0iaWQtNTMxYjJiZjAyYWUw YTU4OGMzMDIzNDE2M2FkYmZkOWQ2YmJmMDc0NyI+CiAgICAgICAgICAgIDxzYW1sMjpBdXRobkNv bnRleHQ+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXV0aG5Db250ZXh0Q2xhc3NSZWY+dXJuOm9h c2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFjOmNsYXNzZXM6UGFzc3dvcmRQcm90ZWN0ZWRUcmFuc3Bv cnQ8L3NhbWwyOkF1dGhuQ29udGV4dENsYXNzUmVmPgogICAgICAgICAgICA8L3NhbWwyOkF1dGhu Q29udGV4dD4KICAgICAgICA8L3NhbWwyOkF1dGhuU3RhdGVtZW50PgogICAgICAgIDxzYW1sMjpB dHRyaWJ1dGVTdGF0ZW1lbnQgeG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIu MDphc3NlcnRpb24iPgogICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlIE5hbWU9ImdpdmVuTmFt ZSIgTmFtZUZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmF0dHJuYW1lLWZvcm1h dDp1bnNwZWNpZmllZCI+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlVmFsdWUgeG1s bnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIiB4bWxuczp4c2k9Imh0dHA6 Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIiB4c2k6dHlwZT0ieHM6c3RyaW5n Ij5GaXJzdDwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAgICAgIDwvc2FtbDI6QXR0cmli dXRlPgogICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlIE5hbWU9InNuIiBOYW1lRm9ybWF0PSJ1 cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXR0cm5hbWUtZm9ybWF0OnVuc3BlY2lmaWVkIj4K ICAgICAgICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVWYWx1ZSB4bWxuczp4cz0iaHR0cDovL3d3 dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5vcmcvMjAw MS9YTUxTY2hlbWEtaW5zdGFuY2UiIHhzaTp0eXBlPSJ4czpzdHJpbmciPkxhc3Q8L3NhbWwyOkF0 dHJpYnV0ZVZhbHVlPgogICAgICAgICAgICA8L3NhbWwyOkF0dHJpYnV0ZT4KICAgICAgICAgICAg PHNhbWwyOkF0dHJpYnV0ZSBOYW1lPSJncm91cCIgTmFtZUZvcm1hdD0idXJuOm9hc2lzOm5hbWVz OnRjOlNBTUw6Mi4wOmF0dHJuYW1lLWZvcm1hdDp1bnNwZWNpZmllZCI+CiAgICAgICAgICAgICAg ICA8c2FtbDI6QXR0cmlidXRlVmFsdWUgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEv WE1MU2NoZW1hIiB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWlu c3RhbmNlIiB4c2k6dHlwZT0ieHM6c3RyaW5nIj5yZWQ8L3NhbWwyOkF0dHJpYnV0ZVZhbHVlPgog ICAgICAgICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8vd3d3 LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAx L1hNTFNjaGVtYS1pbnN0YW5jZSIgeHNpOnR5cGU9InhzOnN0cmluZyI+Z3JlZW48L3NhbWwyOkF0 dHJpYnV0ZVZhbHVlPgogICAgICAgICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZVZhbHVlIHhtbG5z OnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIgeG1sbnM6eHNpPSJodHRwOi8v d3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSIgeHNpOnR5cGU9InhzOnN0cmluZyI+ Ymx1ZTwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAgICAgIDwvc2FtbDI6QXR0cmlidXRl PgogICAgICAgIDwvc2FtbDI6QXR0cmlidXRlU3RhdGVtZW50PgogICAgPC9zYW1sMjpBc3NlcnRp b24+Cjwvc2FtbDJwOlJlc3BvbnNlPgo= ================================================ FILE: providertests/testdata/onelogin/olgn09_response_13.b64 ================================================ PHNhbWwycDpSZXNwb25zZSB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIu MDpwcm90b2NvbCIgRGVzdGluYXRpb249Imh0dHBzOi8vc2FtbC5zcC5ub3BlL3Nlc3Npb24vc3Nv L3NhbWwvYWNzL3JxNWp3a3ZiOHoiIElEPSJpZDcwOTM4Mjk1Mzc1MDIyNTcyMTQyODc1NDY5IiBJ blJlc3BvbnNlVG89ImlkLTUzMWIyYmYwMmFlMGE1ODhjMzAyMzQxNjNhZGJmZDlkNmJiZjA3NDci IElzc3VlSW5zdGFudD0iMjAxNy0wOC0zMFQyMzoxNDo0MS4zNzlaIiBWZXJzaW9uPSIyLjAiPgog ICAgPHNhbWwyOklzc3VlciB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4w OmFzc2VydGlvbiIgRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6bmFtZWlkLWZv cm1hdDplbnRpdHkiPmh0dHBzOi8vc2FtbC5pZHAubm9wZS9oOWdranp2YjNlPC9zYW1sMjpJc3N1 ZXI+CiAgICA8c2FtbDJwOlN0YXR1cyB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpT QU1MOjIuMDpwcm90b2NvbCI+CiAgICAgICAgPHNhbWwycDpTdGF0dXNDb2RlIFZhbHVlPSJ1cm46 b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6c3RhdHVzOlN1Y2Nlc3MiLz4KICAgIDwvc2FtbDJwOlN0 YXR1cz4KICAgIDxzYW1sMjpBc3NlcnRpb24geG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0 YzpTQU1MOjIuMDphc3NlcnRpb24iIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hN TFNjaGVtYSIgSUQ9InBmeDk4M2Y0MGJlLTYyZWEtY2UxZi04NWU4LTI5ZTExYjg2MWE3MyIgSXNz dWVJbnN0YW50PSIyMDE3LTA4LTMwVDIzOjE0OjQwLjM3OVoiIFZlcnNpb249IjIuMCI+CiAgICAg ICAgPHNhbWwyOklzc3VlciB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4w OmFzc2VydGlvbiIgRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6bmFtZWlkLWZv cm1hdDplbnRpdHkiPmh0dHBzOi8vc2FtbC5pZHAubm9wZS9oOWdranp2YjNlPC9zYW1sMjpJc3N1 ZXI+PGRzOlNpZ25hdHVyZSB4bWxuczpkcz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8wOS94bWxk c2lnIyI+CiAgPGRzOlNpZ25lZEluZm8+PGRzOkNhbm9uaWNhbGl6YXRpb25NZXRob2QgQWxnb3Jp dGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzEwL3htbC1leGMtYzE0biMiLz4KICAgIDxkczpT aWduYXR1cmVNZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRz aWcjcnNhLXNoYTEiLz4KICA8ZHM6UmVmZXJlbmNlIFVSST0iI3BmeDk4M2Y0MGJlLTYyZWEtY2Ux Zi04NWU4LTI5ZTExYjg2MWE3MyI+PGRzOlRyYW5zZm9ybXM+PGRzOlRyYW5zZm9ybSBBbGdvcml0 aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyNlbnZlbG9wZWQtc2lnbmF0dXJl Ii8+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvMTAveG1s LWV4Yy1jMTRuIyIvPjwvZHM6VHJhbnNmb3Jtcz48ZHM6RGlnZXN0TWV0aG9kIEFsZ29yaXRobT0i aHR0cDovL3d3dy53My5vcmcvMjAwMC8wOS94bWxkc2lnI3NoYTEiLz48ZHM6RGlnZXN0VmFsdWU+ RnBLNHZMamNwMG8wZ1hlRGRXRDV4WlgrbERBPTwvZHM6RGlnZXN0VmFsdWU+PC9kczpSZWZlcmVu Y2U+PC9kczpTaWduZWRJbmZvPjxkczpTaWduYXR1cmVWYWx1ZT5tZWdVZ2dkVzlZTmNST3FQb0Mw OEh1Q3RVZWZMaFdWS1djcHIxQjNrb1NkZzNJNStueFhiWks1QzUxdnpWNXN6N0Y2alRHL0lsYnNR eGl1NGt0bWErYUZiVnB6YVRmV0VOZEdzdVRaMmFCL1kzMm03ekU0KzVUajVKenEvbVNVVUxQYXdk c09uOHc3V3NIdGU5OUgzWE56aGQvVVA1dnVpUUpnSW13UGxRaTJqSlRpNE1XVytON0NQRVZvb3M1 YW1OUVRUdWFyN1NRVkdOaTFhQWNvUThTVzJWRFQ1MnpSM3ZxMnVtUVo2dUhCYThrK0x4YWNaeW9B WVVyRXlYc0JrZFBGVEp6RVVER21jMFp5Qk9TaE1pMC9EZnBZazZzbHNrMWQwUE5RMHNCVU5iZ3U4 aDM5Y3ZMblpJWWV3dTFOb3F2RVgyQ0pId2JmSDg5S1FaeEJLTGc9PTwvZHM6U2lnbmF0dXJlVmFs dWU+CjxkczpLZXlJbmZvPjxkczpYNTA5RGF0YT48ZHM6WDUwOUNlcnRpZmljYXRlPk1JSURQakND QWlhZ0F3SUJBZ0lKQU1RZVduREpWYVR5TUEwR0NTcUdTSWIzRFFFQkN3VUFNRlV4Q3pBSkJnTlZC QVlUQWxWVE1STXdFUVlEVlFRSUV3cERZV3hwWm05eWJtbGhNUmd3RmdZRFZRUUtFdzlUUVUxTUlG UmxjM1FnVG05d1pTNHhGekFWQmdOVkJBTVREbk5oYld3dWRHVnpkQzV1YjNCbE1DQVhEVEUzTURn d09ERTNOREl5TjFvWUR6SXhNVGN3TnpFMU1UYzBNakkzV2pCVk1Rc3dDUVlEVlFRR0V3SlZVekVU TUJFR0ExVUVDQk1LUTJGc2FXWnZjbTVwWVRFWU1CWUdBMVVFQ2hNUFUwRk5UQ0JVWlhOMElFNXZj R1V1TVJjd0ZRWURWUVFERXc1ellXMXNMblJsYzNRdWJtOXdaVENDQVNJd0RRWUpLb1pJaHZjTkFR RUJCUUFEZ2dFUEFEQ0NBUW9DZ2dFQkFPd1ZWWEU2N2RXRldRR25GeVdMUXlhQXFjbytoYXJnSE5x NURXVGlRTTVFRzFHRUx0NVFxVzdYUUp3Z3dmSUhpYzd6TUJEVTEzRjZJVXJoMzEwZ05tME55Z2c3 RFdFUkVCTlp2VGRqZzk5OXBiUnl0NUlnZWloS2g1TkV3cEg5VEdYbmJvdzhRakk3OUFxc0I5SXJu MGZFdUxLYjFLT0YwRU10NVhxSm5XMm9xSnJ2VGRZZUdvaTdDa3BnOUo5ODZYTXFMTXA0OEdkOS9B VG84M0dIc083dytOS3MwbUF4Qi9UZmZoNmhyYklMdE1WTUVOUUI2bHYzZElyZG1RcVBHSjEyMHhP NmRtSHFMVGordE5Tamhrem5TS1hCREhULzd2R3QzUmEzOFA2bUdDS3JEQWxvQXoyWGRYSmNkaVk1 N1B4ZVF2YzB6d1J0SnRPeHBoQTVXSE1DQXdFQUFhTVBNQTB3Q3dZRFZSMFBCQVFEQWdlQU1BMEdD U3FHU0liM0RRRUJDd1VBQTRJQkFRQVEyUDlhVUJhTTFrQzBYSkY4NkE0YVlrcVJWdXlzcEpUNitE T1lBL3BjaWZaM3pocFhQZTIrVFkyZ0tzR2txZlltYTdjaDZkcTR6VkVyRk13a244cU03UEQxa25L L1A4U1p1VVBDM0xUSDNFVEgrYmViMWxNOU5JQ09JdGtodTdSSXd3d3doQVpLUDUyL1d3MEY1OVBD djFTUFpKMU5rRjhYV2FrNERmOGw0dW40eHNYMWpjRmtGbFV4Q0RoNnNpbWRGT0szaWJNSFVaeHlH YnZLL013SmZLUW1NY2pvL2ZJYXVrdjEvMnRLWG5pbFNEaFFTMTE2MXlpWDdvb0ZkRCt5NTVLYUdG NU81MEsvOURXMzBFOVpnclNEbHRELzZhR3QxN1ZyWDV3bmtvVWI2OENxWWZVclJqaHBiUFlJTEd1 OTZhbEk2K2VMZUl3WktwS1NiTWo0PC9kczpYNTA5Q2VydGlmaWNhdGU+PC9kczpYNTA5RGF0YT48 L2RzOktleUluZm8+PC9kczpTaWduYXR1cmU+CiAgICAgICAgPHNhbWwyOlN1YmplY3QgeG1sbnM6 c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPgogICAgICAgICAg ICA8c2FtbDI6TmFtZUlEIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6MS4xOm5hbWVp ZC1mb3JtYXQ6ZW1haWxBZGRyZXNzIj51c2VyQHNhbWwuc3Aubm9wZTwvc2FtbDI6TmFtZUlEPgog ICAgICAgICAgICA8c2FtbDI6U3ViamVjdENvbmZpcm1hdGlvbiBNZXRob2Q9InVybjpvYXNpczpu YW1lczp0YzpTQU1MOjIuMDpjbTpiZWFyZXIiPgogICAgICAgICAgICAgICAgPHNhbWwyOlN1Ympl Y3RDb25maXJtYXRpb25EYXRhIEluUmVzcG9uc2VUbz0iaWQtNTMxYjJiZjAyYWUwYTU4OGMzMDIz NDE2M2FkYmZkOWQ2YmJmMDc0NyIgTm90T25PckFmdGVyPSIyMDE3LTA4LTMwVDIzOjE5OjQxLjM3 OVoiIFJlY2lwaWVudD0iaHR0cHM6Ly9zYW1sLnNwLm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9hY3Mv cnE1andrdmI4eiIvPgogICAgICAgICAgICA8L3NhbWwyOlN1YmplY3RDb25maXJtYXRpb24+CiAg ICAgICAgPC9zYW1sMjpTdWJqZWN0PgogICAgICAgIDxzYW1sMjpDb25kaXRpb25zIHhtbG5zOnNh bWwyPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIiBOb3RCZWZvcmU9IjIw MTctMDgtMzBUMjM6MDk6NDEuMzc5WiIgTm90T25PckFmdGVyPSIyMDE3LTA4LTMwVDIzOjE5OjQx LjM3OVoiPgogICAgICAgICAgICA8c2FtbDI6QXVkaWVuY2VSZXN0cmljdGlvbj4KICAgICAgICAg ICAgICAgIDxzYW1sMjpBdWRpZW5jZT5odHRwczovL3NhbWwuc3Aubm9wZS9zZXNzaW9uL3Nzby9z YW1sL3NwZW50aXR5aWQvcnE1andrdmI4ejwvc2FtbDI6QXVkaWVuY2U+CiAgICAgICAgICAgIDwv c2FtbDI6QXVkaWVuY2VSZXN0cmljdGlvbj4KICAgICAgICA8L3NhbWwyOkNvbmRpdGlvbnM+CiAg ICAgICAgPHNhbWwyOkF1dGhuU3RhdGVtZW50IHhtbG5zOnNhbWwyPSJ1cm46b2FzaXM6bmFtZXM6 dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIiBBdXRobkluc3RhbnQ9IjIwMTctMDgtMzBUMjM6MTQ6NDEu Mzc5WiIgU2Vzc2lvbkluZGV4PSJpZC01MzFiMmJmMDJhZTBhNTg4YzMwMjM0MTYzYWRiZmQ5ZDZi YmYwNzQ3Ij4KICAgICAgICAgICAgPHNhbWwyOkF1dGhuQ29udGV4dD4KICAgICAgICAgICAgICAg IDxzYW1sMjpBdXRobkNvbnRleHRDbGFzc1JlZj51cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6 YWM6Y2xhc3NlczpQYXNzd29yZFByb3RlY3RlZFRyYW5zcG9ydDwvc2FtbDI6QXV0aG5Db250ZXh0 Q2xhc3NSZWY+CiAgICAgICAgICAgIDwvc2FtbDI6QXV0aG5Db250ZXh0PgogICAgICAgIDwvc2Ft bDI6QXV0aG5TdGF0ZW1lbnQ+CiAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZVN0YXRlbWVudCB4bWxu czpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiI+CiAgICAgICAg ICAgIDxzYW1sMjpBdHRyaWJ1dGUgTmFtZT0iZ2l2ZW5OYW1lIiBOYW1lRm9ybWF0PSJ1cm46b2Fz aXM6bmFtZXM6dGM6U0FNTDoyLjA6YXR0cm5hbWUtZm9ybWF0OnVuc3BlY2lmaWVkIj4KICAgICAg ICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVWYWx1ZSB4bWxuczp4cz0iaHR0cDovL3d3dy53My5v cmcvMjAwMS9YTUxTY2hlbWEiIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxT Y2hlbWEtaW5zdGFuY2UiIHhzaTp0eXBlPSJ4czpzdHJpbmciPkZpcnN0PC9zYW1sMjpBdHRyaWJ1 dGVWYWx1ZT4KICAgICAgICAgICAgPC9zYW1sMjpBdHRyaWJ1dGU+CiAgICAgICAgICAgIDxzYW1s MjpBdHRyaWJ1dGUgTmFtZT0ic24iIE5hbWVGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1M OjIuMDphdHRybmFtZS1mb3JtYXQ6dW5zcGVjaWZpZWQiPgogICAgICAgICAgICAgICAgPHNhbWwy OkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVt YSIgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSIg eHNpOnR5cGU9InhzOnN0cmluZyI+TGFzdDwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAg ICAgIDwvc2FtbDI6QXR0cmlidXRlPgogICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlIE5hbWU9 Imdyb3VwIiBOYW1lRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXR0cm5hbWUt Zm9ybWF0OnVuc3BlY2lmaWVkIj4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVWYWx1 ZSB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiIHhtbG5zOnhzaT0i aHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEtaW5zdGFuY2UiIHhzaTp0eXBlPSJ4czpz dHJpbmciPnJlZDwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAgICAgICAgICA8c2FtbDI6 QXR0cmlidXRlVmFsdWUgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1h IiB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIiB4 c2k6dHlwZT0ieHM6c3RyaW5nIj5ncmVlbjwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAg ICAgICAgICA8c2FtbDI6QXR0cmlidXRlVmFsdWUgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3Jn LzIwMDEvWE1MU2NoZW1hIiB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2No ZW1hLWluc3RhbmNlIiB4c2k6dHlwZT0ieHM6c3RyaW5nIj5ibHVlPC9zYW1sMjpBdHRyaWJ1dGVW YWx1ZT4KICAgICAgICAgICAgPC9zYW1sMjpBdHRyaWJ1dGU+CiAgICAgICAgPC9zYW1sMjpBdHRy aWJ1dGVTdGF0ZW1lbnQ+CiAgICA8L3NhbWwyOkFzc2VydGlvbj4KPC9zYW1sMnA6UmVzcG9uc2U+ Cg== ================================================ FILE: providertests/testdata/onelogin/olgn09_response_14.b64 ================================================ PD94bWwgdmVyc2lvbj0iMS4wIj8+CjxzYW1sMnA6UmVzcG9uc2UgeG1sbnM6c2FtbDJwPSJ1cm46 b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiIERlc3RpbmF0aW9uPSJodHRwczovL3Nh bWwuc3Aubm9wZS9zZXNzaW9uL3Nzby9zYW1sL2Fjcy9ycTVqd2t2Yjh6IiBJRD0icGZ4ZTNjMWQw MzQtNjI3NC01ZDAzLTgyMzAtMjdlZTMxOGU1MjNiIiBJblJlc3BvbnNlVG89ImlkLTUzMWIyYmYw MmFlMGE1ODhjMzAyMzQxNjNhZGJmZDlkNmJiZjA3NDciIElzc3VlSW5zdGFudD0iMjAxNy0wOC0z MFQyMzoxNDo0MS4zNzlaIiBWZXJzaW9uPSIyLjAiPgogICAgPHNhbWwyOklzc3VlciB4bWxuczpz YW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiIgRm9ybWF0PSJ1cm46 b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6bmFtZWlkLWZvcm1hdDplbnRpdHkiPmh0dHBzOi8vc2Ft bC5pZHAubm9wZS9oOWdranp2YjNlPC9zYW1sMjpJc3N1ZXI+PGRzOlNpZ25hdHVyZSB4bWxuczpk cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8wOS94bWxkc2lnIyI+CiAgPGRzOlNpZ25lZEluZm8+ PGRzOkNhbm9uaWNhbGl6YXRpb25NZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8y MDAxLzEwL3htbC1leGMtYzE0biMiLz4KICAgIDxkczpTaWduYXR1cmVNZXRob2QgQWxnb3JpdGht PSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjcnNhLXNoYTEiLz4KICA8ZHM6UmVm ZXJlbmNlIFVSST0iI3BmeGUzYzFkMDM0LTYyNzQtNWQwMy04MjMwLTI3ZWUzMThlNTIzYiI+PGRz OlRyYW5zZm9ybXM+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIw MDAvMDkveG1sZHNpZyNlbnZlbG9wZWQtc2lnbmF0dXJlIi8+PGRzOlRyYW5zZm9ybSBBbGdvcml0 aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvMTAveG1sLWV4Yy1jMTRuIyIvPjwvZHM6VHJhbnNm b3Jtcz48ZHM6RGlnZXN0TWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8w OS94bWxkc2lnI3NoYTEiLz48ZHM6RGlnZXN0VmFsdWU+UktxRkp5cWRZcWRETUFjUEtmUW5SMmNG M3R3PTwvZHM6RGlnZXN0VmFsdWU+PC9kczpSZWZlcmVuY2U+PC9kczpTaWduZWRJbmZvPjxkczpT aWduYXR1cmVWYWx1ZT42RUpTN1Z0VDljNXdpSG1xNmlUMnJMYjB4aWY0NmpLSEJNaFdKdXNFZi84 c0I2QTBHRFkvbmZyTnpkWlZ4akQ0Tm9vSTFTVzZuZ2dYVDdxVGZmV3pXVnh0Zm5WcC9qSXVGVkFy bG9sMDdMc1l2bEFCT0w2MFY4YzMySXZ6Vmk5ZEJiMzlJeHdtV0l6SU5BOXhnMjl2TGlWNzc4MlNt WFpVbk8yQ3AyTGRZbHFLQXdFeS9XbEhDRjFFWVZNekpqeE9ySHo1NWhPV3hTQWswWTdYZUtSWGdv K1VMVHZxSnd2dmQ5d0gyWVZlOFk3WUFYRDlCaE9adU5CTkxNcG8rc09FbExjT25IYTgvZmdEQzJu T3h4dFU4RFVSSGpqLzRKR2pDU1JCU2UrTmg1VUdWQldpTnZoaURtNU9oRnRHY2J6NlRzN0IzSFp6 N0lBVGNYNEQxOTZnbFE9PTwvZHM6U2lnbmF0dXJlVmFsdWU+CjxkczpLZXlJbmZvPjxkczpYNTA5 RGF0YT48ZHM6WDUwOUNlcnRpZmljYXRlPk1JSURQakNDQWlhZ0F3SUJBZ0lKQU1RZVduREpWYVR5 TUEwR0NTcUdTSWIzRFFFQkN3VUFNRlV4Q3pBSkJnTlZCQVlUQWxWVE1STXdFUVlEVlFRSUV3cERZ V3hwWm05eWJtbGhNUmd3RmdZRFZRUUtFdzlUUVUxTUlGUmxjM1FnVG05d1pTNHhGekFWQmdOVkJB TVREbk5oYld3dWRHVnpkQzV1YjNCbE1DQVhEVEUzTURnd09ERTNOREl5TjFvWUR6SXhNVGN3TnpF MU1UYzBNakkzV2pCVk1Rc3dDUVlEVlFRR0V3SlZVekVUTUJFR0ExVUVDQk1LUTJGc2FXWnZjbTVw WVRFWU1CWUdBMVVFQ2hNUFUwRk5UQ0JVWlhOMElFNXZjR1V1TVJjd0ZRWURWUVFERXc1ellXMXNM blJsYzNRdWJtOXdaVENDQVNJd0RRWUpLb1pJaHZjTkFRRUJCUUFEZ2dFUEFEQ0NBUW9DZ2dFQkFP d1ZWWEU2N2RXRldRR25GeVdMUXlhQXFjbytoYXJnSE5xNURXVGlRTTVFRzFHRUx0NVFxVzdYUUp3 Z3dmSUhpYzd6TUJEVTEzRjZJVXJoMzEwZ05tME55Z2c3RFdFUkVCTlp2VGRqZzk5OXBiUnl0NUln ZWloS2g1TkV3cEg5VEdYbmJvdzhRakk3OUFxc0I5SXJuMGZFdUxLYjFLT0YwRU10NVhxSm5XMm9x SnJ2VGRZZUdvaTdDa3BnOUo5ODZYTXFMTXA0OEdkOS9BVG84M0dIc083dytOS3MwbUF4Qi9UZmZo NmhyYklMdE1WTUVOUUI2bHYzZElyZG1RcVBHSjEyMHhPNmRtSHFMVGordE5Tamhrem5TS1hCREhU Lzd2R3QzUmEzOFA2bUdDS3JEQWxvQXoyWGRYSmNkaVk1N1B4ZVF2YzB6d1J0SnRPeHBoQTVXSE1D QXdFQUFhTVBNQTB3Q3dZRFZSMFBCQVFEQWdlQU1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQkFRQVEy UDlhVUJhTTFrQzBYSkY4NkE0YVlrcVJWdXlzcEpUNitET1lBL3BjaWZaM3pocFhQZTIrVFkyZ0tz R2txZlltYTdjaDZkcTR6VkVyRk13a244cU03UEQxa25LL1A4U1p1VVBDM0xUSDNFVEgrYmViMWxN OU5JQ09JdGtodTdSSXd3d3doQVpLUDUyL1d3MEY1OVBDdjFTUFpKMU5rRjhYV2FrNERmOGw0dW40 eHNYMWpjRmtGbFV4Q0RoNnNpbWRGT0szaWJNSFVaeHlHYnZLL013SmZLUW1NY2pvL2ZJYXVrdjEv MnRLWG5pbFNEaFFTMTE2MXlpWDdvb0ZkRCt5NTVLYUdGNU81MEsvOURXMzBFOVpnclNEbHRELzZh R3QxN1ZyWDV3bmtvVWI2OENxWWZVclJqaHBiUFlJTEd1OTZhbEk2K2VMZUl3WktwS1NiTWo0PC9k czpYNTA5Q2VydGlmaWNhdGU+PC9kczpYNTA5RGF0YT48L2RzOktleUluZm8+PC9kczpTaWduYXR1 cmU+CiAgICA8c2FtbDJwOlN0YXR1cyB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpT QU1MOjIuMDpwcm90b2NvbCI+CiAgICAgICAgPHNhbWwycDpTdGF0dXNDb2RlIFZhbHVlPSJ1cm46 b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6c3RhdHVzOlN1Y2Nlc3MiLz4KICAgIDwvc2FtbDJwOlN0 YXR1cz4KICAgIDxzYW1sMjpBc3NlcnRpb24geG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0 YzpTQU1MOjIuMDphc3NlcnRpb24iIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hN TFNjaGVtYSIgSUQ9InBmeGE4N2MyYjRmLTU5NWItZjc4Ny1kMGFjLWI2MTExY2Y3MWUyNyIgSXNz dWVJbnN0YW50PSIyMDE3LTA4LTMwVDIzOjE0OjQwLjM3OVoiIFZlcnNpb249IjIuMCI+CiAgICAg ICAgPHNhbWwyOklzc3VlciB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4w OmFzc2VydGlvbiIgRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6bmFtZWlkLWZv cm1hdDplbnRpdHkiPmh0dHBzOi8vc2FtbC5pZHAubm9wZS9oOWdranp2YjNlPC9zYW1sMjpJc3N1 ZXI+PGRzOlNpZ25hdHVyZSB4bWxuczpkcz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8wOS94bWxk c2lnIyI+CiAgPGRzOlNpZ25lZEluZm8+PGRzOkNhbm9uaWNhbGl6YXRpb25NZXRob2QgQWxnb3Jp dGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzEwL3htbC1leGMtYzE0biMiLz4KICAgIDxkczpT aWduYXR1cmVNZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRz aWcjcnNhLXNoYTEiLz4KICA8ZHM6UmVmZXJlbmNlIFVSST0iI3BmeGE4N2MyYjRmLTU5NWItZjc4 Ny1kMGFjLWI2MTExY2Y3MWUyNyI+PGRzOlRyYW5zZm9ybXM+PGRzOlRyYW5zZm9ybSBBbGdvcml0 aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyNlbnZlbG9wZWQtc2lnbmF0dXJl Ii8+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvMTAveG1s LWV4Yy1jMTRuIyIvPjwvZHM6VHJhbnNmb3Jtcz48ZHM6RGlnZXN0TWV0aG9kIEFsZ29yaXRobT0i aHR0cDovL3d3dy53My5vcmcvMjAwMC8wOS94bWxkc2lnI3NoYTEiLz48ZHM6RGlnZXN0VmFsdWU+ aHYwR2RrOXlWUVR1YWxoNGNsZW41VWZkQU0wPTwvZHM6RGlnZXN0VmFsdWU+PC9kczpSZWZlcmVu Y2U+PC9kczpTaWduZWRJbmZvPjxkczpTaWduYXR1cmVWYWx1ZT5PQ0hVV2FWbmUxVTBQWEFpZElj bzI3SDVzYVpmbGYyamdiMnh2QXc0V1VHWmlFUmt0UGJJdWRnRWhreU42Ny9LMlUya1A0ekFCNkZh ZjhLbmtWY2s2WHBCSUhEMkpzN1Rsa244RGxjN2dLQXNiTmh2SFNWeklQbkxUelFHK0hjbFhmQTJC MHZwWk5YM3lpK1dZOUtJc1dnTXZzSXRUalRFRW55SUZqMmRaQXRRclhBclFMc2d0Tmtnb0ZpcHhp eDZxM1l0NHl5UmU3MVhXTXNldW81ZUV0VFhTOCtFS3FPUW50V0xoYzhudDJWemFtK1Z1RUVzT0Yr Szl5K1FnbzBDelFHNU9udnpZMVN3UG5HclRyaHAyL09TVDJJbkV5Sk9MeEpCMWY1STNDYkYrWXlr djJKeXNjL0ppMHlGWjJZSnlNYS9KdEN4U2t5Y01EY2RVbThNYXc9PTwvZHM6U2lnbmF0dXJlVmFs dWU+CjxkczpLZXlJbmZvPjxkczpYNTA5RGF0YT48ZHM6WDUwOUNlcnRpZmljYXRlPk1JSURQakND QWlhZ0F3SUJBZ0lKQU1RZVduREpWYVR5TUEwR0NTcUdTSWIzRFFFQkN3VUFNRlV4Q3pBSkJnTlZC QVlUQWxWVE1STXdFUVlEVlFRSUV3cERZV3hwWm05eWJtbGhNUmd3RmdZRFZRUUtFdzlUUVUxTUlG UmxjM1FnVG05d1pTNHhGekFWQmdOVkJBTVREbk5oYld3dWRHVnpkQzV1YjNCbE1DQVhEVEUzTURn d09ERTNOREl5TjFvWUR6SXhNVGN3TnpFMU1UYzBNakkzV2pCVk1Rc3dDUVlEVlFRR0V3SlZVekVU TUJFR0ExVUVDQk1LUTJGc2FXWnZjbTVwWVRFWU1CWUdBMVVFQ2hNUFUwRk5UQ0JVWlhOMElFNXZj R1V1TVJjd0ZRWURWUVFERXc1ellXMXNMblJsYzNRdWJtOXdaVENDQVNJd0RRWUpLb1pJaHZjTkFR RUJCUUFEZ2dFUEFEQ0NBUW9DZ2dFQkFPd1ZWWEU2N2RXRldRR25GeVdMUXlhQXFjbytoYXJnSE5x NURXVGlRTTVFRzFHRUx0NVFxVzdYUUp3Z3dmSUhpYzd6TUJEVTEzRjZJVXJoMzEwZ05tME55Z2c3 RFdFUkVCTlp2VGRqZzk5OXBiUnl0NUlnZWloS2g1TkV3cEg5VEdYbmJvdzhRakk3OUFxc0I5SXJu MGZFdUxLYjFLT0YwRU10NVhxSm5XMm9xSnJ2VGRZZUdvaTdDa3BnOUo5ODZYTXFMTXA0OEdkOS9B VG84M0dIc083dytOS3MwbUF4Qi9UZmZoNmhyYklMdE1WTUVOUUI2bHYzZElyZG1RcVBHSjEyMHhP NmRtSHFMVGordE5Tamhrem5TS1hCREhULzd2R3QzUmEzOFA2bUdDS3JEQWxvQXoyWGRYSmNkaVk1 N1B4ZVF2YzB6d1J0SnRPeHBoQTVXSE1DQXdFQUFhTVBNQTB3Q3dZRFZSMFBCQVFEQWdlQU1BMEdD U3FHU0liM0RRRUJDd1VBQTRJQkFRQVEyUDlhVUJhTTFrQzBYSkY4NkE0YVlrcVJWdXlzcEpUNitE T1lBL3BjaWZaM3pocFhQZTIrVFkyZ0tzR2txZlltYTdjaDZkcTR6VkVyRk13a244cU03UEQxa25L L1A4U1p1VVBDM0xUSDNFVEgrYmViMWxNOU5JQ09JdGtodTdSSXd3d3doQVpLUDUyL1d3MEY1OVBD djFTUFpKMU5rRjhYV2FrNERmOGw0dW40eHNYMWpjRmtGbFV4Q0RoNnNpbWRGT0szaWJNSFVaeHlH YnZLL013SmZLUW1NY2pvL2ZJYXVrdjEvMnRLWG5pbFNEaFFTMTE2MXlpWDdvb0ZkRCt5NTVLYUdG NU81MEsvOURXMzBFOVpnclNEbHRELzZhR3QxN1ZyWDV3bmtvVWI2OENxWWZVclJqaHBiUFlJTEd1 OTZhbEk2K2VMZUl3WktwS1NiTWo0PC9kczpYNTA5Q2VydGlmaWNhdGU+PC9kczpYNTA5RGF0YT48 L2RzOktleUluZm8+PC9kczpTaWduYXR1cmU+CiAgICAgICAgPHNhbWwyOlN1YmplY3QgeG1sbnM6 c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPgogICAgICAgICAg ICA8c2FtbDI6TmFtZUlEIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6MS4xOm5hbWVp ZC1mb3JtYXQ6ZW1haWxBZGRyZXNzIj51c2VyQHNhbWwuc3Aubm9wZTwvc2FtbDI6TmFtZUlEPgog ICAgICAgICAgICA8c2FtbDI6U3ViamVjdENvbmZpcm1hdGlvbiBNZXRob2Q9InVybjpvYXNpczpu YW1lczp0YzpTQU1MOjIuMDpjbTpiZWFyZXIiPgogICAgICAgICAgICAgICAgPHNhbWwyOlN1Ympl Y3RDb25maXJtYXRpb25EYXRhIEluUmVzcG9uc2VUbz0iaWQtNTMxYjJiZjAyYWUwYTU4OGMzMDIz NDE2M2FkYmZkOWQ2YmJmMDc0NyIgTm90T25PckFmdGVyPSIyMDE3LTA4LTMwVDIzOjE5OjQxLjM3 OVoiIFJlY2lwaWVudD0iaHR0cHM6Ly9zYW1sLnNwLm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9hY3Mv cnE1andrdmI4eiIvPgogICAgICAgICAgICA8L3NhbWwyOlN1YmplY3RDb25maXJtYXRpb24+CiAg ICAgICAgPC9zYW1sMjpTdWJqZWN0PgogICAgICAgIDxzYW1sMjpDb25kaXRpb25zIHhtbG5zOnNh bWwyPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIiBOb3RCZWZvcmU9IjIw MTctMDgtMzBUMjM6MDk6NDEuMzc5WiIgTm90T25PckFmdGVyPSIyMDE3LTA4LTMwVDIzOjE5OjQx LjM3OVoiPgogICAgICAgICAgICA8c2FtbDI6QXVkaWVuY2VSZXN0cmljdGlvbj4KICAgICAgICAg ICAgICAgIDxzYW1sMjpBdWRpZW5jZT5odHRwczovL3NhbWwuc3Aubm9wZS9zZXNzaW9uL3Nzby9z YW1sL3NwZW50aXR5aWQvcnE1andrdmI4ejwvc2FtbDI6QXVkaWVuY2U+CiAgICAgICAgICAgIDwv c2FtbDI6QXVkaWVuY2VSZXN0cmljdGlvbj4KICAgICAgICA8L3NhbWwyOkNvbmRpdGlvbnM+CiAg ICAgICAgPHNhbWwyOkF1dGhuU3RhdGVtZW50IHhtbG5zOnNhbWwyPSJ1cm46b2FzaXM6bmFtZXM6 dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIiBBdXRobkluc3RhbnQ9IjIwMTctMDgtMzBUMjM6MTQ6NDEu Mzc5WiIgU2Vzc2lvbkluZGV4PSJpZC01MzFiMmJmMDJhZTBhNTg4YzMwMjM0MTYzYWRiZmQ5ZDZi YmYwNzQ3Ij4KICAgICAgICAgICAgPHNhbWwyOkF1dGhuQ29udGV4dD4KICAgICAgICAgICAgICAg IDxzYW1sMjpBdXRobkNvbnRleHRDbGFzc1JlZj51cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6 YWM6Y2xhc3NlczpQYXNzd29yZFByb3RlY3RlZFRyYW5zcG9ydDwvc2FtbDI6QXV0aG5Db250ZXh0 Q2xhc3NSZWY+CiAgICAgICAgICAgIDwvc2FtbDI6QXV0aG5Db250ZXh0PgogICAgICAgIDwvc2Ft bDI6QXV0aG5TdGF0ZW1lbnQ+CiAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZVN0YXRlbWVudCB4bWxu czpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiI+CiAgICAgICAg ICAgIDxzYW1sMjpBdHRyaWJ1dGUgTmFtZT0iZ2l2ZW5OYW1lIiBOYW1lRm9ybWF0PSJ1cm46b2Fz aXM6bmFtZXM6dGM6U0FNTDoyLjA6YXR0cm5hbWUtZm9ybWF0OnVuc3BlY2lmaWVkIj4KICAgICAg ICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVWYWx1ZSB4bWxuczp4cz0iaHR0cDovL3d3dy53My5v cmcvMjAwMS9YTUxTY2hlbWEiIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxT Y2hlbWEtaW5zdGFuY2UiIHhzaTp0eXBlPSJ4czpzdHJpbmciPkZpcnN0PC9zYW1sMjpBdHRyaWJ1 dGVWYWx1ZT4KICAgICAgICAgICAgPC9zYW1sMjpBdHRyaWJ1dGU+CiAgICAgICAgICAgIDxzYW1s MjpBdHRyaWJ1dGUgTmFtZT0ic24iIE5hbWVGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1M OjIuMDphdHRybmFtZS1mb3JtYXQ6dW5zcGVjaWZpZWQiPgogICAgICAgICAgICAgICAgPHNhbWwy OkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVt YSIgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSIg eHNpOnR5cGU9InhzOnN0cmluZyI+TGFzdDwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAg ICAgIDwvc2FtbDI6QXR0cmlidXRlPgogICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlIE5hbWU9 Imdyb3VwIiBOYW1lRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXR0cm5hbWUt Zm9ybWF0OnVuc3BlY2lmaWVkIj4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVWYWx1 ZSB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiIHhtbG5zOnhzaT0i aHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEtaW5zdGFuY2UiIHhzaTp0eXBlPSJ4czpz dHJpbmciPnJlZDwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAgICAgICAgICA8c2FtbDI6 QXR0cmlidXRlVmFsdWUgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1h IiB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIiB4 c2k6dHlwZT0ieHM6c3RyaW5nIj5ncmVlbjwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAg ICAgICAgICA8c2FtbDI6QXR0cmlidXRlVmFsdWUgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3Jn LzIwMDEvWE1MU2NoZW1hIiB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2No ZW1hLWluc3RhbmNlIiB4c2k6dHlwZT0ieHM6c3RyaW5nIj5ibHVlPC9zYW1sMjpBdHRyaWJ1dGVW YWx1ZT4KICAgICAgICAgICAgPC9zYW1sMjpBdHRyaWJ1dGU+CiAgICAgICAgPC9zYW1sMjpBdHRy aWJ1dGVTdGF0ZW1lbnQ+CiAgICA8L3NhbWwyOkFzc2VydGlvbj4KPC9zYW1sMnA6UmVzcG9uc2U+ Cg== ================================================ FILE: providertests/testdata/onelogin/olgn09_response_15.b64 ================================================ PD94bWwgdmVyc2lvbj0iMS4wIj8+CjxzYW1sMnA6UmVzcG9uc2UgeG1sbnM6c2FtbDJwPSJ1cm46 b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiIERlc3RpbmF0aW9uPSJodHRwczovL3Nh bWwuc3Aubm9wZS9zZXNzaW9uL3Nzby9zYW1sL2Fjcy9ycTVqd2t2Yjh6IiBJRD0icGZ4ZTNjMWQw MzQtNjI3NC01ZDAzLTgyMzAtMjdlZTMxOGU1MjNiIiBJblJlc3BvbnNlVG89ImlkLTUzMWIyYmYw MmFlMGE1ODhjMzAyMzQxNjNhZGJmZDlkNmJiZjA3NDciIElzc3VlSW5zdGFudD0iMjAxNy0wOC0z MFQyMzoxNDo0MC4zNzlaIiBWZXJzaW9uPSIyLjAiPgogICAgPHNhbWwyOklzc3VlciB4bWxuczpz YW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiIgRm9ybWF0PSJ1cm46 b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6bmFtZWlkLWZvcm1hdDplbnRpdHkiPmh0dHBzOi8vc2Ft bC5pZHAubm9wZS9oOWdranp2YjNlPC9zYW1sMjpJc3N1ZXI+PGRzOlNpZ25hdHVyZSB4bWxuczpk cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8wOS94bWxkc2lnIyI+CiAgPGRzOlNpZ25lZEluZm8+ PGRzOkNhbm9uaWNhbGl6YXRpb25NZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8y MDAxLzEwL3htbC1leGMtYzE0biMiLz4KICAgIDxkczpTaWduYXR1cmVNZXRob2QgQWxnb3JpdGht PSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjcnNhLXNoYTEiLz4KICA8ZHM6UmVm ZXJlbmNlIFVSST0iI3BmeGUzYzFkMDM0LTYyNzQtNWQwMy04MjMwLTI3ZWUzMThlNTIzYiI+PGRz OlRyYW5zZm9ybXM+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIw MDAvMDkveG1sZHNpZyNlbnZlbG9wZWQtc2lnbmF0dXJlIi8+PGRzOlRyYW5zZm9ybSBBbGdvcml0 aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvMTAveG1sLWV4Yy1jMTRuIyIvPjwvZHM6VHJhbnNm b3Jtcz48ZHM6RGlnZXN0TWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8w OS94bWxkc2lnI3NoYTEiLz48ZHM6RGlnZXN0VmFsdWU+UktxRkp5cWRZcWRETUFjUEtmUW5SMmNG M3R3PTwvZHM6RGlnZXN0VmFsdWU+PC9kczpSZWZlcmVuY2U+PC9kczpTaWduZWRJbmZvPjxkczpT aWduYXR1cmVWYWx1ZT42RUpTN1Z0VDljNXdpSG1xNmlUMnJMYjB4aWY0NmpLSEJNaFdKdXNFZi84 c0I2QTBHRFkvbmZyTnpkWlZ4akQ0Tm9vSTFTVzZuZ2dYVDdxVGZmV3pXVnh0Zm5WcC9qSXVGVkFy bG9sMDdMc1l2bEFCT0w2MFY4YzMySXZ6Vmk5ZEJiMzlJeHdtV0l6SU5BOXhnMjl2TGlWNzc4MlNt WFpVbk8yQ3AyTGRZbHFLQXdFeS9XbEhDRjFFWVZNekpqeE9ySHo1NWhPV3hTQWswWTdYZUtSWGdv K1VMVHZxSnd2dmQ5d0gyWVZlOFk3WUFYRDlCaE9adU5CTkxNcG8rc09FbExjT25IYTgvZmdEQzJu T3h4dFU4RFVSSGpqLzRKR2pDU1JCU2UrTmg1VUdWQldpTnZoaURtNU9oRnRHY2J6NlRzN0IzSFp6 N0lBVGNYNEQxOTZnbFE9PTwvZHM6U2lnbmF0dXJlVmFsdWU+CjxkczpLZXlJbmZvPjxkczpYNTA5 RGF0YT48ZHM6WDUwOUNlcnRpZmljYXRlPk1JSURQakNDQWlhZ0F3SUJBZ0lKQU1RZVduREpWYVR5 TUEwR0NTcUdTSWIzRFFFQkN3VUFNRlV4Q3pBSkJnTlZCQVlUQWxWVE1STXdFUVlEVlFRSUV3cERZ V3hwWm05eWJtbGhNUmd3RmdZRFZRUUtFdzlUUVUxTUlGUmxjM1FnVG05d1pTNHhGekFWQmdOVkJB TVREbk5oYld3dWRHVnpkQzV1YjNCbE1DQVhEVEUzTURnd09ERTNOREl5TjFvWUR6SXhNVGN3TnpF MU1UYzBNakkzV2pCVk1Rc3dDUVlEVlFRR0V3SlZVekVUTUJFR0ExVUVDQk1LUTJGc2FXWnZjbTVw WVRFWU1CWUdBMVVFQ2hNUFUwRk5UQ0JVWlhOMElFNXZjR1V1TVJjd0ZRWURWUVFERXc1ellXMXNM blJsYzNRdWJtOXdaVENDQVNJd0RRWUpLb1pJaHZjTkFRRUJCUUFEZ2dFUEFEQ0NBUW9DZ2dFQkFP d1ZWWEU2N2RXRldRR25GeVdMUXlhQXFjbytoYXJnSE5xNURXVGlRTTVFRzFHRUx0NVFxVzdYUUp3 Z3dmSUhpYzd6TUJEVTEzRjZJVXJoMzEwZ05tME55Z2c3RFdFUkVCTlp2VGRqZzk5OXBiUnl0NUln ZWloS2g1TkV3cEg5VEdYbmJvdzhRakk3OUFxc0I5SXJuMGZFdUxLYjFLT0YwRU10NVhxSm5XMm9x SnJ2VGRZZUdvaTdDa3BnOUo5ODZYTXFMTXA0OEdkOS9BVG84M0dIc083dytOS3MwbUF4Qi9UZmZo NmhyYklMdE1WTUVOUUI2bHYzZElyZG1RcVBHSjEyMHhPNmRtSHFMVGordE5Tamhrem5TS1hCREhU Lzd2R3QzUmEzOFA2bUdDS3JEQWxvQXoyWGRYSmNkaVk1N1B4ZVF2YzB6d1J0SnRPeHBoQTVXSE1D QXdFQUFhTVBNQTB3Q3dZRFZSMFBCQVFEQWdlQU1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQkFRQVEy UDlhVUJhTTFrQzBYSkY4NkE0YVlrcVJWdXlzcEpUNitET1lBL3BjaWZaM3pocFhQZTIrVFkyZ0tz R2txZlltYTdjaDZkcTR6VkVyRk13a244cU03UEQxa25LL1A4U1p1VVBDM0xUSDNFVEgrYmViMWxN OU5JQ09JdGtodTdSSXd3d3doQVpLUDUyL1d3MEY1OVBDdjFTUFpKMU5rRjhYV2FrNERmOGw0dW40 eHNYMWpjRmtGbFV4Q0RoNnNpbWRGT0szaWJNSFVaeHlHYnZLL013SmZLUW1NY2pvL2ZJYXVrdjEv MnRLWG5pbFNEaFFTMTE2MXlpWDdvb0ZkRCt5NTVLYUdGNU81MEsvOURXMzBFOVpnclNEbHRELzZh R3QxN1ZyWDV3bmtvVWI2OENxWWZVclJqaHBiUFlJTEd1OTZhbEk2K2VMZUl3WktwS1NiTWo0PC9k czpYNTA5Q2VydGlmaWNhdGU+PC9kczpYNTA5RGF0YT48L2RzOktleUluZm8+PC9kczpTaWduYXR1 cmU+CiAgICA8c2FtbDJwOlN0YXR1cyB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpT QU1MOjIuMDpwcm90b2NvbCI+CiAgICAgICAgPHNhbWwycDpTdGF0dXNDb2RlIFZhbHVlPSJ1cm46 b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6c3RhdHVzOlN1Y2Nlc3MiLz4KICAgIDwvc2FtbDJwOlN0 YXR1cz4KICAgIDxzYW1sMjpBc3NlcnRpb24geG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0 YzpTQU1MOjIuMDphc3NlcnRpb24iIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hN TFNjaGVtYSIgSUQ9InBmeGE4N2MyYjRmLTU5NWItZjc4Ny1kMGFjLWI2MTExY2Y3MWUyNyIgSXNz dWVJbnN0YW50PSIyMDE3LTA4LTMwVDIzOjE0OjQxLjM3OVoiIFZlcnNpb249IjIuMCI+CiAgICAg ICAgPHNhbWwyOklzc3VlciB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4w OmFzc2VydGlvbiIgRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6bmFtZWlkLWZv cm1hdDplbnRpdHkiPmh0dHBzOi8vc2FtbC5pZHAubm9wZS9oOWdranp2YjNlPC9zYW1sMjpJc3N1 ZXI+PGRzOlNpZ25hdHVyZSB4bWxuczpkcz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8wOS94bWxk c2lnIyI+CiAgPGRzOlNpZ25lZEluZm8+PGRzOkNhbm9uaWNhbGl6YXRpb25NZXRob2QgQWxnb3Jp dGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzEwL3htbC1leGMtYzE0biMiLz4KICAgIDxkczpT aWduYXR1cmVNZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRz aWcjcnNhLXNoYTEiLz4KICA8ZHM6UmVmZXJlbmNlIFVSST0iI3BmeGE4N2MyYjRmLTU5NWItZjc4 Ny1kMGFjLWI2MTExY2Y3MWUyNyI+PGRzOlRyYW5zZm9ybXM+PGRzOlRyYW5zZm9ybSBBbGdvcml0 aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyNlbnZlbG9wZWQtc2lnbmF0dXJl Ii8+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvMTAveG1s LWV4Yy1jMTRuIyIvPjwvZHM6VHJhbnNmb3Jtcz48ZHM6RGlnZXN0TWV0aG9kIEFsZ29yaXRobT0i aHR0cDovL3d3dy53My5vcmcvMjAwMC8wOS94bWxkc2lnI3NoYTEiLz48ZHM6RGlnZXN0VmFsdWU+ aHYwR2RrOXlWUVR1YWxoNGNsZW41VWZkQU0wPTwvZHM6RGlnZXN0VmFsdWU+PC9kczpSZWZlcmVu Y2U+PC9kczpTaWduZWRJbmZvPjxkczpTaWduYXR1cmVWYWx1ZT5PQ0hVV2FWbmUxVTBQWEFpZElj bzI3SDVzYVpmbGYyamdiMnh2QXc0V1VHWmlFUmt0UGJJdWRnRWhreU42Ny9LMlUya1A0ekFCNkZh ZjhLbmtWY2s2WHBCSUhEMkpzN1Rsa244RGxjN2dLQXNiTmh2SFNWeklQbkxUelFHK0hjbFhmQTJC MHZwWk5YM3lpK1dZOUtJc1dnTXZzSXRUalRFRW55SUZqMmRaQXRRclhBclFMc2d0Tmtnb0ZpcHhp eDZxM1l0NHl5UmU3MVhXTXNldW81ZUV0VFhTOCtFS3FPUW50V0xoYzhudDJWemFtK1Z1RUVzT0Yr Szl5K1FnbzBDelFHNU9udnpZMVN3UG5HclRyaHAyL09TVDJJbkV5Sk9MeEpCMWY1STNDYkYrWXlr djJKeXNjL0ppMHlGWjJZSnlNYS9KdEN4U2t5Y01EY2RVbThNYXc9PTwvZHM6U2lnbmF0dXJlVmFs dWU+CjxkczpLZXlJbmZvPjxkczpYNTA5RGF0YT48ZHM6WDUwOUNlcnRpZmljYXRlPk1JSURQakND QWlhZ0F3SUJBZ0lKQU1RZVduREpWYVR5TUEwR0NTcUdTSWIzRFFFQkN3VUFNRlV4Q3pBSkJnTlZC QVlUQWxWVE1STXdFUVlEVlFRSUV3cERZV3hwWm05eWJtbGhNUmd3RmdZRFZRUUtFdzlUUVUxTUlG UmxjM1FnVG05d1pTNHhGekFWQmdOVkJBTVREbk5oYld3dWRHVnpkQzV1YjNCbE1DQVhEVEUzTURn d09ERTNOREl5TjFvWUR6SXhNVGN3TnpFMU1UYzBNakkzV2pCVk1Rc3dDUVlEVlFRR0V3SlZVekVU TUJFR0ExVUVDQk1LUTJGc2FXWnZjbTVwWVRFWU1CWUdBMVVFQ2hNUFUwRk5UQ0JVWlhOMElFNXZj R1V1TVJjd0ZRWURWUVFERXc1ellXMXNMblJsYzNRdWJtOXdaVENDQVNJd0RRWUpLb1pJaHZjTkFR RUJCUUFEZ2dFUEFEQ0NBUW9DZ2dFQkFPd1ZWWEU2N2RXRldRR25GeVdMUXlhQXFjbytoYXJnSE5x NURXVGlRTTVFRzFHRUx0NVFxVzdYUUp3Z3dmSUhpYzd6TUJEVTEzRjZJVXJoMzEwZ05tME55Z2c3 RFdFUkVCTlp2VGRqZzk5OXBiUnl0NUlnZWloS2g1TkV3cEg5VEdYbmJvdzhRakk3OUFxc0I5SXJu MGZFdUxLYjFLT0YwRU10NVhxSm5XMm9xSnJ2VGRZZUdvaTdDa3BnOUo5ODZYTXFMTXA0OEdkOS9B VG84M0dIc083dytOS3MwbUF4Qi9UZmZoNmhyYklMdE1WTUVOUUI2bHYzZElyZG1RcVBHSjEyMHhP NmRtSHFMVGordE5Tamhrem5TS1hCREhULzd2R3QzUmEzOFA2bUdDS3JEQWxvQXoyWGRYSmNkaVk1 N1B4ZVF2YzB6d1J0SnRPeHBoQTVXSE1DQXdFQUFhTVBNQTB3Q3dZRFZSMFBCQVFEQWdlQU1BMEdD U3FHU0liM0RRRUJDd1VBQTRJQkFRQVEyUDlhVUJhTTFrQzBYSkY4NkE0YVlrcVJWdXlzcEpUNitE T1lBL3BjaWZaM3pocFhQZTIrVFkyZ0tzR2txZlltYTdjaDZkcTR6VkVyRk13a244cU03UEQxa25L L1A4U1p1VVBDM0xUSDNFVEgrYmViMWxNOU5JQ09JdGtodTdSSXd3d3doQVpLUDUyL1d3MEY1OVBD djFTUFpKMU5rRjhYV2FrNERmOGw0dW40eHNYMWpjRmtGbFV4Q0RoNnNpbWRGT0szaWJNSFVaeHlH YnZLL013SmZLUW1NY2pvL2ZJYXVrdjEvMnRLWG5pbFNEaFFTMTE2MXlpWDdvb0ZkRCt5NTVLYUdG NU81MEsvOURXMzBFOVpnclNEbHRELzZhR3QxN1ZyWDV3bmtvVWI2OENxWWZVclJqaHBiUFlJTEd1 OTZhbEk2K2VMZUl3WktwS1NiTWo0PC9kczpYNTA5Q2VydGlmaWNhdGU+PC9kczpYNTA5RGF0YT48 L2RzOktleUluZm8+PC9kczpTaWduYXR1cmU+CiAgICAgICAgPHNhbWwyOlN1YmplY3QgeG1sbnM6 c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPgogICAgICAgICAg ICA8c2FtbDI6TmFtZUlEIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6MS4xOm5hbWVp ZC1mb3JtYXQ6ZW1haWxBZGRyZXNzIj51c2VyQHNhbWwuc3Aubm9wZTwvc2FtbDI6TmFtZUlEPgog ICAgICAgICAgICA8c2FtbDI6U3ViamVjdENvbmZpcm1hdGlvbiBNZXRob2Q9InVybjpvYXNpczpu YW1lczp0YzpTQU1MOjIuMDpjbTpiZWFyZXIiPgogICAgICAgICAgICAgICAgPHNhbWwyOlN1Ympl Y3RDb25maXJtYXRpb25EYXRhIEluUmVzcG9uc2VUbz0iaWQtNTMxYjJiZjAyYWUwYTU4OGMzMDIz NDE2M2FkYmZkOWQ2YmJmMDc0NyIgTm90T25PckFmdGVyPSIyMDE3LTA4LTMwVDIzOjE5OjQxLjM3 OVoiIFJlY2lwaWVudD0iaHR0cHM6Ly9zYW1sLnNwLm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9hY3Mv cnE1andrdmI4eiIvPgogICAgICAgICAgICA8L3NhbWwyOlN1YmplY3RDb25maXJtYXRpb24+CiAg ICAgICAgPC9zYW1sMjpTdWJqZWN0PgogICAgICAgIDxzYW1sMjpDb25kaXRpb25zIHhtbG5zOnNh bWwyPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIiBOb3RCZWZvcmU9IjIw MTctMDgtMzBUMjM6MDk6NDEuMzc5WiIgTm90T25PckFmdGVyPSIyMDE3LTA4LTMwVDIzOjE5OjQx LjM3OVoiPgogICAgICAgICAgICA8c2FtbDI6QXVkaWVuY2VSZXN0cmljdGlvbj4KICAgICAgICAg ICAgICAgIDxzYW1sMjpBdWRpZW5jZT5odHRwczovL3NhbWwuc3Aubm9wZS9zZXNzaW9uL3Nzby9z YW1sL3NwZW50aXR5aWQvcnE1andrdmI4ejwvc2FtbDI6QXVkaWVuY2U+CiAgICAgICAgICAgIDwv c2FtbDI6QXVkaWVuY2VSZXN0cmljdGlvbj4KICAgICAgICA8L3NhbWwyOkNvbmRpdGlvbnM+CiAg ICAgICAgPHNhbWwyOkF1dGhuU3RhdGVtZW50IHhtbG5zOnNhbWwyPSJ1cm46b2FzaXM6bmFtZXM6 dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIiBBdXRobkluc3RhbnQ9IjIwMTctMDgtMzBUMjM6MTQ6NDEu Mzc5WiIgU2Vzc2lvbkluZGV4PSJpZC01MzFiMmJmMDJhZTBhNTg4YzMwMjM0MTYzYWRiZmQ5ZDZi YmYwNzQ3Ij4KICAgICAgICAgICAgPHNhbWwyOkF1dGhuQ29udGV4dD4KICAgICAgICAgICAgICAg IDxzYW1sMjpBdXRobkNvbnRleHRDbGFzc1JlZj51cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6 YWM6Y2xhc3NlczpQYXNzd29yZFByb3RlY3RlZFRyYW5zcG9ydDwvc2FtbDI6QXV0aG5Db250ZXh0 Q2xhc3NSZWY+CiAgICAgICAgICAgIDwvc2FtbDI6QXV0aG5Db250ZXh0PgogICAgICAgIDwvc2Ft bDI6QXV0aG5TdGF0ZW1lbnQ+CiAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZVN0YXRlbWVudCB4bWxu czpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiI+CiAgICAgICAg ICAgIDxzYW1sMjpBdHRyaWJ1dGUgTmFtZT0iZ2l2ZW5OYW1lIiBOYW1lRm9ybWF0PSJ1cm46b2Fz aXM6bmFtZXM6dGM6U0FNTDoyLjA6YXR0cm5hbWUtZm9ybWF0OnVuc3BlY2lmaWVkIj4KICAgICAg ICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVWYWx1ZSB4bWxuczp4cz0iaHR0cDovL3d3dy53My5v cmcvMjAwMS9YTUxTY2hlbWEiIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxT Y2hlbWEtaW5zdGFuY2UiIHhzaTp0eXBlPSJ4czpzdHJpbmciPkZpcnN0PC9zYW1sMjpBdHRyaWJ1 dGVWYWx1ZT4KICAgICAgICAgICAgPC9zYW1sMjpBdHRyaWJ1dGU+CiAgICAgICAgICAgIDxzYW1s MjpBdHRyaWJ1dGUgTmFtZT0ic24iIE5hbWVGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1M OjIuMDphdHRybmFtZS1mb3JtYXQ6dW5zcGVjaWZpZWQiPgogICAgICAgICAgICAgICAgPHNhbWwy OkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVt YSIgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSIg eHNpOnR5cGU9InhzOnN0cmluZyI+TGFzdDwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAg ICAgIDwvc2FtbDI6QXR0cmlidXRlPgogICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlIE5hbWU9 Imdyb3VwIiBOYW1lRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXR0cm5hbWUt Zm9ybWF0OnVuc3BlY2lmaWVkIj4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVWYWx1 ZSB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiIHhtbG5zOnhzaT0i aHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEtaW5zdGFuY2UiIHhzaTp0eXBlPSJ4czpz dHJpbmciPnJlZDwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAgICAgICAgICA8c2FtbDI6 QXR0cmlidXRlVmFsdWUgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1h IiB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIiB4 c2k6dHlwZT0ieHM6c3RyaW5nIj5ncmVlbjwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAg ICAgICAgICA8c2FtbDI6QXR0cmlidXRlVmFsdWUgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3Jn LzIwMDEvWE1MU2NoZW1hIiB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2No ZW1hLWluc3RhbmNlIiB4c2k6dHlwZT0ieHM6c3RyaW5nIj5ibHVlPC9zYW1sMjpBdHRyaWJ1dGVW YWx1ZT4KICAgICAgICAgICAgPC9zYW1sMjpBdHRyaWJ1dGU+CiAgICAgICAgPC9zYW1sMjpBdHRy aWJ1dGVTdGF0ZW1lbnQ+CiAgICA8L3NhbWwyOkFzc2VydGlvbj4KPC9zYW1sMnA6UmVzcG9uc2U+ Cg== ================================================ FILE: providertests/testdata/onelogin/olgn09_response_155.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" ID="pfxae6d178b-ab05-745d-a53f-e342a4a08472" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfxae6d178b-ab05-745d-a53f-e342a4a08472"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>ivfGXY402QpjBcmPy2pYgkTEacY=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>noNf/JxDez9f0vGDmfRVv9qmZdJkJ/BZRyzJ2/2BidvvKWIhpIUBF8VAxL88kbN8EIVZZBiyPoXuvmylcJjaqPhPvSZThhrfWxwn95o8ooprWcoADjr/n0ZxdVB1xBXWGz6Y8yCfHI4z9NKLJ+wWTa9TwP2kZy/7slOVfUnx6meFAmxDQcA9PsVYJ2RUKAyRnuxGBNX7tgqB6rFaRTDF5+LooszPDOZCfYuZbUi9PUq/Z0647UQpBb89oK/G0eqfRs0eg0xIhIsNtW1/7+wcp4qNLNEDv9HnC4gBbR23mzxWlxWd9swoRJKJUtZz/MZwu92lg2YBrffdmMk+0saITg==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="pfx83e79208-9f3b-a332-c15f-529b8ab5a022" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx83e79208-9f3b-a332-c15f-529b8ab5a022"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>EpFL6n+Y5OFfnw3cAFvwMYC3VGU=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>ERboVDDJHG7AWITvdkfVbQuResbKwRfOXfw8vg1Ylwagz3K6BWACPWbIRH3aZt/AZ5UDggG0zsKFkwaZDJZe4FBmxwwQIY6LE4gvQbPbM/UMeb/JxjNvgh1pq/vLPNNXOmPUnLp/ZOv/WGJ69vYk6bdx0VtQTBWmlwiA6ImHQHXLWfak3QYvNgWwEownxs12lqyOdOg5mWb4z9r5tTh/FFnHwLleOdVq1DxtLZ5FiFEMzc4bvDwTl4ARzu8lbg+OiDbOUB1V2wnkTi+ihGho7qlKtuc7g4dABiaHRTfV94T+we2JE7QIzfYz2A1pLj2vu4dswSJAuAHwgIq8N1bldg==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-30T23:19:41.379Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-30T23:09:41.379Z" NotOnOrAfter="2017-08-30T23:19:41.379Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_156.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/incorrect" ID="pfx6e5fc17a-154b-72d0-a4d2-c3491c5a6f7d" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx6e5fc17a-154b-72d0-a4d2-c3491c5a6f7d"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>ygTRXbqFU3Fssjp0EqO9OjQTaXA=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>wypoMCgfgT9PdJUbtZRoJ1/bhpty8E/XVCU/oWyQK22ARXOL2D7XtYfOzwv/dU1etlYj9mYdb99pGP9LyFJ4AEGaWhGSoB0AHFZLewwJwE3Xj7oQbG+APwLY2XwAKkzyD8916LXyMGX8Frna75FNUY8bytahAtTIAjz7eq6h0bfQYnupEbK4oMQWiJ/se0xAeSVsn14b3oDmdj+FCV7fnGnLAbEW+MGJLG+PD2gGDQaJj1suBjonCjMnYQXnwYvP7ChmxB2hyKgeAuIZgnaARH9WYPGLafWORPQjYfCa4206Nc0RCH4Cg15q98x2SrxYJDdygTGaX/gkSYt5CrhruA==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="pfxf869205e-eb05-0263-ad73-d3110d0c7598" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfxf869205e-eb05-0263-ad73-d3110d0c7598"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>W9g/FC8eAFCY7+qnZmA/Ybv7WM8=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>IkFtba/zqHd6Gn7LV3nzkC4ES5eRZvFVcCRIx07BeR0EYuiqCsqUqjV/6+dG93up1jVxEq8K4QtwJK7lU2+mHm8zbXqDN+DaqHardimUR4PSgauA+BgM50oESz/bU7FR0GzO09cvumpApmZb2o2IoT2MOgs6cQFACxGu1IlI+7A5Ymz3vQA/EmutbDcvLKSP7Nk2jPHA1y+iHObWc5N4nwvnxuSbCS/bspgPzRBJkuprBYR7HjqYUzXNaFmW/FrFKz6lA6XxIzBEKJ+1pXAfIaEsvcwo39XZCMcvJasfQJCr4EPOdQP4uEYlT8rcryqofUI9b9Wznd/4+5qaphfLdA==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-30T23:19:41.379Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-30T23:09:41.379Z" NotOnOrAfter="2017-08-30T23:19:41.379Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_157.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="pfxa99435d6-43c5-094e-e89a-1e0442fd4fde" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/incorrect</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="#pfxa99435d6-43c5-094e-e89a-1e0442fd4fde"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>tTtFN1rFpWjOxNlSIWEYSG/ogJc=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>nhq2JRaIJMx/olvq6xzNt885gRDDkj5Ry9qzE/jybmBwKWKeYXTsr3+puyLIvz1f4iEO5YtYkn6Cx1yRdS7Orfjjm5j+CIybtMkzldozlzKvHm+y9Cn3m61PL4eJXhw5Q3eQc7HCCZLWetbqmQRyXCHi8j1a4MGQrGq4alipMlHj+2n+x4mQgDbVOBvgbKhk3heTcVfVp2kosDk7x6Ipkc7a0CtrgprBJN8ZBtMpYikLnhTnVyrEYwAGtjvqQkNL9tjtJ32jhdIyJ90CTlzWrh++sM8ASlAMCQb/xnNHoo1YPuNU2zhCYuDmey6TNCbgPmNj7S4jLv2dm/aJq5FLNw==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="pfx879b1631-cbc5-be3c-313a-c905a67381ae" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx879b1631-cbc5-be3c-313a-c905a67381ae"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>dnkcROGorfaLx3xik6+lOZ6fUjg=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>H4oR1kXwh/xABStLDphr8/udv3H5Uoj82d0IE7n7lA5JVOGKS6mvoufgwSR1uivHoztAf6l3lr2fL6jcuWaUK4oRXfMastpbInrLjBkhrKNRUmC5vcwH+evs6Y3oyTL5Z+9eiGS7iauPHjjYqGcDzf03Ef2gLlsLY4tA6zboCi8MRDrJHZzDZ9ntTMYPLyNxtuFOMjWGfozkvRnbvGNcqGhpnQ5QABUc4t2F/XmwINTJb4J0Ijoy2HRUzRAO5UXDyb5kiaEk9qCRbh3N3oSu50pi9Ka3JRaK6iExpOz0P0o8nP4bI62YyqMxM0w6ENeB7Rv+Hg1IU3th0RdlZuaGQw==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-30T23:19:41.379Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-30T23:09:41.379Z" NotOnOrAfter="2017-08-30T23:19:41.379Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_158.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="pfx8baedc13-cacd-32e2-6091-0d31fde91e73" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx8baedc13-cacd-32e2-6091-0d31fde91e73"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>sjMTnFPKwk9fc3NBJiX/+5v8wnM=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>x4oJYqJJx/+tTrpbCY5xZZ1rH2mBB8yBwhDcktHqLJ1lqBlQoh2EuY+VjNxVy16rW5fUUZo0V7EY7cMYxTB3ZjdhhXBVFHcAlaJi4AJgqQHyJDXby0WbM0S6mVWZ5rBoOo8WCvANS1rShRGh+o2ZEKTkg4OocYGdT2jehKGlg45+JcZR5K9V1lH8ez4cd0bSdx5u5cSwhuFpRnuqsR+YCmRROSPAcWLSR+bxqN2tby/fEzJhdhQBcPS4qAKwKA3D3MwBhQl7KyuzlHvYbD6xGupthntMiZv/JpIne8BRQu+yEYpY9kaLQwrDwmZzbi7w4SSzORecIKim18STtYxqgA==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="pfx00634dac-7be3-a91d-5048-56be6cd41f86" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx00634dac-7be3-a91d-5048-56be6cd41f86"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>usy0dnSA0g0TUf8DqaWKO6/5bA0=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>oUDhsMrtyVkzH3WED1axb5lYn2CZ+ceAmn1Ku7yxmoQ2L+wt2ruB7AZ7wgFs72BNTVs5W2kPOKosXpsl9CAc4YZysoxGzLw3vueD/QKhLUncz8ATiG742MBXd/isKP5tx64fF7QZLPh25bu9RZIGkHs/cP8hOkV660WBzI+NZev5Ulx/pwiV8WniA8cttmnnxGWPRRpudaRinYxMFbgpAEmBM9JzHKoTKUHKNLcH5cosUVC7Hy/NpNBSYKIRswF6LWTcQTrJ0i6sfXd7LpwIVY/OQiDCY/OMiFElVWsBUTLBEU+L2JkIIw3G8CYC7El346FowH9iAECq7wBnvRQK/g==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-30T23:19:41.379Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-30T23:09:41.379Z" NotOnOrAfter="2017-08-30T23:19:41.379Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/incorrect</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_159.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="pfx94a22940-e319-7f00-4242-2db41ca65d4a" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx94a22940-e319-7f00-4242-2db41ca65d4a"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>vQD94he5f/3TMkVyWxa5KPAvKFQ=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>beoRFMRjv3KTKSYJ9nmDwGwk2yr8zmXhkHMB9iyd04Zf4dI4ltEopAdDQrWXmkIiONH7a+T+CkY5hnradnYI41On2sWzJ0kBffKvmdubs7qvbl2iSgQBJmM3U1Zj1qcpUbeJxE/egGSEdJDzLLbtIGn32GvXVxsFhYpTd4vVjqPmeWJRLb6RqjBVbMP6xmOkFTG0XzLn9s/bM8PS4cu/ySTYk8TnDm1TfbM1bzUNoeRn8u1muKBg7BziI5ULxq1bYXeIw9lp6HNR2IktLvcMh4escy5xH1hHjdeLdwpbFsJ3CNggYwZTphncxBU+bsB7c5k35hLdLlHursOQcqg3vg==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="pfx5619a2e7-26e9-8d12-de76-d784b4b7c4a2" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/incorrect</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="#pfx5619a2e7-26e9-8d12-de76-d784b4b7c4a2"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>fE7rtiQHIU0tGqK8dNo2H75SaVQ=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>mEsD1a8ZFT2eKO0FPVFU6n6fKn0VsoiHt0Ut5KJPQWO+CAci6+JIJhA6dO5+RFLejDrTaoWUG1/GAYpc12QrKroV+nIpGsIN0UmbFBkGN5Obch06w1u/QxE9TA5Uq50QYb6L870QtOL8P+0e/aClX4f6Vh71y/fAm8eC7b+5PbHKaBmAC/lV3YMisNfC0IKe3mdljYK+6legkRukpvqFvJbBPwO24+qytdJK/VsIMSspeTjuAyvqdmzn1LyGRNxEvI/7CYEUlB10FttkQBmZqnXlawSkVm8IO6wNEP8y6lfPemmReYagYYUftdJWgwVph88ROCYDvJ7mKqBJ2ljgCw==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-30T23:19:41.379Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-30T23:09:41.379Z" NotOnOrAfter="2017-08-30T23:19:41.379Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_16.b64 ================================================ PHNhbWwycDpSZXNwb25zZSB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIu MDpwcm90b2NvbCIgRGVzdGluYXRpb249Imh0dHBzOi8vc2FtbC5zcC5ub3BlL3Nlc3Npb24vc3Nv L3NhbWwvYWNzL3JxNWp3a3ZiOHoiIElEPSJpZDcwOTM4Mjk1Mzc1MDIyNTcyMTQyODc1NDY5IiBJ blJlc3BvbnNlVG89ImlkLTUzMWIyYmYwMmFlMGE1ODhjMzAyMzQxNjNhZGJmZDlkNmJiZjA3NDci IElzc3VlSW5zdGFudD0iMjAxNy0wOC0zMFQyMzoxNDo0MS4zNzlaIiBWZXJzaW9uPSIyLjAiPgog ICAgPHNhbWwyOklzc3VlciB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4w OmFzc2VydGlvbiIgRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6bmFtZWlkLWZv cm1hdDplbnRpdHkiPmh0dHBzOi8vc2FtbC5pZHAubm9wZS9oOWdranp2YjNlPC9zYW1sMjpJc3N1 ZXI+CiAgICA8c2FtbDJwOlN0YXR1cyB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpT QU1MOjIuMDpwcm90b2NvbCI+CiAgICAgICAgPHNhbWwycDpTdGF0dXNDb2RlIFZhbHVlPSJ1cm46 b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6c3RhdHVzOlN1Y2Nlc3MiLz4KICAgIDwvc2FtbDJwOlN0 YXR1cz4KPHNhbWwyOkVuY3J5cHRlZEFzc2VydGlvbiB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5h bWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiIgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIw MDEvWE1MU2NoZW1hIj48eGVuYzpFbmNyeXB0ZWREYXRhIHhtbG5zOnhlbmM9Imh0dHA6Ly93d3cu dzMub3JnLzIwMDEvMDQveG1sZW5jIyIgeG1sbnM6ZHNpZz0iaHR0cDovL3d3dy53My5vcmcvMjAw MC8wOS94bWxkc2lnIyIgVHlwZT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8wNC94bWxlbmMjRWxl bWVudCI+PHhlbmM6RW5jcnlwdGlvbk1ldGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3Jn LzIwMDEvMDQveG1sZW5jI2FlczI1Ni1jYmMiLz48ZHNpZzpLZXlJbmZvIHhtbG5zOmRzaWc9Imh0 dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyMiPjx4ZW5jOkVuY3J5cHRlZEtleT48eGVu YzpFbmNyeXB0aW9uTWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8wNC94 bWxlbmMjcnNhLW9hZXAtbWdmMXAiPjxkc2lnOkRpZ2VzdE1ldGhvZCBBbGdvcml0aG09Imh0dHA6 Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyNzaGExIi8+PC94ZW5jOkVuY3J5cHRpb25NZXRo b2Q+PGRzaWc6S2V5SW5mbz48ZHNpZzpYNTA5RGF0YT48ZHNpZzpYNTA5Q2VydGlmaWNhdGU+TUlJ RFBqQ0NBaWFnQXdJQkFnSUpBT3ZwWnRKTnRRL3JNQTBHQ1NxR1NJYjNEUUVCQ3dVQU1GVXhDekFK QmdOVkJBWVRBbFZUTVJNd0VRWURWUVFJRXdwRFlXeHBabTl5Ym1saE1SZ3dGZ1lEVlFRS0V3OVRR VTFNSUZSbGMzUWdUbTl3WlM0eEZ6QVZCZ05WQkFNVERuTmhiV3d1ZEdWemRDNXViM0JsTUNBWERU RTNNRGd4TkRBeE5EZzFOMW9ZRHpJeE1UWXdNekE0TURFME9EVTNXakJWTVFzd0NRWURWUVFHRXdK VlV6RVRNQkVHQTFVRUNCTUtRMkZzYVdadmNtNXBZVEVZTUJZR0ExVUVDaE1QVTBGTlRDQlVaWE4w SUU1dmNHVXVNUmN3RlFZRFZRUURFdzV6WVcxc0xuUmxjM1F1Ym05d1pUQ0NBU0l3RFFZSktvWklo dmNOQVFFQkJRQURnZ0VQQURDQ0FRb0NnZ0VCQUtmVWxjaXdEUENKOUpYeTFOc3hLZnF5T2ZMUVhG S0tHZ05LS1JMekxBV080M0dnUVlyVjY3UWFBbnk1THZnT2E4MUtRT1g0SXZqSnkwbmQvVnJPNmpH OXBUZE1SOXZGSFQwVHUzVzFRVXN5UFBTUXFwS1h3YjJaQ1NYTmdoWUQ1Z0JyTnRtT3hBT3MxQXp4 NXFtSXpCSjRGMFJrUml2Y2RiWFNmQlVCTHBDbjFNMjg1YzR0azVTRXZvUmdCZWlzTEpKREI3aG15 bEExVjYvK0JOK042YjNNK1paRy8vQ1R2T2pKS2dud2tNQUx6WGJQYlFXYTBrcGJNTERNejhLcjJw T0RMS2IzckdtZGY0UDZBOWFBNDFrNkw0Y2xUc05kY0s3WndKMmZHRjc5V0d6RTZSTHlCWDJVUzNn UEhVWHQvV01RWlh5VUxPM2V4aVREc1FYV0ZmOENBd0VBQWFNUE1BMHdDd1lEVlIwUEJBUURBZ1FR TUEwR0NTcUdTSWIzRFFFQkN3VUFBNElCQVFCM2ZRWnoycU5Bby93b2hQTmFSMnVBYWtMdDI1Y0ty c2JnbjNYd08rWCtEUkg0bnFNU1prSGRMR3I4MnhEM2kzM0JMU1F3WHpGZWNFTitDQThTbHBOb0lY SHdrNkQ2VjN1RUJTaktlbVp0SkZDSnFlOGQrNXF0M0dWNTBBS210RXQyTmM3Qjk0VE44eEI1RW1a bGFkblRKV2NCZ1N1dXoxaExYUVEwMmRKM2REcThGTWx5UjcwUzJEVHR1UHUwaTIvZjZLdHJsbW1O c1UyNEFxK2ZDekVHNDNOcVNoT01lTTVyRHhMc1NKQ3RqZk1Sd0c4WWV5TmY2Y0NNU014WUFKZnJU eWorQVM4UnRaUU5HRjd0WCtleEVXSE9mMUM5Q0J6SHRLUkNsQlJMNnpEamxwUENJRHdjTUZpOE5Y dmFpVmNseElxM1hkZnF4aUdCQkVsZGtoZ1o8L2RzaWc6WDUwOUNlcnRpZmljYXRlPjwvZHNpZzpY NTA5RGF0YT48L2RzaWc6S2V5SW5mbz48eGVuYzpDaXBoZXJEYXRhPjx4ZW5jOkNpcGhlclZhbHVl PkRzOUZ4TXVJVWpiZ0hvVEtUSkw0WEk1eVlRSVpMZlRUV200dFhTaUdMN3hYdkZHc25oaFVOb2Z0 K0RXbGh4b2VhdkthOVdQWXpwMHpXdEFCeWg4NitsdzIvWjVHbU9UV2VYTGVsbTI0RnFOZnNZOFV1 L0s2S0I4b2UzN0lzWHNSMmZtaE1KWVF1N2JqYlVaQ04zSUNtd1lMV2g1dUNWYWI3Szl0bzdyMGFj eE1mNjFYWllDNGxzWkZENHE0ZCt5bEVtbWJ3LzhoVWlMSGgrcU9IQ3FqZlNrSEFRK1lPQlVhNlpH UU12WTVQNFpGaEpaWjFQRGZMSkUvSzkwUy9ZZDBia05vdEorREFYcjVKbzJjMHQ2RHBzNVZXNDND MXlqQW10d1RzalRpVW5PcVJUZlFGYmdpbGJnMm0wMjFPeHBhUVphaDliMDU2aFl4YmNoQ3lwZnRi UT09PC94ZW5jOkNpcGhlclZhbHVlPjwveGVuYzpDaXBoZXJEYXRhPjwveGVuYzpFbmNyeXB0ZWRL ZXk+PC9kc2lnOktleUluZm8+CiAgIDx4ZW5jOkNpcGhlckRhdGE+CiAgICAgIDx4ZW5jOkNpcGhl clZhbHVlPisrUVRYdWZvRVpIQ2FzMVBISWY1WUhxTVpnZ3ljWVhEUjVNbWJBV2M5aXlBS0ZiNDd1 d0hqdGVKeDBybUI3d1VqYndVaFlqbFp1UmtHclRRQ1JLMDVlTFJpZVlhenE3MU10WVZHVUxuV01q TUxYbVZiVDJJR2pWRE5EcVZUSnpiSE9BaUI2ZUtaZWQxbkhhTXhrc2xLZ0cxR25nY2dJdTRVd2gx anFaZEtBeWpBcWxGcnZVUWxjd3JYd1lzRjB4K3dhMk9LQUlsdFV1Z2w4dXIrL1V6ZFBMRWROUm1H WkN5YU5DODJFM2czOWpvbnhQNlZWbGdPUnBsd3NzZ1VUVEV3czFQNENhalF2NjFMcEQ4VCtSNHpC MjF0KzZTaFlBTlc4T0s2LzdRM3BiREFrc05JU2g5Sk5VZFNPQzRab3MvMkxmQXg3UnpSalVUdS9J dFJEM0ZiazdGQzVEdTJYWjRTYk9GWTB0dlR3TFVFQ1Q4RlpIdGxPeE5mYW5IRWx6WG05VDZLT0VX UHBLbzNCZ0xvODJPUE96Y0F2aXkwaG5uWDY1aXl3YWZtMm9BYzBSbTBVY0Y5Zm45d1FMVDN3R1ZT UzkrUjRvMEpuY040aVVvaHl1STV3SUNYMzBYZzF0Qk53L2ZFU21HK041YmRlMXdIMGRKY2d1RG9m OFZPdXYxemg0Ym5PdEVBbWl0Yno5ZGJKREgvWCsvdzByRHNnK0xFQXNzM25GZXNSOHJYOW55aTdi WUtyRjJ0S1RyWHFCZFpCUTVyS0gvVzNXT2dBNVc3ZHlYaUMzMGZCMEwzc3RWWDhBSSs1cGM5dlhh cVhrK2FiVXd3NmsxUnB4Q3Z0TlZoYjBGWG55ZjRIUmNScHM4RHNjOEk3V1g1dEhZVzlhQTd2ZFdP MTBIK2ZWRjhyR0srRlFSMEhsWDhpUERjYm9DQjBVMzJIdEZVbUhZT3lpRHo4QXFSUzN1MCt0Y2Nt bTNyUGVKUVdWalV1KzNnWU1xWitCaVRFZi9CRUFoWmNiOWIyQ1NtelVDYmlQK3RwT1hjUmxleE9m NUhXSjBLa2pjYlVod1Q1L1RlZCtYUDhSeFAwQkNubzU5dWlLOW1kUjVsUC80Y084NnhMM2pveS81 YW8wT0pCZlhQR3V3YkdnbmQzQ2lnUTVRN2l5YmhGQ2NPaHVuUU5SaC93S2RsMExPb29nUHdUcnpj b2hHTTZsc2pGWmpXM3ZjYmIrdXhsRmdzdEVZU0gxQ29Ga0hRNXV5SWRlcjh3a0g0TGh6cFpWL2F5 WFF0RnRPWDVKWFBGdWptbXJnYWhRaVpLdjFQMFVWYSs5S0Zla0xOcXVyTXdPZGRjbTNSK0NRMU0x bVUwNWdEKzFBMnBFUnhGMG9BOHNKM0VPL1JSKythdjU0dlU4L3h1ak0zcGFZak5BdkpleVFPSzV4 MHVxWFM0dEIrL2JTUGpEVXVBTkRtUFR2NE9xTDlrL2dQK2MzMGxPODE0NG1reFFKN0FwbGMrMHNQ Smt1SS9PNmQ1TDArRjFEYm90Z0h3ZzJNVDUxVElGYWtDalN1RFMyOE5ZYkttM2lPU0VFb29vNU5z elZoclEwa3Z1OUg1enVrWWFtYzNVcTZ0cmRIVFJQQU50anJ0YzZLSG1xV0FkbzBpSklzdWJEVXpt S25QR0o1Rk5jOURJbll5U2ZVOUtraEYrc2RMU3Q3WkUrSUt6bmZoaDBYWUh1cHgwT1F3a3c1WGxR QnplbFdtSTdFbUYxWEVwd2UyQ3Babm8zU0FpaEdydTBVbFZlRlJmZUFyZzgzRDl2Yk91Z3hDTDAw dGk1YzhZYWg0WHMvV1BocExwSGhwWkNtYTJLSEJVL2s0d3dNSVpUY211Rk13MmpqRFNUaGMyejIy REJvcE9JZ3ZLMTM4ZlpzMnRoWEkyekNaY0d4Y1JaSElVYlNNVjZpcmM4RW94VXRiREpTRWZ3Szh5 QlBERXJ5eFU4bGVJc04zeEJ1TEpYeDUxODlsNzBBRlVLL2w2WXZjWWxTTlBGRkl6ZUxsbldPb2JS ZzhJT1RWYXNOMDVjdlhHTHpRTjg0VmZXK2VTdzN6OUtudkdHVFQ5WW5WZ0NtUmJXMVpDNGZzRW5n QTBja3YzN0NHSGNwOHNXMVYzLzg5NjJCZkRBK3ZhOURSSkxsWTh1ZHh3T0JiSDgrRmkvSkQ2RjFF cEx3ZnIzRHluN0tyalJrYUNrNEpiL3E3OU1LaDB3SmN0TkdHeDdXY3ZraGJINVRWRmxwenF4b09n QXpnTy9XS29ONlFXZ2FCT29uMFhzZjZnYndENXhtNHg1RkxOZFlpY1NkTzI5WC9tK0tjejhUelN2 eE00VElNdmJkaHhlUzJMTC9xNTgzc0xuaVRSa0Z1bHBBWjdiaHF2TVl3RWJsczFSNWxBMUlkMlNR Z2tGWENoL3FTeDltOFJVN1k2cWc3Z2pIYTVWdDdXNXEvYkF0Mlg2b1d1KzBqUjVuNy9nbFZWYU1K Y0ptQUQxa3pOQVZwdjA2YVk1YXp5QTkxY3lSVk1Nb2t3NWpYdUVjZkE4OEJIQjd1WDVMNEVuYWFi NllvN09Ia0hteXE5NU5PSmN3ZURVNDVBK3RuTStWbHA2eUFWQ0NkWko4UVFBTFRqajlzYVB1anpV WEpkRDZ6RlNVeDM4SmxGa1duVllVMCt3WUZSeW5TaHhVbWlXUUhadnJ2VkZVVVU3bDVsNzROejFH ZlhqMCszbUwwQmFJL1lBeUJyczZmSTljSGpCWVMzaERqQzZGL0NwbmFGVjhVV1grdXVqZVowRGhm RXFMM3BoUktveGtyS3grNWlBaGthMklqaG9KSDYrVnprTVI4TVYyam5UbFVNZ0R1R25BSHBYRW9k R2RNRDcxald3RlF6SjU0N3lrK1l6bDc0KzN1aVdLQ3RrZkhDNTJFVzV2VnpHZTM5TkxMMHNRU3Vw QlZXM3hGK3lRN1VDSGVrT04wQ3NOL1Z0aTJDVFpGT3NOVzQraVhuYUVOdVF0eU43WFRtTEtFM2o1 RDVEc2M5QkNoSHV2bzdBV2ViMGRPdDBNRXFta3QvSDV6L1RKMldWbjZHem9xcEJTZEphamNBT0VZ SHp0KzVzNkdkQ2xTZ0lTRk04RHdpOXp6bVlSR2FBVkRTakRXc2p6VmdocTRjMytua3RPNWhabjd0 SE54OERGTnZORVBzNnlCZjBaL1NPeDRseTlBMGRubWNrRnFiV0dKblVxOFBVTWZkQ2x2bDhTVFNt dEFkUjZpWUxySDlodjl6M2ozYi81MGQ1blZPKzJnQUl1clp2QkpsVFBOQUNYdVA0ck94ZEQ5d09k ZDFjS3haMGRmdTAvMlZkam14Yi9SN1ZRdDNGaG9zcGVCQ3plRDVQWU9TUU9PV1VzQS9hM3dod0RT NWJUY3NvMHViWWdqRk5GbHRkZk1FOE1WbFIwUmZuM3ZyMG5PMDFXRGhKVGE2MW5qcXRIeFNWNFZr S0NpaC8wTnZOSWVQNEQ3em5KQm1oWEdKSFlxN2R1VUdxb0ZHTHZQSkFmd2JRUnNvZG42clkxVG0y OHJ2c1k1RWorZmZRanlRR3phS1k3ZTBuT0dPbHdJQVNVS0RnSHhzTkVCOFprK2NLRDJWcjhpUFo3 cGR6ajY4YSs4aDNaYmFHQ0dCQXhOTTdlOVM1K2M1bjM0WkVGVlVnNU9lMFYyWi9JVlVGbGtRQVNz NEtzdndFWmZLdWVIeDRSK2EyUDQ5dUpxbjNBWkJqYzVDdW5sQm1iRDBwSW5SS0JqMHlNZUgvRGc5 Uis1UEMrZ3dNMmNaamZRMVpWM3NXOWJTNVZ4dE9ET0JsL1prL1BRM1JHRGtBaUhZdkdsaGt6d2JN bzlsZmZ1UHp3Rk5GTllZcWFXNGd6MXRudUJhTmp4NUxuUTAwSkFvMTRZbGs2WCs3L2ppazBqd3lv RndSMElWUVRoMkVQcytKMkNicVRhNDE5L0xVNVRzRlJQTTJGZVBINk15SDE2K0tXYnkxRDJrM0xH UjJ4OHI0azRzM2w0N2V6blRQS0lMdTFFN1FISFFZMDZUZWt3eWhubTdlOTZqb0NweStRVkRpZGxY ejZmekl4SWkxMG9yMzNVZDdyTzd4TzNsSEhKcmNXV284UFVobDYveFZRRHg3TVdpaFhuSkV4d0hk U1BtVjNkRXowT2k2WmJRYnZRZVU5b2tkVHV0Zk5YTmZURXNXd0E0bnNFdTNVeUlOTWhiYjRhRUo3 eEdUeGcyQVFnaHpOV0o0NEtibWxKNG91TTJYemxlYnc0UjhIN0J6WkJ3WC9aK1VkMDJ1VzYrNFZJ K1Fkam9uVWwySmc3RnA3cjVNbitoKzllOHBLU3JIQzZQRUsvbW1mcDNxMytLcmdtM3Q5MGh0R0NX VDRWbUxWbDJJVURSbWRkN2NhU0dDMVlWdUtnNFVjWSs0OHU2bTN4NzNaODUwS0psUmJ3VG80YW1N UjFISXlPQ0krTE8wRVd2UVk3dzVienkrU0ZiN2tIenRIWnFSRElEUkFQMDJIamlNaWZzVHFUUitD N2hFRXVwRGNoczdKeXQ3V2JVaDlTVmthU1pTbjluRG1mY01vMGVvTldVZVNuS3hmcW1yQTFGZGg3 M3Vzb3dwbERsekdFeFI4TVZBY2plQ2JzMThYZ3c3K0o1NEd4M2hYLythanNUbEJuNDRiOGRNWjN2 bTBOSVAzNmJtUUNzd3QrZGlhbUJsaVZjbjQrQnQ5cXVJNVNsOWJ1Rm5kZ1lEV3Urakw0LytlQkFn QWZXZWxFUDYyaTExYVYzM2loQ3ZMSFhSNk1nR1huMEN1cVlUNEJNV1p6ZVVzNEo1Y2RxbWpDQy9M WUk4ZFQ5bS8wL3FBSXhMbDVvSXcxZkN1OHdzN0p1UzlCVWpmdllFR0NOUTdBdXMvaCtscld1TjBS alhDcTZ4Q0c2RTNMR0pTU1BMa2c2RFV1aVc0SXByMUMwcEc4NmVmOFNDckNxMENncktpYm5mTmlj bllhR0RtM2FGbDRYV2hLZ1NMM2JVenh0eDNvd2FUMEZCOHdlYkxjYWdjd2FmY2ErU1F3dzVGQnQ2 NG43cy9yeloyVTlUZDF5dkVwMVpXTjBMMHNEanZ4bm1UK2lDRHZvVXlkRTA5QTJJKzJMREQ2M1pl dTdmSjJpWUtBelVyV1RJcDFDa0FVSlNSTVlZckQ2RHNlQUMxYVVxaFRDc0g3RUd0aFpCSE1RM0ZK MUZ3RE42S3ZIZWt4MFdyWlRWR2FhbUpxcm5ZdTlLUlRzYjByK0hmMHc3eGcxdG93bXk3TU5TcjdS bGZNeG42WVYyRTRiY3M2ZzdMTUxpRElCdjdYYXFYMURPdm1ZdjJrakwrd0pGZlVFelA4VUQveHQv a2pSU0k4RURuSGhYNWdDVkNNWWk3bmNLdVY3aDJHU3Z0OHo4cDdJeUtXU1BRN01iUC9WNjlDUmxB NEpBNzlmRmxkRzhMbi9YcWwydGNYZHFqSW9zMkNJdTVPM3ZPV0U3a0ZjajNpTkJkc3E3ZHBmdVdV eU5WdDB6ZU1CU1I2US9GamZwUVIwaSt1a1c0c3k4WDViWUJqQUhXY0IxRjQyTitpVnA0V3k1OFNF Q1ZydHJLVE9uVlJrM3l4TWtPRWdpektxZzAzNDYwQVE3OU5pR2JhSDNIWk83WTNOUDg2SnVUd2pD RlFUcTFKSW5rWjFMVmliQlFBY3dSSUR3angvbCtPK3k4U2YwVkxXakhyTGFxbHdIUkIzRDZldzNl YzFwaU5IWHlvYjFUU1RnRnFMREdGbTczSXYxSk5ycXhpN21vbHk1SWR1b0lIOW5Rb3NhVDhXeWk1 SmgrV0dqQndmd1plMy81NnBSZmlnK1dZaGRyQnFFSUJNallDVlU1c2xzNm9JdHNJZlFNd2s2Ykx3 RmdzOWNWQUtYd25zWklEQ1p5cU85M0FTUkNrU2ZnN2VBYnlIWmFzRmdhbzRiYmhGeTA4K2FFQUVT dmYzRjFvcU5xWjY3S3VzRk0vNnNwS1BGMHc1V2t0b3dKenQ3ZEdzZXlLU3M3eGZQVUVnakJpZ0p1 S2EvWm02ckNlM2w4Y1pjTjJxZFlYNGo5VVhZaDVIeWxFdXBrNDRycWxzNm1pMC80YURyRFRXM0xz cWNIbzNuUFhkSk1pOFBSYkhnVndUdE5RcFRNdGRBWTBXZmRaZzdCVGdicFg5Rno5R2JCSXhBMjZq WnEraUYyTy9NemlGNFFyK00rYXllL21uVHB0eFEzcktFaE5pRFlIQUVHeHZtSkR3T0s2d2FhRjV1 cmZoakh0SjVnK3FnRkVRTzJVZHhYWHJtak1OQ3prbTZuRjFHTm1QQTU4OHJaQjI5d0lOclluVjcr Tmw0VnUyL1dBQkU2TkowSG5hdGtwYlBPZWxkYTJjekEyeWlRUW54c3JScEN0eXhmV0VXQjllaUZV SnlWNTNycENYMUpqa1k5cXJzb1pBWHJRTUxCOTIrZVBDVlZ1MzdYaXJaUVNCcThpYlNSUUl4YWJu ZWY0TG14dUpoR1VmdkNQOUNwcnlTMmJPWW9OUG5vTXJpNkJvTGVmSlE1YklubHFFajdMbThtNzhl b2swelU5VGtKaXBoMGU2SExmTmczY3FuSERHcjViUjFqdzJtV3QwL3RZcmZaMXBEbmJQRjBBUEFm azN0TE9WTE81N0E2Nm95VjZLTEZERTlhYmUyYkNzQ3FWZzhTWHBUelU4UEpIQXhKYWpIUmE3UUNT R1dneDVtUmdxNmI0by9BV29nT2ErUTd5KzhXZ1N2SEN3RHU0RVd6RHJ2dDg3cDVvOVl1cWtSM3Rj M1BoT1BDWEVrT2ZMNGRBWWs1T2E5NkhRNUptOTIyOXRVcFBCeTRqVGgraStuR1NLUXFMOHVXWEJB cHM2aEJFUUU2MmVreGdjcXQ5UWNDSjZiTWhhOEgwVk45MjhzM0VlNzd5Sk1GYXE1MytyQjhMR2RV cWR6Y0hjckM5R01OWlhKZFhoUUg1ZFhSMUNIN2hpL3BSU1FOREpxSXpzclIrTlFZWnVFQTIwSHo1 Z1REallxSWVWQXI0bjdBczQrbkNuQzRwelRzbTNDbzdxSDVmV2ZReStQZzRNY3RyRTd2dklVSHhq SXpNQVFTMmJLUWJWeUFxaWNrQ1AvOFdZb1A3QXdMUE5WbWNRTE5UZUJXQU9HMEQ0WUZtUWlENVJI U3B1YlB0VzR5TUh5VkUxU1BKRk9KTjBPazYvdDJSVDRlTTNVQnVBanFVeUxzaFNTcFlZUmNsTDRy R2I2cFhyeWc3TGhZWXNlRGRNSWRyQlBFYnFFZ2dOVHErK1llTmFKRVAwMnpiblNsbmJlOXdSTmI5 YkpQSlk1cGpmTWNRbEVxdkx6OHpYSkwzWnl1bnhKWnptV2F0WUhIWHZEWisveVBrZi96TTk2M0Q1 d2lpUnRvYjNkckRNRWdtZjBEZ2RWZWNHN1FidHo1OTNLcFI0Um52bEhpd2xoSUxOZnpCYkhuVkpz dnVTQTJXRFd1b1g5aVFha1hlbjJkWExpalRnRFB4ZjdhM2YvSUVOQkZuWUYweEZkUldpTzB5VDlN VUo4TUYvMEFXaFgyWEE3L3FRcUpsOENMSlFtVHRPY3ArdmdXOTNxS2dVbnM5cFZhUnFFTVVseFd4 bURKS3lTem9tLy9OaklkM1lqeDNzUEdvQkZXbGJnbUNteVZmQzJNOXIyWTBETmxTOGJsOGtWWUVX WEtvRmFYZHMvZ2NCNktmWU92bjlGdHQ3RWdDd2ZMZThJVDFsWWNYaEtja29vbXUrUTlTZlZhTERj N3ppRGFhakZRQ284ckw0TDh4U0h1UDFPZmkrR1Y4a3EyT1orUCs1TUIvaWhpVXdkUzZYcHl6M1Bz Q2pJTmRNOG5sZ1Rua21xMzNQd2xBYk9ueWlMZlIwMDBZZk1pRGtnSkpnUWxUSW10QjRMejNCYjJC cUs0aU5jMmtTQ0dRVFBYbjRiV0JHVVN3VjB4Y1I2NmQzekx2SlhsVTBpMWZ3WlJjaDROc3oyWnRa a0xOMFBqSmpvUlRBZ2hWSWtZd2NIc0tWNWtnTVJNdmQ2VG9oamFYSm5aNUUzeFU3Sk5qeHFXMHBT aUZKS2gvTG0rcGFCaXJhdEVydjhISk9mdkZWRVpSQkszZ0ZNQjk2cnFHODZmQUh2VnluSUl1MlV1 Q2tXWVJqRFFqd0VxaDF3OEd1QWVpV1FNdTFyUzF5V21QNTZlYXliKzNoQ2s5R3N1aHBSSHRxMk1a eU9tOHNDZEdnaXpFbUdZTGlNRUMxTVhoNnhXM2NSZ0pMK1BUTWh2Q0R0aS9YbkdmOVI1MW1QODRt V3BQT1BsQUNOMWRpZURsblYzSUhMVFpMWWx6UHQzZW1TZ1ZwM28rV2JidzA1RXhIU1djOFpHYUlv UytSY1M1Q1dtYkI5SzcybERSUnY0RlpXcmkzSmprMi80bVg4R1YwOFh3elpVNndFb05kRmJ3MHVR bkZpQVlob3JYNWk0YXJIOWdUcFdYWlZHTkpYYWxtWk9Yb3p5TGFkSSsrZlExTEs0VkV3NW1ZeTMz dnF3UU02QnpoNEEwSTFzbkszTDFrTHAyQ0V0Q29zZFArakxMN0hvMVRVaEJxUHd5MTBSTFNZYkcz d25WbU42QmRrVjh6U1BzbGlVc2pLUUZtSU83T0RPa3lqWlpRSlNWbWIwcnRzcWdEZmRwaGh4TXVz Z3ZlQ1RoU29qbWM3bU03VU1tRGJPUmF2TzFCWitQcm0vVElWTGtCNk41MmhTTXc4QWdRZFJsRXVv U3VDZE5jNkFpclVDRkg3ckV4WWVjUk82a1J3NGFYejV6aUJIem9lQjVObDd0RmtsVEhJelEydHJp dWZUeFBsaFB2RjZHbXZYN0pMN0NLRWpPYzJaZUhMRXNRTXZxUEY1NkVGQXpHcjF1d0N0QmN5bWsx U29zL0JsL3E5cFJlcU1xMkdpRVpmbjcxbkdJdE5RTmVRaGJwSTZvcE9lMHh2NXJraktlbk04YTRU bEJmRCs3ajZseG9QWjV5MkpnZjZkUldjSnNRRDNkNCtJbnZDOVNMMlYxWTBtZVBmM3ZzRWJvNmxY RFBnMUZON0hZdVpnRDJ2eVBJelJGMEZnM25ObW5rcVBJNGxDYnlzRzdqMkd1NENaUE5ETEZXVy9i YkUvK0Zkc04vRmlaOGRyVXE2U3NGMCt4azJqcS9nL1lRbkN0Qk4vNDJsSVZFbDNjZm5hdFRzS3FW NWZ6ZHpGMUZ5R3MxQmdqZmZIeDdENzQ1dTRrYU5wOEtmV0E1VXJ5bXpnNVJjRmtaUDI1bVoyTVA3 N3lET1lXNFZkQ1cvRWFudktIZ3JHVkxBZTNJMzFra2xqRWhnQ0ZsWjJ5amV4c3BDM0Rxc2U4SGEv eTlmTlM3ejlUNU9oenNOT0RWN0RXaUtteHdZcDY0TG1xd3BVQko0MU1kL3BzL3V5WVl2TWYxWXZw YnN6dG5pSlZST2NucmsvU25zdmViMnJTMnNoNjNITklJN0ExUzVSMThKRDFQTVFJNVBURDhsTjVh WElHOUdCTFhzSzd4bzdHVWg4U09uT0xkNnBCOUk3YjBSOFdzUDA1ZlhmSWphUXRyQ1drekI4c2Jq NXJjNEkzbFo3cm9MZXpVMnlUNjRPTjZVVXpvQ2pYWW82aURIanVXNHV4eXZ0L0MrMkRIUm51UllJ dGlJcGh4MktFZW1XZWY0dlZZdkM5TWhyYWlzUWM5Ynk4RGROTVVNbDFib2RiVWo3WmxTeWdoU1hC VGNjQ29mK1d4ZXYzeWQ8L3hlbmM6Q2lwaGVyVmFsdWU+CiAgIDwveGVuYzpDaXBoZXJEYXRhPgo8 L3hlbmM6RW5jcnlwdGVkRGF0YT48L3NhbWwyOkVuY3J5cHRlZEFzc2VydGlvbj4KPC9zYW1sMnA6 UmVzcG9uc2U+Cg== ================================================ FILE: providertests/testdata/onelogin/olgn09_response_17.b64 ================================================ PD94bWwgdmVyc2lvbj0iMS4wIj8+CjxzYW1sMnA6UmVzcG9uc2UgeG1sbnM6c2FtbDJwPSJ1cm46 b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiIERlc3RpbmF0aW9uPSJodHRwczovL3Nh bWwuc3Aubm9wZS9zZXNzaW9uL3Nzby9zYW1sL2Fjcy9ycTVqd2t2Yjh6IiBJRD0icGZ4NmM4OGU2 NmUtM2MwMC1lNDc3LTZhYWMtNWQ1MDEyZjk1ZTZhIiBJblJlc3BvbnNlVG89ImlkLTUzMWIyYmYw MmFlMGE1ODhjMzAyMzQxNjNhZGJmZDlkNmJiZjA3NDciIElzc3VlSW5zdGFudD0iMjAxNy0wOC0z MFQyMzoxNDo0MC4zNzlaIiBWZXJzaW9uPSIyLjAiPgogICAgPHNhbWwyOklzc3VlciB4bWxuczpz YW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiIgRm9ybWF0PSJ1cm46 b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6bmFtZWlkLWZvcm1hdDplbnRpdHkiPmh0dHBzOi8vc2Ft bC5pZHAubm9wZS9oOWdranp2YjNlPC9zYW1sMjpJc3N1ZXI+PGRzOlNpZ25hdHVyZSB4bWxuczpk cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8wOS94bWxkc2lnIyI+CiAgPGRzOlNpZ25lZEluZm8+ PGRzOkNhbm9uaWNhbGl6YXRpb25NZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8y MDAxLzEwL3htbC1leGMtYzE0biMiLz4KICAgIDxkczpTaWduYXR1cmVNZXRob2QgQWxnb3JpdGht PSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjcnNhLXNoYTEiLz4KICA8ZHM6UmVm ZXJlbmNlIFVSST0iI3BmeDZjODhlNjZlLTNjMDAtZTQ3Ny02YWFjLTVkNTAxMmY5NWU2YSI+PGRz OlRyYW5zZm9ybXM+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIw MDAvMDkveG1sZHNpZyNlbnZlbG9wZWQtc2lnbmF0dXJlIi8+PGRzOlRyYW5zZm9ybSBBbGdvcml0 aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvMTAveG1sLWV4Yy1jMTRuIyIvPjwvZHM6VHJhbnNm b3Jtcz48ZHM6RGlnZXN0TWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8w OS94bWxkc2lnI3NoYTEiLz48ZHM6RGlnZXN0VmFsdWU+cVFHemJXcUNZNEdoZGdUMzBpTmlYRHlJ Zm9jPTwvZHM6RGlnZXN0VmFsdWU+PC9kczpSZWZlcmVuY2U+PC9kczpTaWduZWRJbmZvPjxkczpT aWduYXR1cmVWYWx1ZT4zMmN2VzQrN0VwdXZJYVpCaG1HcjRYVGRxU0gzcXBNWWRNdFlqQk01U3dh T0QxdUw2a1NtUEFweG1SNWIyb3JkblZ2NjV5eFFybTdENnUwdUl2RFYvVUJEaDcrakVuVkowR1lk dXZsYlNMSXpjTkZybEI3QVpPT2JqMUJvZWZJeEt0dHFkcUxHckgwKzZYMnNhaU5CVnR0VUpKb29x NnVpZ05mWmpUbkY2TGJuejJReHlBeTNKeEZvTnZHQ25meGFmU25TdWdQYmhvb2tVSElvYk12UGh2 Ym5ac0VVL3lEcUw0elYrREFkcm0xaHc0U28vVzcrVGpWdGNJOXFYc0x6WjJRcWsvdi8wOHdUR1Av eEZnWWw5SlBmN0R4eUhBVDR0ZjNEQTFoSFhBNkVaRHdOSkdkU3FWcmJFVEwyMGF4WEk4ak1WaGVR NU54Y1dFYzcrVjFvYnc9PTwvZHM6U2lnbmF0dXJlVmFsdWU+CjxkczpLZXlJbmZvPjxkczpYNTA5 RGF0YT48ZHM6WDUwOUNlcnRpZmljYXRlPk1JSURQakNDQWlhZ0F3SUJBZ0lKQU1RZVduREpWYVR5 TUEwR0NTcUdTSWIzRFFFQkN3VUFNRlV4Q3pBSkJnTlZCQVlUQWxWVE1STXdFUVlEVlFRSUV3cERZ V3hwWm05eWJtbGhNUmd3RmdZRFZRUUtFdzlUUVUxTUlGUmxjM1FnVG05d1pTNHhGekFWQmdOVkJB TVREbk5oYld3dWRHVnpkQzV1YjNCbE1DQVhEVEUzTURnd09ERTNOREl5TjFvWUR6SXhNVGN3TnpF MU1UYzBNakkzV2pCVk1Rc3dDUVlEVlFRR0V3SlZVekVUTUJFR0ExVUVDQk1LUTJGc2FXWnZjbTVw WVRFWU1CWUdBMVVFQ2hNUFUwRk5UQ0JVWlhOMElFNXZjR1V1TVJjd0ZRWURWUVFERXc1ellXMXNM blJsYzNRdWJtOXdaVENDQVNJd0RRWUpLb1pJaHZjTkFRRUJCUUFEZ2dFUEFEQ0NBUW9DZ2dFQkFP d1ZWWEU2N2RXRldRR25GeVdMUXlhQXFjbytoYXJnSE5xNURXVGlRTTVFRzFHRUx0NVFxVzdYUUp3 Z3dmSUhpYzd6TUJEVTEzRjZJVXJoMzEwZ05tME55Z2c3RFdFUkVCTlp2VGRqZzk5OXBiUnl0NUln ZWloS2g1TkV3cEg5VEdYbmJvdzhRakk3OUFxc0I5SXJuMGZFdUxLYjFLT0YwRU10NVhxSm5XMm9x SnJ2VGRZZUdvaTdDa3BnOUo5ODZYTXFMTXA0OEdkOS9BVG84M0dIc083dytOS3MwbUF4Qi9UZmZo NmhyYklMdE1WTUVOUUI2bHYzZElyZG1RcVBHSjEyMHhPNmRtSHFMVGordE5Tamhrem5TS1hCREhU Lzd2R3QzUmEzOFA2bUdDS3JEQWxvQXoyWGRYSmNkaVk1N1B4ZVF2YzB6d1J0SnRPeHBoQTVXSE1D QXdFQUFhTVBNQTB3Q3dZRFZSMFBCQVFEQWdlQU1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQkFRQVEy UDlhVUJhTTFrQzBYSkY4NkE0YVlrcVJWdXlzcEpUNitET1lBL3BjaWZaM3pocFhQZTIrVFkyZ0tz R2txZlltYTdjaDZkcTR6VkVyRk13a244cU03UEQxa25LL1A4U1p1VVBDM0xUSDNFVEgrYmViMWxN OU5JQ09JdGtodTdSSXd3d3doQVpLUDUyL1d3MEY1OVBDdjFTUFpKMU5rRjhYV2FrNERmOGw0dW40 eHNYMWpjRmtGbFV4Q0RoNnNpbWRGT0szaWJNSFVaeHlHYnZLL013SmZLUW1NY2pvL2ZJYXVrdjEv MnRLWG5pbFNEaFFTMTE2MXlpWDdvb0ZkRCt5NTVLYUdGNU81MEsvOURXMzBFOVpnclNEbHRELzZh R3QxN1ZyWDV3bmtvVWI2OENxWWZVclJqaHBiUFlJTEd1OTZhbEk2K2VMZUl3WktwS1NiTWo0PC9k czpYNTA5Q2VydGlmaWNhdGU+PC9kczpYNTA5RGF0YT48L2RzOktleUluZm8+PC9kczpTaWduYXR1 cmU+CiAgICA8c2FtbDJwOlN0YXR1cyB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpT QU1MOjIuMDpwcm90b2NvbCI+CiAgICAgICAgPHNhbWwycDpTdGF0dXNDb2RlIFZhbHVlPSJ1cm46 b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6c3RhdHVzOlN1Y2Nlc3MiLz4KICAgIDwvc2FtbDJwOlN0 YXR1cz4KPHNhbWwyOkVuY3J5cHRlZEFzc2VydGlvbiB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5h bWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiIgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIw MDEvWE1MU2NoZW1hIj48eGVuYzpFbmNyeXB0ZWREYXRhIHhtbG5zOnhlbmM9Imh0dHA6Ly93d3cu dzMub3JnLzIwMDEvMDQveG1sZW5jIyIgeG1sbnM6ZHNpZz0iaHR0cDovL3d3dy53My5vcmcvMjAw MC8wOS94bWxkc2lnIyIgVHlwZT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8wNC94bWxlbmMjRWxl bWVudCI+PHhlbmM6RW5jcnlwdGlvbk1ldGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3Jn LzIwMDEvMDQveG1sZW5jI2FlczI1Ni1jYmMiLz48ZHNpZzpLZXlJbmZvIHhtbG5zOmRzaWc9Imh0 dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyMiPjx4ZW5jOkVuY3J5cHRlZEtleT48eGVu YzpFbmNyeXB0aW9uTWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8wNC94 bWxlbmMjcnNhLW9hZXAtbWdmMXAiPjxkc2lnOkRpZ2VzdE1ldGhvZCBBbGdvcml0aG09Imh0dHA6 Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyNzaGExIi8+PC94ZW5jOkVuY3J5cHRpb25NZXRo b2Q+PGRzaWc6S2V5SW5mbz48ZHNpZzpYNTA5RGF0YT48ZHNpZzpYNTA5Q2VydGlmaWNhdGU+TUlJ RFBqQ0NBaWFnQXdJQkFnSUpBT3ZwWnRKTnRRL3JNQTBHQ1NxR1NJYjNEUUVCQ3dVQU1GVXhDekFK QmdOVkJBWVRBbFZUTVJNd0VRWURWUVFJRXdwRFlXeHBabTl5Ym1saE1SZ3dGZ1lEVlFRS0V3OVRR VTFNSUZSbGMzUWdUbTl3WlM0eEZ6QVZCZ05WQkFNVERuTmhiV3d1ZEdWemRDNXViM0JsTUNBWERU RTNNRGd4TkRBeE5EZzFOMW9ZRHpJeE1UWXdNekE0TURFME9EVTNXakJWTVFzd0NRWURWUVFHRXdK VlV6RVRNQkVHQTFVRUNCTUtRMkZzYVdadmNtNXBZVEVZTUJZR0ExVUVDaE1QVTBGTlRDQlVaWE4w SUU1dmNHVXVNUmN3RlFZRFZRUURFdzV6WVcxc0xuUmxjM1F1Ym05d1pUQ0NBU0l3RFFZSktvWklo dmNOQVFFQkJRQURnZ0VQQURDQ0FRb0NnZ0VCQUtmVWxjaXdEUENKOUpYeTFOc3hLZnF5T2ZMUVhG S0tHZ05LS1JMekxBV080M0dnUVlyVjY3UWFBbnk1THZnT2E4MUtRT1g0SXZqSnkwbmQvVnJPNmpH OXBUZE1SOXZGSFQwVHUzVzFRVXN5UFBTUXFwS1h3YjJaQ1NYTmdoWUQ1Z0JyTnRtT3hBT3MxQXp4 NXFtSXpCSjRGMFJrUml2Y2RiWFNmQlVCTHBDbjFNMjg1YzR0azVTRXZvUmdCZWlzTEpKREI3aG15 bEExVjYvK0JOK042YjNNK1paRy8vQ1R2T2pKS2dud2tNQUx6WGJQYlFXYTBrcGJNTERNejhLcjJw T0RMS2IzckdtZGY0UDZBOWFBNDFrNkw0Y2xUc05kY0s3WndKMmZHRjc5V0d6RTZSTHlCWDJVUzNn UEhVWHQvV01RWlh5VUxPM2V4aVREc1FYV0ZmOENBd0VBQWFNUE1BMHdDd1lEVlIwUEJBUURBZ1FR TUEwR0NTcUdTSWIzRFFFQkN3VUFBNElCQVFCM2ZRWnoycU5Bby93b2hQTmFSMnVBYWtMdDI1Y0ty c2JnbjNYd08rWCtEUkg0bnFNU1prSGRMR3I4MnhEM2kzM0JMU1F3WHpGZWNFTitDQThTbHBOb0lY SHdrNkQ2VjN1RUJTaktlbVp0SkZDSnFlOGQrNXF0M0dWNTBBS210RXQyTmM3Qjk0VE44eEI1RW1a bGFkblRKV2NCZ1N1dXoxaExYUVEwMmRKM2REcThGTWx5UjcwUzJEVHR1UHUwaTIvZjZLdHJsbW1O c1UyNEFxK2ZDekVHNDNOcVNoT01lTTVyRHhMc1NKQ3RqZk1Sd0c4WWV5TmY2Y0NNU014WUFKZnJU eWorQVM4UnRaUU5HRjd0WCtleEVXSE9mMUM5Q0J6SHRLUkNsQlJMNnpEamxwUENJRHdjTUZpOE5Y dmFpVmNseElxM1hkZnF4aUdCQkVsZGtoZ1o8L2RzaWc6WDUwOUNlcnRpZmljYXRlPjwvZHNpZzpY NTA5RGF0YT48L2RzaWc6S2V5SW5mbz48eGVuYzpDaXBoZXJEYXRhPjx4ZW5jOkNpcGhlclZhbHVl Pkg0WUJITXBMdzBYZkZJdFVHSmhWdW93QWJmZlh1djhsZ1N3N1ZjbkhuWk5OWUF3U0M0dFU5Mndp d293c2E4dlRTWTZwWkxjK1hzRm1uY3NyS0ZQOW9helBKYnI4cEhqQmZTa3RJaFVkeEJtNkVTaWkz SUNub1YrQlp2aW9lbTkwOVdNRVlUb29HaXdBOEhqYVlFRDhqdTBlTzVrQ01QNE5veUROMXZWcmhT aXRWOHo1RHZpaXk3RWpPY1RIb3E4b0VQUUNGNHpRMVBldW9acWxQN0VDYlJQWWh1NlBSN01rT3dy ZHE1aUluWm96OFB5Mk14TnhTaU9mUHl2c2s4MHM4SVBuTUVWNFk1R2dhdVMwYnZtcVM1RHluRWI5 VHJPazdYMmE3ajE1eDZ3QlRMdzl5ZTRPcEdaRThWYU94YXFQZWJGV2w2QVEzYUp4dWkzZnJwakgr UT09PC94ZW5jOkNpcGhlclZhbHVlPjwveGVuYzpDaXBoZXJEYXRhPjwveGVuYzpFbmNyeXB0ZWRL ZXk+PC9kc2lnOktleUluZm8+CiAgIDx4ZW5jOkNpcGhlckRhdGE+CiAgICAgIDx4ZW5jOkNpcGhl clZhbHVlPkl6aWpyQUpTdHJFS21YSjZacGFSL1pZWkdidG1ybmVSUERqMHRPZnpkUkR0Q3BObGMy aHp4b1dpYXBVUjRQaWQ1ZnBCUENYa2d3ZDZXb21mWCtzaWlZNEdDclFCcmJ0c1lDTm92UFVYOGJx Y1libFpYaldsVklucnpTc205RXkvNStEMjl1Mit1ZGI5ZlFGOVVxKzVzY0FSTy9HSG12Vml0N29y MDliZlVrd0p4VWNvOEtiWTRPUklraEpWWTRPdzBvVWZ3MzNxRDFzSFJ5c0VpTmdBNWxMRmF6RW9H UkcxcDg0dnFJOTdVRUkrUW1tcnFJU3grU1BKQTQzZ1pqNzRYci8yeUlnWEtVemhoSFRLQlhMc1l4 M2hhQkNLeVk3WXFSZVlCenU4WUFtbVBGeU1OV1k3YjkxcDRBQ0RrU2daTHRIZFZTeVhKZGx3OVpj d0wyei9sbmFLNWcxOU1NYm5zMXVzOVZEU2l2V0s0SVJyY0EvYVBCQkhZMUZucW1DbVNzZ2hWTkNR bngvZkRlK3FHdW1iL3R5NGpLMGN5MllIeXdCaFVWa1dHYUVaa3h4Nm9YOTlsbi9WMSs3NlY3M2tL NGJ4UjFXMS9nVXB0MjRWV3Q4MUVwU2YrNlVHa3pMK2ZNd0VqT1hlcEtSVlM4b0hGV3NlSDVxOGVX TFRDQ1NaWld2Y3Vvb2txSUhZc2l5ZmkzSmVZclZxQ1hqbm0vaGdEV0UwOFpuemUzY3FlTGs2L2RB eDB4ZkU3enpreGJnQm1neEozSUExTElkK0Ztb1ZWSlpZSTNWTm9GQUdKQ21lWG9DVDRITnJJMWlL RjMwbVo2ejBuVDQ5bmxUemJyWVozNFVkbzF5S1dWZ3VKdWtVZS9qcFVraWp6Mk0vRE9RSkhLeUw5 czdJZUtJc3pwL3VrOGxwUzl3aTdCUFk4eFozZ2lPbHFZdW1YVUEyaDNFUHpRQmhFY3lHYWk1M282 WjBFNG5lc2NlQVVCOWI1UkFHZmJkYkptUkR0c1VGUGpvVGZENVJxV1NIUkxIbVJMVEQ0OHpqeUo2 SXF0Qjk3aGVHazZhblJ4RWtzUEpvNHN5a1FSMEZJQldhSlBlZG5GaDhlakRhd1QwRGdTT21uTVpJ VldRSlNWRmNoWlk1NUdtQjNkSkZNcTRUL0hOdEhOSmErdmJzZk1jQlhYQmZBamtmaS90WEVCdS9V SmFhNnVodXJwd29obi95YjM5YjcxZWNVaGdMdHY2VE1lcWJZRjVVTUxIbi9VNXIrU2dHUi8waTYw YUhieUo0Q1BhTHhlZnJGOFByZHI4S05hZ1FmM05EaVY2d3RZVE1tM1FZWWhZME9VMzRxcldxaWFm eXVIc0tLb04yYnN4dForaitjeS9TY0VhcGtPWlNndVJ3bzlTdTJNU0hxWUJxVExhdmp3RktsUkt5 d2ZPcklzbFBTZFBsU0pHV1B4RloyWng5TnhGUGRpaTJvamFBNE0rbU9jVTlTR2duMUZ5K2srUEdo Mm9PTS83ZEwrVkhEUzUwRndXN3RZekZxWHdOUFNiRFNDZ2JGUWNmVVptSjFzbDVGN25qQWxjN1BC Z21JYmRiR3JiNU05TFF0eXFEYVRFdlpDRDA2cVNKQ3Z5K1BLWEdxaGl5UUdaVTVhNzJudnRPKzRh aGd1TS9CMTgzcVduejFOOVd5SG1BWUJrUlRYMGxKdVZrd2R5RDloOHRZMWkwbERKS1dYQmVxdTJQ NkhPZTBJSFp3ZzJXKzBzcWxaYU9hbGhjYWMwZ09uUHN6YStHWmcrZzdrdDhHUmR2MEpnSTZ1MkFK RW43S1lDNVAzN1NGOEUyK1YrVUtCK0NTa1FqWmV6b0JFR0FDKzRPOXpCN1VvUHZCTU9ZTlVvaGNu eDF4KzNuSitFcUYyZ1JlVnZPWFc1a0NIYml3WWVKZDFmam9uUjBkY3AxQkhadUlPYUdOdnJERTJC b3NXOFo5R2NKNDl1SGZoN01MYnY5VzZ4MEVvRVNKalVhYUtQaGxPV2tYRi9oU005cW9OZUpzOCt3 Q1FpK1l4RFJJbEwwc0gzN0IyK0VMN1hLOWkwR0s2SGU0WE9pUDY3OElYRU1WNjc2d3dzL2xUSllO V3h2b3pObkVDS1ZDNTlPRjZTNHN3NkhFK0VMZnhGai9BcVpMZ05vbFVNOVRENzVGTWUzV2QvdWxE N2QwTUpjaWVIcXJRUytJVnRJb0d2TkpTUHFXQUFKM0c1dWJ2enhqNmx1UWxQS05iVG4vTzV3SUJL MGtKaHhHNEhjNFdYNWEvVERocjltK0M0SXhmTmRZem4yNHJjckMvdTJTcjR6dzBZbElQM3hsTXFD TldpdThLbDY5eHczeEJrS0xmQWNtUDQ3alFqbFp1bW5vVldIMHI3TmVmbTVkYTc2ZG5kTm1nc2sv bjQ5K09OL3NjdFVLWUVEN2VXWHdQcnpUK3dIUktBVC8vZGtxK1k4RGVqZ04yek9SSU1Qb2NpMFNX MUJtUnZIOXpseE1Zdkg0N1N1UkhqNi93V2pEUWFrSkQ2TXdRbGU2NHV6OENhVDFJdS9OenBCN1c5 VWVFUWdETVVFOEFCMWxRNVdHR2M1cEN6YVhNM0h0SDA4K3h2NEtzTGtDUWpDV0NJclNjMll2OFlB SVB1WUlQM0hxaGNVeVBESmVjVnF5bjNrUUtzbXZxTlBrYS9lWGJVbkdsVmxOOW92OStWWjA3OGtv SUQvUE81SkNhZE1VbFRpVnZUVERkamVabUFxMTdRWTVwTGx2dE9PaktJUHF5aHROSEliQTlKbXc1 YUYvcTZqREdWSlZOL3FLSzg2Z2tpTysvNW9HSGJpQkpDK2lSQUkzNUZvVjVXdExHTWVpSm9RbVJs UkRaZERSNWVDcVNtc3hZdWlXVW43RC9BdWFSN0U4elBDMEZ3RmRzQ1k4SzZNNlZsN01KcTFJK094 YTdnZHRLS09IekV3ZXdVcDQ5WTNvM0RlT0ZVRjAwZy9rem9xV3gzVHB0MWZNL3hFU25RN3RZcCsr R2Y1UkNobFRQYkVZMWhNSCtiREZ5UkhHazltbGN1NXllMTRldi9aTkRoSUowZ0wxV3daQittN0xm MktBek1VY1BVU3ZzK1NyeEkvVVdwSnEvSWs1bzlpVWRlcjZET2FEd2FLLzhYREcxZWtNSXlZcXpX N3ppcHVFSmZzQWp1Ujl5ZFRhVjRGQVVUYy81dHR6TDBWd1FBUU9MQi9GNGRSNHhuSGJoOXE3K0ZF REN3K0Rjc3hvZ3BjTi9FL1FnMll0UDNPbnNZTXorczZkYmhjMys0bGlRWFBiTU82R043ait6SDcz dUhNMHZTWWswL3lSV051Q2dxMVBxTVhUblN6Q0pnNldLMFhnelpHN29ieW5ycjh5ZStINXN3T1pV YnQzQ0FzaG02aXVsQk9FbXRSbkdVam4wR2o5UGxVRHBoVnd5RFZFaThTS1hKK29oaEdVdW1CQWJU R2JLMTQzbG0yU0xGMXBFbFVOMEZFcjBucU9GRzhiRDdIZlRPOHU3bitNSC9aSEFNMlpBdkk2dGJC bGJOV2NOWm5oUUcrWmFTTXVicWJNRWdBOEtFdHNWQ2pUaXluS0xWSXJBS1YzY3J4VHpJcFJQTjhT dXNpSGJUWFZCNHo2dUQycnowVTZEUjRiSGxsRzlxZzRlUnBlNjNiMXQxZnE0UWdtaUNQVkE1YTVK TzhlSGdoK3JOZ3cxL2tVTjAzWkVUeXJVVFF0N0tOc2E2TGplRno2ZUpUUEppT284ZlZ4ZFlNNzJ0 cTNvRWpxRWE3Z09jRFhMeGlGWlYxYXlhSHI4VGlJQ0g3WFZVYVg3bkdXWjYyUUM3VGpNRlp5bytE emZxSHZOa1BLY0xTUncrWktuY2lCaGQzdXRSMHZsOVJVWEdZYkNTVmpuV2JuUVZZN0RTMEZyS1hq d2t2T29lK0NYKzgvTmM0MkV5TnpNZmxsaW5YdU9JV2I0OGNtZ3lPT2xCMzhBRGs4bTlvNWJsYWJV bG1FRE4xNi9YblhkaytXcksxQmJNUzdqMUZhWU95NTVSakdCRlVTVHZHaUl1V2pFQ3FtdWkzYlpD WW0zRExMdGFFUEg2Uy8wWCtTRWcwaGt0T2E0ZzRNM1FJdURCdUg3dWxYTXh6c2gzY3U4dGJSWklS QjdtdEladjBVaGJORUJodUQwQU9kWjZnbEpzc0tQSUhpRlNpUHFvVjBMelpaVTZqZFQvQlZBTlA5 SE5BVDFQWTU1SUR3OFRIcmtDdDRIcWc2WU8zSjVSa3FibjJvU2h2QkcvOTNwblQ5Vy80VWE4ZG9R UXdsanl2UDFpWUw3SzFDRndHR045dGRSK25UK0ZwWWV6QjdxZEU4ZS9RNDkvc0QrYklLVTNycVRW ZmUzQTZwRVNlekZJbzBsaUg3eVU0Y3BFQjFNdGhubkRhRkdINE9FaDJvckNMam5KOEhXL1NMdEVB UThnWHE4cWpqVTBHdFdITFVFejRIQmZSOGVNWjJXb1NBdUx2WUNHWW5sRUtMZmhTVTNtdUtIR0pp eDdRRzJRNktGT3liTkxqL0hGcm95MnlhQUVHY3hXeG5lWUNqVkpDZktrVkhoajBEOVo4eGFWaGk5 TW8wdFdBQzV1Y0Zrc25zRzQvYjNBRVlaSHRHSFg2SUFCdmFDbERTQm02MzhsQlRtRGFnYVlTMmpx OGQ5WTdEYWQ0OU5Yb1ZxQm5yaUszOWgvUHZrNXdDcW50U2M0WDBuQ2hzb3hKS2c4Yk41cm1SSGZY bUV2azNsang0WVhhOVZxVlNnZ2k1b3M4T3R3a2tkYWlBM1BDbVNUMVR3N3JOK0hCOUM0MzYyUTN1 aUlYa0d6TmljRjdCRkM4NEVQN1lpdUJVWUswVkVmL3g2eDcxT3kyVzVjdXdxem9sSm9scDhVdXAy QldWYjZXSC9VcTZnd0ZQOCtWRWREKzRyeTlvRmhQMXo0Y2RnTy95eEd3MFl3dFhhUGU2ZkdsTVJS dTNYelVZbWI3cTU1RUUveGFvcFppNEd2TGdiV215L3JQVnVuZHhIeHVLZm0vejc0WjlCbnZsN0x1 WTV5RnB0Syt2Wm1WY25hejFxUXZocTBxMklEREdRQ3IxOW9UdVNwZGo1TUdwM3hDL2FSdE9lbFA4 THZzYlRnS3lRRHNzTVVrM2psL0dIV2svQWRzZ0lPSko3YmxjZzcwZnB2WU04ajhsL0hxS0txenp2 Wlp3emJSNFFhbGt2b01iZ0ZjQVMrcXlzV3lYR05NQUxpOFpmcWZxK3pTbHpwOEhPMGsxNWlHRnhm ZTYzdW9xUUxETEt0dUJrZlBDNndGZDJqekNYZThrNFBHczZSMDdtcmM3dUIxZWZuWlRsYkxyMGhI cDhuYkpyZHRuRUN3Mi9tQ0NsVDVQUys1Yzc5VjlZaGI5ZmpyMGlNeVF5c0p5WlZ4MW56R1JnQzdx aUxnbEVHWHF4cDFqMFowZU5YcEFlOUMrVTNiQVJ5Q0dYb25JekQ2cGFTNExhalNtcU1iWmxHbHhS RTRFd2EvTWlaWHFQb2V1ZEpkWWx6OUN6VmxRTzJvU1Z5Vy9YOGpNY2pmeVlXNXI0UG91akZMc2tN MnBFWUJaZDdtUHlyR2xseEd3S0hjUjhWUndaN09iWWRibzlCd1BqY3dtNWhHSitncWJuV2MwdXFP K1NDQUQvRzVRRmVrUHFZMDlXZHBNdEhJcC93cnlOY2syK202Q0pTeDlsYUdYTTc4dW9Cc29udjNu SHBXWWdrQVVzTzNSRHczN2pOZS8rYmsyYktsPC94ZW5jOkNpcGhlclZhbHVlPgogICA8L3hlbmM6 Q2lwaGVyRGF0YT4KPC94ZW5jOkVuY3J5cHRlZERhdGE+PC9zYW1sMjpFbmNyeXB0ZWRBc3NlcnRp b24+Cjwvc2FtbDJwOlJlc3BvbnNlPgo= ================================================ FILE: providertests/testdata/onelogin/olgn09_response_18.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="pfxfdbb7180-5d54-e553-f223-0637e7e0bf0f" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfxfdbb7180-5d54-e553-f223-0637e7e0bf0f"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>8BA2Y9q1RUqmKApabc4ex2KBMa0=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>T4EVgt/yIeJZcKAPfaWSvcGIApuCFjaX3mqaaxNZzSRutdJsIk7jGExiJHgnFRaDgSjDrqZQUkoUl4ZOaddaLXPKHq5YR9kGUcWU5fFfc1GzPhrjLQl04pz5EuizUm1XpBcHG02/wILX/D1nX2tDjtGNegBvY31GUJPIek1R3zv8Q9Ck5Epfjp5WYgNaFkaLPgO3ICMr6CszuJNWcWwrmFzQnvvlDcVz/T8ecuju5DOEFdBGIlTHYzSi3mUKzzJLH1v8b/9f5XrvQOSQqs6g+TVw861qBu2I7t/RDuyGmEWoNkR6id6wdbzdqWL6Ayml5ldlWFkOOOuiOo4d1Hws8A==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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" xmlns:xs="http://www.w3.org/2001/XMLSchema"><xenc:EncryptedData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#" xmlns:dsig="http://www.w3.org/2000/09/xmldsig#" Type="http://www.w3.org/2001/04/xmlenc#Element"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes256-cbc"/><dsig:KeyInfo xmlns:dsig="http://www.w3.org/2000/09/xmldsig#"><xenc:EncryptedKey><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p"><dsig:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/></xenc:EncryptionMethod><dsig:KeyInfo><dsig:X509Data><dsig:X509Certificate>MIIDPjCCAiagAwIBAgIJAOvpZtJNtQ/rMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgxNDAxNDg1N1oYDzIxMTYwMzA4MDE0ODU3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKfUlciwDPCJ9JXy1NsxKfqyOfLQXFKKGgNKKRLzLAWO43GgQYrV67QaAny5LvgOa81KQOX4IvjJy0nd/VrO6jG9pTdMR9vFHT0Tu3W1QUsyPPSQqpKXwb2ZCSXNghYD5gBrNtmOxAOs1Azx5qmIzBJ4F0RkRivcdbXSfBUBLpCn1M285c4tk5SEvoRgBeisLJJDB7hmylA1V6/+BN+N6b3M+ZZG//CTvOjJKgnwkMALzXbPbQWa0kpbMLDMz8Kr2pODLKb3rGmdf4P6A9aA41k6L4clTsNdcK7ZwJ2fGF79WGzE6RLyBX2US3gPHUXt/WMQZXyULO3exiTDsQXWFf8CAwEAAaMPMA0wCwYDVR0PBAQDAgQQMA0GCSqGSIb3DQEBCwUAA4IBAQB3fQZz2qNAo/wohPNaR2uAakLt25cKrsbgn3XwO+X+DRH4nqMSZkHdLGr82xD3i33BLSQwXzFecEN+CA8SlpNoIXHwk6D6V3uEBSjKemZtJFCJqe8d+5qt3GV50AKmtEt2Nc7B94TN8xB5EmZladnTJWcBgSuuz1hLXQQ02dJ3dDq8FMlyR70S2DTtuPu0i2/f6KtrlmmNsU24Aq+fCzEG43NqShOMeM5rDxLsSJCtjfMRwG8YeyNf6cCMSMxYAJfrTyj+AS8RtZQNGF7tX+exEWHOf1C9CBzHtKRClBRL6zDjlpPCIDwcMFi8NXvaiVclxIq3XdfqxiGBBEldkhgZ</dsig:X509Certificate></dsig:X509Data></dsig:KeyInfo><xenc:CipherData><xenc:CipherValue>Ds9FxMuIUjbgHoTKTJL4XI5yYQIZLfTTWm4tXSiGL7xXvFGsnhhUNoft+DWlhxoeavKa9WPYzp0zWtAByh86+lw2/Z5GmOTWeXLelm24FqNfsY8Uu/K6KB8oe37IsXsR2fmhMJYQu7bjbUZCN3ICmwYLWh5uCVab7K9to7r0acxMf61XZYC4lsZFD4q4d+ylEmmbw/8hUiLHh+qOHCqjfSkHAQ+YOBUa6ZGQMvY5P4ZFhJZZ1PDfLJE/K90S/Yd0bkNotJ+DAXr5Jo2c0t6Dps5VW43C1yjAmtwTsjTiUnOqRTfQFbgilbg2m021OxpaQZah9b056hYxbchCypftbQ==</xenc:CipherValue></xenc:CipherData></xenc:EncryptedKey></dsig:KeyInfo>
   <xenc:CipherData>
      <xenc:CipherValue>++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</xenc:CipherValue>
   </xenc:CipherData>
</xenc:EncryptedData></saml2:EncryptedAssertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_21.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="pfx963c20f2-1ba7-b73b-20b0-98ed1fb2d74a" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-08T01:05:00Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx963c20f2-1ba7-b73b-20b0-98ed1fb2d74a"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>UE3tHfP6HY5vp4DKfob1q/DHWDw=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>2lItygqeAi6nYpwu2rsRUa5RrZf2sdLjbaeNpVD5dMJzPFwbqVbknFYRg54SyiQPSpp7KW85OIPVszHb7v5iVvADjrF8bGqyeqEd2hmrbB1qAIQaG5Uv4OVXkb2bBCdqD3EmUJ6QvQiGX4t2yAHt5LTJ/vgE3mGndlcpVgkC6dsKGav3X3ftEVT35Z3gM4RTsaVXJ0hdxQ+AIyjiJp0+WPTIKURhWzRK1c4rkCIA2nKni8x7c1Z3onKxpnWY6Y/9yxK4u4c0i1pGgc7UyaIfJkGML7tEoIlVXMXRTuTThimAaX5ckC5nB1ZiXkOBnaVeQoFWOyG6dj7yl0hCNuLcNQ==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="id70938295375467671318387720" IssueInstant="2017-08-08T01:05:00Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
        <saml2:Subject xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:NameID Format="urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-08T01:10:00Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-08T01:00:00Z" NotOnOrAfter="2017-08-08T01:10:00Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_22.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="pfx14163976-191a-bde4-de7d-613c78c16cf3" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2117-07-15T23:05:00Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx14163976-191a-bde4-de7d-613c78c16cf3"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>tD1TSy8BoR68YpQwQr4SfskTQWM=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>PBs6wwAxLfR/8nBFNVP+LZVVMkG/TQJA5n7m7KTVCDP/7niI6VAtR60cHMo5xgNaqcWmnH1sMP+r3Kh7zG80TRXqTbvZRbbCGiFqztFfOwUnexdnj1iyGd3lGxMxi6h+uz/HQ5jYCrbhR4iMbVtUsEUnnuIi67PW2TeFBARBDN8+yG/juhRSm/j0j4o1jLFsc17iC2JMOUuqF+7jXiZiI1R90G3/M9ufjeRMc9uuEbx8Mgn5XwE/7MVUcsw3wXsn7q027pf5bUKDxq3sV0uAfLsl3KdhoWUhU+EOnf+cfZduQl56qgxtVMvUGqOvv5xUFL9KfhXvd3ezz6uHmZYChg==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="id70938295375467671318387720" IssueInstant="2117-07-15T23:05:00Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
        <saml2:Subject xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:NameID Format="urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2117-07-15T23:10:00Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2117-07-15T23:00:00Z" NotOnOrAfter="2117-07-15T23:10:00Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_23.b64 ================================================ <saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="id70938295375022572142875469" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-11T01:05:00Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
    <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" xmlns:xs="http://www.w3.org/2001/XMLSchema"><xenc:EncryptedData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#" xmlns:dsig="http://www.w3.org/2000/09/xmldsig#" Type="http://www.w3.org/2001/04/xmlenc#Element"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes256-cbc"/><dsig:KeyInfo xmlns:dsig="http://www.w3.org/2000/09/xmldsig#"><xenc:EncryptedKey><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p"><dsig:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/></xenc:EncryptionMethod><dsig:KeyInfo><dsig:X509Data><dsig:X509Certificate>MIIDPjCCAiagAwIBAgIJAOvpZtJNtQ/rMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgxNDAxNDg1N1oYDzIxMTYwMzA4MDE0ODU3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKfUlciwDPCJ9JXy1NsxKfqyOfLQXFKKGgNKKRLzLAWO43GgQYrV67QaAny5LvgOa81KQOX4IvjJy0nd/VrO6jG9pTdMR9vFHT0Tu3W1QUsyPPSQqpKXwb2ZCSXNghYD5gBrNtmOxAOs1Azx5qmIzBJ4F0RkRivcdbXSfBUBLpCn1M285c4tk5SEvoRgBeisLJJDB7hmylA1V6/+BN+N6b3M+ZZG//CTvOjJKgnwkMALzXbPbQWa0kpbMLDMz8Kr2pODLKb3rGmdf4P6A9aA41k6L4clTsNdcK7ZwJ2fGF79WGzE6RLyBX2US3gPHUXt/WMQZXyULO3exiTDsQXWFf8CAwEAAaMPMA0wCwYDVR0PBAQDAgQQMA0GCSqGSIb3DQEBCwUAA4IBAQB3fQZz2qNAo/wohPNaR2uAakLt25cKrsbgn3XwO+X+DRH4nqMSZkHdLGr82xD3i33BLSQwXzFecEN+CA8SlpNoIXHwk6D6V3uEBSjKemZtJFCJqe8d+5qt3GV50AKmtEt2Nc7B94TN8xB5EmZladnTJWcBgSuuz1hLXQQ02dJ3dDq8FMlyR70S2DTtuPu0i2/f6KtrlmmNsU24Aq+fCzEG43NqShOMeM5rDxLsSJCtjfMRwG8YeyNf6cCMSMxYAJfrTyj+AS8RtZQNGF7tX+exEWHOf1C9CBzHtKRClBRL6zDjlpPCIDwcMFi8NXvaiVclxIq3XdfqxiGBBEldkhgZ</dsig:X509Certificate></dsig:X509Data></dsig:KeyInfo><xenc:CipherData><xenc:CipherValue>GWFgHernp79Fk+C5+rY1iOkR42nCtJ02LU6/POVmLJti2m5jM3iQaD8KVc6YomHuTYAbnoChewFOH354zr94Z0xJq84S/r5OOJ+DudkG38AEwaxnhJlyDliHTkdzbMrrfreZypvpVG7t06/m7LcJ60lXGXZtaj8DcaNEWycwvSzMVv4aZQhYOXSXs4c5w8UmJ3N6Ry4WjgbNCNeBVIOrYU2eWEGAxcnPDWVPU3dFoPiNpncOVkGcmGP3xsf4EhOOaJ5pdH4JdUjVvxK77kU5QyA3rsjKzGsoH4zrIHNE3QImpoKbo03SWy/4X87Bjb/PZ413pm1lEV854R64DwaWEg==</xenc:CipherValue></xenc:CipherData></xenc:EncryptedKey></dsig:KeyInfo>
   <xenc:CipherData>
      <xenc:CipherValue>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</xenc:CipherValue>
   </xenc:CipherData>
</xenc:EncryptedData></saml2:EncryptedAssertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_24.b64 ================================================ <saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="id70938295375022572142875469" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2116-03-08T23:05:00Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
    <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" xmlns:xs="http://www.w3.org/2001/XMLSchema"><xenc:EncryptedData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#" xmlns:dsig="http://www.w3.org/2000/09/xmldsig#" Type="http://www.w3.org/2001/04/xmlenc#Element"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes256-cbc"/><dsig:KeyInfo xmlns:dsig="http://www.w3.org/2000/09/xmldsig#"><xenc:EncryptedKey><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p"><dsig:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/></xenc:EncryptionMethod><dsig:KeyInfo><dsig:X509Data><dsig:X509Certificate>MIIDPjCCAiagAwIBAgIJAOvpZtJNtQ/rMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgxNDAxNDg1N1oYDzIxMTYwMzA4MDE0ODU3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKfUlciwDPCJ9JXy1NsxKfqyOfLQXFKKGgNKKRLzLAWO43GgQYrV67QaAny5LvgOa81KQOX4IvjJy0nd/VrO6jG9pTdMR9vFHT0Tu3W1QUsyPPSQqpKXwb2ZCSXNghYD5gBrNtmOxAOs1Azx5qmIzBJ4F0RkRivcdbXSfBUBLpCn1M285c4tk5SEvoRgBeisLJJDB7hmylA1V6/+BN+N6b3M+ZZG//CTvOjJKgnwkMALzXbPbQWa0kpbMLDMz8Kr2pODLKb3rGmdf4P6A9aA41k6L4clTsNdcK7ZwJ2fGF79WGzE6RLyBX2US3gPHUXt/WMQZXyULO3exiTDsQXWFf8CAwEAAaMPMA0wCwYDVR0PBAQDAgQQMA0GCSqGSIb3DQEBCwUAA4IBAQB3fQZz2qNAo/wohPNaR2uAakLt25cKrsbgn3XwO+X+DRH4nqMSZkHdLGr82xD3i33BLSQwXzFecEN+CA8SlpNoIXHwk6D6V3uEBSjKemZtJFCJqe8d+5qt3GV50AKmtEt2Nc7B94TN8xB5EmZladnTJWcBgSuuz1hLXQQ02dJ3dDq8FMlyR70S2DTtuPu0i2/f6KtrlmmNsU24Aq+fCzEG43NqShOMeM5rDxLsSJCtjfMRwG8YeyNf6cCMSMxYAJfrTyj+AS8RtZQNGF7tX+exEWHOf1C9CBzHtKRClBRL6zDjlpPCIDwcMFi8NXvaiVclxIq3XdfqxiGBBEldkhgZ</dsig:X509Certificate></dsig:X509Data></dsig:KeyInfo><xenc:CipherData><xenc:CipherValue>SO7mfmMtaQZq/IS0Z60B9c3AGhzg9nkIeZQNLfOBfGo3wUPhz/amCAax+NfyKVcVrXIpjx+DIqsuS6a3K0/6r4301GLKp62/erakDqOwMMYlQJZoFhI/iQxUat5vcu24VUR2SqVHzk1lQW+yGAZ4Mk+NNbJn1NqEVXZyydgrq7mY68hO3Zc6Bhfzc13qLlHZRGkqS/0MyVowbnRlMF9ygnvIMZIcJCjrMj1LNkjVu/uJhgoAc6W4anHXom+J1FoSOE/B5Kzp8Ensc414E0N8S4QMJzyjE1ImObbQsKXh4G++jPQRwbH9xjnOFq76e5pOreiiKLectx026tJ+bZmdvg==</xenc:CipherValue></xenc:CipherData></xenc:EncryptedKey></dsig:KeyInfo>
   <xenc:CipherData>
      <xenc:CipherValue>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</xenc:CipherValue>
   </xenc:CipherData>
</xenc:EncryptedData></saml2:EncryptedAssertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_25.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="pfx3b05d1fe-3b5d-ba02-fbf7-2c525c73ef54" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx3b05d1fe-3b5d-ba02-fbf7-2c525c73ef54"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>XRwVv9AoG/qSqUDu5c2K9lHwbwM=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>Oaxrfk2c5hSplmWoljpOaFlnQQXSamBcktNMjcepP5WYlvX2ybl7aa0ew81ettjtUyE0ym2antWtzwJI4arL5dGfHfPPQn9XJ/CvZG7YCiWPTkfc4jwqsm9OS3kafv/A0IoLOsffA3rFezu8fuCLixL92KNlNhRN/bryF9a7Fz7As20kOmp82mBMGuvL/APFOssxShmxb0NRvCMJCJkRAp837FKx+rn8RF/PbiFVZinRfO1qgMEsV/emnnf6awYzd6EPqSYX9FQ5jsKZn64nXXWyDV9YuAtDylo2kbO/XWDQcVB08MSfP9X2RWVTF/2rY2mc3lE0IEptr1nL45MZ3Q==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="id70938295375467671318387720" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
        <saml2:Subject xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:NameID Format="urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-30T23:19:41.379Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-30T23:09:41.379Z" NotOnOrAfter="2017-08-30T23:19:41.379Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_26.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="pfx3b05d1fe-3b5d-ba02-fbf7-2c525c73ef54" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx3b05d1fe-3b5d-ba02-fbf7-2c525c73ef54"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>XRwVv9AoG/qSqUDu5c2K9lHwbwM=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>Oaxrfk2c5hSplmWoljpOaFlnQQXSamBcktNMjcepP5WYlvX2ybl7aa0ew81ettjtUyE0ym2antWtzwJI4arL5dGfHfPPQn9XJ/CvZG7YCiWPTkfc4jwqsm9OS3kafv/A0IoLOsffA3rFezu8fuCLixL92KNlNhRN/bryF9a7Fz7As20kOmp82mBMGuvL/APFOssxShmxb0NRvCMJCJkRAp837FKx+rn8RF/PbiFVZinRfO1qgMEsV/emnnf6awYzd6EPqSYX9FQ5jsKZn64nXXWyDV9YuAtDylo2kbO/XWDQcVB08MSfP9X2RWVTF/2rY2mc3lE0IEptr1nL45MZ3Q==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="id70938295375467671318387720" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
        <saml2:Subject xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:NameID Format="urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-30T23:19:41.379Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-30T23:09:41.379Z" NotOnOrAfter="2017-08-30T23:19:41.379Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_27.b64 ================================================ <saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="id70938295375022572142875469" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
    <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" xmlns:xs="http://www.w3.org/2001/XMLSchema"><xenc:EncryptedData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#" xmlns:dsig="http://www.w3.org/2000/09/xmldsig#" Type="http://www.w3.org/2001/04/xmlenc#Element"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes256-cbc"/><dsig:KeyInfo xmlns:dsig="http://www.w3.org/2000/09/xmldsig#"><xenc:EncryptedKey><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p"><dsig:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/></xenc:EncryptionMethod><dsig:KeyInfo><dsig:X509Data><dsig:X509Certificate>MIIDPjCCAiagAwIBAgIJAOvpZtJNtQ/rMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgxNDAxNDg1N1oYDzIxMTYwMzA4MDE0ODU3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKfUlciwDPCJ9JXy1NsxKfqyOfLQXFKKGgNKKRLzLAWO43GgQYrV67QaAny5LvgOa81KQOX4IvjJy0nd/VrO6jG9pTdMR9vFHT0Tu3W1QUsyPPSQqpKXwb2ZCSXNghYD5gBrNtmOxAOs1Azx5qmIzBJ4F0RkRivcdbXSfBUBLpCn1M285c4tk5SEvoRgBeisLJJDB7hmylA1V6/+BN+N6b3M+ZZG//CTvOjJKgnwkMALzXbPbQWa0kpbMLDMz8Kr2pODLKb3rGmdf4P6A9aA41k6L4clTsNdcK7ZwJ2fGF79WGzE6RLyBX2US3gPHUXt/WMQZXyULO3exiTDsQXWFf8CAwEAAaMPMA0wCwYDVR0PBAQDAgQQMA0GCSqGSIb3DQEBCwUAA4IBAQB3fQZz2qNAo/wohPNaR2uAakLt25cKrsbgn3XwO+X+DRH4nqMSZkHdLGr82xD3i33BLSQwXzFecEN+CA8SlpNoIXHwk6D6V3uEBSjKemZtJFCJqe8d+5qt3GV50AKmtEt2Nc7B94TN8xB5EmZladnTJWcBgSuuz1hLXQQ02dJ3dDq8FMlyR70S2DTtuPu0i2/f6KtrlmmNsU24Aq+fCzEG43NqShOMeM5rDxLsSJCtjfMRwG8YeyNf6cCMSMxYAJfrTyj+AS8RtZQNGF7tX+exEWHOf1C9CBzHtKRClBRL6zDjlpPCIDwcMFi8NXvaiVclxIq3XdfqxiGBBEldkhgZ</dsig:X509Certificate></dsig:X509Data></dsig:KeyInfo><xenc:CipherData><xenc:CipherValue>Ds9FxMuIUjbgHoTKTJL4XI5yYQIZLfTTWm4tXSiGL7xXvFGsnhhVNoft+DWlhxoeavKa9WPYzp0zWtAByh86+lw2/Z5GmOTWeXLelm24FqNfsY8Uu/K6KB8oe37IsXsR2fmhMJYQu7bjbUZCN3ICmwYLWh5uCVab7K9to7r0acxMf61XZYC4lsZFD4q4d+ylEmmbw/8hUiLHh+qOHCqjfSkHAQ+YOBUa6ZGQMvY5P4ZFhJZZ1PDfLJE/K90S/Yd0bkNotJ+DAXr5Jo2c0t6Dps5VW43C1yjAmtwTsjTiUnOqRTfQFbgilbg2m021OxpaQZah9b056hYxbchCypftbQ==</xenc:CipherValue></xenc:CipherData></xenc:EncryptedKey></dsig:KeyInfo>
   <xenc:CipherData>
      <xenc:CipherValue>++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</xenc:CipherValue>
   </xenc:CipherData>
</xenc:EncryptedData></saml2:EncryptedAssertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_28.b64 ================================================ <saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="id70938295375022572142875469" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
    <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" xmlns:xs="http://www.w3.org/2001/XMLSchema"><xenc:EncryptedData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#" xmlns:dsig="http://www.w3.org/2000/09/xmldsig#" Type="http://www.w3.org/2001/04/xmlenc#Element"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes256-cbc"/><dsig:KeyInfo xmlns:dsig="http://www.w3.org/2000/09/xmldsig#"><xenc:EncryptedKey><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p"><dsig:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/></xenc:EncryptionMethod><dsig:KeyInfo><dsig:X509Data><dsig:X509Certificate>MIIDPjCCAiagAwIBAgIJAOvpZtJNtQ/rMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgxNDAxNDg1N1oYDzIxMTYwMzA4MDE0ODU3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKfUlciwDPCJ9JXy1NsxKfqyOfLQXFKKGgNKKRLzLAWO43GgQYrV67QaAny5LvgOa81KQOX4IvjJy0nd/VrO6jG9pTdMR9vFHT0Tu3W1QUsyPPSQqpKXwb2ZCSXNghYD5gBrNtmOxAOs1Azx5qmIzBJ4F0RkRivcdbXSfBUBLpCn1M285c4tk5SEvoRgBeisLJJDB7hmylA1V6/+BN+N6b3M+ZZG//CTvOjJKgnwkMALzXbPbQWa0kpbMLDMz8Kr2pODLKb3rGmdf4P6A9aA41k6L4clTsNdcK7ZwJ2fGF79WGzE6RLyBX2US3gPHUXt/WMQZXyULO3exiTDsQXWFf8CAwEAAaMPMA0wCwYDVR0PBAQDAgQQMA0GCSqGSIb3DQEBCwUAA4IBAQB3fQZz2qNAo/wohPNaR2uAakLt25cKrsbgn3XwO+X+DRH4nqMSZkHdLGr82xD3i33BLSQwXzFecEN+CA8SlpNoIXHwk6D6V3uEBSjKemZtJFCJqe8d+5qt3GV50AKmtEt2Nc7B94TN8xB5EmZladnTJWcBgSuuz1hLXQQ02dJ3dDq8FMlyR70S2DTtuPu0i2/f6KtrlmmNsU24Aq+fCzEG43NqShOMeM5rDxLsSJCtjfMRwG8YeyNf6cCMSMxYAJfrTyj+AS8RtZQNGF7tX+exEWHOf1C9CBzHtKRClBRL6zDjlpPCIDwcMFi8NXvaiVclxIq3XdfqxiGBBEldkhgZ</dsig:X509Certificate></dsig:X509Data></dsig:KeyInfo><xenc:CipherData><xenc:CipherValue>Ds9FxMuIUjbgHoTKTJL4XI5yYQIZLfTTWm4tXSiGL7xXvFGsnhhVNoft+DWlhxoeavKa9WPYzp0zWtAByh86+lw2/Z5GmOTWeXLelm24FqNfsY8Uu/K6KB8oe37IsXsR2fmhMJYQu7bjbUZCN3ICmwYLWh5uCVab7K9to7r0acxMf61XZYC4lsZFD4q4d+ylEmmbw/8hUiLHh+qOHCqjfSkHAQ+YOBUa6ZGQMvY5P4ZFhJZZ1PDfLJE/K90S/Yd0bkNotJ+DAXr5Jo2c0t6Dps5VW43C1yjAmtwTsjTiUnOqRTfQFbgilbg2m021OxpaQZah9b056hYxbchCypftbQ==</xenc:CipherValue></xenc:CipherData></xenc:EncryptedKey></dsig:KeyInfo>
   <xenc:CipherData>
      <xenc:CipherValue>++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</xenc:CipherValue>
   </xenc:CipherData>
</xenc:EncryptedData></saml2:EncryptedAssertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_31.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="pfx08b2c002-7c39-8d8c-502b-3423fcc573f0" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx08b2c002-7c39-8d8c-502b-3423fcc573f0"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>ov5DnJ3lKcP61BGShnIDz80WGwM=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>EPRBNKKRxit8B3TvHDD6KRI8LNtAOB0Nrb6cWE7Y17Wb2sgGiYLMRkEjK0FYzgqjX+v/+WwC06YAV6hhmvZOHMGmAJIiaCdN44FepsbwNGDhEjXcFZcrQRQFN7EA98lk69hUs+wTXo9A5FlBjE0AkwAAPSm10hgjQhZFtJsF0zcJ2CreAjGQoy9E0YizmDppleNniGbRLZjLKI4222RfS5xybqAWKEHvJL24CkPuxtQOKg9HIJO4fitGQscAE43GsPCdJXk3jeVGE9WbuC0dKd3OrBQOyaTbaB3+WqWqtw1Y2Uqng9KBCGGG/WcWVsrDFmEluz3f4byW7I1Dv/4+HA==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAM+FhCUAbPDCMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgzMDIzMTAzNloYDzIxMTcwODA2MjMxMDM2WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBANvJvip8M0faCM9wV9unzLACcLfvAgX7H9nYAOJ9dSlfLjfqaP/8Pf4EEyzypWuDjvZ9A0UVaf3dj9xBF1snkK7n8gVdju8GDlfemR/XYBXs7n4Z4C3RsPRX7qxtaVbA2U7ZbblvYIN6IKJawQGrorPxUXG7lMcpGn0Yw5F41klWdFh3DCOlwLF/NBDr6HNFXhwnIvoZahUPrMBjR7dw3dAI/bc0xD28GW70JAPnTpSMjIvsIM8apo9lUxq/TFgwPBFUsFsqsXyMzL0cslKaqudzU/U5DctyAG1GbYE8TzVniqxW+w1jzZ1J+AsknalhWjO56uyI8jXQ0ERVu3d79osCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQCtsjS4ahLpRRtjmjhPvg9ng3Fr1A8K4vd+7hUbvHWiuRhBewSoe/BaY8dRayWzsD7Zv723FvRzK1Gx06Spv1Yvh73Sv42NVDsZT2KxDTB4kXfln29aS2c82q/VzinQsxNFmLZFMKlcbviVCSp7/hqkpAAxupug48DlwFW+KMA4WrPWJJUix0/01YBcPuNF81fHzEVLmxImVhTQ/1sUATjkCQOkmlmBPyO6Z2if3pm6Y7vujNWFfjwLMlhshDNzP67WAMdcaBw9wRHh2tzztshkoZUXnGujWtyjydrvznInZgWsiCXMk2Y+fdAYucaQ/Ocfdl2FPViRWC+ExKzagHso</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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="id70938295375467671318387720" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
        <saml2:Subject xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:NameID Format="urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-30T23:19:41.379Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-30T23:09:41.379Z" NotOnOrAfter="2017-08-30T23:19:41.379Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_33.b64 ================================================ <saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="id70938295375022572142875469" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
    <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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="pfx1c2b13aa-f0cc-7812-1a2e-60df211780bf" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx1c2b13aa-f0cc-7812-1a2e-60df211780bf"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>CGe7HMIc7Lc2VqIVN8KYxIuZQ98=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>WjfMI8+O9gRU6zbTmf4ferUhlsA0dG0qp+5neqBq9whJsXg/P+/I1HwpklBj0+FaEQTjOrVG2lee9DoCOY2u0PS5JQVO/9EJbhKn4HXAYxS0cNb8DX+IdLFS/Db3zezROTvCTlq2IqbCe6kA+dkmW+P/+5fUmug9AdcdQ8pgNYCK9XEjDGmX2QiBVktUyvzBePpykIgYlFKPChU9BDk/4mkazp3kIwReKqw3e/yWb4sH/hxAz5S4aPzzhdiwkjuZnBYfaB4R6q3s0knUIf43V2acOXQu2/59teVr713NW1/HrrbvjJgUMyBbLm7ZF0ygc9TPHhCrlaa4ox/MoBluWQ==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAM+FhCUAbPDCMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgzMDIzMTAzNloYDzIxMTcwODA2MjMxMDM2WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBANvJvip8M0faCM9wV9unzLACcLfvAgX7H9nYAOJ9dSlfLjfqaP/8Pf4EEyzypWuDjvZ9A0UVaf3dj9xBF1snkK7n8gVdju8GDlfemR/XYBXs7n4Z4C3RsPRX7qxtaVbA2U7ZbblvYIN6IKJawQGrorPxUXG7lMcpGn0Yw5F41klWdFh3DCOlwLF/NBDr6HNFXhwnIvoZahUPrMBjR7dw3dAI/bc0xD28GW70JAPnTpSMjIvsIM8apo9lUxq/TFgwPBFUsFsqsXyMzL0cslKaqudzU/U5DctyAG1GbYE8TzVniqxW+w1jzZ1J+AsknalhWjO56uyI8jXQ0ERVu3d79osCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQCtsjS4ahLpRRtjmjhPvg9ng3Fr1A8K4vd+7hUbvHWiuRhBewSoe/BaY8dRayWzsD7Zv723FvRzK1Gx06Spv1Yvh73Sv42NVDsZT2KxDTB4kXfln29aS2c82q/VzinQsxNFmLZFMKlcbviVCSp7/hqkpAAxupug48DlwFW+KMA4WrPWJJUix0/01YBcPuNF81fHzEVLmxImVhTQ/1sUATjkCQOkmlmBPyO6Z2if3pm6Y7vujNWFfjwLMlhshDNzP67WAMdcaBw9wRHh2tzztshkoZUXnGujWtyjydrvznInZgWsiCXMk2Y+fdAYucaQ/Ocfdl2FPViRWC+ExKzagHso</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:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-30T23:19:41.379Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-30T23:09:41.379Z" NotOnOrAfter="2017-08-30T23:19:41.379Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_34.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="pfxb4c35301-7b97-548a-a5c4-55ecadb825cd" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfxb4c35301-7b97-548a-a5c4-55ecadb825cd"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>jpPaGu4din5Pl+0k/i31iNoqJFA=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>GxfQKQY0ihars3IhCi4aUq0x2wOZTFz/y0phqifP1Ox2cld+MkIlzTCopbz/k80Uv20U6N4tH9jO9RjOiwowHYgqTjcI0Giy58rx9jrX6TPG7OG6CjnA6ta1xYd+3C5WbOTCSHGwMp2ebWPyjJzJHPwu+kzXHou/da9OFwCF66C5SQdarCK/bKWZTDST2bLVJbL81Tcbf8SDb515yKwalJw8R+vGXkymf+oDTYQ5MIboTre5XrFYNOea6Gr+tHgQQuALZU+29aNQeeTVA99T0XTpier8ftP2b0IxZx4JXqRVrwM4BwbSEx63Pj+9HU/3ZthR+stGEiU+7L9F4fTz6Q==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAM+FhCUAbPDCMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgzMDIzMTAzNloYDzIxMTcwODA2MjMxMDM2WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBANvJvip8M0faCM9wV9unzLACcLfvAgX7H9nYAOJ9dSlfLjfqaP/8Pf4EEyzypWuDjvZ9A0UVaf3dj9xBF1snkK7n8gVdju8GDlfemR/XYBXs7n4Z4C3RsPRX7qxtaVbA2U7ZbblvYIN6IKJawQGrorPxUXG7lMcpGn0Yw5F41klWdFh3DCOlwLF/NBDr6HNFXhwnIvoZahUPrMBjR7dw3dAI/bc0xD28GW70JAPnTpSMjIvsIM8apo9lUxq/TFgwPBFUsFsqsXyMzL0cslKaqudzU/U5DctyAG1GbYE8TzVniqxW+w1jzZ1J+AsknalhWjO56uyI8jXQ0ERVu3d79osCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQCtsjS4ahLpRRtjmjhPvg9ng3Fr1A8K4vd+7hUbvHWiuRhBewSoe/BaY8dRayWzsD7Zv723FvRzK1Gx06Spv1Yvh73Sv42NVDsZT2KxDTB4kXfln29aS2c82q/VzinQsxNFmLZFMKlcbviVCSp7/hqkpAAxupug48DlwFW+KMA4WrPWJJUix0/01YBcPuNF81fHzEVLmxImVhTQ/1sUATjkCQOkmlmBPyO6Z2if3pm6Y7vujNWFfjwLMlhshDNzP67WAMdcaBw9wRHh2tzztshkoZUXnGujWtyjydrvznInZgWsiCXMk2Y+fdAYucaQ/Ocfdl2FPViRWC+ExKzagHso</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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="pfxbecb40df-6a02-d199-486e-d375e4a486e1" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfxbecb40df-6a02-d199-486e-d375e4a486e1"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>4P1EGx4xq9dmkxQq8uAIYrc/SSw=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>DdNCDSkshgrlJQjA16kzIUjNSA3enLg6foyfGobGcANwe0oWlMvN2c2HHs1Nxk8vmOPYhloEdVA+JjkkbPtzTy9imrdMKGlENHgD+1kwdD9KJ3l1UP2TeJlL7XfIqgwz16mADD5N6rLIx2/H5GbRb4ejt3vzM3/FXyTqGeQpTuYZWLpe3U+vlLqac/jbeOm0fXT8nmeq/0AztTqHN7S2FM7x03m6CGdSPouV8jM2BgT5AlnI1qCLHLoIxY91Uj0lkl6aiAyynetu0rYWQ4EmJ0OlGm0OQeEddaCm/6CMBM8PfZ3s7nl7ylO4J5Xy28RHwt5AhsrczkuyU7sCs5zHXQ==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAM+FhCUAbPDCMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgzMDIzMTAzNloYDzIxMTcwODA2MjMxMDM2WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBANvJvip8M0faCM9wV9unzLACcLfvAgX7H9nYAOJ9dSlfLjfqaP/8Pf4EEyzypWuDjvZ9A0UVaf3dj9xBF1snkK7n8gVdju8GDlfemR/XYBXs7n4Z4C3RsPRX7qxtaVbA2U7ZbblvYIN6IKJawQGrorPxUXG7lMcpGn0Yw5F41klWdFh3DCOlwLF/NBDr6HNFXhwnIvoZahUPrMBjR7dw3dAI/bc0xD28GW70JAPnTpSMjIvsIM8apo9lUxq/TFgwPBFUsFsqsXyMzL0cslKaqudzU/U5DctyAG1GbYE8TzVniqxW+w1jzZ1J+AsknalhWjO56uyI8jXQ0ERVu3d79osCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQCtsjS4ahLpRRtjmjhPvg9ng3Fr1A8K4vd+7hUbvHWiuRhBewSoe/BaY8dRayWzsD7Zv723FvRzK1Gx06Spv1Yvh73Sv42NVDsZT2KxDTB4kXfln29aS2c82q/VzinQsxNFmLZFMKlcbviVCSp7/hqkpAAxupug48DlwFW+KMA4WrPWJJUix0/01YBcPuNF81fHzEVLmxImVhTQ/1sUATjkCQOkmlmBPyO6Z2if3pm6Y7vujNWFfjwLMlhshDNzP67WAMdcaBw9wRHh2tzztshkoZUXnGujWtyjydrvznInZgWsiCXMk2Y+fdAYucaQ/Ocfdl2FPViRWC+ExKzagHso</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:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-30T23:19:41.379Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-30T23:09:41.379Z" NotOnOrAfter="2017-08-30T23:19:41.379Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_36.b64 ================================================ <saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="id70938295375022572142875469" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
    <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" xmlns:xs="http://www.w3.org/2001/XMLSchema"><xenc:EncryptedData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#" xmlns:dsig="http://www.w3.org/2000/09/xmldsig#" Type="http://www.w3.org/2001/04/xmlenc#Element"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes256-cbc"/><dsig:KeyInfo xmlns:dsig="http://www.w3.org/2000/09/xmldsig#"><xenc:EncryptedKey><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p"><dsig:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/></xenc:EncryptionMethod><dsig:KeyInfo><dsig:X509Data><dsig:X509Certificate>MIIDPjCCAiagAwIBAgIJAOvpZtJNtQ/rMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgxNDAxNDg1N1oYDzIxMTYwMzA4MDE0ODU3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKfUlciwDPCJ9JXy1NsxKfqyOfLQXFKKGgNKKRLzLAWO43GgQYrV67QaAny5LvgOa81KQOX4IvjJy0nd/VrO6jG9pTdMR9vFHT0Tu3W1QUsyPPSQqpKXwb2ZCSXNghYD5gBrNtmOxAOs1Azx5qmIzBJ4F0RkRivcdbXSfBUBLpCn1M285c4tk5SEvoRgBeisLJJDB7hmylA1V6/+BN+N6b3M+ZZG//CTvOjJKgnwkMALzXbPbQWa0kpbMLDMz8Kr2pODLKb3rGmdf4P6A9aA41k6L4clTsNdcK7ZwJ2fGF79WGzE6RLyBX2US3gPHUXt/WMQZXyULO3exiTDsQXWFf8CAwEAAaMPMA0wCwYDVR0PBAQDAgQQMA0GCSqGSIb3DQEBCwUAA4IBAQB3fQZz2qNAo/wohPNaR2uAakLt25cKrsbgn3XwO+X+DRH4nqMSZkHdLGr82xD3i33BLSQwXzFecEN+CA8SlpNoIXHwk6D6V3uEBSjKemZtJFCJqe8d+5qt3GV50AKmtEt2Nc7B94TN8xB5EmZladnTJWcBgSuuz1hLXQQ02dJ3dDq8FMlyR70S2DTtuPu0i2/f6KtrlmmNsU24Aq+fCzEG43NqShOMeM5rDxLsSJCtjfMRwG8YeyNf6cCMSMxYAJfrTyj+AS8RtZQNGF7tX+exEWHOf1C9CBzHtKRClBRL6zDjlpPCIDwcMFi8NXvaiVclxIq3XdfqxiGBBEldkhgZ</dsig:X509Certificate></dsig:X509Data></dsig:KeyInfo><xenc:CipherData><xenc:CipherValue>J0UGnQLJujclPD0F8yTi1SR1OhYnxI/SvIyObj4rXP2BCho558axyuom/5bKElHyQ5JpLx0v/dCSUgCW1n+sMGDJ+3BhDU0hVPhpULwfZryKHusMlBkvysvd/O6L1whPlGgJrT39tkiBBi6AJ8mKeD3fhogYqpleF+lkrKxjFDBfhWTAbuZ8y8C3Mx6mos7kjbR5Gs47wnrz4eYgW+NRJ8V/NyauCEmp9BAbgrwWZ/rmgMXYnRof+9mSQ8f2LfqcuIvr3I+LNLhw1ICaNvaUQIV6B0JZKXfibwk50wAK4As6LRIy2/OJ1eM2rn+S/9KEMEqbVJ0SNrtdczJOhji/qg==</xenc:CipherValue></xenc:CipherData></xenc:EncryptedKey></dsig:KeyInfo>
   <xenc:CipherData>
      <xenc:CipherValue>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</xenc:CipherValue>
   </xenc:CipherData>
</xenc:EncryptedData></saml2:EncryptedAssertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_37.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="pfx2a29acdc-9cff-490b-8289-a96f25cb8ff9" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx2a29acdc-9cff-490b-8289-a96f25cb8ff9"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>t7M7i7BZiV6Ldhzr6AV5SpzfOfY=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>KN8ULAuvzJWTL1wZAlKeVm1xxIwDxwRP7CazkgtI3NNpFbYH00o9bUdxEWd70tBbvP1CJSkpLlL7d6qxhDesgVD1x7MaHdJJ3DP9sBXxnZTLGkRpdBvV/s6LGEB9H0WS2oG+BbUPT3MLCASBtXgbkfbOP9SIFMI1Y4Uzon+PB8w1wVa4cH6aWo+lfO/zyw58Gj9FyE9NQfpUxzsTv2+5NsNjkCJSgBO8I0DCRpDgIsa3DWWqBd/uaVDKlb1F+9ctntRL4Ycf4HPX6eaqpF6H9CSO3nSEgzbucKpxw6Npr+fqL+YD3l/zKE2qIVwqEmFzIF3JnPjtu4sCnIRl3GPBrg==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAM+FhCUAbPDCMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgzMDIzMTAzNloYDzIxMTcwODA2MjMxMDM2WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBANvJvip8M0faCM9wV9unzLACcLfvAgX7H9nYAOJ9dSlfLjfqaP/8Pf4EEyzypWuDjvZ9A0UVaf3dj9xBF1snkK7n8gVdju8GDlfemR/XYBXs7n4Z4C3RsPRX7qxtaVbA2U7ZbblvYIN6IKJawQGrorPxUXG7lMcpGn0Yw5F41klWdFh3DCOlwLF/NBDr6HNFXhwnIvoZahUPrMBjR7dw3dAI/bc0xD28GW70JAPnTpSMjIvsIM8apo9lUxq/TFgwPBFUsFsqsXyMzL0cslKaqudzU/U5DctyAG1GbYE8TzVniqxW+w1jzZ1J+AsknalhWjO56uyI8jXQ0ERVu3d79osCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQCtsjS4ahLpRRtjmjhPvg9ng3Fr1A8K4vd+7hUbvHWiuRhBewSoe/BaY8dRayWzsD7Zv723FvRzK1Gx06Spv1Yvh73Sv42NVDsZT2KxDTB4kXfln29aS2c82q/VzinQsxNFmLZFMKlcbviVCSp7/hqkpAAxupug48DlwFW+KMA4WrPWJJUix0/01YBcPuNF81fHzEVLmxImVhTQ/1sUATjkCQOkmlmBPyO6Z2if3pm6Y7vujNWFfjwLMlhshDNzP67WAMdcaBw9wRHh2tzztshkoZUXnGujWtyjydrvznInZgWsiCXMk2Y+fdAYucaQ/Ocfdl2FPViRWC+ExKzagHso</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" xmlns:xs="http://www.w3.org/2001/XMLSchema"><xenc:EncryptedData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#" xmlns:dsig="http://www.w3.org/2000/09/xmldsig#" Type="http://www.w3.org/2001/04/xmlenc#Element"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes256-cbc"/><dsig:KeyInfo xmlns:dsig="http://www.w3.org/2000/09/xmldsig#"><xenc:EncryptedKey><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p"><dsig:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/></xenc:EncryptionMethod><dsig:KeyInfo><dsig:X509Data><dsig:X509Certificate>MIIDPjCCAiagAwIBAgIJAOvpZtJNtQ/rMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgxNDAxNDg1N1oYDzIxMTYwMzA4MDE0ODU3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKfUlciwDPCJ9JXy1NsxKfqyOfLQXFKKGgNKKRLzLAWO43GgQYrV67QaAny5LvgOa81KQOX4IvjJy0nd/VrO6jG9pTdMR9vFHT0Tu3W1QUsyPPSQqpKXwb2ZCSXNghYD5gBrNtmOxAOs1Azx5qmIzBJ4F0RkRivcdbXSfBUBLpCn1M285c4tk5SEvoRgBeisLJJDB7hmylA1V6/+BN+N6b3M+ZZG//CTvOjJKgnwkMALzXbPbQWa0kpbMLDMz8Kr2pODLKb3rGmdf4P6A9aA41k6L4clTsNdcK7ZwJ2fGF79WGzE6RLyBX2US3gPHUXt/WMQZXyULO3exiTDsQXWFf8CAwEAAaMPMA0wCwYDVR0PBAQDAgQQMA0GCSqGSIb3DQEBCwUAA4IBAQB3fQZz2qNAo/wohPNaR2uAakLt25cKrsbgn3XwO+X+DRH4nqMSZkHdLGr82xD3i33BLSQwXzFecEN+CA8SlpNoIXHwk6D6V3uEBSjKemZtJFCJqe8d+5qt3GV50AKmtEt2Nc7B94TN8xB5EmZladnTJWcBgSuuz1hLXQQ02dJ3dDq8FMlyR70S2DTtuPu0i2/f6KtrlmmNsU24Aq+fCzEG43NqShOMeM5rDxLsSJCtjfMRwG8YeyNf6cCMSMxYAJfrTyj+AS8RtZQNGF7tX+exEWHOf1C9CBzHtKRClBRL6zDjlpPCIDwcMFi8NXvaiVclxIq3XdfqxiGBBEldkhgZ</dsig:X509Certificate></dsig:X509Data></dsig:KeyInfo><xenc:CipherData><xenc:CipherValue>H4YBHMpLw0XfFItUGJhVuowAbffXuv8lgSw7VcnHnZNNYAwSC4tU92wiwowsa8vTSY6pZLc+XsFmncsrKFP9oazPJbr8pHjBfSktIhUdxBm6ESii3ICnoV+BZvioem909WMEYTooGiwA8HjaYED8ju0eO5kCMP4NoyDN1vVrhSitV8z5Dviiy7EjOcTHoq8oEPQCF4zQ1PeuoZqlP7ECbRPYhu6PR7MkOwrdq5iInZoz8Py2MxNxSiOfPyvsk80s8IPnMEV4Y5GgauS0bvmqS5DynEb9TrOk7X2a7j15x6wBTLw9ye4OpGZE8VaOxaqPebFWl6AQ3aJxui3frpjH+Q==</xenc:CipherValue></xenc:CipherData></xenc:EncryptedKey></dsig:KeyInfo>
   <xenc:CipherData>
      <xenc:CipherValue>IzijrAJStrEKmXJ6ZpaR/ZYZGbtmrneRPDj0tOfzdRDtCpNlc2hzxoWiapUR4Pid5fpBPCXkgwd6WomfX+siiY4GCrQBrbtsYCNovPUX8bqcYblZXjWlVInrzSsm9Ey/5+D29u2+udb9fQF9Uq+5scARO/GHmvVit7or09bfUkwJxUco8KbY4ORIkhJVY4Ow0oUfw33qD1sHRysEiNgA5lLFazEoGRG1p84vqI97UEI+QmmrqISx+SPJA43gZj74Xr/2yIgXKUzhhHTKBXLsYx3haBCKyY7YqReYBzu8YAmmPFyMNWY7b91p4ACDkSgZLtHdVSyXJdlw9ZcwL2z/lnaK5g19MMbns1us9VDSivWK4IRrcA/aPBBHY1FnqmCmSsghVNCQnx/fDe+qGumb/ty4jK0cy2YHywBhUVkWGaEZkxx6oX99ln/V1+76V73kK4bxR1W1/gUpt24VWt81EpSf+6UGkzL+fMwEjOXepKRVS8oHFWseH5q8eWLTCCSZZWvcuookqIHYsiyfi3JeYrVqCXjnm/hgDWE08Znze3cqeLk6/dAx0xfE7zzkxbgBmgxJ3IA1LId+FmoVVJZYI3VNoFAGJCmeXoCT4HNrI1iKF30mZ6z0nT49nlTzbrYZ34Udo1yKWVguJukUe/jpUkijz2M/DOQJHKyL9s7IeKIszp/uk8lpS9wi7BPY8xZ3giOlqYumXUA2h3EPzQBhEcyGai53o6Z0E4nesceAUB9b5RAGfbdbJmRDtsUFPjoTfD5RqWSHRLHmRLTD48zjyJ6IqtB97heGk6anRxEksPJo4sykQR0FIBWaJPednFh8ejDawT0DgSOmnMZIVWQJSVFchZY55GmB3dJFMq4T/HNtHNJa+vbsfMcBXXBfAjkfi/tXEBu/UJaa6uhurpwohn/yb39b71ecUhgLtv6TMeqbYF5UMLHn/U5r+SgGR/0i60aHbyJ4CPaLxefrF8Prdr8KNagQf3NDiV6wtYTMm3QYYhY0OU34qrWqiafyuHsKKoN2bsxtZ+j+cy/ScEapkOZSguRwo9Su2MSHqYBqTLavjwFKlRKywfOrIslPSdPlSJGWPxFZ2Zx9NxFPdii2ojaA4M+mOcU9SGgn1Fy+k+PGh2oOM/7dL+VHDS50FwW7tYzFqXwNPSbDSCgbFQcfUZmJ1sl5F7njAlc7PBgmIbdbGrb5M9LQtyqDaTEvZCD06qSJCvy+PKXGqhiyQGZU5a72nvtO+4ahguM/B183qWnz1N9WyHmAYBkRTX0lJuVkwdyD9h8tY1i0lDJKWXBequ2P6HOe0IHZwg2W+0sqlZaOalhcac0gOnPsza+GZg+g7kt8GRdv0JgI6u2AJEn7KYC5P37SF8E2+V+UKB+CSkQjZezoBEGAC+4O9zB7UoPvBMOYNUohcnx1x+3nJ+EqF2gReVvOXW5kCHbiwYeJd1fjonR0dcp1BHZuIOaGNvrDE2BosW8Z9GcJ49uHfh7MLbv9W6x0EoESJjUaaKPhlOWkXF/hSM9qoNeJs8+wCQi+YxDRIlL0sH37B2+EL7XK9i0GK6He4XOiP678IXEMV676wws/lTJYNWxvozNnECKVC59OF6S4sw6HE+ELfxFj/AqZLgNolUM9TD75FMe3Wd/ulD7d0MJcieHqrQS+IVtIoGvNJSPqWAAJ3G5ubvzxj6luQlPKNbTn/O5wIBK0kJhxG4Hc4WX5a/TDhr9m+C4IxfNdYzn24rcrC/u2Sr4zw0YlIP3xlMqCNWiu8Kl69xw3xBkKLfAcmP47jQjlZumnoVWH0r7Nefm5da76dndNmgsk/n49+ON/sctUKYED7eWXwPrzT+wHRKAT//dkq+Y8DejgN2zORIMPoci0SW1BmRvH9zlxMYvH47SuRHj6/wWjDQakJD6MwQle64uz8CaT1Iu/NzpB7W9UeEQgDMUE8AB1lQ5WGGc5pCzaXM3HtH08+xv4KsLkCQjCWCIrSc2Yv8YAIPuYIP3HqhcUyPDJecVqyn3kQKsmvqNPka/eXbUnGlVlN9ov9+VZ078koID/PO5JCadMUlTiVvTTDdjeZmAq17QY5pLlvtOOjKIPqyhtNHIbA9Jmw5aF/q6jDGVJVN/qKK86gkiO+/5oGHbiBJC+iRAI35FoV5WtLGMeiJoQmRlRDZdDR5eCqSmsxYuiWUn7D/AuaR7E8zPC0FwFdsCY8K6M6Vl7MJq1I+Oxa7gdtKKOHzEwewUp49Y3o3DeOFUF00g/kzoqWx3Tpt1fM/xESnQ7tYp++Gf5RChlTPbEY1hMH+bDFyRHGk9mlcu5ye14ev/ZNDhIJ0gL1WwZB+m7Lf2KAzMUcPUSvs+SrxI/UWpJq/Ik5o9iUder6DOaDwaK/8XDG1ekMIyYqzW7zipuEJfsAjuR9ydTaV4FAUTc/5ttzL0VwQAQOLB/F4dR4xnHbh9q7+FEDCw+DcsxogpcN/E/Qg2YtP3OnsYMz+s6dbhc3+4liQXPbMO6GN7j+zH73uHM0vSYk0/yRWNuCgq1PqMXTnSzCJg6WK0XgzZG7obynrr8ye+H5swOZUbt3CAshm6iulBOEmtRnGUjn0Gj9PlUDphVwyDVEi8SKXJ+ohhGUumBAbTGbK143lm2SLF1pElUN0FEr0nqOFG8bD7HfTO8u7n+MH/ZHAM2ZAvI6tbBlbNWcNZnhQG+ZaSMubqbMEgA8KEtsVCjTiynKLVIrAKV3crxTzIpRPN8SusiHbTXVB4z6uD2rz0U6DR4bHllG9qg4eRpe63b1t1fq4QgmiCPVA5a5JO8eHgh+rNgw1/kUN03ZETyrUTQt7KNsa6LjeFz6eJTPJiOo8fVxdYM72tq3oEjqEa7gOcDXLxiFZV1ayaHr8TiICH7XVUaX7nGWZ62QC7TjMFZyo+DzfqHvNkPKcLSRw+ZKnciBhd3utR0vl9RUXGYbCSVjnWbnQVY7DS0FrKXjwkvOoe+CX+8/Nc42EyNzMfllinXuOIWb48cmgyOOlB38ADk8m9o5blabUlmEDN16/XnXdk+WrK1BbMS7j1FaYOy55RjGBFUSTvGiIuWjECqmui3bZCYm3DLLtaEPH6S/0X+SEg0hktOa4g4M3QIuDBuH7ulXMxzsh3cu8tbRZIRB7mtIZv0UhbNEBhuD0AOdZ6glJssKPIHiFSiPqoV0LzZZU6jdT/BVANP9HNAT1PY55IDw8THrkCt4Hqg6YO3J5Rkqbn2oShvBG/93pnT9W/4Ua8doQQwljyvP1iYL7K1CFwGGN9tdR+nT+FpYezB7qdE8e/Q49/sD+bIKU3rqTVfe3A6pESezFIo0liH7yU4cpEB1MthnnDaFGH4OEh2orCLjnJ8HW/SLtEAQ8gXq8qjjU0GtWHLUEz4HBfR8eMZ2WoSAuLvYCGYnlEKLfhSU3muKHGJix7QG2Q6KFOybNLj/HFroy2yaAEGcxWxneYCjVJCfKkVHhj0D9Z8xaVhi9Mo0tWAC5ucFksnsG4/b3AEYZHtGHX6IABvaClDSBm638lBTmDagaYS2jq8d9Y7Dad49NXoVqBnriK39h/Pvk5wCqntSc4X0nChsoxJKg8bN5rmRHfXmEvk3ljx4YXa9VqVSggi5os8OtwkkdaiA3PCmST1Tw7rN+HB9C4362Q3uiIXkGzNicF7BFC84EP7YiuBUYK0VEf/x6x71Oy2W5cuwqzolJolp8Uup2BWVb6WH/Uq6gwFP8+VEdD+4ry9oFhP1z4cdgO/yxGw0YwtXaPe6fGlMRRu3XzUYmb7q55EE/xaopZi4GvLgbWmy/rPVundxHxuKfm/z74Z9Bnvl7LuY5yFptK+vZmVcnaz1qQvhq0q2IDDGQCr19oTuSpdj5MGp3xC/aRtOelP8LvsbTgKyQDssMUk3jl/GHWk/AdsgIOJJ7blcg70fpvYM8j8l/HqKKqzzvZZwzbR4QalkvoMbgFcAS+qysWyXGNMALi8Zfqfq+zSlzp8HO0k15iGFxfe63uoqQLDLKtuBkfPC6wFd2jzCXe8k4PGs6R07mrc7uB1efnZTlbLr0hHp8nbJrdtnECw2/mCClT5PS+5c79V9Yhb9fjr0iMyQysJyZVx1nzGRgC7qiLglEGXqxp1j0Z0eNXpAe9C+U3bARyCGXonIzD6paS4LajSmqMbZlGlxRE4Ewa/MiZXqPoeudJdYlz9CzVlQO2oSVyW/X8jMcjfyYW5r4PoujFLskM2pEYBZd7mPyrGllxGwKHcR8VRwZ7ObYdbo9BwPjcwm5hGJ+gqbnWc0uqO+SCAD/G5QFekPqY09WdpMtHIp/wryNck2+m6CJSx9laGXM78uoBsonv3nHpWYgkAUsO3RDw37jNe/+bk2bKl</xenc:CipherValue>
   </xenc:CipherData>
</xenc:EncryptedData></saml2:EncryptedAssertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_38.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="pfxa68890e5-6a85-e10a-95e0-23e0d6f8e493" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfxa68890e5-6a85-e10a-95e0-23e0d6f8e493"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>BwiQYCMjjDPCYTp9TmZCAsh2GZY=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>V94GD4P9Gc4EME6yQxWrnmK/YXh87Gvp69wQez40EJ6qXuJnfbG9xOWgll6r1F6SZtZWlUr8T9b0JsTlOr0ZuGgDS64G5icMYfRBYIVjY21Gi33McIgmbCHrSgL8HCOE8Snr1Ry1BrP9HhT1QGWITArl36F/DyFB/QF2FeVzCCKYuSXofLGAKSRO6ndJ3D0rA67a1Iqjz8MwUq9Ue758TDb0w0tZVyasXizVNDLTHb1DgYEfbTCwznuZ8TAX57b+SH77YEQ//GwrKAQVSfNFAZwfP6UlL+s5M5Mu5+nbTLHsWIAoAPtpozaL29lVxoZmck5Y9Wn4s5+ZXgBvk867rg==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAM+FhCUAbPDCMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgzMDIzMTAzNloYDzIxMTcwODA2MjMxMDM2WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBANvJvip8M0faCM9wV9unzLACcLfvAgX7H9nYAOJ9dSlfLjfqaP/8Pf4EEyzypWuDjvZ9A0UVaf3dj9xBF1snkK7n8gVdju8GDlfemR/XYBXs7n4Z4C3RsPRX7qxtaVbA2U7ZbblvYIN6IKJawQGrorPxUXG7lMcpGn0Yw5F41klWdFh3DCOlwLF/NBDr6HNFXhwnIvoZahUPrMBjR7dw3dAI/bc0xD28GW70JAPnTpSMjIvsIM8apo9lUxq/TFgwPBFUsFsqsXyMzL0cslKaqudzU/U5DctyAG1GbYE8TzVniqxW+w1jzZ1J+AsknalhWjO56uyI8jXQ0ERVu3d79osCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQCtsjS4ahLpRRtjmjhPvg9ng3Fr1A8K4vd+7hUbvHWiuRhBewSoe/BaY8dRayWzsD7Zv723FvRzK1Gx06Spv1Yvh73Sv42NVDsZT2KxDTB4kXfln29aS2c82q/VzinQsxNFmLZFMKlcbviVCSp7/hqkpAAxupug48DlwFW+KMA4WrPWJJUix0/01YBcPuNF81fHzEVLmxImVhTQ/1sUATjkCQOkmlmBPyO6Z2if3pm6Y7vujNWFfjwLMlhshDNzP67WAMdcaBw9wRHh2tzztshkoZUXnGujWtyjydrvznInZgWsiCXMk2Y+fdAYucaQ/Ocfdl2FPViRWC+ExKzagHso</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" xmlns:xs="http://www.w3.org/2001/XMLSchema"><xenc:EncryptedData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#" xmlns:dsig="http://www.w3.org/2000/09/xmldsig#" Type="http://www.w3.org/2001/04/xmlenc#Element"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes256-cbc"/><dsig:KeyInfo xmlns:dsig="http://www.w3.org/2000/09/xmldsig#"><xenc:EncryptedKey><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p"><dsig:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/></xenc:EncryptionMethod><dsig:KeyInfo><dsig:X509Data><dsig:X509Certificate>MIIDPjCCAiagAwIBAgIJAOvpZtJNtQ/rMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgxNDAxNDg1N1oYDzIxMTYwMzA4MDE0ODU3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKfUlciwDPCJ9JXy1NsxKfqyOfLQXFKKGgNKKRLzLAWO43GgQYrV67QaAny5LvgOa81KQOX4IvjJy0nd/VrO6jG9pTdMR9vFHT0Tu3W1QUsyPPSQqpKXwb2ZCSXNghYD5gBrNtmOxAOs1Azx5qmIzBJ4F0RkRivcdbXSfBUBLpCn1M285c4tk5SEvoRgBeisLJJDB7hmylA1V6/+BN+N6b3M+ZZG//CTvOjJKgnwkMALzXbPbQWa0kpbMLDMz8Kr2pODLKb3rGmdf4P6A9aA41k6L4clTsNdcK7ZwJ2fGF79WGzE6RLyBX2US3gPHUXt/WMQZXyULO3exiTDsQXWFf8CAwEAAaMPMA0wCwYDVR0PBAQDAgQQMA0GCSqGSIb3DQEBCwUAA4IBAQB3fQZz2qNAo/wohPNaR2uAakLt25cKrsbgn3XwO+X+DRH4nqMSZkHdLGr82xD3i33BLSQwXzFecEN+CA8SlpNoIXHwk6D6V3uEBSjKemZtJFCJqe8d+5qt3GV50AKmtEt2Nc7B94TN8xB5EmZladnTJWcBgSuuz1hLXQQ02dJ3dDq8FMlyR70S2DTtuPu0i2/f6KtrlmmNsU24Aq+fCzEG43NqShOMeM5rDxLsSJCtjfMRwG8YeyNf6cCMSMxYAJfrTyj+AS8RtZQNGF7tX+exEWHOf1C9CBzHtKRClBRL6zDjlpPCIDwcMFi8NXvaiVclxIq3XdfqxiGBBEldkhgZ</dsig:X509Certificate></dsig:X509Data></dsig:KeyInfo><xenc:CipherData><xenc:CipherValue>J0UGnQLJujclPD0F8yTi1SR1OhYnxI/SvIyObj4rXP2BCho558axyuom/5bKElHyQ5JpLx0v/dCSUgCW1n+sMGDJ+3BhDU0hVPhpULwfZryKHusMlBkvysvd/O6L1whPlGgJrT39tkiBBi6AJ8mKeD3fhogYqpleF+lkrKxjFDBfhWTAbuZ8y8C3Mx6mos7kjbR5Gs47wnrz4eYgW+NRJ8V/NyauCEmp9BAbgrwWZ/rmgMXYnRof+9mSQ8f2LfqcuIvr3I+LNLhw1ICaNvaUQIV6B0JZKXfibwk50wAK4As6LRIy2/OJ1eM2rn+S/9KEMEqbVJ0SNrtdczJOhji/qg==</xenc:CipherValue></xenc:CipherData></xenc:EncryptedKey></dsig:KeyInfo>
   <xenc:CipherData>
      <xenc:CipherValue>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</xenc:CipherValue>
   </xenc:CipherData>
</xenc:EncryptedData></saml2:EncryptedAssertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_46.b64 ================================================ <saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="id70938295375022572142875469" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
    <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" xmlns:xs="http://www.w3.org/2001/XMLSchema"><xenc:EncryptedData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#" xmlns:dsig="http://www.w3.org/2000/09/xmldsig#" Type="http://www.w3.org/2001/04/xmlenc#Element"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes256-cbc"/><dsig:KeyInfo xmlns:dsig="http://www.w3.org/2000/09/xmldsig#"><xenc:EncryptedKey><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p"><dsig:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/></xenc:EncryptionMethod><dsig:KeyInfo><dsig:X509Data><dsig:X509Certificate>MIIDPjCCAiagAwIBAgIJAMMdzQFZ6vqIMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgzMDIzMTAzNloYDzIxMTcwODA2MjMxMDM2WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAK9o4wv2G1m/OwCVYzqsVN+PMHbkES3rpxDRAPRI024vDzKxznXWmh3X/f33Oqm2jAGuT70Rw34C878OKIlpcKfWGuouLXneYGxW6WY1ICfioExLlT+VngeQHFIzR0K9U7C3FHxJh0XL24b3wvAce3LaKENlE2cd4I4hfVqEPyiTogr9+mdXIX1++w6DNUYibpbYpe8Vo19Fe31HkiIjuDUPLXSH0hk6pnM6mmIdM+CBCg7oRr/UYBGqvHg5ItL+E036eKwdCjkxhOFddPEx78/ssJB+mq4V/CLQbVPnGniKYB4RqBZl56tp12pEdUW6VlzEPLuVMMlV5mRLUuwjtiUCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQByP5NYYOIYsQkkgcNJXCP8oI+tuKDfgZfcpgqJ4kuz7zOERpVztgYgUKYo0pmee+WT6X3q3fZCPTtQiAuelHOHTR/rwltjPT0OuAz3U50dcOFMXuWii/FAUjRw26OtR/7J6r90g75SeNBBXTgv6wRr8n4/iERQh0JkBJcpwCD7ZcDgcRwPZqpuBF31U2jo1NgOhSSVg7ZDgFZDLUeeGekfbDLg9TD+xIt06fYtd4pdIpK2reBiKgE9epksjQO7FzmJzB4yaAILrffSsxCWZrHgwASaaOe1FYP3UgLzhvOU/C30feltvG9WWtPWMxCop2q2JR0SRG+mWiWau8uXfpmE</dsig:X509Certificate></dsig:X509Data></dsig:KeyInfo><xenc:CipherData><xenc:CipherValue>oH5g/zuqKjU/XYCyl99b/kyTzP8o6rhETaaXSXXGWTcj+Bj+toTVGtYsoDH4Ggd8UyToreMdebgj3yD+3fILkD26mC3Bu2YbUVcSNJ/8fn3ObkmkgkY2w9tm6fm/cQNvXsGemoytUj3Y7n88xFdvHPbBhBaPDw0rp9G9asSqh0VZCn3Y7ctuevZ+mCxCMcvmTFXfQf9jDmQkv2yNyvlonycIeQT+7L7oWYZDswJkvBCm/1+cqkVZLyzQUkSYCImyPduagJyeA4vcLb4DdVUUqQkTv/oyJZdrY7z1T2Sik5+nUqkMiuNTkmJzBMfL0PA92BuzR7QhlAXKkTCicvcLCQ==</xenc:CipherValue></xenc:CipherData></xenc:EncryptedKey></dsig:KeyInfo>
   <xenc:CipherData>
      <xenc:CipherValue>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</xenc:CipherValue>
   </xenc:CipherData>
</xenc:EncryptedData></saml2:EncryptedAssertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_47.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="pfxb4858bf4-d4fe-3fb6-9363-8f7b8384699c" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfxb4858bf4-d4fe-3fb6-9363-8f7b8384699c"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>oZPHjE7LtorOT383wdd8iGUEbUU=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>U5fSTPQDqNaqe9QWub41tsJBXH3Fg2Gg6h4USV9kCuMQdJgZ7nNlZtfzrW8TMZ9BIRkHyIi4RPYcU8aDKlPS0vBr+9qYHeNJZmlZD8y1WPg1MQO1ftsJkP0EffgpoTsblrFNXjmp5z+GsS1KUSXesxaO7oxoED9nVqlgta3odSCs/a6i7fEGb1nnMVvU5QYDsRPzfykAx6IkZdsAHHMM9CYHrTUWhKNk5mGoZ9DrQkgUPM2rNU02G7tPFaoIMxp25YOhcNKgMn4HtJckQulEugVY06zXz7+iGCxtbKxIUzbjB2YLi10U+WIo0yq5eAlDDeV8W3FRQ7G05JCC0JqfPQ==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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" xmlns:xs="http://www.w3.org/2001/XMLSchema"><xenc:EncryptedData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#" xmlns:dsig="http://www.w3.org/2000/09/xmldsig#" Type="http://www.w3.org/2001/04/xmlenc#Element"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes256-cbc"/><dsig:KeyInfo xmlns:dsig="http://www.w3.org/2000/09/xmldsig#"><xenc:EncryptedKey><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p"><dsig:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/></xenc:EncryptionMethod><dsig:KeyInfo><dsig:X509Data><dsig:X509Certificate>MIIDPjCCAiagAwIBAgIJAMMdzQFZ6vqIMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgzMDIzMTAzNloYDzIxMTcwODA2MjMxMDM2WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAK9o4wv2G1m/OwCVYzqsVN+PMHbkES3rpxDRAPRI024vDzKxznXWmh3X/f33Oqm2jAGuT70Rw34C878OKIlpcKfWGuouLXneYGxW6WY1ICfioExLlT+VngeQHFIzR0K9U7C3FHxJh0XL24b3wvAce3LaKENlE2cd4I4hfVqEPyiTogr9+mdXIX1++w6DNUYibpbYpe8Vo19Fe31HkiIjuDUPLXSH0hk6pnM6mmIdM+CBCg7oRr/UYBGqvHg5ItL+E036eKwdCjkxhOFddPEx78/ssJB+mq4V/CLQbVPnGniKYB4RqBZl56tp12pEdUW6VlzEPLuVMMlV5mRLUuwjtiUCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQByP5NYYOIYsQkkgcNJXCP8oI+tuKDfgZfcpgqJ4kuz7zOERpVztgYgUKYo0pmee+WT6X3q3fZCPTtQiAuelHOHTR/rwltjPT0OuAz3U50dcOFMXuWii/FAUjRw26OtR/7J6r90g75SeNBBXTgv6wRr8n4/iERQh0JkBJcpwCD7ZcDgcRwPZqpuBF31U2jo1NgOhSSVg7ZDgFZDLUeeGekfbDLg9TD+xIt06fYtd4pdIpK2reBiKgE9epksjQO7FzmJzB4yaAILrffSsxCWZrHgwASaaOe1FYP3UgLzhvOU/C30feltvG9WWtPWMxCop2q2JR0SRG+mWiWau8uXfpmE</dsig:X509Certificate></dsig:X509Data></dsig:KeyInfo><xenc:CipherData><xenc:CipherValue>GXTdUmBNxr2O5IvBTaDPkOMNw3QohZgRerdWrJdm8o7sD1ZQuutdcKy3rpL+PIoW+LGKNFll/3vdWIboeKjMF1erZSF7RdA2zt6LxFzzqSF5tPgPMV2C4thdSq7lkT8wCRLCcY5Bywf7LjPJ7MUzK8cab9OYc+g9CB7jR4HOyLSsnfDoSIrc8Z8vf73vZMDAUuuzvkVwAUfNSsoUCVM7YsKkU7YaUZXSfgRbR11ZZMb7HqAZ7g7vI5LdhJcxk+Yd7CP7lOUFYNon/MxJXMSAoQE03aJVfLC5gemTdDDEGLhkF+OUVSHsv2hCDJDNZx9QonK/klrkhr2TbFtXFrIkzA==</xenc:CipherValue></xenc:CipherData></xenc:EncryptedKey></dsig:KeyInfo>
   <xenc:CipherData>
      <xenc:CipherValue>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</xenc:CipherValue>
   </xenc:CipherData>
</xenc:EncryptedData></saml2:EncryptedAssertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_48.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="pfx33eca366-2451-8acb-dbb6-b153caa06889" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx33eca366-2451-8acb-dbb6-b153caa06889"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>Hnt3AoVgZHWW/znjwFi0y/vZoWw=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>lZ9pweXeyCu+ogQm9L9cNQY/6rYG9aWBzRt3lBII9BzP6SY/1tHpF/p3LMQevYVizKEJCSCImFEIj3zu9lpeBrN3pfxOzAWN2Z4pTrUDvy32ryfibHp7YlXTYRBjx9lB595sQtEg44rftdl69eC4yFMzsgguksUfmbICMSmzHV7/gway5AeUC/Ga3SkA/S6aWaPsDK/hWhPKYWpHLi9/1uA40i80wmMLVXyDFqNInYK4L527laNr5SElHsVGYyI0uko+zInnipga3oyT+IvjeDAQLR1GTEk00sxDzfH4ie6M4EzYSkpWuzvgosk56QSyrm3pls/+0z5awaN/icLBgw==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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" xmlns:xs="http://www.w3.org/2001/XMLSchema"><xenc:EncryptedData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#" xmlns:dsig="http://www.w3.org/2000/09/xmldsig#" Type="http://www.w3.org/2001/04/xmlenc#Element"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes256-cbc"/><dsig:KeyInfo xmlns:dsig="http://www.w3.org/2000/09/xmldsig#"><xenc:EncryptedKey><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p"><dsig:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/></xenc:EncryptionMethod><dsig:KeyInfo><dsig:X509Data><dsig:X509Certificate>MIIDPjCCAiagAwIBAgIJAMMdzQFZ6vqIMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgzMDIzMTAzNloYDzIxMTcwODA2MjMxMDM2WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAK9o4wv2G1m/OwCVYzqsVN+PMHbkES3rpxDRAPRI024vDzKxznXWmh3X/f33Oqm2jAGuT70Rw34C878OKIlpcKfWGuouLXneYGxW6WY1ICfioExLlT+VngeQHFIzR0K9U7C3FHxJh0XL24b3wvAce3LaKENlE2cd4I4hfVqEPyiTogr9+mdXIX1++w6DNUYibpbYpe8Vo19Fe31HkiIjuDUPLXSH0hk6pnM6mmIdM+CBCg7oRr/UYBGqvHg5ItL+E036eKwdCjkxhOFddPEx78/ssJB+mq4V/CLQbVPnGniKYB4RqBZl56tp12pEdUW6VlzEPLuVMMlV5mRLUuwjtiUCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQByP5NYYOIYsQkkgcNJXCP8oI+tuKDfgZfcpgqJ4kuz7zOERpVztgYgUKYo0pmee+WT6X3q3fZCPTtQiAuelHOHTR/rwltjPT0OuAz3U50dcOFMXuWii/FAUjRw26OtR/7J6r90g75SeNBBXTgv6wRr8n4/iERQh0JkBJcpwCD7ZcDgcRwPZqpuBF31U2jo1NgOhSSVg7ZDgFZDLUeeGekfbDLg9TD+xIt06fYtd4pdIpK2reBiKgE9epksjQO7FzmJzB4yaAILrffSsxCWZrHgwASaaOe1FYP3UgLzhvOU/C30feltvG9WWtPWMxCop2q2JR0SRG+mWiWau8uXfpmE</dsig:X509Certificate></dsig:X509Data></dsig:KeyInfo><xenc:CipherData><xenc:CipherValue>oH5g/zuqKjU/XYCyl99b/kyTzP8o6rhETaaXSXXGWTcj+Bj+toTVGtYsoDH4Ggd8UyToreMdebgj3yD+3fILkD26mC3Bu2YbUVcSNJ/8fn3ObkmkgkY2w9tm6fm/cQNvXsGemoytUj3Y7n88xFdvHPbBhBaPDw0rp9G9asSqh0VZCn3Y7ctuevZ+mCxCMcvmTFXfQf9jDmQkv2yNyvlonycIeQT+7L7oWYZDswJkvBCm/1+cqkVZLyzQUkSYCImyPduagJyeA4vcLb4DdVUUqQkTv/oyJZdrY7z1T2Sik5+nUqkMiuNTkmJzBMfL0PA92BuzR7QhlAXKkTCicvcLCQ==</xenc:CipherValue></xenc:CipherData></xenc:EncryptedKey></dsig:KeyInfo>
   <xenc:CipherData>
      <xenc:CipherValue>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</xenc:CipherValue>
   </xenc:CipherData>
</xenc:EncryptedData></saml2:EncryptedAssertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_50.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" ID="pfx4400b8cb-db22-beea-1787-9cfe5d720e4e" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx4400b8cb-db22-beea-1787-9cfe5d720e4e"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>DxAnkOoYPVrziwT9RP5L1CNy/GU=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>qZwyZgXWJt/0CrGFFLL0gb7+t4jwvpSsrxJmg0IA0Dy6a4CgdTxTk9sXcvMJIYxPmB8BbIQyazjtv6KrXmeYjTDNMkY/3zwYx/BI8Okc4WbHUAI8pP0mPI0wGcdmbCig9UUrhZ76DK0jq9xgsEg9j52s5P+OUHVeEEbO+Uu6OiG1a9AGbZup79Xj1sz3MmusIIQRmWE55w1MvGQo4aFiqxLDwzP2w+X1kzTCOZVMr5oe6AgyxsWsElA/dst/G7AWwVfPSBIE4qbks0K6TMVLOMyTlA5SvlAIEdfskY848JdQ10zg96UAdAXANqXM2N850FemZzc8xMFN/19NtnNmIQ==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="id70938295375467671318387720" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
        <saml2:Subject xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:NameID Format="urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-30T23:19:41.379Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-30T23:09:41.379Z" NotOnOrAfter="2017-08-30T23:19:41.379Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_51.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/incorrect" ID="pfxcf98ab30-7a3e-fdf4-818e-c8a8894e0bc3" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfxcf98ab30-7a3e-fdf4-818e-c8a8894e0bc3"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>nRiX/7VDBs6JuUxbug79zryj5bU=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>CJwBpzu47F6OZrUK/G68GoEc6hIzx3hWNnMiby7uPctF565ZXGfWMUmu/HIQEaDkZ2dGFp2HbxMUGFm7lT4k1EU7MGDMnaTRa2ml2J/QWRfxnbZJXc+kylQCjkdkJiVYKKFaN6EDDjr3xJDht2ZPtJNIoT21SJKocgPwLnilg0hJ3AFhNfdCkxQLP/Zz4LHFOUpNsVNOSJC9ybUMY4TDX7zZUUDljDcv2u53OREQeNLeK29o4/o9+tx+9naBP9LjovTNeHUFMMlno2I+UtwK+gotGtcC7sEitcebYWEC2grpyn+8kWjCyRNPaae7rkuZe7awfnU2+0cTH5TGfll1qQ==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="id70938295375467671318387720" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
        <saml2:Subject xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:NameID Format="urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-30T23:19:41.379Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-30T23:09:41.379Z" NotOnOrAfter="2017-08-30T23:19:41.379Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_52.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="pfx7dda6033-7933-4b3d-86fc-99ed05eee43a" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/incorrect</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="#pfx7dda6033-7933-4b3d-86fc-99ed05eee43a"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>oaqNntdRpGLbScVrqsPdo6Oq0QY=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>Rr9dVrWgVrSCNFirkNfzs45kwVAAxmRQVfF7iBCsywbJLUpQYxcvyrf0QN5D7UaXiT/c1V1fjvr+kokcYXcibYfXa2lOTw4b6LOeG1E+iCJK6chzJaf43uUpmOW9rgwuW9Jtd/fssgiPtR2YMYyH1vjhCGrEqzFobDhD6R3W0antxYVBr/Ug2TZdO2DpA6U9jxrX7dygGqfIzT957ii8p+nEembsgsnkS17PR2Kxpw4mCv6PSZqCGLNnJfQunh/TV7YaoQmDc4zkUlxCkLXoifjk+O9c4FpH1pnGLLQR5o1QgLazT3i6Kp1n/Tt6KWUNITPZfNTPAxHkefQJqT8TSQ==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="id70938295375467671318387720" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
        <saml2:Subject xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:NameID Format="urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-30T23:19:41.379Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-30T23:09:41.379Z" NotOnOrAfter="2017-08-30T23:19:41.379Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_53.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="pfx06a98d9a-3b13-5d25-5be1-6ff50f9cc630" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx06a98d9a-3b13-5d25-5be1-6ff50f9cc630"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>DryzEqERuHAqb0jOpCMID9RMN+k=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>w8m60W0wQtswrnQNJrjo0eR76WyVW470DzjURLcKDss8YJvDenSQwBrdummtr4yVrQC6BK79ug+WOxH4QcgvUZSE3+VjS21i38E5JHH6YX3bAUfwJhaW/wI/PDRSflqcjVxDVVMyo0gT2jQtHcqZUauY64oN+HtuDlUL7akoe6ccpfPjbjZPPBhzw5e5JLkHe1Z4dHlHZpLoe8zdvtPxhBsSdEbUG+5Rg/WsGi6Cmb0CL0db8JHKqlq/qqWxpKkV5JgL+osc8k/ddylEZvai8yqvlWMr5eVlZa9kBF826CvigbLXqEkL0F7n3yjM5WkHQSilMf76CJhf6HGTkrTduQ==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="id70938295375467671318387720" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
        <saml2:Subject xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:NameID Format="urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-30T23:19:41.379Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-30T23:09:41.379Z" NotOnOrAfter="2017-08-30T23:19:41.379Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/incorrect</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_54.b64 ================================================ <?xml version="1.0"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="pfx4b222836-b201-ec46-5106-da0ff59772f6" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx4b222836-b201-ec46-5106-da0ff59772f6"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>eqUoCvnxIo97biuXWDAvMjjQH5M=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>kTwjEI3pe/t4Kb53+3MXoKkJM6ozSkvDdt0LoId1Gjug7P98gwVSfdqU6N2RLhPgttjFkHQ/dBL4eh8mqWQOoTk1MqQtGLWNQGOTD5NClLWdCyQNup77T6hh5aYmIT9KwL6XBT3JKvhUY5Yhsx7QaclMlQtKJFiS6qPtb8QLMr6yJZHjWOPCuLMvWD/wg2kUsNzmskM9FRGXOHDs4sqyDnAt0XzrPuC9Tib2NeF4YgIMXnMGyIwW6fspD0ygJg9V0B24n16jhnizmgG+niKhZvtQHztRGSe0E5MHZPhsFOySxyjs5ANH2HgikrRbI/wg9ZoZqwC39pW5txr7F7L/RA==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="id70938295375467671318387720" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/incorrect</saml2:Issuer>
        <saml2:Subject xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:NameID Format="urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-30T23:19:41.379Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-30T23:09:41.379Z" NotOnOrAfter="2017-08-30T23:19:41.379Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_55.b64 ================================================ <saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" ID="id70938295375022572142875469" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
    <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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="pfx83e79208-9f3b-a332-c15f-529b8ab5a022" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx83e79208-9f3b-a332-c15f-529b8ab5a022"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>EpFL6n+Y5OFfnw3cAFvwMYC3VGU=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>ERboVDDJHG7AWITvdkfVbQuResbKwRfOXfw8vg1Ylwagz3K6BWACPWbIRH3aZt/AZ5UDggG0zsKFkwaZDJZe4FBmxwwQIY6LE4gvQbPbM/UMeb/JxjNvgh1pq/vLPNNXOmPUnLp/ZOv/WGJ69vYk6bdx0VtQTBWmlwiA6ImHQHXLWfak3QYvNgWwEownxs12lqyOdOg5mWb4z9r5tTh/FFnHwLleOdVq1DxtLZ5FiFEMzc4bvDwTl4ARzu8lbg+OiDbOUB1V2wnkTi+ihGho7qlKtuc7g4dABiaHRTfV94T+we2JE7QIzfYz2A1pLj2vu4dswSJAuAHwgIq8N1bldg==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-30T23:19:41.379Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-30T23:09:41.379Z" NotOnOrAfter="2017-08-30T23:19:41.379Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_56.b64 ================================================ <saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/incorrect" ID="id70938295375022572142875469" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
    <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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="pfxf869205e-eb05-0263-ad73-d3110d0c7598" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfxf869205e-eb05-0263-ad73-d3110d0c7598"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>W9g/FC8eAFCY7+qnZmA/Ybv7WM8=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>IkFtba/zqHd6Gn7LV3nzkC4ES5eRZvFVcCRIx07BeR0EYuiqCsqUqjV/6+dG93up1jVxEq8K4QtwJK7lU2+mHm8zbXqDN+DaqHardimUR4PSgauA+BgM50oESz/bU7FR0GzO09cvumpApmZb2o2IoT2MOgs6cQFACxGu1IlI+7A5Ymz3vQA/EmutbDcvLKSP7Nk2jPHA1y+iHObWc5N4nwvnxuSbCS/bspgPzRBJkuprBYR7HjqYUzXNaFmW/FrFKz6lA6XxIzBEKJ+1pXAfIaEsvcwo39XZCMcvJasfQJCr4EPOdQP4uEYlT8rcryqofUI9b9Wznd/4+5qaphfLdA==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-30T23:19:41.379Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-30T23:09:41.379Z" NotOnOrAfter="2017-08-30T23:19:41.379Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_57.b64 ================================================ <saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="id70938295375022572142875469" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/incorrect</saml2:Issuer>
    <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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="pfx879b1631-cbc5-be3c-313a-c905a67381ae" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx879b1631-cbc5-be3c-313a-c905a67381ae"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>dnkcROGorfaLx3xik6+lOZ6fUjg=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>H4oR1kXwh/xABStLDphr8/udv3H5Uoj82d0IE7n7lA5JVOGKS6mvoufgwSR1uivHoztAf6l3lr2fL6jcuWaUK4oRXfMastpbInrLjBkhrKNRUmC5vcwH+evs6Y3oyTL5Z+9eiGS7iauPHjjYqGcDzf03Ef2gLlsLY4tA6zboCi8MRDrJHZzDZ9ntTMYPLyNxtuFOMjWGfozkvRnbvGNcqGhpnQ5QABUc4t2F/XmwINTJb4J0Ijoy2HRUzRAO5UXDyb5kiaEk9qCRbh3N3oSu50pi9Ka3JRaK6iExpOz0P0o8nP4bI62YyqMxM0w6ENeB7Rv+Hg1IU3th0RdlZuaGQw==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-30T23:19:41.379Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-30T23:09:41.379Z" NotOnOrAfter="2017-08-30T23:19:41.379Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_58.b64 ================================================ <saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="id70938295375022572142875469" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
    <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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="pfx00634dac-7be3-a91d-5048-56be6cd41f86" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx00634dac-7be3-a91d-5048-56be6cd41f86"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>usy0dnSA0g0TUf8DqaWKO6/5bA0=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>oUDhsMrtyVkzH3WED1axb5lYn2CZ+ceAmn1Ku7yxmoQ2L+wt2ruB7AZ7wgFs72BNTVs5W2kPOKosXpsl9CAc4YZysoxGzLw3vueD/QKhLUncz8ATiG742MBXd/isKP5tx64fF7QZLPh25bu9RZIGkHs/cP8hOkV660WBzI+NZev5Ulx/pwiV8WniA8cttmnnxGWPRRpudaRinYxMFbgpAEmBM9JzHKoTKUHKNLcH5cosUVC7Hy/NpNBSYKIRswF6LWTcQTrJ0i6sfXd7LpwIVY/OQiDCY/OMiFElVWsBUTLBEU+L2JkIIw3G8CYC7El346FowH9iAECq7wBnvRQK/g==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-30T23:19:41.379Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-30T23:09:41.379Z" NotOnOrAfter="2017-08-30T23:19:41.379Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/incorrect</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_59.b64 ================================================ <saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="id70938295375022572142875469" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
    <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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="pfx5619a2e7-26e9-8d12-de76-d784b4b7c4a2" IssueInstant="2017-08-30T23:14:41.379Z" 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://saml.idp.nope/incorrect</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="#pfx5619a2e7-26e9-8d12-de76-d784b4b7c4a2"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>fE7rtiQHIU0tGqK8dNo2H75SaVQ=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>mEsD1a8ZFT2eKO0FPVFU6n6fKn0VsoiHt0Ut5KJPQWO+CAci6+JIJhA6dO5+RFLejDrTaoWUG1/GAYpc12QrKroV+nIpGsIN0UmbFBkGN5Obch06w1u/QxE9TA5Uq50QYb6L870QtOL8P+0e/aClX4f6Vh71y/fAm8eC7b+5PbHKaBmAC/lV3YMisNfC0IKe3mdljYK+6legkRukpvqFvJbBPwO24+qytdJK/VsIMSspeTjuAyvqdmzn1LyGRNxEvI/7CYEUlB10FttkQBmZqnXlawSkVm8IO6wNEP8y6lfPemmReYagYYUftdJWgwVph88ROCYDvJ7mKqBJ2ljgCw==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-30T23:19:41.379Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-30T23:09:41.379Z" NotOnOrAfter="2017-08-30T23:19:41.379Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_81.b64 ================================================ PHNhbWwycDpSZXNwb25zZSB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIu MDpwcm90b2NvbCIKICAgICAgICAgICAgICAgICBEZXN0aW5hdGlvbj0iaHR0cHM6Ly9zYW1sLnNw Lm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9hY3MvcnE1andrdmI4eiIKICAgICAgICAgICAgICAgICBJ RD0iaWQ3MDkzODI5NTM3NTAyMjU3MjE0Mjg3NTQ2OSIKICAgICAgICAgICAgICAgICBJblJlc3Bv bnNlVG89ImlkLTUzMWIyYmYwMmFlMGE1ODhjMzAyMzQxNjNhZGJmZDlkNmJiZjA3NDciCiAgICAg ICAgICAgICAgICAgSXNzdWVJbnN0YW50PSIyMDE3LTA4LTExVDAxOjA1OjAwWiIKICAgICAgICAg ICAgICAgICBWZXJzaW9uPSIyLjAiPgogICAgPHNhbWwyOklzc3VlciB4bWxuczpzYW1sMj0idXJu Om9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiIKICAgICAgICAgICAgICAgICAgRm9y bWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6bmFtZWlkLWZvcm1hdDplbnRpdHkiPmh0 dHBzOi8vc2FtbC5pZHAubm9wZS9oOWdranp2YjNlPC9zYW1sMjpJc3N1ZXI+CiAgICA8c2FtbDJw OlN0YXR1cyB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpwcm90b2Nv bCI+CiAgICAgICAgPHNhbWwycDpTdGF0dXNDb2RlIFZhbHVlPSJ1cm46b2FzaXM6bmFtZXM6dGM6 U0FNTDoyLjA6c3RhdHVzOlN1Y2Nlc3MiLz4KICAgIDwvc2FtbDJwOlN0YXR1cz4KICAgIDxzYW1s MjpBc3NlcnRpb24geG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3Nl cnRpb24iCiAgICAgICAgICAgICAgICAgICAgIElEPSJpZDcwOTM4Mjk1Mzc1NDY3NjcxMzE4Mzg3 NzIwIgogICAgICAgICAgICAgICAgICAgICBJc3N1ZUluc3RhbnQ9IjIwMTctMDgtMTFUMDE6MDU6 MDBaIgogICAgICAgICAgICAgICAgICAgICBWZXJzaW9uPSIyLjAiCiAgICAgICAgICAgICAgICAg ICAgIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSI+CiAgICAgICAg PHNhbWwyOklzc3VlciBGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpuYW1laWQt Zm9ybWF0OmVudGl0eSIKICAgICAgICAgICAgICAgICAgICAgIHhtbG5zOnNhbWwyPSJ1cm46b2Fz aXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIj5odHRwczovL3NhbWwuaWRwLm5vcGUvaDln a2p6dmIzZTwvc2FtbDI6SXNzdWVyPgogICAgICAgIDxzYW1sMjpTdWJqZWN0IHhtbG5zOnNhbWwy PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIj4KICAgICAgICAgICAgPHNh bWwyOk5hbWVJRCBGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjEuMTpuYW1laWQtZm9y bWF0OmVtYWlsQWRkcmVzcyI+dXNlckBzYW1sLnNwLm5vcGU8L3NhbWwyOk5hbWVJRD4KICAgICAg ICAgICAgPHNhbWwyOlN1YmplY3RDb25maXJtYXRpb24gTWV0aG9kPSJ1cm46b2FzaXM6bmFtZXM6 dGM6U0FNTDoyLjA6Y206YmVhcmVyIj4KICAgICAgICAgICAgICAgIDxzYW1sMjpTdWJqZWN0Q29u ZmlybWF0aW9uRGF0YSBJblJlc3BvbnNlVG89ImlkLTUzMWIyYmYwMmFlMGE1ODhjMzAyMzQxNjNh ZGJmZDlkNmJiZjA3NDciCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgTm90T25PckFmdGVyPSIyMDE3LTA4LTExVDAxOjEwOjAwWiIKICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBSZWNpcGllbnQ9Imh0dHBzOi8vc2FtbC5z cC5ub3BlL3Nlc3Npb24vc3NvL3NhbWwvYWNzL3JxNWp3a3ZiOHoiLz4KICAgICAgICAgICAgPC9z YW1sMjpTdWJqZWN0Q29uZmlybWF0aW9uPgogICAgICAgIDwvc2FtbDI6U3ViamVjdD4KICAgICAg ICA8c2FtbDI6Q29uZGl0aW9ucyBOb3RCZWZvcmU9IjIwMTctMDgtMTFUMDE6MDA6MDBaIgogICAg ICAgICAgICAgICAgICAgICAgICAgIE5vdE9uT3JBZnRlcj0iMjAxNy0wOC0xMVQwMToxMDowMFoi CiAgICAgICAgICAgICAgICAgICAgICAgICAgeG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0 YzpTQU1MOjIuMDphc3NlcnRpb24iPgogICAgICAgICAgICA8c2FtbDI6QXVkaWVuY2VSZXN0cmlj dGlvbj4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdWRpZW5jZT5odHRwczovL3NhbWwuc3Aubm9w ZS9zZXNzaW9uL3Nzby9zYW1sL3NwZW50aXR5aWQvcnE1andrdmI4ejwvc2FtbDI6QXVkaWVuY2U+ CiAgICAgICAgICAgIDwvc2FtbDI6QXVkaWVuY2VSZXN0cmljdGlvbj4KICAgICAgICA8L3NhbWwy OkNvbmRpdGlvbnM+CiAgICAgICAgPHNhbWwyOkF1dGhuU3RhdGVtZW50IEF1dGhuSW5zdGFudD0i MjAxNy0wOC0zMFQyMzoxNDo0MS4zNzlaIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICBT ZXNzaW9uSW5kZXg9ImlkLTUzMWIyYmYwMmFlMGE1ODhjMzAyMzQxNjNhZGJmZDlkNmJiZjA3NDci CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhtbG5zOnNhbWwyPSJ1cm46b2FzaXM6bmFt ZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIj4KICAgICAgICAgICAgPHNhbWwyOkF1dGhuQ29udGV4 dD4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdXRobkNvbnRleHRDbGFzc1JlZj51cm46b2FzaXM6 bmFtZXM6dGM6U0FNTDoyLjA6YWM6Y2xhc3NlczpQYXNzd29yZFByb3RlY3RlZFRyYW5zcG9ydDwv c2FtbDI6QXV0aG5Db250ZXh0Q2xhc3NSZWY+CiAgICAgICAgICAgIDwvc2FtbDI6QXV0aG5Db250 ZXh0PgogICAgICAgIDwvc2FtbDI6QXV0aG5TdGF0ZW1lbnQ+CiAgICAgICAgPHNhbWwyOkF0dHJp YnV0ZVN0YXRlbWVudCB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFz c2VydGlvbiI+CiAgICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGUgTmFtZT0iZ2l2ZW5OYW1lIgog ICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5hbWVGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0 YzpTQU1MOjIuMDphdHRybmFtZS1mb3JtYXQ6dW5zcGVjaWZpZWQiPgogICAgICAgICAgICAgICAg PHNhbWwyOkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hN TFNjaGVtYSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4bWxuczp4c2k9 Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIgogICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgIHhzaTp0eXBlPSJ4czpzdHJpbmciPkZpcnN0PC9zYW1s MjpBdHRyaWJ1dGVWYWx1ZT4KICAgICAgICAgICAgPC9zYW1sMjpBdHRyaWJ1dGU+CiAgICAgICAg ICAgIDxzYW1sMjpBdHRyaWJ1dGUgTmFtZT0ic24iCiAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgTmFtZUZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmF0dHJuYW1lLWZvcm1h dDp1bnNwZWNpZmllZCI+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlVmFsdWUgeG1s bnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIgogICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9Y TUxTY2hlbWEtaW5zdGFuY2UiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg eHNpOnR5cGU9InhzOnN0cmluZyI+TGFzdDwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAg ICAgIDwvc2FtbDI6QXR0cmlidXRlPgogICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlIE5hbWU9 Imdyb3VwIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5hbWVGb3JtYXQ9InVybjpvYXNp czpuYW1lczp0YzpTQU1MOjIuMDphdHRybmFtZS1mb3JtYXQ6dW5zcGVjaWZpZWQiPgogICAgICAg ICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9y Zy8yMDAxL1hNTFNjaGVtYSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4 bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIgogICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhzaTp0eXBlPSJ4czpzdHJpbmciPnJl ZDwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRl VmFsdWUgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIgogICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5v cmcvMjAwMS9YTUxTY2hlbWEtaW5zdGFuY2UiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgeHNpOnR5cGU9InhzOnN0cmluZyI+Z3JlZW48L3NhbWwyOkF0dHJpYnV0ZVZhbHVl PgogICAgICAgICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8v d3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3Rh bmNlIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhzaTp0eXBlPSJ4czpz dHJpbmciPmJsdWU8L3NhbWwyOkF0dHJpYnV0ZVZhbHVlPgogICAgICAgICAgICA8L3NhbWwyOkF0 dHJpYnV0ZT4KICAgICAgICA8L3NhbWwyOkF0dHJpYnV0ZVN0YXRlbWVudD4KICAgIDwvc2FtbDI6 QXNzZXJ0aW9uPgo8L3NhbWwycDpSZXNwb25zZT4K ================================================ FILE: providertests/testdata/onelogin/olgn09_response_82.b64 ================================================ PHNhbWwycDpSZXNwb25zZSB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIu MDpwcm90b2NvbCIKICAgICAgICAgICAgICAgICBEZXN0aW5hdGlvbj0iaHR0cHM6Ly9zYW1sLnNw Lm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9hY3MvcnE1andrdmI4eiIKICAgICAgICAgICAgICAgICBJ RD0iaWQ3MDkzODI5NTM3NTAyMjU3MjE0Mjg3NTQ2OSIKICAgICAgICAgICAgICAgICBJblJlc3Bv bnNlVG89ImlkLTUzMWIyYmYwMmFlMGE1ODhjMzAyMzQxNjNhZGJmZDlkNmJiZjA3NDciCiAgICAg ICAgICAgICAgICAgSXNzdWVJbnN0YW50PSIyMTE2LTAzLTA4VDIzOjA1OjAwWiIKICAgICAgICAg ICAgICAgICBWZXJzaW9uPSIyLjAiPgogICAgPHNhbWwyOklzc3VlciB4bWxuczpzYW1sMj0idXJu Om9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiIKICAgICAgICAgICAgICAgICAgRm9y bWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6bmFtZWlkLWZvcm1hdDplbnRpdHkiPmh0 dHBzOi8vc2FtbC5pZHAubm9wZS9oOWdranp2YjNlPC9zYW1sMjpJc3N1ZXI+CiAgICA8c2FtbDJw OlN0YXR1cyB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpwcm90b2Nv bCI+CiAgICAgICAgPHNhbWwycDpTdGF0dXNDb2RlIFZhbHVlPSJ1cm46b2FzaXM6bmFtZXM6dGM6 U0FNTDoyLjA6c3RhdHVzOlN1Y2Nlc3MiLz4KICAgIDwvc2FtbDJwOlN0YXR1cz4KICAgIDxzYW1s MjpBc3NlcnRpb24geG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3Nl cnRpb24iCiAgICAgICAgICAgICAgICAgICAgIElEPSJpZDcwOTM4Mjk1Mzc1NDY3NjcxMzE4Mzg3 NzIwIgogICAgICAgICAgICAgICAgICAgICBJc3N1ZUluc3RhbnQ9IjIxMTYtMDMtMDhUMjM6MDU6 MDBaIgogICAgICAgICAgICAgICAgICAgICBWZXJzaW9uPSIyLjAiCiAgICAgICAgICAgICAgICAg ICAgIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSI+CiAgICAgICAg PHNhbWwyOklzc3VlciBGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpuYW1laWQt Zm9ybWF0OmVudGl0eSIKICAgICAgICAgICAgICAgICAgICAgIHhtbG5zOnNhbWwyPSJ1cm46b2Fz aXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIj5odHRwczovL3NhbWwuaWRwLm5vcGUvaDln a2p6dmIzZTwvc2FtbDI6SXNzdWVyPgogICAgICAgIDxzYW1sMjpTdWJqZWN0IHhtbG5zOnNhbWwy PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIj4KICAgICAgICAgICAgPHNh bWwyOk5hbWVJRCBGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjEuMTpuYW1laWQtZm9y bWF0OmVtYWlsQWRkcmVzcyI+dXNlckBzYW1sLnNwLm5vcGU8L3NhbWwyOk5hbWVJRD4KICAgICAg ICAgICAgPHNhbWwyOlN1YmplY3RDb25maXJtYXRpb24gTWV0aG9kPSJ1cm46b2FzaXM6bmFtZXM6 dGM6U0FNTDoyLjA6Y206YmVhcmVyIj4KICAgICAgICAgICAgICAgIDxzYW1sMjpTdWJqZWN0Q29u ZmlybWF0aW9uRGF0YSBJblJlc3BvbnNlVG89ImlkLTUzMWIyYmYwMmFlMGE1ODhjMzAyMzQxNjNh ZGJmZDlkNmJiZjA3NDciCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgTm90T25PckFmdGVyPSIyMTE2LTAzLTA4VDIzOjEwOjAwWiIKICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBSZWNpcGllbnQ9Imh0dHBzOi8vc2FtbC5z cC5ub3BlL3Nlc3Npb24vc3NvL3NhbWwvYWNzL3JxNWp3a3ZiOHoiLz4KICAgICAgICAgICAgPC9z YW1sMjpTdWJqZWN0Q29uZmlybWF0aW9uPgogICAgICAgIDwvc2FtbDI6U3ViamVjdD4KICAgICAg ICA8c2FtbDI6Q29uZGl0aW9ucyBOb3RCZWZvcmU9IjIxMTYtMDMtMDhUMjM6MDA6MDBaIgogICAg ICAgICAgICAgICAgICAgICAgICAgIE5vdE9uT3JBZnRlcj0iMjExNi0wMy0wOFQyMzoxMDowMFoi CiAgICAgICAgICAgICAgICAgICAgICAgICAgeG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0 YzpTQU1MOjIuMDphc3NlcnRpb24iPgogICAgICAgICAgICA8c2FtbDI6QXVkaWVuY2VSZXN0cmlj dGlvbj4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdWRpZW5jZT5odHRwczovL3NhbWwuc3Aubm9w ZS9zZXNzaW9uL3Nzby9zYW1sL3NwZW50aXR5aWQvcnE1andrdmI4ejwvc2FtbDI6QXVkaWVuY2U+ CiAgICAgICAgICAgIDwvc2FtbDI6QXVkaWVuY2VSZXN0cmljdGlvbj4KICAgICAgICA8L3NhbWwy OkNvbmRpdGlvbnM+CiAgICAgICAgPHNhbWwyOkF1dGhuU3RhdGVtZW50IEF1dGhuSW5zdGFudD0i MjAxNy0wOC0zMFQyMzoxNDo0MS4zNzlaIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICBT ZXNzaW9uSW5kZXg9ImlkLTUzMWIyYmYwMmFlMGE1ODhjMzAyMzQxNjNhZGJmZDlkNmJiZjA3NDci CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhtbG5zOnNhbWwyPSJ1cm46b2FzaXM6bmFt ZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIj4KICAgICAgICAgICAgPHNhbWwyOkF1dGhuQ29udGV4 dD4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdXRobkNvbnRleHRDbGFzc1JlZj51cm46b2FzaXM6 bmFtZXM6dGM6U0FNTDoyLjA6YWM6Y2xhc3NlczpQYXNzd29yZFByb3RlY3RlZFRyYW5zcG9ydDwv c2FtbDI6QXV0aG5Db250ZXh0Q2xhc3NSZWY+CiAgICAgICAgICAgIDwvc2FtbDI6QXV0aG5Db250 ZXh0PgogICAgICAgIDwvc2FtbDI6QXV0aG5TdGF0ZW1lbnQ+CiAgICAgICAgPHNhbWwyOkF0dHJp YnV0ZVN0YXRlbWVudCB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFz c2VydGlvbiI+CiAgICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGUgTmFtZT0iZ2l2ZW5OYW1lIgog ICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5hbWVGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0 YzpTQU1MOjIuMDphdHRybmFtZS1mb3JtYXQ6dW5zcGVjaWZpZWQiPgogICAgICAgICAgICAgICAg PHNhbWwyOkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hN TFNjaGVtYSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4bWxuczp4c2k9 Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIgogICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgIHhzaTp0eXBlPSJ4czpzdHJpbmciPkZpcnN0PC9zYW1s MjpBdHRyaWJ1dGVWYWx1ZT4KICAgICAgICAgICAgPC9zYW1sMjpBdHRyaWJ1dGU+CiAgICAgICAg ICAgIDxzYW1sMjpBdHRyaWJ1dGUgTmFtZT0ic24iCiAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgTmFtZUZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmF0dHJuYW1lLWZvcm1h dDp1bnNwZWNpZmllZCI+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlVmFsdWUgeG1s bnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIgogICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9Y TUxTY2hlbWEtaW5zdGFuY2UiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg eHNpOnR5cGU9InhzOnN0cmluZyI+TGFzdDwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAg ICAgIDwvc2FtbDI6QXR0cmlidXRlPgogICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlIE5hbWU9 Imdyb3VwIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5hbWVGb3JtYXQ9InVybjpvYXNp czpuYW1lczp0YzpTQU1MOjIuMDphdHRybmFtZS1mb3JtYXQ6dW5zcGVjaWZpZWQiPgogICAgICAg ICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9y Zy8yMDAxL1hNTFNjaGVtYSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4 bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIgogICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhzaTp0eXBlPSJ4czpzdHJpbmciPnJl ZDwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRl VmFsdWUgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIgogICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5v cmcvMjAwMS9YTUxTY2hlbWEtaW5zdGFuY2UiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgeHNpOnR5cGU9InhzOnN0cmluZyI+Z3JlZW48L3NhbWwyOkF0dHJpYnV0ZVZhbHVl PgogICAgICAgICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8v d3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3Rh bmNlIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhzaTp0eXBlPSJ4czpz dHJpbmciPmJsdWU8L3NhbWwyOkF0dHJpYnV0ZVZhbHVlPgogICAgICAgICAgICA8L3NhbWwyOkF0 dHJpYnV0ZT4KICAgICAgICA8L3NhbWwyOkF0dHJpYnV0ZVN0YXRlbWVudD4KICAgIDwvc2FtbDI6 QXNzZXJ0aW9uPgo8L3NhbWwycDpSZXNwb25zZT4K ================================================ FILE: providertests/testdata/onelogin/olgn09_response_83.b64 ================================================ <saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="id70938295375022572142875469" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-11T01:05:00Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
    <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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="pfx24c5e597-acf1-f9ce-37f0-4458e97c5123" IssueInstant="2017-08-11T01:05:00Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx24c5e597-acf1-f9ce-37f0-4458e97c5123"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>LA8T8Xxwuc/8SHJtmChW2PqNUGM=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>Dgw5pBV+mW8vfFd4TrCGRD/RpLi0Uawn8KWuhNhCWMSocQfVOxiETybOT6gZf0AXZpG7A/RiRMVMcCkHOE/HPA18bRN5lZl74oVKraEDL7+Q7BXZRm+Uhwa/wih7DI6hVNkl7ZIUT34E8deBRrmPq8AwK9ByFU8ljQBKpN6gPVIUuTZNMAlvI85sFZ8WgSY542H+p0T1h72ZOv6D4ZSx80njOIyafmwsDzg+vdyPeh4VurAUIXe0CdjCK5UoP2hjjXaBRqk+jEzl8cnWLsEuoWJsqigXeJogWo/FeMBIH7wZZfckYA4GlWU3a6N3vtYvt6pYgs4Pok/ctMXXV96LDg==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-11T01:10:00Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-11T01:00:00Z" NotOnOrAfter="2017-08-11T01:10:00Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_84.b64 ================================================ <saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="id70938295375022572142875469" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2116-03-08T23:05:00Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
    <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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="pfx58432add-0368-c547-1f00-ff279f5aa550" IssueInstant="2116-03-08T23:05:00Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx58432add-0368-c547-1f00-ff279f5aa550"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>ex/+g0NYqOkgkm674KLcBIJqtp0=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>djkrD+3NuiuiTiF+CDtICJRQVlbfSPxCDnxkaJD83TDruoJ0nSp/3rbA1IkBcFUG9gGHxXv/YayjZN2iF5W29hFKScN6/jo+/xkKCCuz5XpRwIXxvbsz9ElaZ393V2S9xUelyPi5InTffGSsqXXbOkefuY3RuOmd6MD7DtrXkkDcBxl/IRZsG3e3RqY5GrGjw3DWQ5FpcxRdt/6l+QN08GCnYrGoyA+cuTM+ubMxSIfhF+jD/Nns4GDm1a3ymbiiadc+xbhaXLZVfsEb/irk0iu7avnXIKRTe7JL2NUX53x2lIQK6IcH0HEXf4Q0VMccPeiln1s8seSNgYkBkJPIHg==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2116-03-08T23:10:00Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2116-03-08T23:00:00Z" NotOnOrAfter="2116-03-08T23:10:00Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_85.b64 ================================================ PHNhbWwycDpSZXNwb25zZSB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpwcm90b2NvbCIKICAgICAgICAgICAgICAgICBJRD0iaWQ3MDkzODI5NTM3NTAyMjU3MjE0Mjg3NTQ2OSIKICAgICAgICAgICAgICAgICBJblJlc3BvbnNlVG89ImlkLTUzMWIyYmYwMmFlMGE1ODhjMzAyMzQxNjNhZGJmZDlkNmJiZjA3NDciCiAgICAgICAgICAgICAgICAgSXNzdWVJbnN0YW50PSIyMDE3LTA4LTMwVDIzOjE0OjQxLjM3OVoiCiAgICAgICAgICAgICAgICAgVmVyc2lvbj0iMi4wIj4KICAgIDxzYW1sMjpJc3N1ZXIgeG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iCiAgICAgICAgICAgICAgICAgIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOm5hbWVpZC1mb3JtYXQ6ZW50aXR5Ij5odHRwczovL3NhbWwuaWRwLm5vcGUvaDlna2p6dmIzZTwvc2FtbDI6SXNzdWVyPgogICAgPHNhbWwycDpTdGF0dXMgeG1sbnM6c2FtbDJwPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiPgogICAgICAgIDxzYW1sMnA6U3RhdHVzQ29kZSBWYWx1ZT0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOnN0YXR1czpTdWNjZXNzIi8+CiAgICA8L3NhbWwycDpTdGF0dXM+CiAgICA8c2FtbDI6QXNzZXJ0aW9uIHhtbG5zOnNhbWwyPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIgogICAgICAgICAgICAgICAgICAgICBJRD0iaWQ3MDkzODI5NTM3NTQ2NzY3MTMxODM4NzcyMCIKICAgICAgICAgICAgICAgICAgICAgSXNzdWVJbnN0YW50PSIyMDE3LTA4LTMwVDIzOjE0OjQxLjM3OVoiCiAgICAgICAgICAgICAgICAgICAgIFZlcnNpb249IjIuMCIKICAgICAgICAgICAgICAgICAgICAgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIj4KICAgICAgICA8c2FtbDI6SXNzdWVyIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOm5hbWVpZC1mb3JtYXQ6ZW50aXR5IgogICAgICAgICAgICAgICAgICAgICAgeG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPmh0dHBzOi8vc2FtbC5pZHAubm9wZS9oOWdranp2YjNlPC9zYW1sMjpJc3N1ZXI+CiAgICAgICAgPHNhbWwyOlN1YmplY3QgeG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPgogICAgICAgICAgICA8c2FtbDI6TmFtZUlEIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6MS4xOm5hbWVpZC1mb3JtYXQ6ZW1haWxBZGRyZXNzIj51c2VyQHNhbWwuc3Aubm9wZTwvc2FtbDI6TmFtZUlEPgogICAgICAgICAgICA8c2FtbDI6U3ViamVjdENvbmZpcm1hdGlvbiBNZXRob2Q9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpjbTpiZWFyZXIiPgogICAgICAgICAgICAgICAgPHNhbWwyOlN1YmplY3RDb25maXJtYXRpb25EYXRhIEluUmVzcG9uc2VUbz0iaWQtNTMxYjJiZjAyYWUwYTU4OGMzMDIzNDE2M2FkYmZkOWQ2YmJmMDc0NyIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBOb3RPbk9yQWZ0ZXI9IjIwMTctMDgtMzBUMjM6MTk6NDEuMzc5WiIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBSZWNpcGllbnQ9Imh0dHBzOi8vc2FtbC5zcC5ub3BlL3Nlc3Npb24vc3NvL3NhbWwvYWNzL3JxNWp3a3ZiOHoiLz4KICAgICAgICAgICAgPC9zYW1sMjpTdWJqZWN0Q29uZmlybWF0aW9uPgogICAgICAgIDwvc2FtbDI6U3ViamVjdD4KICAgICAgICA8c2FtbDI6Q29uZGl0aW9ucyBOb3RCZWZvcmU9IjIwMTctMDgtMzBUMjM6MDk6NDEuMzc5WiIKICAgICAgICAgICAgICAgICAgICAgICAgICBOb3RPbk9yQWZ0ZXI9IjIwMTctMDgtMzBUMjM6MTk6NDEuMzc5WiIKICAgICAgICAgICAgICAgICAgICAgICAgICB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiI+CiAgICAgICAgICAgIDxzYW1sMjpBdWRpZW5jZVJlc3RyaWN0aW9uPgogICAgICAgICAgICAgICAgPHNhbWwyOkF1ZGllbmNlPmh0dHBzOi8vc2FtbC5zcC5ub3BlL3Nlc3Npb24vc3NvL3NhbWwvc3BlbnRpdHlpZC9ycTVqd2t2Yjh6PC9zYW1sMjpBdWRpZW5jZT4KICAgICAgICAgICAgPC9zYW1sMjpBdWRpZW5jZVJlc3RyaWN0aW9uPgogICAgICAgIDwvc2FtbDI6Q29uZGl0aW9ucz4KICAgICAgICA8c2FtbDI6QXV0aG5TdGF0ZW1lbnQgQXV0aG5JbnN0YW50PSIyMDE3LTA4LTMwVDIzOjE0OjQxLjM3OVoiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFNlc3Npb25JbmRleD0iaWQtNTMxYjJiZjAyYWUwYTU4OGMzMDIzNDE2M2FkYmZkOWQ2YmJmMDc0NyIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPgogICAgICAgICAgICA8c2FtbDI6QXV0aG5Db250ZXh0PgogICAgICAgICAgICAgICAgPHNhbWwyOkF1dGhuQ29udGV4dENsYXNzUmVmPnVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphYzpjbGFzc2VzOlBhc3N3b3JkUHJvdGVjdGVkVHJhbnNwb3J0PC9zYW1sMjpBdXRobkNvbnRleHRDbGFzc1JlZj4KICAgICAgICAgICAgPC9zYW1sMjpBdXRobkNvbnRleHQ+CiAgICAgICAgPC9zYW1sMjpBdXRoblN0YXRlbWVudD4KICAgICAgICA8c2FtbDI6QXR0cmlidXRlU3RhdGVtZW50IHhtbG5zOnNhbWwyPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIj4KICAgICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZSBOYW1lPSJnaXZlbk5hbWUiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgTmFtZUZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmF0dHJuYW1lLWZvcm1hdDp1bnNwZWNpZmllZCI+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlVmFsdWUgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEtaW5zdGFuY2UiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeHNpOnR5cGU9InhzOnN0cmluZyI+Rmlyc3Q8L3NhbWwyOkF0dHJpYnV0ZVZhbHVlPgogICAgICAgICAgICA8L3NhbWwyOkF0dHJpYnV0ZT4KICAgICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZSBOYW1lPSJzbiIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICBOYW1lRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXR0cm5hbWUtZm9ybWF0OnVuc3BlY2lmaWVkIj4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVWYWx1ZSB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4c2k6dHlwZT0ieHM6c3RyaW5nIj5MYXN0PC9zYW1sMjpBdHRyaWJ1dGVWYWx1ZT4KICAgICAgICAgICAgPC9zYW1sMjpBdHRyaWJ1dGU+CiAgICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGUgTmFtZT0iZ3JvdXAiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgTmFtZUZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmF0dHJuYW1lLWZvcm1hdDp1bnNwZWNpZmllZCI+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlVmFsdWUgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEtaW5zdGFuY2UiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeHNpOnR5cGU9InhzOnN0cmluZyI+cmVkPC9zYW1sMjpBdHRyaWJ1dGVWYWx1ZT4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVWYWx1ZSB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4c2k6dHlwZT0ieHM6c3RyaW5nIj5ncmVlbjwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlVmFsdWUgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEtaW5zdGFuY2UiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeHNpOnR5cGU9InhzOnN0cmluZyI+Ymx1ZTwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAgICAgIDwvc2FtbDI6QXR0cmlidXRlPgogICAgICAgIDwvc2FtbDI6QXR0cmlidXRlU3RhdGVtZW50PgogICAgPC9zYW1sMjpBc3NlcnRpb24+Cjwvc2FtbDJwOlJlc3BvbnNlPgo= ================================================ FILE: providertests/testdata/onelogin/olgn09_response_86.b64 ================================================ PHNhbWwycDpSZXNwb25zZSB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpwcm90b2NvbCIKICAgICAgICAgICAgICAgICBEZXN0aW5hdGlvbj0iaHR0cHM6Ly9zYW1sLnNwLm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9hY3MvaW5jb3JyZWN0IgogICAgICAgICAgICAgICAgIElEPSJpZDcwOTM4Mjk1Mzc1MDIyNTcyMTQyODc1NDY5IgogICAgICAgICAgICAgICAgIEluUmVzcG9uc2VUbz0iaWQtNTMxYjJiZjAyYWUwYTU4OGMzMDIzNDE2M2FkYmZkOWQ2YmJmMDc0NyIKICAgICAgICAgICAgICAgICBJc3N1ZUluc3RhbnQ9IjIwMTctMDgtMzBUMjM6MTQ6NDEuMzc5WiIKICAgICAgICAgICAgICAgICBWZXJzaW9uPSIyLjAiPgogICAgPHNhbWwyOklzc3VlciB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiIKICAgICAgICAgICAgICAgICAgRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6bmFtZWlkLWZvcm1hdDplbnRpdHkiPmh0dHBzOi8vc2FtbC5pZHAubm9wZS9oOWdranp2YjNlPC9zYW1sMjpJc3N1ZXI+CiAgICA8c2FtbDJwOlN0YXR1cyB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpwcm90b2NvbCI+CiAgICAgICAgPHNhbWwycDpTdGF0dXNDb2RlIFZhbHVlPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6c3RhdHVzOlN1Y2Nlc3MiLz4KICAgIDwvc2FtbDJwOlN0YXR1cz4KICAgIDxzYW1sMjpBc3NlcnRpb24geG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iCiAgICAgICAgICAgICAgICAgICAgIElEPSJpZDcwOTM4Mjk1Mzc1NDY3NjcxMzE4Mzg3NzIwIgogICAgICAgICAgICAgICAgICAgICBJc3N1ZUluc3RhbnQ9IjIwMTctMDgtMzBUMjM6MTQ6NDEuMzc5WiIKICAgICAgICAgICAgICAgICAgICAgVmVyc2lvbj0iMi4wIgogICAgICAgICAgICAgICAgICAgICB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiPgogICAgICAgIDxzYW1sMjpJc3N1ZXIgRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6bmFtZWlkLWZvcm1hdDplbnRpdHkiCiAgICAgICAgICAgICAgICAgICAgICB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiI+aHR0cHM6Ly9zYW1sLmlkcC5ub3BlL2g5Z2tqenZiM2U8L3NhbWwyOklzc3Vlcj4KICAgICAgICA8c2FtbDI6U3ViamVjdCB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiI+CiAgICAgICAgICAgIDxzYW1sMjpOYW1lSUQgRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoxLjE6bmFtZWlkLWZvcm1hdDplbWFpbEFkZHJlc3MiPnVzZXJAc2FtbC5zcC5ub3BlPC9zYW1sMjpOYW1lSUQ+CiAgICAgICAgICAgIDxzYW1sMjpTdWJqZWN0Q29uZmlybWF0aW9uIE1ldGhvZD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmNtOmJlYXJlciI+CiAgICAgICAgICAgICAgICA8c2FtbDI6U3ViamVjdENvbmZpcm1hdGlvbkRhdGEgSW5SZXNwb25zZVRvPSJpZC01MzFiMmJmMDJhZTBhNTg4YzMwMjM0MTYzYWRiZmQ5ZDZiYmYwNzQ3IgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5vdE9uT3JBZnRlcj0iMjAxNy0wOC0zMFQyMzoxOTo0MS4zNzlaIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFJlY2lwaWVudD0iaHR0cHM6Ly9zYW1sLnNwLm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9hY3MvcnE1andrdmI4eiIvPgogICAgICAgICAgICA8L3NhbWwyOlN1YmplY3RDb25maXJtYXRpb24+CiAgICAgICAgPC9zYW1sMjpTdWJqZWN0PgogICAgICAgIDxzYW1sMjpDb25kaXRpb25zIE5vdEJlZm9yZT0iMjAxNy0wOC0zMFQyMzowOTo0MS4zNzlaIgogICAgICAgICAgICAgICAgICAgICAgICAgIE5vdE9uT3JBZnRlcj0iMjAxNy0wOC0zMFQyMzoxOTo0MS4zNzlaIgogICAgICAgICAgICAgICAgICAgICAgICAgIHhtbG5zOnNhbWwyPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIj4KICAgICAgICAgICAgPHNhbWwyOkF1ZGllbmNlUmVzdHJpY3Rpb24+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXVkaWVuY2U+aHR0cHM6Ly9zYW1sLnNwLm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9zcGVudGl0eWlkL3JxNWp3a3ZiOHo8L3NhbWwyOkF1ZGllbmNlPgogICAgICAgICAgICA8L3NhbWwyOkF1ZGllbmNlUmVzdHJpY3Rpb24+CiAgICAgICAgPC9zYW1sMjpDb25kaXRpb25zPgogICAgICAgIDxzYW1sMjpBdXRoblN0YXRlbWVudCBBdXRobkluc3RhbnQ9IjIwMTctMDgtMzBUMjM6MTQ6NDEuMzc5WiIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgU2Vzc2lvbkluZGV4PSJpZC01MzFiMmJmMDJhZTBhNTg4YzMwMjM0MTYzYWRiZmQ5ZDZiYmYwNzQ3IgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiI+CiAgICAgICAgICAgIDxzYW1sMjpBdXRobkNvbnRleHQ+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXV0aG5Db250ZXh0Q2xhc3NSZWY+dXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFjOmNsYXNzZXM6UGFzc3dvcmRQcm90ZWN0ZWRUcmFuc3BvcnQ8L3NhbWwyOkF1dGhuQ29udGV4dENsYXNzUmVmPgogICAgICAgICAgICA8L3NhbWwyOkF1dGhuQ29udGV4dD4KICAgICAgICA8L3NhbWwyOkF1dGhuU3RhdGVtZW50PgogICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVTdGF0ZW1lbnQgeG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPgogICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlIE5hbWU9ImdpdmVuTmFtZSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICBOYW1lRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXR0cm5hbWUtZm9ybWF0OnVuc3BlY2lmaWVkIj4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVWYWx1ZSB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4c2k6dHlwZT0ieHM6c3RyaW5nIj5GaXJzdDwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAgICAgIDwvc2FtbDI6QXR0cmlidXRlPgogICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlIE5hbWU9InNuIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5hbWVGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphdHRybmFtZS1mb3JtYXQ6dW5zcGVjaWZpZWQiPgogICAgICAgICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhzaTp0eXBlPSJ4czpzdHJpbmciPkxhc3Q8L3NhbWwyOkF0dHJpYnV0ZVZhbHVlPgogICAgICAgICAgICA8L3NhbWwyOkF0dHJpYnV0ZT4KICAgICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZSBOYW1lPSJncm91cCIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICBOYW1lRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXR0cm5hbWUtZm9ybWF0OnVuc3BlY2lmaWVkIj4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVWYWx1ZSB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4c2k6dHlwZT0ieHM6c3RyaW5nIj5yZWQ8L3NhbWwyOkF0dHJpYnV0ZVZhbHVlPgogICAgICAgICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhzaTp0eXBlPSJ4czpzdHJpbmciPmdyZWVuPC9zYW1sMjpBdHRyaWJ1dGVWYWx1ZT4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVWYWx1ZSB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4c2k6dHlwZT0ieHM6c3RyaW5nIj5ibHVlPC9zYW1sMjpBdHRyaWJ1dGVWYWx1ZT4KICAgICAgICAgICAgPC9zYW1sMjpBdHRyaWJ1dGU+CiAgICAgICAgPC9zYW1sMjpBdHRyaWJ1dGVTdGF0ZW1lbnQ+CiAgICA8L3NhbWwyOkFzc2VydGlvbj4KPC9zYW1sMnA6UmVzcG9uc2U+Cg== ================================================ FILE: providertests/testdata/onelogin/olgn09_response_87.b64 ================================================ PHNhbWwycDpSZXNwb25zZSB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpwcm90b2NvbCIKICAgICAgICAgICAgICAgICBEZXN0aW5hdGlvbj0iaHR0cHM6Ly9zYW1sLnNwLm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9hY3MvcnE1andrdmI4eiIKICAgICAgICAgICAgICAgICBJRD0iaWQ3MDkzODI5NTM3NTAyMjU3MjE0Mjg3NTQ2OSIKICAgICAgICAgICAgICAgICBJblJlc3BvbnNlVG89ImlkLTUzMWIyYmYwMmFlMGE1ODhjMzAyMzQxNjNhZGJmZDlkNmJiZjA3NDciCiAgICAgICAgICAgICAgICAgSXNzdWVJbnN0YW50PSIyMDE3LTA4LTMwVDIzOjE0OjQxLjM3OVoiCiAgICAgICAgICAgICAgICAgVmVyc2lvbj0iMi4wIj4KICAgIDxzYW1sMjpJc3N1ZXIgeG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iCiAgICAgICAgICAgICAgICAgIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOm5hbWVpZC1mb3JtYXQ6ZW50aXR5Ij5odHRwczovL3NhbWwuaWRwLm5vcGUvaW5jb3JyZWN0PC9zYW1sMjpJc3N1ZXI+CiAgICA8c2FtbDJwOlN0YXR1cyB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpwcm90b2NvbCI+CiAgICAgICAgPHNhbWwycDpTdGF0dXNDb2RlIFZhbHVlPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6c3RhdHVzOlN1Y2Nlc3MiLz4KICAgIDwvc2FtbDJwOlN0YXR1cz4KICAgIDxzYW1sMjpBc3NlcnRpb24geG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iCiAgICAgICAgICAgICAgICAgICAgIElEPSJpZDcwOTM4Mjk1Mzc1NDY3NjcxMzE4Mzg3NzIwIgogICAgICAgICAgICAgICAgICAgICBJc3N1ZUluc3RhbnQ9IjIwMTctMDgtMzBUMjM6MTQ6NDEuMzc5WiIKICAgICAgICAgICAgICAgICAgICAgVmVyc2lvbj0iMi4wIgogICAgICAgICAgICAgICAgICAgICB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiPgogICAgICAgIDxzYW1sMjpJc3N1ZXIgRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6bmFtZWlkLWZvcm1hdDplbnRpdHkiCiAgICAgICAgICAgICAgICAgICAgICB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiI+aHR0cHM6Ly9zYW1sLmlkcC5ub3BlL2g5Z2tqenZiM2U8L3NhbWwyOklzc3Vlcj4KICAgICAgICA8c2FtbDI6U3ViamVjdCB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiI+CiAgICAgICAgICAgIDxzYW1sMjpOYW1lSUQgRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoxLjE6bmFtZWlkLWZvcm1hdDplbWFpbEFkZHJlc3MiPnVzZXJAc2FtbC5zcC5ub3BlPC9zYW1sMjpOYW1lSUQ+CiAgICAgICAgICAgIDxzYW1sMjpTdWJqZWN0Q29uZmlybWF0aW9uIE1ldGhvZD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmNtOmJlYXJlciI+CiAgICAgICAgICAgICAgICA8c2FtbDI6U3ViamVjdENvbmZpcm1hdGlvbkRhdGEgSW5SZXNwb25zZVRvPSJpZC01MzFiMmJmMDJhZTBhNTg4YzMwMjM0MTYzYWRiZmQ5ZDZiYmYwNzQ3IgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5vdE9uT3JBZnRlcj0iMjAxNy0wOC0zMFQyMzoxOTo0MS4zNzlaIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFJlY2lwaWVudD0iaHR0cHM6Ly9zYW1sLnNwLm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9hY3MvcnE1andrdmI4eiIvPgogICAgICAgICAgICA8L3NhbWwyOlN1YmplY3RDb25maXJtYXRpb24+CiAgICAgICAgPC9zYW1sMjpTdWJqZWN0PgogICAgICAgIDxzYW1sMjpDb25kaXRpb25zIE5vdEJlZm9yZT0iMjAxNy0wOC0zMFQyMzowOTo0MS4zNzlaIgogICAgICAgICAgICAgICAgICAgICAgICAgIE5vdE9uT3JBZnRlcj0iMjAxNy0wOC0zMFQyMzoxOTo0MS4zNzlaIgogICAgICAgICAgICAgICAgICAgICAgICAgIHhtbG5zOnNhbWwyPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIj4KICAgICAgICAgICAgPHNhbWwyOkF1ZGllbmNlUmVzdHJpY3Rpb24+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXVkaWVuY2U+aHR0cHM6Ly9zYW1sLnNwLm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9zcGVudGl0eWlkL3JxNWp3a3ZiOHo8L3NhbWwyOkF1ZGllbmNlPgogICAgICAgICAgICA8L3NhbWwyOkF1ZGllbmNlUmVzdHJpY3Rpb24+CiAgICAgICAgPC9zYW1sMjpDb25kaXRpb25zPgogICAgICAgIDxzYW1sMjpBdXRoblN0YXRlbWVudCBBdXRobkluc3RhbnQ9IjIwMTctMDgtMzBUMjM6MTQ6NDEuMzc5WiIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgU2Vzc2lvbkluZGV4PSJpZC01MzFiMmJmMDJhZTBhNTg4YzMwMjM0MTYzYWRiZmQ5ZDZiYmYwNzQ3IgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiI+CiAgICAgICAgICAgIDxzYW1sMjpBdXRobkNvbnRleHQ+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXV0aG5Db250ZXh0Q2xhc3NSZWY+dXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFjOmNsYXNzZXM6UGFzc3dvcmRQcm90ZWN0ZWRUcmFuc3BvcnQ8L3NhbWwyOkF1dGhuQ29udGV4dENsYXNzUmVmPgogICAgICAgICAgICA8L3NhbWwyOkF1dGhuQ29udGV4dD4KICAgICAgICA8L3NhbWwyOkF1dGhuU3RhdGVtZW50PgogICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVTdGF0ZW1lbnQgeG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPgogICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlIE5hbWU9ImdpdmVuTmFtZSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICBOYW1lRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXR0cm5hbWUtZm9ybWF0OnVuc3BlY2lmaWVkIj4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVWYWx1ZSB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4c2k6dHlwZT0ieHM6c3RyaW5nIj5GaXJzdDwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAgICAgIDwvc2FtbDI6QXR0cmlidXRlPgogICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlIE5hbWU9InNuIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5hbWVGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphdHRybmFtZS1mb3JtYXQ6dW5zcGVjaWZpZWQiPgogICAgICAgICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhzaTp0eXBlPSJ4czpzdHJpbmciPkxhc3Q8L3NhbWwyOkF0dHJpYnV0ZVZhbHVlPgogICAgICAgICAgICA8L3NhbWwyOkF0dHJpYnV0ZT4KICAgICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZSBOYW1lPSJncm91cCIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICBOYW1lRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXR0cm5hbWUtZm9ybWF0OnVuc3BlY2lmaWVkIj4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVWYWx1ZSB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4c2k6dHlwZT0ieHM6c3RyaW5nIj5yZWQ8L3NhbWwyOkF0dHJpYnV0ZVZhbHVlPgogICAgICAgICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhzaTp0eXBlPSJ4czpzdHJpbmciPmdyZWVuPC9zYW1sMjpBdHRyaWJ1dGVWYWx1ZT4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVWYWx1ZSB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4c2k6dHlwZT0ieHM6c3RyaW5nIj5ibHVlPC9zYW1sMjpBdHRyaWJ1dGVWYWx1ZT4KICAgICAgICAgICAgPC9zYW1sMjpBdHRyaWJ1dGU+CiAgICAgICAgPC9zYW1sMjpBdHRyaWJ1dGVTdGF0ZW1lbnQ+CiAgICA8L3NhbWwyOkFzc2VydGlvbj4KPC9zYW1sMnA6UmVzcG9uc2U+Cg== ================================================ FILE: providertests/testdata/onelogin/olgn09_response_88.b64 ================================================ PHNhbWwycDpSZXNwb25zZSB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpwcm90b2NvbCIKICAgICAgICAgICAgICAgICBEZXN0aW5hdGlvbj0iaHR0cHM6Ly9zYW1sLnNwLm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9hY3MvcnE1andrdmI4eiIKICAgICAgICAgICAgICAgICBJRD0iaWQ3MDkzODI5NTM3NTAyMjU3MjE0Mjg3NTQ2OSIKICAgICAgICAgICAgICAgICBJblJlc3BvbnNlVG89ImlkLTUzMWIyYmYwMmFlMGE1ODhjMzAyMzQxNjNhZGJmZDlkNmJiZjA3NDciCiAgICAgICAgICAgICAgICAgSXNzdWVJbnN0YW50PSIyMDE3LTA4LTMwVDIzOjE0OjQxLjM3OVoiCiAgICAgICAgICAgICAgICAgVmVyc2lvbj0iMi4wIj4KICAgIDxzYW1sMjpJc3N1ZXIgeG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iCiAgICAgICAgICAgICAgICAgIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOm5hbWVpZC1mb3JtYXQ6ZW50aXR5Ij5odHRwczovL3NhbWwuaWRwLm5vcGUvaDlna2p6dmIzZTwvc2FtbDI6SXNzdWVyPgogICAgPHNhbWwycDpTdGF0dXMgeG1sbnM6c2FtbDJwPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiPgogICAgICAgIDxzYW1sMnA6U3RhdHVzQ29kZSBWYWx1ZT0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOnN0YXR1czpTdWNjZXNzIi8+CiAgICA8L3NhbWwycDpTdGF0dXM+CiAgICA8c2FtbDI6QXNzZXJ0aW9uIHhtbG5zOnNhbWwyPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIgogICAgICAgICAgICAgICAgICAgICBJRD0iaWQ3MDkzODI5NTM3NTQ2NzY3MTMxODM4NzcyMCIKICAgICAgICAgICAgICAgICAgICAgSXNzdWVJbnN0YW50PSIyMDE3LTA4LTMwVDIzOjE0OjQxLjM3OVoiCiAgICAgICAgICAgICAgICAgICAgIFZlcnNpb249IjIuMCIKICAgICAgICAgICAgICAgICAgICAgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIj4KICAgICAgICA8c2FtbDI6SXNzdWVyIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOm5hbWVpZC1mb3JtYXQ6ZW50aXR5IgogICAgICAgICAgICAgICAgICAgICAgeG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPmh0dHBzOi8vc2FtbC5pZHAubm9wZS9oOWdranp2YjNlPC9zYW1sMjpJc3N1ZXI+CiAgICAgICAgPHNhbWwyOlN1YmplY3QgeG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPgogICAgICAgICAgICA8c2FtbDI6TmFtZUlEIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6MS4xOm5hbWVpZC1mb3JtYXQ6ZW1haWxBZGRyZXNzIj51c2VyQHNhbWwuc3Aubm9wZTwvc2FtbDI6TmFtZUlEPgogICAgICAgICAgICA8c2FtbDI6U3ViamVjdENvbmZpcm1hdGlvbiBNZXRob2Q9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpjbTpiZWFyZXIiPgogICAgICAgICAgICAgICAgPHNhbWwyOlN1YmplY3RDb25maXJtYXRpb25EYXRhIEluUmVzcG9uc2VUbz0iaWQtNTMxYjJiZjAyYWUwYTU4OGMzMDIzNDE2M2FkYmZkOWQ2YmJmMDc0NyIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBOb3RPbk9yQWZ0ZXI9IjIwMTctMDgtMzBUMjM6MTk6NDEuMzc5WiIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBSZWNpcGllbnQ9Imh0dHBzOi8vc2FtbC5zcC5ub3BlL3Nlc3Npb24vc3NvL3NhbWwvYWNzL3JxNWp3a3ZiOHoiLz4KICAgICAgICAgICAgPC9zYW1sMjpTdWJqZWN0Q29uZmlybWF0aW9uPgogICAgICAgIDwvc2FtbDI6U3ViamVjdD4KICAgICAgICA8c2FtbDI6Q29uZGl0aW9ucyBOb3RCZWZvcmU9IjIwMTctMDgtMzBUMjM6MDk6NDEuMzc5WiIKICAgICAgICAgICAgICAgICAgICAgICAgICBOb3RPbk9yQWZ0ZXI9IjIwMTctMDgtMzBUMjM6MTk6NDEuMzc5WiIKICAgICAgICAgICAgICAgICAgICAgICAgICB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiI+CiAgICAgICAgICAgIDxzYW1sMjpBdWRpZW5jZVJlc3RyaWN0aW9uPgogICAgICAgICAgICAgICAgPHNhbWwyOkF1ZGllbmNlPmh0dHBzOi8vc2FtbC5zcC5ub3BlL3Nlc3Npb24vc3NvL3NhbWwvc3BlbnRpdHlpZC9pbmNvcnJlY3Q8L3NhbWwyOkF1ZGllbmNlPgogICAgICAgICAgICA8L3NhbWwyOkF1ZGllbmNlUmVzdHJpY3Rpb24+CiAgICAgICAgPC9zYW1sMjpDb25kaXRpb25zPgogICAgICAgIDxzYW1sMjpBdXRoblN0YXRlbWVudCBBdXRobkluc3RhbnQ9IjIwMTctMDgtMzBUMjM6MTQ6NDEuMzc5WiIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgU2Vzc2lvbkluZGV4PSJpZC01MzFiMmJmMDJhZTBhNTg4YzMwMjM0MTYzYWRiZmQ5ZDZiYmYwNzQ3IgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiI+CiAgICAgICAgICAgIDxzYW1sMjpBdXRobkNvbnRleHQ+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXV0aG5Db250ZXh0Q2xhc3NSZWY+dXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFjOmNsYXNzZXM6UGFzc3dvcmRQcm90ZWN0ZWRUcmFuc3BvcnQ8L3NhbWwyOkF1dGhuQ29udGV4dENsYXNzUmVmPgogICAgICAgICAgICA8L3NhbWwyOkF1dGhuQ29udGV4dD4KICAgICAgICA8L3NhbWwyOkF1dGhuU3RhdGVtZW50PgogICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVTdGF0ZW1lbnQgeG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPgogICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlIE5hbWU9ImdpdmVuTmFtZSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICBOYW1lRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXR0cm5hbWUtZm9ybWF0OnVuc3BlY2lmaWVkIj4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVWYWx1ZSB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4c2k6dHlwZT0ieHM6c3RyaW5nIj5GaXJzdDwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAgICAgIDwvc2FtbDI6QXR0cmlidXRlPgogICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlIE5hbWU9InNuIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5hbWVGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphdHRybmFtZS1mb3JtYXQ6dW5zcGVjaWZpZWQiPgogICAgICAgICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhzaTp0eXBlPSJ4czpzdHJpbmciPkxhc3Q8L3NhbWwyOkF0dHJpYnV0ZVZhbHVlPgogICAgICAgICAgICA8L3NhbWwyOkF0dHJpYnV0ZT4KICAgICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZSBOYW1lPSJncm91cCIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICBOYW1lRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXR0cm5hbWUtZm9ybWF0OnVuc3BlY2lmaWVkIj4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVWYWx1ZSB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4c2k6dHlwZT0ieHM6c3RyaW5nIj5yZWQ8L3NhbWwyOkF0dHJpYnV0ZVZhbHVlPgogICAgICAgICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhzaTp0eXBlPSJ4czpzdHJpbmciPmdyZWVuPC9zYW1sMjpBdHRyaWJ1dGVWYWx1ZT4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVWYWx1ZSB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4c2k6dHlwZT0ieHM6c3RyaW5nIj5ibHVlPC9zYW1sMjpBdHRyaWJ1dGVWYWx1ZT4KICAgICAgICAgICAgPC9zYW1sMjpBdHRyaWJ1dGU+CiAgICAgICAgPC9zYW1sMjpBdHRyaWJ1dGVTdGF0ZW1lbnQ+CiAgICA8L3NhbWwyOkFzc2VydGlvbj4KPC9zYW1sMnA6UmVzcG9uc2U+Cg== ================================================ FILE: providertests/testdata/onelogin/olgn09_response_89.b64 ================================================ PHNhbWwycDpSZXNwb25zZSB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpwcm90b2NvbCIKICAgICAgICAgICAgICAgICBEZXN0aW5hdGlvbj0iaHR0cHM6Ly9zYW1sLnNwLm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9hY3MvcnE1andrdmI4eiIKICAgICAgICAgICAgICAgICBJRD0iaWQ3MDkzODI5NTM3NTAyMjU3MjE0Mjg3NTQ2OSIKICAgICAgICAgICAgICAgICBJblJlc3BvbnNlVG89ImlkLTUzMWIyYmYwMmFlMGE1ODhjMzAyMzQxNjNhZGJmZDlkNmJiZjA3NDciCiAgICAgICAgICAgICAgICAgSXNzdWVJbnN0YW50PSIyMDE3LTA4LTMwVDIzOjE0OjQxLjM3OVoiCiAgICAgICAgICAgICAgICAgVmVyc2lvbj0iMi4wIj4KICAgIDxzYW1sMjpJc3N1ZXIgeG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iCiAgICAgICAgICAgICAgICAgIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOm5hbWVpZC1mb3JtYXQ6ZW50aXR5Ij5odHRwczovL3NhbWwuaWRwLm5vcGUvaDlna2p6dmIzZTwvc2FtbDI6SXNzdWVyPgogICAgPHNhbWwycDpTdGF0dXMgeG1sbnM6c2FtbDJwPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiPgogICAgICAgIDxzYW1sMnA6U3RhdHVzQ29kZSBWYWx1ZT0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOnN0YXR1czpTdWNjZXNzIi8+CiAgICA8L3NhbWwycDpTdGF0dXM+CiAgICA8c2FtbDI6QXNzZXJ0aW9uIHhtbG5zOnNhbWwyPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIgogICAgICAgICAgICAgICAgICAgICBJRD0iaWQ3MDkzODI5NTM3NTQ2NzY3MTMxODM4NzcyMCIKICAgICAgICAgICAgICAgICAgICAgSXNzdWVJbnN0YW50PSIyMDE3LTA4LTMwVDIzOjE0OjQxLjM3OVoiCiAgICAgICAgICAgICAgICAgICAgIFZlcnNpb249IjIuMCIKICAgICAgICAgICAgICAgICAgICAgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIj4KICAgICAgICA8c2FtbDI6SXNzdWVyIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOm5hbWVpZC1mb3JtYXQ6ZW50aXR5IgogICAgICAgICAgICAgICAgICAgICAgeG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPmh0dHBzOi8vc2FtbC5pZHAubm9wZS9pbmNvcnJlY3Q8L3NhbWwyOklzc3Vlcj4KICAgICAgICA8c2FtbDI6U3ViamVjdCB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiI+CiAgICAgICAgICAgIDxzYW1sMjpOYW1lSUQgRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoxLjE6bmFtZWlkLWZvcm1hdDplbWFpbEFkZHJlc3MiPnVzZXJAc2FtbC5zcC5ub3BlPC9zYW1sMjpOYW1lSUQ+CiAgICAgICAgICAgIDxzYW1sMjpTdWJqZWN0Q29uZmlybWF0aW9uIE1ldGhvZD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmNtOmJlYXJlciI+CiAgICAgICAgICAgICAgICA8c2FtbDI6U3ViamVjdENvbmZpcm1hdGlvbkRhdGEgSW5SZXNwb25zZVRvPSJpZC01MzFiMmJmMDJhZTBhNTg4YzMwMjM0MTYzYWRiZmQ5ZDZiYmYwNzQ3IgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5vdE9uT3JBZnRlcj0iMjAxNy0wOC0zMFQyMzoxOTo0MS4zNzlaIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFJlY2lwaWVudD0iaHR0cHM6Ly9zYW1sLnNwLm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9hY3MvcnE1andrdmI4eiIvPgogICAgICAgICAgICA8L3NhbWwyOlN1YmplY3RDb25maXJtYXRpb24+CiAgICAgICAgPC9zYW1sMjpTdWJqZWN0PgogICAgICAgIDxzYW1sMjpDb25kaXRpb25zIE5vdEJlZm9yZT0iMjAxNy0wOC0zMFQyMzowOTo0MS4zNzlaIgogICAgICAgICAgICAgICAgICAgICAgICAgIE5vdE9uT3JBZnRlcj0iMjAxNy0wOC0zMFQyMzoxOTo0MS4zNzlaIgogICAgICAgICAgICAgICAgICAgICAgICAgIHhtbG5zOnNhbWwyPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIj4KICAgICAgICAgICAgPHNhbWwyOkF1ZGllbmNlUmVzdHJpY3Rpb24+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXVkaWVuY2U+aHR0cHM6Ly9zYW1sLnNwLm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9zcGVudGl0eWlkL3JxNWp3a3ZiOHo8L3NhbWwyOkF1ZGllbmNlPgogICAgICAgICAgICA8L3NhbWwyOkF1ZGllbmNlUmVzdHJpY3Rpb24+CiAgICAgICAgPC9zYW1sMjpDb25kaXRpb25zPgogICAgICAgIDxzYW1sMjpBdXRoblN0YXRlbWVudCBBdXRobkluc3RhbnQ9IjIwMTctMDgtMzBUMjM6MTQ6NDEuMzc5WiIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgU2Vzc2lvbkluZGV4PSJpZC01MzFiMmJmMDJhZTBhNTg4YzMwMjM0MTYzYWRiZmQ5ZDZiYmYwNzQ3IgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiI+CiAgICAgICAgICAgIDxzYW1sMjpBdXRobkNvbnRleHQ+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXV0aG5Db250ZXh0Q2xhc3NSZWY+dXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFjOmNsYXNzZXM6UGFzc3dvcmRQcm90ZWN0ZWRUcmFuc3BvcnQ8L3NhbWwyOkF1dGhuQ29udGV4dENsYXNzUmVmPgogICAgICAgICAgICA8L3NhbWwyOkF1dGhuQ29udGV4dD4KICAgICAgICA8L3NhbWwyOkF1dGhuU3RhdGVtZW50PgogICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVTdGF0ZW1lbnQgeG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPgogICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlIE5hbWU9ImdpdmVuTmFtZSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICBOYW1lRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXR0cm5hbWUtZm9ybWF0OnVuc3BlY2lmaWVkIj4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVWYWx1ZSB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4c2k6dHlwZT0ieHM6c3RyaW5nIj5GaXJzdDwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAgICAgIDwvc2FtbDI6QXR0cmlidXRlPgogICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlIE5hbWU9InNuIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5hbWVGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphdHRybmFtZS1mb3JtYXQ6dW5zcGVjaWZpZWQiPgogICAgICAgICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhzaTp0eXBlPSJ4czpzdHJpbmciPkxhc3Q8L3NhbWwyOkF0dHJpYnV0ZVZhbHVlPgogICAgICAgICAgICA8L3NhbWwyOkF0dHJpYnV0ZT4KICAgICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZSBOYW1lPSJncm91cCIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICBOYW1lRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXR0cm5hbWUtZm9ybWF0OnVuc3BlY2lmaWVkIj4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVWYWx1ZSB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4c2k6dHlwZT0ieHM6c3RyaW5nIj5yZWQ8L3NhbWwyOkF0dHJpYnV0ZVZhbHVlPgogICAgICAgICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhzaTp0eXBlPSJ4czpzdHJpbmciPmdyZWVuPC9zYW1sMjpBdHRyaWJ1dGVWYWx1ZT4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGVWYWx1ZSB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4c2k6dHlwZT0ieHM6c3RyaW5nIj5ibHVlPC9zYW1sMjpBdHRyaWJ1dGVWYWx1ZT4KICAgICAgICAgICAgPC9zYW1sMjpBdHRyaWJ1dGU+CiAgICAgICAgPC9zYW1sMjpBdHRyaWJ1dGVTdGF0ZW1lbnQ+CiAgICA8L3NhbWwyOkFzc2VydGlvbj4KPC9zYW1sMnA6UmVzcG9uc2U+Cg== ================================================ FILE: providertests/testdata/onelogin/olgn09_response_91.b64 ================================================ PHNhbWwycDpSZXNwb25zZSB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIu MDpwcm90b2NvbCIKICAgICAgICAgICAgICAgICBEZXN0aW5hdGlvbj0iaHR0cHM6Ly9zYW1sLnNw Lm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9hY3MvcnE1andrdmI4eiIKICAgICAgICAgICAgICAgICBJ RD0iaWQ3MDkzODI5NTM3NTAyMjU3MjE0Mjg3NTQ2OSIKICAgICAgICAgICAgICAgICBJblJlc3Bv bnNlVG89ImlkLTUzMWIyYmYwMmFlMGE1ODhjMzAyMzQxNjNhZGJmZDlkNmJiZjA3NDciCiAgICAg ICAgICAgICAgICAgSXNzdWVJbnN0YW50PSIyMDE3LTA4LTA4VDAxOjA1OjAwWiIKICAgICAgICAg ICAgICAgICBWZXJzaW9uPSIyLjAiPgogICAgPHNhbWwyOklzc3VlciB4bWxuczpzYW1sMj0idXJu Om9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiIKICAgICAgICAgICAgICAgICAgRm9y bWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6bmFtZWlkLWZvcm1hdDplbnRpdHkiPmh0 dHBzOi8vc2FtbC5pZHAubm9wZS9oOWdranp2YjNlPC9zYW1sMjpJc3N1ZXI+CiAgICA8c2FtbDJw OlN0YXR1cyB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpwcm90b2Nv bCI+CiAgICAgICAgPHNhbWwycDpTdGF0dXNDb2RlIFZhbHVlPSJ1cm46b2FzaXM6bmFtZXM6dGM6 U0FNTDoyLjA6c3RhdHVzOlN1Y2Nlc3MiLz4KICAgIDwvc2FtbDJwOlN0YXR1cz4KICAgIDxzYW1s MjpBc3NlcnRpb24geG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3Nl cnRpb24iCiAgICAgICAgICAgICAgICAgICAgIElEPSJpZDcwOTM4Mjk1Mzc1NDY3NjcxMzE4Mzg3 NzIwIgogICAgICAgICAgICAgICAgICAgICBJc3N1ZUluc3RhbnQ9IjIwMTctMDgtMDhUMDE6MDU6 MDBaIgogICAgICAgICAgICAgICAgICAgICBWZXJzaW9uPSIyLjAiCiAgICAgICAgICAgICAgICAg ICAgIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSI+CiAgICAgICAg PHNhbWwyOklzc3VlciBGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpuYW1laWQt Zm9ybWF0OmVudGl0eSIKICAgICAgICAgICAgICAgICAgICAgIHhtbG5zOnNhbWwyPSJ1cm46b2Fz aXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIj5odHRwczovL3NhbWwuaWRwLm5vcGUvaDln a2p6dmIzZTwvc2FtbDI6SXNzdWVyPgogICAgICAgIDxzYW1sMjpTdWJqZWN0IHhtbG5zOnNhbWwy PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIj4KICAgICAgICAgICAgPHNh bWwyOk5hbWVJRCBGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjEuMTpuYW1laWQtZm9y bWF0OmVtYWlsQWRkcmVzcyI+dXNlckBzYW1sLnNwLm5vcGU8L3NhbWwyOk5hbWVJRD4KICAgICAg ICAgICAgPHNhbWwyOlN1YmplY3RDb25maXJtYXRpb24gTWV0aG9kPSJ1cm46b2FzaXM6bmFtZXM6 dGM6U0FNTDoyLjA6Y206YmVhcmVyIj4KICAgICAgICAgICAgICAgIDxzYW1sMjpTdWJqZWN0Q29u ZmlybWF0aW9uRGF0YSBJblJlc3BvbnNlVG89ImlkLTUzMWIyYmYwMmFlMGE1ODhjMzAyMzQxNjNh ZGJmZDlkNmJiZjA3NDciCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgTm90T25PckFmdGVyPSIyMDE3LTA4LTA4VDAxOjEwOjAwWiIKICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBSZWNpcGllbnQ9Imh0dHBzOi8vc2FtbC5z cC5ub3BlL3Nlc3Npb24vc3NvL3NhbWwvYWNzL3JxNWp3a3ZiOHoiLz4KICAgICAgICAgICAgPC9z YW1sMjpTdWJqZWN0Q29uZmlybWF0aW9uPgogICAgICAgIDwvc2FtbDI6U3ViamVjdD4KICAgICAg ICA8c2FtbDI6Q29uZGl0aW9ucyBOb3RCZWZvcmU9IjIwMTctMDgtMDhUMDE6MDA6MDBaIgogICAg ICAgICAgICAgICAgICAgICAgICAgIE5vdE9uT3JBZnRlcj0iMjAxNy0wOC0wOFQwMToxMDowMFoi CiAgICAgICAgICAgICAgICAgICAgICAgICAgeG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0 YzpTQU1MOjIuMDphc3NlcnRpb24iPgogICAgICAgICAgICA8c2FtbDI6QXVkaWVuY2VSZXN0cmlj dGlvbj4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdWRpZW5jZT5odHRwczovL3NhbWwuc3Aubm9w ZS9zZXNzaW9uL3Nzby9zYW1sL3NwZW50aXR5aWQvcnE1andrdmI4ejwvc2FtbDI6QXVkaWVuY2U+ CiAgICAgICAgICAgIDwvc2FtbDI6QXVkaWVuY2VSZXN0cmljdGlvbj4KICAgICAgICA8L3NhbWwy OkNvbmRpdGlvbnM+CiAgICAgICAgPHNhbWwyOkF1dGhuU3RhdGVtZW50IEF1dGhuSW5zdGFudD0i MjAxNy0wOC0zMFQyMzoxNDo0MS4zNzlaIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICBT ZXNzaW9uSW5kZXg9ImlkLTUzMWIyYmYwMmFlMGE1ODhjMzAyMzQxNjNhZGJmZDlkNmJiZjA3NDci CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhtbG5zOnNhbWwyPSJ1cm46b2FzaXM6bmFt ZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIj4KICAgICAgICAgICAgPHNhbWwyOkF1dGhuQ29udGV4 dD4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdXRobkNvbnRleHRDbGFzc1JlZj51cm46b2FzaXM6 bmFtZXM6dGM6U0FNTDoyLjA6YWM6Y2xhc3NlczpQYXNzd29yZFByb3RlY3RlZFRyYW5zcG9ydDwv c2FtbDI6QXV0aG5Db250ZXh0Q2xhc3NSZWY+CiAgICAgICAgICAgIDwvc2FtbDI6QXV0aG5Db250 ZXh0PgogICAgICAgIDwvc2FtbDI6QXV0aG5TdGF0ZW1lbnQ+CiAgICAgICAgPHNhbWwyOkF0dHJp YnV0ZVN0YXRlbWVudCB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFz c2VydGlvbiI+CiAgICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGUgTmFtZT0iZ2l2ZW5OYW1lIgog ICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5hbWVGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0 YzpTQU1MOjIuMDphdHRybmFtZS1mb3JtYXQ6dW5zcGVjaWZpZWQiPgogICAgICAgICAgICAgICAg PHNhbWwyOkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hN TFNjaGVtYSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4bWxuczp4c2k9 Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIgogICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgIHhzaTp0eXBlPSJ4czpzdHJpbmciPkZpcnN0PC9zYW1s MjpBdHRyaWJ1dGVWYWx1ZT4KICAgICAgICAgICAgPC9zYW1sMjpBdHRyaWJ1dGU+CiAgICAgICAg ICAgIDxzYW1sMjpBdHRyaWJ1dGUgTmFtZT0ic24iCiAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgTmFtZUZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmF0dHJuYW1lLWZvcm1h dDp1bnNwZWNpZmllZCI+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlVmFsdWUgeG1s bnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIgogICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9Y TUxTY2hlbWEtaW5zdGFuY2UiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg eHNpOnR5cGU9InhzOnN0cmluZyI+TGFzdDwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAg ICAgIDwvc2FtbDI6QXR0cmlidXRlPgogICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlIE5hbWU9 Imdyb3VwIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5hbWVGb3JtYXQ9InVybjpvYXNp czpuYW1lczp0YzpTQU1MOjIuMDphdHRybmFtZS1mb3JtYXQ6dW5zcGVjaWZpZWQiPgogICAgICAg ICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9y Zy8yMDAxL1hNTFNjaGVtYSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4 bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIgogICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhzaTp0eXBlPSJ4czpzdHJpbmciPnJl ZDwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRl VmFsdWUgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIgogICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5v cmcvMjAwMS9YTUxTY2hlbWEtaW5zdGFuY2UiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgeHNpOnR5cGU9InhzOnN0cmluZyI+Z3JlZW48L3NhbWwyOkF0dHJpYnV0ZVZhbHVl PgogICAgICAgICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8v d3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3Rh bmNlIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhzaTp0eXBlPSJ4czpz dHJpbmciPmJsdWU8L3NhbWwyOkF0dHJpYnV0ZVZhbHVlPgogICAgICAgICAgICA8L3NhbWwyOkF0 dHJpYnV0ZT4KICAgICAgICA8L3NhbWwyOkF0dHJpYnV0ZVN0YXRlbWVudD4KICAgIDwvc2FtbDI6 QXNzZXJ0aW9uPgo8L3NhbWwycDpSZXNwb25zZT4K ================================================ FILE: providertests/testdata/onelogin/olgn09_response_92.b64 ================================================ PHNhbWwycDpSZXNwb25zZSB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIu MDpwcm90b2NvbCIKICAgICAgICAgICAgICAgICBEZXN0aW5hdGlvbj0iaHR0cHM6Ly9zYW1sLnNw Lm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9hY3MvcnE1andrdmI4eiIKICAgICAgICAgICAgICAgICBJ RD0iaWQ3MDkzODI5NTM3NTAyMjU3MjE0Mjg3NTQ2OSIKICAgICAgICAgICAgICAgICBJblJlc3Bv bnNlVG89ImlkLTUzMWIyYmYwMmFlMGE1ODhjMzAyMzQxNjNhZGJmZDlkNmJiZjA3NDciCiAgICAg ICAgICAgICAgICAgSXNzdWVJbnN0YW50PSIyMTE3LTA3LTE1VDIzOjA1OjAwWiIKICAgICAgICAg ICAgICAgICBWZXJzaW9uPSIyLjAiPgogICAgPHNhbWwyOklzc3VlciB4bWxuczpzYW1sMj0idXJu Om9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiIKICAgICAgICAgICAgICAgICAgRm9y bWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6bmFtZWlkLWZvcm1hdDplbnRpdHkiPmh0 dHBzOi8vc2FtbC5pZHAubm9wZS9oOWdranp2YjNlPC9zYW1sMjpJc3N1ZXI+CiAgICA8c2FtbDJw OlN0YXR1cyB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpwcm90b2Nv bCI+CiAgICAgICAgPHNhbWwycDpTdGF0dXNDb2RlIFZhbHVlPSJ1cm46b2FzaXM6bmFtZXM6dGM6 U0FNTDoyLjA6c3RhdHVzOlN1Y2Nlc3MiLz4KICAgIDwvc2FtbDJwOlN0YXR1cz4KICAgIDxzYW1s MjpBc3NlcnRpb24geG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3Nl cnRpb24iCiAgICAgICAgICAgICAgICAgICAgIElEPSJpZDcwOTM4Mjk1Mzc1NDY3NjcxMzE4Mzg3 NzIwIgogICAgICAgICAgICAgICAgICAgICBJc3N1ZUluc3RhbnQ9IjIxMTctMDctMTVUMjM6MDU6 MDBaIgogICAgICAgICAgICAgICAgICAgICBWZXJzaW9uPSIyLjAiCiAgICAgICAgICAgICAgICAg ICAgIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSI+CiAgICAgICAg PHNhbWwyOklzc3VlciBGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpuYW1laWQt Zm9ybWF0OmVudGl0eSIKICAgICAgICAgICAgICAgICAgICAgIHhtbG5zOnNhbWwyPSJ1cm46b2Fz aXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIj5odHRwczovL3NhbWwuaWRwLm5vcGUvaDln a2p6dmIzZTwvc2FtbDI6SXNzdWVyPgogICAgICAgIDxzYW1sMjpTdWJqZWN0IHhtbG5zOnNhbWwy PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIj4KICAgICAgICAgICAgPHNh bWwyOk5hbWVJRCBGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjEuMTpuYW1laWQtZm9y bWF0OmVtYWlsQWRkcmVzcyI+dXNlckBzYW1sLnNwLm5vcGU8L3NhbWwyOk5hbWVJRD4KICAgICAg ICAgICAgPHNhbWwyOlN1YmplY3RDb25maXJtYXRpb24gTWV0aG9kPSJ1cm46b2FzaXM6bmFtZXM6 dGM6U0FNTDoyLjA6Y206YmVhcmVyIj4KICAgICAgICAgICAgICAgIDxzYW1sMjpTdWJqZWN0Q29u ZmlybWF0aW9uRGF0YSBJblJlc3BvbnNlVG89ImlkLTUzMWIyYmYwMmFlMGE1ODhjMzAyMzQxNjNh ZGJmZDlkNmJiZjA3NDciCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgTm90T25PckFmdGVyPSIyMTE3LTA3LTE1VDIzOjEwOjAwWiIKICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBSZWNpcGllbnQ9Imh0dHBzOi8vc2FtbC5z cC5ub3BlL3Nlc3Npb24vc3NvL3NhbWwvYWNzL3JxNWp3a3ZiOHoiLz4KICAgICAgICAgICAgPC9z YW1sMjpTdWJqZWN0Q29uZmlybWF0aW9uPgogICAgICAgIDwvc2FtbDI6U3ViamVjdD4KICAgICAg ICA8c2FtbDI6Q29uZGl0aW9ucyBOb3RCZWZvcmU9IjIxMTctMDctMTVUMjM6MDA6MDBaIgogICAg ICAgICAgICAgICAgICAgICAgICAgIE5vdE9uT3JBZnRlcj0iMjExNy0wNy0xNVQyMzoxMDowMFoi CiAgICAgICAgICAgICAgICAgICAgICAgICAgeG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0 YzpTQU1MOjIuMDphc3NlcnRpb24iPgogICAgICAgICAgICA8c2FtbDI6QXVkaWVuY2VSZXN0cmlj dGlvbj4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdWRpZW5jZT5odHRwczovL3NhbWwuc3Aubm9w ZS9zZXNzaW9uL3Nzby9zYW1sL3NwZW50aXR5aWQvcnE1andrdmI4ejwvc2FtbDI6QXVkaWVuY2U+ CiAgICAgICAgICAgIDwvc2FtbDI6QXVkaWVuY2VSZXN0cmljdGlvbj4KICAgICAgICA8L3NhbWwy OkNvbmRpdGlvbnM+CiAgICAgICAgPHNhbWwyOkF1dGhuU3RhdGVtZW50IEF1dGhuSW5zdGFudD0i MjAxNy0wOC0zMFQyMzoxNDo0MS4zNzlaIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICBT ZXNzaW9uSW5kZXg9ImlkLTUzMWIyYmYwMmFlMGE1ODhjMzAyMzQxNjNhZGJmZDlkNmJiZjA3NDci CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhtbG5zOnNhbWwyPSJ1cm46b2FzaXM6bmFt ZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIj4KICAgICAgICAgICAgPHNhbWwyOkF1dGhuQ29udGV4 dD4KICAgICAgICAgICAgICAgIDxzYW1sMjpBdXRobkNvbnRleHRDbGFzc1JlZj51cm46b2FzaXM6 bmFtZXM6dGM6U0FNTDoyLjA6YWM6Y2xhc3NlczpQYXNzd29yZFByb3RlY3RlZFRyYW5zcG9ydDwv c2FtbDI6QXV0aG5Db250ZXh0Q2xhc3NSZWY+CiAgICAgICAgICAgIDwvc2FtbDI6QXV0aG5Db250 ZXh0PgogICAgICAgIDwvc2FtbDI6QXV0aG5TdGF0ZW1lbnQ+CiAgICAgICAgPHNhbWwyOkF0dHJp YnV0ZVN0YXRlbWVudCB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFz c2VydGlvbiI+CiAgICAgICAgICAgIDxzYW1sMjpBdHRyaWJ1dGUgTmFtZT0iZ2l2ZW5OYW1lIgog ICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5hbWVGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0 YzpTQU1MOjIuMDphdHRybmFtZS1mb3JtYXQ6dW5zcGVjaWZpZWQiPgogICAgICAgICAgICAgICAg PHNhbWwyOkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hN TFNjaGVtYSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4bWxuczp4c2k9 Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIgogICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgIHhzaTp0eXBlPSJ4czpzdHJpbmciPkZpcnN0PC9zYW1s MjpBdHRyaWJ1dGVWYWx1ZT4KICAgICAgICAgICAgPC9zYW1sMjpBdHRyaWJ1dGU+CiAgICAgICAg ICAgIDxzYW1sMjpBdHRyaWJ1dGUgTmFtZT0ic24iCiAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgTmFtZUZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmF0dHJuYW1lLWZvcm1h dDp1bnNwZWNpZmllZCI+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlVmFsdWUgeG1s bnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIgogICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9Y TUxTY2hlbWEtaW5zdGFuY2UiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg eHNpOnR5cGU9InhzOnN0cmluZyI+TGFzdDwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAg ICAgIDwvc2FtbDI6QXR0cmlidXRlPgogICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlIE5hbWU9 Imdyb3VwIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5hbWVGb3JtYXQ9InVybjpvYXNp czpuYW1lczp0YzpTQU1MOjIuMDphdHRybmFtZS1mb3JtYXQ6dW5zcGVjaWZpZWQiPgogICAgICAg ICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9y Zy8yMDAxL1hNTFNjaGVtYSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4 bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIgogICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhzaTp0eXBlPSJ4czpzdHJpbmciPnJl ZDwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRl VmFsdWUgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIgogICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5v cmcvMjAwMS9YTUxTY2hlbWEtaW5zdGFuY2UiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgeHNpOnR5cGU9InhzOnN0cmluZyI+Z3JlZW48L3NhbWwyOkF0dHJpYnV0ZVZhbHVl PgogICAgICAgICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZVZhbHVlIHhtbG5zOnhzPSJodHRwOi8v d3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3Rh bmNlIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhzaTp0eXBlPSJ4czpz dHJpbmciPmJsdWU8L3NhbWwyOkF0dHJpYnV0ZVZhbHVlPgogICAgICAgICAgICA8L3NhbWwyOkF0 dHJpYnV0ZT4KICAgICAgICA8L3NhbWwyOkF0dHJpYnV0ZVN0YXRlbWVudD4KICAgIDwvc2FtbDI6 QXNzZXJ0aW9uPgo8L3NhbWwycDpSZXNwb25zZT4K ================================================ FILE: providertests/testdata/onelogin/olgn09_response_93.b64 ================================================ <saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="id70938295375022572142875469" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2017-08-08T01:05:00Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
    <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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="pfx4a2cd6d1-cddd-d47d-59e8-78537ae56c3b" IssueInstant="2017-08-08T01:05:00Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx4a2cd6d1-cddd-d47d-59e8-78537ae56c3b"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>+YOwgZ3IKLDztJnDIa9FqI1Szaw=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>ab9s6eWQNKJU50f10LiaBMJdyH0rM7Pn+VABidkI1QecWueCycehteXF7PRR7BvVqzvE5eCqjd6guVkbdzAS9qwp4XHEVTYrKydn2NqZioXLvhVrVau4RMr8jd7/CVc7+VPAYnaSNzNFAwTksqkmY4z3mPIlNLj2CVhYRVTkgFYL3IuAHRfkAN2nuhruUG2fWvXeagbMG2VsjE8NfSuwv5Jg8/zlZB7ZZOprkpQDwIDyyCrXb4ZbbNsS5aVwT4EvM67Yk/DQ33zHqPo6gKlwGXwBvNZxEJ+DS7o1XXBjbvuE5ZF/Z48SfxeYM3xUiDU0yPGmMkg/p1lM5++21BWUTQ==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2017-08-08T01:10:00Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2017-08-08T01:00:00Z" NotOnOrAfter="2017-08-08T01:10:00Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_94.b64 ================================================ <saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z" ID="id70938295375022572142875469" InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" IssueInstant="2117-07-15T23:05:00Z" 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
    <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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="pfx8d12e5f3-2e0a-4531-4ca4-113761c3a77f" IssueInstant="2117-07-15T23:05:00Z" 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://saml.idp.nope/h9gkjzvb3e</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="#pfx8d12e5f3-2e0a-4531-4ca4-113761c3a77f"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>woSUwDMR3/AB5zUT+EFK6NKIZn0=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>gWOt0V3BSQruaIwJFkvcjL7MNighF3qlRZOO4eolzTwPTp76JjlUVaQOGfm9+pZCjQNvc9Bk35uvwLgcj7FtXpjjyNUIetKU7sawPPBztU3G+1rOPDpH3Ny+GbgIseAosZidhWfKUA7LOhReWTTEAXYj+0hZHA6LdnPjtyIuq1ZXmj9QONoLRjaBF9XHg4ByawivDmvjGAt+NnwZXN7ac2/iqz+mTcXYX2TEEaCnpPqTgduk1azJiSKJZQdM8FHqPI62rdhgetOHTtsxzUEMZZBP2ZnWcGz94A3TJZi2q0N0Cj39NqzouWJ/4S+2Q/vEPH4g636YkN4NbWtAYFf/lQ==</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4</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:1.1:nameid-format:emailAddress">user@saml.sp.nope</saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747" NotOnOrAfter="2117-07-15T23:10:00Z" Recipient="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2117-07-15T23:00:00Z" NotOnOrAfter="2117-07-15T23:10:00Z">
            <saml2:AudienceRestriction>
                <saml2:Audience>https://saml.sp.nope/session/sso/saml/spentityid/rq5jwkvb8z</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2017-08-30T23:14:41.379Z" SessionIndex="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747">
            <saml2:AuthnContext>
                <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
            </saml2:AuthnContext>
        </saml2:AuthnStatement>
        <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:Attribute Name="givenName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">First</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Last</saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="group" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">red</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">green</saml2:AttributeValue>
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">blue</saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_97.b64 ================================================ <saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol"
                 Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"
                 ID="id70938295375022572142875469"
                 InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747"
                 IssueInstant="2017-08-30T23:14:41.379Z"
                 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
    <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" xmlns:xs="http://www.w3.org/2001/XMLSchema"><xenc:EncryptedData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#" xmlns:dsig="http://www.w3.org/2000/09/xmldsig#" Type="http://www.w3.org/2001/04/xmlenc#Element"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes256-cbc"/><dsig:KeyInfo xmlns:dsig="http://www.w3.org/2000/09/xmldsig#"><xenc:EncryptedKey><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p"><dsig:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/></xenc:EncryptionMethod><dsig:KeyInfo><dsig:X509Data><dsig:X509Certificate>MIIDPjCCAiagAwIBAgIJAMMdzQFZ6vqIMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgzMDIzMTAzNloYDzIxMTcwODA2MjMxMDM2WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAK9o4wv2G1m/OwCVYzqsVN+PMHbkES3rpxDRAPRI024vDzKxznXWmh3X/f33Oqm2jAGuT70Rw34C878OKIlpcKfWGuouLXneYGxW6WY1ICfioExLlT+VngeQHFIzR0K9U7C3FHxJh0XL24b3wvAce3LaKENlE2cd4I4hfVqEPyiTogr9+mdXIX1++w6DNUYibpbYpe8Vo19Fe31HkiIjuDUPLXSH0hk6pnM6mmIdM+CBCg7oRr/UYBGqvHg5ItL+E036eKwdCjkxhOFddPEx78/ssJB+mq4V/CLQbVPnGniKYB4RqBZl56tp12pEdUW6VlzEPLuVMMlV5mRLUuwjtiUCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IBAQByP5NYYOIYsQkkgcNJXCP8oI+tuKDfgZfcpgqJ4kuz7zOERpVztgYgUKYo0pmee+WT6X3q3fZCPTtQiAuelHOHTR/rwltjPT0OuAz3U50dcOFMXuWii/FAUjRw26OtR/7J6r90g75SeNBBXTgv6wRr8n4/iERQh0JkBJcpwCD7ZcDgcRwPZqpuBF31U2jo1NgOhSSVg7ZDgFZDLUeeGekfbDLg9TD+xIt06fYtd4pdIpK2reBiKgE9epksjQO7FzmJzB4yaAILrffSsxCWZrHgwASaaOe1FYP3UgLzhvOU/C30feltvG9WWtPWMxCop2q2JR0SRG+mWiWau8uXfpmE</dsig:X509Certificate></dsig:X509Data></dsig:KeyInfo><xenc:CipherData><xenc:CipherValue>GXTdUmBNxr2O5IvBTaDPkOMNw3QohZgRerdWrJdm8o7sD1ZQuutdcKy3rpL+PIoW+LGKNFll/3vdWIboeKjMF1erZSF7RdA2zt6LxFzzqSF5tPgPMV2C4thdSq7lkT8wCRLCcY5Bywf7LjPJ7MUzK8cab9OYc+g9CB7jR4HOyLSsnfDoSIrc8Z8vf73vZMDAUuuzvkVwAUfNSsoUCVM7YsKkU7YaUZXSfgRbR11ZZMb7HqAZ7g7vI5LdhJcxk+Yd7CP7lOUFYNon/MxJXMSAoQE03aJVfLC5gemTdDDEGLhkF+OUVSHsv2hCDJDNZx9QonK/klrkhr2TbFtXFrIkzA==</xenc:CipherValue></xenc:CipherData></xenc:EncryptedKey></dsig:KeyInfo>
   <xenc:CipherData>
      <xenc:CipherValue>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</xenc:CipherValue>
   </xenc:CipherData>
</xenc:EncryptedData></saml2:EncryptedAssertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_98.b64 ================================================ <saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol"
                 Destination="https://saml.sp.nope/session/sso/saml/acs/rq5jwkvb8z"
                 ID="id70938295375022572142875469"
                 InResponseTo="id-531b2bf02ae0a588c30234163adbfd9d6bbf0747"
                 IssueInstant="2017-08-30T23:14:41.379Z"
                 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://saml.idp.nope/h9gkjzvb3e</saml2:Issuer>
    <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" xmlns:xs="http://www.w3.org/2001/XMLSchema"><xenc:EncryptedData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#" xmlns:dsig="http://www.w3.org/2000/09/xmldsig#" Type="http://www.w3.org/2001/04/xmlenc#Element"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes256-cbc"/><dsig:KeyInfo xmlns:dsig="http://www.w3.org/2000/09/xmldsig#"><xenc:EncryptedKey><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p"><dsig:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/></xenc:EncryptionMethod><dsig:KeyInfo><dsig:X509Data><dsig:X509Certificate>MIIDPjCCAiagAwIBAgIJAOvpZtJNtQ/rMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgxNDAxNDg1N1oYDzIxMTYwMzA4MDE0ODU3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKfUlciwDPCJ9JXy1NsxKfqyOfLQXFKKGgNKKRLzLAWO43GgQYrV67QaAny5LvgOa81KQOX4IvjJy0nd/VrO6jG9pTdMR9vFHT0Tu3W1QUsyPPSQqpKXwb2ZCSXNghYD5gBrNtmOxAOs1Azx5qmIzBJ4F0RkRivcdbXSfBUBLpCn1M285c4tk5SEvoRgBeisLJJDB7hmylA1V6/+BN+N6b3M+ZZG//CTvOjJKgnwkMALzXbPbQWa0kpbMLDMz8Kr2pODLKb3rGmdf4P6A9aA41k6L4clTsNdcK7ZwJ2fGF79WGzE6RLyBX2US3gPHUXt/WMQZXyULO3exiTDsQXWFf8CAwEAAaMPMA0wCwYDVR0PBAQDAgQQMA0GCSqGSIb3DQEBCwUAA4IBAQB3fQZz2qNAo/wohPNaR2uAakLt25cKrsbgn3XwO+X+DRH4nqMSZkHdLGr82xD3i33BLSQwXzFecEN+CA8SlpNoIXHwk6D6V3uEBSjKemZtJFCJqe8d+5qt3GV50AKmtEt2Nc7B94TN8xB5EmZladnTJWcBgSuuz1hLXQQ02dJ3dDq8FMlyR70S2DTtuPu0i2/f6KtrlmmNsU24Aq+fCzEG43NqShOMeM5rDxLsSJCtjfMRwG8YeyNf6cCMSMxYAJfrTyj+AS8RtZQNGF7tX+exEWHOf1C9CBzHtKRClBRL6zDjlpPCIDwcMFi8NXvaiVclxIq3XdfqxiGBBEldkhgZ</dsig:X509Certificate></dsig:X509Data></dsig:KeyInfo><xenc:CipherData><xenc:CipherValue>H4YBHMpLw0XfFItUGJhVuowAbffXuv8lgSw7VcnHnZNNYAwSC4tU92wiwowsa8vTSY6pZLc+XsFmncsrKFP9oazPJbr8pHjBfSktIhUdxBm6ESii3ICnoV+BZvioem909WMEYTooGiwA8HjaYED8ju0eO5kCMP4NoyDN1vVrhSitV8z5Dviiy7EjOcTHoq8oEPQCF4zQ1PeuoZqlP7ECbRPYhu6PR7MkOwrdq5iInZoz8Py2MxNxSiOfPyvsk80s8IPnMEV4Y5GgauS0bvmqS5DynEb9TrOk7X2a7j15x6wBTLw9ye4OpGZE8VaOxaqPebFWl6AQ3aJxui3frpjH+Q==</xenc:CipherValue></xenc:CipherData></xenc:EncryptedKey></dsig:KeyInfo>
   <xenc:CipherData>
      <xenc:CipherValue>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</xenc:CipherValue>
   </xenc:CipherData>
</xenc:EncryptedData></saml2:EncryptedAssertion>
</saml2p:Response>
 ================================================ FILE: providertests/testdata/onelogin/olgn09_response_99.b64 ================================================ PHNhbWwycDpSZXNwb25zZSB4bWxuczpzYW1sMnA9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIu MDpwcm90b2NvbCIKICAgICAgICAgICAgICAgICBEZXN0aW5hdGlvbj0iaHR0cHM6Ly9zYW1sLnNw Lm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9hY3MvcnE1andrdmI4eiIKICAgICAgICAgICAgICAgICBJ RD0iaWQ3MDkzODI5NTM3NTAyMjU3MjE0Mjg3NTQ2OSIKICAgICAgICAgICAgICAgICBJblJlc3Bv bnNlVG89ImlkLTUzMWIyYmYwMmFlMGE1ODhjMzAyMzQxNjNhZGJmZDlkNmJiZjA3NDciCiAgICAg ICAgICAgICAgICAgSXNzdWVJbnN0YW50PSIyMDE3LTA4LTMwVDIzOjE0OjQxLjM3OVoiCiAgICAg ICAgICAgICAgICAgVmVyc2lvbj0iMi4wIj4KICAgIDxzYW1sMjpJc3N1ZXIgeG1sbnM6c2FtbDI9 InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iCiAgICAgICAgICAgICAgICAg IEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOm5hbWVpZC1mb3JtYXQ6ZW50aXR5 Ij5odHRwczovL3NhbWwuaWRwLm5vcGUvaDlna2p6dmIzZTwvc2FtbDI6SXNzdWVyPgogICAgPHNh bWwycDpTdGF0dXMgeG1sbnM6c2FtbDJwPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJv dG9jb2wiPgogICAgICAgIDxzYW1sMnA6U3RhdHVzQ29kZSBWYWx1ZT0idXJuOm9hc2lzOm5hbWVz OnRjOlNBTUw6Mi4wOnN0YXR1czpTdWNjZXNzIi8+CiAgICA8L3NhbWwycDpTdGF0dXM+CiAgICA8 c2FtbDI6QXNzZXJ0aW9uIHhtbG5zOnNhbWwyPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6 YXNzZXJ0aW9uIgogICAgICAgICAgICAgICAgICAgICBJRD0iaWQ3MDkzODI5NTM3NTQ2NzY3MTMx ODM4NzcyMCIKICAgICAgICAgICAgICAgICAgICAgSXNzdWVJbnN0YW50PSIyMDE3LTA4LTMwVDIz OjE0OjQxLjM3OVoiCiAgICAgICAgICAgICAgICAgICAgIFZlcnNpb249IjIuMCIKICAgICAgICAg ICAgICAgICAgICAgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIj4K ICAgICAgICA8c2FtbDI6SXNzdWVyIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4w Om5hbWVpZC1mb3JtYXQ6ZW50aXR5IgogICAgICAgICAgICAgICAgICAgICAgeG1sbnM6c2FtbDI9 InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPmh0dHBzOi8vc2FtbC5pZHAu bm9wZS9oOWdranp2YjNlPC9zYW1sMjpJc3N1ZXI+CiAgICAgICAgPHNhbWwyOlN1YmplY3QgeG1s bnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPgogICAgICAg ICAgICA8c2FtbDI6TmFtZUlEIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6MS4xOm5h bWVpZC1mb3JtYXQ6ZW1haWxBZGRyZXNzIj51c2VyQHNhbWwuc3Aubm9wZTwvc2FtbDI6TmFtZUlE PgogICAgICAgICAgICA8c2FtbDI6U3ViamVjdENvbmZpcm1hdGlvbiBNZXRob2Q9InVybjpvYXNp czpuYW1lczp0YzpTQU1MOjIuMDpjbTpiZWFyZXIiPgogICAgICAgICAgICAgICAgPHNhbWwyOlN1 YmplY3RDb25maXJtYXRpb25EYXRhIEluUmVzcG9uc2VUbz0iaWQtNTMxYjJiZjAyYWUwYTU4OGMz MDIzNDE2M2FkYmZkOWQ2YmJmMDc0NyIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgICBOb3RPbk9yQWZ0ZXI9IjIwMTctMDgtMzBUMjM6MTk6NDEuMzc5WiIKICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBSZWNpcGllbnQ9Imh0 dHBzOi8vc2FtbC5zcC5ub3BlL3Nlc3Npb24vc3NvL3NhbWwvYWNzL3JxNWp3a3ZiOHoiLz4KICAg ICAgICAgICAgPC9zYW1sMjpTdWJqZWN0Q29uZmlybWF0aW9uPgogICAgICAgIDwvc2FtbDI6U3Vi amVjdD4KICAgICAgICA8c2FtbDI6Q29uZGl0aW9ucyBOb3RCZWZvcmU9IjIwMTctMDgtMzBUMjM6 MDk6NDEuMzc5WiIKICAgICAgICAgICAgICAgICAgICAgICAgICBOb3RPbk9yQWZ0ZXI9IjIwMTct MDgtMzBUMjM6MTk6NDEuMzc5WiIKICAgICAgICAgICAgICAgICAgICAgICAgICB4bWxuczpzYW1s Mj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiI+CiAgICAgICAgICAgIDxz YW1sMjpBdWRpZW5jZVJlc3RyaWN0aW9uPgogICAgICAgICAgICAgICAgPHNhbWwyOkF1ZGllbmNl Pmh0dHBzOi8vc2FtbC5zcC5ub3BlL3Nlc3Npb24vc3NvL3NhbWwvc3BlbnRpdHlpZC9ycTVqd2t2 Yjh6PC9zYW1sMjpBdWRpZW5jZT4KICAgICAgICAgICAgPC9zYW1sMjpBdWRpZW5jZVJlc3RyaWN0 aW9uPgogICAgICAgIDwvc2FtbDI6Q29uZGl0aW9ucz4KICAgICAgICA8c2FtbDI6QXV0aG5TdGF0 ZW1lbnQgQXV0aG5JbnN0YW50PSIyMDE3LTA4LTMwVDIzOjE0OjQxLjM3OVoiCiAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgIFNlc3Npb25JbmRleD0iaWQtNTMxYjJiZjAyYWUwYTU4OGMzMDIz NDE2M2FkYmZkOWQ2YmJmMDc0NyIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeG1sbnM6 c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPgogICAgICAgICAg ICA8c2FtbDI6QXV0aG5Db250ZXh0PgogICAgICAgICAgICAgICAgPHNhbWwyOkF1dGhuQ29udGV4 dENsYXNzUmVmPnVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphYzpjbGFzc2VzOlBhc3N3b3Jk UHJvdGVjdGVkVHJhbnNwb3J0PC9zYW1sMjpBdXRobkNvbnRleHRDbGFzc1JlZj4KICAgICAgICAg ICAgPC9zYW1sMjpBdXRobkNvbnRleHQ+CiAgICAgICAgPC9zYW1sMjpBdXRoblN0YXRlbWVudD4K ICAgICAgICA8c2FtbDI6QXR0cmlidXRlU3RhdGVtZW50IHhtbG5zOnNhbWwyPSJ1cm46b2FzaXM6 bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIj4KICAgICAgICAgICAgPHNhbWwyOkF0dHJpYnV0 ZSBOYW1lPSJnaXZlbk5hbWUiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgTmFtZUZvcm1h dD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmF0dHJuYW1lLWZvcm1hdDp1bnNwZWNpZmll ZCI+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlVmFsdWUgeG1sbnM6eHM9Imh0dHA6 Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIgogICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEtaW5z dGFuY2UiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeHNpOnR5cGU9Inhz OnN0cmluZyI+Rmlyc3Q8L3NhbWwyOkF0dHJpYnV0ZVZhbHVlPgogICAgICAgICAgICA8L3NhbWwy OkF0dHJpYnV0ZT4KICAgICAgICAgICAgPHNhbWwyOkF0dHJpYnV0ZSBOYW1lPSJzbiIKICAgICAg ICAgICAgICAgICAgICAgICAgICAgICBOYW1lRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FN TDoyLjA6YXR0cm5hbWUtZm9ybWF0OnVuc3BlY2lmaWVkIj4KICAgICAgICAgICAgICAgIDxzYW1s MjpBdHRyaWJ1dGVWYWx1ZSB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hl bWEiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeG1sbnM6eHNpPSJodHRw Oi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSIKICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICB4c2k6dHlwZT0ieHM6c3RyaW5nIj5MYXN0PC9zYW1sMjpBdHRy aWJ1dGVWYWx1ZT4KICAgICAgICAgICAgPC9zYW1sMjpBdHRyaWJ1dGU+CiAgICAgICAgICAgIDxz YW1sMjpBdHRyaWJ1dGUgTmFtZT0iZ3JvdXAiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAg TmFtZUZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmF0dHJuYW1lLWZvcm1hdDp1 bnNwZWNpZmllZCI+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlVmFsdWUgeG1sbnM6 eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIgogICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxT Y2hlbWEtaW5zdGFuY2UiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeHNp OnR5cGU9InhzOnN0cmluZyI+cmVkPC9zYW1sMjpBdHRyaWJ1dGVWYWx1ZT4KICAgICAgICAgICAg ICAgIDxzYW1sMjpBdHRyaWJ1dGVWYWx1ZSB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAw MS9YTUxTY2hlbWEiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeG1sbnM6 eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSIKICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICB4c2k6dHlwZT0ieHM6c3RyaW5nIj5ncmVlbjwv c2FtbDI6QXR0cmlidXRlVmFsdWU+CiAgICAgICAgICAgICAgICA8c2FtbDI6QXR0cmlidXRlVmFs dWUgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIgogICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5vcmcv MjAwMS9YTUxTY2hlbWEtaW5zdGFuY2UiCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgeHNpOnR5cGU9InhzOnN0cmluZyI+Ymx1ZTwvc2FtbDI6QXR0cmlidXRlVmFsdWU+CiAg ICAgICAgICAgIDwvc2FtbDI6QXR0cmlidXRlPgogICAgICAgIDwvc2FtbDI6QXR0cmlidXRlU3Rh dGVtZW50PgogICAgPC9zYW1sMjpBc3NlcnRpb24+Cjwvc2FtbDJwOlJlc3BvbnNlPgo= ================================================ FILE: providertests/testdata/onelogin/sp.encryption.cert ================================================ -----BEGIN CERTIFICATE----- MIIDPjCCAiagAwIBAgIJAOvpZtJNtQ/rMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNV BAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3Qg Tm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgxNDAxNDg1N1oY DzIxMTYwMzA4MDE0ODU3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZv cm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRl c3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKfUlciwDPCJ 9JXy1NsxKfqyOfLQXFKKGgNKKRLzLAWO43GgQYrV67QaAny5LvgOa81KQOX4IvjJ y0nd/VrO6jG9pTdMR9vFHT0Tu3W1QUsyPPSQqpKXwb2ZCSXNghYD5gBrNtmOxAOs 1Azx5qmIzBJ4F0RkRivcdbXSfBUBLpCn1M285c4tk5SEvoRgBeisLJJDB7hmylA1 V6/+BN+N6b3M+ZZG//CTvOjJKgnwkMALzXbPbQWa0kpbMLDMz8Kr2pODLKb3rGmd f4P6A9aA41k6L4clTsNdcK7ZwJ2fGF79WGzE6RLyBX2US3gPHUXt/WMQZXyULO3e xiTDsQXWFf8CAwEAAaMPMA0wCwYDVR0PBAQDAgQQMA0GCSqGSIb3DQEBCwUAA4IB AQB3fQZz2qNAo/wohPNaR2uAakLt25cKrsbgn3XwO+X+DRH4nqMSZkHdLGr82xD3 i33BLSQwXzFecEN+CA8SlpNoIXHwk6D6V3uEBSjKemZtJFCJqe8d+5qt3GV50AKm tEt2Nc7B94TN8xB5EmZladnTJWcBgSuuz1hLXQQ02dJ3dDq8FMlyR70S2DTtuPu0 i2/f6KtrlmmNsU24Aq+fCzEG43NqShOMeM5rDxLsSJCtjfMRwG8YeyNf6cCMSMxY AJfrTyj+AS8RtZQNGF7tX+exEWHOf1C9CBzHtKRClBRL6zDjlpPCIDwcMFi8NXva iVclxIq3XdfqxiGBBEldkhgZ -----END CERTIFICATE----- ================================================ FILE: providertests/testdata/onelogin/sp.encryption.key ================================================ -----BEGIN PRIVATE KEY----- MIIEvAIBADANBgkqhkiG9w0BAQEFAASCBKYwggSiAgEAAoIBAQCn1JXIsAzwifSV 8tTbMSn6sjny0FxSihoDSikS8ywFjuNxoEGK1eu0GgJ8uS74DmvNSkDl+CL4yctJ 3f1azuoxvaU3TEfbxR09E7t1tUFLMjz0kKqSl8G9mQklzYIWA+YAazbZjsQDrNQM 8eapiMwSeBdEZEYr3HW10nwVAS6Qp9TNvOXOLZOUhL6EYAXorCySQwe4ZspQNVev /gTfjem9zPmWRv/wk7zoySoJ8JDAC812z20FmtJKWzCwzM/Cq9qTgyym96xpnX+D +gPWgONZOi+HJU7DXXCu2cCdnxhe/VhsxOkS8gV9lEt4Dx1F7f1jEGV8lCzt3sYk w7EF1hX/AgMBAAECggEATD8qZWiGGGm0csNFrOdjGQALj6LVrrILK19v1aogX84Q yrhxzm9ti/8dDijbi9qRY0zOuyvGR5z1/HMb/Ttv7nUoMD05kEC3Dd5/FfTo2w7R 3pIyzDKh1E9IdqIs7W+L+Li8zI4twzWriM4FaxQ5ElL4zxt3PcoEuDwOH0TQMOsy P2gLEhzzkFp7TRoKzR87sM6lXoERsGKh7XNWjjS15/w+XHMaDverOOALwWDbv32N UCdVSAGBx4Ic4mZuJv+e3MH2SAja0J6NLMzCMtrzmfcgVECykMnELi1XftZYbgD+ KulSvHuamygS4KJppnAdly8950C8CxI7fp9QJV/8UQKBgQDUaT68z9e203L/XATr sa9CgZodWvjrLH7a2e5EvUPq8slmg2VqEYNjHzP4rCoOcLul6TwrlNInxqTIkIPR mRxBSrG24azfGRrOs34IMTXgqfMVVxbcSVK8OijHs94NTwYrRjMXeaAOnKjPH484 DALrEoEGcrjXmDDKBV9rb+a5XQKBgQDKRVkUvCoILjsA3jG6qaKBwKSZBFla2o6x YxgOZdeSG2NEuMt74yRHjgV6iogpvw9i/FSY9TAaZsoX0L3I5LWRtwEi3iXtEC9X qFlS9EPr9encpdd2vu1O6aWXW4IlUWbu3ecdb5UAxu44ObUQS6HiXEfcK8vufF5l WyilXNerCwKBgAMYYYSo1rDgVe2orp2soiwq7U7+M2Bh7ptLz7AKvgGfdhXbVk/8 X1jDbKN0BszdEa7yPiE4cvOHboFJsdINFB9TclGC6lz55a0banu+E9XpRBSMh1XA b8c0ZcG7OkIhY6qfxEDUUePEnqUeBZ1Ad45rX5vzcgQaQKPA/kn3gHo1AoGAU/05 wSdk2KLBs1mQEq9PoEsqzbMFm3k3WScJnSjiu3ON48JMFDQ8I04wrjKJ2bPRIswe IKlnAP9/mSX/OETntArmeOD/pJFc5ywrcwukjH0/T3S5pEAhb+wK629++hn0AOm5 hvqHR5xS3JvxuEN/g+vHlv/EnVGdLL8OgKOtlgMCgYBU/5WF/7dr89uYzjiBvedh HQCgwd+8aSs+raY5eTzJrJgqVbEMoxhco1GWzWYUjDVw88Y63k+fqIf1DQJFkWFi 9T1nppVDeofoLDLTrh/2oTAHIM2QL6kWwoHiD7b/scF5z/rC21KqobqroAh2R0CP J2waRoJgqT+P15Lq3PEcSA== -----END PRIVATE KEY----- ================================================ FILE: providertests/testdata/onelogin/sp.signing.cert ================================================ -----BEGIN CERTIFICATE----- MIIDPjCCAiagAwIBAgIJAKHPtM2MqZxXMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNV BAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3Qg Tm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oY DzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZv cm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRl c3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBALWw8EP/dSG0 yy7cL2sQvcRqiTrsVCWzQ5SGgZNGbFJXq36pshZ21H7gFPI/K2n6m4I3vNMCQtRJ JwfjyrPbuXpVaTMcmg8J3PGUVzaab+dZ28EQ7V9HEnzcVbEgu87xY/SB6SCiJbdI COZWlsgLUkgZS9CFkw5q6i29nL6nSZw/MmNr1hjJWvVvs1KwnGjB2aF6wYBQKKsY GxfZTJqKKBGXwIB5qnaWpVQgP6+H/84YCHLUEKk1hgh9AnR1xNVE6e64clcAE+O/ HWDS6QW658TJsw18TapzVbiUGou4TlxJZqEuJv3BfPX3EMsnp0uRurMtwgyzI/ZP CCHxSMJs4xECAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IB AQBRwSaE1AnhZU/GzMngLSG6WsOp1NksoEHZsJoIKxUJWdMj9s0Pb/QSGg/W/2UU CREt6xBd9rh3jv17AwH6+IAvq/zQn36UtOE0/0v85Tp/I6t8v96cTjkEgDHBWSqw qfPvnrokKUpDRv1cxCL0qh4oW7selKkI0VpZOgpKm87oi6POQJ/KOMfcewlH+DXt zN3Es8Xp8BAfRRIEk7i3PqZSrhWUguQgCOAOvkb0tGuPDsFLLJJBML7B7aYrS1Kw EyuowZiDCDSk49KpGOmKYv2ocIG65gr7+am/l2NN+6cxuCf/o9H8UL8qm0LUJdgh 5sVa0DJzIcuOjWsp2QxqTjr/ -----END CERTIFICATE----- ================================================ FILE: providertests/testdata/onelogin/sp.signing.key ================================================ -----BEGIN PRIVATE KEY----- MIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQC1sPBD/3UhtMsu 3C9rEL3Eaok67FQls0OUhoGTRmxSV6t+qbIWdtR+4BTyPytp+puCN7zTAkLUSScH 48qz27l6VWkzHJoPCdzxlFc2mm/nWdvBEO1fRxJ83FWxILvO8WP0gekgoiW3SAjm VpbIC1JIGUvQhZMOauotvZy+p0mcPzJja9YYyVr1b7NSsJxowdmhesGAUCirGBsX 2UyaiigRl8CAeap2lqVUID+vh//OGAhy1BCpNYYIfQJ0dcTVROnuuHJXABPjvx1g 0ukFuufEybMNfE2qc1W4lBqLuE5cSWahLib9wXz19xDLJ6dLkbqzLcIMsyP2Twgh 8UjCbOMRAgMBAAECggEAA/py2FpQm0NVK5qAo0yDizh19sdT9FtfgHINhkcFeiwX Qje/AYTqlDid3MwLTE/Dde94f/pNsk5Dv4V6W8PU5NvX6NmYefnST6va2QQ6rQsn p6uSNwLcYcWFTtKTqi1Y7fKmQyOpxcCbCUgeFxVAYPnE0jUKikdHB2dedkI9d2FV ZMSBAlNp5NQQTTojjdvfa3yxFqB/5Gh+tZZnnXm0BmtSHjWvXnpi62Nz8LHtKwtO qzS6650vhbC8GyuILeBkEa0Zvw2aUhRI0grCjWsbXJT66FrV+pIElOAQvyHP6hlX zC43ODdXSiFogVkF07umlqmopv4gDLgst8fjY61VfQKBgQDpVytmVrNXI9A2uDv/ 0RhCZpmBMgz8o3OQY0KRtZqupeVUGCTKk0zNqxsvUg31fa+DLYu+fYUDRVy58ST7 vTiXjKYllWY5LAacsqtA/1E4BghOuYfU12tGJcOUM1TZNkQ/s2to/fDL0HTjYX6T STqxoyg9zCnSYpF+u7gj91QuywKBgQDHVcUGiL69Tws3J6riKvFBtqrqcJaRu5OS t/U+kqM1m5/GOaBpZyropeusQgb/nZHIE/lEur7CHYcTi8PKF2lGxnqWOn31LVrc rM11r2pweDpCBBQqytNoE9vUzgfueXbPPgl+l1pTDA02u6EE45IHC1bPPbjDx29/ xhfAykD+EwKBgQCrVA3Rvqc/vFQNWYj0dJrTZnIfophWh806nycpxaYlxjl0XaXl 9/HUsWXsgNsu/XH5Z1/MJm2b0TocbSsyi+UZoXP89I1yPRk9xRJpTw5bjFJdO2y4 otNpViEcl/Qc6PODskGTfaFohU7OBa/ihUpLU/kgJuAuUaFy5HJ4NgnhsQKBgQCm q/K4SfKiu8r27TYXMizT83bp3AYqCJuWHDb1gQryshNgXaLhPyBDsyhhuju70/an Qvw0GamTCbl+AGlPO1ANm7u4jWPwc2H8DoklE+196SldNaffOASYi7JON4+uOOW8 13R84vTlZ7hMwYobWmUperO1STiKiuGSBwKpcvPw/QKBgBgqByvETHwewxnYoIsp yn3Fz1KM7MMnRil2sXVTdpS6lpF+iGs7iXc8sBnWKxFFQWnvvx6VvhXw6lCCnEQX 3LH177jH+s0jVQgD+YZLnYDBF347tU7W/dPz5Df7hgmuQhOU/UV9ihm4udutRFbR 4fd3j6wIcv2MZ0iDUVJ0UFYr -----END PRIVATE KEY----- ================================================ FILE: providertests/testdata/onelogin_cert.pem ================================================ -----BEGIN CERTIFICATE----- MIIEJjCCAw6gAwIBAgIUOHrykO4ce1TbjvGgXXVVnR4NsqMwDQYJKoZIhvcNAQEF BQAwXTELMAkGA1UEBhMCVVMxFTATBgNVBAoMDExhdW5jaERhcmtseTEVMBMGA1UE CwwMT25lTG9naW4gSWRQMSAwHgYDVQQDDBdPbmVMb2dpbiBBY2NvdW50IDEwMjEy NzAeFw0xNzAzMDYwMjQ2NTNaFw0yMjAzMDcwMjQ2NTNaMF0xCzAJBgNVBAYTAlVT MRUwEwYDVQQKDAxMYXVuY2hEYXJrbHkxFTATBgNVBAsMDE9uZUxvZ2luIElkUDEg MB4GA1UEAwwXT25lTG9naW4gQWNjb3VudCAxMDIxMjcwggEiMA0GCSqGSIb3DQEB AQUAA4IBDwAwggEKAoIBAQCaJ02AnJe5vq+zzkmrIHhRy8V/UxJogbJGEJW6nqrE mO7Q4sXO7dLIKxGccCEz0KAavGKWzSX9uhVvKpazpD4bW80wPQIgFxN3CjiA3qlY Ifhhh4emSZo2AnaTuG4BPVGFNPx0jxXGAhh/3xkpIsqARJFPB6njT2+MwFctm3fo ckx3Yp4e1xoUD8qQR0f/8oq1LjrYd2Vlckmmw7qrzSqS8POHW/I1jx9Y/vAjTPWD KXmbmLcTe3188PDrthSyoBuaAGBRVTP9WTuYMh4kGvmfX6sNvIDGejUcUCq6IObR r4xLSZiGy5uoyqsQc9agAhQm+26Gpq0R3NSvN91JdbZHAgMBAAGjgd0wgdowDAYD VR0TAQH/BAIwADAdBgNVHQ4EFgQUnbxBsHgNVq3OSXEuG5EkR0Jd1UswgZoGA1Ud IwSBkjCBj4AUnbxBsHgNVq3OSXEuG5EkR0Jd1UuhYaRfMF0xCzAJBgNVBAYTAlVT MRUwEwYDVQQKDAxMYXVuY2hEYXJrbHkxFTATBgNVBAsMDE9uZUxvZ2luIElkUDEg MB4GA1UEAwwXT25lTG9naW4gQWNjb3VudCAxMDIxMjeCFDh68pDuHHtU247xoF11 VZ0eDbKjMA4GA1UdDwEB/wQEAwIHgDANBgkqhkiG9w0BAQUFAAOCAQEAL/6j2qpM CrnolwKT7mfPEpA6btbtl0R0t6zSwYUVU9T3PK0/P3LKXvbjSySov0E4R9d5qlOc yj5CbYiuqAO2aON3xy82s0dN3FHRiO6kcjoRPwVIIF0S8x7tpzcPKa42zSPfBqMR w4ezUEzTijFriepkSWST1Btr3QeK2Cxhr0fC1xmw/YK82BV0/oVRslGL27ro+v3/ dNY0A0r32Xe2+THomrY/YaZaDCPCjHo8dlxrX3D/mPfoiiKSkm2mGagQXT0giTHV o3oIq+u+KdrBcQn65EBcjfFKDIeFCdiVmO0xPl9mmWskVRLy2/wpuDIp6hnAphl9 lj5DY48eBsrEXQ== -----END CERTIFICATE----- ================================================ FILE: providertests/testdata/onelogin_response.xml ================================================ https://app.onelogin.com/saml/metadata/634027https://app.onelogin.com/saml/metadata/634027gd5V090n/m4JRrtpo5WgrwPyyy0=SLzvdNM+1R1+3XsXpC+/RIvb5L4Lhy7Eb7caPG2CLMPYhzbKLAwIiT7/0fEMO/xL7rdIgEShbcU9iu5PX4hGYBhirsFIZvdHytns5+JKHnlVBmHm4TsSU1z+dGMXBa//L0KFSrvdgBUpsr5vs50SuYnnVp61VN+zCLMqO221CQfP95QyMcSQ+fiyq4GOmWLwQy1m1+NV3U8zlapp6FIH5stW/dp4OqpRdafV96rVwmmR4yeUw7VAzbJuMrPgkXO9nUbHeMUTgQxkQ4ThzG5jt6fT+Ro1NOYS4zpVtzqlQwGzqWxQVRLEqXIf500/Qi0NuFQOW42ZAUiXDgdLENTVGA==MIIEJjCCAw6gAwIBAgIUOHrykO4ce1TbjvGgXXVVnR4NsqMwDQYJKoZIhvcNAQEFBQAwXTELMAkGA1UEBhMCVVMxFTATBgNVBAoMDExhdW5jaERhcmtseTEVMBMGA1UECwwMT25lTG9naW4gSWRQMSAwHgYDVQQDDBdPbmVMb2dpbiBBY2NvdW50IDEwMjEyNzAeFw0xNzAzMDYwMjQ2NTNaFw0yMjAzMDcwMjQ2NTNaMF0xCzAJBgNVBAYTAlVTMRUwEwYDVQQKDAxMYXVuY2hEYXJrbHkxFTATBgNVBAsMDE9uZUxvZ2luIElkUDEgMB4GA1UEAwwXT25lTG9naW4gQWNjb3VudCAxMDIxMjcwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCaJ02AnJe5vq+zzkmrIHhRy8V/UxJogbJGEJW6nqrEmO7Q4sXO7dLIKxGccCEz0KAavGKWzSX9uhVvKpazpD4bW80wPQIgFxN3CjiA3qlYIfhhh4emSZo2AnaTuG4BPVGFNPx0jxXGAhh/3xkpIsqARJFPB6njT2+MwFctm3fockx3Yp4e1xoUD8qQR0f/8oq1LjrYd2Vlckmmw7qrzSqS8POHW/I1jx9Y/vAjTPWDKXmbmLcTe3188PDrthSyoBuaAGBRVTP9WTuYMh4kGvmfX6sNvIDGejUcUCq6IObRr4xLSZiGy5uoyqsQc9agAhQm+26Gpq0R3NSvN91JdbZHAgMBAAGjgd0wgdowDAYDVR0TAQH/BAIwADAdBgNVHQ4EFgQUnbxBsHgNVq3OSXEuG5EkR0Jd1UswgZoGA1UdIwSBkjCBj4AUnbxBsHgNVq3OSXEuG5EkR0Jd1UuhYaRfMF0xCzAJBgNVBAYTAlVTMRUwEwYDVQQKDAxMYXVuY2hEYXJrbHkxFTATBgNVBAsMDE9uZUxvZ2luIElkUDEgMB4GA1UEAwwXT25lTG9naW4gQWNjb3VudCAxMDIxMjeCFDh68pDuHHtU247xoF11VZ0eDbKjMA4GA1UdDwEB/wQEAwIHgDANBgkqhkiG9w0BAQUFAAOCAQEAL/6j2qpMCrnolwKT7mfPEpA6btbtl0R0t6zSwYUVU9T3PK0/P3LKXvbjSySov0E4R9d5qlOcyj5CbYiuqAO2aON3xy82s0dN3FHRiO6kcjoRPwVIIF0S8x7tpzcPKa42zSPfBqMRw4ezUEzTijFriepkSWST1Btr3QeK2Cxhr0fC1xmw/YK82BV0/oVRslGL27ro+v3/dNY0A0r32Xe2+THomrY/YaZaDCPCjHo8dlxrX3D/mPfoiiKSkm2mGagQXT0giTHVo3oIq+u+KdrBcQn65EBcjfFKDIeFCdiVmO0xPl9mmWskVRLy2/wpuDIp6hnAphl9lj5DY48eBsrEXQ==arun@launchdarkly.com{audience}urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport ================================================ FILE: providertests/testdata/pingfed/idp.signing.cert ================================================ -----BEGIN CERTIFICATE----- MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNV BAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3Qg Tm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oY DzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZv cm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRl c3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE67dWF WQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6 IUrh310gNm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI7 9AqsB9Irn0fEuLKb1KOF0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9 /ATo83GHsO7w+NKs0mAxB/Tffh6hrbILtMVMENQB6lv3dIrdmQqPGJ120xO6dmHq LTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2XdXJcdiY57PxeQvc0zwRt JtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IB AQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGk qfYma7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkh u7RIwwwwhAZKP52/Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6 simdFOK3ibMHUZxyGbvK/MwJfKQmMcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooF dD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17VrX5wnkoUb68CqYfUrRjhpbPYI LGu96alI6+eLeIwZKpKSbMj4 -----END CERTIFICATE----- ================================================ FILE: providertests/testdata/pingfed/pfed11_response_01.b64 ================================================ PHNhbWxwOlJlc3BvbnNlIFZlcnNpb249IjIuMCIgSUQ9Ik95RHVjOFZPX1Y2UGZlLUMuNHlYQzJoS0xRMCIgSXNzdWVJbnN0YW50PSIyMDE3LTA5LTAyVDAwOjEyOjA2LjUwNVoiIEluUmVzcG9uc2VUbz0iXzI3MjQyYTI3LTlhZWEtNDBkNi1iNjAzLWMxZDZkYWExOThkNCIgRGVzdGluYXRpb249Imh0dHBzOi8vc2FtbC50ZXN0Lm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9hY3MvaHAyNGRxbnB2cSIgeG1sbnM6c2FtbHA9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpwcm90b2NvbCI+PHNhbWw6SXNzdWVyIHhtbG5zOnNhbWw9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPmh0dHBzOi8vc2FtbC50ZXN0Lm5vcGU6OTAzMS9laWQvc3hwbXJoYmt6bjwvc2FtbDpJc3N1ZXI+PGRzOlNpZ25hdHVyZSB4bWxuczpkcz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8wOS94bWxkc2lnIyI+CjxkczpTaWduZWRJbmZvPgo8ZHM6Q2Fub25pY2FsaXphdGlvbk1ldGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvMTAveG1sLWV4Yy1jMTRuIyIvPgo8ZHM6U2lnbmF0dXJlTWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8wNC94bWxkc2lnLW1vcmUjcnNhLXNoYTI1NiIvPgo8ZHM6UmVmZXJlbmNlIFVSST0iI095RHVjOFZPX1Y2UGZlLUMuNHlYQzJoS0xRMCI+CjxkczpUcmFuc2Zvcm1zPgo8ZHM6VHJhbnNmb3JtIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8wOS94bWxkc2lnI2VudmVsb3BlZC1zaWduYXR1cmUiLz4KPGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvMTAveG1sLWV4Yy1jMTRuIyIvPgo8L2RzOlRyYW5zZm9ybXM+CjxkczpEaWdlc3RNZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzA0L3htbGVuYyNzaGEyNTYiLz4KPGRzOkRpZ2VzdFZhbHVlPnhOWFB0dHJ4VGxRWU8waHdRaFIvTHA2dUl1Y1cvc3p2WnNzb2VSTGpLdGM9PC9kczpEaWdlc3RWYWx1ZT4KPC9kczpSZWZlcmVuY2U+CjwvZHM6U2lnbmVkSW5mbz4KPGRzOlNpZ25hdHVyZVZhbHVlPgpQaDI3bVhCbGlWa0pLMTBGVUFtQ0pPZmpuRVpnVWQ1WVdzcFdnSXdBNEVweUVuRzNhS2VTZFR2aHc3M3VVblVsNnVRM2JOMkRwT3JOCjV3OVV6aG9FQnF1SjI4WG0yVVpGb2gwaklMK2craW53TnRPR21tRHRVWkhuL3ZWVUl0QXk3RCtlVjJKY0tpaG1PalRNNHoybUVvYlUKakdTQWJLZmpUMCt5MXJDODZGdmZlNUwrZWpuZkNxYm8vQndqV2pzdi8xUHRNLzlJdTR2OEYxYVY2OFJqRUxQbHRzVkt0QUU5RHlycgpUYjhxSmV3QXFwUVUyUmZSY2FQdXYvSUFNRzdWZUxzU2xuK1p0NjZxUS9VN3l2S0ZYOGhvNFJiZndsMFZEelZvaWhJWk9SVjNYRjd5CmxKcUhuZklFYUo2Y3JHak5aYktoNmVLUmFXZHRFcXZLTFpiSzFBPT0KPC9kczpTaWduYXR1cmVWYWx1ZT4KPC9kczpTaWduYXR1cmU+PHNhbWxwOlN0YXR1cz48c2FtbHA6U3RhdHVzQ29kZSBWYWx1ZT0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOnN0YXR1czpTdWNjZXNzIi8+PC9zYW1scDpTdGF0dXM+PHNhbWw6QXNzZXJ0aW9uIElEPSJ2aC1TSGtrZVBqcVplRzduNkpDZEhPMG96RVQiIElzc3VlSW5zdGFudD0iMjAxNy0wOS0wMlQwMDoxMjowNi41MTZaIiBWZXJzaW9uPSIyLjAiIHhtbG5zOnNhbWw9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPjxzYW1sOklzc3Vlcj5odHRwczovL3NhbWwudGVzdC5ub3BlOjkwMzEvZWlkL3N4cG1yaGJrem48L3NhbWw6SXNzdWVyPjxzYW1sOlN1YmplY3Q+PHNhbWw6TmFtZUlEIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6MS4xOm5hbWVpZC1mb3JtYXQ6ZW1haWxBZGRyZXNzIj5maXJzdGxhc3RAc2FtbC50ZXN0Lm5vcGU8L3NhbWw6TmFtZUlEPjxzYW1sOlN1YmplY3RDb25maXJtYXRpb24gTWV0aG9kPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6Y206YmVhcmVyIj48c2FtbDpTdWJqZWN0Q29uZmlybWF0aW9uRGF0YSBSZWNpcGllbnQ9Imh0dHBzOi8vc2FtbC50ZXN0Lm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9hY3MvaHAyNGRxbnB2cSIgTm90T25PckFmdGVyPSIyMDE3LTA5LTAyVDAwOjE3OjA2LjUxNloiIEluUmVzcG9uc2VUbz0iXzI3MjQyYTI3LTlhZWEtNDBkNi1iNjAzLWMxZDZkYWExOThkNCIvPjwvc2FtbDpTdWJqZWN0Q29uZmlybWF0aW9uPjwvc2FtbDpTdWJqZWN0PjxzYW1sOkNvbmRpdGlvbnMgTm90QmVmb3JlPSIyMDE3LTA5LTAyVDAwOjA3OjA2LjUxNloiIE5vdE9uT3JBZnRlcj0iMjAxNy0wOS0wMlQwMDoxNzowNi41MTZaIj48c2FtbDpBdWRpZW5jZVJlc3RyaWN0aW9uPjxzYW1sOkF1ZGllbmNlPmh0dHBzOi8vc2FtbC50ZXN0Lm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9zcGVudGl0eWlkL2hwMjRkcW5wdnE8L3NhbWw6QXVkaWVuY2U+PC9zYW1sOkF1ZGllbmNlUmVzdHJpY3Rpb24+PC9zYW1sOkNvbmRpdGlvbnM+PHNhbWw6QXV0aG5TdGF0ZW1lbnQgU2Vzc2lvbkluZGV4PSJ2aC1TSGtrZVBqcVplRzduNkpDZEhPMG96RVQiIEF1dGhuSW5zdGFudD0iMjAxNy0wOS0wMlQwMDoxMjowNi4wMDBaIj48c2FtbDpBdXRobkNvbnRleHQ+PHNhbWw6QXV0aG5Db250ZXh0Q2xhc3NSZWY+dXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFjOmNsYXNzZXM6UGFzc3dvcmQ8L3NhbWw6QXV0aG5Db250ZXh0Q2xhc3NSZWY+PC9zYW1sOkF1dGhuQ29udGV4dD48L3NhbWw6QXV0aG5TdGF0ZW1lbnQ+PHNhbWw6QXR0cmlidXRlU3RhdGVtZW50PjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJmaXJzdG5hbWUiIE5hbWVGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphdHRybmFtZS1mb3JtYXQ6dW5zcGVjaWZpZWQiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czpzdHJpbmciIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSI+Rmlyc3Q8L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48c2FtbDpBdHRyaWJ1dGUgTmFtZT0iZ3JvdXAiIE5hbWVGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphdHRybmFtZS1mb3JtYXQ6dW5zcGVjaWZpZWQiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czpzdHJpbmciIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSI+cmVkLGdyZWVuLGJsdWU8L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48c2FtbDpBdHRyaWJ1dGUgTmFtZT0ibGFzdG5hbWUiIE5hbWVGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphdHRybmFtZS1mb3JtYXQ6dW5zcGVjaWZpZWQiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czpzdHJpbmciIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSI+TGFzdDwvc2FtbDpBdHRyaWJ1dGVWYWx1ZT48L3NhbWw6QXR0cmlidXRlPjwvc2FtbDpBdHRyaWJ1dGVTdGF0ZW1lbnQ+PC9zYW1sOkFzc2VydGlvbj48L3NhbWxwOlJlc3BvbnNlPg== ================================================ FILE: providertests/testdata/pingfed/pfed11_response_02.b64 ================================================ PHNhbWxwOlJlc3BvbnNlIFZlcnNpb249IjIuMCIgSUQ9Im9vTWpNTUpMTTl2RDZPSTRGbG4xejh5X3lodSIgSXNzdWVJbnN0YW50PSIyMDE3LTA5LTAyVDIzOjUwOjA4LjQ2NVoiIEluUmVzcG9uc2VUbz0iXzMxNWFiMTczLTk5MmEtNGMxYi1iOTlhLWZhY2NmZDhlY2VhMCIgeG1sbnM6c2FtbHA9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpwcm90b2NvbCI+PHNhbWw6SXNzdWVyIHhtbG5zOnNhbWw9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPmh0dHBzOi8vc2FtbC50ZXN0Lm5vcGU6OTAzMS9laWQvc3hwbXJoYmt6bjwvc2FtbDpJc3N1ZXI+PHNhbWxwOlN0YXR1cz48c2FtbHA6U3RhdHVzQ29kZSBWYWx1ZT0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOnN0YXR1czpTdWNjZXNzIi8+PC9zYW1scDpTdGF0dXM+PHNhbWw6QXNzZXJ0aW9uIElEPSJpXy5uS3hPR1I1LWp0RjF2UFpwVDVjZnNpMWMiIElzc3VlSW5zdGFudD0iMjAxNy0wOS0wMlQyMzo1MDowOC40NjlaIiBWZXJzaW9uPSIyLjAiIHhtbG5zOnNhbWw9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPjxzYW1sOklzc3Vlcj5odHRwczovL3NhbWwudGVzdC5ub3BlOjkwMzEvZWlkL3N4cG1yaGJrem48L3NhbWw6SXNzdWVyPjxkczpTaWduYXR1cmUgeG1sbnM6ZHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyMiPgo8ZHM6U2lnbmVkSW5mbz4KPGRzOkNhbm9uaWNhbGl6YXRpb25NZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzEwL3htbC1leGMtYzE0biMiLz4KPGRzOlNpZ25hdHVyZU1ldGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvMDQveG1sZHNpZy1tb3JlI3JzYS1zaGEyNTYiLz4KPGRzOlJlZmVyZW5jZSBVUkk9IiNpXy5uS3hPR1I1LWp0RjF2UFpwVDVjZnNpMWMiPgo8ZHM6VHJhbnNmb3Jtcz4KPGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyNlbnZlbG9wZWQtc2lnbmF0dXJlIi8+CjxkczpUcmFuc2Zvcm0gQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzEwL3htbC1leGMtYzE0biMiLz4KPC9kczpUcmFuc2Zvcm1zPgo8ZHM6RGlnZXN0TWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8wNC94bWxlbmMjc2hhMjU2Ii8+CjxkczpEaWdlc3RWYWx1ZT5XdytiMy9jbXQvYW1tTk8yaVhpd3BJTU5EbFVXN0NRZzZJVUJraW5pcTZBPTwvZHM6RGlnZXN0VmFsdWU+CjwvZHM6UmVmZXJlbmNlPgo8L2RzOlNpZ25lZEluZm8+CjxkczpTaWduYXR1cmVWYWx1ZT4KSjR6UFNsb3hudkR2QjJYelduNXZ1dXpoejRFbUVxcU9sMlI5ODc4dXowMW5kNTJqOCsxMjhqdzRaSDVnUzJFTCtLSFVRQXlTZlNFMQoybnhoR3UzOHpkVHE1NkE1RTRYU2R0azlaSWVrcDduOEVJMFRwYTR1bHpHalNaTy92N1crYkVNL2hDMk4veGhUaVhFWnF0N2p6WVI1ClhXdTNkbUtnNEphVVNZQTBDU3VMb25NRG5uM1ozQVpRQVF3VWpOaDVYU3FXaFBwYW9xRmtVcHRKSnFWa2srT2xEcXpvQUNFY0M3cXEKUUJBZzdUaFpvQ1cyVDBlR2lLdjNuaXc1c0psU2FuQytuajlaWExYa21JTllxWTMva3E4Q1U5ZU44NmxYNWlDbTQvYlZzNHdMNndWMQpTZTUxb1VaZDh5RDlYOENuaVBKT1FWdnBDK1pnTldkWVExMGlEZz09CjwvZHM6U2lnbmF0dXJlVmFsdWU+CjxkczpLZXlJbmZvPgo8ZHM6WDUwOURhdGE+CjxkczpYNTA5Q2VydGlmaWNhdGU+Ck1JSURQakNDQWlhZ0F3SUJBZ0lKQU1RZVduREpWYVR5TUEwR0NTcUdTSWIzRFFFQkN3VUFNRlV4Q3pBSkJnTlZCQVlUQWxWVE1STXcKRVFZRFZRUUlFd3BEWVd4cFptOXlibWxoTVJnd0ZnWURWUVFLRXc5VFFVMU1JRlJsYzNRZ1RtOXdaUzR4RnpBVkJnTlZCQU1URG5OaApiV3d1ZEdWemRDNXViM0JsTUNBWERURTNNRGd3T0RFM05ESXlOMW9ZRHpJeE1UY3dOekUxTVRjME1qSTNXakJWTVFzd0NRWURWUVFHCkV3SlZVekVUTUJFR0ExVUVDQk1LUTJGc2FXWnZjbTVwWVRFWU1CWUdBMVVFQ2hNUFUwRk5UQ0JVWlhOMElFNXZjR1V1TVJjd0ZRWUQKVlFRREV3NXpZVzFzTG5SbGMzUXVibTl3WlRDQ0FTSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnRVBBRENDQVFvQ2dnRUJBT3dWVlhFNgo3ZFdGV1FHbkZ5V0xReWFBcWNvK2hhcmdITnE1RFdUaVFNNUVHMUdFTHQ1UXFXN1hRSndnd2ZJSGljN3pNQkRVMTNGNklVcmgzMTBnCk5tME55Z2c3RFdFUkVCTlp2VGRqZzk5OXBiUnl0NUlnZWloS2g1TkV3cEg5VEdYbmJvdzhRakk3OUFxc0I5SXJuMGZFdUxLYjFLT0YKMEVNdDVYcUpuVzJvcUpydlRkWWVHb2k3Q2twZzlKOTg2WE1xTE1wNDhHZDkvQVRvODNHSHNPN3crTktzMG1BeEIvVGZmaDZocmJJTAp0TVZNRU5RQjZsdjNkSXJkbVFxUEdKMTIweE82ZG1IcUxUait0TlNqaGt6blNLWEJESFQvN3ZHdDNSYTM4UDZtR0NLckRBbG9BejJYCmRYSmNkaVk1N1B4ZVF2YzB6d1J0SnRPeHBoQTVXSE1DQXdFQUFhTVBNQTB3Q3dZRFZSMFBCQVFEQWdlQU1BMEdDU3FHU0liM0RRRUIKQ3dVQUE0SUJBUUFRMlA5YVVCYU0xa0MwWEpGODZBNGFZa3FSVnV5c3BKVDYrRE9ZQS9wY2lmWjN6aHBYUGUyK1RZMmdLc0drcWZZbQphN2NoNmRxNHpWRXJGTXdrbjhxTTdQRDFrbksvUDhTWnVVUEMzTFRIM0VUSCtiZWIxbE05TklDT0l0a2h1N1JJd3d3d2hBWktQNTIvCld3MEY1OVBDdjFTUFpKMU5rRjhYV2FrNERmOGw0dW40eHNYMWpjRmtGbFV4Q0RoNnNpbWRGT0szaWJNSFVaeHlHYnZLL013SmZLUW0KTWNqby9mSWF1a3YxLzJ0S1huaWxTRGhRUzExNjF5aVg3b29GZEQreTU1S2FHRjVPNTBLLzlEVzMwRTlaZ3JTRGx0RC82YUd0MTdWcgpYNXdua29VYjY4Q3FZZlVyUmpocGJQWUlMR3U5NmFsSTYrZUxlSXdaS3BLU2JNajQKPC9kczpYNTA5Q2VydGlmaWNhdGU+CjwvZHM6WDUwOURhdGE+CjwvZHM6S2V5SW5mbz4KPC9kczpTaWduYXR1cmU+PHNhbWw6U3ViamVjdD48c2FtbDpOYW1lSUQgRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoxLjE6bmFtZWlkLWZvcm1hdDplbWFpbEFkZHJlc3MiPmZpcnN0bGFzdEBzYW1sLnRlc3Qubm9wZTwvc2FtbDpOYW1lSUQ+PHNhbWw6U3ViamVjdENvbmZpcm1hdGlvbiBNZXRob2Q9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpjbTpiZWFyZXIiPjxzYW1sOlN1YmplY3RDb25maXJtYXRpb25EYXRhIFJlY2lwaWVudD0iaHR0cHM6Ly9zYW1sLnRlc3Qubm9wZS9zZXNzaW9uL3Nzby9zYW1sL2Fjcy9ocDI0ZHFucHZxIiBOb3RPbk9yQWZ0ZXI9IjIwMTctMDktMDJUMjM6NTU6MDguNDY5WiIgSW5SZXNwb25zZVRvPSJfMzE1YWIxNzMtOTkyYS00YzFiLWI5OWEtZmFjY2ZkOGVjZWEwIi8+PC9zYW1sOlN1YmplY3RDb25maXJtYXRpb24+PC9zYW1sOlN1YmplY3Q+PHNhbWw6Q29uZGl0aW9ucyBOb3RCZWZvcmU9IjIwMTctMDktMDJUMjM6NDU6MDguNDY5WiIgTm90T25PckFmdGVyPSIyMDE3LTA5LTAyVDIzOjU1OjA4LjQ2OVoiPjxzYW1sOkF1ZGllbmNlUmVzdHJpY3Rpb24+PHNhbWw6QXVkaWVuY2U+aHR0cHM6Ly9zYW1sLnRlc3Qubm9wZS9zZXNzaW9uL3Nzby9zYW1sL3NwZW50aXR5aWQvaHAyNGRxbnB2cTwvc2FtbDpBdWRpZW5jZT48L3NhbWw6QXVkaWVuY2VSZXN0cmljdGlvbj48L3NhbWw6Q29uZGl0aW9ucz48c2FtbDpBdXRoblN0YXRlbWVudCBTZXNzaW9uSW5kZXg9ImlfLm5LeE9HUjUtanRGMXZQWnBUNWNmc2kxYyIgQXV0aG5JbnN0YW50PSIyMDE3LTA5LTAyVDIzOjUwOjA4LjAwMFoiPjxzYW1sOkF1dGhuQ29udGV4dD48c2FtbDpBdXRobkNvbnRleHRDbGFzc1JlZj51cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YWM6Y2xhc3NlczpQYXNzd29yZDwvc2FtbDpBdXRobkNvbnRleHRDbGFzc1JlZj48L3NhbWw6QXV0aG5Db250ZXh0Pjwvc2FtbDpBdXRoblN0YXRlbWVudD48c2FtbDpBdHRyaWJ1dGVTdGF0ZW1lbnQ+PHNhbWw6QXR0cmlidXRlIE5hbWU9ImZpcnN0bmFtZSIgTmFtZUZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmF0dHJuYW1lLWZvcm1hdDp1bnNwZWNpZmllZCI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOnN0cmluZyIgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIiB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIj5GaXJzdDwvc2FtbDpBdHRyaWJ1dGVWYWx1ZT48L3NhbWw6QXR0cmlidXRlPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJncm91cCIgTmFtZUZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmF0dHJuYW1lLWZvcm1hdDp1bnNwZWNpZmllZCI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOnN0cmluZyIgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIiB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIj5yZWQsZ3JlZW4sYmx1ZTwvc2FtbDpBdHRyaWJ1dGVWYWx1ZT48L3NhbWw6QXR0cmlidXRlPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJsYXN0bmFtZSIgTmFtZUZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmF0dHJuYW1lLWZvcm1hdDp1bnNwZWNpZmllZCI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOnN0cmluZyIgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIiB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIj5MYXN0PC9zYW1sOkF0dHJpYnV0ZVZhbHVlPjwvc2FtbDpBdHRyaWJ1dGU+PC9zYW1sOkF0dHJpYnV0ZVN0YXRlbWVudD48L3NhbWw6QXNzZXJ0aW9uPjwvc2FtbHA6UmVzcG9uc2U+ ================================================ FILE: providertests/testdata/pingfed/pfed11_response_03.b64 ================================================ PHNhbWxwOlJlc3BvbnNlIFZlcnNpb249IjIuMCIgSUQ9IlZfbGJUdjVhbUJOM1dSeFU1c2ZDLl9RT0F1ViIgSXNzdWVJbnN0YW50PSIyMDE3LTA5LTAxVDIxOjI0OjQ2LjI2OFoiIEluUmVzcG9uc2VUbz0iXzVmZjRlZDIzLWJmMjItNDI4Ny04NWEzLThiNjQ5NDhhZDlmMCIgeG1sbnM6c2FtbHA9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpwcm90b2NvbCI+PHNhbWw6SXNzdWVyIHhtbG5zOnNhbWw9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPmh0dHBzOi8vc2FtbC50ZXN0Lm5vcGU6OTAzMS9laWQvc3hwbXJoYmt6bjwvc2FtbDpJc3N1ZXI+PHNhbWxwOlN0YXR1cz48c2FtbHA6U3RhdHVzQ29kZSBWYWx1ZT0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOnN0YXR1czpTdWNjZXNzIi8+PC9zYW1scDpTdGF0dXM+PHNhbWw6QXNzZXJ0aW9uIElEPSJYOXl4Y1NETFlneDktWnVicThkcEJRV2NlLWIiIElzc3VlSW5zdGFudD0iMjAxNy0wOS0wMVQyMToyNDo0Ni4yOThaIiBWZXJzaW9uPSIyLjAiIHhtbG5zOnNhbWw9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPjxzYW1sOklzc3Vlcj5odHRwczovL3NhbWwudGVzdC5ub3BlOjkwMzEvZWlkL3N4cG1yaGJrem48L3NhbWw6SXNzdWVyPjxkczpTaWduYXR1cmUgeG1sbnM6ZHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyMiPgo8ZHM6U2lnbmVkSW5mbz4KPGRzOkNhbm9uaWNhbGl6YXRpb25NZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzEwL3htbC1leGMtYzE0biMiLz4KPGRzOlNpZ25hdHVyZU1ldGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvMDQveG1sZHNpZy1tb3JlI3JzYS1zaGEyNTYiLz4KPGRzOlJlZmVyZW5jZSBVUkk9IiNYOXl4Y1NETFlneDktWnVicThkcEJRV2NlLWIiPgo8ZHM6VHJhbnNmb3Jtcz4KPGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyNlbnZlbG9wZWQtc2lnbmF0dXJlIi8+CjxkczpUcmFuc2Zvcm0gQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzEwL3htbC1leGMtYzE0biMiLz4KPC9kczpUcmFuc2Zvcm1zPgo8ZHM6RGlnZXN0TWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8wNC94bWxlbmMjc2hhMjU2Ii8+CjxkczpEaWdlc3RWYWx1ZT55eVA1d214WitGODZ2dUdnOUdPZzRqeGNFYWUzSW1RclFZOGxWb3BaajNJPTwvZHM6RGlnZXN0VmFsdWU+CjwvZHM6UmVmZXJlbmNlPgo8L2RzOlNpZ25lZEluZm8+CjxkczpTaWduYXR1cmVWYWx1ZT4KNElPdVpzYlEyYlNXa2Z4cXRDTEs5a1M0a1NGOGFiYTJZc1YrZ3JobGJ6NU1MeC85OWczREF0cHVleFFlZ0NGWWxXOEJIWStsaE1DVwp5cXkyTENwY1lDdzBLRnZwa0hybjZPaVVTWCtoOVhCM3dQZ29LRU5OOXBOMmo5c0ZkSWNPWkNBT0JadWI5eUVZRHhLWEUrOXNzTVY5CnZMcWl6bWxmbDFza1lqUVJKYUhEdEhldGN2UkM2VFdod1hLSmwxdWIwbHgyRmhtaUZidGZlOEcxTkNoWmNGSDNCejJKWTJjUXk0d2wKOCtjejAvUmpPVWVIMDhBT1VJdnBWVVRBSnZZM0s2dTdRekNEelU2czdrT1F4UE54K0tnZk9uQ1hETURwaEpNd3RDQkdmSGs4ZG4wTApHOUxSYmlZamwrUDcyUndtTm9Kd3NjRlE4RlErVjhiWmNDZ1Q3QT09CjwvZHM6U2lnbmF0dXJlVmFsdWU+CjwvZHM6U2lnbmF0dXJlPjxzYW1sOlN1YmplY3Q+PHNhbWw6TmFtZUlEIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6MS4xOm5hbWVpZC1mb3JtYXQ6ZW1haWxBZGRyZXNzIj5maXJzdGxhc3RAc2FtbC50ZXN0Lm5vcGU8L3NhbWw6TmFtZUlEPjxzYW1sOlN1YmplY3RDb25maXJtYXRpb24gTWV0aG9kPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6Y206YmVhcmVyIj48c2FtbDpTdWJqZWN0Q29uZmlybWF0aW9uRGF0YSBSZWNpcGllbnQ9Imh0dHBzOi8vc2FtbC50ZXN0Lm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9hY3MvaHAyNGRxbnB2cSIgTm90T25PckFmdGVyPSIyMDE3LTA5LTAxVDIxOjI5OjQ2LjMwMVoiIEluUmVzcG9uc2VUbz0iXzVmZjRlZDIzLWJmMjItNDI4Ny04NWEzLThiNjQ5NDhhZDlmMCIvPjwvc2FtbDpTdWJqZWN0Q29uZmlybWF0aW9uPjwvc2FtbDpTdWJqZWN0PjxzYW1sOkNvbmRpdGlvbnMgTm90QmVmb3JlPSIyMDE3LTA5LTAxVDIxOjE5OjQ2LjMwMVoiIE5vdE9uT3JBZnRlcj0iMjAxNy0wOS0wMVQyMToyOTo0Ni4zMDFaIj48c2FtbDpBdWRpZW5jZVJlc3RyaWN0aW9uPjxzYW1sOkF1ZGllbmNlPmh0dHBzOi8vc2FtbC50ZXN0Lm5vcGUvc2Vzc2lvbi9zc28vc2FtbC9zcGVudGl0eWlkL2hwMjRkcW5wdnE8L3NhbWw6QXVkaWVuY2U+PC9zYW1sOkF1ZGllbmNlUmVzdHJpY3Rpb24+PC9zYW1sOkNvbmRpdGlvbnM+PHNhbWw6QXV0aG5TdGF0ZW1lbnQgU2Vzc2lvbkluZGV4PSJYOXl4Y1NETFlneDktWnVicThkcEJRV2NlLWIiIEF1dGhuSW5zdGFudD0iMjAxNy0wOS0wMVQyMToyNDo0Ni4wMDBaIj48c2FtbDpBdXRobkNvbnRleHQ+PHNhbWw6QXV0aG5Db250ZXh0Q2xhc3NSZWY+dXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFjOmNsYXNzZXM6UGFzc3dvcmQ8L3NhbWw6QXV0aG5Db250ZXh0Q2xhc3NSZWY+PC9zYW1sOkF1dGhuQ29udGV4dD48L3NhbWw6QXV0aG5TdGF0ZW1lbnQ+PHNhbWw6QXR0cmlidXRlU3RhdGVtZW50PjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJmaXJzdG5hbWUiIE5hbWVGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphdHRybmFtZS1mb3JtYXQ6dW5zcGVjaWZpZWQiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czpzdHJpbmciIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSI+Rmlyc3Q8L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48c2FtbDpBdHRyaWJ1dGUgTmFtZT0iZ3JvdXAiIE5hbWVGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphdHRybmFtZS1mb3JtYXQ6dW5zcGVjaWZpZWQiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czpzdHJpbmciIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSI+cmVkLGdyZWVuLGJsdWU8L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48c2FtbDpBdHRyaWJ1dGUgTmFtZT0ibGFzdG5hbWUiIE5hbWVGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphdHRybmFtZS1mb3JtYXQ6dW5zcGVjaWZpZWQiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czpzdHJpbmciIHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSI+TGFzdDwvc2FtbDpBdHRyaWJ1dGVWYWx1ZT48L3NhbWw6QXR0cmlidXRlPjwvc2FtbDpBdHRyaWJ1dGVTdGF0ZW1lbnQ+PC9zYW1sOkFzc2VydGlvbj48L3NhbWxwOlJlc3BvbnNlPg== ================================================ FILE: providertests/testdata/pingfed/pfed11_response_05.b64 ================================================ <samlp:Response Version="2.0" ID="VeDr1FTHd6mtFTJifPSuH4YJTPF" IssueInstant="2017-09-03T01:22:57.594Z" InResponseTo="_f76c0eed-5023-4d82-9c2e-3bb760997fd1" Destination="https://saml.test.nope/session/sso/saml/acs/hp24dqnpvq" xmlns:samlp="urn:oasis:names:tc:SAML:2.0:protocol"><saml:Issuer xmlns:saml="urn:oasis:names:tc:SAML:2.0:assertion">https://saml.test.nope:9031/eid/sxpmrhbkzn</saml:Issuer><ds:Signature xmlns:ds="http://www.w3.org/2000/09/xmldsig#">
<ds:SignedInfo>
<ds:CanonicalizationMethod Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/>
<ds:SignatureMethod Algorithm="http://www.w3.org/2001/04/xmldsig-more#rsa-sha256"/>
<ds:Reference URI="#VeDr1FTHd6mtFTJifPSuH4YJTPF">
<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>IKxfOuL3MmckUi1tXQNXFjwp8M9dtZSOPN8qkf/2Jyw=</ds:DigestValue>
</ds:Reference>
</ds:SignedInfo>
<ds:SignatureValue>
zuoxr1lrqC/MU1J48ADWQ3WxncSB2ajDir0OVAJXdlu1Yz1d/0I3sRJ+bRsjVYGdLhTaCFtF7OOW
k6EK9IYv3pIeNfdrMFqCUMkfE6q1Cg4TLiu60cClldDYBZtq4+sKOBB0ZuYJJZG/ViKGKaXQkLv7
OCk9JkBBfTNTJ1r+Q4j2w5f8ybRr6xTopQJiyY0FcBfolESbVGNOorU4C0vFuNvA5CyE+zzOMo94
jwoWq9SUDPFUzAj8GkeQhWaVOKyWRFxFnl4obFzgDKYqVWZE0aCjw5f4VVIC2aN2HqpV53U6+qcc
MdcUWD35Zdc4n1HgkkHoABV4Iz8VFDRB/Al3GA==
</ds:SignatureValue>
<ds:KeyInfo>
<ds:X509Data>
<ds:X509Certificate>
MIIDPjCCAiagAwIBAgIJAMQeWnDJVaTyMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMRMw
EQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3QgTm9wZS4xFzAVBgNVBAMTDnNh
bWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oYDzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQG
EwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYD
VQQDEw5zYW1sLnRlc3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOwVVXE6
7dWFWQGnFyWLQyaAqco+hargHNq5DWTiQM5EG1GELt5QqW7XQJwgwfIHic7zMBDU13F6IUrh310g
Nm0Nygg7DWEREBNZvTdjg999pbRyt5IgeihKh5NEwpH9TGXnbow8QjI79AqsB9Irn0fEuLKb1KOF
0EMt5XqJnW2oqJrvTdYeGoi7Ckpg9J986XMqLMp48Gd9/ATo83GHsO7w+NKs0mAxB/Tffh6hrbIL
tMVMENQB6lv3dIrdmQqPGJ120xO6dmHqLTj+tNSjhkznSKXBDHT/7vGt3Ra38P6mGCKrDAloAz2X
dXJcdiY57PxeQvc0zwRtJtOxphA5WHMCAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEB
CwUAA4IBAQAQ2P9aUBaM1kC0XJF86A4aYkqRVuyspJT6+DOYA/pcifZ3zhpXPe2+TY2gKsGkqfYm
a7ch6dq4zVErFMwkn8qM7PD1knK/P8SZuUPC3LTH3ETH+beb1lM9NICOItkhu7RIwwwwhAZKP52/
Ww0F59PCv1SPZJ1NkF8XWak4Df8l4un4xsX1jcFkFlUxCDh6simdFOK3ibMHUZxyGbvK/MwJfKQm
Mcjo/fIaukv1/2tKXnilSDhQS1161yiX7ooFdD+y55KaGF5O50K/9DW30E9ZgrSDltD/6aGt17Vr
X5wnkoUb68CqYfUrRjhpbPYILGu96alI6+eLeIwZKpKSbMj4
</ds:X509Certificate>
</ds:X509Data>
</ds:KeyInfo>
</ds:Signature><samlp:Status><samlp:StatusCode Value="urn:oasis:names:tc:SAML:2.0:status:Success"/></samlp:Status><saml:EncryptedAssertion xmlns:saml="urn:oasis:names:tc:SAML:2.0:assertion"><xenc:EncryptedData Type="http://www.w3.org/2001/04/xmlenc#Element" xmlns:xenc="http://www.w3.org/2001/04/xmlenc#"><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes256-cbc"/><ds:KeyInfo xmlns:ds="http://www.w3.org/2000/09/xmldsig#">
<xenc:EncryptedKey><xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p"/><xenc:CipherData><xenc:CipherValue>Kg3MhEYiPl7YxNu87pHlEA3tERQFCGHT/GbjXiNQWh/sa26LEHcbk0NUDL6JMiP/F8D+q02E2XHr
b3SJqMcmflhtea+YEzfiBfvwL5hVkClAwP/T8kJyFfkIjHgP3bCPV5fE9VY5jVAaKNRqJ1WmVDFc
jWMTqkBnc8WB4hdPI9Nv0XxiipcU/yXmfiJc8PFOGh6bx/0ZSVPy2wHOvGRJNp+QycPnTUcU5MYB
+1+qJBUFWnxWD39qddlTEBvEYt/XNRvVgO8S1tCunOpqXa6G5RA7ehKgzl3Edt21D6gsTgFaKEXi
pmbVVS+q0fLnyF5R9c3qSas/pvFVF7Vy6i13xw==</xenc:CipherValue></xenc:CipherData></xenc:EncryptedKey></ds:KeyInfo><xenc:CipherData><xenc:CipherValue>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</xenc:CipherValue></xenc:CipherData></xenc:EncryptedData></saml:EncryptedAssertion></samlp:Response> ================================================ FILE: providertests/testdata/pingfed/sp.encryption.cert ================================================ -----BEGIN CERTIFICATE----- MIIDPjCCAiagAwIBAgIJAOvpZtJNtQ/rMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNV BAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3Qg Tm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgxNDAxNDg1N1oY DzIxMTYwMzA4MDE0ODU3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZv cm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRl c3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKfUlciwDPCJ 9JXy1NsxKfqyOfLQXFKKGgNKKRLzLAWO43GgQYrV67QaAny5LvgOa81KQOX4IvjJ y0nd/VrO6jG9pTdMR9vFHT0Tu3W1QUsyPPSQqpKXwb2ZCSXNghYD5gBrNtmOxAOs 1Azx5qmIzBJ4F0RkRivcdbXSfBUBLpCn1M285c4tk5SEvoRgBeisLJJDB7hmylA1 V6/+BN+N6b3M+ZZG//CTvOjJKgnwkMALzXbPbQWa0kpbMLDMz8Kr2pODLKb3rGmd f4P6A9aA41k6L4clTsNdcK7ZwJ2fGF79WGzE6RLyBX2US3gPHUXt/WMQZXyULO3e xiTDsQXWFf8CAwEAAaMPMA0wCwYDVR0PBAQDAgQQMA0GCSqGSIb3DQEBCwUAA4IB AQB3fQZz2qNAo/wohPNaR2uAakLt25cKrsbgn3XwO+X+DRH4nqMSZkHdLGr82xD3 i33BLSQwXzFecEN+CA8SlpNoIXHwk6D6V3uEBSjKemZtJFCJqe8d+5qt3GV50AKm tEt2Nc7B94TN8xB5EmZladnTJWcBgSuuz1hLXQQ02dJ3dDq8FMlyR70S2DTtuPu0 i2/f6KtrlmmNsU24Aq+fCzEG43NqShOMeM5rDxLsSJCtjfMRwG8YeyNf6cCMSMxY AJfrTyj+AS8RtZQNGF7tX+exEWHOf1C9CBzHtKRClBRL6zDjlpPCIDwcMFi8NXva iVclxIq3XdfqxiGBBEldkhgZ -----END CERTIFICATE----- ================================================ FILE: providertests/testdata/pingfed/sp.encryption.key ================================================ -----BEGIN PRIVATE KEY----- MIIEvAIBADANBgkqhkiG9w0BAQEFAASCBKYwggSiAgEAAoIBAQCn1JXIsAzwifSV 8tTbMSn6sjny0FxSihoDSikS8ywFjuNxoEGK1eu0GgJ8uS74DmvNSkDl+CL4yctJ 3f1azuoxvaU3TEfbxR09E7t1tUFLMjz0kKqSl8G9mQklzYIWA+YAazbZjsQDrNQM 8eapiMwSeBdEZEYr3HW10nwVAS6Qp9TNvOXOLZOUhL6EYAXorCySQwe4ZspQNVev /gTfjem9zPmWRv/wk7zoySoJ8JDAC812z20FmtJKWzCwzM/Cq9qTgyym96xpnX+D +gPWgONZOi+HJU7DXXCu2cCdnxhe/VhsxOkS8gV9lEt4Dx1F7f1jEGV8lCzt3sYk w7EF1hX/AgMBAAECggEATD8qZWiGGGm0csNFrOdjGQALj6LVrrILK19v1aogX84Q yrhxzm9ti/8dDijbi9qRY0zOuyvGR5z1/HMb/Ttv7nUoMD05kEC3Dd5/FfTo2w7R 3pIyzDKh1E9IdqIs7W+L+Li8zI4twzWriM4FaxQ5ElL4zxt3PcoEuDwOH0TQMOsy P2gLEhzzkFp7TRoKzR87sM6lXoERsGKh7XNWjjS15/w+XHMaDverOOALwWDbv32N UCdVSAGBx4Ic4mZuJv+e3MH2SAja0J6NLMzCMtrzmfcgVECykMnELi1XftZYbgD+ KulSvHuamygS4KJppnAdly8950C8CxI7fp9QJV/8UQKBgQDUaT68z9e203L/XATr sa9CgZodWvjrLH7a2e5EvUPq8slmg2VqEYNjHzP4rCoOcLul6TwrlNInxqTIkIPR mRxBSrG24azfGRrOs34IMTXgqfMVVxbcSVK8OijHs94NTwYrRjMXeaAOnKjPH484 DALrEoEGcrjXmDDKBV9rb+a5XQKBgQDKRVkUvCoILjsA3jG6qaKBwKSZBFla2o6x YxgOZdeSG2NEuMt74yRHjgV6iogpvw9i/FSY9TAaZsoX0L3I5LWRtwEi3iXtEC9X qFlS9EPr9encpdd2vu1O6aWXW4IlUWbu3ecdb5UAxu44ObUQS6HiXEfcK8vufF5l WyilXNerCwKBgAMYYYSo1rDgVe2orp2soiwq7U7+M2Bh7ptLz7AKvgGfdhXbVk/8 X1jDbKN0BszdEa7yPiE4cvOHboFJsdINFB9TclGC6lz55a0banu+E9XpRBSMh1XA b8c0ZcG7OkIhY6qfxEDUUePEnqUeBZ1Ad45rX5vzcgQaQKPA/kn3gHo1AoGAU/05 wSdk2KLBs1mQEq9PoEsqzbMFm3k3WScJnSjiu3ON48JMFDQ8I04wrjKJ2bPRIswe IKlnAP9/mSX/OETntArmeOD/pJFc5ywrcwukjH0/T3S5pEAhb+wK629++hn0AOm5 hvqHR5xS3JvxuEN/g+vHlv/EnVGdLL8OgKOtlgMCgYBU/5WF/7dr89uYzjiBvedh HQCgwd+8aSs+raY5eTzJrJgqVbEMoxhco1GWzWYUjDVw88Y63k+fqIf1DQJFkWFi 9T1nppVDeofoLDLTrh/2oTAHIM2QL6kWwoHiD7b/scF5z/rC21KqobqroAh2R0CP J2waRoJgqT+P15Lq3PEcSA== -----END PRIVATE KEY----- ================================================ FILE: providertests/testdata/pingfed/sp.signing.cert ================================================ -----BEGIN CERTIFICATE----- MIIDPjCCAiagAwIBAgIJAKHPtM2MqZxXMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNV BAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRgwFgYDVQQKEw9TQU1MIFRlc3Qg Tm9wZS4xFzAVBgNVBAMTDnNhbWwudGVzdC5ub3BlMCAXDTE3MDgwODE3NDIyN1oY DzIxMTcwNzE1MTc0MjI3WjBVMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZv cm5pYTEYMBYGA1UEChMPU0FNTCBUZXN0IE5vcGUuMRcwFQYDVQQDEw5zYW1sLnRl c3Qubm9wZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBALWw8EP/dSG0 yy7cL2sQvcRqiTrsVCWzQ5SGgZNGbFJXq36pshZ21H7gFPI/K2n6m4I3vNMCQtRJ JwfjyrPbuXpVaTMcmg8J3PGUVzaab+dZ28EQ7V9HEnzcVbEgu87xY/SB6SCiJbdI COZWlsgLUkgZS9CFkw5q6i29nL6nSZw/MmNr1hjJWvVvs1KwnGjB2aF6wYBQKKsY GxfZTJqKKBGXwIB5qnaWpVQgP6+H/84YCHLUEKk1hgh9AnR1xNVE6e64clcAE+O/ HWDS6QW658TJsw18TapzVbiUGou4TlxJZqEuJv3BfPX3EMsnp0uRurMtwgyzI/ZP CCHxSMJs4xECAwEAAaMPMA0wCwYDVR0PBAQDAgeAMA0GCSqGSIb3DQEBCwUAA4IB AQBRwSaE1AnhZU/GzMngLSG6WsOp1NksoEHZsJoIKxUJWdMj9s0Pb/QSGg/W/2UU CREt6xBd9rh3jv17AwH6+IAvq/zQn36UtOE0/0v85Tp/I6t8v96cTjkEgDHBWSqw qfPvnrokKUpDRv1cxCL0qh4oW7selKkI0VpZOgpKm87oi6POQJ/KOMfcewlH+DXt zN3Es8Xp8BAfRRIEk7i3PqZSrhWUguQgCOAOvkb0tGuPDsFLLJJBML7B7aYrS1Kw EyuowZiDCDSk49KpGOmKYv2ocIG65gr7+am/l2NN+6cxuCf/o9H8UL8qm0LUJdgh 5sVa0DJzIcuOjWsp2QxqTjr/ -----END CERTIFICATE----- ================================================ FILE: providertests/testdata/pingfed/sp.signing.key ================================================ -----BEGIN PRIVATE KEY----- MIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQC1sPBD/3UhtMsu 3C9rEL3Eaok67FQls0OUhoGTRmxSV6t+qbIWdtR+4BTyPytp+puCN7zTAkLUSScH 48qz27l6VWkzHJoPCdzxlFc2mm/nWdvBEO1fRxJ83FWxILvO8WP0gekgoiW3SAjm VpbIC1JIGUvQhZMOauotvZy+p0mcPzJja9YYyVr1b7NSsJxowdmhesGAUCirGBsX 2UyaiigRl8CAeap2lqVUID+vh//OGAhy1BCpNYYIfQJ0dcTVROnuuHJXABPjvx1g 0ukFuufEybMNfE2qc1W4lBqLuE5cSWahLib9wXz19xDLJ6dLkbqzLcIMsyP2Twgh 8UjCbOMRAgMBAAECggEAA/py2FpQm0NVK5qAo0yDizh19sdT9FtfgHINhkcFeiwX Qje/AYTqlDid3MwLTE/Dde94f/pNsk5Dv4V6W8PU5NvX6NmYefnST6va2QQ6rQsn p6uSNwLcYcWFTtKTqi1Y7fKmQyOpxcCbCUgeFxVAYPnE0jUKikdHB2dedkI9d2FV ZMSBAlNp5NQQTTojjdvfa3yxFqB/5Gh+tZZnnXm0BmtSHjWvXnpi62Nz8LHtKwtO qzS6650vhbC8GyuILeBkEa0Zvw2aUhRI0grCjWsbXJT66FrV+pIElOAQvyHP6hlX zC43ODdXSiFogVkF07umlqmopv4gDLgst8fjY61VfQKBgQDpVytmVrNXI9A2uDv/ 0RhCZpmBMgz8o3OQY0KRtZqupeVUGCTKk0zNqxsvUg31fa+DLYu+fYUDRVy58ST7 vTiXjKYllWY5LAacsqtA/1E4BghOuYfU12tGJcOUM1TZNkQ/s2to/fDL0HTjYX6T STqxoyg9zCnSYpF+u7gj91QuywKBgQDHVcUGiL69Tws3J6riKvFBtqrqcJaRu5OS t/U+kqM1m5/GOaBpZyropeusQgb/nZHIE/lEur7CHYcTi8PKF2lGxnqWOn31LVrc rM11r2pweDpCBBQqytNoE9vUzgfueXbPPgl+l1pTDA02u6EE45IHC1bPPbjDx29/ xhfAykD+EwKBgQCrVA3Rvqc/vFQNWYj0dJrTZnIfophWh806nycpxaYlxjl0XaXl 9/HUsWXsgNsu/XH5Z1/MJm2b0TocbSsyi+UZoXP89I1yPRk9xRJpTw5bjFJdO2y4 otNpViEcl/Qc6PODskGTfaFohU7OBa/ihUpLU/kgJuAuUaFy5HJ4NgnhsQKBgQCm q/K4SfKiu8r27TYXMizT83bp3AYqCJuWHDb1gQryshNgXaLhPyBDsyhhuju70/an Qvw0GamTCbl+AGlPO1ANm7u4jWPwc2H8DoklE+196SldNaffOASYi7JON4+uOOW8 13R84vTlZ7hMwYobWmUperO1STiKiuGSBwKpcvPw/QKBgBgqByvETHwewxnYoIsp yn3Fz1KM7MMnRil2sXVTdpS6lpF+iGs7iXc8sBnWKxFFQWnvvx6VvhXw6lCCnEQX 3LH177jH+s0jVQgD+YZLnYDBF347tU7W/dPz5Df7hgmuQhOU/UV9ihm4udutRFbR 4fd3j6wIcv2MZ0iDUVJ0UFYr -----END PRIVATE KEY----- ================================================ FILE: providertests/testdata/saml.oktadev.com/oktadev.pem ================================================ -----BEGIN CERTIFICATE----- MIIDPDCCAiQCCQDydJgOlszqbzANBgkqhkiG9w0BAQUFADBgMQswCQYDVQQGEwJV UzETMBEGA1UECBMKQ2FsaWZvcm5pYTEWMBQGA1UEBxMNU2FuIEZyYW5jaXNjbzEQ MA4GA1UEChMHSmFua3lDbzESMBAGA1UEAxMJbG9jYWxob3N0MB4XDTE0MDMxMjE5 NDYzM1oXDTI3MTExOTE5NDYzM1owYDELMAkGA1UEBhMCVVMxEzARBgNVBAgTCkNh bGlmb3JuaWExFjAUBgNVBAcTDVNhbiBGcmFuY2lzY28xEDAOBgNVBAoTB0phbmt5 Q28xEjAQBgNVBAMTCWxvY2FsaG9zdDCCASIwDQYJKoZIhvcNAQEBBQADggEPADCC AQoCggEBAMGvJpRTTasRUSPqcbqCG+ZnTAurnu0vVpIG9lzExnh11o/BGmzu7lB+ yLHcEdwrKBBmpepDBPCYxpVajvuEhZdKFx/Fdy6j5mH3rrW0Bh/zd36CoUNjbbhH yTjeM7FN2yF3u9lcyubuvOzr3B3gX66IwJlU46+wzcQVhSOlMk2tXR+fIKQExFrO uK9tbX3JIBUqItpI+HnAow509CnM134svw8PTFLkR6/CcMqnDfDK1m993PyoC1Y+ N4X9XkhSmEQoAlAHPI5LHrvuujM13nvtoVYvKYoj7ScgumkpWNEvX652LfXOnKYl kB8ZybuxmFfIkzedQrbJsyOhfL03cMECAwEAATANBgkqhkiG9w0BAQUFAAOCAQEA eHwzqwnzGEkxjzSD47imXaTqtYyETZow7XwBc0ZaFS50qRFJUgKTAmKS1xQBP/qH pStsROT35DUxJAE6NY1Kbq3ZbCuhGoSlY0L7VzVT5tpu4EY8+Dq/u2EjRmmhoL7U kskvIZ2n1DdERtd+YUMTeqYl9co43csZwDno/IKomeN5qaPc39IZjikJ+nUC6kPF Keu/3j9rgHNlRtocI6S1FdtFz9OZMQlpr0JbUt2T3xS/YoQJn6coDmJL5GTiiKM6 cOe+Ur1VwzS1JEDbSS2TWWhzq8ojLdrotYLGd9JOsoQhElmz+tMfCFQUFLExinPA yy7YHlSiVX13QH2XTu/iQQ== -----END CERTIFICATE----- ================================================ FILE: providertests/testdata/saml.oktadev.com/response_0 ================================================ PHNhbWxwOlJlc3BvbnNlIHhtbG5zOnNhbWxwPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiIElEPSJfZDczMWM3YTQ2NGMwODZmMDJjNzEiICBWZXJzaW9uPSIyLjAiIElzc3VlSW5zdGFudD0iMjAxNy0wNC0wNFQxNjo1NDoxMloiICBEZXN0aW5hdGlvbj0iaHR0cDovL2RiYTlhNWZjLm5ncm9rLmlvL3YxL19zYW1sX2NhbGxiYWNrIj48c2FtbDpJc3N1ZXIgeG1sbnM6c2FtbD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiI+aHR0cDovL2V4YW1wbGUuY29tL3NhbWwvYWNzL2V4YW1wbGU8L3NhbWw6SXNzdWVyPjxzYW1scDpTdGF0dXM+PHNhbWxwOlN0YXR1c0NvZGUgVmFsdWU9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpzdGF0dXM6U3VjY2VzcyIvPjwvc2FtbHA6U3RhdHVzPjxzYW1sOkFzc2VydGlvbiB4bWxuczpzYW1sPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIiBWZXJzaW9uPSIyLjAiIElEPSJfRXBmS2RGYjlzTHJlRGVld2JMdzBCUDRsbzZYV1h2cDgiIElzc3VlSW5zdGFudD0iMjAxNy0wNC0wNFQxNjo1NDoxMi4xNzFaIj48c2FtbDpJc3N1ZXI+aHR0cDovL2V4YW1wbGUuY29tL3NhbWwvYWNzL2V4YW1wbGU8L3NhbWw6SXNzdWVyPjxTaWduYXR1cmUgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyMiPjxTaWduZWRJbmZvPjxDYW5vbmljYWxpemF0aW9uTWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8xMC94bWwtZXhjLWMxNG4jIi8+PFNpZ25hdHVyZU1ldGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyNyc2Etc2hhMSIvPjxSZWZlcmVuY2UgVVJJPSIjX0VwZktkRmI5c0xyZURlZXdiTHcwQlA0bG82WFdYdnA4Ij48VHJhbnNmb3Jtcz48VHJhbnNmb3JtIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8wOS94bWxkc2lnI2VudmVsb3BlZC1zaWduYXR1cmUiLz48VHJhbnNmb3JtIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8xMC94bWwtZXhjLWMxNG4jIi8+PC9UcmFuc2Zvcm1zPjxEaWdlc3RNZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjc2hhMSIvPjxEaWdlc3RWYWx1ZT4zS245NjlUam9taldsWm5MQ3pWeDc2Yk1jTjA9PC9EaWdlc3RWYWx1ZT48L1JlZmVyZW5jZT48L1NpZ25lZEluZm8+PFNpZ25hdHVyZVZhbHVlPkp2ZlJLU0ZmaTc3WDdzalZsbGZRYWtOQmJ6NDJWZHErdzk0YzA4OVd0OUFDdWhyZWZ4Q094TTNtN08xOTlOSisrMnZyd2FIZHd4TmtDNVdTWk5JZVRSMWg0VWZGamhKSkFWL3N4ak5jZU5CTDZybFFITVZlNlV1aU95L0Z6S21XTEZObmd2TjRJdXpuN3B0ZTNhcVBIeE9mSC8ycjhsTnBBNm9hOWhJRm1uNzJDL2FteVlSVWF1a3EzT1NOOE1SUTNBaGowZ1U3U1kzdzNXWkp1anlpaGphNHloMitEZnd5bjBUdGx6ZEJMK2dGMzFGOXBSUlZucW1UbTcwM3pRNTM1RGRGSjE4RjJXcU1yR3B0MjUxZEVIYUFidG1GVm0yOGNocElnZStBa0VpL0lMSVlKbXF3dEN6amMyY21GS0QvdEg4a3lTMnpwb0U1WEFVd0xlTENVUT09PC9TaWduYXR1cmVWYWx1ZT48S2V5SW5mbz48WDUwOURhdGE+PFg1MDlDZXJ0aWZpY2F0ZT5NSUlEUERDQ0FpUUNDUUR5ZEpnT2xzenFiekFOQmdrcWhraUc5dzBCQVFVRkFEQmdNUXN3Q1FZRFZRUUdFd0pWVXpFVE1CRUdBMVVFQ0JNS1EyRnNhV1p2Y201cFlURVdNQlFHQTFVRUJ4TU5VMkZ1SUVaeVlXNWphWE5qYnpFUU1BNEdBMVVFQ2hNSFNtRnVhM2xEYnpFU01CQUdBMVVFQXhNSmJHOWpZV3hvYjNOME1CNFhEVEUwTURNeE1qRTVORFl6TTFvWERUSTNNVEV4T1RFNU5EWXpNMW93WURFTE1Ba0dBMVVFQmhNQ1ZWTXhFekFSQmdOVkJBZ1RDa05oYkdsbWIzSnVhV0V4RmpBVUJnTlZCQWNURFZOaGJpQkdjbUZ1WTJselkyOHhFREFPQmdOVkJBb1RCMHBoYm10NVEyOHhFakFRQmdOVkJBTVRDV3h2WTJGc2FHOXpkRENDQVNJd0RRWUpLb1pJaHZjTkFRRUJCUUFEZ2dFUEFEQ0NBUW9DZ2dFQkFNR3ZKcFJUVGFzUlVTUHFjYnFDRytablRBdXJudTB2VnBJRzlsekV4bmgxMW8vQkdtenU3bEIreUxIY0Vkd3JLQkJtcGVwREJQQ1l4cFZhanZ1RWhaZEtGeC9GZHk2ajVtSDNyclcwQmgvemQzNkNvVU5qYmJoSHlUamVNN0ZOMnlGM3U5bGN5dWJ1dk96cjNCM2dYNjZJd0psVTQ2K3d6Y1FWaFNPbE1rMnRYUitmSUtRRXhGck91Szl0YlgzSklCVXFJdHBJK0huQW93NTA5Q25NMTM0c3Z3OFBURkxrUjYvQ2NNcW5EZkRLMW05OTNQeW9DMVkrTjRYOVhraFNtRVFvQWxBSFBJNUxIcnZ1dWpNMTNudnRvVll2S1lvajdTY2d1bWtwV05Fdlg2NTJMZlhPbktZbGtCOFp5YnV4bUZmSWt6ZWRRcmJKc3lPaGZMMDNjTUVDQXdFQUFUQU5CZ2txaGtpRzl3MEJBUVVGQUFPQ0FRRUFlSHd6cXduekdFa3hqelNENDdpbVhhVHF0WXlFVFpvdzdYd0JjMFphRlM1MHFSRkpVZ0tUQW1LUzF4UUJQL3FIcFN0c1JPVDM1RFV4SkFFNk5ZMUticTNaYkN1aEdvU2xZMEw3VnpWVDV0cHU0RVk4K0RxL3UyRWpSbW1ob0w3VWtza3ZJWjJuMURkRVJ0ZCtZVU1UZXFZbDljbzQzY3Nad0Ruby9JS29tZU41cWFQYzM5SVpqaWtKK25VQzZrUEZLZXUvM2o5cmdITmxSdG9jSTZTMUZkdEZ6OU9aTVFscHIwSmJVdDJUM3hTL1lvUUpuNmNvRG1KTDVHVGlpS002Y09lK1VyMVZ3elMxSkVEYlNTMlRXV2h6cThvakxkcm90WUxHZDlKT3NvUWhFbG16K3RNZkNGUVVGTEV4aW5QQXl5N1lIbFNpVlgxM1FIMlhUdS9pUVE9PTwvWDUwOUNlcnRpZmljYXRlPjwvWDUwOURhdGE+PC9LZXlJbmZvPjwvU2lnbmF0dXJlPjxzYW1sOlN1YmplY3Q+PHNhbWw6TmFtZUlEIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6MS4xOm5hbWVpZC1mb3JtYXQ6dW5zcGVjaWZpZWQiPmphbmUuZG9lQGV4YW1wbGUuY29tPC9zYW1sOk5hbWVJRD48c2FtbDpTdWJqZWN0Q29uZmlybWF0aW9uIE1ldGhvZD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmNtOmJlYXJlciI+PHNhbWw6U3ViamVjdENvbmZpcm1hdGlvbkRhdGEgTm90T25PckFmdGVyPSIyMDE3LTA0LTA0VDE3OjU0OjEyLjE3MVoiIFJlY2lwaWVudD0iaHR0cDovL2RiYTlhNWZjLm5ncm9rLmlvL3YxL19zYW1sX2NhbGxiYWNrIi8+PC9zYW1sOlN1YmplY3RDb25maXJtYXRpb24+PC9zYW1sOlN1YmplY3Q+PHNhbWw6Q29uZGl0aW9ucyBOb3RCZWZvcmU9IjIwMTctMDQtMDRUMTY6NTQ6MTIuMTcxWiIgTm90T25PckFmdGVyPSIyMDE3LTA0LTA0VDE3OjU0OjEyLjE3MVoiPjxzYW1sOkF1ZGllbmNlUmVzdHJpY3Rpb24+PHNhbWw6QXVkaWVuY2U+aHR0cDovL2V4YW1wbGUuY29tL3NhbWwvYWNzL2V4YW1wbGU8L3NhbWw6QXVkaWVuY2U+PC9zYW1sOkF1ZGllbmNlUmVzdHJpY3Rpb24+PC9zYW1sOkNvbmRpdGlvbnM+PHNhbWw6QXR0cmlidXRlU3RhdGVtZW50IHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSI+PHNhbWw6QXR0cmlidXRlIE5hbWU9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjEuMTpuYW1laWQtZm9ybWF0OmVtYWlsQWRkcmVzcyI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOmFueVR5cGUiPmphbmUuZG9lQGV4YW1wbGUuY29tPC9zYW1sOkF0dHJpYnV0ZVZhbHVlPjwvc2FtbDpBdHRyaWJ1dGU+PHNhbWw6QXR0cmlidXRlIE5hbWU9IkVtYWlsIj48c2FtbDpBdHRyaWJ1dGVWYWx1ZSB4c2k6dHlwZT0ieHM6YW55VHlwZSI+amFuZS5kb2VAZXhhbXBsZS5jb208L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48c2FtbDpBdHRyaWJ1dGUgTmFtZT0iRmlyc3ROYW1lIj48c2FtbDpBdHRyaWJ1dGVWYWx1ZSB4c2k6dHlwZT0ieHM6YW55VHlwZSI+SmFuZTwvc2FtbDpBdHRyaWJ1dGVWYWx1ZT48L3NhbWw6QXR0cmlidXRlPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJMYXN0TmFtZSI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOmFueVR5cGUiPkRvZTwvc2FtbDpBdHRyaWJ1dGVWYWx1ZT48L3NhbWw6QXR0cmlidXRlPjwvc2FtbDpBdHRyaWJ1dGVTdGF0ZW1lbnQ+PHNhbWw6QXV0aG5TdGF0ZW1lbnQgQXV0aG5JbnN0YW50PSIyMDE3LTA0LTA0VDE2OjU0OjEyLjE3MVoiPjxzYW1sOkF1dGhuQ29udGV4dD48c2FtbDpBdXRobkNvbnRleHRDbGFzc1JlZj51cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YWM6Y2xhc3Nlczp1bnNwZWNpZmllZDwvc2FtbDpBdXRobkNvbnRleHRDbGFzc1JlZj48L3NhbWw6QXV0aG5Db250ZXh0Pjwvc2FtbDpBdXRoblN0YXRlbWVudD48L3NhbWw6QXNzZXJ0aW9uPjwvc2FtbHA6UmVzcG9uc2U+ ================================================ FILE: providertests/testdata/saml.oktadev.com/response_1 ================================================ PHNhbWxwOlJlc3BvbnNlIHhtbG5zOnNhbWxwPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiIElEPSJfYjUyYjhhMjdhMmUwMWJiYTIyMzEiIFZlcnNpb249IjIuMCIgSXNzdWVJbnN0YW50PSIyMDE3LTA0LTA0VDE2OjU0OjEyWiIgRGVzdGluYXRpb249Imh0dHA6Ly9kYmE5YTVmYy5uZ3Jvay5pby92MS9fc2FtbF9jYWxsYmFjayI+PHNhbWw6SXNzdWVyIHhtbG5zOnNhbWw9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPmh0dHA6Ly9leGFtcGxlLmNvbS9zYW1sL2Fjcy9leGFtcGxlPC9zYW1sOklzc3Vlcj48c2FtbHA6U3RhdHVzPjxzYW1scDpTdGF0dXNDb2RlIFZhbHVlPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6c3RhdHVzOlN1Y2Nlc3MiLz48L3NhbWxwOlN0YXR1cz48c2FtbDpBc3NlcnRpb24geG1sbnM6c2FtbD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiIgVmVyc2lvbj0iMi4wIiBJRD0iX3czdWNOM3h4bTJEc3BEQkh5c1phQVNkVkRRREZxREJuIiBJc3N1ZUluc3RhbnQ9IjIwMTctMDQtMDRUMTY6NTQ6MTIuOTQ3WiI+PHNhbWw6SXNzdWVyPmh0dHA6Ly9leGFtcGxlLmNvbS9zYW1sL2Fjcy9leGFtcGxlPC9zYW1sOklzc3Vlcj48c2FtbDpTdWJqZWN0PjxzYW1sOk5hbWVJRCBGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjEuMTpuYW1laWQtZm9ybWF0OnVuc3BlY2lmaWVkIj5qYW5lLmRvZUBleGFtcGxlLmNvbTwvc2FtbDpOYW1lSUQ+PHNhbWw6U3ViamVjdENvbmZpcm1hdGlvbiBNZXRob2Q9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpjbTpiZWFyZXIiPjxzYW1sOlN1YmplY3RDb25maXJtYXRpb25EYXRhIE5vdE9uT3JBZnRlcj0iMjAxNy0wNC0wNFQxNzo1NDoxMi45NDdaIiBSZWNpcGllbnQ9Imh0dHA6Ly9kYmE5YTVmYy5uZ3Jvay5pby92MS9fc2FtbF9jYWxsYmFjayIvPjwvc2FtbDpTdWJqZWN0Q29uZmlybWF0aW9uPjwvc2FtbDpTdWJqZWN0PjxzYW1sOkNvbmRpdGlvbnMgTm90QmVmb3JlPSIyMDE3LTA0LTA0VDE2OjU0OjEyLjk0N1oiIE5vdE9uT3JBZnRlcj0iMjAxNy0wNC0wNFQxNzo1NDoxMi45NDdaIj48c2FtbDpBdWRpZW5jZVJlc3RyaWN0aW9uPjxzYW1sOkF1ZGllbmNlPmh0dHA6Ly9leGFtcGxlLmNvbS9zYW1sL2Fjcy9leGFtcGxlPC9zYW1sOkF1ZGllbmNlPjwvc2FtbDpBdWRpZW5jZVJlc3RyaWN0aW9uPjwvc2FtbDpDb25kaXRpb25zPjxzYW1sOkF0dHJpYnV0ZVN0YXRlbWVudCB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEtaW5zdGFuY2UiPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoxLjE6bmFtZWlkLWZvcm1hdDplbWFpbEFkZHJlc3MiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czphbnlUeXBlIj5qYW5lLmRvZUBleGFtcGxlLmNvbTwvc2FtbDpBdHRyaWJ1dGVWYWx1ZT48L3NhbWw6QXR0cmlidXRlPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJFbWFpbCI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOmFueVR5cGUiPmphbmUuZG9lQGV4YW1wbGUuY29tPC9zYW1sOkF0dHJpYnV0ZVZhbHVlPjwvc2FtbDpBdHRyaWJ1dGU+PHNhbWw6QXR0cmlidXRlIE5hbWU9IkZpcnN0TmFtZSI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOmFueVR5cGUiPkphbmU8L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48c2FtbDpBdHRyaWJ1dGUgTmFtZT0iTGFzdE5hbWUiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czphbnlUeXBlIj5Eb2U8L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48L3NhbWw6QXR0cmlidXRlU3RhdGVtZW50PjxzYW1sOkF1dGhuU3RhdGVtZW50IEF1dGhuSW5zdGFudD0iMjAxNy0wNC0wNFQxNjo1NDoxMi45NDdaIj48c2FtbDpBdXRobkNvbnRleHQ+PHNhbWw6QXV0aG5Db250ZXh0Q2xhc3NSZWY+dXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFjOmNsYXNzZXM6dW5zcGVjaWZpZWQ8L3NhbWw6QXV0aG5Db250ZXh0Q2xhc3NSZWY+PC9zYW1sOkF1dGhuQ29udGV4dD48L3NhbWw6QXV0aG5TdGF0ZW1lbnQ+PC9zYW1sOkFzc2VydGlvbj48L3NhbWxwOlJlc3BvbnNlPg== ================================================ FILE: providertests/testdata/saml.oktadev.com/response_10 ================================================ PHNhbWxwOlJlc3BvbnNlIHhtbG5zOnNhbWxwPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiIElEPSJfZTNlYjNjODQ4NjFhY2JjYjhiZmYiIFZlcnNpb249IjIuMCIgSXNzdWVJbnN0YW50PSIyMDE3LTA0LTA0VDE2OjU0OjE3WiIgRGVzdGluYXRpb249Imh0dHA6Ly9kYmE5YTVmYy5uZ3Jvay5pby92MS9fc2FtbF9jYWxsYmFjayI+PHNhbWw6SXNzdWVyIHhtbG5zOnNhbWw9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPmh0dHA6Ly9leGFtcGxlLmNvbS9zYW1sL2Fjcy9leGFtcGxlPC9zYW1sOklzc3Vlcj48ZHM6U2lnbmF0dXJlIHhtbG5zOmRzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjIj48ZHM6U2lnbmVkSW5mbz48ZHM6Q2Fub25pY2FsaXphdGlvbk1ldGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDYvMTIveG1sLWMxNG4xMSIvPjxkczpTaWduYXR1cmVNZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzA0L3htbGRzaWctbW9yZSNyc2Etc2hhMjU2Ii8+PGRzOlJlZmVyZW5jZSBVUkk9IiI+PGRzOlRyYW5zZm9ybXM+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyNlbnZlbG9wZWQtc2lnbmF0dXJlIi8+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDYvMTIveG1sLWMxNG4xMSIvPjwvZHM6VHJhbnNmb3Jtcz48ZHM6RGlnZXN0TWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8wNC94bWxlbmMjc2hhMjU2Ii8+PGRzOkRpZ2VzdFZhbHVlPjFpTVhWS01QNUJKUEpFTWQzK2piY0NMZFV4aG1YeUNpZHJFeWIvL0E3MW89PC9kczpEaWdlc3RWYWx1ZT48L2RzOlJlZmVyZW5jZT48L2RzOlNpZ25lZEluZm8+PGRzOlNpZ25hdHVyZVZhbHVlPlpIK1NZQUNnY2dhSVdVbk9XanI1TU54SjZHRlM1UFdyQ1FybWMyQkxORDZDRXBHcTlCbDVIVHdZcXI2WjZyemszNzJsZmIzaWxydTloZ3dVZmZ5dDEwTlk0bC9WbEtKSFhYdjl4b081UFVKbmQwa1owTjZaQ3RXV2xsNTRlbEszNDllT0h5RFk4NnRUVXZGYUd6UlpIMkZyTXFhMWJKUWtGbXRpaXZkN29RRVMrMy9ZWXhEUGlnTXd5OVZ2RkxpeEw1R05UdTFaL3lWMnFxRU5oelVhY2g0RUVLdXRwc1NTZzFYVURTbWRBMm9BcW5FMlI2SXlPeUsrQVU2bDRrNjM2R01aczNYMU5INmdCcnUrWjMrYjBOdCtQRzAxMENjdVFPUlhUaEN1eWlxWUF1dERKeklGQXAwL1BVQ0xCR3pWR0ZtRTZJenRZVDM5Sk1WS21JT2t4dz09PC9kczpTaWduYXR1cmVWYWx1ZT48ZHM6S2V5SW5mbz48ZHM6WDUwOURhdGE+PGRzOlg1MDlDZXJ0aWZpY2F0ZT5NSUlEUERDQ0FpUUNDUUR5ZEpnT2xzenFiekFOQmdrcWhraUc5dzBCQVFVRkFEQmdNUXN3Q1FZRFZRUUdFd0pWVXpFVE1CRUdBMVVFQ0JNS1EyRnNhV1p2Y201cFlURVdNQlFHQTFVRUJ4TU5VMkZ1SUVaeVlXNWphWE5qYnpFUU1BNEdBMVVFQ2hNSFNtRnVhM2xEYnpFU01CQUdBMVVFQXhNSmJHOWpZV3hvYjNOME1CNFhEVEUwTURNeE1qRTVORFl6TTFvWERUSTNNVEV4T1RFNU5EWXpNMW93WURFTE1Ba0dBMVVFQmhNQ1ZWTXhFekFSQmdOVkJBZ1RDa05oYkdsbWIzSnVhV0V4RmpBVUJnTlZCQWNURFZOaGJpQkdjbUZ1WTJselkyOHhFREFPQmdOVkJBb1RCMHBoYm10NVEyOHhFakFRQmdOVkJBTVRDV3h2WTJGc2FHOXpkRENDQVNJd0RRWUpLb1pJaHZjTkFRRUJCUUFEZ2dFUEFEQ0NBUW9DZ2dFQkFNR3ZKcFJUVGFzUlVTUHFjYnFDRytablRBdXJudTB2VnBJRzlsekV4bmgxMW8vQkdtenU3bEIreUxIY0Vkd3JLQkJtcGVwREJQQ1l4cFZhanZ1RWhaZEtGeC9GZHk2ajVtSDNyclcwQmgvemQzNkNvVU5qYmJoSHlUamVNN0ZOMnlGM3U5bGN5dWJ1dk96cjNCM2dYNjZJd0psVTQ2K3d6Y1FWaFNPbE1rMnRYUitmSUtRRXhGck91Szl0YlgzSklCVXFJdHBJK0huQW93NTA5Q25NMTM0c3Z3OFBURkxrUjYvQ2NNcW5EZkRLMW05OTNQeW9DMVkrTjRYOVhraFNtRVFvQWxBSFBJNUxIcnZ1dWpNMTNudnRvVll2S1lvajdTY2d1bWtwV05Fdlg2NTJMZlhPbktZbGtCOFp5YnV4bUZmSWt6ZWRRcmJKc3lPaGZMMDNjTUVDQXdFQUFUQU5CZ2txaGtpRzl3MEJBUVVGQUFPQ0FRRUFlSHd6cXduekdFa3hqelNENDdpbVhhVHF0WXlFVFpvdzdYd0JjMFphRlM1MHFSRkpVZ0tUQW1LUzF4UUJQL3FIcFN0c1JPVDM1RFV4SkFFNk5ZMUticTNaYkN1aEdvU2xZMEw3VnpWVDV0cHU0RVk4K0RxL3UyRWpSbW1ob0w3VWtza3ZJWjJuMURkRVJ0ZCtZVU1UZXFZbDljbzQzY3Nad0Ruby9JS29tZU41cWFQYzM5SVpqaWtKK25VQzZrUEZLZXUvM2o5cmdITmxSdG9jSTZTMUZkdEZ6OU9aTVFscHIwSmJVdDJUM3hTL1lvUUpuNmNvRG1KTDVHVGlpS002Y09lK1VyMVZ3elMxSkVEYlNTMlRXV2h6cThvakxkcm90WUxHZDlKT3NvUWhFbG16K3RNZkNGUVVGTEV4aW5QQXl5N1lIbFNpVlgxM1FIMlhUdS9pUVE9PTwvZHM6WDUwOUNlcnRpZmljYXRlPjwvZHM6WDUwOURhdGE+PC9kczpLZXlJbmZvPjwvZHM6U2lnbmF0dXJlPjxzYW1scDpTdGF0dXM+PHNhbWxwOlN0YXR1c0NvZGUgVmFsdWU9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpzdGF0dXM6U3VjY2VzcyIvPjwvc2FtbHA6U3RhdHVzPjxzYW1sOkFzc2VydGlvbiB4bWxuczpzYW1sPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIiBWZXJzaW9uPSIyLjAiIElEPSJfSzA3ZDFyYklOVmVoS2NzRHBsMHFROHA2ODRzMFF2MVoiIElzc3VlSW5zdGFudD0iMjAxNy0wNC0wNFQxNjo1NDoxNy4wMzJaIj48c2FtbDpJc3N1ZXI+aHR0cDovL2V4YW1wbGUuY29tL3NhbWwvYWNzL2V4YW1wbGU8L3NhbWw6SXNzdWVyPjxzYW1sOlN1YmplY3Q+PHNhbWw6TmFtZUlEIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6MS4xOm5hbWVpZC1mb3JtYXQ6dW5zcGVjaWZpZWQiPmphbmUuZG9lQGV4YW1wbGUuY29tPC9zYW1sOk5hbWVJRD48c2FtbDpTdWJqZWN0Q29uZmlybWF0aW9uIE1ldGhvZD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmNtOmJlYXJlciI+PHNhbWw6U3ViamVjdENvbmZpcm1hdGlvbkRhdGEgTm90T25PckFmdGVyPSIyMDE3LTA0LTA0VDE3OjU0OjE3LjAzMloiIFJlY2lwaWVudD0iaHR0cDovL2RiYTlhNWZjLm5ncm9rLmlvL3YxL19zYW1sX2NhbGxiYWNrIi8+PC9zYW1sOlN1YmplY3RDb25maXJtYXRpb24+PC9zYW1sOlN1YmplY3Q+PHNhbWw6Q29uZGl0aW9ucz48c2FtbDpBdWRpZW5jZVJlc3RyaWN0aW9uPjxzYW1sOkF1ZGllbmNlPmh0dHA6Ly9leGFtcGxlLmNvbS9zYW1sL2Fjcy9leGFtcGxlPC9zYW1sOkF1ZGllbmNlPjwvc2FtbDpBdWRpZW5jZVJlc3RyaWN0aW9uPjwvc2FtbDpDb25kaXRpb25zPjxzYW1sOkF0dHJpYnV0ZVN0YXRlbWVudCB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEtaW5zdGFuY2UiPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoxLjE6bmFtZWlkLWZvcm1hdDplbWFpbEFkZHJlc3MiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czphbnlUeXBlIj5qYW5lLmRvZUBleGFtcGxlLmNvbTwvc2FtbDpBdHRyaWJ1dGVWYWx1ZT48L3NhbWw6QXR0cmlidXRlPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJFbWFpbCI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOmFueVR5cGUiPmphbmUuZG9lQGV4YW1wbGUuY29tPC9zYW1sOkF0dHJpYnV0ZVZhbHVlPjwvc2FtbDpBdHRyaWJ1dGU+PHNhbWw6QXR0cmlidXRlIE5hbWU9IkZpcnN0TmFtZSI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOmFueVR5cGUiPkphbmU8L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48c2FtbDpBdHRyaWJ1dGUgTmFtZT0iTGFzdE5hbWUiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czphbnlUeXBlIj5Eb2U8L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48L3NhbWw6QXR0cmlidXRlU3RhdGVtZW50PjxzYW1sOkF1dGhuU3RhdGVtZW50IEF1dGhuSW5zdGFudD0iMjAxNy0wNC0wNFQxNjo1NDoxNy4wMzJaIj48c2FtbDpBdXRobkNvbnRleHQ+PHNhbWw6QXV0aG5Db250ZXh0Q2xhc3NSZWY+dXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFjOmNsYXNzZXM6dW5zcGVjaWZpZWQ8L3NhbWw6QXV0aG5Db250ZXh0Q2xhc3NSZWY+PC9zYW1sOkF1dGhuQ29udGV4dD48L3NhbWw6QXV0aG5TdGF0ZW1lbnQ+PC9zYW1sOkFzc2VydGlvbj48L3NhbWxwOlJlc3BvbnNlPg== ================================================ FILE: providertests/testdata/saml.oktadev.com/response_11 ================================================ PHNhbWxwOlJlc3BvbnNlIHhtbG5zOnNhbWxwPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiIElEPSJfNWUxNWJkYWI0OGZlNzFlODc4ZGUiIFZlcnNpb249IjIuMCIgSXNzdWVJbnN0YW50PSIyMDE3LTA0LTA0VDE2OjU0OjE3WiIgRGVzdGluYXRpb249Imh0dHA6Ly9kYmE5YTVmYy5uZ3Jvay5pby92MS9fc2FtbF9jYWxsYmFjayI+PHNhbWw6SXNzdWVyIHhtbG5zOnNhbWw9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPmh0dHA6Ly9leGFtcGxlLmNvbS9zYW1sL2Fjcy9leGFtcGxlPC9zYW1sOklzc3Vlcj48ZHM6U2lnbmF0dXJlIHhtbG5zOmRzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjIj48ZHM6U2lnbmVkSW5mbz48ZHM6Q2Fub25pY2FsaXphdGlvbk1ldGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDYvMTIveG1sLWMxNG4xMSIvPjxkczpTaWduYXR1cmVNZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzA0L3htbGRzaWctbW9yZSNyc2Etc2hhMjU2Ii8+PGRzOlJlZmVyZW5jZSBVUkk9IiI+PGRzOlRyYW5zZm9ybXM+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyNlbnZlbG9wZWQtc2lnbmF0dXJlIi8+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDYvMTIveG1sLWMxNG4xMSIvPjwvZHM6VHJhbnNmb3Jtcz48ZHM6RGlnZXN0TWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8wNC94bWxlbmMjc2hhMjU2Ii8+PGRzOkRpZ2VzdFZhbHVlPmNXL1NxbkdQZElHdG12WTRxbUlxaWlMaFdHdzZ6RUpXWStFY0VrbG5QVGM9PC9kczpEaWdlc3RWYWx1ZT48L2RzOlJlZmVyZW5jZT48L2RzOlNpZ25lZEluZm8+PGRzOlNpZ25hdHVyZVZhbHVlPkt3RHE3dEFid1ZWSEQrSzRNV2FadHJHYlUvdVZvZjdPWmxWQ29yeGZqVUl6ZE9HdnpJNmxzayt1M0NmR295Mi9yMzFCWXVNN0dUVytMdlF5WmJWcUlia0JuZjlwZThQbE15dHJuOG1oT0p5b2JwNnMwVWw2S0dFZllXRkVMS0FxK0dESzRyeldhOWc5Z1Nqb3pzZ3NOSHY3SVVzRjNrUnFkOHdZcy9pbUhQTkY5TEg5aGs4cHNzT1R6dXFnVE5MTUpvVTZBWVVveVNiL3RqOGh2djlDSGZXc2Zra2QxM0hDK3FmQ0tXZldyZ3lOS1AxZzRDSTRKOThNenlPRWs0MzJ6Uzh2ZFFvSk9NeEwwR3cra0NOeW9rRHhhdWs1aEx0Y2k5SmpWWWdkTGJRajNSTXg1Wnl0clZpNWlVUUhVVTdWNUZxU3B0ZC9xWHhuOENOL1RYNUZkZz09PC9kczpTaWduYXR1cmVWYWx1ZT48ZHM6S2V5SW5mbz48ZHM6WDUwOURhdGE+PGRzOlg1MDlDZXJ0aWZpY2F0ZT5NSUlEUERDQ0FpUUNDUUR5ZEpnT2xzenFiekFOQmdrcWhraUc5dzBCQVFVRkFEQmdNUXN3Q1FZRFZRUUdFd0pWVXpFVE1CRUdBMVVFQ0JNS1EyRnNhV1p2Y201cFlURVdNQlFHQTFVRUJ4TU5VMkZ1SUVaeVlXNWphWE5qYnpFUU1BNEdBMVVFQ2hNSFNtRnVhM2xEYnpFU01CQUdBMVVFQXhNSmJHOWpZV3hvYjNOME1CNFhEVEUwTURNeE1qRTVORFl6TTFvWERUSTNNVEV4T1RFNU5EWXpNMW93WURFTE1Ba0dBMVVFQmhNQ1ZWTXhFekFSQmdOVkJBZ1RDa05oYkdsbWIzSnVhV0V4RmpBVUJnTlZCQWNURFZOaGJpQkdjbUZ1WTJselkyOHhFREFPQmdOVkJBb1RCMHBoYm10NVEyOHhFakFRQmdOVkJBTVRDV3h2WTJGc2FHOXpkRENDQVNJd0RRWUpLb1pJaHZjTkFRRUJCUUFEZ2dFUEFEQ0NBUW9DZ2dFQkFNR3ZKcFJUVGFzUlVTUHFjYnFDRytablRBdXJudTB2VnBJRzlsekV4bmgxMW8vQkdtenU3bEIreUxIY0Vkd3JLQkJtcGVwREJQQ1l4cFZhanZ1RWhaZEtGeC9GZHk2ajVtSDNyclcwQmgvemQzNkNvVU5qYmJoSHlUamVNN0ZOMnlGM3U5bGN5dWJ1dk96cjNCM2dYNjZJd0psVTQ2K3d6Y1FWaFNPbE1rMnRYUitmSUtRRXhGck91Szl0YlgzSklCVXFJdHBJK0huQW93NTA5Q25NMTM0c3Z3OFBURkxrUjYvQ2NNcW5EZkRLMW05OTNQeW9DMVkrTjRYOVhraFNtRVFvQWxBSFBJNUxIcnZ1dWpNMTNudnRvVll2S1lvajdTY2d1bWtwV05Fdlg2NTJMZlhPbktZbGtCOFp5YnV4bUZmSWt6ZWRRcmJKc3lPaGZMMDNjTUVDQXdFQUFUQU5CZ2txaGtpRzl3MEJBUVVGQUFPQ0FRRUFlSHd6cXduekdFa3hqelNENDdpbVhhVHF0WXlFVFpvdzdYd0JjMFphRlM1MHFSRkpVZ0tUQW1LUzF4UUJQL3FIcFN0c1JPVDM1RFV4SkFFNk5ZMUticTNaYkN1aEdvU2xZMEw3VnpWVDV0cHU0RVk4K0RxL3UyRWpSbW1ob0w3VWtza3ZJWjJuMURkRVJ0ZCtZVU1UZXFZbDljbzQzY3Nad0Ruby9JS29tZU41cWFQYzM5SVpqaWtKK25VQzZrUEZLZXUvM2o5cmdITmxSdG9jSTZTMUZkdEZ6OU9aTVFscHIwSmJVdDJUM3hTL1lvUUpuNmNvRG1KTDVHVGlpS002Y09lK1VyMVZ3elMxSkVEYlNTMlRXV2h6cThvakxkcm90WUxHZDlKT3NvUWhFbG16K3RNZkNGUVVGTEV4aW5QQXl5N1lIbFNpVlgxM1FIMlhUdS9pUVE9PTwvZHM6WDUwOUNlcnRpZmljYXRlPjwvZHM6WDUwOURhdGE+PC9kczpLZXlJbmZvPjwvZHM6U2lnbmF0dXJlPjxzYW1scDpTdGF0dXM+PHNhbWxwOlN0YXR1c0NvZGUgVmFsdWU9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpzdGF0dXM6U3VjY2VzcyIvPjwvc2FtbHA6U3RhdHVzPjxzYW1sOkFzc2VydGlvbiB4bWxuczpzYW1sPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIiBWZXJzaW9uPSIyLjAiIElEPSJfem5zVFU5dTVMQ0MxUnhGTEprdEVPazNzWnhtanRvSHciIElzc3VlSW5zdGFudD0iMjAxNy0wNC0wNFQxNjo1NDoxNy4yMjlaIj48c2FtbDpJc3N1ZXI+aHR0cDovL2V4YW1wbGUuY29tL3NhbWwvYWNzL2V4YW1wbGU8L3NhbWw6SXNzdWVyPjxzYW1sOlN1YmplY3Q+PHNhbWw6TmFtZUlEIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6MS4xOm5hbWVpZC1mb3JtYXQ6dW5zcGVjaWZpZWQiPmphbmUuZG9lQGV4YW1wbGUuY29tPC9zYW1sOk5hbWVJRD48c2FtbDpTdWJqZWN0Q29uZmlybWF0aW9uIE1ldGhvZD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmNtOmJlYXJlciI+PHNhbWw6U3ViamVjdENvbmZpcm1hdGlvbkRhdGEgTm90T25PckFmdGVyPSIyMDE3LTA0LTA0VDE3OjU0OjE3LjIyOVoiIFJlY2lwaWVudD0iaHR0cDovL2RiYTlhNWZjLm5ncm9rLmlvL3YxL19zYW1sX2NhbGxiYWNrIi8+PC9zYW1sOlN1YmplY3RDb25maXJtYXRpb24+PC9zYW1sOlN1YmplY3Q+PHNhbWw6Q29uZGl0aW9ucyBOb3RCZWZvcmU9IjE5OTctMDktMjlUMDY6MTQ6MDAuMDAwWiIgTm90T25PckFmdGVyPSIyMDA0LTA3LTI1VDIyOjE4OjAwLjAwMFoiPjxzYW1sOkF1ZGllbmNlUmVzdHJpY3Rpb24+PHNhbWw6QXVkaWVuY2U+aHR0cDovL2V4YW1wbGUuY29tL3NhbWwvYWNzL2V4YW1wbGU8L3NhbWw6QXVkaWVuY2U+PC9zYW1sOkF1ZGllbmNlUmVzdHJpY3Rpb24+PC9zYW1sOkNvbmRpdGlvbnM+PHNhbWw6QXR0cmlidXRlU3RhdGVtZW50IHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSI+PHNhbWw6QXR0cmlidXRlIE5hbWU9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjEuMTpuYW1laWQtZm9ybWF0OmVtYWlsQWRkcmVzcyI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOmFueVR5cGUiPmphbmUuZG9lQGV4YW1wbGUuY29tPC9zYW1sOkF0dHJpYnV0ZVZhbHVlPjwvc2FtbDpBdHRyaWJ1dGU+PHNhbWw6QXR0cmlidXRlIE5hbWU9IkVtYWlsIj48c2FtbDpBdHRyaWJ1dGVWYWx1ZSB4c2k6dHlwZT0ieHM6YW55VHlwZSI+amFuZS5kb2VAZXhhbXBsZS5jb208L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48c2FtbDpBdHRyaWJ1dGUgTmFtZT0iRmlyc3ROYW1lIj48c2FtbDpBdHRyaWJ1dGVWYWx1ZSB4c2k6dHlwZT0ieHM6YW55VHlwZSI+SmFuZTwvc2FtbDpBdHRyaWJ1dGVWYWx1ZT48L3NhbWw6QXR0cmlidXRlPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJMYXN0TmFtZSI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOmFueVR5cGUiPkRvZTwvc2FtbDpBdHRyaWJ1dGVWYWx1ZT48L3NhbWw6QXR0cmlidXRlPjwvc2FtbDpBdHRyaWJ1dGVTdGF0ZW1lbnQ+PHNhbWw6QXV0aG5TdGF0ZW1lbnQgQXV0aG5JbnN0YW50PSIyMDE3LTA0LTA0VDE2OjU0OjE3LjIyOVoiPjxzYW1sOkF1dGhuQ29udGV4dD48c2FtbDpBdXRobkNvbnRleHRDbGFzc1JlZj51cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YWM6Y2xhc3Nlczp1bnNwZWNpZmllZDwvc2FtbDpBdXRobkNvbnRleHRDbGFzc1JlZj48L3NhbWw6QXV0aG5Db250ZXh0Pjwvc2FtbDpBdXRoblN0YXRlbWVudD48L3NhbWw6QXNzZXJ0aW9uPjwvc2FtbHA6UmVzcG9uc2U+ ================================================ FILE: providertests/testdata/saml.oktadev.com/response_12 ================================================ PHNhbWxwOlJlc3BvbnNlIHhtbG5zOnNhbWxwPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiIElEPSJfZGNiZDcyZmEwZjc2M2YyNWEwYTQiIFZlcnNpb249IjIuMCIgSXNzdWVJbnN0YW50PSIyMDE3LTA0LTA0VDE2OjU0OjE3WiIgRGVzdGluYXRpb249Imh0dHA6Ly9kYmE5YTVmYy5uZ3Jvay5pby92MS9fc2FtbF9jYWxsYmFjayI+PHNhbWw6SXNzdWVyIHhtbG5zOnNhbWw9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPmh0dHA6Ly9leGFtcGxlLmNvbS9zYW1sL2Fjcy9leGFtcGxlPC9zYW1sOklzc3Vlcj48c2FtbHA6U3RhdHVzPjxzYW1scDpTdGF0dXNDb2RlIFZhbHVlPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6c3RhdHVzOlN1Y2Nlc3MiLz48L3NhbWxwOlN0YXR1cz48c2FtbDpBc3NlcnRpb24geG1sbnM6c2FtbD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiIgVmVyc2lvbj0iMi4wIiBJc3N1ZUluc3RhbnQ9IjIwMTctMDQtMDRUMTY6NTQ6MTcuNDEwWiI+PHNhbWw6SXNzdWVyPmh0dHA6Ly9leGFtcGxlLmNvbS9zYW1sL2Fjcy9leGFtcGxlPC9zYW1sOklzc3Vlcj48c2FtbDpTdWJqZWN0PjxzYW1sOk5hbWVJRCBGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjEuMTpuYW1laWQtZm9ybWF0OnVuc3BlY2lmaWVkIj5hZG1pbkBleGFtcGxlLmNvbTwvc2FtbDpOYW1lSUQ+PHNhbWw6U3ViamVjdENvbmZpcm1hdGlvbiBNZXRob2Q9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpjbTpiZWFyZXIiPjxzYW1sOlN1YmplY3RDb25maXJtYXRpb25EYXRhIE5vdE9uT3JBZnRlcj0iMjAxNy0wNC0wNFQxNzo1NDoxNy40MTBaIiBSZWNpcGllbnQ9Imh0dHA6Ly9kYmE5YTVmYy5uZ3Jvay5pby92MS9fc2FtbF9jYWxsYmFjayIvPjwvc2FtbDpTdWJqZWN0Q29uZmlybWF0aW9uPjwvc2FtbDpTdWJqZWN0PjxzYW1sOkNvbmRpdGlvbnMgTm90QmVmb3JlPSIyMDE3LTA0LTA0VDE2OjU0OjE3LjQxMFoiIE5vdE9uT3JBZnRlcj0iMjAxNy0wNC0wNFQxNzo1NDoxNy40MTBaIj48c2FtbDpBdWRpZW5jZVJlc3RyaWN0aW9uPjxzYW1sOkF1ZGllbmNlPmh0dHA6Ly9leGFtcGxlLmNvbS9zYW1sL2Fjcy9leGFtcGxlPC9zYW1sOkF1ZGllbmNlPjwvc2FtbDpBdWRpZW5jZVJlc3RyaWN0aW9uPjwvc2FtbDpDb25kaXRpb25zPjxzYW1sOkF0dHJpYnV0ZVN0YXRlbWVudCB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEtaW5zdGFuY2UiPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoxLjE6bmFtZWlkLWZvcm1hdDplbWFpbEFkZHJlc3MiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czphbnlUeXBlIj5qYW5lLmRvZUBleGFtcGxlLmNvbTwvc2FtbDpBdHRyaWJ1dGVWYWx1ZT48L3NhbWw6QXR0cmlidXRlPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJFbWFpbCI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOmFueVR5cGUiPmphbmUuZG9lQGV4YW1wbGUuY29tPC9zYW1sOkF0dHJpYnV0ZVZhbHVlPjwvc2FtbDpBdHRyaWJ1dGU+PHNhbWw6QXR0cmlidXRlIE5hbWU9IkZpcnN0TmFtZSI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOmFueVR5cGUiPkphbmU8L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48c2FtbDpBdHRyaWJ1dGUgTmFtZT0iTGFzdE5hbWUiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czphbnlUeXBlIj5Eb2U8L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48L3NhbWw6QXR0cmlidXRlU3RhdGVtZW50PjxzYW1sOkF1dGhuU3RhdGVtZW50IEF1dGhuSW5zdGFudD0iMjAxNy0wNC0wNFQxNjo1NDoxNy40MTBaIj48c2FtbDpBdXRobkNvbnRleHQ+PHNhbWw6QXV0aG5Db250ZXh0Q2xhc3NSZWY+dXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFjOmNsYXNzZXM6dW5zcGVjaWZpZWQ8L3NhbWw6QXV0aG5Db250ZXh0Q2xhc3NSZWY+PC9zYW1sOkF1dGhuQ29udGV4dD48L3NhbWw6QXV0aG5TdGF0ZW1lbnQ+PC9zYW1sOkFzc2VydGlvbj48L3NhbWxwOlJlc3BvbnNlPg== ================================================ FILE: providertests/testdata/saml.oktadev.com/response_13 ================================================ PHNhbWxwOlJlc3BvbnNlIHhtbG5zOnNhbWxwPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiIElEPSJfZTZhMWFlZjE1N2ViMzQ0YjQzYjUiIFZlcnNpb249IjIuMCIgSXNzdWVJbnN0YW50PSIyMDE3LTA0LTA0VDE2OjU0OjE3WiIgRGVzdGluYXRpb249Imh0dHA6Ly9kYmE5YTVmYy5uZ3Jvay5pby92MS9fc2FtbF9jYWxsYmFjayI+PHNhbWw6SXNzdWVyIHhtbG5zOnNhbWw9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPmh0dHA6Ly9leGFtcGxlLmNvbS9zYW1sL2Fjcy9leGFtcGxlPC9zYW1sOklzc3Vlcj48c2FtbHA6U3RhdHVzPjxzYW1scDpTdGF0dXNDb2RlIFZhbHVlPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6c3RhdHVzOlN1Y2Nlc3MiLz48L3NhbWxwOlN0YXR1cz48c2FtbDpBc3NlcnRpb24geG1sbnM6c2FtbD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiIgVmVyc2lvbj0iMi4wIiBJRD0iX0YyWnZiaGxqV0tYdWpuYmx1c0Q3dXJZM0lrM1RqWWE1IiBJc3N1ZUluc3RhbnQ9IjIwMTctMDQtMDRUMTY6NTQ6MTcuNTkyWiI+PHNhbWw6SXNzdWVyPmh0dHA6Ly9leGFtcGxlLmNvbS9zYW1sL2Fjcy9leGFtcGxlPC9zYW1sOklzc3Vlcj48U2lnbmF0dXJlIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjIj48U2lnbmVkSW5mbz48Q2Fub25pY2FsaXphdGlvbk1ldGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvMTAveG1sLWV4Yy1jMTRuIyIvPjxTaWduYXR1cmVNZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjcnNhLXNoYTEiLz48UmVmZXJlbmNlIFVSST0iI19GMlp2YmhsaldLWHVqbmJsdXNEN3VyWTNJazNUallhNSI+PFRyYW5zZm9ybXM+PFRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyNlbnZlbG9wZWQtc2lnbmF0dXJlIi8+PFRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvMTAveG1sLWV4Yy1jMTRuIyIvPjwvVHJhbnNmb3Jtcz48RGlnZXN0TWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8wOS94bWxkc2lnI3NoYTEiLz48RGlnZXN0VmFsdWU+em5BcjNuUkk3aUtGckViQi81UTJjdWl4a1hBPTwvRGlnZXN0VmFsdWU+PC9SZWZlcmVuY2U+PC9TaWduZWRJbmZvPjxTaWduYXR1cmVWYWx1ZT5KRFkrVmp2RHF6dCtHTk85RjVHNGdpcC9hQXBPbEZidEM2S3NiNWhob3hDc2VGY0NobmM0OExiem5ZWCtpY09TZEthWHNvdElzdEh6K1p3T2pWU0FpS3dnN0N0emUwSyt6WE1ldDdFOVlveGlFNXdJZlV4Z3lVU1MyNjU3dGl0cjlodE1QVURNeUtMOGUrdHpKZWxScWVWa1Rld1RoQXlzYko1VWd4MjVNTFNmOVVLUmJmcUpGdHh6aDIzRGhGTjZEQzVnUnhrZlRPVGtsaW56Z1AzdVNyRHVQblUrN3BsOFVWNUFDR293eTJ5c3FKaXhJdGdFV1FYSldVRXVBamhUaUs0Z0s1YkxqZnd0cEF5YW1PYm14YklpeWhlaTNMR3JUVDFVaGRyUXdWVnVORmVJQ3l4ank2UVJ0TGR6c1lYRzhsakRnWVdtWXYzc2YxVVhqNUN5d0E9PTwvU2lnbmF0dXJlVmFsdWU+PEtleUluZm8+PFg1MDlEYXRhPjxYNTA5Q2VydGlmaWNhdGU+TUlJRFBEQ0NBaVFDQ1FEeWRKZ09sc3pxYnpBTkJna3Foa2lHOXcwQkFRVUZBREJnTVFzd0NRWURWUVFHRXdKVlV6RVRNQkVHQTFVRUNCTUtRMkZzYVdadmNtNXBZVEVXTUJRR0ExVUVCeE1OVTJGdUlFWnlZVzVqYVhOamJ6RVFNQTRHQTFVRUNoTUhTbUZ1YTNsRGJ6RVNNQkFHQTFVRUF4TUpiRzlqWVd4b2IzTjBNQjRYRFRFME1ETXhNakU1TkRZek0xb1hEVEkzTVRFeE9URTVORFl6TTFvd1lERUxNQWtHQTFVRUJoTUNWVk14RXpBUkJnTlZCQWdUQ2tOaGJHbG1iM0p1YVdFeEZqQVVCZ05WQkFjVERWTmhiaUJHY21GdVkybHpZMjh4RURBT0JnTlZCQW9UQjBwaGJtdDVRMjh4RWpBUUJnTlZCQU1UQ1d4dlkyRnNhRzl6ZERDQ0FTSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnRVBBRENDQVFvQ2dnRUJBTUd2SnBSVFRhc1JVU1BxY2JxQ0crWm5UQXVybnUwdlZwSUc5bHpFeG5oMTFvL0JHbXp1N2xCK3lMSGNFZHdyS0JCbXBlcERCUENZeHBWYWp2dUVoWmRLRngvRmR5Nmo1bUgzcnJXMEJoL3pkMzZDb1VOamJiaEh5VGplTTdGTjJ5RjN1OWxjeXVidXZPenIzQjNnWDY2SXdKbFU0Nit3emNRVmhTT2xNazJ0WFIrZklLUUV4RnJPdUs5dGJYM0pJQlVxSXRwSStIbkFvdzUwOUNuTTEzNHN2dzhQVEZMa1I2L0NjTXFuRGZESzFtOTkzUHlvQzFZK040WDlYa2hTbUVRb0FsQUhQSTVMSHJ2dXVqTTEzbnZ0b1ZZdktZb2o3U2NndW1rcFdORXZYNjUyTGZYT25LWWxrQjhaeWJ1eG1GZklremVkUXJiSnN5T2hmTDAzY01FQ0F3RUFBVEFOQmdrcWhraUc5dzBCQVFVRkFBT0NBUUVBZUh3enF3bnpHRWt4anpTRDQ3aW1YYVRxdFl5RVRab3c3WHdCYzBaYUZTNTBxUkZKVWdLVEFtS1MxeFFCUC9xSHBTdHNST1QzNURVeEpBRTZOWTFLYnEzWmJDdWhHb1NsWTBMN1Z6VlQ1dHB1NEVZOCtEcS91MkVqUm1taG9MN1Vrc2t2SVoybjFEZEVSdGQrWVVNVGVxWWw5Y280M2NzWndEbm8vSUtvbWVONXFhUGMzOUlaamlrSituVUM2a1BGS2V1LzNqOXJnSE5sUnRvY0k2UzFGZHRGejlPWk1RbHByMEpiVXQyVDN4Uy9Zb1FKbjZjb0RtSkw1R1RpaUtNNmNPZStVcjFWd3pTMUpFRGJTUzJUV1doenE4b2pMZHJvdFlMR2Q5Sk9zb1FoRWxteit0TWZDRlFVRkxFeGluUEF5eTdZSGxTaVZYMTNRSDJYVHUvaVFRPT08L1g1MDlDZXJ0aWZpY2F0ZT48L1g1MDlEYXRhPjwvS2V5SW5mbz48L1NpZ25hdHVyZT48c2FtbDpTdWJqZWN0PjxzYW1sOk5hbWVJRCBGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjEuMTpuYW1laWQtZm9ybWF0OnVuc3BlY2lmaWVkIj5hZG1pbkBleGFtcGxlLmNvbTwvc2FtbDpOYW1lSUQ+PHNhbWw6U3ViamVjdENvbmZpcm1hdGlvbiBNZXRob2Q9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpjbTpiZWFyZXIiPjxzYW1sOlN1YmplY3RDb25maXJtYXRpb25EYXRhIE5vdE9uT3JBZnRlcj0iMjAxNy0wNC0wNFQxNzo1NDoxNy41OTJaIiBSZWNpcGllbnQ9Imh0dHA6Ly9kYmE5YTVmYy5uZ3Jvay5pby92MS9fc2FtbF9jYWxsYmFjayIvPjwvc2FtbDpTdWJqZWN0Q29uZmlybWF0aW9uPjwvc2FtbDpTdWJqZWN0PjxzYW1sOkNvbmRpdGlvbnMgTm90QmVmb3JlPSIyMDE3LTA0LTA0VDE2OjU0OjE3LjU5MloiIE5vdE9uT3JBZnRlcj0iMjAxNy0wNC0wNFQxNzo1NDoxNy41OTJaIj48c2FtbDpBdWRpZW5jZVJlc3RyaWN0aW9uPjxzYW1sOkF1ZGllbmNlPmh0dHA6Ly9leGFtcGxlLmNvbS9zYW1sL2Fjcy9leGFtcGxlPC9zYW1sOkF1ZGllbmNlPjwvc2FtbDpBdWRpZW5jZVJlc3RyaWN0aW9uPjwvc2FtbDpDb25kaXRpb25zPjxzYW1sOkF0dHJpYnV0ZVN0YXRlbWVudCB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEtaW5zdGFuY2UiPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoxLjE6bmFtZWlkLWZvcm1hdDplbWFpbEFkZHJlc3MiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czphbnlUeXBlIj5qYW5lLmRvZUBleGFtcGxlLmNvbTwvc2FtbDpBdHRyaWJ1dGVWYWx1ZT48L3NhbWw6QXR0cmlidXRlPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJFbWFpbCI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOmFueVR5cGUiPmphbmUuZG9lQGV4YW1wbGUuY29tPC9zYW1sOkF0dHJpYnV0ZVZhbHVlPjwvc2FtbDpBdHRyaWJ1dGU+PHNhbWw6QXR0cmlidXRlIE5hbWU9IkZpcnN0TmFtZSI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOmFueVR5cGUiPkphbmU8L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48c2FtbDpBdHRyaWJ1dGUgTmFtZT0iTGFzdE5hbWUiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czphbnlUeXBlIj5Eb2U8L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48L3NhbWw6QXR0cmlidXRlU3RhdGVtZW50PjxzYW1sOkF1dGhuU3RhdGVtZW50IEF1dGhuSW5zdGFudD0iMjAxNy0wNC0wNFQxNjo1NDoxNy41OTJaIj48c2FtbDpBdXRobkNvbnRleHQ+PHNhbWw6QXV0aG5Db250ZXh0Q2xhc3NSZWY+dXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFjOmNsYXNzZXM6dW5zcGVjaWZpZWQ8L3NhbWw6QXV0aG5Db250ZXh0Q2xhc3NSZWY+PC9zYW1sOkF1dGhuQ29udGV4dD48L3NhbWw6QXV0aG5TdGF0ZW1lbnQ+PC9zYW1sOkFzc2VydGlvbj48L3NhbWxwOlJlc3BvbnNlPg== ================================================ FILE: providertests/testdata/saml.oktadev.com/response_14 ================================================ PHNhbWxwOlJlc3BvbnNlIHhtbG5zOnNhbWxwPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiIElEPSJfNzNlNTQzY2FkMjJkZGI0YWJjMDQiIFZlcnNpb249IjIuMCIgSXNzdWVJbnN0YW50PSIyMDE3LTA0LTA0VDE2OjU0OjE3WiIgRGVzdGluYXRpb249Imh0dHA6Ly9kYmE5YTVmYy5uZ3Jvay5pby92MS9fc2FtbF9jYWxsYmFjayI+PHNhbWw6SXNzdWVyIHhtbG5zOnNhbWw9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPmh0dHA6Ly9leGFtcGxlLmNvbS9zYW1sL2Fjcy9leGFtcGxlPC9zYW1sOklzc3Vlcj48ZHM6U2lnbmF0dXJlIHhtbG5zOmRzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjIj48ZHM6U2lnbmVkSW5mbz48ZHM6Q2Fub25pY2FsaXphdGlvbk1ldGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDYvMTIveG1sLWMxNG4xMSIvPjxkczpTaWduYXR1cmVNZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzA0L3htbGRzaWctbW9yZSNyc2Etc2hhMjU2Ii8+PGRzOlJlZmVyZW5jZSBVUkk9IiI+PGRzOlRyYW5zZm9ybXM+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyNlbnZlbG9wZWQtc2lnbmF0dXJlIi8+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDYvMTIveG1sLWMxNG4xMSIvPjwvZHM6VHJhbnNmb3Jtcz48ZHM6RGlnZXN0TWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8wNC94bWxlbmMjc2hhMjU2Ii8+PGRzOkRpZ2VzdFZhbHVlPjRtaVNzZmxlbWlQbTJwOVd2M1VRTVR1aTl5YVhRUEpWaFlLNWEvVHJURzQ9PC9kczpEaWdlc3RWYWx1ZT48L2RzOlJlZmVyZW5jZT48L2RzOlNpZ25lZEluZm8+PGRzOlNpZ25hdHVyZVZhbHVlPnZVbDh3YWNsc1daY2NnV292ZTl4OU5mRktWWFpkRUEwZ1JPcnEwb2ViVFNnKzhHUmQ2U0JXalhBaTd3N3pSem5SeUJHdDVZTkloSWsxd3JCTVkvZTBhWmdmYmUzNWpzUlZaMnlzK0piTXpteDlnYWlFaEpEWTR0djhqWVYyMXRDTHFwRE54Ti9CTEVFMEVlaTBBek4zUE1IVnU1TE1sZHZmYzQrOWtkbkNiSFZrSDU4a3VsZm9tZmJGY1VSREJ0eXlGZkJjeHE1eXg5NVFRMFFnSlRJbWZzUlJwdk82NVRQU01USjkrYXBVMzdxQ0dRc0VSaUx5ckZMMWJ3WlBVVjd1ZTdCV3A2OXpJMVJ1MG11MXA2TWt4RFVxRHNROEVLbGh3MEhnOEltZkJ5b1Era1lpQXhHQmZFVUdDa0ZudWxkQ1A5ZEo1RjlxaDNRZDRCL0VPdk1FQT09PC9kczpTaWduYXR1cmVWYWx1ZT48ZHM6S2V5SW5mbz48ZHM6WDUwOURhdGE+PGRzOlg1MDlDZXJ0aWZpY2F0ZT5NSUlEUERDQ0FpUUNDUUR5ZEpnT2xzenFiekFOQmdrcWhraUc5dzBCQVFVRkFEQmdNUXN3Q1FZRFZRUUdFd0pWVXpFVE1CRUdBMVVFQ0JNS1EyRnNhV1p2Y201cFlURVdNQlFHQTFVRUJ4TU5VMkZ1SUVaeVlXNWphWE5qYnpFUU1BNEdBMVVFQ2hNSFNtRnVhM2xEYnpFU01CQUdBMVVFQXhNSmJHOWpZV3hvYjNOME1CNFhEVEUwTURNeE1qRTVORFl6TTFvWERUSTNNVEV4T1RFNU5EWXpNMW93WURFTE1Ba0dBMVVFQmhNQ1ZWTXhFekFSQmdOVkJBZ1RDa05oYkdsbWIzSnVhV0V4RmpBVUJnTlZCQWNURFZOaGJpQkdjbUZ1WTJselkyOHhFREFPQmdOVkJBb1RCMHBoYm10NVEyOHhFakFRQmdOVkJBTVRDV3h2WTJGc2FHOXpkRENDQVNJd0RRWUpLb1pJaHZjTkFRRUJCUUFEZ2dFUEFEQ0NBUW9DZ2dFQkFNR3ZKcFJUVGFzUlVTUHFjYnFDRytablRBdXJudTB2VnBJRzlsekV4bmgxMW8vQkdtenU3bEIreUxIY0Vkd3JLQkJtcGVwREJQQ1l4cFZhanZ1RWhaZEtGeC9GZHk2ajVtSDNyclcwQmgvemQzNkNvVU5qYmJoSHlUamVNN0ZOMnlGM3U5bGN5dWJ1dk96cjNCM2dYNjZJd0psVTQ2K3d6Y1FWaFNPbE1rMnRYUitmSUtRRXhGck91Szl0YlgzSklCVXFJdHBJK0huQW93NTA5Q25NMTM0c3Z3OFBURkxrUjYvQ2NNcW5EZkRLMW05OTNQeW9DMVkrTjRYOVhraFNtRVFvQWxBSFBJNUxIcnZ1dWpNMTNudnRvVll2S1lvajdTY2d1bWtwV05Fdlg2NTJMZlhPbktZbGtCOFp5YnV4bUZmSWt6ZWRRcmJKc3lPaGZMMDNjTUVDQXdFQUFUQU5CZ2txaGtpRzl3MEJBUVVGQUFPQ0FRRUFlSHd6cXduekdFa3hqelNENDdpbVhhVHF0WXlFVFpvdzdYd0JjMFphRlM1MHFSRkpVZ0tUQW1LUzF4UUJQL3FIcFN0c1JPVDM1RFV4SkFFNk5ZMUticTNaYkN1aEdvU2xZMEw3VnpWVDV0cHU0RVk4K0RxL3UyRWpSbW1ob0w3VWtza3ZJWjJuMURkRVJ0ZCtZVU1UZXFZbDljbzQzY3Nad0Ruby9JS29tZU41cWFQYzM5SVpqaWtKK25VQzZrUEZLZXUvM2o5cmdITmxSdG9jSTZTMUZkdEZ6OU9aTVFscHIwSmJVdDJUM3hTL1lvUUpuNmNvRG1KTDVHVGlpS002Y09lK1VyMVZ3elMxSkVEYlNTMlRXV2h6cThvakxkcm90WUxHZDlKT3NvUWhFbG16K3RNZkNGUVVGTEV4aW5QQXl5N1lIbFNpVlgxM1FIMlhUdS9pUVE9PTwvZHM6WDUwOUNlcnRpZmljYXRlPjwvZHM6WDUwOURhdGE+PC9kczpLZXlJbmZvPjwvZHM6U2lnbmF0dXJlPjxzYW1scDpTdGF0dXM+PHNhbWxwOlN0YXR1c0NvZGUgVmFsdWU9IkZhaWx1cmUiLz48L3NhbWxwOlN0YXR1cz48c2FtbDpBc3NlcnRpb24geG1sbnM6c2FtbD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiIgVmVyc2lvbj0iMi4wIiBJRD0iX2c4d0tOOWxFV1VnSElZNXlpb05hcldrNnFQMmY2TEFSIiBJc3N1ZUluc3RhbnQ9IjIwMTctMDQtMDRUMTY6NTQ6MTcuNzU4WiI+PHNhbWw6SXNzdWVyPmh0dHA6Ly9leGFtcGxlLmNvbS9zYW1sL2Fjcy9leGFtcGxlPC9zYW1sOklzc3Vlcj48c2FtbDpTdWJqZWN0PjxzYW1sOk5hbWVJRCBGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjEuMTpuYW1laWQtZm9ybWF0OnVuc3BlY2lmaWVkIj5qYW5lLmRvZUBleGFtcGxlLmNvbTwvc2FtbDpOYW1lSUQ+PHNhbWw6U3ViamVjdENvbmZpcm1hdGlvbiBNZXRob2Q9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpjbTpiZWFyZXIiPjxzYW1sOlN1YmplY3RDb25maXJtYXRpb25EYXRhIE5vdE9uT3JBZnRlcj0iMjAxNy0wNC0wNFQxNzo1NDoxNy43NThaIiBSZWNpcGllbnQ9Imh0dHA6Ly9kYmE5YTVmYy5uZ3Jvay5pby92MS9fc2FtbF9jYWxsYmFjayIvPjwvc2FtbDpTdWJqZWN0Q29uZmlybWF0aW9uPjwvc2FtbDpTdWJqZWN0PjxzYW1sOkNvbmRpdGlvbnMgTm90QmVmb3JlPSIyMDE3LTA0LTA0VDE2OjU0OjE3Ljc1OFoiIE5vdE9uT3JBZnRlcj0iMjAxNy0wNC0wNFQxNzo1NDoxNy43NThaIj48c2FtbDpBdWRpZW5jZVJlc3RyaWN0aW9uPjxzYW1sOkF1ZGllbmNlPmh0dHA6Ly9leGFtcGxlLmNvbS9zYW1sL2Fjcy9leGFtcGxlPC9zYW1sOkF1ZGllbmNlPjwvc2FtbDpBdWRpZW5jZVJlc3RyaWN0aW9uPjwvc2FtbDpDb25kaXRpb25zPjxzYW1sOkF0dHJpYnV0ZVN0YXRlbWVudCB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEtaW5zdGFuY2UiPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoxLjE6bmFtZWlkLWZvcm1hdDplbWFpbEFkZHJlc3MiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czphbnlUeXBlIj5qYW5lLmRvZUBleGFtcGxlLmNvbTwvc2FtbDpBdHRyaWJ1dGVWYWx1ZT48L3NhbWw6QXR0cmlidXRlPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJFbWFpbCI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOmFueVR5cGUiPmphbmUuZG9lQGV4YW1wbGUuY29tPC9zYW1sOkF0dHJpYnV0ZVZhbHVlPjwvc2FtbDpBdHRyaWJ1dGU+PHNhbWw6QXR0cmlidXRlIE5hbWU9IkZpcnN0TmFtZSI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOmFueVR5cGUiPkphbmU8L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48c2FtbDpBdHRyaWJ1dGUgTmFtZT0iTGFzdE5hbWUiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czphbnlUeXBlIj5Eb2U8L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48L3NhbWw6QXR0cmlidXRlU3RhdGVtZW50PjxzYW1sOkF1dGhuU3RhdGVtZW50IEF1dGhuSW5zdGFudD0iMjAxNy0wNC0wNFQxNjo1NDoxNy43NThaIj48c2FtbDpBdXRobkNvbnRleHQ+PHNhbWw6QXV0aG5Db250ZXh0Q2xhc3NSZWY+dXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFjOmNsYXNzZXM6dW5zcGVjaWZpZWQ8L3NhbWw6QXV0aG5Db250ZXh0Q2xhc3NSZWY+PC9zYW1sOkF1dGhuQ29udGV4dD48L3NhbWw6QXV0aG5TdGF0ZW1lbnQ+PC9zYW1sOkFzc2VydGlvbj48L3NhbWxwOlJlc3BvbnNlPg== ================================================ FILE: providertests/testdata/saml.oktadev.com/response_15 ================================================ PHNhbWxwOlJlc3BvbnNlIHhtbG5zOnNhbWxwPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiIElEPSJfNGNhNTMwMTMzZWRiYzExZDc4ZTEiIFZlcnNpb249IjIuMCIgSXNzdWVJbnN0YW50PSIyMDE3LTA0LTA0VDE2OjU0OjE3WiIgRGVzdGluYXRpb249Imh0dHA6Ly9kYmE5YTVmYy5uZ3Jvay5pby92MS9fc2FtbF9jYWxsYmFjayI+PHNhbWw6SXNzdWVyIHhtbG5zOnNhbWw9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPmh0dHA6Ly9leGFtcGxlLmNvbS9zYW1sL2Fjcy9leGFtcGxlPC9zYW1sOklzc3Vlcj48ZHM6U2lnbmF0dXJlIHhtbG5zOmRzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjIj48ZHM6U2lnbmVkSW5mbz48ZHM6Q2Fub25pY2FsaXphdGlvbk1ldGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDYvMTIveG1sLWMxNG4xMSIvPjxkczpTaWduYXR1cmVNZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzA0L3htbGRzaWctbW9yZSNyc2Etc2hhMjU2Ii8+PGRzOlJlZmVyZW5jZSBVUkk9IiI+PGRzOlRyYW5zZm9ybXM+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyNlbnZlbG9wZWQtc2lnbmF0dXJlIi8+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDYvMTIveG1sLWMxNG4xMSIvPjwvZHM6VHJhbnNmb3Jtcz48ZHM6RGlnZXN0TWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8wNC94bWxlbmMjc2hhMjU2Ii8+PGRzOkRpZ2VzdFZhbHVlPmVuVi9KSllkdzd5cGJ3N1IwQU5oTmRzZ1lQUmJGYTd2Q3lTWmtKUDVNOGc9PC9kczpEaWdlc3RWYWx1ZT48L2RzOlJlZmVyZW5jZT48L2RzOlNpZ25lZEluZm8+PGRzOlNpZ25hdHVyZVZhbHVlPlNEemVZVmQxVU9jWUZrbEQwSE5EWStSc1JaVzNQdlJMQ2MwNW0xQ05XMWc2WHllWEk5QVNSN0hyMGxOZEt6dHRzclJQSUcxLytDVnE4OEZZdDYwZ0FSMVQrblZDaHVFVXI5VEdIdEQ1RE9QQm5DcWI4S3BBcFN5Y1JpVEFDeGdHVGw3Uy85OTIyRklOVmpodUhweXBLdWdqcm9KTFdFR1BVRkxLWDB0Ry91Z2sxOHcySmhhdDhFdGFXS29naVAzbTh4VUpCdkdLaU96ZWNMSWFMSkl0Z2NZSWpLdnJjckg2R1hHOVZVekwreXhiMWRLUUtodlJ6aEFBN1RpQlJqNEo1WHcweWJ6UVYrMExxUXFsODcxMkpqc3BPMVhqMG1HaTk3ODY5aHNLaVJBaWlCUkRoYkoxNmZJUHBCMkxtUjJwME82Y21MWHZxbDJEaFZsR1kxNWFZUT09PC9kczpTaWduYXR1cmVWYWx1ZT48ZHM6S2V5SW5mbz48ZHM6WDUwOURhdGE+PGRzOlg1MDlDZXJ0aWZpY2F0ZT5NSUlEUERDQ0FpUUNDUUR5ZEpnT2xzenFiekFOQmdrcWhraUc5dzBCQVFVRkFEQmdNUXN3Q1FZRFZRUUdFd0pWVXpFVE1CRUdBMVVFQ0JNS1EyRnNhV1p2Y201cFlURVdNQlFHQTFVRUJ4TU5VMkZ1SUVaeVlXNWphWE5qYnpFUU1BNEdBMVVFQ2hNSFNtRnVhM2xEYnpFU01CQUdBMVVFQXhNSmJHOWpZV3hvYjNOME1CNFhEVEUwTURNeE1qRTVORFl6TTFvWERUSTNNVEV4T1RFNU5EWXpNMW93WURFTE1Ba0dBMVVFQmhNQ1ZWTXhFekFSQmdOVkJBZ1RDa05oYkdsbWIzSnVhV0V4RmpBVUJnTlZCQWNURFZOaGJpQkdjbUZ1WTJselkyOHhFREFPQmdOVkJBb1RCMHBoYm10NVEyOHhFakFRQmdOVkJBTVRDV3h2WTJGc2FHOXpkRENDQVNJd0RRWUpLb1pJaHZjTkFRRUJCUUFEZ2dFUEFEQ0NBUW9DZ2dFQkFNR3ZKcFJUVGFzUlVTUHFjYnFDRytablRBdXJudTB2VnBJRzlsekV4bmgxMW8vQkdtenU3bEIreUxIY0Vkd3JLQkJtcGVwREJQQ1l4cFZhanZ1RWhaZEtGeC9GZHk2ajVtSDNyclcwQmgvemQzNkNvVU5qYmJoSHlUamVNN0ZOMnlGM3U5bGN5dWJ1dk96cjNCM2dYNjZJd0psVTQ2K3d6Y1FWaFNPbE1rMnRYUitmSUtRRXhGck91Szl0YlgzSklCVXFJdHBJK0huQW93NTA5Q25NMTM0c3Z3OFBURkxrUjYvQ2NNcW5EZkRLMW05OTNQeW9DMVkrTjRYOVhraFNtRVFvQWxBSFBJNUxIcnZ1dWpNMTNudnRvVll2S1lvajdTY2d1bWtwV05Fdlg2NTJMZlhPbktZbGtCOFp5YnV4bUZmSWt6ZWRRcmJKc3lPaGZMMDNjTUVDQXdFQUFUQU5CZ2txaGtpRzl3MEJBUVVGQUFPQ0FRRUFlSHd6cXduekdFa3hqelNENDdpbVhhVHF0WXlFVFpvdzdYd0JjMFphRlM1MHFSRkpVZ0tUQW1LUzF4UUJQL3FIcFN0c1JPVDM1RFV4SkFFNk5ZMUticTNaYkN1aEdvU2xZMEw3VnpWVDV0cHU0RVk4K0RxL3UyRWpSbW1ob0w3VWtza3ZJWjJuMURkRVJ0ZCtZVU1UZXFZbDljbzQzY3Nad0Ruby9JS29tZU41cWFQYzM5SVpqaWtKK25VQzZrUEZLZXUvM2o5cmdITmxSdG9jSTZTMUZkdEZ6OU9aTVFscHIwSmJVdDJUM3hTL1lvUUpuNmNvRG1KTDVHVGlpS002Y09lK1VyMVZ3elMxSkVEYlNTMlRXV2h6cThvakxkcm90WUxHZDlKT3NvUWhFbG16K3RNZkNGUVVGTEV4aW5QQXl5N1lIbFNpVlgxM1FIMlhUdS9pUVE9PTwvZHM6WDUwOUNlcnRpZmljYXRlPjwvZHM6WDUwOURhdGE+PC9kczpLZXlJbmZvPjwvZHM6U2lnbmF0dXJlPjxzYW1scDpTdGF0dXM+PHNhbWxwOlN0YXR1c0NvZGUgVmFsdWU9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpzdGF0dXM6UmVxdWVzdGVyIi8+PC9zYW1scDpTdGF0dXM+PHNhbWw6QXNzZXJ0aW9uIHhtbG5zOnNhbWw9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iIFZlcnNpb249IjIuMCIgSUQ9Il9xcDNYYmk3cVZBRFJrRlBpQW8wVjdWVk5UTXNLc1pwMiIgSXNzdWVJbnN0YW50PSIyMDE3LTA0LTA0VDE2OjU0OjE3Ljk0NFoiPjxzYW1sOklzc3Vlcj5odHRwOi8vZXhhbXBsZS5jb20vc2FtbC9hY3MvZXhhbXBsZTwvc2FtbDpJc3N1ZXI+PHNhbWw6U3ViamVjdD48c2FtbDpOYW1lSUQgRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoxLjE6bmFtZWlkLWZvcm1hdDp1bnNwZWNpZmllZCI+amFuZS5kb2VAZXhhbXBsZS5jb208L3NhbWw6TmFtZUlEPjxzYW1sOlN1YmplY3RDb25maXJtYXRpb24gTWV0aG9kPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6Y206YmVhcmVyIj48c2FtbDpTdWJqZWN0Q29uZmlybWF0aW9uRGF0YSBOb3RPbk9yQWZ0ZXI9IjIwMTctMDQtMDRUMTc6NTQ6MTcuOTQ0WiIgUmVjaXBpZW50PSJodHRwOi8vZGJhOWE1ZmMubmdyb2suaW8vdjEvX3NhbWxfY2FsbGJhY2siLz48L3NhbWw6U3ViamVjdENvbmZpcm1hdGlvbj48L3NhbWw6U3ViamVjdD48c2FtbDpDb25kaXRpb25zIE5vdEJlZm9yZT0iMjAxNy0wNC0wNFQxNjo1NDoxNy45NDRaIiBOb3RPbk9yQWZ0ZXI9IjIwMTctMDQtMDRUMTc6NTQ6MTcuOTQ0WiI+PHNhbWw6QXVkaWVuY2VSZXN0cmljdGlvbj48c2FtbDpBdWRpZW5jZT5odHRwOi8vZXhhbXBsZS5jb20vc2FtbC9hY3MvZXhhbXBsZTwvc2FtbDpBdWRpZW5jZT48L3NhbWw6QXVkaWVuY2VSZXN0cmljdGlvbj48L3NhbWw6Q29uZGl0aW9ucz48c2FtbDpBdHRyaWJ1dGVTdGF0ZW1lbnQgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIiB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIj48c2FtbDpBdHRyaWJ1dGUgTmFtZT0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6MS4xOm5hbWVpZC1mb3JtYXQ6ZW1haWxBZGRyZXNzIj48c2FtbDpBdHRyaWJ1dGVWYWx1ZSB4c2k6dHlwZT0ieHM6YW55VHlwZSI+amFuZS5kb2VAZXhhbXBsZS5jb208L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48c2FtbDpBdHRyaWJ1dGUgTmFtZT0iRW1haWwiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czphbnlUeXBlIj5qYW5lLmRvZUBleGFtcGxlLmNvbTwvc2FtbDpBdHRyaWJ1dGVWYWx1ZT48L3NhbWw6QXR0cmlidXRlPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJGaXJzdE5hbWUiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czphbnlUeXBlIj5KYW5lPC9zYW1sOkF0dHJpYnV0ZVZhbHVlPjwvc2FtbDpBdHRyaWJ1dGU+PHNhbWw6QXR0cmlidXRlIE5hbWU9Ikxhc3ROYW1lIj48c2FtbDpBdHRyaWJ1dGVWYWx1ZSB4c2k6dHlwZT0ieHM6YW55VHlwZSI+RG9lPC9zYW1sOkF0dHJpYnV0ZVZhbHVlPjwvc2FtbDpBdHRyaWJ1dGU+PC9zYW1sOkF0dHJpYnV0ZVN0YXRlbWVudD48c2FtbDpBdXRoblN0YXRlbWVudCBBdXRobkluc3RhbnQ9IjIwMTctMDQtMDRUMTY6NTQ6MTcuOTQ0WiI+PHNhbWw6QXV0aG5Db250ZXh0PjxzYW1sOkF1dGhuQ29udGV4dENsYXNzUmVmPnVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphYzpjbGFzc2VzOnVuc3BlY2lmaWVkPC9zYW1sOkF1dGhuQ29udGV4dENsYXNzUmVmPjwvc2FtbDpBdXRobkNvbnRleHQ+PC9zYW1sOkF1dGhuU3RhdGVtZW50Pjwvc2FtbDpBc3NlcnRpb24+PC9zYW1scDpSZXNwb25zZT4= ================================================ FILE: providertests/testdata/saml.oktadev.com/response_16 ================================================ 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 ================================================ FILE: providertests/testdata/saml.oktadev.com/response_2 ================================================ PHNhbWxwOlJlc3BvbnNlIHhtbG5zOnNhbWxwPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiIElEPSJfMDg2Y2ZjMWVlMGJkYThhMDAzMTciIFZlcnNpb249IjIuMCIgSXNzdWVJbnN0YW50PSIyMDE3LTA0LTA0VDE2OjU0OjEzWiIgRGVzdGluYXRpb249Imh0dHA6Ly9kYmE5YTVmYy5uZ3Jvay5pby92MS9fc2FtbF9jYWxsYmFjayI+PHNhbWw6SXNzdWVyIHhtbG5zOnNhbWw9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPmh0dHA6Ly9leGFtcGxlLmNvbS9zYW1sL2Fjcy9leGFtcGxlPC9zYW1sOklzc3Vlcj48ZHM6U2lnbmF0dXJlIHhtbG5zOmRzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjIj48ZHM6U2lnbmVkSW5mbz48ZHM6Q2Fub25pY2FsaXphdGlvbk1ldGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDYvMTIveG1sLWMxNG4xMSIvPjxkczpTaWduYXR1cmVNZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzA0L3htbGRzaWctbW9yZSNyc2Etc2hhMjU2Ii8+PGRzOlJlZmVyZW5jZSBVUkk9IiI+PGRzOlRyYW5zZm9ybXM+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyNlbnZlbG9wZWQtc2lnbmF0dXJlIi8+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDYvMTIveG1sLWMxNG4xMSIvPjwvZHM6VHJhbnNmb3Jtcz48ZHM6RGlnZXN0TWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8wNC94bWxlbmMjc2hhMjU2Ii8+PGRzOkRpZ2VzdFZhbHVlPkdyVG1tTGdZZ1Q3cVlSc2RoZlJsY1BhZ1RuMXZuUWsvYVdJaGd1elhEVzA9PC9kczpEaWdlc3RWYWx1ZT48L2RzOlJlZmVyZW5jZT48L2RzOlNpZ25lZEluZm8+PGRzOlNpZ25hdHVyZVZhbHVlPko2dmZUSE4vQXN1MDljUFpSaEhjV09XdlBsbmZGeXFKcnpyWGZWUTJ2eThhZjlwUWpFaVB6L3JUOVVFcWc3TDlHZXB5Sk5xVmNpa3hROHpTUzlkTFhBWDB0WE1CcjJxQUNRQnZJbHRKSmxOeG1xYUtzQmYvdkpHU3kzNEIyVVB2WWhQVUNpMzBpMWcyNm04dEE0dXNaUFFlVFRzYlVIbyt2Rnh6Q1RCR0kzWTAzSTl5WEladHJPTlhna1F2Rk1oMldZc3VnUVpMR0cyRnZ4SlpaZDcraHFGUE1nT0V1ZWVqVUMvNk42MFBuaXc0K2Y3di9ZRjRyR01qZnVsT2J0YXI2Vk54YTkvZlRtUXRwZGxWSWhkWGdoN3dEcDdobzdvY1ExWk5VcDZTamdSNjRFYjNuVFVBR2JHY09PT0pNRWluWFlxV2xRazR3VGwzdzdVOW1kS0ZwQT09PC9kczpTaWduYXR1cmVWYWx1ZT48ZHM6S2V5SW5mbz48ZHM6WDUwOURhdGE+PGRzOlg1MDlDZXJ0aWZpY2F0ZT5NSUlEUERDQ0FpUUNDUUR5ZEpnT2xzenFiekFOQmdrcWhraUc5dzBCQVFVRkFEQmdNUXN3Q1FZRFZRUUdFd0pWVXpFVE1CRUdBMVVFQ0JNS1EyRnNhV1p2Y201cFlURVdNQlFHQTFVRUJ4TU5VMkZ1SUVaeVlXNWphWE5qYnpFUU1BNEdBMVVFQ2hNSFNtRnVhM2xEYnpFU01CQUdBMVVFQXhNSmJHOWpZV3hvYjNOME1CNFhEVEUwTURNeE1qRTVORFl6TTFvWERUSTNNVEV4T1RFNU5EWXpNMW93WURFTE1Ba0dBMVVFQmhNQ1ZWTXhFekFSQmdOVkJBZ1RDa05oYkdsbWIzSnVhV0V4RmpBVUJnTlZCQWNURFZOaGJpQkdjbUZ1WTJselkyOHhFREFPQmdOVkJBb1RCMHBoYm10NVEyOHhFakFRQmdOVkJBTVRDV3h2WTJGc2FHOXpkRENDQVNJd0RRWUpLb1pJaHZjTkFRRUJCUUFEZ2dFUEFEQ0NBUW9DZ2dFQkFNR3ZKcFJUVGFzUlVTUHFjYnFDRytablRBdXJudTB2VnBJRzlsekV4bmgxMW8vQkdtenU3bEIreUxIY0Vkd3JLQkJtcGVwREJQQ1l4cFZhanZ1RWhaZEtGeC9GZHk2ajVtSDNyclcwQmgvemQzNkNvVU5qYmJoSHlUamVNN0ZOMnlGM3U5bGN5dWJ1dk96cjNCM2dYNjZJd0psVTQ2K3d6Y1FWaFNPbE1rMnRYUitmSUtRRXhGck91Szl0YlgzSklCVXFJdHBJK0huQW93NTA5Q25NMTM0c3Z3OFBURkxrUjYvQ2NNcW5EZkRLMW05OTNQeW9DMVkrTjRYOVhraFNtRVFvQWxBSFBJNUxIcnZ1dWpNMTNudnRvVll2S1lvajdTY2d1bWtwV05Fdlg2NTJMZlhPbktZbGtCOFp5YnV4bUZmSWt6ZWRRcmJKc3lPaGZMMDNjTUVDQXdFQUFUQU5CZ2txaGtpRzl3MEJBUVVGQUFPQ0FRRUFlSHd6cXduekdFa3hqelNENDdpbVhhVHF0WXlFVFpvdzdYd0JjMFphRlM1MHFSRkpVZ0tUQW1LUzF4UUJQL3FIcFN0c1JPVDM1RFV4SkFFNk5ZMUticTNaYkN1aEdvU2xZMEw3VnpWVDV0cHU0RVk4K0RxL3UyRWpSbW1ob0w3VWtza3ZJWjJuMURkRVJ0ZCtZVU1UZXFZbDljbzQzY3Nad0Ruby9JS29tZU41cWFQYzM5SVpqaWtKK25VQzZrUEZLZXUvM2o5cmdITmxSdG9jSTZTMUZkdEZ6OU9aTVFscHIwSmJVdDJUM3hTL1lvUUpuNmNvRG1KTDVHVGlpS002Y09lK1VyMVZ3elMxSkVEYlNTMlRXV2h6cThvakxkcm90WUxHZDlKT3NvUWhFbG16K3RNZkNGUVVGTEV4aW5QQXl5N1lIbFNpVlgxM1FIMlhUdS9pUVE9PTwvZHM6WDUwOUNlcnRpZmljYXRlPjwvZHM6WDUwOURhdGE+PC9kczpLZXlJbmZvPjwvZHM6U2lnbmF0dXJlPjxzYW1scDpTdGF0dXM+PHNhbWxwOlN0YXR1c0NvZGUgVmFsdWU9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpzdGF0dXM6U3VjY2VzcyIvPjwvc2FtbHA6U3RhdHVzPjxzYW1sOkFzc2VydGlvbiB4bWxuczpzYW1sPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIiBWZXJzaW9uPSIyLjAiIElEPSJfcEZJRWo5U3hRZDFqSFdycHlwd1F2ZFNRSDFiYzFzSUUiIElzc3VlSW5zdGFudD0iMjAxNy0wNC0wNFQxNjo1NDoxMy4yMDdaIj48c2FtbDpJc3N1ZXI+aHR0cDovL2V4YW1wbGUuY29tL3NhbWwvYWNzL2V4YW1wbGU8L3NhbWw6SXNzdWVyPjxzYW1sOlN1YmplY3Q+PHNhbWw6TmFtZUlEIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6MS4xOm5hbWVpZC1mb3JtYXQ6dW5zcGVjaWZpZWQiPmphbmUuZG9lQGV4YW1wbGUuY29tPC9zYW1sOk5hbWVJRD48c2FtbDpTdWJqZWN0Q29uZmlybWF0aW9uIE1ldGhvZD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmNtOmJlYXJlciI+PHNhbWw6U3ViamVjdENvbmZpcm1hdGlvbkRhdGEgTm90T25PckFmdGVyPSIyMDE3LTA0LTA0VDE3OjU0OjEzLjIwN1oiIFJlY2lwaWVudD0iaHR0cDovL2RiYTlhNWZjLm5ncm9rLmlvL3YxL19zYW1sX2NhbGxiYWNrIi8+PC9zYW1sOlN1YmplY3RDb25maXJtYXRpb24+PC9zYW1sOlN1YmplY3Q+PHNhbWw6Q29uZGl0aW9ucyBOb3RCZWZvcmU9IjIwMTctMDQtMDRUMTY6NTQ6MTMuMjA3WiIgTm90T25PckFmdGVyPSIyMDE3LTA0LTA0VDE3OjU0OjEzLjIwN1oiPjxzYW1sOkF1ZGllbmNlUmVzdHJpY3Rpb24+PHNhbWw6QXVkaWVuY2U+aHR0cDovL2V4YW1wbGUuY29tL3NhbWwvYWNzL2V4YW1wbGU8L3NhbWw6QXVkaWVuY2U+PC9zYW1sOkF1ZGllbmNlUmVzdHJpY3Rpb24+PC9zYW1sOkNvbmRpdGlvbnM+PHNhbWw6QXR0cmlidXRlU3RhdGVtZW50IHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSI+PHNhbWw6QXR0cmlidXRlIE5hbWU9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjEuMTpuYW1laWQtZm9ybWF0OmVtYWlsQWRkcmVzcyI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOmFueVR5cGUiPmphbmUuZG9lQGV4YW1wbGUuY29tPC9zYW1sOkF0dHJpYnV0ZVZhbHVlPjwvc2FtbDpBdHRyaWJ1dGU+PHNhbWw6QXR0cmlidXRlIE5hbWU9IkVtYWlsIj48c2FtbDpBdHRyaWJ1dGVWYWx1ZSB4c2k6dHlwZT0ieHM6YW55VHlwZSI+amFuZS5kb2VAZXhhbXBsZS5jb208L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48c2FtbDpBdHRyaWJ1dGUgTmFtZT0iRmlyc3ROYW1lIj48c2FtbDpBdHRyaWJ1dGVWYWx1ZSB4c2k6dHlwZT0ieHM6YW55VHlwZSI+SmFuZTwvc2FtbDpBdHRyaWJ1dGVWYWx1ZT48L3NhbWw6QXR0cmlidXRlPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJMYXN0TmFtZSI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOmFueVR5cGUiPkRvZTwvc2FtbDpBdHRyaWJ1dGVWYWx1ZT48L3NhbWw6QXR0cmlidXRlPjwvc2FtbDpBdHRyaWJ1dGVTdGF0ZW1lbnQ+PHNhbWw6QXV0aG5TdGF0ZW1lbnQgQXV0aG5JbnN0YW50PSIyMDE3LTA0LTA0VDE2OjU0OjEzLjIwN1oiPjxzYW1sOkF1dGhuQ29udGV4dD48c2FtbDpBdXRobkNvbnRleHRDbGFzc1JlZj51cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YWM6Y2xhc3Nlczp1bnNwZWNpZmllZDwvc2FtbDpBdXRobkNvbnRleHRDbGFzc1JlZj48L3NhbWw6QXV0aG5Db250ZXh0Pjwvc2FtbDpBdXRoblN0YXRlbWVudD48L3NhbWw6QXNzZXJ0aW9uPjwvc2FtbHA6UmVzcG9uc2U+ ================================================ FILE: providertests/testdata/saml.oktadev.com/response_3 ================================================ PHNhbWxwOlJlc3BvbnNlIHhtbG5zOnNhbWxwPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiIElEPSJfNjEzOGY0ODBjODRlNmUzZGZlZDEiIFZlcnNpb249IjIuMCIgSXNzdWVJbnN0YW50PSIyMDE3LTA0LTA0VDE2OjU0OjE1WiIgRGVzdGluYXRpb249Imh0dHA6Ly9kYmE5YTVmYy5uZ3Jvay5pby92MS9fc2FtbF9jYWxsYmFjayI+PHNhbWw6SXNzdWVyIHhtbG5zOnNhbWw9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPmh0dHA6Ly9leGFtcGxlLmNvbS9zYW1sL2Fjcy9leGFtcGxlPC9zYW1sOklzc3Vlcj48ZHM6U2lnbmF0dXJlIHhtbG5zOmRzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjIj48ZHM6U2lnbmVkSW5mbz48ZHM6Q2Fub25pY2FsaXphdGlvbk1ldGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDYvMTIveG1sLWMxNG4xMSIvPjxkczpTaWduYXR1cmVNZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzA0L3htbGRzaWctbW9yZSNyc2Etc2hhMjU2Ii8+PGRzOlJlZmVyZW5jZSBVUkk9IiI+PGRzOlRyYW5zZm9ybXM+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyNlbnZlbG9wZWQtc2lnbmF0dXJlIi8+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDYvMTIveG1sLWMxNG4xMSIvPjwvZHM6VHJhbnNmb3Jtcz48ZHM6RGlnZXN0TWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8wNC94bWxlbmMjc2hhMjU2Ii8+PGRzOkRpZ2VzdFZhbHVlPk5ZSmw3VUtJaHUyN01lbG5jZkZYQmJXM09lZm04L2pGZ2VLOUIrYzZzLzA9PC9kczpEaWdlc3RWYWx1ZT48L2RzOlJlZmVyZW5jZT48L2RzOlNpZ25lZEluZm8+PGRzOlNpZ25hdHVyZVZhbHVlPmpBbjlyME5PMHd3eUI4L0cwU2JyNlJIYkdXT2NrOGtESEFoeGJMN0E5bkxVS2ZmUGcwT2ZnZmVwbTkxUk5YdmpwRlptaTk4YjZZN1lNWEdUUDZFL3JUR0hCMVR0bEFOTmJvRzFlQ2ZhVVFFWDdBT2p1dGZER1FTdmtQajJENE1IK2xibWxhMlRaa3hPd015MElEMGJJRGQxaE5GcTFvbk1MUGVNdko0aDNVZ240TmE4QnBLL1RLNHpqekpab0tMakFUQ3cxZUtuTkxaREFVOXJaM1A4OTJSdHNDSHoxZDZISC9qQ1hidXJoV1FNZ2FZTzNkRFc1UVNWSnZQU3EzblpSVUFPS1dOWGMxeGlkeWhOZmpSMkp2KzU3Smt6WFBkd1BmS1Q0UnpIb2R1TElHVU95anFkYy94MDhySWROWC9Jdyt4U013cXJhaXFyMHlpRERaVjh3QT09PC9kczpTaWduYXR1cmVWYWx1ZT48ZHM6S2V5SW5mbz48ZHM6WDUwOURhdGE+PGRzOlg1MDlDZXJ0aWZpY2F0ZT5NSUlEdFRDQ0FwMmdBd0lCQWdJSkFKNjVWb3ZzM2JpUE1BMEdDU3FHU0liM0RRRUJCUVVBTUVVeEN6QUpCZ05WQkFZVEFrRlZNUk13RVFZRFZRUUlFd3BUYjIxbExWTjBZWFJsTVNFd0h3WURWUVFLRXhoSmJuUmxjbTVsZENCWGFXUm5hWFJ6SUZCMGVTQk1kR1F3SGhjTk1UVXdOREl5TURBME9URTVXaGNOTVRZd01URXlNREEwT1RFNVdqQkZNUXN3Q1FZRFZRUUdFd0pCVlRFVE1CRUdBMVVFQ0JNS1UyOXRaUzFUZEdGMFpURWhNQjhHQTFVRUNoTVlTVzUwWlhKdVpYUWdWMmxrWjJsMGN5QlFkSGtnVEhSa01JSUJJakFOQmdrcWhraUc5dzBCQVFFRkFBT0NBUThBTUlJQkNnS0NBUUVBeFpZNzFhSlVPbUtzV25HL1hYTmhOVFRERUIvTXoyT0RHS2YraGNKVVo2MlZBRmZlTENWMnFucGJWL2tQbmF0cVpEd21qSVBZQ1lIUitCb3NNSkVhRWVHeVlrUlk2Z0xJNFZhSEVFZkRiTEJWNWR3TXhYWSt4cFFJYkdEQm82L3lZeTRyRHdDNVFKaXZjSW1HVUt0M2FpODNBTnRpbnFKZGU4d1h6TFA2U2x1V3FmT3FiYUtxVHRIYmo2MGYrOE5yUzd2eDM3ZFF3WHZzS041TDlXSmlpZ0V1aTdrOWJLOFBwYmNHaDZoK0dJQmZFTUM0OGJYWi9uN2RnK04waFM2VDQwaTdlVmF3U0ppNmZabXFwdTNYbXo0RGd3ZjdLVk1EUFNUWWxzakVkS1dqeWQzbitKc0FpTUFMMGNHbG10dTB5aVNuYmF5OFBXYTRTblZVM1pjM3FRSURBUUFCbzRHbk1JR2tNQjBHQTFVZERnUVdCQlMwMy9kUjF6OWEzS084K3owUjhBRUZyNkJvempCMUJnTlZIU01FYmpCc2dCUzAzL2RSMXo5YTNLTzgrejBSOEFFRnI2Qm96cUZKcEVjd1JURUxNQWtHQTFVRUJoTUNRVlV4RXpBUkJnTlZCQWdUQ2xOdmJXVXRVM1JoZEdVeElUQWZCZ05WQkFvVEdFbHVkR1Z5Ym1WMElGZHBaR2RwZEhNZ1VIUjVJRXgwWklJSkFKNjVWb3ZzM2JpUE1Bd0dBMVVkRXdRRk1BTUJBZjh3RFFZSktvWklodmNOQVFFRkJRQURnZ0VCQUZyQWFqbmwwNHprTVd1Q2YyaWpNWjJUYXdoaTR5OWFuN1RIeVdybXVQYUVhWVYxbzFWSHFnMGIwTUM5S2pFd0c5ZnlZK01JazNBOE5BbG8wUnBFUmFJUHU2c1JxTUVqUDI0eXZZbEsvQ1F0NU1Id1YyZkRHa2xLWkVzTUY5a2t3ZGErSThaQk94bmVYeDFhdTdDWTZwaFB4S2ltMDd4UmNJZXBNVW9DSk9JUHFQWHoxQ2xZZlFmNXJyM0pxL1hCQkxhTnVMSHloMkQ3Q1MzVDFYenFCZlNYR1FxK0RwWWtmMG9RU0VCeXd1TG1ISTF0aGpSeVNjQ0RjWGxYd3JWa3IwMit2TzE0dW5EWG9YWU1RS01LdWN3MTFzYWRsUSsyMFF3WHVHQ0Fick9OY1BJQmd3bFF6aXRNcXpCSWs3TCsxbnBzRDRkVmRmV3hzeHFKSzZNWjNpQT08L2RzOlg1MDlDZXJ0aWZpY2F0ZT48L2RzOlg1MDlEYXRhPjwvZHM6S2V5SW5mbz48L2RzOlNpZ25hdHVyZT48c2FtbHA6U3RhdHVzPjxzYW1scDpTdGF0dXNDb2RlIFZhbHVlPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6c3RhdHVzOlN1Y2Nlc3MiLz48L3NhbWxwOlN0YXR1cz48c2FtbDpBc3NlcnRpb24geG1sbnM6c2FtbD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiIgVmVyc2lvbj0iMi4wIiBJRD0iX1hVYTREbVhUVFFEM2lyb01ab21YdVRSQWNVUmZDRDQwIiBJc3N1ZUluc3RhbnQ9IjIwMTctMDQtMDRUMTY6NTQ6MTUuNDcwWiI+PHNhbWw6SXNzdWVyPmh0dHA6Ly9leGFtcGxlLmNvbS9zYW1sL2Fjcy9leGFtcGxlPC9zYW1sOklzc3Vlcj48c2FtbDpTdWJqZWN0PjxzYW1sOk5hbWVJRCBGb3JtYXQ9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjEuMTpuYW1laWQtZm9ybWF0OnVuc3BlY2lmaWVkIj5qYW5lLmRvZUBleGFtcGxlLmNvbTwvc2FtbDpOYW1lSUQ+PHNhbWw6U3ViamVjdENvbmZpcm1hdGlvbiBNZXRob2Q9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpjbTpiZWFyZXIiPjxzYW1sOlN1YmplY3RDb25maXJtYXRpb25EYXRhIE5vdE9uT3JBZnRlcj0iMjAxNy0wNC0wNFQxNzo1NDoxNS40NzBaIiBSZWNpcGllbnQ9Imh0dHA6Ly9kYmE5YTVmYy5uZ3Jvay5pby92MS9fc2FtbF9jYWxsYmFjayIvPjwvc2FtbDpTdWJqZWN0Q29uZmlybWF0aW9uPjwvc2FtbDpTdWJqZWN0PjxzYW1sOkNvbmRpdGlvbnMgTm90QmVmb3JlPSIyMDE3LTA0LTA0VDE2OjU0OjE1LjQ3MFoiIE5vdE9uT3JBZnRlcj0iMjAxNy0wNC0wNFQxNzo1NDoxNS40NzBaIj48c2FtbDpBdWRpZW5jZVJlc3RyaWN0aW9uPjxzYW1sOkF1ZGllbmNlPmh0dHA6Ly9leGFtcGxlLmNvbS9zYW1sL2Fjcy9leGFtcGxlPC9zYW1sOkF1ZGllbmNlPjwvc2FtbDpBdWRpZW5jZVJlc3RyaWN0aW9uPjwvc2FtbDpDb25kaXRpb25zPjxzYW1sOkF0dHJpYnV0ZVN0YXRlbWVudCB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEtaW5zdGFuY2UiPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoxLjE6bmFtZWlkLWZvcm1hdDplbWFpbEFkZHJlc3MiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czphbnlUeXBlIj5qYW5lLmRvZUBleGFtcGxlLmNvbTwvc2FtbDpBdHRyaWJ1dGVWYWx1ZT48L3NhbWw6QXR0cmlidXRlPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJFbWFpbCI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOmFueVR5cGUiPmphbmUuZG9lQGV4YW1wbGUuY29tPC9zYW1sOkF0dHJpYnV0ZVZhbHVlPjwvc2FtbDpBdHRyaWJ1dGU+PHNhbWw6QXR0cmlidXRlIE5hbWU9IkZpcnN0TmFtZSI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOmFueVR5cGUiPkphbmU8L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48c2FtbDpBdHRyaWJ1dGUgTmFtZT0iTGFzdE5hbWUiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czphbnlUeXBlIj5Eb2U8L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48L3NhbWw6QXR0cmlidXRlU3RhdGVtZW50PjxzYW1sOkF1dGhuU3RhdGVtZW50IEF1dGhuSW5zdGFudD0iMjAxNy0wNC0wNFQxNjo1NDoxNS40NzBaIj48c2FtbDpBdXRobkNvbnRleHQ+PHNhbWw6QXV0aG5Db250ZXh0Q2xhc3NSZWY+dXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFjOmNsYXNzZXM6dW5zcGVjaWZpZWQ8L3NhbWw6QXV0aG5Db250ZXh0Q2xhc3NSZWY+PC9zYW1sOkF1dGhuQ29udGV4dD48L3NhbWw6QXV0aG5TdGF0ZW1lbnQ+PC9zYW1sOkFzc2VydGlvbj48L3NhbWxwOlJlc3BvbnNlPg== ================================================ FILE: providertests/testdata/saml.oktadev.com/response_4 ================================================ PHNhbWxwOlJlc3BvbnNlIHhtbG5zOnNhbWxwPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiIElEPSJfOGM1ZjQ0NDMyNmMwZjM3N2YzNzYiIFZlcnNpb249IjIuMCIgSXNzdWVJbnN0YW50PSIyMDE3LTA0LTA0VDE2OjU0OjE1WiIgRGVzdGluYXRpb249ImZha2UuaWRlbnRpZmllci5leGFtcGxlLmNvbSI+PHNhbWw6SXNzdWVyIHhtbG5zOnNhbWw9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPmh0dHA6Ly9leGFtcGxlLmNvbS9zYW1sL2Fjcy9leGFtcGxlPC9zYW1sOklzc3Vlcj48ZHM6U2lnbmF0dXJlIHhtbG5zOmRzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjIj48ZHM6U2lnbmVkSW5mbz48ZHM6Q2Fub25pY2FsaXphdGlvbk1ldGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDYvMTIveG1sLWMxNG4xMSIvPjxkczpTaWduYXR1cmVNZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzA0L3htbGRzaWctbW9yZSNyc2Etc2hhMjU2Ii8+PGRzOlJlZmVyZW5jZSBVUkk9IiI+PGRzOlRyYW5zZm9ybXM+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyNlbnZlbG9wZWQtc2lnbmF0dXJlIi8+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDYvMTIveG1sLWMxNG4xMSIvPjwvZHM6VHJhbnNmb3Jtcz48ZHM6RGlnZXN0TWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8wNC94bWxlbmMjc2hhMjU2Ii8+PGRzOkRpZ2VzdFZhbHVlPjFXTjBHQkFKVnVoTTE1dUdrWHZNMzg4Q0NKckwxWjcxSG0vNW9YVWdnTGs9PC9kczpEaWdlc3RWYWx1ZT48L2RzOlJlZmVyZW5jZT48L2RzOlNpZ25lZEluZm8+PGRzOlNpZ25hdHVyZVZhbHVlPmprUkxSM0pJTlJGb3g1TldJYWRKN0dLR2tXMlprbTd3R0toQ1dFYWtUc2Y1M0NRcU9GVHNNQzMxVk9DcWtJdUIvYkpFdEo3UjFXaktmdTNuRkVlV3NHK3NKQkl4K1NzcUVCeDlWUmYxdEZiL0RIcGc4eWFKMlVUU0swRGpTZldpYy9oS0ZNQWZvVEpLdS8zZmppSlJIOW9hbUNlOUlEMjRLQWNGRlB0dWt6WEgyaElJTFZNdnJwKzBGREVVSFhuTW1RZlVnTmtxV2tCK0I2VS9EVjZLck44YVJiQ3duV2FMaTUzR09ldUx4Ykx3OWFSd0pTeFJFeHk3U1padkRhY2cwN0h3UWJkTCtKcFRSaTNoLzY3SGVoR1p1SVRGSUdjdnIydGpIdnUrRnRkRnQvU3U0UENjcVo1eGU3SVF4WFUvcjZqQjdkTmNhQmFYcWt4UExhRmNnZz09PC9kczpTaWduYXR1cmVWYWx1ZT48ZHM6S2V5SW5mbz48ZHM6WDUwOURhdGE+PGRzOlg1MDlDZXJ0aWZpY2F0ZT5NSUlEUERDQ0FpUUNDUUR5ZEpnT2xzenFiekFOQmdrcWhraUc5dzBCQVFVRkFEQmdNUXN3Q1FZRFZRUUdFd0pWVXpFVE1CRUdBMVVFQ0JNS1EyRnNhV1p2Y201cFlURVdNQlFHQTFVRUJ4TU5VMkZ1SUVaeVlXNWphWE5qYnpFUU1BNEdBMVVFQ2hNSFNtRnVhM2xEYnpFU01CQUdBMVVFQXhNSmJHOWpZV3hvYjNOME1CNFhEVEUwTURNeE1qRTVORFl6TTFvWERUSTNNVEV4T1RFNU5EWXpNMW93WURFTE1Ba0dBMVVFQmhNQ1ZWTXhFekFSQmdOVkJBZ1RDa05oYkdsbWIzSnVhV0V4RmpBVUJnTlZCQWNURFZOaGJpQkdjbUZ1WTJselkyOHhFREFPQmdOVkJBb1RCMHBoYm10NVEyOHhFakFRQmdOVkJBTVRDV3h2WTJGc2FHOXpkRENDQVNJd0RRWUpLb1pJaHZjTkFRRUJCUUFEZ2dFUEFEQ0NBUW9DZ2dFQkFNR3ZKcFJUVGFzUlVTUHFjYnFDRytablRBdXJudTB2VnBJRzlsekV4bmgxMW8vQkdtenU3bEIreUxIY0Vkd3JLQkJtcGVwREJQQ1l4cFZhanZ1RWhaZEtGeC9GZHk2ajVtSDNyclcwQmgvemQzNkNvVU5qYmJoSHlUamVNN0ZOMnlGM3U5bGN5dWJ1dk96cjNCM2dYNjZJd0psVTQ2K3d6Y1FWaFNPbE1rMnRYUitmSUtRRXhGck91Szl0YlgzSklCVXFJdHBJK0huQW93NTA5Q25NMTM0c3Z3OFBURkxrUjYvQ2NNcW5EZkRLMW05OTNQeW9DMVkrTjRYOVhraFNtRVFvQWxBSFBJNUxIcnZ1dWpNMTNudnRvVll2S1lvajdTY2d1bWtwV05Fdlg2NTJMZlhPbktZbGtCOFp5YnV4bUZmSWt6ZWRRcmJKc3lPaGZMMDNjTUVDQXdFQUFUQU5CZ2txaGtpRzl3MEJBUVVGQUFPQ0FRRUFlSHd6cXduekdFa3hqelNENDdpbVhhVHF0WXlFVFpvdzdYd0JjMFphRlM1MHFSRkpVZ0tUQW1LUzF4UUJQL3FIcFN0c1JPVDM1RFV4SkFFNk5ZMUticTNaYkN1aEdvU2xZMEw3VnpWVDV0cHU0RVk4K0RxL3UyRWpSbW1ob0w3VWtza3ZJWjJuMURkRVJ0ZCtZVU1UZXFZbDljbzQzY3Nad0Ruby9JS29tZU41cWFQYzM5SVpqaWtKK25VQzZrUEZLZXUvM2o5cmdITmxSdG9jSTZTMUZkdEZ6OU9aTVFscHIwSmJVdDJUM3hTL1lvUUpuNmNvRG1KTDVHVGlpS002Y09lK1VyMVZ3elMxSkVEYlNTMlRXV2h6cThvakxkcm90WUxHZDlKT3NvUWhFbG16K3RNZkNGUVVGTEV4aW5QQXl5N1lIbFNpVlgxM1FIMlhUdS9pUVE9PTwvZHM6WDUwOUNlcnRpZmljYXRlPjwvZHM6WDUwOURhdGE+PC9kczpLZXlJbmZvPjwvZHM6U2lnbmF0dXJlPjxzYW1scDpTdGF0dXM+PHNhbWxwOlN0YXR1c0NvZGUgVmFsdWU9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpzdGF0dXM6U3VjY2VzcyIvPjwvc2FtbHA6U3RhdHVzPjxzYW1sOkFzc2VydGlvbiB4bWxuczpzYW1sPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIiBWZXJzaW9uPSIyLjAiIElEPSJfSnp4RDZzSkFpREx1cE9uRmVDT2lRWXJDMWhDUWt4SFciIElzc3VlSW5zdGFudD0iMjAxNy0wNC0wNFQxNjo1NDoxNS43NjNaIj48c2FtbDpJc3N1ZXI+aHR0cDovL2V4YW1wbGUuY29tL3NhbWwvYWNzL2V4YW1wbGU8L3NhbWw6SXNzdWVyPjxzYW1sOlN1YmplY3Q+PHNhbWw6TmFtZUlEIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6MS4xOm5hbWVpZC1mb3JtYXQ6dW5zcGVjaWZpZWQiPmphbmUuZG9lQGV4YW1wbGUuY29tPC9zYW1sOk5hbWVJRD48c2FtbDpTdWJqZWN0Q29uZmlybWF0aW9uIE1ldGhvZD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmNtOmJlYXJlciI+PHNhbWw6U3ViamVjdENvbmZpcm1hdGlvbkRhdGEgTm90T25PckFmdGVyPSIyMDE3LTA0LTA0VDE3OjU0OjE1Ljc2M1oiIFJlY2lwaWVudD0iaHR0cDovL2RiYTlhNWZjLm5ncm9rLmlvL3YxL19zYW1sX2NhbGxiYWNrIi8+PC9zYW1sOlN1YmplY3RDb25maXJtYXRpb24+PC9zYW1sOlN1YmplY3Q+PHNhbWw6Q29uZGl0aW9ucyBOb3RCZWZvcmU9IjIwMTctMDQtMDRUMTY6NTQ6MTUuNzYzWiIgTm90T25PckFmdGVyPSIyMDE3LTA0LTA0VDE3OjU0OjE1Ljc2M1oiPjxzYW1sOkF1ZGllbmNlUmVzdHJpY3Rpb24+PHNhbWw6QXVkaWVuY2U+aHR0cDovL2V4YW1wbGUuY29tL3NhbWwvYWNzL2V4YW1wbGU8L3NhbWw6QXVkaWVuY2U+PC9zYW1sOkF1ZGllbmNlUmVzdHJpY3Rpb24+PC9zYW1sOkNvbmRpdGlvbnM+PHNhbWw6QXR0cmlidXRlU3RhdGVtZW50IHhtbG5zOnhzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYSIgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVtYS1pbnN0YW5jZSI+PHNhbWw6QXR0cmlidXRlIE5hbWU9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjEuMTpuYW1laWQtZm9ybWF0OmVtYWlsQWRkcmVzcyI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOmFueVR5cGUiPmphbmUuZG9lQGV4YW1wbGUuY29tPC9zYW1sOkF0dHJpYnV0ZVZhbHVlPjwvc2FtbDpBdHRyaWJ1dGU+PHNhbWw6QXR0cmlidXRlIE5hbWU9IkVtYWlsIj48c2FtbDpBdHRyaWJ1dGVWYWx1ZSB4c2k6dHlwZT0ieHM6YW55VHlwZSI+amFuZS5kb2VAZXhhbXBsZS5jb208L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48c2FtbDpBdHRyaWJ1dGUgTmFtZT0iRmlyc3ROYW1lIj48c2FtbDpBdHRyaWJ1dGVWYWx1ZSB4c2k6dHlwZT0ieHM6YW55VHlwZSI+SmFuZTwvc2FtbDpBdHRyaWJ1dGVWYWx1ZT48L3NhbWw6QXR0cmlidXRlPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJMYXN0TmFtZSI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOmFueVR5cGUiPkRvZTwvc2FtbDpBdHRyaWJ1dGVWYWx1ZT48L3NhbWw6QXR0cmlidXRlPjwvc2FtbDpBdHRyaWJ1dGVTdGF0ZW1lbnQ+PHNhbWw6QXV0aG5TdGF0ZW1lbnQgQXV0aG5JbnN0YW50PSIyMDE3LTA0LTA0VDE2OjU0OjE1Ljc2M1oiPjxzYW1sOkF1dGhuQ29udGV4dD48c2FtbDpBdXRobkNvbnRleHRDbGFzc1JlZj51cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YWM6Y2xhc3Nlczp1bnNwZWNpZmllZDwvc2FtbDpBdXRobkNvbnRleHRDbGFzc1JlZj48L3NhbWw6QXV0aG5Db250ZXh0Pjwvc2FtbDpBdXRoblN0YXRlbWVudD48L3NhbWw6QXNzZXJ0aW9uPjwvc2FtbHA6UmVzcG9uc2U+ ================================================ FILE: providertests/testdata/saml.oktadev.com/response_5 ================================================ PHNhbWxwOlJlc3BvbnNlIHhtbG5zOnNhbWxwPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiIElEPSJfODE0ZDRiYmNlMThmODQ4ODNjZjciIFZlcnNpb249IjIuMCIgSXNzdWVJbnN0YW50PSIyMDE3LTA0LTA0VDE2OjU0OjE1WiIgRGVzdGluYXRpb249Imh0dHA6Ly9kYmE5YTVmYy5uZ3Jvay5pby92MS9fc2FtbF9jYWxsYmFjayI+PHNhbWw6SXNzdWVyIHhtbG5zOnNhbWw9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPmZha2UuaWRlbnRpZmllci5leGFtcGxlLmNvbTwvc2FtbDpJc3N1ZXI+PGRzOlNpZ25hdHVyZSB4bWxuczpkcz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8wOS94bWxkc2lnIyI+PGRzOlNpZ25lZEluZm8+PGRzOkNhbm9uaWNhbGl6YXRpb25NZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDA2LzEyL3htbC1jMTRuMTEiLz48ZHM6U2lnbmF0dXJlTWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8wNC94bWxkc2lnLW1vcmUjcnNhLXNoYTI1NiIvPjxkczpSZWZlcmVuY2UgVVJJPSIiPjxkczpUcmFuc2Zvcm1zPjxkczpUcmFuc2Zvcm0gQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjZW52ZWxvcGVkLXNpZ25hdHVyZSIvPjxkczpUcmFuc2Zvcm0gQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDA2LzEyL3htbC1jMTRuMTEiLz48L2RzOlRyYW5zZm9ybXM+PGRzOkRpZ2VzdE1ldGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvMDQveG1sZW5jI3NoYTI1NiIvPjxkczpEaWdlc3RWYWx1ZT5DUzZnZXc4UFlidjJiOXpwMWE0clJmOWVpVGVwYXRjZ2JlRDF0QmRNcEdnPTwvZHM6RGlnZXN0VmFsdWU+PC9kczpSZWZlcmVuY2U+PC9kczpTaWduZWRJbmZvPjxkczpTaWduYXR1cmVWYWx1ZT5oZ1FSbklkOURLelEwWWVTSE8wSE5BRmNXNjhJOWp6VUFnQnV5RkJXaXJrOEVsenVUREhJUmtpdW1YWUZ3THdsVjgzZ2dsdDFsM25ST3NydmRxb0YvWHk3dnp4QXpIK0ZQSjVtSVdLWlNkN0JSL0paeWJ6MGs2ektmSXlHZ2MyN0E2Nkd4b3docEZucURIMjFQWDBpVGhYVUFCMzNsSHNBVGprVlpzWjNJNitIT1RtWUwxaWZXQWQ2OTdMdnJ2bUExU1JQaG9vQkc5Slh1RWRTSE4rVDhBUlJpbmFGRkFxS2w4eis1RnlOZkdYR2tiT0V4RzRwV2NsK01FcVpTMS9yR2FvQ2Vrc1JhU3R5aU0zRTdjUzdNWnZDVEVPSTNuUkJHMHQzeCtqejhQaE9ta2krQVR2NHZwTGp3cGhTaWNpL1Y5UFFnRWsrbFc5TGpqa1hicjhGY1E9PTwvZHM6U2lnbmF0dXJlVmFsdWU+PGRzOktleUluZm8+PGRzOlg1MDlEYXRhPjxkczpYNTA5Q2VydGlmaWNhdGU+TUlJRFBEQ0NBaVFDQ1FEeWRKZ09sc3pxYnpBTkJna3Foa2lHOXcwQkFRVUZBREJnTVFzd0NRWURWUVFHRXdKVlV6RVRNQkVHQTFVRUNCTUtRMkZzYVdadmNtNXBZVEVXTUJRR0ExVUVCeE1OVTJGdUlFWnlZVzVqYVhOamJ6RVFNQTRHQTFVRUNoTUhTbUZ1YTNsRGJ6RVNNQkFHQTFVRUF4TUpiRzlqWVd4b2IzTjBNQjRYRFRFME1ETXhNakU1TkRZek0xb1hEVEkzTVRFeE9URTVORFl6TTFvd1lERUxNQWtHQTFVRUJoTUNWVk14RXpBUkJnTlZCQWdUQ2tOaGJHbG1iM0p1YVdFeEZqQVVCZ05WQkFjVERWTmhiaUJHY21GdVkybHpZMjh4RURBT0JnTlZCQW9UQjBwaGJtdDVRMjh4RWpBUUJnTlZCQU1UQ1d4dlkyRnNhRzl6ZERDQ0FTSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnRVBBRENDQVFvQ2dnRUJBTUd2SnBSVFRhc1JVU1BxY2JxQ0crWm5UQXVybnUwdlZwSUc5bHpFeG5oMTFvL0JHbXp1N2xCK3lMSGNFZHdyS0JCbXBlcERCUENZeHBWYWp2dUVoWmRLRngvRmR5Nmo1bUgzcnJXMEJoL3pkMzZDb1VOamJiaEh5VGplTTdGTjJ5RjN1OWxjeXVidXZPenIzQjNnWDY2SXdKbFU0Nit3emNRVmhTT2xNazJ0WFIrZklLUUV4RnJPdUs5dGJYM0pJQlVxSXRwSStIbkFvdzUwOUNuTTEzNHN2dzhQVEZMa1I2L0NjTXFuRGZESzFtOTkzUHlvQzFZK040WDlYa2hTbUVRb0FsQUhQSTVMSHJ2dXVqTTEzbnZ0b1ZZdktZb2o3U2NndW1rcFdORXZYNjUyTGZYT25LWWxrQjhaeWJ1eG1GZklremVkUXJiSnN5T2hmTDAzY01FQ0F3RUFBVEFOQmdrcWhraUc5dzBCQVFVRkFBT0NBUUVBZUh3enF3bnpHRWt4anpTRDQ3aW1YYVRxdFl5RVRab3c3WHdCYzBaYUZTNTBxUkZKVWdLVEFtS1MxeFFCUC9xSHBTdHNST1QzNURVeEpBRTZOWTFLYnEzWmJDdWhHb1NsWTBMN1Z6VlQ1dHB1NEVZOCtEcS91MkVqUm1taG9MN1Vrc2t2SVoybjFEZEVSdGQrWVVNVGVxWWw5Y280M2NzWndEbm8vSUtvbWVONXFhUGMzOUlaamlrSituVUM2a1BGS2V1LzNqOXJnSE5sUnRvY0k2UzFGZHRGejlPWk1RbHByMEpiVXQyVDN4Uy9Zb1FKbjZjb0RtSkw1R1RpaUtNNmNPZStVcjFWd3pTMUpFRGJTUzJUV1doenE4b2pMZHJvdFlMR2Q5Sk9zb1FoRWxteit0TWZDRlFVRkxFeGluUEF5eTdZSGxTaVZYMTNRSDJYVHUvaVFRPT08L2RzOlg1MDlDZXJ0aWZpY2F0ZT48L2RzOlg1MDlEYXRhPjwvZHM6S2V5SW5mbz48L2RzOlNpZ25hdHVyZT48c2FtbHA6U3RhdHVzPjxzYW1scDpTdGF0dXNDb2RlIFZhbHVlPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6c3RhdHVzOlN1Y2Nlc3MiLz48L3NhbWxwOlN0YXR1cz48c2FtbDpBc3NlcnRpb24geG1sbnM6c2FtbD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiIgVmVyc2lvbj0iMi4wIiBJRD0iX2pRb1ExUDFlQlY5ZXdPVFZxRER0Z1V0VHlxU0R6SENyIiBJc3N1ZUluc3RhbnQ9IjIwMTctMDQtMDRUMTY6NTQ6MTUuOTUxWiI+PHNhbWw6SXNzdWVyPmZha2UuaWRlbnRpZmllci5leGFtcGxlLmNvbTwvc2FtbDpJc3N1ZXI+PHNhbWw6U3ViamVjdD48c2FtbDpOYW1lSUQgRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoxLjE6bmFtZWlkLWZvcm1hdDp1bnNwZWNpZmllZCI+amFuZS5kb2VAZXhhbXBsZS5jb208L3NhbWw6TmFtZUlEPjxzYW1sOlN1YmplY3RDb25maXJtYXRpb24gTWV0aG9kPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6Y206YmVhcmVyIj48c2FtbDpTdWJqZWN0Q29uZmlybWF0aW9uRGF0YSBOb3RPbk9yQWZ0ZXI9IjIwMTctMDQtMDRUMTc6NTQ6MTUuOTUxWiIgUmVjaXBpZW50PSJodHRwOi8vZGJhOWE1ZmMubmdyb2suaW8vdjEvX3NhbWxfY2FsbGJhY2siLz48L3NhbWw6U3ViamVjdENvbmZpcm1hdGlvbj48L3NhbWw6U3ViamVjdD48c2FtbDpDb25kaXRpb25zIE5vdEJlZm9yZT0iMjAxNy0wNC0wNFQxNjo1NDoxNS45NTFaIiBOb3RPbk9yQWZ0ZXI9IjIwMTctMDQtMDRUMTc6NTQ6MTUuOTUxWiI+PHNhbWw6QXVkaWVuY2VSZXN0cmljdGlvbj48c2FtbDpBdWRpZW5jZT5odHRwOi8vZXhhbXBsZS5jb20vc2FtbC9hY3MvZXhhbXBsZTwvc2FtbDpBdWRpZW5jZT48L3NhbWw6QXVkaWVuY2VSZXN0cmljdGlvbj48L3NhbWw6Q29uZGl0aW9ucz48c2FtbDpBdHRyaWJ1dGVTdGF0ZW1lbnQgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIiB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIj48c2FtbDpBdHRyaWJ1dGUgTmFtZT0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6MS4xOm5hbWVpZC1mb3JtYXQ6ZW1haWxBZGRyZXNzIj48c2FtbDpBdHRyaWJ1dGVWYWx1ZSB4c2k6dHlwZT0ieHM6YW55VHlwZSI+amFuZS5kb2VAZXhhbXBsZS5jb208L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48c2FtbDpBdHRyaWJ1dGUgTmFtZT0iRW1haWwiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czphbnlUeXBlIj5qYW5lLmRvZUBleGFtcGxlLmNvbTwvc2FtbDpBdHRyaWJ1dGVWYWx1ZT48L3NhbWw6QXR0cmlidXRlPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJGaXJzdE5hbWUiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czphbnlUeXBlIj5KYW5lPC9zYW1sOkF0dHJpYnV0ZVZhbHVlPjwvc2FtbDpBdHRyaWJ1dGU+PHNhbWw6QXR0cmlidXRlIE5hbWU9Ikxhc3ROYW1lIj48c2FtbDpBdHRyaWJ1dGVWYWx1ZSB4c2k6dHlwZT0ieHM6YW55VHlwZSI+RG9lPC9zYW1sOkF0dHJpYnV0ZVZhbHVlPjwvc2FtbDpBdHRyaWJ1dGU+PC9zYW1sOkF0dHJpYnV0ZVN0YXRlbWVudD48c2FtbDpBdXRoblN0YXRlbWVudCBBdXRobkluc3RhbnQ9IjIwMTctMDQtMDRUMTY6NTQ6MTUuOTUxWiI+PHNhbWw6QXV0aG5Db250ZXh0PjxzYW1sOkF1dGhuQ29udGV4dENsYXNzUmVmPnVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphYzpjbGFzc2VzOnVuc3BlY2lmaWVkPC9zYW1sOkF1dGhuQ29udGV4dENsYXNzUmVmPjwvc2FtbDpBdXRobkNvbnRleHQ+PC9zYW1sOkF1dGhuU3RhdGVtZW50Pjwvc2FtbDpBc3NlcnRpb24+PC9zYW1scDpSZXNwb25zZT4= ================================================ FILE: providertests/testdata/saml.oktadev.com/response_6 ================================================ PHNhbWxwOlJlc3BvbnNlIHhtbG5zOnNhbWxwPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiIElEPSJfMzFmMmM3NmY0ZDhlNTRmZTRmNTYiIFZlcnNpb249IjIuMCIgSXNzdWVJbnN0YW50PSIyMDE3LTA0LTA0VDE2OjU0OjE2WiIgRGVzdGluYXRpb249Imh0dHA6Ly9kYmE5YTVmYy5uZ3Jvay5pby92MS9fc2FtbF9jYWxsYmFjayI+PHNhbWw6SXNzdWVyIHhtbG5zOnNhbWw9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPmh0dHA6Ly9leGFtcGxlLmNvbS9zYW1sL2Fjcy9leGFtcGxlPC9zYW1sOklzc3Vlcj48ZHM6U2lnbmF0dXJlIHhtbG5zOmRzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjIj48ZHM6U2lnbmVkSW5mbz48ZHM6Q2Fub25pY2FsaXphdGlvbk1ldGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDYvMTIveG1sLWMxNG4xMSIvPjxkczpTaWduYXR1cmVNZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzA0L3htbGRzaWctbW9yZSNyc2Etc2hhMjU2Ii8+PGRzOlJlZmVyZW5jZSBVUkk9IiI+PGRzOlRyYW5zZm9ybXM+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyNlbnZlbG9wZWQtc2lnbmF0dXJlIi8+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDYvMTIveG1sLWMxNG4xMSIvPjwvZHM6VHJhbnNmb3Jtcz48ZHM6RGlnZXN0TWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8wNC94bWxlbmMjc2hhMjU2Ii8+PGRzOkRpZ2VzdFZhbHVlPldBRnowNDF4dGc4OGk0M1o3U3BadFl0SWovWCtsc2xzbjBQNWxxMXlYMUk9PC9kczpEaWdlc3RWYWx1ZT48L2RzOlJlZmVyZW5jZT48L2RzOlNpZ25lZEluZm8+PGRzOlNpZ25hdHVyZVZhbHVlPlhBUTZlYmxtYlBEM1pua3huTUkwdldlbUt2a0VyZGd1UXN3T2V0OEpxZko1OW0zMUpqN3lYUGZFVHEvb1o2WlR1eTlSOGtOZzR3WGhYUDk1a2gzU2VqK3RzUUs1MVhlVlNjNHEwSkRTZzE1S2VKK2dHUEcyMTVvOFVnNUlUVlhkMlc1dVNZL3VhY2w4RU82TmZXVTk2ZTVtWXpsS2FkaU9VaU5BbnFHRHh5VzltZGlpY21PWVpMcDB6SHFzSTNqeE90Slp4c0VOaW5HaWJpZ2RwSjFwdEc5S0ExUzYvSndLa09BRnlaRXQvRkJVSGhOc0NtcW9lL01uYm1FeDZhT1dRM0FnRDRwdTk0M3BlVWIzS01QdERkVmI0eGNnT1hLRkl6d091YlpzdncvbGlibXZMb3pFaG1wVEJLZFluVEdjWUd6ZnVQc0hNK1hWdk5aY1ZUN1htZz09PC9kczpTaWduYXR1cmVWYWx1ZT48ZHM6S2V5SW5mbz48ZHM6WDUwOURhdGE+PGRzOlg1MDlDZXJ0aWZpY2F0ZT5NSUlEUERDQ0FpUUNDUUR5ZEpnT2xzenFiekFOQmdrcWhraUc5dzBCQVFVRkFEQmdNUXN3Q1FZRFZRUUdFd0pWVXpFVE1CRUdBMVVFQ0JNS1EyRnNhV1p2Y201cFlURVdNQlFHQTFVRUJ4TU5VMkZ1SUVaeVlXNWphWE5qYnpFUU1BNEdBMVVFQ2hNSFNtRnVhM2xEYnpFU01CQUdBMVVFQXhNSmJHOWpZV3hvYjNOME1CNFhEVEUwTURNeE1qRTVORFl6TTFvWERUSTNNVEV4T1RFNU5EWXpNMW93WURFTE1Ba0dBMVVFQmhNQ1ZWTXhFekFSQmdOVkJBZ1RDa05oYkdsbWIzSnVhV0V4RmpBVUJnTlZCQWNURFZOaGJpQkdjbUZ1WTJselkyOHhFREFPQmdOVkJBb1RCMHBoYm10NVEyOHhFakFRQmdOVkJBTVRDV3h2WTJGc2FHOXpkRENDQVNJd0RRWUpLb1pJaHZjTkFRRUJCUUFEZ2dFUEFEQ0NBUW9DZ2dFQkFNR3ZKcFJUVGFzUlVTUHFjYnFDRytablRBdXJudTB2VnBJRzlsekV4bmgxMW8vQkdtenU3bEIreUxIY0Vkd3JLQkJtcGVwREJQQ1l4cFZhanZ1RWhaZEtGeC9GZHk2ajVtSDNyclcwQmgvemQzNkNvVU5qYmJoSHlUamVNN0ZOMnlGM3U5bGN5dWJ1dk96cjNCM2dYNjZJd0psVTQ2K3d6Y1FWaFNPbE1rMnRYUitmSUtRRXhGck91Szl0YlgzSklCVXFJdHBJK0huQW93NTA5Q25NMTM0c3Z3OFBURkxrUjYvQ2NNcW5EZkRLMW05OTNQeW9DMVkrTjRYOVhraFNtRVFvQWxBSFBJNUxIcnZ1dWpNMTNudnRvVll2S1lvajdTY2d1bWtwV05Fdlg2NTJMZlhPbktZbGtCOFp5YnV4bUZmSWt6ZWRRcmJKc3lPaGZMMDNjTUVDQXdFQUFUQU5CZ2txaGtpRzl3MEJBUVVGQUFPQ0FRRUFlSHd6cXduekdFa3hqelNENDdpbVhhVHF0WXlFVFpvdzdYd0JjMFphRlM1MHFSRkpVZ0tUQW1LUzF4UUJQL3FIcFN0c1JPVDM1RFV4SkFFNk5ZMUticTNaYkN1aEdvU2xZMEw3VnpWVDV0cHU0RVk4K0RxL3UyRWpSbW1ob0w3VWtza3ZJWjJuMURkRVJ0ZCtZVU1UZXFZbDljbzQzY3Nad0Ruby9JS29tZU41cWFQYzM5SVpqaWtKK25VQzZrUEZLZXUvM2o5cmdITmxSdG9jSTZTMUZkdEZ6OU9aTVFscHIwSmJVdDJUM3hTL1lvUUpuNmNvRG1KTDVHVGlpS002Y09lK1VyMVZ3elMxSkVEYlNTMlRXV2h6cThvakxkcm90WUxHZDlKT3NvUWhFbG16K3RNZkNGUVVGTEV4aW5QQXl5N1lIbFNpVlgxM1FIMlhUdS9pUVE9PTwvZHM6WDUwOUNlcnRpZmljYXRlPjwvZHM6WDUwOURhdGE+PC9kczpLZXlJbmZvPjwvZHM6U2lnbmF0dXJlPjxzYW1scDpTdGF0dXM+PHNhbWxwOlN0YXR1c0NvZGUgVmFsdWU9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpzdGF0dXM6U3VjY2VzcyIvPjwvc2FtbHA6U3RhdHVzPjxzYW1sOkFzc2VydGlvbiB4bWxuczpzYW1sPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIiBWZXJzaW9uPSIyLjAiIElEPSJfdUI1Tjd2WThQRHRiTGNmNU40QzdpTkhWbEdhcEI2dnMiIElzc3VlSW5zdGFudD0iMjAxNy0wNC0wNFQxNjo1NDoxNi4xODBaIj48c2FtbDpJc3N1ZXI+aHR0cDovL2V4YW1wbGUuY29tL3NhbWwvYWNzL2V4YW1wbGU8L3NhbWw6SXNzdWVyPjxzYW1sOlN1YmplY3Q+PHNhbWw6TmFtZUlEIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6MS4xOm5hbWVpZC1mb3JtYXQ6dW5zcGVjaWZpZWQiPmphbmUuZG9lQGV4YW1wbGUuY29tPC9zYW1sOk5hbWVJRD48c2FtbDpTdWJqZWN0Q29uZmlybWF0aW9uIE1ldGhvZD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmNtOmJlYXJlciI+PHNhbWw6U3ViamVjdENvbmZpcm1hdGlvbkRhdGEgTm90T25PckFmdGVyPSIyMDE3LTA0LTA0VDE3OjU0OjE2LjE4MFoiIFJlY2lwaWVudD0iaHR0cDovL2RiYTlhNWZjLm5ncm9rLmlvL3YxL19zYW1sX2NhbGxiYWNrIi8+PC9zYW1sOlN1YmplY3RDb25maXJtYXRpb24+PC9zYW1sOlN1YmplY3Q+PHNhbWw6Q29uZGl0aW9ucyBOb3RCZWZvcmU9IjIwMTctMDQtMDRUMTY6NTQ6MTYuMTgwWiIgTm90T25PckFmdGVyPSIyMDE3LTA0LTA0VDE3OjU0OjE2LjE4MFoiPjxzYW1sOkF1ZGllbmNlUmVzdHJpY3Rpb24+PHNhbWw6QXVkaWVuY2U+ZmFrZS5pZGVudGlmaWVyLmV4YW1wbGUuY29tPC9zYW1sOkF1ZGllbmNlPjwvc2FtbDpBdWRpZW5jZVJlc3RyaWN0aW9uPjwvc2FtbDpDb25kaXRpb25zPjxzYW1sOkF0dHJpYnV0ZVN0YXRlbWVudCB4bWxuczp4cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEiIHhtbG5zOnhzaT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS9YTUxTY2hlbWEtaW5zdGFuY2UiPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoxLjE6bmFtZWlkLWZvcm1hdDplbWFpbEFkZHJlc3MiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czphbnlUeXBlIj5qYW5lLmRvZUBleGFtcGxlLmNvbTwvc2FtbDpBdHRyaWJ1dGVWYWx1ZT48L3NhbWw6QXR0cmlidXRlPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJFbWFpbCI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOmFueVR5cGUiPmphbmUuZG9lQGV4YW1wbGUuY29tPC9zYW1sOkF0dHJpYnV0ZVZhbHVlPjwvc2FtbDpBdHRyaWJ1dGU+PHNhbWw6QXR0cmlidXRlIE5hbWU9IkZpcnN0TmFtZSI+PHNhbWw6QXR0cmlidXRlVmFsdWUgeHNpOnR5cGU9InhzOmFueVR5cGUiPkphbmU8L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48c2FtbDpBdHRyaWJ1dGUgTmFtZT0iTGFzdE5hbWUiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czphbnlUeXBlIj5Eb2U8L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48L3NhbWw6QXR0cmlidXRlU3RhdGVtZW50PjxzYW1sOkF1dGhuU3RhdGVtZW50IEF1dGhuSW5zdGFudD0iMjAxNy0wNC0wNFQxNjo1NDoxNi4xODBaIj48c2FtbDpBdXRobkNvbnRleHQ+PHNhbWw6QXV0aG5Db250ZXh0Q2xhc3NSZWY+dXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFjOmNsYXNzZXM6dW5zcGVjaWZpZWQ8L3NhbWw6QXV0aG5Db250ZXh0Q2xhc3NSZWY+PC9zYW1sOkF1dGhuQ29udGV4dD48L3NhbWw6QXV0aG5TdGF0ZW1lbnQ+PC9zYW1sOkFzc2VydGlvbj48L3NhbWxwOlJlc3BvbnNlPg== ================================================ FILE: providertests/testdata/saml.oktadev.com/response_7 ================================================ PHNhbWxwOlJlc3BvbnNlIHhtbG5zOnNhbWxwPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiIElEPSJfZThhMTdkMWYyNzEwM2Y1OGQ1ZjYiIFZlcnNpb249IjIuMCIgSXNzdWVJbnN0YW50PSIyMDE3LTA0LTA0VDE2OjU0OjE2WiIgRGVzdGluYXRpb249Imh0dHA6Ly9kYmE5YTVmYy5uZ3Jvay5pby92MS9fc2FtbF9jYWxsYmFjayI+PHNhbWxwOlN0YXR1cz48c2FtbHA6U3RhdHVzQ29kZSBWYWx1ZT0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOnN0YXR1czpTdWNjZXNzIi8+PC9zYW1scDpTdGF0dXM+PGRzOlNpZ25hdHVyZSB4bWxuczpkcz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8wOS94bWxkc2lnIyI+PGRzOlNpZ25lZEluZm8+PGRzOkNhbm9uaWNhbGl6YXRpb25NZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDA2LzEyL3htbC1jMTRuMTEiLz48ZHM6U2lnbmF0dXJlTWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8wNC94bWxkc2lnLW1vcmUjcnNhLXNoYTI1NiIvPjxkczpSZWZlcmVuY2UgVVJJPSIiPjxkczpUcmFuc2Zvcm1zPjxkczpUcmFuc2Zvcm0gQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjZW52ZWxvcGVkLXNpZ25hdHVyZSIvPjxkczpUcmFuc2Zvcm0gQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDA2LzEyL3htbC1jMTRuMTEiLz48L2RzOlRyYW5zZm9ybXM+PGRzOkRpZ2VzdE1ldGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvMDQveG1sZW5jI3NoYTI1NiIvPjxkczpEaWdlc3RWYWx1ZT5KQjI5R1l2QjBIazhuQ0tLTm9oVDlHQXVyVld0S1BWZkdUMHdSNWlDYWxFPTwvZHM6RGlnZXN0VmFsdWU+PC9kczpSZWZlcmVuY2U+PC9kczpTaWduZWRJbmZvPjxkczpTaWduYXR1cmVWYWx1ZT5uY0dTTm9GVTBuTXpLdWF0RXZBT1Y5TWtkMGFHTXZobmFSS3dHRG1mRFg1UjMwNkcxVjhJZ0lsSHlWeWlGbTN6L0Frc004aHFIZEZuWUxvTDEwYldUZ2FmcEw3M2RwUnB6VFRPb2N0ZExjTE04L0QycVB1MWluR1FraE9WMVBBWlVpaC9FcGJaTWp4ZHNqV2JKd1pnVVNKaFdLVVZxUXRYWUJrWlV2WWhtdG9vZG5Cb3V0WDBSeWQ5eEhCcHZiU08zdkVmTm8wK1UzbXgvYjhYejZZQS9CdkZFU21QYWMzcTQzWDgzeW1TczRsNXgxVm4yNTVTMzhUZEJMbnUrdXJncGlUUXlLMlFMOXBhUTR2NUk2cm44WWliazQ1MGdMb1pUSHgvOTZRbFp6MytsYjJxdStkZ3k5a2FzbElEV0xlTkc0M2dObzZ5RlM2ZlY0c2svaGd6a0E9PTwvZHM6U2lnbmF0dXJlVmFsdWU+PGRzOktleUluZm8+PGRzOlg1MDlEYXRhPjxkczpYNTA5Q2VydGlmaWNhdGU+TUlJRFBEQ0NBaVFDQ1FEeWRKZ09sc3pxYnpBTkJna3Foa2lHOXcwQkFRVUZBREJnTVFzd0NRWURWUVFHRXdKVlV6RVRNQkVHQTFVRUNCTUtRMkZzYVdadmNtNXBZVEVXTUJRR0ExVUVCeE1OVTJGdUlFWnlZVzVqYVhOamJ6RVFNQTRHQTFVRUNoTUhTbUZ1YTNsRGJ6RVNNQkFHQTFVRUF4TUpiRzlqWVd4b2IzTjBNQjRYRFRFME1ETXhNakU1TkRZek0xb1hEVEkzTVRFeE9URTVORFl6TTFvd1lERUxNQWtHQTFVRUJoTUNWVk14RXpBUkJnTlZCQWdUQ2tOaGJHbG1iM0p1YVdFeEZqQVVCZ05WQkFjVERWTmhiaUJHY21GdVkybHpZMjh4RURBT0JnTlZCQW9UQjBwaGJtdDVRMjh4RWpBUUJnTlZCQU1UQ1d4dlkyRnNhRzl6ZERDQ0FTSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnRVBBRENDQVFvQ2dnRUJBTUd2SnBSVFRhc1JVU1BxY2JxQ0crWm5UQXVybnUwdlZwSUc5bHpFeG5oMTFvL0JHbXp1N2xCK3lMSGNFZHdyS0JCbXBlcERCUENZeHBWYWp2dUVoWmRLRngvRmR5Nmo1bUgzcnJXMEJoL3pkMzZDb1VOamJiaEh5VGplTTdGTjJ5RjN1OWxjeXVidXZPenIzQjNnWDY2SXdKbFU0Nit3emNRVmhTT2xNazJ0WFIrZklLUUV4RnJPdUs5dGJYM0pJQlVxSXRwSStIbkFvdzUwOUNuTTEzNHN2dzhQVEZMa1I2L0NjTXFuRGZESzFtOTkzUHlvQzFZK040WDlYa2hTbUVRb0FsQUhQSTVMSHJ2dXVqTTEzbnZ0b1ZZdktZb2o3U2NndW1rcFdORXZYNjUyTGZYT25LWWxrQjhaeWJ1eG1GZklremVkUXJiSnN5T2hmTDAzY01FQ0F3RUFBVEFOQmdrcWhraUc5dzBCQVFVRkFBT0NBUUVBZUh3enF3bnpHRWt4anpTRDQ3aW1YYVRxdFl5RVRab3c3WHdCYzBaYUZTNTBxUkZKVWdLVEFtS1MxeFFCUC9xSHBTdHNST1QzNURVeEpBRTZOWTFLYnEzWmJDdWhHb1NsWTBMN1Z6VlQ1dHB1NEVZOCtEcS91MkVqUm1taG9MN1Vrc2t2SVoybjFEZEVSdGQrWVVNVGVxWWw5Y280M2NzWndEbm8vSUtvbWVONXFhUGMzOUlaamlrSituVUM2a1BGS2V1LzNqOXJnSE5sUnRvY0k2UzFGZHRGejlPWk1RbHByMEpiVXQyVDN4Uy9Zb1FKbjZjb0RtSkw1R1RpaUtNNmNPZStVcjFWd3pTMUpFRGJTUzJUV1doenE4b2pMZHJvdFlMR2Q5Sk9zb1FoRWxteit0TWZDRlFVRkxFeGluUEF5eTdZSGxTaVZYMTNRSDJYVHUvaVFRPT08L2RzOlg1MDlDZXJ0aWZpY2F0ZT48L2RzOlg1MDlEYXRhPjwvZHM6S2V5SW5mbz48L2RzOlNpZ25hdHVyZT48c2FtbDpBc3NlcnRpb24geG1sbnM6c2FtbD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiIgVmVyc2lvbj0iMi4wIiBJRD0iX0xRYlRIc0R0bHRPa1hSS3Q2YWRZTTJJUnk0a1h0b2JTIiBJc3N1ZUluc3RhbnQ9IjIwMTctMDQtMDRUMTY6NTQ6MTYuMzk5WiI+PHNhbWw6U3ViamVjdD48c2FtbDpOYW1lSUQgRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoxLjE6bmFtZWlkLWZvcm1hdDp1bnNwZWNpZmllZCI+amFuZS5kb2VAZXhhbXBsZS5jb208L3NhbWw6TmFtZUlEPjxzYW1sOlN1YmplY3RDb25maXJtYXRpb24gTWV0aG9kPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6Y206YmVhcmVyIj48c2FtbDpTdWJqZWN0Q29uZmlybWF0aW9uRGF0YSBOb3RPbk9yQWZ0ZXI9IjIwMTctMDQtMDRUMTc6NTQ6MTYuMzk5WiIgUmVjaXBpZW50PSJodHRwOi8vZGJhOWE1ZmMubmdyb2suaW8vdjEvX3NhbWxfY2FsbGJhY2siLz48L3NhbWw6U3ViamVjdENvbmZpcm1hdGlvbj48L3NhbWw6U3ViamVjdD48c2FtbDpDb25kaXRpb25zIE5vdEJlZm9yZT0iMjAxNy0wNC0wNFQxNjo1NDoxNi4zOTlaIiBOb3RPbk9yQWZ0ZXI9IjIwMTctMDQtMDRUMTc6NTQ6MTYuMzk5WiI+PHNhbWw6QXVkaWVuY2VSZXN0cmljdGlvbj48c2FtbDpBdWRpZW5jZT5odHRwOi8vZXhhbXBsZS5jb20vc2FtbC9hY3MvZXhhbXBsZTwvc2FtbDpBdWRpZW5jZT48L3NhbWw6QXVkaWVuY2VSZXN0cmljdGlvbj48L3NhbWw6Q29uZGl0aW9ucz48c2FtbDpBdHRyaWJ1dGVTdGF0ZW1lbnQgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIiB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIj48c2FtbDpBdHRyaWJ1dGUgTmFtZT0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6MS4xOm5hbWVpZC1mb3JtYXQ6ZW1haWxBZGRyZXNzIj48c2FtbDpBdHRyaWJ1dGVWYWx1ZSB4c2k6dHlwZT0ieHM6YW55VHlwZSI+amFuZS5kb2VAZXhhbXBsZS5jb208L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48c2FtbDpBdHRyaWJ1dGUgTmFtZT0iRW1haWwiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czphbnlUeXBlIj5qYW5lLmRvZUBleGFtcGxlLmNvbTwvc2FtbDpBdHRyaWJ1dGVWYWx1ZT48L3NhbWw6QXR0cmlidXRlPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJGaXJzdE5hbWUiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czphbnlUeXBlIj5KYW5lPC9zYW1sOkF0dHJpYnV0ZVZhbHVlPjwvc2FtbDpBdHRyaWJ1dGU+PHNhbWw6QXR0cmlidXRlIE5hbWU9Ikxhc3ROYW1lIj48c2FtbDpBdHRyaWJ1dGVWYWx1ZSB4c2k6dHlwZT0ieHM6YW55VHlwZSI+RG9lPC9zYW1sOkF0dHJpYnV0ZVZhbHVlPjwvc2FtbDpBdHRyaWJ1dGU+PC9zYW1sOkF0dHJpYnV0ZVN0YXRlbWVudD48c2FtbDpBdXRoblN0YXRlbWVudCBBdXRobkluc3RhbnQ9IjIwMTctMDQtMDRUMTY6NTQ6MTYuMzk5WiI+PHNhbWw6QXV0aG5Db250ZXh0PjxzYW1sOkF1dGhuQ29udGV4dENsYXNzUmVmPnVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphYzpjbGFzc2VzOnVuc3BlY2lmaWVkPC9zYW1sOkF1dGhuQ29udGV4dENsYXNzUmVmPjwvc2FtbDpBdXRobkNvbnRleHQ+PC9zYW1sOkF1dGhuU3RhdGVtZW50Pjwvc2FtbDpBc3NlcnRpb24+PC9zYW1scDpSZXNwb25zZT4= ================================================ FILE: providertests/testdata/saml.oktadev.com/response_8 ================================================ PHNhbWxwOlJlc3BvbnNlIHhtbG5zOnNhbWxwPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiIElEPSJfN2I4ZmUwMWNmNjhhNTczMjBiMzIiIFZlcnNpb249IjIuMCIgSXNzdWVJbnN0YW50PSIyMDE3LTA0LTA0VDE2OjU0OjE2WiIgRGVzdGluYXRpb249Imh0dHA6Ly9kYmE5YTVmYy5uZ3Jvay5pby92MS9fc2FtbF9jYWxsYmFjayI+PHNhbWw6SXNzdWVyIHhtbG5zOnNhbWw9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPmh0dHA6Ly9leGFtcGxlLmNvbS9zYW1sL2Fjcy9leGFtcGxlPC9zYW1sOklzc3Vlcj48ZHM6U2lnbmF0dXJlIHhtbG5zOmRzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjIj48ZHM6U2lnbmVkSW5mbz48ZHM6Q2Fub25pY2FsaXphdGlvbk1ldGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDYvMTIveG1sLWMxNG4xMSIvPjxkczpTaWduYXR1cmVNZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzA0L3htbGRzaWctbW9yZSNyc2Etc2hhMjU2Ii8+PGRzOlJlZmVyZW5jZSBVUkk9IiI+PGRzOlRyYW5zZm9ybXM+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyNlbnZlbG9wZWQtc2lnbmF0dXJlIi8+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDYvMTIveG1sLWMxNG4xMSIvPjwvZHM6VHJhbnNmb3Jtcz48ZHM6RGlnZXN0TWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8wNC94bWxlbmMjc2hhMjU2Ii8+PGRzOkRpZ2VzdFZhbHVlPjdGVncxRG5jTnBTR2pWNHhYeDhCWm9aNnNQREo0NWUxYjNRUU1iOWtseVE9PC9kczpEaWdlc3RWYWx1ZT48L2RzOlJlZmVyZW5jZT48L2RzOlNpZ25lZEluZm8+PGRzOlNpZ25hdHVyZVZhbHVlPmF1cHFxL0d2Z0crZlBwczF0eGVGbzkrT1FURDdST08yRDVVbXh0KzFFem5FNkFodGFWLzZXWFViMjJCS0VpaCtuRVQ0Mm1GZWhXTWhoSDZ6SFMxMW9qZ2RQVjFwTDR0UUNJUGh4RXVrTFE2T1hYWU9XR0I1N2ZCY01tUlAyYzN1Z1FTZ3dCVkxGU0VYUzZLS0NNSmtDMmxSRGdFcktXb1ZldXZWekVaOWZyanV5cWNZekVuOXZzNHVJcUVXcHBSRW1HNTlZNHdZeDQ0cksrSXhmb0oycmhwalRPT2N3Q1lzUXRMVkQxZTJHdXd5S050RWEvQWF5SzljbnNCZ3hZYTU4YnpVaU9yeGdkWlE1TUdWNWR4cWlrbGNEeWRyaFRwYlQxY042OExmbVRCdm5TOWREclY2endyaklzbHlzZlF4bUZZWTR4TklaM1g2WFNNZ1A2enlYdz09PC9kczpTaWduYXR1cmVWYWx1ZT48ZHM6S2V5SW5mbz48ZHM6WDUwOURhdGE+PGRzOlg1MDlDZXJ0aWZpY2F0ZT5NSUlEUERDQ0FpUUNDUUR5ZEpnT2xzenFiekFOQmdrcWhraUc5dzBCQVFVRkFEQmdNUXN3Q1FZRFZRUUdFd0pWVXpFVE1CRUdBMVVFQ0JNS1EyRnNhV1p2Y201cFlURVdNQlFHQTFVRUJ4TU5VMkZ1SUVaeVlXNWphWE5qYnpFUU1BNEdBMVVFQ2hNSFNtRnVhM2xEYnpFU01CQUdBMVVFQXhNSmJHOWpZV3hvYjNOME1CNFhEVEUwTURNeE1qRTVORFl6TTFvWERUSTNNVEV4T1RFNU5EWXpNMW93WURFTE1Ba0dBMVVFQmhNQ1ZWTXhFekFSQmdOVkJBZ1RDa05oYkdsbWIzSnVhV0V4RmpBVUJnTlZCQWNURFZOaGJpQkdjbUZ1WTJselkyOHhFREFPQmdOVkJBb1RCMHBoYm10NVEyOHhFakFRQmdOVkJBTVRDV3h2WTJGc2FHOXpkRENDQVNJd0RRWUpLb1pJaHZjTkFRRUJCUUFEZ2dFUEFEQ0NBUW9DZ2dFQkFNR3ZKcFJUVGFzUlVTUHFjYnFDRytablRBdXJudTB2VnBJRzlsekV4bmgxMW8vQkdtenU3bEIreUxIY0Vkd3JLQkJtcGVwREJQQ1l4cFZhanZ1RWhaZEtGeC9GZHk2ajVtSDNyclcwQmgvemQzNkNvVU5qYmJoSHlUamVNN0ZOMnlGM3U5bGN5dWJ1dk96cjNCM2dYNjZJd0psVTQ2K3d6Y1FWaFNPbE1rMnRYUitmSUtRRXhGck91Szl0YlgzSklCVXFJdHBJK0huQW93NTA5Q25NMTM0c3Z3OFBURkxrUjYvQ2NNcW5EZkRLMW05OTNQeW9DMVkrTjRYOVhraFNtRVFvQWxBSFBJNUxIcnZ1dWpNMTNudnRvVll2S1lvajdTY2d1bWtwV05Fdlg2NTJMZlhPbktZbGtCOFp5YnV4bUZmSWt6ZWRRcmJKc3lPaGZMMDNjTUVDQXdFQUFUQU5CZ2txaGtpRzl3MEJBUVVGQUFPQ0FRRUFlSHd6cXduekdFa3hqelNENDdpbVhhVHF0WXlFVFpvdzdYd0JjMFphRlM1MHFSRkpVZ0tUQW1LUzF4UUJQL3FIcFN0c1JPVDM1RFV4SkFFNk5ZMUticTNaYkN1aEdvU2xZMEw3VnpWVDV0cHU0RVk4K0RxL3UyRWpSbW1ob0w3VWtza3ZJWjJuMURkRVJ0ZCtZVU1UZXFZbDljbzQzY3Nad0Ruby9JS29tZU41cWFQYzM5SVpqaWtKK25VQzZrUEZLZXUvM2o5cmdITmxSdG9jSTZTMUZkdEZ6OU9aTVFscHIwSmJVdDJUM3hTL1lvUUpuNmNvRG1KTDVHVGlpS002Y09lK1VyMVZ3elMxSkVEYlNTMlRXV2h6cThvakxkcm90WUxHZDlKT3NvUWhFbG16K3RNZkNGUVVGTEV4aW5QQXl5N1lIbFNpVlgxM1FIMlhUdS9pUVE9PTwvZHM6WDUwOUNlcnRpZmljYXRlPjwvZHM6WDUwOURhdGE+PC9kczpLZXlJbmZvPjwvZHM6U2lnbmF0dXJlPjxzYW1scDpTdGF0dXM+PHNhbWxwOlN0YXR1c0NvZGUgVmFsdWU9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpzdGF0dXM6U3VjY2VzcyIvPjwvc2FtbHA6U3RhdHVzPjxzYW1sOkFzc2VydGlvbiB4bWxuczpzYW1sPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIiBWZXJzaW9uPSIyLjAiIElEPSJfeVJ1N2dSWFN2UXJra2JlZXZreldUdTIzVGFrY2hGQzciIElzc3VlSW5zdGFudD0iMjAxNy0wNC0wNFQxNjo1NDoxNi42MzZaIj48c2FtbDpJc3N1ZXI+aHR0cDovL2V4YW1wbGUuY29tL3NhbWwvYWNzL2V4YW1wbGU8L3NhbWw6SXNzdWVyPjxzYW1sOlN1YmplY3Q+PHNhbWw6TmFtZUlEIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6MS4xOm5hbWVpZC1mb3JtYXQ6dW5zcGVjaWZpZWQiPmphbmUuZG9lQGV4YW1wbGUuY29tPC9zYW1sOk5hbWVJRD48c2FtbDpTdWJqZWN0Q29uZmlybWF0aW9uIE1ldGhvZD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmNtOmJlYXJlciI+PHNhbWw6U3ViamVjdENvbmZpcm1hdGlvbkRhdGEgUmVjaXBpZW50PSJodHRwOi8vZGJhOWE1ZmMubmdyb2suaW8vdjEvX3NhbWxfY2FsbGJhY2siLz48L3NhbWw6U3ViamVjdENvbmZpcm1hdGlvbj48L3NhbWw6U3ViamVjdD48c2FtbDpDb25kaXRpb25zIE5vdEJlZm9yZT0iMjAxNy0wNC0wNFQxNjo1NDoxNi42MzZaIiBOb3RPbk9yQWZ0ZXI9IjIwMTctMDQtMDRUMTc6NTQ6MTYuNjM2WiI+PHNhbWw6QXVkaWVuY2VSZXN0cmljdGlvbj48c2FtbDpBdWRpZW5jZT5odHRwOi8vZXhhbXBsZS5jb20vc2FtbC9hY3MvZXhhbXBsZTwvc2FtbDpBdWRpZW5jZT48L3NhbWw6QXVkaWVuY2VSZXN0cmljdGlvbj48L3NhbWw6Q29uZGl0aW9ucz48c2FtbDpBdHRyaWJ1dGVTdGF0ZW1lbnQgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIiB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIj48c2FtbDpBdHRyaWJ1dGUgTmFtZT0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6MS4xOm5hbWVpZC1mb3JtYXQ6ZW1haWxBZGRyZXNzIj48c2FtbDpBdHRyaWJ1dGVWYWx1ZSB4c2k6dHlwZT0ieHM6YW55VHlwZSI+amFuZS5kb2VAZXhhbXBsZS5jb208L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48c2FtbDpBdHRyaWJ1dGUgTmFtZT0iRW1haWwiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czphbnlUeXBlIj5qYW5lLmRvZUBleGFtcGxlLmNvbTwvc2FtbDpBdHRyaWJ1dGVWYWx1ZT48L3NhbWw6QXR0cmlidXRlPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJGaXJzdE5hbWUiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czphbnlUeXBlIj5KYW5lPC9zYW1sOkF0dHJpYnV0ZVZhbHVlPjwvc2FtbDpBdHRyaWJ1dGU+PHNhbWw6QXR0cmlidXRlIE5hbWU9Ikxhc3ROYW1lIj48c2FtbDpBdHRyaWJ1dGVWYWx1ZSB4c2k6dHlwZT0ieHM6YW55VHlwZSI+RG9lPC9zYW1sOkF0dHJpYnV0ZVZhbHVlPjwvc2FtbDpBdHRyaWJ1dGU+PC9zYW1sOkF0dHJpYnV0ZVN0YXRlbWVudD48c2FtbDpBdXRoblN0YXRlbWVudCBBdXRobkluc3RhbnQ9IjIwMTctMDQtMDRUMTY6NTQ6MTYuNjM2WiI+PHNhbWw6QXV0aG5Db250ZXh0PjxzYW1sOkF1dGhuQ29udGV4dENsYXNzUmVmPnVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphYzpjbGFzc2VzOnVuc3BlY2lmaWVkPC9zYW1sOkF1dGhuQ29udGV4dENsYXNzUmVmPjwvc2FtbDpBdXRobkNvbnRleHQ+PC9zYW1sOkF1dGhuU3RhdGVtZW50Pjwvc2FtbDpBc3NlcnRpb24+PC9zYW1scDpSZXNwb25zZT4= ================================================ FILE: providertests/testdata/saml.oktadev.com/response_9 ================================================ PHNhbWxwOlJlc3BvbnNlIHhtbG5zOnNhbWxwPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6cHJvdG9jb2wiIElEPSJfMmQ4MDM0NmQyZmU4MGEzZjdjNDIiIFZlcnNpb249IjIuMCIgSXNzdWVJbnN0YW50PSIyMDE3LTA0LTA0VDE2OjU0OjE2WiIgRGVzdGluYXRpb249Imh0dHA6Ly9kYmE5YTVmYy5uZ3Jvay5pby92MS9fc2FtbF9jYWxsYmFjayI+PHNhbWw6SXNzdWVyIHhtbG5zOnNhbWw9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPmh0dHA6Ly9leGFtcGxlLmNvbS9zYW1sL2Fjcy9leGFtcGxlPC9zYW1sOklzc3Vlcj48ZHM6U2lnbmF0dXJlIHhtbG5zOmRzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjIj48ZHM6U2lnbmVkSW5mbz48ZHM6Q2Fub25pY2FsaXphdGlvbk1ldGhvZCBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDYvMTIveG1sLWMxNG4xMSIvPjxkczpTaWduYXR1cmVNZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzA0L3htbGRzaWctbW9yZSNyc2Etc2hhMjU2Ii8+PGRzOlJlZmVyZW5jZSBVUkk9IiI+PGRzOlRyYW5zZm9ybXM+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyNlbnZlbG9wZWQtc2lnbmF0dXJlIi8+PGRzOlRyYW5zZm9ybSBBbGdvcml0aG09Imh0dHA6Ly93d3cudzMub3JnLzIwMDYvMTIveG1sLWMxNG4xMSIvPjwvZHM6VHJhbnNmb3Jtcz48ZHM6RGlnZXN0TWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8wNC94bWxlbmMjc2hhMjU2Ii8+PGRzOkRpZ2VzdFZhbHVlPmpqM1ZOb2pRbzRoQnhFZVhiQW81ZG5EVU5GSjdieVNIYmpjK1Zwa1BDREk9PC9kczpEaWdlc3RWYWx1ZT48L2RzOlJlZmVyZW5jZT48L2RzOlNpZ25lZEluZm8+PGRzOlNpZ25hdHVyZVZhbHVlPkJFVVBxb3JZNGFPNG5wRExFYklYMmFNaytWOGZ6U0UxeWdSSFMzc2pJRVI3eUJkNURDNjQzY055V2RYa2FabDBUVTRjQXU4d1NuQlJxeVl1bVE0V3dtbXRDR3dueXhyS0RMaE81QXVNRjdHMjZpQ1Ftcm55ZE90a1BoeDRBNjhUNDRHL0FWWE91NWJLa1pMbEdZODRXYThEWVVFMFkrQlNBYzFNRnJ2eFp1cXpCSmhnVnFFd2FqQ0ljb3RYMStacFpTbWRVM2RjUE4zMU5yVmpOZ0MrTnBkTzJOdmFtYTU3QlVWWmZtY1g4RWNGa01Xb3d6blZnQ2VmVmQwRktydThTNldBZHhHdXFHZjV3VHdLa3RqKzZqWTIycURtUGlBdEU1eElTeHpFcDZKcnMrWU92RVNKYU0yVW9HMjdrMitxU0JrRHNEUHYrdnhSUU43UnlkMUNjZz09PC9kczpTaWduYXR1cmVWYWx1ZT48ZHM6S2V5SW5mbz48ZHM6WDUwOURhdGE+PGRzOlg1MDlDZXJ0aWZpY2F0ZT5NSUlEUERDQ0FpUUNDUUR5ZEpnT2xzenFiekFOQmdrcWhraUc5dzBCQVFVRkFEQmdNUXN3Q1FZRFZRUUdFd0pWVXpFVE1CRUdBMVVFQ0JNS1EyRnNhV1p2Y201cFlURVdNQlFHQTFVRUJ4TU5VMkZ1SUVaeVlXNWphWE5qYnpFUU1BNEdBMVVFQ2hNSFNtRnVhM2xEYnpFU01CQUdBMVVFQXhNSmJHOWpZV3hvYjNOME1CNFhEVEUwTURNeE1qRTVORFl6TTFvWERUSTNNVEV4T1RFNU5EWXpNMW93WURFTE1Ba0dBMVVFQmhNQ1ZWTXhFekFSQmdOVkJBZ1RDa05oYkdsbWIzSnVhV0V4RmpBVUJnTlZCQWNURFZOaGJpQkdjbUZ1WTJselkyOHhFREFPQmdOVkJBb1RCMHBoYm10NVEyOHhFakFRQmdOVkJBTVRDV3h2WTJGc2FHOXpkRENDQVNJd0RRWUpLb1pJaHZjTkFRRUJCUUFEZ2dFUEFEQ0NBUW9DZ2dFQkFNR3ZKcFJUVGFzUlVTUHFjYnFDRytablRBdXJudTB2VnBJRzlsekV4bmgxMW8vQkdtenU3bEIreUxIY0Vkd3JLQkJtcGVwREJQQ1l4cFZhanZ1RWhaZEtGeC9GZHk2ajVtSDNyclcwQmgvemQzNkNvVU5qYmJoSHlUamVNN0ZOMnlGM3U5bGN5dWJ1dk96cjNCM2dYNjZJd0psVTQ2K3d6Y1FWaFNPbE1rMnRYUitmSUtRRXhGck91Szl0YlgzSklCVXFJdHBJK0huQW93NTA5Q25NMTM0c3Z3OFBURkxrUjYvQ2NNcW5EZkRLMW05OTNQeW9DMVkrTjRYOVhraFNtRVFvQWxBSFBJNUxIcnZ1dWpNMTNudnRvVll2S1lvajdTY2d1bWtwV05Fdlg2NTJMZlhPbktZbGtCOFp5YnV4bUZmSWt6ZWRRcmJKc3lPaGZMMDNjTUVDQXdFQUFUQU5CZ2txaGtpRzl3MEJBUVVGQUFPQ0FRRUFlSHd6cXduekdFa3hqelNENDdpbVhhVHF0WXlFVFpvdzdYd0JjMFphRlM1MHFSRkpVZ0tUQW1LUzF4UUJQL3FIcFN0c1JPVDM1RFV4SkFFNk5ZMUticTNaYkN1aEdvU2xZMEw3VnpWVDV0cHU0RVk4K0RxL3UyRWpSbW1ob0w3VWtza3ZJWjJuMURkRVJ0ZCtZVU1UZXFZbDljbzQzY3Nad0Ruby9JS29tZU41cWFQYzM5SVpqaWtKK25VQzZrUEZLZXUvM2o5cmdITmxSdG9jSTZTMUZkdEZ6OU9aTVFscHIwSmJVdDJUM3hTL1lvUUpuNmNvRG1KTDVHVGlpS002Y09lK1VyMVZ3elMxSkVEYlNTMlRXV2h6cThvakxkcm90WUxHZDlKT3NvUWhFbG16K3RNZkNGUVVGTEV4aW5QQXl5N1lIbFNpVlgxM1FIMlhUdS9pUVE9PTwvZHM6WDUwOUNlcnRpZmljYXRlPjwvZHM6WDUwOURhdGE+PC9kczpLZXlJbmZvPjwvZHM6U2lnbmF0dXJlPjxzYW1scDpTdGF0dXM+PHNhbWxwOlN0YXR1c0NvZGUgVmFsdWU9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDpzdGF0dXM6U3VjY2VzcyIvPjwvc2FtbHA6U3RhdHVzPjxzYW1sOkFzc2VydGlvbiB4bWxuczpzYW1sPSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6YXNzZXJ0aW9uIiBWZXJzaW9uPSIyLjAiIElEPSJfS2NDYURJalV2VHlaWWFMOHZrbnM3VGRVbjgzckJZZ0QiIElzc3VlSW5zdGFudD0iMjAxNy0wNC0wNFQxNjo1NDoxNi44NTdaIj48c2FtbDpJc3N1ZXI+aHR0cDovL2V4YW1wbGUuY29tL3NhbWwvYWNzL2V4YW1wbGU8L3NhbWw6SXNzdWVyPjxzYW1sOlN1YmplY3Q+PHNhbWw6TmFtZUlEIEZvcm1hdD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6MS4xOm5hbWVpZC1mb3JtYXQ6dW5zcGVjaWZpZWQiPmphbmUuZG9lQGV4YW1wbGUuY29tPC9zYW1sOk5hbWVJRD48c2FtbDpTdWJqZWN0Q29uZmlybWF0aW9uIE1ldGhvZD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmNtOmJlYXJlciI+PHNhbWw6U3ViamVjdENvbmZpcm1hdGlvbkRhdGEgTm90T25PckFmdGVyPSIyMDE3LTA0LTA0VDE3OjU0OjE2Ljg1N1oiIFJlY2lwaWVudD0iaHR0cDovL2RiYTlhNWZjLm5ncm9rLmlvL3YxL19zYW1sX2NhbGxiYWNrIi8+PC9zYW1sOlN1YmplY3RDb25maXJtYXRpb24+PC9zYW1sOlN1YmplY3Q+PHNhbWw6Q29uZGl0aW9ucyBOb3RCZWZvcmU9IjIwMTctMDQtMDRUMTY6NTQ6MTYuODU3WiI+PHNhbWw6QXVkaWVuY2VSZXN0cmljdGlvbj48c2FtbDpBdWRpZW5jZT5odHRwOi8vZXhhbXBsZS5jb20vc2FtbC9hY3MvZXhhbXBsZTwvc2FtbDpBdWRpZW5jZT48L3NhbWw6QXVkaWVuY2VSZXN0cmljdGlvbj48L3NhbWw6Q29uZGl0aW9ucz48c2FtbDpBdHRyaWJ1dGVTdGF0ZW1lbnQgeG1sbnM6eHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hIiB4bWxuczp4c2k9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvWE1MU2NoZW1hLWluc3RhbmNlIj48c2FtbDpBdHRyaWJ1dGUgTmFtZT0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6MS4xOm5hbWVpZC1mb3JtYXQ6ZW1haWxBZGRyZXNzIj48c2FtbDpBdHRyaWJ1dGVWYWx1ZSB4c2k6dHlwZT0ieHM6YW55VHlwZSI+amFuZS5kb2VAZXhhbXBsZS5jb208L3NhbWw6QXR0cmlidXRlVmFsdWU+PC9zYW1sOkF0dHJpYnV0ZT48c2FtbDpBdHRyaWJ1dGUgTmFtZT0iRW1haWwiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czphbnlUeXBlIj5qYW5lLmRvZUBleGFtcGxlLmNvbTwvc2FtbDpBdHRyaWJ1dGVWYWx1ZT48L3NhbWw6QXR0cmlidXRlPjxzYW1sOkF0dHJpYnV0ZSBOYW1lPSJGaXJzdE5hbWUiPjxzYW1sOkF0dHJpYnV0ZVZhbHVlIHhzaTp0eXBlPSJ4czphbnlUeXBlIj5KYW5lPC9zYW1sOkF0dHJpYnV0ZVZhbHVlPjwvc2FtbDpBdHRyaWJ1dGU+PHNhbWw6QXR0cmlidXRlIE5hbWU9Ikxhc3ROYW1lIj48c2FtbDpBdHRyaWJ1dGVWYWx1ZSB4c2k6dHlwZT0ieHM6YW55VHlwZSI+RG9lPC9zYW1sOkF0dHJpYnV0ZVZhbHVlPjwvc2FtbDpBdHRyaWJ1dGU+PC9zYW1sOkF0dHJpYnV0ZVN0YXRlbWVudD48c2FtbDpBdXRoblN0YXRlbWVudCBBdXRobkluc3RhbnQ9IjIwMTctMDQtMDRUMTY6NTQ6MTYuODU3WiI+PHNhbWw6QXV0aG5Db250ZXh0PjxzYW1sOkF1dGhuQ29udGV4dENsYXNzUmVmPnVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphYzpjbGFzc2VzOnVuc3BlY2lmaWVkPC9zYW1sOkF1dGhuQ29udGV4dENsYXNzUmVmPjwvc2FtbDpBdXRobkNvbnRleHQ+PC9zYW1sOkF1dGhuU3RhdGVtZW50Pjwvc2FtbDpBc3NlcnRpb24+PC9zYW1scDpSZXNwb25zZT4= ================================================ FILE: providertests/utils.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package providertests import ( "crypto/tls" "crypto/x509" "encoding/base64" "encoding/pem" "encoding/xml" "fmt" "io/ioutil" "sort" "testing" "time" "github.com/jonboulle/clockwork" "github.com/russellhaering/gosaml2" "github.com/russellhaering/gosaml2/types" "github.com/russellhaering/goxmldsig" "github.com/stretchr/testify/require" ) func scenarioIndexes(errs map[int]string, warns map[int]scenarioWarnings) (idxs []int) { for idx, _ := range errs { idxs = append(idxs, idx) } for idx, _ := range warns { idxs = append(idxs, idx) } sort.Ints(idxs) return } type scenarioWarnings struct { InvalidTime bool NotInAudience bool } func scenarioErrorChecker(i int, scenarioErrors map[int]string) func(*testing.T, error) { return func(t *testing.T, err error) { if msg, ok := scenarioErrors[i]; ok && msg != "" { require.EqualError(t, err, msg, "Expected error message") } else { require.NoError(t, err) } } } func scenarioWarningChecker(i int, scenarioWarns map[int]scenarioWarnings) func(*testing.T, *saml2.WarningInfo) { return func(t *testing.T, warningInfo *saml2.WarningInfo) { expectedWarnings := scenarioWarns[i] require.Equal(t, expectedWarnings.InvalidTime, warningInfo.InvalidTime, "InvalidTime mismatch") require.Equal(t, expectedWarnings.NotInAudience, warningInfo.NotInAudience, "NotInAudience mismatch") } } func LoadXMLResponse(path string) string { xml, err := ioutil.ReadFile(path) if err != nil { panic(err) } return base64.StdEncoding.EncodeToString(xml) } func LoadRawResponse(path string) string { data, err := ioutil.ReadFile(path) if err != nil { panic(err) } return string(data) } func LoadKeyStore(certPath, keyPath string) (ks dsig.TLSCertKeyStore) { if certBytes, err := ioutil.ReadFile(certPath); err != nil { panic(fmt.Errorf("%v: cannot read: %v", certPath, err)) } else if keyBytes, err := ioutil.ReadFile(keyPath); err != nil { panic(fmt.Errorf("%v: cannot read: %v", keyPath, err)) } else if cert, err := tls.X509KeyPair(certBytes, keyBytes); err != nil { panic(fmt.Errorf("%v/%v: cannot create key pair: %v", certPath, keyPath, err)) } else { ks = dsig.TLSCertKeyStore(cert) } return } func LoadCertificateStore(path string) dsig.X509CertificateStore { encoded, err := ioutil.ReadFile(path) if err != nil { panic(err) } block, _ := pem.Decode(encoded) if block == nil { panic("no certificate block found") } cert, err := x509.ParseCertificate(block.Bytes) if err != nil { panic(err) } return &dsig.MemoryX509CertificateStore{ Roots: []*x509.Certificate{cert}, } } type ProviderTestScenario struct { ScenarioName string Response string ServiceProvider *saml2.SAMLServiceProvider CheckError func(*testing.T, error) CheckWarningInfo func(*testing.T, *saml2.WarningInfo) } func getAtTime(idx int, scenarioAtTimes map[int]string) (atTime time.Time) { if strAtTime, ok := scenarioAtTimes[idx]; ok && strAtTime != "" { if atm, err := time.Parse(time.RFC3339, strAtTime); err == nil { return atm } } return // zero time } func spAtTime(template *saml2.SAMLServiceProvider, atTime time.Time, rawResp string) *saml2.SAMLServiceProvider { resp := &types.Response{} if rawResp == "" { panic(fmt.Errorf("empty rawResp")) } var respBytes []byte var err error if respBytes, err = base64.StdEncoding.DecodeString(rawResp); err != nil { respBytes = []byte(rawResp) } if err := xml.Unmarshal(respBytes, resp); err != nil { panic(fmt.Errorf("cannot parse Response XML: %v", err)) } var sp saml2.SAMLServiceProvider sp = *template // copy most fields template, we only set the clock below if atTime.IsZero() { // Prefer more official Assertion IssueInstant over Response IssueIntant // (Assertion will be signed, either individually or as part of Response) if len(resp.Assertions) > 0 && !resp.Assertions[0].IssueInstant.IsZero() { atTime = resp.Assertions[0].IssueInstant } else if !resp.IssueInstant.IsZero() { atTime = resp.IssueInstant } else { panic(fmt.Errorf("could not determine atTime")) } } sp.Clock = dsig.NewFakeClock(clockwork.NewFakeClockAt(atTime)) return &sp } ================================================ FILE: retrieve_assertion.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package saml2 import "fmt" //ErrMissingElement is the error type that indicates an element and/or attribute is //missing. It provides a structured error that can be more appropriately acted //upon. type ErrMissingElement struct { Tag, Attribute string } type ErrVerification struct { Cause error } func (e ErrVerification) Error() string { return fmt.Sprintf("error validating response: %s", e.Cause.Error()) } //ErrMissingAssertion indicates that an appropriate assertion element could not //be found in the SAML Response var ( ErrMissingAssertion = ErrMissingElement{Tag: AssertionTag} ) func (e ErrMissingElement) Error() string { if e.Attribute != "" { return fmt.Sprintf("missing %s attribute on %s element", e.Attribute, e.Tag) } return fmt.Sprintf("missing %s element", e.Tag) } //RetrieveAssertionInfo takes an encoded response and returns the AssertionInfo //contained, or an error message if an error has been encountered. func (sp *SAMLServiceProvider) RetrieveAssertionInfo(encodedResponse string) (*AssertionInfo, error) { assertionInfo := &AssertionInfo{ Values: make(Values), } response, err := sp.ValidateEncodedResponse(encodedResponse) if err != nil { return nil, ErrVerification{Cause: err} } // TODO: Support multiple assertions if len(response.Assertions) == 0 { return nil, ErrMissingAssertion } assertion := response.Assertions[0] assertionInfo.Assertions = response.Assertions assertionInfo.ResponseSignatureValidated = response.SignatureValidated warningInfo, err := sp.VerifyAssertionConditions(&assertion) if err != nil { return nil, err } //Get the NameID subject := assertion.Subject if subject == nil { return nil, ErrMissingElement{Tag: SubjectTag} } nameID := subject.NameID if nameID == nil { return nil, ErrMissingElement{Tag: NameIdTag} } assertionInfo.NameID = nameID.Value //Get the actual assertion attributes attributeStatement := assertion.AttributeStatement if attributeStatement == nil && !sp.AllowMissingAttributes { return nil, ErrMissingElement{Tag: AttributeStatementTag} } if attributeStatement != nil { for _, attribute := range attributeStatement.Attributes { assertionInfo.Values[attribute.Name] = attribute } } if assertion.AuthnStatement != nil { if assertion.AuthnStatement.AuthnInstant != nil { assertionInfo.AuthnInstant = assertion.AuthnStatement.AuthnInstant } if assertion.AuthnStatement.SessionNotOnOrAfter != nil { assertionInfo.SessionNotOnOrAfter = assertion.AuthnStatement.SessionNotOnOrAfter } assertionInfo.SessionIndex = assertion.AuthnStatement.SessionIndex } assertionInfo.WarningInfo = warningInfo return assertionInfo, nil } ================================================ FILE: run_test.sh ================================================ #!/bin/bash cd `dirname $0` DIRS=`git grep -l 'func Test' | xargs dirname | sort -u` for DIR in $DIRS do echo echo "dir: $DIR" echo "======================================" pushd $DIR >/dev/null go test -v || exit 1 popd >/dev/null done ================================================ FILE: s2example/demo.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package main import ( "crypto/x509" "fmt" "net/http" "io/ioutil" "encoding/base64" "encoding/xml" saml2 "github.com/russellhaering/gosaml2" "github.com/russellhaering/gosaml2/types" dsig "github.com/russellhaering/goxmldsig" ) func main() { res, err := http.Get("http://idp.oktadev.com/metadata") if err != nil { panic(err) } rawMetadata, err := ioutil.ReadAll(res.Body) if err != nil { panic(err) } metadata := &types.EntityDescriptor{} err = xml.Unmarshal(rawMetadata, metadata) if err != nil { panic(err) } certStore := dsig.MemoryX509CertificateStore{ Roots: []*x509.Certificate{}, } for _, kd := range metadata.IDPSSODescriptor.KeyDescriptors { for idx, xcert := range kd.KeyInfo.X509Data.X509Certificates { if xcert.Data == "" { panic(fmt.Errorf("metadata certificate(%d) must not be empty", idx)) } certData, err := base64.StdEncoding.DecodeString(xcert.Data) if err != nil { panic(err) } idpCert, err := x509.ParseCertificate(certData) if err != nil { panic(err) } certStore.Roots = append(certStore.Roots, idpCert) } } // We sign the AuthnRequest with a random key because Okta doesn't seem // to verify these. randomKeyStore := dsig.RandomKeyStoreForTest() sp := &saml2.SAMLServiceProvider{ IdentityProviderSSOURL: metadata.IDPSSODescriptor.SingleSignOnServices[0].Location, IdentityProviderIssuer: metadata.EntityID, ServiceProviderIssuer: "http://example.com/saml/acs/example", AssertionConsumerServiceURL: "http://localhost:8080/v1/_saml_callback", SignAuthnRequests: true, AudienceURI: "http://example.com/saml/acs/example", IDPCertificateStore: &certStore, SPKeyStore: randomKeyStore, } http.HandleFunc("/v1/_saml_callback", func(rw http.ResponseWriter, req *http.Request) { err := req.ParseForm() if err != nil { rw.WriteHeader(http.StatusBadRequest) return } assertionInfo, err := sp.RetrieveAssertionInfo(req.FormValue("SAMLResponse")) if err != nil { rw.WriteHeader(http.StatusForbidden) return } if assertionInfo.WarningInfo.InvalidTime { rw.WriteHeader(http.StatusForbidden) return } if assertionInfo.WarningInfo.NotInAudience { rw.WriteHeader(http.StatusForbidden) return } fmt.Fprintf(rw, "NameID: %s\n", assertionInfo.NameID) fmt.Fprintf(rw, "Assertions:\n") for key, val := range assertionInfo.Values { fmt.Fprintf(rw, " %s: %+v\n", key, val) } fmt.Fprintf(rw, "\n") fmt.Fprintf(rw, "Warnings:\n") fmt.Fprintf(rw, "%+v\n", assertionInfo.WarningInfo) }) println("Visit this URL To Authenticate:") authURL, err := sp.BuildAuthURL("") if err != nil { panic(err) } println(authURL) println("Supply:") fmt.Printf(" SP ACS URL : %s\n", sp.AssertionConsumerServiceURL) err = http.ListenAndServe(":8080", nil) if err != nil { panic(err) } } ================================================ FILE: saml.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package saml2 import ( "crypto" "encoding/base64" "sync" "time" "github.com/russellhaering/gosaml2/types" dsig "github.com/russellhaering/goxmldsig" dsigtypes "github.com/russellhaering/goxmldsig/types" ) type ErrSaml struct { Message string System error } func (serr ErrSaml) Error() string { if serr.Message != "" { return serr.Message } return "SAML error" } type SAMLServiceProvider struct { IdentityProviderSSOURL string IdentityProviderSSOBinding string IdentityProviderSLOURL string IdentityProviderSLOBinding string IdentityProviderIssuer string AssertionConsumerServiceURL string ServiceProviderSLOURL string ServiceProviderIssuer string SignAuthnRequests bool SignAuthnRequestsAlgorithm string SignAuthnRequestsCanonicalizer dsig.Canonicalizer // ForceAuthn attribute in authentication request forces the identity provider to // re-authenticate the presenter directly rather than rely on a previous security context. // NOTE: If both ForceAuthn and IsPassive are "true", the identity provider MUST NOT freshly // authenticate the presenter unless the constraints of IsPassive can be met. ForceAuthn bool // IsPassive attribute in authentication request requires that the identity provider and the // user agent itself MUST NOT visibly take control of the user interface from the requester // and interact with the presenter in a noticeable fashion. IsPassive bool // RequestedAuthnContext allows service providers to require that the identity // provider use specific authentication mechanisms. Leaving this unset will // permit the identity provider to choose the auth method. To maximize compatibility // with identity providers it is recommended to leave this unset. RequestedAuthnContext *RequestedAuthnContext AudienceURI string IDPCertificateStore dsig.X509CertificateStore NameIdFormat string ValidateEncryptionCert bool SkipSignatureValidation bool AllowMissingAttributes bool Clock *dsig.Clock // Required encryption key and default signing key. // Deprecated: Use SetSPKeyStore instead of setting or reading this field. SPKeyStore dsig.X509KeyStore // Optional signing key. // Deprecated: Use SetSPSigningKeyStore instead of setting or reading this field. SPSigningKeyStore dsig.X509KeyStore spKeyStoreOverride *KeyStore // When set via SetSPKeyStore, this field is used instead of SPKeyStore spSigningKeyStoreOverride *KeyStore // When set via SetSPSigningKeyStore, this field is used instead of SPSigningKeyStore // MaximumDecompressedBodySize is the maximum size to which a compressed // SAML document will be decompressed. If a compresed document is exceeds // this size during decompression an error will be returned. MaximumDecompressedBodySize int64 signingContextMu sync.RWMutex signingContext *dsig.SigningContext } // SetSPKeyStore sets the encryption key to be used. // It is required to either call this method (recommended) or // set SPKeyStore directly (deprecated). func (sp *SAMLServiceProvider) SetSPKeyStore(ks *KeyStore) error { if ks != nil && ks.Signer == nil { return ErrSaml{Message: "SP key store signer can't be nil"} } sp.spKeyStoreOverride = ks return nil } // SetSPSigningKeyStore sets the signing key to be used. func (sp *SAMLServiceProvider) SetSPSigningKeyStore(ks *KeyStore) error { if ks != nil && ks.Signer == nil { return ErrSaml{Message: "SP signing key store signer can't be nil"} } sp.spSigningKeyStoreOverride = ks return nil } type KeyStore struct { Signer crypto.Signer Cert []byte } // RequestedAuthnContext controls which authentication mechanisms are requested of // the identity provider. It is generally sufficient to omit this and let the // identity provider select an authentication mechansim. type RequestedAuthnContext struct { // The RequestedAuthnContext comparison policy to use. See the section 3.3.2.2.1 // of the SAML 2.0 specification for details. Constants named AuthnPolicyMatch* // contain standardized values. Comparison string // Contexts will be passed as AuthnContextClassRefs. For example, to force password // authentication on some identity providers, Contexts should have a value of // []string{AuthnContextPasswordProtectedTransport}, and Comparison should have a // value of AuthnPolicyMatchExact. Contexts []string } func (sp *SAMLServiceProvider) Metadata() (*types.EntityDescriptor, error) { keyDescriptors := make([]types.KeyDescriptor, 0, 2) if sp.GetSigningKey() != nil { signingCertBytes, err := sp.GetSigningCertBytes() if err != nil { return nil, err } keyDescriptors = append(keyDescriptors, types.KeyDescriptor{ Use: "signing", KeyInfo: dsigtypes.KeyInfo{ X509Data: dsigtypes.X509Data{ X509Certificates: []dsigtypes.X509Certificate{dsigtypes.X509Certificate{ Data: base64.StdEncoding.EncodeToString(signingCertBytes), }}, }, }, }) } encryptionCertBytes, err := sp.GetEncryptionCertBytes() if err != nil { return nil, err } if encryptionCertBytes != nil { keyDescriptors = append(keyDescriptors, types.KeyDescriptor{ Use: "encryption", KeyInfo: dsigtypes.KeyInfo{ X509Data: dsigtypes.X509Data{ X509Certificates: []dsigtypes.X509Certificate{{ Data: base64.StdEncoding.EncodeToString(encryptionCertBytes), }}, }, }, EncryptionMethods: []types.EncryptionMethod{ {Algorithm: types.MethodAES128GCM}, {Algorithm: types.MethodAES192GCM}, {Algorithm: types.MethodAES256GCM}, {Algorithm: types.MethodAES128CBC}, {Algorithm: types.MethodAES256CBC}, }, }) } return &types.EntityDescriptor{ ValidUntil: sp.Clock.Now().UTC().Add(time.Hour * 24 * 7), // 7 days EntityID: sp.ServiceProviderIssuer, SPSSODescriptor: &types.SPSSODescriptor{ AuthnRequestsSigned: sp.SignAuthnRequests, WantAssertionsSigned: !sp.SkipSignatureValidation, ProtocolSupportEnumeration: SAMLProtocolNamespace, KeyDescriptors: keyDescriptors, AssertionConsumerServices: []types.IndexedEndpoint{{ Binding: BindingHttpPost, Location: sp.AssertionConsumerServiceURL, Index: 1, }}, }, }, nil } func (sp *SAMLServiceProvider) MetadataWithSLO(validityHours int64) (*types.EntityDescriptor, error) { signingCertBytes, err := sp.GetSigningCertBytes() if err != nil { return nil, err } encryptionCertBytes, err := sp.GetEncryptionCertBytes() if err != nil { return nil, err } if validityHours <= 0 { // By default let's keep it to 7 days. validityHours = int64(time.Hour * 24 * 7) } return &types.EntityDescriptor{ ValidUntil: sp.Clock.Now().UTC().Add(time.Duration(validityHours)), // default 7 days EntityID: sp.ServiceProviderIssuer, SPSSODescriptor: &types.SPSSODescriptor{ AuthnRequestsSigned: sp.SignAuthnRequests, WantAssertionsSigned: !sp.SkipSignatureValidation, ProtocolSupportEnumeration: SAMLProtocolNamespace, KeyDescriptors: []types.KeyDescriptor{ { Use: "signing", KeyInfo: dsigtypes.KeyInfo{ X509Data: dsigtypes.X509Data{ X509Certificates: []dsigtypes.X509Certificate{{ Data: base64.StdEncoding.EncodeToString(signingCertBytes), }}, }, }, }, { Use: "encryption", KeyInfo: dsigtypes.KeyInfo{ X509Data: dsigtypes.X509Data{ X509Certificates: []dsigtypes.X509Certificate{{ Data: base64.StdEncoding.EncodeToString(encryptionCertBytes), }}, }, }, EncryptionMethods: []types.EncryptionMethod{ {Algorithm: types.MethodAES128GCM, DigestMethod: nil}, {Algorithm: types.MethodAES192GCM, DigestMethod: nil}, {Algorithm: types.MethodAES256GCM, DigestMethod: nil}, {Algorithm: types.MethodAES128CBC, DigestMethod: nil}, {Algorithm: types.MethodAES256CBC, DigestMethod: nil}, }, }, }, AssertionConsumerServices: []types.IndexedEndpoint{{ Binding: BindingHttpPost, Location: sp.AssertionConsumerServiceURL, Index: 1, }}, SingleLogoutServices: []types.Endpoint{{ Binding: BindingHttpPost, Location: sp.ServiceProviderSLOURL, }}, }, }, nil } // Deprecated: This method won't return the correct value if SetSPKeyStore is used. func (sp *SAMLServiceProvider) GetEncryptionKey() dsig.X509KeyStore { return sp.SPKeyStore } // Deprecated: This method won't return the correct value if SetSPSigningKeyStore is used. func (sp *SAMLServiceProvider) GetSigningKey() dsig.X509KeyStore { if sp.SPSigningKeyStore == nil { return sp.GetEncryptionKey() // Default is signing key is same as encryption key } return sp.SPSigningKeyStore } func (sp *SAMLServiceProvider) getEncryptionCert() ([]byte, error) { if sp.spKeyStoreOverride != nil { return sp.spKeyStoreOverride.Cert, nil } if sp.SPKeyStore != nil { _, cert, err := sp.SPKeyStore.GetKeyPair() return cert, err } return nil, nil } func (sp *SAMLServiceProvider) GetEncryptionCertBytes() ([]byte, error) { cert, err := sp.getEncryptionCert() if err != nil { return nil, err } if len(cert) < 1 { return nil, ErrSaml{Message: "empty SP encryption certificate"} } return cert, nil } func (sp *SAMLServiceProvider) getSigningCert() ([]byte, error) { if sp.spSigningKeyStoreOverride != nil { return sp.spSigningKeyStoreOverride.Cert, nil } if sp.SPSigningKeyStore != nil { _, cert, err := sp.SPSigningKeyStore.GetKeyPair() return cert, err } return sp.getEncryptionCert() } func (sp *SAMLServiceProvider) GetSigningCertBytes() ([]byte, error) { cert, err := sp.getSigningCert() if err != nil { return nil, err } if len(cert) < 1 { return nil, ErrSaml{Message: "empty SP signing certificate"} } return cert, nil } func (sp *SAMLServiceProvider) getSignerCert() (crypto.Signer, []byte, error) { if s := sp.spSigningKeyStoreOverride; s != nil { return s.Signer, s.Cert, nil } if s := sp.SPSigningKeyStore; s != nil { return s.GetKeyPair() } return nil, nil, nil } func (sp *SAMLServiceProvider) SigningContext() *dsig.SigningContext { sp.signingContextMu.RLock() signingContext := sp.signingContext sp.signingContextMu.RUnlock() if signingContext != nil { return signingContext } sp.signingContextMu.Lock() defer sp.signingContextMu.Unlock() signing := sp.spSigningKeyStoreOverride if signing == nil { signing = sp.spKeyStoreOverride } var err error if signing != nil { sp.signingContext, err = dsig.NewSigningContext(signing.Signer, [][]byte{signing.Cert}) if err != nil { // Ideally this function should return the error, but updating the function // signature would be backward incompatible. Returning nil avoids the previous // panic while preserving the existing API contract. In practice, this error // should never happen because NewSigningContext only errors when passed a nil // signer, and sp.spSigningKeyStoreOverride only gets set after checking to // ensure the signer is not nil. return nil } } else { sp.signingContext = dsig.NewDefaultSigningContext(sp.GetSigningKey()) } sp.signingContext.SetSignatureMethod(sp.SignAuthnRequestsAlgorithm) if sp.SignAuthnRequestsCanonicalizer != nil { sp.signingContext.Canonicalizer = sp.SignAuthnRequestsCanonicalizer } return sp.signingContext } type ProxyRestriction struct { Count int Audience []string } type WarningInfo struct { OneTimeUse bool ProxyRestriction *ProxyRestriction NotInAudience bool InvalidTime bool } type AssertionInfo struct { NameID string Values Values WarningInfo *WarningInfo SessionIndex string AuthnInstant *time.Time SessionNotOnOrAfter *time.Time Assertions []types.Assertion ResponseSignatureValidated bool } ================================================ FILE: saml_test.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package saml2 import ( "bytes" "compress/flate" "crypto" "crypto/rand" "crypto/rsa" "crypto/tls" "crypto/x509" "encoding/base64" "encoding/hex" "encoding/pem" "encoding/xml" "fmt" "io/ioutil" "log" "math/big" "testing" "time" "github.com/beevik/etree" "github.com/jonboulle/clockwork" "github.com/russellhaering/gosaml2/types" dsig "github.com/russellhaering/goxmldsig" "github.com/stretchr/testify/require" ) var cert tls.Certificate var pk crypto.PrivateKey func init() { var err error pfx := "./testdata/test" cert, err = tls.LoadX509KeyPair(fmt.Sprintf("%s.crt", pfx), fmt.Sprintf("%s.key", pfx)) if err != nil { log.Fatal(err) } pk = cert.PrivateKey } func TestDecode(t *testing.T) { f, err := ioutil.ReadFile("./testdata/saml.post") if err != nil { t.Fatalf("could not open test file: %v\n", err) } decoded := make([]byte, len(f)) base64.StdEncoding.Decode(decoded, f) response := &types.Response{} err = xml.Unmarshal(decoded, response) if err != nil { t.Fatalf("error decoding test saml: %v", err) } ea := response.EncryptedAssertions[0] k, err := ea.EncryptedKey.DecryptSymmetricKey(&cert) if err != nil { t.Fatalf("could not get symmetric key: %v\n", err) } if k == nil { t.Fatalf("no symmetric key") } assertion, err := ea.Decrypt(&cert) if err != nil { t.Fatalf("error decrypting saml data: %v\n", err) } f2, err := ioutil.ReadFile("./testdata/saml.xml") if err != nil { t.Fatalf("could not read expected output") } expected := &types.Assertion{} err = xml.Unmarshal(f2, expected) require.EqualValues(t, expected, assertion, "decrypted assertion did not match expectation") } type testKeyStoreImpl struct { key *rsa.PrivateKey cert []byte } func (ks *testKeyStoreImpl) GetKeyPair() (*rsa.PrivateKey, []byte, error) { return ks.key, ks.cert, nil } // testKeyStore generates an RSA key pair with a certificate valid at the given // time, suitable for use with a fake clock in tests. func testKeyStore(t *testing.T, validAt time.Time) dsig.X509KeyStore { t.Helper() key, err := rsa.GenerateKey(rand.Reader, 1024) require.NoError(t, err) template := &x509.Certificate{ SerialNumber: big.NewInt(0), NotBefore: validAt.Add(-time.Hour), NotAfter: validAt.Add(365 * 24 * time.Hour), KeyUsage: x509.KeyUsageDigitalSignature, BasicConstraintsValid: true, } certBytes, err := x509.CreateCertificate(rand.Reader, template, template, &key.PublicKey, key) require.NoError(t, err) return &testKeyStoreImpl{key: key, cert: certBytes} } func signResponse(t *testing.T, resp string, sp *SAMLServiceProvider) string { doc := etree.NewDocument() err := doc.ReadFromBytes([]byte(resp)) require.NoError(t, err) el := doc.Root() // Strip existing signatures signatures := el.FindElements("//Signature") for _, sig := range signatures { parent := sig.Parent() parent.RemoveChild(sig) } el, err = sp.SigningContext().SignEnveloped(el) require.NoError(t, err) doc0 := etree.NewDocument() doc0.SetRoot(el) doc0.WriteSettings = etree.WriteSettings{ CanonicalAttrVal: true, CanonicalEndTags: true, CanonicalText: true, } str, err := doc0.WriteToString() require.NoError(t, err) return str } // getSAMLServiceProvider returns a SAMLServiceProvider that needs to either // set SPKeyStore or call SetSPKeyStore. func getSAMLServiceProvider(t *testing.T, _cert []byte) *SAMLServiceProvider { t.Helper() block, _ := pem.Decode([]byte(idpCertificate)) require.NotEmpty(t, block) cert, err := x509.ParseCertificate(block.Bytes) require.NoError(t, err) require.NotEmpty(t, cert) cert0, err := x509.ParseCertificate(_cert) require.NoError(t, err) require.NotEmpty(t, cert0) certStore := dsig.MemoryX509CertificateStore{ Roots: []*x509.Certificate{cert, cert0}, } return &SAMLServiceProvider{ IdentityProviderSSOURL: "https://dev-116807.oktapreview.com/app/scaleftdev116807_scaleft_1/exk5zt0r12Edi4rD20h7/sso/saml", IdentityProviderIssuer: "http://www.okta.com/exk5zt0r12Edi4rD20h7", AssertionConsumerServiceURL: "http://localhost:8080/v1/_saml_callback", SignAuthnRequests: true, AudienceURI: "123", IDPCertificateStore: &certStore, NameIdFormat: NameIdFormatPersistent, Clock: dsig.NewFakeClock(clockwork.NewFakeClockAt(time.Date(2025, 1, 1, 0, 0, 0, 0, time.UTC))), } } func TestSAML(t *testing.T) { ks := testKeyStore(t, time.Date(2025, 1, 1, 0, 0, 0, 0, time.UTC)) _, _cert, err := ks.GetKeyPair() require.NoError(t, err) sp := getSAMLServiceProvider(t, _cert) sp.SPKeyStore = ks testSAMLServiceProvider(t, sp) } func TestSAMLUsingSetSPKeyStore(t *testing.T) { ks := testKeyStore(t, time.Date(2025, 1, 1, 0, 0, 0, 0, time.UTC)) privateKey, _cert, err := ks.GetKeyPair() require.NoError(t, err) sp := getSAMLServiceProvider(t, _cert) sp.SetSPKeyStore(&KeyStore{ Cert: _cert, Signer: privateKey, }) testSAMLServiceProvider(t, sp) } func testSAMLServiceProvider(t *testing.T, sp *SAMLServiceProvider) { t.Helper() authRequestURL, err := sp.BuildAuthURL("/some/link/here") require.NoError(t, err) require.NotEmpty(t, authRequestURL) authRequestString, err := sp.BuildAuthRequest() require.NoError(t, err) require.NotEmpty(t, authRequestString) // Note (Phoebe): The sample responses we acquired expired fairly quickly, meaning that our validation will fail // because we check the expiration time; // I've modified them to expire in ~100 years and removed their signatures, since those hash values are no longer // valid. We have to re-sign them here before validating them raw := signResponse(t, rawResponse, sp) el, err := sp.ValidateEncodedResponse(base64.StdEncoding.EncodeToString([]byte(raw))) require.NoError(t, err) require.NotEmpty(t, el) assertionInfo, err := sp.RetrieveAssertionInfo(base64.StdEncoding.EncodeToString([]byte(raw))) require.NoError(t, err) require.NotEmpty(t, assertionInfo) require.NotNil(t, assertionInfo.WarningInfo) // always set when err == nil require.False(t, assertionInfo.WarningInfo.OneTimeUse) require.False(t, assertionInfo.WarningInfo.NotInAudience) require.False(t, assertionInfo.WarningInfo.InvalidTime) require.Nil(t, assertionInfo.WarningInfo.ProxyRestriction) require.Equal(t, "phoebe.simon@scaleft.com", assertionInfo.NameID) require.Equal(t, "phoebe.simon@scaleft.com", assertionInfo.Values.Get("Email")) require.Equal(t, "Phoebe", assertionInfo.Values.Get("FirstName")) require.Equal(t, "Simon", assertionInfo.Values.Get("LastName")) require.Equal(t, "phoebesimon", assertionInfo.Values.Get("Login")) assertionInfoModifiedAudience := signResponse(t, assertionInfoModifiedAudienceResponse, sp) assertionInfo, err = sp.RetrieveAssertionInfo(base64.StdEncoding.EncodeToString([]byte(assertionInfoModifiedAudience))) require.NoError(t, err) require.NotEmpty(t, assertionInfo) require.True(t, assertionInfo.WarningInfo.NotInAudience) assertionInfoOneTimeUse := signResponse(t, assertionInfoOneTimeUseResponse, sp) assertionInfo, err = sp.RetrieveAssertionInfo(base64.StdEncoding.EncodeToString([]byte(assertionInfoOneTimeUse))) require.NoError(t, err) require.NotEmpty(t, assertionInfo) require.True(t, assertionInfo.WarningInfo.OneTimeUse) assertionInfoProxyRestriction := signResponse(t, assertionInfoProxyRestrictionResponse, sp) assertionInfo, err = sp.RetrieveAssertionInfo(base64.StdEncoding.EncodeToString([]byte(assertionInfoProxyRestriction))) require.NoError(t, err) require.NotEmpty(t, assertionInfo) require.NotEmpty(t, assertionInfo.WarningInfo.ProxyRestriction) require.Equal(t, 3, assertionInfo.WarningInfo.ProxyRestriction.Count) require.Equal(t, []string{"123"}, assertionInfo.WarningInfo.ProxyRestriction.Audience) assertionInfoProxyRestrictionNoCount := signResponse(t, assertionInfoProxyRestrictionNoCountResponse, sp) assertionInfo, err = sp.RetrieveAssertionInfo(base64.StdEncoding.EncodeToString([]byte(assertionInfoProxyRestrictionNoCount))) require.NoError(t, err) require.NotEmpty(t, assertionInfo) require.NotEmpty(t, assertionInfo.WarningInfo.ProxyRestriction) require.Equal(t, 0, assertionInfo.WarningInfo.ProxyRestriction.Count) require.Equal(t, []string{"123"}, assertionInfo.WarningInfo.ProxyRestriction.Audience) assertionInfoProxyRestrictionNoAudience := signResponse(t, assertionInfoProxyRestrictionNoAudienceResponse, sp) assertionInfo, err = sp.RetrieveAssertionInfo(base64.StdEncoding.EncodeToString([]byte(assertionInfoProxyRestrictionNoAudience))) require.NoError(t, err) require.NotEmpty(t, assertionInfo) require.NotEmpty(t, assertionInfo.WarningInfo.ProxyRestriction) require.Equal(t, 3, assertionInfo.WarningInfo.ProxyRestriction.Count) require.Equal(t, []string{}, assertionInfo.WarningInfo.ProxyRestriction.Audience) assertionInfoResp := signResponse(t, assertionInfoResponse, sp) assertionInfo, err = sp.RetrieveAssertionInfo(base64.StdEncoding.EncodeToString([]byte(assertionInfoResp))) require.NoError(t, err) require.NotEmpty(t, assertionInfo) require.NotEmpty(t, assertionInfo.Values) require.Equal(t, "phoebe.simon@scaleft.com", assertionInfo.Values.Get("Email")) require.Equal(t, "Phoebe", assertionInfo.Values.Get("FirstName")) require.Equal(t, "Simon", assertionInfo.Values.Get("LastName")) require.Equal(t, "phoebe.simon@scaleft.com", assertionInfo.Values.Get("Login")) _, err = sp.ValidateEncodedResponse(base64.StdEncoding.EncodeToString([]byte(manInTheMiddledResponse))) require.Error(t, err) require.Equal(t, "Signature could not be verified", err.Error()) _, err = sp.ValidateEncodedResponse(base64.StdEncoding.EncodeToString([]byte(alteredReferenceURIResponse))) require.Error(t, err) // require.IsType(t, ErrInvalidValue{}, err, err.Error()) require.Equal(t, "Could not verify certificate against trusted certs", err.Error()) _, err = sp.ValidateEncodedResponse(base64.StdEncoding.EncodeToString([]byte(alteredSignedInfoResponse))) require.Error(t, err) require.Equal(t, "Could not verify certificate against trusted certs", err.Error()) alteredRecipient := signResponse(t, alteredRecipientResponse, sp) _, err = sp.ValidateEncodedResponse(base64.StdEncoding.EncodeToString([]byte(alteredRecipient))) require.Error(t, err) require.IsType(t, err, ErrInvalidValue{}) require.Contains(t, err.Error(), "Recipient") alteredDestination := signResponse(t, alteredDestinationResponse, sp) _, err = sp.ValidateEncodedResponse(base64.StdEncoding.EncodeToString([]byte(alteredDestination))) require.Error(t, err) require.IsType(t, err, ErrInvalidValue{}) require.Equal(t, err.(ErrInvalidValue).Key, "Destination") alteredSubjectConfirmationMethod := signResponse(t, alteredSubjectConfirmationMethodResponse, sp) _, err = sp.ValidateEncodedResponse(base64.StdEncoding.EncodeToString([]byte(alteredSubjectConfirmationMethod))) require.Error(t, err) require.IsType(t, err, ErrInvalidValue{}) require.Equal(t, err.(ErrInvalidValue).Reason, ReasonUnsupported) require.Equal(t, err.(ErrInvalidValue).Key, SubjectConfirmationTag) alteredVersion := signResponse(t, alteredVersionResponse, sp) _, err = sp.ValidateEncodedResponse(base64.StdEncoding.EncodeToString([]byte(alteredVersion))) require.Error(t, err) require.IsType(t, err, ErrInvalidValue{}) require.Equal(t, err.(ErrInvalidValue).Reason, ReasonUnsupported) require.Equal(t, err.(ErrInvalidValue).Key, "SAML version") require.Contains(t, err.Error(), "Unsupported SAML version") _, err = sp.ValidateEncodedResponse(base64.StdEncoding.EncodeToString([]byte(missingIDResponse))) require.Error(t, err) require.Equal(t, "Signature could not be verified", err.Error()) } func TestInvalidResponseBadBase64(t *testing.T) { sp := &SAMLServiceProvider{} response, err := sp.ValidateEncodedResponse("invalid-base64") require.EqualError(t, err, "illegal base64 data at input byte 7") require.Nil(t, response) } func TestInvalidResponseBadCompression(t *testing.T) { sp := &SAMLServiceProvider{} // Value from: https://github.com/golang/go/blob/23416315060bf7601e5779c3a6a2529d4d604584/src/compress/flate/flate_test.go#L219 rawResponse, err := hex.DecodeString("33180700") require.NoError(t, err) b64Response := base64.StdEncoding.EncodeToString(rawResponse) response, err := sp.ValidateEncodedResponse(b64Response) require.EqualError(t, err, "flate: corrupt input before offset 3") require.Nil(t, response) } func TestInvalidResponseBadXML(t *testing.T) { sp := &SAMLServiceProvider{} compressed := &bytes.Buffer{} compressor, err := flate.NewWriter(compressed, flate.BestCompression) require.NoError(t, err) compressor.Write([]byte(">Definitely&Invalid XML")) compressor.Close() b64Response := base64.StdEncoding.EncodeToString(compressed.Bytes()) response, err := sp.ValidateEncodedResponse(b64Response) require.EqualError(t, err, "XML syntax error on line 1: invalid character entity &Invalid (no semicolon)") require.Nil(t, response) } func TestInvalidResponseNoElement(t *testing.T) { sp := &SAMLServiceProvider{} b64Response := base64.StdEncoding.EncodeToString([]byte("no-element-here")) response, err := sp.ValidateEncodedResponse(b64Response) require.EqualError(t, err, "unable to parse response") require.Nil(t, response) } func TestSAMLCommentInjection(t *testing.T) { /* Explanation: See: https://duo.com/blog/duo-finds-saml-vulnerabilities-affecting-multiple-implementations The TLDR is that XML canonicalization may result in a different value being signed from the one being retrieved. The target of this is the NameID in the Subject of the SAMLResponse Assertion Example: The following Subject ``` user@user.com.evil.com ``` would get canonicalized to ``` user@user.com.evil.com ``` Many XML parsers have a behavior where they pull the first text element, so in the example with the comment, a vulnerable XML parser would return `user@user.com`, ignoring the text after the comment. Knowing this, a user (user@user.com.evil.com) can attack a vulnerable SP by manipulating their signed SAMLResponse with a comment that turns their username into another one. */ // To show that we are not vulnerable, we want to prove that we get the canonicalized value using our parser _, el, err := parseResponse([]byte(commentInjectionAttackResponse), 0) require.NoError(t, err) decodedResponse := &types.Response{} err = xmlUnmarshalElement(el, decodedResponse) require.NoError(t, err) require.Equal(t, "phoebe.simon@scaleft.com.evil.com", decodedResponse.Assertions[0].Subject.NameID.Value, "The full, canonacalized NameID should be returned.") } ================================================ FILE: test_constants.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package saml2 var idpCertificate = ` -----BEGIN CERTIFICATE----- MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5 QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4 2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+ LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC qRnqQ+TccSu/B6uONFsDEngGcXSKfB+a -----END CERTIFICATE----- ` const rawResponse = ` http://www.okta.com/exk5zt0r12Edi4rD20h7http://www.okta.com/exk5zt0r12Edi4rD20h7FsWGCBC+t/LaVkUKUvRQpzyZTmlxUzw4R9FOzXPPJRw=hS50WgYs/cn3uxmhrza/0/0QW3H7bwdjPZ2hQmG7IeSd7awTOghBqdrjvaPfQ7tRW+UK6ewMgIBVKG6jV3qYAWeW2U70hMb7hE9qJqBKyYyimmhVWULx1HB2YmlU1wmispywoPlXQ6gj0iWaL2RFI83vUp7X50eZ6dELqoJVZpzQI065Tt0TG7UuKUW1flYsbiS9NaXnuw+mcrBW25ZA9F5CLePHki01ZzUw+XtNmKthEb7SR30mzPoj08Dji22daYvGu82IR01wIZPoQJPCGMT6y2xC/pQPqGljAg/vUa+gaYgaMaAVYxhk/hfgMUBlOeKACBaGTmygab1Nz5KvPg==MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5 QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4 2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+ LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC qRnqQ+TccSu/B6uONFsDEngGcXSKfB+aphoebe.simon@scaleft.com123urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransportPhoebeSimonphoebe.simon@scaleft.comphoebesimon` const manInTheMiddledResponse = ` http://www.okta.com/exk5zt0r12Edi4rD20h7ijTqmVmDy7ssK+rvmJaCQ6AQaFaXz+HIN/r6O37B0eQ=G09fAYXGDLK+/jAekHsNL0RLo40Xm6+VwXmUj0IDIrvIIv/mJU5VD6ylOLnPezLDBVY9BJst1YCz+8krdvmQ8Stkd6qiN2bN/5KpCdika111YGpeNdMmg/E57ZG3S895hTNJQYOfCwhPFUtQuXLkspOaw81pcqOTr+bVSofJ8uQP7cVQa/ANxbjKAj0fhAuxAvZfiqPms5Stv4sNGpzULUDJl87CoEleHExGmpTsI7Qt3EvGToPMZXPHF4MGvuC0Z2ZD4iI6Pr7xk98t54PJtAX2qJu1tZqBJmL0Qcq5spl9W3yC1tAZuDeFLm1C4/T9crO2Q5WILP/tkw/yJ+ZttQ==MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5 QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4 2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+ LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC qRnqQ+TccSu/B6uONFsDEngGcXSKfB+ahttp://www.okta.com/exk5zt0r12Edi4rD20h7zln6sheEO2JBdanrT5mZtJZ192tGHavuBpCFHQsJFVg=dHh6TWbnjtImyrfjPTX5QzE/6Vm/HsRWVvWWlvFAddf/CvhO4Kc5j8C7hvQoYMLhYuZMFFSReGysuDy5IscOJwTGhhcvb238qHSGGs6q8OUBCsmLSDAbIaGA++LV/tkUZ2ridGIi0yT81UOl1oT1batlHsK3eMyxkpnFmvBzIm4tGTzRkOPpYRLeiM9bxbKI+DM/623DCXyBCLYBzJo1O6QE02aLajwRMi/vmiV4LSiGlFcY9TtDCafdVJRv0tIQ25BQoT4feuHdr6S8xOSpGgRYH5ECamVOt4e079XdEkVUiSzQokiUkgDlTXEyerPLOVsOk4PW5nRs86sXIiGL5w==MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiH9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5 QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4 2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+ LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC qRnqQ+TccSu/B6uONFsDEngGcXSKfB+aphoebe.simon@scaleft.com123urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransportPhoebeSimonphoebe.simon@scaleft.com` const alteredReferenceURIResponse = ` http://www.okta.com/exk5zt0r12Edi4rD20h7ijTqmVmDy7ssK+rvmJaCQ6AQaFaXz+HIN/r6O37B0eQ=G09fAYXGDLK+/jAekHsNL0RLo40Xm6+VwXmUj0IDIrvIIv/mJU5VD6ylOLnPezLDBVY9BJst1YCz+8krdvmQ8Stkd6qiN2bN/5KpCdika111YGpeNdMmg/E57ZG3S895hTNJQYOfCwhPFUtQuXLkspOaw81pcqOTr+bVSofJ8uQP7cVQa/ANxbjKAj0fhAuxAvZfiqPms5Stv4sNGpzULUDJl87CoEleHExGmpTsI7Qt3EvGToPMZXPHF4MGvuC0Z2ZD4iI6Pr7xk98t54PJtAX2qJu1tZqBJmL0Qcq5spl9W3yC1tAZuDeFLm1C4/T9crO2Q5WILP/tkw/yJ+ZttQ==MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5 QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4 2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+ LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC qRnqQ+TccSu/B6uONFsDEngGcXSKfB+ahttp://www.okta.com/exk5zt0r12Edi4rD20h7zln6sheEO2JBdanrT5mZtJZ192tGHavuBpCFHQsJFVg=dHh6TWbnjtImyrfjPTX5QzE/6Vm/HsRWVvWWlvFAddf/CvhO4Kc5j8C7hvQoYMLhYuZMFFSReGysuDy5IscOJwTGhhcvb238qHSGGs6q8OUBCsmLSDAbIaGA++LV/tkUZ2ridGIi0yT81UOl1oT1batlHsK3eMyxkpnFmvBzIm4tGTzRkOPpYRLeiM9bxbKI+DM/623DCXyBCLYBzJo1O6QE02aLajwRMi/vmiV4LSiGlFcY9TtDCafdVJRv0tIQ25BQoT4feuHdr6S8xOSpGgRYH5ECamVOt4e079XdEkVUiSzQokiUkgDlTXEyerPLOVsOk4PW5nRs86sXIiGL5w==MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiH9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5 QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4 2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+ LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC qRnqQ+TccSu/B6uONFsDEngGcXSKfB+aphoebe.simon@scaleft.com123urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransportPhoebeSimonphoebe.simon@scaleft.com` const alteredSignedInfoResponse = ` http://www.okta.com/exk5zt0r12Edi4rD20h7ijTqmVmDy7ssK+rvmJaCQ6AQaFaXz+HIN/r6O37B0eQ=G09fAYXGDLK+/jAekHsNL0RLo40Xm6+VwXmUj0IDIrvIIv/mJU5VD6ylOLnPezLDBVY9BJst1YCz+8krdvmQ8Stkd6qiN2bN/5KpCdika111YGpeNdMmg/E57ZG3S895hTNJQYOfCwhPFUtQuXLkspOaw81pcqOTr+bVSofJ8uQP7cVQa/ANxbjKAj0fhAuxAvZfiqPms5Stv4sNGpzULUDJl87CoEleHExGmpTsI7Qt3EvGToPMZXPHF4MGvuC0Z2ZD4iI6Pr7xk98t54PJtAX2qJu1tZqBJmL0Qcq5spl9W3yC1tAZuDeFLm1C4/T9crO2Q5WILP/tkw/yJ+ZttQ==MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEV MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5 QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4 2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+ LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC qRnqQ+TccSu/B6uONFsDEngGcXSKfB+ahttp://www.okta.com/exk5zt0r12Edi4rD20h7zln6sheEO2JBdanrT5mZtJZ192tGHavuBpCFHQsJFVg=dHh6TWbnjtImyrfjPTX5QzE/6Vm/HsRWVvWWlvFAddf/CvhO4Kc5j8C7hvQoYMLhYuZMFFSReGysuDy5IscOJwTGhhcvb238qHSGGs6q8OUBCsmLSDAbIaGA++LV/tkUZ2ridGIi0yT81UOl1oT1batlHsK3eMyxkpnFmvBzIm4tGTzRkOPpYRLeiM9bxbKI+DM/623DCXyBCLYBzJo1O6QE02aLajwRMi/vmiV4LSiGlFcY9TtDCafdVJRv0tIQ25BQoT4feuHdr6S8xOSpGgRYH5ECamVOt4e079XdEkVUiSzQokiUkgDlTXEyerPLOVsOk4PW5nRs86sXIiGL5w==MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiH9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5 QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4 2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+ LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC qRnqQ+TccSu/B6uONFsDEngGcXSKfB+aphoebe.simon@scaleft.com123urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransportPhoebeSimonphoebe.simon@scaleft.com` const alteredRecipientResponse = ` http://www.okta.com/exk5zt0r12Edi4rD20h7http://www.okta.com/exk5zt0r12Edi4rD20h7FsWGCBC+t/LaVkUKUvRQpzyZTmlxUzw4R9FOzXPPJRw=hS50WgYs/cn3uxmhrza/0/0QW3H7bwdjPZ2hQmG7IeSd7awTOghBqdrjvaPfQ7tRW+UK6ewMgIBVKG6jV3qYAWeW2U70hMb7hE9qJqBKyYyimmhVWULx1HB2YmlU1wmispywoPlXQ6gj0iWaL2RFI83vUp7X50eZ6dELqoJVZpzQI065Tt0TG7UuKUW1flYsbiS9NaXnuw+mcrBW25ZA9F5CLePHki01ZzUw+XtNmKthEb7SR30mzPoj08Dji22daYvGu82IR01wIZPoQJPCGMT6y2xC/pQPqGljAg/vUa+gaYgaMaAVYxhk/hfgMUBlOeKACBaGTmygab1Nz5KvPg==MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5 QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4 2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+ LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC qRnqQ+TccSu/B6uONFsDEngGcXSKfB+aphoebe.simon@scaleft.com123urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransportPhoebeSimonphoebe.simon@scaleft.comphoebe.simon@scaleft.com` const alteredSubjectConfirmationMethodResponse = ` http://www.okta.com/exk5zt0r12Edi4rD20h7http://www.okta.com/exk5zt0r12Edi4rD20h7FsWGCBC+t/LaVkUKUvRQpzyZTmlxUzw4R9FOzXPPJRw=hS50WgYs/cn3uxmhrza/0/0QW3H7bwdjPZ2hQmG7IeSd7awTOghBqdrjvaPfQ7tRW+UK6ewMgIBVKG6jV3qYAWeW2U70hMb7hE9qJqBKyYyimmhVWULx1HB2YmlU1wmispywoPlXQ6gj0iWaL2RFI83vUp7X50eZ6dELqoJVZpzQI065Tt0TG7UuKUW1flYsbiS9NaXnuw+mcrBW25ZA9F5CLePHki01ZzUw+XtNmKthEb7SR30mzPoj08Dji22daYvGu82IR01wIZPoQJPCGMT6y2xC/pQPqGljAg/vUa+gaYgaMaAVYxhk/hfgMUBlOeKACBaGTmygab1Nz5KvPg==MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5 QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4 2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+ LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC qRnqQ+TccSu/B6uONFsDEngGcXSKfB+aphoebe.simon@scaleft.com123urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransportPhoebeSimonphoebe.simon@scaleft.comphoebe.simon@scaleft.com` const alteredDestinationResponse = ` http://www.okta.com/exk5zt0r12Edi4rD20h7http://www.okta.com/exk5zt0r12Edi4rD20h7FsWGCBC+t/LaVkUKUvRQpzyZTmlxUzw4R9FOzXPPJRw=hS50WgYs/cn3uxmhrza/0/0QW3H7bwdjPZ2hQmG7IeSd7awTOghBqdrjvaPfQ7tRW+UK6ewMgIBVKG6jV3qYAWeW2U70hMb7hE9qJqBKyYyimmhVWULx1HB2YmlU1wmispywoPlXQ6gj0iWaL2RFI83vUp7X50eZ6dELqoJVZpzQI065Tt0TG7UuKUW1flYsbiS9NaXnuw+mcrBW25ZA9F5CLePHki01ZzUw+XtNmKthEb7SR30mzPoj08Dji22daYvGu82IR01wIZPoQJPCGMT6y2xC/pQPqGljAg/vUa+gaYgaMaAVYxhk/hfgMUBlOeKACBaGTmygab1Nz5KvPg==MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5 QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4 2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+ LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC qRnqQ+TccSu/B6uONFsDEngGcXSKfB+aphoebe.simon@scaleft.com123urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransportPhoebeSimonphoebe.simon@scaleft.comphoebe.simon@scaleft.com` const alteredVersionResponse = ` http://www.okta.com/exk5zt0r12Edi4rD20h7http://www.okta.com/exk5zt0r12Edi4rD20h7FsWGCBC+t/LaVkUKUvRQpzyZTmlxUzw4R9FOzXPPJRw=hS50WgYs/cn3uxmhrza/0/0QW3H7bwdjPZ2hQmG7IeSd7awTOghBqdrjvaPfQ7tRW+UK6ewMgIBVKG6jV3qYAWeW2U70hMb7hE9qJqBKyYyimmhVWULx1HB2YmlU1wmispywoPlXQ6gj0iWaL2RFI83vUp7X50eZ6dELqoJVZpzQI065Tt0TG7UuKUW1flYsbiS9NaXnuw+mcrBW25ZA9F5CLePHki01ZzUw+XtNmKthEb7SR30mzPoj08Dji22daYvGu82IR01wIZPoQJPCGMT6y2xC/pQPqGljAg/vUa+gaYgaMaAVYxhk/hfgMUBlOeKACBaGTmygab1Nz5KvPg==MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5 QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4 2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+ LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC qRnqQ+TccSu/B6uONFsDEngGcXSKfB+aphoebe.simon@scaleft.com123urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransportPhoebeSimonphoebe.simon@scaleft.comphoebe.simon@scaleft.com` const missingIDResponse = ` http://www.okta.com/exk5zt0r12Edi4rD20h7mj+xyS5DtKVNbbFq4caWhGcrirqNzv7mIHNzHQH/f60=GA1URoMOE5EFfkHYimGXm7Ecph/m0s135VyF9Wut6NSpuZdQ2crM1IslvKCRjkE09rZgagQQMAThUcOFuX35dZPz9J4Ihpt1juhfGv1AV8I8jiOKFETj65MiPabDEi8+P6YWf4qNujAJXHKJIa/MFXBqoKR/imLQT8eu1nhVBQGYqWwZePddfXO2JYk2ce7mtnyMT0dUVb+o+tlEDYa7ri9fj4JL/z1XX7yrbVZxn2mdKPJtSSP8uHNOWSM6j1vp4oK+KSDviBfiVLlVA58noz5GyFtp642h+LV2quKbncMFfnfB1kfHLK/xaz9UaDBy+bHK4oGzSpVhZqcOzzliKA==MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5 QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4 2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+ LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC qRnqQ+TccSu/B6uONFsDEngGcXSKfB+ahttp://www.okta.com/exk5zt0r12Edi4rD20h7FsWGCBC+t/LaVkUKUvRQpzyZTmlxUzw4R9FOzXPPJRw=hS50WgYs/cn3uxmhrza/0/0QW3H7bwdjPZ2hQmG7IeSd7awTOghBqdrjvaPfQ7tRW+UK6ewMgIBVKG6jV3qYAWeW2U70hMb7hE9qJqBKyYyimmhVWULx1HB2YmlU1wmispywoPlXQ6gj0iWaL2RFI83vUp7X50eZ6dELqoJVZpzQI065Tt0TG7UuKUW1flYsbiS9NaXnuw+mcrBW25ZA9F5CLePHki01ZzUw+XtNmKthEb7SR30mzPoj08Dji22daYvGu82IR01wIZPoQJPCGMT6y2xC/pQPqGljAg/vUa+gaYgaMaAVYxhk/hfgMUBlOeKACBaGTmygab1Nz5KvPg==MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5 QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4 2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+ LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC qRnqQ+TccSu/B6uONFsDEngGcXSKfB+aphoebe.simon@scaleft.com123urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransportPhoebeSimonphoebe.simon@scaleft.comphoebe.simon@scaleft.com` const assertionInfoResponse = ` http://www.okta.com/exk5zt0r12Edi4rD20h7http://www.okta.com/exk5zt0r12Edi4rD20h7FsWGCBC+t/LaVkUKUvRQpzyZTmlxUzw4R9FOzXPPJRw=hS50WgYs/cn3uxmhrza/0/0QW3H7bwdjPZ2hQmG7IeSd7awTOghBqdrjvaPfQ7tRW+UK6ewMgIBVKG6jV3qYAWeW2U70hMb7hE9qJqBKyYyimmhVWULx1HB2YmlU1wmispywoPlXQ6gj0iWaL2RFI83vUp7X50eZ6dELqoJVZpzQI065Tt0TG7UuKUW1flYsbiS9NaXnuw+mcrBW25ZA9F5CLePHki01ZzUw+XtNmKthEb7SR30mzPoj08Dji22daYvGu82IR01wIZPoQJPCGMT6y2xC/pQPqGljAg/vUa+gaYgaMaAVYxhk/hfgMUBlOeKACBaGTmygab1Nz5KvPg==MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5 QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4 2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+ LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC qRnqQ+TccSu/B6uONFsDEngGcXSKfB+aphoebe.simon@scaleft.com123urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransportPhoebeSimonphoebe.simon@scaleft.comphoebe.simon@scaleft.com` const assertionInfoModifiedAudienceResponse = ` http://www.okta.com/exk5zt0r12Edi4rD20h7http://www.okta.com/exk5zt0r12Edi4rD20h7FsWGCBC+t/LaVkUKUvRQpzyZTmlxUzw4R9FOzXPPJRw=hS50WgYs/cn3uxmhrza/0/0QW3H7bwdjPZ2hQmG7IeSd7awTOghBqdrjvaPfQ7tRW+UK6ewMgIBVKG6jV3qYAWeW2U70hMb7hE9qJqBKyYyimmhVWULx1HB2YmlU1wmispywoPlXQ6gj0iWaL2RFI83vUp7X50eZ6dELqoJVZpzQI065Tt0TG7UuKUW1flYsbiS9NaXnuw+mcrBW25ZA9F5CLePHki01ZzUw+XtNmKthEb7SR30mzPoj08Dji22daYvGu82IR01wIZPoQJPCGMT6y2xC/pQPqGljAg/vUa+gaYgaMaAVYxhk/hfgMUBlOeKACBaGTmygab1Nz5KvPg==MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5 QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4 2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+ LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC qRnqQ+TccSu/B6uONFsDEngGcXSKfB+aphoebe.simon@scaleft.com124urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransportPhoebeSimonphoebe.simon@scaleft.comphoebe.simon@scaleft.com` const assertionInfoOneTimeUseResponse = ` http://www.okta.com/exk5zt0r12Edi4rD20h7http://www.okta.com/exk5zt0r12Edi4rD20h7FsWGCBC+t/LaVkUKUvRQpzyZTmlxUzw4R9FOzXPPJRw=hS50WgYs/cn3uxmhrza/0/0QW3H7bwdjPZ2hQmG7IeSd7awTOghBqdrjvaPfQ7tRW+UK6ewMgIBVKG6jV3qYAWeW2U70hMb7hE9qJqBKyYyimmhVWULx1HB2YmlU1wmispywoPlXQ6gj0iWaL2RFI83vUp7X50eZ6dELqoJVZpzQI065Tt0TG7UuKUW1flYsbiS9NaXnuw+mcrBW25ZA9F5CLePHki01ZzUw+XtNmKthEb7SR30mzPoj08Dji22daYvGu82IR01wIZPoQJPCGMT6y2xC/pQPqGljAg/vUa+gaYgaMaAVYxhk/hfgMUBlOeKACBaGTmygab1Nz5KvPg==MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5 QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4 2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+ LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC qRnqQ+TccSu/B6uONFsDEngGcXSKfB+aphoebe.simon@scaleft.com123urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransportPhoebeSimonphoebe.simon@scaleft.comphoebe.simon@scaleft.com` const assertionInfoProxyRestrictionResponse = ` http://www.okta.com/exk5zt0r12Edi4rD20h7http://www.okta.com/exk5zt0r12Edi4rD20h7FsWGCBC+t/LaVkUKUvRQpzyZTmlxUzw4R9FOzXPPJRw=hS50WgYs/cn3uxmhrza/0/0QW3H7bwdjPZ2hQmG7IeSd7awTOghBqdrjvaPfQ7tRW+UK6ewMgIBVKG6jV3qYAWeW2U70hMb7hE9qJqBKyYyimmhVWULx1HB2YmlU1wmispywoPlXQ6gj0iWaL2RFI83vUp7X50eZ6dELqoJVZpzQI065Tt0TG7UuKUW1flYsbiS9NaXnuw+mcrBW25ZA9F5CLePHki01ZzUw+XtNmKthEb7SR30mzPoj08Dji22daYvGu82IR01wIZPoQJPCGMT6y2xC/pQPqGljAg/vUa+gaYgaMaAVYxhk/hfgMUBlOeKACBaGTmygab1Nz5KvPg==MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5 QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4 2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+ LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC qRnqQ+TccSu/B6uONFsDEngGcXSKfB+aphoebe.simon@scaleft.com123123urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransportPhoebeSimonphoebe.simon@scaleft.comphoebe.simon@scaleft.com` const assertionInfoProxyRestrictionNoCountResponse = ` http://www.okta.com/exk5zt0r12Edi4rD20h7http://www.okta.com/exk5zt0r12Edi4rD20h7FsWGCBC+t/LaVkUKUvRQpzyZTmlxUzw4R9FOzXPPJRw=hS50WgYs/cn3uxmhrza/0/0QW3H7bwdjPZ2hQmG7IeSd7awTOghBqdrjvaPfQ7tRW+UK6ewMgIBVKG6jV3qYAWeW2U70hMb7hE9qJqBKyYyimmhVWULx1HB2YmlU1wmispywoPlXQ6gj0iWaL2RFI83vUp7X50eZ6dELqoJVZpzQI065Tt0TG7UuKUW1flYsbiS9NaXnuw+mcrBW25ZA9F5CLePHki01ZzUw+XtNmKthEb7SR30mzPoj08Dji22daYvGu82IR01wIZPoQJPCGMT6y2xC/pQPqGljAg/vUa+gaYgaMaAVYxhk/hfgMUBlOeKACBaGTmygab1Nz5KvPg==MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5 QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4 2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+ LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC qRnqQ+TccSu/B6uONFsDEngGcXSKfB+aphoebe.simon@scaleft.com123123urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransportPhoebeSimonphoebe.simon@scaleft.comphoebe.simon@scaleft.com` const assertionInfoProxyRestrictionNoAudienceResponse = ` http://www.okta.com/exk5zt0r12Edi4rD20h7http://www.okta.com/exk5zt0r12Edi4rD20h7FsWGCBC+t/LaVkUKUvRQpzyZTmlxUzw4R9FOzXPPJRw=hS50WgYs/cn3uxmhrza/0/0QW3H7bwdjPZ2hQmG7IeSd7awTOghBqdrjvaPfQ7tRW+UK6ewMgIBVKG6jV3qYAWeW2U70hMb7hE9qJqBKyYyimmhVWULx1HB2YmlU1wmispywoPlXQ6gj0iWaL2RFI83vUp7X50eZ6dELqoJVZpzQI065Tt0TG7UuKUW1flYsbiS9NaXnuw+mcrBW25ZA9F5CLePHki01ZzUw+XtNmKthEb7SR30mzPoj08Dji22daYvGu82IR01wIZPoQJPCGMT6y2xC/pQPqGljAg/vUa+gaYgaMaAVYxhk/hfgMUBlOeKACBaGTmygab1Nz5KvPg==MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5 QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4 2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+ LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC qRnqQ+TccSu/B6uONFsDEngGcXSKfB+aphoebe.simon@scaleft.com123urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransportPhoebeSimonphoebe.simon@scaleft.comphoebe.simon@scaleft.com` const exampleBase64 = `<?xml version="1.0" encoding="UTF-8"?><saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="http://localhost:8080/v1/_saml_callback" ID="id103532804647787975381325" InResponseTo="_8699c655-c482-451a-9b7f-61668f140b47" IssueInstant="2016-03-16T01:02:57.682Z" 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/exk5zt0r12Edi4rD20h7</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="#id103532804647787975381325"><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>npTAl6kraksBlCRlunbyD6nICTcfsDaHjPXVxoDPrw0=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>SbB03fI1TVstJ7q1B6Xx8YRGkDpNQ8ar4zF3p3aikkcq8TTS0eR28FoQuN1HX72Pn2rccE4ONizYNS6/rvrlyV/SlXXmC9mhTLRPeJz5mrxjqO5QYD1Y3IzmnkfQ6KutukkcGOJEpa3vYesf5JKRS+0WGRtzOS4wJF18oGIZ+ba8P6gxmMryA8xB/eJgxpfrmUbBjPHLSfljebh88EiNID088XuSGyd+3DmpW5B52DQB8cAyyOBRkRRcqLFIgxibmvtIiequU0a2ncojpu0+4ojl+4wDCWdGOEyqtJoTQXC4sKRaU79FK5IFfEiYMqviFD0oau4sPj0gnFCEF5Fl4w==</ds:SignatureValue><ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG
A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU
MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW
DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE
BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV
BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ
KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA
mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5
QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4
2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN
uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+
LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ
TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ
DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a
cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP
pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC
qRnqQ+TccSu/B6uONFsDEngGcXSKfB+a</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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" ID="id1035328046526588900089424" IssueInstant="2016-03-16T01:02:57.682Z" Version="2.0"><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/exk5zt0r12Edi4rD20h7</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="#id1035328046526588900089424"><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>No1VyQlk8Xif4FiJ+haViwEQySIzBa14lGy0coCn0c8=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>VSV8Vw47q7n/XZwaQOPWQeKI5ZA69fnGZyEFhex4xuaIfC+LOYnfd8q8qcZsm1M6kv47H/dR6YXRIMjPKXZeyX/MKcmGPCadqWFT7EWFvzuO/uy/AB/CL5ZCQiY9H/aOhDysO8glse1S+Y2K0CwvsoRwMfFiO2XOYhVOsngUSkCBdLIB6Oq4f+ZsK0rw/E79n9QUd8owDq3dVC18SFYYdcIVDhQppglyuBEZfu2tG06gD9jls7ZE8vjcMfHmhuHtxlH3ovNLB35NFO/VrCNdFqmD76GnEA98foiJxCX8vzNHF4rPUFXAEdiS4OdQAxb7jNNVoKVYuadunLygysZGSg==</ds:SignatureValue><ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG
A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU
MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW
DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE
BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV
BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ
KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA
mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5
QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4
2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN
uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+
LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ
TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ
DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a
cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP
pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC
qRnqQ+TccSu/B6uONFsDEngGcXSKfB+a</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:1.1:nameid-format:unspecified">russell.haering@scaleft.com</saml2:NameID><saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer"><saml2:SubjectConfirmationData InResponseTo="_8699c655-c482-451a-9b7f-61668f140b47" NotOnOrAfter="2016-03-16T01:07:57.682Z" Recipient="http://localhost:8080/v1/_saml_callback"/></saml2:SubjectConfirmation></saml2:Subject><saml2:Conditions NotBefore="2016-03-16T00:57:57.682Z" NotOnOrAfter="2016-03-16T01:07:57.682Z" xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion"><saml2:AudienceRestriction><saml2:Audience>123</saml2:Audience></saml2:AudienceRestriction></saml2:Conditions><saml2:AuthnStatement AuthnInstant="2016-03-16T01:02:57.682Z" SessionIndex="_8699c655-c482-451a-9b7f-61668f140b47" 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>` const exampleBase64_2 = `<?xml version="1.0" encoding="UTF-8"?><saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="http://localhost:8080/v1/_saml_callback" ID="id2128248929510670834559185" InResponseTo="_da213df8-ef95-41d0-b9bf-71d271735cd7" IssueInstant="2016-03-28T16:38:18.565Z" Version="2.0" xmlns:xs="http://www.w3.org/2001/XMLSchema"><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/exk5zt0r12Edi4rD20h7</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="#id2128248929510670834559185"><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#"><ec:InclusiveNamespaces xmlns:ec="http://www.w3.org/2001/10/xml-exc-c14n#" PrefixList="xs"/></ds:Transform></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2001/04/xmlenc#sha256"/><ds:DigestValue>WvgW/JfP4mjU+/1wtyX06E9EGxYNsoCU+rbSZnAvj2s=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>GA1URoMOE5EFfkHYimGXm7Ecph/m0s135VyF9Wut6NSpuZdQ2crM1IslvKCRjkE09rZgagQQMAThUcOFuX35dZPz9J4Ihpt1juhfGv1AV8I8jiOKFETj65MiPabDEi8+P6YWf4qNujAJXHKJIa/MFXBqoKR/imLQT8eu1nhVBQGYqWwZePddfXO2JYk2ce7mtnyMT0dUVb+o+tlEDYa7ri9fj4JL/z1XX7yrbVZxn2mdKPJtSSP8uHNOWSM6j1vp4oK+KSDviBfiVLlVA58noz5GyFtp642h+LV2quKbncMFfnfB1kfHLK/xaz9UaDBy+bHK4oGzSpVhZqcOzzliKA==</ds:SignatureValue><ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG
A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU
MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW
DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE
BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV
BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ
KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA
mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5
QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4
2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN
uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+
LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ
TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ
DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a
cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP
pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC
qRnqQ+TccSu/B6uONFsDEngGcXSKfB+a</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 xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" ID="id21282489295776782126468319" IssueInstant="2016-03-28T16:38:18.565Z" Version="2.0" xmlns:xs="http://www.w3.org/2001/XMLSchema"><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/exk5zt0r12Edi4rD20h7</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="#id21282489295776782126468319"><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#"><ec:InclusiveNamespaces xmlns:ec="http://www.w3.org/2001/10/xml-exc-c14n#" PrefixList="xs"/></ds:Transform></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2001/04/xmlenc#sha256"/><ds:DigestValue>FsWGCBC+t/LaVkUKUvRQpzyZTmlxUzw4R9FOzXPPJRw=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>hS50WgYs/cn3uxmhrza/0/0QW3H7bwdjPZ2hQmG7IeSd7awTOghBqdrjvaPfQ7tRW+UK6ewMgIBVKG6jV3qYAWeW2U70hMb7hE9qJqBKyYyimmhVWULx1HB2YmlU1wmispywoPlXQ6gj0iWaL2RFI83vUp7X50eZ6dELqoJVZpzQI065Tt0TG7UuKUW1flYsbiS9NaXnuw+mcrBW25ZA9F5CLePHki01ZzUw+XtNmKthEb7SR30mzPoj08Dji22daYvGu82IR01wIZPoQJPCGMT6y2xC/pQPqGljAg/vUa+gaYgaMaAVYxhk/hfgMUBlOeKACBaGTmygab1Nz5KvPg==</ds:SignatureValue><ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG
A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU
MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW
DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE
BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV
BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ
KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA
mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5
QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4
2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN
uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+
LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ
TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ
DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a
cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP
pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC
qRnqQ+TccSu/B6uONFsDEngGcXSKfB+a</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:1.1:nameid-format:emailAddress">phoebe.simon@scaleft.com</saml2:NameID><saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer"><saml2:SubjectConfirmationData InResponseTo="_da213df8-ef95-41d0-b9bf-71d271735cd7" NotOnOrAfter="2016-03-28T16:43:18.565Z" Recipient="http://localhost:8080/v1/_saml_callback"/></saml2:SubjectConfirmation></saml2:Subject><saml2:Conditions NotBefore="2016-03-28T16:33:18.565Z" NotOnOrAfter="2016-03-28T16:43:18.565Z" xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion"><saml2:AudienceRestriction><saml2:Audience>123</saml2:Audience></saml2:AudienceRestriction></saml2:Conditions><saml2:AuthnStatement AuthnInstant="2016-03-28T16:38:18.565Z" SessionIndex="_da213df8-ef95-41d0-b9bf-71d271735cd7" 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:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion"><saml2:Attribute Name="FirstName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified"><saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Phoebe</saml2:AttributeValue></saml2:Attribute><saml2:Attribute Name="LastName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified"><saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Simon</saml2:AttributeValue></saml2:Attribute><saml2:Attribute Name="Email" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified"><saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">phoebe.simon@scaleft.com</saml2:AttributeValue></saml2:Attribute><saml2:Attribute Name="Login" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified"><saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">phoebe.simon@scaleft.com</saml2:AttributeValue></saml2:Attribute></saml2:AttributeStatement></saml2:Assertion></saml2p:Response>` const commentInjectionAttackResponse = ` http://www.okta.com/exk5zt0r12Edi4rD20h7http://www.okta.com/exk5zt0r12Edi4rD20h7FsWGCBC+t/LaVkUKUvRQpzyZTmlxUzw4R9FOzXPPJRw=hS50WgYs/cn3uxmhrza/0/0QW3H7bwdjPZ2hQmG7IeSd7awTOghBqdrjvaPfQ7tRW+UK6ewMgIBVKG6jV3qYAWeW2U70hMb7hE9qJqBKyYyimmhVWULx1HB2YmlU1wmispywoPlXQ6gj0iWaL2RFI83vUp7X50eZ6dELqoJVZpzQI065Tt0TG7UuKUW1flYsbiS9NaXnuw+mcrBW25ZA9F5CLePHki01ZzUw+XtNmKthEb7SR30mzPoj08Dji22daYvGu82IR01wIZPoQJPCGMT6y2xC/pQPqGljAg/vUa+gaYgaMaAVYxhk/hfgMUBlOeKACBaGTmygab1Nz5KvPg==MIIDpDCCAoygAwIBAgIGAVLIBhAwMA0GCSqGSIb3DQEBBQUAMIGSMQswCQYDVQQGEwJVUzETMBEG A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU MBIGA1UECwwLU1NPUHJvdmlkZXIxEzARBgNVBAMMCmRldi0xMTY4MDcxHDAaBgkqhkiG9w0BCQEW DWluZm9Ab2t0YS5jb20wHhcNMTYwMjA5MjE1MjA2WhcNMjYwMjA5MjE1MzA2WjCBkjELMAkGA1UE BhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNV BAoMBE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRMwEQYDVQQDDApkZXYtMTE2ODA3MRwwGgYJ KoZIhvcNAQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA mtjBOZ8MmhUyi8cGk4dUY6Fj1MFDt/q3FFiaQpLzu3/q5lRVUNUBbAtqQWwY10dzfZguHOuvA5p5 QyiVDvUhe+XkVwN2R2WfArQJRTPnIcOaHrxqQf3o5cCIG21ZtysFHJSo8clPSOe+0VsoRgcJ1aF4 2rODwgqRRZdO9Wh3502XlJ799DJQ23IC7XasKEsGKzJqhlRrfd/FyIuZT0sFHDKRz5snSJhm9gpN uQlCmk7ONZ1sXqtt+nBIfWIqeoYQubPW7pT5GTc7wouWq4TCjHJiK9k2HiyNxW0E3JX08swEZi2+ LVDjgLzNc4lwjSYIj3AOtPZs8s606oBdIBni4wIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBMxSkJ TxkXxsoKNW0awJNpWRbU81QpheMFfENIzLam4Itc/5kSZAaSy/9e2QKfo4jBo/MMbCq2vM9TyeJQ DJpRaioUTd2lGh4TLUxAxCxtUk/pascL+3Nn936LFmUCLxaxnbeGzPOXAhscCtU1H0nFsXRnKx5a cPXYSKFZZZktieSkww2Oi8dg2DYaQhGQMSFMVqgVfwEu4bvCRBvdSiNXdWGCZQmFVzBZZ/9rOLzP pvTFTPnpkavJm81FLlUhiE/oFgKlCDLWDknSpXAI0uZGERcwPca6xvIMh86LjQKjbVci9FYDStXC qRnqQ+TccSu/B6uONFsDEngGcXSKfB+aphoebe.simon@scaleft.com.evil.com123urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransportPhoebeSimonphoebe.simon@scaleft.comphoebesimon` const doubleColonAssertionInjectionAttackResponse = ` https://app.onelogin.com/saml/metadata/634027 <::Assertion xmlns="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:saml="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" Version="2.0" ID="x" IssueInstant="2017-03-08T07:53:39Z">https://app.onelogin.com/saml/metadata/634027gd5V090n/m4JRrtpo5WgrwPyyy0=what@launchdarkly.com{audience}urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport https://app.onelogin.com/saml/metadata/634027gd5V090n/m4JRrtpo5WgrwPyyy0=SLzvdNM+1R1+3XsXpC+/RIvb5L4Lhy7Eb7caPG2CLMPYhzbKLAwIiT7/0fEMO/xL7rdIgEShbcU9iu5PX4hGYBhirsFIZvdHytns5+JKHnlVBmHm4TsSU1z+dGMXBa//L0KFSrvdgBUpsr5vs50SuYnnVp61VN+zCLMqO221CQfP95QyMcSQ+fiyq4GOmWLwQy1m1+NV3U8zlapp6FIH5stW/dp4OqpRdafV96rVwmmR4yeUw7VAzbJuMrPgkXO9nUbHeMUTgQxkQ4ThzG5jt6fT+Ro1NOYS4zpVtzqlQwGzqWxQVRLEqXIf500/Qi0NuFQOW42ZAUiXDgdLENTVGA==MIIEJjCCAw6gAwIBAgIUOHrykO4ce1TbjvGgXXVVnR4NsqMwDQYJKoZIhvcNAQEFBQAwXTELMAkGA1UEBhMCVVMxFTATBgNVBAoMDExhdW5jaERhcmtseTEVMBMGA1UECwwMT25lTG9naW4gSWRQMSAwHgYDVQQDDBdPbmVMb2dpbiBBY2NvdW50IDEwMjEyNzAeFw0xNzAzMDYwMjQ2NTNaFw0yMjAzMDcwMjQ2NTNaMF0xCzAJBgNVBAYTAlVTMRUwEwYDVQQKDAxMYXVuY2hEYXJrbHkxFTATBgNVBAsMDE9uZUxvZ2luIElkUDEgMB4GA1UEAwwXT25lTG9naW4gQWNjb3VudCAxMDIxMjcwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCaJ02AnJe5vq+zzkmrIHhRy8V/UxJogbJGEJW6nqrEmO7Q4sXO7dLIKxGccCEz0KAavGKWzSX9uhVvKpazpD4bW80wPQIgFxN3CjiA3qlYIfhhh4emSZo2AnaTuG4BPVGFNPx0jxXGAhh/3xkpIsqARJFPB6njT2+MwFctm3fockx3Yp4e1xoUD8qQR0f/8oq1LjrYd2Vlckmmw7qrzSqS8POHW/I1jx9Y/vAjTPWDKXmbmLcTe3188PDrthSyoBuaAGBRVTP9WTuYMh4kGvmfX6sNvIDGejUcUCq6IObRr4xLSZiGy5uoyqsQc9agAhQm+26Gpq0R3NSvN91JdbZHAgMBAAGjgd0wgdowDAYDVR0TAQH/BAIwADAdBgNVHQ4EFgQUnbxBsHgNVq3OSXEuG5EkR0Jd1UswgZoGA1UdIwSBkjCBj4AUnbxBsHgNVq3OSXEuG5EkR0Jd1UuhYaRfMF0xCzAJBgNVBAYTAlVTMRUwEwYDVQQKDAxMYXVuY2hEYXJrbHkxFTATBgNVBAsMDE9uZUxvZ2luIElkUDEgMB4GA1UEAwwXT25lTG9naW4gQWNjb3VudCAxMDIxMjeCFDh68pDuHHtU247xoF11VZ0eDbKjMA4GA1UdDwEB/wQEAwIHgDANBgkqhkiG9w0BAQUFAAOCAQEAL/6j2qpMCrnolwKT7mfPEpA6btbtl0R0t6zSwYUVU9T3PK0/P3LKXvbjSySov0E4R9d5qlOcyj5CbYiuqAO2aON3xy82s0dN3FHRiO6kcjoRPwVIIF0S8x7tpzcPKa42zSPfBqMRw4ezUEzTijFriepkSWST1Btr3QeK2Cxhr0fC1xmw/YK82BV0/oVRslGL27ro+v3/dNY0A0r32Xe2+THomrY/YaZaDCPCjHo8dlxrX3D/mPfoiiKSkm2mGagQXT0giTHVo3oIq+u+KdrBcQn65EBcjfFKDIeFCdiVmO0xPl9mmWskVRLy2/wpuDIp6hnAphl9lj5DY48eBsrEXQ==arun@launchdarkly.com{audience}urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport ` ================================================ FILE: testdata/assertion.xml ================================================ https://idp.astuart.co/idp/shibboleth AAdzZWNyZXQx6UL9kX1rPkSRwv/pFpk49idUCREsqJRkBQvfzT1Fd2ZsVQbw+QXIzXhBUhmPdydrqqXIC0NEMBWriN5zl1A+q761LIFNcElBcPKrolxyzuPt oauth.astuart.co urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport astuart member andrew.stuart2@gmail.com ================================================ FILE: testdata/idp.crt ================================================ -----BEGIN CERTIFICATE----- MIIDODCCAiCgAwIBAgIUDPz+OwougAXSuQmKDyAEL46KlPgwDQYJKoZIhvcNAQEL BQAwHTEbMBkGA1UEAwwSY29sbGVnZS5jY2N0Y2EuZWR1MB4XDTE1MDYwNDIyMTA0 NFoXDTM1MDYwNDIyMTA0NFowHTEbMBkGA1UEAwwSY29sbGVnZS5jY2N0Y2EuZWR1 MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEApa0K3OtkHwOnBKSJ7PxT 7zry+p8kpu20d+whJs9mHW8w+DikLQ2orLPDZA34Xor0QdR6Y6+gqezIJqqpvuaj YTneQQtXD3neCGD9pPemyF4efEnl21YHryt6Juy6VXIcB6ytHGhmaWg41btdxweD li0b6M7Z6KAW5FjJUoqA+GqFY8rvdm0HZQN+ko4KRK7zTft6ZaPOSbQd7vMtU8bj Msh2XGLWx9G10jvCOFDUbsCNQ3xeFkV30rlUgjb6p2eRUSDWcVPs2Q/FG3t8TVfJ dDtRYps7QW0GDaCPM5hYnlSm+gXwkS8V0j8bGPjv7TfxxK3VMx6okIVsKga7swuZ 4QIDAQABo3AwbjAdBgNVHQ4EFgQUT56D4cLSoNxs17FBY+evwXvL2jowTQYDVR0R BEYwRIISY29sbGVnZS5jY2N0Y2EuZWR1hi5odHRwczovL2NvbGxlZ2UuY2NjdGNh LmVkdTo4NDQzL2lkcC9zaGliYm9sZXRoMA0GCSqGSIb3DQEBCwUAA4IBAQBiG0Nw KxslU74tcgjK8CBVahTs5s9Nh2s/En9lP6iWqS2wOHotZ19qqp+AJoIG0pJJpQ6o fRSHdWD2uHmF0F7Uzu1XBxxbV3oG8DmbhzUw2TAOsn0Czt8V30Tfn9U+auNW2XSb z27FACHplll7/T+pycCW6vUcw+boDJIG92TxqIMzlBQOzDGGOTGf/OaKXLb48rWT kEfMv//2Kh735TytX0bJsPmmCLlI9kLcrBNKgHGPNB7oeQNGnYOu+ALxSIugZ7MW LRx2jHND7RSVTetgfEEkkSzsebCxNKMdhIL62Z8VZgYUGD07EeV/3RZ0eV0q5Yf8 BhBA6Owk2P264O4R -----END CERTIFICATE----- ================================================ FILE: testdata/saml.post ================================================ <?xml version="1.0" encoding="UTF-8"?>
<saml2p:Response Destination="https://saml2.test.astuart.co/sso/saml2" ID="_b9e8e6bddb1f60483802c7ae4aa922a6" IssueInstant="2016-04-28T22:41:49.655Z" Version="2.0" xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol"><saml2:Issuer xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">https://idp.astuart.co/idp/shibboleth</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="#_b9e8e6bddb1f60483802c7ae4aa922a6">
<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>0bFyCR1uWb6t2uouG2HmqshKsrR5qSNVfNjixXPsvls=</ds:DigestValue>
</ds:Reference>
</ds:SignedInfo>
<ds:SignatureValue>
E8cFue9zwz+aN5HeOI6bKZwvBBDcya8aaaAo6CQn1xK32B8alWBhI38WS06jscD8HNvQCQ2+gFHz
3kvf3HcGj5NLseHgWlLmZB8KeowZtN/nHF6UR/b8s1ViLwa1DqQxUY+koeGsk/RSJ5EiV9/rP8wF
ABChNCWoIiIXs7cK5SeenbVZcIQPG0FM8DTiUnLusKk3uYhw1MeJJLEcIghElPOIevUDb05vKQb/
L/7VMLe1I7o4EnBWYRHgigTykdpt3MO2Ua7oV/h9mHZlT1fOXCJ3gxC37puJ7Zo0vcregdNbIJ1Q
07DXJ0B0J41/cDDPdsRF4QTStdQnN2r6EcBZtQ==
</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDODCCAiCgAwIBAgIUQH54kyyeacU69J2iwz9bzeLmMaswDQYJKoZIhvcNAQELBQAwHTEbMBkG
A1UEAwwSY29sbGVnZS5jY2N0Y2EuZWR1MB4XDTE1MDYwNDIyMTAzMVoXDTM1MDYwNDIyMTAzMVow
HTEbMBkGA1UEAwwSY29sbGVnZS5jY2N0Y2EuZWR1MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIB
CgKCAQEAlJhN20ng2VN/cTrWtqUINaUsrHCkYXbm2y1PTN4b6fJI5hbvcv+LWCuLkLi3+iPGlBpc
HHfrdJcyhmBHRHQ9Sos3RIH5Lsn1IgjWe3hxQQmVeEi5xVxnw2YZGHaeX4YnI1TEBJwhtJmyitk7
4LHybPGEqOJdApUnLz54L7I+252G/cOfEqUHMbxxtmHSc/9chF8bBxQ8OzIbJsByHnqiawQHwtst
tre7n328gVqmf1VHE27cfAYiSjuK5pCsx/1kuJMBN+kg/3Gg9oi6aR50WX1VUF3IBcnTDeiAXRz3
PgsT8FlVZou6Ik9NT/Y5IHOZVGk64SRDaG8FuGxLexXrswIDAQABo3AwbjAdBgNVHQ4EFgQUjQwa
AoY3u/iToIE3ADeNEW+Uu34wTQYDVR0RBEYwRIISY29sbGVnZS5jY2N0Y2EuZWR1hi5odHRwczov
L2NvbGxlZ2UuY2NjdGNhLmVkdTo4NDQzL2lkcC9zaGliYm9sZXRoMA0GCSqGSIb3DQEBCwUAA4IB
AQB26rdxphN1YKad3yDhLg6Y1ZwbmAjc+l4QB1KSL+cLqhDn5iMy4VdWh8HpSKRqCwofLtlw3qOw
ospj+mJaguXRMpjYODRQaKRkTrCGxJhuNrQxDXL/b6FOEIJnUYenbPevuNgRJc1VnREhWUUXT44K
N5YUz9FEiG0BsBK8ecCPKBzTQ/hwaczhpqw6uqVMqxJaTGcnlCUHJAhVHiA8lWJ7vaNPsJ86xBFs
/F76EwyFXIKQaruvcvChU7GNNSYdNJBa6HO99QWdGbr5aNQ4diunnBQdrdjgbQIwyhKTfbFWa2l5
vbqEKDc0dwuPa6c25l8ruqxqCQ1CF8ZDDJ0XV6Ab</ds:X509Certificate></ds:X509Data></ds:KeyInfo></ds:Signature><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 Id="_d6ea344d0b30ad7f79e506cca0673d2f" Type="http://www.w3.org/2001/04/xmlenc#Element" xmlns:xenc="http://www.w3.org/2001/04/xmlenc#"><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="_df159ee65e25d92495fd8a33cc205d25" Recipient="https://saml2.test.astuart.co/sso/saml2" 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>MIID2zCCAsOgAwIBAgIJANfD2hyjW72lMA0GCSqGSIb3DQEBCwUAMIGDMQswCQYDVQQGEwJaWjEU
MBIGA1UECAwLVHJhbnF1aWxpdHkxITAfBgNVBAoMGEludGVybmV0IFdpZGdpdHMgUHR5IEx0ZDES
MBAGA1UEAwwJc2FtbC50ZXN0MScwJQYJKoZIhvcNAQkBFhhhbmRyZXcuc3R1YXJ0MkBnbWFpbC5j
b20wHhcNMTYwNDI4MjIzODE5WhcNMTYwNTI4MjIzODE5WjCBgzELMAkGA1UEBhMCWloxFDASBgNV
BAgMC1RyYW5xdWlsaXR5MSEwHwYDVQQKDBhJbnRlcm5ldCBXaWRnaXRzIFB0eSBMdGQxEjAQBgNV
BAMMCXNhbWwudGVzdDEnMCUGCSqGSIb3DQEJARYYYW5kcmV3LnN0dWFydDJAZ21haWwuY29tMIIB
IjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEApwtg91fGm7NZBASrAdASmK86Nsh1fNFs6pz4
FFfCwyUHulJTKCk6Ph0ToGRcOFhVgPWtPYkCwL6iUmJTPzj5uoB0Y3eF2MM+tkix8f4RUrWzpqyM
hECtsv4rzF7LpZXCWdJHnN9Z6zwFdLxub6V01PGmIhtGyf9mEqZ2qonSIPAzoRBzZStPu4SJkJzI
N3BttvHVRVF+E5AKxYLvkBTtl5JzCsivs+hTrrDg/zwiq7yXOwoZhzPrAHriYPOLm/sPuwTIBxAH
mKwp0ihDHpEC5eNAXvChkUYcG8DdDNpSxjpH6ufyVLxfKWtHUcHnJCGnw/LUgI1S1bdljeyZeKFB
MwIDAQABo1AwTjAdBgNVHQ4EFgQUiuceZuXfFuk1aC/J1RQVYQtzlz4wHwYDVR0jBBgwFoAUiuce
ZuXfFuk1aC/J1RQVYQtzlz4wDAYDVR0TBAUwAwEB/zANBgkqhkiG9w0BAQsFAAOCAQEAn3ShXVUl
caM8bmtlpF6stGB00bNinVfkGQ1OWYVb8J7l3QPb2pK0aoccb6MyDhmthYYeSNcLVUK6J0yHCQUC
2cFa/y7jwZHhnb5RoMLjYan0710FZy27Y8LYVNpdtT3RKxPHzWIW8EELsShHQ1UfGNPQo+OxdVlj
zQGpDjjNPiFKJFRt7A4XURHfS43d5mMj6znGHcsP4XpcQLZXpQwF+u7TyHtAXwKOIanRuGrwoBtA
WvZBgEJ047KdHZGyxa42yWILFW+fraK4Vx6wo56LLlwoTEHB8YLuHAuoFtYxq4fO/ORJPlxENszT
xphXaYUoryRyPCiuMOKo770wa+4D+g==</ds:X509Certificate></ds:X509Data></ds:KeyInfo><xenc:CipherData xmlns:xenc="http://www.w3.org/2001/04/xmlenc#"><xenc:CipherValue>bKIJhP/y1opxYD4iNXbNH+wEQEvpEf8k3VlN0ZBtrv+wThwSBhF0opGlihYoyo5wY1HPN4zqzQMU
ABw8zKD5pVf2yDHlBuUicmAUyNK9/NLT08y4zU12ODKI6SKnhV9QTpe0QvdgROtMGFeJvObFZpH+
xNcGPzsJ8/BhYs40+bTUI6eTMBEci360bNsFN4yAOx5KGSz5iB+8pZa/+BVYmJGwF0qzyaCxZ/TJ
vDT8L/GDsD1ORv9qcJ4wHE/i3YQ0bFpQ4VklAYoK5zy+F01s1jMOoZ6w7uWfgP2DYHg2B/gvoR7u
tDSnF8GUw4mVJDYHEPjPM5q9GHWO1+ZV5S2/pg==</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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
V+dF3IWPhAsTSCxKkRE=</xenc:CipherValue></xenc:CipherData></xenc:EncryptedData></saml2:EncryptedAssertion></saml2p:Response> ================================================ FILE: testdata/saml.xml ================================================ https://idp.astuart.co/idp/shibboleth njFuiDnD41G6xI2DUPqLG24GWBYuzrYurVWNH6CXHlA= TUg7S7GdqWUYm7EkdBkH/k3CnqUm78c4IQxyB1MPMpcMAswjHQnUOY4f3P4EssYZRkTvk5Xazi2O r7DcN3f9U7FXtWAVD0HzBkbVKNM+jPCSKxd66zRUUFINJbYi/WJePiIveuSaUiK/8JJgFXr5z9GR EQtCuJTBAIf4JNUv0lhLWTACwrEYirtsrKrJMT0qd3Ff1iNuw9ufcMXuUJCiWGa3x3hTbV6XFmGY aMDv43aKAI64ytRd4URtJtKR1L6zt85ncF3FVwMdE9XVTzzKhaqDKafa4H8obZsIUwUDsY/k4qlc wt2/lVq6JE8I2v2oXPY817b2v0aP/Z8SyImgCQ== MIIDODCCAiCgAwIBAgIUQH54kyyeacU69J2iwz9bzeLmMaswDQYJKoZIhvcNAQELBQAwHTEbMBkG A1UEAwwSY29sbGVnZS5jY2N0Y2EuZWR1MB4XDTE1MDYwNDIyMTAzMVoXDTM1MDYwNDIyMTAzMVow HTEbMBkGA1UEAwwSY29sbGVnZS5jY2N0Y2EuZWR1MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIB CgKCAQEAlJhN20ng2VN/cTrWtqUINaUsrHCkYXbm2y1PTN4b6fJI5hbvcv+LWCuLkLi3+iPGlBpc HHfrdJcyhmBHRHQ9Sos3RIH5Lsn1IgjWe3hxQQmVeEi5xVxnw2YZGHaeX4YnI1TEBJwhtJmyitk7 4LHybPGEqOJdApUnLz54L7I+252G/cOfEqUHMbxxtmHSc/9chF8bBxQ8OzIbJsByHnqiawQHwtst tre7n328gVqmf1VHE27cfAYiSjuK5pCsx/1kuJMBN+kg/3Gg9oi6aR50WX1VUF3IBcnTDeiAXRz3 PgsT8FlVZou6Ik9NT/Y5IHOZVGk64SRDaG8FuGxLexXrswIDAQABo3AwbjAdBgNVHQ4EFgQUjQwa AoY3u/iToIE3ADeNEW+Uu34wTQYDVR0RBEYwRIISY29sbGVnZS5jY2N0Y2EuZWR1hi5odHRwczov L2NvbGxlZ2UuY2NjdGNhLmVkdTo4NDQzL2lkcC9zaGliYm9sZXRoMA0GCSqGSIb3DQEBCwUAA4IB AQB26rdxphN1YKad3yDhLg6Y1ZwbmAjc+l4QB1KSL+cLqhDn5iMy4VdWh8HpSKRqCwofLtlw3qOw ospj+mJaguXRMpjYODRQaKRkTrCGxJhuNrQxDXL/b6FOEIJnUYenbPevuNgRJc1VnREhWUUXT44K N5YUz9FEiG0BsBK8ecCPKBzTQ/hwaczhpqw6uqVMqxJaTGcnlCUHJAhVHiA8lWJ7vaNPsJ86xBFs /F76EwyFXIKQaruvcvChU7GNNSYdNJBa6HO99QWdGbr5aNQ4diunnBQdrdjgbQIwyhKTfbFWa2l5 vbqEKDc0dwuPa6c25l8ruqxqCQ1CF8ZDDJ0XV6AbAAdzZWNyZXQxAVyT8pMdokSCQIwZcewBdiLGv/UGZX4UNVpUI5QqkXPxy/s2H7BHxnT9AnVoDdLcKVhMcZrqHsnx6rB7YHOCQFymgctznZPosV/kNb85pM6ptKly1SqxBOw9iicrUwVrBOlbqZpRJufAGG8/dT0Qhttps://saml2.test.astuart.co/sso/saml2urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransportpcollegeadminportalCollegeAdmin000portalCollegeAdminCollegeadminPeter CollegeadminPeterpcollegeadmin@democollege.edu ================================================ FILE: testdata/saml_compressed.post ================================================ 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 ================================================ FILE: testdata/test.crt ================================================ -----BEGIN CERTIFICATE----- MIID2zCCAsOgAwIBAgIJANfD2hyjW72lMA0GCSqGSIb3DQEBCwUAMIGDMQswCQYD VQQGEwJaWjEUMBIGA1UECAwLVHJhbnF1aWxpdHkxITAfBgNVBAoMGEludGVybmV0 IFdpZGdpdHMgUHR5IEx0ZDESMBAGA1UEAwwJc2FtbC50ZXN0MScwJQYJKoZIhvcN AQkBFhhhbmRyZXcuc3R1YXJ0MkBnbWFpbC5jb20wHhcNMTYwNDI4MjIzODE5WhcN MTYwNTI4MjIzODE5WjCBgzELMAkGA1UEBhMCWloxFDASBgNVBAgMC1RyYW5xdWls aXR5MSEwHwYDVQQKDBhJbnRlcm5ldCBXaWRnaXRzIFB0eSBMdGQxEjAQBgNVBAMM CXNhbWwudGVzdDEnMCUGCSqGSIb3DQEJARYYYW5kcmV3LnN0dWFydDJAZ21haWwu Y29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEApwtg91fGm7NZBASr AdASmK86Nsh1fNFs6pz4FFfCwyUHulJTKCk6Ph0ToGRcOFhVgPWtPYkCwL6iUmJT Pzj5uoB0Y3eF2MM+tkix8f4RUrWzpqyMhECtsv4rzF7LpZXCWdJHnN9Z6zwFdLxu b6V01PGmIhtGyf9mEqZ2qonSIPAzoRBzZStPu4SJkJzIN3BttvHVRVF+E5AKxYLv kBTtl5JzCsivs+hTrrDg/zwiq7yXOwoZhzPrAHriYPOLm/sPuwTIBxAHmKwp0ihD HpEC5eNAXvChkUYcG8DdDNpSxjpH6ufyVLxfKWtHUcHnJCGnw/LUgI1S1bdljeyZ eKFBMwIDAQABo1AwTjAdBgNVHQ4EFgQUiuceZuXfFuk1aC/J1RQVYQtzlz4wHwYD VR0jBBgwFoAUiuceZuXfFuk1aC/J1RQVYQtzlz4wDAYDVR0TBAUwAwEB/zANBgkq hkiG9w0BAQsFAAOCAQEAn3ShXVUlcaM8bmtlpF6stGB00bNinVfkGQ1OWYVb8J7l 3QPb2pK0aoccb6MyDhmthYYeSNcLVUK6J0yHCQUC2cFa/y7jwZHhnb5RoMLjYan0 710FZy27Y8LYVNpdtT3RKxPHzWIW8EELsShHQ1UfGNPQo+OxdVljzQGpDjjNPiFK JFRt7A4XURHfS43d5mMj6znGHcsP4XpcQLZXpQwF+u7TyHtAXwKOIanRuGrwoBtA WvZBgEJ047KdHZGyxa42yWILFW+fraK4Vx6wo56LLlwoTEHB8YLuHAuoFtYxq4fO /ORJPlxENszTxphXaYUoryRyPCiuMOKo770wa+4D+g== -----END CERTIFICATE----- ================================================ FILE: testdata/test.key ================================================ -----BEGIN PRIVATE KEY----- MIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCnC2D3V8abs1kE BKsB0BKYrzo2yHV80WzqnPgUV8LDJQe6UlMoKTo+HROgZFw4WFWA9a09iQLAvqJS YlM/OPm6gHRjd4XYwz62SLHx/hFStbOmrIyEQK2y/ivMXsullcJZ0kec31nrPAV0 vG5vpXTU8aYiG0bJ/2YSpnaqidIg8DOhEHNlK0+7hImQnMg3cG228dVFUX4TkArF gu+QFO2XknMKyK+z6FOusOD/PCKrvJc7ChmHM+sAeuJg84ub+w+7BMgHEAeYrCnS KEMekQLl40Be8KGRRhwbwN0M2lLGOkfq5/JUvF8pa0dRweckIafD8tSAjVLVt2WN 7Jl4oUEzAgMBAAECggEANODrPyEwI9WwVg9MOvStDlxZ50Gpv2tkORibh4UIiFHO knLBFDOI1mTJ87oRX1zHJF2hC5u1nWI7bCzoAVl95EYJkfsiCa40yetVOS+eODqA tkBk8vCui7zeDIHtoWs47MoeFVC23DpR19RWeU09ILOmTaGo1QTeQQUlB3M9a2Nb LZcJmxqQyFg5G0oDs/Xo3rlGw/MWm1gsRuBEW42xuAUKyBcUEHvIAPozXBfEnwAv cf0+VLoxGsHwY8Rbz2R886ex0/sKnSD673dM3LRQv8S2i/5UtLBYX0BqDKzuLO4K JS/uDJtPDmErjgA4p74ytqJFYmSnGnmluKR0OE9KgQKBgQDbXa4oEcdoGN15FoTb g3hiy5zi4xw2NQrofKmHeFOFfgDOF0RxRQVCIiKFu619oalVJE5wqq0vt61W3mQ7 /OikHdlwXipcZ8LKEIeViT6KNrU4UTXL7aR2YiMTkBnbfDLhiMDOyKwyySmF7+hD WR7gq1CuJXmjFsPlw9RwIAoVIQKBgQDC8NprSK1ggQ0riBj5PY/JUD6LTp1MO223 wU2OvjfA7L3cK33GpPx7fRRcnh3sv5UqUgEtfTuCu2bD+u/cvdfzUxLXk89mh9zD Fe4E+SLSd5Vo6Wpe8W7LamK2i3Lc/rRdby7GM+qEQ22vhkegyFW+klDOXYULo2ZO OsEB+Q/30wKBgQCKfMPb7A11fG0lasAJTSCNTnoHCtXeqvHt//WO3rnrxrZ/ZVUC JU7Ch4Y/41INxCeA5uDWZAnd3BmEg/XHoUzFf0qsk+YuXBsvMexGzVQ8MXmKykoq KibvzdjTGuAYHnqIw6rlYO7FSRX7xo9dJUBHGiBfMK1v9olJ3q2Y88EpwQKBgQCE qRGKxuet78S9ph2Qp9NM5X3aoYIsGZk93p9gD5Szhqhhx3sNjsN/agxMRxIIRgxF w46nnTy9Z7i0j/VhnBP0s8jzydPva2/Rlv/mhICtB9I2lfncaKLEbT6GCXn+aJrn pr0HBteGcLiZJWFjSlIHoVy6QyxCUk1R2Wv1Yr/6HwKBgD4IrY33kSHCpElzLY2Q q4ysjYF1XfWvji+SOhwM97KMXz0U+Pk4GIik0WZVZbvyU48EQaKf+hupPou8EdMR YD5XYh7Owjg2FY354XX5kl2SzI+00EDnZiEC6mLPsVEsIayty1QxozFzkCZgmb59 9Nqhywrrbsnv7kDX3QBxZMkn -----END PRIVATE KEY----- ================================================ FILE: types/encrypted_assertion.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package types import ( "bytes" "crypto/cipher" "crypto/tls" "encoding/base64" "encoding/xml" "fmt" ) type EncryptedAssertion struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:assertion EncryptedAssertion"` EncryptionMethod EncryptionMethod `xml:"EncryptedData>EncryptionMethod"` EncryptedKey EncryptedKey `xml:"EncryptedData>KeyInfo>EncryptedKey"` DetEncryptedKey EncryptedKey `xml:"EncryptedKey"` // detached EncryptedKey element CipherValue string `xml:"EncryptedData>CipherData>CipherValue"` } func (ea *EncryptedAssertion) DecryptBytes(cert *tls.Certificate) ([]byte, error) { data, err := base64.StdEncoding.DecodeString(ea.CipherValue) if err != nil { return nil, err } // EncryptedKey must include CipherValue. EncryptedKey may be part of EncryptedData. ek := &ea.EncryptedKey if ek.CipherValue == "" { // Use detached EncryptedKey element (sibling of EncryptedData). See: // https://www.w3.org/TR/2002/REC-xmlenc-core-20021210/Overview.html#sec-Extensions-to-KeyInfo ek = &ea.DetEncryptedKey } k, err := ek.DecryptSymmetricKey(cert) if err != nil { return nil, fmt.Errorf("cannot decrypt, error retrieving private key: %s", err) } switch ea.EncryptionMethod.Algorithm { case MethodAES128GCM, MethodAES192GCM, MethodAES256GCM: c, err := cipher.NewGCM(k) if err != nil { return nil, fmt.Errorf("cannot create AES-GCM: %s", err) } nonce, data := data[:c.NonceSize()], data[c.NonceSize():] plainText, err := c.Open(nil, nonce, data, nil) if err != nil { return nil, fmt.Errorf("cannot open AES-GCM: %s", err) } return plainText, nil case MethodAES128CBC, MethodAES256CBC, MethodTripleDESCBC: if len(data)%k.BlockSize() != 0 { return nil, fmt.Errorf("encrypted data is not a multiple of the expected CBC block size %d: actual size %d", k.BlockSize(), len(data)) } nonce, data := data[:k.BlockSize()], data[k.BlockSize():] c := cipher.NewCBCDecrypter(k, nonce) c.CryptBlocks(data, data) // Remove zero bytes data = bytes.TrimRight(data, "\x00") if len(data) == 0 { return nil, fmt.Errorf("CBC decrypted data is empty after trimming zero bytes") } // Validate and remove padding. The pad length byte indicates // how many bytes to strip. Bounds-check to prevent panics from // crafted ciphertext. padLength := int(data[len(data)-1]) if padLength == 0 || padLength > len(data) || padLength > k.BlockSize() { return nil, fmt.Errorf("invalid CBC padding length: %d (data length: %d, block size: %d)", padLength, len(data), k.BlockSize()) } return data[:len(data)-padLength], nil default: return nil, fmt.Errorf("unknown symmetric encryption method %#v", ea.EncryptionMethod.Algorithm) } } // Decrypt decrypts and unmarshals the EncryptedAssertion. func (ea *EncryptedAssertion) Decrypt(cert *tls.Certificate) (*Assertion, error) { plaintext, err := ea.DecryptBytes(cert) if err != nil { return nil, fmt.Errorf("Error decrypting assertion: %v", err) } assertion := &Assertion{} err = xml.Unmarshal(plaintext, assertion) if err != nil { return nil, fmt.Errorf("Error unmarshaling assertion: %v", err) } return assertion, nil } ================================================ FILE: types/encrypted_key.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package types import ( "bytes" "crypto/aes" "crypto/cipher" "crypto/rand" "crypto/rsa" "crypto/sha1" "crypto/sha256" "crypto/sha512" "crypto/tls" "encoding/base64" "encoding/hex" "fmt" "hash" "strings" ) //EncryptedKey contains the decryption key data from the saml2 core and xmlenc //standards. type EncryptedKey struct { // EncryptionMethod string `xml:"EncryptionMethod>Algorithm"` X509Data string `xml:"KeyInfo>X509Data>X509Certificate"` CipherValue string `xml:"CipherData>CipherValue"` EncryptionMethod EncryptionMethod } //EncryptionMethod specifies the type of encryption that was used. type EncryptionMethod struct { Algorithm string `xml:",attr,omitempty"` //Digest method is present for algorithms like RSA-OAEP. //See https://www.w3.org/TR/xmlenc-core1/. //To convey the digest methods an entity supports, //DigestMethod in extensions element is used. //See http://docs.oasis-open.org/security/saml/Post2.0/sstc-saml-metadata-algsupport.html. DigestMethod *DigestMethod `xml:",omitempty"` } //DigestMethod is a digest type specification type DigestMethod struct { Algorithm string `xml:",attr,omitempty"` } //Well-known public-key encryption methods const ( MethodRSAOAEP = "http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p" MethodRSAOAEP2 = "http://www.w3.org/2009/xmlenc11#rsa-oaep" MethodRSAv1_5 = "http://www.w3.org/2001/04/xmlenc#rsa-1_5" ) //Well-known private key encryption methods const ( MethodAES128GCM = "http://www.w3.org/2009/xmlenc11#aes128-gcm" MethodAES192GCM = "http://www.w3.org/2009/xmlenc11#aes192-gcm" MethodAES256GCM = "http://www.w3.org/2009/xmlenc11#aes256-gcm" MethodAES128CBC = "http://www.w3.org/2001/04/xmlenc#aes128-cbc" MethodAES256CBC = "http://www.w3.org/2001/04/xmlenc#aes256-cbc" MethodTripleDESCBC = "http://www.w3.org/2001/04/xmlenc#tripledes-cbc" ) //Well-known hash methods const ( MethodSHA1 = "http://www.w3.org/2000/09/xmldsig#sha1" MethodSHA256 = "http://www.w3.org/2000/09/xmldsig#sha256" MethodSHA512 = "http://www.w3.org/2000/09/xmldsig#sha512" ) //SHA-1 is commonly used for certificate fingerprints (openssl -fingerprint and ADFS thumbprint). //SHA-1 is sufficient for our purposes here (error message). func debugKeyFp(keyBytes []byte) string { if len(keyBytes) < 1 { return "" } hashFunc := sha1.New() hashFunc.Write(keyBytes) sum := strings.ToLower(hex.EncodeToString(hashFunc.Sum(nil))) var ret string for idx := 0; idx+1 < len(sum); idx += 2 { if idx == 0 { ret += sum[idx : idx+2] } else { ret += ":" + sum[idx:idx+2] } } return ret } //DecryptSymmetricKey returns the private key contained in the EncryptedKey document func (ek *EncryptedKey) DecryptSymmetricKey(cert *tls.Certificate) (cipher.Block, error) { if len(cert.Certificate) < 1 { return nil, fmt.Errorf("decryption tls.Certificate has no public certs attached") } // The EncryptedKey may or may not include X509Data (certificate). // If included, the EncryptedKey certificate: // - is FYI only (fail if it does not match the SP certificate) // - is NOT used to decrypt CipherData if ek.X509Data != "" { if encCert, err := base64.StdEncoding.DecodeString(ek.X509Data); err != nil { return nil, fmt.Errorf("error decoding EncryptedKey certificate: %v", err) } else if !bytes.Equal(cert.Certificate[0], encCert) { return nil, fmt.Errorf("key decryption attempted with mismatched cert, SP cert(%.11s), assertion cert(%.11s)", debugKeyFp(cert.Certificate[0]), debugKeyFp(encCert)) } } cipherText, err := base64.StdEncoding.DecodeString(ek.CipherValue) if err != nil { return nil, err } switch pk := cert.PrivateKey.(type) { case *rsa.PrivateKey: var h hash.Hash if ek.EncryptionMethod.DigestMethod == nil { //if digest method is not present lets set default method to SHA1. //Digest method is used by methods like RSA-OAEP. h = sha1.New() } else { switch ek.EncryptionMethod.DigestMethod.Algorithm { case "", MethodSHA1: h = sha1.New() // default case MethodSHA256: h = sha256.New() case MethodSHA512: h = sha512.New() default: return nil, fmt.Errorf("unsupported digest algorithm: %v", ek.EncryptionMethod.DigestMethod.Algorithm) } } switch ek.EncryptionMethod.Algorithm { case "": return nil, fmt.Errorf("missing encryption algorithm") case MethodRSAOAEP, MethodRSAOAEP2: pt, err := rsa.DecryptOAEP(h, rand.Reader, pk, cipherText, nil) if err != nil { return nil, fmt.Errorf("rsa internal error: %v", err) } b, err := aes.NewCipher(pt) if err != nil { return nil, err } return b, nil case MethodRSAv1_5: pt, err := rsa.DecryptPKCS1v15(rand.Reader, pk, cipherText) if err != nil { return nil, fmt.Errorf("rsa internal error: %v", err) } //From https://docs.oasis-open.org/security/saml/v2.0/saml-core-2.0-os.pdf the xml encryption //methods to be supported are from http://www.w3.org/2001/04/xmlenc#Element. //https://www.w3.org/TR/2002/REC-xmlenc-core-20021210/Overview.html#Element. //https://www.w3.org/TR/2002/REC-xmlenc-core-20021210/#sec-Algorithms //Sec 5.4 Key Transport: //The RSA v1.5 Key Transport algorithm given below are those used in conjunction with TRIPLEDES //Please also see https://www.w3.org/TR/xmlenc-core/#sec-Algorithms and //https://www.w3.org/TR/xmlenc-core/#rsav15note. b, err := aes.NewCipher(pt) if err != nil { return nil, err } return b, nil default: return nil, fmt.Errorf("unsupported encryption algorithm: %s", ek.EncryptionMethod.Algorithm) } } return nil, fmt.Errorf("no cipher for decoding symmetric key") } ================================================ FILE: types/metadata.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package types import ( "encoding/xml" "time" dsigtypes "github.com/russellhaering/goxmldsig/types" ) type EntityDescriptor struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:metadata EntityDescriptor"` ValidUntil time.Time `xml:"validUntil,attr"` // SAML 2.0 8.3.6 Entity Identifier could be used to represent issuer EntityID string `xml:"entityID,attr"` SPSSODescriptor *SPSSODescriptor `xml:"SPSSODescriptor,omitempty"` IDPSSODescriptor *IDPSSODescriptor `xml:"IDPSSODescriptor,omitempty"` Extensions *Extensions `xml:"Extensions,omitempty"` } type Endpoint struct { Binding string `xml:"Binding,attr"` Location string `xml:"Location,attr"` ResponseLocation string `xml:"ResponseLocation,attr,omitempty"` } type IndexedEndpoint struct { Binding string `xml:"Binding,attr"` Location string `xml:"Location,attr"` Index int `xml:"index,attr"` } type SPSSODescriptor struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:metadata SPSSODescriptor"` AuthnRequestsSigned bool `xml:"AuthnRequestsSigned,attr"` WantAssertionsSigned bool `xml:"WantAssertionsSigned,attr"` ProtocolSupportEnumeration string `xml:"protocolSupportEnumeration,attr"` KeyDescriptors []KeyDescriptor `xml:"KeyDescriptor"` SingleLogoutServices []Endpoint `xml:"SingleLogoutService"` NameIDFormats []string `xml:"NameIDFormat"` AssertionConsumerServices []IndexedEndpoint `xml:"AssertionConsumerService"` Extensions *Extensions `xml:"Extensions,omitempty"` } type IDPSSODescriptor struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:metadata IDPSSODescriptor"` WantAuthnRequestsSigned bool `xml:"WantAuthnRequestsSigned,attr"` KeyDescriptors []KeyDescriptor `xml:"KeyDescriptor"` NameIDFormats []NameIDFormat `xml:"NameIDFormat"` SingleSignOnServices []SingleSignOnService `xml:"SingleSignOnService"` SingleLogoutServices []SingleLogoutService `xml:"SingleLogoutService"` Attributes []Attribute `xml:"Attribute"` Extensions *Extensions `xml:"Extensions,omitempty"` } type KeyDescriptor struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:metadata KeyDescriptor"` Use string `xml:"use,attr"` KeyInfo dsigtypes.KeyInfo `xml:"KeyInfo"` EncryptionMethods []EncryptionMethod `xml:"EncryptionMethod"` } type NameIDFormat struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:metadata NameIDFormat"` Value string `xml:",chardata"` } type SingleSignOnService struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:metadata SingleSignOnService"` Binding string `xml:"Binding,attr"` Location string `xml:"Location,attr"` } type SingleLogoutService struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:metadata SingleLogoutService"` Binding string `xml:"Binding,attr"` Location string `xml:"Location,attr"` } type SigningMethod struct { Algorithm string `xml:",attr"` MinKeySize string `xml:"MinKeySize,attr,omitempty"` MaxKeySize string `xml:"MaxKeySize,attr,omitempty"` } type Extensions struct { DigestMethod *DigestMethod `xml:",omitempty"` SigningMethod *SigningMethod `xml:",omitempty"` } ================================================ FILE: types/response.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package types import ( "encoding/xml" "time" ) // UnverifiedBaseResponse extracts several basic attributes of a SAML Response // which may be useful in deciding how to validate the Response. An UnverifiedBaseResponse // is parsed by this library prior to any validation of the Response, so the // values it contains may have been supplied by an attacker and should not be // trusted as authoritative from the IdP. type UnverifiedBaseResponse struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:protocol Response"` ID string `xml:"ID,attr"` InResponseTo string `xml:"InResponseTo,attr"` Destination string `xml:"Destination,attr"` Version string `xml:"Version,attr"` Issuer *Issuer `xml:"Issuer"` } type Response struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:protocol Response"` ID string `xml:"ID,attr"` InResponseTo string `xml:"InResponseTo,attr"` Destination string `xml:"Destination,attr"` Version string `xml:"Version,attr"` IssueInstant time.Time `xml:"IssueInstant,attr"` Status *Status `xml:"Status"` Issuer *Issuer `xml:"Issuer"` Assertions []Assertion `xml:"Assertion"` EncryptedAssertions []EncryptedAssertion `xml:"EncryptedAssertion"` SignatureValidated bool `xml:"-"` // not read, not dumped } type LogoutResponse struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:protocol LogoutResponse"` ID string `xml:"ID,attr"` InResponseTo string `xml:"InResponseTo,attr"` Destination string `xml:"Destination,attr"` Version string `xml:"Version,attr"` IssueInstant time.Time `xml:"IssueInstant,attr"` Status *Status `xml:"Status"` Issuer *Issuer `xml:"Issuer"` SignatureValidated bool `xml:"-"` // not read, not dumped } type Status struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:protocol Status"` StatusCode *StatusCode `xml:"StatusCode"` } type StatusCode struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:protocol StatusCode"` Value string `xml:"Value,attr"` } type Issuer struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:assertion Issuer"` Value string `xml:",chardata"` } type Signature struct { SignatureDocument []byte `xml:",innerxml"` } type Assertion struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:assertion Assertion"` Version string `xml:"Version,attr"` ID string `xml:"ID,attr"` IssueInstant time.Time `xml:"IssueInstant,attr"` Issuer *Issuer `xml:"Issuer"` Signature *Signature `xml:"Signature"` Subject *Subject `xml:"Subject"` Conditions *Conditions `xml:"Conditions"` AttributeStatement *AttributeStatement `xml:"AttributeStatement"` AuthnStatement *AuthnStatement `xml:"AuthnStatement"` SignatureValidated bool `xml:"-"` // not read, not dumped } type Subject struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:assertion Subject"` NameID *NameID `xml:"NameID"` SubjectConfirmation *SubjectConfirmation `xml:"SubjectConfirmation"` } type AuthnContext struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:assertion AuthnContext"` AuthnContextClassRef *AuthnContextClassRef `xml:"AuthnContextClassRef"` } type AuthnContextClassRef struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:assertion AuthnContextClassRef"` Value string `xml:",chardata"` } type NameID struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:assertion NameID"` Value string `xml:",chardata"` } type SubjectConfirmation struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:assertion SubjectConfirmation"` Method string `xml:"Method,attr"` SubjectConfirmationData *SubjectConfirmationData `xml:"SubjectConfirmationData"` } type SubjectConfirmationData struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:assertion SubjectConfirmationData"` NotOnOrAfter string `xml:"NotOnOrAfter,attr"` Recipient string `xml:"Recipient,attr"` InResponseTo string `xml:"InResponseTo,attr"` } type Conditions struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:assertion Conditions"` NotBefore string `xml:"NotBefore,attr"` NotOnOrAfter string `xml:"NotOnOrAfter,attr"` AudienceRestrictions []AudienceRestriction `xml:"AudienceRestriction"` OneTimeUse *OneTimeUse `xml:"OneTimeUse"` ProxyRestriction *ProxyRestriction `xml:"ProxyRestriction"` } type AudienceRestriction struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:assertion AudienceRestriction"` Audiences []Audience `xml:"Audience"` } type Audience struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:assertion Audience"` Value string `xml:",chardata"` } type OneTimeUse struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:assertion OneTimeUse"` } type ProxyRestriction struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:assertion ProxyRestriction"` Count int `xml:"Count,attr"` Audience []Audience `xml:"Audience"` } type AttributeStatement struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:assertion AttributeStatement"` Attributes []Attribute `xml:"Attribute"` } type Attribute struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:assertion Attribute"` FriendlyName string `xml:"FriendlyName,attr"` Name string `xml:"Name,attr"` NameFormat string `xml:"NameFormat,attr"` Values []AttributeValue `xml:"AttributeValue"` } type AttributeValue struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:assertion AttributeValue"` Type string `xml:"xsi:type,attr"` Value string `xml:",chardata"` } type AuthnStatement struct { XMLName xml.Name `xml:"urn:oasis:names:tc:SAML:2.0:assertion AuthnStatement"` //Section 4.1.4.2 - https://docs.oasis-open.org/security/saml/v2.0/saml-profiles-2.0-os.pdf //If the identity provider supports the Single Logout profile, defined in Section 4.4 //, any such authentication statements MUST include a SessionIndex attribute to enable //per-session logout requests by the service provider. SessionIndex string `xml:"SessionIndex,attr,omitempty"` AuthnInstant *time.Time `xml:"AuthnInstant,attr,omitempty"` SessionNotOnOrAfter *time.Time `xml:"SessionNotOnOrAfter,attr,omitempty"` AuthnContext *AuthnContext `xml:"AuthnContext"` } ================================================ FILE: uuid/uuid.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package uuid // relevant bits from https://github.com/abneptis/GoUUID/blob/master/uuid.go import ( "crypto/rand" "fmt" ) type UUID [16]byte // NewV4 returns random generated UUID. func NewV4() *UUID { u := &UUID{} _, err := rand.Read(u[:16]) if err != nil { panic(err) } u[8] = (u[8] | 0x80) & 0xBf u[6] = (u[6] | 0x40) & 0x4f return u } func (u *UUID) String() string { return fmt.Sprintf("%x-%x-%x-%x-%x", u[:4], u[4:6], u[6:8], u[8:10], u[10:]) } ================================================ FILE: uuid/uuid_test.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package uuid import ( "testing" ) func TestUUID(t *testing.T) { s := NewV4() s2 := NewV4() if len(s) != 16 { t.Errorf("Expecting len of 16, got %d\n", len(s)) } if len(s.String()) != 36 { t.Errorf("Expecting uuid hex string len of 36, got %d\n", len(s.String())) } if s == s2 { t.Errorf("Expecting different UUIDs to be different, but they are the same.\n") } } ================================================ FILE: validate.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package saml2 import ( "fmt" "time" "github.com/russellhaering/gosaml2/types" ) //ErrParsing indicates that the value present in an assertion could not be //parsed. It can be inspected for the specific tag name, the contents, and the //intended type. type ErrParsing struct { Tag, Value, Type string } func (ep ErrParsing) Error() string { return fmt.Sprintf("Error parsing %s tag value as type %s", ep.Tag, ep.Value) } //Oft-used messages const ( ReasonUnsupported = "Unsupported" ReasonExpired = "Expired" ) //ErrInvalidValue indicates that the expected value did not match the received //value. type ErrInvalidValue struct { Key, Expected, Actual string Reason string } func (e ErrInvalidValue) Error() string { if e.Reason == "" { e.Reason = "Unrecognized" } return fmt.Sprintf("%s %s value, Expected: %s, Actual: %s", e.Reason, e.Key, e.Expected, e.Actual) } //Well-known methods of subject confirmation const ( SubjMethodBearer = "urn:oasis:names:tc:SAML:2.0:cm:bearer" ) //VerifyAssertionConditions inspects an assertion element and makes sure that //all SAML2 contracts are upheld. func (sp *SAMLServiceProvider) VerifyAssertionConditions(assertion *types.Assertion) (*WarningInfo, error) { warningInfo := &WarningInfo{} now := sp.Clock.Now() conditions := assertion.Conditions if conditions == nil { return nil, ErrMissingElement{Tag: ConditionsTag} } if conditions.NotBefore == "" { return nil, ErrMissingElement{Tag: ConditionsTag, Attribute: NotBeforeAttr} } notBefore, err := time.Parse(time.RFC3339, conditions.NotBefore) if err != nil { return nil, ErrParsing{Tag: NotBeforeAttr, Value: conditions.NotBefore, Type: "time.RFC3339"} } if now.Before(notBefore) { warningInfo.InvalidTime = true } if conditions.NotOnOrAfter == "" { return nil, ErrMissingElement{Tag: ConditionsTag, Attribute: NotOnOrAfterAttr} } notOnOrAfter, err := time.Parse(time.RFC3339, conditions.NotOnOrAfter) if err != nil { return nil, ErrParsing{Tag: NotOnOrAfterAttr, Value: conditions.NotOnOrAfter, Type: "time.RFC3339"} } if now.After(notOnOrAfter) { warningInfo.InvalidTime = true } for _, audienceRestriction := range conditions.AudienceRestrictions { matched := false for _, audience := range audienceRestriction.Audiences { if audience.Value == sp.AudienceURI { matched = true break } } if !matched { warningInfo.NotInAudience = true break } } if conditions.OneTimeUse != nil { warningInfo.OneTimeUse = true } proxyRestriction := conditions.ProxyRestriction if proxyRestriction != nil { proxyRestrictionInfo := &ProxyRestriction{ Count: proxyRestriction.Count, Audience: []string{}, } for _, audience := range proxyRestriction.Audience { proxyRestrictionInfo.Audience = append(proxyRestrictionInfo.Audience, audience.Value) } warningInfo.ProxyRestriction = proxyRestrictionInfo } return warningInfo, nil } //Validate ensures that the assertion passed is valid for the current Service //Provider. func (sp *SAMLServiceProvider) Validate(response *types.Response) error { err := sp.validateResponseAttributes(response) if err != nil { return err } if len(response.Assertions) == 0 { return ErrMissingAssertion } issuer := response.Issuer if issuer == nil { // FIXME?: SAML Core 2.0 Section 3.2.2 has Response.Issuer as [Optional] return ErrMissingElement{Tag: IssuerTag} } if sp.IdentityProviderIssuer != "" && response.Issuer.Value != sp.IdentityProviderIssuer { return ErrInvalidValue{ Key: IssuerTag, Expected: sp.IdentityProviderIssuer, Actual: response.Issuer.Value, } } status := response.Status if status == nil { return ErrMissingElement{Tag: StatusTag} } statusCode := status.StatusCode if statusCode == nil { return ErrMissingElement{Tag: StatusCodeTag} } if statusCode.Value != StatusCodeSuccess { return ErrInvalidValue{ Key: StatusCodeTag, Expected: StatusCodeSuccess, Actual: statusCode.Value, } } for _, assertion := range response.Assertions { issuer = assertion.Issuer if issuer == nil { return ErrMissingElement{Tag: IssuerTag} } if sp.IdentityProviderIssuer != "" && assertion.Issuer.Value != sp.IdentityProviderIssuer { return ErrInvalidValue{ Key: IssuerTag, Expected: sp.IdentityProviderIssuer, Actual: issuer.Value, } } subject := assertion.Subject if subject == nil { return ErrMissingElement{Tag: SubjectTag} } subjectConfirmation := subject.SubjectConfirmation if subjectConfirmation == nil { return ErrMissingElement{Tag: SubjectConfirmationTag} } if subjectConfirmation.Method != SubjMethodBearer { return ErrInvalidValue{ Reason: ReasonUnsupported, Key: SubjectConfirmationTag, Expected: SubjMethodBearer, Actual: subjectConfirmation.Method, } } subjectConfirmationData := subjectConfirmation.SubjectConfirmationData if subjectConfirmationData == nil { return ErrMissingElement{Tag: SubjectConfirmationDataTag} } if subjectConfirmationData.Recipient != sp.AssertionConsumerServiceURL { return ErrInvalidValue{ Key: RecipientAttr, Expected: sp.AssertionConsumerServiceURL, Actual: subjectConfirmationData.Recipient, } } if subjectConfirmationData.NotOnOrAfter == "" { return ErrMissingElement{Tag: SubjectConfirmationDataTag, Attribute: NotOnOrAfterAttr} } notOnOrAfter, err := time.Parse(time.RFC3339, subjectConfirmationData.NotOnOrAfter) if err != nil { return ErrParsing{Tag: NotOnOrAfterAttr, Value: subjectConfirmationData.NotOnOrAfter, Type: "time.RFC3339"} } now := sp.Clock.Now() if now.After(notOnOrAfter) { return ErrInvalidValue{ Reason: ReasonExpired, Key: NotOnOrAfterAttr, Expected: now.Format(time.RFC3339), Actual: subjectConfirmationData.NotOnOrAfter, } } } return nil } func (sp *SAMLServiceProvider) ValidateDecodedLogoutResponse(response *types.LogoutResponse) error { err := sp.validateLogoutResponseAttributes(response) if err != nil { return err } issuer := response.Issuer if issuer == nil { // FIXME?: SAML Core 2.0 Section 3.2.2 has Response.Issuer as [Optional] return ErrMissingElement{Tag: IssuerTag} } if sp.IdentityProviderIssuer != "" && response.Issuer.Value != sp.IdentityProviderIssuer { return ErrInvalidValue{ Key: IssuerTag, Expected: sp.IdentityProviderIssuer, Actual: response.Issuer.Value, } } status := response.Status if status == nil { return ErrMissingElement{Tag: StatusTag} } statusCode := status.StatusCode if statusCode == nil { return ErrMissingElement{Tag: StatusCodeTag} } if statusCode.Value != StatusCodeSuccess { return ErrInvalidValue{ Key: StatusCodeTag, Expected: StatusCodeSuccess, Actual: statusCode.Value, } } return nil } func (sp *SAMLServiceProvider) ValidateDecodedLogoutRequest(request *LogoutRequest) error { err := sp.validateLogoutRequestAttributes(request) if err != nil { return err } issuer := request.Issuer if issuer == nil { // FIXME?: SAML Core 2.0 Section 3.2.2 has Response.Issuer as [Optional] return ErrMissingElement{Tag: IssuerTag} } if sp.IdentityProviderIssuer != "" && request.Issuer.Value != sp.IdentityProviderIssuer { return ErrInvalidValue{ Key: IssuerTag, Expected: sp.IdentityProviderIssuer, Actual: request.Issuer.Value, } } return nil } ================================================ FILE: xml_constants.go ================================================ // Copyright 2016 Russell Haering et al. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package saml2 const ( ResponseTag = "Response" AssertionTag = "Assertion" EncryptedAssertionTag = "EncryptedAssertion" SubjectTag = "Subject" NameIdTag = "NameID" SubjectConfirmationTag = "SubjectConfirmation" SubjectConfirmationDataTag = "SubjectConfirmationData" AttributeStatementTag = "AttributeStatement" AttributeValueTag = "AttributeValue" ConditionsTag = "Conditions" AudienceRestrictionTag = "AudienceRestriction" AudienceTag = "Audience" OneTimeUseTag = "OneTimeUse" ProxyRestrictionTag = "ProxyRestriction" IssuerTag = "Issuer" StatusTag = "Status" StatusCodeTag = "StatusCode" ) const ( DestinationAttr = "Destination" VersionAttr = "Version" IdAttr = "ID" MethodAttr = "Method" RecipientAttr = "Recipient" NameAttr = "Name" NotBeforeAttr = "NotBefore" NotOnOrAfterAttr = "NotOnOrAfter" CountAttr = "Count" ) const ( NameIdFormatPersistent = "urn:oasis:names:tc:SAML:2.0:nameid-format:persistent" NameIdFormatTransient = "urn:oasis:names:tc:SAML:2.0:nameid-format:transient" NameIdFormatEmailAddress = "urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress" NameIdFormatUnspecified = "urn:oasis:names:tc:SAML:1.1:nameid-format:unspecified" NameIdFormatX509SubjectName = "urn:oasis:names:tc:SAML:1.1:nameid-format:x509SubjectName" AuthnContextPasswordProtectedTransport = "urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport" AuthnPolicyMatchExact = "exact" AuthnPolicyMatchMinimum = "minimum" AuthnPolicyMatchMaximum = "maximum" AuthnPolicyMatchBetter = "better" StatusCodeSuccess = "urn:oasis:names:tc:SAML:2.0:status:Success" StatusCodePartialLogout = "urn:oasis:names:tc:SAML:2.0:status:PartialLogout" StatusCodeUnknownPrincipal = "urn:oasis:names:tc:SAML:2.0:status:UnknownPrincipal" BindingHttpPost = "urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST" BindingHttpRedirect = "urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect" ) const ( SAMLAssertionNamespace = "urn:oasis:names:tc:SAML:2.0:assertion" SAMLProtocolNamespace = "urn:oasis:names:tc:SAML:2.0:protocol" )