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.
Eduard S 2b4090bb7d Fix loading root key 4 years ago
.github/workflows Add golangci-lint to GHA & fix lint warnings 4 years ago
db Improve PebbleStorage.Iterate performance 4 years ago
LICENSE Init MT adapting from https://github.com/iden3/go-iden3-core/tree/v0.0.8 4 years ago
README.md Small fixes 4 years ago
go.mod Update to new Poseidon version 4 years ago
go.sum Update Circom proofs for compatibility,add parsers 4 years ago
merkletree.go Fix loading root key 4 years ago
merkletree_test.go Fix loading root key 4 years ago
node.go Add NewHashFromBytes & update comments 4 years ago
utils.go Update to new Poseidon version 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())

	v, err := mt.Get(key)
	asseert.Equal(t, value, v)

	value = big.NewInt(3)
	err = mt.Update(key, value)

	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)
}