UNPKG

@pulumi/openstack

Version:

A Pulumi package for creating and managing OpenStack cloud resources.

97 lines 4.14 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.RegisteredLimitV3 = void 0; const pulumi = require("@pulumi/pulumi"); const utilities = require("../utilities"); /** * Manages a V3 Registered Limit resource within OpenStack Keystone. * * > **Note:** You _must_ have admin privileges in your OpenStack cloud to use * this resource. * * ## Example Usage * * ```typescript * import * as pulumi from "@pulumi/pulumi"; * import * as openstack from "@pulumi/openstack"; * * const glance = openstack.identity.getService({ * name: "glance", * }); * const limit1 = new openstack.identity.RegisteredLimitV3("limit_1", { * serviceId: glance.then(glance => glance.id), * resourceName: "image_count_total", * defaultLimit: 10, * description: "foo", * }); * ``` * * ## Import * * Registered Limits can be imported using the `id`, e.g. * * ```sh * $ pulumi import openstack:identity/registeredLimitV3:RegisteredLimitV3 limit_1 89c60255-9bd6-460c-822a-e2b959ede9d2 * ``` */ class RegisteredLimitV3 extends pulumi.CustomResource { /** * Get an existing RegisteredLimitV3 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 RegisteredLimitV3(name, state, Object.assign(Object.assign({}, opts), { id: id })); } /** * Returns true if the given object is an instance of RegisteredLimitV3. 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'] === RegisteredLimitV3.__pulumiType; } constructor(name, argsOrState, opts) { let resourceInputs = {}; opts = opts || {}; if (opts.id) { const state = argsOrState; resourceInputs["defaultLimit"] = state ? state.defaultLimit : undefined; resourceInputs["description"] = state ? state.description : undefined; resourceInputs["region"] = state ? state.region : undefined; resourceInputs["resourceName"] = state ? state.resourceName : undefined; resourceInputs["serviceId"] = state ? state.serviceId : undefined; } else { const args = argsOrState; if ((!args || args.defaultLimit === undefined) && !opts.urn) { throw new Error("Missing required property 'defaultLimit'"); } if ((!args || args.resourceName === undefined) && !opts.urn) { throw new Error("Missing required property 'resourceName'"); } if ((!args || args.serviceId === undefined) && !opts.urn) { throw new Error("Missing required property 'serviceId'"); } resourceInputs["defaultLimit"] = args ? args.defaultLimit : undefined; resourceInputs["description"] = args ? args.description : undefined; resourceInputs["region"] = args ? args.region : undefined; resourceInputs["resourceName"] = args ? args.resourceName : undefined; resourceInputs["serviceId"] = args ? args.serviceId : undefined; } opts = pulumi.mergeOptions(utilities.resourceOptsDefaults(), opts); super(RegisteredLimitV3.__pulumiType, name, resourceInputs, opts); } } exports.RegisteredLimitV3 = RegisteredLimitV3; /** @internal */ RegisteredLimitV3.__pulumiType = 'openstack:identity/registeredLimitV3:RegisteredLimitV3'; //# sourceMappingURL=registeredLimitV3.js.map