mirror of
https://github.com/kopia/kopia.git
synced 2026-01-01 19:17:56 -05:00
* linter: upgraded to 1.33, disabled some linters * lint: fixed 'errorlint' errors This ensures that all error comparisons use errors.Is() or errors.As(). We will be wrapping more errors going forward so it's important that error checks are not strict everywhere. Verified that there are no exceptions for errorlint linter which guarantees that. * lint: fixed or suppressed wrapcheck errors * lint: nolintlint and misc cleanups Co-authored-by: Julio López <julio+gh@kasten.io>
40 lines
962 B
Go
40 lines
962 B
Go
package cli
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
"github.com/pkg/errors"
|
|
|
|
"github.com/kopia/kopia/internal/apiclient"
|
|
"github.com/kopia/kopia/internal/serverapi"
|
|
)
|
|
|
|
var serverStartUploadCommand = serverCommands.Command("upload", "Trigger upload for one or more sources")
|
|
|
|
func init() {
|
|
serverStartUploadCommand.Action(serverAction(runServerStartUpload))
|
|
}
|
|
|
|
func runServerStartUpload(ctx context.Context, cli *apiclient.KopiaAPIClient) error {
|
|
return triggerActionOnMatchingSources(ctx, cli, "sources/upload")
|
|
}
|
|
|
|
func triggerActionOnMatchingSources(ctx context.Context, cli *apiclient.KopiaAPIClient, path string) error {
|
|
var resp serverapi.MultipleSourceActionResponse
|
|
|
|
if err := cli.Post(ctx, path, &serverapi.Empty{}, &resp); err != nil {
|
|
return errors.Wrapf(err, "unable to start upload on %v", path)
|
|
}
|
|
|
|
for src, resp := range resp.Sources {
|
|
if resp.Success {
|
|
fmt.Println("SUCCESS", src)
|
|
} else {
|
|
fmt.Println("FAILED", src)
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|