{-# 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.SWF.DescribeActivityType -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Returns information about the specified activity type. This includes -- configuration settings provided when the type was registered and other -- general information about the type. -- -- __Access Control__ -- -- You can use IAM policies to control this action\'s access to Amazon SWF -- resources as follows: -- -- - Use a @Resource@ element with the domain name to limit the action to -- only specified domains. -- -- - Use an @Action@ element to allow or deny permission to call this -- action. -- -- - Constrain the following parameters by using a @Condition@ element -- with the appropriate keys. -- -- - @activityType.name@: String constraint. The key is -- @swf:activityType.name@. -- -- - @activityType.version@: String constraint. The key is -- @swf:activityType.version@. -- -- If the caller doesn\'t have sufficient permissions to invoke the action, -- or the parameter values fall outside the specified constraints, the -- action fails. The associated event attribute\'s @cause@ parameter is set -- to @OPERATION_NOT_PERMITTED@. For details and example IAM policies, see -- -- in the /Amazon SWF Developer Guide/. module Amazonka.SWF.DescribeActivityType ( -- * Creating a Request DescribeActivityType (..), newDescribeActivityType, -- * Request Lenses describeActivityType_domain, describeActivityType_activityType, -- * Destructuring the Response DescribeActivityTypeResponse (..), newDescribeActivityTypeResponse, -- * Response Lenses describeActivityTypeResponse_httpStatus, describeActivityTypeResponse_typeInfo, describeActivityTypeResponse_configuration, ) where 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 import Amazonka.SWF.Types -- | /See:/ 'newDescribeActivityType' smart constructor. data DescribeActivityType = DescribeActivityType' { -- | The name of the domain in which the activity type is registered. domain :: Prelude.Text, -- | The activity type to get information about. Activity types are -- identified by the @name@ and @version@ that were supplied when the -- activity was registered. activityType :: ActivityType } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeActivityType' 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: -- -- 'domain', 'describeActivityType_domain' - The name of the domain in which the activity type is registered. -- -- 'activityType', 'describeActivityType_activityType' - The activity type to get information about. Activity types are -- identified by the @name@ and @version@ that were supplied when the -- activity was registered. newDescribeActivityType :: -- | 'domain' Prelude.Text -> -- | 'activityType' ActivityType -> DescribeActivityType newDescribeActivityType pDomain_ pActivityType_ = DescribeActivityType' { domain = pDomain_, activityType = pActivityType_ } -- | The name of the domain in which the activity type is registered. describeActivityType_domain :: Lens.Lens' DescribeActivityType Prelude.Text describeActivityType_domain = Lens.lens (\DescribeActivityType' {domain} -> domain) (\s@DescribeActivityType' {} a -> s {domain = a} :: DescribeActivityType) -- | The activity type to get information about. Activity types are -- identified by the @name@ and @version@ that were supplied when the -- activity was registered. describeActivityType_activityType :: Lens.Lens' DescribeActivityType ActivityType describeActivityType_activityType = Lens.lens (\DescribeActivityType' {activityType} -> activityType) (\s@DescribeActivityType' {} a -> s {activityType = a} :: DescribeActivityType) instance Core.AWSRequest DescribeActivityType where type AWSResponse DescribeActivityType = DescribeActivityTypeResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> DescribeActivityTypeResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) Prelude.<*> (x Data..:> "typeInfo") Prelude.<*> (x Data..:> "configuration") ) instance Prelude.Hashable DescribeActivityType where hashWithSalt _salt DescribeActivityType' {..} = _salt `Prelude.hashWithSalt` domain `Prelude.hashWithSalt` activityType instance Prelude.NFData DescribeActivityType where rnf DescribeActivityType' {..} = Prelude.rnf domain `Prelude.seq` Prelude.rnf activityType instance Data.ToHeaders DescribeActivityType where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "SimpleWorkflowService.DescribeActivityType" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.0" :: Prelude.ByteString ) ] ) instance Data.ToJSON DescribeActivityType where toJSON DescribeActivityType' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("domain" Data..= domain), Prelude.Just ("activityType" Data..= activityType) ] ) instance Data.ToPath DescribeActivityType where toPath = Prelude.const "/" instance Data.ToQuery DescribeActivityType where toQuery = Prelude.const Prelude.mempty -- | Detailed information about an activity type. -- -- /See:/ 'newDescribeActivityTypeResponse' smart constructor. data DescribeActivityTypeResponse = DescribeActivityTypeResponse' { -- | The response's http status code. httpStatus :: Prelude.Int, -- | General information about the activity type. -- -- The status of activity type (returned in the ActivityTypeInfo structure) -- can be one of the following. -- -- - @REGISTERED@ – The type is registered and available. Workers -- supporting this type should be running. -- -- - @DEPRECATED@ – The type was deprecated using DeprecateActivityType, -- but is still in use. You should keep workers supporting this type -- running. You cannot create new tasks of this type. typeInfo :: ActivityTypeInfo, -- | The configuration settings registered with the activity type. configuration :: ActivityTypeConfiguration } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeActivityTypeResponse' 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', 'describeActivityTypeResponse_httpStatus' - The response's http status code. -- -- 'typeInfo', 'describeActivityTypeResponse_typeInfo' - General information about the activity type. -- -- The status of activity type (returned in the ActivityTypeInfo structure) -- can be one of the following. -- -- - @REGISTERED@ – The type is registered and available. Workers -- supporting this type should be running. -- -- - @DEPRECATED@ – The type was deprecated using DeprecateActivityType, -- but is still in use. You should keep workers supporting this type -- running. You cannot create new tasks of this type. -- -- 'configuration', 'describeActivityTypeResponse_configuration' - The configuration settings registered with the activity type. newDescribeActivityTypeResponse :: -- | 'httpStatus' Prelude.Int -> -- | 'typeInfo' ActivityTypeInfo -> -- | 'configuration' ActivityTypeConfiguration -> DescribeActivityTypeResponse newDescribeActivityTypeResponse pHttpStatus_ pTypeInfo_ pConfiguration_ = DescribeActivityTypeResponse' { httpStatus = pHttpStatus_, typeInfo = pTypeInfo_, configuration = pConfiguration_ } -- | The response's http status code. describeActivityTypeResponse_httpStatus :: Lens.Lens' DescribeActivityTypeResponse Prelude.Int describeActivityTypeResponse_httpStatus = Lens.lens (\DescribeActivityTypeResponse' {httpStatus} -> httpStatus) (\s@DescribeActivityTypeResponse' {} a -> s {httpStatus = a} :: DescribeActivityTypeResponse) -- | General information about the activity type. -- -- The status of activity type (returned in the ActivityTypeInfo structure) -- can be one of the following. -- -- - @REGISTERED@ – The type is registered and available. Workers -- supporting this type should be running. -- -- - @DEPRECATED@ – The type was deprecated using DeprecateActivityType, -- but is still in use. You should keep workers supporting this type -- running. You cannot create new tasks of this type. describeActivityTypeResponse_typeInfo :: Lens.Lens' DescribeActivityTypeResponse ActivityTypeInfo describeActivityTypeResponse_typeInfo = Lens.lens (\DescribeActivityTypeResponse' {typeInfo} -> typeInfo) (\s@DescribeActivityTypeResponse' {} a -> s {typeInfo = a} :: DescribeActivityTypeResponse) -- | The configuration settings registered with the activity type. describeActivityTypeResponse_configuration :: Lens.Lens' DescribeActivityTypeResponse ActivityTypeConfiguration describeActivityTypeResponse_configuration = Lens.lens (\DescribeActivityTypeResponse' {configuration} -> configuration) (\s@DescribeActivityTypeResponse' {} a -> s {configuration = a} :: DescribeActivityTypeResponse) instance Prelude.NFData DescribeActivityTypeResponse where rnf DescribeActivityTypeResponse' {..} = Prelude.rnf httpStatus `Prelude.seq` Prelude.rnf typeInfo `Prelude.seq` Prelude.rnf configuration