forked from github/server
rename [eressea] section to [game]
This commit is contained in:
parent
d7dd281a6a
commit
6d5749308d
|
@ -1,8 +1,7 @@
|
||||||
[game]
|
[game]
|
||||||
email = Eressea Server <eressea-server@kn-bremen.de>
|
email = eressea-server@kn-bremen.de
|
||||||
|
sender = Eressea Server
|
||||||
name = Eressea
|
name = Eressea
|
||||||
|
|
||||||
[eressea]
|
|
||||||
base = .
|
base = .
|
||||||
report = reports
|
report = reports
|
||||||
verbose = 0
|
verbose = 0
|
||||||
|
|
|
@ -27,13 +27,12 @@ if not os.path.isdir(dir):
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
rootdir = dir
|
rootdir = dir
|
||||||
|
|
||||||
try:
|
|
||||||
game = int(sys.argv[1])
|
game = int(sys.argv[1])
|
||||||
except:
|
|
||||||
game = sys.argv[1]
|
|
||||||
gamedir = os.path.join(rootdir, "game-%d" % (game, ))
|
gamedir = os.path.join(rootdir, "game-%d" % (game, ))
|
||||||
frommail = 'Eressea Server <eressea-server@eressea.kn-bremen.de>'
|
frommail = 'eressea-server@kn-bremen.de'
|
||||||
gamename = 'Eressea'
|
gamename = 'Eressea'
|
||||||
|
sender = '%s Server <%s>' % (gamename, frommail)
|
||||||
|
|
||||||
inifile = os.path.join(gamedir, 'eressea.ini')
|
inifile = os.path.join(gamedir, 'eressea.ini')
|
||||||
if not os.path.exists(inifile):
|
if not os.path.exists(inifile):
|
||||||
print "no such file: " . inifile
|
print "no such file: " . inifile
|
||||||
|
@ -44,6 +43,10 @@ else:
|
||||||
frommail = config.get('game', 'email')
|
frommail = config.get('game', 'email')
|
||||||
if config.has_option('game', 'name'):
|
if config.has_option('game', 'name'):
|
||||||
gamename = config.get('game', 'name')
|
gamename = config.get('game', 'name')
|
||||||
|
if config.has_option('game', 'sender'):
|
||||||
|
sender = config.get('game', 'sender')
|
||||||
|
else:
|
||||||
|
sender = "%s Server <%s>" % (gamename, frommail)
|
||||||
config = None
|
config = None
|
||||||
prefix = 'turn-'
|
prefix = 'turn-'
|
||||||
hostname = gethostname()
|
hostname = gethostname()
|
||||||
|
@ -278,7 +281,7 @@ def copy_orders(message, filename, sender):
|
||||||
# create a file, containing:
|
# create a file, containing:
|
||||||
# game=0 locale=de file=/path/to/filename email=rcpt@domain.to
|
# game=0 locale=de file=/path/to/filename email=rcpt@domain.to
|
||||||
def accept(game, locale, stream, extend=None):
|
def accept(game, locale, stream, extend=None):
|
||||||
global rootdir, orderbase, gamedir, gamename, frommail
|
global rootdir, orderbase, gamedir, gamename, sender
|
||||||
if extend is not None:
|
if extend is not None:
|
||||||
orderbase = orderbase + ".pre-" + extend
|
orderbase = orderbase + ".pre-" + extend
|
||||||
savedir = os.path.join(gamedir, orderbase)
|
savedir = os.path.join(gamedir, orderbase)
|
||||||
|
@ -288,21 +291,21 @@ def accept(game, locale, stream, extend=None):
|
||||||
if not os.path.exists(savedir): os.mkdir(savedir)
|
if not os.path.exists(savedir): os.mkdir(savedir)
|
||||||
# parse message
|
# parse message
|
||||||
message = Parser().parse(stream)
|
message = Parser().parse(stream)
|
||||||
sender = get_sender(message)
|
email = get_sender(message)
|
||||||
logger = logging.getLogger(sender)
|
logger = logging.getLogger(email)
|
||||||
# write syslog
|
# write syslog
|
||||||
if sender is None or valid_email(sender)==0:
|
if email is None or valid_email(email)==0:
|
||||||
logger.warning("invalid email address: " + str(sender))
|
logger.warning("invalid email address: " + str(email))
|
||||||
return -1
|
return -1
|
||||||
logger.info("received orders from " + sender)
|
logger.info("received orders from " + email)
|
||||||
# get an available filename
|
# get an available filename
|
||||||
lock_file(gamedir + "/orders.queue")
|
lock_file(gamedir + "/orders.queue")
|
||||||
maxdate, filename = available_file(savedir, prefix + sender)
|
maxdate, filename = available_file(savedir, prefix + email)
|
||||||
if filename is None:
|
if filename is None:
|
||||||
logger.warning("more than " + str(maxfiles) + " orders from " + sender)
|
logger.warning("more than " + str(maxfiles) + " orders from " + email)
|
||||||
return -1
|
return -1
|
||||||
# copy the orders to the file
|
# copy the orders to the file
|
||||||
text_ok = copy_orders(message, filename, sender)
|
text_ok = copy_orders(message, filename, email)
|
||||||
unlock_file(gamedir + "/orders.queue")
|
unlock_file(gamedir + "/orders.queue")
|
||||||
|
|
||||||
warning, msg, fail = None, "", False
|
warning, msg, fail = None, "", False
|
||||||
|
@ -312,47 +315,47 @@ def accept(game, locale, stream, extend=None):
|
||||||
os.utime(filename, (turndate, turndate))
|
os.utime(filename, (turndate, turndate))
|
||||||
logger.debug("mail date is '%s' (%d)" % (maildate, turndate))
|
logger.debug("mail date is '%s' (%d)" % (maildate, turndate))
|
||||||
if turndate < maxdate:
|
if turndate < maxdate:
|
||||||
logger.warning("inconsistent message date " + sender)
|
logger.warning("inconsistent message date " + email)
|
||||||
warning = " (" + messages["warning-" + locale] + ")"
|
warning = " (" + messages["warning-" + locale] + ")"
|
||||||
msg = msg + formatpar(messages["maildate-" + locale] % (ctime(maxdate),ctime(turndate)), 76, 2) + "\n"
|
msg = msg + formatpar(messages["maildate-" + locale] % (ctime(maxdate),ctime(turndate)), 76, 2) + "\n"
|
||||||
else:
|
else:
|
||||||
logger.warning("missing message date " + sender)
|
logger.warning("missing message date " + email)
|
||||||
warning = " (" + messages["warning-" + locale] + ")"
|
warning = " (" + messages["warning-" + locale] + ")"
|
||||||
msg = msg + formatpar(messages["nodate-" + locale], 76, 2) + "\n"
|
msg = msg + formatpar(messages["nodate-" + locale], 76, 2) + "\n"
|
||||||
|
|
||||||
if not text_ok:
|
if not text_ok:
|
||||||
warning = " (" + messages["error-" + locale] + ")"
|
warning = " (" + messages["error-" + locale] + ")"
|
||||||
msg = msg + formatpar(messages["multipart-" + locale], 76, 2) + "\n"
|
msg = msg + formatpar(messages["multipart-" + locale], 76, 2) + "\n"
|
||||||
logger.warning("rejected - no text/plain in orders from " + sender)
|
logger.warning("rejected - no text/plain in orders from " + email)
|
||||||
os.unlink(filename)
|
os.unlink(filename)
|
||||||
savedir = savedir + "/rejected"
|
savedir = savedir + "/rejected"
|
||||||
if not os.path.exists(savedir): os.mkdir(savedir)
|
if not os.path.exists(savedir): os.mkdir(savedir)
|
||||||
lock_file(gamedir + "/orders.queue")
|
lock_file(gamedir + "/orders.queue")
|
||||||
maxdate, filename = available_file(savedir, prefix + sender)
|
maxdate, filename = available_file(savedir, prefix + email)
|
||||||
store_message(message, filename)
|
store_message(message, filename)
|
||||||
unlock_file(gamedir + "/orders.queue")
|
unlock_file(gamedir + "/orders.queue")
|
||||||
fail = True
|
fail = True
|
||||||
|
|
||||||
if sendmail and warning is not None:
|
if sendmail and warning is not None:
|
||||||
subject = gamename + " " + messages["subject-"+locale] + warning
|
subject = gamename + " " + messages["subject-"+locale] + warning
|
||||||
mail = "Subject: %s\nFrom: %s\nTo: %s\n\n" % (subject, frommail, sender) + msg
|
mail = "Subject: %s\nFrom: %s\nTo: %s\n\n" % (subject, sender, email) + msg
|
||||||
from smtplib import SMTP
|
from smtplib import SMTP
|
||||||
server = SMTP("localhost")
|
server = SMTP("localhost")
|
||||||
server.sendmail(frommail, sender, mail)
|
server.sendmail(sender, email, mail)
|
||||||
server.close()
|
server.close()
|
||||||
|
|
||||||
if not sendmail:
|
if not sendmail:
|
||||||
print text_ok, fail, sender
|
print text_ok, fail, email
|
||||||
print filename
|
print filename
|
||||||
|
|
||||||
if not fail:
|
if not fail:
|
||||||
lock_file(gamedir + "/orders.queue")
|
lock_file(gamedir + "/orders.queue")
|
||||||
queue = open(gamedir + "/orders.queue", "a")
|
queue = open(gamedir + "/orders.queue", "a")
|
||||||
queue.write("email=%s file=%s locale=%s game=%s\n" % (sender, filename, locale, game))
|
queue.write("email=%s file=%s locale=%s game=%s\n" % (email, filename, locale, game))
|
||||||
queue.close()
|
queue.close()
|
||||||
unlock_file(gamedir + "/orders.queue")
|
unlock_file(gamedir + "/orders.queue")
|
||||||
|
|
||||||
logger.info("done - accepted orders from " + sender)
|
logger.info("done - accepted orders from " + email)
|
||||||
|
|
||||||
return 0
|
return 0
|
||||||
|
|
||||||
|
|
|
@ -2,7 +2,9 @@
|
||||||
# -*- coding: iso-8859-1 -*-
|
# -*- coding: iso-8859-1 -*-
|
||||||
|
|
||||||
from os import unlink, symlink, rename, popen, tmpfile
|
from os import unlink, symlink, rename, popen, tmpfile
|
||||||
from os.path import exists
|
import os
|
||||||
|
import os.path
|
||||||
|
import ConfigParser
|
||||||
from re import compile, IGNORECASE
|
from re import compile, IGNORECASE
|
||||||
from string import split, join, upper, strip
|
from string import split, join, upper, strip
|
||||||
from sys import argv, exit
|
from sys import argv, exit
|
||||||
|
@ -14,9 +16,8 @@ from epasswd import EPasswd
|
||||||
def pwd_get_email(faction, pwd, pwdfile=None):
|
def pwd_get_email(faction, pwd, pwdfile=None):
|
||||||
return None
|
return None
|
||||||
|
|
||||||
def splitfilename(filename):
|
def split_filename(filename):
|
||||||
from os.path import split
|
return os.path.split(filename)
|
||||||
return split(filename)
|
|
||||||
|
|
||||||
def unlock_file(filename):
|
def unlock_file(filename):
|
||||||
try:
|
try:
|
||||||
|
@ -28,7 +29,7 @@ def unlock_file(filename):
|
||||||
def lock_file(filename):
|
def lock_file(filename):
|
||||||
i = 0
|
i = 0
|
||||||
wait = 1
|
wait = 1
|
||||||
if not exists(filename):
|
if not os.path.exists(filename):
|
||||||
file=open(filename, "w")
|
file=open(filename, "w")
|
||||||
file.close()
|
file.close()
|
||||||
while True:
|
while True:
|
||||||
|
@ -62,17 +63,47 @@ messages = {
|
||||||
"error-en": "Error",
|
"error-en": "Error",
|
||||||
}
|
}
|
||||||
|
|
||||||
|
game = int(sys.argv[1])
|
||||||
|
echeck_cmd = "/home/eressea/echeck/echeck.sh"
|
||||||
|
maxlines = 25
|
||||||
|
|
||||||
# base directory for all your games:
|
# base directory for all your games:
|
||||||
rootdir = "/home/eressea/eressea"
|
install_dir = "/home/eressea/eressea"
|
||||||
frommail = "Eressea Server <eressea-server@eressea.kn-bremen.de>"
|
if 'ERESSEA' in os.environ:
|
||||||
orderbase = "orders.dir"
|
install_dir = os.environ['ERESSEA']
|
||||||
sendmail = True
|
elif 'HOME' in os.environ:
|
||||||
maxlines = 25
|
install_dir = os.path.join(os.environ['HOME'], '/eressea')
|
||||||
echeck_cmd = "/home/eressea/echeck/echeck.sh"
|
if not os.path.isdir(install_dir):
|
||||||
|
print "please set the ERESSEA environment variable to the install path"
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
|
game_dir = os.path.join(install_dir, "game-%d" % (game, ))
|
||||||
|
frommail = 'eressea-server@kn-bremen.de'
|
||||||
|
gamename = 'Eressea'
|
||||||
|
sender = '%s Server <%s>' % (gamename, frommail)
|
||||||
|
|
||||||
|
inifile = os.path.join(gamedir, 'eressea.ini')
|
||||||
|
if not os.path.exists(inifile):
|
||||||
|
print "no such file: " . inifile
|
||||||
|
else:
|
||||||
|
config = ConfigParser.ConfigParser()
|
||||||
|
config.read(inifile)
|
||||||
|
if config.has_option('game', 'email'):
|
||||||
|
frommail = config.get('game', 'email')
|
||||||
|
if config.has_option('game', 'name'):
|
||||||
|
gamename = config.get('game', 'name')
|
||||||
|
if config.has_option('game', 'sender'):
|
||||||
|
sender = config.get('game', 'sender')
|
||||||
|
else:
|
||||||
|
sender = "%s Server <%s>" % (gamename, frommail)
|
||||||
|
config = None
|
||||||
|
|
||||||
|
queue_file = os.path.join(game_dir, "orders.queue")
|
||||||
|
if not os.path.exists(queue_file):
|
||||||
|
exit(0)
|
||||||
|
|
||||||
# regular expression that finds the start of a faction
|
# regular expression that finds the start of a faction
|
||||||
fact_re = compile("^\s*(eressea|vinyambar|partei|faction)\s+([a-zA-Z0-9]+)\s+\"?([^\"]*)\"?", IGNORECASE)
|
fact_re = compile("^\s*(eressea|partei|faction)\s+([a-zA-Z0-9]+)\s+\"?([^\"]*)\"?", IGNORECASE)
|
||||||
|
|
||||||
def check_pwd(filename, email, pw_data):
|
def check_pwd(filename, email, pw_data):
|
||||||
results = []
|
results = []
|
||||||
|
@ -98,7 +129,7 @@ def check_pwd(filename, email, pw_data):
|
||||||
return results
|
return results
|
||||||
|
|
||||||
def echeck(filename, locale, rules):
|
def echeck(filename, locale, rules):
|
||||||
dirname, filename = splitfilename(filename)
|
dirname, filename = split_filename(filename)
|
||||||
stream = popen("%s %s %s %s %s" % (echeck_cmd, locale, filename, dirname, rules), 'r')
|
stream = popen("%s %s %s %s %s" % (echeck_cmd, locale, filename, dirname, rules), 'r')
|
||||||
lines = stream.readlines()
|
lines = stream.readlines()
|
||||||
if len(lines)==0:
|
if len(lines)==0:
|
||||||
|
@ -111,14 +142,6 @@ def echeck(filename, locale, rules):
|
||||||
stream.close()
|
stream.close()
|
||||||
return mail
|
return mail
|
||||||
|
|
||||||
## the main body of the script
|
|
||||||
game = int(argv[1])
|
|
||||||
|
|
||||||
basedir = rootdir + "/game-%d" % (game, )
|
|
||||||
queuename = basedir + "/orders.queue"
|
|
||||||
if not exists(queuename):
|
|
||||||
exit(0)
|
|
||||||
|
|
||||||
# parse the queue file -
|
# parse the queue file -
|
||||||
#print "connecting to SMTP..."
|
#print "connecting to SMTP..."
|
||||||
from smtplib import SMTP
|
from smtplib import SMTP
|
||||||
|
@ -127,16 +150,17 @@ try:
|
||||||
except:
|
except:
|
||||||
print "could not connect to SMTP server"
|
print "could not connect to SMTP server"
|
||||||
exit(0)
|
exit(0)
|
||||||
|
|
||||||
#print "reading password file..."
|
#print "reading password file..."
|
||||||
pw_data = EPasswd(basedir + "/passwd")
|
pw_data = EPasswd(os.path.join(game_dir,"passwd"))
|
||||||
|
|
||||||
#print "reading orders.queue..."
|
#print "reading orders.queue..."
|
||||||
# move the queue file to a save space while locking it:
|
# move the queue file to a save space while locking it:
|
||||||
try:
|
try:
|
||||||
lock_file(queuename)
|
lock_file(queue_file)
|
||||||
except:
|
except:
|
||||||
exit(0)
|
exit(0)
|
||||||
queuefile = open(queuename, "r")
|
queuefile = open(queue_file, "r")
|
||||||
lines = queuefile.readlines()
|
lines = queuefile.readlines()
|
||||||
queuefile.close()
|
queuefile.close()
|
||||||
|
|
||||||
|
@ -154,9 +178,9 @@ tmpfile.close()
|
||||||
|
|
||||||
openlog("orders")
|
openlog("orders")
|
||||||
|
|
||||||
unlink(queuename)
|
unlink(queue_file)
|
||||||
try:
|
try:
|
||||||
unlock_file(queuename)
|
unlock_file(queue_file)
|
||||||
except:
|
except:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
@ -170,15 +194,15 @@ for line in lines:
|
||||||
email = dict["email"]
|
email = dict["email"]
|
||||||
locale = dict["locale"]
|
locale = dict["locale"]
|
||||||
game = int(dict["game"])
|
game = int(dict["game"])
|
||||||
file = dict["file"]
|
infile = dict["file"]
|
||||||
gamename='[E%d]' % game
|
gamename='[E%d]' % game
|
||||||
rules='e%d' % game
|
rules='e%d' % game
|
||||||
warning = ""
|
warning = ""
|
||||||
failed = True
|
failed = True
|
||||||
results = check_pwd(file, email, pw_data)
|
results = check_pwd(infile, email, pw_data)
|
||||||
logfile = open(basedir+"/zug.log", "a")
|
logfile = open(os.path.join(game_dir, "zug.log"), "a")
|
||||||
dirname, filename = splitfilename(file)
|
dirname, filename = split_filename(infile)
|
||||||
msg = messages["validate-"+locale] + " " + filename + "\n\n"
|
msg = messages["validate-"+locale] + " " + infilename + "\n\n"
|
||||||
for faction, game_email, success, pwd in results:
|
for faction, game_email, success, pwd in results:
|
||||||
msg = msg + messages["faction-"+locale] + " " + faction + "\n"
|
msg = msg + messages["faction-"+locale] + " " + faction + "\n"
|
||||||
if success: failed = False
|
if success: failed = False
|
||||||
|
@ -189,25 +213,24 @@ for line in lines:
|
||||||
|
|
||||||
if failed:
|
if failed:
|
||||||
warning = " (" + messages["warning-" + locale] + ")"
|
warning = " (" + messages["warning-" + locale] + ")"
|
||||||
syslog("failed - no valid password in " + file)
|
syslog("failed - no valid password in " + infile)
|
||||||
else:
|
else:
|
||||||
result = echeck(file, locale, rules)
|
result = None
|
||||||
if email=='eressea':
|
if os.path.exists(echeck_cmd):
|
||||||
print result
|
result = echeck(infile, locale, rules)
|
||||||
continue
|
if result is None:
|
||||||
elif result is None:
|
|
||||||
# echeck did not finish
|
# echeck did not finish
|
||||||
msg = msg + "Echeck was killed. Your turn was accepted, but could not be verified.\n"
|
msg = msg + "Echeck is broken. Your turn was accepted, but could not be verified.\n"
|
||||||
warning = " (" + messages["warning-" + locale] + ")"
|
warning = " (" + messages["warning-" + locale] + ")"
|
||||||
syslog("process - echeck got killed, " + file)
|
syslog("process - echeck broken, " + infile)
|
||||||
else:
|
else:
|
||||||
msg = msg + result
|
msg = msg + result
|
||||||
syslog("process - checked orders in " + file)
|
syslog("process - checked orders in " + infile)
|
||||||
|
|
||||||
subject = gamename + " " + messages["subject-" + locale] + warning
|
subject = gamename + " " + messages["subject-" + locale] + warning
|
||||||
msg = "Subject: %s\nFrom: %s\nTo: %s\nContent-Type: text/plain; charset=utf-8\n\n" % (subject, frommail, email) + msg
|
msg = "Subject: %s\nFrom: %s\nTo: %s\nContent-Type: text/plain; charset=utf-8\n\n" % (subject, sender, email) + msg
|
||||||
try:
|
try:
|
||||||
server.sendmail(frommail, email, msg)
|
server.sendmail(sender, email, msg)
|
||||||
except:
|
except:
|
||||||
syslog("failed - cannot send to " + email)
|
syslog("failed - cannot send to " + email)
|
||||||
|
|
||||||
|
|
4
s/setup
4
s/setup
|
@ -94,8 +94,8 @@ touch eressea.ini
|
||||||
}
|
}
|
||||||
|
|
||||||
ini_start
|
ini_start
|
||||||
ini_sec eressea
|
ini_sec game
|
||||||
ini_add eressea locales de,en
|
ini_add game locales de,en
|
||||||
ini_sec lua
|
ini_sec lua
|
||||||
ini_add lua install $SOURCE
|
ini_add lua install $SOURCE
|
||||||
ini_add lua paths $SOURCE/scripts:$SOURCE/lunit
|
ini_add lua paths $SOURCE/scripts:$SOURCE/lunit
|
||||||
|
|
14
src/main.c
14
src/main.c
|
@ -54,23 +54,23 @@ static void load_inifile(dictionary * d)
|
||||||
|
|
||||||
assert(d);
|
assert(d);
|
||||||
|
|
||||||
str = iniparser_getstring(d, "eressea:base", basedir);
|
str = iniparser_getstring(d, "game:base", basedir);
|
||||||
if (str != basedir) {
|
if (str != basedir) {
|
||||||
set_basepath(str);
|
set_basepath(str);
|
||||||
}
|
}
|
||||||
str = iniparser_getstring(d, "eressea:report", reportdir);
|
str = iniparser_getstring(d, "game:report", reportdir);
|
||||||
if (str != reportdir) {
|
if (str != reportdir) {
|
||||||
set_reportpath(str);
|
set_reportpath(str);
|
||||||
}
|
}
|
||||||
str = iniparser_getstring(d, "eressea:data", datadir);
|
str = iniparser_getstring(d, "game:data", datadir);
|
||||||
if (str != datadir) {
|
if (str != datadir) {
|
||||||
set_datapath(str);
|
set_datapath(str);
|
||||||
}
|
}
|
||||||
|
|
||||||
lomem = iniparser_getint(d, "eressea:lomem", lomem) ? 1 : 0;
|
lomem = iniparser_getint(d, "game:lomem", lomem) ? 1 : 0;
|
||||||
|
|
||||||
verbosity = iniparser_getint(d, "eressea:verbose", 2);
|
verbosity = iniparser_getint(d, "game:verbose", 2);
|
||||||
str = iniparser_getstring(d, "eressea:locales", "de,en");
|
str = iniparser_getstring(d, "game:locales", "de,en");
|
||||||
make_locales(str);
|
make_locales(str);
|
||||||
|
|
||||||
if (global.inifile) iniparser_freedict(global.inifile);
|
if (global.inifile) iniparser_freedict(global.inifile);
|
||||||
|
@ -84,7 +84,7 @@ static void parse_config(const char *filename)
|
||||||
load_inifile(d);
|
load_inifile(d);
|
||||||
log_debug("reading from configuration file %s\n", filename);
|
log_debug("reading from configuration file %s\n", filename);
|
||||||
|
|
||||||
memdebug = iniparser_getint(d, "eressea:memcheck", memdebug);
|
memdebug = iniparser_getint(d, "game:memcheck", memdebug);
|
||||||
#ifdef USE_CURSES
|
#ifdef USE_CURSES
|
||||||
/* only one value in the [editor] section */
|
/* only one value in the [editor] section */
|
||||||
force_color = iniparser_getint(d, "editor:color", force_color);
|
force_color = iniparser_getint(d, "editor:color", force_color);
|
||||||
|
|
Loading…
Reference in New Issue