serve webdav,serve restic: Fix flags so they use environment variables

See: https://forum.rclone.org/t/serve-restic-append-only-environment-variable/17050
This commit is contained in:
Nick Craig-Wood 2020-06-10 17:33:55 +01:00
parent 6a2b7b97d7
commit 63e6d9d2d1
2 changed files with 12 additions and 8 deletions

View file

@ -17,6 +17,7 @@ import (
"github.com/rclone/rclone/cmd/serve/httplib/serve" "github.com/rclone/rclone/cmd/serve/httplib/serve"
"github.com/rclone/rclone/fs" "github.com/rclone/rclone/fs"
"github.com/rclone/rclone/fs/accounting" "github.com/rclone/rclone/fs/accounting"
"github.com/rclone/rclone/fs/config/flags"
"github.com/rclone/rclone/fs/fserrors" "github.com/rclone/rclone/fs/fserrors"
"github.com/rclone/rclone/fs/operations" "github.com/rclone/rclone/fs/operations"
"github.com/rclone/rclone/fs/walk" "github.com/rclone/rclone/fs/walk"
@ -33,9 +34,10 @@ var (
func init() { func init() {
httpflags.AddFlags(Command.Flags()) httpflags.AddFlags(Command.Flags())
Command.Flags().BoolVar(&stdio, "stdio", false, "run an HTTP2 server on stdin/stdout") flagSet := Command.Flags()
Command.Flags().BoolVar(&appendOnly, "append-only", false, "disallow deletion of repository data") flags.BoolVarP(flagSet, &stdio, "stdio", "", false, "run an HTTP2 server on stdin/stdout")
Command.Flags().BoolVar(&privateRepos, "private-repos", false, "users can only access their private repo") flags.BoolVarP(flagSet, &appendOnly, "append-only", "", false, "disallow deletion of repository data")
flags.BoolVarP(flagSet, &privateRepos, "private-repos", "", false, "users can only access their private repo")
} }
// Command definition for cobra // Command definition for cobra

View file

@ -15,6 +15,7 @@ import (
"github.com/rclone/rclone/cmd/serve/proxy" "github.com/rclone/rclone/cmd/serve/proxy"
"github.com/rclone/rclone/cmd/serve/proxy/proxyflags" "github.com/rclone/rclone/cmd/serve/proxy/proxyflags"
"github.com/rclone/rclone/fs" "github.com/rclone/rclone/fs"
"github.com/rclone/rclone/fs/config/flags"
"github.com/rclone/rclone/fs/hash" "github.com/rclone/rclone/fs/hash"
"github.com/rclone/rclone/lib/errors" "github.com/rclone/rclone/lib/errors"
"github.com/rclone/rclone/vfs" "github.com/rclone/rclone/vfs"
@ -30,11 +31,12 @@ var (
) )
func init() { func init() {
httpflags.AddFlags(Command.Flags()) flagSet := Command.Flags()
vfsflags.AddFlags(Command.Flags()) httpflags.AddFlags(flagSet)
proxyflags.AddFlags(Command.Flags()) vfsflags.AddFlags(flagSet)
Command.Flags().StringVar(&hashName, "etag-hash", "", "Which hash to use for the ETag, or auto or blank for off") proxyflags.AddFlags(flagSet)
Command.Flags().BoolVar(&disableGETDir, "disable-dir-list", false, "Disable HTML directory list on GET request for a directory") flags.StringVarP(flagSet, &hashName, "etag-hash", "", "", "Which hash to use for the ETag, or auto or blank for off")
flags.BoolVarP(flagSet, &disableGETDir, "disable-dir-list", "", false, "Disable HTML directory list on GET request for a directory")
} }
// Command definition for cobra // Command definition for cobra