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 JSON schema struct generation #210

Merged
merged 13 commits into from
Dec 1, 2023
Merged

Add JSON schema struct generation #210

merged 13 commits into from
Dec 1, 2023

Conversation

SferaDev
Copy link
Member

@SferaDev SferaDev commented Nov 27, 2023

All structs matched well except for PrimaryKey which we mapped differently, I've refactored it to Pk as it doesn't seem to support different names for go and JSON

Signed-off-by: Alexis Rico <sferadev@gmail.com>
Signed-off-by: Alexis Rico <sferadev@gmail.com>
Signed-off-by: Alexis Rico <sferadev@gmail.com>
Signed-off-by: Alexis Rico <sferadev@gmail.com>
Copy link
Collaborator

@andrew-farries andrew-farries left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good 👍

  • I think we should also add a Makefile with a rule to regenerate these types.
  • The docs could be updated to include a reference to this JSON schema in the operations reference section

schema.json Show resolved Hide resolved
schema.json Outdated Show resolved Hide resolved
Signed-off-by: Alexis Rico <sferadev@gmail.com>
Signed-off-by: Alexis Rico <sferadev@gmail.com>
@SferaDev SferaDev marked this pull request as ready for review November 30, 2023 06:57
@SferaDev
Copy link
Member Author

SferaDev commented Nov 30, 2023

@andrew-farries Updated!

  • Updated to latest JSON Schema draft
  • When doing go get for the dependency, it updated other versions in the mod/sum files.
  • Added a Makefile with a generate step
  • Fixed the license check in the Makefile step
  • Updated all objects to include descriptions

Proposed follow-ups:

  • Add linter/formatter to the Makefile
  • Add a github workflow to run make generate and check the generated file wasn't manually edited
  • Update docs and use the JSON schema to generate API reference

Signed-off-by: Alexis Rico <sferadev@gmail.com>
Signed-off-by: Alexis Rico <sferadev@gmail.com>
Signed-off-by: Alexis Rico <sferadev@gmail.com>
Copy link
Collaborator

@andrew-farries andrew-farries left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This looks good, just a few more suggestions.

Makefile Outdated Show resolved Hide resolved
@@ -0,0 +1,404 @@
{
"$schema": "https://json-schema.org/draft/2020-12/schema",
"allOf": [{ "$ref": "#/$defs/PgRollMigration" }],
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What's the purpose of allOf here? The same types are still generated successfully if I remove this line.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Some tooling fails to parse $ref in the top level. The allOf is a workaround that makes it work.

I think we could also move PgRollMigration definition top level instead of a $ref, not sure what you'd prefer. It's the only definition we actually don't really need in the types.go file.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The PgRollMigration type actually duplicates a type we define here:

https://github.com/xataio/pgroll/blob/main/pkg/migrations/migrations.go#L46-L53

So it could probably be removed entirely.

Copy link
Member Author

@SferaDev SferaDev Nov 30, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I missed those. What about I create: Migration, Operation and Operations definitions and keep the allOf with $ref top level?

I kind of like having at least the Operation one as a definition as it will be the one we document outside the pgroll context.

I can get it done tomorrow so it's ready for a final review.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

After checking today, it might not be possible to generate these and re-use them.

  1. The Operation in pgroll it's not just an struct, it's an interface with methods.
  2. The library hasn't added support for anyOf yet, they have a PR open but stale

I think it's fine as-is leaving the top level allOf: { $ref } to reference the definition of PgRollMigration that doesn't clash with the internal Migration one.

I've subscribed to that PR, once they merge support for anyOf maybe we can accomodate both and fully re-use Migration, Operations and Operation.

WDYT?

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thats fine from my POV. The main benefit we get from this is being able to generate the types for the different operations.

Is this PR good to go from your side now?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, can be merged when you're good with it

schema.json Show resolved Hide resolved
@andrew-farries
Copy link
Collaborator

Update docs and use the JSON schema to generate API reference

Do you have an idea in mind for how to generate documentation from the JSON schema?

SferaDev and others added 3 commits November 30, 2023 13:29
Co-authored-by: Andrew Farries <andyrb@gmail.com>
Signed-off-by: Alexis Rico <sferadev@gmail.com>
@SferaDev
Copy link
Member Author

SferaDev commented Nov 30, 2023

Update docs and use the JSON schema to generate API reference

Do you have an idea in mind for how to generate documentation from the JSON schema?

There are different tools to read JSON schemas and generate docs. Cloudflare has doca although doesn't seem maintained, Adobe has a markdown generator and there might be a few more.

In any case, I was thinking of doing something a little bit more tailored for xata.io/docs. I think we will likely have 2 documentation sites: pgroll open source repo (and maybe even website in a future), and xata.io website for documenting the schema migrations in-product. It would be great if we make both share a single source of truth like the JSON Schema.

@andrew-farries andrew-farries merged commit 788bac6 into main Dec 1, 2023
22 checks passed
@andrew-farries andrew-farries deleted the json-schema branch December 1, 2023 16:01
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

Successfully merging this pull request may close these issues.

2 participants