Ensure tokens being in correct format

This commit is contained in:
ChillerDragon 2022-11-12 12:51:09 +01:00
parent e3292deb15
commit 11898d0f41
4 changed files with 44 additions and 20 deletions

View file

@ -1,12 +1,15 @@
# frozen_string_literal: true
require_relative 'token'
##
# NetBase
#
# Lowest network layer logic. Sends packets via udp.
# Also adding the teeworlds protocol packet header.
class NetBase
attr_accessor :peer_token, :ack
attr_accessor :ack
attr_reader :peer_token
def initialize(opts = {})
@verbose = opts[:verbose] || false
@ -28,6 +31,11 @@ class NetBase
@ack = 0
end
def set_peer_token(token)
SecurityToken.validate(token)
@peer_token = token
end
##
# Sends a packing setting the proper header for you
#

View file

@ -281,7 +281,7 @@ class TeeworldsClient
data += Packer.pack_int(inp[:wanted_weapon])
data += Packer.pack_int(inp[:next_weapon])
data += Packer.pack_int(inp[:prev_weapon])
msg = NetChunk.createl_header(vital: false, size: data.size + 1) +
msg = NetChunk.create_header(vital: false, size: data.size + 1) +
[pack_msg_id(NETMSG_INPUT, system: true)] +
data
@netbase.send_packet(msg, 1)
@ -289,7 +289,7 @@ class TeeworldsClient
def on_msg_token(data)
@token = bytes_to_str(data)
@netbase.peer_token = @token
@netbase.set_peer_token(@token)
puts "Got token #{@token}"
send_msg_connect
end

View file

@ -13,6 +13,7 @@ require_relative 'net_addr'
require_relative 'packer'
require_relative 'game_server'
require_relative 'message'
require_relative 'token'
class Client
attr_accessor :id, :addr, :vital_sent, :last_recv_time, :token
@ -21,14 +22,9 @@ class Client
@id = attr[:id]
@addr = attr[:addr]
@vital_sent = 0
@token = attr[:token]
unless @token.size == 4
raise "Invalid client token size\n" \
"got=#{@token.size} expected=4\n" \
"#{str_hex(@token)}"
end
@last_recv_time = Time.now
@token = attr[:token]
SecurityToken.validate(@token)
end
# TODO: use or remove
@ -145,16 +141,16 @@ class TeeworldsServer
def send_ctrl_close(client, reason)
msg = [NET_CTRLMSG_CLOSE]
msg += Packer.pack_str(reason) unless reason.nil?
@netbase.peer_token = client.token
@netbase.set_peer_token(client.token)
@netbase.send_packet(msg, 0, control: true, addr: client.addr)
# @netbase.peer_token = @server_token
# @netbase.set_peer_token(@server_token)
end
def send_ctrl_with_token(addr, token)
msg = [NET_CTRLMSG_TOKEN] + str_bytes(@server_token)
@netbase.peer_token = token
@netbase.set_peer_token(token)
@netbase.send_packet(msg, 0, control: true, addr:)
# @netbase.peer_token = @server_token
# @netbase.set_peer_token(@server_token)
end
def send_map(client)
@ -200,9 +196,9 @@ class TeeworldsServer
def on_ctrl_token(packet)
u = Unpacker.new(packet.payload[1..])
token = u.get_raw(4)
token = token.map { |b| b.to_s(16).rjust(2, '0') }.join
puts "got token #{token}"
send_ctrl_with_token(packet.addr, token)
token_str = token.map { |b| b.to_s(16).rjust(2, '0') }.join
puts "got token #{token_str}"
send_ctrl_with_token(packet.addr, token_str)
end
def on_ctrl_keep_alive(packet)
@ -214,14 +210,14 @@ class TeeworldsServer
end
def on_ctrl_connect(packet)
puts 'got connection, sending accept'
id = get_next_client_id
if id == -1
puts 'server full drop packet. TODO: tell the client'
return
end
client = Client.new(id:, addr: packet.addr, token: packet.payload[...4])
token = bytes_to_str(packet.payload[...4])
puts "got connection, sending accept (client token: #{token})"
client = Client.new(id:, addr: packet.addr, token:)
@clients[id] = client
@netbase.send_packet([NET_CTRLMSG_ACCEPT], 0, control: true, addr: packet.addr)
end

20
lib/token.rb Normal file
View file

@ -0,0 +1,20 @@
# frozen_string_literal: true
require_relative 'bytes'
class SecurityToken
def self.err_msg(msg, token)
hex = ''
hex = "hex: #{str_hex(token)}\n" if token.instance_of?(String)
"Invalid token! Token should be a human readable hex string!\n" \
" Good sample token: aabbccdd\n" \
" #{msg}\n" \
" token: #{token}:#{token.class}\n" \
" #{hex}"
end
def self.validate(token)
raise err_msg("Expected type: String got: #{token.class}", token) unless token.instance_of?(String)
raise err_msg("Expected size: 8 got: #{token.size}", token) unless token.size == 8
end
end