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

[Feature Request] Typescript Support #67

Open
elliotmjackson opened this issue Aug 10, 2023 · 27 comments
Open

[Feature Request] Typescript Support #67

elliotmjackson opened this issue Aug 10, 2023 · 27 comments
Labels
Feature New feature or request Language Support Interest in adding support for another language

Comments

@elliotmjackson
Copy link
Contributor

Feature description:
Introduce TypeScript support to the protovalidate library for performing runtime validation of Protocol Buffers messages in TypeScript projects. This was a feature request in protovalidates predecessor bufbuild/protoc-gen-validate#71

Problem it solves or use case:
The absence of TypeScript support in the protovalidate library hinders developers who work with Protocol Buffers and TypeScript. By adding TypeScript support, developers would be able to validate Protocol Buffers messages at runtime within their TypeScript applications, enhancing data integrity and reducing potential bugs related to data validation.

Proposed implementation or solution:
The proposed solution involves extending the existing protovalidate library to include TypeScript bindings and support. This includes defining TypeScript type definitions that correspond to Protocol Buffers message structures, and implementing runtime validation functions that work seamlessly with TypeScript types.

Contribution:
I am willing to contribute to this feature request by actively participating in discussions, assisting in defining TypeScript type definitions, and collaborating on the implementation of runtime validation functions for TypeScript. If necessary, I can also assist in writing tests and documentation to ensure the feature is thoroughly covered and well-documented.

Examples or references:
While protovalidate doesn't currently have TypeScript support, similar libraries like protobufjs and protobuf-ts provide inspiration for how TypeScript bindings and runtime validation can be integrated for Protocol Buffers messages in a type-safe manner.

Additional context:
Enabling TypeScript support in the protovalidate library would bridge the gap for developers who use Protocol Buffers in TypeScript projects, allowing them to perform runtime validation without relying on separate code generation processes. This aligns with the trend of utilizing TypeScript's strong typing and safety features in modern software development.

@elliotmjackson elliotmjackson added Feature New feature or request Language Support Interest in adding support for another language labels Aug 10, 2023
@nickwinger
Copy link

Good to hear that, maybe i can also contribute. It seems like zod is popular these days, you would instantly also have validation up to the frontend: https://zod.dev/

@akosyakov
Copy link

@elliotmjackson Hi there! Is there already something available to try out?

@nicksnyder
Copy link
Member

Working on this is on our roadmap, but progress is blocked on a solution to bufbuild/protobuf-es#397 (which is also on our roadmap). We will share any updates when we have them.

@kwhitehouse
Copy link

Hi there! Having typescript support for protovalidate would be fantastic.

I noticed in the linked blocker above that @protobuf-ts correctly includes options in the generated typescript. I was able to successfully test this out locally, such that my generated Typescript code contained custom proto options I defined using protovalidate syntax.

Would you folks be open to adding library functions that don't depend on protobuf-es while that blocker exists? For example, instead of providing a function public ValidationResult validate(Message msg) within the library, you could instead expect that:

  • Users of your library would define their validation in their .proto files (no change here).
  • Users of your library would be responsible for generating FieldConstraints and MessageConstraints and such. (As a user, I would rely on protobuf-ts to help me do this with its helper functions like readFieldOption.)
  • Your Typescript protovalidate library would provide methods like public ValidationResult validate(fieldValue Value, fieldConstraints FieldConstraints).

I believe with this structure, your library wouldn't have any need to inspect what options were defined on a given proto message. Instead, clients would be responsible for doing this themselves, and your protovalidate Typescript library would simply provide the validation component. Long-term it would obviously be wonderful to address bufbuild/protobuf-es#397 and have a simple validate method available that could parse custom proto options, similar to what's present in the Python and Golang and Java libraries you folks have developed. But it would definitely be helpful to have a stop-gap solution here that at least provided partial support for users of your protovalidate ecosystem!

@nicksnyder
Copy link
Member

Would you folks be open to adding library functions that don't depend on protobuf-es while that blocker exists?

No, we are focusing our attention on improving protobuf-es and are actively working on a solution to the blocking issue.

@kwhitehouse
Copy link

Would you folks be open to adding library functions that don't depend on protobuf-es while that blocker exists?

No, we are focusing our attention on improving protobuf-es and are actively working on a solution to the blocking issue.

Thanks Nick, that's great to hear! Do you folks have any ETA on when you might have the blocking issue resolved, and when it might be possible to start developing the protovalidate-typescript library? (I'd be happy to help out with the latter if you're looking for contributors!)

@nicksnyder
Copy link
Member

Rough guess is that we will be unblocked sometime in Q1. Appreciate the offer to help and will post to the issue if we could use help when the time comes.

@kwhitehouse
Copy link

Awesome, thanks, I'll check back in on this ticket in Q1!

@svdney4
Copy link

svdney4 commented Feb 7, 2024

