package gs import ( "path" "strings" "github.com/restic/restic/internal/errors" "github.com/restic/restic/internal/options" ) // Config contains all configuration necessary to connect to an gcs compatible // server. type Config struct { ProjectID string JSONKeyPath string Bucket string Prefix string Connections uint `option:"connections" help:"set a limit for the number of concurrent connections (default: 20)"` } // NewConfig returns a new Config with the default values filled in. func NewConfig() Config { return Config{ Connections: 5, } } func init() { options.Register("gs", Config{}) } // ParseConfig parses the string s and extracts the gcs config. The // supported configuration format is gs:bucketName:/[prefix]. func ParseConfig(s string) (interface{}, error) { if !strings.HasPrefix(s, "gs:") { return nil, errors.New("gs: invalid format") } // strip prefix "gs:" s = s[3:] // use the first entry of the path as the bucket name and the // remainder as prefix data := strings.SplitN(s, ":", 2) if len(data) < 2 { return nil, errors.New("gs: invalid format: bucket name or path not found") } bucket, path := data[0], path.Clean(data[1]) if strings.HasPrefix(path, "/") { path = path[1:] } cfg := NewConfig() cfg.Bucket = bucket cfg.Prefix = path return cfg, nil }