Improved connection handling
This commit is contained in:
@ -1,11 +1,19 @@
|
||||
extends NetworkNode
|
||||
|
||||
## Port number.
|
||||
@export var port := 4242
|
||||
|
||||
## Timeout in milliseconds.
|
||||
@export var timeout := 5000
|
||||
|
||||
## Maximum number of pending connections.
|
||||
@export var max_pending_connections := 4096
|
||||
|
||||
var server := UDPServer.new()
|
||||
var last_statistics := Time.get_ticks_msec()
|
||||
var clients := {}
|
||||
var packet_count := 0
|
||||
var now := 0
|
||||
|
||||
func _init():
|
||||
super._init()
|
||||
@ -14,16 +22,44 @@ func _init():
|
||||
|
||||
func _process(_delta):
|
||||
server.poll()
|
||||
now = Time.get_ticks_msec()
|
||||
|
||||
while server.is_connection_available():
|
||||
var peer: PacketPeerUDP = server.take_connection()
|
||||
var address := "%s:%d" % [peer.get_packet_ip(), peer.get_packet_port()]
|
||||
|
||||
if !clients.has(address):
|
||||
var connection = Connection.new()
|
||||
connection.peer = peer
|
||||
clients[address] = connection
|
||||
peer_connected(address)
|
||||
|
||||
clients[address].last_packet = now
|
||||
|
||||
for key in clients:
|
||||
var client = clients[key]
|
||||
var peer = client.peer
|
||||
|
||||
while peer.get_available_packet_count() > 0:
|
||||
var packet = peer.get_packet()
|
||||
handle_packet(packet, peer)
|
||||
client.last_packet = now
|
||||
packet_count += 1
|
||||
|
||||
if Time.get_ticks_msec() > last_statistics + 1000:
|
||||
print("[Server] %d packets per second" % packet_count)
|
||||
if now > last_statistics + 1000:
|
||||
for address in clients.keys():
|
||||
var last_packet_time = clients[address].last_packet
|
||||
|
||||
if now - last_packet_time > timeout:
|
||||
peer_disconnected(address)
|
||||
clients.erase(address)
|
||||
|
||||
print("[Server] %d clients | %d packets" % [clients.size(), packet_count])
|
||||
packet_count = 0
|
||||
last_statistics = Time.get_ticks_msec()
|
||||
|
||||
func peer_connected(_address: String):
|
||||
pass
|
||||
|
||||
func peer_disconnected(address: String):
|
||||
print("TIMEOUT ", address)
|
||||
|
Reference in New Issue
Block a user