@pulumi/f5bigip
Version:
A Pulumi package for creating and managing F5 BigIP resources.
142 lines • 6.82 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.ProfileRewrite = void 0;
const pulumi = require("@pulumi/pulumi");
const utilities = require("../utilities");
/**
* `bigipLtmRewriteProfile` Configures ltm policies to manage traffic assigned to a virtual server
*
* For resources should be named with their `full path`. The full path is the combination of the `partition + name` of the resource. For example `/Common/test-profile`.
*
* ## Example Usage
*
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as f5bigip from "@pulumi/f5bigip";
*
* const test_profile = new f5bigip.ltm.ProfileRewrite("test-profile", {
* name: "/Common/tf_profile",
* defaultsFrom: "/Common/rewrite",
* bypassLists: ["http://notouch.com"],
* rewriteLists: ["http://some.com"],
* rewriteMode: "portal",
* cacheType: "cache-img-css-js",
* caFile: "/Common/ca-bundle.crt",
* crlFile: "none",
* signingCert: "/Common/default.crt",
* signingKey: "/Common/default.key",
* splitTunneling: "true",
* });
* const test_profile2 = new f5bigip.ltm.ProfileRewrite("test-profile2", {
* name: "/Common/tf_profile_translate",
* defaultsFrom: "/Common/rewrite",
* rewriteMode: "uri-translation",
* requests: [{
* insertXfwdFor: "enabled",
* insertXfwdHost: "disabled",
* insertXfwdProtocol: "enabled",
* rewriteHeaders: "disabled",
* }],
* responses: [{
* rewriteContent: "enabled",
* rewriteHeaders: "disabled",
* }],
* cookieRules: [
* {
* ruleName: "cookie1",
* clientDomain: "wrong.com",
* clientPath: "/this/",
* serverDomain: "wrong.com",
* serverPath: "/this/",
* },
* {
* ruleName: "cookie2",
* clientDomain: "incorrect.com",
* clientPath: "/this/",
* serverDomain: "absolute.com",
* serverPath: "/this/",
* },
* ],
* });
* ```
*/
class ProfileRewrite extends pulumi.CustomResource {
/**
* Get an existing ProfileRewrite 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 ProfileRewrite(name, state, Object.assign(Object.assign({}, opts), { id: id }));
}
/**
* Returns true if the given object is an instance of ProfileRewrite. 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'] === ProfileRewrite.__pulumiType;
}
constructor(name, argsOrState, opts) {
let resourceInputs = {};
opts = opts || {};
if (opts.id) {
const state = argsOrState;
resourceInputs["bypassLists"] = state ? state.bypassLists : undefined;
resourceInputs["caFile"] = state ? state.caFile : undefined;
resourceInputs["cacheType"] = state ? state.cacheType : undefined;
resourceInputs["cookieRules"] = state ? state.cookieRules : undefined;
resourceInputs["crlFile"] = state ? state.crlFile : undefined;
resourceInputs["defaultsFrom"] = state ? state.defaultsFrom : undefined;
resourceInputs["name"] = state ? state.name : undefined;
resourceInputs["requests"] = state ? state.requests : undefined;
resourceInputs["responses"] = state ? state.responses : undefined;
resourceInputs["rewriteLists"] = state ? state.rewriteLists : undefined;
resourceInputs["rewriteMode"] = state ? state.rewriteMode : undefined;
resourceInputs["signingCert"] = state ? state.signingCert : undefined;
resourceInputs["signingKey"] = state ? state.signingKey : undefined;
resourceInputs["signingKeyPassword"] = state ? state.signingKeyPassword : undefined;
resourceInputs["splitTunneling"] = state ? state.splitTunneling : undefined;
}
else {
const args = argsOrState;
if ((!args || args.name === undefined) && !opts.urn) {
throw new Error("Missing required property 'name'");
}
if ((!args || args.rewriteMode === undefined) && !opts.urn) {
throw new Error("Missing required property 'rewriteMode'");
}
resourceInputs["bypassLists"] = args ? args.bypassLists : undefined;
resourceInputs["caFile"] = args ? args.caFile : undefined;
resourceInputs["cacheType"] = args ? args.cacheType : undefined;
resourceInputs["cookieRules"] = args ? args.cookieRules : undefined;
resourceInputs["crlFile"] = args ? args.crlFile : undefined;
resourceInputs["defaultsFrom"] = args ? args.defaultsFrom : undefined;
resourceInputs["name"] = args ? args.name : undefined;
resourceInputs["requests"] = args ? args.requests : undefined;
resourceInputs["responses"] = args ? args.responses : undefined;
resourceInputs["rewriteLists"] = args ? args.rewriteLists : undefined;
resourceInputs["rewriteMode"] = args ? args.rewriteMode : undefined;
resourceInputs["signingCert"] = args ? args.signingCert : undefined;
resourceInputs["signingKey"] = args ? args.signingKey : undefined;
resourceInputs["signingKeyPassword"] = (args === null || args === void 0 ? void 0 : args.signingKeyPassword) ? pulumi.secret(args.signingKeyPassword) : undefined;
resourceInputs["splitTunneling"] = args ? args.splitTunneling : undefined;
}
opts = pulumi.mergeOptions(utilities.resourceOptsDefaults(), opts);
const secretOpts = { additionalSecretOutputs: ["signingKeyPassword"] };
opts = pulumi.mergeOptions(opts, secretOpts);
super(ProfileRewrite.__pulumiType, name, resourceInputs, opts);
}
}
exports.ProfileRewrite = ProfileRewrite;
/** @internal */
ProfileRewrite.__pulumiType = 'f5bigip:ltm/profileRewrite:ProfileRewrite';
//# sourceMappingURL=profileRewrite.js.map