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

GSOC 2025 : Build a Java wrapper library for sourcemeta/blaze #874

Open
erosb opened this issue Feb 2, 2025 · 57 comments
Open

GSOC 2025 : Build a Java wrapper library for sourcemeta/blaze #874

erosb opened this issue Feb 2, 2025 · 57 comments
Labels
gsoc Google Summer of Code Project Idea

Comments

@erosb
Copy link

erosb commented Feb 2, 2025

Build a Java wrapper library for sourcemeta/blaze

Brief Description
sourcemeta/blaze is a high-performance json schema validation library. The goal of this project would be making it available on the JVM platform by building a wrapper library around it, and publishing it on maven central.

Expected Outcomes
A java library should be available on maven central that has a Java-friendly API, and use sourcemeta/blaze under the hood for performing json schema validation.

Skills Required

Interest both in java and native c/c++ libraries, DX and documentation.

Mentors
@erosb

Expected Difficulty
Medium

Expected Time Commitment
175 hours

@benjagm benjagm added the gsoc Google Summer of Code Project Idea label Feb 2, 2025
@jviotti
Copy link
Member

jviotti commented Feb 3, 2025

Hey @erosb, thanks for suggesting this! Just some misc notes:

  • The project that implements the validator is https://github.com/sourcemeta/blaze. The JSON Schema CLI just offers a simple opinionated interface to it
  • I don't know almost anything about Java, but happy to attempt to help 😅
  • Note that Blaze is an AGPL library, so the Java bindings would be AGPL as well (just pointing that out!)

Also, one of the main challenges we saw when attempting Blaze bindings to other programming languages is converting the JSON inputs from whatever the programming language JSON implementation is to the JSON implementation that Blaze expects. In cases like Node.js, converting a v8 JSON object to a Sourcemeta JSON object was expensive enough to counter the performance benefits of Blaze. Do you have any insights on how to do this in a performant manner in Java?

@erosb erosb changed the title Build a Java wrapper library for sourcemeta/jsonschema Build a Java wrapper library for sourcemeta/blaze Feb 3, 2025
@erosb
Copy link
Author

erosb commented Feb 3, 2025

Hello @jviotti thanks for the feedback!

The project that implements the validator is https://github.com/sourcemeta/blaze

Thanks, updated the issue title and description accordingly

I don't know almost anything about Java, but happy to attempt to help

sounds good, I don't know almost anything about C++ so it will be perfectly fine :)

Note that Blaze is an AGPL library, so the Java bindings would be AGPL as well

No problem with that

In cases like Node.js, converting a v8 JSON object to a Sourcemeta JSON object was expensive

I don't have any input about the mapping overhead. Probably this heavily depends on the complexity of the schema and the size of the instance. If it turns out to be severe, I think it should be possible to implement a json parser as part of this library, which directly parses a json string into a sourcemeta json object.

@Karan-Palan
Copy link
Contributor

Hey mentors, this idea interests me. However I do not have experience in Java. I'd like to however try and work on this. Will start learning java, any specifics that I shall learn?

@jviotti
Copy link
Member

jviotti commented Feb 3, 2025

I don't have any input about the mapping overhead. Probably this heavily depends on the complexity of the schema and the size of the instance. If it turns out to be severe, I think it should be possible to implement a json parser as part of this library, which directly parses a json string into a sourcemeta json object.

@erosb Yeah, this sounds good. Blaze has its own JSON parser and the bindings can just take a JSON string, and do everything internally with Blaze stuff 👍🏻

@erosb
Copy link
Author

erosb commented Feb 3, 2025

Helo @Karan-Palan , beside learning java in general, the specific skills this project will need are

  • Java Native Interface
  • and/or Foreign Function and Memory API

@Karan-Palan
Copy link
Contributor

Thanks for the reply! I'll learn and create some projects using them

@jdesrosiers
Copy link
Member

Also, one of the main challenges we saw when attempting Blaze bindings to other programming languages is converting the JSON inputs from whatever the programming language JSON implementation is to the JSON implementation that Blaze expects. In cases like Node.js, converting a v8 JSON object to a Sourcemeta JSON object was expensive enough to counter the performance benefits of Blaze.

