Skip to content
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

Add support for custom directives #77

Open
jangko opened this issue May 8, 2021 · 1 comment
Open

Add support for custom directives #77

jangko opened this issue May 8, 2021 · 1 comment
Labels
features New features not availabel yet medium priority We might need it soon

Comments

@jangko
Copy link
Contributor

jangko commented May 8, 2021

we have at least two types of directives:

  1. schema directives
  2. query directives

but we also have lots of unanswered questions:

  1. where in the execution/validation pipeline we should put custom directives execution?
  2. how do we expose the internal of nim-graphql to custom directives?
  3. how custom directives can safely manipulate things/AST?
@jangko jangko added features New features not availabel yet medium priority We might need it soon labels May 8, 2021
@jangko
Copy link
Contributor Author

jangko commented May 12, 2021

after #80, now we have instrumentation infrastructure in place.

  • can we extend this new feature to implement custom directives?

We will not execute directives like we are executing resolvers. we can't treat a directive like a function. Although it has parameters like a function, those parameters actually configuration parameter to adjust directive behavior. They are not parameters like a function. What I mean is, we cannot attach a function to directive and then execute that function by validator/executor. A scalar or a field resolver can work in that way because they have specific role in graphql system. But a directive can have a very broad unspecified role.

For example the @Skip and @include directives. When the validator encounter those directives, it become a flag that a field should be included or not in final execution. Although those two directives are attached to query field, but they will modify field set, not only modify a single field. We cannot limit what kind of environment(e.g. only a query field) we should pass to a directive handler. That's why a directive need more privileges compared to scalars or resolvers.

execution approach:

  • Like an instrument, a directive can scan the AST for the presence of a @directive in use.
  • Or the validator/executor when encounter a @directive, will call that 'directive instrument'.
  • Or the directive implementer can specify how the directive should be executed like when an instrument will be executed.
    This still have to be explored again, because it's still unclear how we should execute custom directives.

may be we can collect whatever custom directives out there and try to implement it using our instrument.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
features New features not availabel yet medium priority We might need it soon
Projects
None yet
Development

No branches or pull requests

1 participant