You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
We use graphql-ruby and graphql-client to talk to each other. The graphql-ruby library defines a few extra types beyond the standard GraphQL types, e.g. ISO8601Date, ISO8601DateTime, etc, which we make use of.
In the client we've found that the values of these fields are not getting automatically cast back to Date / Time objects, like they do for other types of object.
I was wondering what might be the best way to get automatic casting for these types. At the moment the only way I can see it might work is by monkey-patching the GraphQL::Schema::BUILT_IN_TYPES hash, which is a bit 🤢 .
Is there a better way of managing this? I can imagine that other GraphQL schemas might have other sorts of custom types, but then how should they be re-interpreted by the client?
Incidentally the tests don't tickle this situation, as the schema is defined using the DSL. To get the datetime/date parsing tests to fail, change test/test_query_result.rb to dump/reload the schema:
Hey, thanks for the suggestion -- I agree that this would be a good default, but we should take care to to support backwards compatibility for people who have already found a solution. I'm not sure the best way to add this behavior but I'll take a look soon and follow up here.
Compatibility-wise, I bet we could add support for these on an opt-in basis in 0.x and then make them default in 1.0 (#15).
I think there's a more general issue here too, about how to handle custom GraphQL types in general. This probably comes in under the main graphql-ruby repo, too. It has docs around custom scalers, and I guess would be really useful to have the same sort of casting functionality in the client too.
Not sure how to implement it though, as the graphql-ruby library does the heavy lifting here and that's where the types are mapped to classes (and also here). Seems a bit tricky to fixinate.
We use graphql-ruby and graphql-client to talk to each other. The
graphql-ruby
library defines a few extra types beyond the standard GraphQL types, e.g.ISO8601Date
,ISO8601DateTime
, etc, which we make use of.In the client we've found that the values of these fields are not getting automatically cast back to
Date
/Time
objects, like they do for other types of object.I was wondering what might be the best way to get automatic casting for these types. At the moment the only way I can see it might work is by monkey-patching the
GraphQL::Schema::BUILT_IN_TYPES
hash, which is a bit 🤢 .Is there a better way of managing this? I can imagine that other GraphQL schemas might have other sorts of custom types, but then how should they be re-interpreted by the client?
Incidentally the tests don't tickle this situation, as the schema is defined using the DSL. To get the datetime/date parsing tests to fail, change test/test_query_result.rb to dump/reload the schema:
Then the test fails:
Adding the "monkey patch" above then re-fixes the tests as the casting happens automatically.
This all feels a bit gross! Is there a better way?
Thanks!
The text was updated successfully, but these errors were encountered: