gopenfusion/server/server.go

89 lines
2.0 KiB
Go
Raw Normal View History

package main
import (
"fmt"
"log"
"net"
2023-03-07 08:06:40 +00:00
"github.com/CPunch/GopenFusion/protocol"
)
2023-03-05 08:14:36 +00:00
type Server struct {
listener net.Listener
clients map[*Client]bool
unregister chan *Client
}
2023-03-05 08:14:36 +00:00
func newServer() *Server {
listener, err := net.Listen("tcp", ":23000")
if err != nil {
log.Fatal(err)
}
2023-03-05 08:14:36 +00:00
return &Server{
listener: listener,
clients: make(map[*Client]bool),
unregister: make(chan *Client),
}
}
2023-03-05 08:14:36 +00:00
func (server *Server) Start() {
log.Print("Server hosted on 127.0.0.1:23000")
for {
2023-03-05 08:14:36 +00:00
select {
case client := <-server.unregister:
delete(server.clients, client)
fmt.Printf("Client %p disconnected\n", client)
default:
2023-03-05 08:14:36 +00:00
conn, err := server.listener.Accept()
if err != nil {
log.Println("Connection error: ", err)
return
}
client := newClient(server, conn)
2023-03-05 08:14:36 +00:00
server.clients[client] = true
go client.ClientHandler()
fmt.Printf("Client %p connected\n", client)
}
}
}
2023-03-07 08:06:40 +00:00
func (server *Server) handlePacket(client *Client, typeID uint32, pkt *protocol.Packet) {
switch typeID {
case protocol.P_CL2LS_REQ_LOGIN:
var loginPkt protocol.SP_CL2LS_REQ_LOGIN
pkt.Decode(&loginPkt)
// TODO: for now, we're a dummy server
client.AcceptLogin(loginPkt.SZID, loginPkt.IClientVerC, 1, []protocol.SP_LS2CL_REP_CHAR_INFO{})
case protocol.P_CL2LS_REQ_CHECK_CHAR_NAME:
var charPkt protocol.SP_CL2LS_REQ_CHECK_CHAR_NAME
pkt.Decode(&charPkt)
client.Send(&protocol.SP_LS2CL_REP_CHECK_CHAR_NAME_SUCC{
SZFirstName: charPkt.SZFirstName,
SZLastName: charPkt.SZLastName,
}, protocol.P_LS2CL_REP_CHECK_CHAR_NAME_SUCC)
case protocol.P_CL2LS_REQ_SAVE_CHAR_NAME:
var charPkt protocol.SP_CL2LS_REQ_SAVE_CHAR_NAME
pkt.Decode(&charPkt)
client.Send(&protocol.SP_LS2CL_REP_SAVE_CHAR_NAME_SUCC{
IPC_UID: 1,
ISlotNum: charPkt.ISlotNum,
IGender: charPkt.IGender,
SZFirstName: charPkt.SZFirstName,
SZLastName: charPkt.SZLastName,
}, protocol.P_LS2CL_REP_SAVE_CHAR_NAME_SUCC)
default:
log.Printf("[WARN] unsupported packet ID: %x\n", typeID)
}
}
func main() {
2023-03-05 08:14:36 +00:00
server := newServer()
server.Start()
}