@pulumi/aws-native
Version:
The Pulumi AWS Cloud Control Provider enables you to build, deploy, and manage [any AWS resource that's supported by the AWS Cloud Control API](https://github.com/pulumi/pulumi-aws-native/blob/master/provider/cmd/pulumi-gen-aws-native/supported-types.txt)
113 lines • 6.26 kB
JavaScript
;
// *** WARNING: this file was generated by pulumi-language-nodejs. ***
// *** Do not edit by hand unless you're certain you know what you are doing! ***
Object.defineProperty(exports, "__esModule", { value: true });
exports.DataSource = void 0;
const pulumi = require("@pulumi/pulumi");
const utilities = require("../utilities");
/**
* A data source is used to import technical metadata of assets (data) from the source databases or data warehouses into Amazon DataZone.
*/
class DataSource extends pulumi.CustomResource {
/**
* Get an existing DataSource resource's state with the given name, ID, and optional extra
* properties used to qualify the lookup.
*
* @param name The _unique_ name of the resulting resource.
* @param id The _unique_ provider ID of the resource to lookup.
* @param opts Optional settings to control the behavior of the CustomResource.
*/
static get(name, id, opts) {
return new DataSource(name, undefined, Object.assign(Object.assign({}, opts), { id: id }));
}
/**
* Returns true if the given object is an instance of DataSource. This is designed to work even
* when multiple copies of the Pulumi SDK have been loaded into the same process.
*/
static isInstance(obj) {
if (obj === undefined || obj === null) {
return false;
}
return obj['__pulumiType'] === DataSource.__pulumiType;
}
/**
* Create a DataSource resource with the given unique name, arguments, and options.
*
* @param name The _unique_ name of the resource.
* @param args The arguments to use to populate this resource's properties.
* @param opts A bag of options that control this resource's behavior.
*/
constructor(name, args, opts) {
let resourceInputs = {};
opts = opts || {};
if (!opts.id) {
if ((!args || args.domainIdentifier === undefined) && !opts.urn) {
throw new Error("Missing required property 'domainIdentifier'");
}
if ((!args || args.projectIdentifier === undefined) && !opts.urn) {
throw new Error("Missing required property 'projectIdentifier'");
}
if ((!args || args.type === undefined) && !opts.urn) {
throw new Error("Missing required property 'type'");
}
resourceInputs["assetFormsInput"] = args ? args.assetFormsInput : undefined;
resourceInputs["configuration"] = args ? args.configuration : undefined;
resourceInputs["connectionIdentifier"] = args ? args.connectionIdentifier : undefined;
resourceInputs["description"] = args ? args.description : undefined;
resourceInputs["domainIdentifier"] = args ? args.domainIdentifier : undefined;
resourceInputs["enableSetting"] = args ? args.enableSetting : undefined;
resourceInputs["environmentIdentifier"] = args ? args.environmentIdentifier : undefined;
resourceInputs["name"] = args ? args.name : undefined;
resourceInputs["projectIdentifier"] = args ? args.projectIdentifier : undefined;
resourceInputs["publishOnImport"] = args ? args.publishOnImport : undefined;
resourceInputs["recommendation"] = args ? args.recommendation : undefined;
resourceInputs["schedule"] = args ? args.schedule : undefined;
resourceInputs["type"] = args ? args.type : undefined;
resourceInputs["awsId"] = undefined /*out*/;
resourceInputs["connectionId"] = undefined /*out*/;
resourceInputs["createdAt"] = undefined /*out*/;
resourceInputs["domainId"] = undefined /*out*/;
resourceInputs["environmentId"] = undefined /*out*/;
resourceInputs["lastRunAssetCount"] = undefined /*out*/;
resourceInputs["lastRunAt"] = undefined /*out*/;
resourceInputs["lastRunStatus"] = undefined /*out*/;
resourceInputs["projectId"] = undefined /*out*/;
resourceInputs["status"] = undefined /*out*/;
resourceInputs["updatedAt"] = undefined /*out*/;
}
else {
resourceInputs["assetFormsInput"] = undefined /*out*/;
resourceInputs["awsId"] = undefined /*out*/;
resourceInputs["configuration"] = undefined /*out*/;
resourceInputs["connectionId"] = undefined /*out*/;
resourceInputs["connectionIdentifier"] = undefined /*out*/;
resourceInputs["createdAt"] = undefined /*out*/;
resourceInputs["description"] = undefined /*out*/;
resourceInputs["domainId"] = undefined /*out*/;
resourceInputs["domainIdentifier"] = undefined /*out*/;
resourceInputs["enableSetting"] = undefined /*out*/;
resourceInputs["environmentId"] = undefined /*out*/;
resourceInputs["environmentIdentifier"] = undefined /*out*/;
resourceInputs["lastRunAssetCount"] = undefined /*out*/;
resourceInputs["lastRunAt"] = undefined /*out*/;
resourceInputs["lastRunStatus"] = undefined /*out*/;
resourceInputs["name"] = undefined /*out*/;
resourceInputs["projectId"] = undefined /*out*/;
resourceInputs["projectIdentifier"] = undefined /*out*/;
resourceInputs["publishOnImport"] = undefined /*out*/;
resourceInputs["recommendation"] = undefined /*out*/;
resourceInputs["schedule"] = undefined /*out*/;
resourceInputs["status"] = undefined /*out*/;
resourceInputs["type"] = undefined /*out*/;
resourceInputs["updatedAt"] = undefined /*out*/;
}
opts = pulumi.mergeOptions(utilities.resourceOptsDefaults(), opts);
const replaceOnChanges = { replaceOnChanges: ["connectionIdentifier", "domainIdentifier", "environmentIdentifier", "projectIdentifier", "type"] };
opts = pulumi.mergeOptions(opts, replaceOnChanges);
super(DataSource.__pulumiType, name, resourceInputs, opts);
}
}
exports.DataSource = DataSource;
/** @internal */
DataSource.__pulumiType = 'aws-native:datazone:DataSource';
//# sourceMappingURL=dataSource.js.map