- package kv
-
- import (
- "bytes"
- "fmt"
-
- "github.com/tendermint/go-wire"
-
- db "github.com/tendermint/tmlibs/db"
-
- "github.com/tendermint/tendermint/state/txindex"
- "github.com/tendermint/tendermint/types"
- )
-
- // TxIndex is the simplest possible indexer, backed by Key-Value storage (levelDB).
- // It can only index transaction by its identifier.
- type TxIndex struct {
- store db.DB
- }
-
- // NewTxIndex returns new instance of TxIndex.
- func NewTxIndex(store db.DB) *TxIndex {
- return &TxIndex{store: store}
- }
-
- // Get gets transaction from the TxIndex storage and returns it or nil if the
- // transaction is not found.
- func (txi *TxIndex) Get(hash []byte) (*types.TxResult, error) {
- if len(hash) == 0 {
- return nil, txindex.ErrorEmptyHash
- }
-
- rawBytes := txi.store.Get(hash)
- if rawBytes == nil {
- return nil, nil
- }
-
- r := bytes.NewReader(rawBytes)
- var n int
- var err error
- txResult := wire.ReadBinary(&types.TxResult{}, r, 0, &n, &err).(*types.TxResult)
- if err != nil {
- return nil, fmt.Errorf("Error reading TxResult: %v", err)
- }
-
- return txResult, nil
- }
-
- // AddBatch writes a batch of transactions into the TxIndex storage.
- func (txi *TxIndex) AddBatch(b *txindex.Batch) error {
- storeBatch := txi.store.NewBatch()
- for _, result := range b.Ops {
- rawBytes := wire.BinaryBytes(&result)
- storeBatch.Set(result.Tx.Hash(), rawBytes)
- }
- storeBatch.Write()
- return nil
- }
|