{-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE DuplicateRecordFields #-} {-# LANGUAGE NamedFieldPuns #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE StrictData #-} {-# LANGUAGE TypeFamilies #-} {-# LANGUAGE NoImplicitPrelude #-} {-# OPTIONS_GHC -fno-warn-unused-binds #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} {-# OPTIONS_GHC -fno-warn-unused-matches #-} -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | -- Module : Amazonka.CognitoIdentity.GetIdentityPoolRoles -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Gets the roles for an identity pool. -- -- You must use AWS Developer credentials to call this API. module Amazonka.CognitoIdentity.GetIdentityPoolRoles ( -- * Creating a Request GetIdentityPoolRoles (..), newGetIdentityPoolRoles, -- * Request Lenses getIdentityPoolRoles_identityPoolId, -- * Destructuring the Response GetIdentityPoolRolesResponse (..), newGetIdentityPoolRolesResponse, -- * Response Lenses getIdentityPoolRolesResponse_identityPoolId, getIdentityPoolRolesResponse_roleMappings, getIdentityPoolRolesResponse_roles, getIdentityPoolRolesResponse_httpStatus, ) where import Amazonka.CognitoIdentity.Types import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | Input to the @GetIdentityPoolRoles@ action. -- -- /See:/ 'newGetIdentityPoolRoles' smart constructor. data GetIdentityPoolRoles = GetIdentityPoolRoles' { -- | An identity pool ID in the format REGION:GUID. identityPoolId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'GetIdentityPoolRoles' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'identityPoolId', 'getIdentityPoolRoles_identityPoolId' - An identity pool ID in the format REGION:GUID. newGetIdentityPoolRoles :: -- | 'identityPoolId' Prelude.Text -> GetIdentityPoolRoles newGetIdentityPoolRoles pIdentityPoolId_ = GetIdentityPoolRoles' { identityPoolId = pIdentityPoolId_ } -- | An identity pool ID in the format REGION:GUID. getIdentityPoolRoles_identityPoolId :: Lens.Lens' GetIdentityPoolRoles Prelude.Text getIdentityPoolRoles_identityPoolId = Lens.lens (\GetIdentityPoolRoles' {identityPoolId} -> identityPoolId) (\s@GetIdentityPoolRoles' {} a -> s {identityPoolId = a} :: GetIdentityPoolRoles) instance Core.AWSRequest GetIdentityPoolRoles where type AWSResponse GetIdentityPoolRoles = GetIdentityPoolRolesResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> GetIdentityPoolRolesResponse' Prelude.<$> (x Data..?> "IdentityPoolId") Prelude.<*> (x Data..?> "RoleMappings" Core..!@ Prelude.mempty) Prelude.<*> (x Data..?> "Roles" Core..!@ Prelude.mempty) Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable GetIdentityPoolRoles where hashWithSalt _salt GetIdentityPoolRoles' {..} = _salt `Prelude.hashWithSalt` identityPoolId instance Prelude.NFData GetIdentityPoolRoles where rnf GetIdentityPoolRoles' {..} = Prelude.rnf identityPoolId instance Data.ToHeaders GetIdentityPoolRoles where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AWSCognitoIdentityService.GetIdentityPoolRoles" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON GetIdentityPoolRoles where toJSON GetIdentityPoolRoles' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("IdentityPoolId" Data..= identityPoolId) ] ) instance Data.ToPath GetIdentityPoolRoles where toPath = Prelude.const "/" instance Data.ToQuery GetIdentityPoolRoles where toQuery = Prelude.const Prelude.mempty -- | Returned in response to a successful @GetIdentityPoolRoles@ operation. -- -- /See:/ 'newGetIdentityPoolRolesResponse' smart constructor. data GetIdentityPoolRolesResponse = GetIdentityPoolRolesResponse' { -- | An identity pool ID in the format REGION:GUID. identityPoolId :: Prelude.Maybe Prelude.Text, -- | How users for a specific identity provider are to mapped to roles. This -- is a String-to-RoleMapping object map. The string identifies the -- identity provider, for example, \"graph.facebook.com\" or -- \"cognito-idp.us-east-1.amazonaws.com\/us-east-1_abcdefghi:app_client_id\". roleMappings :: Prelude.Maybe (Prelude.HashMap Prelude.Text RoleMapping), -- | The map of roles associated with this pool. Currently only authenticated -- and unauthenticated roles are supported. roles :: Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text), -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'GetIdentityPoolRolesResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'identityPoolId', 'getIdentityPoolRolesResponse_identityPoolId' - An identity pool ID in the format REGION:GUID. -- -- 'roleMappings', 'getIdentityPoolRolesResponse_roleMappings' - How users for a specific identity provider are to mapped to roles. This -- is a String-to-RoleMapping object map. The string identifies the -- identity provider, for example, \"graph.facebook.com\" or -- \"cognito-idp.us-east-1.amazonaws.com\/us-east-1_abcdefghi:app_client_id\". -- -- 'roles', 'getIdentityPoolRolesResponse_roles' - The map of roles associated with this pool. Currently only authenticated -- and unauthenticated roles are supported. -- -- 'httpStatus', 'getIdentityPoolRolesResponse_httpStatus' - The response's http status code. newGetIdentityPoolRolesResponse :: -- | 'httpStatus' Prelude.Int -> GetIdentityPoolRolesResponse newGetIdentityPoolRolesResponse pHttpStatus_ = GetIdentityPoolRolesResponse' { identityPoolId = Prelude.Nothing, roleMappings = Prelude.Nothing, roles = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | An identity pool ID in the format REGION:GUID. getIdentityPoolRolesResponse_identityPoolId :: Lens.Lens' GetIdentityPoolRolesResponse (Prelude.Maybe Prelude.Text) getIdentityPoolRolesResponse_identityPoolId = Lens.lens (\GetIdentityPoolRolesResponse' {identityPoolId} -> identityPoolId) (\s@GetIdentityPoolRolesResponse' {} a -> s {identityPoolId = a} :: GetIdentityPoolRolesResponse) -- | How users for a specific identity provider are to mapped to roles. This -- is a String-to-RoleMapping object map. The string identifies the -- identity provider, for example, \"graph.facebook.com\" or -- \"cognito-idp.us-east-1.amazonaws.com\/us-east-1_abcdefghi:app_client_id\". getIdentityPoolRolesResponse_roleMappings :: Lens.Lens' GetIdentityPoolRolesResponse (Prelude.Maybe (Prelude.HashMap Prelude.Text RoleMapping)) getIdentityPoolRolesResponse_roleMappings = Lens.lens (\GetIdentityPoolRolesResponse' {roleMappings} -> roleMappings) (\s@GetIdentityPoolRolesResponse' {} a -> s {roleMappings = a} :: GetIdentityPoolRolesResponse) Prelude.. Lens.mapping Lens.coerced -- | The map of roles associated with this pool. Currently only authenticated -- and unauthenticated roles are supported. getIdentityPoolRolesResponse_roles :: Lens.Lens' GetIdentityPoolRolesResponse (Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text)) getIdentityPoolRolesResponse_roles = Lens.lens (\GetIdentityPoolRolesResponse' {roles} -> roles) (\s@GetIdentityPoolRolesResponse' {} a -> s {roles = a} :: GetIdentityPoolRolesResponse) Prelude.. Lens.mapping Lens.coerced -- | The response's http status code. getIdentityPoolRolesResponse_httpStatus :: Lens.Lens' GetIdentityPoolRolesResponse Prelude.Int getIdentityPoolRolesResponse_httpStatus = Lens.lens (\GetIdentityPoolRolesResponse' {httpStatus} -> httpStatus) (\s@GetIdentityPoolRolesResponse' {} a -> s {httpStatus = a} :: GetIdentityPoolRolesResponse) instance Prelude.NFData GetIdentityPoolRolesResponse where rnf GetIdentityPoolRolesResponse' {..} = Prelude.rnf identityPoolId `Prelude.seq` Prelude.rnf roleMappings `Prelude.seq` Prelude.rnf roles `Prelude.seq` Prelude.rnf httpStatus