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

Support of Long (64-bit integer) scalar #73

Closed
OlegIlyenko opened this issue Aug 9, 2015 · 16 comments
Closed

Support of Long (64-bit integer) scalar #73

OlegIlyenko opened this issue Aug 9, 2015 · 16 comments

Comments

@OlegIlyenko
Copy link
Contributor

In my experience long is pretty common primitive data type. It also used to represent pretty common things like timestamps or cent amounts. As a result of it, most of modern programming languages naively support 64-bit integer values in one form or another. Is there particular reason why long scalar type was not included in the spec?

@leebyron
Copy link
Collaborator

It wasn't included because it's not available across all platforms, most importantly and practically in our case: JavaScript.

The GraphQL spec does not specify a maximum byte width or storage size for its Int and Float type, but there is a note about the caveat of platform specific restrictions. The two types only represent the semantic difference between whole and part numbers.

This means that you can use Int as a Long or Float as a Double as long as the platforms you're using support that size.

GraphQL allows you to define custom scalars as well, in the case that you want to distinguish between Long and Int, or define a custom serialization for it.

Custom scalars is how we expect these kinds of desired Scalars to be introduced in a way that doesn't burden spec-following GraphQL core libraries.

@OlegIlyenko
Copy link
Contributor Author

Thanks a lot for the reply. I would agree with your suggestion to model it with custom/separate type. I would prefer to strictly define the capabilities of datatype, since it establishes a protocol between client and server, and they both need to know, whether number is bounded or unbounded and what is the maximum size. For that reason I created built-in/custom scalars for Int (32-bits), Long (64-bits), BigInt (unbounded), Float (64-bits) and BigDecimal (unbounded) in scala implementation.

The GraphQL spec does not specify a maximum byte width or storage size for its Int and Float type

This surprises me, because as far as I understood from the spec, Int GraphQL scalar type is 32-bit integer value:

The Int scalar type represents a signed 32‐bit numeric non‐fractional values. Response formats that support a 32‐bit integer or a number type should use that type to represent this scalar.

https://facebook.github.io/graphql/#sec-Int

The same is for the float:

The Float scalar type represents signed double‐precision fractional values as specified by IEEE 754.

