Oracle Cloud Infrastructure v2.33.0 published on Thursday, May 1, 2025 by Pulumi
oci.Waas.getCustomProtectionRules
Explore with Pulumi AI
This data source provides the list of Custom Protection Rules in Oracle Cloud Infrastructure Web Application Acceleration and Security service.
Gets a list of custom protection rules for the specified Web Application Firewall.
Example Usage
import * as pulumi from "@pulumi/pulumi";
import * as oci from "@pulumi/oci";
const testCustomProtectionRules = oci.Waas.getCustomProtectionRules({
    compartmentId: compartmentId,
    displayNames: customProtectionRuleDisplayNames,
    ids: customProtectionRuleIds,
    states: customProtectionRuleStates,
    timeCreatedGreaterThanOrEqualTo: customProtectionRuleTimeCreatedGreaterThanOrEqualTo,
    timeCreatedLessThan: customProtectionRuleTimeCreatedLessThan,
});
import pulumi
import pulumi_oci as oci
test_custom_protection_rules = oci.Waas.get_custom_protection_rules(compartment_id=compartment_id,
    display_names=custom_protection_rule_display_names,
    ids=custom_protection_rule_ids,
    states=custom_protection_rule_states,
    time_created_greater_than_or_equal_to=custom_protection_rule_time_created_greater_than_or_equal_to,
    time_created_less_than=custom_protection_rule_time_created_less_than)
package main
import (
	"github.com/pulumi/pulumi-oci/sdk/v2/go/oci/waas"
	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
	pulumi.Run(func(ctx *pulumi.Context) error {
		_, err := waas.GetCustomProtectionRules(ctx, &waas.GetCustomProtectionRulesArgs{
			CompartmentId:                   compartmentId,
			DisplayNames:                    customProtectionRuleDisplayNames,
			Ids:                             customProtectionRuleIds,
			States:                          customProtectionRuleStates,
			TimeCreatedGreaterThanOrEqualTo: pulumi.StringRef(customProtectionRuleTimeCreatedGreaterThanOrEqualTo),
			TimeCreatedLessThan:             pulumi.StringRef(customProtectionRuleTimeCreatedLessThan),
		}, nil)
		if err != nil {
			return err
		}
		return nil
	})
}
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Oci = Pulumi.Oci;
return await Deployment.RunAsync(() => 
{
    var testCustomProtectionRules = Oci.Waas.GetCustomProtectionRules.Invoke(new()
    {
        CompartmentId = compartmentId,
        DisplayNames = customProtectionRuleDisplayNames,
        Ids = customProtectionRuleIds,
        States = customProtectionRuleStates,
        TimeCreatedGreaterThanOrEqualTo = customProtectionRuleTimeCreatedGreaterThanOrEqualTo,
        TimeCreatedLessThan = customProtectionRuleTimeCreatedLessThan,
    });
});
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.oci.Waas.WaasFunctions;
import com.pulumi.oci.Waas.inputs.GetCustomProtectionRulesArgs;
import java.util.List;
import java.util.ArrayList;
import java.util.Map;
import java.io.File;
import java.nio.file.Files;
import java.nio.file.Paths;
public class App {
    public static void main(String[] args) {
        Pulumi.run(App::stack);
    }
    public static void stack(Context ctx) {
        final var testCustomProtectionRules = WaasFunctions.getCustomProtectionRules(GetCustomProtectionRulesArgs.builder()
            .compartmentId(compartmentId)
            .displayNames(customProtectionRuleDisplayNames)
            .ids(customProtectionRuleIds)
            .states(customProtectionRuleStates)
            .timeCreatedGreaterThanOrEqualTo(customProtectionRuleTimeCreatedGreaterThanOrEqualTo)
            .timeCreatedLessThan(customProtectionRuleTimeCreatedLessThan)
            .build());
    }
}
variables:
  testCustomProtectionRules:
    fn::invoke:
      function: oci:Waas:getCustomProtectionRules
      arguments:
        compartmentId: ${compartmentId}
        displayNames: ${customProtectionRuleDisplayNames}
        ids: ${customProtectionRuleIds}
        states: ${customProtectionRuleStates}
        timeCreatedGreaterThanOrEqualTo: ${customProtectionRuleTimeCreatedGreaterThanOrEqualTo}
        timeCreatedLessThan: ${customProtectionRuleTimeCreatedLessThan}
