1 |
root |
1.17 |
#! perl # mandatory |
2 |
root |
1.1 |
|
3 |
|
|
# this listens for new tcp connections and hands them over to the server core |
4 |
root |
1.19 |
# whether this being an extension introduces or reduces stability problems |
5 |
root |
1.1 |
# is unknown as of today. |
6 |
|
|
|
7 |
|
|
use Socket; |
8 |
root |
1.12 |
use AnyEvent::Socket; |
9 |
root |
1.1 |
|
10 |
root |
1.20 |
CONF BIND_ADDRESSES = [[undef, 13327]]; |
11 |
|
|
|
12 |
root |
1.24 |
our $MAX_DETECT = 32; # how many bytes to read to identify the protocol |
13 |
root |
1.21 |
|
14 |
root |
1.15 |
our @LISTENERS; |
15 |
root |
1.12 |
|
16 |
root |
1.23 |
sub flash_policy_server { |
17 |
|
|
my ($fh) = @_; |
18 |
|
|
|
19 |
|
|
# socket policy file, just write answer and hope the kernel accepts it in one go |
20 |
|
|
syswrite $fh, <<EOF . "\x00" |
21 |
|
|
<?xml version="1.0"?> |
22 |
|
|
<!DOCTYPE cross-domain-policy SYSTEM "http://www.adobe.com/xml/dtds/cross-domain-policy.dtd"> |
23 |
|
|
<cross-domain-policy> |
24 |
|
|
<allow-access-from domain="*" to-ports="*"/> |
25 |
|
|
</cross-domain-policy> |
26 |
|
|
EOF |
27 |
|
|
} |
28 |
|
|
|
29 |
root |
1.20 |
for (@$BIND_ADDRESSES) { |
30 |
root |
1.12 |
my ($host, $port) = @$_; |
31 |
root |
1.16 |
cf::info "listening on ", (format_hostport $host, $port), "\n"; |
32 |
root |
1.12 |
|
33 |
root |
1.15 |
push @LISTENERS, tcp_server $host, $port, sub { |
34 |
root |
1.12 |
my ($fh, $host, $port) = @_ |
35 |
|
|
or return; |
36 |
|
|
|
37 |
root |
1.18 |
my $lhost = AnyEvent::Socket::format_address |
38 |
|
|
+(AnyEvent::Socket::unpack_sockaddr getsockname $fh)[1]; |
39 |
|
|
|
40 |
root |
1.21 |
my $id = format_hostport $host, $port; |
41 |
|
|
|
42 |
|
|
cf::info "$id: new connection\n" |
43 |
root |
1.18 |
if $lhost ne $host; # do not log connections from the host, e.g. for watchdogs |
44 |
root |
1.12 |
|
45 |
root |
1.21 |
my $buf; |
46 |
|
|
my $w; $w = AE::io $fh, 0, sub { |
47 |
|
|
my $len = sysread $fh, $buf, 512, length $buf; |
48 |
|
|
|
49 |
|
|
if ($len) { |
50 |
|
|
if ($buf =~ /^..version /s) { # deliantra protocol |
51 |
|
|
undef $w; |
52 |
|
|
|
53 |
|
|
my $ns = cf::client::create fileno $fh, $host; |
54 |
|
|
$ns->inbuf_append ($buf); |
55 |
|
|
|
56 |
|
|
} elsif ($buf =~ /^GET / && defined &ext::http::server) { # http or websocket |
57 |
|
|
undef $w; |
58 |
|
|
|
59 |
root |
1.22 |
&ext::http::server ($id, $fh, $buf); |
60 |
root |
1.21 |
|
61 |
root |
1.23 |
} elsif ($buf =~ /^<policy-file-request\/>\x00/) { |
62 |
|
|
undef $w; |
63 |
|
|
|
64 |
|
|
flash_policy_server $fh; |
65 |
|
|
|
66 |
root |
1.21 |
} elsif (length $buf >= $MAX_DETECT) { # unable to detect protocol |
67 |
|
|
undef $w; |
68 |
|
|
|
69 |
|
|
cf::info "$id: protocol detection error\n"; |
70 |
|
|
} |
71 |
|
|
} else { |
72 |
|
|
undef $w; |
73 |
|
|
|
74 |
|
|
cf::info "$id: read error during protocol detection\n"; |
75 |
|
|
} |
76 |
|
|
}; |
77 |
root |
1.12 |
}; |
78 |
root |
1.1 |
} |
79 |
|
|
|