protobuf-ts icon indicating copy to clipboard operation
protobuf-ts copied to clipboard

Protobuf and RPC for TypeScript

protobuf-ts <timostamm> npm

Protocol buffers and RPC for Node.js and the Web Browser. Pure TypeScript.

For the following .proto file:

syntax = "proto3";

message Person {
    string name = 1;
    uint64 id = 2;
    int32 years = 3;
    optional bytes data = 5;
}

protobuf-ts generates code that can be used like this:

let pete: Person = {
    name: "pete", 
    id: 123n, // it's a bigint
    years: 30
    // data: new Uint8Array([0xDE, 0xAD, 0xBE, 0xEF]);
};

let bytes = Person.toBinary(pete);
pete = Person.fromBinary(bytes);

pete = Person.fromJsonString('{"name":"pete", "id":"123", "years": 30}')

What are protocol buffers?

Protocol buffers is an interface definition language and binary serialization format.
Data structures defined in .proto files are platform-independent and can be used in many languages.
To learn more about the capabilities, please check the official language guide.

Quickstart

  • npm install @protobuf-ts/plugin

    installs the plugin and the compiler "protoc"

  • download the example file msg-readme.proto and place it into a protos/ directory

  • npx protoc --ts_out . --proto_path protos protos/msg-readme.proto

    generates msg-readme.ts
    if your protoc version asks for it, add the flag "--experimental_allow_proto3_optional"

Features

  • [x] implements the canonical proto3 JSON format
  • [x] implements the binary format and respects unknown fields
  • [x] strictly conforms to the protobuf spec
  • [x] generates clients that can be used with the gRPC web, Twirp or gRPC protocol
  • [x] generates native gRPC servers and clients for usage with @grpc/grpc-js
  • [x] supported by Twirp-TS for Twirp servers running on Node.js
  • [x] supports Angular dependency injection and pipes
  • [x] automatically installs protoc (with Yarn berry, please use node-protoc)
  • [x] can optimize for speed or code size
  • [x] supports proto3 optionals
  • [x] supports bigint for 64 bit integers
  • [x] every message type has methods to compare, clone, merge and type guard messages
  • [x] provides reflection information, including custom options
  • [x] supports all well-known-types with custom JSON representation and helper methods
  • [x] uses standard TypeScript enums
  • [x] runs in the Web Browser and in Node.js
  • [x] uses an algebraic data type for oneof groups
  • [x] can generate TypeScript or JavaScript
  • [x] available as a plugin on the BSR
  • [x] can be used with buf

Read the MANUAL to learn more.

Copyright

  • The code to decode UTF8 is Copyright 2016 by Daniel Wirtz, licensed under BSD-3-Clause.
  • The code to encode and decode varint is Copyright 2008 Google Inc., licensed under BSD-3-Clause.
  • The files plugin.ts and descriptor.ts are Copyright 2008 Google Inc., licensed under BSD-3-Clause
  • The gRPC status codes are Copyright 2016 gRPC authors, licensed under Apache-2.0.
  • The Twirp error codes are Copyright 2018 Twitch Interactive, Inc., licensed under Apache-2.0.
  • The proto files in test-fixtures/google and test-fixtures/conformance are Copyright Google Inc. / Google LLC, licensed under Apache-2.0 / BSD-3-Clause.
  • The proto files in test-fixtures/validate are Copyright 2019 Envoy Project Authors, licensed under Apache License 2.0.
  • All other files are licensed under Apache-2.0, see LICENSE.

Support

Buy Me A Coffee