From 6b378c5cc30b06a84f04f85605979aa54188833c Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Tue, 17 Oct 2023 12:57:15 -0400 Subject: [PATCH 1/8] the most basic dav (#218) --- cmd/drive/main.go | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) create mode 100644 cmd/drive/main.go diff --git a/cmd/drive/main.go b/cmd/drive/main.go new file mode 100644 index 000000000..b29faa3af --- /dev/null +++ b/cmd/drive/main.go @@ -0,0 +1,25 @@ +package main + +import ( + "golang.org/x/net/webdav" + "log" + "net/http" +) + +func main() { + dav := &webdav.Handler{ + FileSystem: webdav.Dir("."), + LockSystem: webdav.NewMemLS(), + Logger: func(r *http.Request, err error) { + if err != nil { + log.Printf("WEBDAV [%s]: %s, ERROR: %s\n", r.Method, r.URL, err) + } else { + log.Printf("WEBDAV [%s]: %s \n", r.Method, r.URL) + } + }, + } + http.Handle("/", dav) + if err := http.ListenAndServe("0.0.0.0:8800", nil); err != nil { + log.Fatalf("error serving: ") + } +} From 83e7263fdedf0a506f878e31f308a7c297cacc08 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Tue, 17 Oct 2023 13:04:09 -0400 Subject: [PATCH 2/8] new backend mode 'drive' (#218) --- .../014_v0_4_9_backend_mode_drive.sql | 3 ++ .../sqlite3/014_v0_4_9_backend_mode_drive.sql | 54 +++++++++++++++++++ 2 files changed, 57 insertions(+) create mode 100644 controller/store/sql/postgresql/014_v0_4_9_backend_mode_drive.sql create mode 100644 controller/store/sql/sqlite3/014_v0_4_9_backend_mode_drive.sql diff --git a/controller/store/sql/postgresql/014_v0_4_9_backend_mode_drive.sql b/controller/store/sql/postgresql/014_v0_4_9_backend_mode_drive.sql new file mode 100644 index 000000000..dce7a1e62 --- /dev/null +++ b/controller/store/sql/postgresql/014_v0_4_9_backend_mode_drive.sql @@ -0,0 +1,3 @@ +-- +migrate Up + +alter type backend_mode add value 'drive'; \ No newline at end of file diff --git a/controller/store/sql/sqlite3/014_v0_4_9_backend_mode_drive.sql b/controller/store/sql/sqlite3/014_v0_4_9_backend_mode_drive.sql new file mode 100644 index 000000000..9a78ea271 --- /dev/null +++ b/controller/store/sql/sqlite3/014_v0_4_9_backend_mode_drive.sql @@ -0,0 +1,54 @@ +-- +migrate Up + +alter table shares rename to shares_old; +create table shares ( + id integer primary key, + environment_id integer constraint fk_environments_shares references environments on delete cascade, + z_id string not null unique, + token string not null unique, + share_mode string not null, + backend_mode string not null, + frontend_selection string, + frontend_endpoint string, + backend_proxy_endpoint string, + reserved boolean not null default(false), + created_at datetime not null default(strftime('%Y-%m-%d %H:%M:%f', 'now')), + updated_at datetime not null default(strftime('%Y-%m-%d %H:%M:%f', 'now')), deleted boolean not null default(false), + + constraint chk_z_id check (z_id <> ''), + constraint chk_token check (token <> ''), + constraint chk_share_mode check (share_mode == 'public' or share_mode == 'private'), + constraint chk_backend_mode check (backend_mode == 'proxy' or backend_mode == 'web' or backend_mode == 'tcpTunnel' or backend_mode == 'udpTunnel' or backend_mode == 'caddy' or backend_mode == 'drive') +); +insert into shares select * from shares_old; +drop table shares_old; + +alter table frontends rename to frontends_old; +create table frontends ( + id integer primary key, + environment_id integer references environments(id), + token varchar(32) not null unique, + z_id varchar(32) not null, + public_name varchar(64) unique, + url_template varchar(1024), + reserved boolean not null default(false), + created_at datetime not null default(strftime('%Y-%m-%d %H:%M:%f', 'now')), + updated_at datetime not null default(strftime('%Y-%m-%d %H:%M:%f', 'now')), + deleted boolean not null default(false), + private_share_id integer references shares(id) +); +insert into frontends select * from frontends_old; +drop table frontends_old; + +alter table share_limit_journal rename to share_limit_journal_old; +create table share_limit_journal ( + id integer primary key, + share_id integer references shares(id), + rx_bytes bigint not null, + tx_bytes bigint not null, + action limit_action_type not null, + created_at datetime not null default(strftime('%Y-%m-%d %H:%M:%f', 'now')), + updated_at datetime not null default(strftime('%Y-%m-%d %H:%M:%f', 'now')) +); +insert into share_limit_journal select * from share_limit_journal_old; +drop table share_limit_journal_old; \ No newline at end of file From 952dd3aff0ec66b4da7c5167bf5b31ff1cbd08ba Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Tue, 17 Oct 2023 13:05:55 -0400 Subject: [PATCH 3/8] spec updated to include backend mode 'drive' (#218) --- rest_model_zrok/share_request.go | 7 +++++-- rest_server_zrok/embedded_spec.go | 6 ++++-- specs/zrok.yml | 2 +- 3 files changed, 10 insertions(+), 5 deletions(-) diff --git a/rest_model_zrok/share_request.go b/rest_model_zrok/share_request.go index c2c1d0122..8fddf3675 100644 --- a/rest_model_zrok/share_request.go +++ b/rest_model_zrok/share_request.go @@ -28,7 +28,7 @@ type ShareRequest struct { AuthUsers []*AuthUser `json:"authUsers"` // backend mode - // Enum: [proxy web tcpTunnel udpTunnel caddy] + // Enum: [proxy web tcpTunnel udpTunnel caddy drive] BackendMode string `json:"backendMode,omitempty"` // backend proxy endpoint @@ -114,7 +114,7 @@ var shareRequestTypeBackendModePropEnum []interface{} func init() { var res []string - if err := json.Unmarshal([]byte(`["proxy","web","tcpTunnel","udpTunnel","caddy"]`), &res); err != nil { + if err := json.Unmarshal([]byte(`["proxy","web","tcpTunnel","udpTunnel","caddy","drive"]`), &res); err != nil { panic(err) } for _, v := range res { @@ -138,6 +138,9 @@ const ( // ShareRequestBackendModeCaddy captures enum value "caddy" ShareRequestBackendModeCaddy string = "caddy" + + // ShareRequestBackendModeDrive captures enum value "drive" + ShareRequestBackendModeDrive string = "drive" ) // prop value enum diff --git a/rest_server_zrok/embedded_spec.go b/rest_server_zrok/embedded_spec.go index ee155ad8f..67e518997 100644 --- a/rest_server_zrok/embedded_spec.go +++ b/rest_server_zrok/embedded_spec.go @@ -1472,7 +1472,8 @@ func init() { "web", "tcpTunnel", "udpTunnel", - "caddy" + "caddy", + "drive" ] }, "backendProxyEndpoint": { @@ -3088,7 +3089,8 @@ func init() { "web", "tcpTunnel", "udpTunnel", - "caddy" + "caddy", + "drive" ] }, "backendProxyEndpoint": { diff --git a/specs/zrok.yml b/specs/zrok.yml index 88539ac19..1f5ebeb8c 100644 --- a/specs/zrok.yml +++ b/specs/zrok.yml @@ -971,7 +971,7 @@ definitions: type: string backendMode: type: string - enum: ["proxy", "web", "tcpTunnel", "udpTunnel", "caddy"] + enum: ["proxy", "web", "tcpTunnel", "udpTunnel", "caddy", "drive"] backendProxyEndpoint: type: string authScheme: From 23a6f128d0a66b8996e925735dbffc4fd12d6487 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Tue, 17 Oct 2023 13:23:16 -0400 Subject: [PATCH 4/8] lint --- controller/share.go | 2 -- 1 file changed, 2 deletions(-) diff --git a/controller/share.go b/controller/share.go index 860c106b3..5a6b31a86 100644 --- a/controller/share.go +++ b/controller/share.go @@ -19,8 +19,6 @@ func newShareHandler() *shareHandler { } func (h *shareHandler) Handle(params share.ShareParams, principal *rest_model_zrok.Principal) middleware.Responder { - logrus.Info("handling") - trx, err := str.Begin() if err != nil { logrus.Errorf("error starting transaction: %v", err) From 62cfa4a2c7bbf4fdb1e4121e93006b616c57408f Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Tue, 17 Oct 2023 13:49:44 -0400 Subject: [PATCH 5/8] the most basic drive implementation (#218) --- cmd/drive/main.go | 25 ---------- cmd/zrok/sharePrivate.go | 28 ++++++++++- endpoints/drive/backend.go | 72 +++++++++++++++++++++++++++++ endpoints/proxy/backend.go | 6 --- endpoints/proxy/caddyfileBackend.go | 4 -- endpoints/requests.go | 4 -- sdk/model.go | 1 + 7 files changed, 100 insertions(+), 40 deletions(-) delete mode 100644 cmd/drive/main.go create mode 100644 endpoints/drive/backend.go diff --git a/cmd/drive/main.go b/cmd/drive/main.go deleted file mode 100644 index b29faa3af..000000000 --- a/cmd/drive/main.go +++ /dev/null @@ -1,25 +0,0 @@ -package main - -import ( - "golang.org/x/net/webdav" - "log" - "net/http" -) - -func main() { - dav := &webdav.Handler{ - FileSystem: webdav.Dir("."), - LockSystem: webdav.NewMemLS(), - Logger: func(r *http.Request, err error) { - if err != nil { - log.Printf("WEBDAV [%s]: %s, ERROR: %s\n", r.Method, r.URL, err) - } else { - log.Printf("WEBDAV [%s]: %s \n", r.Method, r.URL) - } - }, - } - http.Handle("/", dav) - if err := http.ListenAndServe("0.0.0.0:8800", nil); err != nil { - log.Fatalf("error serving: ") - } -} diff --git a/cmd/zrok/sharePrivate.go b/cmd/zrok/sharePrivate.go index 3c6de78b3..8a25a7e95 100644 --- a/cmd/zrok/sharePrivate.go +++ b/cmd/zrok/sharePrivate.go @@ -4,6 +4,7 @@ import ( "fmt" tea "github.com/charmbracelet/bubbletea" "github.com/openziti/zrok/endpoints" + "github.com/openziti/zrok/endpoints/drive" "github.com/openziti/zrok/endpoints/proxy" "github.com/openziti/zrok/endpoints/tcpTunnel" "github.com/openziti/zrok/endpoints/udpTunnel" @@ -72,8 +73,11 @@ func (cmd *sharePrivateCommand) run(_ *cobra.Command, args []string) { target = args[0] cmd.headless = true + case "drive": + target = args[0] + default: - tui.Error(fmt.Sprintf("invalid backend mode '%v'; expected {proxy, web, tcpTunnel, udpTunnel, caddy}", cmd.backendMode), nil) + tui.Error(fmt.Sprintf("invalid backend mode '%v'; expected {proxy, web, tcpTunnel, udpTunnel, caddy, drive}", cmd.backendMode), nil) } root, err := environment.LoadRoot() @@ -238,6 +242,28 @@ func (cmd *sharePrivateCommand) run(_ *cobra.Command, args []string) { } }() + case "drive": + cfg := &drive.BackendConfig{ + IdentityPath: zif, + DriveRoot: target, + ShrToken: shr.Token, + Requests: requests, + } + + be, err := drive.NewBackend(cfg) + if err != nil { + if !panicInstead { + tui.Error("error creating drive backend", err) + } + panic(err) + } + + go func() { + if err := be.Run(); err != nil { + logrus.Errorf("error running drive backend: %v", err) + } + }() + default: tui.Error("invalid backend mode", nil) } diff --git a/endpoints/drive/backend.go b/endpoints/drive/backend.go new file mode 100644 index 000000000..f9147e8c1 --- /dev/null +++ b/endpoints/drive/backend.go @@ -0,0 +1,72 @@ +package drive + +import ( + "fmt" + "github.com/openziti/sdk-golang/ziti" + "github.com/openziti/sdk-golang/ziti/edge" + "github.com/openziti/zrok/endpoints" + "github.com/pkg/errors" + "golang.org/x/net/webdav" + "net/http" + "time" +) + +type BackendConfig struct { + IdentityPath string + DriveRoot string + ShrToken string + Requests chan *endpoints.Request +} + +type Backend struct { + cfg *BackendConfig + listener edge.Listener + handler http.Handler +} + +func NewBackend(cfg *BackendConfig) (*Backend, error) { + options := ziti.ListenOptions{ + ConnectTimeout: 5 * time.Minute, + MaxConnections: 64, + } + zcfg, err := ziti.NewConfigFromFile(cfg.IdentityPath) + if err != nil { + return nil, errors.Wrap(err, "error loading ziti identity") + } + zctx, err := ziti.NewContext(zcfg) + if err != nil { + return nil, errors.Wrap(err, "error loading ziti context") + } + listener, err := zctx.ListenWithOptions(cfg.ShrToken, &options) + if err != nil { + return nil, err + } + + handler := &webdav.Handler{ + FileSystem: webdav.Dir(cfg.DriveRoot), + LockSystem: webdav.NewMemLS(), + Logger: func(r *http.Request, err error) { + if cfg.Requests != nil { + cfg.Requests <- &endpoints.Request{ + Stamp: time.Now(), + RemoteAddr: fmt.Sprintf("%v", r.Header["X-Real-Ip"]), + Method: r.Method, + Path: r.URL.String(), + } + } + }, + } + + return &Backend{ + cfg: cfg, + listener: listener, + handler: handler, + }, nil +} + +func (b *Backend) Run() error { + if err := http.Serve(b.listener, b.handler); err != nil { + return err + } + return nil +} diff --git a/endpoints/proxy/backend.go b/endpoints/proxy/backend.go index 8b8b62e17..06858ada4 100644 --- a/endpoints/proxy/backend.go +++ b/endpoints/proxy/backend.go @@ -25,7 +25,6 @@ type BackendConfig struct { type Backend struct { cfg *BackendConfig - requests func() int32 listener edge.Listener handler http.Handler } @@ -56,7 +55,6 @@ func NewBackend(cfg *BackendConfig) (*Backend, error) { handler := util.NewProxyHandler(proxy) return &Backend{ cfg: cfg, - requests: handler.Requests, listener: listener, handler: handler, }, nil @@ -69,10 +67,6 @@ func (b *Backend) Run() error { return nil } -func (b *Backend) Requests() func() int32 { - return b.requests -} - func newReverseProxy(cfg *BackendConfig) (*httputil.ReverseProxy, error) { targetURL, err := url.Parse(cfg.EndpointAddress) if err != nil { diff --git a/endpoints/proxy/caddyfileBackend.go b/endpoints/proxy/caddyfileBackend.go index 30b98abbf..c69d93aa0 100644 --- a/endpoints/proxy/caddyfileBackend.go +++ b/endpoints/proxy/caddyfileBackend.go @@ -56,10 +56,6 @@ func (b *CaddyfileBackend) Run() error { return nil } -func (b *CaddyfileBackend) Requests() func() int32 { - return nil -} - func preprocessCaddyfile(inF string, shr *sdk.Share) (string, error) { input, err := os.ReadFile(inF) if err != nil { diff --git a/endpoints/requests.go b/endpoints/requests.go index 883a8d586..6eed60136 100644 --- a/endpoints/requests.go +++ b/endpoints/requests.go @@ -2,10 +2,6 @@ package endpoints import "time" -type RequestHandler interface { - Requests() func() int32 -} - type Request struct { Stamp time.Time RemoteAddr string diff --git a/sdk/model.go b/sdk/model.go index fa0310eb4..4592a4831 100644 --- a/sdk/model.go +++ b/sdk/model.go @@ -10,6 +10,7 @@ const ( TcpTunnelBackendMode BackendMode = "tcpTunnel" UdpTunnelBackendMode BackendMode = "udpTunnel" CaddyBackendMode BackendMode = "caddy" + DriveBackendMode BackendMode = "drive" ) type ShareMode string From e188f1243df354322ece4809133ab1153b864b7e Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Fri, 20 Oct 2023 16:13:00 -0400 Subject: [PATCH 6/8] support public and reserved shares with drives backend (#218) --- cmd/zrok/sharePublic.go | 28 +++++++++++++++++++++++++- cmd/zrok/shareReserved.go | 41 ++++++++++++++++++++++++++++++--------- 2 files changed, 59 insertions(+), 10 deletions(-) diff --git a/cmd/zrok/sharePublic.go b/cmd/zrok/sharePublic.go index b0181be3b..5aa1b0e18 100644 --- a/cmd/zrok/sharePublic.go +++ b/cmd/zrok/sharePublic.go @@ -4,6 +4,7 @@ import ( "fmt" tea "github.com/charmbracelet/bubbletea" "github.com/openziti/zrok/endpoints" + drive "github.com/openziti/zrok/endpoints/drive" "github.com/openziti/zrok/endpoints/proxy" "github.com/openziti/zrok/environment" "github.com/openziti/zrok/environment/env_core" @@ -42,7 +43,7 @@ func newSharePublicCommand() *sharePublicCommand { } command := &sharePublicCommand{cmd: cmd} cmd.Flags().StringArrayVar(&command.frontendSelection, "frontends", []string{"public"}, "Selected frontends to use for the share") - cmd.Flags().StringVarP(&command.backendMode, "backend-mode", "b", "proxy", "The backend mode {proxy, web, caddy}") + cmd.Flags().StringVarP(&command.backendMode, "backend-mode", "b", "proxy", "The backend mode {proxy, web, caddy, drive}") cmd.Flags().BoolVar(&command.headless, "headless", false, "Disable TUI and run headless") cmd.Flags().BoolVar(&command.insecure, "insecure", false, "Enable insecure TLS certificate validation for ") @@ -77,6 +78,9 @@ func (cmd *sharePublicCommand) run(_ *cobra.Command, args []string) { target = args[0] cmd.headless = true + case "drive": + target = args[0] + default: tui.Error(fmt.Sprintf("invalid backend mode '%v'; expected {proxy, web}", cmd.backendMode), nil) } @@ -204,6 +208,28 @@ func (cmd *sharePublicCommand) run(_ *cobra.Command, args []string) { } }() + case "drive": + cfg := &drive.BackendConfig{ + IdentityPath: zif, + DriveRoot: target, + ShrToken: shr.Token, + Requests: requests, + } + + be, err := drive.NewBackend(cfg) + if err != nil { + if !panicInstead { + tui.Error("error creating drive backend", err) + } + panic(err) + } + + go func() { + if err := be.Run(); err != nil { + logrus.Errorf("error running drive backend: %v", err) + } + }() + default: tui.Error("invalid backend mode", nil) } diff --git a/cmd/zrok/shareReserved.go b/cmd/zrok/shareReserved.go index c4e33bb72..1a74d0ff2 100644 --- a/cmd/zrok/shareReserved.go +++ b/cmd/zrok/shareReserved.go @@ -5,6 +5,7 @@ import ( tea "github.com/charmbracelet/bubbletea" httptransport "github.com/go-openapi/runtime/client" "github.com/openziti/zrok/endpoints" + "github.com/openziti/zrok/endpoints/drive" "github.com/openziti/zrok/endpoints/proxy" "github.com/openziti/zrok/endpoints/tcpTunnel" "github.com/openziti/zrok/endpoints/udpTunnel" @@ -123,7 +124,7 @@ func (cmd *shareReservedCommand) run(_ *cobra.Command, args []string) { proxy.SetCaddyLoggingWriter(mdl) } - requestsChan := make(chan *endpoints.Request, 1024) + requests := make(chan *endpoints.Request, 1024) switch resp.Payload.BackendMode { case "proxy": cfg := &proxy.BackendConfig{ @@ -131,7 +132,7 @@ func (cmd *shareReservedCommand) run(_ *cobra.Command, args []string) { EndpointAddress: target, ShrToken: shrToken, Insecure: cmd.insecure, - Requests: requestsChan, + Requests: requests, } be, err := proxy.NewBackend(cfg) @@ -153,7 +154,7 @@ func (cmd *shareReservedCommand) run(_ *cobra.Command, args []string) { IdentityPath: zif, WebRoot: target, ShrToken: shrToken, - Requests: requestsChan, + Requests: requests, } be, err := proxy.NewCaddyWebBackend(cfg) @@ -175,7 +176,7 @@ func (cmd *shareReservedCommand) run(_ *cobra.Command, args []string) { IdentityPath: zif, EndpointAddress: target, ShrToken: shrToken, - RequestsChan: requestsChan, + RequestsChan: requests, } be, err := tcpTunnel.NewBackend(cfg) @@ -197,7 +198,7 @@ func (cmd *shareReservedCommand) run(_ *cobra.Command, args []string) { IdentityPath: zif, EndpointAddress: target, ShrToken: shrToken, - RequestsChan: requestsChan, + RequestsChan: requests, } be, err := udpTunnel.NewBackend(cfg) @@ -218,7 +219,7 @@ func (cmd *shareReservedCommand) run(_ *cobra.Command, args []string) { cfg := &proxy.CaddyfileBackendConfig{ CaddyfilePath: target, Shr: &sdk.Share{Token: shrToken, FrontendEndpoints: []string{resp.Payload.FrontendEndpoint}}, - Requests: requestsChan, + Requests: requests, } be, err := proxy.NewCaddyfileBackend(cfg) @@ -235,6 +236,28 @@ func (cmd *shareReservedCommand) run(_ *cobra.Command, args []string) { } }() + case "drive": + cfg := &drive.BackendConfig{ + IdentityPath: zif, + DriveRoot: target, + ShrToken: shrToken, + Requests: requests, + } + + be, err := drive.NewBackend(cfg) + if err != nil { + if !panicInstead { + tui.Error("error creating drive backend", err) + } + panic(err) + } + + go func() { + if err := be.Run(); err != nil { + logrus.Errorf("error running drive backend: %v", err) + } + }() + default: tui.Error("invalid backend mode", nil) } @@ -249,7 +272,7 @@ func (cmd *shareReservedCommand) run(_ *cobra.Command, args []string) { } for { select { - case req := <-requestsChan: + case req := <-requests: logrus.Infof("%v -> %v %v", req.RemoteAddr, req.Method, req.Path) } } @@ -261,7 +284,7 @@ func (cmd *shareReservedCommand) run(_ *cobra.Command, args []string) { go func() { for { select { - case req := <-requestsChan: + case req := <-requests: prg.Send(req) } } @@ -271,6 +294,6 @@ func (cmd *shareReservedCommand) run(_ *cobra.Command, args []string) { tui.Error("An error occurred", err) } - close(requestsChan) + close(requests) } } From 2b26f71834fc101564eb30cc31415751a7488e9b Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Mon, 23 Oct 2023 11:34:23 -0400 Subject: [PATCH 7/8] changelog (#218) --- CHANGELOG.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 217ff3015..8a972b916 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,7 @@ +# v0.4.11 + +FEATURE: `zrok` Drives "Phase 1" (`p1`) functionality included in this release. This includes new `--backend-mode drive`, which accepts a folder path as a target. A `drive` share can be mounted as a network drive on Windows, macOS, and Linux, allowing full read/write access from all applications on those systems (https://github.com/openziti/zrok/issues/218) Subsequent releases will address CLI use cases and provide further refinements to the overall approach. + # v0.4.10 CHANGE: The public frontend configuration has been bumped from `v: 2` to `v: 3`. The `redirect_host`, `redirect_port` and `redirect_http_only` parameters have been removed. These three configuration options have been replaced with `bind_address`, `redirect_url` and `cookie_domain`. See the OAuth configuration guide at `docs/guides/self-hosting/oauth/configuring-oauth.md` for more details (https://github.com/openziti/zrok/issues/411) From a2e888385217d8264958df8c85072ae5e50195c9 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Mon, 30 Oct 2023 13:02:30 -0400 Subject: [PATCH 8/8] 'zrok reserve' fix for 'drive' backend (#218) --- cmd/zrok/reserve.go | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/cmd/zrok/reserve.go b/cmd/zrok/reserve.go index b6be848d0..4b029f110 100644 --- a/cmd/zrok/reserve.go +++ b/cmd/zrok/reserve.go @@ -34,7 +34,7 @@ func newReserveCommand() *reserveCommand { } command := &reserveCommand{cmd: cmd} cmd.Flags().StringArrayVar(&command.frontendSelection, "frontends", []string{"public"}, "Selected frontends to use for the share") - cmd.Flags().StringVarP(&command.backendMode, "backend-mode", "b", "proxy", "The backend mode {proxy, web, , caddy}") + cmd.Flags().StringVarP(&command.backendMode, "backend-mode", "b", "proxy", "The backend mode {proxy, web, , caddy, drive}") cmd.Flags().BoolVarP(&command.jsonOutput, "json-output", "j", false, "Emit JSON describing the created reserved share") cmd.Flags().StringArrayVar(&command.basicAuth, "basic-auth", []string{}, "Basic authentication users (,...)") cmd.Flags().StringVar(&command.oauthProvider, "oauth-provider", "", "Enable OAuth provider [google, github]") @@ -73,8 +73,11 @@ func (cmd *reserveCommand) run(_ *cobra.Command, args []string) { case "caddy": target = args[1] + case "drive": + target = args[1] + default: - tui.Error(fmt.Sprintf("invalid backend mode '%v'; expected {proxy, web, tcpTunnel, udpTunnel, caddy}", cmd.backendMode), nil) + tui.Error(fmt.Sprintf("invalid backend mode '%v'; expected {proxy, web, tcpTunnel, udpTunnel, caddy, drive}", cmd.backendMode), nil) } env, err := environment.LoadRoot()