@pulumi/nomad
Version:
A Pulumi package for creating and managing nomad cloud resources.
155 lines • 6.78 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.Volume = void 0;
const pulumi = require("@pulumi/pulumi");
const utilities = require("./utilities");
/**
* ## Example Usage
*
* Registering a volume:
*
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as nomad from "@pulumi/nomad";
*
* // It can sometimes be helpful to wait for a particular plugin to be available
* const ebs = nomad.getPlugin({
* pluginId: "aws-ebs0",
* waitForHealthy: true,
* });
* const mysqlVolume = new nomad.Volume("mysql_volume", {
* type: "csi",
* pluginId: "aws-ebs0",
* volumeId: "mysql_volume",
* name: "mysql_volume",
* externalId: hashistack.ebsTestVolumeId,
* capabilities: [{
* accessMode: "single-node-writer",
* attachmentMode: "file-system",
* }],
* mountOptions: {
* fsType: "ext4",
* },
* topologyRequest: {
* required: {
* topologies: [
* {
* segments: {
* rack: "R1",
* zone: "us-east-1a",
* },
* },
* {
* segments: {
* rack: "R2",
* },
* },
* ],
* },
* },
* }, {
* dependsOn: [ebs],
* });
* ```
*/
class Volume extends pulumi.CustomResource {
/**
* Get an existing Volume 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 state Any extra arguments used during the lookup.
* @param opts Optional settings to control the behavior of the CustomResource.
*/
static get(name, id, state, opts) {
return new Volume(name, state, { ...opts, id: id });
}
/**
* Returns true if the given object is an instance of Volume. 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'] === Volume.__pulumiType;
}
constructor(name, argsOrState, opts) {
let resourceInputs = {};
opts = opts || {};
if (opts.id) {
const state = argsOrState;
resourceInputs["accessMode"] = state?.accessMode;
resourceInputs["attachmentMode"] = state?.attachmentMode;
resourceInputs["capabilities"] = state?.capabilities;
resourceInputs["context"] = state?.context;
resourceInputs["controllerRequired"] = state?.controllerRequired;
resourceInputs["controllersExpected"] = state?.controllersExpected;
resourceInputs["controllersHealthy"] = state?.controllersHealthy;
resourceInputs["deregisterOnDestroy"] = state?.deregisterOnDestroy;
resourceInputs["externalId"] = state?.externalId;
resourceInputs["mountOptions"] = state?.mountOptions;
resourceInputs["name"] = state?.name;
resourceInputs["namespace"] = state?.namespace;
resourceInputs["nodesExpected"] = state?.nodesExpected;
resourceInputs["nodesHealthy"] = state?.nodesHealthy;
resourceInputs["parameters"] = state?.parameters;
resourceInputs["pluginId"] = state?.pluginId;
resourceInputs["pluginProvider"] = state?.pluginProvider;
resourceInputs["pluginProviderVersion"] = state?.pluginProviderVersion;
resourceInputs["schedulable"] = state?.schedulable;
resourceInputs["secrets"] = state?.secrets;
resourceInputs["topologies"] = state?.topologies;
resourceInputs["topologyRequest"] = state?.topologyRequest;
resourceInputs["type"] = state?.type;
resourceInputs["volumeId"] = state?.volumeId;
}
else {
const args = argsOrState;
if (args?.externalId === undefined && !opts.urn) {
throw new Error("Missing required property 'externalId'");
}
if (args?.pluginId === undefined && !opts.urn) {
throw new Error("Missing required property 'pluginId'");
}
if (args?.volumeId === undefined && !opts.urn) {
throw new Error("Missing required property 'volumeId'");
}
resourceInputs["accessMode"] = args?.accessMode;
resourceInputs["attachmentMode"] = args?.attachmentMode;
resourceInputs["capabilities"] = args?.capabilities;
resourceInputs["context"] = args?.context;
resourceInputs["deregisterOnDestroy"] = args?.deregisterOnDestroy;
resourceInputs["externalId"] = args?.externalId;
resourceInputs["mountOptions"] = args?.mountOptions;
resourceInputs["name"] = args?.name;
resourceInputs["namespace"] = args?.namespace;
resourceInputs["parameters"] = args?.parameters;
resourceInputs["pluginId"] = args?.pluginId;
resourceInputs["secrets"] = args?.secrets ? pulumi.secret(args.secrets) : undefined;
resourceInputs["topologyRequest"] = args?.topologyRequest;
resourceInputs["type"] = args?.type;
resourceInputs["volumeId"] = args?.volumeId;
resourceInputs["controllerRequired"] = undefined /*out*/;
resourceInputs["controllersExpected"] = undefined /*out*/;
resourceInputs["controllersHealthy"] = undefined /*out*/;
resourceInputs["nodesExpected"] = undefined /*out*/;
resourceInputs["nodesHealthy"] = undefined /*out*/;
resourceInputs["pluginProvider"] = undefined /*out*/;
resourceInputs["pluginProviderVersion"] = undefined /*out*/;
resourceInputs["schedulable"] = undefined /*out*/;
resourceInputs["topologies"] = undefined /*out*/;
}
opts = pulumi.mergeOptions(utilities.resourceOptsDefaults(), opts);
const secretOpts = { additionalSecretOutputs: ["secrets"] };
opts = pulumi.mergeOptions(opts, secretOpts);
super(Volume.__pulumiType, name, resourceInputs, opts);
}
}
exports.Volume = Volume;
/** @internal */
Volume.__pulumiType = 'nomad:index/volume:Volume';
//# sourceMappingURL=volume.js.map