Files
kopia/cli/command_index_list.go
Jarek Kowalski 62ad437bb6 Implemented epoch-based index manager (#1174)
* epoch: misc fixes and logging

* blob: misc helpers

* cli: removed useless 'repository upgrade', replaced by 'repository set-parameters'

* content: implemented indexBlobManagerV1 which uses epoch manager

* cli: commands to manipulate repository epoch parameters

* cli: commands to examine epoch-based indexes

* content: added test suite that uses epoch-based index manager

* content: fixed a ton of test data races caused by sharing blobtesting.DataMap

* cli: additional tests and validation for 'repository set-params'

* testing: replaced the use of suite with our own, since suite is not parallelizable
2021-07-06 21:38:08 -07:00

71 lines
1.8 KiB
Go

package cli
import (
"context"
"sort"
"github.com/pkg/errors"
"github.com/kopia/kopia/repo"
)
type commandIndexList struct {
blockIndexListSummary bool
blockIndexListIncludeSuperseded bool
blockIndexListSort string
jo jsonOutput
out textOutput
}
func (c *commandIndexList) setup(svc appServices, parent commandParent) {
cmd := parent.Command("list", "List content indexes").Alias("ls").Default()
cmd.Flag("summary", "Display index blob summary").BoolVar(&c.blockIndexListSummary)
cmd.Flag("superseded", "Include inactive index files superseded by compaction").BoolVar(&c.blockIndexListIncludeSuperseded)
cmd.Flag("sort", "Index blob sort order").Default("time").EnumVar(&c.blockIndexListSort, "time", "size", "name")
c.jo.setup(svc, cmd)
c.out.setup(svc)
cmd.Action(svc.directRepositoryReadAction(c.run))
}
func (c *commandIndexList) run(ctx context.Context, rep repo.DirectRepository) error {
var jl jsonList
jl.begin(&c.jo)
defer jl.end()
blks, err := rep.IndexBlobs(ctx, c.blockIndexListIncludeSuperseded)
if err != nil {
return errors.Wrap(err, "error listing index blobs")
}
switch c.blockIndexListSort {
case "time":
sort.Slice(blks, func(i, j int) bool {
return blks[i].Timestamp.Before(blks[j].Timestamp)
})
case "size":
sort.Slice(blks, func(i, j int) bool {
return blks[i].Length < blks[j].Length
})
case "name":
sort.Slice(blks, func(i, j int) bool {
return blks[i].BlobID < blks[j].BlobID
})
}
for _, b := range blks {
if c.jo.jsonOutput {
jl.emit(b)
} else {
c.out.printStdout("%-60v %10v %v %v\n", b.BlobID, b.Length, formatTimestampPrecise(b.Timestamp), b.Superseded)
}
}
if c.blockIndexListSummary && !c.jo.jsonOutput {
c.out.printStdout("total %v indexes\n", len(blks))
}
return nil
}