From 917ba12ce69c34c3ed35d86159f3563b505d60b7 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Mon, 10 Jul 2023 13:44:58 -0400 Subject: [PATCH 01/28] refactoring around the new sdk approach (#34) --- sdk/model.go | 23 +++++++++++++++++++++++ sdk/share.go | 42 ++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 65 insertions(+) create mode 100644 sdk/model.go create mode 100644 sdk/share.go diff --git a/sdk/model.go b/sdk/model.go new file mode 100644 index 000000000..68779641c --- /dev/null +++ b/sdk/model.go @@ -0,0 +1,23 @@ +package sdk + +type BackendMode string + +const ( + ProxyBackendMode BackendMode = "proxy" + WebBackendMode BackendMode = "web" + TcpTunnelBackendMode BackendMode = "tcpTunnel" + UdpTunnelBackendMode BackendMode = "udpTunnel" +) + +type ShareMode string + +const ( + PrivateShareMode ShareMode = "private" + PublicShareMode ShareMode = "public" +) + +type ShareRequest struct { + BackendMode BackendMode + ShareMode ShareMode + Target string +} diff --git a/sdk/share.go b/sdk/share.go new file mode 100644 index 000000000..0a09e8d05 --- /dev/null +++ b/sdk/share.go @@ -0,0 +1,42 @@ +package sdk + +import ( + "github.com/openziti/zrok/rest_model_zrok" + "github.com/openziti/zrok/zrokdir" + "github.com/pkg/errors" +) + +type Share struct { + Token string +} + +func NewShare(request *ShareRequest) (*Share, error) { + switch request.ShareMode { + case PrivateShareMode: + return newPrivateShare(request) + case PublicShareMode: + return newPublicShare(request) + default: + return nil, errors.Errorf("unknown share mode '%v'", request.ShareMode) + } +} + +func newPrivateShare(request *ShareRequest) (*Share, error) { + return nil, nil +} + +func newPublicShare(request *ShareRequest) (*Share, error) { + return nil, nil +} + +func loadEnvironment(request *ShareRequest) (*zrokdir.ZrokDir, error) { + zrd, err := zrokdir.Load() + if err != nil { + return nil, errors.Wrap(err, "error loading zrokdir") + } + return zrd, nil +} + +func createShare(zrd *zrokdir.ZrokDir, req *rest_model_zrok.ShareRequest) (*Share, error) { + return nil, nil +} From ea71493f2f1362655672eadd691b1b31cd98006e Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Mon, 10 Jul 2023 16:41:16 -0400 Subject: [PATCH 02/28] zrokdir -> environment (#34) --- cmd/zrok/accessPrivate.go | 6 ++-- cmd/zrok/adminCreateFrontend.go | 4 +-- cmd/zrok/adminCreateIdentity.go | 8 ++--- cmd/zrok/adminDeleteFrontend.go | 4 +-- cmd/zrok/adminGenerate.go | 6 ++-- cmd/zrok/adminListFrontends.go | 4 +-- cmd/zrok/adminUpdateFrontend.go | 4 +-- cmd/zrok/configGet.go | 4 +-- cmd/zrok/configSet.go | 6 ++-- cmd/zrok/configUnset.go | 4 +-- cmd/zrok/console.go | 8 ++--- cmd/zrok/disable.go | 18 +++++----- cmd/zrok/enable.go | 12 +++---- cmd/zrok/invite.go | 6 ++-- cmd/zrok/release.go | 6 ++-- cmd/zrok/reserve.go | 6 ++-- cmd/zrok/sharePrivate.go | 8 ++--- cmd/zrok/sharePublic.go | 8 ++--- cmd/zrok/shareReserved.go | 8 ++--- cmd/zrok/status.go | 6 ++-- cmd/zrok/testLoopPublic.go | 8 ++--- controller/bootstrap.go | 8 ++--- docs/_attic/overview.md | 6 ++-- docs/getting-started.md | 4 +-- endpoints/proxy/frontend.go | 6 ++-- endpoints/publicProxy/http.go | 6 ++-- endpoints/tcpTunnel/frontend.go | 6 ++-- endpoints/udpTunnel/frontend.go | 6 ++-- {zrokdir => environment}/client.go | 8 ++--- {zrokdir => environment}/config.go | 4 +-- {zrokdir => environment}/environment.go | 4 +-- {zrokdir => environment}/identity.go | 4 +-- zrokdir/zrokdir.go => environment/root.go | 40 +++++++++++------------ {zrokdir => environment}/version.go | 6 ++-- sdk/share.go | 12 +++---- 35 files changed, 132 insertions(+), 132 deletions(-) rename {zrokdir => environment}/client.go (89%) rename {zrokdir => environment}/config.go (92%) rename {zrokdir => environment}/environment.go (94%) rename {zrokdir => environment}/identity.go (88%) rename zrokdir/zrokdir.go => environment/root.go (75%) rename {zrokdir => environment}/version.go (84%) diff --git a/cmd/zrok/accessPrivate.go b/cmd/zrok/accessPrivate.go index 9c23990e8..d97edac0f 100644 --- a/cmd/zrok/accessPrivate.go +++ b/cmd/zrok/accessPrivate.go @@ -8,11 +8,11 @@ import ( "github.com/openziti/zrok/endpoints/proxy" "github.com/openziti/zrok/endpoints/tcpTunnel" "github.com/openziti/zrok/endpoints/udpTunnel" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/rest_client_zrok" "github.com/openziti/zrok/rest_client_zrok/share" "github.com/openziti/zrok/rest_model_zrok" "github.com/openziti/zrok/tui" - "github.com/openziti/zrok/zrokdir" "github.com/sirupsen/logrus" "github.com/spf13/cobra" "net/url" @@ -48,9 +48,9 @@ func newAccessPrivateCommand() *accessPrivateCommand { func (cmd *accessPrivateCommand) run(_ *cobra.Command, args []string) { shrToken := args[0] - zrd, err := zrokdir.Load() + zrd, err := environment.Load() if err != nil { - tui.Error("unable to load zrokdir", err) + tui.Error("error loading environment", err) } if zrd.Env == nil { diff --git a/cmd/zrok/adminCreateFrontend.go b/cmd/zrok/adminCreateFrontend.go index 34588f6c3..c9da26270 100644 --- a/cmd/zrok/adminCreateFrontend.go +++ b/cmd/zrok/adminCreateFrontend.go @@ -3,10 +3,10 @@ package main import ( "os" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/rest_client_zrok/admin" "github.com/openziti/zrok/rest_model_zrok" "github.com/openziti/zrok/tui" - "github.com/openziti/zrok/zrokdir" "github.com/sirupsen/logrus" "github.com/spf13/cobra" ) @@ -35,7 +35,7 @@ func (cmd *adminCreateFrontendCommand) run(_ *cobra.Command, args []string) { publicName := args[1] urlTemplate := args[2] - zrd, err := zrokdir.Load() + zrd, err := environment.Load() if err != nil { panic(err) } diff --git a/cmd/zrok/adminCreateIdentity.go b/cmd/zrok/adminCreateIdentity.go index ee04feefd..61ae340f2 100644 --- a/cmd/zrok/adminCreateIdentity.go +++ b/cmd/zrok/adminCreateIdentity.go @@ -3,7 +3,7 @@ package main import ( "fmt" "github.com/openziti/zrok/rest_client_zrok/admin" - "github.com/openziti/zrok/zrokdir" + "github.com/openziti/zrok/environment" "github.com/sirupsen/logrus" "github.com/spf13/cobra" "os" @@ -32,7 +32,7 @@ func newAdminCreateIdentity() *adminCreateIdentity { func (cmd *adminCreateIdentity) run(_ *cobra.Command, args []string) { name := args[0] - zif, err := zrokdir.ZitiIdentityFile(name) + zif, err := environment.ZitiIdentityFile(name) if err != nil { panic(err) } @@ -41,7 +41,7 @@ func (cmd *adminCreateIdentity) run(_ *cobra.Command, args []string) { os.Exit(1) } - zrd, err := zrokdir.Load() + zrd, err := environment.Load() if err != nil { panic(err) } @@ -59,7 +59,7 @@ func (cmd *adminCreateIdentity) run(_ *cobra.Command, args []string) { panic(err) } - if err := zrokdir.SaveZitiIdentity(name, resp.Payload.Cfg); err != nil { + if err := environment.SaveZitiIdentity(name, resp.Payload.Cfg); err != nil { panic(err) } diff --git a/cmd/zrok/adminDeleteFrontend.go b/cmd/zrok/adminDeleteFrontend.go index 071889bed..4783fdeb7 100644 --- a/cmd/zrok/adminDeleteFrontend.go +++ b/cmd/zrok/adminDeleteFrontend.go @@ -3,7 +3,7 @@ package main import ( "github.com/openziti/zrok/rest_client_zrok/admin" "github.com/openziti/zrok/rest_model_zrok" - "github.com/openziti/zrok/zrokdir" + "github.com/openziti/zrok/environment" "github.com/sirupsen/logrus" "github.com/spf13/cobra" ) @@ -30,7 +30,7 @@ func newAdminDeleteFrontendCommand() *adminDeleteFrontendCommand { func (cmd *adminDeleteFrontendCommand) run(_ *cobra.Command, args []string) { feToken := args[0] - zrd, err := zrokdir.Load() + zrd, err := environment.Load() if err != nil { panic(err) } diff --git a/cmd/zrok/adminGenerate.go b/cmd/zrok/adminGenerate.go index afe5aa15c..26e7951a1 100644 --- a/cmd/zrok/adminGenerate.go +++ b/cmd/zrok/adminGenerate.go @@ -3,9 +3,9 @@ package main import ( "fmt" "github.com/jaevor/go-nanoid" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/rest_client_zrok/admin" "github.com/openziti/zrok/rest_model_zrok" - "github.com/openziti/zrok/zrokdir" "github.com/sirupsen/logrus" "github.com/spf13/cobra" ) @@ -43,9 +43,9 @@ func (cmd *adminGenerateCommand) run(_ *cobra.Command, args []string) { } } - zrd, err := zrokdir.Load() + zrd, err := environment.Load() if err != nil { - logrus.Error("error loading zrokdir", err) + logrus.Error("error loading environment", err) } zrok, err := zrd.Client() diff --git a/cmd/zrok/adminListFrontends.go b/cmd/zrok/adminListFrontends.go index 8a8fbf640..5d63b3759 100644 --- a/cmd/zrok/adminListFrontends.go +++ b/cmd/zrok/adminListFrontends.go @@ -4,7 +4,7 @@ import ( "fmt" "github.com/jedib0t/go-pretty/v6/table" "github.com/openziti/zrok/rest_client_zrok/admin" - "github.com/openziti/zrok/zrokdir" + "github.com/openziti/zrok/environment" "github.com/spf13/cobra" "os" "time" @@ -31,7 +31,7 @@ func newAdminListFrontendsCommand() *adminListFrontendsCommand { } func (cmd *adminListFrontendsCommand) run(_ *cobra.Command, _ []string) { - zrd, err := zrokdir.Load() + zrd, err := environment.Load() if err != nil { panic(err) } diff --git a/cmd/zrok/adminUpdateFrontend.go b/cmd/zrok/adminUpdateFrontend.go index 2605458a0..1de2d9676 100644 --- a/cmd/zrok/adminUpdateFrontend.go +++ b/cmd/zrok/adminUpdateFrontend.go @@ -3,7 +3,7 @@ package main import ( "github.com/openziti/zrok/rest_client_zrok/admin" "github.com/openziti/zrok/rest_model_zrok" - "github.com/openziti/zrok/zrokdir" + "github.com/openziti/zrok/environment" "github.com/sirupsen/logrus" "github.com/spf13/cobra" ) @@ -38,7 +38,7 @@ func (cmd *adminUpdateFrontendCommand) run(_ *cobra.Command, args []string) { panic("must specify at least one of public name or url template") } - zrd, err := zrokdir.Load() + zrd, err := environment.Load() if err != nil { panic(err) } diff --git a/cmd/zrok/configGet.go b/cmd/zrok/configGet.go index 5340cf4b8..544177724 100644 --- a/cmd/zrok/configGet.go +++ b/cmd/zrok/configGet.go @@ -2,7 +2,7 @@ package main import ( "fmt" - "github.com/openziti/zrok/zrokdir" + "github.com/openziti/zrok/environment" "github.com/spf13/cobra" ) @@ -28,7 +28,7 @@ func newConfigGetCommand() *configGetCommand { func (cmd *configGetCommand) run(_ *cobra.Command, args []string) { configName := args[0] - zrd, err := zrokdir.Load() + zrd, err := environment.Load() if err != nil { panic(err) } diff --git a/cmd/zrok/configSet.go b/cmd/zrok/configSet.go index a72d29f40..13e9d6ce0 100644 --- a/cmd/zrok/configSet.go +++ b/cmd/zrok/configSet.go @@ -5,8 +5,8 @@ import ( "net/url" "os" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/tui" - "github.com/openziti/zrok/zrokdir" "github.com/spf13/cobra" ) @@ -33,7 +33,7 @@ func (cmd *configSetCommand) run(_ *cobra.Command, args []string) { configName := args[0] value := args[1] - zrd, err := zrokdir.Load() + zrd, err := environment.Load() if err != nil { panic(err) } @@ -42,7 +42,7 @@ func (cmd *configSetCommand) run(_ *cobra.Command, args []string) { switch configName { case "apiEndpoint": if zrd.Cfg == nil { - zrd.Cfg = &zrokdir.Config{} + zrd.Cfg = &environment.Config{} } ok, err := isFullyValidUrl(value) if err != nil { diff --git a/cmd/zrok/configUnset.go b/cmd/zrok/configUnset.go index 6d27a930d..2aa506123 100644 --- a/cmd/zrok/configUnset.go +++ b/cmd/zrok/configUnset.go @@ -3,7 +3,7 @@ package main import ( "fmt" "github.com/openziti/zrok/tui" - "github.com/openziti/zrok/zrokdir" + "github.com/openziti/zrok/environment" "github.com/spf13/cobra" "os" ) @@ -30,7 +30,7 @@ func newConfigUnsetCommand() *configUnsetCommand { func (cmd *configUnsetCommand) run(_ *cobra.Command, args []string) { configName := args[0] - zrd, err := zrokdir.Load() + zrd, err := environment.Load() if err != nil { panic(err) } diff --git a/cmd/zrok/console.go b/cmd/zrok/console.go index 1650e6c1b..83eb97c3c 100644 --- a/cmd/zrok/console.go +++ b/cmd/zrok/console.go @@ -2,8 +2,8 @@ package main import ( "fmt" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/tui" - "github.com/openziti/zrok/zrokdir" "github.com/spf13/cobra" ) @@ -27,12 +27,12 @@ func newConsoleCommand() *consoleCommand { } func (cmd *consoleCommand) run(_ *cobra.Command, _ []string) { - zrd, err := zrokdir.Load() + env, err := environment.Load() if err != nil { - tui.Error("unable to load zrokdir", err) + tui.Error("unable to load environment", err) } - apiEndpoint, _ := zrd.ApiEndpoint() + apiEndpoint, _ := env.ApiEndpoint() if err := openBrowser(apiEndpoint); err != nil { tui.Error(fmt.Sprintf("unable to open '%v'", apiEndpoint), err) } diff --git a/cmd/zrok/disable.go b/cmd/zrok/disable.go index d1382e8cf..17e804d03 100644 --- a/cmd/zrok/disable.go +++ b/cmd/zrok/disable.go @@ -2,11 +2,11 @@ package main import ( "fmt" - httptransport "github.com/go-openapi/runtime/client" - "github.com/openziti/zrok/rest_client_zrok/environment" + httpTransport "github.com/go-openapi/runtime/client" + "github.com/openziti/zrok/environment" + restEnvironment "github.com/openziti/zrok/rest_client_zrok/environment" "github.com/openziti/zrok/rest_model_zrok" "github.com/openziti/zrok/tui" - "github.com/openziti/zrok/zrokdir" "github.com/sirupsen/logrus" "github.com/spf13/cobra" ) @@ -31,10 +31,10 @@ func newDisableCommand() *disableCommand { } func (cmd *disableCommand) run(_ *cobra.Command, _ []string) { - zrd, err := zrokdir.Load() + zrd, err := environment.Load() if err != nil { if !panicInstead { - tui.Error("unable to load zrokdir", err) + tui.Error("unable to load environment", err) } panic(err) } @@ -50,8 +50,8 @@ func (cmd *disableCommand) run(_ *cobra.Command, _ []string) { } panic(err) } - auth := httptransport.APIKeyAuth("X-TOKEN", "header", zrd.Env.Token) - req := environment.NewDisableParams() + auth := httpTransport.APIKeyAuth("X-TOKEN", "header", zrd.Env.Token) + req := restEnvironment.NewDisableParams() req.Body = &rest_model_zrok.DisableRequest{ Identity: zrd.Env.ZId, } @@ -59,13 +59,13 @@ func (cmd *disableCommand) run(_ *cobra.Command, _ []string) { if err != nil { logrus.Warnf("share cleanup failed (%v); will clean up local environment", err) } - if err := zrokdir.DeleteEnvironment(); err != nil { + if err := environment.DeleteEnvironment(); err != nil { if !panicInstead { tui.Error("error removing zrok environment", err) } panic(err) } - if err := zrokdir.DeleteZitiIdentity("backend"); err != nil { + if err := environment.DeleteZitiIdentity("backend"); err != nil { if !panicInstead { tui.Error("error removing zrok backend identity", err) } diff --git a/cmd/zrok/enable.go b/cmd/zrok/enable.go index d9790f951..c6bf946c7 100644 --- a/cmd/zrok/enable.go +++ b/cmd/zrok/enable.go @@ -10,10 +10,10 @@ import ( "github.com/charmbracelet/bubbles/spinner" tea "github.com/charmbracelet/bubbletea" httptransport "github.com/go-openapi/runtime/client" - "github.com/openziti/zrok/rest_client_zrok/environment" + "github.com/openziti/zrok/environment" + restEnvironment "github.com/openziti/zrok/rest_client_zrok/environment" "github.com/openziti/zrok/rest_model_zrok" "github.com/openziti/zrok/tui" - "github.com/openziti/zrok/zrokdir" "github.com/shirou/gopsutil/v3/host" "github.com/spf13/cobra" ) @@ -42,7 +42,7 @@ func newEnableCommand() *enableCommand { } func (cmd *enableCommand) run(_ *cobra.Command, args []string) { - zrd, err := zrokdir.Load() + zrd, err := environment.Load() if err != nil { panic(err) } @@ -70,7 +70,7 @@ func (cmd *enableCommand) run(_ *cobra.Command, args []string) { tui.Error("error creating service client", err) } auth := httptransport.APIKeyAuth("X-TOKEN", "header", token) - req := environment.NewEnableParams() + req := restEnvironment.NewEnableParams() req.Body = &rest_model_zrok.EnableRequest{ Description: cmd.description, Host: hostDetail, @@ -117,7 +117,7 @@ func (cmd *enableCommand) run(_ *cobra.Command, args []string) { prg.Send("writing the environment details...") } apiEndpoint, _ := zrd.ApiEndpoint() - zrd.Env = &zrokdir.Environment{Token: token, ZId: resp.Payload.Identity, ApiEndpoint: apiEndpoint} + zrd.Env = &environment.Environment{Token: token, ZId: resp.Payload.Identity, ApiEndpoint: apiEndpoint} if err := zrd.Save(); err != nil { if !cmd.headless && prg != nil { prg.Send(fmt.Sprintf("there was an error saving the new environment: %v", err)) @@ -131,7 +131,7 @@ func (cmd *enableCommand) run(_ *cobra.Command, args []string) { } os.Exit(1) } - if err := zrokdir.SaveZitiIdentity("backend", resp.Payload.Cfg); err != nil { + if err := environment.SaveZitiIdentity("backend", resp.Payload.Cfg); err != nil { if !cmd.headless && prg != nil { prg.Send(fmt.Sprintf("there was an error writing the environment: %v", err)) prg.Quit() diff --git a/cmd/zrok/invite.go b/cmd/zrok/invite.go index ed33cf26d..1a69269a8 100644 --- a/cmd/zrok/invite.go +++ b/cmd/zrok/invite.go @@ -8,12 +8,12 @@ import ( "github.com/charmbracelet/bubbles/textinput" tea "github.com/charmbracelet/bubbletea" "github.com/charmbracelet/lipgloss" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/rest_client_zrok/account" "github.com/openziti/zrok/rest_client_zrok/metadata" "github.com/openziti/zrok/rest_model_zrok" "github.com/openziti/zrok/tui" "github.com/openziti/zrok/util" - "github.com/openziti/zrok/zrokdir" "github.com/spf13/cobra" ) @@ -42,9 +42,9 @@ func newInviteCommand() *inviteCommand { } func (cmd *inviteCommand) run(_ *cobra.Command, _ []string) { - zrd, err := zrokdir.Load() + zrd, err := environment.Load() if err != nil { - tui.Error("error loading zrokdir", err) + tui.Error("error loading environment", err) } zrok, err := zrd.Client() diff --git a/cmd/zrok/release.go b/cmd/zrok/release.go index 32b5525b0..967b3cd51 100644 --- a/cmd/zrok/release.go +++ b/cmd/zrok/release.go @@ -2,10 +2,10 @@ package main import ( httptransport "github.com/go-openapi/runtime/client" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/rest_client_zrok/share" "github.com/openziti/zrok/rest_model_zrok" "github.com/openziti/zrok/tui" - "github.com/openziti/zrok/zrokdir" "github.com/sirupsen/logrus" "github.com/spf13/cobra" ) @@ -31,10 +31,10 @@ func newReleaseCommand() *releaseCommand { func (cmd *releaseCommand) run(_ *cobra.Command, args []string) { shrToken := args[0] - zrd, err := zrokdir.Load() + zrd, err := environment.Load() if err != nil { if !panicInstead { - tui.Error("unable to load zrokdir", err) + tui.Error("unable to load environment", err) } panic(err) } diff --git a/cmd/zrok/reserve.go b/cmd/zrok/reserve.go index bf21b6648..d39237576 100644 --- a/cmd/zrok/reserve.go +++ b/cmd/zrok/reserve.go @@ -2,11 +2,11 @@ package main import ( httptransport "github.com/go-openapi/runtime/client" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/model" "github.com/openziti/zrok/rest_client_zrok/share" "github.com/openziti/zrok/rest_model_zrok" "github.com/openziti/zrok/tui" - "github.com/openziti/zrok/zrokdir" "github.com/pkg/errors" "github.com/sirupsen/logrus" "github.com/spf13/cobra" @@ -60,10 +60,10 @@ func (cmd *reserveCommand) run(_ *cobra.Command, args []string) { target = args[1] } - zrd, err := zrokdir.Load() + zrd, err := environment.Load() if err != nil { if !panicInstead { - tui.Error("error loading zrokdir", err) + tui.Error("error loading environment", err) } panic(err) } diff --git a/cmd/zrok/sharePrivate.go b/cmd/zrok/sharePrivate.go index 049d91a52..a3e6c3c99 100644 --- a/cmd/zrok/sharePrivate.go +++ b/cmd/zrok/sharePrivate.go @@ -9,12 +9,12 @@ import ( "github.com/openziti/zrok/endpoints/proxy" "github.com/openziti/zrok/endpoints/tcpTunnel" "github.com/openziti/zrok/endpoints/udpTunnel" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/model" "github.com/openziti/zrok/rest_client_zrok" "github.com/openziti/zrok/rest_client_zrok/share" "github.com/openziti/zrok/rest_model_zrok" "github.com/openziti/zrok/tui" - "github.com/openziti/zrok/zrokdir" "github.com/pkg/errors" "github.com/sirupsen/logrus" "github.com/spf13/cobra" @@ -78,10 +78,10 @@ func (cmd *sharePrivateCommand) run(_ *cobra.Command, args []string) { tui.Error(fmt.Sprintf("invalid backend mode '%v'; expected {proxy, web, tcpTunnel}", cmd.backendMode), nil) } - zrd, err := zrokdir.Load() + zrd, err := environment.Load() if err != nil { if !panicInstead { - tui.Error("unable to load zrokdir", err) + tui.Error("unable to load environment", err) } panic(err) } @@ -90,7 +90,7 @@ func (cmd *sharePrivateCommand) run(_ *cobra.Command, args []string) { tui.Error("unable to load environment; did you 'zrok enable'?", nil) } - zif, err := zrokdir.ZitiIdentityFile("backend") + zif, err := environment.ZitiIdentityFile("backend") if err != nil { if !panicInstead { tui.Error("unable to load ziti identity configuration", err) diff --git a/cmd/zrok/sharePublic.go b/cmd/zrok/sharePublic.go index 336c51b7b..d88e2ea7b 100644 --- a/cmd/zrok/sharePublic.go +++ b/cmd/zrok/sharePublic.go @@ -7,12 +7,12 @@ import ( httptransport "github.com/go-openapi/runtime/client" "github.com/openziti/zrok/endpoints" "github.com/openziti/zrok/endpoints/proxy" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/model" "github.com/openziti/zrok/rest_client_zrok" "github.com/openziti/zrok/rest_client_zrok/share" "github.com/openziti/zrok/rest_model_zrok" "github.com/openziti/zrok/tui" - "github.com/openziti/zrok/zrokdir" "github.com/pkg/errors" "github.com/sirupsen/logrus" "github.com/spf13/cobra" @@ -72,10 +72,10 @@ func (cmd *sharePublicCommand) run(_ *cobra.Command, args []string) { tui.Error(fmt.Sprintf("invalid backend mode '%v'; expected {proxy, web}", cmd.backendMode), nil) } - zrd, err := zrokdir.Load() + zrd, err := environment.Load() if err != nil { if !panicInstead { - tui.Error("unable to load zrokdir", err) + tui.Error("unable to load environment", err) } panic(err) } @@ -84,7 +84,7 @@ func (cmd *sharePublicCommand) run(_ *cobra.Command, args []string) { tui.Error("unable to load environment; did you 'zrok enable'?", nil) } - zif, err := zrokdir.ZitiIdentityFile("backend") + zif, err := environment.ZitiIdentityFile("backend") if err != nil { if !panicInstead { tui.Error("unable to load ziti identity configuration", err) diff --git a/cmd/zrok/shareReserved.go b/cmd/zrok/shareReserved.go index dafeeb569..ac3300134 100644 --- a/cmd/zrok/shareReserved.go +++ b/cmd/zrok/shareReserved.go @@ -6,11 +6,11 @@ import ( httptransport "github.com/go-openapi/runtime/client" "github.com/openziti/zrok/endpoints" "github.com/openziti/zrok/endpoints/proxy" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/rest_client_zrok/metadata" "github.com/openziti/zrok/rest_client_zrok/share" "github.com/openziti/zrok/rest_model_zrok" "github.com/openziti/zrok/tui" - "github.com/openziti/zrok/zrokdir" "github.com/pkg/errors" "github.com/sirupsen/logrus" "github.com/spf13/cobra" @@ -44,10 +44,10 @@ func (cmd *shareReservedCommand) run(_ *cobra.Command, args []string) { shrToken := args[0] var target string - zrd, err := zrokdir.Load() + zrd, err := environment.Load() if err != nil { if !panicInstead { - tui.Error("error loading zrokdir", err) + tui.Error("error loading environment", err) } panic(err) } @@ -78,7 +78,7 @@ func (cmd *shareReservedCommand) run(_ *cobra.Command, args []string) { target = resp.Payload.BackendProxyEndpoint } - zif, err := zrokdir.ZitiIdentityFile("backend") + zif, err := environment.ZitiIdentityFile("backend") if err != nil { if !panicInstead { tui.Error("unable to load ziti identity configuration", err) diff --git a/cmd/zrok/status.go b/cmd/zrok/status.go index 3cdccb8be..8728dd17b 100644 --- a/cmd/zrok/status.go +++ b/cmd/zrok/status.go @@ -3,8 +3,8 @@ package main import ( "fmt" "github.com/jedib0t/go-pretty/v6/table" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/tui" - "github.com/openziti/zrok/zrokdir" "github.com/spf13/cobra" "os" ) @@ -34,9 +34,9 @@ func newStatusCommand() *statusCommand { func (cmd *statusCommand) run(_ *cobra.Command, _ []string) { _, _ = fmt.Fprintf(os.Stderr, "\n") - zrd, err := zrokdir.Load() + zrd, err := environment.Load() if err != nil { - tui.Error("unable to load zrokdir", err) + tui.Error("error loading environment", err) } _, _ = fmt.Fprintf(os.Stdout, tui.Code.Render("Config")+":\n\n") diff --git a/cmd/zrok/testLoopPublic.go b/cmd/zrok/testLoopPublic.go index 7f7da5503..1e66e8f8e 100644 --- a/cmd/zrok/testLoopPublic.go +++ b/cmd/zrok/testLoopPublic.go @@ -14,7 +14,7 @@ import ( "github.com/openziti/zrok/rest_model_zrok" "github.com/openziti/zrok/tui" "github.com/openziti/zrok/util" - "github.com/openziti/zrok/zrokdir" + "github.com/openziti/zrok/environment" "github.com/sirupsen/logrus" "github.com/spf13/cobra" "io" @@ -105,7 +105,7 @@ func (cmd *testLoopPublicCommand) run(_ *cobra.Command, _ []string) { type looper struct { id int cmd *testLoopPublicCommand - env *zrokdir.Environment + env *environment.Environment done chan struct{} listener edge.Listener zif string @@ -175,7 +175,7 @@ func (l *looper) ServeHTTP(w http.ResponseWriter, r *http.Request) { func (l *looper) startup() { logrus.Infof("starting #%d", l.id) - zrd, err := zrokdir.Load() + zrd, err := environment.Load() if err != nil { panic(err) } @@ -185,7 +185,7 @@ func (l *looper) startup() { } l.env = zrd.Env - l.zif, err = zrokdir.ZitiIdentityFile("backend") + l.zif, err = environment.ZitiIdentityFile("backend") if err != nil { panic(err) } diff --git a/controller/bootstrap.go b/controller/bootstrap.go index 084c51b14..70929f93c 100644 --- a/controller/bootstrap.go +++ b/controller/bootstrap.go @@ -14,8 +14,8 @@ import ( zrok_config "github.com/openziti/zrok/controller/config" "github.com/openziti/zrok/controller/store" "github.com/openziti/zrok/controller/zrokEdgeSdk" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/model" - "github.com/openziti/zrok/zrokdir" "github.com/pkg/errors" "github.com/sirupsen/logrus" "time" @@ -133,9 +133,9 @@ func assertZrokProxyConfigType(edge *rest_management_api_client.ZitiEdgeManageme } func getIdentityId(identityName string) (string, error) { - zif, err := zrokdir.ZitiIdentityFile(identityName) + zif, err := environment.ZitiIdentityFile(identityName) if err != nil { - return "", errors.Wrapf(err, "error opening identity '%v' from zrokdir", identityName) + return "", errors.Wrapf(err, "error opening identity '%v' from environment", identityName) } zcfg, err := ziti.NewConfigFromFile(zif) if err != nil { @@ -195,7 +195,7 @@ func bootstrapIdentity(name string, edge *rest_management_api_client.ZitiEdgeMan if err != nil { return "", errors.Wrapf(err, "error encoding identity config '%v'", name) } - if err := zrokdir.SaveZitiIdentity(name, out.String()); err != nil { + if err := environment.SaveZitiIdentity(name, out.String()); err != nil { return "", errors.Wrapf(err, "error saving identity config '%v'", name) } return zId, nil diff --git a/docs/_attic/overview.md b/docs/_attic/overview.md index d098ac634..9aa3a3d7f 100644 --- a/docs/_attic/overview.md +++ b/docs/_attic/overview.md @@ -56,15 +56,15 @@ When the user runs `zrok enable` from their shell, here's what happens: 2. The `zrok` controller creates a new OpenZiti identity for the environment and enrolls it. 3. The `zrok` controller creates an edge router policy associating the new OpenZiti identity with `#all` edge routers. 4. The `zrok` controller returns the entire SDK configuration back to the `zrok enable` client. -5. The `zrok enable` client then stores the OpenZiti identity along with a few other housekeeping details in the user's `~/.zrok` folder (we refer to this as `zrokdir`, conceptually in the code). -6. With the OpenZiti identity and configuration details stored in the user's `zrokdir`, the user is then able to create any number of binding endpoints using the `zrok http` command. +5. The `zrok enable` client then stores the OpenZiti identity along with a few other housekeeping details in the user's `~/.zrok` folder. +6. With the OpenZiti identity and configuration details stored in the user's `environment`, the user is then able to create any number of binding endpoints using the `zrok http` command. ### The `zrok http` Flow When a `zrok` user issues a `zrok http` command for an endpoint, here's what happens: -1. The `zrok http` client gathers the necessary identity details from the `zrokdir` (this was all staged during `zrok enable`). +1. The `zrok http` client gathers the necessary identity details from the `environment` (this was all staged during `zrok enable`). 2. The `zrok http` client reaches out to the `zrok` controller with an authenticated `tunnel` request, asking to have a new endpoint binding created. 3. The `zrok` controller allocates a new "service name" for the binding. 4. The `zrok` controller creates a `zrok.proxy.v1` configuration describing the user's requested authentication details (currently: `none` or `basic`). diff --git a/docs/getting-started.md b/docs/getting-started.md index 7ab2fe795..45cac38ba 100644 --- a/docs/getting-started.md +++ b/docs/getting-started.md @@ -107,13 +107,13 @@ The `zrok` executable defaults to using the `zrok` service instance at `api.zrok ``` $ zrok config set apiEndpoint https://zrok.mydomain.com -[WARNING]: unable to open zrokdir metadata; ignoring +[WARNING]: unable to open environment metadata; ignoring zrok configuration updated ``` :::note -The `WARNING` about `zrokdir metadata` is ignorable. Running the `zrok config set` command writes a small piece of metadata into a `.zrok` folder inside your home directory. This allows `zrok` to identify the version of its settings, providing a mechanism to upgrade your installation as new versions are released. This `WARNING` is letting you know that your current environment has not been initialized by `zrok`. +The `WARNING` about `environment metadata` is ignorable. Running the `zrok config set` command writes a small piece of metadata into a `.zrok` folder inside your home directory. This allows `zrok` to identify the version of its settings, providing a mechanism to upgrade your installation as new versions are released. This `WARNING` is letting you know that your current environment has not been initialized by `zrok`. ::: You can use the `zrok status` command to inspect the state of your local _environment_. `zrok` refers to each shell where you install and `enable` a copy of `zrok` as as an _environment_. diff --git a/endpoints/proxy/frontend.go b/endpoints/proxy/frontend.go index be6393357..d38ea3e60 100644 --- a/endpoints/proxy/frontend.go +++ b/endpoints/proxy/frontend.go @@ -6,9 +6,9 @@ import ( "github.com/openziti/sdk-golang/ziti" "github.com/openziti/zrok/endpoints" "github.com/openziti/zrok/endpoints/publicProxy/notFoundUi" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/model" "github.com/openziti/zrok/util" - "github.com/openziti/zrok/zrokdir" "github.com/pkg/errors" "github.com/sirupsen/logrus" "net" @@ -40,9 +40,9 @@ type Frontend struct { } func NewFrontend(cfg *FrontendConfig) (*Frontend, error) { - zCfgPath, err := zrokdir.ZitiIdentityFile(cfg.IdentityName) + zCfgPath, err := environment.ZitiIdentityFile(cfg.IdentityName) if err != nil { - return nil, errors.Wrapf(err, "error getting ziti identity '%v' from zrokdir", cfg.IdentityName) + return nil, errors.Wrapf(err, "error getting ziti identity '%v' from environment", cfg.IdentityName) } zCfg, err := ziti.NewConfigFromFile(zCfgPath) if err != nil { diff --git a/endpoints/publicProxy/http.go b/endpoints/publicProxy/http.go index e9aab21b8..42672b95f 100644 --- a/endpoints/publicProxy/http.go +++ b/endpoints/publicProxy/http.go @@ -7,9 +7,9 @@ import ( "github.com/openziti/zrok/endpoints" "github.com/openziti/zrok/endpoints/publicProxy/healthUi" "github.com/openziti/zrok/endpoints/publicProxy/notFoundUi" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/model" "github.com/openziti/zrok/util" - "github.com/openziti/zrok/zrokdir" "github.com/pkg/errors" "github.com/sirupsen/logrus" "net" @@ -26,9 +26,9 @@ type httpFrontend struct { } func NewHTTP(cfg *Config) (*httpFrontend, error) { - zCfgPath, err := zrokdir.ZitiIdentityFile(cfg.Identity) + zCfgPath, err := environment.ZitiIdentityFile(cfg.Identity) if err != nil { - return nil, errors.Wrapf(err, "error getting ziti identity '%v' from zrokdir", cfg.Identity) + return nil, errors.Wrapf(err, "error getting ziti identity '%v' from environment", cfg.Identity) } zCfg, err := ziti.NewConfigFromFile(zCfgPath) if err != nil { diff --git a/endpoints/tcpTunnel/frontend.go b/endpoints/tcpTunnel/frontend.go index 217a63530..f4f9e3aa4 100644 --- a/endpoints/tcpTunnel/frontend.go +++ b/endpoints/tcpTunnel/frontend.go @@ -3,8 +3,8 @@ package tcpTunnel import ( "github.com/openziti/sdk-golang/ziti" "github.com/openziti/zrok/endpoints" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/model" - "github.com/openziti/zrok/zrokdir" "github.com/pkg/errors" "github.com/sirupsen/logrus" "net" @@ -29,9 +29,9 @@ func NewFrontend(cfg *FrontendConfig) (*Frontend, error) { if err != nil { return nil, errors.Wrapf(err, "error resolving tcp address '%v'", cfg.BindAddress) } - zCfgPath, err := zrokdir.ZitiIdentityFile(cfg.IdentityName) + zCfgPath, err := environment.ZitiIdentityFile(cfg.IdentityName) if err != nil { - return nil, errors.Wrapf(err, "error getting ziti identity '%v' from zrokdir", cfg.IdentityName) + return nil, errors.Wrapf(err, "error getting ziti identity '%v' from environment", cfg.IdentityName) } zCfg, err := ziti.NewConfigFromFile(zCfgPath) if err != nil { diff --git a/endpoints/udpTunnel/frontend.go b/endpoints/udpTunnel/frontend.go index 954433cbc..785597f9c 100644 --- a/endpoints/udpTunnel/frontend.go +++ b/endpoints/udpTunnel/frontend.go @@ -3,8 +3,8 @@ package udpTunnel import ( "github.com/openziti/sdk-golang/ziti" "github.com/openziti/zrok/endpoints" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/model" - "github.com/openziti/zrok/zrokdir" "github.com/pkg/errors" "github.com/sirupsen/logrus" "net" @@ -99,9 +99,9 @@ func NewFrontend(cfg *FrontendConfig) (*Frontend, error) { if err != nil { return nil, errors.Wrapf(err, "error resolving udp address '%v'", cfg.BindAddress) } - zCfgPath, err := zrokdir.ZitiIdentityFile(cfg.IdentityName) + zCfgPath, err := environment.ZitiIdentityFile(cfg.IdentityName) if err != nil { - return nil, errors.Wrapf(err, "error getting ziti identity '%v' from zrokdir", cfg.IdentityName) + return nil, errors.Wrapf(err, "error getting ziti identity '%v' from environment", cfg.IdentityName) } zCfg, err := ziti.NewConfigFromFile(zCfgPath) if err != nil { diff --git a/zrokdir/client.go b/environment/client.go similarity index 89% rename from zrokdir/client.go rename to environment/client.go index 2f41b47b0..62f0983a5 100644 --- a/zrokdir/client.go +++ b/environment/client.go @@ -1,4 +1,4 @@ -package zrokdir +package environment import ( "github.com/go-openapi/runtime" @@ -12,7 +12,7 @@ import ( "regexp" ) -func (zrd *ZrokDir) Client() (*rest_client_zrok.Zrok, error) { +func (zrd *Root) Client() (*rest_client_zrok.Zrok, error) { apiEndpoint, _ := zrd.ApiEndpoint() apiUrl, err := url.Parse(apiEndpoint) if err != nil { @@ -30,14 +30,14 @@ func (zrd *ZrokDir) Client() (*rest_client_zrok.Zrok, error) { // allow reported version string to be optionally prefixed with // "refs/heads/" or "refs/tags/" re := regexp.MustCompile(`^(refs/(heads|tags)/)?` + build.Series) - if ! re.MatchString(string(v.Payload)) { + if !re.MatchString(string(v.Payload)) { return nil, errors.Errorf("expected a '%v' version, received: '%v'", build.Series, v.Payload) } return zrok, nil } -func (zrd *ZrokDir) ApiEndpoint() (apiEndpoint string, from string) { +func (zrd *Root) ApiEndpoint() (apiEndpoint string, from string) { apiEndpoint = "https://api.zrok.io" from = "binary" diff --git a/zrokdir/config.go b/environment/config.go similarity index 92% rename from zrokdir/config.go rename to environment/config.go index d8e77cfdc..181758ff3 100644 --- a/zrokdir/config.go +++ b/environment/config.go @@ -1,4 +1,4 @@ -package zrokdir +package environment import ( "encoding/json" @@ -52,7 +52,7 @@ func saveConfig(cfg *Config) error { return errors.Wrap(err, "error getting config file path") } if err := os.MkdirAll(filepath.Dir(cf), os.FileMode(0700)); err != nil { - return errors.Wrapf(err, "error creating zrokdir path '%v'", filepath.Dir(cf)) + return errors.Wrapf(err, "error creating environment path '%v'", filepath.Dir(cf)) } if err := os.WriteFile(cf, data, os.FileMode(0600)); err != nil { return errors.Wrap(err, "error saving config file") diff --git a/zrokdir/environment.go b/environment/environment.go similarity index 94% rename from zrokdir/environment.go rename to environment/environment.go index 56b502276..300db0532 100644 --- a/zrokdir/environment.go +++ b/environment/environment.go @@ -1,4 +1,4 @@ -package zrokdir +package environment import ( "encoding/json" @@ -54,7 +54,7 @@ func saveEnvironment(env *Environment) error { return errors.Wrap(err, "error getting environment file") } if err := os.MkdirAll(filepath.Dir(ef), os.FileMode(0700)); err != nil { - return errors.Wrapf(err, "error creating zrokdir path '%v'", filepath.Dir(ef)) + return errors.Wrapf(err, "error creating environment path '%v'", filepath.Dir(ef)) } if err := os.WriteFile(ef, data, os.FileMode(0600)); err != nil { return errors.Wrap(err, "error saving environment file") diff --git a/zrokdir/identity.go b/environment/identity.go similarity index 88% rename from zrokdir/identity.go rename to environment/identity.go index 4c912ebc0..b3ef5a6f0 100644 --- a/zrokdir/identity.go +++ b/environment/identity.go @@ -1,4 +1,4 @@ -package zrokdir +package environment import ( "github.com/pkg/errors" @@ -16,7 +16,7 @@ func SaveZitiIdentity(name, data string) error { return err } if err := os.MkdirAll(filepath.Dir(zif), os.FileMode(0700)); err != nil { - return errors.Wrapf(err, "error creating zrokdir path '%v'", filepath.Dir(zif)) + return errors.Wrapf(err, "error creating environment path '%v'", filepath.Dir(zif)) } if err := os.WriteFile(zif, []byte(data), os.FileMode(0600)); err != nil { return errors.Wrapf(err, "error writing ziti identity file '%v'", zif) diff --git a/zrokdir/zrokdir.go b/environment/root.go similarity index 75% rename from zrokdir/zrokdir.go rename to environment/root.go index 9c8d0c710..d50ef165a 100644 --- a/zrokdir/zrokdir.go +++ b/environment/root.go @@ -1,4 +1,4 @@ -package zrokdir +package environment import ( "fmt" @@ -8,39 +8,39 @@ import ( "strings" ) -type ZrokDir struct { +type Root struct { Env *Environment Cfg *Config identities map[string]struct{} } -func Initialize() (*ZrokDir, error) { - zrd, err := zrokDir() +func Initialize() (*Root, error) { + zrd, err := rootDir() if err != nil { - return nil, errors.Wrap(err, "error getting zrokdir path") + return nil, errors.Wrap(err, "error getting environment path") } if err := os.MkdirAll(zrd, os.FileMode(0700)); err != nil { - return nil, errors.Wrapf(err, "error creating zrokdir root path '%v'", zrd) + return nil, errors.Wrapf(err, "error creating environment root path '%v'", zrd) } if err := DeleteEnvironment(); err != nil { return nil, errors.Wrap(err, "error deleting environment") } idd, err := identitiesDir() if err != nil { - return nil, errors.Wrap(err, "error getting zrokdir identities path") + return nil, errors.Wrap(err, "error getting environment identities path") } if err := os.MkdirAll(idd, os.FileMode(0700)); err != nil { - return nil, errors.Wrapf(err, "error creating zrokdir identities root path '%v'", idd) + return nil, errors.Wrapf(err, "error creating environment identities root path '%v'", idd) } return Load() } -func Load() (*ZrokDir, error) { +func Load() (*Root, error) { if err := checkMetadata(); err != nil { return nil, err } - zrd := &ZrokDir{} + zrd := &Root{} ids, err := listIdentities() if err != nil { @@ -75,7 +75,7 @@ func Load() (*ZrokDir, error) { return zrd, nil } -func (zrd *ZrokDir) Save() error { +func (zrd *Root) Save() error { if err := writeMetadata(); err != nil { return errors.Wrap(err, "error saving metadata") } @@ -93,7 +93,7 @@ func (zrd *ZrokDir) Save() error { } func Obliterate() error { - zrd, err := zrokDir() + zrd, err := rootDir() if err != nil { return err } @@ -108,18 +108,18 @@ func listIdentities() (map[string]struct{}, error) { idd, err := identitiesDir() if err != nil { - return nil, errors.Wrap(err, "error getting zrokdir identities path") + return nil, errors.Wrap(err, "error getting environment identities path") } _, err = os.Stat(idd) if os.IsNotExist(err) { return ids, nil } if err != nil { - return nil, errors.Wrapf(err, "error stat-ing zrokdir identities root '%v'", idd) + return nil, errors.Wrapf(err, "error stat-ing environment identities root '%v'", idd) } des, err := os.ReadDir(idd) if err != nil { - return nil, errors.Wrapf(err, "error listing zrokdir identities from '%v'", idd) + return nil, errors.Wrapf(err, "error listing environment identities from '%v'", idd) } for _, de := range des { if strings.HasSuffix(de.Name(), ".json") && !de.IsDir() { @@ -131,7 +131,7 @@ func listIdentities() (map[string]struct{}, error) { } func configFile() (string, error) { - zrd, err := zrokDir() + zrd, err := rootDir() if err != nil { return "", err } @@ -139,7 +139,7 @@ func configFile() (string, error) { } func environmentFile() (string, error) { - zrd, err := zrokDir() + zrd, err := rootDir() if err != nil { return "", err } @@ -155,7 +155,7 @@ func identityFile(name string) (string, error) { } func identitiesDir() (string, error) { - zrd, err := zrokDir() + zrd, err := rootDir() if err != nil { return "", err } @@ -163,14 +163,14 @@ func identitiesDir() (string, error) { } func metadataFile() (string, error) { - zrd, err := zrokDir() + zrd, err := rootDir() if err != nil { return "", err } return filepath.Join(zrd, "metadata.json"), nil } -func zrokDir() (string, error) { +func rootDir() (string, error) { home, err := os.UserHomeDir() if err != nil { return "", err diff --git a/zrokdir/version.go b/environment/version.go similarity index 84% rename from zrokdir/version.go rename to environment/version.go index e073aa99f..e75238ed1 100644 --- a/zrokdir/version.go +++ b/environment/version.go @@ -1,4 +1,4 @@ -package zrokdir +package environment import ( "encoding/json" @@ -21,7 +21,7 @@ func checkMetadata() error { } data, err := os.ReadFile(mf) if err != nil { - tui.Warning("unable to open zrokdir metadata; ignoring\n") + tui.Warning("unable to open environment metadata; ignoring\n") return nil } m := &Metadata{} @@ -29,7 +29,7 @@ func checkMetadata() error { return errors.Wrapf(err, "error unmarshaling metadata file '%v'", mf) } if m.V != V { - return errors.Errorf("invalid zrokdir metadata version '%v'", m.V) + return errors.Errorf("invalid environment metadata version '%v'", m.V) } return nil } diff --git a/sdk/share.go b/sdk/share.go index 0a09e8d05..d98f9b5b3 100644 --- a/sdk/share.go +++ b/sdk/share.go @@ -1,8 +1,8 @@ package sdk import ( + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/rest_model_zrok" - "github.com/openziti/zrok/zrokdir" "github.com/pkg/errors" ) @@ -29,14 +29,14 @@ func newPublicShare(request *ShareRequest) (*Share, error) { return nil, nil } -func loadEnvironment(request *ShareRequest) (*zrokdir.ZrokDir, error) { - zrd, err := zrokdir.Load() +func loadEnvironment(request *ShareRequest) (*environment.Root, error) { + env, err := environment.Load() if err != nil { - return nil, errors.Wrap(err, "error loading zrokdir") + return nil, errors.Wrap(err, "error loading environment") } - return zrd, nil + return env, nil } -func createShare(zrd *zrokdir.ZrokDir, req *rest_model_zrok.ShareRequest) (*Share, error) { +func createShare(zrd *environment.Root, req *rest_model_zrok.ShareRequest) (*Share, error) { return nil, nil } From e26ef1ba1a0bc7a8b0f98b4940927e000464639a Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Mon, 10 Jul 2023 16:53:27 -0400 Subject: [PATCH 03/28] environment refactoring (#34, #369) --- cmd/zrok/testLoopPublic.go | 2 +- environment/client.go | 16 ++++++++-------- environment/config.go | 6 +++--- environment/environment.go | 2 +- environment/root.go | 16 ++++++++-------- 5 files changed, 21 insertions(+), 21 deletions(-) diff --git a/cmd/zrok/testLoopPublic.go b/cmd/zrok/testLoopPublic.go index 1e66e8f8e..902ec482e 100644 --- a/cmd/zrok/testLoopPublic.go +++ b/cmd/zrok/testLoopPublic.go @@ -8,13 +8,13 @@ import ( httptransport "github.com/go-openapi/runtime/client" "github.com/openziti/sdk-golang/ziti" "github.com/openziti/sdk-golang/ziti/edge" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/model" "github.com/openziti/zrok/rest_client_zrok" "github.com/openziti/zrok/rest_client_zrok/share" "github.com/openziti/zrok/rest_model_zrok" "github.com/openziti/zrok/tui" "github.com/openziti/zrok/util" - "github.com/openziti/zrok/environment" "github.com/sirupsen/logrus" "github.com/spf13/cobra" "io" diff --git a/environment/client.go b/environment/client.go index 62f0983a5..bb752a815 100644 --- a/environment/client.go +++ b/environment/client.go @@ -12,11 +12,11 @@ import ( "regexp" ) -func (zrd *Root) Client() (*rest_client_zrok.Zrok, error) { - apiEndpoint, _ := zrd.ApiEndpoint() +func (r *Root) Client() (*rest_client_zrok.Zrok, error) { + apiEndpoint, _ := r.ApiEndpoint() apiUrl, err := url.Parse(apiEndpoint) if err != nil { - return nil, errors.Wrapf(err, "error parsing api endpoint '%v'", zrd) + return nil, errors.Wrapf(err, "error parsing api endpoint '%v'", r) } transport := httptransport.New(apiUrl.Host, "/api/v1", []string{apiUrl.Scheme}) transport.Producers["application/zrok.v1+json"] = runtime.JSONProducer() @@ -37,12 +37,12 @@ func (zrd *Root) Client() (*rest_client_zrok.Zrok, error) { return zrok, nil } -func (zrd *Root) ApiEndpoint() (apiEndpoint string, from string) { +func (r *Root) ApiEndpoint() (apiEndpoint string, from string) { apiEndpoint = "https://api.zrok.io" from = "binary" - if zrd.Cfg != nil && zrd.Cfg.ApiEndpoint != "" { - apiEndpoint = zrd.Cfg.ApiEndpoint + if r.Cfg != nil && r.Cfg.ApiEndpoint != "" { + apiEndpoint = r.Cfg.ApiEndpoint from = "config" } @@ -52,8 +52,8 @@ func (zrd *Root) ApiEndpoint() (apiEndpoint string, from string) { from = "ZROK_API_ENDPOINT" } - if zrd.Env != nil && zrd.Env.ApiEndpoint != "" { - apiEndpoint = zrd.Env.ApiEndpoint + if r.Env != nil && r.Env.ApiEndpoint != "" { + apiEndpoint = r.Env.ApiEndpoint from = "env" } diff --git a/environment/config.go b/environment/config.go index 181758ff3..46931e5b1 100644 --- a/environment/config.go +++ b/environment/config.go @@ -11,7 +11,7 @@ type Config struct { ApiEndpoint string `json:"api_endpoint"` } -func hasConfig() (bool, error) { +func HasConfig() (bool, error) { cf, err := configFile() if err != nil { return false, errors.Wrap(err, "error getting config file path") @@ -26,7 +26,7 @@ func hasConfig() (bool, error) { return true, nil } -func loadConfig() (*Config, error) { +func LoadConfig() (*Config, error) { cf, err := configFile() if err != nil { return nil, errors.Wrap(err, "error getting config file path") @@ -42,7 +42,7 @@ func loadConfig() (*Config, error) { return cfg, nil } -func saveConfig(cfg *Config) error { +func SaveConfig(cfg *Config) error { data, err := json.MarshalIndent(cfg, "", " ") if err != nil { return errors.Wrap(err, "error marshaling config") diff --git a/environment/environment.go b/environment/environment.go index 300db0532..8542ab302 100644 --- a/environment/environment.go +++ b/environment/environment.go @@ -13,7 +13,7 @@ type Environment struct { ApiEndpoint string `json:"api_endpoint"` } -func hasEnvironment() (bool, error) { +func IsEnabled() (bool, error) { ef, err := environmentFile() if err != nil { return false, errors.Wrap(err, "error getting environment file path") diff --git a/environment/root.go b/environment/root.go index d50ef165a..ff015350b 100644 --- a/environment/root.go +++ b/environment/root.go @@ -48,19 +48,19 @@ func Load() (*Root, error) { } zrd.identities = ids - hasCfg, err := hasConfig() + hasCfg, err := HasConfig() if err != nil { return nil, err } if hasCfg { - cfg, err := loadConfig() + cfg, err := LoadConfig() if err != nil { return nil, err } zrd.Cfg = cfg } - hasEnv, err := hasEnvironment() + hasEnv, err := IsEnabled() if err != nil { return nil, err } @@ -75,17 +75,17 @@ func Load() (*Root, error) { return zrd, nil } -func (zrd *Root) Save() error { +func (r *Root) Save() error { if err := writeMetadata(); err != nil { return errors.Wrap(err, "error saving metadata") } - if zrd.Env != nil { - if err := saveEnvironment(zrd.Env); err != nil { + if r.Env != nil { + if err := saveEnvironment(r.Env); err != nil { return errors.Wrap(err, "error saving environment") } } - if zrd.Cfg != nil { - if err := saveConfig(zrd.Cfg); err != nil { + if r.Cfg != nil { + if err := SaveConfig(r.Cfg); err != nil { return errors.Wrap(err, "error saving config") } } From c468c7ace98b25f4008f48ca80812b479fedd195 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Tue, 11 Jul 2023 14:59:02 -0400 Subject: [PATCH 04/28] environment -> env_v0_3 (#369) --- cmd/zrok/accessPrivate.go | 4 ++-- cmd/zrok/adminCreateFrontend.go | 4 ++-- cmd/zrok/adminCreateIdentity.go | 8 ++++---- cmd/zrok/adminDeleteFrontend.go | 4 ++-- cmd/zrok/adminGenerate.go | 4 ++-- cmd/zrok/adminListFrontends.go | 4 ++-- cmd/zrok/adminUpdateFrontend.go | 4 ++-- cmd/zrok/configGet.go | 4 ++-- cmd/zrok/configSet.go | 6 +++--- cmd/zrok/configUnset.go | 4 ++-- cmd/zrok/console.go | 4 ++-- cmd/zrok/disable.go | 8 ++++---- cmd/zrok/enable.go | 8 ++++---- cmd/zrok/invite.go | 4 ++-- cmd/zrok/release.go | 4 ++-- cmd/zrok/reserve.go | 4 ++-- cmd/zrok/sharePrivate.go | 6 +++--- cmd/zrok/sharePublic.go | 6 +++--- cmd/zrok/shareReserved.go | 6 +++--- cmd/zrok/status.go | 4 ++-- cmd/zrok/testLoopPublic.go | 8 ++++---- controller/bootstrap.go | 6 +++--- endpoints/proxy/frontend.go | 4 ++-- endpoints/publicProxy/http.go | 4 ++-- endpoints/tcpTunnel/frontend.go | 4 ++-- endpoints/udpTunnel/frontend.go | 4 ++-- environment/{ => env_v0_3}/client.go | 2 +- environment/{ => env_v0_3}/config.go | 2 +- environment/{ => env_v0_3}/environment.go | 2 +- environment/{ => env_v0_3}/identity.go | 2 +- environment/{ => env_v0_3}/root.go | 2 +- environment/{ => env_v0_3}/version.go | 2 +- sdk/share.go | 8 ++++---- 33 files changed, 75 insertions(+), 75 deletions(-) rename environment/{ => env_v0_3}/client.go (98%) rename environment/{ => env_v0_3}/config.go (98%) rename environment/{ => env_v0_3}/environment.go (98%) rename environment/{ => env_v0_3}/identity.go (97%) rename environment/{ => env_v0_3}/root.go (99%) rename environment/{ => env_v0_3}/version.go (98%) diff --git a/cmd/zrok/accessPrivate.go b/cmd/zrok/accessPrivate.go index d97edac0f..9f485c5af 100644 --- a/cmd/zrok/accessPrivate.go +++ b/cmd/zrok/accessPrivate.go @@ -8,7 +8,7 @@ import ( "github.com/openziti/zrok/endpoints/proxy" "github.com/openziti/zrok/endpoints/tcpTunnel" "github.com/openziti/zrok/endpoints/udpTunnel" - "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/environment/env_v0_3" "github.com/openziti/zrok/rest_client_zrok" "github.com/openziti/zrok/rest_client_zrok/share" "github.com/openziti/zrok/rest_model_zrok" @@ -48,7 +48,7 @@ func newAccessPrivateCommand() *accessPrivateCommand { func (cmd *accessPrivateCommand) run(_ *cobra.Command, args []string) { shrToken := args[0] - zrd, err := environment.Load() + zrd, err := env_v0_3.Load() if err != nil { tui.Error("error loading environment", err) } diff --git a/cmd/zrok/adminCreateFrontend.go b/cmd/zrok/adminCreateFrontend.go index c9da26270..2b88bc109 100644 --- a/cmd/zrok/adminCreateFrontend.go +++ b/cmd/zrok/adminCreateFrontend.go @@ -1,9 +1,9 @@ package main import ( + "github.com/openziti/zrok/environment/env_v0_3" "os" - "github.com/openziti/zrok/environment" "github.com/openziti/zrok/rest_client_zrok/admin" "github.com/openziti/zrok/rest_model_zrok" "github.com/openziti/zrok/tui" @@ -35,7 +35,7 @@ func (cmd *adminCreateFrontendCommand) run(_ *cobra.Command, args []string) { publicName := args[1] urlTemplate := args[2] - zrd, err := environment.Load() + zrd, err := env_v0_3.Load() if err != nil { panic(err) } diff --git a/cmd/zrok/adminCreateIdentity.go b/cmd/zrok/adminCreateIdentity.go index 61ae340f2..e6da348f0 100644 --- a/cmd/zrok/adminCreateIdentity.go +++ b/cmd/zrok/adminCreateIdentity.go @@ -2,8 +2,8 @@ package main import ( "fmt" + "github.com/openziti/zrok/environment/env_v0_3" "github.com/openziti/zrok/rest_client_zrok/admin" - "github.com/openziti/zrok/environment" "github.com/sirupsen/logrus" "github.com/spf13/cobra" "os" @@ -32,7 +32,7 @@ func newAdminCreateIdentity() *adminCreateIdentity { func (cmd *adminCreateIdentity) run(_ *cobra.Command, args []string) { name := args[0] - zif, err := environment.ZitiIdentityFile(name) + zif, err := env_v0_3.ZitiIdentityFile(name) if err != nil { panic(err) } @@ -41,7 +41,7 @@ func (cmd *adminCreateIdentity) run(_ *cobra.Command, args []string) { os.Exit(1) } - zrd, err := environment.Load() + zrd, err := env_v0_3.Load() if err != nil { panic(err) } @@ -59,7 +59,7 @@ func (cmd *adminCreateIdentity) run(_ *cobra.Command, args []string) { panic(err) } - if err := environment.SaveZitiIdentity(name, resp.Payload.Cfg); err != nil { + if err := env_v0_3.SaveZitiIdentity(name, resp.Payload.Cfg); err != nil { panic(err) } diff --git a/cmd/zrok/adminDeleteFrontend.go b/cmd/zrok/adminDeleteFrontend.go index 4783fdeb7..b715d44f6 100644 --- a/cmd/zrok/adminDeleteFrontend.go +++ b/cmd/zrok/adminDeleteFrontend.go @@ -1,9 +1,9 @@ package main import ( + "github.com/openziti/zrok/environment/env_v0_3" "github.com/openziti/zrok/rest_client_zrok/admin" "github.com/openziti/zrok/rest_model_zrok" - "github.com/openziti/zrok/environment" "github.com/sirupsen/logrus" "github.com/spf13/cobra" ) @@ -30,7 +30,7 @@ func newAdminDeleteFrontendCommand() *adminDeleteFrontendCommand { func (cmd *adminDeleteFrontendCommand) run(_ *cobra.Command, args []string) { feToken := args[0] - zrd, err := environment.Load() + zrd, err := env_v0_3.Load() if err != nil { panic(err) } diff --git a/cmd/zrok/adminGenerate.go b/cmd/zrok/adminGenerate.go index 26e7951a1..5740ca268 100644 --- a/cmd/zrok/adminGenerate.go +++ b/cmd/zrok/adminGenerate.go @@ -3,7 +3,7 @@ package main import ( "fmt" "github.com/jaevor/go-nanoid" - "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/environment/env_v0_3" "github.com/openziti/zrok/rest_client_zrok/admin" "github.com/openziti/zrok/rest_model_zrok" "github.com/sirupsen/logrus" @@ -43,7 +43,7 @@ func (cmd *adminGenerateCommand) run(_ *cobra.Command, args []string) { } } - zrd, err := environment.Load() + zrd, err := env_v0_3.Load() if err != nil { logrus.Error("error loading environment", err) } diff --git a/cmd/zrok/adminListFrontends.go b/cmd/zrok/adminListFrontends.go index 5d63b3759..818acca36 100644 --- a/cmd/zrok/adminListFrontends.go +++ b/cmd/zrok/adminListFrontends.go @@ -3,8 +3,8 @@ package main import ( "fmt" "github.com/jedib0t/go-pretty/v6/table" + "github.com/openziti/zrok/environment/env_v0_3" "github.com/openziti/zrok/rest_client_zrok/admin" - "github.com/openziti/zrok/environment" "github.com/spf13/cobra" "os" "time" @@ -31,7 +31,7 @@ func newAdminListFrontendsCommand() *adminListFrontendsCommand { } func (cmd *adminListFrontendsCommand) run(_ *cobra.Command, _ []string) { - zrd, err := environment.Load() + zrd, err := env_v0_3.Load() if err != nil { panic(err) } diff --git a/cmd/zrok/adminUpdateFrontend.go b/cmd/zrok/adminUpdateFrontend.go index 1de2d9676..f1d434a3d 100644 --- a/cmd/zrok/adminUpdateFrontend.go +++ b/cmd/zrok/adminUpdateFrontend.go @@ -1,9 +1,9 @@ package main import ( + "github.com/openziti/zrok/environment/env_v0_3" "github.com/openziti/zrok/rest_client_zrok/admin" "github.com/openziti/zrok/rest_model_zrok" - "github.com/openziti/zrok/environment" "github.com/sirupsen/logrus" "github.com/spf13/cobra" ) @@ -38,7 +38,7 @@ func (cmd *adminUpdateFrontendCommand) run(_ *cobra.Command, args []string) { panic("must specify at least one of public name or url template") } - zrd, err := environment.Load() + zrd, err := env_v0_3.Load() if err != nil { panic(err) } diff --git a/cmd/zrok/configGet.go b/cmd/zrok/configGet.go index 544177724..ef8e2208f 100644 --- a/cmd/zrok/configGet.go +++ b/cmd/zrok/configGet.go @@ -2,7 +2,7 @@ package main import ( "fmt" - "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/environment/env_v0_3" "github.com/spf13/cobra" ) @@ -28,7 +28,7 @@ func newConfigGetCommand() *configGetCommand { func (cmd *configGetCommand) run(_ *cobra.Command, args []string) { configName := args[0] - zrd, err := environment.Load() + zrd, err := env_v0_3.Load() if err != nil { panic(err) } diff --git a/cmd/zrok/configSet.go b/cmd/zrok/configSet.go index 13e9d6ce0..eb84f6971 100644 --- a/cmd/zrok/configSet.go +++ b/cmd/zrok/configSet.go @@ -2,10 +2,10 @@ package main import ( "fmt" + "github.com/openziti/zrok/environment/env_v0_3" "net/url" "os" - "github.com/openziti/zrok/environment" "github.com/openziti/zrok/tui" "github.com/spf13/cobra" ) @@ -33,7 +33,7 @@ func (cmd *configSetCommand) run(_ *cobra.Command, args []string) { configName := args[0] value := args[1] - zrd, err := environment.Load() + zrd, err := env_v0_3.Load() if err != nil { panic(err) } @@ -42,7 +42,7 @@ func (cmd *configSetCommand) run(_ *cobra.Command, args []string) { switch configName { case "apiEndpoint": if zrd.Cfg == nil { - zrd.Cfg = &environment.Config{} + zrd.Cfg = &env_v0_3.Config{} } ok, err := isFullyValidUrl(value) if err != nil { diff --git a/cmd/zrok/configUnset.go b/cmd/zrok/configUnset.go index 2aa506123..72eeda461 100644 --- a/cmd/zrok/configUnset.go +++ b/cmd/zrok/configUnset.go @@ -2,8 +2,8 @@ package main import ( "fmt" + "github.com/openziti/zrok/environment/env_v0_3" "github.com/openziti/zrok/tui" - "github.com/openziti/zrok/environment" "github.com/spf13/cobra" "os" ) @@ -30,7 +30,7 @@ func newConfigUnsetCommand() *configUnsetCommand { func (cmd *configUnsetCommand) run(_ *cobra.Command, args []string) { configName := args[0] - zrd, err := environment.Load() + zrd, err := env_v0_3.Load() if err != nil { panic(err) } diff --git a/cmd/zrok/console.go b/cmd/zrok/console.go index 83eb97c3c..34024ff6c 100644 --- a/cmd/zrok/console.go +++ b/cmd/zrok/console.go @@ -2,7 +2,7 @@ package main import ( "fmt" - "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/environment/env_v0_3" "github.com/openziti/zrok/tui" "github.com/spf13/cobra" ) @@ -27,7 +27,7 @@ func newConsoleCommand() *consoleCommand { } func (cmd *consoleCommand) run(_ *cobra.Command, _ []string) { - env, err := environment.Load() + env, err := env_v0_3.Load() if err != nil { tui.Error("unable to load environment", err) } diff --git a/cmd/zrok/disable.go b/cmd/zrok/disable.go index 17e804d03..20764f3c3 100644 --- a/cmd/zrok/disable.go +++ b/cmd/zrok/disable.go @@ -3,7 +3,7 @@ package main import ( "fmt" httpTransport "github.com/go-openapi/runtime/client" - "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/environment/env_v0_3" restEnvironment "github.com/openziti/zrok/rest_client_zrok/environment" "github.com/openziti/zrok/rest_model_zrok" "github.com/openziti/zrok/tui" @@ -31,7 +31,7 @@ func newDisableCommand() *disableCommand { } func (cmd *disableCommand) run(_ *cobra.Command, _ []string) { - zrd, err := environment.Load() + zrd, err := env_v0_3.Load() if err != nil { if !panicInstead { tui.Error("unable to load environment", err) @@ -59,13 +59,13 @@ func (cmd *disableCommand) run(_ *cobra.Command, _ []string) { if err != nil { logrus.Warnf("share cleanup failed (%v); will clean up local environment", err) } - if err := environment.DeleteEnvironment(); err != nil { + if err := env_v0_3.DeleteEnvironment(); err != nil { if !panicInstead { tui.Error("error removing zrok environment", err) } panic(err) } - if err := environment.DeleteZitiIdentity("backend"); err != nil { + if err := env_v0_3.DeleteZitiIdentity("backend"); err != nil { if !panicInstead { tui.Error("error removing zrok backend identity", err) } diff --git a/cmd/zrok/enable.go b/cmd/zrok/enable.go index c6bf946c7..b9e84d36b 100644 --- a/cmd/zrok/enable.go +++ b/cmd/zrok/enable.go @@ -2,6 +2,7 @@ package main import ( "fmt" + "github.com/openziti/zrok/environment/env_v0_3" "github.com/sirupsen/logrus" "os" user2 "os/user" @@ -10,7 +11,6 @@ import ( "github.com/charmbracelet/bubbles/spinner" tea "github.com/charmbracelet/bubbletea" httptransport "github.com/go-openapi/runtime/client" - "github.com/openziti/zrok/environment" restEnvironment "github.com/openziti/zrok/rest_client_zrok/environment" "github.com/openziti/zrok/rest_model_zrok" "github.com/openziti/zrok/tui" @@ -42,7 +42,7 @@ func newEnableCommand() *enableCommand { } func (cmd *enableCommand) run(_ *cobra.Command, args []string) { - zrd, err := environment.Load() + zrd, err := env_v0_3.Load() if err != nil { panic(err) } @@ -117,7 +117,7 @@ func (cmd *enableCommand) run(_ *cobra.Command, args []string) { prg.Send("writing the environment details...") } apiEndpoint, _ := zrd.ApiEndpoint() - zrd.Env = &environment.Environment{Token: token, ZId: resp.Payload.Identity, ApiEndpoint: apiEndpoint} + zrd.Env = &env_v0_3.Environment{Token: token, ZId: resp.Payload.Identity, ApiEndpoint: apiEndpoint} if err := zrd.Save(); err != nil { if !cmd.headless && prg != nil { prg.Send(fmt.Sprintf("there was an error saving the new environment: %v", err)) @@ -131,7 +131,7 @@ func (cmd *enableCommand) run(_ *cobra.Command, args []string) { } os.Exit(1) } - if err := environment.SaveZitiIdentity("backend", resp.Payload.Cfg); err != nil { + if err := env_v0_3.SaveZitiIdentity("backend", resp.Payload.Cfg); err != nil { if !cmd.headless && prg != nil { prg.Send(fmt.Sprintf("there was an error writing the environment: %v", err)) prg.Quit() diff --git a/cmd/zrok/invite.go b/cmd/zrok/invite.go index 1a69269a8..dd268c736 100644 --- a/cmd/zrok/invite.go +++ b/cmd/zrok/invite.go @@ -2,13 +2,13 @@ package main import ( "fmt" + "github.com/openziti/zrok/environment/env_v0_3" "os" "strings" "github.com/charmbracelet/bubbles/textinput" tea "github.com/charmbracelet/bubbletea" "github.com/charmbracelet/lipgloss" - "github.com/openziti/zrok/environment" "github.com/openziti/zrok/rest_client_zrok/account" "github.com/openziti/zrok/rest_client_zrok/metadata" "github.com/openziti/zrok/rest_model_zrok" @@ -42,7 +42,7 @@ func newInviteCommand() *inviteCommand { } func (cmd *inviteCommand) run(_ *cobra.Command, _ []string) { - zrd, err := environment.Load() + zrd, err := env_v0_3.Load() if err != nil { tui.Error("error loading environment", err) } diff --git a/cmd/zrok/release.go b/cmd/zrok/release.go index 967b3cd51..12f891b0f 100644 --- a/cmd/zrok/release.go +++ b/cmd/zrok/release.go @@ -2,7 +2,7 @@ package main import ( httptransport "github.com/go-openapi/runtime/client" - "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/environment/env_v0_3" "github.com/openziti/zrok/rest_client_zrok/share" "github.com/openziti/zrok/rest_model_zrok" "github.com/openziti/zrok/tui" @@ -31,7 +31,7 @@ func newReleaseCommand() *releaseCommand { func (cmd *releaseCommand) run(_ *cobra.Command, args []string) { shrToken := args[0] - zrd, err := environment.Load() + zrd, err := env_v0_3.Load() if err != nil { if !panicInstead { tui.Error("unable to load environment", err) diff --git a/cmd/zrok/reserve.go b/cmd/zrok/reserve.go index d39237576..c6d1b179f 100644 --- a/cmd/zrok/reserve.go +++ b/cmd/zrok/reserve.go @@ -2,7 +2,7 @@ package main import ( httptransport "github.com/go-openapi/runtime/client" - "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/environment/env_v0_3" "github.com/openziti/zrok/model" "github.com/openziti/zrok/rest_client_zrok/share" "github.com/openziti/zrok/rest_model_zrok" @@ -60,7 +60,7 @@ func (cmd *reserveCommand) run(_ *cobra.Command, args []string) { target = args[1] } - zrd, err := environment.Load() + zrd, err := env_v0_3.Load() if err != nil { if !panicInstead { tui.Error("error loading environment", err) diff --git a/cmd/zrok/sharePrivate.go b/cmd/zrok/sharePrivate.go index a3e6c3c99..4b54bfbc8 100644 --- a/cmd/zrok/sharePrivate.go +++ b/cmd/zrok/sharePrivate.go @@ -9,7 +9,7 @@ import ( "github.com/openziti/zrok/endpoints/proxy" "github.com/openziti/zrok/endpoints/tcpTunnel" "github.com/openziti/zrok/endpoints/udpTunnel" - "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/environment/env_v0_3" "github.com/openziti/zrok/model" "github.com/openziti/zrok/rest_client_zrok" "github.com/openziti/zrok/rest_client_zrok/share" @@ -78,7 +78,7 @@ func (cmd *sharePrivateCommand) run(_ *cobra.Command, args []string) { tui.Error(fmt.Sprintf("invalid backend mode '%v'; expected {proxy, web, tcpTunnel}", cmd.backendMode), nil) } - zrd, err := environment.Load() + zrd, err := env_v0_3.Load() if err != nil { if !panicInstead { tui.Error("unable to load environment", err) @@ -90,7 +90,7 @@ func (cmd *sharePrivateCommand) run(_ *cobra.Command, args []string) { tui.Error("unable to load environment; did you 'zrok enable'?", nil) } - zif, err := environment.ZitiIdentityFile("backend") + zif, err := env_v0_3.ZitiIdentityFile("backend") if err != nil { if !panicInstead { tui.Error("unable to load ziti identity configuration", err) diff --git a/cmd/zrok/sharePublic.go b/cmd/zrok/sharePublic.go index d88e2ea7b..e8a7f95bc 100644 --- a/cmd/zrok/sharePublic.go +++ b/cmd/zrok/sharePublic.go @@ -7,7 +7,7 @@ import ( httptransport "github.com/go-openapi/runtime/client" "github.com/openziti/zrok/endpoints" "github.com/openziti/zrok/endpoints/proxy" - "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/environment/env_v0_3" "github.com/openziti/zrok/model" "github.com/openziti/zrok/rest_client_zrok" "github.com/openziti/zrok/rest_client_zrok/share" @@ -72,7 +72,7 @@ func (cmd *sharePublicCommand) run(_ *cobra.Command, args []string) { tui.Error(fmt.Sprintf("invalid backend mode '%v'; expected {proxy, web}", cmd.backendMode), nil) } - zrd, err := environment.Load() + zrd, err := env_v0_3.Load() if err != nil { if !panicInstead { tui.Error("unable to load environment", err) @@ -84,7 +84,7 @@ func (cmd *sharePublicCommand) run(_ *cobra.Command, args []string) { tui.Error("unable to load environment; did you 'zrok enable'?", nil) } - zif, err := environment.ZitiIdentityFile("backend") + zif, err := env_v0_3.ZitiIdentityFile("backend") if err != nil { if !panicInstead { tui.Error("unable to load ziti identity configuration", err) diff --git a/cmd/zrok/shareReserved.go b/cmd/zrok/shareReserved.go index ac3300134..d485487f9 100644 --- a/cmd/zrok/shareReserved.go +++ b/cmd/zrok/shareReserved.go @@ -6,7 +6,7 @@ import ( httptransport "github.com/go-openapi/runtime/client" "github.com/openziti/zrok/endpoints" "github.com/openziti/zrok/endpoints/proxy" - "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/environment/env_v0_3" "github.com/openziti/zrok/rest_client_zrok/metadata" "github.com/openziti/zrok/rest_client_zrok/share" "github.com/openziti/zrok/rest_model_zrok" @@ -44,7 +44,7 @@ func (cmd *shareReservedCommand) run(_ *cobra.Command, args []string) { shrToken := args[0] var target string - zrd, err := environment.Load() + zrd, err := env_v0_3.Load() if err != nil { if !panicInstead { tui.Error("error loading environment", err) @@ -78,7 +78,7 @@ func (cmd *shareReservedCommand) run(_ *cobra.Command, args []string) { target = resp.Payload.BackendProxyEndpoint } - zif, err := environment.ZitiIdentityFile("backend") + zif, err := env_v0_3.ZitiIdentityFile("backend") if err != nil { if !panicInstead { tui.Error("unable to load ziti identity configuration", err) diff --git a/cmd/zrok/status.go b/cmd/zrok/status.go index 8728dd17b..60c62d97a 100644 --- a/cmd/zrok/status.go +++ b/cmd/zrok/status.go @@ -3,7 +3,7 @@ package main import ( "fmt" "github.com/jedib0t/go-pretty/v6/table" - "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/environment/env_v0_3" "github.com/openziti/zrok/tui" "github.com/spf13/cobra" "os" @@ -34,7 +34,7 @@ func newStatusCommand() *statusCommand { func (cmd *statusCommand) run(_ *cobra.Command, _ []string) { _, _ = fmt.Fprintf(os.Stderr, "\n") - zrd, err := environment.Load() + zrd, err := env_v0_3.Load() if err != nil { tui.Error("error loading environment", err) } diff --git a/cmd/zrok/testLoopPublic.go b/cmd/zrok/testLoopPublic.go index 902ec482e..c99420de3 100644 --- a/cmd/zrok/testLoopPublic.go +++ b/cmd/zrok/testLoopPublic.go @@ -8,7 +8,7 @@ import ( httptransport "github.com/go-openapi/runtime/client" "github.com/openziti/sdk-golang/ziti" "github.com/openziti/sdk-golang/ziti/edge" - "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/environment/env_v0_3" "github.com/openziti/zrok/model" "github.com/openziti/zrok/rest_client_zrok" "github.com/openziti/zrok/rest_client_zrok/share" @@ -105,7 +105,7 @@ func (cmd *testLoopPublicCommand) run(_ *cobra.Command, _ []string) { type looper struct { id int cmd *testLoopPublicCommand - env *environment.Environment + env *env_v0_3.Environment done chan struct{} listener edge.Listener zif string @@ -175,7 +175,7 @@ func (l *looper) ServeHTTP(w http.ResponseWriter, r *http.Request) { func (l *looper) startup() { logrus.Infof("starting #%d", l.id) - zrd, err := environment.Load() + zrd, err := env_v0_3.Load() if err != nil { panic(err) } @@ -185,7 +185,7 @@ func (l *looper) startup() { } l.env = zrd.Env - l.zif, err = environment.ZitiIdentityFile("backend") + l.zif, err = env_v0_3.ZitiIdentityFile("backend") if err != nil { panic(err) } diff --git a/controller/bootstrap.go b/controller/bootstrap.go index 70929f93c..fdfd9300e 100644 --- a/controller/bootstrap.go +++ b/controller/bootstrap.go @@ -14,7 +14,7 @@ import ( zrok_config "github.com/openziti/zrok/controller/config" "github.com/openziti/zrok/controller/store" "github.com/openziti/zrok/controller/zrokEdgeSdk" - "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/environment/env_v0_3" "github.com/openziti/zrok/model" "github.com/pkg/errors" "github.com/sirupsen/logrus" @@ -133,7 +133,7 @@ func assertZrokProxyConfigType(edge *rest_management_api_client.ZitiEdgeManageme } func getIdentityId(identityName string) (string, error) { - zif, err := environment.ZitiIdentityFile(identityName) + zif, err := env_v0_3.ZitiIdentityFile(identityName) if err != nil { return "", errors.Wrapf(err, "error opening identity '%v' from environment", identityName) } @@ -195,7 +195,7 @@ func bootstrapIdentity(name string, edge *rest_management_api_client.ZitiEdgeMan if err != nil { return "", errors.Wrapf(err, "error encoding identity config '%v'", name) } - if err := environment.SaveZitiIdentity(name, out.String()); err != nil { + if err := env_v0_3.SaveZitiIdentity(name, out.String()); err != nil { return "", errors.Wrapf(err, "error saving identity config '%v'", name) } return zId, nil diff --git a/endpoints/proxy/frontend.go b/endpoints/proxy/frontend.go index d38ea3e60..db1ede678 100644 --- a/endpoints/proxy/frontend.go +++ b/endpoints/proxy/frontend.go @@ -6,7 +6,7 @@ import ( "github.com/openziti/sdk-golang/ziti" "github.com/openziti/zrok/endpoints" "github.com/openziti/zrok/endpoints/publicProxy/notFoundUi" - "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/environment/env_v0_3" "github.com/openziti/zrok/model" "github.com/openziti/zrok/util" "github.com/pkg/errors" @@ -40,7 +40,7 @@ type Frontend struct { } func NewFrontend(cfg *FrontendConfig) (*Frontend, error) { - zCfgPath, err := environment.ZitiIdentityFile(cfg.IdentityName) + zCfgPath, err := env_v0_3.ZitiIdentityFile(cfg.IdentityName) if err != nil { return nil, errors.Wrapf(err, "error getting ziti identity '%v' from environment", cfg.IdentityName) } diff --git a/endpoints/publicProxy/http.go b/endpoints/publicProxy/http.go index 42672b95f..51a422c11 100644 --- a/endpoints/publicProxy/http.go +++ b/endpoints/publicProxy/http.go @@ -7,7 +7,7 @@ import ( "github.com/openziti/zrok/endpoints" "github.com/openziti/zrok/endpoints/publicProxy/healthUi" "github.com/openziti/zrok/endpoints/publicProxy/notFoundUi" - "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/environment/env_v0_3" "github.com/openziti/zrok/model" "github.com/openziti/zrok/util" "github.com/pkg/errors" @@ -26,7 +26,7 @@ type httpFrontend struct { } func NewHTTP(cfg *Config) (*httpFrontend, error) { - zCfgPath, err := environment.ZitiIdentityFile(cfg.Identity) + zCfgPath, err := env_v0_3.ZitiIdentityFile(cfg.Identity) if err != nil { return nil, errors.Wrapf(err, "error getting ziti identity '%v' from environment", cfg.Identity) } diff --git a/endpoints/tcpTunnel/frontend.go b/endpoints/tcpTunnel/frontend.go index f4f9e3aa4..2280e4295 100644 --- a/endpoints/tcpTunnel/frontend.go +++ b/endpoints/tcpTunnel/frontend.go @@ -3,7 +3,7 @@ package tcpTunnel import ( "github.com/openziti/sdk-golang/ziti" "github.com/openziti/zrok/endpoints" - "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/environment/env_v0_3" "github.com/openziti/zrok/model" "github.com/pkg/errors" "github.com/sirupsen/logrus" @@ -29,7 +29,7 @@ func NewFrontend(cfg *FrontendConfig) (*Frontend, error) { if err != nil { return nil, errors.Wrapf(err, "error resolving tcp address '%v'", cfg.BindAddress) } - zCfgPath, err := environment.ZitiIdentityFile(cfg.IdentityName) + zCfgPath, err := env_v0_3.ZitiIdentityFile(cfg.IdentityName) if err != nil { return nil, errors.Wrapf(err, "error getting ziti identity '%v' from environment", cfg.IdentityName) } diff --git a/endpoints/udpTunnel/frontend.go b/endpoints/udpTunnel/frontend.go index 785597f9c..3463aa8ca 100644 --- a/endpoints/udpTunnel/frontend.go +++ b/endpoints/udpTunnel/frontend.go @@ -3,7 +3,7 @@ package udpTunnel import ( "github.com/openziti/sdk-golang/ziti" "github.com/openziti/zrok/endpoints" - "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/environment/env_v0_3" "github.com/openziti/zrok/model" "github.com/pkg/errors" "github.com/sirupsen/logrus" @@ -99,7 +99,7 @@ func NewFrontend(cfg *FrontendConfig) (*Frontend, error) { if err != nil { return nil, errors.Wrapf(err, "error resolving udp address '%v'", cfg.BindAddress) } - zCfgPath, err := environment.ZitiIdentityFile(cfg.IdentityName) + zCfgPath, err := env_v0_3.ZitiIdentityFile(cfg.IdentityName) if err != nil { return nil, errors.Wrapf(err, "error getting ziti identity '%v' from environment", cfg.IdentityName) } diff --git a/environment/client.go b/environment/env_v0_3/client.go similarity index 98% rename from environment/client.go rename to environment/env_v0_3/client.go index bb752a815..319377fb5 100644 --- a/environment/client.go +++ b/environment/env_v0_3/client.go @@ -1,4 +1,4 @@ -package environment +package env_v0_3 import ( "github.com/go-openapi/runtime" diff --git a/environment/config.go b/environment/env_v0_3/config.go similarity index 98% rename from environment/config.go rename to environment/env_v0_3/config.go index 46931e5b1..0aafdc04f 100644 --- a/environment/config.go +++ b/environment/env_v0_3/config.go @@ -1,4 +1,4 @@ -package environment +package env_v0_3 import ( "encoding/json" diff --git a/environment/environment.go b/environment/env_v0_3/environment.go similarity index 98% rename from environment/environment.go rename to environment/env_v0_3/environment.go index 8542ab302..fe4cd2709 100644 --- a/environment/environment.go +++ b/environment/env_v0_3/environment.go @@ -1,4 +1,4 @@ -package environment +package env_v0_3 import ( "encoding/json" diff --git a/environment/identity.go b/environment/env_v0_3/identity.go similarity index 97% rename from environment/identity.go rename to environment/env_v0_3/identity.go index b3ef5a6f0..2b5f4dc23 100644 --- a/environment/identity.go +++ b/environment/env_v0_3/identity.go @@ -1,4 +1,4 @@ -package environment +package env_v0_3 import ( "github.com/pkg/errors" diff --git a/environment/root.go b/environment/env_v0_3/root.go similarity index 99% rename from environment/root.go rename to environment/env_v0_3/root.go index ff015350b..e5be40640 100644 --- a/environment/root.go +++ b/environment/env_v0_3/root.go @@ -1,4 +1,4 @@ -package environment +package env_v0_3 import ( "fmt" diff --git a/environment/version.go b/environment/env_v0_3/version.go similarity index 98% rename from environment/version.go rename to environment/env_v0_3/version.go index e75238ed1..1416126ca 100644 --- a/environment/version.go +++ b/environment/env_v0_3/version.go @@ -1,4 +1,4 @@ -package environment +package env_v0_3 import ( "encoding/json" diff --git a/sdk/share.go b/sdk/share.go index d98f9b5b3..15d33f2da 100644 --- a/sdk/share.go +++ b/sdk/share.go @@ -1,7 +1,7 @@ package sdk import ( - "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/environment/env_v0_3" "github.com/openziti/zrok/rest_model_zrok" "github.com/pkg/errors" ) @@ -29,14 +29,14 @@ func newPublicShare(request *ShareRequest) (*Share, error) { return nil, nil } -func loadEnvironment(request *ShareRequest) (*environment.Root, error) { - env, err := environment.Load() +func loadEnvironment(request *ShareRequest) (*env_v0_3.Root, error) { + env, err := env_v0_3.Load() if err != nil { return nil, errors.Wrap(err, "error loading environment") } return env, nil } -func createShare(zrd *environment.Root, req *rest_model_zrok.ShareRequest) (*Share, error) { +func createShare(zrd *env_v0_3.Root, req *rest_model_zrok.ShareRequest) (*Share, error) { return nil, nil } From 875644398fc85f1d67ec719fd220560593d53bfd Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Tue, 11 Jul 2023 15:47:13 -0400 Subject: [PATCH 05/28] first round of the multi-version environment proxy (#369) --- environment/api.go | 36 +++++++++++++++++++++++++++++++++++ environment/env_core/model.go | 11 +++++++++++ 2 files changed, 47 insertions(+) create mode 100644 environment/api.go create mode 100644 environment/env_core/model.go diff --git a/environment/api.go b/environment/api.go new file mode 100644 index 000000000..8d163d95a --- /dev/null +++ b/environment/api.go @@ -0,0 +1,36 @@ +package environment + +import ( + "github.com/openziti/zrok/environment/env_v0_3" +) + +type Root interface { +} + +func Load() (Root, error) { + return nil, nil +} + +func IsEnabled() (bool, error) { + return env_v0_3.IsEnabled() +} + +func DeleteEnvironment() error { + return env_v0_3.DeleteEnvironment() +} + +func HasConfig() (bool, error) { + return env_v0_3.HasConfig() +} + +func ZitiIdentityFile(name string) (string, error) { + return env_v0_3.ZitiIdentityFile(name) +} + +func SaveZitiIdentity(name, data string) error { + return env_v0_3.SaveZitiIdentity(name, data) +} + +func DeleteZitiIdentity(name string) error { + return env_v0_3.DeleteZitiIdentity(name) +} diff --git a/environment/env_core/model.go b/environment/env_core/model.go new file mode 100644 index 000000000..6ae74a4df --- /dev/null +++ b/environment/env_core/model.go @@ -0,0 +1,11 @@ +package env_core + +type Environment struct { + Token string + ZitiIdentity string + ApiEndpoint string +} + +type Config struct { + ApiEndpoint string +} From 3dd90fd15d08bbc59031ef67e4356f006f0093f3 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Wed, 12 Jul 2023 16:18:13 -0400 Subject: [PATCH 06/28] updated high-level environment framework (#369) --- environment/api.go | 47 +++++++++++++++++++---------------- environment/env_core/model.go | 5 ++++ 2 files changed, 30 insertions(+), 22 deletions(-) diff --git a/environment/api.go b/environment/api.go index 8d163d95a..4884b0914 100644 --- a/environment/api.go +++ b/environment/api.go @@ -1,36 +1,39 @@ package environment import ( - "github.com/openziti/zrok/environment/env_v0_3" + "github.com/openziti/zrok/environment/env_core" + "github.com/openziti/zrok/rest_client_zrok" ) type Root interface { -} - -func Load() (Root, error) { + Metadata() *env_core.Metadata + IsLatest() bool + HasConfig() (bool, error) + Config() *env_core.Config + SetConfig(cfg *env_core.Config) error + Client() (*rest_client_zrok.Zrok, error) + ApiEndpoint() (string, string) + Environment() *env_core.Environment + DeleteEnvironment() error + IsEnabled() (bool, error) + ZitiIdentityFile(name string) (string, error) + SaveZitiIdentity(name, data string) error + DeleteZitiIdentity(name string) error + Obliterate() error +} + +func ListRoots() ([]*env_core.Metadata, error) { return nil, nil } -func IsEnabled() (bool, error) { - return env_v0_3.IsEnabled() -} - -func DeleteEnvironment() error { - return env_v0_3.DeleteEnvironment() -} - -func HasConfig() (bool, error) { - return env_v0_3.HasConfig() -} - -func ZitiIdentityFile(name string) (string, error) { - return env_v0_3.ZitiIdentityFile(name) +func LoadRoot() (Root, error) { + return nil, nil } -func SaveZitiIdentity(name, data string) error { - return env_v0_3.SaveZitiIdentity(name, data) +func LoadRootVersion(m *env_core.Metadata) (Root, error) { + return nil, nil } -func DeleteZitiIdentity(name string) error { - return env_v0_3.DeleteZitiIdentity(name) +func UpdateRoot(r Root) (Root, error) { + return nil, nil } diff --git a/environment/env_core/model.go b/environment/env_core/model.go index 6ae74a4df..2f7f9da70 100644 --- a/environment/env_core/model.go +++ b/environment/env_core/model.go @@ -9,3 +9,8 @@ type Environment struct { type Config struct { ApiEndpoint string } + +type Metadata struct { + V string + RootPath string +} From 7bfafd494f6ae44220d873d4ba160d7ddd46377e Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Wed, 12 Jul 2023 17:22:24 -0400 Subject: [PATCH 07/28] building out env_v0_3x (#369) --- environment/api.go | 20 +++- environment/env_v0_3x/api.go | 65 ++++++++++ environment/env_v0_3x/dirs.go | 38 ++++++ environment/env_v0_3x/root.go | 216 ++++++++++++++++++++++++++++++++++ 4 files changed, 336 insertions(+), 3 deletions(-) create mode 100644 environment/env_v0_3x/api.go create mode 100644 environment/env_v0_3x/dirs.go create mode 100644 environment/env_v0_3x/root.go diff --git a/environment/api.go b/environment/api.go index 4884b0914..b0bce4526 100644 --- a/environment/api.go +++ b/environment/api.go @@ -2,12 +2,13 @@ package environment import ( "github.com/openziti/zrok/environment/env_core" + "github.com/openziti/zrok/environment/env_v0_3x" "github.com/openziti/zrok/rest_client_zrok" + "github.com/pkg/errors" ) type Root interface { Metadata() *env_core.Metadata - IsLatest() bool HasConfig() (bool, error) Config() *env_core.Config SetConfig(cfg *env_core.Config) error @@ -27,11 +28,24 @@ func ListRoots() ([]*env_core.Metadata, error) { } func LoadRoot() (Root, error) { - return nil, nil + return env_v0_3x.Load() } func LoadRootVersion(m *env_core.Metadata) (Root, error) { - return nil, nil + if m == nil { + return nil, errors.Errorf("specify metadata version") + } + switch m.V { + case env_v0_3x.V: + return env_v0_3x.Load() + + default: + return nil, errors.Errorf("unknown metadata version '%v'", m.V) + } +} + +func NeedsUpdate(r Root) bool { + return r.Metadata().V != env_v0_3x.V } func UpdateRoot(r Root) (Root, error) { diff --git a/environment/env_v0_3x/api.go b/environment/env_v0_3x/api.go new file mode 100644 index 000000000..fb19186bc --- /dev/null +++ b/environment/env_v0_3x/api.go @@ -0,0 +1,65 @@ +package env_v0_3x + +import ( + "github.com/openziti/zrok/environment/env_core" + "github.com/openziti/zrok/rest_client_zrok" +) + +func (r *Root) Metadata() *env_core.Metadata { + return r.meta +} + +func (r *Root) HasConfig() (bool, error) { + return r.cfg != nil, nil +} + +func (r *Root) Config() *env_core.Config { + return r.cfg +} + +func (r *Root) SetConfig(cfg *env_core.Config) error { + if err := saveConfig(cfg); err != nil { + return err + } + r.cfg = cfg + return nil +} + +func (r *Root) Client() (*rest_client_zrok.Zrok, error) { + return nil, nil +} + +func (r *Root) ApiEndpoint() (string, string) { + if r.env != nil { + return r.env.ApiEndpoint, "env" + } + return "", "" +} + +func (r *Root) Environment() *env_core.Environment { + return r.env +} + +func (r *Root) DeleteEnvironment() error { + return nil +} + +func (r *Root) IsEnabled() (bool, error) { + return r.env != nil, nil +} + +func (r *Root) ZitiIdentityFile(name string) (string, error) { + return "", nil +} + +func (r *Root) SaveZitiIdentity(name, data string) error { + return nil +} + +func (r *Root) DeleteZitiIdentity(name string) error { + return nil +} + +func (r *Root) Obliterate() error { + return nil +} diff --git a/environment/env_v0_3x/dirs.go b/environment/env_v0_3x/dirs.go new file mode 100644 index 000000000..10a70de79 --- /dev/null +++ b/environment/env_v0_3x/dirs.go @@ -0,0 +1,38 @@ +package env_v0_3x + +import ( + "os" + "path/filepath" +) + +func rootDir() (string, error) { + home, err := os.UserHomeDir() + if err != nil { + return "", err + } + return filepath.Join(home, ".zrok"), nil +} + +func metadataFile() (string, error) { + zrd, err := rootDir() + if err != nil { + return "", err + } + return filepath.Join(zrd, "metadata.json"), nil +} + +func configFile() (string, error) { + zrd, err := rootDir() + if err != nil { + return "", err + } + return filepath.Join(zrd, "config.json"), nil +} + +func environmentFile() (string, error) { + zrd, err := rootDir() + if err != nil { + return "", err + } + return filepath.Join(zrd, "environment.json"), nil +} diff --git a/environment/env_v0_3x/root.go b/environment/env_v0_3x/root.go new file mode 100644 index 000000000..2a725376d --- /dev/null +++ b/environment/env_v0_3x/root.go @@ -0,0 +1,216 @@ +package env_v0_3x + +import ( + "encoding/json" + "github.com/openziti/zrok/environment/env_core" + "github.com/pkg/errors" + "os" + "path/filepath" +) + +const V = "v0.3" + +type Root struct { + meta *env_core.Metadata + cfg *env_core.Config + env *env_core.Environment +} + +func Load() (*Root, error) { + r := &Root{} + exists, err := rootExists() + if err != nil { + return nil, err + } + if exists { + if meta, err := loadMetadata(); err == nil { + r.meta = meta + } else { + return nil, err + } + + if cfg, err := loadConfig(); err == nil { + r.cfg = cfg + } + + if env, err := loadEnvironment(); err == nil { + r.env = env + } + + } else { + root, err := rootDir() + if err != nil { + return nil, err + } + r.meta = &env_core.Metadata{ + V: V, + RootPath: root, + } + } + return r, nil +} + +func rootExists() (bool, error) { + mf, err := metadataFile() + if err != nil { + return false, err + } + _, err = os.Stat(mf) + if os.IsNotExist(err) { + return false, nil + } + if err != nil { + return false, err + } + return true, err +} + +func loadMetadata() (*env_core.Metadata, error) { + mf, err := metadataFile() + if err != nil { + return nil, err + } + data, err := os.ReadFile(mf) + if err != nil { + return nil, err + } + m := &metadata{} + if err := json.Unmarshal(data, m); err != nil { + return nil, errors.Wrapf(err, "error unmarshaling metadata file '%v'", mf) + } + if m.V != V { + return nil, errors.Errorf("got metadata version '%v', expected '%v'", m.V, V) + } + rf, err := rootDir() + if err != nil { + return nil, err + } + out := &env_core.Metadata{ + V: m.V, + RootPath: rf, + } + return out, nil +} + +func loadConfig() (*env_core.Config, error) { + cf, err := configFile() + if err != nil { + return nil, errors.Wrap(err, "error getting config file path") + } + data, err := os.ReadFile(cf) + if err != nil { + return nil, errors.Wrapf(err, "error reading config file '%v'", cf) + } + cfg := &config{} + if err := json.Unmarshal(data, cfg); err != nil { + return nil, errors.Wrapf(err, "error unmarshaling config file '%v'", cf) + } + out := &env_core.Config{ + ApiEndpoint: cfg.ApiEndpoint, + } + return out, nil +} + +func saveConfig(cfg *env_core.Config) error { + in := &config{ApiEndpoint: cfg.ApiEndpoint} + data, err := json.MarshalIndent(in, "", " ") + if err != nil { + return errors.Wrap(err, "error marshaling config") + } + cf, err := configFile() + if err != nil { + return errors.Wrap(err, "error getting config file path") + } + if err := os.MkdirAll(filepath.Dir(cf), os.FileMode(0700)); err != nil { + return errors.Wrapf(err, "error creating environment path '%v'", filepath.Dir(cf)) + } + if err := os.WriteFile(cf, data, os.FileMode(0600)); err != nil { + return errors.Wrap(err, "error saving config file") + } + return nil +} + +func isEnabled() (bool, error) { + ef, err := environmentFile() + if err != nil { + return false, errors.Wrap(err, "error getting environment file path") + } + _, err = os.Stat(ef) + if os.IsNotExist(err) { + return false, nil + } + if err != nil { + return false, errors.Wrapf(err, "error stat-ing environment file '%v'", ef) + } + return true, nil +} + +func loadEnvironment() (*env_core.Environment, error) { + ef, err := environmentFile() + if err != nil { + return nil, errors.Wrap(err, "error getting environment file") + } + data, err := os.ReadFile(ef) + if err != nil { + return nil, errors.Wrapf(err, "error reading environment file '%v'", ef) + } + env := &environment{} + if err := json.Unmarshal(data, env); err != nil { + return nil, errors.Wrapf(err, "error unmarshaling environment file '%v'", ef) + } + out := &env_core.Environment{ + Token: env.Token, + ZitiIdentity: env.ZId, + ApiEndpoint: env.ApiEndpoint, + } + return out, nil +} + +func saveEnvironment(env *env_core.Environment) error { + in := &environment{ + Token: env.Token, + ZId: env.ZitiIdentity, + ApiEndpoint: env.ApiEndpoint, + } + data, err := json.MarshalIndent(in, "", " ") + if err != nil { + return errors.Wrap(err, "error marshaling environment") + } + ef, err := environmentFile() + if err != nil { + return errors.Wrap(err, "error getting environment file") + } + if err := os.MkdirAll(filepath.Dir(ef), os.FileMode(0700)); err != nil { + return errors.Wrapf(err, "error creating environment path '%v'", filepath.Dir(ef)) + } + if err := os.WriteFile(ef, data, os.FileMode(0600)); err != nil { + return errors.Wrap(err, "error saving environment file") + } + return nil +} + +func deleteEnvironment() error { + ef, err := environmentFile() + if err != nil { + return errors.Wrap(err, "error getting environment file") + } + if err := os.Remove(ef); err != nil { + return errors.Wrap(err, "error removing environment file") + } + + return nil +} + +type metadata struct { + V string `json:"v"` +} + +type config struct { + ApiEndpoint string `json:"api_endpoint"` +} + +type environment struct { + Token string `json:"zrok_token"` + ZId string `json:"ziti_identity"` + ApiEndpoint string `json:"api_endpoint"` +} From 04b0b64ebf46bad74a6000481261fa647e8f4243 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Thu, 13 Jul 2023 14:26:35 -0400 Subject: [PATCH 08/28] migrated all usages to the new package (#369) --- cmd/zrok/accessPrivate.go | 16 +- cmd/zrok/adminCreateFrontend.go | 9 +- cmd/zrok/adminCreateIdentity.go | 17 +- cmd/zrok/adminDeleteFrontend.go | 6 +- cmd/zrok/adminGenerate.go | 6 +- cmd/zrok/adminListFrontends.go | 6 +- cmd/zrok/adminUpdateFrontend.go | 6 +- cmd/zrok/configGet.go | 8 +- cmd/zrok/configSet.go | 43 ++-- cmd/zrok/configUnset.go | 27 +- cmd/zrok/console.go | 4 +- cmd/zrok/disable.go | 16 +- cmd/zrok/enable.go | 29 +-- cmd/zrok/invite.go | 17 +- cmd/zrok/release.go | 12 +- cmd/zrok/reserve.go | 12 +- cmd/zrok/sharePrivate.go | 18 +- cmd/zrok/sharePublic.go | 18 +- cmd/zrok/shareReserved.go | 12 +- cmd/zrok/status.go | 16 +- cmd/zrok/testLoopPublic.go | 19 +- controller/bootstrap.go | 15 +- endpoints/proxy/frontend.go | 8 +- endpoints/publicProxy/http.go | 8 +- endpoints/tcpTunnel/frontend.go | 8 +- endpoints/udpTunnel/frontend.go | 8 +- environment/api.go | 18 +- environment/env_v0_3/api.go | 151 +++++++++++ environment/env_v0_3/client.go | 61 ----- environment/env_v0_3/config.go | 61 ----- environment/{env_v0_3x => env_v0_3}/dirs.go | 19 +- environment/env_v0_3/environment.go | 75 ------ environment/env_v0_3/identity.go | 36 --- environment/env_v0_3/root.go | 271 ++++++++++++-------- environment/env_v0_3/version.go | 53 ---- environment/env_v0_3x/api.go | 65 ----- environment/env_v0_3x/root.go | 216 ---------------- sdk/share.go | 14 - 38 files changed, 528 insertions(+), 876 deletions(-) create mode 100644 environment/env_v0_3/api.go delete mode 100644 environment/env_v0_3/client.go delete mode 100644 environment/env_v0_3/config.go rename environment/{env_v0_3x => env_v0_3}/dirs.go (64%) delete mode 100644 environment/env_v0_3/environment.go delete mode 100644 environment/env_v0_3/identity.go delete mode 100644 environment/env_v0_3/version.go delete mode 100644 environment/env_v0_3x/api.go delete mode 100644 environment/env_v0_3x/root.go diff --git a/cmd/zrok/accessPrivate.go b/cmd/zrok/accessPrivate.go index 9f485c5af..6927b57f7 100644 --- a/cmd/zrok/accessPrivate.go +++ b/cmd/zrok/accessPrivate.go @@ -8,7 +8,7 @@ import ( "github.com/openziti/zrok/endpoints/proxy" "github.com/openziti/zrok/endpoints/tcpTunnel" "github.com/openziti/zrok/endpoints/udpTunnel" - "github.com/openziti/zrok/environment/env_v0_3" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/rest_client_zrok" "github.com/openziti/zrok/rest_client_zrok/share" "github.com/openziti/zrok/rest_model_zrok" @@ -48,16 +48,16 @@ func newAccessPrivateCommand() *accessPrivateCommand { func (cmd *accessPrivateCommand) run(_ *cobra.Command, args []string) { shrToken := args[0] - zrd, err := env_v0_3.Load() + env, err := environment.LoadRoot() if err != nil { tui.Error("error loading environment", err) } - if zrd.Env == nil { + if !env.IsEnabled() { tui.Error("unable to load environment; did you 'zrok enable'?", nil) } - zrok, err := zrd.Client() + zrok, err := env.Client() if err != nil { if !panicInstead { tui.Error("unable to create zrok client", err) @@ -65,11 +65,11 @@ func (cmd *accessPrivateCommand) run(_ *cobra.Command, args []string) { panic(err) } - auth := httptransport.APIKeyAuth("X-TOKEN", "header", zrd.Env.Token) + auth := httptransport.APIKeyAuth("X-TOKEN", "header", env.Environment().Token) req := share.NewAccessParams() req.Body = &rest_model_zrok.AccessRequest{ ShrToken: shrToken, - EnvZID: zrd.Env.ZId, + EnvZID: env.Environment().ZitiIdentity, } accessResp, err := zrok.Share.Access(req, auth) if err != nil { @@ -168,7 +168,7 @@ func (cmd *accessPrivateCommand) run(_ *cobra.Command, args []string) { signal.Notify(c, os.Interrupt, syscall.SIGTERM) go func() { <-c - cmd.destroy(accessResp.Payload.FrontendToken, zrd.Env.ZId, shrToken, zrok, auth) + cmd.destroy(accessResp.Payload.FrontendToken, env.Environment().ZitiIdentity, shrToken, zrok, auth) os.Exit(0) }() @@ -203,7 +203,7 @@ func (cmd *accessPrivateCommand) run(_ *cobra.Command, args []string) { } close(requests) - cmd.destroy(accessResp.Payload.FrontendToken, zrd.Env.ZId, shrToken, zrok, auth) + cmd.destroy(accessResp.Payload.FrontendToken, env.Environment().ZitiIdentity, shrToken, zrok, auth) } } diff --git a/cmd/zrok/adminCreateFrontend.go b/cmd/zrok/adminCreateFrontend.go index 2b88bc109..430ecc59c 100644 --- a/cmd/zrok/adminCreateFrontend.go +++ b/cmd/zrok/adminCreateFrontend.go @@ -1,14 +1,13 @@ package main import ( - "github.com/openziti/zrok/environment/env_v0_3" - "os" - + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/rest_client_zrok/admin" "github.com/openziti/zrok/rest_model_zrok" "github.com/openziti/zrok/tui" "github.com/sirupsen/logrus" "github.com/spf13/cobra" + "os" ) func init() { @@ -35,12 +34,12 @@ func (cmd *adminCreateFrontendCommand) run(_ *cobra.Command, args []string) { publicName := args[1] urlTemplate := args[2] - zrd, err := env_v0_3.Load() + env, err := environment.LoadRoot() if err != nil { panic(err) } - zrok, err := zrd.Client() + zrok, err := env.Client() if err != nil { panic(err) } diff --git a/cmd/zrok/adminCreateIdentity.go b/cmd/zrok/adminCreateIdentity.go index e6da348f0..74723ffbd 100644 --- a/cmd/zrok/adminCreateIdentity.go +++ b/cmd/zrok/adminCreateIdentity.go @@ -2,7 +2,7 @@ package main import ( "fmt" - "github.com/openziti/zrok/environment/env_v0_3" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/rest_client_zrok/admin" "github.com/sirupsen/logrus" "github.com/spf13/cobra" @@ -32,7 +32,11 @@ func newAdminCreateIdentity() *adminCreateIdentity { func (cmd *adminCreateIdentity) run(_ *cobra.Command, args []string) { name := args[0] - zif, err := env_v0_3.ZitiIdentityFile(name) + env, err := environment.LoadRoot() + if err != nil { + panic(err) + } + zif, err := env.ZitiIdentityFile(name) if err != nil { panic(err) } @@ -41,12 +45,7 @@ func (cmd *adminCreateIdentity) run(_ *cobra.Command, args []string) { os.Exit(1) } - zrd, err := env_v0_3.Load() - if err != nil { - panic(err) - } - - zrok, err := zrd.Client() + zrok, err := env.Client() if err != nil { panic(err) } @@ -59,7 +58,7 @@ func (cmd *adminCreateIdentity) run(_ *cobra.Command, args []string) { panic(err) } - if err := env_v0_3.SaveZitiIdentity(name, resp.Payload.Cfg); err != nil { + if err := env.SaveZitiIdentity(name, resp.Payload.Cfg); err != nil { panic(err) } diff --git a/cmd/zrok/adminDeleteFrontend.go b/cmd/zrok/adminDeleteFrontend.go index b715d44f6..9d806df72 100644 --- a/cmd/zrok/adminDeleteFrontend.go +++ b/cmd/zrok/adminDeleteFrontend.go @@ -1,7 +1,7 @@ package main import ( - "github.com/openziti/zrok/environment/env_v0_3" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/rest_client_zrok/admin" "github.com/openziti/zrok/rest_model_zrok" "github.com/sirupsen/logrus" @@ -30,12 +30,12 @@ func newAdminDeleteFrontendCommand() *adminDeleteFrontendCommand { func (cmd *adminDeleteFrontendCommand) run(_ *cobra.Command, args []string) { feToken := args[0] - zrd, err := env_v0_3.Load() + env, err := environment.LoadRoot() if err != nil { panic(err) } - zrok, err := zrd.Client() + zrok, err := env.Client() if err != nil { panic(err) } diff --git a/cmd/zrok/adminGenerate.go b/cmd/zrok/adminGenerate.go index 5740ca268..9576646d7 100644 --- a/cmd/zrok/adminGenerate.go +++ b/cmd/zrok/adminGenerate.go @@ -3,7 +3,7 @@ package main import ( "fmt" "github.com/jaevor/go-nanoid" - "github.com/openziti/zrok/environment/env_v0_3" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/rest_client_zrok/admin" "github.com/openziti/zrok/rest_model_zrok" "github.com/sirupsen/logrus" @@ -43,12 +43,12 @@ func (cmd *adminGenerateCommand) run(_ *cobra.Command, args []string) { } } - zrd, err := env_v0_3.Load() + env, err := environment.LoadRoot() if err != nil { logrus.Error("error loading environment", err) } - zrok, err := zrd.Client() + zrok, err := env.Client() if err != nil { if !panicInstead { logrus.Error("error creating zrok api client", err) diff --git a/cmd/zrok/adminListFrontends.go b/cmd/zrok/adminListFrontends.go index 818acca36..ee7ece190 100644 --- a/cmd/zrok/adminListFrontends.go +++ b/cmd/zrok/adminListFrontends.go @@ -3,7 +3,7 @@ package main import ( "fmt" "github.com/jedib0t/go-pretty/v6/table" - "github.com/openziti/zrok/environment/env_v0_3" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/rest_client_zrok/admin" "github.com/spf13/cobra" "os" @@ -31,12 +31,12 @@ func newAdminListFrontendsCommand() *adminListFrontendsCommand { } func (cmd *adminListFrontendsCommand) run(_ *cobra.Command, _ []string) { - zrd, err := env_v0_3.Load() + env, err := environment.LoadRoot() if err != nil { panic(err) } - zrok, err := zrd.Client() + zrok, err := env.Client() if err != nil { panic(err) } diff --git a/cmd/zrok/adminUpdateFrontend.go b/cmd/zrok/adminUpdateFrontend.go index f1d434a3d..2c77513d3 100644 --- a/cmd/zrok/adminUpdateFrontend.go +++ b/cmd/zrok/adminUpdateFrontend.go @@ -1,7 +1,7 @@ package main import ( - "github.com/openziti/zrok/environment/env_v0_3" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/rest_client_zrok/admin" "github.com/openziti/zrok/rest_model_zrok" "github.com/sirupsen/logrus" @@ -38,12 +38,12 @@ func (cmd *adminUpdateFrontendCommand) run(_ *cobra.Command, args []string) { panic("must specify at least one of public name or url template") } - zrd, err := env_v0_3.Load() + env, err := environment.LoadRoot() if err != nil { panic(err) } - zrok, err := zrd.Client() + zrok, err := env.Client() if err != nil { panic(err) } diff --git a/cmd/zrok/configGet.go b/cmd/zrok/configGet.go index ef8e2208f..45480da41 100644 --- a/cmd/zrok/configGet.go +++ b/cmd/zrok/configGet.go @@ -2,7 +2,7 @@ package main import ( "fmt" - "github.com/openziti/zrok/environment/env_v0_3" + "github.com/openziti/zrok/environment" "github.com/spf13/cobra" ) @@ -28,15 +28,15 @@ func newConfigGetCommand() *configGetCommand { func (cmd *configGetCommand) run(_ *cobra.Command, args []string) { configName := args[0] - zrd, err := env_v0_3.Load() + env, err := environment.LoadRoot() if err != nil { panic(err) } switch configName { case "apiEndpoint": - if zrd.Cfg != nil && zrd.Cfg.ApiEndpoint != "" { - fmt.Printf("apiEndpoint = %v\n", zrd.Cfg.ApiEndpoint) + if env.Config() != nil && env.Config().ApiEndpoint != "" { + fmt.Printf("apiEndpoint = %v\n", env.Config().ApiEndpoint) } else { fmt.Println("apiEndpoint = ") } diff --git a/cmd/zrok/configSet.go b/cmd/zrok/configSet.go index eb84f6971..553102e9f 100644 --- a/cmd/zrok/configSet.go +++ b/cmd/zrok/configSet.go @@ -2,12 +2,12 @@ package main import ( "fmt" - "github.com/openziti/zrok/environment/env_v0_3" - "net/url" - "os" - + "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/environment/env_core" "github.com/openziti/zrok/tui" "github.com/spf13/cobra" + "net/url" + "os" ) func init() { @@ -33,17 +33,13 @@ func (cmd *configSetCommand) run(_ *cobra.Command, args []string) { configName := args[0] value := args[1] - zrd, err := env_v0_3.Load() + env, err := environment.LoadRoot() if err != nil { panic(err) } - modified := false switch configName { case "apiEndpoint": - if zrd.Cfg == nil { - zrd.Cfg = &env_v0_3.Config{} - } ok, err := isFullyValidUrl(value) if err != nil { tui.Error("unable to validate api endpoint", err) @@ -51,24 +47,25 @@ func (cmd *configSetCommand) run(_ *cobra.Command, args []string) { if !ok { tui.Error("invalid apiEndpoint; please make sure URL starts with http:// or https://", nil) } - zrd.Cfg.ApiEndpoint = value - modified = true - - default: - fmt.Printf("unknown config name '%v'\n", configName) - os.Exit(1) - } - - if modified { - if err := zrd.Save(); err != nil { - panic(err) + if env.Config() == nil { + if err := env.SetConfig(&env_core.Config{ApiEndpoint: value}); err != nil { + tui.Error("unable to save config", err) + } + } else { + cfg := env.Config() + cfg.ApiEndpoint = value + if err := env.SetConfig(cfg); err != nil { + tui.Error("unable to save config", err) + } } fmt.Println("zrok configuration updated") - if zrd.Env != nil && configName == "apiEndpoint" { + if env.IsEnabled() { fmt.Printf("\n[%v]: because you have a %v-d environment, you won't see your config change until you run %v first!\n\n", tui.WarningLabel, tui.Code.Render("zrok enable"), tui.Code.Render("zrok disable")) } - } else { - fmt.Println("zrok configuration not changed") + + default: + fmt.Printf("unknown config name '%v'\n", configName) + os.Exit(1) } } diff --git a/cmd/zrok/configUnset.go b/cmd/zrok/configUnset.go index 72eeda461..a7cb6930a 100644 --- a/cmd/zrok/configUnset.go +++ b/cmd/zrok/configUnset.go @@ -2,7 +2,8 @@ package main import ( "fmt" - "github.com/openziti/zrok/environment/env_v0_3" + "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/environment/env_core" "github.com/openziti/zrok/tui" "github.com/spf13/cobra" "os" @@ -30,33 +31,23 @@ func newConfigUnsetCommand() *configUnsetCommand { func (cmd *configUnsetCommand) run(_ *cobra.Command, args []string) { configName := args[0] - zrd, err := env_v0_3.Load() + env, err := environment.LoadRoot() if err != nil { panic(err) } - modified := false switch configName { case "apiEndpoint": - if zrd.Cfg != nil && zrd.Cfg.ApiEndpoint != "" { - zrd.Cfg.ApiEndpoint = "" - modified = true + if err := env.SetConfig(&env_core.Config{}); err != nil { + tui.Error("unable to save config", err) + } + fmt.Println("zrok configuration updated") + if env.IsEnabled() { + fmt.Printf("\n[%v]: because you have a %v-d environment, you won't see your config change until you run %v first!\n\n", tui.WarningLabel, tui.Code.Render("zrok enable"), tui.Code.Render("zrok disable")) } default: fmt.Printf("unknown config name '%v'\n", configName) os.Exit(1) } - - if modified { - if err := zrd.Save(); err != nil { - panic(err) - } - fmt.Println("zrok configuration updated") - if zrd.Env != nil && configName == "apiEndpoint" { - fmt.Printf("\n[%v]: because you have a %v-d environment, you won't see your config change until you run %v first!\n\n", tui.WarningLabel, tui.Code.Render("zrok enable"), tui.Code.Render("zrok disable")) - } - } else { - fmt.Println("zrok configuration not changed") - } } diff --git a/cmd/zrok/console.go b/cmd/zrok/console.go index 34024ff6c..72de2ce4b 100644 --- a/cmd/zrok/console.go +++ b/cmd/zrok/console.go @@ -2,7 +2,7 @@ package main import ( "fmt" - "github.com/openziti/zrok/environment/env_v0_3" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/tui" "github.com/spf13/cobra" ) @@ -27,7 +27,7 @@ func newConsoleCommand() *consoleCommand { } func (cmd *consoleCommand) run(_ *cobra.Command, _ []string) { - env, err := env_v0_3.Load() + env, err := environment.LoadRoot() if err != nil { tui.Error("unable to load environment", err) } diff --git a/cmd/zrok/disable.go b/cmd/zrok/disable.go index 20764f3c3..79c03e615 100644 --- a/cmd/zrok/disable.go +++ b/cmd/zrok/disable.go @@ -3,7 +3,7 @@ package main import ( "fmt" httpTransport "github.com/go-openapi/runtime/client" - "github.com/openziti/zrok/environment/env_v0_3" + "github.com/openziti/zrok/environment" restEnvironment "github.com/openziti/zrok/rest_client_zrok/environment" "github.com/openziti/zrok/rest_model_zrok" "github.com/openziti/zrok/tui" @@ -31,7 +31,7 @@ func newDisableCommand() *disableCommand { } func (cmd *disableCommand) run(_ *cobra.Command, _ []string) { - zrd, err := env_v0_3.Load() + env, err := environment.LoadRoot() if err != nil { if !panicInstead { tui.Error("unable to load environment", err) @@ -39,33 +39,33 @@ func (cmd *disableCommand) run(_ *cobra.Command, _ []string) { panic(err) } - if zrd.Env == nil { + if !env.IsEnabled() { tui.Error("no environment found; nothing to disable!", nil) } - zrok, err := zrd.Client() + zrok, err := env.Client() if err != nil { if !panicInstead { tui.Error("could not create zrok client", err) } panic(err) } - auth := httpTransport.APIKeyAuth("X-TOKEN", "header", zrd.Env.Token) + auth := httpTransport.APIKeyAuth("X-TOKEN", "header", env.Environment().Token) req := restEnvironment.NewDisableParams() req.Body = &rest_model_zrok.DisableRequest{ - Identity: zrd.Env.ZId, + Identity: env.Environment().ZitiIdentity, } _, err = zrok.Environment.Disable(req, auth) if err != nil { logrus.Warnf("share cleanup failed (%v); will clean up local environment", err) } - if err := env_v0_3.DeleteEnvironment(); err != nil { + if err := env.DeleteEnvironment(); err != nil { if !panicInstead { tui.Error("error removing zrok environment", err) } panic(err) } - if err := env_v0_3.DeleteZitiIdentity("backend"); err != nil { + if err := env.DeleteZitiIdentity("backend"); err != nil { if !panicInstead { tui.Error("error removing zrok backend identity", err) } diff --git a/cmd/zrok/enable.go b/cmd/zrok/enable.go index b9e84d36b..d0e5d2d37 100644 --- a/cmd/zrok/enable.go +++ b/cmd/zrok/enable.go @@ -2,20 +2,20 @@ package main import ( "fmt" - "github.com/openziti/zrok/environment/env_v0_3" - "github.com/sirupsen/logrus" - "os" - user2 "os/user" - "time" - "github.com/charmbracelet/bubbles/spinner" tea "github.com/charmbracelet/bubbletea" httptransport "github.com/go-openapi/runtime/client" + "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/environment/env_core" restEnvironment "github.com/openziti/zrok/rest_client_zrok/environment" "github.com/openziti/zrok/rest_model_zrok" "github.com/openziti/zrok/tui" "github.com/shirou/gopsutil/v3/host" + "github.com/sirupsen/logrus" "github.com/spf13/cobra" + "os" + user2 "os/user" + "time" ) func init() { @@ -42,13 +42,13 @@ func newEnableCommand() *enableCommand { } func (cmd *enableCommand) run(_ *cobra.Command, args []string) { - zrd, err := env_v0_3.Load() + env, err := environment.LoadRoot() if err != nil { panic(err) } token := args[0] - if zrd.Env != nil { + if env.IsEnabled() { tui.Error(fmt.Sprintf("you already have an enabled environment, %v first before you %v", tui.Code.Render("zrok disable"), tui.Code.Render("zrok enable")), nil) } @@ -64,9 +64,9 @@ func (cmd *enableCommand) run(_ *cobra.Command, args []string) { if cmd.description == "@" { cmd.description = fmt.Sprintf("%v@%v", user.Username, hostName) } - zrok, err := zrd.Client() + zrok, err := env.Client() if err != nil { - cmd.endpointError(zrd.ApiEndpoint()) + cmd.endpointError(env.ApiEndpoint()) tui.Error("error creating service client", err) } auth := httptransport.APIKeyAuth("X-TOKEN", "header", token) @@ -110,15 +110,14 @@ func (cmd *enableCommand) run(_ *cobra.Command, args []string) { case <-done: case <-time.After(1 * time.Second): } - cmd.endpointError(zrd.ApiEndpoint()) + cmd.endpointError(env.ApiEndpoint()) os.Exit(1) } if err != nil { prg.Send("writing the environment details...") } - apiEndpoint, _ := zrd.ApiEndpoint() - zrd.Env = &env_v0_3.Environment{Token: token, ZId: resp.Payload.Identity, ApiEndpoint: apiEndpoint} - if err := zrd.Save(); err != nil { + apiEndpoint, _ := env.ApiEndpoint() + if err := env.SetEnvironment(&env_core.Environment{Token: token, ZitiIdentity: resp.Payload.Identity, ApiEndpoint: apiEndpoint}); err != nil { if !cmd.headless && prg != nil { prg.Send(fmt.Sprintf("there was an error saving the new environment: %v", err)) prg.Quit() @@ -131,7 +130,7 @@ func (cmd *enableCommand) run(_ *cobra.Command, args []string) { } os.Exit(1) } - if err := env_v0_3.SaveZitiIdentity("backend", resp.Payload.Cfg); err != nil { + if err := env.SaveZitiIdentity("backend", resp.Payload.Cfg); err != nil { if !cmd.headless && prg != nil { prg.Send(fmt.Sprintf("there was an error writing the environment: %v", err)) prg.Quit() diff --git a/cmd/zrok/invite.go b/cmd/zrok/invite.go index dd268c736..0695474f7 100644 --- a/cmd/zrok/invite.go +++ b/cmd/zrok/invite.go @@ -2,19 +2,18 @@ package main import ( "fmt" - "github.com/openziti/zrok/environment/env_v0_3" - "os" - "strings" - "github.com/charmbracelet/bubbles/textinput" tea "github.com/charmbracelet/bubbletea" "github.com/charmbracelet/lipgloss" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/rest_client_zrok/account" "github.com/openziti/zrok/rest_client_zrok/metadata" "github.com/openziti/zrok/rest_model_zrok" "github.com/openziti/zrok/tui" "github.com/openziti/zrok/util" "github.com/spf13/cobra" + "os" + "strings" ) func init() { @@ -42,15 +41,15 @@ func newInviteCommand() *inviteCommand { } func (cmd *inviteCommand) run(_ *cobra.Command, _ []string) { - zrd, err := env_v0_3.Load() + env, err := environment.LoadRoot() if err != nil { tui.Error("error loading environment", err) } - zrok, err := zrd.Client() + zrok, err := env.Client() if err != nil { if !panicInstead { - cmd.endpointError(zrd.ApiEndpoint()) + cmd.endpointError(env.ApiEndpoint()) tui.Error("error creating zrok api client", err) } panic(err) @@ -63,7 +62,7 @@ func (cmd *inviteCommand) run(_ *cobra.Command, _ []string) { if md != nil { if !md.GetPayload().InvitesOpen { - apiEndpoint, _ := zrd.ApiEndpoint() + apiEndpoint, _ := env.ApiEndpoint() tui.Error(fmt.Sprintf("'%v' is not currently accepting new users", apiEndpoint), nil) } cmd.tui.invitesOpen = md.GetPayload().InvitesOpen @@ -86,7 +85,7 @@ func (cmd *inviteCommand) run(_ *cobra.Command, _ []string) { } _, err = zrok.Account.Invite(req) if err != nil { - cmd.endpointError(zrd.ApiEndpoint()) + cmd.endpointError(env.ApiEndpoint()) tui.Error("error creating invitation", err) } diff --git a/cmd/zrok/release.go b/cmd/zrok/release.go index 12f891b0f..f68ec68a7 100644 --- a/cmd/zrok/release.go +++ b/cmd/zrok/release.go @@ -2,7 +2,7 @@ package main import ( httptransport "github.com/go-openapi/runtime/client" - "github.com/openziti/zrok/environment/env_v0_3" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/rest_client_zrok/share" "github.com/openziti/zrok/rest_model_zrok" "github.com/openziti/zrok/tui" @@ -31,7 +31,7 @@ func newReleaseCommand() *releaseCommand { func (cmd *releaseCommand) run(_ *cobra.Command, args []string) { shrToken := args[0] - zrd, err := env_v0_3.Load() + env, err := environment.LoadRoot() if err != nil { if !panicInstead { tui.Error("unable to load environment", err) @@ -39,11 +39,11 @@ func (cmd *releaseCommand) run(_ *cobra.Command, args []string) { panic(err) } - if zrd.Env == nil { + if !env.IsEnabled() { tui.Error("unable to load environment; did you 'zrok enable'?", nil) } - zrok, err := zrd.Client() + zrok, err := env.Client() if err != nil { if !panicInstead { tui.Error("unable to create zrok client", err) @@ -51,10 +51,10 @@ func (cmd *releaseCommand) run(_ *cobra.Command, args []string) { panic(err) } - auth := httptransport.APIKeyAuth("X-TOKEN", "header", zrd.Env.Token) + auth := httptransport.APIKeyAuth("X-TOKEN", "header", env.Environment().Token) req := share.NewUnshareParams() req.Body = &rest_model_zrok.UnshareRequest{ - EnvZID: zrd.Env.ZId, + EnvZID: env.Environment().ZitiIdentity, ShrToken: shrToken, Reserved: true, } diff --git a/cmd/zrok/reserve.go b/cmd/zrok/reserve.go index c6d1b179f..68c4c1236 100644 --- a/cmd/zrok/reserve.go +++ b/cmd/zrok/reserve.go @@ -2,7 +2,7 @@ package main import ( httptransport "github.com/go-openapi/runtime/client" - "github.com/openziti/zrok/environment/env_v0_3" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/model" "github.com/openziti/zrok/rest_client_zrok/share" "github.com/openziti/zrok/rest_model_zrok" @@ -60,7 +60,7 @@ func (cmd *reserveCommand) run(_ *cobra.Command, args []string) { target = args[1] } - zrd, err := env_v0_3.Load() + env, err := environment.LoadRoot() if err != nil { if !panicInstead { tui.Error("error loading environment", err) @@ -68,21 +68,21 @@ func (cmd *reserveCommand) run(_ *cobra.Command, args []string) { panic(err) } - if zrd.Env == nil { + if !env.IsEnabled() { tui.Error("unable to load environment; did you 'zrok enable'?", nil) } - zrok, err := zrd.Client() + zrok, err := env.Client() if err != nil { if !panicInstead { tui.Error("unable to create zrok client", err) } panic(err) } - auth := httptransport.APIKeyAuth("X-TOKEN", "header", zrd.Env.Token) + auth := httptransport.APIKeyAuth("X-TOKEN", "header", env.Environment().Token) req := share.NewShareParams() req.Body = &rest_model_zrok.ShareRequest{ - EnvZID: zrd.Env.ZId, + EnvZID: env.Environment().ZitiIdentity, ShareMode: shareMode, BackendMode: cmd.backendMode, BackendProxyEndpoint: target, diff --git a/cmd/zrok/sharePrivate.go b/cmd/zrok/sharePrivate.go index 4b54bfbc8..68daa5cde 100644 --- a/cmd/zrok/sharePrivate.go +++ b/cmd/zrok/sharePrivate.go @@ -9,7 +9,7 @@ import ( "github.com/openziti/zrok/endpoints/proxy" "github.com/openziti/zrok/endpoints/tcpTunnel" "github.com/openziti/zrok/endpoints/udpTunnel" - "github.com/openziti/zrok/environment/env_v0_3" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/model" "github.com/openziti/zrok/rest_client_zrok" "github.com/openziti/zrok/rest_client_zrok/share" @@ -78,7 +78,7 @@ func (cmd *sharePrivateCommand) run(_ *cobra.Command, args []string) { tui.Error(fmt.Sprintf("invalid backend mode '%v'; expected {proxy, web, tcpTunnel}", cmd.backendMode), nil) } - zrd, err := env_v0_3.Load() + env, err := environment.LoadRoot() if err != nil { if !panicInstead { tui.Error("unable to load environment", err) @@ -86,11 +86,11 @@ func (cmd *sharePrivateCommand) run(_ *cobra.Command, args []string) { panic(err) } - if zrd.Env == nil { + if !env.IsEnabled() { tui.Error("unable to load environment; did you 'zrok enable'?", nil) } - zif, err := env_v0_3.ZitiIdentityFile("backend") + zif, err := env.ZitiIdentityFile("backend") if err != nil { if !panicInstead { tui.Error("unable to load ziti identity configuration", err) @@ -98,7 +98,7 @@ func (cmd *sharePrivateCommand) run(_ *cobra.Command, args []string) { panic(err) } - zrok, err := zrd.Client() + zrok, err := env.Client() if err != nil { if !panicInstead { tui.Error("unable to create zrok client", err) @@ -106,10 +106,10 @@ func (cmd *sharePrivateCommand) run(_ *cobra.Command, args []string) { panic(err) } - auth := httptransport.APIKeyAuth("X-TOKEN", "header", zrd.Env.Token) + auth := httptransport.APIKeyAuth("X-TOKEN", "header", env.Environment().Token) req := share.NewShareParams() req.Body = &rest_model_zrok.ShareRequest{ - EnvZID: zrd.Env.ZId, + EnvZID: env.Environment().ZitiIdentity, ShareMode: "private", BackendMode: cmd.backendMode, BackendProxyEndpoint: target, @@ -139,7 +139,7 @@ func (cmd *sharePrivateCommand) run(_ *cobra.Command, args []string) { signal.Notify(c, os.Interrupt, syscall.SIGTERM) go func() { <-c - cmd.destroy(zrd.Env.ZId, resp.Payload.ShrToken, zrok, auth) + cmd.destroy(env.Environment().ZitiIdentity, resp.Payload.ShrToken, zrok, auth) os.Exit(0) }() @@ -250,7 +250,7 @@ func (cmd *sharePrivateCommand) run(_ *cobra.Command, args []string) { } close(requestsChan) - cmd.destroy(zrd.Env.ZId, resp.Payload.ShrToken, zrok, auth) + cmd.destroy(env.Environment().ZitiIdentity, resp.Payload.ShrToken, zrok, auth) } } diff --git a/cmd/zrok/sharePublic.go b/cmd/zrok/sharePublic.go index e8a7f95bc..2e40fe0f0 100644 --- a/cmd/zrok/sharePublic.go +++ b/cmd/zrok/sharePublic.go @@ -7,7 +7,7 @@ import ( httptransport "github.com/go-openapi/runtime/client" "github.com/openziti/zrok/endpoints" "github.com/openziti/zrok/endpoints/proxy" - "github.com/openziti/zrok/environment/env_v0_3" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/model" "github.com/openziti/zrok/rest_client_zrok" "github.com/openziti/zrok/rest_client_zrok/share" @@ -72,7 +72,7 @@ func (cmd *sharePublicCommand) run(_ *cobra.Command, args []string) { tui.Error(fmt.Sprintf("invalid backend mode '%v'; expected {proxy, web}", cmd.backendMode), nil) } - zrd, err := env_v0_3.Load() + env, err := environment.LoadRoot() if err != nil { if !panicInstead { tui.Error("unable to load environment", err) @@ -80,11 +80,11 @@ func (cmd *sharePublicCommand) run(_ *cobra.Command, args []string) { panic(err) } - if zrd.Env == nil { + if !env.IsEnabled() { tui.Error("unable to load environment; did you 'zrok enable'?", nil) } - zif, err := env_v0_3.ZitiIdentityFile("backend") + zif, err := env.ZitiIdentityFile("backend") if err != nil { if !panicInstead { tui.Error("unable to load ziti identity configuration", err) @@ -92,7 +92,7 @@ func (cmd *sharePublicCommand) run(_ *cobra.Command, args []string) { panic(err) } - zrok, err := zrd.Client() + zrok, err := env.Client() if err != nil { if !panicInstead { tui.Error("unable to create zrok client", err) @@ -100,10 +100,10 @@ func (cmd *sharePublicCommand) run(_ *cobra.Command, args []string) { panic(err) } - auth := httptransport.APIKeyAuth("X-TOKEN", "header", zrd.Env.Token) + auth := httptransport.APIKeyAuth("X-TOKEN", "header", env.Environment().Token) req := share.NewShareParams() req.Body = &rest_model_zrok.ShareRequest{ - EnvZID: zrd.Env.ZId, + EnvZID: env.Environment().ZitiIdentity, ShareMode: "public", FrontendSelection: cmd.frontendSelection, BackendMode: cmd.backendMode, @@ -134,7 +134,7 @@ func (cmd *sharePublicCommand) run(_ *cobra.Command, args []string) { signal.Notify(c, os.Interrupt, syscall.SIGTERM) go func() { <-c - cmd.destroy(zrd.Env.ZId, resp.Payload.ShrToken, zrok, auth) + cmd.destroy(env.Environment().ZitiIdentity, resp.Payload.ShrToken, zrok, auth) os.Exit(0) }() @@ -204,7 +204,7 @@ func (cmd *sharePublicCommand) run(_ *cobra.Command, args []string) { } close(requestsChan) - cmd.destroy(zrd.Env.ZId, resp.Payload.ShrToken, zrok, auth) + cmd.destroy(env.Environment().ZitiIdentity, resp.Payload.ShrToken, zrok, auth) } } diff --git a/cmd/zrok/shareReserved.go b/cmd/zrok/shareReserved.go index d485487f9..59f8c4197 100644 --- a/cmd/zrok/shareReserved.go +++ b/cmd/zrok/shareReserved.go @@ -6,7 +6,7 @@ import ( httptransport "github.com/go-openapi/runtime/client" "github.com/openziti/zrok/endpoints" "github.com/openziti/zrok/endpoints/proxy" - "github.com/openziti/zrok/environment/env_v0_3" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/rest_client_zrok/metadata" "github.com/openziti/zrok/rest_client_zrok/share" "github.com/openziti/zrok/rest_model_zrok" @@ -44,7 +44,7 @@ func (cmd *shareReservedCommand) run(_ *cobra.Command, args []string) { shrToken := args[0] var target string - zrd, err := env_v0_3.Load() + env, err := environment.LoadRoot() if err != nil { if !panicInstead { tui.Error("error loading environment", err) @@ -52,18 +52,18 @@ func (cmd *shareReservedCommand) run(_ *cobra.Command, args []string) { panic(err) } - if zrd.Env == nil { + if !env.IsEnabled() { tui.Error("unable to load environment; did you 'zrok enable'?", nil) } - zrok, err := zrd.Client() + zrok, err := env.Client() if err != nil { if !panicInstead { tui.Error("unable to create zrok client", err) } panic(err) } - auth := httptransport.APIKeyAuth("X-TOKEN", "header", zrd.Env.Token) + auth := httptransport.APIKeyAuth("X-TOKEN", "header", env.Environment().Token) req := metadata.NewGetShareDetailParams() req.ShrToken = shrToken resp, err := zrok.Metadata.GetShareDetail(req, auth) @@ -78,7 +78,7 @@ func (cmd *shareReservedCommand) run(_ *cobra.Command, args []string) { target = resp.Payload.BackendProxyEndpoint } - zif, err := env_v0_3.ZitiIdentityFile("backend") + zif, err := env.ZitiIdentityFile("backend") if err != nil { if !panicInstead { tui.Error("unable to load ziti identity configuration", err) diff --git a/cmd/zrok/status.go b/cmd/zrok/status.go index 60c62d97a..d9d2af991 100644 --- a/cmd/zrok/status.go +++ b/cmd/zrok/status.go @@ -3,7 +3,7 @@ package main import ( "fmt" "github.com/jedib0t/go-pretty/v6/table" - "github.com/openziti/zrok/environment/env_v0_3" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/tui" "github.com/spf13/cobra" "os" @@ -34,7 +34,7 @@ func newStatusCommand() *statusCommand { func (cmd *statusCommand) run(_ *cobra.Command, _ []string) { _, _ = fmt.Fprintf(os.Stderr, "\n") - zrd, err := env_v0_3.Load() + env, err := environment.LoadRoot() if err != nil { tui.Error("error loading environment", err) } @@ -44,12 +44,12 @@ func (cmd *statusCommand) run(_ *cobra.Command, _ []string) { t.SetOutputMirror(os.Stdout) t.SetStyle(table.StyleColoredDark) t.AppendHeader(table.Row{"Config", "Value", "Source"}) - apiEndpoint, from := zrd.ApiEndpoint() + apiEndpoint, from := env.ApiEndpoint() t.AppendRow(table.Row{"apiEndpoint", apiEndpoint, from}) t.Render() _, _ = fmt.Fprintf(os.Stderr, "\n") - if zrd.Env == nil { + if !env.IsEnabled() { tui.Warning("Unable to load your local environment!\n") _, _ = fmt.Fprintf(os.Stderr, "To create a local environment use the %v command.\n", tui.Code.Render("zrok enable")) } else { @@ -60,17 +60,17 @@ func (cmd *statusCommand) run(_ *cobra.Command, _ []string) { t.SetStyle(table.StyleColoredDark) t.AppendHeader(table.Row{"Property", "Value"}) if cmd.secrets { - t.AppendRow(table.Row{"Secret Token", zrd.Env.Token}) - t.AppendRow(table.Row{"Ziti Identity", zrd.Env.ZId}) + t.AppendRow(table.Row{"Secret Token", env.Environment().Token}) + t.AppendRow(table.Row{"Ziti Identity", env.Environment().ZitiIdentity}) } else { secretToken := "<>" - if zrd.Env.Token == "" { + if env.Environment().Token == "" { secretToken = "<>" } t.AppendRow(table.Row{"Secret Token", secretToken}) zId := "<>" - if zrd.Env.ZId == "" { + if env.Environment().ZitiIdentity == "" { zId = "<>" } t.AppendRow(table.Row{"Ziti Identity", zId}) diff --git a/cmd/zrok/testLoopPublic.go b/cmd/zrok/testLoopPublic.go index c99420de3..2342ab7f0 100644 --- a/cmd/zrok/testLoopPublic.go +++ b/cmd/zrok/testLoopPublic.go @@ -8,7 +8,8 @@ import ( httptransport "github.com/go-openapi/runtime/client" "github.com/openziti/sdk-golang/ziti" "github.com/openziti/sdk-golang/ziti/edge" - "github.com/openziti/zrok/environment/env_v0_3" + "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/environment/env_core" "github.com/openziti/zrok/model" "github.com/openziti/zrok/rest_client_zrok" "github.com/openziti/zrok/rest_client_zrok/share" @@ -105,7 +106,7 @@ func (cmd *testLoopPublicCommand) run(_ *cobra.Command, _ []string) { type looper struct { id int cmd *testLoopPublicCommand - env *env_v0_3.Environment + env *env_core.Environment done chan struct{} listener edge.Listener zif string @@ -175,28 +176,28 @@ func (l *looper) ServeHTTP(w http.ResponseWriter, r *http.Request) { func (l *looper) startup() { logrus.Infof("starting #%d", l.id) - zrd, err := env_v0_3.Load() + env, err := environment.LoadRoot() if err != nil { panic(err) } - if zrd.Env == nil { + if !env.IsEnabled() { tui.Error("unable to load environment; did you 'zrok enable'?", nil) } - l.env = zrd.Env + l.env = env.Environment() - l.zif, err = env_v0_3.ZitiIdentityFile("backend") + l.zif, err = env.ZitiIdentityFile("backend") if err != nil { panic(err) } - l.zrok, err = zrd.Client() + l.zrok, err = env.Client() if err != nil { panic(err) } l.auth = httptransport.APIKeyAuth("x-token", "header", l.env.Token) tunnelReq := share.NewShareParams() tunnelReq.Body = &rest_model_zrok.ShareRequest{ - EnvZID: l.env.ZId, + EnvZID: l.env.ZitiIdentity, ShareMode: "public", FrontendSelection: l.cmd.frontendSelection, BackendMode: "proxy", @@ -272,7 +273,7 @@ func (l *looper) shutdown() { untunnelReq := share.NewUnshareParams() untunnelReq.Body = &rest_model_zrok.UnshareRequest{ - EnvZID: l.env.ZId, + EnvZID: l.env.ZitiIdentity, ShrToken: l.shrToken, } if _, err := l.zrok.Share.Unshare(untunnelReq, l.auth); err != nil { diff --git a/controller/bootstrap.go b/controller/bootstrap.go index fdfd9300e..2ee0be153 100644 --- a/controller/bootstrap.go +++ b/controller/bootstrap.go @@ -14,7 +14,7 @@ import ( zrok_config "github.com/openziti/zrok/controller/config" "github.com/openziti/zrok/controller/store" "github.com/openziti/zrok/controller/zrokEdgeSdk" - "github.com/openziti/zrok/environment/env_v0_3" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/model" "github.com/pkg/errors" "github.com/sirupsen/logrus" @@ -133,7 +133,11 @@ func assertZrokProxyConfigType(edge *rest_management_api_client.ZitiEdgeManageme } func getIdentityId(identityName string) (string, error) { - zif, err := env_v0_3.ZitiIdentityFile(identityName) + env, err := environment.LoadRoot() + if err != nil { + return "", errors.Wrap(err, "error opening environment root") + } + zif, err := env.ZitiIdentityFile(identityName) if err != nil { return "", errors.Wrapf(err, "error opening identity '%v' from environment", identityName) } @@ -177,6 +181,11 @@ func assertIdentity(zId string, edge *rest_management_api_client.ZitiEdgeManagem } func bootstrapIdentity(name string, edge *rest_management_api_client.ZitiEdgeManagement) (string, error) { + env, err := environment.LoadRoot() + if err != nil { + return "", errors.Wrap(err, "error loading environment root") + } + idc, err := zrokEdgeSdk.CreateIdentity(name, rest_model_edge.IdentityTypeDevice, nil, edge) if err != nil { return "", errors.Wrapf(err, "error creating '%v' identity", name) @@ -195,7 +204,7 @@ func bootstrapIdentity(name string, edge *rest_management_api_client.ZitiEdgeMan if err != nil { return "", errors.Wrapf(err, "error encoding identity config '%v'", name) } - if err := env_v0_3.SaveZitiIdentity(name, out.String()); err != nil { + if err := env.SaveZitiIdentity(name, out.String()); err != nil { return "", errors.Wrapf(err, "error saving identity config '%v'", name) } return zId, nil diff --git a/endpoints/proxy/frontend.go b/endpoints/proxy/frontend.go index db1ede678..b50020603 100644 --- a/endpoints/proxy/frontend.go +++ b/endpoints/proxy/frontend.go @@ -6,7 +6,7 @@ import ( "github.com/openziti/sdk-golang/ziti" "github.com/openziti/zrok/endpoints" "github.com/openziti/zrok/endpoints/publicProxy/notFoundUi" - "github.com/openziti/zrok/environment/env_v0_3" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/model" "github.com/openziti/zrok/util" "github.com/pkg/errors" @@ -40,7 +40,11 @@ type Frontend struct { } func NewFrontend(cfg *FrontendConfig) (*Frontend, error) { - zCfgPath, err := env_v0_3.ZitiIdentityFile(cfg.IdentityName) + env, err := environment.LoadRoot() + if err != nil { + return nil, errors.Wrap(err, "error loading environment root") + } + zCfgPath, err := env.ZitiIdentityFile(cfg.IdentityName) if err != nil { return nil, errors.Wrapf(err, "error getting ziti identity '%v' from environment", cfg.IdentityName) } diff --git a/endpoints/publicProxy/http.go b/endpoints/publicProxy/http.go index 51a422c11..70effb129 100644 --- a/endpoints/publicProxy/http.go +++ b/endpoints/publicProxy/http.go @@ -7,7 +7,7 @@ import ( "github.com/openziti/zrok/endpoints" "github.com/openziti/zrok/endpoints/publicProxy/healthUi" "github.com/openziti/zrok/endpoints/publicProxy/notFoundUi" - "github.com/openziti/zrok/environment/env_v0_3" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/model" "github.com/openziti/zrok/util" "github.com/pkg/errors" @@ -26,7 +26,11 @@ type httpFrontend struct { } func NewHTTP(cfg *Config) (*httpFrontend, error) { - zCfgPath, err := env_v0_3.ZitiIdentityFile(cfg.Identity) + env, err := environment.LoadRoot() + if err != nil { + return nil, errors.Wrap(err, "error loading environment root") + } + zCfgPath, err := env.ZitiIdentityFile(cfg.Identity) if err != nil { return nil, errors.Wrapf(err, "error getting ziti identity '%v' from environment", cfg.Identity) } diff --git a/endpoints/tcpTunnel/frontend.go b/endpoints/tcpTunnel/frontend.go index 2280e4295..136b61375 100644 --- a/endpoints/tcpTunnel/frontend.go +++ b/endpoints/tcpTunnel/frontend.go @@ -3,7 +3,7 @@ package tcpTunnel import ( "github.com/openziti/sdk-golang/ziti" "github.com/openziti/zrok/endpoints" - "github.com/openziti/zrok/environment/env_v0_3" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/model" "github.com/pkg/errors" "github.com/sirupsen/logrus" @@ -29,7 +29,11 @@ func NewFrontend(cfg *FrontendConfig) (*Frontend, error) { if err != nil { return nil, errors.Wrapf(err, "error resolving tcp address '%v'", cfg.BindAddress) } - zCfgPath, err := env_v0_3.ZitiIdentityFile(cfg.IdentityName) + env, err := environment.LoadRoot() + if err != nil { + return nil, errors.Wrap(err, "error loading environment root") + } + zCfgPath, err := env.ZitiIdentityFile(cfg.IdentityName) if err != nil { return nil, errors.Wrapf(err, "error getting ziti identity '%v' from environment", cfg.IdentityName) } diff --git a/endpoints/udpTunnel/frontend.go b/endpoints/udpTunnel/frontend.go index 3463aa8ca..d9daec568 100644 --- a/endpoints/udpTunnel/frontend.go +++ b/endpoints/udpTunnel/frontend.go @@ -3,7 +3,7 @@ package udpTunnel import ( "github.com/openziti/sdk-golang/ziti" "github.com/openziti/zrok/endpoints" - "github.com/openziti/zrok/environment/env_v0_3" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/model" "github.com/pkg/errors" "github.com/sirupsen/logrus" @@ -99,7 +99,11 @@ func NewFrontend(cfg *FrontendConfig) (*Frontend, error) { if err != nil { return nil, errors.Wrapf(err, "error resolving udp address '%v'", cfg.BindAddress) } - zCfgPath, err := env_v0_3.ZitiIdentityFile(cfg.IdentityName) + env, err := environment.LoadRoot() + if err != nil { + return nil, errors.Wrap(err, "error loading environment root") + } + zCfgPath, err := env.ZitiIdentityFile(cfg.IdentityName) if err != nil { return nil, errors.Wrapf(err, "error getting ziti identity '%v' from environment", cfg.IdentityName) } diff --git a/environment/api.go b/environment/api.go index b0bce4526..71ee42611 100644 --- a/environment/api.go +++ b/environment/api.go @@ -2,7 +2,6 @@ package environment import ( "github.com/openziti/zrok/environment/env_core" - "github.com/openziti/zrok/environment/env_v0_3x" "github.com/openziti/zrok/rest_client_zrok" "github.com/pkg/errors" ) @@ -15,20 +14,21 @@ type Root interface { Client() (*rest_client_zrok.Zrok, error) ApiEndpoint() (string, string) Environment() *env_core.Environment + SetEnvironment(env *env_core.Environment) error DeleteEnvironment() error - IsEnabled() (bool, error) + IsEnabled() bool ZitiIdentityFile(name string) (string, error) SaveZitiIdentity(name, data string) error DeleteZitiIdentity(name string) error Obliterate() error } -func ListRoots() ([]*env_core.Metadata, error) { - return nil, nil +func LoadRoot() (Root, error) { + return env_v0_3.Load() } -func LoadRoot() (Root, error) { - return env_v0_3x.Load() +func ListRoots() ([]*env_core.Metadata, error) { + return nil, nil } func LoadRootVersion(m *env_core.Metadata) (Root, error) { @@ -36,8 +36,8 @@ func LoadRootVersion(m *env_core.Metadata) (Root, error) { return nil, errors.Errorf("specify metadata version") } switch m.V { - case env_v0_3x.V: - return env_v0_3x.Load() + case env_v0_3.V: + return env_v0_3.Load() default: return nil, errors.Errorf("unknown metadata version '%v'", m.V) @@ -45,7 +45,7 @@ func LoadRootVersion(m *env_core.Metadata) (Root, error) { } func NeedsUpdate(r Root) bool { - return r.Metadata().V != env_v0_3x.V + return r.Metadata().V != env_v0_3.V } func UpdateRoot(r Root) (Root, error) { diff --git a/environment/env_v0_3/api.go b/environment/env_v0_3/api.go new file mode 100644 index 000000000..be8bdb344 --- /dev/null +++ b/environment/env_v0_3/api.go @@ -0,0 +1,151 @@ +package env_v0_3 + +import ( + "github.com/go-openapi/runtime" + httptransport "github.com/go-openapi/runtime/client" + "github.com/go-openapi/strfmt" + "github.com/openziti/zrok/build" + "github.com/openziti/zrok/environment/env_core" + "github.com/openziti/zrok/rest_client_zrok" + "github.com/pkg/errors" + "net/url" + "os" + "path/filepath" + "regexp" +) + +func (r *Root) Metadata() *env_core.Metadata { + return r.meta +} + +func (r *Root) HasConfig() (bool, error) { + return r.cfg != nil, nil +} + +func (r *Root) Config() *env_core.Config { + return r.cfg +} + +func (r *Root) SetConfig(cfg *env_core.Config) error { + if err := saveConfig(cfg); err != nil { + return err + } + r.cfg = cfg + return nil +} + +func (r *Root) Client() (*rest_client_zrok.Zrok, error) { + apiEndpoint, _ := r.ApiEndpoint() + apiUrl, err := url.Parse(apiEndpoint) + if err != nil { + return nil, errors.Wrapf(err, "error parsing api endpoint '%v'", r) + } + transport := httptransport.New(apiUrl.Host, "/api/v1", []string{apiUrl.Scheme}) + transport.Producers["application/zrok.v1+json"] = runtime.JSONProducer() + transport.Consumers["application/zrok.v1+json"] = runtime.JSONConsumer() + + zrok := rest_client_zrok.New(transport, strfmt.Default) + v, err := zrok.Metadata.Version(nil) + if err != nil { + return nil, errors.Wrapf(err, "error getting version from api endpoint '%v': %v", apiEndpoint, err) + } + // allow reported version string to be optionally prefixed with + // "refs/heads/" or "refs/tags/" + re := regexp.MustCompile(`^(refs/(heads|tags)/)?` + build.Series) + if !re.MatchString(string(v.Payload)) { + return nil, errors.Errorf("expected a '%v' version, received: '%v'", build.Series, v.Payload) + } + + return zrok, nil +} + +func (r *Root) ApiEndpoint() (string, string) { + apiEndpoint := "https://api.zrok.io" + from := "binary" + + if r.Config() != nil && r.Config().ApiEndpoint != "" { + apiEndpoint = r.Config().ApiEndpoint + from = "config" + } + + env := os.Getenv("ZROK_API_ENDPOINT") + if env != "" { + apiEndpoint = env + from = "ZROK_API_ENDPOINT" + } + + if r.IsEnabled() { + apiEndpoint = r.Environment().ApiEndpoint + from = "env" + } + + return apiEndpoint, from +} + +func (r *Root) Environment() *env_core.Environment { + return r.env +} + +func (r *Root) SetEnvironment(env *env_core.Environment) error { + if err := saveEnvironment(env); err != nil { + return err + } + r.env = env + return nil +} + +func (r *Root) DeleteEnvironment() error { + ef, err := environmentFile() + if err != nil { + return errors.Wrap(err, "error getting environment file") + } + if err := os.Remove(ef); err != nil { + return errors.Wrap(err, "error removing environment file") + } + r.env = nil + return nil +} + +func (r *Root) IsEnabled() bool { + return r.env != nil +} + +func (r *Root) ZitiIdentityFile(name string) (string, error) { + return identityFile(name) +} + +func (r *Root) SaveZitiIdentity(name, data string) error { + zif, err := r.ZitiIdentityFile(name) + if err != nil { + return err + } + if err := os.MkdirAll(filepath.Dir(zif), os.FileMode(0700)); err != nil { + return errors.Wrapf(err, "error creating environment path '%v'", filepath.Dir(zif)) + } + if err := os.WriteFile(zif, []byte(data), os.FileMode(0600)); err != nil { + return errors.Wrapf(err, "error writing ziti identity file '%v'", zif) + } + return nil +} + +func (r *Root) DeleteZitiIdentity(name string) error { + zif, err := r.ZitiIdentityFile(name) + if err != nil { + return errors.Wrapf(err, "error getting ziti identity file path for '%v'", name) + } + if err := os.Remove(zif); err != nil { + return errors.Wrapf(err, "error removing ziti identity file '%v'", zif) + } + return nil +} + +func (r *Root) Obliterate() error { + zrd, err := rootDir() + if err != nil { + return err + } + if err := os.RemoveAll(zrd); err != nil { + return err + } + return nil +} diff --git a/environment/env_v0_3/client.go b/environment/env_v0_3/client.go deleted file mode 100644 index 319377fb5..000000000 --- a/environment/env_v0_3/client.go +++ /dev/null @@ -1,61 +0,0 @@ -package env_v0_3 - -import ( - "github.com/go-openapi/runtime" - httptransport "github.com/go-openapi/runtime/client" - "github.com/go-openapi/strfmt" - "github.com/openziti/zrok/build" - "github.com/openziti/zrok/rest_client_zrok" - "github.com/pkg/errors" - "net/url" - "os" - "regexp" -) - -func (r *Root) Client() (*rest_client_zrok.Zrok, error) { - apiEndpoint, _ := r.ApiEndpoint() - apiUrl, err := url.Parse(apiEndpoint) - if err != nil { - return nil, errors.Wrapf(err, "error parsing api endpoint '%v'", r) - } - transport := httptransport.New(apiUrl.Host, "/api/v1", []string{apiUrl.Scheme}) - transport.Producers["application/zrok.v1+json"] = runtime.JSONProducer() - transport.Consumers["application/zrok.v1+json"] = runtime.JSONConsumer() - - zrok := rest_client_zrok.New(transport, strfmt.Default) - v, err := zrok.Metadata.Version(nil) - if err != nil { - return nil, errors.Wrapf(err, "error getting version from api endpoint '%v': %v", apiEndpoint, err) - } - // allow reported version string to be optionally prefixed with - // "refs/heads/" or "refs/tags/" - re := regexp.MustCompile(`^(refs/(heads|tags)/)?` + build.Series) - if !re.MatchString(string(v.Payload)) { - return nil, errors.Errorf("expected a '%v' version, received: '%v'", build.Series, v.Payload) - } - - return zrok, nil -} - -func (r *Root) ApiEndpoint() (apiEndpoint string, from string) { - apiEndpoint = "https://api.zrok.io" - from = "binary" - - if r.Cfg != nil && r.Cfg.ApiEndpoint != "" { - apiEndpoint = r.Cfg.ApiEndpoint - from = "config" - } - - env := os.Getenv("ZROK_API_ENDPOINT") - if env != "" { - apiEndpoint = env - from = "ZROK_API_ENDPOINT" - } - - if r.Env != nil && r.Env.ApiEndpoint != "" { - apiEndpoint = r.Env.ApiEndpoint - from = "env" - } - - return apiEndpoint, from -} diff --git a/environment/env_v0_3/config.go b/environment/env_v0_3/config.go deleted file mode 100644 index 0aafdc04f..000000000 --- a/environment/env_v0_3/config.go +++ /dev/null @@ -1,61 +0,0 @@ -package env_v0_3 - -import ( - "encoding/json" - "github.com/pkg/errors" - "os" - "path/filepath" -) - -type Config struct { - ApiEndpoint string `json:"api_endpoint"` -} - -func HasConfig() (bool, error) { - cf, err := configFile() - if err != nil { - return false, errors.Wrap(err, "error getting config file path") - } - _, err = os.Stat(cf) - if os.IsNotExist(err) { - return false, nil - } - if err != nil { - return false, errors.Wrapf(err, "error stat-ing config file '%v'", cf) - } - return true, nil -} - -func LoadConfig() (*Config, error) { - cf, err := configFile() - if err != nil { - return nil, errors.Wrap(err, "error getting config file path") - } - data, err := os.ReadFile(cf) - if err != nil { - return nil, errors.Wrapf(err, "error reading config file '%v'", cf) - } - cfg := &Config{} - if err := json.Unmarshal(data, cfg); err != nil { - return nil, errors.Wrapf(err, "error unmarshaling config file '%v'", cf) - } - return cfg, nil -} - -func SaveConfig(cfg *Config) error { - data, err := json.MarshalIndent(cfg, "", " ") - if err != nil { - return errors.Wrap(err, "error marshaling config") - } - cf, err := configFile() - if err != nil { - return errors.Wrap(err, "error getting config file path") - } - if err := os.MkdirAll(filepath.Dir(cf), os.FileMode(0700)); err != nil { - return errors.Wrapf(err, "error creating environment path '%v'", filepath.Dir(cf)) - } - if err := os.WriteFile(cf, data, os.FileMode(0600)); err != nil { - return errors.Wrap(err, "error saving config file") - } - return nil -} diff --git a/environment/env_v0_3x/dirs.go b/environment/env_v0_3/dirs.go similarity index 64% rename from environment/env_v0_3x/dirs.go rename to environment/env_v0_3/dirs.go index 10a70de79..ec382f7fe 100644 --- a/environment/env_v0_3x/dirs.go +++ b/environment/env_v0_3/dirs.go @@ -1,6 +1,7 @@ -package env_v0_3x +package env_v0_3 import ( + "fmt" "os" "path/filepath" ) @@ -36,3 +37,19 @@ func environmentFile() (string, error) { } return filepath.Join(zrd, "environment.json"), nil } + +func identitiesDir() (string, error) { + zrd, err := rootDir() + if err != nil { + return "", err + } + return filepath.Join(zrd, "identities"), nil +} + +func identityFile(name string) (string, error) { + idd, err := identitiesDir() + if err != nil { + return "", err + } + return filepath.Join(idd, fmt.Sprintf("%v.json", name)), nil +} diff --git a/environment/env_v0_3/environment.go b/environment/env_v0_3/environment.go deleted file mode 100644 index fe4cd2709..000000000 --- a/environment/env_v0_3/environment.go +++ /dev/null @@ -1,75 +0,0 @@ -package env_v0_3 - -import ( - "encoding/json" - "github.com/pkg/errors" - "os" - "path/filepath" -) - -type Environment struct { - Token string `json:"zrok_token"` - ZId string `json:"ziti_identity"` - ApiEndpoint string `json:"api_endpoint"` -} - -func IsEnabled() (bool, error) { - ef, err := environmentFile() - if err != nil { - return false, errors.Wrap(err, "error getting environment file path") - } - _, err = os.Stat(ef) - if os.IsNotExist(err) { - return false, nil - } - if err != nil { - return false, errors.Wrapf(err, "error stat-ing environment file '%v'", ef) - } - return true, nil -} - -func loadEnvironment() (*Environment, error) { - ef, err := environmentFile() - if err != nil { - return nil, errors.Wrap(err, "error getting environment file") - } - data, err := os.ReadFile(ef) - if err != nil { - return nil, errors.Wrapf(err, "error reading environment file '%v'", ef) - } - env := &Environment{} - if err := json.Unmarshal(data, env); err != nil { - return nil, errors.Wrapf(err, "error unmarshaling environment file '%v'", ef) - } - return env, nil -} - -func saveEnvironment(env *Environment) error { - data, err := json.MarshalIndent(env, "", " ") - if err != nil { - return errors.Wrap(err, "error marshaling environment") - } - ef, err := environmentFile() - if err != nil { - return errors.Wrap(err, "error getting environment file") - } - if err := os.MkdirAll(filepath.Dir(ef), os.FileMode(0700)); err != nil { - return errors.Wrapf(err, "error creating environment path '%v'", filepath.Dir(ef)) - } - if err := os.WriteFile(ef, data, os.FileMode(0600)); err != nil { - return errors.Wrap(err, "error saving environment file") - } - return nil -} - -func DeleteEnvironment() error { - ef, err := environmentFile() - if err != nil { - return errors.Wrap(err, "error getting environment file") - } - if err := os.Remove(ef); err != nil { - return errors.Wrap(err, "error removing environment file") - } - - return nil -} diff --git a/environment/env_v0_3/identity.go b/environment/env_v0_3/identity.go deleted file mode 100644 index 2b5f4dc23..000000000 --- a/environment/env_v0_3/identity.go +++ /dev/null @@ -1,36 +0,0 @@ -package env_v0_3 - -import ( - "github.com/pkg/errors" - "os" - "path/filepath" -) - -func ZitiIdentityFile(name string) (string, error) { - return identityFile(name) -} - -func SaveZitiIdentity(name, data string) error { - zif, err := ZitiIdentityFile(name) - if err != nil { - return err - } - if err := os.MkdirAll(filepath.Dir(zif), os.FileMode(0700)); err != nil { - return errors.Wrapf(err, "error creating environment path '%v'", filepath.Dir(zif)) - } - if err := os.WriteFile(zif, []byte(data), os.FileMode(0600)); err != nil { - return errors.Wrapf(err, "error writing ziti identity file '%v'", zif) - } - return nil -} - -func DeleteZitiIdentity(name string) error { - zif, err := ZitiIdentityFile(name) - if err != nil { - return errors.Wrapf(err, "error getting ziti identity file path for '%v'", name) - } - if err := os.Remove(zif); err != nil { - return errors.Wrapf(err, "error removing ziti identity file '%v'", zif) - } - return nil -} diff --git a/environment/env_v0_3/root.go b/environment/env_v0_3/root.go index e5be40640..842ef128e 100644 --- a/environment/env_v0_3/root.go +++ b/environment/env_v0_3/root.go @@ -1,179 +1,234 @@ package env_v0_3 import ( - "fmt" + "encoding/json" + "github.com/openziti/zrok/environment/env_core" "github.com/pkg/errors" "os" "path/filepath" - "strings" ) +const V = "v0.3" + type Root struct { - Env *Environment - Cfg *Config - identities map[string]struct{} + meta *env_core.Metadata + cfg *env_core.Config + env *env_core.Environment } -func Initialize() (*Root, error) { - zrd, err := rootDir() +func Load() (*Root, error) { + r := &Root{} + exists, err := rootExists() if err != nil { - return nil, errors.Wrap(err, "error getting environment path") - } - if err := os.MkdirAll(zrd, os.FileMode(0700)); err != nil { - return nil, errors.Wrapf(err, "error creating environment root path '%v'", zrd) + return nil, err } - if err := DeleteEnvironment(); err != nil { - return nil, errors.Wrap(err, "error deleting environment") + if exists { + if meta, err := loadMetadata(); err == nil { + r.meta = meta + } else { + return nil, err + } + + if cfg, err := loadConfig(); err == nil { + r.cfg = cfg + } + + if env, err := loadEnvironment(); err == nil { + r.env = env + } + + } else { + root, err := rootDir() + if err != nil { + return nil, err + } + r.meta = &env_core.Metadata{ + V: V, + RootPath: root, + } } - idd, err := identitiesDir() + return r, nil +} + +func rootExists() (bool, error) { + mf, err := metadataFile() if err != nil { - return nil, errors.Wrap(err, "error getting environment identities path") + return false, err } - if err := os.MkdirAll(idd, os.FileMode(0700)); err != nil { - return nil, errors.Wrapf(err, "error creating environment identities root path '%v'", idd) + _, err = os.Stat(mf) + if os.IsNotExist(err) { + return false, nil + } + if err != nil { + return false, err } - return Load() + return true, err } -func Load() (*Root, error) { - if err := checkMetadata(); err != nil { +func loadMetadata() (*env_core.Metadata, error) { + mf, err := metadataFile() + if err != nil { return nil, err } - - zrd := &Root{} - - ids, err := listIdentities() + data, err := os.ReadFile(mf) if err != nil { return nil, err } - zrd.identities = ids - - hasCfg, err := HasConfig() + m := &metadata{} + if err := json.Unmarshal(data, m); err != nil { + return nil, errors.Wrapf(err, "error unmarshaling metadata file '%v'", mf) + } + if m.V != V { + return nil, errors.Errorf("got metadata version '%v', expected '%v'", m.V, V) + } + rf, err := rootDir() if err != nil { return nil, err } - if hasCfg { - cfg, err := LoadConfig() - if err != nil { - return nil, err - } - zrd.Cfg = cfg + out := &env_core.Metadata{ + V: m.V, + RootPath: rf, } + return out, nil +} - hasEnv, err := IsEnabled() +func writeMetadata() error { + mf, err := metadataFile() if err != nil { - return nil, err + return err } - if hasEnv { - env, err := loadEnvironment() - if err != nil { - return nil, err - } - zrd.Env = env + data, err := json.Marshal(&metadata{V: V}) + if err != nil { + return err } - - return zrd, nil + if err := os.MkdirAll(filepath.Dir(mf), os.FileMode(0700)); err != nil { + return err + } + if err := os.WriteFile(mf, data, os.FileMode(0600)); err != nil { + return err + } + return nil } -func (r *Root) Save() error { - if err := writeMetadata(); err != nil { - return errors.Wrap(err, "error saving metadata") +func loadConfig() (*env_core.Config, error) { + cf, err := configFile() + if err != nil { + return nil, errors.Wrap(err, "error getting config file path") } - if r.Env != nil { - if err := saveEnvironment(r.Env); err != nil { - return errors.Wrap(err, "error saving environment") - } + data, err := os.ReadFile(cf) + if err != nil { + return nil, errors.Wrapf(err, "error reading config file '%v'", cf) } - if r.Cfg != nil { - if err := SaveConfig(r.Cfg); err != nil { - return errors.Wrap(err, "error saving config") - } + cfg := &config{} + if err := json.Unmarshal(data, cfg); err != nil { + return nil, errors.Wrapf(err, "error unmarshaling config file '%v'", cf) } - return nil + out := &env_core.Config{ + ApiEndpoint: cfg.ApiEndpoint, + } + return out, nil } -func Obliterate() error { - zrd, err := rootDir() +func saveConfig(cfg *env_core.Config) error { + in := &config{ApiEndpoint: cfg.ApiEndpoint} + data, err := json.MarshalIndent(in, "", " ") if err != nil { - return err + return errors.Wrap(err, "error marshaling config") } - if err := os.RemoveAll(zrd); err != nil { - return err + cf, err := configFile() + if err != nil { + return errors.Wrap(err, "error getting config file path") + } + if err := os.MkdirAll(filepath.Dir(cf), os.FileMode(0700)); err != nil { + return errors.Wrapf(err, "error creating environment path '%v'", filepath.Dir(cf)) + } + if err := os.WriteFile(cf, data, os.FileMode(0600)); err != nil { + return errors.Wrap(err, "error saving config file") } return nil } -func listIdentities() (map[string]struct{}, error) { - ids := make(map[string]struct{}) - - idd, err := identitiesDir() +func isEnabled() (bool, error) { + ef, err := environmentFile() if err != nil { - return nil, errors.Wrap(err, "error getting environment identities path") + return false, errors.Wrap(err, "error getting environment file path") } - _, err = os.Stat(idd) + _, err = os.Stat(ef) if os.IsNotExist(err) { - return ids, nil + return false, nil + } + if err != nil { + return false, errors.Wrapf(err, "error stat-ing environment file '%v'", ef) } + return true, nil +} + +func loadEnvironment() (*env_core.Environment, error) { + ef, err := environmentFile() if err != nil { - return nil, errors.Wrapf(err, "error stat-ing environment identities root '%v'", idd) + return nil, errors.Wrap(err, "error getting environment file") } - des, err := os.ReadDir(idd) + data, err := os.ReadFile(ef) if err != nil { - return nil, errors.Wrapf(err, "error listing environment identities from '%v'", idd) + return nil, errors.Wrapf(err, "error reading environment file '%v'", ef) } - for _, de := range des { - if strings.HasSuffix(de.Name(), ".json") && !de.IsDir() { - name := strings.TrimSuffix(de.Name(), ".json") - ids[name] = struct{}{} - } + env := &environment{} + if err := json.Unmarshal(data, env); err != nil { + return nil, errors.Wrapf(err, "error unmarshaling environment file '%v'", ef) } - return ids, nil + out := &env_core.Environment{ + Token: env.Token, + ZitiIdentity: env.ZId, + ApiEndpoint: env.ApiEndpoint, + } + return out, nil } -func configFile() (string, error) { - zrd, err := rootDir() +func saveEnvironment(env *env_core.Environment) error { + in := &environment{ + Token: env.Token, + ZId: env.ZitiIdentity, + ApiEndpoint: env.ApiEndpoint, + } + data, err := json.MarshalIndent(in, "", " ") if err != nil { - return "", err + return errors.Wrap(err, "error marshaling environment") } - return filepath.Join(zrd, "config.json"), nil -} - -func environmentFile() (string, error) { - zrd, err := rootDir() + ef, err := environmentFile() if err != nil { - return "", err + return errors.Wrap(err, "error getting environment file") + } + if err := os.MkdirAll(filepath.Dir(ef), os.FileMode(0700)); err != nil { + return errors.Wrapf(err, "error creating environment path '%v'", filepath.Dir(ef)) } - return filepath.Join(zrd, "environment.json"), nil + if err := os.WriteFile(ef, data, os.FileMode(0600)); err != nil { + return errors.Wrap(err, "error saving environment file") + } + return nil } -func identityFile(name string) (string, error) { - idd, err := identitiesDir() +func deleteEnvironment() error { + ef, err := environmentFile() if err != nil { - return "", err + return errors.Wrap(err, "error getting environment file") } - return filepath.Join(idd, fmt.Sprintf("%v.json", name)), nil + if err := os.Remove(ef); err != nil { + return errors.Wrap(err, "error removing environment file") + } + + return nil } -func identitiesDir() (string, error) { - zrd, err := rootDir() - if err != nil { - return "", err - } - return filepath.Join(zrd, "identities"), nil +type metadata struct { + V string `json:"v"` } -func metadataFile() (string, error) { - zrd, err := rootDir() - if err != nil { - return "", err - } - return filepath.Join(zrd, "metadata.json"), nil +type config struct { + ApiEndpoint string `json:"api_endpoint"` } -func rootDir() (string, error) { - home, err := os.UserHomeDir() - if err != nil { - return "", err - } - return filepath.Join(home, ".zrok"), nil +type environment struct { + Token string `json:"zrok_token"` + ZId string `json:"ziti_identity"` + ApiEndpoint string `json:"api_endpoint"` } diff --git a/environment/env_v0_3/version.go b/environment/env_v0_3/version.go deleted file mode 100644 index 1416126ca..000000000 --- a/environment/env_v0_3/version.go +++ /dev/null @@ -1,53 +0,0 @@ -package env_v0_3 - -import ( - "encoding/json" - "github.com/openziti/zrok/tui" - "github.com/pkg/errors" - "os" - "path/filepath" -) - -const V = "v0.3" - -type Metadata struct { - V string `json:"v"` -} - -func checkMetadata() error { - mf, err := metadataFile() - if err != nil { - return err - } - data, err := os.ReadFile(mf) - if err != nil { - tui.Warning("unable to open environment metadata; ignoring\n") - return nil - } - m := &Metadata{} - if err := json.Unmarshal(data, m); err != nil { - return errors.Wrapf(err, "error unmarshaling metadata file '%v'", mf) - } - if m.V != V { - return errors.Errorf("invalid environment metadata version '%v'", m.V) - } - return nil -} - -func writeMetadata() error { - mf, err := metadataFile() - if err != nil { - return err - } - data, err := json.Marshal(&Metadata{V: V}) - if err != nil { - return err - } - if err := os.MkdirAll(filepath.Dir(mf), os.FileMode(0700)); err != nil { - return err - } - if err := os.WriteFile(mf, data, os.FileMode(0600)); err != nil { - return err - } - return nil -} diff --git a/environment/env_v0_3x/api.go b/environment/env_v0_3x/api.go deleted file mode 100644 index fb19186bc..000000000 --- a/environment/env_v0_3x/api.go +++ /dev/null @@ -1,65 +0,0 @@ -package env_v0_3x - -import ( - "github.com/openziti/zrok/environment/env_core" - "github.com/openziti/zrok/rest_client_zrok" -) - -func (r *Root) Metadata() *env_core.Metadata { - return r.meta -} - -func (r *Root) HasConfig() (bool, error) { - return r.cfg != nil, nil -} - -func (r *Root) Config() *env_core.Config { - return r.cfg -} - -func (r *Root) SetConfig(cfg *env_core.Config) error { - if err := saveConfig(cfg); err != nil { - return err - } - r.cfg = cfg - return nil -} - -func (r *Root) Client() (*rest_client_zrok.Zrok, error) { - return nil, nil -} - -func (r *Root) ApiEndpoint() (string, string) { - if r.env != nil { - return r.env.ApiEndpoint, "env" - } - return "", "" -} - -func (r *Root) Environment() *env_core.Environment { - return r.env -} - -func (r *Root) DeleteEnvironment() error { - return nil -} - -func (r *Root) IsEnabled() (bool, error) { - return r.env != nil, nil -} - -func (r *Root) ZitiIdentityFile(name string) (string, error) { - return "", nil -} - -func (r *Root) SaveZitiIdentity(name, data string) error { - return nil -} - -func (r *Root) DeleteZitiIdentity(name string) error { - return nil -} - -func (r *Root) Obliterate() error { - return nil -} diff --git a/environment/env_v0_3x/root.go b/environment/env_v0_3x/root.go deleted file mode 100644 index 2a725376d..000000000 --- a/environment/env_v0_3x/root.go +++ /dev/null @@ -1,216 +0,0 @@ -package env_v0_3x - -import ( - "encoding/json" - "github.com/openziti/zrok/environment/env_core" - "github.com/pkg/errors" - "os" - "path/filepath" -) - -const V = "v0.3" - -type Root struct { - meta *env_core.Metadata - cfg *env_core.Config - env *env_core.Environment -} - -func Load() (*Root, error) { - r := &Root{} - exists, err := rootExists() - if err != nil { - return nil, err - } - if exists { - if meta, err := loadMetadata(); err == nil { - r.meta = meta - } else { - return nil, err - } - - if cfg, err := loadConfig(); err == nil { - r.cfg = cfg - } - - if env, err := loadEnvironment(); err == nil { - r.env = env - } - - } else { - root, err := rootDir() - if err != nil { - return nil, err - } - r.meta = &env_core.Metadata{ - V: V, - RootPath: root, - } - } - return r, nil -} - -func rootExists() (bool, error) { - mf, err := metadataFile() - if err != nil { - return false, err - } - _, err = os.Stat(mf) - if os.IsNotExist(err) { - return false, nil - } - if err != nil { - return false, err - } - return true, err -} - -func loadMetadata() (*env_core.Metadata, error) { - mf, err := metadataFile() - if err != nil { - return nil, err - } - data, err := os.ReadFile(mf) - if err != nil { - return nil, err - } - m := &metadata{} - if err := json.Unmarshal(data, m); err != nil { - return nil, errors.Wrapf(err, "error unmarshaling metadata file '%v'", mf) - } - if m.V != V { - return nil, errors.Errorf("got metadata version '%v', expected '%v'", m.V, V) - } - rf, err := rootDir() - if err != nil { - return nil, err - } - out := &env_core.Metadata{ - V: m.V, - RootPath: rf, - } - return out, nil -} - -func loadConfig() (*env_core.Config, error) { - cf, err := configFile() - if err != nil { - return nil, errors.Wrap(err, "error getting config file path") - } - data, err := os.ReadFile(cf) - if err != nil { - return nil, errors.Wrapf(err, "error reading config file '%v'", cf) - } - cfg := &config{} - if err := json.Unmarshal(data, cfg); err != nil { - return nil, errors.Wrapf(err, "error unmarshaling config file '%v'", cf) - } - out := &env_core.Config{ - ApiEndpoint: cfg.ApiEndpoint, - } - return out, nil -} - -func saveConfig(cfg *env_core.Config) error { - in := &config{ApiEndpoint: cfg.ApiEndpoint} - data, err := json.MarshalIndent(in, "", " ") - if err != nil { - return errors.Wrap(err, "error marshaling config") - } - cf, err := configFile() - if err != nil { - return errors.Wrap(err, "error getting config file path") - } - if err := os.MkdirAll(filepath.Dir(cf), os.FileMode(0700)); err != nil { - return errors.Wrapf(err, "error creating environment path '%v'", filepath.Dir(cf)) - } - if err := os.WriteFile(cf, data, os.FileMode(0600)); err != nil { - return errors.Wrap(err, "error saving config file") - } - return nil -} - -func isEnabled() (bool, error) { - ef, err := environmentFile() - if err != nil { - return false, errors.Wrap(err, "error getting environment file path") - } - _, err = os.Stat(ef) - if os.IsNotExist(err) { - return false, nil - } - if err != nil { - return false, errors.Wrapf(err, "error stat-ing environment file '%v'", ef) - } - return true, nil -} - -func loadEnvironment() (*env_core.Environment, error) { - ef, err := environmentFile() - if err != nil { - return nil, errors.Wrap(err, "error getting environment file") - } - data, err := os.ReadFile(ef) - if err != nil { - return nil, errors.Wrapf(err, "error reading environment file '%v'", ef) - } - env := &environment{} - if err := json.Unmarshal(data, env); err != nil { - return nil, errors.Wrapf(err, "error unmarshaling environment file '%v'", ef) - } - out := &env_core.Environment{ - Token: env.Token, - ZitiIdentity: env.ZId, - ApiEndpoint: env.ApiEndpoint, - } - return out, nil -} - -func saveEnvironment(env *env_core.Environment) error { - in := &environment{ - Token: env.Token, - ZId: env.ZitiIdentity, - ApiEndpoint: env.ApiEndpoint, - } - data, err := json.MarshalIndent(in, "", " ") - if err != nil { - return errors.Wrap(err, "error marshaling environment") - } - ef, err := environmentFile() - if err != nil { - return errors.Wrap(err, "error getting environment file") - } - if err := os.MkdirAll(filepath.Dir(ef), os.FileMode(0700)); err != nil { - return errors.Wrapf(err, "error creating environment path '%v'", filepath.Dir(ef)) - } - if err := os.WriteFile(ef, data, os.FileMode(0600)); err != nil { - return errors.Wrap(err, "error saving environment file") - } - return nil -} - -func deleteEnvironment() error { - ef, err := environmentFile() - if err != nil { - return errors.Wrap(err, "error getting environment file") - } - if err := os.Remove(ef); err != nil { - return errors.Wrap(err, "error removing environment file") - } - - return nil -} - -type metadata struct { - V string `json:"v"` -} - -type config struct { - ApiEndpoint string `json:"api_endpoint"` -} - -type environment struct { - Token string `json:"zrok_token"` - ZId string `json:"ziti_identity"` - ApiEndpoint string `json:"api_endpoint"` -} diff --git a/sdk/share.go b/sdk/share.go index 15d33f2da..5e4bb07f4 100644 --- a/sdk/share.go +++ b/sdk/share.go @@ -1,8 +1,6 @@ package sdk import ( - "github.com/openziti/zrok/environment/env_v0_3" - "github.com/openziti/zrok/rest_model_zrok" "github.com/pkg/errors" ) @@ -28,15 +26,3 @@ func newPrivateShare(request *ShareRequest) (*Share, error) { func newPublicShare(request *ShareRequest) (*Share, error) { return nil, nil } - -func loadEnvironment(request *ShareRequest) (*env_v0_3.Root, error) { - env, err := env_v0_3.Load() - if err != nil { - return nil, errors.Wrap(err, "error loading environment") - } - return env, nil -} - -func createShare(zrd *env_v0_3.Root, req *rest_model_zrok.ShareRequest) (*Share, error) { - return nil, nil -} From 1c8ab67bf10f7c4bb9dd7356dcf9302cacde5691 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Fri, 14 Jul 2023 09:42:06 -0400 Subject: [PATCH 09/28] controller no longer needs an identity; identity management organization (#369) --- cmd/zrok/adminBootstrap.go | 4 +--- controller/bootstrap.go | 36 ++++++++---------------------------- environment/api.go | 10 ++++++++-- 3 files changed, 17 insertions(+), 33 deletions(-) diff --git a/cmd/zrok/adminBootstrap.go b/cmd/zrok/adminBootstrap.go index 2501d17c1..e2e8416df 100644 --- a/cmd/zrok/adminBootstrap.go +++ b/cmd/zrok/adminBootstrap.go @@ -14,7 +14,6 @@ func init() { type adminBootstrap struct { cmd *cobra.Command - skipCtrl bool skipFrontend bool } @@ -26,7 +25,6 @@ func newAdminBootstrap() *adminBootstrap { } command := &adminBootstrap{cmd: cmd} cmd.Run = command.run - cmd.Flags().BoolVar(&command.skipCtrl, "skip-ctrl", false, "Skip controller (ctrl) identity bootstrapping") cmd.Flags().BoolVar(&command.skipFrontend, "skip-frontend", false, "Skip frontend identity bootstrapping") return command } @@ -38,7 +36,7 @@ func (cmd *adminBootstrap) run(_ *cobra.Command, args []string) { panic(err) } logrus.Infof(cf.Dump(inCfg, cf.DefaultOptions())) - if err := controller.Bootstrap(cmd.skipCtrl, cmd.skipFrontend, inCfg); err != nil { + if err := controller.Bootstrap(cmd.skipFrontend, inCfg); err != nil { panic(err) } logrus.Info("bootstrap complete!") diff --git a/controller/bootstrap.go b/controller/bootstrap.go index 2ee0be153..290fe330a 100644 --- a/controller/bootstrap.go +++ b/controller/bootstrap.go @@ -6,12 +6,12 @@ import ( "encoding/json" "fmt" "github.com/openziti/edge-api/rest_management_api_client" - "github.com/openziti/edge-api/rest_management_api_client/config" + restMgmtEdgeConfig "github.com/openziti/edge-api/rest_management_api_client/config" "github.com/openziti/edge-api/rest_management_api_client/edge_router_policy" "github.com/openziti/edge-api/rest_management_api_client/identity" - rest_model_edge "github.com/openziti/edge-api/rest_model" + restModelEdge "github.com/openziti/edge-api/rest_model" "github.com/openziti/sdk-golang/ziti" - zrok_config "github.com/openziti/zrok/controller/config" + "github.com/openziti/zrok/controller/config" "github.com/openziti/zrok/controller/store" "github.com/openziti/zrok/controller/zrokEdgeSdk" "github.com/openziti/zrok/environment" @@ -21,7 +21,7 @@ import ( "time" ) -func Bootstrap(skipCtrl, skipFrontend bool, inCfg *zrok_config.Config) error { +func Bootstrap(skipFrontend bool, inCfg *config.Config) error { cfg = inCfg if v, err := store.Open(cfg.Store); err == nil { @@ -36,26 +36,6 @@ func Bootstrap(skipCtrl, skipFrontend bool, inCfg *zrok_config.Config) error { return errors.Wrap(err, "error connecting to the ziti edge management api") } - var ctrlZId string - if !skipCtrl { - logrus.Info("creating identity for controller ziti access") - - if ctrlZId, err = getIdentityId("ctrl"); err == nil { - logrus.Infof("controller identity: %v", ctrlZId) - } else { - ctrlZId, err = bootstrapIdentity("ctrl", edge) - if err != nil { - panic(err) - } - } - if err := assertIdentity(ctrlZId, edge); err != nil { - panic(err) - } - if err := assertErpForIdentity("ctrl", ctrlZId, edge); err != nil { - panic(err) - } - } - var frontendZId string if !skipFrontend { logrus.Info("creating identity for frontend ziti access") @@ -103,7 +83,7 @@ func assertZrokProxyConfigType(edge *rest_management_api_client.ZitiEdgeManageme filter := fmt.Sprintf("name=\"%v\"", model.ZrokProxyConfig) limit := int64(100) offset := int64(0) - listReq := &config.ListConfigTypesParams{ + listReq := &restMgmtEdgeConfig.ListConfigTypesParams{ Filter: &filter, Limit: &limit, Offset: &offset, @@ -116,8 +96,8 @@ func assertZrokProxyConfigType(edge *rest_management_api_client.ZitiEdgeManageme } if len(listResp.Payload.Data) < 1 { name := model.ZrokProxyConfig - ct := &rest_model_edge.ConfigTypeCreate{Name: &name} - createReq := &config.CreateConfigTypeParams{ConfigType: ct} + ct := &restModelEdge.ConfigTypeCreate{Name: &name} + createReq := &restMgmtEdgeConfig.CreateConfigTypeParams{ConfigType: ct} createReq.SetTimeout(30 * time.Second) createResp, err := edge.Config.CreateConfigType(createReq, nil) if err != nil { @@ -186,7 +166,7 @@ func bootstrapIdentity(name string, edge *rest_management_api_client.ZitiEdgeMan return "", errors.Wrap(err, "error loading environment root") } - idc, err := zrokEdgeSdk.CreateIdentity(name, rest_model_edge.IdentityTypeDevice, nil, edge) + idc, err := zrokEdgeSdk.CreateIdentity(name, restModelEdge.IdentityTypeDevice, nil, edge) if err != nil { return "", errors.Wrapf(err, "error creating '%v' identity", name) } diff --git a/environment/api.go b/environment/api.go index 71ee42611..a9bd95eeb 100644 --- a/environment/api.go +++ b/environment/api.go @@ -2,25 +2,31 @@ package environment import ( "github.com/openziti/zrok/environment/env_core" + "github.com/openziti/zrok/environment/env_v0_3" "github.com/openziti/zrok/rest_client_zrok" "github.com/pkg/errors" ) +// Root is the primary interface encapsulating the on-disk environment data. type Root interface { Metadata() *env_core.Metadata + Obliterate() error + HasConfig() (bool, error) Config() *env_core.Config SetConfig(cfg *env_core.Config) error + Client() (*rest_client_zrok.Zrok, error) ApiEndpoint() (string, string) + + IsEnabled() bool Environment() *env_core.Environment SetEnvironment(env *env_core.Environment) error DeleteEnvironment() error - IsEnabled() bool + ZitiIdentityFile(name string) (string, error) SaveZitiIdentity(name, data string) error DeleteZitiIdentity(name string) error - Obliterate() error } func LoadRoot() (Root, error) { From 48cfaada205d39a37c52c7c10b97438967a03d5f Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Fri, 14 Jul 2023 09:57:40 -0400 Subject: [PATCH 10/28] need to assert environment metadata when modifying the environment (#369) --- environment/env_v0_3/api.go | 9 +++++++++ environment/env_v0_3/root.go | 13 +++++++++++++ 2 files changed, 22 insertions(+) diff --git a/environment/env_v0_3/api.go b/environment/env_v0_3/api.go index be8bdb344..03c4ce896 100644 --- a/environment/env_v0_3/api.go +++ b/environment/env_v0_3/api.go @@ -27,6 +27,9 @@ func (r *Root) Config() *env_core.Config { } func (r *Root) SetConfig(cfg *env_core.Config) error { + if err := assertMetadata(); err != nil { + return err + } if err := saveConfig(cfg); err != nil { return err } @@ -87,6 +90,9 @@ func (r *Root) Environment() *env_core.Environment { } func (r *Root) SetEnvironment(env *env_core.Environment) error { + if err := assertMetadata(); err != nil { + return err + } if err := saveEnvironment(env); err != nil { return err } @@ -115,6 +121,9 @@ func (r *Root) ZitiIdentityFile(name string) (string, error) { } func (r *Root) SaveZitiIdentity(name, data string) error { + if err := assertMetadata(); err != nil { + return err + } zif, err := r.ZitiIdentityFile(name) if err != nil { return err diff --git a/environment/env_v0_3/root.go b/environment/env_v0_3/root.go index 842ef128e..68e1809bd 100644 --- a/environment/env_v0_3/root.go +++ b/environment/env_v0_3/root.go @@ -65,6 +65,19 @@ func rootExists() (bool, error) { return true, err } +func assertMetadata() error { + exists, err := rootExists() + if err != nil { + return err + } + if !exists { + if err := writeMetadata(); err != nil { + return err + } + } + return nil +} + func loadMetadata() (*env_core.Metadata, error) { mf, err := metadataFile() if err != nil { From 4713243e2c5f85012ee04085de8a37e18e525508 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Fri, 14 Jul 2023 10:14:32 -0400 Subject: [PATCH 11/28] further ziti identity naming cleanup (#369) --- cmd/zrok/accessPrivate.go | 10 +++++----- cmd/zrok/adminCreateIdentity.go | 4 ++-- cmd/zrok/disable.go | 2 +- cmd/zrok/enable.go | 2 +- cmd/zrok/sharePrivate.go | 2 +- cmd/zrok/sharePublic.go | 2 +- cmd/zrok/shareReserved.go | 2 +- cmd/zrok/testLoopPublic.go | 2 +- controller/bootstrap.go | 15 ++++++++++----- endpoints/proxy/frontend.go | 2 +- endpoints/publicProxy/http.go | 2 +- endpoints/tcpTunnel/frontend.go | 2 +- endpoints/udpTunnel/frontend.go | 2 +- environment/api.go | 9 ++++++--- environment/env_v0_3/api.go | 18 +++++++++++++----- 15 files changed, 46 insertions(+), 30 deletions(-) diff --git a/cmd/zrok/accessPrivate.go b/cmd/zrok/accessPrivate.go index 6927b57f7..ec1b1a799 100644 --- a/cmd/zrok/accessPrivate.go +++ b/cmd/zrok/accessPrivate.go @@ -101,20 +101,20 @@ func (cmd *accessPrivateCommand) run(_ *cobra.Command, args []string) { case "tcpTunnel": fe, err := tcpTunnel.NewFrontend(&tcpTunnel.FrontendConfig{ BindAddress: cmd.bindAddress, - IdentityName: "backend", + IdentityName: env.ShareIdentityName(), ShrToken: args[0], RequestsChan: requests, }) if err != nil { if !panicInstead { - tui.Error("unable to create private frontend", err) + tui.Error("unable to create private access", err) } panic(err) } go func() { if err := fe.Run(); err != nil { if !panicInstead { - tui.Error("error starting frontend", err) + tui.Error("error starting access", err) } panic(err) } @@ -123,7 +123,7 @@ func (cmd *accessPrivateCommand) run(_ *cobra.Command, args []string) { case "udpTunnel": fe, err := udpTunnel.NewFrontend(&udpTunnel.FrontendConfig{ BindAddress: cmd.bindAddress, - IdentityName: "backend", + IdentityName: env.ShareIdentityName(), ShrToken: args[0], RequestsChan: requests, IdleTime: time.Minute, @@ -144,7 +144,7 @@ func (cmd *accessPrivateCommand) run(_ *cobra.Command, args []string) { }() default: - cfg := proxy.DefaultFrontendConfig("backend") + cfg := proxy.DefaultFrontendConfig(env.ShareIdentityName()) cfg.ShrToken = shrToken cfg.Address = cmd.bindAddress cfg.RequestsChan = requests diff --git a/cmd/zrok/adminCreateIdentity.go b/cmd/zrok/adminCreateIdentity.go index 74723ffbd..f32ad348b 100644 --- a/cmd/zrok/adminCreateIdentity.go +++ b/cmd/zrok/adminCreateIdentity.go @@ -36,7 +36,7 @@ func (cmd *adminCreateIdentity) run(_ *cobra.Command, args []string) { if err != nil { panic(err) } - zif, err := env.ZitiIdentityFile(name) + zif, err := env.ZitiIdentityNamed(name) if err != nil { panic(err) } @@ -58,7 +58,7 @@ func (cmd *adminCreateIdentity) run(_ *cobra.Command, args []string) { panic(err) } - if err := env.SaveZitiIdentity(name, resp.Payload.Cfg); err != nil { + if err := env.SaveZitiIdentityNamed(name, resp.Payload.Cfg); err != nil { panic(err) } diff --git a/cmd/zrok/disable.go b/cmd/zrok/disable.go index 79c03e615..960af6a7a 100644 --- a/cmd/zrok/disable.go +++ b/cmd/zrok/disable.go @@ -65,7 +65,7 @@ func (cmd *disableCommand) run(_ *cobra.Command, _ []string) { } panic(err) } - if err := env.DeleteZitiIdentity("backend"); err != nil { + if err := env.DeleteZitiIdentityNamed(env.ShareIdentityName()); err != nil { if !panicInstead { tui.Error("error removing zrok backend identity", err) } diff --git a/cmd/zrok/enable.go b/cmd/zrok/enable.go index d0e5d2d37..19ffb7a32 100644 --- a/cmd/zrok/enable.go +++ b/cmd/zrok/enable.go @@ -130,7 +130,7 @@ func (cmd *enableCommand) run(_ *cobra.Command, args []string) { } os.Exit(1) } - if err := env.SaveZitiIdentity("backend", resp.Payload.Cfg); err != nil { + if err := env.SaveZitiIdentityNamed(env.ShareIdentityName(), resp.Payload.Cfg); err != nil { if !cmd.headless && prg != nil { prg.Send(fmt.Sprintf("there was an error writing the environment: %v", err)) prg.Quit() diff --git a/cmd/zrok/sharePrivate.go b/cmd/zrok/sharePrivate.go index 68daa5cde..72499e8ea 100644 --- a/cmd/zrok/sharePrivate.go +++ b/cmd/zrok/sharePrivate.go @@ -90,7 +90,7 @@ func (cmd *sharePrivateCommand) run(_ *cobra.Command, args []string) { tui.Error("unable to load environment; did you 'zrok enable'?", nil) } - zif, err := env.ZitiIdentityFile("backend") + zif, err := env.ZitiIdentityNamed(env.ShareIdentityName()) if err != nil { if !panicInstead { tui.Error("unable to load ziti identity configuration", err) diff --git a/cmd/zrok/sharePublic.go b/cmd/zrok/sharePublic.go index 2e40fe0f0..de9487959 100644 --- a/cmd/zrok/sharePublic.go +++ b/cmd/zrok/sharePublic.go @@ -84,7 +84,7 @@ func (cmd *sharePublicCommand) run(_ *cobra.Command, args []string) { tui.Error("unable to load environment; did you 'zrok enable'?", nil) } - zif, err := env.ZitiIdentityFile("backend") + zif, err := env.ZitiIdentityNamed(env.ShareIdentityName()) if err != nil { if !panicInstead { tui.Error("unable to load ziti identity configuration", err) diff --git a/cmd/zrok/shareReserved.go b/cmd/zrok/shareReserved.go index 59f8c4197..ec9348c58 100644 --- a/cmd/zrok/shareReserved.go +++ b/cmd/zrok/shareReserved.go @@ -78,7 +78,7 @@ func (cmd *shareReservedCommand) run(_ *cobra.Command, args []string) { target = resp.Payload.BackendProxyEndpoint } - zif, err := env.ZitiIdentityFile("backend") + zif, err := env.ZitiIdentityNamed(env.ShareIdentityName()) if err != nil { if !panicInstead { tui.Error("unable to load ziti identity configuration", err) diff --git a/cmd/zrok/testLoopPublic.go b/cmd/zrok/testLoopPublic.go index 2342ab7f0..3c62c73c9 100644 --- a/cmd/zrok/testLoopPublic.go +++ b/cmd/zrok/testLoopPublic.go @@ -186,7 +186,7 @@ func (l *looper) startup() { } l.env = env.Environment() - l.zif, err = env.ZitiIdentityFile("backend") + l.zif, err = env.ZitiIdentityNamed(env.ShareIdentityName()) if err != nil { panic(err) } diff --git a/controller/bootstrap.go b/controller/bootstrap.go index 290fe330a..029cd75f6 100644 --- a/controller/bootstrap.go +++ b/controller/bootstrap.go @@ -36,14 +36,19 @@ func Bootstrap(skipFrontend bool, inCfg *config.Config) error { return errors.Wrap(err, "error connecting to the ziti edge management api") } + env, err := environment.LoadRoot() + if err != nil { + return err + } + var frontendZId string if !skipFrontend { logrus.Info("creating identity for frontend ziti access") - if frontendZId, err = getIdentityId("frontend"); err == nil { + if frontendZId, err = getIdentityId(env.AccessIdentityName()); err == nil { logrus.Infof("frontend identity: %v", frontendZId) } else { - frontendZId, err = bootstrapIdentity("frontend", edge) + frontendZId, err = bootstrapIdentity(env.AccessIdentityName(), edge) if err != nil { panic(err) } @@ -51,7 +56,7 @@ func Bootstrap(skipFrontend bool, inCfg *config.Config) error { if err := assertIdentity(frontendZId, edge); err != nil { panic(err) } - if err := assertErpForIdentity("frontend", frontendZId, edge); err != nil { + if err := assertErpForIdentity(env.AccessIdentityName(), frontendZId, edge); err != nil { panic(err) } @@ -117,7 +122,7 @@ func getIdentityId(identityName string) (string, error) { if err != nil { return "", errors.Wrap(err, "error opening environment root") } - zif, err := env.ZitiIdentityFile(identityName) + zif, err := env.ZitiIdentityNamed(identityName) if err != nil { return "", errors.Wrapf(err, "error opening identity '%v' from environment", identityName) } @@ -184,7 +189,7 @@ func bootstrapIdentity(name string, edge *rest_management_api_client.ZitiEdgeMan if err != nil { return "", errors.Wrapf(err, "error encoding identity config '%v'", name) } - if err := env.SaveZitiIdentity(name, out.String()); err != nil { + if err := env.SaveZitiIdentityNamed(name, out.String()); err != nil { return "", errors.Wrapf(err, "error saving identity config '%v'", name) } return zId, nil diff --git a/endpoints/proxy/frontend.go b/endpoints/proxy/frontend.go index b50020603..4cc325c4a 100644 --- a/endpoints/proxy/frontend.go +++ b/endpoints/proxy/frontend.go @@ -44,7 +44,7 @@ func NewFrontend(cfg *FrontendConfig) (*Frontend, error) { if err != nil { return nil, errors.Wrap(err, "error loading environment root") } - zCfgPath, err := env.ZitiIdentityFile(cfg.IdentityName) + zCfgPath, err := env.ZitiIdentityNamed(cfg.IdentityName) if err != nil { return nil, errors.Wrapf(err, "error getting ziti identity '%v' from environment", cfg.IdentityName) } diff --git a/endpoints/publicProxy/http.go b/endpoints/publicProxy/http.go index 70effb129..70e74deb0 100644 --- a/endpoints/publicProxy/http.go +++ b/endpoints/publicProxy/http.go @@ -30,7 +30,7 @@ func NewHTTP(cfg *Config) (*httpFrontend, error) { if err != nil { return nil, errors.Wrap(err, "error loading environment root") } - zCfgPath, err := env.ZitiIdentityFile(cfg.Identity) + zCfgPath, err := env.ZitiIdentityNamed(cfg.Identity) if err != nil { return nil, errors.Wrapf(err, "error getting ziti identity '%v' from environment", cfg.Identity) } diff --git a/endpoints/tcpTunnel/frontend.go b/endpoints/tcpTunnel/frontend.go index 136b61375..031fa2ace 100644 --- a/endpoints/tcpTunnel/frontend.go +++ b/endpoints/tcpTunnel/frontend.go @@ -33,7 +33,7 @@ func NewFrontend(cfg *FrontendConfig) (*Frontend, error) { if err != nil { return nil, errors.Wrap(err, "error loading environment root") } - zCfgPath, err := env.ZitiIdentityFile(cfg.IdentityName) + zCfgPath, err := env.ZitiIdentityNamed(cfg.IdentityName) if err != nil { return nil, errors.Wrapf(err, "error getting ziti identity '%v' from environment", cfg.IdentityName) } diff --git a/endpoints/udpTunnel/frontend.go b/endpoints/udpTunnel/frontend.go index d9daec568..f14036379 100644 --- a/endpoints/udpTunnel/frontend.go +++ b/endpoints/udpTunnel/frontend.go @@ -103,7 +103,7 @@ func NewFrontend(cfg *FrontendConfig) (*Frontend, error) { if err != nil { return nil, errors.Wrap(err, "error loading environment root") } - zCfgPath, err := env.ZitiIdentityFile(cfg.IdentityName) + zCfgPath, err := env.ZitiIdentityNamed(cfg.IdentityName) if err != nil { return nil, errors.Wrapf(err, "error getting ziti identity '%v' from environment", cfg.IdentityName) } diff --git a/environment/api.go b/environment/api.go index a9bd95eeb..6d2bae8c4 100644 --- a/environment/api.go +++ b/environment/api.go @@ -24,9 +24,12 @@ type Root interface { SetEnvironment(env *env_core.Environment) error DeleteEnvironment() error - ZitiIdentityFile(name string) (string, error) - SaveZitiIdentity(name, data string) error - DeleteZitiIdentity(name string) error + AccessIdentityName() string + ShareIdentityName() string + + ZitiIdentityNamed(name string) (string, error) + SaveZitiIdentityNamed(name, data string) error + DeleteZitiIdentityNamed(name string) error } func LoadRoot() (Root, error) { diff --git a/environment/env_v0_3/api.go b/environment/env_v0_3/api.go index 03c4ce896..424f88363 100644 --- a/environment/env_v0_3/api.go +++ b/environment/env_v0_3/api.go @@ -116,15 +116,23 @@ func (r *Root) IsEnabled() bool { return r.env != nil } -func (r *Root) ZitiIdentityFile(name string) (string, error) { +func (r *Root) AccessIdentityName() string { + return "frontend" +} + +func (r *Root) ShareIdentityName() string { + return "backend" +} + +func (r *Root) ZitiIdentityNamed(name string) (string, error) { return identityFile(name) } -func (r *Root) SaveZitiIdentity(name, data string) error { +func (r *Root) SaveZitiIdentityNamed(name, data string) error { if err := assertMetadata(); err != nil { return err } - zif, err := r.ZitiIdentityFile(name) + zif, err := r.ZitiIdentityNamed(name) if err != nil { return err } @@ -137,8 +145,8 @@ func (r *Root) SaveZitiIdentity(name, data string) error { return nil } -func (r *Root) DeleteZitiIdentity(name string) error { - zif, err := r.ZitiIdentityFile(name) +func (r *Root) DeleteZitiIdentityNamed(name string) error { + zif, err := r.ZitiIdentityNamed(name) if err != nil { return errors.Wrapf(err, "error getting ziti identity file path for '%v'", name) } From af77de015ac2e753699d72f7fb888c973de34ad2 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Fri, 14 Jul 2023 10:51:35 -0400 Subject: [PATCH 12/28] environment load assert chain (#369); get rid of warnings in zrok status --- cmd/zrok/status.go | 1 - environment/api.go | 6 +++++- environment/env_v0_3/root.go | 17 ++++++++++++++++- 3 files changed, 21 insertions(+), 3 deletions(-) diff --git a/cmd/zrok/status.go b/cmd/zrok/status.go index d9d2af991..4de14e54f 100644 --- a/cmd/zrok/status.go +++ b/cmd/zrok/status.go @@ -50,7 +50,6 @@ func (cmd *statusCommand) run(_ *cobra.Command, _ []string) { _, _ = fmt.Fprintf(os.Stderr, "\n") if !env.IsEnabled() { - tui.Warning("Unable to load your local environment!\n") _, _ = fmt.Fprintf(os.Stderr, "To create a local environment use the %v command.\n", tui.Code.Render("zrok enable")) } else { _, _ = fmt.Fprintf(os.Stdout, tui.Code.Render("Environment")+":\n\n") diff --git a/environment/api.go b/environment/api.go index 6d2bae8c4..1c100635a 100644 --- a/environment/api.go +++ b/environment/api.go @@ -33,7 +33,11 @@ type Root interface { } func LoadRoot() (Root, error) { - return env_v0_3.Load() + if assert, err := env_v0_3.Assert(); assert && err == nil { + return env_v0_3.Load() + } else { + return nil, err + } } func ListRoots() ([]*env_core.Metadata, error) { diff --git a/environment/env_v0_3/root.go b/environment/env_v0_3/root.go index 68e1809bd..f80345936 100644 --- a/environment/env_v0_3/root.go +++ b/environment/env_v0_3/root.go @@ -16,6 +16,21 @@ type Root struct { env *env_core.Environment } +func Assert() (bool, error) { + exists, err := rootExists() + if err != nil { + return true, err + } + if exists { + meta, err := loadMetadata() + if err != nil { + return true, err + } + return meta.V == V, nil + } + return false, nil +} + func Load() (*Root, error) { r := &Root{} exists, err := rootExists() @@ -62,7 +77,7 @@ func rootExists() (bool, error) { if err != nil { return false, err } - return true, err + return true, nil } func assertMetadata() error { From d99ac8536904e57eada28ffb358e9f342a9978d1 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Fri, 14 Jul 2023 14:30:35 -0400 Subject: [PATCH 13/28] implemented naive migration from environment v0.3 to v0.4 (#369) --- cmd/zrok/status.go | 4 + cmd/zrok/update.go | 52 ++++++ environment/api.go | 67 +++---- environment/env_core/model.go | 27 +++ environment/env_v0_4/api.go | 168 ++++++++++++++++++ environment/env_v0_4/dirs.go | 55 ++++++ environment/env_v0_4/root.go | 321 ++++++++++++++++++++++++++++++++++ 7 files changed, 647 insertions(+), 47 deletions(-) create mode 100644 cmd/zrok/update.go create mode 100644 environment/env_v0_4/api.go create mode 100644 environment/env_v0_4/dirs.go create mode 100644 environment/env_v0_4/root.go diff --git a/cmd/zrok/status.go b/cmd/zrok/status.go index 4de14e54f..fe6d00beb 100644 --- a/cmd/zrok/status.go +++ b/cmd/zrok/status.go @@ -39,6 +39,10 @@ func (cmd *statusCommand) run(_ *cobra.Command, _ []string) { tui.Error("error loading environment", err) } + if !environment.IsLatest(env) { + tui.Warning(fmt.Sprintf("Your environment is out of date ('%v'), use '%v' to update (make a backup before updating!)\n", env.Metadata().V, tui.Code.Render("zrok update"))) + } + _, _ = fmt.Fprintf(os.Stdout, tui.Code.Render("Config")+":\n\n") t := table.NewWriter() t.SetOutputMirror(os.Stdout) diff --git a/cmd/zrok/update.go b/cmd/zrok/update.go new file mode 100644 index 000000000..da4df341d --- /dev/null +++ b/cmd/zrok/update.go @@ -0,0 +1,52 @@ +package main + +import ( + "fmt" + "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/tui" + "github.com/spf13/cobra" +) + +func init() { + rootCmd.AddCommand(newUpdateCommand().cmd) +} + +type updateCommand struct { + cmd *cobra.Command +} + +func newUpdateCommand() *updateCommand { + cmd := &cobra.Command{ + Use: "update", + Short: "Update your environment to the latest version", + Args: cobra.NoArgs, + } + command := &updateCommand{cmd: cmd} + cmd.Run = command.run + return command +} + +func (cmd *updateCommand) run(_ *cobra.Command, _ []string) { + r, err := environment.LoadRoot() + if err != nil { + if !panicInstead { + tui.Error("unable to load environment", err) + } + panic(err) + } + + if environment.IsLatest(r) { + fmt.Printf("zrok environment is already the latest version at '%v'\n", r.Metadata().V) + return + } + + newR, err := environment.UpdateRoot(r) + if err != nil { + if !panicInstead { + tui.Error("unable to update environment", err) + } + panic(err) + } + + fmt.Printf("environment updated to '%v'\n", newR.Metadata().V) +} diff --git a/environment/api.go b/environment/api.go index 1c100635a..213d9ed49 100644 --- a/environment/api.go +++ b/environment/api.go @@ -3,64 +3,37 @@ package environment import ( "github.com/openziti/zrok/environment/env_core" "github.com/openziti/zrok/environment/env_v0_3" - "github.com/openziti/zrok/rest_client_zrok" + "github.com/openziti/zrok/environment/env_v0_4" "github.com/pkg/errors" ) -// Root is the primary interface encapsulating the on-disk environment data. -type Root interface { - Metadata() *env_core.Metadata - Obliterate() error - - HasConfig() (bool, error) - Config() *env_core.Config - SetConfig(cfg *env_core.Config) error - - Client() (*rest_client_zrok.Zrok, error) - ApiEndpoint() (string, string) - - IsEnabled() bool - Environment() *env_core.Environment - SetEnvironment(env *env_core.Environment) error - DeleteEnvironment() error - - AccessIdentityName() string - ShareIdentityName() string - - ZitiIdentityNamed(name string) (string, error) - SaveZitiIdentityNamed(name, data string) error - DeleteZitiIdentityNamed(name string) error -} - -func LoadRoot() (Root, error) { - if assert, err := env_v0_3.Assert(); assert && err == nil { +func LoadRoot() (env_core.Root, error) { + if assert, err := env_v0_4.Assert(); assert && err == nil { + return env_v0_4.Load() + } else if assert, err := env_v0_3.Assert(); assert && err == nil { return env_v0_3.Load() } else { return nil, err } } -func ListRoots() ([]*env_core.Metadata, error) { - return nil, nil -} - -func LoadRootVersion(m *env_core.Metadata) (Root, error) { - if m == nil { - return nil, errors.Errorf("specify metadata version") +func IsLatest(r env_core.Root) bool { + if r == nil { + return false } - switch m.V { - case env_v0_3.V: - return env_v0_3.Load() - - default: - return nil, errors.Errorf("unknown metadata version '%v'", m.V) + if r.Metadata() == nil { + return false } + if r.Metadata().V == env_v0_4.V { + return true + } + return false } -func NeedsUpdate(r Root) bool { - return r.Metadata().V != env_v0_3.V -} - -func UpdateRoot(r Root) (Root, error) { - return nil, nil +func UpdateRoot(r env_core.Root) (env_core.Root, error) { + newR, err := env_v0_4.Update(r) + if err != nil { + return nil, errors.Wrap(err, "unable to update environment") + } + return newR, nil } diff --git a/environment/env_core/model.go b/environment/env_core/model.go index 2f7f9da70..7e5909dc7 100644 --- a/environment/env_core/model.go +++ b/environment/env_core/model.go @@ -1,5 +1,32 @@ package env_core +import "github.com/openziti/zrok/rest_client_zrok" + +// Root is the primary interface encapsulating the on-disk environment data. +type Root interface { + Metadata() *Metadata + Obliterate() error + + HasConfig() (bool, error) + Config() *Config + SetConfig(cfg *Config) error + + Client() (*rest_client_zrok.Zrok, error) + ApiEndpoint() (string, string) + + IsEnabled() bool + Environment() *Environment + SetEnvironment(env *Environment) error + DeleteEnvironment() error + + AccessIdentityName() string + ShareIdentityName() string + + ZitiIdentityNamed(name string) (string, error) + SaveZitiIdentityNamed(name, data string) error + DeleteZitiIdentityNamed(name string) error +} + type Environment struct { Token string ZitiIdentity string diff --git a/environment/env_v0_4/api.go b/environment/env_v0_4/api.go new file mode 100644 index 000000000..fae20e8d0 --- /dev/null +++ b/environment/env_v0_4/api.go @@ -0,0 +1,168 @@ +package env_v0_4 + +import ( + "github.com/go-openapi/runtime" + httptransport "github.com/go-openapi/runtime/client" + "github.com/go-openapi/strfmt" + "github.com/openziti/zrok/build" + "github.com/openziti/zrok/environment/env_core" + "github.com/openziti/zrok/rest_client_zrok" + "github.com/pkg/errors" + "net/url" + "os" + "path/filepath" + "regexp" +) + +func (r *Root) Metadata() *env_core.Metadata { + return r.meta +} + +func (r *Root) HasConfig() (bool, error) { + return r.cfg != nil, nil +} + +func (r *Root) Config() *env_core.Config { + return r.cfg +} + +func (r *Root) SetConfig(cfg *env_core.Config) error { + if err := assertMetadata(); err != nil { + return err + } + if err := saveConfig(cfg); err != nil { + return err + } + r.cfg = cfg + return nil +} + +func (r *Root) Client() (*rest_client_zrok.Zrok, error) { + apiEndpoint, _ := r.ApiEndpoint() + apiUrl, err := url.Parse(apiEndpoint) + if err != nil { + return nil, errors.Wrapf(err, "error parsing api endpoint '%v'", r) + } + transport := httptransport.New(apiUrl.Host, "/api/v1", []string{apiUrl.Scheme}) + transport.Producers["application/zrok.v1+json"] = runtime.JSONProducer() + transport.Consumers["application/zrok.v1+json"] = runtime.JSONConsumer() + + zrok := rest_client_zrok.New(transport, strfmt.Default) + v, err := zrok.Metadata.Version(nil) + if err != nil { + return nil, errors.Wrapf(err, "error getting version from api endpoint '%v': %v", apiEndpoint, err) + } + // allow reported version string to be optionally prefixed with + // "refs/heads/" or "refs/tags/" + re := regexp.MustCompile(`^(refs/(heads|tags)/)?` + build.Series) + if !re.MatchString(string(v.Payload)) { + return nil, errors.Errorf("expected a '%v' version, received: '%v'", build.Series, v.Payload) + } + + return zrok, nil +} + +func (r *Root) ApiEndpoint() (string, string) { + apiEndpoint := "https://api.zrok.io" + from := "binary" + + if r.Config() != nil && r.Config().ApiEndpoint != "" { + apiEndpoint = r.Config().ApiEndpoint + from = "config" + } + + env := os.Getenv("ZROK_API_ENDPOINT") + if env != "" { + apiEndpoint = env + from = "ZROK_API_ENDPOINT" + } + + if r.IsEnabled() { + apiEndpoint = r.Environment().ApiEndpoint + from = "env" + } + + return apiEndpoint, from +} + +func (r *Root) Environment() *env_core.Environment { + return r.env +} + +func (r *Root) SetEnvironment(env *env_core.Environment) error { + if err := assertMetadata(); err != nil { + return err + } + if err := saveEnvironment(env); err != nil { + return err + } + r.env = env + return nil +} + +func (r *Root) DeleteEnvironment() error { + ef, err := environmentFile() + if err != nil { + return errors.Wrap(err, "error getting environment file") + } + if err := os.Remove(ef); err != nil { + return errors.Wrap(err, "error removing environment file") + } + r.env = nil + return nil +} + +func (r *Root) IsEnabled() bool { + return r.env != nil +} + +func (r *Root) AccessIdentityName() string { + return "access" +} + +func (r *Root) ShareIdentityName() string { + return "share" +} + +func (r *Root) ZitiIdentityNamed(name string) (string, error) { + return identityFile(name) +} + +func (r *Root) SaveZitiIdentityNamed(name, data string) error { + if err := assertMetadata(); err != nil { + return err + } + zif, err := r.ZitiIdentityNamed(name) + if err != nil { + return err + } + if err := os.MkdirAll(filepath.Dir(zif), os.FileMode(0700)); err != nil { + return errors.Wrapf(err, "error creating environment path '%v'", filepath.Dir(zif)) + } + if err := os.WriteFile(zif, []byte(data), os.FileMode(0600)); err != nil { + return errors.Wrapf(err, "error writing ziti identity file '%v'", zif) + } + return nil +} + +func (r *Root) DeleteZitiIdentityNamed(name string) error { + zif, err := r.ZitiIdentityNamed(name) + if err != nil { + return errors.Wrapf(err, "error getting ziti identity file path for '%v'", name) + } + if err := os.Remove(zif); err != nil { + return errors.Wrapf(err, "error removing ziti identity file '%v'", zif) + } + return nil +} + +func (r *Root) Obliterate() error { + zrd, err := rootDir() + if err != nil { + return err + } + if err := os.RemoveAll(zrd); err != nil { + return err + } + return nil +} diff --git a/environment/env_v0_4/dirs.go b/environment/env_v0_4/dirs.go new file mode 100644 index 000000000..b259fe094 --- /dev/null +++ b/environment/env_v0_4/dirs.go @@ -0,0 +1,55 @@ +package env_v0_4 + +import ( + "fmt" + "os" + "path/filepath" +) + +func rootDir() (string, error) { + home, err := os.UserHomeDir() + if err != nil { + return "", err + } + return filepath.Join(home, ".zrok"), nil +} + +func metadataFile() (string, error) { + zrd, err := rootDir() + if err != nil { + return "", err + } + return filepath.Join(zrd, "metadata.json"), nil +} + +func configFile() (string, error) { + zrd, err := rootDir() + if err != nil { + return "", err + } + return filepath.Join(zrd, "config.json"), nil +} + +func environmentFile() (string, error) { + zrd, err := rootDir() + if err != nil { + return "", err + } + return filepath.Join(zrd, "environment.json"), nil +} + +func identitiesDir() (string, error) { + zrd, err := rootDir() + if err != nil { + return "", err + } + return filepath.Join(zrd, "identities"), nil +} + +func identityFile(name string) (string, error) { + idd, err := identitiesDir() + if err != nil { + return "", err + } + return filepath.Join(idd, fmt.Sprintf("%v.json", name)), nil +} diff --git a/environment/env_v0_4/root.go b/environment/env_v0_4/root.go new file mode 100644 index 000000000..5a6f31911 --- /dev/null +++ b/environment/env_v0_4/root.go @@ -0,0 +1,321 @@ +package env_v0_4 + +import ( + "encoding/json" + "fmt" + "github.com/openziti/zrok/environment/env_core" + "github.com/openziti/zrok/environment/env_v0_3" + "github.com/pkg/errors" + "os" + "path/filepath" +) + +const V = "v0.4" + +type Root struct { + meta *env_core.Metadata + cfg *env_core.Config + env *env_core.Environment +} + +func Assert() (bool, error) { + exists, err := rootExists() + if err != nil { + return true, err + } + if exists { + meta, err := loadMetadata() + if err != nil { + return true, err + } + return meta.V == V, nil + } + return false, nil +} + +func Load() (*Root, error) { + r := &Root{} + exists, err := rootExists() + if err != nil { + return nil, err + } + if exists { + if meta, err := loadMetadata(); err == nil { + r.meta = meta + } else { + return nil, err + } + + if cfg, err := loadConfig(); err == nil { + r.cfg = cfg + } + + if env, err := loadEnvironment(); err == nil { + r.env = env + } + + } else { + root, err := rootDir() + if err != nil { + return nil, err + } + r.meta = &env_core.Metadata{ + V: V, + RootPath: root, + } + } + return r, nil +} + +func Update(r env_core.Root) (env_core.Root, error) { + if r == nil || r.Metadata() == nil { + return nil, errors.Errorf("nil root") + } + if r.Metadata().V != env_v0_3.V { + return nil, errors.Errorf("expecting version '%v'", env_v0_3.V) + } + + newR := &Root{meta: r.Metadata(), cfg: r.Config(), env: r.Environment()} + + oldAccessF, err := r.ZitiIdentityNamed(r.AccessIdentityName()) + if err != nil { + return nil, err + } + _, err = os.Stat(oldAccessF) + if err == nil { + newAccessF, err := newR.ZitiIdentityNamed(newR.AccessIdentityName()) + if err != nil { + return nil, err + } + if err := os.Rename(oldAccessF, newAccessF); err != nil { + return nil, err + } + fmt.Printf("renamed '%v' -> '%v'\n", oldAccessF, newAccessF) + } else if !os.IsNotExist(err) { + return nil, err + } + + oldShareF, err := r.ZitiIdentityNamed(r.ShareIdentityName()) + if err != nil { + return nil, err + } + _, err = os.Stat(oldShareF) + if err == nil { + newShareF, err := newR.ZitiIdentityNamed(newR.ShareIdentityName()) + if err != nil { + return nil, err + } + if err := os.Rename(oldShareF, newShareF); err != nil { + return nil, err + } + fmt.Printf("renamed '%v' -> '%v'\n", oldShareF, newShareF) + } + + if err := writeMetadata(); err != nil { + return nil, err + } + + meta, err := loadMetadata() + if err != nil { + return nil, err + } + newR.meta = meta + + return newR, nil +} + +func rootExists() (bool, error) { + mf, err := metadataFile() + if err != nil { + return false, err + } + _, err = os.Stat(mf) + if os.IsNotExist(err) { + return false, nil + } + if err != nil { + return false, err + } + return true, nil +} + +func assertMetadata() error { + exists, err := rootExists() + if err != nil { + return err + } + if !exists { + if err := writeMetadata(); err != nil { + return err + } + } + return nil +} + +func loadMetadata() (*env_core.Metadata, error) { + mf, err := metadataFile() + if err != nil { + return nil, err + } + data, err := os.ReadFile(mf) + if err != nil { + return nil, err + } + m := &metadata{} + if err := json.Unmarshal(data, m); err != nil { + return nil, errors.Wrapf(err, "error unmarshaling metadata file '%v'", mf) + } + if m.V != V { + return nil, errors.Errorf("got metadata version '%v', expected '%v'", m.V, V) + } + rf, err := rootDir() + if err != nil { + return nil, err + } + out := &env_core.Metadata{ + V: m.V, + RootPath: rf, + } + return out, nil +} + +func writeMetadata() error { + mf, err := metadataFile() + if err != nil { + return err + } + data, err := json.Marshal(&metadata{V: V}) + if err != nil { + return err + } + if err := os.MkdirAll(filepath.Dir(mf), os.FileMode(0700)); err != nil { + return err + } + if err := os.WriteFile(mf, data, os.FileMode(0600)); err != nil { + return err + } + return nil +} + +func loadConfig() (*env_core.Config, error) { + cf, err := configFile() + if err != nil { + return nil, errors.Wrap(err, "error getting config file path") + } + data, err := os.ReadFile(cf) + if err != nil { + return nil, errors.Wrapf(err, "error reading config file '%v'", cf) + } + cfg := &config{} + if err := json.Unmarshal(data, cfg); err != nil { + return nil, errors.Wrapf(err, "error unmarshaling config file '%v'", cf) + } + out := &env_core.Config{ + ApiEndpoint: cfg.ApiEndpoint, + } + return out, nil +} + +func saveConfig(cfg *env_core.Config) error { + in := &config{ApiEndpoint: cfg.ApiEndpoint} + data, err := json.MarshalIndent(in, "", " ") + if err != nil { + return errors.Wrap(err, "error marshaling config") + } + cf, err := configFile() + if err != nil { + return errors.Wrap(err, "error getting config file path") + } + if err := os.MkdirAll(filepath.Dir(cf), os.FileMode(0700)); err != nil { + return errors.Wrapf(err, "error creating environment path '%v'", filepath.Dir(cf)) + } + if err := os.WriteFile(cf, data, os.FileMode(0600)); err != nil { + return errors.Wrap(err, "error saving config file") + } + return nil +} + +func isEnabled() (bool, error) { + ef, err := environmentFile() + if err != nil { + return false, errors.Wrap(err, "error getting environment file path") + } + _, err = os.Stat(ef) + if os.IsNotExist(err) { + return false, nil + } + if err != nil { + return false, errors.Wrapf(err, "error stat-ing environment file '%v'", ef) + } + return true, nil +} + +func loadEnvironment() (*env_core.Environment, error) { + ef, err := environmentFile() + if err != nil { + return nil, errors.Wrap(err, "error getting environment file") + } + data, err := os.ReadFile(ef) + if err != nil { + return nil, errors.Wrapf(err, "error reading environment file '%v'", ef) + } + env := &environment{} + if err := json.Unmarshal(data, env); err != nil { + return nil, errors.Wrapf(err, "error unmarshaling environment file '%v'", ef) + } + out := &env_core.Environment{ + Token: env.Token, + ZitiIdentity: env.ZId, + ApiEndpoint: env.ApiEndpoint, + } + return out, nil +} + +func saveEnvironment(env *env_core.Environment) error { + in := &environment{ + Token: env.Token, + ZId: env.ZitiIdentity, + ApiEndpoint: env.ApiEndpoint, + } + data, err := json.MarshalIndent(in, "", " ") + if err != nil { + return errors.Wrap(err, "error marshaling environment") + } + ef, err := environmentFile() + if err != nil { + return errors.Wrap(err, "error getting environment file") + } + if err := os.MkdirAll(filepath.Dir(ef), os.FileMode(0700)); err != nil { + return errors.Wrapf(err, "error creating environment path '%v'", filepath.Dir(ef)) + } + if err := os.WriteFile(ef, data, os.FileMode(0600)); err != nil { + return errors.Wrap(err, "error saving environment file") + } + return nil +} + +func deleteEnvironment() error { + ef, err := environmentFile() + if err != nil { + return errors.Wrap(err, "error getting environment file") + } + if err := os.Remove(ef); err != nil { + return errors.Wrap(err, "error removing environment file") + } + + return nil +} + +type metadata struct { + V string `json:"v"` +} + +type config struct { + ApiEndpoint string `json:"api_endpoint"` +} + +type environment struct { + Token string `json:"zrok_token"` + ZId string `json:"ziti_identity"` + ApiEndpoint string `json:"api_endpoint"` +} From 6629171bac364833e9c56055785262483988983a Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Fri, 14 Jul 2023 15:18:32 -0400 Subject: [PATCH 14/28] missed this (#369) --- environment/env_v0_4/root.go | 2 ++ 1 file changed, 2 insertions(+) diff --git a/environment/env_v0_4/root.go b/environment/env_v0_4/root.go index 5a6f31911..6e60a458f 100644 --- a/environment/env_v0_4/root.go +++ b/environment/env_v0_4/root.go @@ -109,6 +109,8 @@ func Update(r env_core.Root) (env_core.Root, error) { return nil, err } fmt.Printf("renamed '%v' -> '%v'\n", oldShareF, newShareF) + } else if !os.IsNotExist(err) { + return nil, err } if err := writeMetadata(); err != nil { From 141c9ae685a7a628634fae20ccaaac423ec2ed88 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Mon, 17 Jul 2023 13:51:51 -0400 Subject: [PATCH 15/28] even better names for the common identities in the 'environment' (#34, #369) --- cmd/zrok/accessPrivate.go | 6 +++--- cmd/zrok/disable.go | 2 +- cmd/zrok/enable.go | 2 +- cmd/zrok/sharePrivate.go | 2 +- cmd/zrok/sharePublic.go | 2 +- cmd/zrok/shareReserved.go | 2 +- cmd/zrok/testLoopPublic.go | 2 +- controller/bootstrap.go | 8 ++++---- endpoints/publicProxy/config.go | 2 +- environment/env_core/model.go | 4 ++-- environment/env_v0_3/api.go | 4 ++-- environment/env_v0_4/api.go | 8 ++++---- environment/env_v0_4/root.go | 8 ++++---- 13 files changed, 26 insertions(+), 26 deletions(-) diff --git a/cmd/zrok/accessPrivate.go b/cmd/zrok/accessPrivate.go index ec1b1a799..3730493e5 100644 --- a/cmd/zrok/accessPrivate.go +++ b/cmd/zrok/accessPrivate.go @@ -101,7 +101,7 @@ func (cmd *accessPrivateCommand) run(_ *cobra.Command, args []string) { case "tcpTunnel": fe, err := tcpTunnel.NewFrontend(&tcpTunnel.FrontendConfig{ BindAddress: cmd.bindAddress, - IdentityName: env.ShareIdentityName(), + IdentityName: env.EnvironmentIdentityName(), ShrToken: args[0], RequestsChan: requests, }) @@ -123,7 +123,7 @@ func (cmd *accessPrivateCommand) run(_ *cobra.Command, args []string) { case "udpTunnel": fe, err := udpTunnel.NewFrontend(&udpTunnel.FrontendConfig{ BindAddress: cmd.bindAddress, - IdentityName: env.ShareIdentityName(), + IdentityName: env.EnvironmentIdentityName(), ShrToken: args[0], RequestsChan: requests, IdleTime: time.Minute, @@ -144,7 +144,7 @@ func (cmd *accessPrivateCommand) run(_ *cobra.Command, args []string) { }() default: - cfg := proxy.DefaultFrontendConfig(env.ShareIdentityName()) + cfg := proxy.DefaultFrontendConfig(env.EnvironmentIdentityName()) cfg.ShrToken = shrToken cfg.Address = cmd.bindAddress cfg.RequestsChan = requests diff --git a/cmd/zrok/disable.go b/cmd/zrok/disable.go index 960af6a7a..a7e497501 100644 --- a/cmd/zrok/disable.go +++ b/cmd/zrok/disable.go @@ -65,7 +65,7 @@ func (cmd *disableCommand) run(_ *cobra.Command, _ []string) { } panic(err) } - if err := env.DeleteZitiIdentityNamed(env.ShareIdentityName()); err != nil { + if err := env.DeleteZitiIdentityNamed(env.EnvironmentIdentityName()); err != nil { if !panicInstead { tui.Error("error removing zrok backend identity", err) } diff --git a/cmd/zrok/enable.go b/cmd/zrok/enable.go index 19ffb7a32..fb49533f1 100644 --- a/cmd/zrok/enable.go +++ b/cmd/zrok/enable.go @@ -130,7 +130,7 @@ func (cmd *enableCommand) run(_ *cobra.Command, args []string) { } os.Exit(1) } - if err := env.SaveZitiIdentityNamed(env.ShareIdentityName(), resp.Payload.Cfg); err != nil { + if err := env.SaveZitiIdentityNamed(env.EnvironmentIdentityName(), resp.Payload.Cfg); err != nil { if !cmd.headless && prg != nil { prg.Send(fmt.Sprintf("there was an error writing the environment: %v", err)) prg.Quit() diff --git a/cmd/zrok/sharePrivate.go b/cmd/zrok/sharePrivate.go index 72499e8ea..967a27727 100644 --- a/cmd/zrok/sharePrivate.go +++ b/cmd/zrok/sharePrivate.go @@ -90,7 +90,7 @@ func (cmd *sharePrivateCommand) run(_ *cobra.Command, args []string) { tui.Error("unable to load environment; did you 'zrok enable'?", nil) } - zif, err := env.ZitiIdentityNamed(env.ShareIdentityName()) + zif, err := env.ZitiIdentityNamed(env.EnvironmentIdentityName()) if err != nil { if !panicInstead { tui.Error("unable to load ziti identity configuration", err) diff --git a/cmd/zrok/sharePublic.go b/cmd/zrok/sharePublic.go index de9487959..0123fc5a8 100644 --- a/cmd/zrok/sharePublic.go +++ b/cmd/zrok/sharePublic.go @@ -84,7 +84,7 @@ func (cmd *sharePublicCommand) run(_ *cobra.Command, args []string) { tui.Error("unable to load environment; did you 'zrok enable'?", nil) } - zif, err := env.ZitiIdentityNamed(env.ShareIdentityName()) + zif, err := env.ZitiIdentityNamed(env.EnvironmentIdentityName()) if err != nil { if !panicInstead { tui.Error("unable to load ziti identity configuration", err) diff --git a/cmd/zrok/shareReserved.go b/cmd/zrok/shareReserved.go index ec9348c58..345dbc5a5 100644 --- a/cmd/zrok/shareReserved.go +++ b/cmd/zrok/shareReserved.go @@ -78,7 +78,7 @@ func (cmd *shareReservedCommand) run(_ *cobra.Command, args []string) { target = resp.Payload.BackendProxyEndpoint } - zif, err := env.ZitiIdentityNamed(env.ShareIdentityName()) + zif, err := env.ZitiIdentityNamed(env.EnvironmentIdentityName()) if err != nil { if !panicInstead { tui.Error("unable to load ziti identity configuration", err) diff --git a/cmd/zrok/testLoopPublic.go b/cmd/zrok/testLoopPublic.go index 3c62c73c9..6e14baa52 100644 --- a/cmd/zrok/testLoopPublic.go +++ b/cmd/zrok/testLoopPublic.go @@ -186,7 +186,7 @@ func (l *looper) startup() { } l.env = env.Environment() - l.zif, err = env.ZitiIdentityNamed(env.ShareIdentityName()) + l.zif, err = env.ZitiIdentityNamed(env.EnvironmentIdentityName()) if err != nil { panic(err) } diff --git a/controller/bootstrap.go b/controller/bootstrap.go index 029cd75f6..ba9dbe40b 100644 --- a/controller/bootstrap.go +++ b/controller/bootstrap.go @@ -43,12 +43,12 @@ func Bootstrap(skipFrontend bool, inCfg *config.Config) error { var frontendZId string if !skipFrontend { - logrus.Info("creating identity for frontend ziti access") + logrus.Info("creating identity for public frontend access") - if frontendZId, err = getIdentityId(env.AccessIdentityName()); err == nil { + if frontendZId, err = getIdentityId(env.PublicIdentityName()); err == nil { logrus.Infof("frontend identity: %v", frontendZId) } else { - frontendZId, err = bootstrapIdentity(env.AccessIdentityName(), edge) + frontendZId, err = bootstrapIdentity(env.PublicIdentityName(), edge) if err != nil { panic(err) } @@ -56,7 +56,7 @@ func Bootstrap(skipFrontend bool, inCfg *config.Config) error { if err := assertIdentity(frontendZId, edge); err != nil { panic(err) } - if err := assertErpForIdentity(env.AccessIdentityName(), frontendZId, edge); err != nil { + if err := assertErpForIdentity(env.PublicIdentityName(), frontendZId, edge); err != nil { panic(err) } diff --git a/endpoints/publicProxy/config.go b/endpoints/publicProxy/config.go index fd6fe6c04..cb939e7e4 100644 --- a/endpoints/publicProxy/config.go +++ b/endpoints/publicProxy/config.go @@ -13,7 +13,7 @@ type Config struct { func DefaultConfig() *Config { return &Config{ - Identity: "frontend", + Identity: "public", Address: "0.0.0.0:8080", } } diff --git a/environment/env_core/model.go b/environment/env_core/model.go index 7e5909dc7..8c8384291 100644 --- a/environment/env_core/model.go +++ b/environment/env_core/model.go @@ -19,8 +19,8 @@ type Root interface { SetEnvironment(env *Environment) error DeleteEnvironment() error - AccessIdentityName() string - ShareIdentityName() string + PublicIdentityName() string + EnvironmentIdentityName() string ZitiIdentityNamed(name string) (string, error) SaveZitiIdentityNamed(name, data string) error diff --git a/environment/env_v0_3/api.go b/environment/env_v0_3/api.go index 424f88363..b7bd285ce 100644 --- a/environment/env_v0_3/api.go +++ b/environment/env_v0_3/api.go @@ -116,11 +116,11 @@ func (r *Root) IsEnabled() bool { return r.env != nil } -func (r *Root) AccessIdentityName() string { +func (r *Root) PublicIdentityName() string { return "frontend" } -func (r *Root) ShareIdentityName() string { +func (r *Root) EnvironmentIdentityName() string { return "backend" } diff --git a/environment/env_v0_4/api.go b/environment/env_v0_4/api.go index fae20e8d0..3e08202b4 100644 --- a/environment/env_v0_4/api.go +++ b/environment/env_v0_4/api.go @@ -116,12 +116,12 @@ func (r *Root) IsEnabled() bool { return r.env != nil } -func (r *Root) AccessIdentityName() string { - return "access" +func (r *Root) PublicIdentityName() string { + return "public" } -func (r *Root) ShareIdentityName() string { - return "share" +func (r *Root) EnvironmentIdentityName() string { + return "environment" } func (r *Root) ZitiIdentityNamed(name string) (string, error) { diff --git a/environment/env_v0_4/root.go b/environment/env_v0_4/root.go index 6e60a458f..2a5343393 100644 --- a/environment/env_v0_4/root.go +++ b/environment/env_v0_4/root.go @@ -77,13 +77,13 @@ func Update(r env_core.Root) (env_core.Root, error) { newR := &Root{meta: r.Metadata(), cfg: r.Config(), env: r.Environment()} - oldAccessF, err := r.ZitiIdentityNamed(r.AccessIdentityName()) + oldAccessF, err := r.ZitiIdentityNamed(r.PublicIdentityName()) if err != nil { return nil, err } _, err = os.Stat(oldAccessF) if err == nil { - newAccessF, err := newR.ZitiIdentityNamed(newR.AccessIdentityName()) + newAccessF, err := newR.ZitiIdentityNamed(newR.PublicIdentityName()) if err != nil { return nil, err } @@ -95,13 +95,13 @@ func Update(r env_core.Root) (env_core.Root, error) { return nil, err } - oldShareF, err := r.ZitiIdentityNamed(r.ShareIdentityName()) + oldShareF, err := r.ZitiIdentityNamed(r.EnvironmentIdentityName()) if err != nil { return nil, err } _, err = os.Stat(oldShareF) if err == nil { - newShareF, err := newR.ZitiIdentityNamed(newR.ShareIdentityName()) + newShareF, err := newR.ZitiIdentityNamed(newR.EnvironmentIdentityName()) if err != nil { return nil, err } From c0503ae59330e2612c48c6713669643b6578c01d Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Mon, 17 Jul 2023 16:21:29 -0400 Subject: [PATCH 16/28] use sdk types/constants throughout the codebase for backend and share modes (#34) --- cmd/zrok/reserve.go | 9 +++++---- cmd/zrok/sharePrivate.go | 5 +++-- cmd/zrok/sharePublic.go | 5 +++-- cmd/zrok/shareReserved.go | 11 ++++++----- cmd/zrok/shareTui.go | 15 ++++++++------- cmd/zrok/testLoopPublic.go | 5 +++-- controller/limits/accountRelaxAction.go | 5 +++-- controller/limits/environmentRelaxAction.go | 5 +++-- controller/limits/shareRelaxAction.go | 5 +++-- controller/share.go | 7 ++++--- 10 files changed, 41 insertions(+), 31 deletions(-) diff --git a/cmd/zrok/reserve.go b/cmd/zrok/reserve.go index 68c4c1236..443916497 100644 --- a/cmd/zrok/reserve.go +++ b/cmd/zrok/reserve.go @@ -6,6 +6,7 @@ import ( "github.com/openziti/zrok/model" "github.com/openziti/zrok/rest_client_zrok/share" "github.com/openziti/zrok/rest_model_zrok" + "github.com/openziti/zrok/sdk" "github.com/openziti/zrok/tui" "github.com/pkg/errors" "github.com/sirupsen/logrus" @@ -39,8 +40,8 @@ func newReserveCommand() *reserveCommand { } func (cmd *reserveCommand) run(_ *cobra.Command, args []string) { - shareMode := args[0] - if shareMode != "public" && shareMode != "private" { + shareMode := sdk.ShareMode(args[0]) + if shareMode != sdk.PublicShareMode && shareMode != sdk.PrivateShareMode { tui.Error("invalid sharing mode; expecting 'public' or 'private'", nil) } @@ -83,13 +84,13 @@ func (cmd *reserveCommand) run(_ *cobra.Command, args []string) { req := share.NewShareParams() req.Body = &rest_model_zrok.ShareRequest{ EnvZID: env.Environment().ZitiIdentity, - ShareMode: shareMode, + ShareMode: string(shareMode), BackendMode: cmd.backendMode, BackendProxyEndpoint: target, AuthScheme: string(model.None), Reserved: true, } - if shareMode == "public" { + if shareMode == sdk.PublicShareMode { req.Body.FrontendSelection = cmd.frontendSelection } if len(cmd.basicAuth) > 0 { diff --git a/cmd/zrok/sharePrivate.go b/cmd/zrok/sharePrivate.go index 967a27727..1397fc401 100644 --- a/cmd/zrok/sharePrivate.go +++ b/cmd/zrok/sharePrivate.go @@ -14,6 +14,7 @@ import ( "github.com/openziti/zrok/rest_client_zrok" "github.com/openziti/zrok/rest_client_zrok/share" "github.com/openziti/zrok/rest_model_zrok" + "github.com/openziti/zrok/sdk" "github.com/openziti/zrok/tui" "github.com/pkg/errors" "github.com/sirupsen/logrus" @@ -110,7 +111,7 @@ func (cmd *sharePrivateCommand) run(_ *cobra.Command, args []string) { req := share.NewShareParams() req.Body = &rest_model_zrok.ShareRequest{ EnvZID: env.Environment().ZitiIdentity, - ShareMode: "private", + ShareMode: string(sdk.PrivateShareMode), BackendMode: cmd.backendMode, BackendProxyEndpoint: target, AuthScheme: string(model.None), @@ -231,7 +232,7 @@ func (cmd *sharePrivateCommand) run(_ *cobra.Command, args []string) { } else { shareDescription := fmt.Sprintf("access your share with: %v", tui.Code.Render(fmt.Sprintf("zrok access private %v", resp.Payload.ShrToken))) - mdl := newShareModel(resp.Payload.ShrToken, []string{shareDescription}, "private", cmd.backendMode) + mdl := newShareModel(resp.Payload.ShrToken, []string{shareDescription}, sdk.PrivateShareMode, sdk.BackendMode(cmd.backendMode)) logrus.SetOutput(mdl) prg := tea.NewProgram(mdl, tea.WithAltScreen()) mdl.prg = prg diff --git a/cmd/zrok/sharePublic.go b/cmd/zrok/sharePublic.go index 0123fc5a8..6a94aeb19 100644 --- a/cmd/zrok/sharePublic.go +++ b/cmd/zrok/sharePublic.go @@ -12,6 +12,7 @@ import ( "github.com/openziti/zrok/rest_client_zrok" "github.com/openziti/zrok/rest_client_zrok/share" "github.com/openziti/zrok/rest_model_zrok" + "github.com/openziti/zrok/sdk" "github.com/openziti/zrok/tui" "github.com/pkg/errors" "github.com/sirupsen/logrus" @@ -104,7 +105,7 @@ func (cmd *sharePublicCommand) run(_ *cobra.Command, args []string) { req := share.NewShareParams() req.Body = &rest_model_zrok.ShareRequest{ EnvZID: env.Environment().ZitiIdentity, - ShareMode: "public", + ShareMode: string(sdk.PublicShareMode), FrontendSelection: cmd.frontendSelection, BackendMode: cmd.backendMode, BackendProxyEndpoint: target, @@ -185,7 +186,7 @@ func (cmd *sharePublicCommand) run(_ *cobra.Command, args []string) { } } else { - mdl := newShareModel(resp.Payload.ShrToken, resp.Payload.FrontendProxyEndpoints, "public", cmd.backendMode) + mdl := newShareModel(resp.Payload.ShrToken, resp.Payload.FrontendProxyEndpoints, sdk.PublicShareMode, sdk.BackendMode(cmd.backendMode)) logrus.SetOutput(mdl) prg := tea.NewProgram(mdl, tea.WithAltScreen()) mdl.prg = prg diff --git a/cmd/zrok/shareReserved.go b/cmd/zrok/shareReserved.go index 345dbc5a5..f5dd54ce7 100644 --- a/cmd/zrok/shareReserved.go +++ b/cmd/zrok/shareReserved.go @@ -10,6 +10,7 @@ import ( "github.com/openziti/zrok/rest_client_zrok/metadata" "github.com/openziti/zrok/rest_client_zrok/share" "github.com/openziti/zrok/rest_model_zrok" + "github.com/openziti/zrok/sdk" "github.com/openziti/zrok/tui" "github.com/pkg/errors" "github.com/sirupsen/logrus" @@ -144,10 +145,10 @@ func (cmd *shareReservedCommand) run(_ *cobra.Command, args []string) { if cmd.headless { switch resp.Payload.ShareMode { - case "public": + case string(sdk.PublicShareMode): logrus.Infof("access your zrok share: %v", resp.Payload.FrontendEndpoint) - case "private": + case string(sdk.PrivateShareMode): logrus.Infof("use this command to access your zrok share: 'zrok access private %v'", shrToken) } for { @@ -159,13 +160,13 @@ func (cmd *shareReservedCommand) run(_ *cobra.Command, args []string) { } else { var shareDescription string switch resp.Payload.ShareMode { - case "public": + case string(sdk.PublicShareMode): shareDescription = resp.Payload.FrontendEndpoint - case "private": + case string(sdk.PrivateShareMode): shareDescription = fmt.Sprintf("access your share with: %v", tui.Code.Render(fmt.Sprintf("zrok access private %v", shrToken))) } - mdl := newShareModel(shrToken, []string{shareDescription}, resp.Payload.ShareMode, resp.Payload.BackendMode) + mdl := newShareModel(shrToken, []string{shareDescription}, sdk.ShareMode(resp.Payload.ShareMode), sdk.BackendMode(resp.Payload.BackendMode)) logrus.SetOutput(mdl) prg := tea.NewProgram(mdl, tea.WithAltScreen()) mdl.prg = prg diff --git a/cmd/zrok/shareTui.go b/cmd/zrok/shareTui.go index 123b88688..1b709fd5a 100644 --- a/cmd/zrok/shareTui.go +++ b/cmd/zrok/shareTui.go @@ -2,6 +2,7 @@ package main import ( "fmt" + "github.com/openziti/zrok/sdk" "strings" "time" @@ -19,8 +20,8 @@ var wordwrapBreakpoints = map[rune]bool{' ': true, '-': true} type shareModel struct { shrToken string frontendDescriptions []string - shareMode string - backendMode string + shareMode sdk.ShareMode + backendMode sdk.BackendMode requests []*endpoints.Request log []string showLog bool @@ -32,7 +33,7 @@ type shareModel struct { type shareLogLine string -func newShareModel(shrToken string, frontendEndpoints []string, shareMode, backendMode string) *shareModel { +func newShareModel(shrToken string, frontendEndpoints []string, shareMode sdk.ShareMode, backendMode sdk.BackendMode) *shareModel { return &shareModel{ shrToken: shrToken, frontendDescriptions: frontendEndpoints, @@ -116,15 +117,15 @@ func (m *shareModel) adjustPaneHeights() { func (m *shareModel) renderConfig() string { out := "[" if m.shareMode == "public" { - out += shareModePublicStyle.Render(strings.ToUpper(m.shareMode)) + out += shareModePublicStyle.Render(strings.ToUpper(string(m.shareMode))) } else { - out += shareModePrivateStyle.Render(strings.ToUpper(m.shareMode)) + out += shareModePrivateStyle.Render(strings.ToUpper(string(m.shareMode))) } out += "] [" if m.backendMode == "proxy" { - out += backendModeProxyStyle.Render(strings.ToUpper(m.backendMode)) + out += backendModeProxyStyle.Render(strings.ToUpper(string(m.backendMode))) } else { - out += backendModeWebStyle.Render(strings.ToUpper(m.backendMode)) + out += backendModeWebStyle.Render(strings.ToUpper(string(m.backendMode))) } out += "]" return out diff --git a/cmd/zrok/testLoopPublic.go b/cmd/zrok/testLoopPublic.go index 6e14baa52..0a92cae9d 100644 --- a/cmd/zrok/testLoopPublic.go +++ b/cmd/zrok/testLoopPublic.go @@ -14,6 +14,7 @@ import ( "github.com/openziti/zrok/rest_client_zrok" "github.com/openziti/zrok/rest_client_zrok/share" "github.com/openziti/zrok/rest_model_zrok" + "github.com/openziti/zrok/sdk" "github.com/openziti/zrok/tui" "github.com/openziti/zrok/util" "github.com/sirupsen/logrus" @@ -198,9 +199,9 @@ func (l *looper) startup() { tunnelReq := share.NewShareParams() tunnelReq.Body = &rest_model_zrok.ShareRequest{ EnvZID: l.env.ZitiIdentity, - ShareMode: "public", + ShareMode: string(sdk.PublicShareMode), FrontendSelection: l.cmd.frontendSelection, - BackendMode: "proxy", + BackendMode: string(sdk.ProxyBackendMode), BackendProxyEndpoint: fmt.Sprintf("looper#%d", l.id), AuthScheme: string(model.None), } diff --git a/controller/limits/accountRelaxAction.go b/controller/limits/accountRelaxAction.go index 82e66476a..7339b04ee 100644 --- a/controller/limits/accountRelaxAction.go +++ b/controller/limits/accountRelaxAction.go @@ -4,6 +4,7 @@ import ( "github.com/jmoiron/sqlx" "github.com/openziti/zrok/controller/store" "github.com/openziti/zrok/controller/zrokEdgeSdk" + "github.com/openziti/zrok/sdk" "github.com/pkg/errors" "github.com/sirupsen/logrus" ) @@ -38,11 +39,11 @@ func (a *accountRelaxAction) HandleAccount(acct *store.Account, _, _ int64, _ *B for _, shr := range shrs { switch shr.ShareMode { - case "public": + case string(sdk.PublicShareMode): if err := relaxPublicShare(a.str, edge, shr, trx); err != nil { return errors.Wrap(err, "error relaxing public share") } - case "private": + case string(sdk.PrivateShareMode): if err := relaxPrivateShare(a.str, edge, shr, trx); err != nil { return errors.Wrap(err, "error relaxing private share") } diff --git a/controller/limits/environmentRelaxAction.go b/controller/limits/environmentRelaxAction.go index 19d8a115e..e4e7b657f 100644 --- a/controller/limits/environmentRelaxAction.go +++ b/controller/limits/environmentRelaxAction.go @@ -4,6 +4,7 @@ import ( "github.com/jmoiron/sqlx" "github.com/openziti/zrok/controller/store" "github.com/openziti/zrok/controller/zrokEdgeSdk" + "github.com/openziti/zrok/sdk" "github.com/pkg/errors" "github.com/sirupsen/logrus" ) @@ -33,11 +34,11 @@ func (a *environmentRelaxAction) HandleEnvironment(env *store.Environment, rxByt for _, shr := range shrs { if !shr.Deleted { switch shr.ShareMode { - case "public": + case string(sdk.PublicShareMode): if err := relaxPublicShare(a.str, edge, shr, trx); err != nil { return err } - case "private": + case string(sdk.PrivateShareMode): if err := relaxPrivateShare(a.str, edge, shr, trx); err != nil { return err } diff --git a/controller/limits/shareRelaxAction.go b/controller/limits/shareRelaxAction.go index 55e0a2c9f..f90dd41c3 100644 --- a/controller/limits/shareRelaxAction.go +++ b/controller/limits/shareRelaxAction.go @@ -5,6 +5,7 @@ import ( "github.com/openziti/edge-api/rest_management_api_client" "github.com/openziti/zrok/controller/store" "github.com/openziti/zrok/controller/zrokEdgeSdk" + "github.com/openziti/zrok/sdk" "github.com/pkg/errors" "github.com/sirupsen/logrus" ) @@ -28,11 +29,11 @@ func (a *shareRelaxAction) HandleShare(shr *store.Share, _, _ int64, _ *Bandwidt } switch shr.ShareMode { - case "public": + case string(sdk.PublicShareMode): if err := relaxPublicShare(a.str, edge, shr, trx); err != nil { return err } - case "private": + case string(sdk.PrivateShareMode): if err := relaxPrivateShare(a.str, edge, shr, trx); err != nil { return err } diff --git a/controller/share.go b/controller/share.go index 0471f59e8..860c106b3 100644 --- a/controller/share.go +++ b/controller/share.go @@ -7,6 +7,7 @@ import ( "github.com/openziti/zrok/controller/zrokEdgeSdk" "github.com/openziti/zrok/rest_model_zrok" "github.com/openziti/zrok/rest_server_zrok/operations/share" + "github.com/openziti/zrok/sdk" "github.com/pkg/errors" "github.com/sirupsen/logrus" ) @@ -68,7 +69,7 @@ func (h *shareHandler) Handle(params share.ShareParams, principal *rest_model_zr var shrZId string var frontendEndpoints []string switch params.Body.ShareMode { - case "public": + case string(sdk.PublicShareMode): if len(params.Body.FrontendSelection) < 1 { logrus.Info("no frontend selection provided") return share.NewShareNotFound() @@ -94,7 +95,7 @@ func (h *shareHandler) Handle(params share.ShareParams, principal *rest_model_zr return share.NewShareInternalServerError() } - case "private": + case string(sdk.PrivateShareMode): logrus.Info("doing private") shrZId, frontendEndpoints, err = newPrivateResourceAllocator().allocate(envZId, shrToken, params, edge) if err != nil { @@ -123,7 +124,7 @@ func (h *shareHandler) Handle(params share.ShareParams, principal *rest_model_zr } if len(frontendEndpoints) > 0 { sshr.FrontendEndpoint = &frontendEndpoints[0] - } else if sshr.ShareMode == "private" { + } else if sshr.ShareMode == string(sdk.PrivateShareMode) { sshr.FrontendEndpoint = &sshr.ShareMode } From c26d325f61a7cc656a592bc57f857914a84f19c6 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Mon, 17 Jul 2023 16:45:20 -0400 Subject: [PATCH 17/28] generalized implementation of public/private share (#34) --- cmd/zrok/reserve.go | 5 +- cmd/zrok/sharePrivate.go | 5 +- cmd/zrok/sharePublic.go | 5 +- cmd/zrok/testLoopPublic.go | 3 +- controller/bootstrap.go | 12 ++-- controller/sharePrivate.go | 6 +- controller/sharePublic.go | 6 +- controller/startup.go | 6 +- controller/zrokEdgeSdk/config.go | 14 ++--- endpoints/proxy/frontend.go | 12 ++-- endpoints/publicProxy/http.go | 12 ++-- endpoints/tcpTunnel/frontend.go | 4 +- endpoints/udpTunnel/frontend.go | 4 +- model/metrics.go | 12 ---- {model => sdk}/config.go | 9 +-- sdk/model.go | 20 +++++++ sdk/share.go | 94 +++++++++++++++++++++++++++++--- 17 files changed, 153 insertions(+), 76 deletions(-) delete mode 100644 model/metrics.go rename {model => sdk}/config.go (85%) diff --git a/cmd/zrok/reserve.go b/cmd/zrok/reserve.go index 443916497..997bac2fb 100644 --- a/cmd/zrok/reserve.go +++ b/cmd/zrok/reserve.go @@ -3,7 +3,6 @@ package main import ( httptransport "github.com/go-openapi/runtime/client" "github.com/openziti/zrok/environment" - "github.com/openziti/zrok/model" "github.com/openziti/zrok/rest_client_zrok/share" "github.com/openziti/zrok/rest_model_zrok" "github.com/openziti/zrok/sdk" @@ -87,7 +86,7 @@ func (cmd *reserveCommand) run(_ *cobra.Command, args []string) { ShareMode: string(shareMode), BackendMode: cmd.backendMode, BackendProxyEndpoint: target, - AuthScheme: string(model.None), + AuthScheme: string(sdk.None), Reserved: true, } if shareMode == sdk.PublicShareMode { @@ -95,7 +94,7 @@ func (cmd *reserveCommand) run(_ *cobra.Command, args []string) { } if len(cmd.basicAuth) > 0 { logrus.Infof("configuring basic auth") - req.Body.AuthScheme = string(model.Basic) + req.Body.AuthScheme = string(sdk.Basic) for _, pair := range cmd.basicAuth { tokens := strings.Split(pair, ":") if len(tokens) == 2 { diff --git a/cmd/zrok/sharePrivate.go b/cmd/zrok/sharePrivate.go index 1397fc401..4b7f908e9 100644 --- a/cmd/zrok/sharePrivate.go +++ b/cmd/zrok/sharePrivate.go @@ -10,7 +10,6 @@ import ( "github.com/openziti/zrok/endpoints/tcpTunnel" "github.com/openziti/zrok/endpoints/udpTunnel" "github.com/openziti/zrok/environment" - "github.com/openziti/zrok/model" "github.com/openziti/zrok/rest_client_zrok" "github.com/openziti/zrok/rest_client_zrok/share" "github.com/openziti/zrok/rest_model_zrok" @@ -114,11 +113,11 @@ func (cmd *sharePrivateCommand) run(_ *cobra.Command, args []string) { ShareMode: string(sdk.PrivateShareMode), BackendMode: cmd.backendMode, BackendProxyEndpoint: target, - AuthScheme: string(model.None), + AuthScheme: string(sdk.None), } if len(cmd.basicAuth) > 0 { logrus.Infof("configuring basic auth") - req.Body.AuthScheme = string(model.Basic) + req.Body.AuthScheme = string(sdk.Basic) for _, pair := range cmd.basicAuth { tokens := strings.Split(pair, ":") if len(tokens) == 2 { diff --git a/cmd/zrok/sharePublic.go b/cmd/zrok/sharePublic.go index 6a94aeb19..8f572143f 100644 --- a/cmd/zrok/sharePublic.go +++ b/cmd/zrok/sharePublic.go @@ -8,7 +8,6 @@ import ( "github.com/openziti/zrok/endpoints" "github.com/openziti/zrok/endpoints/proxy" "github.com/openziti/zrok/environment" - "github.com/openziti/zrok/model" "github.com/openziti/zrok/rest_client_zrok" "github.com/openziti/zrok/rest_client_zrok/share" "github.com/openziti/zrok/rest_model_zrok" @@ -109,11 +108,11 @@ func (cmd *sharePublicCommand) run(_ *cobra.Command, args []string) { FrontendSelection: cmd.frontendSelection, BackendMode: cmd.backendMode, BackendProxyEndpoint: target, - AuthScheme: string(model.None), + AuthScheme: string(sdk.None), } if len(cmd.basicAuth) > 0 { logrus.Infof("configuring basic auth") - req.Body.AuthScheme = string(model.Basic) + req.Body.AuthScheme = string(sdk.Basic) for _, pair := range cmd.basicAuth { tokens := strings.Split(pair, ":") if len(tokens) == 2 { diff --git a/cmd/zrok/testLoopPublic.go b/cmd/zrok/testLoopPublic.go index 0a92cae9d..f6a0d7267 100644 --- a/cmd/zrok/testLoopPublic.go +++ b/cmd/zrok/testLoopPublic.go @@ -10,7 +10,6 @@ import ( "github.com/openziti/sdk-golang/ziti/edge" "github.com/openziti/zrok/environment" "github.com/openziti/zrok/environment/env_core" - "github.com/openziti/zrok/model" "github.com/openziti/zrok/rest_client_zrok" "github.com/openziti/zrok/rest_client_zrok/share" "github.com/openziti/zrok/rest_model_zrok" @@ -203,7 +202,7 @@ func (l *looper) startup() { FrontendSelection: l.cmd.frontendSelection, BackendMode: string(sdk.ProxyBackendMode), BackendProxyEndpoint: fmt.Sprintf("looper#%d", l.id), - AuthScheme: string(model.None), + AuthScheme: string(sdk.None), } tunnelReq.SetTimeout(60 * time.Second) tunnelResp, err := l.zrok.Share.Share(tunnelReq, l.auth) diff --git a/controller/bootstrap.go b/controller/bootstrap.go index ba9dbe40b..041b722b4 100644 --- a/controller/bootstrap.go +++ b/controller/bootstrap.go @@ -15,7 +15,7 @@ import ( "github.com/openziti/zrok/controller/store" "github.com/openziti/zrok/controller/zrokEdgeSdk" "github.com/openziti/zrok/environment" - "github.com/openziti/zrok/model" + "github.com/openziti/zrok/sdk" "github.com/pkg/errors" "github.com/sirupsen/logrus" "time" @@ -85,7 +85,7 @@ func Bootstrap(skipFrontend bool, inCfg *config.Config) error { } func assertZrokProxyConfigType(edge *rest_management_api_client.ZitiEdgeManagement) error { - filter := fmt.Sprintf("name=\"%v\"", model.ZrokProxyConfig) + filter := fmt.Sprintf("name=\"%v\"", sdk.ZrokProxyConfig) limit := int64(100) offset := int64(0) listReq := &restMgmtEdgeConfig.ListConfigTypesParams{ @@ -100,7 +100,7 @@ func assertZrokProxyConfigType(edge *rest_management_api_client.ZitiEdgeManageme return err } if len(listResp.Payload.Data) < 1 { - name := model.ZrokProxyConfig + name := sdk.ZrokProxyConfig ct := &restModelEdge.ConfigTypeCreate{Name: &name} createReq := &restMgmtEdgeConfig.CreateConfigTypeParams{ConfigType: ct} createReq.SetTimeout(30 * time.Second) @@ -108,11 +108,11 @@ func assertZrokProxyConfigType(edge *rest_management_api_client.ZitiEdgeManageme if err != nil { return err } - logrus.Infof("created '%v' config type with id '%v'", model.ZrokProxyConfig, createResp.Payload.Data.ID) + logrus.Infof("created '%v' config type with id '%v'", sdk.ZrokProxyConfig, createResp.Payload.Data.ID) } else if len(listResp.Payload.Data) > 1 { - return errors.Errorf("found %d '%v' config types; expected 0 or 1", len(listResp.Payload.Data), model.ZrokProxyConfig) + return errors.Errorf("found %d '%v' config types; expected 0 or 1", len(listResp.Payload.Data), sdk.ZrokProxyConfig) } else { - logrus.Infof("found '%v' config type with id '%v'", model.ZrokProxyConfig, *(listResp.Payload.Data[0].ID)) + logrus.Infof("found '%v' config type with id '%v'", sdk.ZrokProxyConfig, *(listResp.Payload.Data[0].ID)) } return nil } diff --git a/controller/sharePrivate.go b/controller/sharePrivate.go index 52853515e..96830cdb5 100644 --- a/controller/sharePrivate.go +++ b/controller/sharePrivate.go @@ -3,8 +3,8 @@ package controller import ( "github.com/openziti/edge-api/rest_management_api_client" "github.com/openziti/zrok/controller/zrokEdgeSdk" - "github.com/openziti/zrok/model" "github.com/openziti/zrok/rest_server_zrok/operations/share" + "github.com/openziti/zrok/sdk" ) type privateResourceAllocator struct{} @@ -14,9 +14,9 @@ func newPrivateResourceAllocator() *privateResourceAllocator { } func (a *privateResourceAllocator) allocate(envZId, shrToken string, params share.ShareParams, edge *rest_management_api_client.ZitiEdgeManagement) (shrZId string, frontendEndpoints []string, err error) { - var authUsers []*model.AuthUser + var authUsers []*sdk.AuthUser for _, authUser := range params.Body.AuthUsers { - authUsers = append(authUsers, &model.AuthUser{authUser.Username, authUser.Password}) + authUsers = append(authUsers, &sdk.AuthUser{authUser.Username, authUser.Password}) } cfgZId, err := zrokEdgeSdk.CreateConfig(zrokProxyConfigId, envZId, shrToken, params.Body.AuthScheme, authUsers, edge) if err != nil { diff --git a/controller/sharePublic.go b/controller/sharePublic.go index cb63ace60..b7522b4c5 100644 --- a/controller/sharePublic.go +++ b/controller/sharePublic.go @@ -3,8 +3,8 @@ package controller import ( "github.com/openziti/edge-api/rest_management_api_client" "github.com/openziti/zrok/controller/zrokEdgeSdk" - "github.com/openziti/zrok/model" "github.com/openziti/zrok/rest_server_zrok/operations/share" + "github.com/openziti/zrok/sdk" ) type publicResourceAllocator struct{} @@ -14,9 +14,9 @@ func newPublicResourceAllocator() *publicResourceAllocator { } func (a *publicResourceAllocator) allocate(envZId, shrToken string, frontendZIds, frontendTemplates []string, params share.ShareParams, edge *rest_management_api_client.ZitiEdgeManagement) (shrZId string, frontendEndpoints []string, err error) { - var authUsers []*model.AuthUser + var authUsers []*sdk.AuthUser for _, authUser := range params.Body.AuthUsers { - authUsers = append(authUsers, &model.AuthUser{authUser.Username, authUser.Password}) + authUsers = append(authUsers, &sdk.AuthUser{authUser.Username, authUser.Password}) } cfgId, err := zrokEdgeSdk.CreateConfig(zrokProxyConfigId, envZId, shrToken, params.Body.AuthScheme, authUsers, edge) if err != nil { diff --git a/controller/startup.go b/controller/startup.go index 19ce1cebc..cdbd27599 100644 --- a/controller/startup.go +++ b/controller/startup.go @@ -6,7 +6,7 @@ import ( "github.com/openziti/edge-api/rest_management_api_client" "github.com/openziti/edge-api/rest_management_api_client/config" "github.com/openziti/zrok/controller/zrokEdgeSdk" - "github.com/openziti/zrok/model" + "github.com/openziti/zrok/sdk" "github.com/pkg/errors" "github.com/sirupsen/logrus" "time" @@ -36,7 +36,7 @@ func inspectZiti() error { } func findZrokProxyConfigType(edge *rest_management_api_client.ZitiEdgeManagement) error { - filter := fmt.Sprintf("name=\"%v\"", model.ZrokProxyConfig) + filter := fmt.Sprintf("name=\"%v\"", sdk.ZrokProxyConfig) limit := int64(100) offset := int64(0) listReq := &config.ListConfigTypesParams{ @@ -53,7 +53,7 @@ func findZrokProxyConfigType(edge *rest_management_api_client.ZitiEdgeManagement if len(listResp.Payload.Data) != 1 { return errors.Errorf("expected 1 zrok proxy config type, found %d", len(listResp.Payload.Data)) } - logrus.Infof("found '%v' config type with id '%v'", model.ZrokProxyConfig, *(listResp.Payload.Data[0].ID)) + logrus.Infof("found '%v' config type with id '%v'", sdk.ZrokProxyConfig, *(listResp.Payload.Data[0].ID)) zrokProxyConfigId = *(listResp.Payload.Data[0].ID) return nil diff --git a/controller/zrokEdgeSdk/config.go b/controller/zrokEdgeSdk/config.go index 46a67ba7b..b0b57509c 100644 --- a/controller/zrokEdgeSdk/config.go +++ b/controller/zrokEdgeSdk/config.go @@ -6,23 +6,23 @@ import ( "github.com/openziti/edge-api/rest_management_api_client" "github.com/openziti/edge-api/rest_management_api_client/config" "github.com/openziti/edge-api/rest_model" - "github.com/openziti/zrok/model" + "github.com/openziti/zrok/sdk" "github.com/sirupsen/logrus" "time" ) -func CreateConfig(cfgTypeZId, envZId, shrToken string, authSchemeStr string, authUsers []*model.AuthUser, edge *rest_management_api_client.ZitiEdgeManagement) (cfgZId string, err error) { - authScheme, err := model.ParseAuthScheme(authSchemeStr) +func CreateConfig(cfgTypeZId, envZId, shrToken string, authSchemeStr string, authUsers []*sdk.AuthUser, edge *rest_management_api_client.ZitiEdgeManagement) (cfgZId string, err error) { + authScheme, err := sdk.ParseAuthScheme(authSchemeStr) if err != nil { return "", err } - cfg := &model.ProxyConfig{ + cfg := &sdk.ProxyConfig{ AuthScheme: authScheme, } - if cfg.AuthScheme == model.Basic { - cfg.BasicAuth = &model.BasicAuth{} + if cfg.AuthScheme == sdk.Basic { + cfg.BasicAuth = &sdk.BasicAuth{} for _, authUser := range authUsers { - cfg.BasicAuth.Users = append(cfg.BasicAuth.Users, &model.AuthUser{Username: authUser.Username, Password: authUser.Password}) + cfg.BasicAuth.Users = append(cfg.BasicAuth.Users, &sdk.AuthUser{Username: authUser.Username, Password: authUser.Password}) } } cfgCrt := &rest_model.ConfigCreate{ diff --git a/endpoints/proxy/frontend.go b/endpoints/proxy/frontend.go index 4cc325c4a..c82c677c3 100644 --- a/endpoints/proxy/frontend.go +++ b/endpoints/proxy/frontend.go @@ -7,7 +7,7 @@ import ( "github.com/openziti/zrok/endpoints" "github.com/openziti/zrok/endpoints/publicProxy/notFoundUi" "github.com/openziti/zrok/environment" - "github.com/openziti/zrok/model" + "github.com/openziti/zrok/sdk" "github.com/openziti/zrok/util" "github.com/pkg/errors" "github.com/sirupsen/logrus" @@ -52,7 +52,7 @@ func NewFrontend(cfg *FrontendConfig) (*Frontend, error) { if err != nil { return nil, errors.Wrap(err, "error loading config") } - zCfg.ConfigTypes = []string{model.ZrokProxyConfig} + zCfg.ConfigTypes = []string{sdk.ZrokProxyConfig} zCtx, err := ziti.NewContext(zCfg) if err != nil { return nil, errors.Wrap(err, "error loading ziti context") @@ -121,7 +121,7 @@ func serviceTargetProxy(cfg *FrontendConfig, ctx ziti.Context) *httputil.Reverse director := func(req *http.Request) { targetShrToken := cfg.ShrToken if svc, found := endpoints.GetRefreshedService(targetShrToken, ctx); found { - if cfg, found := svc.Config[model.ZrokProxyConfig]; found { + if cfg, found := svc.Config[sdk.ZrokProxyConfig]; found { logrus.Debugf("auth model: %v", cfg) } else { logrus.Warn("no config!") @@ -153,15 +153,15 @@ func serviceTargetProxy(cfg *FrontendConfig, ctx ziti.Context) *httputil.Reverse func authHandler(shrToken string, handler http.Handler, realm string, cfg *FrontendConfig, ctx ziti.Context) http.HandlerFunc { return func(w http.ResponseWriter, r *http.Request) { if svc, found := endpoints.GetRefreshedService(shrToken, ctx); found { - if cfg, found := svc.Config[model.ZrokProxyConfig]; found { + if cfg, found := svc.Config[sdk.ZrokProxyConfig]; found { if scheme, found := cfg["auth_scheme"]; found { switch scheme { - case string(model.None): + case string(sdk.None): logrus.Debugf("auth scheme none '%v'", shrToken) handler.ServeHTTP(w, r) return - case string(model.Basic): + case string(sdk.Basic): logrus.Debugf("auth scheme basic '%v", shrToken) inUser, inPass, ok := r.BasicAuth() if !ok { diff --git a/endpoints/publicProxy/http.go b/endpoints/publicProxy/http.go index 70e74deb0..4403c4b1f 100644 --- a/endpoints/publicProxy/http.go +++ b/endpoints/publicProxy/http.go @@ -8,7 +8,7 @@ import ( "github.com/openziti/zrok/endpoints/publicProxy/healthUi" "github.com/openziti/zrok/endpoints/publicProxy/notFoundUi" "github.com/openziti/zrok/environment" - "github.com/openziti/zrok/model" + "github.com/openziti/zrok/sdk" "github.com/openziti/zrok/util" "github.com/pkg/errors" "github.com/sirupsen/logrus" @@ -38,7 +38,7 @@ func NewHTTP(cfg *Config) (*httpFrontend, error) { if err != nil { return nil, errors.Wrap(err, "error loading config") } - zCfg.ConfigTypes = []string{model.ZrokProxyConfig} + zCfg.ConfigTypes = []string{sdk.ZrokProxyConfig} zCtx, err := ziti.NewContext(zCfg) if err != nil { return nil, errors.Wrap(err, "error loading ziti context") @@ -99,7 +99,7 @@ func hostTargetReverseProxy(cfg *Config, ctx ziti.Context) *httputil.ReverseProx director := func(req *http.Request) { targetShrToken := resolveService(cfg.HostMatch, req.Host) if svc, found := endpoints.GetRefreshedService(targetShrToken, ctx); found { - if cfg, found := svc.Config[model.ZrokProxyConfig]; found { + if cfg, found := svc.Config[sdk.ZrokProxyConfig]; found { logrus.Debugf("auth model: %v", cfg) } else { logrus.Warn("no config!") @@ -133,15 +133,15 @@ func authHandler(handler http.Handler, realm string, cfg *Config, ctx ziti.Conte shrToken := resolveService(cfg.HostMatch, r.Host) if shrToken != "" { if svc, found := endpoints.GetRefreshedService(shrToken, ctx); found { - if cfg, found := svc.Config[model.ZrokProxyConfig]; found { + if cfg, found := svc.Config[sdk.ZrokProxyConfig]; found { if scheme, found := cfg["auth_scheme"]; found { switch scheme { - case string(model.None): + case string(sdk.None): logrus.Debugf("auth scheme none '%v'", shrToken) handler.ServeHTTP(w, r) return - case string(model.Basic): + case string(sdk.Basic): logrus.Debugf("auth scheme basic '%v", shrToken) inUser, inPass, ok := r.BasicAuth() if !ok { diff --git a/endpoints/tcpTunnel/frontend.go b/endpoints/tcpTunnel/frontend.go index 031fa2ace..375c6f2d2 100644 --- a/endpoints/tcpTunnel/frontend.go +++ b/endpoints/tcpTunnel/frontend.go @@ -4,7 +4,7 @@ import ( "github.com/openziti/sdk-golang/ziti" "github.com/openziti/zrok/endpoints" "github.com/openziti/zrok/environment" - "github.com/openziti/zrok/model" + "github.com/openziti/zrok/sdk" "github.com/pkg/errors" "github.com/sirupsen/logrus" "net" @@ -41,7 +41,7 @@ func NewFrontend(cfg *FrontendConfig) (*Frontend, error) { if err != nil { return nil, errors.Wrap(err, "error loading config") } - zCfg.ConfigTypes = []string{model.ZrokProxyConfig} + zCfg.ConfigTypes = []string{sdk.ZrokProxyConfig} zCtx, err := ziti.NewContext(zCfg) if err != nil { return nil, errors.Wrap(err, "error loading ziti context") diff --git a/endpoints/udpTunnel/frontend.go b/endpoints/udpTunnel/frontend.go index f14036379..3e837bb89 100644 --- a/endpoints/udpTunnel/frontend.go +++ b/endpoints/udpTunnel/frontend.go @@ -4,7 +4,7 @@ import ( "github.com/openziti/sdk-golang/ziti" "github.com/openziti/zrok/endpoints" "github.com/openziti/zrok/environment" - "github.com/openziti/zrok/model" + "github.com/openziti/zrok/sdk" "github.com/pkg/errors" "github.com/sirupsen/logrus" "net" @@ -111,7 +111,7 @@ func NewFrontend(cfg *FrontendConfig) (*Frontend, error) { if err != nil { return nil, errors.Wrap(err, "error loading config") } - zCfg.ConfigTypes = []string{model.ZrokProxyConfig} + zCfg.ConfigTypes = []string{sdk.ZrokProxyConfig} zCtx, err := ziti.NewContext(zCfg) if err != nil { return nil, errors.Wrap(err, "error loading ziti context") diff --git a/model/metrics.go b/model/metrics.go deleted file mode 100644 index 33f9ca210..000000000 --- a/model/metrics.go +++ /dev/null @@ -1,12 +0,0 @@ -package model - -type Metrics struct { - Namespace string - Sessions map[string]SessionMetrics -} - -type SessionMetrics struct { - BytesRead int64 - BytesWritten int64 - LastUpdate int64 -} diff --git a/model/config.go b/sdk/config.go similarity index 85% rename from model/config.go rename to sdk/config.go index b6c03e4e4..e9d4c318c 100644 --- a/model/config.go +++ b/sdk/config.go @@ -1,16 +1,9 @@ -package model +package sdk import "github.com/pkg/errors" const ZrokProxyConfig = "zrok.proxy.v1" -type AuthScheme string - -const ( - None AuthScheme = "none" - Basic AuthScheme = "basic" -) - type ProxyConfig struct { AuthScheme AuthScheme `json:"auth_scheme"` BasicAuth *BasicAuth `json:"basic_auth"` diff --git a/sdk/model.go b/sdk/model.go index 68779641c..f86ead355 100644 --- a/sdk/model.go +++ b/sdk/model.go @@ -19,5 +19,25 @@ const ( type ShareRequest struct { BackendMode BackendMode ShareMode ShareMode + Frontends []string + Auth []string Target string } + +type Metrics struct { + Namespace string + Sessions map[string]SessionMetrics +} + +type SessionMetrics struct { + BytesRead int64 + BytesWritten int64 + LastUpdate int64 +} + +type AuthScheme string + +const ( + None AuthScheme = "none" + Basic AuthScheme = "basic" +) diff --git a/sdk/share.go b/sdk/share.go index 5e4bb07f4..ddebc50fc 100644 --- a/sdk/share.go +++ b/sdk/share.go @@ -1,28 +1,108 @@ package sdk import ( + httptransport "github.com/go-openapi/runtime/client" + "github.com/openziti/zrok/environment/env_core" + "github.com/openziti/zrok/rest_client_zrok/share" + "github.com/openziti/zrok/rest_model_zrok" "github.com/pkg/errors" + "strings" ) type Share struct { Token string } -func NewShare(request *ShareRequest) (*Share, error) { +func CreateShare(root env_core.Root, request *ShareRequest) (*Share, error) { switch request.ShareMode { case PrivateShareMode: - return newPrivateShare(request) + return newPrivateShare(root, request) case PublicShareMode: - return newPublicShare(request) + return newPublicShare(root, request) default: return nil, errors.Errorf("unknown share mode '%v'", request.ShareMode) } } -func newPrivateShare(request *ShareRequest) (*Share, error) { - return nil, nil +func newPrivateShare(root env_core.Root, request *ShareRequest) (*Share, error) { + req := share.NewShareParams() + req.Body = &rest_model_zrok.ShareRequest{ + EnvZID: root.Environment().ZitiIdentity, + ShareMode: string(request.ShareMode), + BackendMode: string(request.BackendMode), + BackendProxyEndpoint: request.Target, + AuthScheme: string(None), + } + if len(request.Auth) > 0 { + req.Body.AuthScheme = string(Basic) + for _, pair := range request.Auth { + tokens := strings.Split(pair, ":") + if len(tokens) == 2 { + req.Body.AuthUsers = append(req.Body.AuthUsers, &rest_model_zrok.AuthUser{Username: strings.TrimSpace(tokens[0]), Password: strings.TrimSpace(tokens[1])}) + } else { + return nil, errors.Errorf("invalid username:password pair '%v'", pair) + } + } + } + zrok, err := root.Client() + if err != nil { + return nil, errors.Wrap(err, "error getting zrok client") + } + auth := httptransport.APIKeyAuth("X-TOKEN", "header", root.Environment().Token) + resp, err := zrok.Share.Share(req, auth) + if err != nil { + return nil, errors.Wrap(err, "unable to create share") + } + return &Share{Token: resp.Payload.ShrToken}, nil } -func newPublicShare(request *ShareRequest) (*Share, error) { - return nil, nil +func newPublicShare(root env_core.Root, request *ShareRequest) (*Share, error) { + req := share.NewShareParams() + req.Body = &rest_model_zrok.ShareRequest{ + EnvZID: root.Environment().ZitiIdentity, + ShareMode: string(request.ShareMode), + FrontendSelection: request.Frontends, + BackendMode: string(request.BackendMode), + BackendProxyEndpoint: request.Target, + AuthScheme: string(None), + } + if len(request.Auth) > 0 { + req.Body.AuthScheme = string(Basic) + for _, pair := range request.Auth { + tokens := strings.Split(pair, ":") + if len(tokens) == 2 { + req.Body.AuthUsers = append(req.Body.AuthUsers, &rest_model_zrok.AuthUser{Username: strings.TrimSpace(tokens[0]), Password: strings.TrimSpace(tokens[1])}) + } else { + return nil, errors.Errorf("invalid username:password pair '%v'", pair) + } + } + } + zrok, err := root.Client() + if err != nil { + return nil, errors.Wrap(err, "error getting zrok client") + } + auth := httptransport.APIKeyAuth("X-TOKEN", "header", root.Environment().Token) + resp, err := zrok.Share.Share(req, auth) + if err != nil { + return nil, errors.Wrap(err, "unable to create share") + } + return &Share{Token: resp.Payload.ShrToken}, nil +} + +func DeleteShare(root env_core.Root, shrToken string) error { + req := share.NewUnshareParams() + req.Body = &rest_model_zrok.UnshareRequest{ + EnvZID: root.Environment().ZitiIdentity, + ShrToken: shrToken, + } + zrok, err := root.Client() + if err != nil { + return errors.Wrap(err, "error getting zrok client") + } + auth := httptransport.APIKeyAuth("X-TOKEN", "header", root.Environment().Token) + _, err = zrok.Share.Unshare(req, auth) + if err != nil { + return errors.Wrap(err, "error deleting share") + } + return nil } From 7dc14445ad7bc118496bbd21076527bf74d80a4e Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Mon, 17 Jul 2023 16:51:28 -0400 Subject: [PATCH 18/28] slightly improved version of the generalized share implementation (#34) --- sdk/share.go | 66 ++++++++++++++++++++++------------------------------ 1 file changed, 28 insertions(+), 38 deletions(-) diff --git a/sdk/share.go b/sdk/share.go index ddebc50fc..0ebeb9bb6 100644 --- a/sdk/share.go +++ b/sdk/share.go @@ -14,79 +14,67 @@ type Share struct { } func CreateShare(root env_core.Root, request *ShareRequest) (*Share, error) { + var err error + var out *share.ShareParams + switch request.ShareMode { case PrivateShareMode: - return newPrivateShare(root, request) + out = newPrivateShare(root, request) case PublicShareMode: - return newPublicShare(root, request) + out = newPublicShare(root, request) default: return nil, errors.Errorf("unknown share mode '%v'", request.ShareMode) } -} -func newPrivateShare(root env_core.Root, request *ShareRequest) (*Share, error) { - req := share.NewShareParams() - req.Body = &rest_model_zrok.ShareRequest{ - EnvZID: root.Environment().ZitiIdentity, - ShareMode: string(request.ShareMode), - BackendMode: string(request.BackendMode), - BackendProxyEndpoint: request.Target, - AuthScheme: string(None), - } if len(request.Auth) > 0 { - req.Body.AuthScheme = string(Basic) + out.Body.AuthScheme = string(Basic) for _, pair := range request.Auth { tokens := strings.Split(pair, ":") if len(tokens) == 2 { - req.Body.AuthUsers = append(req.Body.AuthUsers, &rest_model_zrok.AuthUser{Username: strings.TrimSpace(tokens[0]), Password: strings.TrimSpace(tokens[1])}) + out.Body.AuthUsers = append(out.Body.AuthUsers, &rest_model_zrok.AuthUser{Username: strings.TrimSpace(tokens[0]), Password: strings.TrimSpace(tokens[1])}) } else { return nil, errors.Errorf("invalid username:password pair '%v'", pair) } } } + zrok, err := root.Client() if err != nil { return nil, errors.Wrap(err, "error getting zrok client") } auth := httptransport.APIKeyAuth("X-TOKEN", "header", root.Environment().Token) - resp, err := zrok.Share.Share(req, auth) + + in, err := zrok.Share.Share(out, auth) if err != nil { return nil, errors.Wrap(err, "unable to create share") } - return &Share{Token: resp.Payload.ShrToken}, nil + + return &Share{Token: in.Payload.ShrToken}, nil } -func newPublicShare(root env_core.Root, request *ShareRequest) (*Share, error) { +func newPrivateShare(root env_core.Root, request *ShareRequest) *share.ShareParams { req := share.NewShareParams() req.Body = &rest_model_zrok.ShareRequest{ EnvZID: root.Environment().ZitiIdentity, ShareMode: string(request.ShareMode), - FrontendSelection: request.Frontends, BackendMode: string(request.BackendMode), BackendProxyEndpoint: request.Target, AuthScheme: string(None), } - if len(request.Auth) > 0 { - req.Body.AuthScheme = string(Basic) - for _, pair := range request.Auth { - tokens := strings.Split(pair, ":") - if len(tokens) == 2 { - req.Body.AuthUsers = append(req.Body.AuthUsers, &rest_model_zrok.AuthUser{Username: strings.TrimSpace(tokens[0]), Password: strings.TrimSpace(tokens[1])}) - } else { - return nil, errors.Errorf("invalid username:password pair '%v'", pair) - } - } - } - zrok, err := root.Client() - if err != nil { - return nil, errors.Wrap(err, "error getting zrok client") - } - auth := httptransport.APIKeyAuth("X-TOKEN", "header", root.Environment().Token) - resp, err := zrok.Share.Share(req, auth) - if err != nil { - return nil, errors.Wrap(err, "unable to create share") + return req +} + +func newPublicShare(root env_core.Root, request *ShareRequest) *share.ShareParams { + req := share.NewShareParams() + req.Body = &rest_model_zrok.ShareRequest{ + EnvZID: root.Environment().ZitiIdentity, + ShareMode: string(request.ShareMode), + FrontendSelection: request.Frontends, + BackendMode: string(request.BackendMode), + BackendProxyEndpoint: request.Target, + AuthScheme: string(None), } - return &Share{Token: resp.Payload.ShrToken}, nil + return req } func DeleteShare(root env_core.Root, shrToken string) error { @@ -95,11 +83,13 @@ func DeleteShare(root env_core.Root, shrToken string) error { EnvZID: root.Environment().ZitiIdentity, ShrToken: shrToken, } + zrok, err := root.Client() if err != nil { return errors.Wrap(err, "error getting zrok client") } auth := httptransport.APIKeyAuth("X-TOKEN", "header", root.Environment().Token) + _, err = zrok.Share.Unshare(req, auth) if err != nil { return errors.Wrap(err, "error deleting share") From 7a3533209a51004114c5836682746556e7a45434 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Tue, 18 Jul 2023 15:30:46 -0400 Subject: [PATCH 19/28] access capabilities; minor alignment and refactoring (#34) --- sdk/access.go | 52 +++++++++++++++++++++++++++++++++++++++++++++++++++ sdk/model.go | 14 ++++++++++++++ sdk/share.go | 9 +++------ 3 files changed, 69 insertions(+), 6 deletions(-) create mode 100644 sdk/access.go diff --git a/sdk/access.go b/sdk/access.go new file mode 100644 index 000000000..15e42d4d5 --- /dev/null +++ b/sdk/access.go @@ -0,0 +1,52 @@ +package sdk + +import ( + httptransport "github.com/go-openapi/runtime/client" + "github.com/openziti/zrok/environment/env_core" + "github.com/openziti/zrok/rest_client_zrok/share" + "github.com/openziti/zrok/rest_model_zrok" + "github.com/pkg/errors" +) + +func CreateAccess(root env_core.Root, request *AccessRequest) (*Access, error) { + out := share.NewAccessParams() + out.Body = &rest_model_zrok.AccessRequest{ + ShrToken: request.ShareToken, + EnvZID: root.Environment().Token, + } + + zrok, err := root.Client() + if err != nil { + return nil, errors.Wrap(err, "error getting zrok client") + } + auth := httptransport.APIKeyAuth("X-TOKEN", "header", root.Environment().Token) + + in, err := zrok.Share.Access(out, auth) + if err != nil { + return nil, errors.Wrap(err, "unable to create access") + } + + return &Access{Token: in.Payload.FrontendToken, ShareToken: request.ShareToken, BackendMode: BackendMode(in.Payload.BackendMode)}, nil +} + +func DeleteAccess(root env_core.Root, acc *Access) error { + out := share.NewUnaccessParams() + out.Body = &rest_model_zrok.UnaccessRequest{ + FrontendToken: acc.Token, + ShrToken: acc.ShareToken, + EnvZID: root.Environment().ZitiIdentity, + } + + zrok, err := root.Client() + if err != nil { + return errors.Wrap(err, "error getting zrok client") + } + auth := httptransport.APIKeyAuth("X-TOKEN", "header", root.Environment().Token) + + _, err = zrok.Share.Unaccess(out, auth) + if err != nil { + return errors.Wrap(err, "error deleting access") + } + + return nil +} diff --git a/sdk/model.go b/sdk/model.go index f86ead355..1cf9a2486 100644 --- a/sdk/model.go +++ b/sdk/model.go @@ -24,6 +24,20 @@ type ShareRequest struct { Target string } +type Share struct { + Token string +} + +type AccessRequest struct { + ShareToken string +} + +type Access struct { + Token string + ShareToken string + BackendMode BackendMode +} + type Metrics struct { Namespace string Sessions map[string]SessionMetrics diff --git a/sdk/share.go b/sdk/share.go index 0ebeb9bb6..c2d0cbbba 100644 --- a/sdk/share.go +++ b/sdk/share.go @@ -9,10 +9,6 @@ import ( "strings" ) -type Share struct { - Token string -} - func CreateShare(root env_core.Root, request *ShareRequest) (*Share, error) { var err error var out *share.ShareParams @@ -77,11 +73,11 @@ func newPublicShare(root env_core.Root, request *ShareRequest) *share.ShareParam return req } -func DeleteShare(root env_core.Root, shrToken string) error { +func DeleteShare(root env_core.Root, shr *Share) error { req := share.NewUnshareParams() req.Body = &rest_model_zrok.UnshareRequest{ EnvZID: root.Environment().ZitiIdentity, - ShrToken: shrToken, + ShrToken: shr.Token, } zrok, err := root.Client() @@ -94,5 +90,6 @@ func DeleteShare(root env_core.Root, shrToken string) error { if err != nil { return errors.Wrap(err, "error deleting share") } + return nil } From 369d703050d1b2856599edf4c482113f4df78b3c Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Wed, 19 Jul 2023 11:51:00 -0400 Subject: [PATCH 20/28] 'zrok overview' updated for sdk changes (#374) --- cmd/zrok/overview.go | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/cmd/zrok/overview.go b/cmd/zrok/overview.go index 3303e8c3c..329e4a29a 100644 --- a/cmd/zrok/overview.go +++ b/cmd/zrok/overview.go @@ -2,8 +2,8 @@ package main import ( "fmt" + "github.com/openziti/zrok/environment" "github.com/openziti/zrok/tui" - "github.com/openziti/zrok/zrokdir" "github.com/spf13/cobra" "io" "net/http" @@ -29,7 +29,7 @@ func newOverviewCommand() *overviewCommand { } func (cmd *overviewCommand) run(_ *cobra.Command, _ []string) { - zrd, err := zrokdir.Load() + root, err := environment.LoadRoot() if err != nil { if !panicInstead { tui.Error("error loading zrokdir", err) @@ -37,12 +37,12 @@ func (cmd *overviewCommand) run(_ *cobra.Command, _ []string) { panic(err) } - if zrd.Env == nil { + if !root.IsEnabled() { tui.Error("unable to load environment; did you 'zrok enable'?", nil) } client := &http.Client{} - apiEndpoint, _ := zrd.ApiEndpoint() + apiEndpoint, _ := root.ApiEndpoint() req, err := http.NewRequest("GET", fmt.Sprintf("%v/api/v1/overview", apiEndpoint), nil) if err != nil { if !panicInstead { @@ -50,7 +50,7 @@ func (cmd *overviewCommand) run(_ *cobra.Command, _ []string) { } panic(err) } - req.Header.Add("X-TOKEN", zrd.Env.Token) + req.Header.Add("X-TOKEN", root.Environment().Token) resp, err := client.Do(req) if err != nil { if !panicInstead { From 86b1e3cde75d441907753f774766ecc7e92259a8 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Wed, 26 Jul 2023 16:19:16 -0400 Subject: [PATCH 21/28] sdk.CreateAccess fix; sdk.NewListener; sdk.NewDialer (#34, #379) --- sdk/access.go | 2 +- sdk/dialer.go | 32 ++++++++++++++++++++++++++++++++ sdk/listener.go | 37 +++++++++++++++++++++++++++++++++++++ 3 files changed, 70 insertions(+), 1 deletion(-) create mode 100644 sdk/dialer.go create mode 100644 sdk/listener.go diff --git a/sdk/access.go b/sdk/access.go index 15e42d4d5..c759c13b7 100644 --- a/sdk/access.go +++ b/sdk/access.go @@ -12,7 +12,7 @@ func CreateAccess(root env_core.Root, request *AccessRequest) (*Access, error) { out := share.NewAccessParams() out.Body = &rest_model_zrok.AccessRequest{ ShrToken: request.ShareToken, - EnvZID: root.Environment().Token, + EnvZID: root.Environment().ZitiIdentity, } zrok, err := root.Client() diff --git a/sdk/dialer.go b/sdk/dialer.go new file mode 100644 index 000000000..2283ea6c1 --- /dev/null +++ b/sdk/dialer.go @@ -0,0 +1,32 @@ +package sdk + +import ( + "github.com/openziti/sdk-golang/ziti" + "github.com/openziti/sdk-golang/ziti/edge" + "github.com/openziti/zrok/environment/env_core" + "github.com/pkg/errors" +) + +func NewDialer(shrToken string, root env_core.Root) (edge.Conn, error) { + zif, err := root.ZitiIdentityNamed(root.EnvironmentIdentityName()) + if err != nil { + return nil, errors.Wrap(err, "error getting ziti identity path") + } + + zcfg, err := ziti.NewConfigFromFile(zif) + 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 getting ziti context") + } + + conn, err := zctx.Dial(shrToken) + if err != nil { + return nil, errors.Wrapf(err, "error dialing '%v'", shrToken) + } + + return conn, nil +} diff --git a/sdk/listener.go b/sdk/listener.go new file mode 100644 index 000000000..4aece922f --- /dev/null +++ b/sdk/listener.go @@ -0,0 +1,37 @@ +package sdk + +import ( + "github.com/openziti/sdk-golang/ziti" + "github.com/openziti/sdk-golang/ziti/edge" + "github.com/openziti/zrok/environment/env_core" + "github.com/pkg/errors" + "time" +) + +func NewListener(shrToken string, root env_core.Root) (edge.Listener, error) { + return NewListenerWithOptions(shrToken, root, &ziti.ListenOptions{ConnectTimeout: 30 * time.Second, MaxConnections: 64}) +} + +func NewListenerWithOptions(shrToken string, root env_core.Root, opts *ziti.ListenOptions) (edge.Listener, error) { + zif, err := root.ZitiIdentityNamed(root.EnvironmentIdentityName()) + if err != nil { + return nil, errors.Wrap(err, "error getting ziti identity path") + } + + zcfg, err := ziti.NewConfigFromFile(zif) + 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 getting ziti context") + } + + listener, err := zctx.ListenWithOptions(shrToken, opts) + if err != nil { + return nil, errors.Wrap(err, "error creating listener") + } + + return listener, nil +} From 1130ff800634f6ef9ca97a45292e4684ca88a0c6 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Wed, 26 Jul 2023 16:25:52 -0400 Subject: [PATCH 22/28] these need to always be enabled anyway... (#34) --- sdk/access.go | 4 ++++ sdk/share.go | 4 ++++ 2 files changed, 8 insertions(+) diff --git a/sdk/access.go b/sdk/access.go index c759c13b7..46c5af4ed 100644 --- a/sdk/access.go +++ b/sdk/access.go @@ -9,6 +9,10 @@ import ( ) func CreateAccess(root env_core.Root, request *AccessRequest) (*Access, error) { + if !root.IsEnabled() { + return nil, errors.New("environment is not enabled; enable with 'zrok enable' first!") + } + out := share.NewAccessParams() out.Body = &rest_model_zrok.AccessRequest{ ShrToken: request.ShareToken, diff --git a/sdk/share.go b/sdk/share.go index c2d0cbbba..2f843e145 100644 --- a/sdk/share.go +++ b/sdk/share.go @@ -10,6 +10,10 @@ import ( ) func CreateShare(root env_core.Root, request *ShareRequest) (*Share, error) { + if !root.IsEnabled() { + return nil, errors.New("environment is not enabled; enable with 'zrok enable' first!") + } + var err error var out *share.ShareParams From 6eddcedb32a2c82a43220504dd212ec3d321d839 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Thu, 27 Jul 2023 14:17:41 -0400 Subject: [PATCH 23/28] minimum infrastructure for pastebin sdk example (#379) --- sdk/examples/pastebin/cmd/copyto/main.go | 60 +++++++++++++++++++++ sdk/examples/pastebin/cmd/pastefrom/main.go | 46 ++++++++++++++++ 2 files changed, 106 insertions(+) create mode 100644 sdk/examples/pastebin/cmd/copyto/main.go create mode 100644 sdk/examples/pastebin/cmd/pastefrom/main.go diff --git a/sdk/examples/pastebin/cmd/copyto/main.go b/sdk/examples/pastebin/cmd/copyto/main.go new file mode 100644 index 000000000..e5640c9fe --- /dev/null +++ b/sdk/examples/pastebin/cmd/copyto/main.go @@ -0,0 +1,60 @@ +package main + +import ( + "fmt" + "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/sdk" + "net" + "os" + "os/signal" + "syscall" +) + +func main() { + root, err := environment.LoadRoot() + if err != nil { + panic(err) + } + + shr, err := sdk.CreateShare(root, &sdk.ShareRequest{ + BackendMode: sdk.TcpTunnelBackendMode, + ShareMode: sdk.PrivateShareMode, + Target: "pastebin", + }) + if err != nil { + panic(err) + } + + fmt.Printf("access your pastebin with: 'pastefrom %v'\n", shr.Token) + + listener, err := sdk.NewListener(shr.Token, root) + if err != nil { + panic(err) + } + + c := make(chan os.Signal) + signal.Notify(c, os.Interrupt, syscall.SIGTERM) + go func() { + <-c + if err := sdk.DeleteShare(root, shr); err != nil { + panic(err) + } + _ = listener.Close() + os.Exit(0) + }() + + for { + if conn, err := listener.Accept(); err == nil { + go handle(conn) + } else { + panic(err) + } + } +} + +func handle(conn net.Conn) { + _, err := conn.Write([]byte("hello from pastebin")) + if err != nil { + fmt.Printf("error: %v\n", err) + } +} diff --git a/sdk/examples/pastebin/cmd/pastefrom/main.go b/sdk/examples/pastebin/cmd/pastefrom/main.go new file mode 100644 index 000000000..8cb790603 --- /dev/null +++ b/sdk/examples/pastebin/cmd/pastefrom/main.go @@ -0,0 +1,46 @@ +package main + +import ( + "fmt" + "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/sdk" + "os" +) + +func main() { + if len(os.Args) < 2 { + panic("usage: pastefrom ") + } + shrToken := os.Args[1] + + root, err := environment.LoadRoot() + if err != nil { + panic(err) + } + + acc, err := sdk.CreateAccess(root, &sdk.AccessRequest{ShareToken: shrToken}) + if err != nil { + panic(err) + } + defer func() { + if err := sdk.DeleteAccess(root, acc); err != nil { + panic(err) + } + }() + + conn, err := sdk.NewDialer(shrToken, root) + if err != nil { + panic(err) + } + defer func() { + _ = conn.Close() + }() + + buf := make([]byte, 10240) + n, err := conn.Read(buf) + if err != nil { + panic(err) + } + + fmt.Println(string(buf[:n])) +} From 33a808837784b5e2fa8f640376ca06c7d178980d Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Thu, 27 Jul 2023 14:31:15 -0400 Subject: [PATCH 24/28] use os.Stdin to read the pastebin text (#379) --- sdk/examples/pastebin/cmd/copyto/main.go | 13 ++++++++++++- sdk/examples/pastebin/cmd/pastefrom/main.go | 4 +++- 2 files changed, 15 insertions(+), 2 deletions(-) diff --git a/sdk/examples/pastebin/cmd/copyto/main.go b/sdk/examples/pastebin/cmd/copyto/main.go index e5640c9fe..3cf769da3 100644 --- a/sdk/examples/pastebin/cmd/copyto/main.go +++ b/sdk/examples/pastebin/cmd/copyto/main.go @@ -4,13 +4,24 @@ import ( "fmt" "github.com/openziti/zrok/environment" "github.com/openziti/zrok/sdk" + "io" "net" "os" "os/signal" "syscall" ) +const MAX_PASTE_SIZE = 64 * 1024 + +var data []byte + func main() { + var err error + data, err = io.ReadAll(os.Stdin) + if err != nil { + panic(err) + } + root, err := environment.LoadRoot() if err != nil { panic(err) @@ -53,7 +64,7 @@ func main() { } func handle(conn net.Conn) { - _, err := conn.Write([]byte("hello from pastebin")) + _, err := conn.Write(data) if err != nil { fmt.Printf("error: %v\n", err) } diff --git a/sdk/examples/pastebin/cmd/pastefrom/main.go b/sdk/examples/pastebin/cmd/pastefrom/main.go index 8cb790603..9ec5885c4 100644 --- a/sdk/examples/pastebin/cmd/pastefrom/main.go +++ b/sdk/examples/pastebin/cmd/pastefrom/main.go @@ -7,6 +7,8 @@ import ( "os" ) +const MAX_PASTE_SIZE = 64 * 1024 + func main() { if len(os.Args) < 2 { panic("usage: pastefrom ") @@ -36,7 +38,7 @@ func main() { _ = conn.Close() }() - buf := make([]byte, 10240) + buf := make([]byte, MAX_PASTE_SIZE) n, err := conn.Read(buf) if err != nil { panic(err) From c43f34083dd9e3cd24a22237af3fe0d63128cafc Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Thu, 27 Jul 2023 17:00:05 -0400 Subject: [PATCH 25/28] copyto; abort when there is no stdin (#379) --- sdk/examples/pastebin/cmd/copyto/main.go | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) diff --git a/sdk/examples/pastebin/cmd/copyto/main.go b/sdk/examples/pastebin/cmd/copyto/main.go index 3cf769da3..5d3d0c0be 100644 --- a/sdk/examples/pastebin/cmd/copyto/main.go +++ b/sdk/examples/pastebin/cmd/copyto/main.go @@ -16,10 +16,15 @@ const MAX_PASTE_SIZE = 64 * 1024 var data []byte func main() { - var err error - data, err = io.ReadAll(os.Stdin) - if err != nil { - panic(err) + stat, _ := os.Stdin.Stat() + if stat.Mode()&os.ModeCharDevice == 0 { + var err error + data, err = io.ReadAll(os.Stdin) + if err != nil { + panic(err) + } + } else { + panic("usage: 'copyto' is requires input from stdin; pipe your paste buffer into it") } root, err := environment.LoadRoot() From 567ee6c003abb09271a9faab16a6cf17fda1f079 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Mon, 31 Jul 2023 13:53:49 -0400 Subject: [PATCH 26/28] copyto/pastefrom tweaks + readme (#379) --- sdk/examples/pastebin/README.md | 117 ++++++++++++++++++++ sdk/examples/pastebin/cmd/copyto/main.go | 40 ++++--- sdk/examples/pastebin/cmd/pastefrom/main.go | 2 +- 3 files changed, 143 insertions(+), 16 deletions(-) create mode 100644 sdk/examples/pastebin/README.md diff --git a/sdk/examples/pastebin/README.md b/sdk/examples/pastebin/README.md new file mode 100644 index 000000000..e8cfac2d3 --- /dev/null +++ b/sdk/examples/pastebin/README.md @@ -0,0 +1,117 @@ +# "pastebin" SDK Example + +This `pastebin` example is a minimal `zrok` SDK application that implements a wormhole that makes redirecting file contents between multiple `zrok` environments very easy. + +The `pastebin` example is split into two separate commands. The `copyto` command takes a copy buffer from standard input. You can use it like this: + +``` +$ echo "this is a pastebin test" | copyto +access your pastebin using 'pastefrom b46p9j82z81f' +``` + +And then using another terminal window, you can access your pastebin data like this: + +``` +$ pastefrom b46p9j82z81f +this is a pastebin test +``` + +## The `copyto` Implementation + +The `copyto` utility is an illustration of how to implement an application that creates a share and exposes it to the `zrok` network. Let's look at each section of the implementation: + +```go + data, err := loadData() + if err != nil { + panic(err) + } +``` + +This first block of code is responsible for calling the `loadData` function, which loads the pastebin with data from `os.Stdin`. + +All SDK applications need to load the user's "root" from the `environment` package, like this: + +```go + root, err := environment.LoadRoot() + if err != nil { + panic(err) + } +``` + +The `root` is a structure that contains all of the user's environment detail and allows the SDK application to access the `zrok` service instance and the underlying OpenZiti network. + +Next, `copyto` will create a `zrok` share: + +```go + shr, err := sdk.CreateShare(root, &sdk.ShareRequest{ + BackendMode: sdk.TcpTunnelBackendMode, + ShareMode: sdk.PrivateShareMode, + Target: "pastebin", + }) + if err != nil { + panic(err) + } + + fmt.Printf("access your pastebin using 'pastefrom %v'\n", shr.Token) +``` + +The `sdk.CreateShare` call uses the loaded `environment` root along with the details of the share request (`sdk.ShareRequest`) to create the share that will be used to access the `pastebin`. + +For the `pastebin` application, we're using a `sdk.TcpTunnelBackendMode` backend mode (we're just using a single network connection that implements a reliable byte stream, so TCP works great). Tunnel backends only work with `private` shares as of `zrok` `v0.4`, so we're using `sdk.PrivateShareMode`. + +We'll set the `Target` to be `pastebin`, as that's just metadata describing the application. + +Finally, we emit the share token so the user can access the `pastebin` using the `pastefrom` command. + +Next, we'll use the SDK to create a listener for this share: + +```go + listener, err := sdk.NewListener(shr.Token, root) + if err != nil { + panic(err) + } +``` + +The `sdk.NewListener` establishes a network listener for the newly created share. This listener works just like a `net.Listener`. + +Next, we're going to add a shutdown hook so that `copyto` will delete the share when the application is terminated using `^C`: + +```go + c := make(chan os.Signal) + signal.Notify(c, os.Interrupt, syscall.SIGTERM) + go func() { + <-c + if err := sdk.DeleteShare(root, shr); err != nil { + panic(err) + } + _ = listener.Close() + os.Exit(0) + }() +``` + +This anonymous function runs waiting for a signal to exit. When that is received, it runs the `sdk.DeleteShare` function to remove the share that was created. This is how ephemeral shares work for the `zrok share` commands as well. + +And finally, we run in an infinite loop waiting for requests for the `pastebin` data from the network: + +```go + for { + if conn, err := listener.Accept(); err == nil { + go handle(conn, data) + } else { + panic(err) + } + } +``` + +## The "pastefrom" Implementation + +The `pastefrom` application works very similarly to `copyto`. The primary difference is that it "dials" the share through the SDK using `sdk.NewDialer`, which returns a `net.Conn`: + +```go + conn, err := sdk.NewDialer(shrToken, root) + if err != nil { + panic(err) + } +``` + +When this `sdk.NewDialer` function returns without an error, a bidirectional `net.Conn` has been established between the `copyto` "server" and the `pastefrom` "client". `pastefrom` then just reads the available data from the `net.Conn` and emits it to `os.Stdout`. \ No newline at end of file diff --git a/sdk/examples/pastebin/cmd/copyto/main.go b/sdk/examples/pastebin/cmd/copyto/main.go index 5d3d0c0be..6c129b995 100644 --- a/sdk/examples/pastebin/cmd/copyto/main.go +++ b/sdk/examples/pastebin/cmd/copyto/main.go @@ -1,9 +1,12 @@ package main import ( + "errors" "fmt" + "github.com/michaelquigley/pfxlog" "github.com/openziti/zrok/environment" "github.com/openziti/zrok/sdk" + "github.com/sirupsen/logrus" "io" "net" "os" @@ -11,20 +14,14 @@ import ( "syscall" ) -const MAX_PASTE_SIZE = 64 * 1024 - -var data []byte +func init() { + pfxlog.GlobalInit(logrus.WarnLevel, pfxlog.DefaultOptions()) +} func main() { - stat, _ := os.Stdin.Stat() - if stat.Mode()&os.ModeCharDevice == 0 { - var err error - data, err = io.ReadAll(os.Stdin) - if err != nil { - panic(err) - } - } else { - panic("usage: 'copyto' is requires input from stdin; pipe your paste buffer into it") + data, err := loadData() + if err != nil { + panic(err) } root, err := environment.LoadRoot() @@ -41,7 +38,7 @@ func main() { panic(err) } - fmt.Printf("access your pastebin with: 'pastefrom %v'\n", shr.Token) + fmt.Printf("access your pastebin using 'pastefrom %v'\n", shr.Token) listener, err := sdk.NewListener(shr.Token, root) if err != nil { @@ -61,14 +58,27 @@ func main() { for { if conn, err := listener.Accept(); err == nil { - go handle(conn) + go handle(conn, data) } else { panic(err) } } } -func handle(conn net.Conn) { +func loadData() ([]byte, error) { + stat, _ := os.Stdin.Stat() + if stat.Mode()&os.ModeCharDevice == 0 { + data, err := io.ReadAll(os.Stdin) + if err != nil { + return nil, err + } + return data, nil + } else { + return nil, errors.New("'copyto' requires input from stdin; direct your paste buffer into stdin") + } +} + +func handle(conn net.Conn, data []byte) { _, err := conn.Write(data) if err != nil { fmt.Printf("error: %v\n", err) diff --git a/sdk/examples/pastebin/cmd/pastefrom/main.go b/sdk/examples/pastebin/cmd/pastefrom/main.go index 9ec5885c4..56ba4e1a7 100644 --- a/sdk/examples/pastebin/cmd/pastefrom/main.go +++ b/sdk/examples/pastebin/cmd/pastefrom/main.go @@ -44,5 +44,5 @@ func main() { panic(err) } - fmt.Println(string(buf[:n])) + fmt.Printf(string(buf[:n])) } From a872db0ffd73f4b72c37eb52f05c7a91f13ca1cb Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Mon, 31 Jul 2023 13:56:35 -0400 Subject: [PATCH 27/28] changelog (#34, #379) --- CHANGELOG.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index a684f154e..467ca31f4 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,8 @@ FEATURE: New `zrok overview` command, which returns all of the account details as a single JSON structure. See the OpenAPI spec at `specs/zrok.yml` for more details of the `/api/v1/overview` endpoint (https://github.com/openziti/zrok/issues/374) +FEATURE: New `zrok` SDK; `zrok` SDK used internally by `zrok share` and `zrok access` commands (https://github.com/openziti/zrok/issues/34); `pastebin` example illustrates basic SDK usage (see `sdk/examples/pastebin/README.md` for details) + # v0.4.2 Some days are just like this. `v0.4.2` is a re-do of `v0.4.1`. Trying to get Homebrew working and had a bad release. Hopefully this is the one. From 6893a534dce4bb95a201078427a4d3a7cd20366f Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Mon, 31 Jul 2023 13:58:31 -0400 Subject: [PATCH 28/28] updated changelog (#34, #379) --- CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 467ca31f4..b4fa0eaa0 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,7 +2,7 @@ FEATURE: New `zrok overview` command, which returns all of the account details as a single JSON structure. See the OpenAPI spec at `specs/zrok.yml` for more details of the `/api/v1/overview` endpoint (https://github.com/openziti/zrok/issues/374) -FEATURE: New `zrok` SDK; `zrok` SDK used internally by `zrok share` and `zrok access` commands (https://github.com/openziti/zrok/issues/34); `pastebin` example illustrates basic SDK usage (see `sdk/examples/pastebin/README.md` for details) +FEATURE: New `zrok` SDK (https://github.com/openziti/zrok/issues/34). `pastebin` example illustrates basic SDK usage (see `sdk/examples/pastebin/README.md` for details) ((https://github.com/openziti/zrok/issues/379) # v0.4.2