You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
arnaucube 3d1b7886ea Add DumpLeafs & ImportDumpedLeafs for MerkleTree backup functionality 4 years ago
.github/workflows Add GHA 4 years ago
LICENSE Init MT adapting from https://github.com/iden3/go-iden3-core/tree/v0.0.8 4 years ago
README.md Add mt.Delete(key) with test vectors 4 years ago
go.mod Add more tests, update README.md 4 years ago
go.sum Add used utils 4 years ago
merkletree.go Add DumpLeafs & ImportDumpedLeafs for MerkleTree backup functionality 4 years ago
merkletree_test.go Add DumpLeafs & ImportDumpedLeafs for MerkleTree backup functionality 4 years ago
node.go Add DumpLeafs & ImportDumpedLeafs for MerkleTree backup functionality 4 years ago
utils.go Add DumpLeafs & ImportDumpedLeafs for MerkleTree backup functionality 4 years ago

README.md

go-merkletree GoDoc Go Report Card Test

MerkleTree compatible with version from circomlib.

Adaptation of the merkletree from https://github.com/iden3/go-iden3-core/tree/v0.0.8 with several changes and more functionalities.

Usage

More detailed examples can be found at the tests, and in the documentation.

import (
	"fmt"
	"math/big"
	"testing"

	"github.com/iden3/go-iden3-core/db"
	"github.com/stretchr/testify/assert"
)

[...]

func TestExampleMerkleTree(t *testing.T) {
	mt, err := NewMerkleTree(db.NewMemoryStorage(), 10)
	assert.Nil(t, err)

	key := big.NewInt(1)
	value := big.NewInt(2)
	err = mt.Add(key, value)
	assert.Nil(t, err)
	fmt.Println(mt.Root().String())

	proof, err := mt.GenerateProof(key, nil)
	assert.Nil(t, err)

	assert.True(t, VerifyProof(mt.Root(), proof, key, value))

	err := mt.Delete(big.NewInt(1)) // delete the leaf of key=1
	assert.Nil(t, err)
}