0
Fork 0
mirror of https://github.com/caddyserver/caddy.git synced 2025-01-06 22:40:31 -05:00

httpcaddyfile: Minor fixes to parsing storage options

This commit is contained in:
Matthew Holt 2020-05-01 09:34:32 -06:00
parent 1fa8c185a8
commit bca610fbde
No known key found for this signature in database
GPG key ID: 2A349DD577D586A5
2 changed files with 26 additions and 10 deletions

View file

@ -136,14 +136,13 @@ func parseOptOrder(d *caddyfile.Dispenser) ([]string, error) {
} }
func parseOptStorage(d *caddyfile.Dispenser) (caddy.StorageConverter, error) { func parseOptStorage(d *caddyfile.Dispenser) (caddy.StorageConverter, error) {
if !d.Next() { if !d.Next() { // consume option name
return nil, d.ArgErr() return nil, d.ArgErr()
} }
args := d.RemainingArgs() if !d.Next() { // get storage module name
if len(args) != 1 {
return nil, d.ArgErr() return nil, d.ArgErr()
} }
modName := args[0] modName := d.Val()
mod, err := caddy.GetModule("caddy.storage." + modName) mod, err := caddy.GetModule("caddy.storage." + modName)
if err != nil { if err != nil {
return nil, d.Errf("getting storage module '%s': %v", modName, err) return nil, d.Errf("getting storage module '%s': %v", modName, err)

View file

@ -48,14 +48,31 @@ func (s *FileStorage) UnmarshalCaddyfile(d *caddyfile.Dispenser) error {
if !d.Next() { if !d.Next() {
return d.Err("expected tokens") return d.Err("expected tokens")
} }
if d.NextArg() {
s.Root = d.Val()
}
if d.NextArg() {
return d.ArgErr()
}
for nesting := d.Nesting(); d.NextBlock(nesting); { for nesting := d.Nesting(); d.NextBlock(nesting); {
switch d.Val() {
case "root":
if !d.NextArg() { if !d.NextArg() {
return d.ArgErr() return d.ArgErr()
} }
if s.Root != "" {
return d.Err("root already set")
}
s.Root = d.Val() s.Root = d.Val()
if d.NextArg() { if d.NextArg() {
return d.ArgErr() return d.ArgErr()
} }
default:
return d.Errf("unrecognized parameter '%s'", d.Val())
}
}
if s.Root == "" {
return d.Err("missing root path (to use default, omit storage config entirely)")
} }
return nil return nil
} }