HFish/core/protocol/telnet/telnet.go

120 lines
2.3 KiB
Go
Raw Normal View History

2019-08-10 18:26:43 +08:00
package telnet
import (
"net"
"fmt"
"bufio"
"strings"
"os"
2019-08-11 20:14:28 +08:00
"HFish/utils/is"
"HFish/core/rpc/client"
"strconv"
"HFish/core/report"
"HFish/utils/log"
2019-08-10 18:26:43 +08:00
)
// 服务端连接
func server(address string, exitChan chan int) {
l, err := net.Listen("tcp", address)
if err != nil {
fmt.Println(err.Error())
exitChan <- 1
}
defer l.Close()
for {
conn, err := l.Accept()
if err != nil {
fmt.Println(err.Error())
continue
}
2019-08-11 20:14:28 +08:00
arr := strings.Split(conn.RemoteAddr().String(), ":")
// 判断是否为 RPC 客户端
var id string
if is.Rpc() {
id = client.ReportResult("TELNET", "", arr[0], conn.RemoteAddr().String()+" 已经连接", "0")
} else {
id = strconv.FormatInt(report.ReportTelnet(arr[0], "本机", conn.RemoteAddr().String()+" 已经连接"), 10)
}
log.Pr("Telnet", arr[0], "已经连接")
2019-08-10 18:26:43 +08:00
// 根据连接开启会话, 这个过程需要并行执行
2019-08-11 20:14:28 +08:00
go handleSession(conn, exitChan, id)
2019-08-10 18:26:43 +08:00
}
}
// 会话处理
2019-08-11 20:14:28 +08:00
func handleSession(conn net.Conn, exitChan chan int, id string) {
2019-08-10 18:26:43 +08:00
fmt.Println("Session started")
reader := bufio.NewReader(conn)
for {
str, err := reader.ReadString('\n')
// telnet命令
if err == nil {
str = strings.TrimSpace(str)
2019-08-11 20:14:28 +08:00
if is.Rpc() {
go client.ReportResult("TELNET", "", "", "&&"+str, id)
} else {
go report.ReportUpdateRedis(id, "&&"+str)
}
2019-08-10 18:26:43 +08:00
if !processTelnetCommand(str, exitChan) {
conn.Close()
break
}
2019-08-11 20:14:28 +08:00
conn.Write([]byte("OK" + "\r\n"))
2019-08-10 18:26:43 +08:00
} else {
// 发生错误
fmt.Println("Session closed")
conn.Close()
break
}
}
}
// telent协议命令
func processTelnetCommand(str string, exitChan chan int) bool {
// @close指令表示终止本次会话
if strings.HasPrefix(str, "@close") {
fmt.Println("Session closed")
// 告知外部需要断开连接
return false
// @shutdown指令表示终止服务进程
} else if strings.HasPrefix(str, "@shutdown") {
fmt.Println("Server shutdown")
// 往通道中写入0, 阻塞等待接收方处理
exitChan <- 0
return false
}
// 打印输入的字符串
fmt.Println(str)
return true
}
2019-08-11 20:14:28 +08:00
func Start(addr string) {
2019-08-10 18:26:43 +08:00
// 创建一个程序结束码的通道
exitChan := make(chan int)
// 将服务器并发运行
2019-08-11 20:14:28 +08:00
go server(addr, exitChan)
2019-08-10 18:26:43 +08:00
// 通道阻塞,等待接受返回值
code := <-exitChan
// 标记程序返回值并退出
os.Exit(code)
}