// Code generated by generators/resource/main.go; DO NOT EDIT. package logs import ( "context" "regexp" "github.com/hashicorp/terraform-plugin-framework/tfsdk" "github.com/hashicorp/terraform-plugin-framework/types" . "github.com/hashicorp/terraform-provider-awscc/internal/generic" "github.com/hashicorp/terraform-provider-awscc/internal/registry" "github.com/hashicorp/terraform-provider-awscc/internal/validate" ) func init() { registry.AddResourceTypeFactory("awscc_logs_resource_policy", resourcePolicyResourceType) } // resourcePolicyResourceType returns the Terraform awscc_logs_resource_policy resource type. // This Terraform resource type corresponds to the CloudFormation AWS::Logs::ResourcePolicy resource type. func resourcePolicyResourceType(ctx context.Context) (tfsdk.ResourceType, error) { attributes := map[string]tfsdk.Attribute{ "policy_document": { // Property: PolicyDocument // CloudFormation resource type schema: // { // "description": "The policy document", // "maxLength": 5120, // "minLength": 1, // "pattern": "", // "type": "string" // } Description: "The policy document", Type: types.StringType, Required: true, Validators: []tfsdk.AttributeValidator{ validate.StringLenBetween(1, 5120), }, }, "policy_name": { // Property: PolicyName // CloudFormation resource type schema: // { // "description": "A name for resource policy", // "maxLength": 255, // "minLength": 1, // "pattern": "^([^:*\\/]+\\/?)*[^:*\\/]+$", // "type": "string" // } Description: "A name for resource policy", Type: types.StringType, Required: true, Validators: []tfsdk.AttributeValidator{ validate.StringLenBetween(1, 255), validate.StringMatch(regexp.MustCompile("^([^:*\\/]+\\/?)*[^:*\\/]+$"), ""), }, PlanModifiers: []tfsdk.AttributePlanModifier{ tfsdk.RequiresReplace(), }, }, } attributes["id"] = tfsdk.Attribute{ Description: "Uniquely identifies the resource.", Type: types.StringType, Computed: true, PlanModifiers: []tfsdk.AttributePlanModifier{ tfsdk.UseStateForUnknown(), }, } schema := tfsdk.Schema{ Description: "The resource schema for AWSLogs ResourcePolicy", Version: 1, Attributes: attributes, } var opts ResourceTypeOptions opts = opts.WithCloudFormationTypeName("AWS::Logs::ResourcePolicy").WithTerraformTypeName("awscc_logs_resource_policy") opts = opts.WithTerraformSchema(schema) opts = opts.WithSyntheticIDAttribute(true) opts = opts.WithAttributeNameMap(map[string]string{ "policy_document": "PolicyDocument", "policy_name": "PolicyName", }) opts = opts.WithCreateTimeoutInMinutes(0).WithDeleteTimeoutInMinutes(0) opts = opts.WithUpdateTimeoutInMinutes(0) resourceType, err := NewResourceType(ctx, opts...) if err != nil { return nil, err } return resourceType, nil }