-
-
Notifications
You must be signed in to change notification settings - Fork 105
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
Better domain type support #399
Comments
Resolving to the base type of the domain makes sense to me
Moving from Opaque to a descriptive type is non-breaking. Opaque types use default postgres json serialization (vs always a string etc) and support the fewest operations (like filtering) for that reason What breakage were you expecting? |
Although I guess a domain based on a bigint (which we serialize as a string vs the default of an int) or json (doesn't support equality but Opaque does) could introduce a data format and API change respectively |
Good point I didn't even think about bigint. I was mainly thinking about fields that weren't surfaced before, domain array types, will now all of a sudden show up. On a lesser extent it's a contract change for users doing introspection on the graphql types and have made workaround for Opaque. I might be overly safe that's why I was going to put it behind a opt out schema config and then that could be removed on the next major release. It's your call just want to get requirements down before working on a pr. |
yeah you're right. I scanned some of the public facing schemas on the platform and there would be impact
a schema level comment directive to enable domain types sounds great If you create a PR, please also add it to the 2.0 breaking changes checklist thanks! |
Will do, just to confirm I would like to do this in two pr's. The first will be a very simple resolve to the base types for domain types. E.g. pos_int would just be int and pos_array would be int[]. Putting the resolve base type behind a opt out of flag just in case someone is reliant on the old behaviour. The second pr would take a while longer and probably needs some further discussion and that would be to surface the domain types. e.g. pos_int would resolve to pos_int ( or should it be PosInt?) on introspection and add it as a scalar type This probably be opt in just in case clients only care about the base types. Does that work for you? |
To roll it out safely I think
and in version 2.0 we remove the schema directive and make that default behavior
there would be no equivalent way to declare the array of positive integer example so I'm not sold on using the domain's name directly, but I'd love to hear any ideas you have |
I haven't given this too much thought yet but it could be embedded in a directive. Something like And then it could be defined on the schema like so: directive @DomainType(type: String!, elementType: String) on FIELD_DEFINITION
type domain_test {
id: ID!
pos_int: Int @DomainType('pos_int`)
pos_int: [Int!] @DomainType('pos_array`,`pos_type`)
} I haven't even tried this out so I don't know if it's valid or how the introspection would work. |
I tried the same example above so see what other tools do. PostGraphile emits the following type: type DomainTest {
id: Int!
intField: Int
arrayField: [Int]
posInt: PosInt
nonEmptyArray: [Int]
posArray: [PosInt]
} Which looks like quite a reasonable solution to me.
I don't fully understand what is the concern here? @olirice could you please show an example? Hasura produces the following type (which I don't like at all): type domain_test {
array_field: [Int!]
id: Int!
int_field: Int
non_empty_array: _int4
pos_array: _pos_int
pos_int: Int
} |
I attempted to step down to base domain types here master...dvv:pg_graphql:master |
Describe the bug
Types for scalar domain types return type Opaque and for array domain types they just fail.
To Reproduce
Given the following schema:
Querying for the types on
domain_test
returns the following:Querying the data will work for the fields on the Opaque types:
And fails for fields with an array domain_type:
You can attempt the above with
pos_array
and get a similar result.Expected behavior
For fields with domain types to resolve to there domain type or at least the domain base type.
E.g.
Would return:
The behavior of the field itself on querying would be the same as it's base type.
Screenshots
N/A
Versions:
Additional context
I think I have a possible fix for this and I'l like to try opening a pr to fix this.
A simple solution would be to resolve the base type of the domain object itself.
To my understanding domain types always have to eventually resolve to a built in sql scalar or array type so this seems like a valid solution.
While this would technically be a breaking change Opaque isn't particularly useful so it could also hide behind a schema directive flag but that would be opt out. This is also a possible fix for #370.
Let me know if you agree and I'll submit a pr.
The complete fix would be to generate new types for domain types.
That is breaking change and some client might not care to know about anything but the base type. It'll have to be behind a schema directive flag that's opt in.
I won't be attempting this approach right away just spitballing a final solution.
The text was updated successfully, but these errors were encountered: