Simplify creation of the Config by moving it to a separate function. Simplify the parsing logic

by sharing the handling of s3: and s3://
This commit is contained in:
Christian Kemper 2016-02-14 09:10:45 -08:00
parent 74608531c7
commit 32c2cafa89

View file

@ -23,20 +23,12 @@ const defaultPrefix = "restic"
// s3:host:bucketname/prefix. The host can also be a valid s3 region // s3:host:bucketname/prefix. The host can also be a valid s3 region
// name. If no prefix is given the prefix "restic" will be used. // name. If no prefix is given the prefix "restic" will be used.
func ParseConfig(s string) (interface{}, error) { func ParseConfig(s string) (interface{}, error) {
var path []string
cfg := Config{}
switch { switch {
case strings.HasPrefix(s, "s3://"):
s = s[5:]
path = strings.SplitN(s, "/", 3)
cfg.Endpoint = path[0]
path = path[1:]
case strings.HasPrefix(s, "s3:http"): case strings.HasPrefix(s, "s3:http"):
s = s[3:]
// assume that a URL has been specified, parse it and // assume that a URL has been specified, parse it and
// use the host as the endpoint and the path as the // use the host as the endpoint and the path as the
// bucket name and prefix // bucket name and prefix
url, err := url.Parse(s) url, err := url.Parse(s[3:])
if err != nil { if err != nil {
return nil, err return nil, err
} }
@ -45,28 +37,36 @@ func ParseConfig(s string) (interface{}, error) {
return nil, errors.New("s3: bucket name not found") return nil, errors.New("s3: bucket name not found")
} }
cfg.Endpoint = url.Host path := strings.SplitN(url.Path[1:], "/", 2)
if url.Scheme == "http" { return createConfig(url.Host, path, url.Scheme == "http")
cfg.UseHTTP = true
}
path = strings.SplitN(url.Path[1:], "/", 2)
case strings.HasPrefix(s, "s3:"): case strings.HasPrefix(s, "s3:"):
// use the first entry of the path as the endpoint and the
// remainder as bucket name and prefix
s = s[3:] s = s[3:]
path = strings.SplitN(s, "/", 3) if strings.HasPrefix(s, "//") {
cfg.Endpoint = path[0] s = s[2:]
path = path[1:] }
path := strings.SplitN(s, "/", 3)
return createConfig(path[0], path[1:], false)
default: default:
return nil, errors.New("s3: invalid format") return nil, errors.New("s3: invalid format")
} }
if len(path) < 1 { }
return nil, errors.New("s3: invalid format, host/region or bucket name not found")
} func createConfig(endpoint string, path []string, useHttp bool) (interface{}, error) {
cfg.Bucket = path[0] var prefix string
if len(path) > 1 { switch {
cfg.Prefix = strings.TrimRight(path[1], "/") case len(path) < 1:
} else { return nil, errors.New("s3: invalid format, host/region or bucket name not found")
cfg.Prefix = defaultPrefix case len(path) == 1:
} prefix = defaultPrefix
default:
return cfg, nil prefix = strings.TrimRight(path[1], "/")
}
return Config{
Endpoint: endpoint,
UseHTTP: useHttp,
Bucket: path[0],
Prefix: prefix,
}, nil
} }