0

我正在尝试为 Jupyterhub 和 Keycloak 实现 SAML 身份验证。我将 Jupyterhub 配置为使用 SAMLAuthenticator,它工作正常。用户使用 SAMLRequest 重定向到 Keycloak 登录屏幕,进行登录,然后使用 SAMLResponse 重定向回来。

我使用 Keycloak SAML 元数据添加了一个 IAM 身份提供者,还创建了一个信任该身份提供者的角色。

当我使用此工具对其进行测试时,SAMLResponse 看起来还不错。

当我尝试打电话时,assume_role_with_saml我不断收到此错误:

An error occurred (InvalidIdentityToken) when calling the AssumeRoleWithSAML operation: Invalid base64 SAMLResponse (Service: AWSOpenIdDiscoveryService; Status Code: 400; Error Code: AuthSamlInvalidSamlResponseException

SAML 请求:

<samlp:AuthnRequest
        xmlns:samlp="urn:oasis:names:tc:SAML:2.0:protocol"
        xmlns:saml="urn:oasis:names:tc:SAML:2.0:assertion"
        ID="b16f49bca24e490986d6616459bc102d"
        Version="2.0"
        IssueInstant="2021-05-27T05:42:25.000000Z"
        Destination="https://keyaloak-docker-ohio.worker.io/auth/realms/master/protocol/saml"
        ProtocolBinding="urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST"
        AssertionConsumerServiceURL="https://elasticsearch-ohio-proxy.worker.io/hub/oauth_callback"
>
    <saml:Issuer>urn:amazon:webservices</saml:Issuer>
</samlp:AuthnRequest>

SAML 响应:

<samlp:Response xmlns:samlp="urn:oasis:names:tc:SAML:2.0:protocol" xmlns:saml="urn:oasis:names:tc:SAML:2.0:assertion" Destination="https://elasticsearch-ohio-proxy.worker.io/hub/oauth_callback" ID="ID_c7304951-70a5-4848-b858-38a0b0f2914b" InResponseTo="b16f49bca24e490986d6616459bc102d" IssueInstant="2021-05-25T05:58:02.802Z" Version="2.0"><saml:Issuer>https://keyaloak-docker-ohio.worker.io/auth/realms/master</saml:Issuer><dsig:Signature xmlns:dsig="http://www.w3.org/2000/09/xmldsig#"><dsig:SignedInfo><dsig:CanonicalizationMethod Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/><dsig:SignatureMethod Algorithm="http://www.w3.org/2001/04/xmldsig-more#rsa-sha256"/><dsig:Reference URI="#ID_c7304951-70a5-4848-b858-38a0b0f2914b"><dsig:Transforms><dsig:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><dsig:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></dsig:Transforms><dsig:DigestMethod Algorithm="http://www.w3.org/2001/04/xmlenc#sha256"/><dsig:DigestValue>zmJYamb7EemZc/jNTXm3gpK51lKG2nUDfrYnR5DYt38=</dsig:DigestValue></dsig:Reference></dsig:SignedInfo><dsig:SignatureValue>A9qqFpwmJPc3Q5Z17wJvm9n109XrgYBtbWEUU7hH+s45xGAs/TSe/t0ZpAo+fbmUSO3MO+WEy2W1GTIGp8p0y3b5w/clV3j02j2pO/tkLY0CZkUB015u6Mz0Aa7JvtbxIeZhJSSVzLXsIrCCRSAJH7GqowLFTR7ySp2Qw8zDj1VGR0/yvtLI0w7iIo9yrugFye+BXlJwICxopKIELmz/zp73H7YZORMW8G9OqdaGQe4Fnt6vWn6DptE6yuHwwxDFQLWhYPMZ4cecC01en/Tm/OfeBXHC4kxOblVTZffvzG9j/WIL78KFHDbt07wyR+mTojnUCMYe+DW2ktW2bTn2Ig==</dsig:SignatureValue><dsig:KeyInfo><dsig:KeyName>OpDIuce9HVmp0yPnMeBwT9HPgzYYpIxwyTwlfdmVaYc</dsig:KeyName><dsig:X509Data><dsig:X509Certificate>MIICmzCCAYMCBgF1btuIQjANBgkqhkiG9w0BAQsFADARMQ8wDQYDVQQDDAZtYXN0ZXIwHhcNMjAxMDI4MTA1NjIyWhcNMzAxMDI4MTA1ODAyWjARMQ8wDQYDVQQDDAZtYXN0ZXIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDbTZR6qZi7UqVuAa4PoNC+nD9Mi677ApBf0NWaNhFhyUSGA1xq1TAx9brwcD+9YLcgW9RstqSTf0VM3NMr3RihVB6WB9ab8drzCTpVOKvOVRiVw3xG0VqV12o4fJcYhBSqpzHvGS/mGeatZ9tNctRaBMym9IxWVe1xFkYZ5m/Grhq0InWlKG5+v9gNm4JTJ4pNI651umUKY2U4Aba0RitZNWpht4y8gxLIaU65W9UScE0Cw+Ue9ojNeLtq7m5YvUm37L68M3xWqZJRsY9pYaTRxg2s7J7mwouOWDDbT5CbF9iw0j+RkH2/EJE0Vb5eUk/5SKzQC8kydsIuofEsDbQdAgMBAAEwDQYJKoZIhvcNAQELBQADggEBAAvVLlMkFjJXB57Q1KFxA+BZLFY+kHc1ZTnMPueIIjhR4t/xF1x9k3lBpklWV0ibvP/tmzC/+ZWzQy9zv9t0o7tTFqYEq5J1Cor6JTLi4HTkHs0cFDcwcmQWSdlcHB3S6LEQy+McG1S0siViJgx38mlmlxZiYxE/ZdjZkf0wAGA/ZGn85Lqq5g0ndvcqpGyDF8ZqeR+DG6+tJ0KsZQdrKzy2NUNUSFKy/dP+YbQcLtxGT6qLMsLWQJYZzLql4mHHYmgVeqVcA2NGuBdVYUhyblCQBK4msfgH/VkPRlfVsJUsd1OTCAnUearOl607e3RRByVqKDdlJLrFRRXo47Gfl8o=</dsig:X509Certificate></dsig:X509Data><dsig:KeyValue><dsig:RSAKeyValue><dsig:Modulus>202UeqmYu1KlbgGuD6DQvpw/TIuu+wKQX9DVmjYRYclEhgNcatUwMfW68HA/vWC3IFvUbLakk39FTNzTK90YoVQelgfWm/Ha8wk6VTirzlUYlcN8RtFalddqOHyXGIQUqqcx7xkv5hnmrWfbTXLUWgTMpvSMVlXtcRZGGeZvxq4atCJ1pShufr/YDZuCUyeKTSOudbplCmNlOAG2tEYrWTVqYbeMvIMSyGlOuVvVEnBNAsPlHvaIzXi7au5uWL1Jt+y+vDN8VqmSUbGPaWGk0cYNrOye5sKLjlgw20+QmxfYsNI/kZB9vxCRNFW+XlJP+Uis0AvJMnbCLqHxLA20HQ==</dsig:Modulus><dsig:Exponent>AQAB</dsig:Exponent></dsig:RSAKeyValue></dsig:KeyValue></dsig:KeyInfo></dsig:Signature><samlp:Status><samlp:StatusCode Value="urn:oasis:names:tc:SAML:2.0:status:Success"/></samlp:Status><saml:Assertion xmlns="urn:oasis:names:tc:SAML:2.0:assertion" ID="ID_d908f8e2-676d-40c7-b13b-921015c0284b" IssueInstant="2021-05-25T05:58:02.801Z" Version="2.0"><saml:Issuer>https://keyaloak-docker-ohio.worker.io/auth/realms/master</saml:Issuer><dsig:Signature xmlns:dsig="http://www.w3.org/2000/09/xmldsig#"><dsig:SignedInfo><dsig:CanonicalizationMethod Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/><dsig:SignatureMethod Algorithm="http://www.w3.org/2001/04/xmldsig-more#rsa-sha256"/><dsig:Reference URI="#ID_d908f8e2-676d-40c7-b13b-921015c0284b"><dsig:Transforms><dsig:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><dsig:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></dsig:Transforms><dsig:DigestMethod Algorithm="http://www.w3.org/2001/04/xmlenc#sha256"/><dsig:DigestValue>iIkBzADUiaP0Hg+u+lD0ubCNJLnaw3J8cNyzkKZR3QQ=</dsig:DigestValue></dsig:Reference></dsig:SignedInfo><dsig:SignatureValue>wB2WRMJEGdn45cjic6zR6pr2Fo9sZOJkFJ2kFYt3mUPHIj25tf05Mt+l8eHrmt0H+Z2TOHTT2ehGH9Jk/dn7BNiLL5k3PYTKPPYB9p8MugCEuiRD8gnwHYRz7unaANo+j8jxW9B1RzkFwClxVHklCgMhIfIPkU2qc2sgl4deQg3DQegcW73GlKZ8wpdB7SvmBO+JAEeuz9ElMjibag+YBSpt5aIkDeUbkzKnaTUkBCbPm07lI/WY3B8EFRq4roR8wkjxz04FW3Wp6y2JlqbIIJ1GsFQhZ3n+IC9kYPuUpW05WHKopKyxR1AAQP0InvAOj7pPnN9MsWb4MqwXk0Qscw==</dsig:SignatureValue><dsig:KeyInfo><dsig:KeyName>OpDIuce9HVmp0yPnMeBwT9HPgzYYpIxwyTwlfdmVaYc</dsig:KeyName><dsig:X509Data><dsig:X509Certificate>MIICmzCCAYMCBgF1btuIQjANBgkqhkiG9w0BAQsFADARMQ8wDQYDVQQDDAZtYXN0ZXIwHhcNMjAxMDI4MTA1NjIyWhcNMzAxMDI4MTA1ODAyWjARMQ8wDQYDVQQDDAZtYXN0ZXIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDbTZR6qZi7UqVuAa4PoNC+nD9Mi677ApBf0NWaNhFhyUSGA1xq1TAx9brwcD+9YLcgW9RstqSTf0VM3NMr3RihVB6WB9ab8drzCTpVOKvOVRiVw3xG0VqV12o4fJcYhBSqpzHvGS/mGeatZ9tNctRaBMym9IxWVe1xFkYZ5m/Grhq0InWlKG5+v9gNm4JTJ4pNI651umUKY2U4Aba0RitZNWpht4y8gxLIaU65W9UScE0Cw+Ue9ojNeLtq7m5YvUm37L68M3xWqZJRsY9pYaTRxg2s7J7mwouOWDDbT5CbF9iw0j+RkH2/EJE0Vb5eUk/5SKzQC8kydsIuofEsDbQdAgMBAAEwDQYJKoZIhvcNAQELBQADggEBAAvVLlMkFjJXB57Q1KFxA+BZLFY+kHc1ZTnMPueIIjhR4t/xF1x9k3lBpklWV0ibvP/tmzC/+ZWzQy9zv9t0o7tTFqYEq5J1Cor6JTLi4HTkHs0cFDcwcmQWSdlcHB3S6LEQy+McG1S0siViJgx38mlmlxZiYxE/ZdjZkf0wAGA/ZGn85Lqq5g0ndvcqpGyDF8ZqeR+DG6+tJ0KsZQdrKzy2NUNUSFKy/dP+YbQcLtxGT6qLMsLWQJYZzLql4mHHYmgVeqVcA2NGuBdVYUhyblCQBK4msfgH/VkPRlfVsJUsd1OTCAnUearOl607e3RRByVqKDdlJLrFRRXo47Gfl8o=</dsig:X509Certificate></dsig:X509Data><dsig:KeyValue><dsig:RSAKeyValue><dsig:Modulus>202UeqmYu1KlbgGuD6DQvpw/TIuu+wKQX9DVmjYRYclEhgNcatUwMfW68HA/vWC3IFvUbLakk39FTNzTK90YoVQelgfWm/Ha8wk6VTirzlUYlcN8RtFalddqOHyXGIQUqqcx7xkv5hnmrWfbTXLUWgTMpvSMVlXtcRZGGeZvxq4atCJ1pShufr/YDZuCUyeKTSOudbplCmNlOAG2tEYrWTVqYbeMvIMSyGlOuVvVEnBNAsPlHvaIzXi7au5uWL1Jt+y+vDN8VqmSUbGPaWGk0cYNrOye5sKLjlgw20+QmxfYsNI/kZB9vxCRNFW+XlJP+Uis0AvJMnbCLqHxLA20HQ==</dsig:Modulus><dsig:Exponent>AQAB</dsig:Exponent></dsig:RSAKeyValue></dsig:KeyValue></dsig:KeyInfo></dsig:Signature><saml:Subject><saml:NameID Format="urn:oasis:names:tc:SAML:1.1:nameid-format:unspecified">vw</saml:NameID><saml:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer"><saml:SubjectConfirmationData InResponseTo="b16f49bca24e490986d6616459bc102d" NotOnOrAfter="2021-05-25T06:58:00.801Z" Recipient="https://elasticsearch-ohio-proxy.worker.io/hub/oauth_callback"/></saml:SubjectConfirmation></saml:Subject><saml:Conditions NotBefore="2021-05-25T05:58:00.801Z" NotOnOrAfter="2021-05-25T05:59:00.801Z"><saml:AudienceRestriction><saml:Audience>https://keyaloak-docker-ohio.worker.io/auth/realms/master</saml:Audience></saml:AudienceRestriction></saml:Conditions><saml:AuthnStatement AuthnInstant="2021-05-25T05:58:02.802Z" SessionIndex="90bf9c1f-71c3-45ef-bfb0-53a14ad59dc5::f30ccd03-b5e6-482e-afcb-c26fbef93c00" SessionNotOnOrAfter="2021-05-25T15:58:02.802Z"><saml:AuthnContext><saml:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:unspecified</saml:AuthnContextClassRef></saml:AuthnContext></saml:AuthnStatement><saml:AttributeStatement><saml:Attribute FriendlyName="Role Session Name" Name="https://aws.amazon.com/SAML/Attributes/RoleSessionName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic"><saml:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">vw</saml:AttributeValue></saml:Attribute><saml:Attribute FriendlyName="Session Duration" Name="https://aws.amazon.com/SAML/Attributes/SessionDuration" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic"><saml:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">28800</saml:AttributeValue></saml:Attribute><saml:Attribute FriendlyName="Role List" Name="https://aws.amazon.com/SAML/Attributes/Role" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic"><saml:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">VW_JUPYTERHUB</saml:AttributeValue><saml:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">VW_JUPYTERHUB_MASTER</saml:AttributeValue></saml:Attribute></saml:AttributeStatement></saml:Assertion></samlp:Response>

相信:

{
  "Effect": "Allow",
  "Principal": {
    "Federated": "arn:aws:iam::1234567890:saml-provider/keyaloak-docker-ohio.worker.io"
  },
  "Action": "sts:AssumeRoleWithSAML",
  "Condition": {
    "StringEquals": {
      "SAML:iss": "https://keyaloak-docker-ohio.worker.io/auth/realms/master"
    }
  }
}

元数据:

<md:EntitiesDescriptor xmlns="urn:oasis:names:tc:SAML:2.0:metadata" xmlns:md="urn:oasis:names:tc:SAML:2.0:metadata"
                       xmlns:saml="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:ds="http://www.w3.org/2000/09/xmldsig#"
                       Name="urn:keycloak">
    <md:EntityDescriptor xmlns="urn:oasis:names:tc:SAML:2.0:metadata" xmlns:md="urn:oasis:names:tc:SAML:2.0:metadata"
                         xmlns:saml="urn:oasis:names:tc:SAML:2.0:assertion"
                         xmlns:ds="http://www.w3.org/2000/09/xmldsig#"
                         entityID="https://keyaloak-docker-ohio.worker.io/auth/realms/master">
        <md:IDPSSODescriptor WantAuthnRequestsSigned="true"
                             protocolSupportEnumeration="urn:oasis:names:tc:SAML:2.0:protocol">
            <md:KeyDescriptor use="signing">
                <ds:KeyInfo>
                    <ds:KeyName>OpDIuce9HVmp0yPnMeBwT9HPgzYYpIxwyTwlfdmVaYc</ds:KeyName>
                    <ds:X509Data>
                        <ds:X509Certificate>
                            MIICmzCCAYMCBgF1btuIQjANBgkqhkiG9w0BAQsFADARMQ8wDQYDVQQDDAZtYXN0ZXIwHhcNMjAxMDI4MTA1NjIyWhcNMzAxMDI4MTA1ODAyWjARMQ8wDQYDVQQDDAZtYXN0ZXIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDbTZR6qZi7UqVuAa4PoNC+nD9Mi677ApBf0NWaNhFhyUSGA1xq1TAx9brwcD+9YLcgW9RstqSTf0VM3NMr3RihVB6WB9ab8drzCTpVOKvOVRiVw3xG0VqV12o4fJcYhBSqpzHvGS/mGeatZ9tNctRaBMym9IxWVe1xFkYZ5m/Grhq0InWlKG5+v9gNm4JTJ4pNI651umUKY2U4Aba0RitZNWpht4y8gxLIaU65W9UScE0Cw+Ue9ojNeLtq7m5YvUm37L68M3xWqZJRsY9pYaTRxg2s7J7mwouOWDDbT5CbF9iw0j+RkH2/EJE0Vb5eUk/5SKzQC8kydsIuofEsDbQdAgMBAAEwDQYJKoZIhvcNAQELBQADggEBAAvVLlMkFjJXB57Q1KFxA+BZLFY+kHc1ZTnMPueIIjhR4t/xF1x9k3lBpklWV0ibvP/tmzC/+ZWzQy9zv9t0o7tTFqYEq5J1Cor6JTLi4HTkHs0cFDcwcmQWSdlcHB3S6LEQy+McG1S0siViJgx38mlmlxZiYxE/ZdjZkf0wAGA/ZGn85Lqq5g0ndvcqpGyDF8ZqeR+DG6+tJ0KsZQdrKzy2NUNUSFKy/dP+YbQcLtxGT6qLMsLWQJYZzLql4mHHYmgVeqVcA2NGuBdVYUhyblCQBK4msfgH/VkPRlfVsJUsd1OTCAnUearOl607e3RRByVqKDdlJLrFRRXo47Gfl8o=
                        </ds:X509Certificate>
                    </ds:X509Data>
                </ds:KeyInfo>
            </md:KeyDescriptor>
            <md:SingleLogoutService Binding="urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST"
                                    Location="https://keyaloak-docker-ohio.worker.io/auth/realms/master/protocol/saml"/>
            <md:SingleLogoutService Binding="urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect"
                                    Location="https://keyaloak-docker-ohio.worker.io/auth/realms/master/protocol/saml"/>
            <md:NameIDFormat>urn:oasis:names:tc:SAML:2.0:nameid-format:persistent</md:NameIDFormat>
            <md:NameIDFormat>urn:oasis:names:tc:SAML:2.0:nameid-format:transient</md:NameIDFormat>
            <md:NameIDFormat>urn:oasis:names:tc:SAML:1.1:nameid-format:unspecified</md:NameIDFormat>
            <md:NameIDFormat>urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress</md:NameIDFormat>
            <md:SingleSignOnService Binding="urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST"
                                    Location="https://keyaloak-docker-ohio.worker.io/auth/realms/master/protocol/saml"/>
            <md:SingleSignOnService Binding="urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect"
                                    Location="https://keyaloak-docker-ohio.worker.io/auth/realms/master/protocol/saml"/>
            <md:SingleSignOnService Binding="urn:oasis:names:tc:SAML:2.0:bindings:SOAP"
                                    Location="https://keyaloak-docker-ohio.worker.io/auth/realms/master/protocol/saml"/>
        </md:IDPSSODescriptor>
    </md:EntityDescriptor>
</md:EntitiesDescriptor>
4

0 回答 0