mirror of
https://gitee.com/lauix/HFish
synced 2025-05-11 04:18:02 +08:00
~ 上钩列表支持批量删除 ~ 上钩列表长度展示 ~ 上钩列表支持集群筛选 ~ 集群页面支持删除 ~ 改用 IPIP 本地库获取地理信息 ~ 支持 WebHook Api 通知 ~ 提供获取上钩列表 API ~ WEB,暗网蜜罐 API 移到各种服务上,抛开 Admin ~ 修复暗网蜜罐使用问题 ~ 修复集群取 IP 错误问题 ~ SSH 高交互支持
118 lines
2.4 KiB
Go
118 lines
2.4 KiB
Go
package server
|
||
|
||
import (
|
||
"HFish/core/rpc/core"
|
||
"HFish/utils/log"
|
||
"HFish/core/report"
|
||
"strconv"
|
||
"net"
|
||
"fmt"
|
||
)
|
||
|
||
// 上报状态结构
|
||
type Status struct {
|
||
AgentIp string
|
||
AgentName string
|
||
Web, Deep, Ssh, Redis, Mysql, Http, Telnet, Ftp string
|
||
}
|
||
|
||
// 上报结果结构
|
||
type Result struct {
|
||
AgentIp string
|
||
AgentName string
|
||
Type string
|
||
ProjectName string
|
||
SourceIp string
|
||
Info string
|
||
Id string // 数据库ID,更新用 0 为新插入数据
|
||
}
|
||
|
||
type HFishRPCService int
|
||
|
||
// 上报状态 RPC 方法
|
||
func (t *HFishRPCService) ReportStatus(s *Status, reply *string) error {
|
||
fmt.Println(s)
|
||
// 上报 客户端 状态
|
||
go report.ReportAgentStatus(
|
||
s.AgentName,
|
||
s.AgentIp,
|
||
s.Web,
|
||
s.Deep,
|
||
s.Ssh,
|
||
s.Redis,
|
||
s.Mysql,
|
||
s.Http,
|
||
s.Telnet,
|
||
s.Ftp,
|
||
)
|
||
|
||
return nil
|
||
}
|
||
|
||
// 上报结果 RPC 方法
|
||
func (t *HFishRPCService) ReportResult(r *Result, reply *string) error {
|
||
var idx string
|
||
|
||
switch r.Type {
|
||
case "WEB":
|
||
go report.ReportWeb(r.ProjectName, r.AgentName, r.SourceIp, r.Info)
|
||
case "DEEP":
|
||
go report.ReportDeepWeb(r.ProjectName, r.AgentName, r.SourceIp, r.Info)
|
||
case "SSH":
|
||
go report.ReportSSH(r.SourceIp, r.AgentName, r.Info)
|
||
case "REDIS":
|
||
if r.Id == "0" {
|
||
id := report.ReportRedis(r.SourceIp, r.AgentName, r.Info)
|
||
idx = strconv.FormatInt(id, 10)
|
||
} else {
|
||
go report.ReportUpdateRedis(r.Id, r.Info)
|
||
}
|
||
case "MYSQL":
|
||
if r.Id == "0" {
|
||
id := report.ReportMysql(r.SourceIp, r.AgentName, r.Info)
|
||
idx = strconv.FormatInt(id, 10)
|
||
} else {
|
||
go report.ReportUpdateMysql(r.Id, r.Info)
|
||
}
|
||
case "TELNET":
|
||
if r.Id == "0" {
|
||
id := report.ReportTelnet(r.SourceIp, r.AgentName, r.Info)
|
||
idx = strconv.FormatInt(id, 10)
|
||
} else {
|
||
go report.ReportUpdateTelnet(r.Id, r.Info)
|
||
}
|
||
case "FTP":
|
||
go report.ReportFTP(r.SourceIp, r.AgentName, r.Info)
|
||
}
|
||
|
||
*reply = idx
|
||
return nil
|
||
}
|
||
|
||
// 启动 RPC 服务端
|
||
func Start(addr string) {
|
||
rpcService := new(HFishRPCService)
|
||
rpc.Register(rpcService)
|
||
|
||
tcpAddr, err := net.ResolveTCPAddr("tcp", addr)
|
||
if err != nil {
|
||
log.Pr("RPC", "127.0.0.1", "RPC Server 启动失败", err)
|
||
}
|
||
|
||
listener, err := net.ListenTCP("tcp", tcpAddr)
|
||
if err != nil {
|
||
log.Pr("RPC", "127.0.0.1", "RPC Server 监听地址失败", err)
|
||
}
|
||
|
||
for {
|
||
conn, err := listener.Accept()
|
||
if err != nil {
|
||
continue
|
||
}
|
||
|
||
fmt.Println(conn.RemoteAddr())
|
||
|
||
rpc.ServeConn(conn)
|
||
}
|
||
}
|