github.com/keybase/client/go@v0.0.0-20241007131713-f10651d043c8/merkletree2/interfaces.go (about) 1 package merkletree2 2 3 import "github.com/keybase/client/go/logger" 4 5 // StorageEngine specifies how to store and lookup merkle tree nodes, roots and 6 // KeyEncodedValuePairs. You can use a DB like Dynamo or SQL to do this. 7 type StorageEngine interface { 8 ExecTransaction(ctx logger.ContextInterface, txFn func(logger.ContextInterface, Transaction) error) error 9 10 // StoreKVPairs stores the []KeyEncodedValuePair in the tree. 11 StoreKEVPairs(logger.ContextInterface, Transaction, Seqno, []KeyEncodedValuePair) error 12 13 // StoreNode stores the Hash (of a tree node) at the provided Position, 14 // Seqno in the tree. 15 StoreNode(logger.ContextInterface, Transaction, Seqno, *Position, Hash) error 16 17 // StoreNode takes multiple pairs of a position and a hash, and stores each 18 // hash (of a tree node) at the corresponding position and at the supplied 19 // Seqno in the tree. 20 StoreNodes(logger.ContextInterface, Transaction, Seqno, []PositionHashPair) error 21 22 // StoreRootMetadata stores the supplied RootMetadata, along with the 23 // corresponding Hash. 24 StoreRootMetadata(logger.ContextInterface, Transaction, RootMetadata, Hash) error 25 26 // LookupLatestRoot returns the latest root metadata and sequence number in 27 // the tree. If no root is found, then a NoLatestRootFound error is returned. 28 LookupLatestRoot(logger.ContextInterface, Transaction) (Seqno, RootMetadata, error) 29 30 // If there is no root for the specified Seqno, an InvalidSeqnoError is returned. 31 LookupRoot(logger.ContextInterface, Transaction, Seqno) (RootMetadata, error) 32 33 // Returns a RootMetadata given its Hash. 34 LookupRootFromHash(logger.ContextInterface, Transaction, Hash) (RootMetadata, error) 35 36 // LookupRoots returns the RootMetadata objects in the tree at the 37 // supplied Seqnos, ordered by seqno. 38 LookupRoots(logger.ContextInterface, Transaction, []Seqno) ([]RootMetadata, error) 39 40 // LookupRootHashes returns hashes of the RootMetadata in the tree at the 41 // corresponding Seqnos, ordered by seqno. 42 LookupRootHashes(logger.ContextInterface, Transaction, []Seqno) ([]Hash, error) 43 44 // LookupNode returns, for any position, the hash of the node with the 45 // highest Seqno s' <= s which was stored at position p. For example, if 46 // StoreNode(ctx, t, 5, p, hash5) and StoreNode(ctx, 6, p, hash6) and 47 // StoreNode(ctx, t, 8, p, hash8) were called for a specific position p, 48 // then LookupNode(ctx, t, 7, p) would return hash6. It returns an error if 49 // no such node was stored in the tree. 50 LookupNode(c logger.ContextInterface, t Transaction, s Seqno, p *Position) (Hash, error) 51 52 // LookupNodes is analogous to LookupNode, but it takes more than one 53 // position and returns pairs of a Position and the corresponding node Hash 54 // only for the nodes which are found in the tree. No error is returned if 55 // some of the positions are not found. 56 LookupNodes(c logger.ContextInterface, t Transaction, s Seqno, positions []Position) ([]PositionHashPair, error) 57 58 // LookupKVPair returns the KeyEncodedValuePair with the highest Seqno s1 <= 59 // s which was stored at position p (similarly to LookupNode). 60 LookupKEVPair(c logger.ContextInterface, t Transaction, s Seqno, k Key) (val EncodedValue, s1 Seqno, err error) 61 62 // LookupKeyHashPairsUnderPosition returns all KeyEncodedValuePairs (ordered by 63 // Key) which were stored at a position p' which is a descendent of p and at 64 // the maximum Seqno s' <= s (similarly to LookupNode). For each such pair, 65 // it returns the Seqno at which it was stored (in the same order). 66 LookupKEVPairsUnderPosition(ctx logger.ContextInterface, t Transaction, s Seqno, p *Position) ([]KeyEncodedValuePair, []Seqno, error) 67 68 // LookupAllKEVPairs returns all the keys and encoded values at the specified Seqno. 69 LookupAllKEVPairs(ctx logger.ContextInterface, t Transaction, s Seqno) ([]KeyEncodedValuePair, error) 70 } 71 72 // StorageEngineWithBlinding extends the StorageEngine interface with methods to 73 // support storing and retrieving the blinding secrets. 74 type StorageEngineWithBlinding interface { 75 StorageEngine 76 77 StoreMasterSecret(ctx logger.ContextInterface, t Transaction, s Seqno, ms MasterSecret) error 78 LookupMasterSecrets(ctx logger.ContextInterface, t Transaction, s []Seqno) (map[Seqno]MasterSecret, error) 79 } 80 81 // Transaction references a DB transaction. 82 type Transaction interface{} 83 84 type GetValueWithProofResponse struct { 85 _struct struct{} `codec:",toarray"` //nolint 86 Value EncodedValue `codec:"v"` 87 Proof MerkleInclusionProof `codec:"r,omitempty"` 88 }