Using getCustomProtectionRules
Two invocation forms are available. The direct form accepts plain arguments and either blocks until the result value is available, or returns a Promise-wrapped result. The output form accepts Input-wrapped arguments and returns an Output-wrapped result.
function getCustomProtectionRules(args: GetCustomProtectionRulesArgs, opts?: InvokeOptions): Promise<GetCustomProtectionRulesResult>
function getCustomProtectionRulesOutput(args: GetCustomProtectionRulesOutputArgs, opts?: InvokeOptions): Output<GetCustomProtectionRulesResult>def get_custom_protection_rules(compartment_id: Optional[str] = None,
                                display_names: Optional[Sequence[str]] = None,
                                filters: Optional[Sequence[GetCustomProtectionRulesFilter]] = None,
                                ids: Optional[Sequence[str]] = None,
                                states: Optional[Sequence[str]] = None,
                                time_created_greater_than_or_equal_to: Optional[str] = None,
                                time_created_less_than: Optional[str] = None,
                                opts: Optional[InvokeOptions] = None) -> GetCustomProtectionRulesResult
def get_custom_protection_rules_output(compartment_id: Optional[pulumi.Input[str]] = None,
                                display_names: Optional[pulumi.Input[Sequence[pulumi.Input[str]]]] = None,
                                filters: Optional[pulumi.Input[Sequence[pulumi.Input[GetCustomProtectionRulesFilterArgs]]]] = None,
                                ids: Optional[pulumi.Input[Sequence[pulumi.Input[str]]]] = None,
                                states: Optional[pulumi.Input[Sequence[pulumi.Input[str]]]] = None,
                                time_created_greater_than_or_equal_to: Optional[pulumi.Input[str]] = None,
                                time_created_less_than: Optional[pulumi.Input[str]] = None,
                                opts: Optional[InvokeOptions] = None) -> Output[GetCustomProtectionRulesResult]func GetCustomProtectionRules(ctx *Context, args *GetCustomProtectionRulesArgs, opts ...InvokeOption) (*GetCustomProtectionRulesResult, error)
func GetCustomProtectionRulesOutput(ctx *Context, args *GetCustomProtectionRulesOutputArgs, opts ...InvokeOption) GetCustomProtectionRulesResultOutput> Note: This function is named GetCustomProtectionRules in the Go SDK.
public static class GetCustomProtectionRules 
{
    public static Task<GetCustomProtectionRulesResult> InvokeAsync(GetCustomProtectionRulesArgs args, InvokeOptions? opts = null)
    public static Output<GetCustomProtectionRulesResult> Invoke(GetCustomProtectionRulesInvokeArgs args, InvokeOptions? opts = null)
}public static CompletableFuture<GetCustomProtectionRulesResult> getCustomProtectionRules(GetCustomProtectionRulesArgs args, InvokeOptions options)
public static Output<GetCustomProtectionRulesResult> getCustomProtectionRules(GetCustomProtectionRulesArgs args, InvokeOptions options)
fn::invoke:
  function: oci:Waas/getCustomProtectionRules:getCustomProtectionRules
  arguments:
    # arguments dictionaryThe following arguments are supported:
