UNPKG

@pulumi/consul

Version:

A Pulumi package for creating and managing consul resources.

111 lines 4.44 kB
"use strict"; // *** 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.ConfigEntryServiceIntentions = void 0; const pulumi = require("@pulumi/pulumi"); const utilities = require("./utilities"); /** * The `consulServiceIntentionsConfigEntry` resource configures [service intentions](https://developer.hashicorp.com/consul/docs/connect/config-entries/service-intentions) that are configurations for controlling access between services in the service mesh. A single service intentions configuration entry specifies one destination service and one or more L4 traffic sources, L7 traffic sources, or combination of traffic sources. * * ## Example Usage * * ```typescript * import * as pulumi from "@pulumi/pulumi"; * import * as consul from "@pulumi/consul"; * * const jwtProvider = new consul.ConfigEntry("jwt_provider", { * name: "okta", * kind: "jwt-provider", * configJson: JSON.stringify({ * ClockSkewSeconds: 30, * Issuer: "test-issuer", * JSONWebKeySet: { * Remote: { * URI: "https://127.0.0.1:9091", * FetchAsynchronously: true, * }, * }, * }), * }); * const web = new consul.ConfigEntryServiceIntentions("web", { * name: "web", * jwts: [{ * providers: [{ * name: jwtProvider.name, * verifyClaims: [{ * paths: [ * "perms", * "role", * ], * value: "admin", * }], * }], * }], * sources: [ * { * name: "frontend-webapp", * type: "consul", * action: "allow", * }, * { * name: "nightly-cronjob", * type: "consul", * action: "deny", * }, * ], * }); * ``` */ class ConfigEntryServiceIntentions extends pulumi.CustomResource { /** * Get an existing ConfigEntryServiceIntentions 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 ConfigEntryServiceIntentions(name, state, { ...opts, id: id }); } /** * Returns true if the given object is an instance of ConfigEntryServiceIntentions. 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'] === ConfigEntryServiceIntentions.__pulumiType; } constructor(name, argsOrState, opts) { let resourceInputs = {}; opts = opts || {}; if (opts.id) { const state = argsOrState; resourceInputs["jwts"] = state?.jwts; resourceInputs["meta"] = state?.meta; resourceInputs["name"] = state?.name; resourceInputs["namespace"] = state?.namespace; resourceInputs["partition"] = state?.partition; resourceInputs["sources"] = state?.sources; } else { const args = argsOrState; resourceInputs["jwts"] = args?.jwts; resourceInputs["meta"] = args?.meta; resourceInputs["name"] = args?.name; resourceInputs["namespace"] = args?.namespace; resourceInputs["partition"] = args?.partition; resourceInputs["sources"] = args?.sources; } opts = pulumi.mergeOptions(utilities.resourceOptsDefaults(), opts); super(ConfigEntryServiceIntentions.__pulumiType, name, resourceInputs, opts); } } exports.ConfigEntryServiceIntentions = ConfigEntryServiceIntentions; /** @internal */ ConfigEntryServiceIntentions.__pulumiType = 'consul:index/configEntryServiceIntentions:ConfigEntryServiceIntentions'; //# sourceMappingURL=configEntryServiceIntentions.js.map