{-# 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.Discovery.DescribeTags -- 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 a list of configuration items that have tags as specified by -- the key-value pairs, name and value, passed to the optional parameter -- @filters@. -- -- There are three valid tag filter names: -- -- - tagKey -- -- - tagValue -- -- - configurationId -- -- Also, all configuration items associated with your user account that -- have tags can be listed if you call @DescribeTags@ as is without passing -- any parameters. -- -- This operation returns paginated results. module Amazonka.Discovery.DescribeTags ( -- * Creating a Request DescribeTags (..), newDescribeTags, -- * Request Lenses describeTags_filters, describeTags_maxResults, describeTags_nextToken, -- * Destructuring the Response DescribeTagsResponse (..), newDescribeTagsResponse, -- * Response Lenses describeTagsResponse_nextToken, describeTagsResponse_tags, describeTagsResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.Discovery.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newDescribeTags' smart constructor. data DescribeTags = DescribeTags' { -- | You can filter the list using a /key/-/value/ format. You can separate -- these items by using logical operators. Allowed filters include -- @tagKey@, @tagValue@, and @configurationId@. filters :: Prelude.Maybe [TagFilter], -- | The total number of items to return in a single page of output. The -- maximum value is 100. maxResults :: Prelude.Maybe Prelude.Int, -- | A token to start the list. Use this token to get the next set of -- results. nextToken :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeTags' 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: -- -- 'filters', 'describeTags_filters' - You can filter the list using a /key/-/value/ format. You can separate -- these items by using logical operators. Allowed filters include -- @tagKey@, @tagValue@, and @configurationId@. -- -- 'maxResults', 'describeTags_maxResults' - The total number of items to return in a single page of output. The -- maximum value is 100. -- -- 'nextToken', 'describeTags_nextToken' - A token to start the list. Use this token to get the next set of -- results. newDescribeTags :: DescribeTags newDescribeTags = DescribeTags' { filters = Prelude.Nothing, maxResults = Prelude.Nothing, nextToken = Prelude.Nothing } -- | You can filter the list using a /key/-/value/ format. You can separate -- these items by using logical operators. Allowed filters include -- @tagKey@, @tagValue@, and @configurationId@. describeTags_filters :: Lens.Lens' DescribeTags (Prelude.Maybe [TagFilter]) describeTags_filters = Lens.lens (\DescribeTags' {filters} -> filters) (\s@DescribeTags' {} a -> s {filters = a} :: DescribeTags) Prelude.. Lens.mapping Lens.coerced -- | The total number of items to return in a single page of output. The -- maximum value is 100. describeTags_maxResults :: Lens.Lens' DescribeTags (Prelude.Maybe Prelude.Int) describeTags_maxResults = Lens.lens (\DescribeTags' {maxResults} -> maxResults) (\s@DescribeTags' {} a -> s {maxResults = a} :: DescribeTags) -- | A token to start the list. Use this token to get the next set of -- results. describeTags_nextToken :: Lens.Lens' DescribeTags (Prelude.Maybe Prelude.Text) describeTags_nextToken = Lens.lens (\DescribeTags' {nextToken} -> nextToken) (\s@DescribeTags' {} a -> s {nextToken = a} :: DescribeTags) instance Core.AWSPager DescribeTags where page rq rs | Core.stop ( rs Lens.^? describeTagsResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? describeTagsResponse_tags Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& describeTags_nextToken Lens..~ rs Lens.^? describeTagsResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest DescribeTags where type AWSResponse DescribeTags = DescribeTagsResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> DescribeTagsResponse' Prelude.<$> (x Data..?> "nextToken") Prelude.<*> (x Data..?> "tags" Core..!@ Prelude.mempty) Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DescribeTags where hashWithSalt _salt DescribeTags' {..} = _salt `Prelude.hashWithSalt` filters `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken instance Prelude.NFData DescribeTags where rnf DescribeTags' {..} = Prelude.rnf filters `Prelude.seq` Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken instance Data.ToHeaders DescribeTags where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AWSPoseidonService_V2015_11_01.DescribeTags" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DescribeTags where toJSON DescribeTags' {..} = Data.object ( Prelude.catMaybes [ ("filters" Data..=) Prelude.<$> filters, ("maxResults" Data..=) Prelude.<$> maxResults, ("nextToken" Data..=) Prelude.<$> nextToken ] ) instance Data.ToPath DescribeTags where toPath = Prelude.const "/" instance Data.ToQuery DescribeTags where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDescribeTagsResponse' smart constructor. data DescribeTagsResponse = DescribeTagsResponse' { -- | The call returns a token. Use this token to get the next set of results. nextToken :: Prelude.Maybe Prelude.Text, -- | Depending on the input, this is a list of configuration items tagged -- with a specific tag, or a list of tags for a specific configuration -- item. tags :: Prelude.Maybe [ConfigurationTag], -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeTagsResponse' 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', 'describeTagsResponse_nextToken' - The call returns a token. Use this token to get the next set of results. -- -- 'tags', 'describeTagsResponse_tags' - Depending on the input, this is a list of configuration items tagged -- with a specific tag, or a list of tags for a specific configuration -- item. -- -- 'httpStatus', 'describeTagsResponse_httpStatus' - The response's http status code. newDescribeTagsResponse :: -- | 'httpStatus' Prelude.Int -> DescribeTagsResponse newDescribeTagsResponse pHttpStatus_ = DescribeTagsResponse' { nextToken = Prelude.Nothing, tags = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The call returns a token. Use this token to get the next set of results. describeTagsResponse_nextToken :: Lens.Lens' DescribeTagsResponse (Prelude.Maybe Prelude.Text) describeTagsResponse_nextToken = Lens.lens (\DescribeTagsResponse' {nextToken} -> nextToken) (\s@DescribeTagsResponse' {} a -> s {nextToken = a} :: DescribeTagsResponse) -- | Depending on the input, this is a list of configuration items tagged -- with a specific tag, or a list of tags for a specific configuration -- item. describeTagsResponse_tags :: Lens.Lens' DescribeTagsResponse (Prelude.Maybe [ConfigurationTag]) describeTagsResponse_tags = Lens.lens (\DescribeTagsResponse' {tags} -> tags) (\s@DescribeTagsResponse' {} a -> s {tags = a} :: DescribeTagsResponse) Prelude.. Lens.mapping Lens.coerced -- | The response's http status code. describeTagsResponse_httpStatus :: Lens.Lens' DescribeTagsResponse Prelude.Int describeTagsResponse_httpStatus = Lens.lens (\DescribeTagsResponse' {httpStatus} -> httpStatus) (\s@DescribeTagsResponse' {} a -> s {httpStatus = a} :: DescribeTagsResponse) instance Prelude.NFData DescribeTagsResponse where rnf DescribeTagsResponse' {..} = Prelude.rnf nextToken `Prelude.seq` Prelude.rnf tags `Prelude.seq` Prelude.rnf httpStatus