mirror of
https://github.com/kopia/kopia.git
synced 2026-01-26 15:28:06 -05:00
* repo: refactored client-specific options (hostname,username,description,readonly) into new struct that is JSON-compatible with current config * cli: added 'repository set-client' to configure parameters of connected repository * cli: cleaned up 'repository status' output
44 lines
1010 B
Go
44 lines
1010 B
Go
package cli
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/pkg/errors"
|
|
|
|
"github.com/kopia/kopia/repo"
|
|
"github.com/kopia/kopia/repo/manifest"
|
|
"github.com/kopia/kopia/snapshot"
|
|
"github.com/kopia/kopia/snapshot/policy"
|
|
)
|
|
|
|
func policyTargets(ctx context.Context, rep repo.Repository, globalFlag *bool, targetsFlag *[]string) ([]snapshot.SourceInfo, error) {
|
|
if *globalFlag == (len(*targetsFlag) > 0) {
|
|
return nil, errors.New("must pass either '--global' or a list of path targets")
|
|
}
|
|
|
|
if *globalFlag {
|
|
return []snapshot.SourceInfo{
|
|
policy.GlobalPolicySourceInfo,
|
|
}, nil
|
|
}
|
|
|
|
var res []snapshot.SourceInfo
|
|
|
|
for _, ts := range *targetsFlag {
|
|
// try loading policy by its manifest ID
|
|
if t, err := policy.GetPolicyByID(ctx, rep, manifest.ID(ts)); err == nil {
|
|
res = append(res, t.Target())
|
|
continue
|
|
}
|
|
|
|
target, err := snapshot.ParseSourceInfo(ts, rep.ClientOptions().Hostname, rep.ClientOptions().Username)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
res = append(res, target)
|
|
}
|
|
|
|
return res, nil
|
|
}
|