github.com/jpreese/tflint@v0.19.2-0.20200908152133-b01686250fb6/rules/awsrules/models/aws_sagemaker_notebook_instance_lifecycle_configuration_invalid_name.go (about) 1 // This file generated by `generator/`. DO NOT EDIT 2 3 package models 4 5 import ( 6 "fmt" 7 "log" 8 "regexp" 9 10 hcl "github.com/hashicorp/hcl/v2" 11 "github.com/terraform-linters/tflint/tflint" 12 ) 13 14 // AwsSagemakerNotebookInstanceLifecycleConfigurationInvalidNameRule checks the pattern is valid 15 type AwsSagemakerNotebookInstanceLifecycleConfigurationInvalidNameRule struct { 16 resourceType string 17 attributeName string 18 max int 19 pattern *regexp.Regexp 20 } 21 22 // NewAwsSagemakerNotebookInstanceLifecycleConfigurationInvalidNameRule returns new rule with default attributes 23 func NewAwsSagemakerNotebookInstanceLifecycleConfigurationInvalidNameRule() *AwsSagemakerNotebookInstanceLifecycleConfigurationInvalidNameRule { 24 return &AwsSagemakerNotebookInstanceLifecycleConfigurationInvalidNameRule{ 25 resourceType: "aws_sagemaker_notebook_instance_lifecycle_configuration", 26 attributeName: "name", 27 max: 63, 28 pattern: regexp.MustCompile(`^[a-zA-Z0-9](-*[a-zA-Z0-9])*`), 29 } 30 } 31 32 // Name returns the rule name 33 func (r *AwsSagemakerNotebookInstanceLifecycleConfigurationInvalidNameRule) Name() string { 34 return "aws_sagemaker_notebook_instance_lifecycle_configuration_invalid_name" 35 } 36 37 // Enabled returns whether the rule is enabled by default 38 func (r *AwsSagemakerNotebookInstanceLifecycleConfigurationInvalidNameRule) Enabled() bool { 39 return true 40 } 41 42 // Severity returns the rule severity 43 func (r *AwsSagemakerNotebookInstanceLifecycleConfigurationInvalidNameRule) Severity() string { 44 return tflint.ERROR 45 } 46 47 // Link returns the rule reference link 48 func (r *AwsSagemakerNotebookInstanceLifecycleConfigurationInvalidNameRule) Link() string { 49 return "" 50 } 51 52 // Check checks the pattern is valid 53 func (r *AwsSagemakerNotebookInstanceLifecycleConfigurationInvalidNameRule) Check(runner *tflint.Runner) error { 54 log.Printf("[TRACE] Check `%s` rule for `%s` runner", r.Name(), runner.TFConfigPath()) 55 56 return runner.WalkResourceAttributes(r.resourceType, r.attributeName, func(attribute *hcl.Attribute) error { 57 var val string 58 err := runner.EvaluateExpr(attribute.Expr, &val) 59 60 return runner.EnsureNoError(err, func() error { 61 if len(val) > r.max { 62 runner.EmitIssue( 63 r, 64 "name must be 63 characters or less", 65 attribute.Expr.Range(), 66 ) 67 } 68 if !r.pattern.MatchString(val) { 69 runner.EmitIssue( 70 r, 71 fmt.Sprintf(`"%s" does not match valid pattern %s`, truncateLongMessage(val), `^[a-zA-Z0-9](-*[a-zA-Z0-9])*`), 72 attribute.Expr.Range(), 73 ) 74 } 75 return nil 76 }) 77 }) 78 }