Skip to content

masroof-maindak/darakht

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

30 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Darakht

This library provides a somewhat robust & fairly performant* implementation to manage Merkle Trees in Go. The user-facing API provides functionality to construct a Merkle Tree from a provided file of arbitrary size, serialise or deserialise it, and to verify a content block's existence in said tree.

Currently, it does not provide support for sorting, which would allow us to return false from the Verify API sooner. This has been deliberately overlooked as sorting an arbitrarily-sized file is not viable in all scenarios. On known, or upper-bound file sizes (e.g the number of transactions in a bitcoin block), this is accomplish-able, but would be antithetical to the purpose of this project.

* Constructing a Merkle Tree from a 1GB file takes ~4 seconds on a quad-core i5-4278U.

Installation

go get github.com/masroof-maindak/darakht

Usage

import "github.com/masroof-maindak/darakht/pkg/merkletree"

// Generate Merkle Tree from file contents
mt1, err := merkletree.NewMerkleTreeFromFile(f, cnum)

// Serialise Merkle Tree to file
err = mt1.Serialise(fJson)

// Load Merkle Tree from saved JSON file
mt2, err := merkletree.NewMerkleTreeFromJSON(fJson)

// Compare two trees
equal := mt1.Equals(mt2)

// Validate a given content block's existence
exists, err := mt2.ProveMember(f, 4, 2)

Development

# Build
make build

# Generate random file
make rng
./rngF <fileName> <IntendedFileSize (MBs)>

# Run
./darakht <fileName> # OR: `make` to run on the sample file

# Run tests
make test