// Code generated by generators/resource/main.go; DO NOT EDIT. package codeartifact 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_codeartifact_domain", domainResourceType) } // domainResourceType returns the Terraform awscc_codeartifact_domain resource type. // This Terraform resource type corresponds to the CloudFormation AWS::CodeArtifact::Domain resource type. func domainResourceType(ctx context.Context) (tfsdk.ResourceType, error) { attributes := map[string]tfsdk.Attribute{ "arn": { // Property: Arn // CloudFormation resource type schema: // { // "description": "The ARN of the domain.", // "maxLength": 2048, // "minLength": 1, // "type": "string" // } Description: "The ARN of the domain.", Type: types.StringType, Computed: true, PlanModifiers: []tfsdk.AttributePlanModifier{ tfsdk.UseStateForUnknown(), }, }, "domain_name": { // Property: DomainName // CloudFormation resource type schema: // { // "description": "The name of the domain.", // "maxLength": 50, // "minLength": 2, // "pattern": "^([a-z][a-z0-9\\-]{0,48}[a-z0-9])$", // "type": "string" // } Description: "The name of the domain.", Type: types.StringType, Required: true, Validators: []tfsdk.AttributeValidator{ validate.StringLenBetween(2, 50), validate.StringMatch(regexp.MustCompile("^([a-z][a-z0-9\\-]{0,48}[a-z0-9])$"), ""), }, PlanModifiers: []tfsdk.AttributePlanModifier{ tfsdk.RequiresReplace(), }, }, "encryption_key": { // Property: EncryptionKey // CloudFormation resource type schema: // { // "description": "The ARN of an AWS Key Management Service (AWS KMS) key associated with a domain.", // "type": "string" // } Description: "The ARN of an AWS Key Management Service (AWS KMS) key associated with a domain.", Type: types.StringType, Computed: true, PlanModifiers: []tfsdk.AttributePlanModifier{ tfsdk.UseStateForUnknown(), tfsdk.RequiresReplace(), }, }, "name": { // Property: Name // CloudFormation resource type schema: // { // "description": "The name of the domain. This field is used for GetAtt", // "maxLength": 50, // "minLength": 2, // "pattern": "^([a-z][a-z0-9\\-]{0,48}[a-z0-9])$", // "type": "string" // } Description: "The name of the domain. This field is used for GetAtt", Type: types.StringType, Computed: true, PlanModifiers: []tfsdk.AttributePlanModifier{ tfsdk.UseStateForUnknown(), }, }, "owner": { // Property: Owner // CloudFormation resource type schema: // { // "description": "The 12-digit account ID of the AWS account that owns the domain. This field is used for GetAtt", // "pattern": "[0-9]{12}", // "type": "string" // } Description: "The 12-digit account ID of the AWS account that owns the domain. This field is used for GetAtt", Type: types.StringType, Computed: true, PlanModifiers: []tfsdk.AttributePlanModifier{ tfsdk.UseStateForUnknown(), }, }, "permissions_policy_document": { // Property: PermissionsPolicyDocument // CloudFormation resource type schema: // { // "description": "The access control resource policy on the provided domain.", // "maxLength": 5120, // "minLength": 2, // "type": "object" // } Description: "The access control resource policy on the provided domain.", Type: types.MapType{ElemType: types.StringType}, Optional: true, }, "tags": { // Property: Tags // CloudFormation resource type schema: // { // "description": "An array of key-value pairs to apply to this resource.", // "items": { // "additionalProperties": false, // "description": "A key-value pair to associate with a resource.", // "properties": { // "Key": { // "description": "The key name of the tag. You can specify a value that is 1 to 127 Unicode characters in length and cannot be prefixed with aws:. You can use any of the following characters: the set of Unicode letters, digits, whitespace, _, ., /, =, +, and -. ", // "maxLength": 128, // "minLength": 1, // "type": "string" // }, // "Value": { // "description": "The value for the tag. You can specify a value that is 1 to 255 Unicode characters in length and cannot be prefixed with aws:. You can use any of the following characters: the set of Unicode letters, digits, whitespace, _, ., /, =, +, and -. ", // "maxLength": 256, // "minLength": 0, // "type": "string" // } // }, // "required": [ // "Value", // "Key" // ], // "type": "object" // }, // "type": "array" // } Description: "An array of key-value pairs to apply to this resource.", Attributes: tfsdk.ListNestedAttributes( map[string]tfsdk.Attribute{ "key": { // Property: Key Description: "The key name of the tag. You can specify a value that is 1 to 127 Unicode characters in length and cannot be prefixed with aws:. You can use any of the following characters: the set of Unicode letters, digits, whitespace, _, ., /, =, +, and -. ", Type: types.StringType, Required: true, Validators: []tfsdk.AttributeValidator{ validate.StringLenBetween(1, 128), }, }, "value": { // Property: Value Description: "The value for the tag. You can specify a value that is 1 to 255 Unicode characters in length and cannot be prefixed with aws:. You can use any of the following characters: the set of Unicode letters, digits, whitespace, _, ., /, =, +, and -. ", Type: types.StringType, Required: true, Validators: []tfsdk.AttributeValidator{ validate.StringLenBetween(0, 256), }, }, }, tfsdk.ListNestedAttributesOptions{}, ), Optional: true, }, } 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 to create a CodeArtifact domain.", Version: 1, Attributes: attributes, } var opts ResourceTypeOptions opts = opts.WithCloudFormationTypeName("AWS::CodeArtifact::Domain").WithTerraformTypeName("awscc_codeartifact_domain") opts = opts.WithTerraformSchema(schema) opts = opts.WithSyntheticIDAttribute(true) opts = opts.WithAttributeNameMap(map[string]string{ "arn": "Arn", "domain_name": "DomainName", "encryption_key": "EncryptionKey", "key": "Key", "name": "Name", "owner": "Owner", "permissions_policy_document": "PermissionsPolicyDocument", "tags": "Tags", "value": "Value", }) opts = opts.WithCreateTimeoutInMinutes(0).WithDeleteTimeoutInMinutes(0) opts = opts.WithUpdateTimeoutInMinutes(0) resourceType, err := NewResourceType(ctx, opts...) if err != nil { return nil, err } return resourceType, nil }