Which means 64-bits (according to the standard: https://en.wikipedia.org/wiki/Double-precision_floating-point_format)

Did I misunderstood the spec?

@leebyron
Copy link
Collaborator

Sorry I may be quoting outdated information. It appears you are correct that we decided on stricter language for the spec out of concern for the exact reasons you brought up. I believe the JavaScript reference implementation is more lenient and allows up to 52bit Int (the max JS number type can represent)

@OlegIlyenko
Copy link
Contributor Author

Since spec explicitly states that:

If the integer input value represents a value less than -231 or greater than or equal to 231, a query error should be raised.

Does this mean that reference implementation does not conform to this part of the spec?

@andimarek
Copy link
Contributor

@leebyron The spec doesn't limit the size of int tokens:
http://facebook.github.io/graphql/#sec-Int-Value

The reference impl also doesn't check the size, so it is possible to create a custom long scalar which allows the usage of int tokens (literals) as input. See https://github.com/andimarek/graphql-java/pull/94#issuecomment-190008636.

Is this intended or just a gap in the spec and the size of the int token should be limited?

Thanks!

@leebyron
Copy link
Collaborator

This is intentional. Note that the same is true for many programming languages including JavaScript. You can type a number in syntax that's larger than what the underlying memory can represent.

In GraphQL's case it's also useful for exactly what you mentioned: being able to create custom scalars which represent large numbers.

@leebyron
Copy link
Collaborator

However the Int scalar type does enforce 32bit both in spec and the reference implementation to be maximally compatible.

@andimarek
Copy link
Contributor

Thanks for the quick response.

@dehamzah
Copy link

here is specification doc of Int http://spec.graphql.org/June2018/#sec-Int

in case someone goes here and want to know the maximum value of Int. You must do 2^31 - 1.
Because the docs said:

If the integer internal value represents a value less than -2^31 or greater than or equal to 2^31, a field error should be raised.

agungdwiprasetyo added a commit to agungdwiprasetyo/graphql-go that referenced this issue Jul 23, 2020
graphql doesn't support int64 data type
(graphql/graphql-spec#73)
agungdwiprasetyo added a commit to golangid/graphql-go that referenced this issue Oct 22, 2020
graphql doesn't support int64 data type
(graphql/graphql-spec#73)
agungdwiprasetyo added a commit to golangid/graphql-go that referenced this issue Oct 29, 2020
graphql doesn't support int64 data type
(graphql/graphql-spec#73)
agungdwiprasetyo added a commit to golangid/graphql-go that referenced this issue Apr 16, 2021
graphql doesn't support int64 data type
(graphql/graphql-spec#73)
@coryfklein
Copy link

coryfklein commented Jul 1, 2021

It wasn't included because it's not available across all platforms, most importantly and practically in our case: JavaScript.

Since 64-bit precision integers via BigInt were added to JavaScript two years ago it sounds like the primary objection to this addition is now obsolete.

Is there any reason we can't introduce a 64-bit integer at this point?

@coryfklein
Copy link

coryfklein commented Jul 6, 2021

@leebyron and @OlegIlyenko I apologize for the at-mention but I wasn't sure you'd see replies on old closed issues like this.

What are your thoughts on my comment above, now that the landscape has changed a bit do you think it warrants a new GraphQL native?

Over the years this PR has accrued quite a high number of cross-references to PRs and issues in several other organizations that are having to work around the absence of a long-like type.

@LeeBurton
Copy link

It wasn't included because it's not available across all platforms, most importantly and practically in our case: JavaScript.

Since 64-bit precision integers via BigInt were added to JavaScript two years ago it sounds like the primary objection to this addition is now obsolete.

Is there any reason we can't introduce a 64-bit integer at this point?

I agree. I would like to hear their feedback on your question too. It has been almost 2 years and no reply - not great!

@benjie
Copy link
Member

benjie commented Mar 8, 2023

If someone wanted to champion this change to the GraphQL specification the process to do so is to read the Guiding Principles, write an RFC (can be as simple as a new issue with a rough idea, a document filed into this folder, or could be actual spec edits in a PR), and then attend a GraphQL Working Group and get feedback on your proposal and go from there. Working groups are open to everyone, there's a small agreement you need to sign before attending and then you can add yourself to an upcoming agenda, e.g. April's primary: https://github.com/graphql/graphql-wg/blob/main/agendas/2023/04-Apr/06-wg-primary.md

Changes like this don't happen without a champion, and currently this change does not have a champion (and, sadly, @OlegIlyenko is no longer with us). If you want to see this change, be the champion of it! If you want further advice on how to be an effective champion, feel free to reach out to me in the #graphql-spec channel of the GraphQL discord (https://discord.graphql.org) - I'm @benjie#5432 - or ask below.

@jakobmerrild
Copy link

I think having support for 64-bit integer in the spec would be great and as noted previously this can be achieved in JavaScript by using BigInt. I'm a little worried that any RFC surrounding such a change might get halted because the lack of out-of-the-box support for BigInt in JSON.stringify() and JSON.parse() in JavaScript.

I realise that the serialization of the data is separate from the spec. However, in practise most use JSON and lack of easy support to implement the spec might hinder any such RFC.
What do you think @benjie ?

@benjie
Copy link
Member

benjie commented Dec 13, 2024

Like ID, BigInt can safely be encoded as string in JSON so I don't see that as a blocker.

(That said, I think it would be much better to make this a standard "custom scalar" and offer it through https://scalars.graphql.org/ rather than requiring that every single GraphQL client and server support it when it's clearly not that big a need.)

@jakobmerrild
Copy link

I'll see if I can make a reasonable contribution to those specs on the other side of the weekend :)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

8 participants