I encountered the same kind of thing when I looked into options for JSON Schema in web assembly. Sending anything other than primitives to web assembly is expensive. But, not only that, you have to also have some libraries for working with structured data in web assembly as well. For example, if using Rust for generating the web assembly, you'd need the rust standard library included. That's bigger than my whole implementation and size matters on the web. It didn't seem like there was reasonable path forward, so I abandoned the effort.

I hope this works out better. My guess is that there will be some point were the validation gets complex enough that it becomes faster than existing Java libraries, but relatively simple cases will probably remain faster in Java due to the translation cost. It will be interesting to see where that line ends up. However, I suspect that its possible for a Java library to be optimized to the degree Blaze is and get close enough performance that it's never going to be worth the translation. I'm sure there doesn't exist a Java implementation that's optimized to that level, but I think it's possible. Java can be quite fast if you're diligent/obsessive enough.

@drLite35
Copy link

drLite35 commented Feb 7, 2025

Hi @erosb and mentors, I am interested in this project I have some experience in both Java and C++, would like to know a bit more about this project and start on this, if there is any additional doc/support you can provide me with, it will be helpful, meanwhile let me go through aforementioned.
Thanks.

@benjagm benjagm changed the title Build a Java wrapper library for sourcemeta/blaze GSOC 2025 : Build a Java wrapper library for sourcemeta/blaze Feb 10, 2025
@GANESHSHARMA1
Copy link

Hi @erosb,

I’m really excited about this project to build a Java wrapper library for sourcemeta/blaze as part of GSoC 2025! I have experience with Java (e.g., developing REST APIs with Spring) and a keen interest in native C/C++ integration, which makes this a perfect fit for me. I’ve started exploring JNI basics and the sourcemeta/blaze codebase to get a head start.

I’d love to contribute by designing a Java-friendly API, implementing the JNI bindings, and ensuring the library is published to Maven Central with great documentation. I’m planning to submit a detailed GSoC proposal soon—would you be open to providing feedback on a draft? I’d also be happy to discuss the project scope or start with a small prototype if that helps.

Looking forward to hearing your thoughts! Thanks for mentoring this project.

@Sahith53
Copy link

Sahith53 commented Mar 1, 2025

Hi @erosb and mentors, I’m really excited about the GSOC 2025 project to build a Java wrapper for sourcemeta/blaze! I don’t have any experience with Java or C++ yet, but I’m super interested in learning and contributing to this. I’d love to get started—any tips or resources you recommend for a beginner like me? Looking forward to hearing from you!

@hamdy-fathi
Copy link

Hi @erosb and mentors, I am interested in this project I have much experience in both Java and C++ (major is c++ ), would like to know a bit more about this project and start on this, also please provide any additional docs .
iam really looking forward to contribute in this project
Thanks.

@Tanmay-Tripathi
Copy link

@erosb
Hello, I am Tanmay and
I’m genuinely excited about the project to build a Java wrapper library, bringing its high-performance JSON schema validation to the JVM ecosystem.
Java has been my primary language for the past six years, and I’ve developed a deep understanding of the language alongside working with native libraries.
The chance of creating an intuitive, developer-friendly API backed by Blaze’s speed — feels incredibly rewarding. I’m eager to contribute my skills to build a tool that makes schema validation faster, easier, and more accessible for Java developers everywhere.
is this project going to be your priority ?

@erosb
Copy link
Author

erosb commented Mar 3, 2025

Hello @Tanmay-Tripathi @hamdy-cufe-eng @Sahith53 @GANESHSHARMA1 @drLite35 @Karan-Palan and anyone whom it may concern, please find the qualification task for this project below:

Implement PoC-level integration of a C++ library

Requirements:

  • create minimal a java program that instantiates a C++ class
  • the object should be an instance of a class that resides in a namespace
  • for calling the native library, you can use FFM (preferred) or JNI (fallback)
  • add a unittest verifying that the program works and returns the expected validation failure

Bonus points / Nice To Have requirements:

  • instantiating a class in the sourcemeta::blaze namespace
  • creating a library with maven or gradle
  • showcasing both FFM and JNI
  • creating GitHub Action workflow for testing & building the project
  • implementing a testrunner that runs the json schema test suite on the wrapper library

