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:
parent
1fa8c185a8
commit
bca610fbde
2 changed files with 26 additions and 10 deletions
|
@ -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)
|
||||||
|
|
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue