2012-06-16 17:44:22 +00:00
|
|
|
require 'logger'
|
|
|
|
|
2012-06-16 04:41:18 +00:00
|
|
|
require 'eventmachine'
|
|
|
|
require 'sequel'
|
|
|
|
|
2012-06-16 17:44:22 +00:00
|
|
|
DB = Sequel.connect("postgres://#{ENV['USER']}@localhost/marco_polo",
|
|
|
|
:max_connections => 10)
|
|
|
|
DB.create_table! :locations do
|
|
|
|
primary_key :id
|
|
|
|
String :client
|
|
|
|
Integer :x
|
|
|
|
Integer :y
|
2012-06-16 04:41:18 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
module MarcoPoloServer
|
|
|
|
def post_init
|
|
|
|
@locations = DB[:locations]
|
|
|
|
end
|
|
|
|
|
|
|
|
def receive_data(data)
|
|
|
|
client, x, y = data.split
|
|
|
|
@locations.insert(:client => client, :x => x.to_i, :y => y.to_i)
|
|
|
|
send_data("thanks\n")
|
|
|
|
rescue => e
|
|
|
|
STDERR.puts("#{e.class.name} #{e.message}: #{e.backtrace.join("\n")}")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
EventMachine.run do
|
|
|
|
host, port = '0.0.0.0', 22000
|
|
|
|
EventMachine.start_server(host, port, MarcoPoloServer)
|
|
|
|
puts "Listening on #{host}:#{port}"
|
|
|
|
end
|