1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
|
package MasterServer;
our (%S, $ROOT);
our %S = (
################################################################################
# Masterserver HOST information #
# #
# Please fill in your contact details here, for two-way synchronization and #
# for your users to be able to contact you. #
# #
# Values may not contain backslashes and quotes: no \ or \\, nor ' and ", #
# unless you know exactly what you're doing! #
# #
################################################################################
# example: 333networks -- http://master.333networks.com -- info@333networks.com
contact_details => '333networks -- http://master.333networks.com -- info@333networks.com',
# host address
masterserver_address => 'master.333networks.com',
################################################################################
# Database Login Configuration #
# #
# Login credentials for the database that was created manually before. #
# Yes, that means that you need to create the database and tables on your own. #
# Use only one option: Postgresql, SQLite (or future: MySQL) #
# #
################################################################################
# Postgresql
dblogin => ['dbi:Pg:dbname=database_name', 'username', 'password'],
# SQLite
#dblogin => ["dbi:SQLite:dbname=$ROOT/data/database_name.db",'',''],
# MySQL
#dblogin => ["dbi:mysql:database=database_name;host=localhost;port=3306",'user','password'],
################################################################################
# Logging configuration #
# #
# All messages are printed to the log (and screen) by default. The following #
# settings determine the file locatioin and which messages are suppressed. #
# #
################################################################################
# log file location (folder name!)
log_dir => "$ROOT/log/",
#new log for every period of time? options: daily, weekly, monthly, yearly, none
log_rotate => "weekly",
# print to screen (1=yes, 0=no)
printlog => 1,
# which messages do you NOT want to see in the logs (and screen)?
suppress => "none", # show all entries
# suppress the most annoying messages
#suppress => "add update delete read tcp udp query secure hostname",
# print database errors
db_print => 0,
################################################################################
# Network settings #
# #
# Beacon UDP port (beacons) and Browser TCP port (serverlist) #
# Settings for games that require different data formats #
# #
################################################################################
# port settings
listen_port => 28900, # default 28900
beacon_port => 27900, # default 27900
# these games require a special hex format instead of \ip\ip:port\
hex_format => "bcommander",
################################################################################
# Secure/Validate configuration #
# #
# Which servers have to validate? Which games may be ignored? #
# #
################################################################################
# disable checks, all games pass as validated (0=validate only, 1=don't check)
debug_validate => 0,
# accept only servers that pass the secure/validate challenge, takes longer
require_secure_beacons => 0,
# ignore keys from games that use multiple keys or do not support keys at all
ignore_beacon_key => "deusex ut",
ignore_browser_key => "deusex",
################################################################################
# Enable + Timer settings #
# #
# When does what process start? Format: after [s], interval [s], #
# maximum cycle time [s] (optional) #
# Wait 60+ seconds before starting timers for incoming beacons #
# #
################################################################################
# Query UCC-based applets
master_applet_enabled => 1,
master_applet_time => [90, 1200],
# Synchronization with other 333networks-based masterservers
sync_enabled => 1, # 0 = disabled
sync_time => [180, 1200],
# Beacon Checker query all addresses in the database, requesting "basic" and
# "info". Execute at least twice per hour, to avoid time-outs in own data.
# disabling breaks support for certain games [citation needed].
beacon_checker_enabled => 1,
beacon_checker_time => [60, 0.5, 1800],
# Collect server information for the 333networks main site. Identical
# mechanism as the Beacon Checker. Disable when not interested in UT info
# for your website.
# NB: with some work it can be adapted to work with any other game. Own risk.
utserver_query_enabled => 1,
utserver_query_time => [75, 0.15, 240],
# Maintenance duties like cleaning out old servers/players
maintenance_time => [3600, 300],
################################################################################
# Synchronization settings #
# #
# Request the masterlist for selected or all games from other 333networks- #
# based masterservers. #
# #
################################################################################
# additional masters to sync with (in addition to db-entries)
sync_masters => [
{ address => "master.333networks.com", port => 28900 }, # default
{ address => "master.noccer.de", port => 28900 },
{ address => "master.oldunreal.com", port => 28900 },
{ address => "master.errorist.tk", port => 28900 },
],
# sync all or selected games?
# 0 = all, 1 + gamenames = selected
sync_games => [0],
#sync_games => [1, "ut unreal"],
################################################################################
# Query UCC Applets #
# #
# Request the masterlist for single games from the remote UCC applet or #
# equivalent. #
# #
################################################################################
# remote applets to be queried
master_applet => [
{ip => "utmaster.epicgames.com", port => 28900, game => "ut"},
{ip => "master.hypercoop.tk", port => 28900, game => "unreal"},
{ip => "master.newbiesplayground.net", port => 28900, game => "unreal"},
{ip => "master.hlkclan.net", port => 28900, game => "unreal"},
],
); #end %S
################################################################################
# #
# Supported Games. #
# #
# List of games that are supported by the 333networks masterserver. Note that #
# adding a game does not necessarily mean that suddenly the protocol will #
# be supported. #
# #
################################################################################
require "$ROOT/data/supportedgames.pl";
1;
|