{-# 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.MachineLearning.UpdateDataSource -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Updates the @DataSourceName@ of a @DataSource@. -- -- You can use the @GetDataSource@ operation to view the contents of the -- updated data element. module Amazonka.MachineLearning.UpdateDataSource ( -- * Creating a Request UpdateDataSource (..), newUpdateDataSource, -- * Request Lenses updateDataSource_dataSourceId, updateDataSource_dataSourceName, -- * Destructuring the Response UpdateDataSourceResponse (..), newUpdateDataSourceResponse, -- * Response Lenses updateDataSourceResponse_dataSourceId, updateDataSourceResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.MachineLearning.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newUpdateDataSource' smart constructor. data UpdateDataSource = UpdateDataSource' { -- | The ID assigned to the @DataSource@ during creation. dataSourceId :: Prelude.Text, -- | A new user-supplied name or description of the @DataSource@ that will -- replace the current description. dataSourceName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateDataSource' 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: -- -- 'dataSourceId', 'updateDataSource_dataSourceId' - The ID assigned to the @DataSource@ during creation. -- -- 'dataSourceName', 'updateDataSource_dataSourceName' - A new user-supplied name or description of the @DataSource@ that will -- replace the current description. newUpdateDataSource :: -- | 'dataSourceId' Prelude.Text -> -- | 'dataSourceName' Prelude.Text -> UpdateDataSource newUpdateDataSource pDataSourceId_ pDataSourceName_ = UpdateDataSource' { dataSourceId = pDataSourceId_, dataSourceName = pDataSourceName_ } -- | The ID assigned to the @DataSource@ during creation. updateDataSource_dataSourceId :: Lens.Lens' UpdateDataSource Prelude.Text updateDataSource_dataSourceId = Lens.lens (\UpdateDataSource' {dataSourceId} -> dataSourceId) (\s@UpdateDataSource' {} a -> s {dataSourceId = a} :: UpdateDataSource) -- | A new user-supplied name or description of the @DataSource@ that will -- replace the current description. updateDataSource_dataSourceName :: Lens.Lens' UpdateDataSource Prelude.Text updateDataSource_dataSourceName = Lens.lens (\UpdateDataSource' {dataSourceName} -> dataSourceName) (\s@UpdateDataSource' {} a -> s {dataSourceName = a} :: UpdateDataSource) instance Core.AWSRequest UpdateDataSource where type AWSResponse UpdateDataSource = UpdateDataSourceResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> UpdateDataSourceResponse' Prelude.<$> (x Data..?> "DataSourceId") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable UpdateDataSource where hashWithSalt _salt UpdateDataSource' {..} = _salt `Prelude.hashWithSalt` dataSourceId `Prelude.hashWithSalt` dataSourceName instance Prelude.NFData UpdateDataSource where rnf UpdateDataSource' {..} = Prelude.rnf dataSourceId `Prelude.seq` Prelude.rnf dataSourceName instance Data.ToHeaders UpdateDataSource where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AmazonML_20141212.UpdateDataSource" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON UpdateDataSource where toJSON UpdateDataSource' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("DataSourceId" Data..= dataSourceId), Prelude.Just ("DataSourceName" Data..= dataSourceName) ] ) instance Data.ToPath UpdateDataSource where toPath = Prelude.const "/" instance Data.ToQuery UpdateDataSource where toQuery = Prelude.const Prelude.mempty -- | Represents the output of an @UpdateDataSource@ operation. -- -- You can see the updated content by using the @GetBatchPrediction@ -- operation. -- -- /See:/ 'newUpdateDataSourceResponse' smart constructor. data UpdateDataSourceResponse = UpdateDataSourceResponse' { -- | The ID assigned to the @DataSource@ during creation. This value should -- be identical to the value of the @DataSourceID@ in the request. dataSourceId :: Prelude.Maybe Prelude.Text, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateDataSourceResponse' 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: -- -- 'dataSourceId', 'updateDataSourceResponse_dataSourceId' - The ID assigned to the @DataSource@ during creation. This value should -- be identical to the value of the @DataSourceID@ in the request. -- -- 'httpStatus', 'updateDataSourceResponse_httpStatus' - The response's http status code. newUpdateDataSourceResponse :: -- | 'httpStatus' Prelude.Int -> UpdateDataSourceResponse newUpdateDataSourceResponse pHttpStatus_ = UpdateDataSourceResponse' { dataSourceId = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The ID assigned to the @DataSource@ during creation. This value should -- be identical to the value of the @DataSourceID@ in the request. updateDataSourceResponse_dataSourceId :: Lens.Lens' UpdateDataSourceResponse (Prelude.Maybe Prelude.Text) updateDataSourceResponse_dataSourceId = Lens.lens (\UpdateDataSourceResponse' {dataSourceId} -> dataSourceId) (\s@UpdateDataSourceResponse' {} a -> s {dataSourceId = a} :: UpdateDataSourceResponse) -- | The response's http status code. updateDataSourceResponse_httpStatus :: Lens.Lens' UpdateDataSourceResponse Prelude.Int updateDataSourceResponse_httpStatus = Lens.lens (\UpdateDataSourceResponse' {httpStatus} -> httpStatus) (\s@UpdateDataSourceResponse' {} a -> s {httpStatus = a} :: UpdateDataSourceResponse) instance Prelude.NFData UpdateDataSourceResponse where rnf UpdateDataSourceResponse' {..} = Prelude.rnf dataSourceId `Prelude.seq` Prelude.rnf httpStatus