brake changes: support dynamic protocols number in ping list handler.
This commit is contained in:
@ -18,16 +18,26 @@ import (
|
|||||||
// ListPingHandler collect server running status info
|
// ListPingHandler collect server running status info
|
||||||
// which is used to handle client ping and list progress.
|
// which is used to handle client ping and list progress.
|
||||||
type ListPingHandler interface {
|
type ListPingHandler interface {
|
||||||
// Name of the server version
|
// Name of the server.
|
||||||
|
// Vanilla server uses its version name, like "1.19.3".
|
||||||
Name() string
|
Name() string
|
||||||
// Protocol number
|
|
||||||
Protocol() int
|
// The Protocol number.
|
||||||
|
// Usually implemented as returning the protocol number the server currently used.
|
||||||
|
// If the server supports multiple protocols, should be implemented as returning clientProtocol
|
||||||
|
Protocol(clientProtocol int32) int
|
||||||
|
|
||||||
MaxPlayer() int
|
MaxPlayer() int
|
||||||
|
|
||||||
OnlinePlayer() int
|
OnlinePlayer() int
|
||||||
// PlayerSamples is a short list of some player in the server
|
|
||||||
|
// PlayerSamples is a short list of players in the server.
|
||||||
|
// Vanilla server returns up to 10 players in the list.
|
||||||
PlayerSamples() []PlayerSample
|
PlayerSamples() []PlayerSample
|
||||||
|
|
||||||
|
// Description also called MOTD, Message Of The Day.
|
||||||
Description() *chat.Message
|
Description() *chat.Message
|
||||||
|
|
||||||
// FavIcon should be a PNG image that is Base64 encoded
|
// FavIcon should be a PNG image that is Base64 encoded
|
||||||
// (without newlines: \n, new lines no longer work since 1.13)
|
// (without newlines: \n, new lines no longer work since 1.13)
|
||||||
// and prepended with "data:image/png;base64,".
|
// and prepended with "data:image/png;base64,".
|
||||||
@ -41,7 +51,7 @@ type PlayerSample struct {
|
|||||||
ID uuid.UUID `json:"id"`
|
ID uuid.UUID `json:"id"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Server) acceptListPing(conn *net.Conn) {
|
func (s *Server) acceptListPing(conn *net.Conn, clientProtocol int32) {
|
||||||
var p pk.Packet
|
var p pk.Packet
|
||||||
for i := 0; i < 2; i++ { // Ping or List. Only allow check twice
|
for i := 0; i < 2; i++ { // Ping or List. Only allow check twice
|
||||||
err := conn.ReadPacket(&p)
|
err := conn.ReadPacket(&p)
|
||||||
@ -52,7 +62,7 @@ func (s *Server) acceptListPing(conn *net.Conn) {
|
|||||||
switch p.ID {
|
switch p.ID {
|
||||||
case packetid.StatusResponse: // List
|
case packetid.StatusResponse: // List
|
||||||
var resp []byte
|
var resp []byte
|
||||||
resp, err = s.listResp()
|
resp, err = s.listResp(clientProtocol)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
@ -66,7 +76,7 @@ func (s *Server) acceptListPing(conn *net.Conn) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Server) listResp() ([]byte, error) {
|
func (s *Server) listResp(clientProtocol int32) ([]byte, error) {
|
||||||
var list struct {
|
var list struct {
|
||||||
Version struct {
|
Version struct {
|
||||||
Name string `json:"name"`
|
Name string `json:"name"`
|
||||||
@ -82,7 +92,7 @@ func (s *Server) listResp() ([]byte, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
list.Version.Name = s.Name()
|
list.Version.Name = s.Name()
|
||||||
list.Version.Protocol = s.Protocol()
|
list.Version.Protocol = s.Protocol(clientProtocol)
|
||||||
list.Players.Max = s.MaxPlayer()
|
list.Players.Max = s.MaxPlayer()
|
||||||
list.Players.Online = s.OnlinePlayer()
|
list.Players.Online = s.OnlinePlayer()
|
||||||
list.Players.Sample = s.PlayerSamples()
|
list.Players.Sample = s.PlayerSamples()
|
||||||
@ -133,7 +143,7 @@ func (p *PingInfo) Name() string {
|
|||||||
return p.name
|
return p.name
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *PingInfo) Protocol() int {
|
func (p *PingInfo) Protocol(int32) int {
|
||||||
return p.protocol
|
return p.protocol
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -73,7 +73,7 @@ func (s *Server) AcceptConn(conn *net.Conn) {
|
|||||||
|
|
||||||
switch intention {
|
switch intention {
|
||||||
case 1: // list ping
|
case 1: // list ping
|
||||||
s.acceptListPing(conn)
|
s.acceptListPing(conn, protocol)
|
||||||
case 2: // login
|
case 2: // login
|
||||||
name, id, profilePubKey, properties, err := s.AcceptLogin(conn, protocol)
|
name, id, profilePubKey, properties, err := s.AcceptLogin(conn, protocol)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
Reference in New Issue
Block a user