@pulumi/consul
Version:
A Pulumi package for creating and managing consul resources.
112 lines • 4.61 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.ConfigEntryServiceResolver = void 0;
const pulumi = require("@pulumi/pulumi");
const utilities = require("./utilities");
/**
* The `consul.ConfigEntryServiceResolver` resource configures a [service resolver](https://developer.hashicorp.com/consul/docs/connect/config-entries/service-resolver) that creates named subsets of service instances and define their behavior when satisfying upstream requests.
*
* ## Example Usage
*
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as consul from "@pulumi/consul";
*
* const web = new consul.ConfigEntryServiceResolver("web", {
* name: "web",
* defaultSubset: "v1",
* connectTimeout: "15s",
* subsets: [
* {
* name: "v1",
* filter: "Service.Meta.version == v1",
* },
* {
* name: "v2",
* filter: "Service.Meta.version == v2",
* },
* ],
* redirects: [{
* service: "web",
* datacenter: "dc2",
* }],
* failovers: [
* {
* subsetName: "v2",
* datacenters: ["dc2"],
* },
* {
* subsetName: "*",
* datacenters: [
* "dc3",
* "dc4",
* ],
* },
* ],
* });
* ```
*/
class ConfigEntryServiceResolver extends pulumi.CustomResource {
/**
* Get an existing ConfigEntryServiceResolver 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 ConfigEntryServiceResolver(name, state, { ...opts, id: id });
}
/**
* Returns true if the given object is an instance of ConfigEntryServiceResolver. 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'] === ConfigEntryServiceResolver.__pulumiType;
}
constructor(name, argsOrState, opts) {
let resourceInputs = {};
opts = opts || {};
if (opts.id) {
const state = argsOrState;
resourceInputs["connectTimeout"] = state?.connectTimeout;
resourceInputs["defaultSubset"] = state?.defaultSubset;
resourceInputs["failovers"] = state?.failovers;
resourceInputs["loadBalancers"] = state?.loadBalancers;
resourceInputs["meta"] = state?.meta;
resourceInputs["name"] = state?.name;
resourceInputs["namespace"] = state?.namespace;
resourceInputs["partition"] = state?.partition;
resourceInputs["redirects"] = state?.redirects;
resourceInputs["requestTimeout"] = state?.requestTimeout;
resourceInputs["subsets"] = state?.subsets;
}
else {
const args = argsOrState;
resourceInputs["connectTimeout"] = args?.connectTimeout;
resourceInputs["defaultSubset"] = args?.defaultSubset;
resourceInputs["failovers"] = args?.failovers;
resourceInputs["loadBalancers"] = args?.loadBalancers;
resourceInputs["meta"] = args?.meta;
resourceInputs["name"] = args?.name;
resourceInputs["namespace"] = args?.namespace;
resourceInputs["partition"] = args?.partition;
resourceInputs["redirects"] = args?.redirects;
resourceInputs["requestTimeout"] = args?.requestTimeout;
resourceInputs["subsets"] = args?.subsets;
}
opts = pulumi.mergeOptions(utilities.resourceOptsDefaults(), opts);
super(ConfigEntryServiceResolver.__pulumiType, name, resourceInputs, opts);
}
}
exports.ConfigEntryServiceResolver = ConfigEntryServiceResolver;
/** @internal */
ConfigEntryServiceResolver.__pulumiType = 'consul:index/configEntryServiceResolver:ConfigEntryServiceResolver';
//# sourceMappingURL=configEntryServiceResolver.js.map