package batchbuilder import ( "math/big" "github.com/hermeznetwork/hermez-node/common" "github.com/iden3/go-merkletree/db" ) // TODO move this file into StateDB, which Synchronizer will use in the disk DB, and BatchBuilder will use with the MemoryDB // GetBalance returns the balance for a given Idx from the DB func (bb *BatchBuilder) GetBalance(tx db.Tx, idx common.Idx) (*common.Leaf, error) { idxBytes := idx.Bytes() vBytes, err := tx.Get(idxBytes[:]) if err != nil { return nil, err } var b [32 * 5]byte copy(b[:], vBytes) leaf, err := common.LeafFromBytes(b) if err != nil { return nil, err } return leaf, nil } // CreateBalance stores the Leaf into the Idx position in the MerkleTree, also adds db entry for the Leaf value func (bb *BatchBuilder) CreateBalance(tx db.Tx, idx common.Idx, leaf common.Leaf) error { // store at the DB the key: v, and value: leaf.Bytes() v, err := leaf.HashValue() if err != nil { return err } leafBytes, err := leaf.Bytes() if err != nil { return err } // store the Leaf value tx.Put(v.Bytes(), leafBytes[:]) // Add k & v into the MT err = bb.mt.Add(idx.BigInt(), v) if err != nil { return err } return nil } // UpdateBalance updates the balance of the leaf of a given Idx. // If sending==true: will substract the amount, if sending==false will add the ammount func (bb *BatchBuilder) UpdateBalance(tx db.Tx, idx common.Idx, amount *big.Int, sending bool) error { leaf, err := bb.GetBalance(tx, idx) if err != nil { return err } // TODO add checks that the numbers are correct and there is no missing value neither impossible values if sending { leaf.Balance = new(big.Int).Sub(leaf.Balance, amount) } else { leaf.Balance = new(big.Int).Add(leaf.Balance, amount) } // store at the DB the key: v, and value: leaf.Bytes() v, err := leaf.HashValue() if err != nil { return err } leafBytes, err := leaf.Bytes() if err != nil { return err } // store the Leaf value tx.Put(v.Bytes(), leafBytes[:]) // Add k & v into the MT err = bb.mt.Update(idx.BigInt(), v) if err != nil { return err } return nil }