{-# 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.DynamoDB.EnableKinesisStreamingDestination -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Starts table data replication to the specified Kinesis data stream at a -- timestamp chosen during the enable workflow. If this operation doesn\'t -- return results immediately, use DescribeKinesisStreamingDestination to -- check if streaming to the Kinesis data stream is ACTIVE. module Amazonka.DynamoDB.EnableKinesisStreamingDestination ( -- * Creating a Request EnableKinesisStreamingDestination (..), newEnableKinesisStreamingDestination, -- * Request Lenses enableKinesisStreamingDestination_tableName, enableKinesisStreamingDestination_streamArn, -- * Destructuring the Response KinesisStreamingDestinationOutput (..), newKinesisStreamingDestinationOutput, -- * Response Lenses kinesisStreamingDestinationOutput_destinationStatus, kinesisStreamingDestinationOutput_streamArn, kinesisStreamingDestinationOutput_tableName, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.DynamoDB.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newEnableKinesisStreamingDestination' smart constructor. data EnableKinesisStreamingDestination = EnableKinesisStreamingDestination' { -- | The name of the DynamoDB table. tableName :: Prelude.Text, -- | The ARN for a Kinesis data stream. streamArn :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'EnableKinesisStreamingDestination' 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: -- -- 'tableName', 'enableKinesisStreamingDestination_tableName' - The name of the DynamoDB table. -- -- 'streamArn', 'enableKinesisStreamingDestination_streamArn' - The ARN for a Kinesis data stream. newEnableKinesisStreamingDestination :: -- | 'tableName' Prelude.Text -> -- | 'streamArn' Prelude.Text -> EnableKinesisStreamingDestination newEnableKinesisStreamingDestination pTableName_ pStreamArn_ = EnableKinesisStreamingDestination' { tableName = pTableName_, streamArn = pStreamArn_ } -- | The name of the DynamoDB table. enableKinesisStreamingDestination_tableName :: Lens.Lens' EnableKinesisStreamingDestination Prelude.Text enableKinesisStreamingDestination_tableName = Lens.lens (\EnableKinesisStreamingDestination' {tableName} -> tableName) (\s@EnableKinesisStreamingDestination' {} a -> s {tableName = a} :: EnableKinesisStreamingDestination) -- | The ARN for a Kinesis data stream. enableKinesisStreamingDestination_streamArn :: Lens.Lens' EnableKinesisStreamingDestination Prelude.Text enableKinesisStreamingDestination_streamArn = Lens.lens (\EnableKinesisStreamingDestination' {streamArn} -> streamArn) (\s@EnableKinesisStreamingDestination' {} a -> s {streamArn = a} :: EnableKinesisStreamingDestination) instance Core.AWSRequest EnableKinesisStreamingDestination where type AWSResponse EnableKinesisStreamingDestination = KinesisStreamingDestinationOutput request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON (\s h x -> Data.eitherParseJSON x) instance Prelude.Hashable EnableKinesisStreamingDestination where hashWithSalt _salt EnableKinesisStreamingDestination' {..} = _salt `Prelude.hashWithSalt` tableName `Prelude.hashWithSalt` streamArn instance Prelude.NFData EnableKinesisStreamingDestination where rnf EnableKinesisStreamingDestination' {..} = Prelude.rnf tableName `Prelude.seq` Prelude.rnf streamArn instance Data.ToHeaders EnableKinesisStreamingDestination where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "DynamoDB_20120810.EnableKinesisStreamingDestination" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.0" :: Prelude.ByteString ) ] ) instance Data.ToJSON EnableKinesisStreamingDestination where toJSON EnableKinesisStreamingDestination' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("TableName" Data..= tableName), Prelude.Just ("StreamArn" Data..= streamArn) ] ) instance Data.ToPath EnableKinesisStreamingDestination where toPath = Prelude.const "/" instance Data.ToQuery EnableKinesisStreamingDestination where toQuery = Prelude.const Prelude.mempty