/* * Copyright 2019 Okta * * 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. */ package com.okta.tools; import com.okta.tools.helpers.RoleHelper; import com.okta.tools.models.AccountOption; import com.okta.tools.models.RoleOption; import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Test; import java.util.List; import static java.util.Collections.singletonList; import static org.junit.jupiter.api.Assertions.assertEquals; class RoleHelperTest { private static final String EXAMPLE_SAML_RESPONSE = "<?xml version="1.0" encoding="UTF-8"?>
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" Destination="https://signin.aws.amazon.com/saml"
                 ID="id119878200645785761552820611" IssueInstant="2019-01-08T13:02:03.020Z" 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/exk55617pu0tHSyY41t7
    </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="#id119878200645785761552820611">
                <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>CkKrXIp5UGZStED+B28ExNRFY3kU9I3DieUNZOKGDp4=</ds:DigestValue>
            </ds:Reference>
        </ds:SignedInfo>
        <ds:SignatureValue>
            M1Jhd9Tq6HhDQGJSgscV17eNUKMzCoEsaxRg8NyxTrQAJavYjJ4ugh313fOLtcSoW6PlIVlnkUuNgKljjeUpGzXNVuIqODbFuLcZZHQorJUVI6D0twZ/ePDbcqiE5C0Zg83Ca+3e3pWNH30g1FNHufEatUOwNoQfjTv8QSF0W82ChsBeBXyIMkmaApcDrhA6MtAvsDHaAYjpQMteZtbux8uEdXICASCrrp5vRGNUqmT/ydXFQ6bEytDIWo/UAREe6Z1wG+6lzGPxvDexc9QXXCmtK2F/fPJRNf1OuNqUH8+Rd6yNLA6LtqCv5eAj/GP+HGgTWdDATfOzsyijfNDuLw==
        </ds:SignatureValue>
        <ds:KeyInfo>
            <ds:X509Data>
                <ds:X509Certificate>MIIDnjCCAoagAwIBAgIGAVlNHQpLMA0GCSqGSIb3DQEBBQUAMIGPMQswCQYDVQQGEwJVUzETMBEG
                    A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU
                    MBIGA1UECwwLU1NPUHJvdmlkZXIxEDAOBgNVBAMMB3ZlcmFmaW4xHDAaBgkqhkiG9w0BCQEWDWlu
                    Zm9Ab2t0YS5jb20wHhcNMTYxMjMwMDAyMzI1WhcNMjYxMjMwMDAyNDI1WjCBjzELMAkGA1UEBhMC
                    VVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNVBAoM
                    BE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRAwDgYDVQQDDAd2ZXJhZmluMRwwGgYJKoZIhvcN
                    AQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAkMfOWiDE
                    k+NnFzi+GD1mq0+gyLfEy0lwXHqHjAWmUD0fBKI5MKLjhS0gnEDXDvH4PCumfj16FgLt4PqYQTRc
                    y/aoCHOScu8RpCPKraqpXfCYOjx6HY4obfJ107y9v/EaRuQbPksV5Tz9Y4JckKECwP+LjxyjhIbU
                    /qU2wdVxruCvFW12vCTZjNhFGhxVmKvCaSInBsWDOiy2rZ4G/NEjHKaMEm240X5AoGmuZLPya6qT
                    fmt6oi0AvNkAiegta1uG8r2Ov8RrWyp4pZCI+jPKkMkeq+dkqeXjQNSPSCdpqxyJnh4kDn6a0xQO
                    slHmG6xlmB4sFojPVP1KKfHspqMeoQIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBlvRUhLYa/EuQ6
                    9mbdwyWToUzNrJqhoXn7sibbrGsc1OddJUcgBEA5UsqHzG2bFk9Rxy7zxZIlouFC/G0rK8VwczSC
                    4DcUVwmTZ+FH6v8L3RiKfRECS3NFCjDG8e71clxEcOhZt2m478WavCWaf4WqDfq+9AwrPi9JmPuw
                    oF6A9kjwcPnXs5ei4P/BAgFQQO8F1KJU5I9Ie0J6v/NHs/tBA1IsvO1O40GnlsJkxcT/lhQfuXsC
                    XTK0uJkYbC2FK8uC3YVPF6jj8qm9CueooIF2lMnzzF7D+KbQ3S/Gat2m1ide6z0Mr+8Mp/N3ty2G
                    vRVSoOhRtuEo9e1tgUrg7EzX
                </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="id119878200646583351568829796"
                     IssueInstant="2019-01-08T13:02:03.020Z" 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/exk55617pu0tHSyY41t7
        </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="#id119878200646583351568829796">
                    <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>scVIM5PpRz/HSGDqNws+O+mvUafolJXRcYPEBb9HOEw=</ds:DigestValue>
                </ds:Reference>
            </ds:SignedInfo>
            <ds:SignatureValue>
                GmyozDHqHqJj3oM4aEfvYXoXQG/gN1MnJLS8y0CRq70BfOClJ5zi8kG/ynsV/vDL9DxhQP3iI5ZZLoL4aYUr7FstungpWd941BZooy9P2CNOax6R+6RmkiovaRNimlg0693yl32ZjW+HdRcFCBcm7+iEbFSLFbPLsugub9TGb8IMbqR+WwEPUnnlt+mXPg7Co0kdNj2b+8sUTgb4WmyGDarquz8ydLfZ94AAHur0b+RGrUzz8mxiARjkXZTNbG63/yqh0Fj+IF1xMi6exlnrxPgGa4cmQ2nyN+I447FxfSwF2aRMn/QKqJpLZCPA3SWdpqvL8V1n5rrf7uDQMGKgZg==
            </ds:SignatureValue>
            <ds:KeyInfo>
                <ds:X509Data>
                    <ds:X509Certificate>MIIDnjCCAoagAwIBAgIGAVlNHQpLMA0GCSqGSIb3DQEBBQUAMIGPMQswCQYDVQQGEwJVUzETMBEG
                        A1UECAwKQ2FsaWZvcm5pYTEWMBQGA1UEBwwNU2FuIEZyYW5jaXNjbzENMAsGA1UECgwET2t0YTEU
                        MBIGA1UECwwLU1NPUHJvdmlkZXIxEDAOBgNVBAMMB3ZlcmFmaW4xHDAaBgkqhkiG9w0BCQEWDWlu
                        Zm9Ab2t0YS5jb20wHhcNMTYxMjMwMDAyMzI1WhcNMjYxMjMwMDAyNDI1WjCBjzELMAkGA1UEBhMC
                        VVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFjAUBgNVBAcMDVNhbiBGcmFuY2lzY28xDTALBgNVBAoM
                        BE9rdGExFDASBgNVBAsMC1NTT1Byb3ZpZGVyMRAwDgYDVQQDDAd2ZXJhZmluMRwwGgYJKoZIhvcN
                        AQkBFg1pbmZvQG9rdGEuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAkMfOWiDE
                        k+NnFzi+GD1mq0+gyLfEy0lwXHqHjAWmUD0fBKI5MKLjhS0gnEDXDvH4PCumfj16FgLt4PqYQTRc
                        y/aoCHOScu8RpCPKraqpXfCYOjx6HY4obfJ107y9v/EaRuQbPksV5Tz9Y4JckKECwP+LjxyjhIbU
                        /qU2wdVxruCvFW12vCTZjNhFGhxVmKvCaSInBsWDOiy2rZ4G/NEjHKaMEm240X5AoGmuZLPya6qT
                        fmt6oi0AvNkAiegta1uG8r2Ov8RrWyp4pZCI+jPKkMkeq+dkqeXjQNSPSCdpqxyJnh4kDn6a0xQO
                        slHmG6xlmB4sFojPVP1KKfHspqMeoQIDAQABMA0GCSqGSIb3DQEBBQUAA4IBAQBlvRUhLYa/EuQ6
                        9mbdwyWToUzNrJqhoXn7sibbrGsc1OddJUcgBEA5UsqHzG2bFk9Rxy7zxZIlouFC/G0rK8VwczSC
                        4DcUVwmTZ+FH6v8L3RiKfRECS3NFCjDG8e71clxEcOhZt2m478WavCWaf4WqDfq+9AwrPi9JmPuw
                        oF6A9kjwcPnXs5ei4P/BAgFQQO8F1KJU5I9Ie0J6v/NHs/tBA1IsvO1O40GnlsJkxcT/lhQfuXsC
                        XTK0uJkYbC2FK8uC3YVPF6jj8qm9CueooIF2lMnzzF7D+KbQ3S/Gat2m1ide6z0Mr+8Mp/N3ty2G
                        vRVSoOhRtuEo9e1tgUrg7EzX
                    </ds:X509Certificate>
                </ds:X509Data>
            </ds:KeyInfo>
        </ds:Signature>
        <saml2:Subject xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:NameID Format="urn:oasis:names:tc:SAML:2.0:nameid-format:unspecified">fakename@acme.example.com
            </saml2:NameID>
            <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
                <saml2:SubjectConfirmationData NotOnOrAfter="2019-01-08T13:07:03.020Z"
                                               Recipient="https://signin.aws.amazon.com/saml"/>
            </saml2:SubjectConfirmation>
        </saml2:Subject>
        <saml2:Conditions NotBefore="2019-01-08T12:57:03.020Z" NotOnOrAfter="2019-01-08T13:07:03.020Z"
                          xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
            <saml2:AudienceRestriction>
                <saml2:Audience>urn:amazon:webservices</saml2:Audience>
            </saml2:AudienceRestriction>
        </saml2:Conditions>
        <saml2:AuthnStatement AuthnInstant="2019-01-08T13:02:03.020Z" SessionIndex="id1546952523020.1098288647"
                              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="https://aws.amazon.com/SAML/Attributes/Role"
                             NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:uri">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema"
                                      xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">
                    arn:aws:iam::660502754662:saml-provider/acme.okta.com,arn:aws:iam::123456789012:role/EC2Admins
                </saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="https://aws.amazon.com/SAML/Attributes/RoleSessionName"
                             NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema"
                                      xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">
                    fakename@acme.example.com
                </saml2:AttributeValue>
            </saml2:Attribute>
            <saml2:Attribute Name="https://aws.amazon.com/SAML/Attributes/SessionDuration"
                             NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic">
                <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema"
                                      xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">14400
                </saml2:AttributeValue>
            </saml2:Attribute>
        </saml2:AttributeStatement>
    </saml2:Assertion>
</saml2p:Response>"; @Test void main() throws Exception { OktaAwsCliEnvironment environment = new OktaAwsCliEnvironment(false, null, null, null, null, null, "https://acmecorp.oktapreview.com/home/amazon_aws/0oa5zrwfs815KJmVF0h7/137", null, 0, null, null, false, null); RoleHelper roleHelper = new RoleHelper(environment); List availableRoles = roleHelper.getAvailableRoles(EXAMPLE_SAML_RESPONSE); assertEquals(singletonList( new AccountOption("Account: (123456789012)", singletonList( new RoleOption("EC2Admins", "arn:aws:iam::123456789012:role/EC2Admins") )) ), availableRoles); } }