New server framework, an example, and compressed packet fixed.

This commit is contained in:
Tnze
2021-11-27 15:25:55 +08:00
parent b909621c58
commit ab63acbd7e
13 changed files with 2792 additions and 69 deletions

80
server/login.go Normal file
View File

@ -0,0 +1,80 @@
package server
import (
"fmt"
"github.com/Tnze/go-mc/data/packetid"
"github.com/Tnze/go-mc/net"
pk "github.com/Tnze/go-mc/net/packet"
"github.com/Tnze/go-mc/offline"
"github.com/Tnze/go-mc/server/auth"
"github.com/google/uuid"
)
type LoginHandler interface {
AcceptLogin(conn *net.Conn, protocol int32) (name string, id uuid.UUID, err error)
}
type MojangLoginHandler struct {
OnlineMode bool
Threshold int
}
func (d *MojangLoginHandler) AcceptLogin(conn *net.Conn, protocol int32) (name string, id uuid.UUID, err error) {
//login start
var p pk.Packet
err = conn.ReadPacket(&p)
if err != nil {
return
}
if p.ID != packetid.LoginStart {
err = wrongPacketErr{expect: packetid.LoginStart, get: p.ID}
return
}
err = p.Scan((*pk.String)(&name)) //decode username as pk.String
if err != nil {
return
}
//auth
if d.OnlineMode {
var resp *auth.Resp
//Auth, Encrypt
resp, err = auth.Encrypt(conn, name)
if err != nil {
return
}
name = resp.Name
id = resp.ID
} else {
// offline-mode UUID
id = offline.NameToUUID(name)
}
//set compression
if d.Threshold >= 0 {
err = conn.WritePacket(pk.Marshal(
packetid.Compress, pk.VarInt(d.Threshold),
))
if err != nil {
return
}
conn.SetThreshold(d.Threshold)
}
// send login success
err = conn.WritePacket(pk.Marshal(packetid.Success,
pk.UUID(id),
pk.String(name),
))
return
}
type wrongPacketErr struct {
expect, get int32
}
func (w wrongPacketErr) Error() string {
return fmt.Sprintf("wrong packet id: expect %#02X, get %#02X", w.expect, w.get)
}