Skip to content

syntifi/borshj

Repository files navigation

BorshJ

Java CI with Gradle GitHub tag (latest SemVer) Project license

BorshJ is an implementation of the Borsh binary serialization format for Java (and Kotlin, Scala, Clojure, Groovy, Jython, JRuby, etc.) projects.

Borsh stands for Binary Object Representation Serializer for Hashing. It is meant to be used in security-critical projects as it prioritizes consistency, safety, speed, and comes with a strict specification.

Features

Prerequisites

  • Java 8+ (this library is compatible with Android)

  • Gradle (when building from source code)

Installation

We are working on building release binaries. They will be available here soon.

In the meantime, if you wish to try out BorshJ, you will need to build the JAR file from source code yourself:

git clone https://github.com/syntifi/borshj.git

cd borshj

gradle jar

ls -l build/libs/borshj-$(cat VERSION).jar

Usage

To use the Borsh object serializer/deserializer, you need add just one import:

import com.syntifi.near.borshj.Borsh;

Examples

The following code examples further below are all predicated on this simple data class definition:

public class Point2D implements Borsh {
  @BorshField(order = 1)  
  public float x;
  
  @BorshField(order = 2)
  public float y;

  public Point2D() {}

  public Point2D(float x, float y) {
    this.x = x;
    this.y = y;
  }
}

NOTE: Only non-transient and annotated fields with BorshField will be serialized.

Serializing an object

To serialize a POJO, use the Borsh.serialize() method:

Point2D point = new Point2D(123.0, 456.0);

byte[] bytes = Borsh.serialize(point);

Deserializing an object

To deserialize a POJO, use the Borsh.deserialize() method:

Point2D point = Borsh.deserialize(bytes, Point2D.class);

Type Mappings

Borsh Java TypeScript
u8 integer byte number
u16 integer short number
u32 integer int number
u64 integer long BN
u128 integer BigInteger BN
f32 float float N/A
f64 float double N/A
fixed-size byte array byte[] Uint8Array
UTF-8 string String string
option Optional null or type
map Map N/A
set Set N/A
structs Object any
enum Enum -
subtypes interface -

Frequently Asked Questions

Q: Why does my class need a default constructor?

Classes used with Borsh.deserialize() must have a nullary default constructor because instances of the class will be instantiated through Java's reflection API.