Since protovalidate relies heavily on CEL does this mean that a CEL typescript evaluator is being developed as well?
And will there be a standalone version of the evaluator?
We have the need for a javascript/typescript CEL evaluator in our project but we can't seem to find a robust implementation at the moment.

@nicksnyder
Copy link
Member

Yes, supporting Protovalidate in TypeScript entails having a high quality open source CEL interpreter that works in all the environments we want (aka doesn't require Node.js APIs and doesn't require WASM). We are also unaware of any existing open source project that meets these requirements and so have already invested some time building our own implementation. We would open source this CEL implementation at the same time that we would open source support for Protovalidate TypeScript (which currently doesn't have a concrete timeline associated with it).

@shoshannamb
Copy link

Is there a clearer timeline on this? We're adding some protobuf-based metadata and being able to add validation would be really helpful. But we do need Typescript support.

@nicksnyder
Copy link
Member

We do not have a clearer timeline for this at this point. As we have been working on bufbuild/protobuf-es#397 and adding support for Protobuf Editions, it became apparent that we need to release a v2 of protobuf-es to support both of these things, so the rough timeline I gave earlier is no longer accurate. The good news is there is an alpha pre-release of protobuf-es v2 already, but there is more work to do. Once protobuf-es v2 is done and bufbuild/protobuf-es#397 is closed, work on Protovalidate TypeScript will not be blocked.

@shoshannamb
Copy link

Will we need to be on protobuf-es in order to use protovalidate? We currently use protobuf-ts.

@nicksnyder
Copy link
Member

Yes, you will need to be using protobuf-es. The runtimes differ to much for us to support both.

@loeffel-io
Copy link

Hey, any update on this? thank you

@soisyourface
Copy link

@nicksnyder,

looks like a bunch of progress has been made on protobuf-es v2, including a release of not just v2.0.0 but also v2.1.0. congrats on those huge milestones!

i'm assuming this means that protovalidate-ts is also in flight as it seems the identified blockers have been removed.

is there anything needed by the buf from the community on testing this or any other help?

@nicksnyder
Copy link
Member

In addition to releasing protobuf-es v2 we have also needed to follow through with connect-es v2 because that depends on protobuf-es. That body of work is wrapping up and we have started to internally discuss our plans to move Protovalidate TS forward, but don't have anything concrete to share publicly yet. I know there are a lot of people interested in this and we want it too!

@singh-hovr
Copy link

any updates?

@jafaircl
Copy link

jafaircl commented Oct 30, 2024

If it's helpful at all (even if just for prior art), I'm working on a CEL typescript implementation based on the cel-go package. The parser and checker work. Just need to finish implementing the interpreter. I know a CEL interpreter is a prerequisite for protovalidate and one doesn't currently exist. https://github.com/jafaircl/bearclaw/tree/issue-35/packages/cel

@StevenACoffman
Copy link

StevenACoffman commented Nov 11, 2024

@jafaircl Very exciting! I would love to see your CEL interpreter used for this, and I have a couple other personal use cases I'd like it for! I also found your https://github.com/jafaircl/cel

For others, it looks like you might be able to track this work jafaircl/bearclaw#35

@nicksnyder
Copy link
Member

We just shipped Connect-ES v2.0 and our intent is to start work on this next.

@loeffel-io
Copy link

loeffel-io commented Nov 21, 2024

@nicksnyder amazing! would be great btw if the we can keep the deps list tiny (against other ts/js libs out there).

do you think protovalidate-ts could be available in the next 3 months? (we want to use this in the browser btw for frontend validations)

@loeffel-io
Copy link

another one: i have no idea how the process works but this will be a protoc plugin which generates the ts/js files right? it would be really helpful if this plugin is written in go/rust or something that ca be statically compiled to make the integration into bazel easy

@timostamm
Copy link
Member

The TypeScript implementation will work the same way that other implementations do: They do not have a plugin and do not generate additional code. Instead, they retrieve the rules for a message from the descriptor embedded into the generated code via reflection.

@jafaircl
Copy link

There's still a good bit of work to be done but I just released an alpha of a CEL library for typescript. The eventual goal is complete feature parity with cel-go. The API is unlikely to change but some of the features may be missing or incomplete. It's mostly missing tests and optimizations. That being said, you should be able to do just about anything you would need to create a protovalidate library. It's integrated tightly with protobuf-es and supports parsing, type-checking, cost estimation and evaluation. https://www.npmjs.com/package/@bearclaw/cel

@MichaelHirn
Copy link

MichaelHirn commented Jan 13, 2025

@nicksnyder @timostamm @jafaircl gents, any updates you can share? Deciding whether to wait for ts support in protovalidate or consider different routes. Would love to use protovalidate with ts and, if useful, I can lend a hand and resources in getting over the line.

@nicksnyder
Copy link
Member

We have started working on this and our goal is to have a pre-1.0 release in Q2

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Feature New feature or request Language Support Interest in adding support for another language
Projects
None yet
Development

No branches or pull requests