grab git branch

This commit is contained in:
sawka 2023-04-11 23:52:58 -07:00
parent fdae19610b
commit a4a4d53eb0
2 changed files with 33 additions and 6 deletions

View File

@ -398,7 +398,7 @@ func parseDeclareStmt(stmt *syntax.Stmt, src string) (*DeclareDeclType, error) {
return rtn, nil return rtn, nil
} }
func parseDeclareOutput(state *packet.ShellState, declareBytes []byte) error { func parseDeclareOutput(state *packet.ShellState, declareBytes []byte, pvarBytes []byte) error {
declareStr := string(declareBytes) declareStr := string(declareBytes)
r := bytes.NewReader(declareBytes) r := bytes.NewReader(declareBytes)
parser := syntax.NewParser(syntax.Variant(syntax.LangBash)) parser := syntax.NewParser(syntax.Variant(syntax.LangBash))
@ -419,6 +419,21 @@ func parseDeclareOutput(state *packet.ShellState, declareBytes []byte) error {
declMap[decl.Name] = decl declMap[decl.Name] = decl
} }
} }
pvars := bytes.Split(pvarBytes, []byte{0})
for _, pvarBA := range pvars {
pvarStr := string(pvarBA)
pvarFields := strings.SplitN(pvarStr, " ", 2)
if len(pvarFields) != 2 {
continue
}
if pvarFields[0] == "" || pvarFields[1] == "" {
continue
}
decl := &DeclareDeclType{Args: "x"}
decl.Name = "PROMPTVAR_" + pvarFields[0]
decl.Value = shellescape.Quote(pvarFields[1])
declMap[decl.Name] = decl
}
state.ShellVars = SerializeDeclMap(declMap) // this writes out the decls in a canonical order state.ShellVars = SerializeDeclMap(declMap) // this writes out the decls in a canonical order
if firstParseErr != nil { if firstParseErr != nil {
state.Error = firstParseErr.Error() state.Error = firstParseErr.Error()
@ -429,7 +444,7 @@ func parseDeclareOutput(state *packet.ShellState, declareBytes []byte) error {
func ParseShellStateOutput(outputBytes []byte) (*packet.ShellState, error) { func ParseShellStateOutput(outputBytes []byte) (*packet.ShellState, error) {
// 5 fields: version, cwd, env/vars, aliases, funcs // 5 fields: version, cwd, env/vars, aliases, funcs
fields := bytes.Split(outputBytes, []byte{0, 0}) fields := bytes.Split(outputBytes, []byte{0, 0})
if len(fields) != 5 { if len(fields) != 6 {
return nil, fmt.Errorf("invalid shell state output, wrong number of fields, fields=%d", len(fields)) return nil, fmt.Errorf("invalid shell state output, wrong number of fields, fields=%d", len(fields))
} }
rtn := &packet.ShellState{} rtn := &packet.ShellState{}
@ -445,7 +460,7 @@ func ParseShellStateOutput(outputBytes []byte) (*packet.ShellState, error) {
cwdStr = cwdStr[0 : len(cwdStr)-1] cwdStr = cwdStr[0 : len(cwdStr)-1]
} }
rtn.Cwd = string(cwdStr) rtn.Cwd = string(cwdStr)
err := parseDeclareOutput(rtn, fields[2]) err := parseDeclareOutput(rtn, fields[2], fields[5])
if err != nil { if err != nil {
return nil, err return nil, err
} }

View File

@ -51,7 +51,15 @@ const MaxTotalRunDataSize = 10 * MaxRunDataSize
const GetStateTimeout = 5 * time.Second const GetStateTimeout = 5 * time.Second
const BaseBashOpts = `set +m; set +H; shopt -s extglob` const BaseBashOpts = `set +m; set +H; shopt -s extglob`
const GetShellStateCmd = `echo bash v${BASH_VERSINFO[0]}.${BASH_VERSINFO[1]}.${BASH_VERSINFO[2]}; printf "\x00\x00"; pwd; printf "\x00\x00"; declare -p $(compgen -A variable); printf "\x00\x00"; alias -p; printf "\x00\x00"; declare -f;`
var GetShellStateCmds = []string{
`echo bash v${BASH_VERSINFO[0]}.${BASH_VERSINFO[1]}.${BASH_VERSINFO[2]};`,
`pwd;`,
`declare -p $(compgen -A variable);`,
`alias -p;`,
`declare -f;`,
`printf "GITBRANCH %s\x00" "$(git rev-parse --abbrev-ref HEAD 2>/dev/null)"`,
}
const ClientCommandFmt = ` const ClientCommandFmt = `
PATH=$PATH:~/.mshell; PATH=$PATH:~/.mshell;
@ -161,6 +169,10 @@ type ShExecUPR struct {
UPR packet.UnknownPacketReporter UPR packet.UnknownPacketReporter
} }
func GetShellStateCmd() string {
return strings.Join(GetShellStateCmds, ` printf "\x00\x00";`)
}
func (s *ShExecType) processSpecialInputPacket(pk *packet.SpecialInputPacketType) error { func (s *ShExecType) processSpecialInputPacket(pk *packet.SpecialInputPacketType) error {
base.Logf("processSpecialInputPacket: %#v\n", pk) base.Logf("processSpecialInputPacket: %#v\n", pk)
if pk.WinSize != nil { if pk.WinSize != nil {
@ -1500,12 +1512,12 @@ func runSimpleCmdInPty(ecmd *exec.Cmd) ([]byte, error) {
} }
func GetShellStateRedirectCommandStr(outputFdNum int) string { func GetShellStateRedirectCommandStr(outputFdNum int) string {
return fmt.Sprintf("cat <(%s) > /dev/fd/%d", GetShellStateCmd, outputFdNum) return fmt.Sprintf("cat <(%s) > /dev/fd/%d", GetShellStateCmd(), outputFdNum)
} }
func GetShellState() (*packet.ShellState, error) { func GetShellState() (*packet.ShellState, error) {
ctx, _ := context.WithTimeout(context.Background(), GetStateTimeout) ctx, _ := context.WithTimeout(context.Background(), GetStateTimeout)
cmdStr := BaseBashOpts + "; " + GetShellStateCmd cmdStr := BaseBashOpts + "; " + GetShellStateCmd()
ecmd := exec.CommandContext(ctx, "bash", "-l", "-i", "-c", cmdStr) ecmd := exec.CommandContext(ctx, "bash", "-l", "-i", "-c", cmdStr)
outputBytes, err := runSimpleCmdInPty(ecmd) outputBytes, err := runSimpleCmdInPty(ecmd)
if err != nil { if err != nil {