@pulumiverse/fortios
Version:
A Pulumi package for creating and managing Fortios resources. Based on terraform-provider-fortios: version v1.16.0
248 lines (247 loc) • 11.5 kB
TypeScript
import * as pulumi from "@pulumi/pulumi";
import * as inputs from "../types/input";
import * as outputs from "../types/output";
/**
* Configure WAN optimization content delivery network rules.
*
* ## Example Usage
*
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as fortios from "@pulumiverse/fortios";
*
* const trname = new fortios.wanopt.Contentdeliverynetworkrule("trname", {
* category: "vcache",
* hostDomainNameSuffixes: [{
* name: "kaf.com",
* }],
* requestCacheControl: "disable",
* responseCacheControl: "disable",
* responseExpires: "enable",
* status: "enable",
* textResponseVcache: "enable",
* updateserver: "disable",
* });
* ```
*
* ## Import
*
* Wanopt ContentDeliveryNetworkRule can be imported using any of these accepted formats:
*
* ```sh
* $ pulumi import fortios:wanopt/contentdeliverynetworkrule:Contentdeliverynetworkrule labelname {{name}}
* ```
*
* If you do not want to import arguments of block:
*
* $ export "FORTIOS_IMPORT_TABLE"="false"
*
* ```sh
* $ pulumi import fortios:wanopt/contentdeliverynetworkrule:Contentdeliverynetworkrule labelname {{name}}
* ```
*
* $ unset "FORTIOS_IMPORT_TABLE"
*/
export declare class Contentdeliverynetworkrule extends pulumi.CustomResource {
/**
* Get an existing Contentdeliverynetworkrule 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: string, id: pulumi.Input<pulumi.ID>, state?: ContentdeliverynetworkruleState, opts?: pulumi.CustomResourceOptions): Contentdeliverynetworkrule;
/**
* Returns true if the given object is an instance of Contentdeliverynetworkrule. This is designed to work even
* when multiple copies of the Pulumi SDK have been loaded into the same process.
*/
static isInstance(obj: any): obj is Contentdeliverynetworkrule;
/**
* Content delivery network rule category. Valid values: `vcache`, `youtube`.
*/
readonly category: pulumi.Output<string>;
/**
* Comment about this CDN-rule.
*/
readonly comment: pulumi.Output<string | undefined>;
/**
* Sort sub-tables, please do not set this parameter when configuring static sub-tables. Options: [ false, true, natural, alphabetical ]. false: Default value, do not sort tables; true/natural: sort tables in natural order. For example: [ a10, a2 ] -> [ a2, a10 ]; alphabetical: sort tables in alphabetical order. For example: [ a10, a2 ] -> [ a10, a2 ].
*/
readonly dynamicSortSubtable: pulumi.Output<string | undefined>;
/**
* Get all sub-tables including unconfigured tables. Do not set this variable to true if you configure sub-table in another resource, otherwise, conflicts and overwrite will occur. Options: [ false, true ]. false: Default value, do not get unconfigured tables; true: get all tables including unconfigured tables.
*/
readonly getAllTables: pulumi.Output<string | undefined>;
/**
* Suffix portion of the fully qualified domain name (eg. fortinet.com in "www.fortinet.com"). The structure of `hostDomainNameSuffix` block is documented below.
*/
readonly hostDomainNameSuffixes: pulumi.Output<outputs.wanopt.ContentdeliverynetworkruleHostDomainNameSuffix[] | undefined>;
/**
* Name of table.
*/
readonly name: pulumi.Output<string>;
/**
* Enable/disable HTTP request cache control. Valid values: `enable`, `disable`.
*/
readonly requestCacheControl: pulumi.Output<string>;
/**
* Enable/disable HTTP response cache control. Valid values: `enable`, `disable`.
*/
readonly responseCacheControl: pulumi.Output<string>;
/**
* Enable/disable HTTP response cache expires. Valid values: `enable`, `disable`.
*/
readonly responseExpires: pulumi.Output<string>;
/**
* WAN optimization content delivery network rule entries. The structure of `rules` block is documented below.
*/
readonly rules: pulumi.Output<outputs.wanopt.ContentdeliverynetworkruleRule[] | undefined>;
/**
* Enable/disable WAN optimization content delivery network rules. Valid values: `enable`, `disable`.
*/
readonly status: pulumi.Output<string>;
/**
* Enable/disable caching of text responses. Valid values: `enable`, `disable`.
*/
readonly textResponseVcache: pulumi.Output<string>;
/**
* Enable/disable update server. Valid values: `enable`, `disable`.
*/
readonly updateserver: pulumi.Output<string>;
/**
* Specifies the vdom to which the resource will be applied when the FortiGate unit is running in VDOM mode. Only one vdom can be specified. If you want to inherit the vdom configuration of the provider, please do not set this parameter.
*/
readonly vdomparam: pulumi.Output<string>;
/**
* Create a Contentdeliverynetworkrule resource with the given unique name, arguments, and options.
*
* @param name The _unique_ name of the resource.
* @param args The arguments to use to populate this resource's properties.
* @param opts A bag of options that control this resource's behavior.
*/
constructor(name: string, args?: ContentdeliverynetworkruleArgs, opts?: pulumi.CustomResourceOptions);
}
/**
* Input properties used for looking up and filtering Contentdeliverynetworkrule resources.
*/
export interface ContentdeliverynetworkruleState {
/**
* Content delivery network rule category. Valid values: `vcache`, `youtube`.
*/
category?: pulumi.Input<string>;
/**
* Comment about this CDN-rule.
*/
comment?: pulumi.Input<string>;
/**
* Sort sub-tables, please do not set this parameter when configuring static sub-tables. Options: [ false, true, natural, alphabetical ]. false: Default value, do not sort tables; true/natural: sort tables in natural order. For example: [ a10, a2 ] -> [ a2, a10 ]; alphabetical: sort tables in alphabetical order. For example: [ a10, a2 ] -> [ a10, a2 ].
*/
dynamicSortSubtable?: pulumi.Input<string>;
/**
* Get all sub-tables including unconfigured tables. Do not set this variable to true if you configure sub-table in another resource, otherwise, conflicts and overwrite will occur. Options: [ false, true ]. false: Default value, do not get unconfigured tables; true: get all tables including unconfigured tables.
*/
getAllTables?: pulumi.Input<string>;
/**
* Suffix portion of the fully qualified domain name (eg. fortinet.com in "www.fortinet.com"). The structure of `hostDomainNameSuffix` block is documented below.
*/
hostDomainNameSuffixes?: pulumi.Input<pulumi.Input<inputs.wanopt.ContentdeliverynetworkruleHostDomainNameSuffix>[]>;
/**
* Name of table.
*/
name?: pulumi.Input<string>;
/**
* Enable/disable HTTP request cache control. Valid values: `enable`, `disable`.
*/
requestCacheControl?: pulumi.Input<string>;
/**
* Enable/disable HTTP response cache control. Valid values: `enable`, `disable`.
*/
responseCacheControl?: pulumi.Input<string>;
/**
* Enable/disable HTTP response cache expires. Valid values: `enable`, `disable`.
*/
responseExpires?: pulumi.Input<string>;
/**
* WAN optimization content delivery network rule entries. The structure of `rules` block is documented below.
*/
rules?: pulumi.Input<pulumi.Input<inputs.wanopt.ContentdeliverynetworkruleRule>[]>;
/**
* Enable/disable WAN optimization content delivery network rules. Valid values: `enable`, `disable`.
*/
status?: pulumi.Input<string>;
/**
* Enable/disable caching of text responses. Valid values: `enable`, `disable`.
*/
textResponseVcache?: pulumi.Input<string>;
/**
* Enable/disable update server. Valid values: `enable`, `disable`.
*/
updateserver?: pulumi.Input<string>;
/**
* Specifies the vdom to which the resource will be applied when the FortiGate unit is running in VDOM mode. Only one vdom can be specified. If you want to inherit the vdom configuration of the provider, please do not set this parameter.
*/
vdomparam?: pulumi.Input<string>;
}
/**
* The set of arguments for constructing a Contentdeliverynetworkrule resource.
*/
export interface ContentdeliverynetworkruleArgs {
/**
* Content delivery network rule category. Valid values: `vcache`, `youtube`.
*/
category?: pulumi.Input<string>;
/**
* Comment about this CDN-rule.
*/
comment?: pulumi.Input<string>;
/**
* Sort sub-tables, please do not set this parameter when configuring static sub-tables. Options: [ false, true, natural, alphabetical ]. false: Default value, do not sort tables; true/natural: sort tables in natural order. For example: [ a10, a2 ] -> [ a2, a10 ]; alphabetical: sort tables in alphabetical order. For example: [ a10, a2 ] -> [ a10, a2 ].
*/
dynamicSortSubtable?: pulumi.Input<string>;
/**
* Get all sub-tables including unconfigured tables. Do not set this variable to true if you configure sub-table in another resource, otherwise, conflicts and overwrite will occur. Options: [ false, true ]. false: Default value, do not get unconfigured tables; true: get all tables including unconfigured tables.
*/
getAllTables?: pulumi.Input<string>;
/**
* Suffix portion of the fully qualified domain name (eg. fortinet.com in "www.fortinet.com"). The structure of `hostDomainNameSuffix` block is documented below.
*/
hostDomainNameSuffixes?: pulumi.Input<pulumi.Input<inputs.wanopt.ContentdeliverynetworkruleHostDomainNameSuffix>[]>;
/**
* Name of table.
*/
name?: pulumi.Input<string>;
/**
* Enable/disable HTTP request cache control. Valid values: `enable`, `disable`.
*/
requestCacheControl?: pulumi.Input<string>;
/**
* Enable/disable HTTP response cache control. Valid values: `enable`, `disable`.
*/
responseCacheControl?: pulumi.Input<string>;
/**
* Enable/disable HTTP response cache expires. Valid values: `enable`, `disable`.
*/
responseExpires?: pulumi.Input<string>;
/**
* WAN optimization content delivery network rule entries. The structure of `rules` block is documented below.
*/
rules?: pulumi.Input<pulumi.Input<inputs.wanopt.ContentdeliverynetworkruleRule>[]>;
/**
* Enable/disable WAN optimization content delivery network rules. Valid values: `enable`, `disable`.
*/
status?: pulumi.Input<string>;
/**
* Enable/disable caching of text responses. Valid values: `enable`, `disable`.
*/
textResponseVcache?: pulumi.Input<string>;
/**
* Enable/disable update server. Valid values: `enable`, `disable`.
*/
updateserver?: pulumi.Input<string>;
/**
* Specifies the vdom to which the resource will be applied when the FortiGate unit is running in VDOM mode. Only one vdom can be specified. If you want to inherit the vdom configuration of the provider, please do not set this parameter.
*/
vdomparam?: pulumi.Input<string>;
}