mirror of
https://github.com/kopia/kopia.git
synced 2025-12-23 22:57:50 -05:00
- upgrade to golangci-lint 2.6.1 - updates for gosec - updates for govet - updates for perfsprint - updates modernize Leaves out modernize:omitempty due to conflicts with tests
80 lines
1.9 KiB
Go
80 lines
1.9 KiB
Go
package cli
|
|
|
|
import (
|
|
"context"
|
|
"slices"
|
|
|
|
"github.com/pkg/errors"
|
|
|
|
"github.com/kopia/kopia/internal/blobcrypto"
|
|
"github.com/kopia/kopia/internal/gather"
|
|
"github.com/kopia/kopia/repo"
|
|
)
|
|
|
|
type commandLogsShow struct {
|
|
logSessionIDs []string
|
|
|
|
crit logSelectionCriteria
|
|
out textOutput
|
|
}
|
|
|
|
func (c *commandLogsShow) setup(svc appServices, parent commandParent) {
|
|
cmd := parent.Command("show", "Show contents of the log. When no flags or arguments are specified, only the last log is shown.").Alias("cat")
|
|
|
|
cmd.Arg("session-id", "Log Session ID to show").StringsVar(&c.logSessionIDs)
|
|
|
|
cmd.Action(svc.directRepositoryReadAction(c.run))
|
|
|
|
c.crit.setup(cmd)
|
|
c.out.setup(svc)
|
|
}
|
|
|
|
func (c *commandLogsShow) run(ctx context.Context, rep repo.DirectRepository) error {
|
|
sessions, err := getLogSessions(ctx, rep.BlobReader())
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
sessions = c.crit.filterLogSessions(sessions)
|
|
|
|
if len(c.logSessionIDs) > 0 {
|
|
sessions = filterLogSessions(sessions, func(l *logSessionInfo) bool {
|
|
return slices.Contains(c.logSessionIDs, l.id)
|
|
})
|
|
}
|
|
|
|
if len(sessions) == 0 {
|
|
return errors.New("no logs found")
|
|
}
|
|
|
|
// by default show latest one
|
|
if !c.crit.any() {
|
|
sessions = sessions[len(sessions)-1:]
|
|
log(ctx).Infof("Showing the latest log (%v)", formatTimestamp(sessions[0].startTime))
|
|
}
|
|
|
|
var data gather.WriteBuffer
|
|
defer data.Close()
|
|
|
|
var decrypted gather.WriteBuffer
|
|
defer decrypted.Close()
|
|
|
|
for _, s := range sessions {
|
|
for _, bm := range s.segments {
|
|
if err := rep.BlobReader().GetBlob(ctx, bm.BlobID, 0, -1, &data); err != nil {
|
|
return errors.Wrap(err, "error getting log")
|
|
}
|
|
|
|
if err := blobcrypto.Decrypt(rep.ContentReader().ContentFormat(), data.Bytes(), bm.BlobID, &decrypted); err != nil {
|
|
return errors.Wrap(err, "error decrypting log")
|
|
}
|
|
|
|
if err := showContentWithFlags(c.out.stdout(), decrypted.Bytes().Reader(), true, false); err != nil {
|
|
log(ctx).Errorf("error showing log: %v", err)
|
|
}
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|