Commit 034441cf authored by Jeromy's avatar Jeromy

use batching transaction interface from datastore

License: MIT
Signed-off-by: default avatarJeromy <jeromyj@gmail.com>
parent db38dad0
...@@ -77,6 +77,22 @@ func (s *BlockService) AddBlock(b *blocks.Block) (key.Key, error) { ...@@ -77,6 +77,22 @@ func (s *BlockService) AddBlock(b *blocks.Block) (key.Key, error) {
return k, nil return k, nil
} }
func (s *BlockService) AddBlocks(bs []*blocks.Block) ([]key.Key, error) {
err := s.Blockstore.PutMany(bs)
if err != nil {
return nil, err
}
var ks []key.Key
for _, b := range bs {
if err := s.worker.HasBlock(b); err != nil {
return nil, errors.New("blockservice is closed")
}
ks = append(ks, b.Key())
}
return ks, nil
}
// GetBlock retrieves a particular block from the service, // GetBlock retrieves a particular block from the service,
// Getting it from the datastore using the key (hash). // Getting it from the datastore using the key (hash).
func (s *BlockService) GetBlock(ctx context.Context, k key.Key) (*blocks.Block, error) { func (s *BlockService) GetBlock(ctx context.Context, k key.Key) (*blocks.Block, error) {
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment