{-# 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.IoTAnalytics.UpdateDatastore -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Used to update the settings of a data store. module Amazonka.IoTAnalytics.UpdateDatastore ( -- * Creating a Request UpdateDatastore (..), newUpdateDatastore, -- * Request Lenses updateDatastore_datastoreStorage, updateDatastore_fileFormatConfiguration, updateDatastore_retentionPeriod, updateDatastore_datastoreName, -- * Destructuring the Response UpdateDatastoreResponse (..), newUpdateDatastoreResponse, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.IoTAnalytics.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newUpdateDatastore' smart constructor. data UpdateDatastore = UpdateDatastore' { -- | Where data in a data store is stored.. You can choose @serviceManagedS3@ -- storage, @customerManagedS3@ storage, or @iotSiteWiseMultiLayerStorage@ -- storage. The default is @serviceManagedS3@. You can\'t change the choice -- of Amazon S3 storage after your data store is created. datastoreStorage :: Prelude.Maybe DatastoreStorage, -- | Contains the configuration information of file formats. IoT Analytics -- data stores support JSON and . -- -- The default file format is JSON. You can specify only one format. -- -- You can\'t change the file format after you create the data store. fileFormatConfiguration :: Prelude.Maybe FileFormatConfiguration, -- | How long, in days, message data is kept for the data store. The -- retention period can\'t be updated if the data store\'s Amazon S3 -- storage is customer-managed. retentionPeriod :: Prelude.Maybe RetentionPeriod, -- | The name of the data store to be updated. datastoreName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateDatastore' 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: -- -- 'datastoreStorage', 'updateDatastore_datastoreStorage' - Where data in a data store is stored.. You can choose @serviceManagedS3@ -- storage, @customerManagedS3@ storage, or @iotSiteWiseMultiLayerStorage@ -- storage. The default is @serviceManagedS3@. You can\'t change the choice -- of Amazon S3 storage after your data store is created. -- -- 'fileFormatConfiguration', 'updateDatastore_fileFormatConfiguration' - Contains the configuration information of file formats. IoT Analytics -- data stores support JSON and . -- -- The default file format is JSON. You can specify only one format. -- -- You can\'t change the file format after you create the data store. -- -- 'retentionPeriod', 'updateDatastore_retentionPeriod' - How long, in days, message data is kept for the data store. The -- retention period can\'t be updated if the data store\'s Amazon S3 -- storage is customer-managed. -- -- 'datastoreName', 'updateDatastore_datastoreName' - The name of the data store to be updated. newUpdateDatastore :: -- | 'datastoreName' Prelude.Text -> UpdateDatastore newUpdateDatastore pDatastoreName_ = UpdateDatastore' { datastoreStorage = Prelude.Nothing, fileFormatConfiguration = Prelude.Nothing, retentionPeriod = Prelude.Nothing, datastoreName = pDatastoreName_ } -- | Where data in a data store is stored.. You can choose @serviceManagedS3@ -- storage, @customerManagedS3@ storage, or @iotSiteWiseMultiLayerStorage@ -- storage. The default is @serviceManagedS3@. You can\'t change the choice -- of Amazon S3 storage after your data store is created. updateDatastore_datastoreStorage :: Lens.Lens' UpdateDatastore (Prelude.Maybe DatastoreStorage) updateDatastore_datastoreStorage = Lens.lens (\UpdateDatastore' {datastoreStorage} -> datastoreStorage) (\s@UpdateDatastore' {} a -> s {datastoreStorage = a} :: UpdateDatastore) -- | Contains the configuration information of file formats. IoT Analytics -- data stores support JSON and . -- -- The default file format is JSON. You can specify only one format. -- -- You can\'t change the file format after you create the data store. updateDatastore_fileFormatConfiguration :: Lens.Lens' UpdateDatastore (Prelude.Maybe FileFormatConfiguration) updateDatastore_fileFormatConfiguration = Lens.lens (\UpdateDatastore' {fileFormatConfiguration} -> fileFormatConfiguration) (\s@UpdateDatastore' {} a -> s {fileFormatConfiguration = a} :: UpdateDatastore) -- | How long, in days, message data is kept for the data store. The -- retention period can\'t be updated if the data store\'s Amazon S3 -- storage is customer-managed. updateDatastore_retentionPeriod :: Lens.Lens' UpdateDatastore (Prelude.Maybe RetentionPeriod) updateDatastore_retentionPeriod = Lens.lens (\UpdateDatastore' {retentionPeriod} -> retentionPeriod) (\s@UpdateDatastore' {} a -> s {retentionPeriod = a} :: UpdateDatastore) -- | The name of the data store to be updated. updateDatastore_datastoreName :: Lens.Lens' UpdateDatastore Prelude.Text updateDatastore_datastoreName = Lens.lens (\UpdateDatastore' {datastoreName} -> datastoreName) (\s@UpdateDatastore' {} a -> s {datastoreName = a} :: UpdateDatastore) instance Core.AWSRequest UpdateDatastore where type AWSResponse UpdateDatastore = UpdateDatastoreResponse request overrides = Request.putJSON (overrides defaultService) response = Response.receiveNull UpdateDatastoreResponse' instance Prelude.Hashable UpdateDatastore where hashWithSalt _salt UpdateDatastore' {..} = _salt `Prelude.hashWithSalt` datastoreStorage `Prelude.hashWithSalt` fileFormatConfiguration `Prelude.hashWithSalt` retentionPeriod `Prelude.hashWithSalt` datastoreName instance Prelude.NFData UpdateDatastore where rnf UpdateDatastore' {..} = Prelude.rnf datastoreStorage `Prelude.seq` Prelude.rnf fileFormatConfiguration `Prelude.seq` Prelude.rnf retentionPeriod `Prelude.seq` Prelude.rnf datastoreName instance Data.ToHeaders UpdateDatastore where toHeaders = Prelude.const Prelude.mempty instance Data.ToJSON UpdateDatastore where toJSON UpdateDatastore' {..} = Data.object ( Prelude.catMaybes [ ("datastoreStorage" Data..=) Prelude.<$> datastoreStorage, ("fileFormatConfiguration" Data..=) Prelude.<$> fileFormatConfiguration, ("retentionPeriod" Data..=) Prelude.<$> retentionPeriod ] ) instance Data.ToPath UpdateDatastore where toPath UpdateDatastore' {..} = Prelude.mconcat ["/datastores/", Data.toBS datastoreName] instance Data.ToQuery UpdateDatastore where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newUpdateDatastoreResponse' smart constructor. data UpdateDatastoreResponse = UpdateDatastoreResponse' { } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateDatastoreResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. newUpdateDatastoreResponse :: UpdateDatastoreResponse newUpdateDatastoreResponse = UpdateDatastoreResponse' instance Prelude.NFData UpdateDatastoreResponse where rnf _ = ()