@Tanmay-Tripathi
Copy link

hello @erosb i wanted to ask can we do this poc task for any c++ library for the purpose of demonstration or we should go on to clone and setup the codebase of sourcemeta/blaze and then do the poc ?

@erosb
Copy link
Author

erosb commented Mar 3, 2025

Hello @Tanmay-Tripathi , thanks for the question. Any c++ library can work, but using sourcemeta/blaze is a nice-to-have bonus point.

@GANESHSHARMA1
Copy link

Hi @erosb,

Implement PoC-level integration of a C++ library
Requirements:

- create minimal a java program that instantiates a C++ class
- the object should be an instance of a class that resides in a namespace
- for calling the native library, you can use FFM (preferred) or JNI (fallback)
- add a unittest verifying that the program works and returns the expected validation failure

Bonus points / Nice To Have requirements:

- instantiating a class in the sourcemeta::blaze namespace
- creating a library with maven or gradle
- showcasing both FFM and JNI
- creating GitHub Action workflow for testing & building the project
- implementing a testrunner that runs the json schema test suite on the wrapper library

Based on above requirements, I have started working on It. Soon I will submit PR.

@Honyii
Copy link
Contributor

Honyii commented Mar 5, 2025

Our qualification task is live! Huge thanks to @erosb for putting this together.
We’re excited to see your amazing submissions! Feel free to drop any questions or clarifications in the comments — happy contributing! 🚀

@hustlerZzZ
Copy link

@erosb @Honyii Heyyy, Prince this side, I completed the assignment.

@Dheerajmaddi
Copy link

Hello @erosb and @Honyii

I am Dheeraj with Full stack development expertise using Java, Spring Boot, React and JavaScript. This project, interests me to learn more about JSON Schema Org and contribute as a GSoC contributor for 2025.

What is the deadline to submit the qualification task Implement PoC-level integration of a C++ library?

@junaidzeb123
Copy link

Hi mentors and @erosb I have much intrest on building the java wrapper library. I have experience with Java (Spring) as well as c/c++. I have started working on above POC and started exploring the sourcemeta/blace codebase.
Thanks.

@erosb
Copy link
Author

erosb commented Mar 9, 2025

Hello @Dheerajmaddi , according to the GSoC 2025 schedule the proposal deadline (which includes the qualification task) is Apr 8. @Honyii please correct me if I'm wrong :) thanks!

@hustlerZzZ
Copy link

@erosb Heyy, Prince this side, I completed the qualification task.

@Honyii
Copy link
Contributor

Honyii commented Mar 9, 2025

Yes you're correct @erosb , application deadline is April, 8. GSoC timeline
cc @Dheerajmaddi

@hustlerZzZ
Copy link

hustlerZzZ commented Mar 9, 2025

Yes you're correct @erosb , application deadline is April, 8. GSoC timeline cc @Dheerajmaddi

Hey @Honyii i completed the following work

  • create minimal a java program that instantiates a C++ class
  • the object should be an instance of a class that resides in a namespace
  • for calling the native library, you can use FFM (preferred) or JNI (fallback)
  • add a unittest verifying that the program works and returns the expected validation failure
  • creating a library with maven or gradle
  • creating GitHub Action workflow for testing & building the project
  • implementing a testrunner that runs the json schema test suite on the wrapper library

what are the next steps

@Honyii
Copy link
Contributor

Honyii commented Mar 9, 2025

@hustlerZzZ The next step is to submit your qualification task and start creating your proposal @erosb will share how/where to submit the task during the week.

@hustlerZzZ
Copy link

@hustlerZzZ The next step is to submit your qualification task and start creating your proposal @erosb will share how/where to submit the task during the week.

Okay thanks!

@Dheerajmaddi
Copy link

Yes you're correct @erosb , application deadline is April, 8. GSoC timeline cc @Dheerajmaddi

Thank you for the quick update @erosb and @Honyii, will work on it and keep you guys posted.

@hamdy-fathi
Copy link

