mirror of
https://github.com/wavetermdev/waveterm.git
synced 2025-01-22 21:42:49 +01:00
feat: allow user input verification for install
Depending on the method of installing waveshell, it may be desired to pop up a modal for user verification. This is a first pass at handling these special cases. The focus is on installing while previously connected and auto installing while connecting.
This commit is contained in:
parent
089862d990
commit
70d4bb8ff4
@ -1689,7 +1689,7 @@ func RemoteInstallCommand(ctx context.Context, pk *scpacket.FeCommandPacketType)
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
mshell := ids.Remote.MShell
|
mshell := ids.Remote.MShell
|
||||||
go mshell.RunInstall()
|
go mshell.RunInstall(false)
|
||||||
return createRemoteViewRemoteIdUpdate(ids.Remote.RemotePtr.RemoteId), nil
|
return createRemoteViewRemoteIdUpdate(ids.Remote.RemotePtr.RemoteId), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -534,7 +534,7 @@ func (msh *MShellProc) tryAutoInstall() {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
msh.writeToPtyBuffer_nolock("trying auto-install\n")
|
msh.writeToPtyBuffer_nolock("trying auto-install\n")
|
||||||
go msh.RunInstall()
|
go msh.RunInstall(true)
|
||||||
}
|
}
|
||||||
|
|
||||||
// if msh.IsConnected() then GetShellPref() should return a valid shell
|
// if msh.IsConnected() then GetShellPref() should return a valid shell
|
||||||
@ -1221,17 +1221,73 @@ func (msh *MShellProc) WaitAndSendPassword(pw string) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (msh *MShellProc) RunInstall() {
|
func (msh *MShellProc) RunInstall(autoInstall bool) {
|
||||||
remoteCopy := msh.GetRemoteCopy()
|
remoteCopy := msh.GetRemoteCopy()
|
||||||
if remoteCopy.Archived {
|
if remoteCopy.Archived {
|
||||||
msh.WriteToPtyBuffer("*error: cannot install on archived remote\n")
|
msh.WriteToPtyBuffer("*error: cannot install on archived remote\n")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
baseStatus := msh.GetStatus()
|
baseStatus := msh.GetStatus()
|
||||||
if baseStatus == StatusConnecting || baseStatus == StatusConnected {
|
if baseStatus == StatusConnecting && !autoInstall {
|
||||||
msh.WriteToPtyBuffer("*error: cannot install on remote that is connected/connecting, disconnect to install\n")
|
msh.WriteToPtyBuffer("*error: cannot install on remote that is connected/connecting, disconnect to install\n")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
if baseStatus == StatusConnecting {
|
||||||
|
//this is the auto-install case
|
||||||
|
request := &userinput.UserInputRequestType{
|
||||||
|
ResponseType: "confirm",
|
||||||
|
QueryText: "Waveshell must be reinstalled on the connection to continue. Would you like to install it?",
|
||||||
|
Title: "Install Waveshell",
|
||||||
|
}
|
||||||
|
ctx, cancelFn := context.WithTimeout(context.Background(), 60*time.Second)
|
||||||
|
defer cancelFn()
|
||||||
|
response, err := userinput.GetUserInput(ctx, scbus.MainRpcBus, request)
|
||||||
|
if err != nil {
|
||||||
|
var errMsg error
|
||||||
|
if err == context.Canceled {
|
||||||
|
errMsg = fmt.Errorf("installation canceled by user")
|
||||||
|
} else {
|
||||||
|
errMsg = fmt.Errorf("timed out waiting for user input")
|
||||||
|
}
|
||||||
|
msh.WithLock(func() {
|
||||||
|
msh.Client = nil
|
||||||
|
})
|
||||||
|
msh.WriteToPtyBuffer("*error, %s\n", errMsg)
|
||||||
|
msh.setErrorStatus(errMsg)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if !response.Confirm {
|
||||||
|
errMsg := fmt.Errorf("installation canceled by user")
|
||||||
|
msh.WriteToPtyBuffer("*error, %s\n", errMsg.Error())
|
||||||
|
msh.setErrorStatus(err)
|
||||||
|
msh.WithLock(func() {
|
||||||
|
msh.Client = nil
|
||||||
|
})
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if baseStatus == StatusConnected {
|
||||||
|
request := &userinput.UserInputRequestType{
|
||||||
|
ResponseType: "confirm",
|
||||||
|
QueryText: "Waveshell is running on your connection and must be restarted to re-install. Would you like to continue?",
|
||||||
|
Title: "Restart Waveshell",
|
||||||
|
}
|
||||||
|
ctx, cancelFn := context.WithTimeout(context.Background(), 60*time.Second)
|
||||||
|
defer cancelFn()
|
||||||
|
response, err := userinput.GetUserInput(ctx, scbus.MainRpcBus, request)
|
||||||
|
if err != nil {
|
||||||
|
if err == context.Canceled {
|
||||||
|
msh.WriteToPtyBuffer("installation canceled by user\n")
|
||||||
|
} else {
|
||||||
|
msh.WriteToPtyBuffer("timed out waiting for user input\n")
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if !response.Confirm {
|
||||||
|
msh.WriteToPtyBuffer("installation canceled by user\n")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
curStatus := msh.GetInstallStatus()
|
curStatus := msh.GetInstallStatus()
|
||||||
if curStatus == StatusConnecting {
|
if curStatus == StatusConnecting {
|
||||||
msh.WriteToPtyBuffer("*error: cannot install on remote that is already trying to install, cancel current install to try again\n")
|
msh.WriteToPtyBuffer("*error: cannot install on remote that is already trying to install, cancel current install to try again\n")
|
||||||
@ -1301,8 +1357,8 @@ func (msh *MShellProc) RunInstall() {
|
|||||||
})
|
})
|
||||||
msh.WriteToPtyBuffer("successfully installed waveshell %s to ~/.mshell\n", scbase.MShellVersion)
|
msh.WriteToPtyBuffer("successfully installed waveshell %s to ~/.mshell\n", scbase.MShellVersion)
|
||||||
go msh.NotifyRemoteUpdate()
|
go msh.NotifyRemoteUpdate()
|
||||||
if connectMode == sstore.ConnectModeStartup || connectMode == sstore.ConnectModeAuto {
|
if connectMode == sstore.ConnectModeStartup || connectMode == sstore.ConnectModeAuto || autoInstall {
|
||||||
// the install was successful, and we don't have a manual connect mode, try to connect
|
// the install was successful, and we didn't click the install button with manual connect mode, try to connect
|
||||||
go msh.Launch(true)
|
go msh.Launch(true)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user