|
|
|
|
@ -203,16 +203,19 @@ func (srv *server) handleAcceptedSSH(ctx context.Context, s ssh.Session, ci *ssh |
|
|
|
|
return |
|
|
|
|
} |
|
|
|
|
cmd = exec.Command(loginShell(lu.Uid)) |
|
|
|
|
if rawCmd := s.RawCommand(); rawCmd != "" { |
|
|
|
|
cmd.Args = append(cmd.Args, "-c", rawCmd) |
|
|
|
|
} |
|
|
|
|
} else { |
|
|
|
|
if rawCmd := s.RawCommand(); rawCmd != "" { |
|
|
|
|
cmd = exec.Command("/usr/bin/env", "su", "-c", rawCmd, localUser) |
|
|
|
|
cmd.Dir = lu.HomeDir |
|
|
|
|
cmd.Env = append(cmd.Env, envForUser(lu)...) |
|
|
|
|
// TODO: and Env for PATH, SSH_CONNECTION, SSH_CLIENT, XDG_SESSION_TYPE, XDG_*, etc
|
|
|
|
|
} else { |
|
|
|
|
cmd = exec.Command("/usr/bin/env", "su", "-", localUser) |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
cmd.Dir = lu.HomeDir |
|
|
|
|
cmd.Env = append(cmd.Env, envForUser(lu)...) |
|
|
|
|
if ptyReq.Term != "" { |
|
|
|
|
cmd.Env = append(cmd.Env, fmt.Sprintf("TERM=%s", ptyReq.Term)) |
|
|
|
|
} |
|
|
|
|
@ -397,7 +400,7 @@ func loginShell(uid string) string { |
|
|
|
|
// out is "root:x:0:0:root:/root:/bin/bash"
|
|
|
|
|
f := strings.SplitN(string(out), ":", 10) |
|
|
|
|
if len(f) > 6 { |
|
|
|
|
return f[6] // shell
|
|
|
|
|
return strings.TrimSpace(f[6]) // shell
|
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
if e := os.Getenv("SHELL"); e != "" { |
|
|
|
|
|