Parse extended options
This commit is contained in:
parent
a8a7701f60
commit
719bb18316
1 changed files with 72 additions and 32 deletions
|
@ -316,6 +316,59 @@ func OpenRepository(opts GlobalOptions) (*repository.Repository, error) {
|
||||||
return s, nil
|
return s, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func parseConfig(loc location.Location, opts options.Options) (interface{}, error) {
|
||||||
|
// only apply options for a particular backend here
|
||||||
|
opts = opts.Extract(loc.Scheme)
|
||||||
|
|
||||||
|
switch loc.Scheme {
|
||||||
|
case "local":
|
||||||
|
cfg := loc.Config.(local.Config)
|
||||||
|
if err := opts.Apply(loc.Scheme, &cfg); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
debug.Log("opening local repository at %#v", cfg)
|
||||||
|
return cfg, nil
|
||||||
|
|
||||||
|
case "sftp":
|
||||||
|
cfg := loc.Config.(sftp.Config)
|
||||||
|
if err := opts.Apply(loc.Scheme, &cfg); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
debug.Log("opening sftp repository at %#v", cfg)
|
||||||
|
return cfg, nil
|
||||||
|
|
||||||
|
case "s3":
|
||||||
|
cfg := loc.Config.(s3.Config)
|
||||||
|
if cfg.KeyID == "" {
|
||||||
|
cfg.KeyID = os.Getenv("AWS_ACCESS_KEY_ID")
|
||||||
|
}
|
||||||
|
|
||||||
|
if cfg.Secret == "" {
|
||||||
|
cfg.Secret = os.Getenv("AWS_SECRET_ACCESS_KEY")
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := opts.Apply(loc.Scheme, &cfg); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
debug.Log("opening s3 repository at %#v", cfg)
|
||||||
|
return cfg, nil
|
||||||
|
|
||||||
|
case "rest":
|
||||||
|
cfg := loc.Config.(rest.Config)
|
||||||
|
if err := opts.Apply(loc.Scheme, &cfg); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
debug.Log("opening rest repository at %#v", cfg)
|
||||||
|
return cfg, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil, errors.Fatalf("invalid backend: %q", loc.Scheme)
|
||||||
|
}
|
||||||
|
|
||||||
// Open the backend specified by a location config.
|
// Open the backend specified by a location config.
|
||||||
func open(s string, opts options.Options) (restic.Backend, error) {
|
func open(s string, opts options.Options) (restic.Backend, error) {
|
||||||
debug.Log("parsing location %v", s)
|
debug.Log("parsing location %v", s)
|
||||||
|
@ -326,27 +379,21 @@ func open(s string, opts options.Options) (restic.Backend, error) {
|
||||||
|
|
||||||
var be restic.Backend
|
var be restic.Backend
|
||||||
|
|
||||||
|
cfg, err := parseConfig(loc, opts)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
switch loc.Scheme {
|
switch loc.Scheme {
|
||||||
case "local":
|
case "local":
|
||||||
debug.Log("opening local repository at %#v", loc.Config)
|
be, err = local.Open(cfg.(local.Config))
|
||||||
be, err = local.Open(loc.Config.(local.Config))
|
|
||||||
case "sftp":
|
case "sftp":
|
||||||
debug.Log("opening sftp repository at %#v", loc.Config)
|
be, err = sftp.OpenWithConfig(cfg.(sftp.Config))
|
||||||
be, err = sftp.OpenWithConfig(loc.Config.(sftp.Config))
|
|
||||||
case "s3":
|
case "s3":
|
||||||
cfg := loc.Config.(s3.Config)
|
be, err = s3.Open(cfg.(s3.Config))
|
||||||
if cfg.KeyID == "" {
|
|
||||||
cfg.KeyID = os.Getenv("AWS_ACCESS_KEY_ID")
|
|
||||||
|
|
||||||
}
|
|
||||||
if cfg.Secret == "" {
|
|
||||||
cfg.Secret = os.Getenv("AWS_SECRET_ACCESS_KEY")
|
|
||||||
}
|
|
||||||
|
|
||||||
debug.Log("opening s3 repository at %#v", cfg)
|
|
||||||
be, err = s3.Open(cfg)
|
|
||||||
case "rest":
|
case "rest":
|
||||||
be, err = rest.Open(loc.Config.(rest.Config))
|
be, err = rest.Open(cfg.(rest.Config))
|
||||||
|
|
||||||
default:
|
default:
|
||||||
return nil, errors.Fatalf("invalid backend: %q", loc.Scheme)
|
return nil, errors.Fatalf("invalid backend: %q", loc.Scheme)
|
||||||
}
|
}
|
||||||
|
@ -366,27 +413,20 @@ func create(s string, opts options.Options) (restic.Backend, error) {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
cfg, err := parseConfig(loc, opts)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
switch loc.Scheme {
|
switch loc.Scheme {
|
||||||
case "local":
|
case "local":
|
||||||
debug.Log("create local repository at %#v", loc.Config)
|
return local.Create(cfg.(local.Config))
|
||||||
return local.Create(loc.Config.(local.Config))
|
|
||||||
case "sftp":
|
case "sftp":
|
||||||
debug.Log("create sftp repository at %#v", loc.Config)
|
return sftp.CreateWithConfig(cfg.(sftp.Config))
|
||||||
return sftp.CreateWithConfig(loc.Config.(sftp.Config))
|
|
||||||
case "s3":
|
case "s3":
|
||||||
cfg := loc.Config.(s3.Config)
|
return s3.Open(cfg.(s3.Config))
|
||||||
if cfg.KeyID == "" {
|
|
||||||
cfg.KeyID = os.Getenv("AWS_ACCESS_KEY_ID")
|
|
||||||
|
|
||||||
}
|
|
||||||
if cfg.Secret == "" {
|
|
||||||
cfg.Secret = os.Getenv("AWS_SECRET_ACCESS_KEY")
|
|
||||||
}
|
|
||||||
|
|
||||||
debug.Log("create s3 repository at %#v", loc.Config)
|
|
||||||
return s3.Open(cfg)
|
|
||||||
case "rest":
|
case "rest":
|
||||||
return rest.Create(loc.Config.(rest.Config))
|
return rest.Create(cfg.(rest.Config))
|
||||||
}
|
}
|
||||||
|
|
||||||
debug.Log("invalid repository scheme: %v", s)
|
debug.Log("invalid repository scheme: %v", s)
|
||||||
|
|
Loading…
Reference in a new issue