@pulumi/f5bigip
Version:
A Pulumi package for creating and managing F5 BigIP resources.
133 lines • 6.59 kB
JavaScript
;
// *** 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.PersistenceProfileSrcAddr = void 0;
const pulumi = require("@pulumi/pulumi");
const utilities = require("../utilities");
/**
* Configures a source address persistence profile
*
* ## Example
*
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as f5bigip from "@pulumi/f5bigip";
*
* const srcaddr = new f5bigip.ltm.PersistenceProfileSrcAddr("srcaddr", {
* name: "/Common/terraform_srcaddr",
* defaultsFrom: "/Common/source_addr",
* matchAcrossPools: "enabled",
* matchAcrossServices: "enabled",
* matchAcrossVirtuals: "enabled",
* mirror: "enabled",
* timeout: 3600,
* overrideConnLimit: "enabled",
* hashAlgorithm: "carp",
* mapProxies: "enabled",
* mask: "255.255.255.255",
* });
* ```
*
* ## Reference
*
* `name` - (Required) Name of the virtual address
*
* `defaultsFrom` - (Required) Parent cookie persistence profile
*
* `matchAcrossPools` (Optional) (enabled or disabled) match across pools with given persistence record
*
* `matchAcrossServices` (Optional) (enabled or disabled) match across services with given persistence record
*
* `matchAcrossVirtuals` (Optional) (enabled or disabled) match across virtual servers with given persistence record
*
* `mirror` (Optional) (enabled or disabled) mirror persistence record
*
* `timeout` (Optional) (enabled or disabled) Timeout for persistence of the session in seconds
*
* `overrideConnLimit` (Optional) (enabled or disabled) Enable or dissable pool member connection limits are overridden for persisted clients. Per-virtual connection limits remain hard limits and are not overridden.
*
* `hashAlgorithm` (Optional) Specify the hash algorithm
*
* `mask` (Optional) Identify a range of source IP addresses to manage together as a single source address affinity persistent connection when connecting to the pool. Must be a valid IPv4 or IPv6 mask.
*
* `mapProxies` (Optional) (enabled or disabled) Directs all to the same single pool member
*
* ## Importing
*
* An source-addr persistence profile can be imported into this resource by supplying the Name in `full path` as `id`.
* An example is below:
* ```sh
* $ terraform import bigip_ltm_persistence_profile_srcaddr.srcaddr "/Common/terraform_srcaddr"
* ```
*/
class PersistenceProfileSrcAddr extends pulumi.CustomResource {
/**
* Get an existing PersistenceProfileSrcAddr 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 PersistenceProfileSrcAddr(name, state, Object.assign(Object.assign({}, opts), { id: id }));
}
/**
* Returns true if the given object is an instance of PersistenceProfileSrcAddr. 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'] === PersistenceProfileSrcAddr.__pulumiType;
}
constructor(name, argsOrState, opts) {
let resourceInputs = {};
opts = opts || {};
if (opts.id) {
const state = argsOrState;
resourceInputs["appService"] = state ? state.appService : undefined;
resourceInputs["defaultsFrom"] = state ? state.defaultsFrom : undefined;
resourceInputs["hashAlgorithm"] = state ? state.hashAlgorithm : undefined;
resourceInputs["mapProxies"] = state ? state.mapProxies : undefined;
resourceInputs["mask"] = state ? state.mask : undefined;
resourceInputs["matchAcrossPools"] = state ? state.matchAcrossPools : undefined;
resourceInputs["matchAcrossServices"] = state ? state.matchAcrossServices : undefined;
resourceInputs["matchAcrossVirtuals"] = state ? state.matchAcrossVirtuals : undefined;
resourceInputs["mirror"] = state ? state.mirror : undefined;
resourceInputs["name"] = state ? state.name : undefined;
resourceInputs["overrideConnLimit"] = state ? state.overrideConnLimit : undefined;
resourceInputs["timeout"] = state ? state.timeout : undefined;
}
else {
const args = argsOrState;
if ((!args || args.defaultsFrom === undefined) && !opts.urn) {
throw new Error("Missing required property 'defaultsFrom'");
}
if ((!args || args.name === undefined) && !opts.urn) {
throw new Error("Missing required property 'name'");
}
resourceInputs["appService"] = args ? args.appService : undefined;
resourceInputs["defaultsFrom"] = args ? args.defaultsFrom : undefined;
resourceInputs["hashAlgorithm"] = args ? args.hashAlgorithm : undefined;
resourceInputs["mapProxies"] = args ? args.mapProxies : undefined;
resourceInputs["mask"] = args ? args.mask : undefined;
resourceInputs["matchAcrossPools"] = args ? args.matchAcrossPools : undefined;
resourceInputs["matchAcrossServices"] = args ? args.matchAcrossServices : undefined;
resourceInputs["matchAcrossVirtuals"] = args ? args.matchAcrossVirtuals : undefined;
resourceInputs["mirror"] = args ? args.mirror : undefined;
resourceInputs["name"] = args ? args.name : undefined;
resourceInputs["overrideConnLimit"] = args ? args.overrideConnLimit : undefined;
resourceInputs["timeout"] = args ? args.timeout : undefined;
}
opts = pulumi.mergeOptions(utilities.resourceOptsDefaults(), opts);
super(PersistenceProfileSrcAddr.__pulumiType, name, resourceInputs, opts);
}
}
exports.PersistenceProfileSrcAddr = PersistenceProfileSrcAddr;
/** @internal */
PersistenceProfileSrcAddr.__pulumiType = 'f5bigip:ltm/persistenceProfileSrcAddr:PersistenceProfileSrcAddr';
//# sourceMappingURL=persistenceProfileSrcAddr.js.map