From 48b26c9df52b73597ff4dc3a016d9f8adf894671 Mon Sep 17 00:00:00 2001 From: Romein van Buren Date: Sat, 24 Jun 2023 11:26:02 +0200 Subject: [PATCH] Parse connection URI correctly --- internal/app/collection_shell.go | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) diff --git a/internal/app/collection_shell.go b/internal/app/collection_shell.go index dffcf1b..10a62cb 100644 --- a/internal/app/collection_shell.go +++ b/internal/app/collection_shell.go @@ -2,10 +2,10 @@ package app import ( "fmt" + "net/url" "os" "os/exec" "path" - "strings" "github.com/google/uuid" "github.com/wailsapp/wails/v2/pkg/runtime" @@ -56,12 +56,16 @@ func (a *App) ExecuteShellScript(hostKey, dbKey, collKey, script string) (result return } - connstr := host.URI - if !strings.HasSuffix(connstr, "/") { - connstr = connstr + "/" + url, err := url.Parse(host.URI) + if err != nil { + runtime.LogWarningf(a.ctx, "Shell: failed to parse host URI %s: %s", host.URI, err.Error()) + result.ErrorTitle = "Could parse host URI" + result.ErrorDescription = err.Error() + return } - connstr = connstr + dbKey + url.Path = "/" + dbKey + connstr := url.String() script = fmt.Sprintf("db = connect('%s');\ncoll = db.getCollection('%s');\n\n%s", connstr, collKey, script) if err := os.WriteFile(fname, []byte(script), os.ModePerm); err != nil {