From 81294820c8550961730476ad93a7dfe4c0f8f403 Mon Sep 17 00:00:00 2001 From: Sylvia Crowe Date: Thu, 14 Mar 2024 16:19:32 -0700 Subject: [PATCH] feat: add connection segfault protection A user recently reported a crash on a failed connection. This handles these errors more gracefully than the previous system and prints the errors to the connection prompt. --- wavesrv/pkg/remote/remote.go | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/wavesrv/pkg/remote/remote.go b/wavesrv/pkg/remote/remote.go index 9e89c0973..0b7e7cb54 100644 --- a/wavesrv/pkg/remote/remote.go +++ b/wavesrv/pkg/remote/remote.go @@ -15,6 +15,7 @@ import ( "os/exec" "path" "regexp" + "runtime/debug" "strconv" "strings" "sync" @@ -1176,6 +1177,15 @@ func (msh *MShellProc) WaitAndSendPassword(pw string) { } func (msh *MShellProc) RunInstall(autoInstall bool) { + defer func() { + if r := recover(); r != nil { + errMsg := fmt.Errorf("this should not happen. if it does, please reach out to us in our discord or open an issue on our github\n\n"+ + "error:\n%v\n\nstack trace:\n%s", r, string(debug.Stack())) + log.Printf("fatal error, %s\n", errMsg) + msh.WriteToPtyBuffer("*fatal error, %s\n", errMsg) + msh.setErrorStatus(errMsg) + } + }() remoteCopy := msh.GetRemoteCopy() if remoteCopy.Archived { msh.WriteToPtyBuffer("*error: cannot install on archived remote\n") @@ -1550,6 +1560,15 @@ func (msh *MShellProc) createWaveshellSession(clientCtx context.Context, remoteC } func (msh *MShellProc) Launch(interactive bool) { + defer func() { + if r := recover(); r != nil { + errMsg := fmt.Errorf("this should not happen. if it does, please reach out to us in our discord or open an issue on our github\n\n"+ + "error:\n%v\n\nstack trace:\n%s", r, string(debug.Stack())) + log.Printf("fatal error, %s\n", errMsg) + msh.WriteToPtyBuffer("*fatal error, %s\n", errMsg) + msh.setErrorStatus(errMsg) + } + }() remoteCopy := msh.GetRemoteCopy() if remoteCopy.Archived { msh.WriteToPtyBuffer("cannot launch archived remote\n")