{-# 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.CodeDeploy.ListDeploymentConfigs -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Lists the deployment configurations with the IAM user or Amazon Web -- Services account. -- -- This operation returns paginated results. module Amazonka.CodeDeploy.ListDeploymentConfigs ( -- * Creating a Request ListDeploymentConfigs (..), newListDeploymentConfigs, -- * Request Lenses listDeploymentConfigs_nextToken, -- * Destructuring the Response ListDeploymentConfigsResponse (..), newListDeploymentConfigsResponse, -- * Response Lenses listDeploymentConfigsResponse_deploymentConfigsList, listDeploymentConfigsResponse_nextToken, listDeploymentConfigsResponse_httpStatus, ) where import Amazonka.CodeDeploy.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 -- | Represents the input of a @ListDeploymentConfigs@ operation. -- -- /See:/ 'newListDeploymentConfigs' smart constructor. data ListDeploymentConfigs = ListDeploymentConfigs' { -- | An identifier returned from the previous @ListDeploymentConfigs@ call. -- It can be used to return the next set of deployment configurations in -- the list. nextToken :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListDeploymentConfigs' 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: -- -- 'nextToken', 'listDeploymentConfigs_nextToken' - An identifier returned from the previous @ListDeploymentConfigs@ call. -- It can be used to return the next set of deployment configurations in -- the list. newListDeploymentConfigs :: ListDeploymentConfigs newListDeploymentConfigs = ListDeploymentConfigs' {nextToken = Prelude.Nothing} -- | An identifier returned from the previous @ListDeploymentConfigs@ call. -- It can be used to return the next set of deployment configurations in -- the list. listDeploymentConfigs_nextToken :: Lens.Lens' ListDeploymentConfigs (Prelude.Maybe Prelude.Text) listDeploymentConfigs_nextToken = Lens.lens (\ListDeploymentConfigs' {nextToken} -> nextToken) (\s@ListDeploymentConfigs' {} a -> s {nextToken = a} :: ListDeploymentConfigs) instance Core.AWSPager ListDeploymentConfigs where page rq rs | Core.stop ( rs Lens.^? listDeploymentConfigsResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? listDeploymentConfigsResponse_deploymentConfigsList Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& listDeploymentConfigs_nextToken Lens..~ rs Lens.^? listDeploymentConfigsResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest ListDeploymentConfigs where type AWSResponse ListDeploymentConfigs = ListDeploymentConfigsResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListDeploymentConfigsResponse' Prelude.<$> ( x Data..?> "deploymentConfigsList" Core..!@ Prelude.mempty ) Prelude.<*> (x Data..?> "nextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ListDeploymentConfigs where hashWithSalt _salt ListDeploymentConfigs' {..} = _salt `Prelude.hashWithSalt` nextToken instance Prelude.NFData ListDeploymentConfigs where rnf ListDeploymentConfigs' {..} = Prelude.rnf nextToken instance Data.ToHeaders ListDeploymentConfigs where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "CodeDeploy_20141006.ListDeploymentConfigs" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON ListDeploymentConfigs where toJSON ListDeploymentConfigs' {..} = Data.object ( Prelude.catMaybes [("nextToken" Data..=) Prelude.<$> nextToken] ) instance Data.ToPath ListDeploymentConfigs where toPath = Prelude.const "/" instance Data.ToQuery ListDeploymentConfigs where toQuery = Prelude.const Prelude.mempty -- | Represents the output of a @ListDeploymentConfigs@ operation. -- -- /See:/ 'newListDeploymentConfigsResponse' smart constructor. data ListDeploymentConfigsResponse = ListDeploymentConfigsResponse' { -- | A list of deployment configurations, including built-in configurations -- such as @CodeDeployDefault.OneAtATime@. deploymentConfigsList :: Prelude.Maybe [Prelude.Text], -- | If a large amount of information is returned, an identifier is also -- returned. It can be used in a subsequent list deployment configurations -- call to return the next set of deployment configurations in the list. nextToken :: Prelude.Maybe Prelude.Text, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListDeploymentConfigsResponse' 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: -- -- 'deploymentConfigsList', 'listDeploymentConfigsResponse_deploymentConfigsList' - A list of deployment configurations, including built-in configurations -- such as @CodeDeployDefault.OneAtATime@. -- -- 'nextToken', 'listDeploymentConfigsResponse_nextToken' - If a large amount of information is returned, an identifier is also -- returned. It can be used in a subsequent list deployment configurations -- call to return the next set of deployment configurations in the list. -- -- 'httpStatus', 'listDeploymentConfigsResponse_httpStatus' - The response's http status code. newListDeploymentConfigsResponse :: -- | 'httpStatus' Prelude.Int -> ListDeploymentConfigsResponse newListDeploymentConfigsResponse pHttpStatus_ = ListDeploymentConfigsResponse' { deploymentConfigsList = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | A list of deployment configurations, including built-in configurations -- such as @CodeDeployDefault.OneAtATime@. listDeploymentConfigsResponse_deploymentConfigsList :: Lens.Lens' ListDeploymentConfigsResponse (Prelude.Maybe [Prelude.Text]) listDeploymentConfigsResponse_deploymentConfigsList = Lens.lens (\ListDeploymentConfigsResponse' {deploymentConfigsList} -> deploymentConfigsList) (\s@ListDeploymentConfigsResponse' {} a -> s {deploymentConfigsList = a} :: ListDeploymentConfigsResponse) Prelude.. Lens.mapping Lens.coerced -- | If a large amount of information is returned, an identifier is also -- returned. It can be used in a subsequent list deployment configurations -- call to return the next set of deployment configurations in the list. listDeploymentConfigsResponse_nextToken :: Lens.Lens' ListDeploymentConfigsResponse (Prelude.Maybe Prelude.Text) listDeploymentConfigsResponse_nextToken = Lens.lens (\ListDeploymentConfigsResponse' {nextToken} -> nextToken) (\s@ListDeploymentConfigsResponse' {} a -> s {nextToken = a} :: ListDeploymentConfigsResponse) -- | The response's http status code. listDeploymentConfigsResponse_httpStatus :: Lens.Lens' ListDeploymentConfigsResponse Prelude.Int listDeploymentConfigsResponse_httpStatus = Lens.lens (\ListDeploymentConfigsResponse' {httpStatus} -> httpStatus) (\s@ListDeploymentConfigsResponse' {} a -> s {httpStatus = a} :: ListDeploymentConfigsResponse) instance Prelude.NFData ListDeploymentConfigsResponse where rnf ListDeploymentConfigsResponse' {..} = Prelude.rnf deploymentConfigsList `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus