{-# 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.ResourceGroups.Tag -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Adds tags to a resource group with the specified ARN. Existing tags on a -- resource group are not changed if they are not specified in the request -- parameters. -- -- Do not store personally identifiable information (PII) or other -- confidential or sensitive information in tags. We use tags to provide -- you with billing and administration services. Tags are not intended to -- be used for private or sensitive data. -- -- __Minimum permissions__ -- -- To run this command, you must have the following permissions: -- -- - @resource-groups:Tag@ module Amazonka.ResourceGroups.Tag ( -- * Creating a Request Tag (..), newTag, -- * Request Lenses tag_arn, tag_tags, -- * Destructuring the Response TagResponse (..), newTagResponse, -- * Response Lenses tagResponse_arn, tagResponse_tags, tagResponse_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 Amazonka.ResourceGroups.Types import qualified Amazonka.Response as Response -- | /See:/ 'newTag' smart constructor. data Tag = Tag' { -- | The ARN of the resource group to which to add tags. arn :: Prelude.Text, -- | The tags to add to the specified resource group. A tag is a -- string-to-string map of key-value pairs. tags :: Prelude.HashMap Prelude.Text Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'Tag' 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: -- -- 'arn', 'tag_arn' - The ARN of the resource group to which to add tags. -- -- 'tags', 'tag_tags' - The tags to add to the specified resource group. A tag is a -- string-to-string map of key-value pairs. newTag :: -- | 'arn' Prelude.Text -> Tag newTag pArn_ = Tag' {arn = pArn_, tags = Prelude.mempty} -- | The ARN of the resource group to which to add tags. tag_arn :: Lens.Lens' Tag Prelude.Text tag_arn = Lens.lens (\Tag' {arn} -> arn) (\s@Tag' {} a -> s {arn = a} :: Tag) -- | The tags to add to the specified resource group. A tag is a -- string-to-string map of key-value pairs. tag_tags :: Lens.Lens' Tag (Prelude.HashMap Prelude.Text Prelude.Text) tag_tags = Lens.lens (\Tag' {tags} -> tags) (\s@Tag' {} a -> s {tags = a} :: Tag) Prelude.. Lens.coerced instance Core.AWSRequest Tag where type AWSResponse Tag = TagResponse request overrides = Request.putJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> TagResponse' Prelude.<$> (x Data..?> "Arn") Prelude.<*> (x Data..?> "Tags" Core..!@ Prelude.mempty) Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable Tag where hashWithSalt _salt Tag' {..} = _salt `Prelude.hashWithSalt` arn `Prelude.hashWithSalt` tags instance Prelude.NFData Tag where rnf Tag' {..} = Prelude.rnf arn `Prelude.seq` Prelude.rnf tags instance Data.ToHeaders Tag where toHeaders = Prelude.const Prelude.mempty instance Data.ToJSON Tag where toJSON Tag' {..} = Data.object ( Prelude.catMaybes [Prelude.Just ("Tags" Data..= tags)] ) instance Data.ToPath Tag where toPath Tag' {..} = Prelude.mconcat ["/resources/", Data.toBS arn, "/tags"] instance Data.ToQuery Tag where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newTagResponse' smart constructor. data TagResponse = TagResponse' { -- | The ARN of the tagged resource. arn :: Prelude.Maybe Prelude.Text, -- | The tags that have been added to the specified resource group. tags :: Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text), -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'TagResponse' 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: -- -- 'arn', 'tagResponse_arn' - The ARN of the tagged resource. -- -- 'tags', 'tagResponse_tags' - The tags that have been added to the specified resource group. -- -- 'httpStatus', 'tagResponse_httpStatus' - The response's http status code. newTagResponse :: -- | 'httpStatus' Prelude.Int -> TagResponse newTagResponse pHttpStatus_ = TagResponse' { arn = Prelude.Nothing, tags = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The ARN of the tagged resource. tagResponse_arn :: Lens.Lens' TagResponse (Prelude.Maybe Prelude.Text) tagResponse_arn = Lens.lens (\TagResponse' {arn} -> arn) (\s@TagResponse' {} a -> s {arn = a} :: TagResponse) -- | The tags that have been added to the specified resource group. tagResponse_tags :: Lens.Lens' TagResponse (Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text)) tagResponse_tags = Lens.lens (\TagResponse' {tags} -> tags) (\s@TagResponse' {} a -> s {tags = a} :: TagResponse) Prelude.. Lens.mapping Lens.coerced -- | The response's http status code. tagResponse_httpStatus :: Lens.Lens' TagResponse Prelude.Int tagResponse_httpStatus = Lens.lens (\TagResponse' {httpStatus} -> httpStatus) (\s@TagResponse' {} a -> s {httpStatus = a} :: TagResponse) instance Prelude.NFData TagResponse where rnf TagResponse' {..} = Prelude.rnf arn `Prelude.seq` Prelude.rnf tags `Prelude.seq` Prelude.rnf httpStatus