mirror of
https://github.com/wavetermdev/waveterm.git
synced 2025-01-14 20:21:27 +01:00
parameterize the mshell bin directory (for packaging). inject MSHELL variables for execution
This commit is contained in:
parent
8939c57dd8
commit
ee36078082
@ -245,6 +245,22 @@ func GoArchOptFile(version string, goos string, goarch string) string {
|
|||||||
return fmt.Sprintf(path.Join(installBinDir, binBaseName))
|
return fmt.Sprintf(path.Join(installBinDir, binBaseName))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func MShellBinaryFromOptDir(version string, goos string, goarch string) (io.ReadCloser, error) {
|
||||||
|
if !ValidGoArch(goos, goarch) {
|
||||||
|
return nil, fmt.Errorf("invalid goos/goarch combination: %s/%s", goos, goarch)
|
||||||
|
}
|
||||||
|
versionStr := semver.MajorMinor(version)
|
||||||
|
if versionStr == "" {
|
||||||
|
return nil, fmt.Errorf("invalid mshell version: %q", version)
|
||||||
|
}
|
||||||
|
fileName := GoArchOptFile(version, goos, goarch)
|
||||||
|
fd, err := os.Open(fileName)
|
||||||
|
if err != nil {
|
||||||
|
return nil, fmt.Errorf("cannot open mshell binary %q: %v", fileName, err)
|
||||||
|
}
|
||||||
|
return fd, nil
|
||||||
|
}
|
||||||
|
|
||||||
func GetRemoteId() (string, error) {
|
func GetRemoteId() (string, error) {
|
||||||
mhome := GetMShellHomeDir()
|
mhome := GetMShellHomeDir()
|
||||||
homeInfo, err := os.Stat(mhome)
|
homeInfo, err := os.Stat(mhome)
|
||||||
|
@ -85,6 +85,8 @@ const RunCommandFmt = `%s`
|
|||||||
const RunSudoCommandFmt = `sudo -n -C %d bash /dev/fd/%d`
|
const RunSudoCommandFmt = `sudo -n -C %d bash /dev/fd/%d`
|
||||||
const RunSudoPasswordCommandFmt = `cat /dev/fd/%d | sudo -k -S -C %d bash -c "echo '[from-mshell]'; exec %d>&-; bash /dev/fd/%d < /dev/fd/%d"`
|
const RunSudoPasswordCommandFmt = `cat /dev/fd/%d | sudo -k -S -C %d bash -c "echo '[from-mshell]'; exec %d>&-; bash /dev/fd/%d < /dev/fd/%d"`
|
||||||
|
|
||||||
|
type MShellBinaryReaderFn func(version string, goos string, goarch string) (io.ReadCloser, error)
|
||||||
|
|
||||||
type ReturnStateBuf struct {
|
type ReturnStateBuf struct {
|
||||||
Lock *sync.Mutex
|
Lock *sync.Mutex
|
||||||
Buf []byte
|
Buf []byte
|
||||||
@ -284,7 +286,7 @@ func MakeDetachedExecCmd(pk *packet.RunPacketType, cmdTty *os.File) (*exec.Cmd,
|
|||||||
ecmd.Env = os.Environ()
|
ecmd.Env = os.Environ()
|
||||||
}
|
}
|
||||||
UpdateCmdEnv(ecmd, EnvMapFromState(state))
|
UpdateCmdEnv(ecmd, EnvMapFromState(state))
|
||||||
UpdateCmdEnv(ecmd, map[string]string{"TERM": getTermType(pk)})
|
UpdateCmdEnv(ecmd, MShellEnvVars(getTermType(pk)))
|
||||||
if state.Cwd != "" {
|
if state.Cwd != "" {
|
||||||
ecmd.Dir = base.ExpandHomeDir(state.Cwd)
|
ecmd.Dir = base.ExpandHomeDir(state.Cwd)
|
||||||
}
|
}
|
||||||
@ -673,19 +675,14 @@ func ValidateRemoteFds(rfds []packet.RemoteFd) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func sendOptFile(input io.WriteCloser, optName string) error {
|
func sendMShellBinary(input io.WriteCloser, mshellStream io.Reader) {
|
||||||
fd, err := os.Open(optName)
|
|
||||||
if err != nil {
|
|
||||||
return fmt.Errorf("cannot open '%s': %w", optName, err)
|
|
||||||
}
|
|
||||||
go func() {
|
go func() {
|
||||||
defer input.Close()
|
defer input.Close()
|
||||||
io.Copy(input, fd)
|
io.Copy(input, mshellStream)
|
||||||
}()
|
}()
|
||||||
return nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func RunInstallFromCmd(ctx context.Context, ecmd *exec.Cmd, tryDetect bool, optName string, msgFn func(string)) error {
|
func RunInstallFromCmd(ctx context.Context, ecmd *exec.Cmd, tryDetect bool, mshellStream io.Reader, mshellReaderFn MShellBinaryReaderFn, msgFn func(string)) error {
|
||||||
inputWriter, err := ecmd.StdinPipe()
|
inputWriter, err := ecmd.StdinPipe()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("creating stdin pipe: %v", err)
|
return fmt.Errorf("creating stdin pipe: %v", err)
|
||||||
@ -701,11 +698,8 @@ func RunInstallFromCmd(ctx context.Context, ecmd *exec.Cmd, tryDetect bool, optN
|
|||||||
go func() {
|
go func() {
|
||||||
io.Copy(os.Stderr, stderrReader)
|
io.Copy(os.Stderr, stderrReader)
|
||||||
}()
|
}()
|
||||||
if optName != "" {
|
if mshellStream != nil {
|
||||||
err = sendOptFile(inputWriter, optName)
|
sendMShellBinary(inputWriter, mshellStream)
|
||||||
if err != nil {
|
|
||||||
return fmt.Errorf("cannot send mshell binary: %v", err)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
packetParser := packet.MakePacketParser(stdoutReader)
|
packetParser := packet.MakePacketParser(stdoutReader)
|
||||||
err = ecmd.Start()
|
err = ecmd.Start()
|
||||||
@ -736,11 +730,12 @@ func RunInstallFromCmd(ctx context.Context, ecmd *exec.Cmd, tryDetect bool, optN
|
|||||||
}
|
}
|
||||||
msgStr := fmt.Sprintf("mshell detected remote architecture as '%s.%s'\n", goos, goarch)
|
msgStr := fmt.Sprintf("mshell detected remote architecture as '%s.%s'\n", goos, goarch)
|
||||||
msgFn(msgStr)
|
msgFn(msgStr)
|
||||||
optName := base.GoArchOptFile(base.MShellVersion, goos, goarch)
|
detectedMSS, err := mshellReaderFn(base.MShellVersion, goos, goarch)
|
||||||
err = sendOptFile(inputWriter, optName)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("cannot send mshell binary: %v", err)
|
return err
|
||||||
}
|
}
|
||||||
|
defer detectedMSS.Close()
|
||||||
|
sendMShellBinary(inputWriter, detectedMSS)
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
if pk.GetType() == packet.InitPacketStr && !firstInit {
|
if pk.GetType() == packet.InitPacketStr && !firstInit {
|
||||||
@ -768,7 +763,15 @@ func RunInstallFromOpts(opts *InstallOpts) error {
|
|||||||
msgFn := func(str string) {
|
msgFn := func(str string) {
|
||||||
fmt.Printf("%s", str)
|
fmt.Printf("%s", str)
|
||||||
}
|
}
|
||||||
err = RunInstallFromCmd(context.Background(), ecmd, opts.Detect, opts.OptName, msgFn)
|
var mshellStream *os.File
|
||||||
|
if opts.OptName != "" {
|
||||||
|
mshellStream, err = os.Open(opts.OptName)
|
||||||
|
if err != nil {
|
||||||
|
return fmt.Errorf("cannot open mshell binary %q: %v", opts.OptName, err)
|
||||||
|
}
|
||||||
|
defer mshellStream.Close()
|
||||||
|
}
|
||||||
|
err = RunInstallFromCmd(context.Background(), ecmd, opts.Detect, mshellStream, base.MShellBinaryFromOptDir, msgFn)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -1070,7 +1073,7 @@ func RunCommandSimple(pk *packet.RunPacketType, sender *packet.PacketSender, fro
|
|||||||
cmdTty.Close()
|
cmdTty.Close()
|
||||||
}()
|
}()
|
||||||
cmd.CmdPty = cmdPty
|
cmd.CmdPty = cmdPty
|
||||||
UpdateCmdEnv(cmd.Cmd, map[string]string{"TERM": getTermType(pk)})
|
UpdateCmdEnv(cmd.Cmd, MShellEnvVars(getTermType(pk)))
|
||||||
}
|
}
|
||||||
if cmdTty != nil {
|
if cmdTty != nil {
|
||||||
cmd.Cmd.Stdin = cmdTty
|
cmd.Cmd.Stdin = cmdTty
|
||||||
@ -1407,7 +1410,7 @@ func getStderr(err error) string {
|
|||||||
|
|
||||||
func runSimpleCmdInPty(ecmd *exec.Cmd) ([]byte, error) {
|
func runSimpleCmdInPty(ecmd *exec.Cmd) ([]byte, error) {
|
||||||
ecmd.Env = os.Environ()
|
ecmd.Env = os.Environ()
|
||||||
UpdateCmdEnv(ecmd, map[string]string{"TERM": DefaultTermType})
|
UpdateCmdEnv(ecmd, MShellEnvVars(DefaultTermType))
|
||||||
cmdPty, cmdTty, err := pty.Open()
|
cmdPty, cmdTty, err := pty.Open()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, fmt.Errorf("opening new pty: %w", err)
|
return nil, fmt.Errorf("opening new pty: %w", err)
|
||||||
@ -1456,3 +1459,13 @@ func GetShellState() (*packet.ShellState, error) {
|
|||||||
}
|
}
|
||||||
return ParseShellStateOutput(outputBytes)
|
return ParseShellStateOutput(outputBytes)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func MShellEnvVars(termType string) map[string]string {
|
||||||
|
rtn := make(map[string]string)
|
||||||
|
if termType != "" {
|
||||||
|
rtn["TERM"] = termType
|
||||||
|
}
|
||||||
|
rtn["MSHELL"], _ = os.Executable()
|
||||||
|
rtn["MSHELL_VERSION"] = base.MShellVersion
|
||||||
|
return rtn
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user