Files
kopia/cli/command_server_status.go
Jarek Kowalski 8515d050e5 test(infra): improved support for in-process testing (#2169)
* feat(infra): improved support for in-process testing

* support for killing of a running server using simulated Ctrl-C
* support for overriding os.Stdin
* migrated many tests from the exe runner to in-process runner

* added required indirection when defining Envar() so we can later override it in tests

* refactored CLI runners by moving environment overrides to CLITestEnv
2022-07-09 18:22:50 -07:00

47 lines
986 B
Go

package cli
import (
"context"
"github.com/pkg/errors"
"github.com/kopia/kopia/internal/apiclient"
"github.com/kopia/kopia/internal/serverapi"
)
type commandServerStatus struct {
sf serverClientFlags
out textOutput
remote bool
}
func (c *commandServerStatus) setup(svc appServices, parent commandParent) {
cmd := parent.Command("status", "Status of Kopia server")
cmd.Flag("remote", "Show remote sources").BoolVar(&c.remote)
c.sf.setup(svc, cmd)
c.out.setup(svc)
cmd.Action(svc.serverAction(&c.sf, c.runServerStatus))
}
func (c *commandServerStatus) runServerStatus(ctx context.Context, cli *apiclient.KopiaAPIClient) error {
var status serverapi.SourcesResponse
if err := cli.Get(ctx, "control/sources", nil, &status); err != nil {
return errors.Wrap(err, "unable to list sources")
}
for _, src := range status.Sources {
if src.Status == "REMOTE" && !c.remote {
continue
}
c.out.printStdout("%v: %v\n", src.Status, src.Source)
}
return nil
}