diff --git a/helper/runner.go b/helper/runner.go index d74c235..45db54b 100644 --- a/helper/runner.go +++ b/helper/runner.go @@ -21,8 +21,10 @@ type Runner struct { Issues Issues files map[string]*hcl.File + sources map[string][]byte config Config variables map[string]*Variable + fixer *tflint.Fixer } // Variable is an implementation of variables in Terraform language @@ -318,6 +320,30 @@ func (r *Runner) EmitIssue(rule tflint.Rule, message string, location hcl.Range) return nil } +// EmitIssueWithFix adds an issue and invoke fix. +func (r *Runner) EmitIssueWithFix(rule tflint.Rule, message string, location hcl.Range, fixFunc func(f *tflint.Fixer) error) error { + if err := fixFunc(r.fixer); err != nil { + return err + } + return r.EmitIssue(rule, message, location) +} + +// HasChanges returns true if the fixer has changes. +func (r *Runner) HasChanges() bool { + return r.fixer.HasChanges() +} + +// ApplyChanges applies changes to the fixer. +func (r *Runner) ApplyChanges() error { + r.fixer.ApplyChanges() + return nil +} + +// Changes returns changes by the fixer. +func (r *Runner) Changes() map[string][]byte { + return r.fixer.Changes() +} + // EnsureNoError is a method that simply runs a function if there is no error. // // Deprecated: Use EvaluateExpr with a function callback. e.g. EvaluateExpr(expr, func (val T) error {}, ...) @@ -331,7 +357,12 @@ func (r *Runner) EnsureNoError(err error, proc func() error) error { // NewLocalRunner initialises a new test runner. // Internal use only. func NewLocalRunner(files map[string]*hcl.File, issues Issues) *Runner { - return &Runner{files: map[string]*hcl.File{}, variables: map[string]*Variable{}, Issues: issues} + return &Runner{ + files: map[string]*hcl.File{}, + sources: map[string][]byte{}, + variables: map[string]*Variable{}, + Issues: issues, + } } // AddLocalFile adds a new file to the current mapped files. @@ -342,6 +373,7 @@ func (r *Runner) AddLocalFile(name string, file *hcl.File) bool { } r.files[name] = file + r.sources[name] = file.Bytes return true } @@ -365,6 +397,7 @@ func (r *Runner) initFromFiles() error { } } } + r.fixer = tflint.NewFixer(r.sources) return nil } diff --git a/helper/testing.go b/helper/testing.go index e67ab91..04b313d 100644 --- a/helper/testing.go +++ b/helper/testing.go @@ -17,6 +17,8 @@ import ( // TestRunner returns a mock Runner for testing. // You can pass the map of file names and their contents in the second argument. func TestRunner(t *testing.T, files map[string]string) *Runner { + t.Helper() + runner := NewLocalRunner(map[string]*hcl.File{}, Issues{}) parser := hclparse.NewParser() @@ -50,25 +52,42 @@ func TestRunner(t *testing.T, files map[string]string) *Runner { } // AssertIssues is an assertion helper for comparing issues. -func AssertIssues(t *testing.T, expected Issues, actual Issues) { +func AssertIssues(t *testing.T, want Issues, got Issues) { + t.Helper() + opts := []cmp.Option{ // Byte field will be ignored because it's not important in tests such as positions cmpopts.IgnoreFields(hcl.Pos{}, "Byte"), ruleComparer(), } - if !cmp.Equal(expected, actual, opts...) { - t.Fatalf("Expected issues are not matched:\n %s\n", cmp.Diff(expected, actual, opts...)) + if diff := cmp.Diff(want, got, opts...); diff != "" { + t.Fatalf("Expected issues are not matched:\n %s\n", diff) } } // AssertIssuesWithoutRange is an assertion helper for comparing issues except for range. -func AssertIssuesWithoutRange(t *testing.T, expected Issues, actual Issues) { +func AssertIssuesWithoutRange(t *testing.T, want Issues, got Issues) { + t.Helper() + opts := []cmp.Option{ cmpopts.IgnoreFields(Issue{}, "Range"), ruleComparer(), } - if !cmp.Equal(expected, actual, opts...) { - t.Fatalf("Expected issues are not matched:\n %s\n", cmp.Diff(expected, actual, opts...)) + if diff := cmp.Diff(want, got, opts...); diff != "" { + t.Fatalf("Expected issues are not matched:\n %s\n", diff) + } +} + +// AssertChanges is an assertion helper for comparing autofix changes. +func AssertChanges(t *testing.T, want map[string]string, got map[string][]byte) { + t.Helper() + + sources := make(map[string]string) + for name, src := range got { + sources[name] = string(src) + } + if diff := cmp.Diff(want, sources); diff != "" { + t.Fatalf("Expected changes are not matched:\n %s\n", diff) } } diff --git a/plugin/fromproto/fromproto.go b/plugin/fromproto/fromproto.go index 2419c2d..c562cb7 100644 --- a/plugin/fromproto/fromproto.go +++ b/plugin/fromproto/fromproto.go @@ -262,6 +262,7 @@ func Config(config *proto.ApplyGlobalConfig_Config) *tflint.Config { Rules: rules, DisabledByDefault: config.DisabledByDefault, Only: config.Only, + Fix: config.Fix, } } diff --git a/plugin/host2plugin/host2plugin_test.go b/plugin/host2plugin/host2plugin_test.go index 662999b..a8e2301 100644 --- a/plugin/host2plugin/host2plugin_test.go +++ b/plugin/host2plugin/host2plugin_test.go @@ -575,7 +575,11 @@ func (s *mockServer) EvaluateExpr(expr hcl.Expression, opts tflint.EvaluateExprO return cty.Value{}, nil } -func (s *mockServer) EmitIssue(rule tflint.Rule, message string, location hcl.Range) error { +func (s *mockServer) EmitIssue(rule tflint.Rule, message string, location hcl.Range, fixable bool) (bool, error) { + return true, nil +} + +func (s *mockServer) ApplyChanges(sources map[string][]byte) error { return nil } diff --git a/plugin/host2plugin/server.go b/plugin/host2plugin/server.go index 77b4fa4..ab0a88c 100644 --- a/plugin/host2plugin/server.go +++ b/plugin/host2plugin/server.go @@ -116,7 +116,13 @@ func (s *GRPCServer) Check(ctx context.Context, req *proto.Check_Request) (*prot } defer conn.Close() - runner, err := s.impl.NewRunner(&plugin2host.GRPCClient{Client: proto.NewRunnerClient(conn)}) + client := proto.NewRunnerClient(conn) + resp, err := client.GetFiles(ctx, &proto.GetFiles_Request{}) + if err != nil { + return nil, toproto.Error(codes.FailedPrecondition, err) + } + + runner, err := s.impl.NewRunner(&plugin2host.GRPCClient{Client: client, Fixer: tflint.NewFixer(resp.Files), FixEnabled: s.impl.FixEnabled()}) if err != nil { return nil, toproto.Error(codes.FailedPrecondition, err) } diff --git a/plugin/plugin2host/client.go b/plugin/plugin2host/client.go index 5cf275a..b8e1460 100644 --- a/plugin/plugin2host/client.go +++ b/plugin/plugin2host/client.go @@ -27,7 +27,9 @@ import ( // GRPCClient is a plugin-side implementation. Plugin can send requests through the client to host's gRPC server. type GRPCClient struct { - Client proto.RunnerClient + Client proto.RunnerClient + Fixer *tflint.Fixer + FixEnabled bool } var _ tflint.Runner = &GRPCClient{} @@ -423,6 +425,44 @@ func (c *GRPCClient) EmitIssue(rule tflint.Rule, message string, location hcl.Ra return nil } +// EmitIssueWithFix emits the issue with the passed rule, message, location. +// If the fix is applied, the fixFunc is invoked. +// An emitted issue is always marked as fixable. +func (c *GRPCClient) EmitIssueWithFix(rule tflint.Rule, message string, location hcl.Range, fixFunc func(f *tflint.Fixer) error) error { + resp, err := c.Client.EmitIssue(context.Background(), &proto.EmitIssue_Request{Rule: toproto.Rule(rule), Message: message, Range: toproto.Range(location), Fixable: true}) + if err != nil { + return fromproto.Error(err) + } + + if c.FixEnabled && resp.Applied { + path, err := c.GetModulePath() + if err != nil { + return fromproto.Error(err) + } + // If the issue is not in the root module, skip the fix. + if !path.IsRoot() { + return nil + } + return fixFunc(c.Fixer) + } + return nil +} + +// HasChanges returns true if the fixer has changes +func (c *GRPCClient) HasChanges() bool { + return c.Fixer.HasChanges() +} + +// ApplyChanges applies the changes in the fixer to the server +func (c *GRPCClient) ApplyChanges() error { + _, err := c.Client.ApplyChanges(context.Background(), &proto.ApplyChanges_Request{Changes: c.Fixer.Changes()}) + if err != nil { + return fromproto.Error(err) + } + c.Fixer.ApplyChanges() + return nil +} + // EnsureNoError is a helper for error handling. Depending on the type of error generated by EvaluateExpr, // determine whether to exit, skip, or continue. If it is continued, the passed function will be executed. // diff --git a/plugin/plugin2host/plugin2host_test.go b/plugin/plugin2host/plugin2host_test.go index 64c1230..949a83c 100644 --- a/plugin/plugin2host/plugin2host_test.go +++ b/plugin/plugin2host/plugin2host_test.go @@ -43,7 +43,7 @@ type mockServerImpl struct { getFiles func() map[string][]byte getRuleConfigContent func(string, *hclext.BodySchema) (*hclext.BodyContent, map[string][]byte, error) evaluateExpr func(hcl.Expression, tflint.EvaluateExprOption) (cty.Value, error) - emitIssue func(tflint.Rule, string, hcl.Range) error + emitIssue func(tflint.Rule, string, hcl.Range, bool) (bool, error) } func newMockServer(impl mockServerImpl) *mockServer { @@ -99,10 +99,14 @@ func (s *mockServer) EvaluateExpr(expr hcl.Expression, opts tflint.EvaluateExprO return cty.Value{}, nil } -func (s *mockServer) EmitIssue(rule tflint.Rule, message string, location hcl.Range) error { +func (s *mockServer) EmitIssue(rule tflint.Rule, message string, location hcl.Range, fixable bool) (bool, error) { if s.impl.emitIssue != nil { - return s.impl.emitIssue(rule, message, location) + return s.impl.emitIssue(rule, message, location, fixable) } + return true, nil +} + +func (s *mockServer) ApplyChanges(sources map[string][]byte) error { return nil } @@ -2359,7 +2363,7 @@ func TestEmitIssue(t *testing.T) { tests := []struct { Name string Args func() (tflint.Rule, string, hcl.Range) - ServerImpl func(tflint.Rule, string, hcl.Range) error + ServerImpl func(tflint.Rule, string, hcl.Range, bool) (bool, error) ErrCheck func(error) bool }{ { @@ -2367,21 +2371,21 @@ func TestEmitIssue(t *testing.T) { Args: func() (tflint.Rule, string, hcl.Range) { return &Rule{}, "this is test", hcl.Range{Filename: "test.tf", Start: hcl.Pos{Line: 2, Column: 2}, End: hcl.Pos{Line: 2, Column: 10}} }, - ServerImpl: func(rule tflint.Rule, message string, location hcl.Range) error { + ServerImpl: func(rule tflint.Rule, message string, location hcl.Range, fixable bool) (bool, error) { if rule.Name() != "test_rule" { - return fmt.Errorf("rule.Name() should be test_rule, but %s", rule.Name()) + return false, fmt.Errorf("rule.Name() should be test_rule, but %s", rule.Name()) } if rule.Enabled() != true { - return fmt.Errorf("rule.Enabled() should be true, but %t", rule.Enabled()) + return false, fmt.Errorf("rule.Enabled() should be true, but %t", rule.Enabled()) } if rule.Severity() != tflint.ERROR { - return fmt.Errorf("rule.Severity() should be ERROR, but %s", rule.Severity()) + return false, fmt.Errorf("rule.Severity() should be ERROR, but %s", rule.Severity()) } if rule.Link() != "https://example.com" { - return fmt.Errorf("rule.Link() should be https://example.com, but %s", rule.Link()) + return false, fmt.Errorf("rule.Link() should be https://example.com, but %s", rule.Link()) } if message != "this is test" { - return fmt.Errorf("message should be `this is test`, but %s", message) + return false, fmt.Errorf("message should be `this is test`, but %s", message) } want := hcl.Range{ Filename: "test.tf", @@ -2389,9 +2393,9 @@ func TestEmitIssue(t *testing.T) { End: hcl.Pos{Line: 2, Column: 10}, } if diff := cmp.Diff(location, want); diff != "" { - return fmt.Errorf("diff: %s", diff) + return false, fmt.Errorf("diff: %s", diff) } - return nil + return true, nil }, ErrCheck: neverHappend, }, @@ -2400,8 +2404,8 @@ func TestEmitIssue(t *testing.T) { Args: func() (tflint.Rule, string, hcl.Range) { return &Rule{}, "this is test", hcl.Range{Filename: "test.tf", Start: hcl.Pos{Line: 2, Column: 2}, End: hcl.Pos{Line: 2, Column: 10}} }, - ServerImpl: func(tflint.Rule, string, hcl.Range) error { - return errors.New("unexpected error") + ServerImpl: func(tflint.Rule, string, hcl.Range, bool) (bool, error) { + return false, errors.New("unexpected error") }, ErrCheck: func(err error) bool { return err == nil || err.Error() != "unexpected error" diff --git a/plugin/plugin2host/server.go b/plugin/plugin2host/server.go index 7f49635..da1c356 100644 --- a/plugin/plugin2host/server.go +++ b/plugin/plugin2host/server.go @@ -35,7 +35,8 @@ type Server interface { GetFiles(tflint.ModuleCtxType) map[string][]byte GetRuleConfigContent(string, *hclext.BodySchema) (*hclext.BodyContent, map[string][]byte, error) EvaluateExpr(hcl.Expression, tflint.EvaluateExprOption) (cty.Value, error) - EmitIssue(rule tflint.Rule, message string, location hcl.Range) error + EmitIssue(rule tflint.Rule, message string, location hcl.Range, fixable bool) (bool, error) + ApplyChanges(map[string][]byte) error } // GetOriginalwd gets the original working directory. @@ -172,9 +173,18 @@ func (s *GRPCServer) EmitIssue(ctx context.Context, req *proto.EmitIssue_Request return nil, status.Error(codes.InvalidArgument, "range should not be null") } - err := s.Impl.EmitIssue(fromproto.Rule(req.Rule), req.Message, fromproto.Range(req.Range)) + applied, err := s.Impl.EmitIssue(fromproto.Rule(req.Rule), req.Message, fromproto.Range(req.Range), req.Fixable) if err != nil { return nil, toproto.Error(codes.FailedPrecondition, err) } - return &proto.EmitIssue_Response{}, nil + return &proto.EmitIssue_Response{Applied: applied}, nil +} + +// ApplyChanges applies the passed changes. +func (s *GRPCServer) ApplyChanges(ctx context.Context, req *proto.ApplyChanges_Request) (*proto.ApplyChanges_Response, error) { + err := s.Impl.ApplyChanges(req.Changes) + if err != nil { + return nil, toproto.Error(codes.InvalidArgument, err) + } + return &proto.ApplyChanges_Response{}, nil } diff --git a/plugin/proto/tflint.pb.go b/plugin/proto/tflint.pb.go index 5108782..0372960 100644 --- a/plugin/proto/tflint.pb.go +++ b/plugin/proto/tflint.pb.go @@ -920,6 +920,44 @@ func (*EmitIssue) Descriptor() ([]byte, []int) { return file_tflint_proto_rawDescGZIP(), []int{16} } +type ApplyChanges struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields +} + +func (x *ApplyChanges) Reset() { + *x = ApplyChanges{} + if protoimpl.UnsafeEnabled { + mi := &file_tflint_proto_msgTypes[17] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *ApplyChanges) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*ApplyChanges) ProtoMessage() {} + +func (x *ApplyChanges) ProtoReflect() protoreflect.Message { + mi := &file_tflint_proto_msgTypes[17] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use ApplyChanges.ProtoReflect.Descriptor instead. +func (*ApplyChanges) Descriptor() ([]byte, []int) { + return file_tflint_proto_rawDescGZIP(), []int{17} +} + type BodySchema struct { state protoimpl.MessageState sizeCache protoimpl.SizeCache @@ -933,7 +971,7 @@ type BodySchema struct { func (x *BodySchema) Reset() { *x = BodySchema{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[17] + mi := &file_tflint_proto_msgTypes[18] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -946,7 +984,7 @@ func (x *BodySchema) String() string { func (*BodySchema) ProtoMessage() {} func (x *BodySchema) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[17] + mi := &file_tflint_proto_msgTypes[18] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -959,7 +997,7 @@ func (x *BodySchema) ProtoReflect() protoreflect.Message { // Deprecated: Use BodySchema.ProtoReflect.Descriptor instead. func (*BodySchema) Descriptor() ([]byte, []int) { - return file_tflint_proto_rawDescGZIP(), []int{17} + return file_tflint_proto_rawDescGZIP(), []int{18} } func (x *BodySchema) GetAttributes() []*BodySchema_Attribute { @@ -995,7 +1033,7 @@ type BodyContent struct { func (x *BodyContent) Reset() { *x = BodyContent{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[18] + mi := &file_tflint_proto_msgTypes[19] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1008,7 +1046,7 @@ func (x *BodyContent) String() string { func (*BodyContent) ProtoMessage() {} func (x *BodyContent) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[18] + mi := &file_tflint_proto_msgTypes[19] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1021,7 +1059,7 @@ func (x *BodyContent) ProtoReflect() protoreflect.Message { // Deprecated: Use BodyContent.ProtoReflect.Descriptor instead. func (*BodyContent) Descriptor() ([]byte, []int) { - return file_tflint_proto_rawDescGZIP(), []int{18} + return file_tflint_proto_rawDescGZIP(), []int{19} } func (x *BodyContent) GetAttributes() map[string]*BodyContent_Attribute { @@ -1052,7 +1090,7 @@ type Expression struct { func (x *Expression) Reset() { *x = Expression{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[19] + mi := &file_tflint_proto_msgTypes[20] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1065,7 +1103,7 @@ func (x *Expression) String() string { func (*Expression) ProtoMessage() {} func (x *Expression) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[19] + mi := &file_tflint_proto_msgTypes[20] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1078,7 +1116,7 @@ func (x *Expression) ProtoReflect() protoreflect.Message { // Deprecated: Use Expression.ProtoReflect.Descriptor instead. func (*Expression) Descriptor() ([]byte, []int) { - return file_tflint_proto_rawDescGZIP(), []int{19} + return file_tflint_proto_rawDescGZIP(), []int{20} } func (x *Expression) GetBytes() []byte { @@ -1122,7 +1160,7 @@ type Range struct { func (x *Range) Reset() { *x = Range{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[20] + mi := &file_tflint_proto_msgTypes[21] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1135,7 +1173,7 @@ func (x *Range) String() string { func (*Range) ProtoMessage() {} func (x *Range) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[20] + mi := &file_tflint_proto_msgTypes[21] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1148,7 +1186,7 @@ func (x *Range) ProtoReflect() protoreflect.Message { // Deprecated: Use Range.ProtoReflect.Descriptor instead. func (*Range) Descriptor() ([]byte, []int) { - return file_tflint_proto_rawDescGZIP(), []int{20} + return file_tflint_proto_rawDescGZIP(), []int{21} } func (x *Range) GetFilename() string { @@ -1183,7 +1221,7 @@ type AttributePath struct { func (x *AttributePath) Reset() { *x = AttributePath{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[21] + mi := &file_tflint_proto_msgTypes[22] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1196,7 +1234,7 @@ func (x *AttributePath) String() string { func (*AttributePath) ProtoMessage() {} func (x *AttributePath) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[21] + mi := &file_tflint_proto_msgTypes[22] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1209,7 +1247,7 @@ func (x *AttributePath) ProtoReflect() protoreflect.Message { // Deprecated: Use AttributePath.ProtoReflect.Descriptor instead. func (*AttributePath) Descriptor() ([]byte, []int) { - return file_tflint_proto_rawDescGZIP(), []int{21} + return file_tflint_proto_rawDescGZIP(), []int{22} } func (x *AttributePath) GetSteps() []*AttributePath_Step { @@ -1231,7 +1269,7 @@ type ValueMark struct { func (x *ValueMark) Reset() { *x = ValueMark{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[22] + mi := &file_tflint_proto_msgTypes[23] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1244,7 +1282,7 @@ func (x *ValueMark) String() string { func (*ValueMark) ProtoMessage() {} func (x *ValueMark) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[22] + mi := &file_tflint_proto_msgTypes[23] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1257,7 +1295,7 @@ func (x *ValueMark) ProtoReflect() protoreflect.Message { // Deprecated: Use ValueMark.ProtoReflect.Descriptor instead. func (*ValueMark) Descriptor() ([]byte, []int) { - return file_tflint_proto_rawDescGZIP(), []int{22} + return file_tflint_proto_rawDescGZIP(), []int{23} } func (x *ValueMark) GetPath() *AttributePath { @@ -1286,7 +1324,7 @@ type ErrorDetail struct { func (x *ErrorDetail) Reset() { *x = ErrorDetail{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[23] + mi := &file_tflint_proto_msgTypes[24] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1299,7 +1337,7 @@ func (x *ErrorDetail) String() string { func (*ErrorDetail) ProtoMessage() {} func (x *ErrorDetail) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[23] + mi := &file_tflint_proto_msgTypes[24] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1312,7 +1350,7 @@ func (x *ErrorDetail) ProtoReflect() protoreflect.Message { // Deprecated: Use ErrorDetail.ProtoReflect.Descriptor instead. func (*ErrorDetail) Descriptor() ([]byte, []int) { - return file_tflint_proto_rawDescGZIP(), []int{23} + return file_tflint_proto_rawDescGZIP(), []int{24} } func (x *ErrorDetail) GetCode() ErrorCode { @@ -1338,7 +1376,7 @@ type GetName_Request struct { func (x *GetName_Request) Reset() { *x = GetName_Request{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[24] + mi := &file_tflint_proto_msgTypes[25] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1351,7 +1389,7 @@ func (x *GetName_Request) String() string { func (*GetName_Request) ProtoMessage() {} func (x *GetName_Request) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[24] + mi := &file_tflint_proto_msgTypes[25] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1378,7 +1416,7 @@ type GetName_Response struct { func (x *GetName_Response) Reset() { *x = GetName_Response{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[25] + mi := &file_tflint_proto_msgTypes[26] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1391,7 +1429,7 @@ func (x *GetName_Response) String() string { func (*GetName_Response) ProtoMessage() {} func (x *GetName_Response) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[25] + mi := &file_tflint_proto_msgTypes[26] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1423,7 +1461,7 @@ type GetVersion_Request struct { func (x *GetVersion_Request) Reset() { *x = GetVersion_Request{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[26] + mi := &file_tflint_proto_msgTypes[27] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1436,7 +1474,7 @@ func (x *GetVersion_Request) String() string { func (*GetVersion_Request) ProtoMessage() {} func (x *GetVersion_Request) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[26] + mi := &file_tflint_proto_msgTypes[27] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1463,7 +1501,7 @@ type GetVersion_Response struct { func (x *GetVersion_Response) Reset() { *x = GetVersion_Response{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[27] + mi := &file_tflint_proto_msgTypes[28] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1476,7 +1514,7 @@ func (x *GetVersion_Response) String() string { func (*GetVersion_Response) ProtoMessage() {} func (x *GetVersion_Response) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[27] + mi := &file_tflint_proto_msgTypes[28] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1508,7 +1546,7 @@ type GetVersionConstraint_Request struct { func (x *GetVersionConstraint_Request) Reset() { *x = GetVersionConstraint_Request{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[28] + mi := &file_tflint_proto_msgTypes[29] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1521,7 +1559,7 @@ func (x *GetVersionConstraint_Request) String() string { func (*GetVersionConstraint_Request) ProtoMessage() {} func (x *GetVersionConstraint_Request) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[28] + mi := &file_tflint_proto_msgTypes[29] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1548,7 +1586,7 @@ type GetVersionConstraint_Response struct { func (x *GetVersionConstraint_Response) Reset() { *x = GetVersionConstraint_Response{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[29] + mi := &file_tflint_proto_msgTypes[30] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1561,7 +1599,7 @@ func (x *GetVersionConstraint_Response) String() string { func (*GetVersionConstraint_Response) ProtoMessage() {} func (x *GetVersionConstraint_Response) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[29] + mi := &file_tflint_proto_msgTypes[30] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1593,7 +1631,7 @@ type GetSDKVersion_Request struct { func (x *GetSDKVersion_Request) Reset() { *x = GetSDKVersion_Request{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[30] + mi := &file_tflint_proto_msgTypes[31] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1606,7 +1644,7 @@ func (x *GetSDKVersion_Request) String() string { func (*GetSDKVersion_Request) ProtoMessage() {} func (x *GetSDKVersion_Request) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[30] + mi := &file_tflint_proto_msgTypes[31] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1633,7 +1671,7 @@ type GetSDKVersion_Response struct { func (x *GetSDKVersion_Response) Reset() { *x = GetSDKVersion_Response{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[31] + mi := &file_tflint_proto_msgTypes[32] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1646,7 +1684,7 @@ func (x *GetSDKVersion_Response) String() string { func (*GetSDKVersion_Response) ProtoMessage() {} func (x *GetSDKVersion_Response) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[31] + mi := &file_tflint_proto_msgTypes[32] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1678,7 +1716,7 @@ type GetRuleNames_Request struct { func (x *GetRuleNames_Request) Reset() { *x = GetRuleNames_Request{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[32] + mi := &file_tflint_proto_msgTypes[33] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1691,7 +1729,7 @@ func (x *GetRuleNames_Request) String() string { func (*GetRuleNames_Request) ProtoMessage() {} func (x *GetRuleNames_Request) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[32] + mi := &file_tflint_proto_msgTypes[33] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1718,7 +1756,7 @@ type GetRuleNames_Response struct { func (x *GetRuleNames_Response) Reset() { *x = GetRuleNames_Response{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[33] + mi := &file_tflint_proto_msgTypes[34] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1731,7 +1769,7 @@ func (x *GetRuleNames_Response) String() string { func (*GetRuleNames_Response) ProtoMessage() {} func (x *GetRuleNames_Response) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[33] + mi := &file_tflint_proto_msgTypes[34] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1763,7 +1801,7 @@ type GetConfigSchema_Request struct { func (x *GetConfigSchema_Request) Reset() { *x = GetConfigSchema_Request{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[34] + mi := &file_tflint_proto_msgTypes[35] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1776,7 +1814,7 @@ func (x *GetConfigSchema_Request) String() string { func (*GetConfigSchema_Request) ProtoMessage() {} func (x *GetConfigSchema_Request) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[34] + mi := &file_tflint_proto_msgTypes[35] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1803,7 +1841,7 @@ type GetConfigSchema_Response struct { func (x *GetConfigSchema_Response) Reset() { *x = GetConfigSchema_Response{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[35] + mi := &file_tflint_proto_msgTypes[36] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1816,7 +1854,7 @@ func (x *GetConfigSchema_Response) String() string { func (*GetConfigSchema_Response) ProtoMessage() {} func (x *GetConfigSchema_Response) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[35] + mi := &file_tflint_proto_msgTypes[36] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1847,12 +1885,13 @@ type ApplyGlobalConfig_Config struct { Rules map[string]*ApplyGlobalConfig_RuleConfig `protobuf:"bytes,1,rep,name=rules,proto3" json:"rules,omitempty" protobuf_key:"bytes,1,opt,name=key,proto3" protobuf_val:"bytes,2,opt,name=value,proto3"` DisabledByDefault bool `protobuf:"varint,2,opt,name=disabled_by_default,json=disabledByDefault,proto3" json:"disabled_by_default,omitempty"` Only []string `protobuf:"bytes,3,rep,name=only,proto3" json:"only,omitempty"` + Fix bool `protobuf:"varint,4,opt,name=fix,proto3" json:"fix,omitempty"` } func (x *ApplyGlobalConfig_Config) Reset() { *x = ApplyGlobalConfig_Config{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[36] + mi := &file_tflint_proto_msgTypes[37] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1865,7 +1904,7 @@ func (x *ApplyGlobalConfig_Config) String() string { func (*ApplyGlobalConfig_Config) ProtoMessage() {} func (x *ApplyGlobalConfig_Config) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[36] + mi := &file_tflint_proto_msgTypes[37] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1902,6 +1941,13 @@ func (x *ApplyGlobalConfig_Config) GetOnly() []string { return nil } +func (x *ApplyGlobalConfig_Config) GetFix() bool { + if x != nil { + return x.Fix + } + return false +} + type ApplyGlobalConfig_RuleConfig struct { state protoimpl.MessageState sizeCache protoimpl.SizeCache @@ -1914,7 +1960,7 @@ type ApplyGlobalConfig_RuleConfig struct { func (x *ApplyGlobalConfig_RuleConfig) Reset() { *x = ApplyGlobalConfig_RuleConfig{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[37] + mi := &file_tflint_proto_msgTypes[38] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1927,7 +1973,7 @@ func (x *ApplyGlobalConfig_RuleConfig) String() string { func (*ApplyGlobalConfig_RuleConfig) ProtoMessage() {} func (x *ApplyGlobalConfig_RuleConfig) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[37] + mi := &file_tflint_proto_msgTypes[38] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -1968,7 +2014,7 @@ type ApplyGlobalConfig_Request struct { func (x *ApplyGlobalConfig_Request) Reset() { *x = ApplyGlobalConfig_Request{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[38] + mi := &file_tflint_proto_msgTypes[39] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -1981,7 +2027,7 @@ func (x *ApplyGlobalConfig_Request) String() string { func (*ApplyGlobalConfig_Request) ProtoMessage() {} func (x *ApplyGlobalConfig_Request) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[38] + mi := &file_tflint_proto_msgTypes[39] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -2013,7 +2059,7 @@ type ApplyGlobalConfig_Response struct { func (x *ApplyGlobalConfig_Response) Reset() { *x = ApplyGlobalConfig_Response{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[39] + mi := &file_tflint_proto_msgTypes[40] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -2026,7 +2072,7 @@ func (x *ApplyGlobalConfig_Response) String() string { func (*ApplyGlobalConfig_Response) ProtoMessage() {} func (x *ApplyGlobalConfig_Response) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[39] + mi := &file_tflint_proto_msgTypes[40] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -2053,7 +2099,7 @@ type ApplyConfig_Request struct { func (x *ApplyConfig_Request) Reset() { *x = ApplyConfig_Request{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[41] + mi := &file_tflint_proto_msgTypes[42] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -2066,7 +2112,7 @@ func (x *ApplyConfig_Request) String() string { func (*ApplyConfig_Request) ProtoMessage() {} func (x *ApplyConfig_Request) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[41] + mi := &file_tflint_proto_msgTypes[42] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -2098,7 +2144,7 @@ type ApplyConfig_Response struct { func (x *ApplyConfig_Response) Reset() { *x = ApplyConfig_Response{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[42] + mi := &file_tflint_proto_msgTypes[43] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -2111,7 +2157,7 @@ func (x *ApplyConfig_Response) String() string { func (*ApplyConfig_Response) ProtoMessage() {} func (x *ApplyConfig_Response) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[42] + mi := &file_tflint_proto_msgTypes[43] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -2138,7 +2184,7 @@ type Check_Request struct { func (x *Check_Request) Reset() { *x = Check_Request{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[43] + mi := &file_tflint_proto_msgTypes[44] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -2151,7 +2197,7 @@ func (x *Check_Request) String() string { func (*Check_Request) ProtoMessage() {} func (x *Check_Request) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[43] + mi := &file_tflint_proto_msgTypes[44] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -2183,7 +2229,7 @@ type Check_Response struct { func (x *Check_Response) Reset() { *x = Check_Response{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[44] + mi := &file_tflint_proto_msgTypes[45] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -2196,7 +2242,7 @@ func (x *Check_Response) String() string { func (*Check_Response) ProtoMessage() {} func (x *Check_Response) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[44] + mi := &file_tflint_proto_msgTypes[45] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -2221,7 +2267,7 @@ type GetOriginalwd_Request struct { func (x *GetOriginalwd_Request) Reset() { *x = GetOriginalwd_Request{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[45] + mi := &file_tflint_proto_msgTypes[46] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -2234,7 +2280,7 @@ func (x *GetOriginalwd_Request) String() string { func (*GetOriginalwd_Request) ProtoMessage() {} func (x *GetOriginalwd_Request) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[45] + mi := &file_tflint_proto_msgTypes[46] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -2261,7 +2307,7 @@ type GetOriginalwd_Response struct { func (x *GetOriginalwd_Response) Reset() { *x = GetOriginalwd_Response{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[46] + mi := &file_tflint_proto_msgTypes[47] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -2274,7 +2320,7 @@ func (x *GetOriginalwd_Response) String() string { func (*GetOriginalwd_Response) ProtoMessage() {} func (x *GetOriginalwd_Response) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[46] + mi := &file_tflint_proto_msgTypes[47] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -2306,7 +2352,7 @@ type GetModulePath_Request struct { func (x *GetModulePath_Request) Reset() { *x = GetModulePath_Request{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[47] + mi := &file_tflint_proto_msgTypes[48] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -2319,7 +2365,7 @@ func (x *GetModulePath_Request) String() string { func (*GetModulePath_Request) ProtoMessage() {} func (x *GetModulePath_Request) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[47] + mi := &file_tflint_proto_msgTypes[48] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -2346,7 +2392,7 @@ type GetModulePath_Response struct { func (x *GetModulePath_Response) Reset() { *x = GetModulePath_Response{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[48] + mi := &file_tflint_proto_msgTypes[49] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -2359,7 +2405,7 @@ func (x *GetModulePath_Response) String() string { func (*GetModulePath_Response) ProtoMessage() {} func (x *GetModulePath_Response) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[48] + mi := &file_tflint_proto_msgTypes[49] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -2393,7 +2439,7 @@ type GetModuleContent_Hint struct { func (x *GetModuleContent_Hint) Reset() { *x = GetModuleContent_Hint{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[49] + mi := &file_tflint_proto_msgTypes[50] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -2406,7 +2452,7 @@ func (x *GetModuleContent_Hint) String() string { func (*GetModuleContent_Hint) ProtoMessage() {} func (x *GetModuleContent_Hint) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[49] + mi := &file_tflint_proto_msgTypes[50] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -2444,7 +2490,7 @@ type GetModuleContent_Option struct { func (x *GetModuleContent_Option) Reset() { *x = GetModuleContent_Option{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[50] + mi := &file_tflint_proto_msgTypes[51] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -2457,7 +2503,7 @@ func (x *GetModuleContent_Option) String() string { func (*GetModuleContent_Option) ProtoMessage() {} func (x *GetModuleContent_Option) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[50] + mi := &file_tflint_proto_msgTypes[51] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -2514,7 +2560,7 @@ type GetModuleContent_Request struct { func (x *GetModuleContent_Request) Reset() { *x = GetModuleContent_Request{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[51] + mi := &file_tflint_proto_msgTypes[52] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -2527,7 +2573,7 @@ func (x *GetModuleContent_Request) String() string { func (*GetModuleContent_Request) ProtoMessage() {} func (x *GetModuleContent_Request) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[51] + mi := &file_tflint_proto_msgTypes[52] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -2568,7 +2614,7 @@ type GetModuleContent_Response struct { func (x *GetModuleContent_Response) Reset() { *x = GetModuleContent_Response{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[52] + mi := &file_tflint_proto_msgTypes[53] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -2581,7 +2627,7 @@ func (x *GetModuleContent_Response) String() string { func (*GetModuleContent_Response) ProtoMessage() {} func (x *GetModuleContent_Response) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[52] + mi := &file_tflint_proto_msgTypes[53] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -2615,7 +2661,7 @@ type GetFile_Request struct { func (x *GetFile_Request) Reset() { *x = GetFile_Request{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[53] + mi := &file_tflint_proto_msgTypes[54] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -2628,7 +2674,7 @@ func (x *GetFile_Request) String() string { func (*GetFile_Request) ProtoMessage() {} func (x *GetFile_Request) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[53] + mi := &file_tflint_proto_msgTypes[54] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -2662,7 +2708,7 @@ type GetFile_Response struct { func (x *GetFile_Response) Reset() { *x = GetFile_Response{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[54] + mi := &file_tflint_proto_msgTypes[55] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -2675,7 +2721,7 @@ func (x *GetFile_Response) String() string { func (*GetFile_Response) ProtoMessage() {} func (x *GetFile_Response) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[54] + mi := &file_tflint_proto_msgTypes[55] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -2707,7 +2753,7 @@ type GetFiles_Request struct { func (x *GetFiles_Request) Reset() { *x = GetFiles_Request{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[55] + mi := &file_tflint_proto_msgTypes[56] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -2720,7 +2766,7 @@ func (x *GetFiles_Request) String() string { func (*GetFiles_Request) ProtoMessage() {} func (x *GetFiles_Request) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[55] + mi := &file_tflint_proto_msgTypes[56] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -2747,7 +2793,7 @@ type GetFiles_Response struct { func (x *GetFiles_Response) Reset() { *x = GetFiles_Response{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[56] + mi := &file_tflint_proto_msgTypes[57] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -2760,7 +2806,7 @@ func (x *GetFiles_Response) String() string { func (*GetFiles_Response) ProtoMessage() {} func (x *GetFiles_Response) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[56] + mi := &file_tflint_proto_msgTypes[57] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -2795,7 +2841,7 @@ type GetRuleConfigContent_Request struct { func (x *GetRuleConfigContent_Request) Reset() { *x = GetRuleConfigContent_Request{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[58] + mi := &file_tflint_proto_msgTypes[59] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -2808,7 +2854,7 @@ func (x *GetRuleConfigContent_Request) String() string { func (*GetRuleConfigContent_Request) ProtoMessage() {} func (x *GetRuleConfigContent_Request) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[58] + mi := &file_tflint_proto_msgTypes[59] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -2849,7 +2895,7 @@ type GetRuleConfigContent_Response struct { func (x *GetRuleConfigContent_Response) Reset() { *x = GetRuleConfigContent_Response{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[59] + mi := &file_tflint_proto_msgTypes[60] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -2862,7 +2908,7 @@ func (x *GetRuleConfigContent_Response) String() string { func (*GetRuleConfigContent_Response) ProtoMessage() {} func (x *GetRuleConfigContent_Response) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[59] + mi := &file_tflint_proto_msgTypes[60] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -2897,7 +2943,7 @@ type EvaluateExpr_Option struct { func (x *EvaluateExpr_Option) Reset() { *x = EvaluateExpr_Option{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[60] + mi := &file_tflint_proto_msgTypes[61] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -2910,7 +2956,7 @@ func (x *EvaluateExpr_Option) String() string { func (*EvaluateExpr_Option) ProtoMessage() {} func (x *EvaluateExpr_Option) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[60] + mi := &file_tflint_proto_msgTypes[61] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -2956,7 +3002,7 @@ type EvaluateExpr_Request struct { func (x *EvaluateExpr_Request) Reset() { *x = EvaluateExpr_Request{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[61] + mi := &file_tflint_proto_msgTypes[62] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -2969,7 +3015,7 @@ func (x *EvaluateExpr_Request) String() string { func (*EvaluateExpr_Request) ProtoMessage() {} func (x *EvaluateExpr_Request) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[61] + mi := &file_tflint_proto_msgTypes[62] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -3027,7 +3073,7 @@ type EvaluateExpr_Response struct { func (x *EvaluateExpr_Response) Reset() { *x = EvaluateExpr_Response{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[62] + mi := &file_tflint_proto_msgTypes[63] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -3040,7 +3086,7 @@ func (x *EvaluateExpr_Response) String() string { func (*EvaluateExpr_Response) ProtoMessage() {} func (x *EvaluateExpr_Response) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[62] + mi := &file_tflint_proto_msgTypes[63] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -3084,7 +3130,7 @@ type EmitIssue_Rule struct { func (x *EmitIssue_Rule) Reset() { *x = EmitIssue_Rule{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[63] + mi := &file_tflint_proto_msgTypes[64] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -3097,7 +3143,7 @@ func (x *EmitIssue_Rule) String() string { func (*EmitIssue_Rule) ProtoMessage() {} func (x *EmitIssue_Rule) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[63] + mi := &file_tflint_proto_msgTypes[64] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -3149,12 +3195,13 @@ type EmitIssue_Request struct { Rule *EmitIssue_Rule `protobuf:"bytes,1,opt,name=rule,proto3" json:"rule,omitempty"` Message string `protobuf:"bytes,2,opt,name=message,proto3" json:"message,omitempty"` Range *Range `protobuf:"bytes,3,opt,name=range,proto3" json:"range,omitempty"` + Fixable bool `protobuf:"varint,4,opt,name=fixable,proto3" json:"fixable,omitempty"` } func (x *EmitIssue_Request) Reset() { *x = EmitIssue_Request{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[64] + mi := &file_tflint_proto_msgTypes[65] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -3167,7 +3214,7 @@ func (x *EmitIssue_Request) String() string { func (*EmitIssue_Request) ProtoMessage() {} func (x *EmitIssue_Request) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[64] + mi := &file_tflint_proto_msgTypes[65] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -3204,16 +3251,25 @@ func (x *EmitIssue_Request) GetRange() *Range { return nil } +func (x *EmitIssue_Request) GetFixable() bool { + if x != nil { + return x.Fixable + } + return false +} + type EmitIssue_Response struct { state protoimpl.MessageState sizeCache protoimpl.SizeCache unknownFields protoimpl.UnknownFields + + Applied bool `protobuf:"varint,1,opt,name=applied,proto3" json:"applied,omitempty"` } func (x *EmitIssue_Response) Reset() { *x = EmitIssue_Response{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[65] + mi := &file_tflint_proto_msgTypes[66] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -3226,7 +3282,7 @@ func (x *EmitIssue_Response) String() string { func (*EmitIssue_Response) ProtoMessage() {} func (x *EmitIssue_Response) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[65] + mi := &file_tflint_proto_msgTypes[66] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -3242,6 +3298,98 @@ func (*EmitIssue_Response) Descriptor() ([]byte, []int) { return file_tflint_proto_rawDescGZIP(), []int{16, 2} } +func (x *EmitIssue_Response) GetApplied() bool { + if x != nil { + return x.Applied + } + return false +} + +type ApplyChanges_Request struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields + + Changes map[string][]byte `protobuf:"bytes,1,rep,name=changes,proto3" json:"changes,omitempty" protobuf_key:"bytes,1,opt,name=key,proto3" protobuf_val:"bytes,2,opt,name=value,proto3"` +} + +func (x *ApplyChanges_Request) Reset() { + *x = ApplyChanges_Request{} + if protoimpl.UnsafeEnabled { + mi := &file_tflint_proto_msgTypes[67] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *ApplyChanges_Request) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*ApplyChanges_Request) ProtoMessage() {} + +func (x *ApplyChanges_Request) ProtoReflect() protoreflect.Message { + mi := &file_tflint_proto_msgTypes[67] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use ApplyChanges_Request.ProtoReflect.Descriptor instead. +func (*ApplyChanges_Request) Descriptor() ([]byte, []int) { + return file_tflint_proto_rawDescGZIP(), []int{17, 0} +} + +func (x *ApplyChanges_Request) GetChanges() map[string][]byte { + if x != nil { + return x.Changes + } + return nil +} + +type ApplyChanges_Response struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields +} + +func (x *ApplyChanges_Response) Reset() { + *x = ApplyChanges_Response{} + if protoimpl.UnsafeEnabled { + mi := &file_tflint_proto_msgTypes[68] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *ApplyChanges_Response) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*ApplyChanges_Response) ProtoMessage() {} + +func (x *ApplyChanges_Response) ProtoReflect() protoreflect.Message { + mi := &file_tflint_proto_msgTypes[68] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use ApplyChanges_Response.ProtoReflect.Descriptor instead. +func (*ApplyChanges_Response) Descriptor() ([]byte, []int) { + return file_tflint_proto_rawDescGZIP(), []int{17, 1} +} + type BodySchema_Attribute struct { state protoimpl.MessageState sizeCache protoimpl.SizeCache @@ -3254,7 +3402,7 @@ type BodySchema_Attribute struct { func (x *BodySchema_Attribute) Reset() { *x = BodySchema_Attribute{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[66] + mi := &file_tflint_proto_msgTypes[70] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -3267,7 +3415,7 @@ func (x *BodySchema_Attribute) String() string { func (*BodySchema_Attribute) ProtoMessage() {} func (x *BodySchema_Attribute) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[66] + mi := &file_tflint_proto_msgTypes[70] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -3280,7 +3428,7 @@ func (x *BodySchema_Attribute) ProtoReflect() protoreflect.Message { // Deprecated: Use BodySchema_Attribute.ProtoReflect.Descriptor instead. func (*BodySchema_Attribute) Descriptor() ([]byte, []int) { - return file_tflint_proto_rawDescGZIP(), []int{17, 0} + return file_tflint_proto_rawDescGZIP(), []int{18, 0} } func (x *BodySchema_Attribute) GetName() string { @@ -3310,7 +3458,7 @@ type BodySchema_Block struct { func (x *BodySchema_Block) Reset() { *x = BodySchema_Block{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[67] + mi := &file_tflint_proto_msgTypes[71] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -3323,7 +3471,7 @@ func (x *BodySchema_Block) String() string { func (*BodySchema_Block) ProtoMessage() {} func (x *BodySchema_Block) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[67] + mi := &file_tflint_proto_msgTypes[71] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -3336,7 +3484,7 @@ func (x *BodySchema_Block) ProtoReflect() protoreflect.Message { // Deprecated: Use BodySchema_Block.ProtoReflect.Descriptor instead. func (*BodySchema_Block) Descriptor() ([]byte, []int) { - return file_tflint_proto_rawDescGZIP(), []int{17, 1} + return file_tflint_proto_rawDescGZIP(), []int{18, 1} } func (x *BodySchema_Block) GetType() string { @@ -3378,7 +3526,7 @@ type BodyContent_Attribute struct { func (x *BodyContent_Attribute) Reset() { *x = BodyContent_Attribute{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[68] + mi := &file_tflint_proto_msgTypes[72] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -3391,7 +3539,7 @@ func (x *BodyContent_Attribute) String() string { func (*BodyContent_Attribute) ProtoMessage() {} func (x *BodyContent_Attribute) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[68] + mi := &file_tflint_proto_msgTypes[72] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -3404,7 +3552,7 @@ func (x *BodyContent_Attribute) ProtoReflect() protoreflect.Message { // Deprecated: Use BodyContent_Attribute.ProtoReflect.Descriptor instead. func (*BodyContent_Attribute) Descriptor() ([]byte, []int) { - return file_tflint_proto_rawDescGZIP(), []int{18, 0} + return file_tflint_proto_rawDescGZIP(), []int{19, 0} } func (x *BodyContent_Attribute) GetName() string { @@ -3467,7 +3615,7 @@ type BodyContent_Block struct { func (x *BodyContent_Block) Reset() { *x = BodyContent_Block{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[69] + mi := &file_tflint_proto_msgTypes[73] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -3480,7 +3628,7 @@ func (x *BodyContent_Block) String() string { func (*BodyContent_Block) ProtoMessage() {} func (x *BodyContent_Block) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[69] + mi := &file_tflint_proto_msgTypes[73] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -3493,7 +3641,7 @@ func (x *BodyContent_Block) ProtoReflect() protoreflect.Message { // Deprecated: Use BodyContent_Block.ProtoReflect.Descriptor instead. func (*BodyContent_Block) Descriptor() ([]byte, []int) { - return file_tflint_proto_rawDescGZIP(), []int{18, 1} + return file_tflint_proto_rawDescGZIP(), []int{19, 1} } func (x *BodyContent_Block) GetType() string { @@ -3551,7 +3699,7 @@ type Range_Pos struct { func (x *Range_Pos) Reset() { *x = Range_Pos{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[71] + mi := &file_tflint_proto_msgTypes[75] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -3564,7 +3712,7 @@ func (x *Range_Pos) String() string { func (*Range_Pos) ProtoMessage() {} func (x *Range_Pos) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[71] + mi := &file_tflint_proto_msgTypes[75] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -3577,7 +3725,7 @@ func (x *Range_Pos) ProtoReflect() protoreflect.Message { // Deprecated: Use Range_Pos.ProtoReflect.Descriptor instead. func (*Range_Pos) Descriptor() ([]byte, []int) { - return file_tflint_proto_rawDescGZIP(), []int{20, 0} + return file_tflint_proto_rawDescGZIP(), []int{21, 0} } func (x *Range_Pos) GetLine() int64 { @@ -3617,7 +3765,7 @@ type AttributePath_Step struct { func (x *AttributePath_Step) Reset() { *x = AttributePath_Step{} if protoimpl.UnsafeEnabled { - mi := &file_tflint_proto_msgTypes[72] + mi := &file_tflint_proto_msgTypes[76] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } @@ -3630,7 +3778,7 @@ func (x *AttributePath_Step) String() string { func (*AttributePath_Step) ProtoMessage() {} func (x *AttributePath_Step) ProtoReflect() protoreflect.Message { - mi := &file_tflint_proto_msgTypes[72] + mi := &file_tflint_proto_msgTypes[76] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { @@ -3643,7 +3791,7 @@ func (x *AttributePath_Step) ProtoReflect() protoreflect.Message { // Deprecated: Use AttributePath_Step.ProtoReflect.Descriptor instead. func (*AttributePath_Step) Descriptor() ([]byte, []int) { - return file_tflint_proto_rawDescGZIP(), []int{21, 0} + return file_tflint_proto_rawDescGZIP(), []int{22, 0} } func (m *AttributePath_Step) GetSelector() isAttributePath_Step_Selector { @@ -3725,9 +3873,9 @@ var file_tflint_proto_rawDesc = []byte{ 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x35, 0x0a, 0x08, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x29, 0x0a, 0x06, 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x11, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x42, 0x6f, 0x64, 0x79, 0x53, - 0x63, 0x68, 0x65, 0x6d, 0x61, 0x52, 0x06, 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x22, 0x8f, 0x03, + 0x63, 0x68, 0x65, 0x6d, 0x61, 0x52, 0x06, 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x22, 0xa1, 0x03, 0x0a, 0x11, 0x41, 0x70, 0x70, 0x6c, 0x79, 0x47, 0x6c, 0x6f, 0x62, 0x61, 0x6c, 0x43, 0x6f, 0x6e, - 0x66, 0x69, 0x67, 0x1a, 0xed, 0x01, 0x0a, 0x06, 0x43, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x12, 0x40, + 0x66, 0x69, 0x67, 0x1a, 0xff, 0x01, 0x0a, 0x06, 0x43, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x12, 0x40, 0x0a, 0x05, 0x72, 0x75, 0x6c, 0x65, 0x73, 0x18, 0x01, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x2a, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x41, 0x70, 0x70, 0x6c, 0x79, 0x47, 0x6c, 0x6f, 0x62, 0x61, 0x6c, 0x43, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x2e, 0x43, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x2e, 0x52, @@ -3736,142 +3884,157 @@ var file_tflint_proto_rawDesc = []byte{ 0x64, 0x65, 0x66, 0x61, 0x75, 0x6c, 0x74, 0x18, 0x02, 0x20, 0x01, 0x28, 0x08, 0x52, 0x11, 0x64, 0x69, 0x73, 0x61, 0x62, 0x6c, 0x65, 0x64, 0x42, 0x79, 0x44, 0x65, 0x66, 0x61, 0x75, 0x6c, 0x74, 0x12, 0x12, 0x0a, 0x04, 0x6f, 0x6e, 0x6c, 0x79, 0x18, 0x03, 0x20, 0x03, 0x28, 0x09, 0x52, 0x04, - 0x6f, 0x6e, 0x6c, 0x79, 0x1a, 0x5d, 0x0a, 0x0a, 0x52, 0x75, 0x6c, 0x65, 0x73, 0x45, 0x6e, 0x74, - 0x72, 0x79, 0x12, 0x10, 0x0a, 0x03, 0x6b, 0x65, 0x79, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, - 0x03, 0x6b, 0x65, 0x79, 0x12, 0x39, 0x0a, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x18, 0x02, 0x20, - 0x01, 0x28, 0x0b, 0x32, 0x23, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x41, 0x70, 0x70, 0x6c, - 0x79, 0x47, 0x6c, 0x6f, 0x62, 0x61, 0x6c, 0x43, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x2e, 0x52, 0x75, - 0x6c, 0x65, 0x43, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x52, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x3a, - 0x02, 0x38, 0x01, 0x1a, 0x3a, 0x0a, 0x0a, 0x52, 0x75, 0x6c, 0x65, 0x43, 0x6f, 0x6e, 0x66, 0x69, - 0x67, 0x12, 0x12, 0x0a, 0x04, 0x6e, 0x61, 0x6d, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, - 0x04, 0x6e, 0x61, 0x6d, 0x65, 0x12, 0x18, 0x0a, 0x07, 0x65, 0x6e, 0x61, 0x62, 0x6c, 0x65, 0x64, - 0x18, 0x02, 0x20, 0x01, 0x28, 0x08, 0x52, 0x07, 0x65, 0x6e, 0x61, 0x62, 0x6c, 0x65, 0x64, 0x1a, - 0x42, 0x0a, 0x07, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x37, 0x0a, 0x06, 0x63, 0x6f, - 0x6e, 0x66, 0x69, 0x67, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x1f, 0x2e, 0x70, 0x72, 0x6f, - 0x74, 0x6f, 0x2e, 0x41, 0x70, 0x70, 0x6c, 0x79, 0x47, 0x6c, 0x6f, 0x62, 0x61, 0x6c, 0x43, 0x6f, - 0x6e, 0x66, 0x69, 0x67, 0x2e, 0x43, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x52, 0x06, 0x63, 0x6f, 0x6e, - 0x66, 0x69, 0x67, 0x1a, 0x0a, 0x0a, 0x08, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, - 0x52, 0x0a, 0x0b, 0x41, 0x70, 0x70, 0x6c, 0x79, 0x43, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x1a, 0x37, - 0x0a, 0x07, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x2c, 0x0a, 0x07, 0x63, 0x6f, 0x6e, - 0x74, 0x65, 0x6e, 0x74, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x12, 0x2e, 0x70, 0x72, 0x6f, - 0x74, 0x6f, 0x2e, 0x42, 0x6f, 0x64, 0x79, 0x43, 0x6f, 0x6e, 0x74, 0x65, 0x6e, 0x74, 0x52, 0x07, - 0x63, 0x6f, 0x6e, 0x74, 0x65, 0x6e, 0x74, 0x1a, 0x0a, 0x0a, 0x08, 0x52, 0x65, 0x73, 0x70, 0x6f, - 0x6e, 0x73, 0x65, 0x22, 0x36, 0x0a, 0x05, 0x43, 0x68, 0x65, 0x63, 0x6b, 0x1a, 0x21, 0x0a, 0x07, - 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x16, 0x0a, 0x06, 0x72, 0x75, 0x6e, 0x6e, 0x65, - 0x72, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0d, 0x52, 0x06, 0x72, 0x75, 0x6e, 0x6e, 0x65, 0x72, 0x1a, - 0x0a, 0x0a, 0x08, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, 0x3a, 0x0a, 0x0d, 0x47, - 0x65, 0x74, 0x4f, 0x72, 0x69, 0x67, 0x69, 0x6e, 0x61, 0x6c, 0x77, 0x64, 0x1a, 0x09, 0x0a, 0x07, - 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x1e, 0x0a, 0x08, 0x52, 0x65, 0x73, 0x70, 0x6f, - 0x6e, 0x73, 0x65, 0x12, 0x12, 0x0a, 0x04, 0x70, 0x61, 0x74, 0x68, 0x18, 0x01, 0x20, 0x01, 0x28, - 0x09, 0x52, 0x04, 0x70, 0x61, 0x74, 0x68, 0x22, 0x3a, 0x0a, 0x0d, 0x47, 0x65, 0x74, 0x4d, 0x6f, - 0x64, 0x75, 0x6c, 0x65, 0x50, 0x61, 0x74, 0x68, 0x1a, 0x09, 0x0a, 0x07, 0x52, 0x65, 0x71, 0x75, - 0x65, 0x73, 0x74, 0x1a, 0x1e, 0x0a, 0x08, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, - 0x12, 0x0a, 0x04, 0x70, 0x61, 0x74, 0x68, 0x18, 0x01, 0x20, 0x03, 0x28, 0x09, 0x52, 0x04, 0x70, - 0x61, 0x74, 0x68, 0x22, 0xab, 0x04, 0x0a, 0x10, 0x47, 0x65, 0x74, 0x4d, 0x6f, 0x64, 0x75, 0x6c, - 0x65, 0x43, 0x6f, 0x6e, 0x74, 0x65, 0x6e, 0x74, 0x1a, 0x2b, 0x0a, 0x04, 0x48, 0x69, 0x6e, 0x74, - 0x12, 0x23, 0x0a, 0x0d, 0x72, 0x65, 0x73, 0x6f, 0x75, 0x72, 0x63, 0x65, 0x5f, 0x74, 0x79, 0x70, - 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x0c, 0x72, 0x65, 0x73, 0x6f, 0x75, 0x72, 0x63, - 0x65, 0x54, 0x79, 0x70, 0x65, 0x1a, 0xe8, 0x01, 0x0a, 0x06, 0x4f, 0x70, 0x74, 0x69, 0x6f, 0x6e, - 0x12, 0x33, 0x0a, 0x0a, 0x6d, 0x6f, 0x64, 0x75, 0x6c, 0x65, 0x5f, 0x63, 0x74, 0x78, 0x18, 0x01, - 0x20, 0x01, 0x28, 0x0e, 0x32, 0x14, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x4d, 0x6f, 0x64, - 0x75, 0x6c, 0x65, 0x43, 0x74, 0x78, 0x54, 0x79, 0x70, 0x65, 0x52, 0x09, 0x6d, 0x6f, 0x64, 0x75, - 0x6c, 0x65, 0x43, 0x74, 0x78, 0x12, 0x30, 0x0a, 0x04, 0x68, 0x69, 0x6e, 0x74, 0x18, 0x02, 0x20, - 0x01, 0x28, 0x0b, 0x32, 0x1c, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x47, 0x65, 0x74, 0x4d, - 0x6f, 0x64, 0x75, 0x6c, 0x65, 0x43, 0x6f, 0x6e, 0x74, 0x65, 0x6e, 0x74, 0x2e, 0x48, 0x69, 0x6e, - 0x74, 0x52, 0x04, 0x68, 0x69, 0x6e, 0x74, 0x12, 0x32, 0x0a, 0x13, 0x69, 0x6e, 0x63, 0x6c, 0x75, - 0x64, 0x65, 0x5f, 0x6e, 0x6f, 0x74, 0x5f, 0x63, 0x72, 0x65, 0x61, 0x74, 0x65, 0x64, 0x18, 0x03, - 0x20, 0x01, 0x28, 0x08, 0x42, 0x02, 0x18, 0x01, 0x52, 0x11, 0x69, 0x6e, 0x63, 0x6c, 0x75, 0x64, - 0x65, 0x4e, 0x6f, 0x74, 0x43, 0x72, 0x65, 0x61, 0x74, 0x65, 0x64, 0x12, 0x43, 0x0a, 0x0b, 0x65, - 0x78, 0x70, 0x61, 0x6e, 0x64, 0x5f, 0x6d, 0x6f, 0x64, 0x65, 0x18, 0x04, 0x20, 0x01, 0x28, 0x0e, - 0x32, 0x22, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x47, 0x65, 0x74, 0x4d, 0x6f, 0x64, 0x75, - 0x6c, 0x65, 0x43, 0x6f, 0x6e, 0x74, 0x65, 0x6e, 0x74, 0x2e, 0x45, 0x78, 0x70, 0x61, 0x6e, 0x64, - 0x4d, 0x6f, 0x64, 0x65, 0x52, 0x0a, 0x65, 0x78, 0x70, 0x61, 0x6e, 0x64, 0x4d, 0x6f, 0x64, 0x65, - 0x1a, 0x6c, 0x0a, 0x07, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x29, 0x0a, 0x06, 0x73, - 0x63, 0x68, 0x65, 0x6d, 0x61, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x11, 0x2e, 0x70, 0x72, - 0x6f, 0x74, 0x6f, 0x2e, 0x42, 0x6f, 0x64, 0x79, 0x53, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x52, 0x06, - 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x12, 0x36, 0x0a, 0x06, 0x6f, 0x70, 0x74, 0x69, 0x6f, 0x6e, - 0x18, 0x02, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x1e, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x47, - 0x65, 0x74, 0x4d, 0x6f, 0x64, 0x75, 0x6c, 0x65, 0x43, 0x6f, 0x6e, 0x74, 0x65, 0x6e, 0x74, 0x2e, - 0x4f, 0x70, 0x74, 0x69, 0x6f, 0x6e, 0x52, 0x06, 0x6f, 0x70, 0x74, 0x69, 0x6f, 0x6e, 0x1a, 0x38, - 0x0a, 0x08, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x2c, 0x0a, 0x07, 0x63, 0x6f, - 0x6e, 0x74, 0x65, 0x6e, 0x74, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x12, 0x2e, 0x70, 0x72, - 0x6f, 0x74, 0x6f, 0x2e, 0x42, 0x6f, 0x64, 0x79, 0x43, 0x6f, 0x6e, 0x74, 0x65, 0x6e, 0x74, 0x52, - 0x07, 0x63, 0x6f, 0x6e, 0x74, 0x65, 0x6e, 0x74, 0x22, 0x57, 0x0a, 0x0a, 0x45, 0x78, 0x70, 0x61, - 0x6e, 0x64, 0x4d, 0x6f, 0x64, 0x65, 0x12, 0x1b, 0x0a, 0x17, 0x45, 0x58, 0x50, 0x41, 0x4e, 0x44, - 0x5f, 0x4d, 0x4f, 0x44, 0x45, 0x5f, 0x55, 0x4e, 0x53, 0x50, 0x45, 0x43, 0x49, 0x46, 0x49, 0x45, - 0x44, 0x10, 0x00, 0x12, 0x14, 0x0a, 0x10, 0x45, 0x58, 0x50, 0x41, 0x4e, 0x44, 0x5f, 0x4d, 0x4f, - 0x44, 0x45, 0x5f, 0x4e, 0x4f, 0x4e, 0x45, 0x10, 0x01, 0x12, 0x16, 0x0a, 0x12, 0x45, 0x58, 0x50, - 0x41, 0x4e, 0x44, 0x5f, 0x4d, 0x4f, 0x44, 0x45, 0x5f, 0x45, 0x58, 0x50, 0x41, 0x4e, 0x44, 0x10, - 0x02, 0x22, 0x48, 0x0a, 0x07, 0x47, 0x65, 0x74, 0x46, 0x69, 0x6c, 0x65, 0x1a, 0x1d, 0x0a, 0x07, - 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x12, 0x0a, 0x04, 0x6e, 0x61, 0x6d, 0x65, 0x18, - 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x04, 0x6e, 0x61, 0x6d, 0x65, 0x1a, 0x1e, 0x0a, 0x08, 0x52, - 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x12, 0x0a, 0x04, 0x66, 0x69, 0x6c, 0x65, 0x18, - 0x01, 0x20, 0x01, 0x28, 0x0c, 0x52, 0x04, 0x66, 0x69, 0x6c, 0x65, 0x22, 0x96, 0x01, 0x0a, 0x08, - 0x47, 0x65, 0x74, 0x46, 0x69, 0x6c, 0x65, 0x73, 0x1a, 0x09, 0x0a, 0x07, 0x52, 0x65, 0x71, 0x75, - 0x65, 0x73, 0x74, 0x1a, 0x7f, 0x0a, 0x08, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, - 0x39, 0x0a, 0x05, 0x66, 0x69, 0x6c, 0x65, 0x73, 0x18, 0x01, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x23, - 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x47, 0x65, 0x74, 0x46, 0x69, 0x6c, 0x65, 0x73, 0x2e, - 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x2e, 0x46, 0x69, 0x6c, 0x65, 0x73, 0x45, 0x6e, - 0x74, 0x72, 0x79, 0x52, 0x05, 0x66, 0x69, 0x6c, 0x65, 0x73, 0x1a, 0x38, 0x0a, 0x0a, 0x46, 0x69, - 0x6c, 0x65, 0x73, 0x45, 0x6e, 0x74, 0x72, 0x79, 0x12, 0x10, 0x0a, 0x03, 0x6b, 0x65, 0x79, 0x18, - 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x03, 0x6b, 0x65, 0x79, 0x12, 0x14, 0x0a, 0x05, 0x76, 0x61, - 0x6c, 0x75, 0x65, 0x18, 0x02, 0x20, 0x01, 0x28, 0x0c, 0x52, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, - 0x3a, 0x02, 0x38, 0x01, 0x22, 0x9a, 0x01, 0x0a, 0x14, 0x47, 0x65, 0x74, 0x52, 0x75, 0x6c, 0x65, - 0x43, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x43, 0x6f, 0x6e, 0x74, 0x65, 0x6e, 0x74, 0x1a, 0x48, 0x0a, - 0x07, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x12, 0x0a, 0x04, 0x6e, 0x61, 0x6d, 0x65, - 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x04, 0x6e, 0x61, 0x6d, 0x65, 0x12, 0x29, 0x0a, 0x06, - 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x18, 0x02, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x11, 0x2e, 0x70, - 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x42, 0x6f, 0x64, 0x79, 0x53, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x52, - 0x06, 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x1a, 0x38, 0x0a, 0x08, 0x52, 0x65, 0x73, 0x70, 0x6f, - 0x6e, 0x73, 0x65, 0x12, 0x2c, 0x0a, 0x07, 0x63, 0x6f, 0x6e, 0x74, 0x65, 0x6e, 0x74, 0x18, 0x01, - 0x20, 0x01, 0x28, 0x0b, 0x32, 0x12, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x42, 0x6f, 0x64, - 0x79, 0x43, 0x6f, 0x6e, 0x74, 0x65, 0x6e, 0x74, 0x52, 0x07, 0x63, 0x6f, 0x6e, 0x74, 0x65, 0x6e, - 0x74, 0x22, 0xe7, 0x02, 0x0a, 0x0c, 0x45, 0x76, 0x61, 0x6c, 0x75, 0x61, 0x74, 0x65, 0x45, 0x78, - 0x70, 0x72, 0x1a, 0x51, 0x0a, 0x06, 0x4f, 0x70, 0x74, 0x69, 0x6f, 0x6e, 0x12, 0x12, 0x0a, 0x04, - 0x74, 0x79, 0x70, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0c, 0x52, 0x04, 0x74, 0x79, 0x70, 0x65, - 0x12, 0x33, 0x0a, 0x0a, 0x6d, 0x6f, 0x64, 0x75, 0x6c, 0x65, 0x5f, 0x63, 0x74, 0x78, 0x18, 0x02, - 0x20, 0x01, 0x28, 0x0e, 0x32, 0x14, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x4d, 0x6f, 0x64, - 0x75, 0x6c, 0x65, 0x43, 0x74, 0x78, 0x54, 0x79, 0x70, 0x65, 0x52, 0x09, 0x6d, 0x6f, 0x64, 0x75, - 0x6c, 0x65, 0x43, 0x74, 0x78, 0x1a, 0xb9, 0x01, 0x0a, 0x07, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, - 0x74, 0x12, 0x16, 0x0a, 0x04, 0x65, 0x78, 0x70, 0x72, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0c, 0x42, - 0x02, 0x18, 0x01, 0x52, 0x04, 0x65, 0x78, 0x70, 0x72, 0x12, 0x2f, 0x0a, 0x0a, 0x65, 0x78, 0x70, - 0x72, 0x5f, 0x72, 0x61, 0x6e, 0x67, 0x65, 0x18, 0x02, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x0c, 0x2e, - 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x52, 0x61, 0x6e, 0x67, 0x65, 0x42, 0x02, 0x18, 0x01, 0x52, - 0x09, 0x65, 0x78, 0x70, 0x72, 0x52, 0x61, 0x6e, 0x67, 0x65, 0x12, 0x32, 0x0a, 0x06, 0x6f, 0x70, - 0x74, 0x69, 0x6f, 0x6e, 0x18, 0x03, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x1a, 0x2e, 0x70, 0x72, 0x6f, - 0x74, 0x6f, 0x2e, 0x45, 0x76, 0x61, 0x6c, 0x75, 0x61, 0x74, 0x65, 0x45, 0x78, 0x70, 0x72, 0x2e, - 0x4f, 0x70, 0x74, 0x69, 0x6f, 0x6e, 0x52, 0x06, 0x6f, 0x70, 0x74, 0x69, 0x6f, 0x6e, 0x12, 0x31, - 0x0a, 0x0a, 0x65, 0x78, 0x70, 0x72, 0x65, 0x73, 0x73, 0x69, 0x6f, 0x6e, 0x18, 0x04, 0x20, 0x01, - 0x28, 0x0b, 0x32, 0x11, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x45, 0x78, 0x70, 0x72, 0x65, - 0x73, 0x73, 0x69, 0x6f, 0x6e, 0x52, 0x0a, 0x65, 0x78, 0x70, 0x72, 0x65, 0x73, 0x73, 0x69, 0x6f, - 0x6e, 0x1a, 0x48, 0x0a, 0x08, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x14, 0x0a, - 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0c, 0x52, 0x05, 0x76, 0x61, - 0x6c, 0x75, 0x65, 0x12, 0x26, 0x0a, 0x05, 0x6d, 0x61, 0x72, 0x6b, 0x73, 0x18, 0x02, 0x20, 0x03, - 0x28, 0x0b, 0x32, 0x10, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x56, 0x61, 0x6c, 0x75, 0x65, - 0x4d, 0x61, 0x72, 0x6b, 0x52, 0x05, 0x6d, 0x61, 0x72, 0x6b, 0x73, 0x22, 0xf1, 0x02, 0x0a, 0x09, - 0x45, 0x6d, 0x69, 0x74, 0x49, 0x73, 0x73, 0x75, 0x65, 0x1a, 0x7f, 0x0a, 0x04, 0x52, 0x75, 0x6c, - 0x65, 0x12, 0x12, 0x0a, 0x04, 0x6e, 0x61, 0x6d, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, - 0x04, 0x6e, 0x61, 0x6d, 0x65, 0x12, 0x18, 0x0a, 0x07, 0x65, 0x6e, 0x61, 0x62, 0x6c, 0x65, 0x64, - 0x18, 0x02, 0x20, 0x01, 0x28, 0x08, 0x52, 0x07, 0x65, 0x6e, 0x61, 0x62, 0x6c, 0x65, 0x64, 0x12, - 0x35, 0x0a, 0x08, 0x73, 0x65, 0x76, 0x65, 0x72, 0x69, 0x74, 0x79, 0x18, 0x03, 0x20, 0x01, 0x28, - 0x0e, 0x32, 0x19, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x45, 0x6d, 0x69, 0x74, 0x49, 0x73, - 0x73, 0x75, 0x65, 0x2e, 0x53, 0x65, 0x76, 0x65, 0x72, 0x69, 0x74, 0x79, 0x52, 0x08, 0x73, 0x65, - 0x76, 0x65, 0x72, 0x69, 0x74, 0x79, 0x12, 0x12, 0x0a, 0x04, 0x6c, 0x69, 0x6e, 0x6b, 0x18, 0x04, - 0x20, 0x01, 0x28, 0x09, 0x52, 0x04, 0x6c, 0x69, 0x6e, 0x6b, 0x1a, 0x72, 0x0a, 0x07, 0x52, 0x65, - 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x29, 0x0a, 0x04, 0x72, 0x75, 0x6c, 0x65, 0x18, 0x01, 0x20, - 0x01, 0x28, 0x0b, 0x32, 0x15, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x45, 0x6d, 0x69, 0x74, - 0x49, 0x73, 0x73, 0x75, 0x65, 0x2e, 0x52, 0x75, 0x6c, 0x65, 0x52, 0x04, 0x72, 0x75, 0x6c, 0x65, - 0x12, 0x18, 0x0a, 0x07, 0x6d, 0x65, 0x73, 0x73, 0x61, 0x67, 0x65, 0x18, 0x02, 0x20, 0x01, 0x28, - 0x09, 0x52, 0x07, 0x6d, 0x65, 0x73, 0x73, 0x61, 0x67, 0x65, 0x12, 0x22, 0x0a, 0x05, 0x72, 0x61, - 0x6e, 0x67, 0x65, 0x18, 0x03, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x0c, 0x2e, 0x70, 0x72, 0x6f, 0x74, - 0x6f, 0x2e, 0x52, 0x61, 0x6e, 0x67, 0x65, 0x52, 0x05, 0x72, 0x61, 0x6e, 0x67, 0x65, 0x1a, 0x0a, - 0x0a, 0x08, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, 0x63, 0x0a, 0x08, 0x53, 0x65, - 0x76, 0x65, 0x72, 0x69, 0x74, 0x79, 0x12, 0x18, 0x0a, 0x14, 0x53, 0x45, 0x56, 0x45, 0x52, 0x49, - 0x54, 0x59, 0x5f, 0x55, 0x4e, 0x53, 0x50, 0x45, 0x43, 0x49, 0x46, 0x49, 0x45, 0x44, 0x10, 0x00, - 0x12, 0x12, 0x0a, 0x0e, 0x53, 0x45, 0x56, 0x45, 0x52, 0x49, 0x54, 0x59, 0x5f, 0x45, 0x52, 0x52, - 0x4f, 0x52, 0x10, 0x01, 0x12, 0x14, 0x0a, 0x10, 0x53, 0x45, 0x56, 0x45, 0x52, 0x49, 0x54, 0x59, - 0x5f, 0x57, 0x41, 0x52, 0x4e, 0x49, 0x4e, 0x47, 0x10, 0x02, 0x12, 0x13, 0x0a, 0x0f, 0x53, 0x45, - 0x56, 0x45, 0x52, 0x49, 0x54, 0x59, 0x5f, 0x4e, 0x4f, 0x54, 0x49, 0x43, 0x45, 0x10, 0x03, 0x22, + 0x6f, 0x6e, 0x6c, 0x79, 0x12, 0x10, 0x0a, 0x03, 0x66, 0x69, 0x78, 0x18, 0x04, 0x20, 0x01, 0x28, + 0x08, 0x52, 0x03, 0x66, 0x69, 0x78, 0x1a, 0x5d, 0x0a, 0x0a, 0x52, 0x75, 0x6c, 0x65, 0x73, 0x45, + 0x6e, 0x74, 0x72, 0x79, 0x12, 0x10, 0x0a, 0x03, 0x6b, 0x65, 0x79, 0x18, 0x01, 0x20, 0x01, 0x28, + 0x09, 0x52, 0x03, 0x6b, 0x65, 0x79, 0x12, 0x39, 0x0a, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x18, + 0x02, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x23, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x41, 0x70, + 0x70, 0x6c, 0x79, 0x47, 0x6c, 0x6f, 0x62, 0x61, 0x6c, 0x43, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x2e, + 0x52, 0x75, 0x6c, 0x65, 0x43, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x52, 0x05, 0x76, 0x61, 0x6c, 0x75, + 0x65, 0x3a, 0x02, 0x38, 0x01, 0x1a, 0x3a, 0x0a, 0x0a, 0x52, 0x75, 0x6c, 0x65, 0x43, 0x6f, 0x6e, + 0x66, 0x69, 0x67, 0x12, 0x12, 0x0a, 0x04, 0x6e, 0x61, 0x6d, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, + 0x09, 0x52, 0x04, 0x6e, 0x61, 0x6d, 0x65, 0x12, 0x18, 0x0a, 0x07, 0x65, 0x6e, 0x61, 0x62, 0x6c, + 0x65, 0x64, 0x18, 0x02, 0x20, 0x01, 0x28, 0x08, 0x52, 0x07, 0x65, 0x6e, 0x61, 0x62, 0x6c, 0x65, + 0x64, 0x1a, 0x42, 0x0a, 0x07, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x37, 0x0a, 0x06, + 0x63, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x1f, 0x2e, 0x70, + 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x41, 0x70, 0x70, 0x6c, 0x79, 0x47, 0x6c, 0x6f, 0x62, 0x61, 0x6c, + 0x43, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x2e, 0x43, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x52, 0x06, 0x63, + 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x1a, 0x0a, 0x0a, 0x08, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, + 0x65, 0x22, 0x52, 0x0a, 0x0b, 0x41, 0x70, 0x70, 0x6c, 0x79, 0x43, 0x6f, 0x6e, 0x66, 0x69, 0x67, + 0x1a, 0x37, 0x0a, 0x07, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x2c, 0x0a, 0x07, 0x63, + 0x6f, 0x6e, 0x74, 0x65, 0x6e, 0x74, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x12, 0x2e, 0x70, + 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x42, 0x6f, 0x64, 0x79, 0x43, 0x6f, 0x6e, 0x74, 0x65, 0x6e, 0x74, + 0x52, 0x07, 0x63, 0x6f, 0x6e, 0x74, 0x65, 0x6e, 0x74, 0x1a, 0x0a, 0x0a, 0x08, 0x52, 0x65, 0x73, + 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, 0x36, 0x0a, 0x05, 0x43, 0x68, 0x65, 0x63, 0x6b, 0x1a, 0x21, + 0x0a, 0x07, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x16, 0x0a, 0x06, 0x72, 0x75, 0x6e, + 0x6e, 0x65, 0x72, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0d, 0x52, 0x06, 0x72, 0x75, 0x6e, 0x6e, 0x65, + 0x72, 0x1a, 0x0a, 0x0a, 0x08, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, 0x3a, 0x0a, + 0x0d, 0x47, 0x65, 0x74, 0x4f, 0x72, 0x69, 0x67, 0x69, 0x6e, 0x61, 0x6c, 0x77, 0x64, 0x1a, 0x09, + 0x0a, 0x07, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x1e, 0x0a, 0x08, 0x52, 0x65, 0x73, + 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x12, 0x0a, 0x04, 0x70, 0x61, 0x74, 0x68, 0x18, 0x01, 0x20, + 0x01, 0x28, 0x09, 0x52, 0x04, 0x70, 0x61, 0x74, 0x68, 0x22, 0x3a, 0x0a, 0x0d, 0x47, 0x65, 0x74, + 0x4d, 0x6f, 0x64, 0x75, 0x6c, 0x65, 0x50, 0x61, 0x74, 0x68, 0x1a, 0x09, 0x0a, 0x07, 0x52, 0x65, + 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x1e, 0x0a, 0x08, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, + 0x65, 0x12, 0x12, 0x0a, 0x04, 0x70, 0x61, 0x74, 0x68, 0x18, 0x01, 0x20, 0x03, 0x28, 0x09, 0x52, + 0x04, 0x70, 0x61, 0x74, 0x68, 0x22, 0xab, 0x04, 0x0a, 0x10, 0x47, 0x65, 0x74, 0x4d, 0x6f, 0x64, + 0x75, 0x6c, 0x65, 0x43, 0x6f, 0x6e, 0x74, 0x65, 0x6e, 0x74, 0x1a, 0x2b, 0x0a, 0x04, 0x48, 0x69, + 0x6e, 0x74, 0x12, 0x23, 0x0a, 0x0d, 0x72, 0x65, 0x73, 0x6f, 0x75, 0x72, 0x63, 0x65, 0x5f, 0x74, + 0x79, 0x70, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x0c, 0x72, 0x65, 0x73, 0x6f, 0x75, + 0x72, 0x63, 0x65, 0x54, 0x79, 0x70, 0x65, 0x1a, 0xe8, 0x01, 0x0a, 0x06, 0x4f, 0x70, 0x74, 0x69, + 0x6f, 0x6e, 0x12, 0x33, 0x0a, 0x0a, 0x6d, 0x6f, 0x64, 0x75, 0x6c, 0x65, 0x5f, 0x63, 0x74, 0x78, + 0x18, 0x01, 0x20, 0x01, 0x28, 0x0e, 0x32, 0x14, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x4d, + 0x6f, 0x64, 0x75, 0x6c, 0x65, 0x43, 0x74, 0x78, 0x54, 0x79, 0x70, 0x65, 0x52, 0x09, 0x6d, 0x6f, + 0x64, 0x75, 0x6c, 0x65, 0x43, 0x74, 0x78, 0x12, 0x30, 0x0a, 0x04, 0x68, 0x69, 0x6e, 0x74, 0x18, + 0x02, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x1c, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x47, 0x65, + 0x74, 0x4d, 0x6f, 0x64, 0x75, 0x6c, 0x65, 0x43, 0x6f, 0x6e, 0x74, 0x65, 0x6e, 0x74, 0x2e, 0x48, + 0x69, 0x6e, 0x74, 0x52, 0x04, 0x68, 0x69, 0x6e, 0x74, 0x12, 0x32, 0x0a, 0x13, 0x69, 0x6e, 0x63, + 0x6c, 0x75, 0x64, 0x65, 0x5f, 0x6e, 0x6f, 0x74, 0x5f, 0x63, 0x72, 0x65, 0x61, 0x74, 0x65, 0x64, + 0x18, 0x03, 0x20, 0x01, 0x28, 0x08, 0x42, 0x02, 0x18, 0x01, 0x52, 0x11, 0x69, 0x6e, 0x63, 0x6c, + 0x75, 0x64, 0x65, 0x4e, 0x6f, 0x74, 0x43, 0x72, 0x65, 0x61, 0x74, 0x65, 0x64, 0x12, 0x43, 0x0a, + 0x0b, 0x65, 0x78, 0x70, 0x61, 0x6e, 0x64, 0x5f, 0x6d, 0x6f, 0x64, 0x65, 0x18, 0x04, 0x20, 0x01, + 0x28, 0x0e, 0x32, 0x22, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x47, 0x65, 0x74, 0x4d, 0x6f, + 0x64, 0x75, 0x6c, 0x65, 0x43, 0x6f, 0x6e, 0x74, 0x65, 0x6e, 0x74, 0x2e, 0x45, 0x78, 0x70, 0x61, + 0x6e, 0x64, 0x4d, 0x6f, 0x64, 0x65, 0x52, 0x0a, 0x65, 0x78, 0x70, 0x61, 0x6e, 0x64, 0x4d, 0x6f, + 0x64, 0x65, 0x1a, 0x6c, 0x0a, 0x07, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x29, 0x0a, + 0x06, 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x11, 0x2e, + 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x42, 0x6f, 0x64, 0x79, 0x53, 0x63, 0x68, 0x65, 0x6d, 0x61, + 0x52, 0x06, 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x12, 0x36, 0x0a, 0x06, 0x6f, 0x70, 0x74, 0x69, + 0x6f, 0x6e, 0x18, 0x02, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x1e, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, + 0x2e, 0x47, 0x65, 0x74, 0x4d, 0x6f, 0x64, 0x75, 0x6c, 0x65, 0x43, 0x6f, 0x6e, 0x74, 0x65, 0x6e, + 0x74, 0x2e, 0x4f, 0x70, 0x74, 0x69, 0x6f, 0x6e, 0x52, 0x06, 0x6f, 0x70, 0x74, 0x69, 0x6f, 0x6e, + 0x1a, 0x38, 0x0a, 0x08, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x2c, 0x0a, 0x07, + 0x63, 0x6f, 0x6e, 0x74, 0x65, 0x6e, 0x74, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x12, 0x2e, + 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x42, 0x6f, 0x64, 0x79, 0x43, 0x6f, 0x6e, 0x74, 0x65, 0x6e, + 0x74, 0x52, 0x07, 0x63, 0x6f, 0x6e, 0x74, 0x65, 0x6e, 0x74, 0x22, 0x57, 0x0a, 0x0a, 0x45, 0x78, + 0x70, 0x61, 0x6e, 0x64, 0x4d, 0x6f, 0x64, 0x65, 0x12, 0x1b, 0x0a, 0x17, 0x45, 0x58, 0x50, 0x41, + 0x4e, 0x44, 0x5f, 0x4d, 0x4f, 0x44, 0x45, 0x5f, 0x55, 0x4e, 0x53, 0x50, 0x45, 0x43, 0x49, 0x46, + 0x49, 0x45, 0x44, 0x10, 0x00, 0x12, 0x14, 0x0a, 0x10, 0x45, 0x58, 0x50, 0x41, 0x4e, 0x44, 0x5f, + 0x4d, 0x4f, 0x44, 0x45, 0x5f, 0x4e, 0x4f, 0x4e, 0x45, 0x10, 0x01, 0x12, 0x16, 0x0a, 0x12, 0x45, + 0x58, 0x50, 0x41, 0x4e, 0x44, 0x5f, 0x4d, 0x4f, 0x44, 0x45, 0x5f, 0x45, 0x58, 0x50, 0x41, 0x4e, + 0x44, 0x10, 0x02, 0x22, 0x48, 0x0a, 0x07, 0x47, 0x65, 0x74, 0x46, 0x69, 0x6c, 0x65, 0x1a, 0x1d, + 0x0a, 0x07, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x12, 0x0a, 0x04, 0x6e, 0x61, 0x6d, + 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x04, 0x6e, 0x61, 0x6d, 0x65, 0x1a, 0x1e, 0x0a, + 0x08, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x12, 0x0a, 0x04, 0x66, 0x69, 0x6c, + 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0c, 0x52, 0x04, 0x66, 0x69, 0x6c, 0x65, 0x22, 0x96, 0x01, + 0x0a, 0x08, 0x47, 0x65, 0x74, 0x46, 0x69, 0x6c, 0x65, 0x73, 0x1a, 0x09, 0x0a, 0x07, 0x52, 0x65, + 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x7f, 0x0a, 0x08, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, + 0x65, 0x12, 0x39, 0x0a, 0x05, 0x66, 0x69, 0x6c, 0x65, 0x73, 0x18, 0x01, 0x20, 0x03, 0x28, 0x0b, + 0x32, 0x23, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x47, 0x65, 0x74, 0x46, 0x69, 0x6c, 0x65, + 0x73, 0x2e, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x2e, 0x46, 0x69, 0x6c, 0x65, 0x73, + 0x45, 0x6e, 0x74, 0x72, 0x79, 0x52, 0x05, 0x66, 0x69, 0x6c, 0x65, 0x73, 0x1a, 0x38, 0x0a, 0x0a, + 0x46, 0x69, 0x6c, 0x65, 0x73, 0x45, 0x6e, 0x74, 0x72, 0x79, 0x12, 0x10, 0x0a, 0x03, 0x6b, 0x65, + 0x79, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x03, 0x6b, 0x65, 0x79, 0x12, 0x14, 0x0a, 0x05, + 0x76, 0x61, 0x6c, 0x75, 0x65, 0x18, 0x02, 0x20, 0x01, 0x28, 0x0c, 0x52, 0x05, 0x76, 0x61, 0x6c, + 0x75, 0x65, 0x3a, 0x02, 0x38, 0x01, 0x22, 0x9a, 0x01, 0x0a, 0x14, 0x47, 0x65, 0x74, 0x52, 0x75, + 0x6c, 0x65, 0x43, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x43, 0x6f, 0x6e, 0x74, 0x65, 0x6e, 0x74, 0x1a, + 0x48, 0x0a, 0x07, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x12, 0x0a, 0x04, 0x6e, 0x61, + 0x6d, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x04, 0x6e, 0x61, 0x6d, 0x65, 0x12, 0x29, + 0x0a, 0x06, 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x18, 0x02, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x11, + 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x42, 0x6f, 0x64, 0x79, 0x53, 0x63, 0x68, 0x65, 0x6d, + 0x61, 0x52, 0x06, 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x1a, 0x38, 0x0a, 0x08, 0x52, 0x65, 0x73, + 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x2c, 0x0a, 0x07, 0x63, 0x6f, 0x6e, 0x74, 0x65, 0x6e, 0x74, + 0x18, 0x01, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x12, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x42, + 0x6f, 0x64, 0x79, 0x43, 0x6f, 0x6e, 0x74, 0x65, 0x6e, 0x74, 0x52, 0x07, 0x63, 0x6f, 0x6e, 0x74, + 0x65, 0x6e, 0x74, 0x22, 0xe7, 0x02, 0x0a, 0x0c, 0x45, 0x76, 0x61, 0x6c, 0x75, 0x61, 0x74, 0x65, + 0x45, 0x78, 0x70, 0x72, 0x1a, 0x51, 0x0a, 0x06, 0x4f, 0x70, 0x74, 0x69, 0x6f, 0x6e, 0x12, 0x12, + 0x0a, 0x04, 0x74, 0x79, 0x70, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0c, 0x52, 0x04, 0x74, 0x79, + 0x70, 0x65, 0x12, 0x33, 0x0a, 0x0a, 0x6d, 0x6f, 0x64, 0x75, 0x6c, 0x65, 0x5f, 0x63, 0x74, 0x78, + 0x18, 0x02, 0x20, 0x01, 0x28, 0x0e, 0x32, 0x14, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x4d, + 0x6f, 0x64, 0x75, 0x6c, 0x65, 0x43, 0x74, 0x78, 0x54, 0x79, 0x70, 0x65, 0x52, 0x09, 0x6d, 0x6f, + 0x64, 0x75, 0x6c, 0x65, 0x43, 0x74, 0x78, 0x1a, 0xb9, 0x01, 0x0a, 0x07, 0x52, 0x65, 0x71, 0x75, + 0x65, 0x73, 0x74, 0x12, 0x16, 0x0a, 0x04, 0x65, 0x78, 0x70, 0x72, 0x18, 0x01, 0x20, 0x01, 0x28, + 0x0c, 0x42, 0x02, 0x18, 0x01, 0x52, 0x04, 0x65, 0x78, 0x70, 0x72, 0x12, 0x2f, 0x0a, 0x0a, 0x65, + 0x78, 0x70, 0x72, 0x5f, 0x72, 0x61, 0x6e, 0x67, 0x65, 0x18, 0x02, 0x20, 0x01, 0x28, 0x0b, 0x32, + 0x0c, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x52, 0x61, 0x6e, 0x67, 0x65, 0x42, 0x02, 0x18, + 0x01, 0x52, 0x09, 0x65, 0x78, 0x70, 0x72, 0x52, 0x61, 0x6e, 0x67, 0x65, 0x12, 0x32, 0x0a, 0x06, + 0x6f, 0x70, 0x74, 0x69, 0x6f, 0x6e, 0x18, 0x03, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x1a, 0x2e, 0x70, + 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x45, 0x76, 0x61, 0x6c, 0x75, 0x61, 0x74, 0x65, 0x45, 0x78, 0x70, + 0x72, 0x2e, 0x4f, 0x70, 0x74, 0x69, 0x6f, 0x6e, 0x52, 0x06, 0x6f, 0x70, 0x74, 0x69, 0x6f, 0x6e, + 0x12, 0x31, 0x0a, 0x0a, 0x65, 0x78, 0x70, 0x72, 0x65, 0x73, 0x73, 0x69, 0x6f, 0x6e, 0x18, 0x04, + 0x20, 0x01, 0x28, 0x0b, 0x32, 0x11, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x45, 0x78, 0x70, + 0x72, 0x65, 0x73, 0x73, 0x69, 0x6f, 0x6e, 0x52, 0x0a, 0x65, 0x78, 0x70, 0x72, 0x65, 0x73, 0x73, + 0x69, 0x6f, 0x6e, 0x1a, 0x48, 0x0a, 0x08, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, + 0x14, 0x0a, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0c, 0x52, 0x05, + 0x76, 0x61, 0x6c, 0x75, 0x65, 0x12, 0x26, 0x0a, 0x05, 0x6d, 0x61, 0x72, 0x6b, 0x73, 0x18, 0x02, + 0x20, 0x03, 0x28, 0x0b, 0x32, 0x10, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x56, 0x61, 0x6c, + 0x75, 0x65, 0x4d, 0x61, 0x72, 0x6b, 0x52, 0x05, 0x6d, 0x61, 0x72, 0x6b, 0x73, 0x22, 0xa6, 0x03, + 0x0a, 0x09, 0x45, 0x6d, 0x69, 0x74, 0x49, 0x73, 0x73, 0x75, 0x65, 0x1a, 0x7f, 0x0a, 0x04, 0x52, + 0x75, 0x6c, 0x65, 0x12, 0x12, 0x0a, 0x04, 0x6e, 0x61, 0x6d, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, + 0x09, 0x52, 0x04, 0x6e, 0x61, 0x6d, 0x65, 0x12, 0x18, 0x0a, 0x07, 0x65, 0x6e, 0x61, 0x62, 0x6c, + 0x65, 0x64, 0x18, 0x02, 0x20, 0x01, 0x28, 0x08, 0x52, 0x07, 0x65, 0x6e, 0x61, 0x62, 0x6c, 0x65, + 0x64, 0x12, 0x35, 0x0a, 0x08, 0x73, 0x65, 0x76, 0x65, 0x72, 0x69, 0x74, 0x79, 0x18, 0x03, 0x20, + 0x01, 0x28, 0x0e, 0x32, 0x19, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x45, 0x6d, 0x69, 0x74, + 0x49, 0x73, 0x73, 0x75, 0x65, 0x2e, 0x53, 0x65, 0x76, 0x65, 0x72, 0x69, 0x74, 0x79, 0x52, 0x08, + 0x73, 0x65, 0x76, 0x65, 0x72, 0x69, 0x74, 0x79, 0x12, 0x12, 0x0a, 0x04, 0x6c, 0x69, 0x6e, 0x6b, + 0x18, 0x04, 0x20, 0x01, 0x28, 0x09, 0x52, 0x04, 0x6c, 0x69, 0x6e, 0x6b, 0x1a, 0x8c, 0x01, 0x0a, + 0x07, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x29, 0x0a, 0x04, 0x72, 0x75, 0x6c, 0x65, + 0x18, 0x01, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x15, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x45, + 0x6d, 0x69, 0x74, 0x49, 0x73, 0x73, 0x75, 0x65, 0x2e, 0x52, 0x75, 0x6c, 0x65, 0x52, 0x04, 0x72, + 0x75, 0x6c, 0x65, 0x12, 0x18, 0x0a, 0x07, 0x6d, 0x65, 0x73, 0x73, 0x61, 0x67, 0x65, 0x18, 0x02, + 0x20, 0x01, 0x28, 0x09, 0x52, 0x07, 0x6d, 0x65, 0x73, 0x73, 0x61, 0x67, 0x65, 0x12, 0x22, 0x0a, + 0x05, 0x72, 0x61, 0x6e, 0x67, 0x65, 0x18, 0x03, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x0c, 0x2e, 0x70, + 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x52, 0x61, 0x6e, 0x67, 0x65, 0x52, 0x05, 0x72, 0x61, 0x6e, 0x67, + 0x65, 0x12, 0x18, 0x0a, 0x07, 0x66, 0x69, 0x78, 0x61, 0x62, 0x6c, 0x65, 0x18, 0x04, 0x20, 0x01, + 0x28, 0x08, 0x52, 0x07, 0x66, 0x69, 0x78, 0x61, 0x62, 0x6c, 0x65, 0x1a, 0x24, 0x0a, 0x08, 0x52, + 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x18, 0x0a, 0x07, 0x61, 0x70, 0x70, 0x6c, 0x69, + 0x65, 0x64, 0x18, 0x01, 0x20, 0x01, 0x28, 0x08, 0x52, 0x07, 0x61, 0x70, 0x70, 0x6c, 0x69, 0x65, + 0x64, 0x22, 0x63, 0x0a, 0x08, 0x53, 0x65, 0x76, 0x65, 0x72, 0x69, 0x74, 0x79, 0x12, 0x18, 0x0a, + 0x14, 0x53, 0x45, 0x56, 0x45, 0x52, 0x49, 0x54, 0x59, 0x5f, 0x55, 0x4e, 0x53, 0x50, 0x45, 0x43, + 0x49, 0x46, 0x49, 0x45, 0x44, 0x10, 0x00, 0x12, 0x12, 0x0a, 0x0e, 0x53, 0x45, 0x56, 0x45, 0x52, + 0x49, 0x54, 0x59, 0x5f, 0x45, 0x52, 0x52, 0x4f, 0x52, 0x10, 0x01, 0x12, 0x14, 0x0a, 0x10, 0x53, + 0x45, 0x56, 0x45, 0x52, 0x49, 0x54, 0x59, 0x5f, 0x57, 0x41, 0x52, 0x4e, 0x49, 0x4e, 0x47, 0x10, + 0x02, 0x12, 0x13, 0x0a, 0x0f, 0x53, 0x45, 0x56, 0x45, 0x52, 0x49, 0x54, 0x59, 0x5f, 0x4e, 0x4f, + 0x54, 0x49, 0x43, 0x45, 0x10, 0x03, 0x22, 0xa6, 0x01, 0x0a, 0x0c, 0x41, 0x70, 0x70, 0x6c, 0x79, + 0x43, 0x68, 0x61, 0x6e, 0x67, 0x65, 0x73, 0x1a, 0x89, 0x01, 0x0a, 0x07, 0x52, 0x65, 0x71, 0x75, + 0x65, 0x73, 0x74, 0x12, 0x42, 0x0a, 0x07, 0x63, 0x68, 0x61, 0x6e, 0x67, 0x65, 0x73, 0x18, 0x01, + 0x20, 0x03, 0x28, 0x0b, 0x32, 0x28, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x41, 0x70, 0x70, + 0x6c, 0x79, 0x43, 0x68, 0x61, 0x6e, 0x67, 0x65, 0x73, 0x2e, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, + 0x74, 0x2e, 0x43, 0x68, 0x61, 0x6e, 0x67, 0x65, 0x73, 0x45, 0x6e, 0x74, 0x72, 0x79, 0x52, 0x07, + 0x63, 0x68, 0x61, 0x6e, 0x67, 0x65, 0x73, 0x1a, 0x3a, 0x0a, 0x0c, 0x43, 0x68, 0x61, 0x6e, 0x67, + 0x65, 0x73, 0x45, 0x6e, 0x74, 0x72, 0x79, 0x12, 0x10, 0x0a, 0x03, 0x6b, 0x65, 0x79, 0x18, 0x01, + 0x20, 0x01, 0x28, 0x09, 0x52, 0x03, 0x6b, 0x65, 0x79, 0x12, 0x14, 0x0a, 0x05, 0x76, 0x61, 0x6c, + 0x75, 0x65, 0x18, 0x02, 0x20, 0x01, 0x28, 0x0c, 0x52, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x3a, + 0x02, 0x38, 0x01, 0x1a, 0x0a, 0x0a, 0x08, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, 0xc3, 0x02, 0x0a, 0x0a, 0x42, 0x6f, 0x64, 0x79, 0x53, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x12, 0x3b, 0x0a, 0x0a, 0x61, 0x74, 0x74, 0x72, 0x69, 0x62, 0x75, 0x74, 0x65, 0x73, 0x18, 0x01, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x1b, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x42, 0x6f, 0x64, 0x79, 0x53, @@ -4046,7 +4209,7 @@ var file_tflint_proto_rawDesc = []byte{ 0x68, 0x65, 0x63, 0x6b, 0x12, 0x14, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x43, 0x68, 0x65, 0x63, 0x6b, 0x2e, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x15, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x43, 0x68, 0x65, 0x63, 0x6b, 0x2e, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, - 0x65, 0x32, 0xe6, 0x04, 0x0a, 0x06, 0x52, 0x75, 0x6e, 0x6e, 0x65, 0x72, 0x12, 0x4c, 0x0a, 0x0d, + 0x65, 0x32, 0xb1, 0x05, 0x0a, 0x06, 0x52, 0x75, 0x6e, 0x6e, 0x65, 0x72, 0x12, 0x4c, 0x0a, 0x0d, 0x47, 0x65, 0x74, 0x4f, 0x72, 0x69, 0x67, 0x69, 0x6e, 0x61, 0x6c, 0x77, 0x64, 0x12, 0x1c, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x47, 0x65, 0x74, 0x4f, 0x72, 0x69, 0x67, 0x69, 0x6e, 0x61, 0x6c, 0x77, 0x64, 0x2e, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x1d, 0x2e, 0x70, 0x72, @@ -4084,12 +4247,16 @@ var file_tflint_proto_rawDesc = []byte{ 0x49, 0x73, 0x73, 0x75, 0x65, 0x12, 0x18, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x45, 0x6d, 0x69, 0x74, 0x49, 0x73, 0x73, 0x75, 0x65, 0x2e, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x19, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x45, 0x6d, 0x69, 0x74, 0x49, 0x73, 0x73, 0x75, - 0x65, 0x2e, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x42, 0x3d, 0x5a, 0x3b, 0x67, 0x69, - 0x74, 0x68, 0x75, 0x62, 0x2e, 0x63, 0x6f, 0x6d, 0x2f, 0x74, 0x65, 0x72, 0x72, 0x61, 0x66, 0x6f, - 0x72, 0x6d, 0x2d, 0x6c, 0x69, 0x6e, 0x74, 0x65, 0x72, 0x73, 0x2f, 0x74, 0x66, 0x6c, 0x69, 0x6e, - 0x74, 0x2d, 0x70, 0x6c, 0x75, 0x67, 0x69, 0x6e, 0x2d, 0x73, 0x64, 0x6b, 0x2f, 0x70, 0x6c, 0x75, - 0x67, 0x69, 0x6e, 0x2f, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x62, 0x06, 0x70, 0x72, 0x6f, 0x74, 0x6f, - 0x33, + 0x65, 0x2e, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x49, 0x0a, 0x0c, 0x41, 0x70, + 0x70, 0x6c, 0x79, 0x43, 0x68, 0x61, 0x6e, 0x67, 0x65, 0x73, 0x12, 0x1b, 0x2e, 0x70, 0x72, 0x6f, + 0x74, 0x6f, 0x2e, 0x41, 0x70, 0x70, 0x6c, 0x79, 0x43, 0x68, 0x61, 0x6e, 0x67, 0x65, 0x73, 0x2e, + 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x1c, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, + 0x41, 0x70, 0x70, 0x6c, 0x79, 0x43, 0x68, 0x61, 0x6e, 0x67, 0x65, 0x73, 0x2e, 0x52, 0x65, 0x73, + 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x42, 0x3d, 0x5a, 0x3b, 0x67, 0x69, 0x74, 0x68, 0x75, 0x62, 0x2e, + 0x63, 0x6f, 0x6d, 0x2f, 0x74, 0x65, 0x72, 0x72, 0x61, 0x66, 0x6f, 0x72, 0x6d, 0x2d, 0x6c, 0x69, + 0x6e, 0x74, 0x65, 0x72, 0x73, 0x2f, 0x74, 0x66, 0x6c, 0x69, 0x6e, 0x74, 0x2d, 0x70, 0x6c, 0x75, + 0x67, 0x69, 0x6e, 0x2d, 0x73, 0x64, 0x6b, 0x2f, 0x70, 0x6c, 0x75, 0x67, 0x69, 0x6e, 0x2f, 0x70, + 0x72, 0x6f, 0x74, 0x6f, 0x62, 0x06, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x33, } var ( @@ -4105,7 +4272,7 @@ func file_tflint_proto_rawDescGZIP() []byte { } var file_tflint_proto_enumTypes = make([]protoimpl.EnumInfo, 5) -var file_tflint_proto_msgTypes = make([]protoimpl.MessageInfo, 73) +var file_tflint_proto_msgTypes = make([]protoimpl.MessageInfo, 77) var file_tflint_proto_goTypes = []interface{}{ (ModuleCtxType)(0), // 0: proto.ModuleCtxType (SchemaMode)(0), // 1: proto.SchemaMode @@ -4129,147 +4296,154 @@ var file_tflint_proto_goTypes = []interface{}{ (*GetRuleConfigContent)(nil), // 19: proto.GetRuleConfigContent (*EvaluateExpr)(nil), // 20: proto.EvaluateExpr (*EmitIssue)(nil), // 21: proto.EmitIssue - (*BodySchema)(nil), // 22: proto.BodySchema - (*BodyContent)(nil), // 23: proto.BodyContent - (*Expression)(nil), // 24: proto.Expression - (*Range)(nil), // 25: proto.Range - (*AttributePath)(nil), // 26: proto.AttributePath - (*ValueMark)(nil), // 27: proto.ValueMark - (*ErrorDetail)(nil), // 28: proto.ErrorDetail - (*GetName_Request)(nil), // 29: proto.GetName.Request - (*GetName_Response)(nil), // 30: proto.GetName.Response - (*GetVersion_Request)(nil), // 31: proto.GetVersion.Request - (*GetVersion_Response)(nil), // 32: proto.GetVersion.Response - (*GetVersionConstraint_Request)(nil), // 33: proto.GetVersionConstraint.Request - (*GetVersionConstraint_Response)(nil), // 34: proto.GetVersionConstraint.Response - (*GetSDKVersion_Request)(nil), // 35: proto.GetSDKVersion.Request - (*GetSDKVersion_Response)(nil), // 36: proto.GetSDKVersion.Response - (*GetRuleNames_Request)(nil), // 37: proto.GetRuleNames.Request - (*GetRuleNames_Response)(nil), // 38: proto.GetRuleNames.Response - (*GetConfigSchema_Request)(nil), // 39: proto.GetConfigSchema.Request - (*GetConfigSchema_Response)(nil), // 40: proto.GetConfigSchema.Response - (*ApplyGlobalConfig_Config)(nil), // 41: proto.ApplyGlobalConfig.Config - (*ApplyGlobalConfig_RuleConfig)(nil), // 42: proto.ApplyGlobalConfig.RuleConfig - (*ApplyGlobalConfig_Request)(nil), // 43: proto.ApplyGlobalConfig.Request - (*ApplyGlobalConfig_Response)(nil), // 44: proto.ApplyGlobalConfig.Response - nil, // 45: proto.ApplyGlobalConfig.Config.RulesEntry - (*ApplyConfig_Request)(nil), // 46: proto.ApplyConfig.Request - (*ApplyConfig_Response)(nil), // 47: proto.ApplyConfig.Response - (*Check_Request)(nil), // 48: proto.Check.Request - (*Check_Response)(nil), // 49: proto.Check.Response - (*GetOriginalwd_Request)(nil), // 50: proto.GetOriginalwd.Request - (*GetOriginalwd_Response)(nil), // 51: proto.GetOriginalwd.Response - (*GetModulePath_Request)(nil), // 52: proto.GetModulePath.Request - (*GetModulePath_Response)(nil), // 53: proto.GetModulePath.Response - (*GetModuleContent_Hint)(nil), // 54: proto.GetModuleContent.Hint - (*GetModuleContent_Option)(nil), // 55: proto.GetModuleContent.Option - (*GetModuleContent_Request)(nil), // 56: proto.GetModuleContent.Request - (*GetModuleContent_Response)(nil), // 57: proto.GetModuleContent.Response - (*GetFile_Request)(nil), // 58: proto.GetFile.Request - (*GetFile_Response)(nil), // 59: proto.GetFile.Response - (*GetFiles_Request)(nil), // 60: proto.GetFiles.Request - (*GetFiles_Response)(nil), // 61: proto.GetFiles.Response - nil, // 62: proto.GetFiles.Response.FilesEntry - (*GetRuleConfigContent_Request)(nil), // 63: proto.GetRuleConfigContent.Request - (*GetRuleConfigContent_Response)(nil), // 64: proto.GetRuleConfigContent.Response - (*EvaluateExpr_Option)(nil), // 65: proto.EvaluateExpr.Option - (*EvaluateExpr_Request)(nil), // 66: proto.EvaluateExpr.Request - (*EvaluateExpr_Response)(nil), // 67: proto.EvaluateExpr.Response - (*EmitIssue_Rule)(nil), // 68: proto.EmitIssue.Rule - (*EmitIssue_Request)(nil), // 69: proto.EmitIssue.Request - (*EmitIssue_Response)(nil), // 70: proto.EmitIssue.Response - (*BodySchema_Attribute)(nil), // 71: proto.BodySchema.Attribute - (*BodySchema_Block)(nil), // 72: proto.BodySchema.Block - (*BodyContent_Attribute)(nil), // 73: proto.BodyContent.Attribute - (*BodyContent_Block)(nil), // 74: proto.BodyContent.Block - nil, // 75: proto.BodyContent.AttributesEntry - (*Range_Pos)(nil), // 76: proto.Range.Pos - (*AttributePath_Step)(nil), // 77: proto.AttributePath.Step + (*ApplyChanges)(nil), // 22: proto.ApplyChanges + (*BodySchema)(nil), // 23: proto.BodySchema + (*BodyContent)(nil), // 24: proto.BodyContent + (*Expression)(nil), // 25: proto.Expression + (*Range)(nil), // 26: proto.Range + (*AttributePath)(nil), // 27: proto.AttributePath + (*ValueMark)(nil), // 28: proto.ValueMark + (*ErrorDetail)(nil), // 29: proto.ErrorDetail + (*GetName_Request)(nil), // 30: proto.GetName.Request + (*GetName_Response)(nil), // 31: proto.GetName.Response + (*GetVersion_Request)(nil), // 32: proto.GetVersion.Request + (*GetVersion_Response)(nil), // 33: proto.GetVersion.Response + (*GetVersionConstraint_Request)(nil), // 34: proto.GetVersionConstraint.Request + (*GetVersionConstraint_Response)(nil), // 35: proto.GetVersionConstraint.Response + (*GetSDKVersion_Request)(nil), // 36: proto.GetSDKVersion.Request + (*GetSDKVersion_Response)(nil), // 37: proto.GetSDKVersion.Response + (*GetRuleNames_Request)(nil), // 38: proto.GetRuleNames.Request + (*GetRuleNames_Response)(nil), // 39: proto.GetRuleNames.Response + (*GetConfigSchema_Request)(nil), // 40: proto.GetConfigSchema.Request + (*GetConfigSchema_Response)(nil), // 41: proto.GetConfigSchema.Response + (*ApplyGlobalConfig_Config)(nil), // 42: proto.ApplyGlobalConfig.Config + (*ApplyGlobalConfig_RuleConfig)(nil), // 43: proto.ApplyGlobalConfig.RuleConfig + (*ApplyGlobalConfig_Request)(nil), // 44: proto.ApplyGlobalConfig.Request + (*ApplyGlobalConfig_Response)(nil), // 45: proto.ApplyGlobalConfig.Response + nil, // 46: proto.ApplyGlobalConfig.Config.RulesEntry + (*ApplyConfig_Request)(nil), // 47: proto.ApplyConfig.Request + (*ApplyConfig_Response)(nil), // 48: proto.ApplyConfig.Response + (*Check_Request)(nil), // 49: proto.Check.Request + (*Check_Response)(nil), // 50: proto.Check.Response + (*GetOriginalwd_Request)(nil), // 51: proto.GetOriginalwd.Request + (*GetOriginalwd_Response)(nil), // 52: proto.GetOriginalwd.Response + (*GetModulePath_Request)(nil), // 53: proto.GetModulePath.Request + (*GetModulePath_Response)(nil), // 54: proto.GetModulePath.Response + (*GetModuleContent_Hint)(nil), // 55: proto.GetModuleContent.Hint + (*GetModuleContent_Option)(nil), // 56: proto.GetModuleContent.Option + (*GetModuleContent_Request)(nil), // 57: proto.GetModuleContent.Request + (*GetModuleContent_Response)(nil), // 58: proto.GetModuleContent.Response + (*GetFile_Request)(nil), // 59: proto.GetFile.Request + (*GetFile_Response)(nil), // 60: proto.GetFile.Response + (*GetFiles_Request)(nil), // 61: proto.GetFiles.Request + (*GetFiles_Response)(nil), // 62: proto.GetFiles.Response + nil, // 63: proto.GetFiles.Response.FilesEntry + (*GetRuleConfigContent_Request)(nil), // 64: proto.GetRuleConfigContent.Request + (*GetRuleConfigContent_Response)(nil), // 65: proto.GetRuleConfigContent.Response + (*EvaluateExpr_Option)(nil), // 66: proto.EvaluateExpr.Option + (*EvaluateExpr_Request)(nil), // 67: proto.EvaluateExpr.Request + (*EvaluateExpr_Response)(nil), // 68: proto.EvaluateExpr.Response + (*EmitIssue_Rule)(nil), // 69: proto.EmitIssue.Rule + (*EmitIssue_Request)(nil), // 70: proto.EmitIssue.Request + (*EmitIssue_Response)(nil), // 71: proto.EmitIssue.Response + (*ApplyChanges_Request)(nil), // 72: proto.ApplyChanges.Request + (*ApplyChanges_Response)(nil), // 73: proto.ApplyChanges.Response + nil, // 74: proto.ApplyChanges.Request.ChangesEntry + (*BodySchema_Attribute)(nil), // 75: proto.BodySchema.Attribute + (*BodySchema_Block)(nil), // 76: proto.BodySchema.Block + (*BodyContent_Attribute)(nil), // 77: proto.BodyContent.Attribute + (*BodyContent_Block)(nil), // 78: proto.BodyContent.Block + nil, // 79: proto.BodyContent.AttributesEntry + (*Range_Pos)(nil), // 80: proto.Range.Pos + (*AttributePath_Step)(nil), // 81: proto.AttributePath.Step } var file_tflint_proto_depIdxs = []int32{ - 71, // 0: proto.BodySchema.attributes:type_name -> proto.BodySchema.Attribute - 72, // 1: proto.BodySchema.blocks:type_name -> proto.BodySchema.Block + 75, // 0: proto.BodySchema.attributes:type_name -> proto.BodySchema.Attribute + 76, // 1: proto.BodySchema.blocks:type_name -> proto.BodySchema.Block 1, // 2: proto.BodySchema.Mode:type_name -> proto.SchemaMode - 75, // 3: proto.BodyContent.attributes:type_name -> proto.BodyContent.AttributesEntry - 74, // 4: proto.BodyContent.blocks:type_name -> proto.BodyContent.Block - 25, // 5: proto.Expression.range:type_name -> proto.Range - 27, // 6: proto.Expression.value_marks:type_name -> proto.ValueMark - 76, // 7: proto.Range.start:type_name -> proto.Range.Pos - 76, // 8: proto.Range.end:type_name -> proto.Range.Pos - 77, // 9: proto.AttributePath.steps:type_name -> proto.AttributePath.Step - 26, // 10: proto.ValueMark.path:type_name -> proto.AttributePath + 79, // 3: proto.BodyContent.attributes:type_name -> proto.BodyContent.AttributesEntry + 78, // 4: proto.BodyContent.blocks:type_name -> proto.BodyContent.Block + 26, // 5: proto.Expression.range:type_name -> proto.Range + 28, // 6: proto.Expression.value_marks:type_name -> proto.ValueMark + 80, // 7: proto.Range.start:type_name -> proto.Range.Pos + 80, // 8: proto.Range.end:type_name -> proto.Range.Pos + 81, // 9: proto.AttributePath.steps:type_name -> proto.AttributePath.Step + 27, // 10: proto.ValueMark.path:type_name -> proto.AttributePath 2, // 11: proto.ErrorDetail.code:type_name -> proto.ErrorCode - 22, // 12: proto.GetConfigSchema.Response.schema:type_name -> proto.BodySchema - 45, // 13: proto.ApplyGlobalConfig.Config.rules:type_name -> proto.ApplyGlobalConfig.Config.RulesEntry - 41, // 14: proto.ApplyGlobalConfig.Request.config:type_name -> proto.ApplyGlobalConfig.Config - 42, // 15: proto.ApplyGlobalConfig.Config.RulesEntry.value:type_name -> proto.ApplyGlobalConfig.RuleConfig - 23, // 16: proto.ApplyConfig.Request.content:type_name -> proto.BodyContent + 23, // 12: proto.GetConfigSchema.Response.schema:type_name -> proto.BodySchema + 46, // 13: proto.ApplyGlobalConfig.Config.rules:type_name -> proto.ApplyGlobalConfig.Config.RulesEntry + 42, // 14: proto.ApplyGlobalConfig.Request.config:type_name -> proto.ApplyGlobalConfig.Config + 43, // 15: proto.ApplyGlobalConfig.Config.RulesEntry.value:type_name -> proto.ApplyGlobalConfig.RuleConfig + 24, // 16: proto.ApplyConfig.Request.content:type_name -> proto.BodyContent 0, // 17: proto.GetModuleContent.Option.module_ctx:type_name -> proto.ModuleCtxType - 54, // 18: proto.GetModuleContent.Option.hint:type_name -> proto.GetModuleContent.Hint + 55, // 18: proto.GetModuleContent.Option.hint:type_name -> proto.GetModuleContent.Hint 3, // 19: proto.GetModuleContent.Option.expand_mode:type_name -> proto.GetModuleContent.ExpandMode - 22, // 20: proto.GetModuleContent.Request.schema:type_name -> proto.BodySchema - 55, // 21: proto.GetModuleContent.Request.option:type_name -> proto.GetModuleContent.Option - 23, // 22: proto.GetModuleContent.Response.content:type_name -> proto.BodyContent - 62, // 23: proto.GetFiles.Response.files:type_name -> proto.GetFiles.Response.FilesEntry - 22, // 24: proto.GetRuleConfigContent.Request.schema:type_name -> proto.BodySchema - 23, // 25: proto.GetRuleConfigContent.Response.content:type_name -> proto.BodyContent + 23, // 20: proto.GetModuleContent.Request.schema:type_name -> proto.BodySchema + 56, // 21: proto.GetModuleContent.Request.option:type_name -> proto.GetModuleContent.Option + 24, // 22: proto.GetModuleContent.Response.content:type_name -> proto.BodyContent + 63, // 23: proto.GetFiles.Response.files:type_name -> proto.GetFiles.Response.FilesEntry + 23, // 24: proto.GetRuleConfigContent.Request.schema:type_name -> proto.BodySchema + 24, // 25: proto.GetRuleConfigContent.Response.content:type_name -> proto.BodyContent 0, // 26: proto.EvaluateExpr.Option.module_ctx:type_name -> proto.ModuleCtxType - 25, // 27: proto.EvaluateExpr.Request.expr_range:type_name -> proto.Range - 65, // 28: proto.EvaluateExpr.Request.option:type_name -> proto.EvaluateExpr.Option - 24, // 29: proto.EvaluateExpr.Request.expression:type_name -> proto.Expression - 27, // 30: proto.EvaluateExpr.Response.marks:type_name -> proto.ValueMark + 26, // 27: proto.EvaluateExpr.Request.expr_range:type_name -> proto.Range + 66, // 28: proto.EvaluateExpr.Request.option:type_name -> proto.EvaluateExpr.Option + 25, // 29: proto.EvaluateExpr.Request.expression:type_name -> proto.Expression + 28, // 30: proto.EvaluateExpr.Response.marks:type_name -> proto.ValueMark 4, // 31: proto.EmitIssue.Rule.severity:type_name -> proto.EmitIssue.Severity - 68, // 32: proto.EmitIssue.Request.rule:type_name -> proto.EmitIssue.Rule - 25, // 33: proto.EmitIssue.Request.range:type_name -> proto.Range - 22, // 34: proto.BodySchema.Block.body:type_name -> proto.BodySchema - 25, // 35: proto.BodyContent.Attribute.expr_range:type_name -> proto.Range - 25, // 36: proto.BodyContent.Attribute.range:type_name -> proto.Range - 25, // 37: proto.BodyContent.Attribute.name_range:type_name -> proto.Range - 24, // 38: proto.BodyContent.Attribute.expression:type_name -> proto.Expression - 23, // 39: proto.BodyContent.Block.body:type_name -> proto.BodyContent - 25, // 40: proto.BodyContent.Block.def_range:type_name -> proto.Range - 25, // 41: proto.BodyContent.Block.type_range:type_name -> proto.Range - 25, // 42: proto.BodyContent.Block.label_ranges:type_name -> proto.Range - 73, // 43: proto.BodyContent.AttributesEntry.value:type_name -> proto.BodyContent.Attribute - 29, // 44: proto.RuleSet.GetName:input_type -> proto.GetName.Request - 31, // 45: proto.RuleSet.GetVersion:input_type -> proto.GetVersion.Request - 33, // 46: proto.RuleSet.GetVersionConstraint:input_type -> proto.GetVersionConstraint.Request - 35, // 47: proto.RuleSet.GetSDKVersion:input_type -> proto.GetSDKVersion.Request - 37, // 48: proto.RuleSet.GetRuleNames:input_type -> proto.GetRuleNames.Request - 39, // 49: proto.RuleSet.GetConfigSchema:input_type -> proto.GetConfigSchema.Request - 43, // 50: proto.RuleSet.ApplyGlobalConfig:input_type -> proto.ApplyGlobalConfig.Request - 46, // 51: proto.RuleSet.ApplyConfig:input_type -> proto.ApplyConfig.Request - 48, // 52: proto.RuleSet.Check:input_type -> proto.Check.Request - 50, // 53: proto.Runner.GetOriginalwd:input_type -> proto.GetOriginalwd.Request - 52, // 54: proto.Runner.GetModulePath:input_type -> proto.GetModulePath.Request - 56, // 55: proto.Runner.GetModuleContent:input_type -> proto.GetModuleContent.Request - 58, // 56: proto.Runner.GetFile:input_type -> proto.GetFile.Request - 60, // 57: proto.Runner.GetFiles:input_type -> proto.GetFiles.Request - 63, // 58: proto.Runner.GetRuleConfigContent:input_type -> proto.GetRuleConfigContent.Request - 66, // 59: proto.Runner.EvaluateExpr:input_type -> proto.EvaluateExpr.Request - 69, // 60: proto.Runner.EmitIssue:input_type -> proto.EmitIssue.Request - 30, // 61: proto.RuleSet.GetName:output_type -> proto.GetName.Response - 32, // 62: proto.RuleSet.GetVersion:output_type -> proto.GetVersion.Response - 34, // 63: proto.RuleSet.GetVersionConstraint:output_type -> proto.GetVersionConstraint.Response - 36, // 64: proto.RuleSet.GetSDKVersion:output_type -> proto.GetSDKVersion.Response - 38, // 65: proto.RuleSet.GetRuleNames:output_type -> proto.GetRuleNames.Response - 40, // 66: proto.RuleSet.GetConfigSchema:output_type -> proto.GetConfigSchema.Response - 44, // 67: proto.RuleSet.ApplyGlobalConfig:output_type -> proto.ApplyGlobalConfig.Response - 47, // 68: proto.RuleSet.ApplyConfig:output_type -> proto.ApplyConfig.Response - 49, // 69: proto.RuleSet.Check:output_type -> proto.Check.Response - 51, // 70: proto.Runner.GetOriginalwd:output_type -> proto.GetOriginalwd.Response - 53, // 71: proto.Runner.GetModulePath:output_type -> proto.GetModulePath.Response - 57, // 72: proto.Runner.GetModuleContent:output_type -> proto.GetModuleContent.Response - 59, // 73: proto.Runner.GetFile:output_type -> proto.GetFile.Response - 61, // 74: proto.Runner.GetFiles:output_type -> proto.GetFiles.Response - 64, // 75: proto.Runner.GetRuleConfigContent:output_type -> proto.GetRuleConfigContent.Response - 67, // 76: proto.Runner.EvaluateExpr:output_type -> proto.EvaluateExpr.Response - 70, // 77: proto.Runner.EmitIssue:output_type -> proto.EmitIssue.Response - 61, // [61:78] is the sub-list for method output_type - 44, // [44:61] is the sub-list for method input_type - 44, // [44:44] is the sub-list for extension type_name - 44, // [44:44] is the sub-list for extension extendee - 0, // [0:44] is the sub-list for field type_name + 69, // 32: proto.EmitIssue.Request.rule:type_name -> proto.EmitIssue.Rule + 26, // 33: proto.EmitIssue.Request.range:type_name -> proto.Range + 74, // 34: proto.ApplyChanges.Request.changes:type_name -> proto.ApplyChanges.Request.ChangesEntry + 23, // 35: proto.BodySchema.Block.body:type_name -> proto.BodySchema + 26, // 36: proto.BodyContent.Attribute.expr_range:type_name -> proto.Range + 26, // 37: proto.BodyContent.Attribute.range:type_name -> proto.Range + 26, // 38: proto.BodyContent.Attribute.name_range:type_name -> proto.Range + 25, // 39: proto.BodyContent.Attribute.expression:type_name -> proto.Expression + 24, // 40: proto.BodyContent.Block.body:type_name -> proto.BodyContent + 26, // 41: proto.BodyContent.Block.def_range:type_name -> proto.Range + 26, // 42: proto.BodyContent.Block.type_range:type_name -> proto.Range + 26, // 43: proto.BodyContent.Block.label_ranges:type_name -> proto.Range + 77, // 44: proto.BodyContent.AttributesEntry.value:type_name -> proto.BodyContent.Attribute + 30, // 45: proto.RuleSet.GetName:input_type -> proto.GetName.Request + 32, // 46: proto.RuleSet.GetVersion:input_type -> proto.GetVersion.Request + 34, // 47: proto.RuleSet.GetVersionConstraint:input_type -> proto.GetVersionConstraint.Request + 36, // 48: proto.RuleSet.GetSDKVersion:input_type -> proto.GetSDKVersion.Request + 38, // 49: proto.RuleSet.GetRuleNames:input_type -> proto.GetRuleNames.Request + 40, // 50: proto.RuleSet.GetConfigSchema:input_type -> proto.GetConfigSchema.Request + 44, // 51: proto.RuleSet.ApplyGlobalConfig:input_type -> proto.ApplyGlobalConfig.Request + 47, // 52: proto.RuleSet.ApplyConfig:input_type -> proto.ApplyConfig.Request + 49, // 53: proto.RuleSet.Check:input_type -> proto.Check.Request + 51, // 54: proto.Runner.GetOriginalwd:input_type -> proto.GetOriginalwd.Request + 53, // 55: proto.Runner.GetModulePath:input_type -> proto.GetModulePath.Request + 57, // 56: proto.Runner.GetModuleContent:input_type -> proto.GetModuleContent.Request + 59, // 57: proto.Runner.GetFile:input_type -> proto.GetFile.Request + 61, // 58: proto.Runner.GetFiles:input_type -> proto.GetFiles.Request + 64, // 59: proto.Runner.GetRuleConfigContent:input_type -> proto.GetRuleConfigContent.Request + 67, // 60: proto.Runner.EvaluateExpr:input_type -> proto.EvaluateExpr.Request + 70, // 61: proto.Runner.EmitIssue:input_type -> proto.EmitIssue.Request + 72, // 62: proto.Runner.ApplyChanges:input_type -> proto.ApplyChanges.Request + 31, // 63: proto.RuleSet.GetName:output_type -> proto.GetName.Response + 33, // 64: proto.RuleSet.GetVersion:output_type -> proto.GetVersion.Response + 35, // 65: proto.RuleSet.GetVersionConstraint:output_type -> proto.GetVersionConstraint.Response + 37, // 66: proto.RuleSet.GetSDKVersion:output_type -> proto.GetSDKVersion.Response + 39, // 67: proto.RuleSet.GetRuleNames:output_type -> proto.GetRuleNames.Response + 41, // 68: proto.RuleSet.GetConfigSchema:output_type -> proto.GetConfigSchema.Response + 45, // 69: proto.RuleSet.ApplyGlobalConfig:output_type -> proto.ApplyGlobalConfig.Response + 48, // 70: proto.RuleSet.ApplyConfig:output_type -> proto.ApplyConfig.Response + 50, // 71: proto.RuleSet.Check:output_type -> proto.Check.Response + 52, // 72: proto.Runner.GetOriginalwd:output_type -> proto.GetOriginalwd.Response + 54, // 73: proto.Runner.GetModulePath:output_type -> proto.GetModulePath.Response + 58, // 74: proto.Runner.GetModuleContent:output_type -> proto.GetModuleContent.Response + 60, // 75: proto.Runner.GetFile:output_type -> proto.GetFile.Response + 62, // 76: proto.Runner.GetFiles:output_type -> proto.GetFiles.Response + 65, // 77: proto.Runner.GetRuleConfigContent:output_type -> proto.GetRuleConfigContent.Response + 68, // 78: proto.Runner.EvaluateExpr:output_type -> proto.EvaluateExpr.Response + 71, // 79: proto.Runner.EmitIssue:output_type -> proto.EmitIssue.Response + 73, // 80: proto.Runner.ApplyChanges:output_type -> proto.ApplyChanges.Response + 63, // [63:81] is the sub-list for method output_type + 45, // [45:63] is the sub-list for method input_type + 45, // [45:45] is the sub-list for extension type_name + 45, // [45:45] is the sub-list for extension extendee + 0, // [0:45] is the sub-list for field type_name } func init() { file_tflint_proto_init() } @@ -4483,7 +4657,7 @@ func file_tflint_proto_init() { } } file_tflint_proto_msgTypes[17].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*BodySchema); i { + switch v := v.(*ApplyChanges); i { case 0: return &v.state case 1: @@ -4495,7 +4669,7 @@ func file_tflint_proto_init() { } } file_tflint_proto_msgTypes[18].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*BodyContent); i { + switch v := v.(*BodySchema); i { case 0: return &v.state case 1: @@ -4507,7 +4681,7 @@ func file_tflint_proto_init() { } } file_tflint_proto_msgTypes[19].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*Expression); i { + switch v := v.(*BodyContent); i { case 0: return &v.state case 1: @@ -4519,7 +4693,7 @@ func file_tflint_proto_init() { } } file_tflint_proto_msgTypes[20].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*Range); i { + switch v := v.(*Expression); i { case 0: return &v.state case 1: @@ -4531,7 +4705,7 @@ func file_tflint_proto_init() { } } file_tflint_proto_msgTypes[21].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*AttributePath); i { + switch v := v.(*Range); i { case 0: return &v.state case 1: @@ -4543,7 +4717,7 @@ func file_tflint_proto_init() { } } file_tflint_proto_msgTypes[22].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*ValueMark); i { + switch v := v.(*AttributePath); i { case 0: return &v.state case 1: @@ -4555,7 +4729,7 @@ func file_tflint_proto_init() { } } file_tflint_proto_msgTypes[23].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*ErrorDetail); i { + switch v := v.(*ValueMark); i { case 0: return &v.state case 1: @@ -4567,7 +4741,7 @@ func file_tflint_proto_init() { } } file_tflint_proto_msgTypes[24].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*GetName_Request); i { + switch v := v.(*ErrorDetail); i { case 0: return &v.state case 1: @@ -4579,7 +4753,7 @@ func file_tflint_proto_init() { } } file_tflint_proto_msgTypes[25].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*GetName_Response); i { + switch v := v.(*GetName_Request); i { case 0: return &v.state case 1: @@ -4591,7 +4765,7 @@ func file_tflint_proto_init() { } } file_tflint_proto_msgTypes[26].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*GetVersion_Request); i { + switch v := v.(*GetName_Response); i { case 0: return &v.state case 1: @@ -4603,7 +4777,7 @@ func file_tflint_proto_init() { } } file_tflint_proto_msgTypes[27].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*GetVersion_Response); i { + switch v := v.(*GetVersion_Request); i { case 0: return &v.state case 1: @@ -4615,7 +4789,7 @@ func file_tflint_proto_init() { } } file_tflint_proto_msgTypes[28].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*GetVersionConstraint_Request); i { + switch v := v.(*GetVersion_Response); i { case 0: return &v.state case 1: @@ -4627,7 +4801,7 @@ func file_tflint_proto_init() { } } file_tflint_proto_msgTypes[29].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*GetVersionConstraint_Response); i { + switch v := v.(*GetVersionConstraint_Request); i { case 0: return &v.state case 1: @@ -4639,7 +4813,7 @@ func file_tflint_proto_init() { } } file_tflint_proto_msgTypes[30].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*GetSDKVersion_Request); i { + switch v := v.(*GetVersionConstraint_Response); i { case 0: return &v.state case 1: @@ -4651,7 +4825,7 @@ func file_tflint_proto_init() { } } file_tflint_proto_msgTypes[31].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*GetSDKVersion_Response); i { + switch v := v.(*GetSDKVersion_Request); i { case 0: return &v.state case 1: @@ -4663,7 +4837,7 @@ func file_tflint_proto_init() { } } file_tflint_proto_msgTypes[32].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*GetRuleNames_Request); i { + switch v := v.(*GetSDKVersion_Response); i { case 0: return &v.state case 1: @@ -4675,7 +4849,7 @@ func file_tflint_proto_init() { } } file_tflint_proto_msgTypes[33].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*GetRuleNames_Response); i { + switch v := v.(*GetRuleNames_Request); i { case 0: return &v.state case 1: @@ -4687,7 +4861,7 @@ func file_tflint_proto_init() { } } file_tflint_proto_msgTypes[34].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*GetConfigSchema_Request); i { + switch v := v.(*GetRuleNames_Response); i { case 0: return &v.state case 1: @@ -4699,7 +4873,7 @@ func file_tflint_proto_init() { } } file_tflint_proto_msgTypes[35].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*GetConfigSchema_Response); i { + switch v := v.(*GetConfigSchema_Request); i { case 0: return &v.state case 1: @@ -4711,7 +4885,7 @@ func file_tflint_proto_init() { } } file_tflint_proto_msgTypes[36].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*ApplyGlobalConfig_Config); i { + switch v := v.(*GetConfigSchema_Response); i { case 0: return &v.state case 1: @@ -4723,7 +4897,7 @@ func file_tflint_proto_init() { } } file_tflint_proto_msgTypes[37].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*ApplyGlobalConfig_RuleConfig); i { + switch v := v.(*ApplyGlobalConfig_Config); i { case 0: return &v.state case 1: @@ -4735,7 +4909,7 @@ func file_tflint_proto_init() { } } file_tflint_proto_msgTypes[38].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*ApplyGlobalConfig_Request); i { + switch v := v.(*ApplyGlobalConfig_RuleConfig); i { case 0: return &v.state case 1: @@ -4747,6 +4921,18 @@ func file_tflint_proto_init() { } } file_tflint_proto_msgTypes[39].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*ApplyGlobalConfig_Request); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + file_tflint_proto_msgTypes[40].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*ApplyGlobalConfig_Response); i { case 0: return &v.state @@ -4758,7 +4944,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[41].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[42].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*ApplyConfig_Request); i { case 0: return &v.state @@ -4770,7 +4956,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[42].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[43].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*ApplyConfig_Response); i { case 0: return &v.state @@ -4782,7 +4968,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[43].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[44].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*Check_Request); i { case 0: return &v.state @@ -4794,7 +4980,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[44].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[45].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*Check_Response); i { case 0: return &v.state @@ -4806,7 +4992,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[45].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[46].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*GetOriginalwd_Request); i { case 0: return &v.state @@ -4818,7 +5004,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[46].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[47].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*GetOriginalwd_Response); i { case 0: return &v.state @@ -4830,7 +5016,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[47].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[48].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*GetModulePath_Request); i { case 0: return &v.state @@ -4842,7 +5028,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[48].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[49].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*GetModulePath_Response); i { case 0: return &v.state @@ -4854,7 +5040,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[49].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[50].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*GetModuleContent_Hint); i { case 0: return &v.state @@ -4866,7 +5052,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[50].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[51].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*GetModuleContent_Option); i { case 0: return &v.state @@ -4878,7 +5064,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[51].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[52].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*GetModuleContent_Request); i { case 0: return &v.state @@ -4890,7 +5076,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[52].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[53].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*GetModuleContent_Response); i { case 0: return &v.state @@ -4902,7 +5088,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[53].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[54].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*GetFile_Request); i { case 0: return &v.state @@ -4914,7 +5100,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[54].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[55].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*GetFile_Response); i { case 0: return &v.state @@ -4926,7 +5112,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[55].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[56].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*GetFiles_Request); i { case 0: return &v.state @@ -4938,7 +5124,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[56].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[57].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*GetFiles_Response); i { case 0: return &v.state @@ -4950,7 +5136,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[58].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[59].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*GetRuleConfigContent_Request); i { case 0: return &v.state @@ -4962,7 +5148,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[59].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[60].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*GetRuleConfigContent_Response); i { case 0: return &v.state @@ -4974,7 +5160,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[60].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[61].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*EvaluateExpr_Option); i { case 0: return &v.state @@ -4986,7 +5172,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[61].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[62].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*EvaluateExpr_Request); i { case 0: return &v.state @@ -4998,7 +5184,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[62].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[63].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*EvaluateExpr_Response); i { case 0: return &v.state @@ -5010,7 +5196,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[63].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[64].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*EmitIssue_Rule); i { case 0: return &v.state @@ -5022,7 +5208,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[64].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[65].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*EmitIssue_Request); i { case 0: return &v.state @@ -5034,7 +5220,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[65].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[66].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*EmitIssue_Response); i { case 0: return &v.state @@ -5046,7 +5232,31 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[66].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[67].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*ApplyChanges_Request); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + file_tflint_proto_msgTypes[68].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*ApplyChanges_Response); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + file_tflint_proto_msgTypes[70].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*BodySchema_Attribute); i { case 0: return &v.state @@ -5058,7 +5268,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[67].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[71].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*BodySchema_Block); i { case 0: return &v.state @@ -5070,7 +5280,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[68].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[72].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*BodyContent_Attribute); i { case 0: return &v.state @@ -5082,7 +5292,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[69].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[73].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*BodyContent_Block); i { case 0: return &v.state @@ -5094,7 +5304,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[71].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[75].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*Range_Pos); i { case 0: return &v.state @@ -5106,7 +5316,7 @@ func file_tflint_proto_init() { return nil } } - file_tflint_proto_msgTypes[72].Exporter = func(v interface{}, i int) interface{} { + file_tflint_proto_msgTypes[76].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*AttributePath_Step); i { case 0: return &v.state @@ -5119,7 +5329,7 @@ func file_tflint_proto_init() { } } } - file_tflint_proto_msgTypes[72].OneofWrappers = []interface{}{ + file_tflint_proto_msgTypes[76].OneofWrappers = []interface{}{ (*AttributePath_Step_AttributeName)(nil), (*AttributePath_Step_ElementKeyString)(nil), (*AttributePath_Step_ElementKeyInt)(nil), @@ -5130,7 +5340,7 @@ func file_tflint_proto_init() { GoPackagePath: reflect.TypeOf(x{}).PkgPath(), RawDescriptor: file_tflint_proto_rawDesc, NumEnums: 5, - NumMessages: 73, + NumMessages: 77, NumExtensions: 0, NumServices: 2, }, diff --git a/plugin/proto/tflint.proto b/plugin/proto/tflint.proto index fcdcfd4..83eb31c 100644 --- a/plugin/proto/tflint.proto +++ b/plugin/proto/tflint.proto @@ -62,6 +62,7 @@ message ApplyGlobalConfig { map rules = 1; bool disabled_by_default = 2; repeated string only = 3; + bool fix = 4; } message RuleConfig { string name = 1; @@ -97,6 +98,7 @@ service Runner { rpc GetRuleConfigContent(GetRuleConfigContent.Request) returns (GetRuleConfigContent.Response); rpc EvaluateExpr(EvaluateExpr.Request) returns (EvaluateExpr.Response); rpc EmitIssue(EmitIssue.Request) returns (EmitIssue.Response); + rpc ApplyChanges(ApplyChanges.Request) returns (ApplyChanges.Response); } enum ModuleCtxType { @@ -207,6 +209,16 @@ message EmitIssue { Rule rule = 1; string message = 2; Range range = 3; + bool fixable = 4; + } + message Response { + bool applied = 1; + } +} + +message ApplyChanges { + message Request { + map changes = 1; } message Response {} } diff --git a/plugin/proto/tflint_grpc.pb.go b/plugin/proto/tflint_grpc.pb.go index 9d4cd67..ae061ee 100644 --- a/plugin/proto/tflint_grpc.pb.go +++ b/plugin/proto/tflint_grpc.pb.go @@ -413,6 +413,7 @@ const ( Runner_GetRuleConfigContent_FullMethodName = "/proto.Runner/GetRuleConfigContent" Runner_EvaluateExpr_FullMethodName = "/proto.Runner/EvaluateExpr" Runner_EmitIssue_FullMethodName = "/proto.Runner/EmitIssue" + Runner_ApplyChanges_FullMethodName = "/proto.Runner/ApplyChanges" ) // RunnerClient is the client API for Runner service. @@ -427,6 +428,7 @@ type RunnerClient interface { GetRuleConfigContent(ctx context.Context, in *GetRuleConfigContent_Request, opts ...grpc.CallOption) (*GetRuleConfigContent_Response, error) EvaluateExpr(ctx context.Context, in *EvaluateExpr_Request, opts ...grpc.CallOption) (*EvaluateExpr_Response, error) EmitIssue(ctx context.Context, in *EmitIssue_Request, opts ...grpc.CallOption) (*EmitIssue_Response, error) + ApplyChanges(ctx context.Context, in *ApplyChanges_Request, opts ...grpc.CallOption) (*ApplyChanges_Response, error) } type runnerClient struct { @@ -509,6 +511,15 @@ func (c *runnerClient) EmitIssue(ctx context.Context, in *EmitIssue_Request, opt return out, nil } +func (c *runnerClient) ApplyChanges(ctx context.Context, in *ApplyChanges_Request, opts ...grpc.CallOption) (*ApplyChanges_Response, error) { + out := new(ApplyChanges_Response) + err := c.cc.Invoke(ctx, Runner_ApplyChanges_FullMethodName, in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + // RunnerServer is the server API for Runner service. // All implementations must embed UnimplementedRunnerServer // for forward compatibility @@ -521,6 +532,7 @@ type RunnerServer interface { GetRuleConfigContent(context.Context, *GetRuleConfigContent_Request) (*GetRuleConfigContent_Response, error) EvaluateExpr(context.Context, *EvaluateExpr_Request) (*EvaluateExpr_Response, error) EmitIssue(context.Context, *EmitIssue_Request) (*EmitIssue_Response, error) + ApplyChanges(context.Context, *ApplyChanges_Request) (*ApplyChanges_Response, error) mustEmbedUnimplementedRunnerServer() } @@ -552,6 +564,9 @@ func (UnimplementedRunnerServer) EvaluateExpr(context.Context, *EvaluateExpr_Req func (UnimplementedRunnerServer) EmitIssue(context.Context, *EmitIssue_Request) (*EmitIssue_Response, error) { return nil, status.Errorf(codes.Unimplemented, "method EmitIssue not implemented") } +func (UnimplementedRunnerServer) ApplyChanges(context.Context, *ApplyChanges_Request) (*ApplyChanges_Response, error) { + return nil, status.Errorf(codes.Unimplemented, "method ApplyChanges not implemented") +} func (UnimplementedRunnerServer) mustEmbedUnimplementedRunnerServer() {} // UnsafeRunnerServer may be embedded to opt out of forward compatibility for this service. @@ -709,6 +724,24 @@ func _Runner_EmitIssue_Handler(srv interface{}, ctx context.Context, dec func(in return interceptor(ctx, in, info, handler) } +func _Runner_ApplyChanges_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(ApplyChanges_Request) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(RunnerServer).ApplyChanges(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: Runner_ApplyChanges_FullMethodName, + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(RunnerServer).ApplyChanges(ctx, req.(*ApplyChanges_Request)) + } + return interceptor(ctx, in, info, handler) +} + // Runner_ServiceDesc is the grpc.ServiceDesc for Runner service. // It's only intended for direct use with grpc.RegisterService, // and not to be introspected or modified (even as a copy) @@ -748,6 +781,10 @@ var Runner_ServiceDesc = grpc.ServiceDesc{ MethodName: "EmitIssue", Handler: _Runner_EmitIssue_Handler, }, + { + MethodName: "ApplyChanges", + Handler: _Runner_ApplyChanges_Handler, + }, }, Streams: []grpc.StreamDesc{}, Metadata: "tflint.proto", diff --git a/plugin/toproto/toproto.go b/plugin/toproto/toproto.go index 679b980..3d31b1c 100644 --- a/plugin/toproto/toproto.go +++ b/plugin/toproto/toproto.go @@ -240,6 +240,7 @@ func Config(config *tflint.Config) *proto.ApplyGlobalConfig_Config { Rules: rules, DisabledByDefault: config.DisabledByDefault, Only: config.Only, + Fix: config.Fix, } } diff --git a/tflint/config.go b/tflint/config.go index ec561de..61ddfc4 100644 --- a/tflint/config.go +++ b/tflint/config.go @@ -5,6 +5,7 @@ type Config struct { Rules map[string]*RuleConfig DisabledByDefault bool Only []string + Fix bool } // RuleConfig is a TFLint's rule configuration. diff --git a/tflint/fixer.go b/tflint/fixer.go new file mode 100644 index 0000000..533997a --- /dev/null +++ b/tflint/fixer.go @@ -0,0 +1,558 @@ +package tflint + +import ( + "bufio" + "bytes" + "fmt" + "strings" + "unicode" + "unicode/utf8" + + "github.com/hashicorp/hcl/v2" + "github.com/hashicorp/hcl/v2/hclsyntax" + "github.com/terraform-linters/tflint-plugin-sdk/hclext" + "github.com/zclconf/go-cty/cty" +) + +// Fixer is a tool to rewrite HCL source code. +type Fixer struct { + sources map[string][]byte + changes map[string][]byte + shifts []shift +} + +type shift struct { + target hcl.Range // rewrite target range caused by the shift + start int // start byte index of the shift + offset int // shift offset +} + +// NewFixer creates a new Fixer instance. +func NewFixer(sources map[string][]byte) *Fixer { + return &Fixer{ + sources: sources, + changes: map[string][]byte{}, + shifts: []shift{}, + } +} + +// ReplaceText rewrites the given range of source code to a new text. +// If the range is overlapped with a previous rewrite range, it returns an error. +// +// If the argument is a text node, and the range is contained in the replacement range, +// this function automatically minimizes the replacement range as much as possible. +// +// For example, if the source code is "(foo)", ReplaceText(rng, "[foo]") +// rewrites the whole "(foo)". But ReplaceText(rng, "[", TextAt(fooRange), "]") +// rewrites only "(" and ")". This is useful to avoid unintended conflicts. +func (f *Fixer) ReplaceText(rng hcl.Range, texts ...any) error { + if len(texts) == 0 { + return fmt.Errorf("no text to replace") + } + + var start hcl.Pos = rng.Start + var new string + + for _, text := range texts { + switch text := text.(type) { + case string: + new += text + case TextNode: + if rng.Filename == text.Range.Filename && start.Byte <= text.Range.Start.Byte { + if err := f.replaceText(hcl.Range{Filename: rng.Filename, Start: start, End: text.Range.Start}, new); err != nil { + return err + } + start = text.Range.End + new = "" + } else { + // If the text node is not contained in the replacement range, just append the text. + new += string(text.Bytes) + } + default: + return fmt.Errorf("ReplaceText only accepts string or textNode, but got %T", text) + } + } + return f.replaceText(hcl.Range{Filename: rng.Filename, Start: start, End: rng.End}, new) +} + +func (f *Fixer) replaceText(rng hcl.Range, new string) error { + // If there are already changes, overwrite the changed content. + var file []byte + if change, exists := f.changes[rng.Filename]; exists { + file = change + } else if source, exists := f.sources[rng.Filename]; exists { + file = source + } else { + return fmt.Errorf("file not found: %s", rng.Filename) + } + + // Apply rewrite gaps so that you can chain rewrites using pre-change ranges. + for _, shift := range f.shifts { + if shift.target.Filename != rng.Filename { + continue + } + if !shift.target.Overlap(rng).Empty() { + // If the range is the same as before, just update the content. + // Note that only the end byte index should reflect the shift. + if shift.target.Start.Byte == rng.Start.Byte && shift.target.End.Byte == rng.End.Byte { + rng.End.Byte += shift.offset + continue + } + return fmt.Errorf("range overlaps with a previous rewrite range: %s", shift.target.String()) + } + // Apply shift to the range if the shift is before the range. + if shift.start <= rng.Start.Byte { + rng.Start.Byte += shift.offset + rng.End.Byte += shift.offset + } + } + + buf := bytes.NewBuffer(bytes.Clone(file[:rng.Start.Byte])) + buf.WriteString(new) + buf.Write(file[rng.End.Byte:]) + + // If the new content is the same as the before, do nothing. + if bytes.Equal(file, buf.Bytes()) { + return nil + } + + // Tracks rewrite gaps + oldBytes := rng.End.Byte - rng.Start.Byte + newBytes := len(new) + if oldBytes == newBytes { + // no shift: foo -> bar + } else if oldBytes < newBytes { + // shift right: foo -> foooo + // |-| shift + f.shifts = append(f.shifts, shift{ + target: rng, + start: rng.End.Byte, + offset: newBytes - oldBytes, + }) + } else { + // shift left: foooo -> foo + // |-| shift + f.shifts = append(f.shifts, shift{ + target: rng, + start: rng.End.Byte - (oldBytes - newBytes), + offset: -(oldBytes - newBytes), + }) + } + + f.changes[rng.Filename] = buf.Bytes() + return nil +} + +// Remove removes the given range of source code. +func (f *Fixer) Remove(rng hcl.Range) error { + return f.ReplaceText(rng, "") +} + +// RemoveAttribute removes the given attribute. +// The difference from Remove is that it removes the attribute +// and the associated newlines, indentations, and comments. +// This only works for HCL native syntax. JSON syntax is not supported +// and returns an error. +func (f *Fixer) RemoveAttribute(attr *hcl.Attribute) error { + if strings.HasSuffix(attr.Range.Filename, ".tf.json") { + return fmt.Errorf("RemoveAttribute is not supported in JSON syntax") + } + + rng, err := f.expandRangeToTrivialTokens(attr.Range) + if err != nil { + return err + } + return f.Remove(rng) +} + +// RemoveBlock removes the given block from the source code. +// The difference from Remove is that it removes the block +// and the associated newlines, indentations, and comments. +// This only works for HCL native syntax. JSON syntax is not supported +// and returns an error. +func (f *Fixer) RemoveBlock(block *hcl.Block) error { + if strings.HasSuffix(block.DefRange.Filename, ".tf.json") { + return fmt.Errorf("RemoveBlock is not supported in JSON syntax") + } + + source, exists := f.sources[block.DefRange.Filename] + if !exists { + return fmt.Errorf("file not found: %s", block.DefRange.Filename) + } + // Parse the source code to get the whole block range. + // Notice that hcl.Block does not have the whole range, but hclsyntax.Block does. + file, diags := hclsyntax.ParseConfig(source, block.DefRange.Filename, hcl.InitialPos) + if diags.HasErrors() { + return diags + } + + var blockRange hcl.Range + diags = hclsyntax.VisitAll(file.Body.(*hclsyntax.Body), func(node hclsyntax.Node) hcl.Diagnostics { + if nativeBlock, ok := node.(*hclsyntax.Block); ok { + if nativeBlock.TypeRange.Start.Byte == block.TypeRange.Start.Byte { + blockRange = hcl.RangeBetween(block.DefRange, nativeBlock.CloseBraceRange) + return nil + } + } + return nil + }) + if diags.HasErrors() { + return diags + } + if blockRange.Empty() { + return fmt.Errorf("block not found at %s:%d,%d", block.DefRange.Filename, block.DefRange.Start.Line, block.DefRange.Start.Column) + } + + rng, err := f.expandRangeToTrivialTokens(blockRange) + if err != nil { + return err + } + + return f.Remove(rng) +} + +// RemoveExtBlock removes the given block from the source code. +// This is similar to RemoveBlock, but it works for *hclext.Block. +func (f *Fixer) RemoveExtBlock(block *hclext.Block) error { + if strings.HasSuffix(block.DefRange.Filename, ".tf.json") { + return fmt.Errorf("RemoveExtBlock is not supported in JSON syntax") + } + + // In RemoveBlock, body is not important, so convert the given block + // to a native block without the body. + return f.RemoveBlock(&hcl.Block{ + Type: block.Type, + Labels: block.Labels, + + DefRange: block.DefRange, + TypeRange: block.TypeRange, + LabelRanges: block.LabelRanges, + }) +} + +// expandRangeToTrivialTokens expands the given range to include comments, newlines, and indentations. +func (f *Fixer) expandRangeToTrivialTokens(rng hcl.Range) (hcl.Range, error) { + source, exists := f.sources[rng.Filename] + if !exists { + return rng, fmt.Errorf("file not found: %s", rng.Filename) + } + // Use tokenScanner to find tokens before and after the attribute/block range, + // in order to remove comments, newlines, and indentations. + scanner, diags := newTokenScanner(source, rng.Filename) + if diags.HasErrors() { + return rng, diags + } + + var expanded = rng + + // Scan backward until a newline is found, and expand the start position. + // + // <-- start + // | + // foo = 1 + if err := scanner.seek(rng.Start, tokenStart); err != nil { + return rng, err + } +endScanBackward: + for scanner.scanBackward() { + switch scanner.token().Type { + case hclsyntax.TokenNewline: + // Seek to the end of the token to keep the newline. + scanner.seekTokenEnd() + break endScanBackward + + case hclsyntax.TokenComment: + // For a trailing single-line comment, determines whether the comment is associated with itself. + // For example, the following comment is associated with the "foo" attribute and should be removed. + // + // # comment + // foo = 1 + // + // On the other hand, the following comment is associated with the "bar" attribute and should not be removed. + // + // bar = 2 # comment + // foo = 1 + // + // To determine these, we need to look at the tokens before the comment token. + if strings.HasPrefix(string(scanner.token().Bytes), "#") || strings.HasPrefix(string(scanner.token().Bytes), "//") { + trailingCommentIndex := scanner.index + + for scanner.scanBackward() { + switch scanner.token().Type { + case hclsyntax.TokenComment: + // Ignore comment tokens in case there are multiple comments. + // + // # comment1 + // # comment2 + // foo = 1 + continue + + case hclsyntax.TokenNewline: + // If there is only a comment after the newline, the line can be deleted. + scanner.seekTokenEnd() + break endScanBackward + + default: + // If there is a token other than comment or newline, seek to the ending position of the trailing comment. + if err := scanner.seekByIndex(trailingCommentIndex, tokenEnd); err != nil { + return rng, err + } + break endScanBackward + } + } + } + + // For an inline block, use an opening brace instead. + // + // block { foo = 1 } => TokenOBrace + Attribute + TokenCBrace + case hclsyntax.TokenOBrace: + // Seek to the end of the token to keep the brace. + scanner.seekTokenEnd() + break endScanBackward + } + } + expanded.Start = scanner.pos + + // Count the number of newlines before the range. + // This is because it doesn't leave a nonsense newline after deletion + newlineCountInBackward := 0 + for scanner.scanBackwardIf(hclsyntax.TokenNewline) { + newlineCountInBackward++ + } + + // Scan forward until a newline is found, and expand the end position. + // + // end --> + // | + // foo = 1 + if err := scanner.seek(rng.End, tokenEnd); err != nil { + return rng, err + } +endScan: + for scanner.scan() { + switch scanner.token().Type { + case hclsyntax.TokenNewline: + // Remove newline + break endScan + + case hclsyntax.TokenComment: + // For a trailing single-line comment, use a comment token instead because it does not produce a newline token. + // + // foo = 1 => Attribute + TokenNewline + // foo = 1 # comment => Attribute + TokenComment + // foo = 1 /* comment */ => Attribute + TokenComment + TokenNewline + if strings.HasPrefix(string(scanner.token().Bytes), "#") || strings.HasPrefix(string(scanner.token().Bytes), "//") { + break endScan + } + + // For an inline block, use an closing brace instead. + // + // block { foo = 1 } => TokenOBrace + Attribute + TokenCBrace + case hclsyntax.TokenCBrace: + // Seek to the start of the token to keep the brace. + scanner.seekTokenStart() + break endScan + } + } + expanded.End = scanner.pos + + // Count the number of newlines after the range. + newlineCountInForward := 0 + for scanner.scanIf(hclsyntax.TokenNewline) { + newlineCountInForward++ + } + // If the number of newlines before and after the range is the same, + // expand the end position to delete nonsense newlines. + // + // foo = 1 + // + // bar = 2 <-- delete this attribute + // + // baz = 3 + // + // Newlines are removed like this: + // + // foo = 1 + // + // baz = 3 + // + if newlineCountInForward > 0 && newlineCountInBackward == newlineCountInForward { + expanded.End = scanner.pos + } + + return expanded, nil +} + +// TextNode represents a text with range in the source code. +type TextNode struct { + Bytes []byte + Range hcl.Range +} + +// TextAt returns a text node at the given range. +// Note this doesn't take into account the changes made by the fixer in a rule. +func (f *Fixer) TextAt(rng hcl.Range) TextNode { + source := f.sources[rng.Filename] + if !rng.CanSliceBytes(source) { + return TextNode{Range: rng} + } + return TextNode{Bytes: rng.SliceBytes(source), Range: rng} +} + +// ValueText returns a text representation of the given cty.Value. +// Values are always converted to a single line. For more pretty-printing, +// implement your own conversion function. +// +// This function is inspired by hclwrite.TokensForValue. +// https://github.com/hashicorp/hcl/blob/v2.16.2/hclwrite/generate.go#L26 +func (f *Fixer) ValueText(val cty.Value) string { + // TODO: write tests + switch { + case !val.IsKnown(): + panic("cannot produce text for unknown value") + + case val.IsNull(): + return "null" + + case val.Type() == cty.Bool: + if val.True() { + return "true" + } + return "false" + + case val.Type() == cty.Number: + return val.AsBigFloat().Text('f', -1) + + case val.Type() == cty.String: + return fmt.Sprintf(`"%s"`, escapeQuotedStringLit(val.AsString())) + + case val.Type().IsListType() || val.Type().IsSetType() || val.Type().IsTupleType(): + items := make([]string, 0, val.LengthInt()) + for it := val.ElementIterator(); it.Next(); { + _, v := it.Element() + items = append(items, f.ValueText(v)) + } + return fmt.Sprintf("[%s]", strings.Join(items, ", ")) + + case val.Type().IsMapType() || val.Type().IsObjectType(): + items := make([]string, 0, val.LengthInt()) + for it := val.ElementIterator(); it.Next(); { + k, v := it.Element() + if hclsyntax.ValidIdentifier(k.AsString()) { + items = append(items, fmt.Sprintf("%s = %s", k.AsString(), f.ValueText(v))) + } else { + items = append(items, fmt.Sprintf("%s = %s", f.ValueText(k), f.ValueText(v))) + } + } + return fmt.Sprintf("{ %s }", strings.Join(items, ", ")) + + default: + panic(fmt.Sprintf("cannot produce text for %s", val.Type().FriendlyName())) + } +} + +func escapeQuotedStringLit(s string) []byte { + if len(s) == 0 { + return nil + } + buf := make([]byte, 0, len(s)) + for i, r := range s { + switch r { + case '\n': + buf = append(buf, '\\', 'n') + case '\r': + buf = append(buf, '\\', 'r') + case '\t': + buf = append(buf, '\\', 't') + case '"': + buf = append(buf, '\\', '"') + case '\\': + buf = append(buf, '\\', '\\') + case '$', '%': + buf = appendRune(buf, r) + remain := s[i+1:] + if len(remain) > 0 && remain[0] == '{' { + // Double up our template introducer symbol to escape it. + buf = appendRune(buf, r) + } + default: + if !unicode.IsPrint(r) { + var fmted string + if r < 65536 { + fmted = fmt.Sprintf("\\u%04x", r) + } else { + fmted = fmt.Sprintf("\\U%08x", r) + } + buf = append(buf, fmted...) + } else { + buf = appendRune(buf, r) + } + } + } + return buf +} + +func appendRune(b []byte, r rune) []byte { + l := utf8.RuneLen(r) + for i := 0; i < l; i++ { + b = append(b, 0) // make room at the end of our buffer + } + ch := b[len(b)-l:] + utf8.EncodeRune(ch, r) + return b +} + +// RangeTo returns a range from the given start position to the given text. +// Note that it doesn't check if the text is actually in the range. +func (f *Fixer) RangeTo(to string, filename string, start hcl.Pos) hcl.Range { + end := start + if to == "" { + return hcl.Range{Filename: filename, Start: start, End: end} + } + + scanner := hcl.NewRangeScanner([]byte(to), filename, bufio.ScanLines) + for scanner.Scan() { + end = scanner.Range().End + } + if scanner.Err() != nil { + // never happen + panic(scanner.Err()) + } + + var line, column, bytes int + line = start.Line + end.Line - 1 + if end.Line == 1 { + column = start.Column + end.Column - 1 + } else { + column = end.Column + } + bytes = start.Byte + end.Byte + + return hcl.Range{ + Filename: filename, + Start: start, + End: hcl.Pos{Line: line, Column: column, Byte: bytes}, + } +} + +// Changes returns the changes made by the fixer. +// Note this API is not intended to be used by plugins. +func (f *Fixer) Changes() map[string][]byte { + return f.changes +} + +// HasChanges returns true if the fixer has changes. +// Note this API is not intended to be used by plugins. +func (f *Fixer) HasChanges() bool { + return len(f.changes) > 0 +} + +// ApplyChanges applies the changes made by the fixer. +// Note this API is not intended to be used by plugins. +func (f *Fixer) ApplyChanges() { + for filename, content := range f.changes { + f.sources[filename] = content + } + f.changes = map[string][]byte{} + f.shifts = []shift{} +} diff --git a/tflint/fixer_test.go b/tflint/fixer_test.go new file mode 100644 index 0000000..0b9b1f9 --- /dev/null +++ b/tflint/fixer_test.go @@ -0,0 +1,1299 @@ +package tflint + +import ( + "testing" + + "github.com/google/go-cmp/cmp" + "github.com/hashicorp/hcl/v2" + "github.com/hashicorp/hcl/v2/hclsyntax" + "github.com/terraform-linters/tflint-plugin-sdk/hclext" +) + +func TestReplaceText(t *testing.T) { + // default error check helper + neverHappend := func(err error) bool { return err != nil } + + tests := []struct { + name string + sources map[string]string + fix func(*Fixer) error + want map[string]string + errCheck func(error) bool + }{ + { + name: "no change", + sources: map[string]string{ + "main.tf": "// comment", + }, + fix: func(fixer *Fixer) error { + return nil + }, + want: map[string]string{}, + errCheck: neverHappend, + }, + { + name: "no shift", + sources: map[string]string{ + "main.tf": "// comment", + }, + fix: func(fixer *Fixer) error { + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 0}, End: hcl.Pos{Byte: 2}}, "##") + }, + want: map[string]string{ + "main.tf": "## comment", + }, + errCheck: neverHappend, + }, + { + name: "shift left", + sources: map[string]string{ + "main.tf": "// comment", + }, + fix: func(fixer *Fixer) error { + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 0}, End: hcl.Pos{Byte: 2}}, "#") + }, + want: map[string]string{ + "main.tf": "# comment", + }, + errCheck: neverHappend, + }, + { + name: "shift right", + sources: map[string]string{ + "main.tf": "# comment", + }, + fix: func(fixer *Fixer) error { + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 0}, End: hcl.Pos{Byte: 1}}, "//") + }, + want: map[string]string{ + "main.tf": "// comment", + }, + errCheck: neverHappend, + }, + { + name: "no shift + shift left", + sources: map[string]string{ + "main.tf": ` +// comment +// comment2`, + }, + fix: func(fixer *Fixer) error { + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 3}}, "##") + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 12}, End: hcl.Pos{Byte: 14}}, "#") + }, + want: map[string]string{ + "main.tf": ` +## comment +# comment2`, + }, + errCheck: neverHappend, + }, + { + name: "no shift + shift right", + sources: map[string]string{ + "main.tf": ` +## comment +# comment2`, + }, + fix: func(fixer *Fixer) error { + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 3}}, "//") + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 12}, End: hcl.Pos{Byte: 13}}, "//") + }, + want: map[string]string{ + "main.tf": ` +// comment +// comment2`, + }, + errCheck: neverHappend, + }, + { + name: "shift left + shift left", + sources: map[string]string{ + "main.tf": ` +// comment +// comment2`, + }, + fix: func(fixer *Fixer) error { + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 3}}, "#") + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 12}, End: hcl.Pos{Byte: 14}}, "#") + }, + want: map[string]string{ + "main.tf": ` +# comment +# comment2`, + }, + errCheck: neverHappend, + }, + { + name: "shift left + shift right", + sources: map[string]string{ + "main.tf": ` +// comment +# comment2`, + }, + fix: func(fixer *Fixer) error { + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 3}}, "#") + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 12}, End: hcl.Pos{Byte: 13}}, "//") + }, + want: map[string]string{ + "main.tf": ` +# comment +// comment2`, + }, + errCheck: neverHappend, + }, + { + name: "shift right + shift left", + sources: map[string]string{ + "main.tf": ` +# comment +// comment2`, + }, + fix: func(fixer *Fixer) error { + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 2}}, "//") + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 11}, End: hcl.Pos{Byte: 13}}, "#") + }, + want: map[string]string{ + "main.tf": ` +// comment +# comment2`, + }, + errCheck: neverHappend, + }, + { + name: "shift right + shift right", + sources: map[string]string{ + "main.tf": ` +# comment +# comment2`, + }, + fix: func(fixer *Fixer) error { + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 2}}, "//") + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 11}, End: hcl.Pos{Byte: 12}}, "//") + }, + want: map[string]string{ + "main.tf": ` +// comment +// comment2`, + }, + errCheck: neverHappend, + }, + { + name: "shift left + shift left + shift left", + sources: map[string]string{ + "main.tf": ` +// comment +// comment2 +// comment3`, + }, + fix: func(fixer *Fixer) error { + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 3}}, "#") + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 12}, End: hcl.Pos{Byte: 14}}, "#") + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 24}, End: hcl.Pos{Byte: 26}}, "#") + }, + want: map[string]string{ + "main.tf": ` +# comment +# comment2 +# comment3`, + }, + errCheck: neverHappend, + }, + { + name: "shift left + shift left + shift right", + sources: map[string]string{ + "main.tf": ` +// comment +// comment2 +# comment3`, + }, + fix: func(fixer *Fixer) error { + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 3}}, "#") + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 12}, End: hcl.Pos{Byte: 14}}, "#") + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 24}, End: hcl.Pos{Byte: 25}}, "//") + }, + want: map[string]string{ + "main.tf": ` +# comment +# comment2 +// comment3`, + }, + errCheck: neverHappend, + }, + { + name: "shift left + shift right + shift left", + sources: map[string]string{ + "main.tf": ` +// comment +# comment2 +// comment3`, + }, + fix: func(fixer *Fixer) error { + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 3}}, "#") + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 12}, End: hcl.Pos{Byte: 13}}, "//") + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 23}, End: hcl.Pos{Byte: 25}}, "#") + }, + want: map[string]string{ + "main.tf": ` +# comment +// comment2 +# comment3`, + }, + errCheck: neverHappend, + }, + { + name: "shift left + shift right + shift right", + sources: map[string]string{ + "main.tf": ` +// comment +# comment2 +# comment3`, + }, + fix: func(fixer *Fixer) error { + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 3}}, "#") + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 12}, End: hcl.Pos{Byte: 13}}, "//") + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 23}, End: hcl.Pos{Byte: 24}}, "//") + }, + want: map[string]string{ + "main.tf": ` +# comment +// comment2 +// comment3`, + }, + errCheck: neverHappend, + }, + { + name: "shift right + shift left + shift left", + sources: map[string]string{ + "main.tf": ` +# comment +// comment2 +// comment3`, + }, + fix: func(fixer *Fixer) error { + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 2}}, "//") + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 11}, End: hcl.Pos{Byte: 13}}, "#") + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 23}, End: hcl.Pos{Byte: 25}}, "#") + }, + want: map[string]string{ + "main.tf": ` +// comment +# comment2 +# comment3`, + }, + errCheck: neverHappend, + }, + { + name: "shift right + shift left + shift right", + sources: map[string]string{ + "main.tf": ` +# comment +// comment2 +# comment3`, + }, + fix: func(fixer *Fixer) error { + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 2}}, "//") + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 11}, End: hcl.Pos{Byte: 13}}, "#") + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 23}, End: hcl.Pos{Byte: 24}}, "//") + }, + want: map[string]string{ + "main.tf": ` +// comment +# comment2 +// comment3`, + }, + errCheck: neverHappend, + }, + { + name: "shift right + shift right + shift left", + sources: map[string]string{ + "main.tf": ` +# comment +# comment2 +// comment3`, + }, + fix: func(fixer *Fixer) error { + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 2}}, "//") + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 11}, End: hcl.Pos{Byte: 12}}, "//") + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 22}, End: hcl.Pos{Byte: 24}}, "#") + }, + want: map[string]string{ + "main.tf": ` +// comment +// comment2 +# comment3`, + }, + errCheck: neverHappend, + }, + { + name: "shift right + shift right + shift right", + sources: map[string]string{ + "main.tf": ` +# comment +# comment2 +# comment3`, + }, + fix: func(fixer *Fixer) error { + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 2}}, "//") + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 11}, End: hcl.Pos{Byte: 12}}, "//") + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 22}, End: hcl.Pos{Byte: 23}}, "//") + }, + want: map[string]string{ + "main.tf": ` +// comment +// comment2 +// comment3`, + }, + errCheck: neverHappend, + }, + { + name: "change order", + sources: map[string]string{ + "main.tf": ` +# comment +# comment2 +# comment3`, + }, + fix: func(fixer *Fixer) error { + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 11}, End: hcl.Pos{Byte: 12}}, "//") + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 2}}, "//") + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 22}, End: hcl.Pos{Byte: 23}}, "//") + }, + want: map[string]string{ + "main.tf": ` +// comment +// comment2 +// comment3`, + }, + errCheck: neverHappend, + }, + { + name: "shift left (boundary)", + sources: map[string]string{ + "main.tf": `"Hellooo, world!"`, + }, + fix: func(fixer *Fixer) error { + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 8}}, "Hello") + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 8}, End: hcl.Pos{Byte: 16}}, ", you and world!") + }, + want: map[string]string{ + "main.tf": `"Hello, you and world!"`, + }, + errCheck: neverHappend, + }, + { + name: "shift right (boundary)", + sources: map[string]string{ + "main.tf": `"Hello, world!"`, + }, + fix: func(fixer *Fixer) error { + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 6}}, "Hellooo") + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 6}, End: hcl.Pos{Byte: 14}}, ", you and world!") + }, + want: map[string]string{ + "main.tf": `"Hellooo, you and world!"`, + }, + errCheck: neverHappend, + }, + { + name: "overlapping", + sources: map[string]string{ + "main.tf": `"Hello, world!"`, + }, + fix: func(fixer *Fixer) error { + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 8}}, "Hellooo, ") + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 6}, End: hcl.Pos{Byte: 14}}, ", you and world!") + }, + want: map[string]string{ + "main.tf": `"Hellooo, world!"`, + }, + errCheck: func(err error) bool { + return err == nil || err.Error() != "range overlaps with a previous rewrite range: main.tf:0,0-0" + }, + }, + { + name: "same range", + sources: map[string]string{ + "main.tf": `"Hello, world!"`, + }, + fix: func(fixer *Fixer) error { + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 6}}, "hello") + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 6}}, "HELLO") + }, + want: map[string]string{ + "main.tf": `"HELLO, world!"`, + }, + errCheck: neverHappend, + }, + { + name: "same range (shift left)", + sources: map[string]string{ + "main.tf": `"Hellooo, world!"`, + }, + fix: func(fixer *Fixer) error { + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 8}}, "hello") + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 8}}, "HELLO") + }, + want: map[string]string{ + "main.tf": `"HELLO, world!"`, + }, + errCheck: neverHappend, + }, + { + name: "same range (shift right)", + sources: map[string]string{ + "main.tf": `"Hello, world!"`, + }, + fix: func(fixer *Fixer) error { + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 6}}, "hellooo") + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 6}}, "HELLOOO") + }, + want: map[string]string{ + "main.tf": `"HELLOOO, world!"`, + }, + errCheck: neverHappend, + }, + { + name: "shift after same range", + sources: map[string]string{ + "main.tf": `"Hello, world!"`, + }, + fix: func(fixer *Fixer) error { + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 6}}, "hellooo") + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 6}}, "HELLOOO") + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 6}, End: hcl.Pos{Byte: 14}}, ", you and world!") + }, + want: map[string]string{ + "main.tf": `"HELLOOO, you and world!"`, + }, + errCheck: neverHappend, + }, + { + name: "same range after shift", + sources: map[string]string{ + "main.tf": `"Hello, world!"`, + }, + fix: func(fixer *Fixer) error { + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 6}}, "hellooo") + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 8}, End: hcl.Pos{Byte: 13}}, "wooorld") + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 6}}, "Hellooo") + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 8}, End: hcl.Pos{Byte: 13}}, "Wooorld") + }, + want: map[string]string{ + "main.tf": `"Hellooo, Wooorld!"`, + }, + errCheck: neverHappend, + }, + { + name: "multibyte", + sources: map[string]string{ + "main.tf": `"Hello, world!"`, + }, + fix: func(fixer *Fixer) error { + fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 6}}, "こんにちは") + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 8}, End: hcl.Pos{Byte: 13}}, "世界") + }, + want: map[string]string{ + "main.tf": `"こんにちは, 世界!"`, + }, + errCheck: neverHappend, + }, + { + name: "file not found", + sources: map[string]string{ + "main.tf": `"Hello, world!"`, + }, + fix: func(fixer *Fixer) error { + return fixer.ReplaceText(hcl.Range{Filename: "template.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 6}}, "hello") + }, + want: map[string]string{}, + errCheck: func(err error) bool { + return err == nil || err.Error() != "file not found: template.tf" + }, + }, + { + name: "multiple string literals", + sources: map[string]string{ + "main.tf": `(foo)(bar)`, + }, + fix: func(fixer *Fixer) error { + return fixer.ReplaceText( + hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 0}, End: hcl.Pos{Byte: 10}}, + "[", + "foo", + "]", + "[", + "bar", + "]", + ) + }, + want: map[string]string{ + "main.tf": `[foo][bar]`, + }, + errCheck: neverHappend, + }, + { + name: "literals with text nodes", + sources: map[string]string{ + "main.tf": `(foo)(bar)`, + }, + fix: func(fixer *Fixer) error { + if err := fixer.ReplaceText( + hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 0}, End: hcl.Pos{Byte: 10}}, + "[", + TextNode{Bytes: []byte("foo"), Range: hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 4}}}, + "]", + "[", + TextNode{Bytes: []byte("bar"), Range: hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 6}, End: hcl.Pos{Byte: 9}}}, + "]", + ); err != nil { + return err + } + // The replacement is not overlapped because the "foo" is not replaced in the previous replacement. + if err := fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 4}}, "bar"); err != nil { + return err + } + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 6}, End: hcl.Pos{Byte: 9}}, "baz") + }, + want: map[string]string{ + "main.tf": `[bar][baz]`, + }, + errCheck: neverHappend, + }, + { + name: "only text nodes", + sources: map[string]string{ + "main.tf": `(foo)(bar)`, + }, + fix: func(fixer *Fixer) error { + if err := fixer.ReplaceText( + hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 0}, End: hcl.Pos{Byte: 10}}, + TextNode{Bytes: []byte("foo"), Range: hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 4}}}, + TextNode{Bytes: []byte("bar"), Range: hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 6}, End: hcl.Pos{Byte: 9}}}, + ); err != nil { + return err + } + // The replacement is not overlapped because the "foo" is not replaced in the previous replacement. + if err := fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 4}}, "bar"); err != nil { + return err + } + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 6}, End: hcl.Pos{Byte: 9}}, "baz") + }, + want: map[string]string{ + "main.tf": `barbaz`, + }, + errCheck: neverHappend, + }, + { + name: "unordered text nodes", + sources: map[string]string{ + "main.tf": `(foo)(bar)`, + }, + fix: func(fixer *Fixer) error { + if err := fixer.ReplaceText( + hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 0}, End: hcl.Pos{Byte: 10}}, + "[", + TextNode{Bytes: []byte("bar"), Range: hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 6}, End: hcl.Pos{Byte: 9}}}, + "]", + "[", + TextNode{Bytes: []byte("foo"), Range: hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 4}}}, + "]", + ); err != nil { + return err + } + // The replacement is not overlapped because the "bar" is not replaced in the previous replacement. + if err := fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 6}, End: hcl.Pos{Byte: 9}}, "baz"); err != nil { + return err + } + // The replacement is overlapped because the "foo" is replaced in the previous replacement. + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 4}}, "bar") + }, + want: map[string]string{ + "main.tf": `[baz][foo]`, + }, + errCheck: func(err error) bool { + return err == nil || err.Error() != "range overlaps with a previous rewrite range: main.tf:0,0-0" + }, + }, + { + name: "out of range text node", + sources: map[string]string{ + "main.tf": `foo`, + }, + fix: func(fixer *Fixer) error { + return fixer.ReplaceText( + hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 0}, End: hcl.Pos{Byte: 3}}, + TextNode{Bytes: []byte("baz"), Range: hcl.Range{Filename: "template.tf", Start: hcl.Pos{Byte: 0}, End: hcl.Pos{Byte: 3}}}, + ) + }, + want: map[string]string{ + "main.tf": `baz`, + }, + errCheck: neverHappend, + }, + { + name: "text node with the same range", + sources: map[string]string{ + "main.tf": `foo`, + }, + fix: func(fixer *Fixer) error { + return fixer.ReplaceText( + hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 0}, End: hcl.Pos{Byte: 3}}, + TextNode{Bytes: []byte("foo"), Range: hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 0}, End: hcl.Pos{Byte: 3}}}, + ) + }, + want: map[string]string{}, + errCheck: neverHappend, + }, + } + + for _, test := range tests { + t.Run(test.name, func(t *testing.T) { + input := map[string][]byte{} + for filename, source := range test.sources { + input[filename] = []byte(source) + } + fixer := NewFixer(input) + + err := test.fix(fixer) + if test.errCheck(err) { + t.Fatalf("failed to check error: %s", err) + } + + changes := map[string]string{} + for filename, source := range fixer.changes { + changes[filename] = string(source) + } + if diff := cmp.Diff(test.want, changes); diff != "" { + t.Errorf(diff) + } + }) + } +} + +func TestRemove(t *testing.T) { + // default error check helper + neverHappend := func(err error) bool { return err != nil } + + tests := []struct { + name string + sources map[string]string + fix func(*Fixer) error + want map[string]string + errCheck func(error) bool + }{ + { + name: "remove", + sources: map[string]string{ + "main.tf": `"Hello, world!"`, + }, + fix: func(fixer *Fixer) error { + return fixer.Remove(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 6}, End: hcl.Pos{Byte: 14}}) + }, + want: map[string]string{ + "main.tf": `"Hello"`, + }, + errCheck: neverHappend, + }, + { + name: "remove and shift", + sources: map[string]string{ + "main.tf": `"Hello, world!"`, + }, + fix: func(fixer *Fixer) error { + fixer.Remove(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 1}, End: hcl.Pos{Byte: 8}}) + return fixer.ReplaceText(hcl.Range{Filename: "main.tf", Start: hcl.Pos{Byte: 8}, End: hcl.Pos{Byte: 14}}, "WORLD!!") + }, + want: map[string]string{ + "main.tf": `"WORLD!!"`, + }, + errCheck: neverHappend, + }, + } + + for _, test := range tests { + t.Run(test.name, func(t *testing.T) { + input := map[string][]byte{} + for filename, source := range test.sources { + input[filename] = []byte(source) + } + fixer := NewFixer(input) + + err := test.fix(fixer) + if test.errCheck(err) { + t.Fatalf("failed to check error: %s", err) + } + + changes := map[string]string{} + for filename, source := range fixer.changes { + changes[filename] = string(source) + } + if diff := cmp.Diff(test.want, changes); diff != "" { + t.Errorf(diff) + } + }) + } +} + +func TestRemoveAttribute(t *testing.T) { + // default error check helper + neverHappend := func(err error) bool { return err != nil } + // helper to get "foo" attribute in locals + getFooAttributeInLocals := func(body hcl.Body) (*hcl.Attribute, hcl.Diagnostics) { + content, _, diags := body.PartialContent(&hcl.BodySchema{ + Blocks: []hcl.BlockHeaderSchema{{Type: "locals"}}, + }) + if diags.HasErrors() { + return nil, diags + } + attributes, diags := content.Blocks[0].Body.JustAttributes() + if diags.HasErrors() { + return nil, diags + } + return attributes["foo"], nil + } + + tests := []struct { + name string + source string + getAttr func(hcl.Body) (*hcl.Attribute, hcl.Diagnostics) + want string + errCheck func(error) bool + }{ + { + name: "remove attribute", + source: `foo = 1`, + getAttr: func(body hcl.Body) (*hcl.Attribute, hcl.Diagnostics) { + attributes, diags := body.JustAttributes() + if diags.HasErrors() { + return nil, diags + } + return attributes["foo"], nil + }, + want: ``, + errCheck: neverHappend, + }, + { + name: "remove attribute within block", + source: ` +locals { + foo = 1 +}`, + getAttr: getFooAttributeInLocals, + want: ` +locals { +}`, + errCheck: neverHappend, + }, + { + name: "remove attribute with trailing comment", + source: ` +locals { + foo = 1 # comment +}`, + getAttr: getFooAttributeInLocals, + want: ` +locals { +}`, + errCheck: neverHappend, + }, + { + name: "remove attribute with trailing legacy comment", + source: ` +locals { + foo = 1 // comment +}`, + getAttr: getFooAttributeInLocals, + want: ` +locals { +}`, + errCheck: neverHappend, + }, + { + name: "remove attribute with trailing multiline comment", + source: ` +locals { + foo = 1 /* comment */ +}`, + getAttr: getFooAttributeInLocals, + want: ` +locals { +}`, + errCheck: neverHappend, + }, + { + name: "remove attribute with next line comment", + source: ` +locals { + foo = 1 + # comment +}`, + getAttr: getFooAttributeInLocals, + want: ` +locals { + # comment +}`, + errCheck: neverHappend, + }, + { + name: "remove attribute with prefix comment", + source: ` +locals { +/* comment */ foo = 1 +}`, + getAttr: getFooAttributeInLocals, + want: ` +locals { +}`, + errCheck: neverHappend, + }, + { + name: "remove attribute with previous line comment", + source: ` +locals { + # comment + foo = 1 +}`, + getAttr: getFooAttributeInLocals, + want: ` +locals { +}`, + errCheck: neverHappend, + }, + { + name: "remove attribute with previous multiple line comments", + source: ` +locals { + # comment + # comment + foo = 1 +}`, + getAttr: getFooAttributeInLocals, + want: ` +locals { +}`, + errCheck: neverHappend, + }, + { + name: "remove attribute with previous multiline comment", + source: ` +locals { + /* comment */ + foo = 1 +}`, + getAttr: getFooAttributeInLocals, + // This is the same behavior as hclwrite.RemoveAttribute. + want: ` +locals { + /* comment */ +}`, + errCheck: neverHappend, + }, + { + name: "remove attribute after attribute with trailing comment", + source: ` +locals { + bar = 1 # comment + foo = 1 +}`, + getAttr: getFooAttributeInLocals, + want: ` +locals { + bar = 1 # comment +}`, + errCheck: neverHappend, + }, + { + name: "remove attribute within inline block", + source: `locals { foo = 1 }`, + getAttr: getFooAttributeInLocals, + want: `locals {}`, + errCheck: neverHappend, + }, + { + name: "remove attribute in the middle of attributes", + source: ` +locals { + bar = 1 + foo = 1 + baz = 1 +}`, + getAttr: getFooAttributeInLocals, + want: ` +locals { + bar = 1 + baz = 1 +}`, + errCheck: neverHappend, + }, + } + + for _, test := range tests { + t.Run(test.name, func(t *testing.T) { + file, diags := hclsyntax.ParseConfig([]byte(test.source), "main.tf", hcl.InitialPos) + if diags.HasErrors() { + t.Fatalf("failed to parse HCL: %s", diags) + } + attr, diags := test.getAttr(file.Body) + if diags.HasErrors() { + t.Fatalf("failed to get attribute: %s", diags) + } + + fixer := NewFixer(map[string][]byte{"main.tf": []byte(test.source)}) + + err := fixer.RemoveAttribute(attr) + if test.errCheck(err) { + t.Fatalf("failed to check error: %s", err) + } + + if diff := cmp.Diff(test.want, string(fixer.changes["main.tf"])); diff != "" { + t.Errorf(diff) + } + }) + } +} + +func TestRemoveBlock(t *testing.T) { + // default error check helper + neverHappend := func(err error) bool { return err != nil } + // getFirstBlock returns the first block in the given body. + getFirstBlock := func(body hcl.Body) (*hcl.Block, hcl.Diagnostics) { + content, _, diags := body.PartialContent(&hcl.BodySchema{ + Blocks: []hcl.BlockHeaderSchema{{Type: "block"}}, + }) + if diags.HasErrors() { + return nil, diags + } + return content.Blocks[0], nil + } + // getNestedBlock returns the nested block in the given body. + getNestedBlock := func(body hcl.Body) (*hcl.Block, hcl.Diagnostics) { + content, _, diags := body.PartialContent(&hcl.BodySchema{ + Blocks: []hcl.BlockHeaderSchema{{Type: "block"}}, + }) + if diags.HasErrors() { + return nil, diags + } + content, _, diags = content.Blocks[0].Body.PartialContent(&hcl.BodySchema{ + Blocks: []hcl.BlockHeaderSchema{{Type: "nested"}}, + }) + if diags.HasErrors() { + return nil, diags + } + return content.Blocks[0], nil + } + + tests := []struct { + name string + source string + getBlock func(hcl.Body) (*hcl.Block, hcl.Diagnostics) + want string + errCheck func(error) bool + }{ + { + name: "remove inline block", + source: `block { foo = 1 }`, + getBlock: getFirstBlock, + want: ``, + errCheck: neverHappend, + }, + { + name: "remove block", + source: ` +block { + foo = 1 +}`, + getBlock: getFirstBlock, + want: ` +`, + errCheck: neverHappend, + }, + { + name: "remove block with comment", + source: ` +# comment +block { + foo = 1 +}`, + getBlock: getFirstBlock, + want: ` +`, + errCheck: neverHappend, + }, + { + name: "remove block with multiple comments", + source: ` +# comment +# comment +block { + foo = 1 +}`, + getBlock: getFirstBlock, + want: ` +`, + errCheck: neverHappend, + }, + { + name: "remove block with multi-line comment", + source: ` +/* comment */ +block { + foo = 1 +}`, + getBlock: getFirstBlock, + // This is the same behavior as hclwrite.RemoveBlock. + want: ` +/* comment */ +`, + errCheck: neverHappend, + }, + { + name: "remove block after attribute", + source: ` +bar = 1 +block { + foo = 1 +}`, + getBlock: getFirstBlock, + want: ` +bar = 1 +`, + errCheck: neverHappend, + }, + { + name: "remove block after attribute and newline", + source: ` +bar = 1 + +block { + foo = 1 +}`, + getBlock: getFirstBlock, + want: ` +bar = 1 + +`, + errCheck: neverHappend, + }, + { + name: "remove block after attribute with trailing comment", + source: ` +bar = 1 # comment +block { + foo = 1 +}`, + getBlock: getFirstBlock, + want: ` +bar = 1 # comment +`, + errCheck: neverHappend, + }, + { + name: "remove inline block after attribute", + source: ` +bar = 1 +block { foo = 1 }`, + getBlock: getFirstBlock, + want: ` +bar = 1 +`, + errCheck: neverHappend, + }, + { + name: "remove nested block", + source: ` +block { + nested { + foo = 1 + } +}`, + getBlock: getNestedBlock, + want: ` +block { +}`, + errCheck: neverHappend, + }, + { + name: "remove nested inline block", + source: ` +block { + nested { foo = 1 } +}`, + getBlock: getNestedBlock, + want: ` +block { +}`, + errCheck: neverHappend, + }, + { + name: "remove block with traling comment", + source: ` +block { + foo = 1 +} # comment`, + getBlock: getFirstBlock, + want: ` +`, + errCheck: neverHappend, + }, + { + name: "remove block with next line comment", + source: ` +block { + foo = 1 +} +# comment`, + getBlock: getFirstBlock, + want: ` +# comment`, + errCheck: neverHappend, + }, + { + name: "remove block in the middle", + source: ` +foo = 1 + +block { + foo = 1 +} + +baz = 1`, + getBlock: getFirstBlock, + want: ` +foo = 1 + +baz = 1`, + errCheck: neverHappend, + }, + } + + for _, test := range tests { + t.Run(test.name, func(t *testing.T) { + file, diags := hclsyntax.ParseConfig([]byte(test.source), "main.tf", hcl.InitialPos) + if diags.HasErrors() { + t.Fatalf("failed to parse HCL: %s", diags) + } + block, diags := test.getBlock(file.Body) + if diags.HasErrors() { + t.Fatalf("failed to get block: %s", diags) + } + + fixer := NewFixer(map[string][]byte{"main.tf": []byte(test.source)}) + + err := fixer.RemoveBlock(block) + if test.errCheck(err) { + t.Fatalf("failed to check error: %s", err) + } + + if diff := cmp.Diff(test.want, string(fixer.changes["main.tf"])); diff != "" { + t.Errorf(diff) + } + }) + } +} + +func TestRemoveExtBlock(t *testing.T) { + // default error check helper + neverHappend := func(err error) bool { return err != nil } + // getFirstBlock returns the first block in the given body. + getFirstBlock := func(body hcl.Body) (*hclext.Block, hcl.Diagnostics) { + content, diags := hclext.PartialContent(body, &hclext.BodySchema{ + Blocks: []hclext.BlockSchema{{Type: "block"}}, + }) + if diags.HasErrors() { + return nil, diags + } + return content.Blocks[0], nil + } + + tests := []struct { + name string + source string + getBlock func(hcl.Body) (*hclext.Block, hcl.Diagnostics) + want string + errCheck func(error) bool + }{ + { + name: "remove block", + source: ` +block { + foo = 1 +}`, + getBlock: getFirstBlock, + want: ` +`, + errCheck: neverHappend, + }, + } + + for _, test := range tests { + t.Run(test.name, func(t *testing.T) { + file, diags := hclsyntax.ParseConfig([]byte(test.source), "main.tf", hcl.InitialPos) + if diags.HasErrors() { + t.Fatalf("failed to parse HCL: %s", diags) + } + block, diags := test.getBlock(file.Body) + if diags.HasErrors() { + t.Fatalf("failed to get block: %s", diags) + } + + fixer := NewFixer(map[string][]byte{"main.tf": []byte(test.source)}) + + err := fixer.RemoveExtBlock(block) + if test.errCheck(err) { + t.Fatalf("failed to check error: %s", err) + } + + if diff := cmp.Diff(test.want, string(fixer.changes["main.tf"])); diff != "" { + t.Errorf(diff) + } + }) + } +} + +func TestRangeTo(t *testing.T) { + start := hcl.Pos{Byte: 10, Line: 2, Column: 1} + + tests := []struct { + name string + to string + want hcl.Range + }{ + { + name: "empty", + to: "", + want: hcl.Range{Start: start, End: start}, + }, + { + name: "single line", + to: "foo", + want: hcl.Range{Start: start, End: hcl.Pos{Byte: 13, Line: 2, Column: 4}}, + }, + { + name: "trailing new line", + to: "foo\n", + want: hcl.Range{Start: start, End: hcl.Pos{Byte: 13, Line: 2, Column: 4}}, + }, + { + name: "multi new line", + to: "foo\nbar", + want: hcl.Range{Start: start, End: hcl.Pos{Byte: 17, Line: 3, Column: 4}}, + }, + { + name: "multibytes", + to: "こんにちは世界", + want: hcl.Range{Start: start, End: hcl.Pos{Byte: 31, Line: 2, Column: 8}}, + }, + } + + for _, test := range tests { + t.Run(test.name, func(t *testing.T) { + fixer := NewFixer(nil) + + got := fixer.RangeTo(test.to, "", start) + if diff := cmp.Diff(test.want, got); diff != "" { + t.Errorf(diff) + } + }) + } +} diff --git a/tflint/interface.go b/tflint/interface.go index 6113979..a226cd8 100644 --- a/tflint/interface.go +++ b/tflint/interface.go @@ -72,6 +72,8 @@ type RuleSet interface { // This is not supposed to be overridden from custom rulesets. Check(Runner) error + FixEnabled() bool + // All Ruleset must embed the builtin ruleset. mustEmbedBuiltinRuleSet() } @@ -227,11 +229,16 @@ type Runner interface { // EmitIssue sends an issue to TFLint. You need to pass the message of the issue and the range. EmitIssue(rule Rule, message string, issueRange hcl.Range) error + EmitIssueWithFix(rule Rule, message string, issueRange hcl.Range, fixFunc func(f *Fixer) error) error + // EnsureNoError is a helper for error handling. Depending on the type of error generated by EvaluateExpr, // determine whether to exit, skip, or continue. If it is continued, the passed function will be executed. // // Deprecated: Use EvaluateExpr with a function callback. e.g. EvaluateExpr(expr, func (val T) error {}, ...) EnsureNoError(error, func() error) error + + HasChanges() bool + ApplyChanges() error } // Rule is the interface that the plugin's rules should satisfy. diff --git a/tflint/ruleset.go b/tflint/ruleset.go index abeea6e..f14c4f2 100644 --- a/tflint/ruleset.go +++ b/tflint/ruleset.go @@ -18,6 +18,7 @@ type BuiltinRuleSet struct { Rules []Rule EnabledRules []Rule + Fix bool } // RuleSetName is the name of the ruleset. @@ -57,6 +58,7 @@ func (r *BuiltinRuleSet) VersionConstraint() string { // 3. The `disabled_by_default` declared in global "config" block func (r *BuiltinRuleSet) ApplyGlobalConfig(config *Config) error { r.EnabledRules = []Rule{} + r.Fix = config.Fix only := map[string]bool{} if len(config.Only) > 0 { @@ -110,8 +112,18 @@ func (r *BuiltinRuleSet) Check(runner Runner) error { if err := rule.Check(runner); err != nil { return fmt.Errorf("Failed to check `%s` rule: %s", rule.Name(), err) } + if runner.HasChanges() { + if err := runner.ApplyChanges(); err != nil { + return fmt.Errorf("Failed to apply fixes by `%s` rule: %s", rule.Name(), err) + } + } } return nil } +// FixEnabled returns whether the autofix is enabled. +func (r *BuiltinRuleSet) FixEnabled() bool { + return r.Fix +} + func (r *BuiltinRuleSet) mustEmbedBuiltinRuleSet() {} diff --git a/tflint/token_scanner.go b/tflint/token_scanner.go new file mode 100644 index 0000000..6a29278 --- /dev/null +++ b/tflint/token_scanner.go @@ -0,0 +1,159 @@ +package tflint + +import ( + "fmt" + + "github.com/hashicorp/hcl/v2" + "github.com/hashicorp/hcl/v2/hclsyntax" +) + +// tokenScanner is a token-based scanner for HCL. +// The scanner scans tokens one by one and returns its position and token details. +type tokenScanner struct { + tokens hclsyntax.Tokens + pos hcl.Pos + index int + filename string +} + +func newTokenScanner(source []byte, filename string) (*tokenScanner, hcl.Diagnostics) { + tokens, diags := hclsyntax.LexConfig(source, filename, hcl.InitialPos) + if diags.HasErrors() { + return nil, diags + } + return &tokenScanner{ + tokens: tokens, + pos: hcl.InitialPos, + index: 0, + filename: filename, + }, nil +} + +type tokenPos int + +const ( + tokenStart tokenPos = iota + tokenEnd +) + +// seek moves the currnet position to the given position. +// The destination token is determined by the given match condtion. +// +// match tokenStart: +// +// | <- pos +// foo=1 +// |-| token is "=" +// +// match tokenEnd: +// +// | <- pos +// foo=1 +// |-| token is "foo" +func (s *tokenScanner) seek(to hcl.Pos, match tokenPos) error { + switch { + case s.tokenPos(match).Byte == to.Byte: + return nil + case to.Byte < s.tokenPos(match).Byte: + for s.scanBackward() { + if to.Byte == s.tokenPos(match).Byte { + s.pos = to + return nil + } + } + case s.tokenPos(match).Byte < to.Byte: + for s.scan() { + if s.tokenPos(match).Byte == to.Byte { + s.pos = to + return nil + } + } + default: + panic("unreachable") + } + + return fmt.Errorf("no token found at %s:%d,%d", s.filename, to.Line, to.Column) +} + +func (s *tokenScanner) seekByIndex(idx int, pos tokenPos) error { + if idx < 0 || len(s.tokens) <= idx { + return fmt.Errorf("index out of range: %d", idx) + } + s.index = idx + s.pos = s.tokenPos(pos) + return nil +} + +// seekTokenStart moves the current position to the start of the current token. +func (s *tokenScanner) seekTokenStart() { + s.pos = s.token().Range.Start +} + +func (s *tokenScanner) seekTokenEnd() { + s.pos = s.token().Range.End +} + +// scan moves the current position to the next token. +// position is always set to the end of the token. +func (s *tokenScanner) scan() bool { + i := s.index + 1 + if i >= len(s.tokens) { + s.seekTokenEnd() + return false + } + s.index = i + s.seekTokenEnd() + return true +} + +func (s *tokenScanner) scanIf(tokenType hclsyntax.TokenType) bool { + i := s.index + 1 + if i >= len(s.tokens) { + return false + } + if s.tokens[i].Type != tokenType { + return false + } + s.scan() + return true +} + +// scanBackward moves the current position to the previous token. +// position is always set to the start of the token. +func (s *tokenScanner) scanBackward() bool { + i := s.index - 1 + if i < 0 { + s.seekTokenStart() + return false + } + s.index = i + s.seekTokenStart() + return true +} + +func (s *tokenScanner) scanBackwardIf(tokenType hclsyntax.TokenType) bool { + i := s.index - 1 + if i < 0 { + return false + } + if s.tokens[i].Type != tokenType { + return false + } + s.scanBackward() + return true +} + +func (s *tokenScanner) token() hclsyntax.Token { + return s.tokens[s.index] +} + +func (s *tokenScanner) tokenPos(pos tokenPos) hcl.Pos { + switch pos { + case tokenStart: + return s.token().Range.Start + case tokenEnd: + return s.token().Range.End + default: + panic("unreachable") + } +} diff --git a/tflint/token_scanner_test.go b/tflint/token_scanner_test.go new file mode 100644 index 0000000..81c60d5 --- /dev/null +++ b/tflint/token_scanner_test.go @@ -0,0 +1,359 @@ +package tflint + +import ( + "testing" + + "github.com/google/go-cmp/cmp" + "github.com/google/go-cmp/cmp/cmpopts" + "github.com/hashicorp/hcl/v2" + "github.com/hashicorp/hcl/v2/hclsyntax" +) + +func TestSeek(t *testing.T) { + tests := []struct { + name string + source string + seek func(*tokenScanner) error + wantPos hcl.Pos + wantToken hclsyntax.Token + }{ + { + name: "seek to initial position", + source: `foo = 1`, + seek: func(s *tokenScanner) error { + return s.seek(hcl.InitialPos, tokenStart) + }, + wantPos: hcl.InitialPos, + wantToken: hclsyntax.Token{ + Type: hclsyntax.TokenIdent, + Bytes: []byte("foo"), + }, + }, + { + name: "seek to forward with tokenStart", + source: `foo = 1`, + seek: func(s *tokenScanner) error { + return s.seek(hcl.Pos{Line: 1, Column: 7, Byte: 6}, tokenStart) + }, + wantPos: hcl.Pos{Line: 1, Column: 7, Byte: 6}, + wantToken: hclsyntax.Token{ + Type: hclsyntax.TokenNumberLit, + Bytes: []byte("1"), + }, + }, + { + name: "seek to forward with tokenEnd", + source: `foo = 1`, + seek: func(s *tokenScanner) error { + return s.seek(hcl.Pos{Line: 1, Column: 8, Byte: 7}, tokenEnd) + }, + wantPos: hcl.Pos{Line: 1, Column: 8, Byte: 7}, + wantToken: hclsyntax.Token{ + Type: hclsyntax.TokenNumberLit, + Bytes: []byte("1"), + }, + }, + { + name: "seek to backward with tokenStart", + source: `foo = 1`, + seek: func(s *tokenScanner) error { + s.seek(hcl.Pos{Line: 1, Column: 7, Byte: 6}, tokenStart) + return s.seek(hcl.Pos{Line: 1, Column: 5, Byte: 4}, tokenStart) + }, + wantPos: hcl.Pos{Line: 1, Column: 5, Byte: 4}, + wantToken: hclsyntax.Token{ + Type: hclsyntax.TokenEqual, + Bytes: []byte("="), + }, + }, + { + name: "seek to backward with tokenEnd", + source: `foo = 1`, + seek: func(s *tokenScanner) error { + s.seek(hcl.Pos{Line: 1, Column: 7, Byte: 6}, tokenStart) + return s.seek(hcl.Pos{Line: 1, Column: 6, Byte: 5}, tokenEnd) + }, + wantPos: hcl.Pos{Line: 1, Column: 6, Byte: 5}, + wantToken: hclsyntax.Token{ + Type: hclsyntax.TokenEqual, + Bytes: []byte("="), + }, + }, + } + + for _, test := range tests { + t.Run(test.name, func(t *testing.T) { + scanner, diags := newTokenScanner([]byte(test.source), "main.tf") + if diags.HasErrors() { + t.Fatalf("failed to set up token scanner: %s", diags) + } + if err := test.seek(scanner); err != nil { + t.Fatalf("failed to seek: %s", err) + } + + if diff := cmp.Diff(test.wantPos, scanner.pos); diff != "" { + t.Errorf("position mismatch: %s", diff) + } + opt := cmpopts.IgnoreFields(hclsyntax.Token{}, "Range") + if diff := cmp.Diff(test.wantToken, scanner.token(), opt); diff != "" { + t.Errorf("token mismatch: %s", diff) + } + }) + } +} + +func TestScan(t *testing.T) { + type scanResult struct { + Pos hcl.Pos + Token hclsyntax.Token + } + + tests := []struct { + name string + source string + seek func(*tokenScanner) error + scanResults []scanResult + want hcl.Pos + }{ + { + name: "scan all tokens", + source: `foo = 1`, + seek: func(s *tokenScanner) error { return nil }, + scanResults: []scanResult{ + { + Pos: hcl.Pos{Line: 1, Column: 6, Byte: 5}, + Token: hclsyntax.Token{ + Type: hclsyntax.TokenEqual, + Bytes: []byte("="), + }, + }, + { + Pos: hcl.Pos{Line: 1, Column: 8, Byte: 7}, + Token: hclsyntax.Token{ + Type: hclsyntax.TokenNumberLit, + Bytes: []byte("1"), + }, + }, + { + Pos: hcl.Pos{Line: 1, Column: 8, Byte: 7}, + Token: hclsyntax.Token{ + Type: hclsyntax.TokenEOF, + Bytes: []byte{}, + }, + }, + }, + want: hcl.Pos{Line: 1, Column: 8, Byte: 7}, + }, + { + name: "scan tokens from the middle", + source: `foo = 1`, + seek: func(s *tokenScanner) error { + return s.seek(hcl.Pos{Line: 1, Column: 5, Byte: 4}, tokenStart) + }, + scanResults: []scanResult{ + { + Pos: hcl.Pos{Line: 1, Column: 8, Byte: 7}, + Token: hclsyntax.Token{ + Type: hclsyntax.TokenNumberLit, + Bytes: []byte("1"), + }, + }, + { + Pos: hcl.Pos{Line: 1, Column: 8, Byte: 7}, + Token: hclsyntax.Token{ + Type: hclsyntax.TokenEOF, + Bytes: []byte{}, + }, + }, + }, + want: hcl.Pos{Line: 1, Column: 8, Byte: 7}, + }, + { + name: "scan tokens from tokenEnd", + source: `foo = 1`, + seek: func(s *tokenScanner) error { + return s.seek(hcl.Pos{Line: 1, Column: 6, Byte: 5}, tokenEnd) + }, + scanResults: []scanResult{ + { + Pos: hcl.Pos{Line: 1, Column: 8, Byte: 7}, + Token: hclsyntax.Token{ + Type: hclsyntax.TokenNumberLit, + Bytes: []byte("1"), + }, + }, + { + Pos: hcl.Pos{Line: 1, Column: 8, Byte: 7}, + Token: hclsyntax.Token{ + Type: hclsyntax.TokenEOF, + Bytes: []byte{}, + }, + }, + }, + want: hcl.Pos{Line: 1, Column: 8, Byte: 7}, + }, + { + name: "no scan", + source: `foo = 1`, + seek: func(s *tokenScanner) error { + return s.seek(hcl.Pos{Line: 1, Column: 8, Byte: 7}, tokenStart) + }, + scanResults: []scanResult{}, + want: hcl.Pos{Line: 1, Column: 8, Byte: 7}, + }, + } + + for _, test := range tests { + t.Run(test.name, func(t *testing.T) { + scanner, diags := newTokenScanner([]byte(test.source), "main.tf") + if diags.HasErrors() { + t.Fatalf("failed to set up token scanner: %s", diags) + } + if err := test.seek(scanner); err != nil { + t.Fatalf("failed to seek: %s", err) + } + + scanResults := []scanResult{} + for scanner.scan() { + scanResults = append(scanResults, scanResult{ + Pos: scanner.pos, + Token: scanner.token(), + }) + } + + opt := cmpopts.IgnoreFields(hclsyntax.Token{}, "Range") + if diff := cmp.Diff(test.scanResults, scanResults, opt); diff != "" { + t.Errorf("scan result mismatch: %s", diff) + } + if diff := cmp.Diff(test.want, scanner.pos); diff != "" { + t.Errorf("position mismatch: %s", diff) + } + }) + } +} + +func TestScanBackward(t *testing.T) { + type scanResult struct { + Pos hcl.Pos + Token hclsyntax.Token + } + + tests := []struct { + name string + source string + seek func(*tokenScanner) error + scanResults []scanResult + want hcl.Pos + }{ + { + name: "scan all tokens", + source: `foo = 1`, + seek: func(s *tokenScanner) error { + return s.seek(hcl.Pos{Line: 1, Column: 8, Byte: 7}, tokenStart) + }, + scanResults: []scanResult{ + { + Pos: hcl.Pos{Line: 1, Column: 7, Byte: 6}, + Token: hclsyntax.Token{ + Type: hclsyntax.TokenNumberLit, + Bytes: []byte("1"), + }, + }, + { + Pos: hcl.Pos{Line: 1, Column: 5, Byte: 4}, + Token: hclsyntax.Token{ + Type: hclsyntax.TokenEqual, + Bytes: []byte("="), + }, + }, + { + Pos: hcl.Pos{Line: 1, Column: 1, Byte: 0}, + Token: hclsyntax.Token{ + Type: hclsyntax.TokenIdent, + Bytes: []byte("foo"), + }, + }, + }, + want: hcl.Pos{Line: 1, Column: 1, Byte: 0}, + }, + { + name: "scan tokens from the middle", + source: `foo = 1`, + seek: func(s *tokenScanner) error { + return s.seek(hcl.Pos{Line: 1, Column: 6, Byte: 5}, tokenEnd) + }, + scanResults: []scanResult{ + { + Pos: hcl.Pos{Line: 1, Column: 1, Byte: 0}, + Token: hclsyntax.Token{ + Type: hclsyntax.TokenIdent, + Bytes: []byte("foo"), + }, + }, + }, + want: hcl.Pos{Line: 1, Column: 1, Byte: 0}, + }, + { + name: "scan tokens from tokenStart", + source: `foo = 1`, + seek: func(s *tokenScanner) error { + return s.seek(hcl.Pos{Line: 1, Column: 5, Byte: 4}, tokenStart) + }, + scanResults: []scanResult{ + { + Pos: hcl.Pos{Line: 1, Column: 1, Byte: 0}, + Token: hclsyntax.Token{ + Type: hclsyntax.TokenIdent, + Bytes: []byte("foo"), + }, + }, + }, + want: hcl.Pos{Line: 1, Column: 1, Byte: 0}, + }, + { + name: "no scan", + source: `foo = 1`, + seek: func(s *tokenScanner) error { return nil }, + scanResults: []scanResult{}, + want: hcl.Pos{Line: 1, Column: 1, Byte: 0}, + }, + { + name: "no scan from endToken", + source: `foo = 1`, + seek: func(s *tokenScanner) error { + s.seekTokenEnd() + return nil + }, + scanResults: []scanResult{}, + want: hcl.Pos{Line: 1, Column: 1, Byte: 0}, + }, + } + + for _, test := range tests { + t.Run(test.name, func(t *testing.T) { + scanner, diags := newTokenScanner([]byte(test.source), "main.tf") + if diags.HasErrors() { + t.Fatalf("failed to set up token scanner: %s", diags) + } + if err := test.seek(scanner); err != nil { + t.Fatalf("failed to seek: %s", err) + } + + scanResults := []scanResult{} + for scanner.scanBackward() { + scanResults = append(scanResults, scanResult{ + Pos: scanner.pos, + Token: scanner.token(), + }) + } + + opt := cmpopts.IgnoreFields(hclsyntax.Token{}, "Range") + if diff := cmp.Diff(test.scanResults, scanResults, opt); diff != "" { + t.Errorf("scan result mismatch: %s", diff) + } + if diff := cmp.Diff(test.want, scanner.pos); diff != "" { + t.Errorf("position mismatch: %s", diff) + } + }) + } +}