Files
kopia/cli/command_cache_prefetch.go
Jarek Kowalski 926e14aacb feat(repository): added PrefetchObjects() API (#1779)
* feat(repository): added precaching of data blobs

* feat(repository): added utilities for converting ID slices to strings

* feat(repository): added object.PrefetchBackingContents

* feat(repository): implemented Repository.PrefetchObjects

* feat(cli): added 'cache prefetch' subcommand

* feat(repository): prefetch in parallel

* added tests
2022-03-06 14:30:58 -08:00

42 lines
1003 B
Go

package cli
import (
"context"
"github.com/pkg/errors"
"github.com/kopia/kopia/repo"
"github.com/kopia/kopia/repo/object"
"github.com/kopia/kopia/snapshot/snapshotfs"
)
type commandCachePrefetch struct {
objectIDs []string
}
func (c *commandCachePrefetch) setup(svc appServices, parent commandParent) {
cmd := parent.Command("prefetch", "Prefetches the provided objects into cache")
cmd.Action(svc.directRepositoryWriteAction(c.run))
cmd.Arg("object", "Object ID to prefetch").Required().StringsVar(&c.objectIDs)
}
func (c *commandCachePrefetch) run(ctx context.Context, rep repo.DirectRepositoryWriter) error {
var oids []object.ID
for _, s := range c.objectIDs {
oid, err := snapshotfs.ParseObjectIDWithPath(ctx, rep, s)
if err != nil {
return errors.Wrapf(err, "unable to parse ID: %v", s)
}
oids = append(oids, oid)
}
cids, err := rep.PrefetchObjects(ctx, oids)
log(ctx).Infof("prefetched %v contents", len(cids))
return errors.Wrap(err, "error prefetching")
}