{-# 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.ListApplications -- 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 applications registered with the IAM user or Amazon Web -- Services account. -- -- This operation returns paginated results. module Amazonka.CodeDeploy.ListApplications ( -- * Creating a Request ListApplications (..), newListApplications, -- * Request Lenses listApplications_nextToken, -- * Destructuring the Response ListApplicationsResponse (..), newListApplicationsResponse, -- * Response Lenses listApplicationsResponse_applications, listApplicationsResponse_nextToken, listApplicationsResponse_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 @ListApplications@ operation. -- -- /See:/ 'newListApplications' smart constructor. data ListApplications = ListApplications' { -- | An identifier returned from the previous list applications call. It can -- be used to return the next set of applications in the list. nextToken :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListApplications' 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', 'listApplications_nextToken' - An identifier returned from the previous list applications call. It can -- be used to return the next set of applications in the list. newListApplications :: ListApplications newListApplications = ListApplications' {nextToken = Prelude.Nothing} -- | An identifier returned from the previous list applications call. It can -- be used to return the next set of applications in the list. listApplications_nextToken :: Lens.Lens' ListApplications (Prelude.Maybe Prelude.Text) listApplications_nextToken = Lens.lens (\ListApplications' {nextToken} -> nextToken) (\s@ListApplications' {} a -> s {nextToken = a} :: ListApplications) instance Core.AWSPager ListApplications where page rq rs | Core.stop ( rs Lens.^? listApplicationsResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? listApplicationsResponse_applications Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& listApplications_nextToken Lens..~ rs Lens.^? listApplicationsResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest ListApplications where type AWSResponse ListApplications = ListApplicationsResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListApplicationsResponse' Prelude.<$> (x Data..?> "applications" Core..!@ Prelude.mempty) Prelude.<*> (x Data..?> "nextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ListApplications where hashWithSalt _salt ListApplications' {..} = _salt `Prelude.hashWithSalt` nextToken instance Prelude.NFData ListApplications where rnf ListApplications' {..} = Prelude.rnf nextToken instance Data.ToHeaders ListApplications where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "CodeDeploy_20141006.ListApplications" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON ListApplications where toJSON ListApplications' {..} = Data.object ( Prelude.catMaybes [("nextToken" Data..=) Prelude.<$> nextToken] ) instance Data.ToPath ListApplications where toPath = Prelude.const "/" instance Data.ToQuery ListApplications where toQuery = Prelude.const Prelude.mempty -- | Represents the output of a ListApplications operation. -- -- /See:/ 'newListApplicationsResponse' smart constructor. data ListApplicationsResponse = ListApplicationsResponse' { -- | A list of application names. applications :: 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 applications call to -- return the next set of applications 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 'ListApplicationsResponse' 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: -- -- 'applications', 'listApplicationsResponse_applications' - A list of application names. -- -- 'nextToken', 'listApplicationsResponse_nextToken' - If a large amount of information is returned, an identifier is also -- returned. It can be used in a subsequent list applications call to -- return the next set of applications in the list. -- -- 'httpStatus', 'listApplicationsResponse_httpStatus' - The response's http status code. newListApplicationsResponse :: -- | 'httpStatus' Prelude.Int -> ListApplicationsResponse newListApplicationsResponse pHttpStatus_ = ListApplicationsResponse' { applications = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | A list of application names. listApplicationsResponse_applications :: Lens.Lens' ListApplicationsResponse (Prelude.Maybe [Prelude.Text]) listApplicationsResponse_applications = Lens.lens (\ListApplicationsResponse' {applications} -> applications) (\s@ListApplicationsResponse' {} a -> s {applications = a} :: ListApplicationsResponse) 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 applications call to -- return the next set of applications in the list. listApplicationsResponse_nextToken :: Lens.Lens' ListApplicationsResponse (Prelude.Maybe Prelude.Text) listApplicationsResponse_nextToken = Lens.lens (\ListApplicationsResponse' {nextToken} -> nextToken) (\s@ListApplicationsResponse' {} a -> s {nextToken = a} :: ListApplicationsResponse) -- | The response's http status code. listApplicationsResponse_httpStatus :: Lens.Lens' ListApplicationsResponse Prelude.Int listApplicationsResponse_httpStatus = Lens.lens (\ListApplicationsResponse' {httpStatus} -> httpStatus) (\s@ListApplicationsResponse' {} a -> s {httpStatus = a} :: ListApplicationsResponse) instance Prelude.NFData ListApplicationsResponse where rnf ListApplicationsResponse' {..} = Prelude.rnf applications `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus