{-# 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.UpdateTimeToLive -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- The @UpdateTimeToLive@ method enables or disables Time to Live (TTL) for -- the specified table. A successful @UpdateTimeToLive@ call returns the -- current @TimeToLiveSpecification@. It can take up to one hour for the -- change to fully process. Any additional @UpdateTimeToLive@ calls for the -- same table during this one hour duration result in a -- @ValidationException@. -- -- TTL compares the current time in epoch time format to the time stored in -- the TTL attribute of an item. If the epoch time value stored in the -- attribute is less than the current time, the item is marked as expired -- and subsequently deleted. -- -- The epoch time format is the number of seconds elapsed since 12:00:00 AM -- January 1, 1970 UTC. -- -- DynamoDB deletes expired items on a best-effort basis to ensure -- availability of throughput for other data operations. -- -- DynamoDB typically deletes expired items within two days of expiration. -- The exact duration within which an item gets deleted after expiration is -- specific to the nature of the workload. Items that have expired and not -- been deleted will still show up in reads, queries, and scans. -- -- As items are deleted, they are removed from any local secondary index -- and global secondary index immediately in the same eventually consistent -- way as a standard delete operation. -- -- For more information, see -- -- in the Amazon DynamoDB Developer Guide. module Amazonka.DynamoDB.UpdateTimeToLive ( -- * Creating a Request UpdateTimeToLive (..), newUpdateTimeToLive, -- * Request Lenses updateTimeToLive_tableName, updateTimeToLive_timeToLiveSpecification, -- * Destructuring the Response UpdateTimeToLiveResponse (..), newUpdateTimeToLiveResponse, -- * Response Lenses updateTimeToLiveResponse_timeToLiveSpecification, updateTimeToLiveResponse_httpStatus, ) 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 -- | Represents the input of an @UpdateTimeToLive@ operation. -- -- /See:/ 'newUpdateTimeToLive' smart constructor. data UpdateTimeToLive = UpdateTimeToLive' { -- | The name of the table to be configured. tableName :: Prelude.Text, -- | Represents the settings used to enable or disable Time to Live for the -- specified table. timeToLiveSpecification :: TimeToLiveSpecification } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateTimeToLive' 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', 'updateTimeToLive_tableName' - The name of the table to be configured. -- -- 'timeToLiveSpecification', 'updateTimeToLive_timeToLiveSpecification' - Represents the settings used to enable or disable Time to Live for the -- specified table. newUpdateTimeToLive :: -- | 'tableName' Prelude.Text -> -- | 'timeToLiveSpecification' TimeToLiveSpecification -> UpdateTimeToLive newUpdateTimeToLive pTableName_ pTimeToLiveSpecification_ = UpdateTimeToLive' { tableName = pTableName_, timeToLiveSpecification = pTimeToLiveSpecification_ } -- | The name of the table to be configured. updateTimeToLive_tableName :: Lens.Lens' UpdateTimeToLive Prelude.Text updateTimeToLive_tableName = Lens.lens (\UpdateTimeToLive' {tableName} -> tableName) (\s@UpdateTimeToLive' {} a -> s {tableName = a} :: UpdateTimeToLive) -- | Represents the settings used to enable or disable Time to Live for the -- specified table. updateTimeToLive_timeToLiveSpecification :: Lens.Lens' UpdateTimeToLive TimeToLiveSpecification updateTimeToLive_timeToLiveSpecification = Lens.lens (\UpdateTimeToLive' {timeToLiveSpecification} -> timeToLiveSpecification) (\s@UpdateTimeToLive' {} a -> s {timeToLiveSpecification = a} :: UpdateTimeToLive) instance Core.AWSRequest UpdateTimeToLive where type AWSResponse UpdateTimeToLive = UpdateTimeToLiveResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> UpdateTimeToLiveResponse' Prelude.<$> (x Data..?> "TimeToLiveSpecification") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable UpdateTimeToLive where hashWithSalt _salt UpdateTimeToLive' {..} = _salt `Prelude.hashWithSalt` tableName `Prelude.hashWithSalt` timeToLiveSpecification instance Prelude.NFData UpdateTimeToLive where rnf UpdateTimeToLive' {..} = Prelude.rnf tableName `Prelude.seq` Prelude.rnf timeToLiveSpecification instance Data.ToHeaders UpdateTimeToLive where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "DynamoDB_20120810.UpdateTimeToLive" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.0" :: Prelude.ByteString ) ] ) instance Data.ToJSON UpdateTimeToLive where toJSON UpdateTimeToLive' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("TableName" Data..= tableName), Prelude.Just ( "TimeToLiveSpecification" Data..= timeToLiveSpecification ) ] ) instance Data.ToPath UpdateTimeToLive where toPath = Prelude.const "/" instance Data.ToQuery UpdateTimeToLive where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newUpdateTimeToLiveResponse' smart constructor. data UpdateTimeToLiveResponse = UpdateTimeToLiveResponse' { -- | Represents the output of an @UpdateTimeToLive@ operation. timeToLiveSpecification :: Prelude.Maybe TimeToLiveSpecification, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateTimeToLiveResponse' 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: -- -- 'timeToLiveSpecification', 'updateTimeToLiveResponse_timeToLiveSpecification' - Represents the output of an @UpdateTimeToLive@ operation. -- -- 'httpStatus', 'updateTimeToLiveResponse_httpStatus' - The response's http status code. newUpdateTimeToLiveResponse :: -- | 'httpStatus' Prelude.Int -> UpdateTimeToLiveResponse newUpdateTimeToLiveResponse pHttpStatus_ = UpdateTimeToLiveResponse' { timeToLiveSpecification = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Represents the output of an @UpdateTimeToLive@ operation. updateTimeToLiveResponse_timeToLiveSpecification :: Lens.Lens' UpdateTimeToLiveResponse (Prelude.Maybe TimeToLiveSpecification) updateTimeToLiveResponse_timeToLiveSpecification = Lens.lens (\UpdateTimeToLiveResponse' {timeToLiveSpecification} -> timeToLiveSpecification) (\s@UpdateTimeToLiveResponse' {} a -> s {timeToLiveSpecification = a} :: UpdateTimeToLiveResponse) -- | The response's http status code. updateTimeToLiveResponse_httpStatus :: Lens.Lens' UpdateTimeToLiveResponse Prelude.Int updateTimeToLiveResponse_httpStatus = Lens.lens (\UpdateTimeToLiveResponse' {httpStatus} -> httpStatus) (\s@UpdateTimeToLiveResponse' {} a -> s {httpStatus = a} :: UpdateTimeToLiveResponse) instance Prelude.NFData UpdateTimeToLiveResponse where rnf UpdateTimeToLiveResponse' {..} = Prelude.rnf timeToLiveSpecification `Prelude.seq` Prelude.rnf httpStatus