Interface IPolicyValidationPlugin

All Superinterfaces:
software.amazon.jsii.JsiiSerializable
All Known Subinterfaces:
IPolicyValidationPlugin.Jsii$Default
All Known Implementing Classes:
IPolicyValidationPlugin.Jsii$Proxy

@Generated(value="jsii-pacmak/1.127.0 (build 2117ad5)", date="2026-04-24T20:29:21.046Z") @Stability(Stable) public interface IPolicyValidationPlugin extends software.amazon.jsii.JsiiSerializable
Represents a validation plugin that will be executed during synthesis.

Example:

 public class MyPlugin implements IPolicyValidationPlugin {
     public final Object name;
     public PolicyValidationPluginReport validate(IPolicyValidationContext context) {
         // First read the templates using context.templatePaths...
         // ...then perform the validation, and then compose and return the report.
         // Using hard-coded values here for better clarity:
         return PolicyValidationPluginReport.builder()
                 .success(false)
                 .violations(List.of(PolicyViolation.builder()
                         .ruleName("CKV_AWS_117")
                         .description("Ensure that AWS Lambda function is configured inside a VPC")
                         .fix("https://docs.bridgecrew.io/docs/ensure-that-aws-lambda-function-is-configured-inside-a-vpc-1")
                         .violatingResources(List.of(PolicyViolatingResource.builder()
                                 .resourceLogicalId("MyFunction3BAA72D1")
                                 .templatePath("/home/johndoe/myapp/cdk.out/MyService.template.json")
                                 .locations(List.of("Properties/VpcConfig"))
                                 .build()))
                         .build()))
                 .build();
     }
 }
 
  • Method Details

    • getName

      @Stability(Stable) @NotNull String getName()
      The name of the plugin that will be displayed in the validation report.
    • getRuleIds

      @Stability(Stable) @Nullable default List<String> getRuleIds()
      The list of rule IDs that the plugin will evaluate.

      Used for analytics purposes.

      Default: - No rule is reported

    • getVersion

      @Stability(Stable) @Nullable default String getVersion()
      The version of the plugin, following the Semantic Versioning specification (see https://semver.org/). This version is used for analytics purposes, to measure the usage of different plugins and different versions. The value of this property should be kept in sync with the actual version of the software package. If the version is not provided or is not a valid semantic version, it will be reported as 0.0.0.
    • validate

      @Stability(Stable) @NotNull PolicyValidationPluginReport validate(@NotNull IPolicyValidationContext context)
      The method that will be called by the CDK framework to perform validations.

      This is where the plugin will evaluate the CloudFormation templates for compliance and report and violations

      Parameters:
      context - This parameter is required.