UNPKG

@pulumi/yandex

Version:

A Pulumi package for creating and managing yandex cloud resources.

116 lines 4.85 kB
"use strict"; // *** WARNING: this file was generated by the Pulumi Terraform Bridge (tfgen) Tool. *** // *** Do not edit by hand unless you're certain you know what you are doing! *** Object.defineProperty(exports, "__esModule", { value: true }); exports.VpcSecurityGroup = void 0; const pulumi = require("@pulumi/pulumi"); const utilities = require("./utilities"); /** * Manages a Security Group within the Yandex.Cloud. For more information, see * [the official documentation](https://cloud.yandex.com/docs/vpc/concepts/security-groups). * * ## Example Usage * * ```typescript * import * as pulumi from "@pulumi/pulumi"; * import * as yandex from "@pulumi/yandex"; * * const lab_net = new yandex.VpcNetwork("lab-net", {}); * const group1 = new yandex.VpcSecurityGroup("group1", { * description: "description for my security group", * egresses: [ * { * description: "rule2 description", * fromPort: 8090, * protocol: "ANY", * toPort: 8099, * v4CidrBlocks: [ * "10.0.1.0/24", * "10.0.2.0/24", * ], * }, * { * description: "rule3 description", * fromPort: 8090, * protocol: "UDP", * toPort: 8099, * v4CidrBlocks: ["10.0.1.0/24"], * }, * ], * ingresses: [{ * description: "rule1 description", * port: 8080, * protocol: "TCP", * v4CidrBlocks: [ * "10.0.1.0/24", * "10.0.2.0/24", * ], * }], * labels: { * "my-label": "my-label-value", * }, * networkId: lab_net.id, * }); * ``` */ class VpcSecurityGroup extends pulumi.CustomResource { constructor(name, argsOrState, opts) { let resourceInputs = {}; opts = opts || {}; if (opts.id) { const state = argsOrState; resourceInputs["createdAt"] = state ? state.createdAt : undefined; resourceInputs["description"] = state ? state.description : undefined; resourceInputs["egresses"] = state ? state.egresses : undefined; resourceInputs["folderId"] = state ? state.folderId : undefined; resourceInputs["ingresses"] = state ? state.ingresses : undefined; resourceInputs["labels"] = state ? state.labels : undefined; resourceInputs["name"] = state ? state.name : undefined; resourceInputs["networkId"] = state ? state.networkId : undefined; resourceInputs["status"] = state ? state.status : undefined; } else { const args = argsOrState; if ((!args || args.networkId === undefined) && !opts.urn) { throw new Error("Missing required property 'networkId'"); } resourceInputs["description"] = args ? args.description : undefined; resourceInputs["egresses"] = args ? args.egresses : undefined; resourceInputs["folderId"] = args ? args.folderId : undefined; resourceInputs["ingresses"] = args ? args.ingresses : undefined; resourceInputs["labels"] = args ? args.labels : undefined; resourceInputs["name"] = args ? args.name : undefined; resourceInputs["networkId"] = args ? args.networkId : undefined; resourceInputs["createdAt"] = undefined /*out*/; resourceInputs["status"] = undefined /*out*/; } opts = pulumi.mergeOptions(utilities.resourceOptsDefaults(), opts); super(VpcSecurityGroup.__pulumiType, name, resourceInputs, opts); } /** * Get an existing VpcSecurityGroup 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 VpcSecurityGroup(name, state, Object.assign(Object.assign({}, opts), { id: id })); } /** * Returns true if the given object is an instance of VpcSecurityGroup. 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'] === VpcSecurityGroup.__pulumiType; } } exports.VpcSecurityGroup = VpcSecurityGroup; /** @internal */ VpcSecurityGroup.__pulumiType = 'yandex:index/vpcSecurityGroup:VpcSecurityGroup'; //# sourceMappingURL=vpcSecurityGroup.js.map