-
-
Notifications
You must be signed in to change notification settings - Fork 749
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Schema Builder #369
Comments
In order to make the type system easier to extend we also will now open up the descriptor types and the types themself. We will start, with the descriptor types and the work our way through to the type initialization etc. This will let users create their own base classes that can provide a custom configuration behavior for things like filter types and so on. |
Work on this issue can also be tracked here #597 |
Type InitializationThe type initialization will now be done in two phases. Phase one will register external dependencies like types on which this type depends or resolvers. Type dependencies can be registered in two variants, dependencies that require the the type on which a type is dependent to be fully completed or dependencies that just require the instance of a type to be created. In both case the dependency context will return a delegate T ResolveType<T>(ICompletionContext context) where T : ITypeSystemObject When the type is being completed these type resolvers can be executed. |
With the above type initialization we would introduce some potential issues:
|
Maybe we could introduce something like a type name resolver. Though, this would introduce an additional initialization step....
The name is such an issue since we want to fully support generic types. Generic types a currently possible, but not in a nice way. For instance the connection type should be able to ask for the name of the edge type etc. and build with this name its own name. |
TODOs:
|
|
Currently, the schema-first approach does not support single line and mutliline documentation (see GraphQL Specifications from June 2018). The following one will not work when we try to use the schema-first approach:
I made a little research and I didn't manage to find any .net GraphQL implementation that supports this. Is this one related to this issue? Thx you 🙄 |
This should work, at least our parser will parse that correctly. I will write a little test tonight. If it is the bug we will fix it with the upcoming patch release next week. |
I have opened another issue and will add comments there. |
Add support for multi-dimensional lists with this one #676 |
The main work on this one is now finished and I close this issue ... we will add further issues to deal with certain aspects. |
The schema builder shall provide a simpler API to create a schema. Moreover, the goal of this issue is to create feature parity between schema-first, code-first and poco driven schemas. Furthermore, we want to simplify the type initialization process and make it easier to generate dynamic types like for Prisma-style filter objects.
Last but not least the current schema declaration API shall not be broken. The goal here would be that the old schema factories use the schema builder underneath. Users can then decide which API approach they like more.
We have started with a simple interface
ISchemaBuilder
Currently we have two open issues:
How shall bindings work? This ones are mainly for the schema first approach:
ISchemaBuilder AddBinding(object binding);
Further, we are pondering the idea of completely removing the service provider from the schema. So, with that
ISchemaBuilder AddServices(IServiceProvider services);
would be removed.The thinking here is that the services that you associate with the schema are not scoped and are not used during execution so they are a bit confusing to the user. Moreover, do we really want dependency injection into our types or should dependency injection be restricted to resolvers and middleware components etc.
Extensions
In order to keep a small builder interface but provide more convenience we will add some extension methods on the builder like the following:
Usage
Type Initialization
We have to review how we can simplify the initialization API and open this up to be extended by users. Types should be immutable once the builder creates the schema. Moreover, we want to be able to use builder services that enable the user to change defaults like how we extract the names from clr types and so on.
The text was updated successfully, but these errors were encountered: