@pulumi/consul
Version:
A Pulumi package for creating and managing consul resources.
88 lines • 3.54 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.Keys = void 0;
const pulumi = require("@pulumi/pulumi");
const utilities = require("./utilities");
/**
* The `consul.Keys` resource writes sets of individual values into Consul.
* This is a powerful way to expose infrastructure details to clients.
*
* This resource manages individual keys, and thus it can create, update
* and delete the keys explicitly given. However, it is not able to detect
* and remove additional keys that have been added by non-Terraform means.
* To manage *all* keys sharing a common prefix, and thus have Terraform
* remove errant keys not present in the configuration, consider using the
* `consul.KeyPrefix` resource instead.
*
* ## Example Usage
*
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as consul from "@pulumi/consul";
*
* const app = new consul.Keys("app", {
* datacenter: "nyc1",
* token: "abcd",
* keys: [{
* path: "service/app/elb_address",
* value: appAwsElb.dnsName,
* }],
* });
* ```
*/
class Keys extends pulumi.CustomResource {
/**
* Get an existing Keys 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 Keys(name, state, { ...opts, id: id });
}
/**
* Returns true if the given object is an instance of Keys. 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'] === Keys.__pulumiType;
}
constructor(name, argsOrState, opts) {
let resourceInputs = {};
opts = opts || {};
if (opts.id) {
const state = argsOrState;
resourceInputs["datacenter"] = state?.datacenter;
resourceInputs["keys"] = state?.keys;
resourceInputs["namespace"] = state?.namespace;
resourceInputs["partition"] = state?.partition;
resourceInputs["token"] = state?.token;
resourceInputs["var"] = state?.var;
}
else {
const args = argsOrState;
resourceInputs["datacenter"] = args?.datacenter;
resourceInputs["keys"] = args?.keys;
resourceInputs["namespace"] = args?.namespace;
resourceInputs["partition"] = args?.partition;
resourceInputs["token"] = args?.token ? pulumi.secret(args.token) : undefined;
resourceInputs["var"] = undefined /*out*/;
}
opts = pulumi.mergeOptions(utilities.resourceOptsDefaults(), opts);
const secretOpts = { additionalSecretOutputs: ["token"] };
opts = pulumi.mergeOptions(opts, secretOpts);
super(Keys.__pulumiType, name, resourceInputs, opts);
}
}
exports.Keys = Keys;
/** @internal */
Keys.__pulumiType = 'consul:index/keys:Keys';
//# sourceMappingURL=keys.js.map