{-# 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.CloudWatch.ListDashboards -- 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 a list of the dashboards for your account. If you include -- @DashboardNamePrefix@, only those dashboards with names starting with -- the prefix are listed. Otherwise, all dashboards in your account are -- listed. -- -- @ListDashboards@ returns up to 1000 results on one page. If there are -- more than 1000 dashboards, you can call @ListDashboards@ again and -- include the value you received for @NextToken@ in the first call, to -- receive the next 1000 results. -- -- This operation returns paginated results. module Amazonka.CloudWatch.ListDashboards ( -- * Creating a Request ListDashboards (..), newListDashboards, -- * Request Lenses listDashboards_dashboardNamePrefix, listDashboards_nextToken, -- * Destructuring the Response ListDashboardsResponse (..), newListDashboardsResponse, -- * Response Lenses listDashboardsResponse_dashboardEntries, listDashboardsResponse_nextToken, listDashboardsResponse_httpStatus, ) where import Amazonka.CloudWatch.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 -- | /See:/ 'newListDashboards' smart constructor. data ListDashboards = ListDashboards' { -- | If you specify this parameter, only the dashboards with names starting -- with the specified string are listed. The maximum length is 255, and -- valid characters are A-Z, a-z, 0-9, \".\", \"-\", and \"_\". dashboardNamePrefix :: Prelude.Maybe Prelude.Text, -- | The token returned by a previous call to indicate that there is more -- data available. nextToken :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListDashboards' 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: -- -- 'dashboardNamePrefix', 'listDashboards_dashboardNamePrefix' - If you specify this parameter, only the dashboards with names starting -- with the specified string are listed. The maximum length is 255, and -- valid characters are A-Z, a-z, 0-9, \".\", \"-\", and \"_\". -- -- 'nextToken', 'listDashboards_nextToken' - The token returned by a previous call to indicate that there is more -- data available. newListDashboards :: ListDashboards newListDashboards = ListDashboards' { dashboardNamePrefix = Prelude.Nothing, nextToken = Prelude.Nothing } -- | If you specify this parameter, only the dashboards with names starting -- with the specified string are listed. The maximum length is 255, and -- valid characters are A-Z, a-z, 0-9, \".\", \"-\", and \"_\". listDashboards_dashboardNamePrefix :: Lens.Lens' ListDashboards (Prelude.Maybe Prelude.Text) listDashboards_dashboardNamePrefix = Lens.lens (\ListDashboards' {dashboardNamePrefix} -> dashboardNamePrefix) (\s@ListDashboards' {} a -> s {dashboardNamePrefix = a} :: ListDashboards) -- | The token returned by a previous call to indicate that there is more -- data available. listDashboards_nextToken :: Lens.Lens' ListDashboards (Prelude.Maybe Prelude.Text) listDashboards_nextToken = Lens.lens (\ListDashboards' {nextToken} -> nextToken) (\s@ListDashboards' {} a -> s {nextToken = a} :: ListDashboards) instance Core.AWSPager ListDashboards where page rq rs | Core.stop ( rs Lens.^? listDashboardsResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? listDashboardsResponse_dashboardEntries Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& listDashboards_nextToken Lens..~ rs Lens.^? listDashboardsResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest ListDashboards where type AWSResponse ListDashboards = ListDashboardsResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveXMLWrapper "ListDashboardsResult" ( \s h x -> ListDashboardsResponse' Prelude.<$> ( x Data..@? "DashboardEntries" Core..!@ Prelude.mempty Prelude.>>= Core.may (Data.parseXMLList "member") ) Prelude.<*> (x Data..@? "NextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ListDashboards where hashWithSalt _salt ListDashboards' {..} = _salt `Prelude.hashWithSalt` dashboardNamePrefix `Prelude.hashWithSalt` nextToken instance Prelude.NFData ListDashboards where rnf ListDashboards' {..} = Prelude.rnf dashboardNamePrefix `Prelude.seq` Prelude.rnf nextToken instance Data.ToHeaders ListDashboards where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath ListDashboards where toPath = Prelude.const "/" instance Data.ToQuery ListDashboards where toQuery ListDashboards' {..} = Prelude.mconcat [ "Action" Data.=: ("ListDashboards" :: Prelude.ByteString), "Version" Data.=: ("2010-08-01" :: Prelude.ByteString), "DashboardNamePrefix" Data.=: dashboardNamePrefix, "NextToken" Data.=: nextToken ] -- | /See:/ 'newListDashboardsResponse' smart constructor. data ListDashboardsResponse = ListDashboardsResponse' { -- | The list of matching dashboards. dashboardEntries :: Prelude.Maybe [DashboardEntry], -- | The token that marks the start of the next batch of returned results. 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 'ListDashboardsResponse' 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: -- -- 'dashboardEntries', 'listDashboardsResponse_dashboardEntries' - The list of matching dashboards. -- -- 'nextToken', 'listDashboardsResponse_nextToken' - The token that marks the start of the next batch of returned results. -- -- 'httpStatus', 'listDashboardsResponse_httpStatus' - The response's http status code. newListDashboardsResponse :: -- | 'httpStatus' Prelude.Int -> ListDashboardsResponse newListDashboardsResponse pHttpStatus_ = ListDashboardsResponse' { dashboardEntries = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The list of matching dashboards. listDashboardsResponse_dashboardEntries :: Lens.Lens' ListDashboardsResponse (Prelude.Maybe [DashboardEntry]) listDashboardsResponse_dashboardEntries = Lens.lens (\ListDashboardsResponse' {dashboardEntries} -> dashboardEntries) (\s@ListDashboardsResponse' {} a -> s {dashboardEntries = a} :: ListDashboardsResponse) Prelude.. Lens.mapping Lens.coerced -- | The token that marks the start of the next batch of returned results. listDashboardsResponse_nextToken :: Lens.Lens' ListDashboardsResponse (Prelude.Maybe Prelude.Text) listDashboardsResponse_nextToken = Lens.lens (\ListDashboardsResponse' {nextToken} -> nextToken) (\s@ListDashboardsResponse' {} a -> s {nextToken = a} :: ListDashboardsResponse) -- | The response's http status code. listDashboardsResponse_httpStatus :: Lens.Lens' ListDashboardsResponse Prelude.Int listDashboardsResponse_httpStatus = Lens.lens (\ListDashboardsResponse' {httpStatus} -> httpStatus) (\s@ListDashboardsResponse' {} a -> s {httpStatus = a} :: ListDashboardsResponse) instance Prelude.NFData ListDashboardsResponse where rnf ListDashboardsResponse' {..} = Prelude.rnf dashboardEntries `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus