-
-
Notifications
You must be signed in to change notification settings - Fork 97
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
[Question] Plans for this library #455
Comments
Hey @DerRidda Thank you for bringing this up and for your kind words! First and foremost, I want to continue working on this library and bring it up to speed with the most recent JSON Schema drafts. In the last two years, I've started three complete rewrites, none of which got through. There are two main reasons for this - complexity & scope. Besides the inherent complexity of newer JSON Schema drafts (specifically in I plan to publish the latest rewrite (a separate repo), continue all the development there for simplicity, and move the code here when there is feature parity. At the same time, I want to address some of the issues opened in this repo (e.g. Python 3.12 support which should not be hard) and publish new versions. A somewhat longer-term vision is to build more components relevant to other projects I am involved in (JSON Schema canonicalization for hypothesis-jsonschema, faster JSON Schema validation in schemathesis, etc) and reuse them. I was postponing them for a long time, but it feels like it the time to get back to them.
Involving the community more will help and I want to have more people contributing & maintaining the library! I also think that the library will benefit if all the development happens in a more public manner (as opposed to my semi-private work). Re: sponsoring - it is something I appreciate a lot and would be happy if somebody is willing to contribute this way :) In conclusion, my immediate next step is to write a high-level plan in the form of a blog post / pinned issue and continue with the implementation. Let me know if you have any questions, I'd be happy to discuss them :) |
Thanks for the quick answer. Reading this leaves me optimistic and I am looking forward to reading the more detailed plan. For our use case the only issue that is somewhat time critical is the Python 3.12 version support you mentioned. But even there we are not blocked from anything meaningful right now, as 3.12 was not the most spectacular release. This is more about a look into the future with 3.13 and beyond, which will most likely be much more interesting releases. |
As it has been around half a year since the start of the discussion, it will be helpful to post an update! APIThe library continues to move to its Custom keywords are supported in the Rust crate and I plan to add support on the Python level too, similar to custom formats. The recent release got significantly updated documentation, which I hope will simplify the onboarding & answer the common usage questions & help with migration from earlier versions. Spec complianceWith the recent release drafts 4, 6, and 7 are 100% supported (it is not yet reflected in bowtie though) and I am working towards supporting anchors & dynamic refs in more recent drafts. Implementing these should bring the compatibility to ~98-99% and there will be only At some point before AsyncReference resolving will be happening before validation and references to remote resources will be processed in batches, which opens up an opportunity to resolve them all concurrently. There will be an async version of UPDATE: Resolving of external references now happens just once. PerformanceI still plan to overhaul the internals to squeeze more performance, but only after getting 100% spec compliance. However, there will be intermediate steps:
What else?In |
Just wanted to confirm that For my application of CSV validation, I can do 761,035 rows/second for a non-trivial JSON Schema! |
@jqnatividad Delighted to hear it! Thank you so much for your kind words :) I appreciate it a lot! |
Thank you all! Closing this in favor of #566 which will be periodically updated |
Hello @Stranger6667,
first of all thank you so much for creating this wonderful library, especially with Python bindings. It's not only much faster than the typical choices in the Python ecosystem, but also more compliant.
Since we moved to it, one of our most expensive processing steps has turned into one of the cheaper ones.
Which brings me to my question: What are your plans for further maintenance and development for jsonschema-rs?
I raise this question as I see no commits have been made to master in quite a while and open PRs have not been engaged with and as somebody who uses it in production, it is my due diligence to check.
Don't misunderstood me, I fully understand and subscribe to the principle that FOSS is supplied as is, with no implied guarantees of anything, and I am fully okay with that reality.
If you don't intend to, or simply lack resources for further maintenance, maybe we can find a model of community ownership for the future or could justify your personal time investment via some sponsoring?
Again, thanks for creating jsonschema-rs in the first place, no matter what the answer to this question will be. :)
The text was updated successfully, but these errors were encountered: