{-# 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.DataExchange.UpdateAsset -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- This operation updates an asset. module Amazonka.DataExchange.UpdateAsset ( -- * Creating a Request UpdateAsset (..), newUpdateAsset, -- * Request Lenses updateAsset_assetId, updateAsset_dataSetId, updateAsset_name, updateAsset_revisionId, -- * Destructuring the Response UpdateAssetResponse (..), newUpdateAssetResponse, -- * Response Lenses updateAssetResponse_arn, updateAssetResponse_assetDetails, updateAssetResponse_assetType, updateAssetResponse_createdAt, updateAssetResponse_dataSetId, updateAssetResponse_id, updateAssetResponse_name, updateAssetResponse_revisionId, updateAssetResponse_sourceId, updateAssetResponse_updatedAt, updateAssetResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.DataExchange.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newUpdateAsset' smart constructor. data UpdateAsset = UpdateAsset' { -- | The unique identifier for an asset. assetId :: Prelude.Text, -- | The unique identifier for a data set. dataSetId :: Prelude.Text, -- | The name of the asset. When importing from Amazon S3, the Amazon S3 -- object key is used as the asset name. When exporting to Amazon S3, the -- asset name is used as default target Amazon S3 object key. When -- importing from Amazon API Gateway API, the API name is used as the asset -- name. When importing from Amazon Redshift, the datashare name is used as -- the asset name. When importing from AWS Lake Formation, the static -- values of \"Database(s) included in the LF-tag policy\" or \"Table(s) -- included in LF-tag policy\" are used as the name. name :: Prelude.Text, -- | The unique identifier for a revision. revisionId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateAsset' 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: -- -- 'assetId', 'updateAsset_assetId' - The unique identifier for an asset. -- -- 'dataSetId', 'updateAsset_dataSetId' - The unique identifier for a data set. -- -- 'name', 'updateAsset_name' - The name of the asset. When importing from Amazon S3, the Amazon S3 -- object key is used as the asset name. When exporting to Amazon S3, the -- asset name is used as default target Amazon S3 object key. When -- importing from Amazon API Gateway API, the API name is used as the asset -- name. When importing from Amazon Redshift, the datashare name is used as -- the asset name. When importing from AWS Lake Formation, the static -- values of \"Database(s) included in the LF-tag policy\" or \"Table(s) -- included in LF-tag policy\" are used as the name. -- -- 'revisionId', 'updateAsset_revisionId' - The unique identifier for a revision. newUpdateAsset :: -- | 'assetId' Prelude.Text -> -- | 'dataSetId' Prelude.Text -> -- | 'name' Prelude.Text -> -- | 'revisionId' Prelude.Text -> UpdateAsset newUpdateAsset pAssetId_ pDataSetId_ pName_ pRevisionId_ = UpdateAsset' { assetId = pAssetId_, dataSetId = pDataSetId_, name = pName_, revisionId = pRevisionId_ } -- | The unique identifier for an asset. updateAsset_assetId :: Lens.Lens' UpdateAsset Prelude.Text updateAsset_assetId = Lens.lens (\UpdateAsset' {assetId} -> assetId) (\s@UpdateAsset' {} a -> s {assetId = a} :: UpdateAsset) -- | The unique identifier for a data set. updateAsset_dataSetId :: Lens.Lens' UpdateAsset Prelude.Text updateAsset_dataSetId = Lens.lens (\UpdateAsset' {dataSetId} -> dataSetId) (\s@UpdateAsset' {} a -> s {dataSetId = a} :: UpdateAsset) -- | The name of the asset. When importing from Amazon S3, the Amazon S3 -- object key is used as the asset name. When exporting to Amazon S3, the -- asset name is used as default target Amazon S3 object key. When -- importing from Amazon API Gateway API, the API name is used as the asset -- name. When importing from Amazon Redshift, the datashare name is used as -- the asset name. When importing from AWS Lake Formation, the static -- values of \"Database(s) included in the LF-tag policy\" or \"Table(s) -- included in LF-tag policy\" are used as the name. updateAsset_name :: Lens.Lens' UpdateAsset Prelude.Text updateAsset_name = Lens.lens (\UpdateAsset' {name} -> name) (\s@UpdateAsset' {} a -> s {name = a} :: UpdateAsset) -- | The unique identifier for a revision. updateAsset_revisionId :: Lens.Lens' UpdateAsset Prelude.Text updateAsset_revisionId = Lens.lens (\UpdateAsset' {revisionId} -> revisionId) (\s@UpdateAsset' {} a -> s {revisionId = a} :: UpdateAsset) instance Core.AWSRequest UpdateAsset where type AWSResponse UpdateAsset = UpdateAssetResponse request overrides = Request.patchJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> UpdateAssetResponse' Prelude.<$> (x Data..?> "Arn") Prelude.<*> (x Data..?> "AssetDetails") Prelude.<*> (x Data..?> "AssetType") Prelude.<*> (x Data..?> "CreatedAt") Prelude.<*> (x Data..?> "DataSetId") Prelude.<*> (x Data..?> "Id") Prelude.<*> (x Data..?> "Name") Prelude.<*> (x Data..?> "RevisionId") Prelude.<*> (x Data..?> "SourceId") Prelude.<*> (x Data..?> "UpdatedAt") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable UpdateAsset where hashWithSalt _salt UpdateAsset' {..} = _salt `Prelude.hashWithSalt` assetId `Prelude.hashWithSalt` dataSetId `Prelude.hashWithSalt` name `Prelude.hashWithSalt` revisionId instance Prelude.NFData UpdateAsset where rnf UpdateAsset' {..} = Prelude.rnf assetId `Prelude.seq` Prelude.rnf dataSetId `Prelude.seq` Prelude.rnf name `Prelude.seq` Prelude.rnf revisionId instance Data.ToHeaders UpdateAsset where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON UpdateAsset where toJSON UpdateAsset' {..} = Data.object ( Prelude.catMaybes [Prelude.Just ("Name" Data..= name)] ) instance Data.ToPath UpdateAsset where toPath UpdateAsset' {..} = Prelude.mconcat [ "/v1/data-sets/", Data.toBS dataSetId, "/revisions/", Data.toBS revisionId, "/assets/", Data.toBS assetId ] instance Data.ToQuery UpdateAsset where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newUpdateAssetResponse' smart constructor. data UpdateAssetResponse = UpdateAssetResponse' { -- | The ARN for the asset. arn :: Prelude.Maybe Prelude.Text, -- | Details about the asset. assetDetails :: Prelude.Maybe AssetDetails, -- | The type of asset that is added to a data set. assetType :: Prelude.Maybe AssetType, -- | The date and time that the asset was created, in ISO 8601 format. createdAt :: Prelude.Maybe Data.ISO8601, -- | The unique identifier for the data set associated with this asset. dataSetId :: Prelude.Maybe Prelude.Text, -- | The unique identifier for the asset. id :: Prelude.Maybe Prelude.Text, -- | The name of the asset. When importing from Amazon S3, the Amazon S3 -- object key is used as the asset name. When exporting to Amazon S3, the -- asset name is used as default target Amazon S3 object key. When -- importing from Amazon API Gateway API, the API name is used as the asset -- name. When importing from Amazon Redshift, the datashare name is used as -- the asset name. When importing from AWS Lake Formation, the static -- values of \"Database(s) included in the LF-tag policy\"- or \"Table(s) -- included in LF-tag policy\" are used as the asset name. name :: Prelude.Maybe Prelude.Text, -- | The unique identifier for the revision associated with this asset. revisionId :: Prelude.Maybe Prelude.Text, -- | The asset ID of the owned asset corresponding to the entitled asset -- being viewed. This parameter is returned when an asset owner is viewing -- the entitled copy of its owned asset. sourceId :: Prelude.Maybe Prelude.Text, -- | The date and time that the asset was last updated, in ISO 8601 format. updatedAt :: Prelude.Maybe Data.ISO8601, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateAssetResponse' 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: -- -- 'arn', 'updateAssetResponse_arn' - The ARN for the asset. -- -- 'assetDetails', 'updateAssetResponse_assetDetails' - Details about the asset. -- -- 'assetType', 'updateAssetResponse_assetType' - The type of asset that is added to a data set. -- -- 'createdAt', 'updateAssetResponse_createdAt' - The date and time that the asset was created, in ISO 8601 format. -- -- 'dataSetId', 'updateAssetResponse_dataSetId' - The unique identifier for the data set associated with this asset. -- -- 'id', 'updateAssetResponse_id' - The unique identifier for the asset. -- -- 'name', 'updateAssetResponse_name' - The name of the asset. When importing from Amazon S3, the Amazon S3 -- object key is used as the asset name. When exporting to Amazon S3, the -- asset name is used as default target Amazon S3 object key. When -- importing from Amazon API Gateway API, the API name is used as the asset -- name. When importing from Amazon Redshift, the datashare name is used as -- the asset name. When importing from AWS Lake Formation, the static -- values of \"Database(s) included in the LF-tag policy\"- or \"Table(s) -- included in LF-tag policy\" are used as the asset name. -- -- 'revisionId', 'updateAssetResponse_revisionId' - The unique identifier for the revision associated with this asset. -- -- 'sourceId', 'updateAssetResponse_sourceId' - The asset ID of the owned asset corresponding to the entitled asset -- being viewed. This parameter is returned when an asset owner is viewing -- the entitled copy of its owned asset. -- -- 'updatedAt', 'updateAssetResponse_updatedAt' - The date and time that the asset was last updated, in ISO 8601 format. -- -- 'httpStatus', 'updateAssetResponse_httpStatus' - The response's http status code. newUpdateAssetResponse :: -- | 'httpStatus' Prelude.Int -> UpdateAssetResponse newUpdateAssetResponse pHttpStatus_ = UpdateAssetResponse' { arn = Prelude.Nothing, assetDetails = Prelude.Nothing, assetType = Prelude.Nothing, createdAt = Prelude.Nothing, dataSetId = Prelude.Nothing, id = Prelude.Nothing, name = Prelude.Nothing, revisionId = Prelude.Nothing, sourceId = Prelude.Nothing, updatedAt = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The ARN for the asset. updateAssetResponse_arn :: Lens.Lens' UpdateAssetResponse (Prelude.Maybe Prelude.Text) updateAssetResponse_arn = Lens.lens (\UpdateAssetResponse' {arn} -> arn) (\s@UpdateAssetResponse' {} a -> s {arn = a} :: UpdateAssetResponse) -- | Details about the asset. updateAssetResponse_assetDetails :: Lens.Lens' UpdateAssetResponse (Prelude.Maybe AssetDetails) updateAssetResponse_assetDetails = Lens.lens (\UpdateAssetResponse' {assetDetails} -> assetDetails) (\s@UpdateAssetResponse' {} a -> s {assetDetails = a} :: UpdateAssetResponse) -- | The type of asset that is added to a data set. updateAssetResponse_assetType :: Lens.Lens' UpdateAssetResponse (Prelude.Maybe AssetType) updateAssetResponse_assetType = Lens.lens (\UpdateAssetResponse' {assetType} -> assetType) (\s@UpdateAssetResponse' {} a -> s {assetType = a} :: UpdateAssetResponse) -- | The date and time that the asset was created, in ISO 8601 format. updateAssetResponse_createdAt :: Lens.Lens' UpdateAssetResponse (Prelude.Maybe Prelude.UTCTime) updateAssetResponse_createdAt = Lens.lens (\UpdateAssetResponse' {createdAt} -> createdAt) (\s@UpdateAssetResponse' {} a -> s {createdAt = a} :: UpdateAssetResponse) Prelude.. Lens.mapping Data._Time -- | The unique identifier for the data set associated with this asset. updateAssetResponse_dataSetId :: Lens.Lens' UpdateAssetResponse (Prelude.Maybe Prelude.Text) updateAssetResponse_dataSetId = Lens.lens (\UpdateAssetResponse' {dataSetId} -> dataSetId) (\s@UpdateAssetResponse' {} a -> s {dataSetId = a} :: UpdateAssetResponse) -- | The unique identifier for the asset. updateAssetResponse_id :: Lens.Lens' UpdateAssetResponse (Prelude.Maybe Prelude.Text) updateAssetResponse_id = Lens.lens (\UpdateAssetResponse' {id} -> id) (\s@UpdateAssetResponse' {} a -> s {id = a} :: UpdateAssetResponse) -- | The name of the asset. When importing from Amazon S3, the Amazon S3 -- object key is used as the asset name. When exporting to Amazon S3, the -- asset name is used as default target Amazon S3 object key. When -- importing from Amazon API Gateway API, the API name is used as the asset -- name. When importing from Amazon Redshift, the datashare name is used as -- the asset name. When importing from AWS Lake Formation, the static -- values of \"Database(s) included in the LF-tag policy\"- or \"Table(s) -- included in LF-tag policy\" are used as the asset name. updateAssetResponse_name :: Lens.Lens' UpdateAssetResponse (Prelude.Maybe Prelude.Text) updateAssetResponse_name = Lens.lens (\UpdateAssetResponse' {name} -> name) (\s@UpdateAssetResponse' {} a -> s {name = a} :: UpdateAssetResponse) -- | The unique identifier for the revision associated with this asset. updateAssetResponse_revisionId :: Lens.Lens' UpdateAssetResponse (Prelude.Maybe Prelude.Text) updateAssetResponse_revisionId = Lens.lens (\UpdateAssetResponse' {revisionId} -> revisionId) (\s@UpdateAssetResponse' {} a -> s {revisionId = a} :: UpdateAssetResponse) -- | The asset ID of the owned asset corresponding to the entitled asset -- being viewed. This parameter is returned when an asset owner is viewing -- the entitled copy of its owned asset. updateAssetResponse_sourceId :: Lens.Lens' UpdateAssetResponse (Prelude.Maybe Prelude.Text) updateAssetResponse_sourceId = Lens.lens (\UpdateAssetResponse' {sourceId} -> sourceId) (\s@UpdateAssetResponse' {} a -> s {sourceId = a} :: UpdateAssetResponse) -- | The date and time that the asset was last updated, in ISO 8601 format. updateAssetResponse_updatedAt :: Lens.Lens' UpdateAssetResponse (Prelude.Maybe Prelude.UTCTime) updateAssetResponse_updatedAt = Lens.lens (\UpdateAssetResponse' {updatedAt} -> updatedAt) (\s@UpdateAssetResponse' {} a -> s {updatedAt = a} :: UpdateAssetResponse) Prelude.. Lens.mapping Data._Time -- | The response's http status code. updateAssetResponse_httpStatus :: Lens.Lens' UpdateAssetResponse Prelude.Int updateAssetResponse_httpStatus = Lens.lens (\UpdateAssetResponse' {httpStatus} -> httpStatus) (\s@UpdateAssetResponse' {} a -> s {httpStatus = a} :: UpdateAssetResponse) instance Prelude.NFData UpdateAssetResponse where rnf UpdateAssetResponse' {..} = Prelude.rnf arn `Prelude.seq` Prelude.rnf assetDetails `Prelude.seq` Prelude.rnf assetType `Prelude.seq` Prelude.rnf createdAt `Prelude.seq` Prelude.rnf dataSetId `Prelude.seq` Prelude.rnf id `Prelude.seq` Prelude.rnf name `Prelude.seq` Prelude.rnf revisionId `Prelude.seq` Prelude.rnf sourceId `Prelude.seq` Prelude.rnf updatedAt `Prelude.seq` Prelude.rnf httpStatus