- CompartmentId string
- The OCID of the compartment. This number is generated when the compartment is created.
- DisplayNames List<string>
- Filter custom protection rules using a list of display names.
- Filters
List<GetCustom Protection Rules Filter> 
- Ids List<string>
- Filter custom protection rules using a list of custom protection rule OCIDs.
- States List<string>
- Filter Custom Protection rules using a list of lifecycle states.
- TimeCreated stringGreater Than Or Equal To 
- A filter that matches Custom Protection rules created on or after the specified date-time.
- TimeCreated stringLess Than 
- A filter that matches custom protection rules created before the specified date-time.
- CompartmentId string
- The OCID of the compartment. This number is generated when the compartment is created.
- DisplayNames []string
- Filter custom protection rules using a list of display names.
- Filters
[]GetCustom Protection Rules Filter 
- Ids []string
- Filter custom protection rules using a list of custom protection rule OCIDs.
- States []string
- Filter Custom Protection rules using a list of lifecycle states.
- TimeCreated stringGreater Than Or Equal To 
- A filter that matches Custom Protection rules created on or after the specified date-time.
- TimeCreated stringLess Than 
- A filter that matches custom protection rules created before the specified date-time.
- compartmentId String
- The OCID of the compartment. This number is generated when the compartment is created.
- displayNames List<String>
- Filter custom protection rules using a list of display names.
- filters
List<GetCustom Protection Rules Filter> 
- ids List<String>
- Filter custom protection rules using a list of custom protection rule OCIDs.
- states List<String>
- Filter Custom Protection rules using a list of lifecycle states.
- timeCreated StringGreater Than Or Equal To 
- A filter that matches Custom Protection rules created on or after the specified date-time.
- timeCreated StringLess Than 
- A filter that matches custom protection rules created before the specified date-time.
- compartmentId string
- The OCID of the compartment. This number is generated when the compartment is created.
- displayNames string[]
- Filter custom protection rules using a list of display names.
- filters
GetCustom Protection Rules Filter[] 
- ids string[]
- Filter custom protection rules using a list of custom protection rule OCIDs.
- states string[]
- Filter Custom Protection rules using a list of lifecycle states.
- timeCreated stringGreater Than Or Equal To 
- A filter that matches Custom Protection rules created on or after the specified date-time.
- timeCreated stringLess Than 
- A filter that matches custom protection rules created before the specified date-time.
- compartment_id str
- The OCID of the compartment. This number is generated when the compartment is created.
- display_names Sequence[str]
- Filter custom protection rules using a list of display names.
- filters
Sequence[GetCustom Protection Rules Filter] 
- ids Sequence[str]
- Filter custom protection rules using a list of custom protection rule OCIDs.
- states Sequence[str]
- Filter Custom Protection rules using a list of lifecycle states.
- time_created_ strgreater_ than_ or_ equal_ to 
- A filter that matches Custom Protection rules created on or after the specified date-time.
- time_created_ strless_ than 
- A filter that matches custom protection rules created before the specified date-time.
- compartmentId String
- The OCID of the compartment. This number is generated when the compartment is created.
- displayNames List<String>
- Filter custom protection rules using a list of display names.
- filters List<Property Map>
- ids List<String>
- Filter custom protection rules using a list of custom protection rule OCIDs.
- states List<String>
- Filter Custom Protection rules using a list of lifecycle states.
- timeCreated StringGreater Than Or Equal To 
- A filter that matches Custom Protection rules created on or after the specified date-time.
- timeCreated StringLess Than 
- A filter that matches custom protection rules created before the specified date-time.
getCustomProtectionRules Result
The following output properties are available:
- CompartmentId string
- The OCID of the custom protection rule's compartment.
- CustomProtection List<GetRules Custom Protection Rules Custom Protection Rule> 
- The list of custom_protection_rules.
- Id string
- The provider-assigned unique ID for this managed resource.
- DisplayNames List<string>
- Filters
List<GetCustom Protection Rules Filter> 
- Ids List<string>
- States List<string>
- TimeCreated stringGreater Than Or Equal To 
- TimeCreated stringLess Than 
- CompartmentId string
- The OCID of the custom protection rule's compartment.
- CustomProtection []GetRules Custom Protection Rules Custom Protection Rule 
- The list of custom_protection_rules.
- Id string
- The provider-assigned unique ID for this managed resource.
- DisplayNames []string
- Filters
[]GetCustom Protection Rules Filter 
- Ids []string
- States []string
- TimeCreated stringGreater Than Or Equal To 
- TimeCreated stringLess Than 
- compartmentId String
- The OCID of the custom protection rule's compartment.
- customProtection List<GetRules Custom Protection Rules Custom Protection Rule> 
- The list of custom_protection_rules.
- id String
- The provider-assigned unique ID for this managed resource.
- displayNames List<String>
- filters
List<GetCustom Protection Rules Filter> 
- ids List<String>
- states List<String>
- timeCreated StringGreater Than Or Equal To 
- timeCreated StringLess Than 
- compartmentId string
- The OCID of the custom protection rule's compartment.
- customProtection GetRules Custom Protection Rules Custom Protection Rule[] 
- The list of custom_protection_rules.
- id string
- The provider-assigned unique ID for this managed resource.
- displayNames string[]
- filters
GetCustom Protection Rules Filter[] 
- ids string[]
- states string[]
- timeCreated stringGreater Than Or Equal To 
- timeCreated stringLess Than 
- compartment_id str
- The OCID of the custom protection rule's compartment.
- custom_protection_ Sequence[Getrules Custom Protection Rules Custom Protection Rule] 
- The list of custom_protection_rules.
- id str
- The provider-assigned unique ID for this managed resource.
- display_names Sequence[str]
- filters
Sequence[GetCustom Protection Rules Filter] 
- ids Sequence[str]
- states Sequence[str]
- time_created_ strgreater_ than_ or_ equal_ to 
- time_created_ strless_ than 
- compartmentId String
- The OCID of the custom protection rule's compartment.
- customProtection List<Property Map>Rules 
- The list of custom_protection_rules.
- id String
- The provider-assigned unique ID for this managed resource.
- displayNames List<String>
- filters List<Property Map>
- ids List<String>
- states List<String>
- timeCreated StringGreater Than Or Equal To 
- timeCreated StringLess Than 
Supporting Types
GetCustomProtectionRulesCustomProtectionRule      
- CompartmentId string
- The OCID of the compartment. This number is generated when the compartment is created.
- Dictionary<string, string>
- Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- Description string
- The description of the custom protection rule.
- DisplayName string
- The user-friendly name of the custom protection rule.
- Dictionary<string, string>
- Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- Id string
- The OCID of the custom protection rule.
- ModSecurity List<string>Rule Ids 
- The auto-generated ID for the custom protection rule. These IDs are referenced in logs.
- State string
- The current lifecycle state of the custom protection rule.
- Template string
- The template text of the custom protection rule. All custom protection rules are expressed in ModSecurity Rule Language.
- TimeCreated string
- The date and time the protection rule was created, expressed in RFC 3339 timestamp format.
- CompartmentId string
- The OCID of the compartment. This number is generated when the compartment is created.
- map[string]string
- Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- Description string
- The description of the custom protection rule.
- DisplayName string
- The user-friendly name of the custom protection rule.
- map[string]string
- Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- Id string
- The OCID of the custom protection rule.
- ModSecurity []stringRule Ids 
- The auto-generated ID for the custom protection rule. These IDs are referenced in logs.
- State string
- The current lifecycle state of the custom protection rule.
- Template string
- The template text of the custom protection rule. All custom protection rules are expressed in ModSecurity Rule Language.
- TimeCreated string
- The date and time the protection rule was created, expressed in RFC 3339 timestamp format.
- compartmentId String
- The OCID of the compartment. This number is generated when the compartment is created.
- Map<String,String>
- Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- description String
- The description of the custom protection rule.
- displayName String
- The user-friendly name of the custom protection rule.
- Map<String,String>
- Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- id String
- The OCID of the custom protection rule.
- modSecurity List<String>Rule Ids 
- The auto-generated ID for the custom protection rule. These IDs are referenced in logs.
- state String
- The current lifecycle state of the custom protection rule.
- template String
- The template text of the custom protection rule. All custom protection rules are expressed in ModSecurity Rule Language.
- timeCreated String
- The date and time the protection rule was created, expressed in RFC 3339 timestamp format.
- compartmentId string
- The OCID of the compartment. This number is generated when the compartment is created.
- {[key: string]: string}
- Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- description string
- The description of the custom protection rule.
- displayName string
- The user-friendly name of the custom protection rule.
- {[key: string]: string}
- Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- id string
- The OCID of the custom protection rule.
- modSecurity string[]Rule Ids 
- The auto-generated ID for the custom protection rule. These IDs are referenced in logs.
- state string
- The current lifecycle state of the custom protection rule.
- template string
- The template text of the custom protection rule. All custom protection rules are expressed in ModSecurity Rule Language.
- timeCreated string
- The date and time the protection rule was created, expressed in RFC 3339 timestamp format.
- compartment_id str
- The OCID of the compartment. This number is generated when the compartment is created.
- Mapping[str, str]
- Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- description str
- The description of the custom protection rule.
- display_name str
- The user-friendly name of the custom protection rule.
- Mapping[str, str]
- Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- id str
- The OCID of the custom protection rule.
- mod_security_ Sequence[str]rule_ ids 
- The auto-generated ID for the custom protection rule. These IDs are referenced in logs.
- state str
- The current lifecycle state of the custom protection rule.
- template str
- The template text of the custom protection rule. All custom protection rules are expressed in ModSecurity Rule Language.
- time_created str
- The date and time the protection rule was created, expressed in RFC 3339 timestamp format.
- compartmentId String
- The OCID of the compartment. This number is generated when the compartment is created.
- Map<String>
- Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags. Example: {"Operations.CostCenter": "42"}
- description String
- The description of the custom protection rule.
- displayName String
- The user-friendly name of the custom protection rule.
- Map<String>
- Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {"Department": "Finance"}
- id String
- The OCID of the custom protection rule.
- modSecurity List<String>Rule Ids 
- The auto-generated ID for the custom protection rule. These IDs are referenced in logs.
- state String
- The current lifecycle state of the custom protection rule.
- template String
- The template text of the custom protection rule. All custom protection rules are expressed in ModSecurity Rule Language.
- timeCreated String
- The date and time the protection rule was created, expressed in RFC 3339 timestamp format.
GetCustomProtectionRulesFilter    
Package Details
- Repository
- oci pulumi/pulumi-oci
- License
- Apache-2.0
- Notes
- This Pulumi package is based on the ociTerraform Provider.