Hello @erosb ,
i have completed the following requirements:

  • create minimal a java program that instantiates a C++ class
  • the object should be an instance of a class that resides in a namespace
  • for calling the native library, you can use FFM (preferred) or JNI (fallback)
  • add a unittest verifying that the program works and returns the expected validation failure

Bonus points

  • showcasing both FFM and JNI
  • creating GitHub Action workflow for testing & building the project

@Elctrony
Copy link

Hello I am interested in both C/C++ and Java how can I start contributing and get more info about the desired work?

@erosb
Copy link
Author

erosb commented Mar 10, 2025

Hello Everyone, in case you want to work on the qualification task, please make sure to:

  • push it into a private GH repo
  • share the repo with @jviotti and me ( @erosb )

Thank you!

@Dheerajmaddi
Copy link

Hello Everyone, in case you want to work on the qualification task, please make sure to:

  • push it into a private GH repo
  • share the repo with @jviotti and me ( @erosb )

Thank you!

Sure @erosb

@Dheerajmaddi
Copy link

Hi Bence @erosb,

  • Qualification task completed. I pushed it to a private repo and shared with you and @jviotti.

  • Could you please provide guidance on the next step for proposal creation? Is there a preferred format or any guidelines?

Thank you!

@Honyii
Copy link
Contributor

Honyii commented Mar 12, 2025

@Dheerajmaddi welldone submitting your qualification task. We've created a proposal guide video and also added some resources, kindly check out this slack message; https://json-schema.slack.com/archives/C04MVQSRBRS/p1741358019012829

@Dheerajmaddi
Copy link

@Honyii Thanks for the update and resources! I tried accessing the Slack link, but it seems I don't have an account on that workspace. Could you please let me know how I can get access?

@Honyii
Copy link
Contributor

Honyii commented Mar 12, 2025

@Dheerajmaddi
Copy link

@Honyii Thank you, this link works!

@bsurajpatra
Copy link

@erosb
I'm eager to contribute to this project as a new learner. I’ve researched the required tech stack (Java, JNI/JNA, Maven/Gradle) and understand the overall workflow—from API design to deployment. This opportunity would be a great learning experience, and I'm committed to giving my best effort. I look forward to your guidance!

@erosb
Copy link
Author

erosb commented Mar 13, 2025

Hello @bsurajpatra , I'm happy to see your interest. You can proceed with implementing the qualification task and submit as described here.

@Alimilla-Abhinandan
Copy link

@erosb
I'm excited about the opportunity to contribute to this project as a new learner. I've taken the time to research the required tech stack, including Java, JNI/JNA, and Maven/Gradle, and I have a solid understanding of the overall workflow from API design to deployment. This role presents a valuable learning experience, and I'm fully committed to putting in my best effort. I look forward to your guidance and collaboration!

@Gundumi-Sri-Krishna-Sudhindra

@erosb
I'm thrilled to be part of this project as a new learner and eager to contribute meaningfully. I've thoroughly researched the required tech stack—Java, JNI/JNA, and Maven/Gradle—and have a strong grasp of the end-to-end workflow, from API design to deployment. This opportunity is an incredible learning experience, and I'm fully committed to putting in my best effort. I look forward to growing, collaborating, and making a positive impact alongside the team!

@Dheerajmaddi
Copy link

Hello @erosb, can you please provide details on sharing my initial proposal for review?

Thank you

@erosb
Copy link
Author

erosb commented Mar 15, 2025

Hello @Dheerajmaddi I think for an initial review it is OK to push your draft proposal into your current repository, in a PROPOSAL.md. Thanks.

@Dheerajmaddi
Copy link

Thank you @erosb! I added it to the current repository (PoC_Integration_Of_Library) for review.

@varsha-1110
Copy link

@erosb
I'm thrilled to join this project as a newcomer and eager to make meaningful contributions. I've invested time in thoroughly exploring the tech stack—Java, JNI/JNA, and Maven/Gradle—and have gained a solid understanding of the entire development cycle, from API architecture to deployment. This is a fantastic opportunity for growth, and I'm fully dedicated to putting in my best effort. Excited to collaborate, learn, and add value alongside the team!

@Tejaswi1305
Copy link

