Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
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
- Host: GitHub
- URL: https://github.com/nevillelyh/protobuf-generic
- Owner: nevillelyh
- License: apache-2.0
- Created: 2016-10-21T18:40:41.000Z (about 8 years ago)
- Default Branch: main
- Last Pushed: 2024-12-05T19:39:46.000Z (27 days ago)
- Last Synced: 2024-12-05T20:28:57.395Z (26 days ago)
- Topics: json, protobuf, scala
- Language: Scala
- Homepage:
- Size: 479 KB
- Stars: 35
- Watchers: 7
- Forks: 6
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
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
```
# LicenseCopyright 2016 Neville Li.
Licensed under the Apache License, Version 2.0: http://www.apache.org/licenses/LICENSE-2.0