1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
package sshd
import (
"strconv"
"github.com/gliderlabs/ssh"
"cocogo/pkg/auth"
"cocogo/pkg/config"
"cocogo/pkg/logger"
"cocogo/pkg/sshd/handler"
)
var (
conf = config.Conf
)
func StartServer() {
logger.Debug("Load host access key")
hostKey := HostKey{Value: conf.HostKey, Path: conf.HostKeyFile}
signer, err := hostKey.Load()
if err != nil {
logger.Fatal("Load access key error: %s", err)
}
srv := ssh.Server{
Addr: conf.BindHost + ":" + strconv.Itoa(conf.SSHPort),
PasswordHandler: auth.CheckUserPassword,
PublicKeyHandler: auth.CheckUserPublicKey,
KeyboardInteractiveHandler: auth.CheckMFA,
HostSigners: []ssh.Signer{signer},
Version: "coco-v1.4",
Handler: handler.SessionHandler,
}
logger.Fatal(srv.ListenAndServe())
}