From a3a7ffecc8ace457922c7add721f299439860660 Mon Sep 17 00:00:00 2001 From: Andrew Ray Date: Thu, 24 Jun 2021 12:19:18 -0700 Subject: [PATCH] Renaming Entity in gqlgen to avoid type name conflict Addresses https://github.com/99designs/gqlgen/issues/1256 --- README.md | 18 ++++++++++++ codegen/templates/templates.go | 15 ++++++++++ codegen/templates/templates_test.go | 5 ++++ .../accounts/graph/generated/federation.go | 10 +++---- .../accounts/graph/generated/generated.go | 28 +++++++++---------- .../accounts/graph/model/models_gen.go | 2 +- .../products/graph/generated/federation.go | 10 +++---- .../products/graph/generated/generated.go | 28 +++++++++---------- .../products/graph/model/models_gen.go | 2 +- .../reviews/graph/generated/federation.go | 10 +++---- .../reviews/graph/generated/generated.go | 28 +++++++++---------- .../federation/reviews/graph/model/models.go | 4 +-- plugin/federation/federation.go | 6 ++-- plugin/federation/federation.gotpl | 10 +++---- plugin/federation/fedruntime/runtime.go | 8 +++--- 15 files changed, 111 insertions(+), 73 deletions(-) diff --git a/README.md b/README.md index 8e6ebdaac1d..b530ffef74f 100644 --- a/README.md +++ b/README.md @@ -1,3 +1,21 @@ +# Grand Rounds Fork of GQLgen + +This fork was created by: + +1. Forking the repository +2. Resetting master of the fork to the tagged commit of the last stable release + of gqlgen. At the time of writing this, it's tag v0.13.0 and commit 07c1f93. +3. Pushing -f to reset master of this fork the above commit. +3. Opening a pull request of the patch we've applied, to this fork, and merging + the patch into the master branch of this fork.s + +Note that means the master branch of this fork diverges from the official +repository. To update this fork to the latest version of gqlgen: + +1. Merge the latest version tagged commit of upstream into master of this fork. + **Don't** merge in the master branch of the main repository, just the commit + of the next tagged version. + # gqlgen [![Continuous Integration](https://github.com/99designs/gqlgen/workflows/Continuous%20Integration/badge.svg)](https://github.com/99designs/gqlgen/actions) [![Read the Docs](https://badgen.net/badge/docs/available/green)](http://gqlgen.com/) [![GoDoc](https://godoc.org/github.com/99designs/gqlgen?status.svg)](https://godoc.org/github.com/99designs/gqlgen) ![gqlgen](https://user-images.githubusercontent.com/46195831/89802919-0bb8ef00-db2a-11ea-8ba4-88e7a58b2fd2.png) diff --git a/codegen/templates/templates.go b/codegen/templates/templates.go index 79b0c5c7d46..c926313f42d 100644 --- a/codegen/templates/templates.go +++ b/codegen/templates/templates.go @@ -282,10 +282,25 @@ func Call(p *types.Func) string { return pkg + p.Name() } +// Federated graphs have the types _Entity and _Service. With default Go struct +// name generation, those become `Service`, which can conflict with users +// of this library who have their own `type Service`. Special case handle the +// federated entity names +var internalNames = map[string]string{ + "_Entity": "GqlgenEntity", + "_Service": "GqlgenService", +} + func ToGo(name string) string { if name == "_" { return "_" } + + internalName, hasInternalName := internalNames[name] + if hasInternalName { + return internalName + } + runes := make([]rune, 0, len(name)) wordWalker(name, func(info *wordInfo) { diff --git a/codegen/templates/templates_test.go b/codegen/templates/templates_test.go index 90af334e7e5..d1b68b18bbc 100644 --- a/codegen/templates/templates_test.go +++ b/codegen/templates/templates_test.go @@ -38,6 +38,11 @@ func TestToGo(t *testing.T) { require.Equal(t, "RelatedUrls", ToGo("RelatedUrls")) require.Equal(t, "ITicket", ToGo("ITicket")) require.Equal(t, "FooTicket", ToGo("fooTicket")) + + require.Equal(t, "GqlgenEntity", ToGo("_Entity")) + require.Equal(t, "GqlgenService", ToGo("_Service")) + require.Equal(t, "Entity", ToGo("Entity")) + require.Equal(t, "Service", ToGo("Service")) } func TestToGoPrivate(t *testing.T) { diff --git a/example/federation/accounts/graph/generated/federation.go b/example/federation/accounts/graph/generated/federation.go index 6c574a8a863..b969e4a9b76 100644 --- a/example/federation/accounts/graph/generated/federation.go +++ b/example/federation/accounts/graph/generated/federation.go @@ -11,9 +11,9 @@ import ( "github.com/99designs/gqlgen/plugin/federation/fedruntime" ) -func (ec *executionContext) __resolve__service(ctx context.Context) (fedruntime.Service, error) { +func (ec *executionContext) __resolve__service(ctx context.Context) (fedruntime.GqlgenService, error) { if ec.DisableIntrospection { - return fedruntime.Service{}, errors.New("federated introspection disabled") + return fedruntime.GqlgenService{}, errors.New("federated introspection disabled") } var sdl []string @@ -25,13 +25,13 @@ func (ec *executionContext) __resolve__service(ctx context.Context) (fedruntime. sdl = append(sdl, src.Input) } - return fedruntime.Service{ + return fedruntime.GqlgenService{ SDL: strings.Join(sdl, "\n"), }, nil } -func (ec *executionContext) __resolve_entities(ctx context.Context, representations []map[string]interface{}) ([]fedruntime.Entity, error) { - list := []fedruntime.Entity{} +func (ec *executionContext) __resolve_entities(ctx context.Context, representations []map[string]interface{}) ([]fedruntime.GqlgenEntity, error) { + list := []fedruntime.GqlgenEntity{} for _, rep := range representations { typeName, ok := rep["__typename"].(string) if !ok { diff --git a/example/federation/accounts/graph/generated/generated.go b/example/federation/accounts/graph/generated/generated.go index 52adf8bb3c5..3eaa9d24cec 100644 --- a/example/federation/accounts/graph/generated/generated.go +++ b/example/federation/accounts/graph/generated/generated.go @@ -60,7 +60,7 @@ type ComplexityRoot struct { Username func(childComplexity int) int } - Service struct { + GqlgenService struct { SDL func(childComplexity int) int } } @@ -140,11 +140,11 @@ func (e *executableSchema) Complexity(typeName, field string, childComplexity in return e.complexity.User.Username(childComplexity), true case "_Service.sdl": - if e.complexity.Service.SDL == nil { + if e.complexity.GqlgenService.SDL == nil { break } - return e.complexity.Service.SDL(childComplexity), true + return e.complexity.GqlgenService.SDL(childComplexity), true } return 0, false @@ -435,9 +435,9 @@ func (ec *executionContext) _Query__entities(ctx context.Context, field graphql. } return graphql.Null } - res := resTmp.([]fedruntime.Entity) + res := resTmp.([]fedruntime.GqlgenEntity) fc.Result = res - return ec.marshalN_Entity2ᚕgithubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐEntity(ctx, field.Selections, res) + return ec.marshalN_Entity2ᚕgithubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐGqlgenEntity(ctx, field.Selections, res) } func (ec *executionContext) _Query__service(ctx context.Context, field graphql.CollectedField) (ret graphql.Marshaler) { @@ -470,9 +470,9 @@ func (ec *executionContext) _Query__service(ctx context.Context, field graphql.C } return graphql.Null } - res := resTmp.(fedruntime.Service) + res := resTmp.(fedruntime.GqlgenService) fc.Result = res - return ec.marshalN_Service2githubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐService(ctx, field.Selections, res) + return ec.marshalN_Service2githubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐGqlgenService(ctx, field.Selections, res) } func (ec *executionContext) _Query___type(ctx context.Context, field graphql.CollectedField) (ret graphql.Marshaler) { @@ -616,7 +616,7 @@ func (ec *executionContext) _User_username(ctx context.Context, field graphql.Co return ec.marshalNString2string(ctx, field.Selections, res) } -func (ec *executionContext) __Service_sdl(ctx context.Context, field graphql.CollectedField, obj *fedruntime.Service) (ret graphql.Marshaler) { +func (ec *executionContext) __Service_sdl(ctx context.Context, field graphql.CollectedField, obj *fedruntime.GqlgenService) (ret graphql.Marshaler) { defer func() { if r := recover(); r != nil { ec.Error(ctx, ec.Recover(ctx, r)) @@ -1774,7 +1774,7 @@ func (ec *executionContext) ___Type_ofType(ctx context.Context, field graphql.Co // region ************************** interface.gotpl *************************** -func (ec *executionContext) __Entity(ctx context.Context, sel ast.SelectionSet, obj fedruntime.Entity) graphql.Marshaler { +func (ec *executionContext) __Entity(ctx context.Context, sel ast.SelectionSet, obj fedruntime.GqlgenEntity) graphql.Marshaler { switch obj := (obj).(type) { case nil: return graphql.Null @@ -1937,7 +1937,7 @@ func (ec *executionContext) _User(ctx context.Context, sel ast.SelectionSet, obj var _ServiceImplementors = []string{"_Service"} -func (ec *executionContext) __Service(ctx context.Context, sel ast.SelectionSet, obj *fedruntime.Service) graphql.Marshaler { +func (ec *executionContext) __Service(ctx context.Context, sel ast.SelectionSet, obj *fedruntime.GqlgenService) graphql.Marshaler { fields := graphql.CollectFields(ec.OperationContext, sel, _ServiceImplementors) out := graphql.NewFieldSet(fields) @@ -2325,7 +2325,7 @@ func (ec *executionContext) marshalN_Any2ᚕmapᚄ(ctx context.Context, sel ast. return ret } -func (ec *executionContext) marshalN_Entity2ᚕgithubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐEntity(ctx context.Context, sel ast.SelectionSet, v []fedruntime.Entity) graphql.Marshaler { +func (ec *executionContext) marshalN_Entity2ᚕgithubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐGqlgenEntity(ctx context.Context, sel ast.SelectionSet, v []fedruntime.GqlgenEntity) graphql.Marshaler { ret := make(graphql.Array, len(v)) var wg sync.WaitGroup isLen1 := len(v) == 1 @@ -2349,7 +2349,7 @@ func (ec *executionContext) marshalN_Entity2ᚕgithubᚗcomᚋ99designsᚋgqlgen if !isLen1 { defer wg.Done() } - ret[i] = ec.marshalO_Entity2githubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐEntity(ctx, sel, v[i]) + ret[i] = ec.marshalO_Entity2githubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐGqlgenEntity(ctx, sel, v[i]) } if isLen1 { f(i) @@ -2378,7 +2378,7 @@ func (ec *executionContext) marshalN_FieldSet2string(ctx context.Context, sel as return res } -func (ec *executionContext) marshalN_Service2githubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐService(ctx context.Context, sel ast.SelectionSet, v fedruntime.Service) graphql.Marshaler { +func (ec *executionContext) marshalN_Service2githubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐGqlgenService(ctx context.Context, sel ast.SelectionSet, v fedruntime.GqlgenService) graphql.Marshaler { return ec.__Service(ctx, sel, &v) } @@ -2694,7 +2694,7 @@ func (ec *executionContext) marshalOUser2ᚖgithubᚗcomᚋ99designsᚋgqlgenᚋ return ec._User(ctx, sel, v) } -func (ec *executionContext) marshalO_Entity2githubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐEntity(ctx context.Context, sel ast.SelectionSet, v fedruntime.Entity) graphql.Marshaler { +func (ec *executionContext) marshalO_Entity2githubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐGqlgenEntity(ctx context.Context, sel ast.SelectionSet, v fedruntime.GqlgenEntity) graphql.Marshaler { if v == nil { return graphql.Null } diff --git a/example/federation/accounts/graph/model/models_gen.go b/example/federation/accounts/graph/model/models_gen.go index 67853e2ba3d..c1e2827723d 100644 --- a/example/federation/accounts/graph/model/models_gen.go +++ b/example/federation/accounts/graph/model/models_gen.go @@ -7,4 +7,4 @@ type User struct { Username string `json:"username"` } -func (User) IsEntity() {} +func (User) IsGqlgenEntity() {} diff --git a/example/federation/products/graph/generated/federation.go b/example/federation/products/graph/generated/federation.go index 6db7e70cd84..236a12a04e0 100644 --- a/example/federation/products/graph/generated/federation.go +++ b/example/federation/products/graph/generated/federation.go @@ -11,9 +11,9 @@ import ( "github.com/99designs/gqlgen/plugin/federation/fedruntime" ) -func (ec *executionContext) __resolve__service(ctx context.Context) (fedruntime.Service, error) { +func (ec *executionContext) __resolve__service(ctx context.Context) (fedruntime.GqlgenService, error) { if ec.DisableIntrospection { - return fedruntime.Service{}, errors.New("federated introspection disabled") + return fedruntime.GqlgenService{}, errors.New("federated introspection disabled") } var sdl []string @@ -25,13 +25,13 @@ func (ec *executionContext) __resolve__service(ctx context.Context) (fedruntime. sdl = append(sdl, src.Input) } - return fedruntime.Service{ + return fedruntime.GqlgenService{ SDL: strings.Join(sdl, "\n"), }, nil } -func (ec *executionContext) __resolve_entities(ctx context.Context, representations []map[string]interface{}) ([]fedruntime.Entity, error) { - list := []fedruntime.Entity{} +func (ec *executionContext) __resolve_entities(ctx context.Context, representations []map[string]interface{}) ([]fedruntime.GqlgenEntity, error) { + list := []fedruntime.GqlgenEntity{} for _, rep := range representations { typeName, ok := rep["__typename"].(string) if !ok { diff --git a/example/federation/products/graph/generated/generated.go b/example/federation/products/graph/generated/generated.go index 5f544afd645..0496f751934 100644 --- a/example/federation/products/graph/generated/generated.go +++ b/example/federation/products/graph/generated/generated.go @@ -61,7 +61,7 @@ type ComplexityRoot struct { __resolve_entities func(childComplexity int, representations []map[string]interface{}) int } - Service struct { + GqlgenService struct { SDL func(childComplexity int) int } } @@ -153,11 +153,11 @@ func (e *executableSchema) Complexity(typeName, field string, childComplexity in return e.complexity.Query.__resolve_entities(childComplexity, args["representations"].([]map[string]interface{})), true case "_Service.sdl": - if e.complexity.Service.SDL == nil { + if e.complexity.GqlgenService.SDL == nil { break } - return e.complexity.Service.SDL(childComplexity), true + return e.complexity.GqlgenService.SDL(childComplexity), true } return 0, false @@ -576,9 +576,9 @@ func (ec *executionContext) _Query__entities(ctx context.Context, field graphql. } return graphql.Null } - res := resTmp.([]fedruntime.Entity) + res := resTmp.([]fedruntime.GqlgenEntity) fc.Result = res - return ec.marshalN_Entity2ᚕgithubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐEntity(ctx, field.Selections, res) + return ec.marshalN_Entity2ᚕgithubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐGqlgenEntity(ctx, field.Selections, res) } func (ec *executionContext) _Query__service(ctx context.Context, field graphql.CollectedField) (ret graphql.Marshaler) { @@ -611,9 +611,9 @@ func (ec *executionContext) _Query__service(ctx context.Context, field graphql.C } return graphql.Null } - res := resTmp.(fedruntime.Service) + res := resTmp.(fedruntime.GqlgenService) fc.Result = res - return ec.marshalN_Service2githubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐService(ctx, field.Selections, res) + return ec.marshalN_Service2githubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐGqlgenService(ctx, field.Selections, res) } func (ec *executionContext) _Query___type(ctx context.Context, field graphql.CollectedField) (ret graphql.Marshaler) { @@ -687,7 +687,7 @@ func (ec *executionContext) _Query___schema(ctx context.Context, field graphql.C return ec.marshalO__Schema2ᚖgithubᚗcomᚋ99designsᚋgqlgenᚋgraphqlᚋintrospectionᚐSchema(ctx, field.Selections, res) } -func (ec *executionContext) __Service_sdl(ctx context.Context, field graphql.CollectedField, obj *fedruntime.Service) (ret graphql.Marshaler) { +func (ec *executionContext) __Service_sdl(ctx context.Context, field graphql.CollectedField, obj *fedruntime.GqlgenService) (ret graphql.Marshaler) { defer func() { if r := recover(); r != nil { ec.Error(ctx, ec.Recover(ctx, r)) @@ -1845,7 +1845,7 @@ func (ec *executionContext) ___Type_ofType(ctx context.Context, field graphql.Co // region ************************** interface.gotpl *************************** -func (ec *executionContext) __Entity(ctx context.Context, sel ast.SelectionSet, obj fedruntime.Entity) graphql.Marshaler { +func (ec *executionContext) __Entity(ctx context.Context, sel ast.SelectionSet, obj fedruntime.GqlgenEntity) graphql.Marshaler { switch obj := (obj).(type) { case nil: return graphql.Null @@ -2013,7 +2013,7 @@ func (ec *executionContext) _Query(ctx context.Context, sel ast.SelectionSet) gr var _ServiceImplementors = []string{"_Service"} -func (ec *executionContext) __Service(ctx context.Context, sel ast.SelectionSet, obj *fedruntime.Service) graphql.Marshaler { +func (ec *executionContext) __Service(ctx context.Context, sel ast.SelectionSet, obj *fedruntime.GqlgenService) graphql.Marshaler { fields := graphql.CollectFields(ec.OperationContext, sel, _ServiceImplementors) out := graphql.NewFieldSet(fields) @@ -2401,7 +2401,7 @@ func (ec *executionContext) marshalN_Any2ᚕmapᚄ(ctx context.Context, sel ast. return ret } -func (ec *executionContext) marshalN_Entity2ᚕgithubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐEntity(ctx context.Context, sel ast.SelectionSet, v []fedruntime.Entity) graphql.Marshaler { +func (ec *executionContext) marshalN_Entity2ᚕgithubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐGqlgenEntity(ctx context.Context, sel ast.SelectionSet, v []fedruntime.GqlgenEntity) graphql.Marshaler { ret := make(graphql.Array, len(v)) var wg sync.WaitGroup isLen1 := len(v) == 1 @@ -2425,7 +2425,7 @@ func (ec *executionContext) marshalN_Entity2ᚕgithubᚗcomᚋ99designsᚋgqlgen if !isLen1 { defer wg.Done() } - ret[i] = ec.marshalO_Entity2githubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐEntity(ctx, sel, v[i]) + ret[i] = ec.marshalO_Entity2githubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐGqlgenEntity(ctx, sel, v[i]) } if isLen1 { f(i) @@ -2454,7 +2454,7 @@ func (ec *executionContext) marshalN_FieldSet2string(ctx context.Context, sel as return res } -func (ec *executionContext) marshalN_Service2githubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐService(ctx context.Context, sel ast.SelectionSet, v fedruntime.Service) graphql.Marshaler { +func (ec *executionContext) marshalN_Service2githubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐGqlgenService(ctx context.Context, sel ast.SelectionSet, v fedruntime.GqlgenService) graphql.Marshaler { return ec.__Service(ctx, sel, &v) } @@ -2826,7 +2826,7 @@ func (ec *executionContext) marshalOString2ᚖstring(ctx context.Context, sel as return graphql.MarshalString(*v) } -func (ec *executionContext) marshalO_Entity2githubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐEntity(ctx context.Context, sel ast.SelectionSet, v fedruntime.Entity) graphql.Marshaler { +func (ec *executionContext) marshalO_Entity2githubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐGqlgenEntity(ctx context.Context, sel ast.SelectionSet, v fedruntime.GqlgenEntity) graphql.Marshaler { if v == nil { return graphql.Null } diff --git a/example/federation/products/graph/model/models_gen.go b/example/federation/products/graph/model/models_gen.go index c18b34dc211..fac2dabf35e 100644 --- a/example/federation/products/graph/model/models_gen.go +++ b/example/federation/products/graph/model/models_gen.go @@ -8,4 +8,4 @@ type Product struct { Price int `json:"price"` } -func (Product) IsEntity() {} +func (Product) IsGqlgenEntity() {} diff --git a/example/federation/reviews/graph/generated/federation.go b/example/federation/reviews/graph/generated/federation.go index 60a34909578..29ce35bf525 100644 --- a/example/federation/reviews/graph/generated/federation.go +++ b/example/federation/reviews/graph/generated/federation.go @@ -11,9 +11,9 @@ import ( "github.com/99designs/gqlgen/plugin/federation/fedruntime" ) -func (ec *executionContext) __resolve__service(ctx context.Context) (fedruntime.Service, error) { +func (ec *executionContext) __resolve__service(ctx context.Context) (fedruntime.GqlgenService, error) { if ec.DisableIntrospection { - return fedruntime.Service{}, errors.New("federated introspection disabled") + return fedruntime.GqlgenService{}, errors.New("federated introspection disabled") } var sdl []string @@ -25,13 +25,13 @@ func (ec *executionContext) __resolve__service(ctx context.Context) (fedruntime. sdl = append(sdl, src.Input) } - return fedruntime.Service{ + return fedruntime.GqlgenService{ SDL: strings.Join(sdl, "\n"), }, nil } -func (ec *executionContext) __resolve_entities(ctx context.Context, representations []map[string]interface{}) ([]fedruntime.Entity, error) { - list := []fedruntime.Entity{} +func (ec *executionContext) __resolve_entities(ctx context.Context, representations []map[string]interface{}) ([]fedruntime.GqlgenEntity, error) { + list := []fedruntime.GqlgenEntity{} for _, rep := range representations { typeName, ok := rep["__typename"].(string) if !ok { diff --git a/example/federation/reviews/graph/generated/generated.go b/example/federation/reviews/graph/generated/generated.go index 0ef7c35a9e9..f95cdd2a9a9 100644 --- a/example/federation/reviews/graph/generated/generated.go +++ b/example/federation/reviews/graph/generated/generated.go @@ -72,7 +72,7 @@ type ComplexityRoot struct { Reviews func(childComplexity int) int } - Service struct { + GqlgenService struct { SDL func(childComplexity int) int } } @@ -196,11 +196,11 @@ func (e *executableSchema) Complexity(typeName, field string, childComplexity in return e.complexity.User.Reviews(childComplexity), true case "_Service.sdl": - if e.complexity.Service.SDL == nil { + if e.complexity.GqlgenService.SDL == nil { break } - return e.complexity.Service.SDL(childComplexity), true + return e.complexity.GqlgenService.SDL(childComplexity), true } return 0, false @@ -591,9 +591,9 @@ func (ec *executionContext) _Query__entities(ctx context.Context, field graphql. } return graphql.Null } - res := resTmp.([]fedruntime.Entity) + res := resTmp.([]fedruntime.GqlgenEntity) fc.Result = res - return ec.marshalN_Entity2ᚕgithubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐEntity(ctx, field.Selections, res) + return ec.marshalN_Entity2ᚕgithubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐGqlgenEntity(ctx, field.Selections, res) } func (ec *executionContext) _Query__service(ctx context.Context, field graphql.CollectedField) (ret graphql.Marshaler) { @@ -626,9 +626,9 @@ func (ec *executionContext) _Query__service(ctx context.Context, field graphql.C } return graphql.Null } - res := resTmp.(fedruntime.Service) + res := resTmp.(fedruntime.GqlgenService) fc.Result = res - return ec.marshalN_Service2githubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐService(ctx, field.Selections, res) + return ec.marshalN_Service2githubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐGqlgenService(ctx, field.Selections, res) } func (ec *executionContext) _Query___type(ctx context.Context, field graphql.CollectedField) (ret graphql.Marshaler) { @@ -874,7 +874,7 @@ func (ec *executionContext) _User_reviews(ctx context.Context, field graphql.Col return ec.marshalOReview2ᚕᚖgithubᚗcomᚋ99designsᚋgqlgenᚋexampleᚋfederationᚋreviewsᚋgraphᚋmodelᚐReview(ctx, field.Selections, res) } -func (ec *executionContext) __Service_sdl(ctx context.Context, field graphql.CollectedField, obj *fedruntime.Service) (ret graphql.Marshaler) { +func (ec *executionContext) __Service_sdl(ctx context.Context, field graphql.CollectedField, obj *fedruntime.GqlgenService) (ret graphql.Marshaler) { defer func() { if r := recover(); r != nil { ec.Error(ctx, ec.Recover(ctx, r)) @@ -2032,7 +2032,7 @@ func (ec *executionContext) ___Type_ofType(ctx context.Context, field graphql.Co // region ************************** interface.gotpl *************************** -func (ec *executionContext) __Entity(ctx context.Context, sel ast.SelectionSet, obj fedruntime.Entity) graphql.Marshaler { +func (ec *executionContext) __Entity(ctx context.Context, sel ast.SelectionSet, obj fedruntime.GqlgenEntity) graphql.Marshaler { switch obj := (obj).(type) { case nil: return graphql.Null @@ -2286,7 +2286,7 @@ func (ec *executionContext) _User(ctx context.Context, sel ast.SelectionSet, obj var _ServiceImplementors = []string{"_Service"} -func (ec *executionContext) __Service(ctx context.Context, sel ast.SelectionSet, obj *fedruntime.Service) graphql.Marshaler { +func (ec *executionContext) __Service(ctx context.Context, sel ast.SelectionSet, obj *fedruntime.GqlgenService) graphql.Marshaler { fields := graphql.CollectFields(ec.OperationContext, sel, _ServiceImplementors) out := graphql.NewFieldSet(fields) @@ -2688,7 +2688,7 @@ func (ec *executionContext) marshalN_Any2ᚕmapᚄ(ctx context.Context, sel ast. return ret } -func (ec *executionContext) marshalN_Entity2ᚕgithubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐEntity(ctx context.Context, sel ast.SelectionSet, v []fedruntime.Entity) graphql.Marshaler { +func (ec *executionContext) marshalN_Entity2ᚕgithubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐGqlgenEntity(ctx context.Context, sel ast.SelectionSet, v []fedruntime.GqlgenEntity) graphql.Marshaler { ret := make(graphql.Array, len(v)) var wg sync.WaitGroup isLen1 := len(v) == 1 @@ -2712,7 +2712,7 @@ func (ec *executionContext) marshalN_Entity2ᚕgithubᚗcomᚋ99designsᚋgqlgen if !isLen1 { defer wg.Done() } - ret[i] = ec.marshalO_Entity2githubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐEntity(ctx, sel, v[i]) + ret[i] = ec.marshalO_Entity2githubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐGqlgenEntity(ctx, sel, v[i]) } if isLen1 { f(i) @@ -2741,7 +2741,7 @@ func (ec *executionContext) marshalN_FieldSet2string(ctx context.Context, sel as return res } -func (ec *executionContext) marshalN_Service2githubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐService(ctx context.Context, sel ast.SelectionSet, v fedruntime.Service) graphql.Marshaler { +func (ec *executionContext) marshalN_Service2githubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐGqlgenService(ctx context.Context, sel ast.SelectionSet, v fedruntime.GqlgenService) graphql.Marshaler { return ec.__Service(ctx, sel, &v) } @@ -3098,7 +3098,7 @@ func (ec *executionContext) marshalOString2ᚖstring(ctx context.Context, sel as return graphql.MarshalString(*v) } -func (ec *executionContext) marshalO_Entity2githubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐEntity(ctx context.Context, sel ast.SelectionSet, v fedruntime.Entity) graphql.Marshaler { +func (ec *executionContext) marshalO_Entity2githubᚗcomᚋ99designsᚋgqlgenᚋpluginᚋfederationᚋfedruntimeᚐGqlgenEntity(ctx context.Context, sel ast.SelectionSet, v fedruntime.GqlgenEntity) graphql.Marshaler { if v == nil { return graphql.Null } diff --git a/example/federation/reviews/graph/model/models.go b/example/federation/reviews/graph/model/models.go index 51394035234..6f7d8a0c665 100644 --- a/example/federation/reviews/graph/model/models.go +++ b/example/federation/reviews/graph/model/models.go @@ -4,7 +4,7 @@ type Product struct { Upc string `json:"upc"` } -func (Product) IsEntity() {} +func (Product) IsGqlgenEntity() {} type Review struct { Body string @@ -16,4 +16,4 @@ type User struct { ID string `json:"id"` } -func (User) IsEntity() {} +func (User) IsGqlgenEntity() {} diff --git a/plugin/federation/federation.go b/plugin/federation/federation.go index 7d9abc9774c..413b545d3d9 100644 --- a/plugin/federation/federation.go +++ b/plugin/federation/federation.go @@ -33,17 +33,17 @@ func (f *federation) MutateConfig(cfg *config.Config) error { builtins := config.TypeMap{ "_Service": { Model: config.StringList{ - "github.com/99designs/gqlgen/plugin/federation/fedruntime.Service", + "github.com/99designs/gqlgen/plugin/federation/fedruntime.GqlgenService", }, }, "_Entity": { Model: config.StringList{ - "github.com/99designs/gqlgen/plugin/federation/fedruntime.Entity", + "github.com/99designs/gqlgen/plugin/federation/fedruntime.GqlgenEntity", }, }, "Entity": { Model: config.StringList{ - "github.com/99designs/gqlgen/plugin/federation/fedruntime.Entity", + "github.com/99designs/gqlgen/plugin/federation/fedruntime.GqlgenEntity", }, }, "_Any": { diff --git a/plugin/federation/federation.gotpl b/plugin/federation/federation.gotpl index 96c25e85723..c29dfcb0f18 100644 --- a/plugin/federation/federation.gotpl +++ b/plugin/federation/federation.gotpl @@ -5,9 +5,9 @@ {{ reserveImport "github.com/99designs/gqlgen/plugin/federation/fedruntime" }} -func (ec *executionContext) __resolve__service(ctx context.Context) (fedruntime.Service, error) { +func (ec *executionContext) __resolve__service(ctx context.Context) (fedruntime.GqlgenService, error) { if ec.DisableIntrospection { - return fedruntime.Service{}, errors.New("federated introspection disabled") + return fedruntime.GqlgenService{}, errors.New("federated introspection disabled") } var sdl []string @@ -19,14 +19,14 @@ func (ec *executionContext) __resolve__service(ctx context.Context) (fedruntime. sdl = append(sdl, src.Input) } - return fedruntime.Service{ + return fedruntime.GqlgenService{ SDL: strings.Join(sdl, "\n"), }, nil } {{if .Entities}} -func (ec *executionContext) __resolve_entities(ctx context.Context, representations []map[string]interface{}) ([]fedruntime.Entity, error) { - list := []fedruntime.Entity{} +func (ec *executionContext) __resolve_entities(ctx context.Context, representations []map[string]interface{}) ([]fedruntime.GqlgenEntity, error) { + list := []fedruntime.GqlgenEntity{} for _, rep := range representations { typeName, ok := rep["__typename"].(string) if !ok { diff --git a/plugin/federation/fedruntime/runtime.go b/plugin/federation/fedruntime/runtime.go index 807bdf365be..6a979f02d94 100644 --- a/plugin/federation/fedruntime/runtime.go +++ b/plugin/federation/fedruntime/runtime.go @@ -1,13 +1,13 @@ package fedruntime -// Service is the service object that the +// GqlgenService is the service object that the // generated.go file will return for the _service // query -type Service struct { +type GqlgenService struct { SDL string `json:"sdl"` } // Everything with a @key implements this -type Entity interface { - IsEntity() +type GqlgenEntity interface { + IsGqlgenEntity() }