diff options
author | holisticode <holistic.computing@gmail.com> | 2019-02-06 19:16:43 +0800 |
---|---|---|
committer | Rafael Matias <rafael@skyle.net> | 2019-02-19 19:57:53 +0800 |
commit | 034f65e9e8976f3ca7d9622e4c362ad9c26ad5f7 (patch) | |
tree | c7a16205a52a88e27b625b952bb3c0a4772248f6 /swarm/storage/filestore.go | |
parent | 607a1968e6cc28194565242cc7d1faa7b2c8a44e (diff) | |
download | go-tangerine-034f65e9e8976f3ca7d9622e4c362ad9c26ad5f7.tar go-tangerine-034f65e9e8976f3ca7d9622e4c362ad9c26ad5f7.tar.gz go-tangerine-034f65e9e8976f3ca7d9622e4c362ad9c26ad5f7.tar.bz2 go-tangerine-034f65e9e8976f3ca7d9622e4c362ad9c26ad5f7.tar.lz go-tangerine-034f65e9e8976f3ca7d9622e4c362ad9c26ad5f7.tar.xz go-tangerine-034f65e9e8976f3ca7d9622e4c362ad9c26ad5f7.tar.zst go-tangerine-034f65e9e8976f3ca7d9622e4c362ad9c26ad5f7.zip |
swarm/storage: Get all chunk references for a given file (#19002)
(cherry picked from commit 3eff652a7b606f25d43bef6ccb998b8e306f8a75)
Diffstat (limited to 'swarm/storage/filestore.go')
-rw-r--r-- | swarm/storage/filestore.go | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/swarm/storage/filestore.go b/swarm/storage/filestore.go index 2d8d82d95..aebe03c1e 100644 --- a/swarm/storage/filestore.go +++ b/swarm/storage/filestore.go @@ -19,6 +19,7 @@ package storage import ( "context" "io" + "sort" ) /* @@ -96,3 +97,42 @@ func (f *FileStore) Store(ctx context.Context, data io.Reader, size int64, toEnc func (f *FileStore) HashSize() int { return f.hashFunc().Size() } + +// Public API. This endpoint returns all chunk hashes (only) for a given file +func (f *FileStore) GetAllReferences(ctx context.Context, data io.Reader, toEncrypt bool) (addrs AddressCollection, err error) { + // create a special kind of putter, which only will store the references + putter := &HashExplorer{ + hasherStore: NewHasherStore(f.ChunkStore, f.hashFunc, toEncrypt), + References: make([]Reference, 0), + } + // do the actual splitting anyway, no way around it + _, _, err = PyramidSplit(ctx, data, putter, putter) + if err != nil { + return nil, err + } + // collect all references + addrs = NewAddressCollection(0) + for _, ref := range putter.References { + addrs = append(addrs, Address(ref)) + } + sort.Sort(addrs) + return addrs, nil +} + +// HashExplorer is a special kind of putter which will only store chunk references +type HashExplorer struct { + *hasherStore + References []Reference +} + +// HashExplorer's Put will add just the chunk hashes to its `References` +func (he *HashExplorer) Put(ctx context.Context, chunkData ChunkData) (Reference, error) { + // Need to do the actual Put, which returns the references + ref, err := he.hasherStore.Put(ctx, chunkData) + if err != nil { + return nil, err + } + // internally store the reference + he.References = append(he.References, ref) + return ref, nil +} |