I'm excited to contribute to this project as a newcomer and eager to learn. I've researched the necessary tech stack (Java, JNI/JNA, Maven/Gradle) and have a solid understanding of the overall workflow, from API design to deployment. This opportunity represents a valuable learning experience, and I am committed to putting in my best effort. I look forward to your guidance!

@JAHNAVI-YERRAMSETTI
Copy link

@erosb
I'm excited to join this project as a newcomer and am keen to make meaningful contributions. I've spent time deeply exploring the tech stack—Java, JNI/JNA, and Maven/Gradle—and have developed a strong understanding of the full development cycle, from API architecture to deployment. This is a valuable opportunity for growth, and I'm fully committed to putting in my best effort. Looking forward to collaborating, learning, and adding value alongside the team!

@Gundumi-Sri-Krishna-Sudhindra

Hi @jviotti and @erosb ,

I have successfully completed the task and shared the repositories with you. Kindly verify the implementation at your convenience and let me know if any modifications are required.

Looking forward to your feedback.

Best regards,
@Gundumi-Sri-Krishna-Sudhindra

@bsurajpatra
Copy link

Hi @jviotti and @erosb ,

I've completed the qualification task and shared the repositories. Please review it when you can and let me know if any changes are needed.

Best,
@bsurajpatra

@varsha-1110
Copy link

Hi @jviotti and @erosb ,

I’m pleased to inform you that I have successfully completed the task and have shared the repositories with you. Please review the implementation at your convenience and let me know if any modifications or improvements are required.

Looking forward to your feedback.

Best regards,
@varsha-1110

@Alimilla-Abhinandan
Copy link

Hi @jviotti and @erosb,

I have successfully completed the task and shared the repositories with you. Please review the implementation at your convenience and let me know if any modifications are required.

Looking forward to your feedback.

Best regards,
@Alimilla-Abhinandan

@hamdy-fathi
Copy link

Hello @erosb, can you please provide of my initial pushed repo( week ago) , also please inform me for any modify / need

Thank you

@MadhavDhatrak
Copy link

Hello @erosb
I have uploaded my draft proposal PROPOSAL.md to my GitHub repo for an initial review. I would appreciate your feedback on it. Please let me know if any improvements are needed!

@VenkataSiriPriya
Copy link

@erosb
Thrilled to be part of this project! I've dived deep into the tech stack—Java, JNI/JNA, and Maven/Gradle—and developed a strong grasp of the full development cycle, from API design to deployment. This is a fantastic opportunity to grow, contribute, and collaborate with the team. I'm eager to learn, share insights, and make a meaningful impact. Let’s build something great together!

@Austin-George
Copy link

Hey all, @erosb ,
I am Austin George.
The project excites me because, I have done some research in which I came to know that in Maven repository there is no dependency which actually supports json schema validation. Of course, there are dependencies which provide methods to play with json object. I feel like creating a Java wrapper class will definitely help Java developer like me to use them in the projects.
I can see that the mentors here are help full. Feeling confident that they can help me around as well.
I have relevant skills in Java, Maven and C++. Mostly I will spend my time in parallel with other works.
Excited about this!... All the best!

@Yae-sine
Copy link

Hello @erosb,

I’m excited about the opportunity to contribute to this project! With experience in Java and the Spring framework, C++, Gradle/Maven, and JSON, I feel confident in my ability to bring value to the project.

I have worked extensively with these technologies and would love to apply my knowledge to an open-source project like this. While I’ve explored various technologies before, this would be my first time contributing to a real-world open-source project, making it an exciting challenge for me.

I would truly appreciate it if you could consider my application. Looking forward to collaborating and learning from the team!

Best regards,
YASSINE ABOULHAJ

@erosb
Copy link
Author

erosb commented Mar 31, 2025

Hello @Austin-George @Yae-sine , happy to see your interest in the project.
Please proceed with implementing the qualification task described here. You can push it into a private GH repo and share it with me and @jviotti . Also, please share your proposal in a PROPOSAL.md in the repo.
Thank you.

@Dheerajmaddi
Copy link

Hello @erosb , I have submitted my proposal as requested on the GSoC portal and connected with you on slack.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
gsoc Google Summer of Code Project Idea
Projects
None yet
Development

No branches or pull requests