{-# 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.CreateDataset -- 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 create a dataset. A dataset stores data retrieved from a data -- store by applying a @queryAction@ (a SQL query) or a @containerAction@ -- (executing a containerized application). This operation creates the -- skeleton of a dataset. The dataset can be populated manually by calling -- @CreateDatasetContent@ or automatically according to a trigger you -- specify. module Amazonka.IoTAnalytics.CreateDataset ( -- * Creating a Request CreateDataset (..), newCreateDataset, -- * Request Lenses createDataset_contentDeliveryRules, createDataset_lateDataRules, createDataset_retentionPeriod, createDataset_tags, createDataset_triggers, createDataset_versioningConfiguration, createDataset_datasetName, createDataset_actions, -- * Destructuring the Response CreateDatasetResponse (..), newCreateDatasetResponse, -- * Response Lenses createDatasetResponse_datasetArn, createDatasetResponse_datasetName, createDatasetResponse_retentionPeriod, createDatasetResponse_httpStatus, ) 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:/ 'newCreateDataset' smart constructor. data CreateDataset = CreateDataset' { -- | When dataset contents are created, they are delivered to destinations -- specified here. contentDeliveryRules :: Prelude.Maybe [DatasetContentDeliveryRule], -- | A list of data rules that send notifications to CloudWatch, when data -- arrives late. To specify @lateDataRules@, the dataset must use a -- -- filter. lateDataRules :: Prelude.Maybe (Prelude.NonEmpty LateDataRule), -- | Optional. How long, in days, versions of dataset contents are kept for -- the dataset. If not specified or set to @null@, versions of dataset -- contents are retained for at most 90 days. The number of versions of -- dataset contents retained is determined by the @versioningConfiguration@ -- parameter. For more information, see -- -- in the /IoT Analytics User Guide/. retentionPeriod :: Prelude.Maybe RetentionPeriod, -- | Metadata which can be used to manage the dataset. tags :: Prelude.Maybe (Prelude.NonEmpty Tag), -- | A list of triggers. A trigger causes dataset contents to be populated at -- a specified time interval or when another dataset\'s contents are -- created. The list of triggers can be empty or contain up to five -- @DataSetTrigger@ objects. triggers :: Prelude.Maybe [DatasetTrigger], -- | Optional. How many versions of dataset contents are kept. If not -- specified or set to null, only the latest version plus the latest -- succeeded version (if they are different) are kept for the time period -- specified by the @retentionPeriod@ parameter. For more information, see -- -- in the /IoT Analytics User Guide/. versioningConfiguration :: Prelude.Maybe VersioningConfiguration, -- | The name of the dataset. datasetName :: Prelude.Text, -- | A list of actions that create the dataset contents. actions :: Prelude.NonEmpty DatasetAction } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'CreateDataset' 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: -- -- 'contentDeliveryRules', 'createDataset_contentDeliveryRules' - When dataset contents are created, they are delivered to destinations -- specified here. -- -- 'lateDataRules', 'createDataset_lateDataRules' - A list of data rules that send notifications to CloudWatch, when data -- arrives late. To specify @lateDataRules@, the dataset must use a -- -- filter. -- -- 'retentionPeriod', 'createDataset_retentionPeriod' - Optional. How long, in days, versions of dataset contents are kept for -- the dataset. If not specified or set to @null@, versions of dataset -- contents are retained for at most 90 days. The number of versions of -- dataset contents retained is determined by the @versioningConfiguration@ -- parameter. For more information, see -- -- in the /IoT Analytics User Guide/. -- -- 'tags', 'createDataset_tags' - Metadata which can be used to manage the dataset. -- -- 'triggers', 'createDataset_triggers' - A list of triggers. A trigger causes dataset contents to be populated at -- a specified time interval or when another dataset\'s contents are -- created. The list of triggers can be empty or contain up to five -- @DataSetTrigger@ objects. -- -- 'versioningConfiguration', 'createDataset_versioningConfiguration' - Optional. How many versions of dataset contents are kept. If not -- specified or set to null, only the latest version plus the latest -- succeeded version (if they are different) are kept for the time period -- specified by the @retentionPeriod@ parameter. For more information, see -- -- in the /IoT Analytics User Guide/. -- -- 'datasetName', 'createDataset_datasetName' - The name of the dataset. -- -- 'actions', 'createDataset_actions' - A list of actions that create the dataset contents. newCreateDataset :: -- | 'datasetName' Prelude.Text -> -- | 'actions' Prelude.NonEmpty DatasetAction -> CreateDataset newCreateDataset pDatasetName_ pActions_ = CreateDataset' { contentDeliveryRules = Prelude.Nothing, lateDataRules = Prelude.Nothing, retentionPeriod = Prelude.Nothing, tags = Prelude.Nothing, triggers = Prelude.Nothing, versioningConfiguration = Prelude.Nothing, datasetName = pDatasetName_, actions = Lens.coerced Lens.# pActions_ } -- | When dataset contents are created, they are delivered to destinations -- specified here. createDataset_contentDeliveryRules :: Lens.Lens' CreateDataset (Prelude.Maybe [DatasetContentDeliveryRule]) createDataset_contentDeliveryRules = Lens.lens (\CreateDataset' {contentDeliveryRules} -> contentDeliveryRules) (\s@CreateDataset' {} a -> s {contentDeliveryRules = a} :: CreateDataset) Prelude.. Lens.mapping Lens.coerced -- | A list of data rules that send notifications to CloudWatch, when data -- arrives late. To specify @lateDataRules@, the dataset must use a -- -- filter. createDataset_lateDataRules :: Lens.Lens' CreateDataset (Prelude.Maybe (Prelude.NonEmpty LateDataRule)) createDataset_lateDataRules = Lens.lens (\CreateDataset' {lateDataRules} -> lateDataRules) (\s@CreateDataset' {} a -> s {lateDataRules = a} :: CreateDataset) Prelude.. Lens.mapping Lens.coerced -- | Optional. How long, in days, versions of dataset contents are kept for -- the dataset. If not specified or set to @null@, versions of dataset -- contents are retained for at most 90 days. The number of versions of -- dataset contents retained is determined by the @versioningConfiguration@ -- parameter. For more information, see -- -- in the /IoT Analytics User Guide/. createDataset_retentionPeriod :: Lens.Lens' CreateDataset (Prelude.Maybe RetentionPeriod) createDataset_retentionPeriod = Lens.lens (\CreateDataset' {retentionPeriod} -> retentionPeriod) (\s@CreateDataset' {} a -> s {retentionPeriod = a} :: CreateDataset) -- | Metadata which can be used to manage the dataset. createDataset_tags :: Lens.Lens' CreateDataset (Prelude.Maybe (Prelude.NonEmpty Tag)) createDataset_tags = Lens.lens (\CreateDataset' {tags} -> tags) (\s@CreateDataset' {} a -> s {tags = a} :: CreateDataset) Prelude.. Lens.mapping Lens.coerced -- | A list of triggers. A trigger causes dataset contents to be populated at -- a specified time interval or when another dataset\'s contents are -- created. The list of triggers can be empty or contain up to five -- @DataSetTrigger@ objects. createDataset_triggers :: Lens.Lens' CreateDataset (Prelude.Maybe [DatasetTrigger]) createDataset_triggers = Lens.lens (\CreateDataset' {triggers} -> triggers) (\s@CreateDataset' {} a -> s {triggers = a} :: CreateDataset) Prelude.. Lens.mapping Lens.coerced -- | Optional. How many versions of dataset contents are kept. If not -- specified or set to null, only the latest version plus the latest -- succeeded version (if they are different) are kept for the time period -- specified by the @retentionPeriod@ parameter. For more information, see -- -- in the /IoT Analytics User Guide/. createDataset_versioningConfiguration :: Lens.Lens' CreateDataset (Prelude.Maybe VersioningConfiguration) createDataset_versioningConfiguration = Lens.lens (\CreateDataset' {versioningConfiguration} -> versioningConfiguration) (\s@CreateDataset' {} a -> s {versioningConfiguration = a} :: CreateDataset) -- | The name of the dataset. createDataset_datasetName :: Lens.Lens' CreateDataset Prelude.Text createDataset_datasetName = Lens.lens (\CreateDataset' {datasetName} -> datasetName) (\s@CreateDataset' {} a -> s {datasetName = a} :: CreateDataset) -- | A list of actions that create the dataset contents. createDataset_actions :: Lens.Lens' CreateDataset (Prelude.NonEmpty DatasetAction) createDataset_actions = Lens.lens (\CreateDataset' {actions} -> actions) (\s@CreateDataset' {} a -> s {actions = a} :: CreateDataset) Prelude.. Lens.coerced instance Core.AWSRequest CreateDataset where type AWSResponse CreateDataset = CreateDatasetResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> CreateDatasetResponse' Prelude.<$> (x Data..?> "datasetArn") Prelude.<*> (x Data..?> "datasetName") Prelude.<*> (x Data..?> "retentionPeriod") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable CreateDataset where hashWithSalt _salt CreateDataset' {..} = _salt `Prelude.hashWithSalt` contentDeliveryRules `Prelude.hashWithSalt` lateDataRules `Prelude.hashWithSalt` retentionPeriod `Prelude.hashWithSalt` tags `Prelude.hashWithSalt` triggers `Prelude.hashWithSalt` versioningConfiguration `Prelude.hashWithSalt` datasetName `Prelude.hashWithSalt` actions instance Prelude.NFData CreateDataset where rnf CreateDataset' {..} = Prelude.rnf contentDeliveryRules `Prelude.seq` Prelude.rnf lateDataRules `Prelude.seq` Prelude.rnf retentionPeriod `Prelude.seq` Prelude.rnf tags `Prelude.seq` Prelude.rnf triggers `Prelude.seq` Prelude.rnf versioningConfiguration `Prelude.seq` Prelude.rnf datasetName `Prelude.seq` Prelude.rnf actions instance Data.ToHeaders CreateDataset where toHeaders = Prelude.const Prelude.mempty instance Data.ToJSON CreateDataset where toJSON CreateDataset' {..} = Data.object ( Prelude.catMaybes [ ("contentDeliveryRules" Data..=) Prelude.<$> contentDeliveryRules, ("lateDataRules" Data..=) Prelude.<$> lateDataRules, ("retentionPeriod" Data..=) Prelude.<$> retentionPeriod, ("tags" Data..=) Prelude.<$> tags, ("triggers" Data..=) Prelude.<$> triggers, ("versioningConfiguration" Data..=) Prelude.<$> versioningConfiguration, Prelude.Just ("datasetName" Data..= datasetName), Prelude.Just ("actions" Data..= actions) ] ) instance Data.ToPath CreateDataset where toPath = Prelude.const "/datasets" instance Data.ToQuery CreateDataset where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newCreateDatasetResponse' smart constructor. data CreateDatasetResponse = CreateDatasetResponse' { -- | The ARN of the dataset. datasetArn :: Prelude.Maybe Prelude.Text, -- | The name of the dataset. datasetName :: Prelude.Maybe Prelude.Text, -- | How long, in days, dataset contents are kept for the dataset. retentionPeriod :: Prelude.Maybe RetentionPeriod, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'CreateDatasetResponse' 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: -- -- 'datasetArn', 'createDatasetResponse_datasetArn' - The ARN of the dataset. -- -- 'datasetName', 'createDatasetResponse_datasetName' - The name of the dataset. -- -- 'retentionPeriod', 'createDatasetResponse_retentionPeriod' - How long, in days, dataset contents are kept for the dataset. -- -- 'httpStatus', 'createDatasetResponse_httpStatus' - The response's http status code. newCreateDatasetResponse :: -- | 'httpStatus' Prelude.Int -> CreateDatasetResponse newCreateDatasetResponse pHttpStatus_ = CreateDatasetResponse' { datasetArn = Prelude.Nothing, datasetName = Prelude.Nothing, retentionPeriod = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The ARN of the dataset. createDatasetResponse_datasetArn :: Lens.Lens' CreateDatasetResponse (Prelude.Maybe Prelude.Text) createDatasetResponse_datasetArn = Lens.lens (\CreateDatasetResponse' {datasetArn} -> datasetArn) (\s@CreateDatasetResponse' {} a -> s {datasetArn = a} :: CreateDatasetResponse) -- | The name of the dataset. createDatasetResponse_datasetName :: Lens.Lens' CreateDatasetResponse (Prelude.Maybe Prelude.Text) createDatasetResponse_datasetName = Lens.lens (\CreateDatasetResponse' {datasetName} -> datasetName) (\s@CreateDatasetResponse' {} a -> s {datasetName = a} :: CreateDatasetResponse) -- | How long, in days, dataset contents are kept for the dataset. createDatasetResponse_retentionPeriod :: Lens.Lens' CreateDatasetResponse (Prelude.Maybe RetentionPeriod) createDatasetResponse_retentionPeriod = Lens.lens (\CreateDatasetResponse' {retentionPeriod} -> retentionPeriod) (\s@CreateDatasetResponse' {} a -> s {retentionPeriod = a} :: CreateDatasetResponse) -- | The response's http status code. createDatasetResponse_httpStatus :: Lens.Lens' CreateDatasetResponse Prelude.Int createDatasetResponse_httpStatus = Lens.lens (\CreateDatasetResponse' {httpStatus} -> httpStatus) (\s@CreateDatasetResponse' {} a -> s {httpStatus = a} :: CreateDatasetResponse) instance Prelude.NFData CreateDatasetResponse where rnf CreateDatasetResponse' {..} = Prelude.rnf datasetArn `Prelude.seq` Prelude.rnf datasetName `Prelude.seq` Prelude.rnf retentionPeriod `Prelude.seq` Prelude.rnf httpStatus