// This is an automatically generated code sample. 
// To make this code sample work in your Oracle Cloud tenancy, 
// please replace the values for any parameters whose current values do not fit
// your use case (such as resource IDs, strings containing ‘EXAMPLE’ or ‘unique_id’, and 
// boolean, number, and enum parameters with values not fitting your use case).

import * as dataintegration from "oci-dataintegration";
import common = require("oci-common");

// Create a default authentication provider that uses the DEFAULT
// profile in the configuration file.
// Refer to <see href="https://docs.cloud.oracle.com/en-us/iaas/Content/API/Concepts/sdkconfig.htm#SDK_and_CLI_Configuration_File>the public documentation</see> on how to prepare a configuration file.

const provider: common.ConfigFileAuthenticationDetailsProvider = new common.ConfigFileAuthenticationDetailsProvider();

(async () => {
    try {
     // Create a service client
     const client = new dataintegration.DataIntegrationClient({ authenticationDetailsProvider: provider });

     // Create a request and dependent object(s).
	const  updateDataAssetDetails = {
		modelType: "ORACLE_ATP_DATA_ASSET",		serviceName: "EXAMPLE-serviceName-Value",
		driverClass: "EXAMPLE-driverClass-Value",
		credentialFileContent: "EXAMPLE-credentialFileContent-Value",
		walletSecret: {
			secretConfig: {
				modelType: "OCI_VAULT_SECRET_CONFIG",				secretId: "ocid1.test.oc1..<unique_ID>EXAMPLE-secretId-Value"

				}
,
			value: "EXAMPLE-value-Value",

			}
,
		walletPasswordSecret: {
			secretConfig: {
				modelType: "OCI_VAULT_SECRET_CONFIG",				secretId: "ocid1.test.oc1..<unique_ID>EXAMPLE-secretId-Value"

				}
,
			value: "EXAMPLE-value-Value",

			}
,
		regionId: "ocid1.test.oc1..<unique_ID>EXAMPLE-regionId-Value",
		tenancyId: "ocid1.test.oc1..<unique_ID>EXAMPLE-tenancyId-Value",
		compartmentId: "ocid1.test.oc1..<unique_ID>EXAMPLE-compartmentId-Value",
		autonomousDbId: "ocid1.test.oc1..<unique_ID>EXAMPLE-autonomousDbId-Value",
		defaultConnection: {
			modelType: "ORACLE_ATP_CONNECTION",			tnsAlias: "EXAMPLE-tnsAlias-Value",
			tnsNames: ["EXAMPLE--Value"					],
			username: "EXAMPLE-username-Value",
			password: "EXAMPLE-password-Value",
			passwordSecret: {
				secretConfig: {
					modelType: "OCI_VAULT_SECRET_CONFIG",					secretId: "ocid1.test.oc1..<unique_ID>EXAMPLE-secretId-Value"

					}
,
				value: "EXAMPLE-value-Value",

				}
,
			key: "EXAMPLE-key-Value",
			modelVersion: "EXAMPLE-modelVersion-Value",
			parentRef: {
				parent: "EXAMPLE-parent-Value",
				rootDocId: "ocid1.test.oc1..<unique_ID>EXAMPLE-rootDocId-Value",

				}
,
			name: "EXAMPLE-name-Value",
			description: "EXAMPLE-description-Value",
			objectStatus: 733,
			objectVersion: 963,
			identifier: "EXAMPLE-identifier-Value",
			connectionProperties: [{
					name: "EXAMPLE-name-Value",
					value: "EXAMPLE-value-Value",

					}
					],
			registryMetadata: {
				aggregatorKey: "EXAMPLE-aggregatorKey-Value",
				labels: ["EXAMPLE--Value"						],
				registryVersion: 373,
				key: "EXAMPLE-key-Value",
				isFavorite: true,

				}


			}
,
		key: "EXAMPLE-key-Value",
		modelVersion: "EXAMPLE-modelVersion-Value",
		name: "EXAMPLE-name-Value",
		description: "EXAMPLE-description-Value",
		objectStatus: 994,
		objectVersion: 19,
		identifier: "EXAMPLE-identifier-Value",
		externalKey: "EXAMPLE-externalKey-Value",
		assetProperties: {
			EXAMPLE_KEY_eEhim :"EXAMPLE_VALUE_ujxrHxBLNYML6dixx5nw"
			},
		registryMetadata: {
			aggregatorKey: "EXAMPLE-aggregatorKey-Value",
			labels: ["EXAMPLE--Value"					],
			registryVersion: 317,
			key: "EXAMPLE-key-Value",
			isFavorite: false,

			}


		}

	const updateDataAssetRequest: dataintegration.requests.UpdateDataAssetRequest = { 
	workspaceId: "ocid1.test.oc1..<unique_ID>EXAMPLE-workspaceId-Value",
	dataAssetKey: "EXAMPLE-dataAssetKey-Value",
	updateDataAssetDetails: updateDataAssetDetails,
	opcRequestId: "RJGPTCNQZB0W6HEF7MOJ<unique_ID>",
	ifMatch: "EXAMPLE-ifMatch-Value",

		}; 


     // Send request to the Client.
     const updateDataAssetResponse = await client.updateDataAsset(updateDataAssetRequest);
     }
     catch (error) {
         console.log("updateDataAsset Failed with error  " + error);
     }
})();