{-# 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.SageMaker.ListTags -- 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 the tags for the specified SageMaker resource. -- -- This operation returns paginated results. module Amazonka.SageMaker.ListTags ( -- * Creating a Request ListTags (..), newListTags, -- * Request Lenses listTags_maxResults, listTags_nextToken, listTags_resourceArn, -- * Destructuring the Response ListTagsResponse (..), newListTagsResponse, -- * Response Lenses listTagsResponse_nextToken, listTagsResponse_tags, listTagsResponse_httpStatus, ) 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.SageMaker.Types -- | /See:/ 'newListTags' smart constructor. data ListTags = ListTags' { -- | Maximum number of tags to return. maxResults :: Prelude.Maybe Prelude.Natural, -- | If the response to the previous @ListTags@ request is truncated, -- SageMaker returns this token. To retrieve the next set of tags, use it -- in the subsequent request. nextToken :: Prelude.Maybe Prelude.Text, -- | The Amazon Resource Name (ARN) of the resource whose tags you want to -- retrieve. resourceArn :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListTags' 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: -- -- 'maxResults', 'listTags_maxResults' - Maximum number of tags to return. -- -- 'nextToken', 'listTags_nextToken' - If the response to the previous @ListTags@ request is truncated, -- SageMaker returns this token. To retrieve the next set of tags, use it -- in the subsequent request. -- -- 'resourceArn', 'listTags_resourceArn' - The Amazon Resource Name (ARN) of the resource whose tags you want to -- retrieve. newListTags :: -- | 'resourceArn' Prelude.Text -> ListTags newListTags pResourceArn_ = ListTags' { maxResults = Prelude.Nothing, nextToken = Prelude.Nothing, resourceArn = pResourceArn_ } -- | Maximum number of tags to return. listTags_maxResults :: Lens.Lens' ListTags (Prelude.Maybe Prelude.Natural) listTags_maxResults = Lens.lens (\ListTags' {maxResults} -> maxResults) (\s@ListTags' {} a -> s {maxResults = a} :: ListTags) -- | If the response to the previous @ListTags@ request is truncated, -- SageMaker returns this token. To retrieve the next set of tags, use it -- in the subsequent request. listTags_nextToken :: Lens.Lens' ListTags (Prelude.Maybe Prelude.Text) listTags_nextToken = Lens.lens (\ListTags' {nextToken} -> nextToken) (\s@ListTags' {} a -> s {nextToken = a} :: ListTags) -- | The Amazon Resource Name (ARN) of the resource whose tags you want to -- retrieve. listTags_resourceArn :: Lens.Lens' ListTags Prelude.Text listTags_resourceArn = Lens.lens (\ListTags' {resourceArn} -> resourceArn) (\s@ListTags' {} a -> s {resourceArn = a} :: ListTags) instance Core.AWSPager ListTags where page rq rs | Core.stop ( rs Lens.^? listTagsResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? listTagsResponse_tags Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& listTags_nextToken Lens..~ rs Lens.^? listTagsResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest ListTags where type AWSResponse ListTags = ListTagsResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListTagsResponse' Prelude.<$> (x Data..?> "NextToken") Prelude.<*> (x Data..?> "Tags" Core..!@ Prelude.mempty) Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ListTags where hashWithSalt _salt ListTags' {..} = _salt `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken `Prelude.hashWithSalt` resourceArn instance Prelude.NFData ListTags where rnf ListTags' {..} = Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf resourceArn instance Data.ToHeaders ListTags where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ("SageMaker.ListTags" :: Prelude.ByteString), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON ListTags where toJSON ListTags' {..} = Data.object ( Prelude.catMaybes [ ("MaxResults" Data..=) Prelude.<$> maxResults, ("NextToken" Data..=) Prelude.<$> nextToken, Prelude.Just ("ResourceArn" Data..= resourceArn) ] ) instance Data.ToPath ListTags where toPath = Prelude.const "/" instance Data.ToQuery ListTags where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newListTagsResponse' smart constructor. data ListTagsResponse = ListTagsResponse' { -- | If response is truncated, SageMaker includes a token in the response. -- You can use this token in your subsequent request to fetch next set of -- tokens. nextToken :: Prelude.Maybe Prelude.Text, -- | An array of @Tag@ objects, each with a tag key and a value. tags :: Prelude.Maybe [Tag], -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListTagsResponse' 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', 'listTagsResponse_nextToken' - If response is truncated, SageMaker includes a token in the response. -- You can use this token in your subsequent request to fetch next set of -- tokens. -- -- 'tags', 'listTagsResponse_tags' - An array of @Tag@ objects, each with a tag key and a value. -- -- 'httpStatus', 'listTagsResponse_httpStatus' - The response's http status code. newListTagsResponse :: -- | 'httpStatus' Prelude.Int -> ListTagsResponse newListTagsResponse pHttpStatus_ = ListTagsResponse' { nextToken = Prelude.Nothing, tags = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | If response is truncated, SageMaker includes a token in the response. -- You can use this token in your subsequent request to fetch next set of -- tokens. listTagsResponse_nextToken :: Lens.Lens' ListTagsResponse (Prelude.Maybe Prelude.Text) listTagsResponse_nextToken = Lens.lens (\ListTagsResponse' {nextToken} -> nextToken) (\s@ListTagsResponse' {} a -> s {nextToken = a} :: ListTagsResponse) -- | An array of @Tag@ objects, each with a tag key and a value. listTagsResponse_tags :: Lens.Lens' ListTagsResponse (Prelude.Maybe [Tag]) listTagsResponse_tags = Lens.lens (\ListTagsResponse' {tags} -> tags) (\s@ListTagsResponse' {} a -> s {tags = a} :: ListTagsResponse) Prelude.. Lens.mapping Lens.coerced -- | The response's http status code. listTagsResponse_httpStatus :: Lens.Lens' ListTagsResponse Prelude.Int listTagsResponse_httpStatus = Lens.lens (\ListTagsResponse' {httpStatus} -> httpStatus) (\s@ListTagsResponse' {} a -> s {httpStatus = a} :: ListTagsResponse) instance Prelude.NFData ListTagsResponse where rnf ListTagsResponse' {..} = Prelude.rnf nextToken `Prelude.seq` Prelude.rnf tags `Prelude.seq` Prelude.rnf httpStatus