{-# 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.Forecast.UpdateDatasetGroup -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Replaces the datasets in a dataset group with the specified datasets. -- -- The @Status@ of the dataset group must be @ACTIVE@ before you can use -- the dataset group to create a predictor. Use the -- -- operation to get the status. module Amazonka.Forecast.UpdateDatasetGroup ( -- * Creating a Request UpdateDatasetGroup (..), newUpdateDatasetGroup, -- * Request Lenses updateDatasetGroup_datasetGroupArn, updateDatasetGroup_datasetArns, -- * Destructuring the Response UpdateDatasetGroupResponse (..), newUpdateDatasetGroupResponse, -- * Response Lenses updateDatasetGroupResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.Forecast.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newUpdateDatasetGroup' smart constructor. data UpdateDatasetGroup = UpdateDatasetGroup' { -- | The ARN of the dataset group. datasetGroupArn :: Prelude.Text, -- | An array of the Amazon Resource Names (ARNs) of the datasets to add to -- the dataset group. datasetArns :: [Prelude.Text] } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateDatasetGroup' 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: -- -- 'datasetGroupArn', 'updateDatasetGroup_datasetGroupArn' - The ARN of the dataset group. -- -- 'datasetArns', 'updateDatasetGroup_datasetArns' - An array of the Amazon Resource Names (ARNs) of the datasets to add to -- the dataset group. newUpdateDatasetGroup :: -- | 'datasetGroupArn' Prelude.Text -> UpdateDatasetGroup newUpdateDatasetGroup pDatasetGroupArn_ = UpdateDatasetGroup' { datasetGroupArn = pDatasetGroupArn_, datasetArns = Prelude.mempty } -- | The ARN of the dataset group. updateDatasetGroup_datasetGroupArn :: Lens.Lens' UpdateDatasetGroup Prelude.Text updateDatasetGroup_datasetGroupArn = Lens.lens (\UpdateDatasetGroup' {datasetGroupArn} -> datasetGroupArn) (\s@UpdateDatasetGroup' {} a -> s {datasetGroupArn = a} :: UpdateDatasetGroup) -- | An array of the Amazon Resource Names (ARNs) of the datasets to add to -- the dataset group. updateDatasetGroup_datasetArns :: Lens.Lens' UpdateDatasetGroup [Prelude.Text] updateDatasetGroup_datasetArns = Lens.lens (\UpdateDatasetGroup' {datasetArns} -> datasetArns) (\s@UpdateDatasetGroup' {} a -> s {datasetArns = a} :: UpdateDatasetGroup) Prelude.. Lens.coerced instance Core.AWSRequest UpdateDatasetGroup where type AWSResponse UpdateDatasetGroup = UpdateDatasetGroupResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveEmpty ( \s h x -> UpdateDatasetGroupResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable UpdateDatasetGroup where hashWithSalt _salt UpdateDatasetGroup' {..} = _salt `Prelude.hashWithSalt` datasetGroupArn `Prelude.hashWithSalt` datasetArns instance Prelude.NFData UpdateDatasetGroup where rnf UpdateDatasetGroup' {..} = Prelude.rnf datasetGroupArn `Prelude.seq` Prelude.rnf datasetArns instance Data.ToHeaders UpdateDatasetGroup where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AmazonForecast.UpdateDatasetGroup" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON UpdateDatasetGroup where toJSON UpdateDatasetGroup' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("DatasetGroupArn" Data..= datasetGroupArn), Prelude.Just ("DatasetArns" Data..= datasetArns) ] ) instance Data.ToPath UpdateDatasetGroup where toPath = Prelude.const "/" instance Data.ToQuery UpdateDatasetGroup where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newUpdateDatasetGroupResponse' smart constructor. data UpdateDatasetGroupResponse = UpdateDatasetGroupResponse' { -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateDatasetGroupResponse' 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: -- -- 'httpStatus', 'updateDatasetGroupResponse_httpStatus' - The response's http status code. newUpdateDatasetGroupResponse :: -- | 'httpStatus' Prelude.Int -> UpdateDatasetGroupResponse newUpdateDatasetGroupResponse pHttpStatus_ = UpdateDatasetGroupResponse' { httpStatus = pHttpStatus_ } -- | The response's http status code. updateDatasetGroupResponse_httpStatus :: Lens.Lens' UpdateDatasetGroupResponse Prelude.Int updateDatasetGroupResponse_httpStatus = Lens.lens (\UpdateDatasetGroupResponse' {httpStatus} -> httpStatus) (\s@UpdateDatasetGroupResponse' {} a -> s {httpStatus = a} :: UpdateDatasetGroupResponse) instance Prelude.NFData UpdateDatasetGroupResponse where rnf UpdateDatasetGroupResponse' {..} = Prelude.rnf httpStatus