{-# 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.IAM.GetRole -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Retrieves information about the specified role, including the role\'s -- path, GUID, ARN, and the role\'s trust policy that grants permission to -- assume the role. For more information about roles, see -- . -- -- Policies returned by this operation are URL-encoded compliant with -- . You can use a URL -- decoding method to convert the policy back to plain JSON text. For -- example, if you use Java, you can use the @decode@ method of the -- @java.net.URLDecoder@ utility class in the Java SDK. Other languages and -- SDKs provide similar functionality. module Amazonka.IAM.GetRole ( -- * Creating a Request GetRole (..), newGetRole, -- * Request Lenses getRole_roleName, -- * Destructuring the Response GetRoleResponse (..), newGetRoleResponse, -- * Response Lenses getRoleResponse_httpStatus, getRoleResponse_role, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.IAM.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newGetRole' smart constructor. data GetRole = GetRole' { -- | The name of the IAM role to get information about. -- -- This parameter allows (through its -- ) a string of characters -- consisting of upper and lowercase alphanumeric characters with no -- spaces. You can also include any of the following characters: _+=,.\@- roleName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'GetRole' 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: -- -- 'roleName', 'getRole_roleName' - The name of the IAM role to get information about. -- -- This parameter allows (through its -- ) a string of characters -- consisting of upper and lowercase alphanumeric characters with no -- spaces. You can also include any of the following characters: _+=,.\@- newGetRole :: -- | 'roleName' Prelude.Text -> GetRole newGetRole pRoleName_ = GetRole' {roleName = pRoleName_} -- | The name of the IAM role to get information about. -- -- This parameter allows (through its -- ) a string of characters -- consisting of upper and lowercase alphanumeric characters with no -- spaces. You can also include any of the following characters: _+=,.\@- getRole_roleName :: Lens.Lens' GetRole Prelude.Text getRole_roleName = Lens.lens (\GetRole' {roleName} -> roleName) (\s@GetRole' {} a -> s {roleName = a} :: GetRole) instance Core.AWSRequest GetRole where type AWSResponse GetRole = GetRoleResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveXMLWrapper "GetRoleResult" ( \s h x -> GetRoleResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) Prelude.<*> (x Data..@ "Role") ) instance Prelude.Hashable GetRole where hashWithSalt _salt GetRole' {..} = _salt `Prelude.hashWithSalt` roleName instance Prelude.NFData GetRole where rnf GetRole' {..} = Prelude.rnf roleName instance Data.ToHeaders GetRole where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath GetRole where toPath = Prelude.const "/" instance Data.ToQuery GetRole where toQuery GetRole' {..} = Prelude.mconcat [ "Action" Data.=: ("GetRole" :: Prelude.ByteString), "Version" Data.=: ("2010-05-08" :: Prelude.ByteString), "RoleName" Data.=: roleName ] -- | Contains the response to a successful GetRole request. -- -- /See:/ 'newGetRoleResponse' smart constructor. data GetRoleResponse = GetRoleResponse' { -- | The response's http status code. httpStatus :: Prelude.Int, -- | A structure containing details about the IAM role. role' :: Role } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'GetRoleResponse' 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: -- -- 'httpStatus', 'getRoleResponse_httpStatus' - The response's http status code. -- -- 'role'', 'getRoleResponse_role' - A structure containing details about the IAM role. newGetRoleResponse :: -- | 'httpStatus' Prelude.Int -> -- | 'role'' Role -> GetRoleResponse newGetRoleResponse pHttpStatus_ pRole_ = GetRoleResponse' { httpStatus = pHttpStatus_, role' = pRole_ } -- | The response's http status code. getRoleResponse_httpStatus :: Lens.Lens' GetRoleResponse Prelude.Int getRoleResponse_httpStatus = Lens.lens (\GetRoleResponse' {httpStatus} -> httpStatus) (\s@GetRoleResponse' {} a -> s {httpStatus = a} :: GetRoleResponse) -- | A structure containing details about the IAM role. getRoleResponse_role :: Lens.Lens' GetRoleResponse Role getRoleResponse_role = Lens.lens (\GetRoleResponse' {role'} -> role') (\s@GetRoleResponse' {} a -> s {role' = a} :: GetRoleResponse) instance Prelude.NFData GetRoleResponse where rnf GetRoleResponse' {..} = Prelude.rnf httpStatus `Prelude.seq` Prelude.rnf role'