Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/nevillelyh/protobuf-generic

Generic protobuf manipulation
https://github.com/nevillelyh/protobuf-generic

json protobuf scala

Last synced: 13 days ago
JSON representation

Generic protobuf manipulation

Awesome Lists containing this project

README

        

protobuf-generic
================

[![Build Status](https://img.shields.io/github/actions/workflow/status/nevillelyh/protobuf-generic/ci.yml?branch=main)](https://github.com/nevillelyh/protobuf-generic/actions?query=workflow%3ACI)
[![codecov.io](https://codecov.io/github/nevillelyh/protobuf-generic/coverage.svg?branch=master)](https://codecov.io/github/nevillelyh/protobuf-generic?branch=master)
[![GitHub license](https://img.shields.io/github/license/nevillelyh/protobuf-generic.svg)](./LICENSE)
[![Maven Central](https://img.shields.io/maven-central/v/me.lyh/protobuf-generic_2.13.svg)](https://maven-badges.herokuapp.com/maven-central/me.lyh/protobuf-generic_2.13)
[![Scala Steward badge](https://img.shields.io/badge/Scala_Steward-helping-brightgreen.svg?style=flat&logo=)](https://scala-steward.org)

Manipulate [Protocol Buffers](https://developers.google.com/protocol-buffers/) schemas and records in a generic manner without compiled classes, similar to [Avro](https://avro.apache.org/)'s `GenericRecord`.

# Usage

```scala
import me.lyh.protobuf.generic._

val schema1 = Schema.of[MyRecord] // generic representation of the protobuf schema
val jsonString = schema1.toJson // serialize to JSON
val schema2 = Schema.fromJson(jsonString) // deserialize from JSON

// read protobuf binary without original class
val bytes1: Array[Byte] = // binary MyRecord
val reader = GenericReader.of(schema2)
val record1 = reader.read(bytes1) // generic record, i.e. Map[String, Any]
val jsonRecord = record1.toJson // JSON string

// write protobuf binary without orignal class
val record2 = GenericRecord.fromJson(jsonRecord) // generic record, i.e. Map[String, Any]
val writer = GenericWriter.of(schema2)
val bytes2 = writer.write(record2) // binary MyRecord
```
# License

Copyright 2016 Neville Li.

Licensed under the Apache License, Version 2.0: http://www.apache.org/licenses/LICENSE-2.0