{-# 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.Kinesis.AddTagsToStream -- 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 or updates tags for the specified Kinesis data stream. You can -- assign up to 50 tags to a data stream. -- -- When invoking this API, it is recommended you use the @StreamARN@ input -- parameter rather than the @StreamName@ input parameter. -- -- If tags have already been assigned to the stream, @AddTagsToStream@ -- overwrites any existing tags that correspond to the specified tag keys. -- -- AddTagsToStream has a limit of five transactions per second per account. module Amazonka.Kinesis.AddTagsToStream ( -- * Creating a Request AddTagsToStream (..), newAddTagsToStream, -- * Request Lenses addTagsToStream_streamARN, addTagsToStream_streamName, addTagsToStream_tags, -- * Destructuring the Response AddTagsToStreamResponse (..), newAddTagsToStreamResponse, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.Kinesis.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | Represents the input for @AddTagsToStream@. -- -- /See:/ 'newAddTagsToStream' smart constructor. data AddTagsToStream = AddTagsToStream' { -- | The ARN of the stream. streamARN :: Prelude.Maybe Prelude.Text, -- | The name of the stream. streamName :: Prelude.Maybe Prelude.Text, -- | A set of up to 10 key-value pairs to use to create the tags. tags :: Prelude.HashMap Prelude.Text Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'AddTagsToStream' 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: -- -- 'streamARN', 'addTagsToStream_streamARN' - The ARN of the stream. -- -- 'streamName', 'addTagsToStream_streamName' - The name of the stream. -- -- 'tags', 'addTagsToStream_tags' - A set of up to 10 key-value pairs to use to create the tags. newAddTagsToStream :: AddTagsToStream newAddTagsToStream = AddTagsToStream' { streamARN = Prelude.Nothing, streamName = Prelude.Nothing, tags = Prelude.mempty } -- | The ARN of the stream. addTagsToStream_streamARN :: Lens.Lens' AddTagsToStream (Prelude.Maybe Prelude.Text) addTagsToStream_streamARN = Lens.lens (\AddTagsToStream' {streamARN} -> streamARN) (\s@AddTagsToStream' {} a -> s {streamARN = a} :: AddTagsToStream) -- | The name of the stream. addTagsToStream_streamName :: Lens.Lens' AddTagsToStream (Prelude.Maybe Prelude.Text) addTagsToStream_streamName = Lens.lens (\AddTagsToStream' {streamName} -> streamName) (\s@AddTagsToStream' {} a -> s {streamName = a} :: AddTagsToStream) -- | A set of up to 10 key-value pairs to use to create the tags. addTagsToStream_tags :: Lens.Lens' AddTagsToStream (Prelude.HashMap Prelude.Text Prelude.Text) addTagsToStream_tags = Lens.lens (\AddTagsToStream' {tags} -> tags) (\s@AddTagsToStream' {} a -> s {tags = a} :: AddTagsToStream) Prelude.. Lens.coerced instance Core.AWSRequest AddTagsToStream where type AWSResponse AddTagsToStream = AddTagsToStreamResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveNull AddTagsToStreamResponse' instance Prelude.Hashable AddTagsToStream where hashWithSalt _salt AddTagsToStream' {..} = _salt `Prelude.hashWithSalt` streamARN `Prelude.hashWithSalt` streamName `Prelude.hashWithSalt` tags instance Prelude.NFData AddTagsToStream where rnf AddTagsToStream' {..} = Prelude.rnf streamARN `Prelude.seq` Prelude.rnf streamName `Prelude.seq` Prelude.rnf tags instance Data.ToHeaders AddTagsToStream where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "Kinesis_20131202.AddTagsToStream" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON AddTagsToStream where toJSON AddTagsToStream' {..} = Data.object ( Prelude.catMaybes [ ("StreamARN" Data..=) Prelude.<$> streamARN, ("StreamName" Data..=) Prelude.<$> streamName, Prelude.Just ("Tags" Data..= tags) ] ) instance Data.ToPath AddTagsToStream where toPath = Prelude.const "/" instance Data.ToQuery AddTagsToStream where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newAddTagsToStreamResponse' smart constructor. data AddTagsToStreamResponse = AddTagsToStreamResponse' { } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'AddTagsToStreamResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. newAddTagsToStreamResponse :: AddTagsToStreamResponse newAddTagsToStreamResponse = AddTagsToStreamResponse' instance Prelude.NFData AddTagsToStreamResponse where rnf _ = ()