AUTH-2004: Adds static host key support

This commit is contained in:
Michael Borkenstein
2019-08-19 13:51:59 -05:00
parent 30c9e2af9b
commit 188f4667cb
2 changed files with 121 additions and 4 deletions

View File

@@ -19,24 +19,31 @@ import (
"github.com/sirupsen/logrus"
)
const (
defaultShellPrompt = `\e[0;31m[\u@\h \W]\$ \e[m `
configDir = "/etc/cloudflared/"
)
type SSHServer struct {
ssh.Server
logger *logrus.Logger
shutdownC chan struct{}
}
const DefaultShellPrompt = `\e[0;31m[\u@\h \W]\$ \e[m `
func New(logger *logrus.Logger, address string, shutdownC chan struct{}) (*SSHServer, error) {
currentUser, err := user.Current()
if err != nil {
return nil, err
}
if currentUser.Uid != "0" {
return nil, errors.New("cloudflared ssh server needs to run as root")
return nil, errors.New("cloudflared SSH server needs to run as root")
}
sshServer := SSHServer{ssh.Server{Addr: address}, logger, shutdownC}
if err := sshServer.configureHostKeys(); err != nil {
return nil, err
}
return &sshServer, nil
}
@@ -85,7 +92,7 @@ func (s *SSHServer) connectionHandler(session ssh.Session) {
}
cmd.Env = append(cmd.Env, fmt.Sprintf("TERM=%s", ptyReq.Term))
cmd.Env = append(cmd.Env, fmt.Sprintf("PS1=%s", DefaultShellPrompt))
cmd.Env = append(cmd.Env, fmt.Sprintf("PS1=%s", defaultShellPrompt))
psuedoTTY, err := pty.Start(cmd)
if err != nil {
s.logger.WithError(err).Error("Failed to start pty session")