UNPKG

@pulumi/tailscale

Version:

A Pulumi package for creating and managing Tailscale cloud resources.

108 lines 4.51 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.FederatedIdentity = void 0; const pulumi = require("@pulumi/pulumi"); const utilities = require("./utilities"); /** * The federatedIdentity resource allows you to create federated identities to programmatically interact with the Tailscale API using workload identity federation. * * ## Example Usage * * ```typescript * import * as pulumi from "@pulumi/pulumi"; * import * as tailscale from "@pulumi/tailscale"; * * const exampleFederatedIdentity = new tailscale.FederatedIdentity("example_federated_identity", { * description: "Example federated identity", * scopes: [ * "auth_keys", * "devices:core", * ], * tags: ["tag:test"], * issuer: "https://example.com", * subject: "example-sub-*", * customClaimRules: { * repo_name: "example-repo-name", * }, * }); * ``` * * ## Import * * The `pulumi import` command can be used, for example: * * ```sh * $ pulumi import tailscale:index/federatedIdentity:FederatedIdentity example k1234511CNTRL-kZDRvszg8621CNTRL * ``` */ class FederatedIdentity extends pulumi.CustomResource { /** * Get an existing FederatedIdentity 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 FederatedIdentity(name, state, { ...opts, id: id }); } /** * Returns true if the given object is an instance of FederatedIdentity. 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'] === FederatedIdentity.__pulumiType; } constructor(name, argsOrState, opts) { let resourceInputs = {}; opts = opts || {}; if (opts.id) { const state = argsOrState; resourceInputs["audience"] = state?.audience; resourceInputs["createdAt"] = state?.createdAt; resourceInputs["customClaimRules"] = state?.customClaimRules; resourceInputs["description"] = state?.description; resourceInputs["issuer"] = state?.issuer; resourceInputs["scopes"] = state?.scopes; resourceInputs["subject"] = state?.subject; resourceInputs["tags"] = state?.tags; resourceInputs["updatedAt"] = state?.updatedAt; resourceInputs["userId"] = state?.userId; } else { const args = argsOrState; if (args?.issuer === undefined && !opts.urn) { throw new Error("Missing required property 'issuer'"); } if (args?.scopes === undefined && !opts.urn) { throw new Error("Missing required property 'scopes'"); } if (args?.subject === undefined && !opts.urn) { throw new Error("Missing required property 'subject'"); } resourceInputs["audience"] = args?.audience; resourceInputs["customClaimRules"] = args?.customClaimRules; resourceInputs["description"] = args?.description; resourceInputs["issuer"] = args?.issuer; resourceInputs["scopes"] = args?.scopes; resourceInputs["subject"] = args?.subject; resourceInputs["tags"] = args?.tags; resourceInputs["createdAt"] = undefined /*out*/; resourceInputs["updatedAt"] = undefined /*out*/; resourceInputs["userId"] = undefined /*out*/; } opts = pulumi.mergeOptions(utilities.resourceOptsDefaults(), opts); super(FederatedIdentity.__pulumiType, name, resourceInputs, opts); } } exports.FederatedIdentity = FederatedIdentity; /** @internal */ FederatedIdentity.__pulumiType = 'tailscale:index/federatedIdentity:FederatedIdentity'; //# sourceMappingURL=federatedIdentity.js.map