Make dgl-create-chroot -script work again.

Change the dgldir directory layout; all rcfiles, dumps and ttyrecs are now under dgldir/userdata/USERNAME/


git-svn-id: svn://katsu.triplehelix.org/dgamelaunch/trunk@466 db0b04b0-f4d1-0310-9a6d-de3e77497b0e
This commit is contained in:
Pasi Kallinen 2009-10-17 17:34:36 +00:00
parent 2b6b21cb51
commit 39456b7a75
7 changed files with 306 additions and 239 deletions

View File

@ -219,10 +219,10 @@ gen_inprogress_lock (int game, pid_t pid, char* ttyrec_filename)
fl.l_start = 0; fl.l_start = 0;
fl.l_len = 0; fl.l_len = 0;
len = strlen(globalconfig.dglroot) + strlen(myconfig[game]->inprogressdir) + strlen(me->username) + strlen(ttyrec_filename) + 13; len = strlen(dgl_format_str(game, me, myconfig[game]->inprogressdir)) + strlen(me->username) + strlen(ttyrec_filename) + 13;
lockfile = calloc(len, sizeof(char)); lockfile = calloc(len, sizeof(char));
snprintf (lockfile, len, "%s%s%s:%s", globalconfig.dglroot, myconfig[game]->inprogressdir, snprintf (lockfile, len, "%s%s:%s", dgl_format_str(game, me, myconfig[game]->inprogressdir),
me->username, ttyrec_filename); me->username, ttyrec_filename);
fd = open (lockfile, O_WRONLY | O_CREAT, 0644); fd = open (lockfile, O_WRONLY | O_CREAT, 0644);
@ -374,7 +374,7 @@ inprogressmenu (int gameid)
if (sortmode == NUM_SORTMODES) if (sortmode == NUM_SORTMODES)
sortmode = globalconfig.sortmode; sortmode = globalconfig.sortmode;
games = populate_games (gameid, &len); games = populate_games (gameid, &len, me);
games = sort_games (games, len, sortmode); games = sort_games (games, len, sortmode);
while (1) while (1)
@ -471,9 +471,9 @@ inprogressmenu (int gameid)
break; break;
/* valid choice has been made */ /* valid choice has been made */
snprintf (ttyrecname, 130, "%sttyrec/%s", globalconfig.dglroot,
games[menuchoice - 97 + offset]->ttyrec_fn);
chosen_name = strdup (games[menuchoice - 97 + offset]->name); chosen_name = strdup (games[menuchoice - 97 + offset]->name);
snprintf (ttyrecname, 130, "%s",
games[menuchoice - 97 + offset]->ttyrec_fn);
/* reuse the char* */ /* reuse the char* */
replacestr = strchr (ttyrecname, ':'); replacestr = strchr (ttyrecname, ':');
@ -481,7 +481,7 @@ inprogressmenu (int gameid)
if (!replacestr) if (!replacestr)
graceful_exit (145); graceful_exit (145);
replacestr[0] = '/'; /*replacestr[0] = '/';*/
clear (); clear ();
refresh (); refresh ();
@ -515,7 +515,7 @@ inprogressmenu (int gameid)
} }
} }
games = populate_games (gameid, &len); games = populate_games (gameid, &len, me);
games = sort_games (games, len, sortmode); games = sort_games (games, len, sortmode);
} }
} }
@ -708,7 +708,7 @@ wall_email(char *from, char *msg)
graceful_exit(120); graceful_exit(120);
} }
games = populate_games(-1, &len); games = populate_games(-1, &len, me);
if (len == 0) { if (len == 0) {
fprintf(stderr, "Error: wall: no one's logged in!\n"); fprintf(stderr, "Error: wall: no one's logged in!\n");
@ -1596,9 +1596,7 @@ purge_stale_locks (int game)
size_t len; size_t len;
short firsttime = 1; short firsttime = 1;
len = strlen(globalconfig.dglroot) + strlen(myconfig[game]->inprogressdir) + 1; dir = strdup(dgl_format_str(game, me, myconfig[game]->inprogressdir));
dir = malloc(len);
snprintf(dir, len, "%s%s", globalconfig.dglroot, myconfig[game]->inprogressdir);
if (!(pdir = opendir (dir))) if (!(pdir = opendir (dir)))
graceful_exit (200); graceful_exit (200);
@ -1627,12 +1625,10 @@ purge_stale_locks (int game)
if (strncmp (dent->d_name, me->username, colon - dent->d_name)) if (strncmp (dent->d_name, me->username, colon - dent->d_name))
continue; continue;
len = strlen (dent->d_name) + strlen(globalconfig.dglroot) + strlen(myconfig[game]->inprogressdir) + 1; len = strlen (dent->d_name) + strlen(dgl_format_str(game, me, myconfig[game]->inprogressdir)) + 1;
fn = malloc (len); fn = malloc (len);
snprintf (fn, len, "%s%s%s", globalconfig.dglroot, myconfig[game]->inprogressdir, dent->d_name); snprintf (fn, len, "%s%s", dgl_format_str(game, me, myconfig[game]->inprogressdir), dent->d_name);
fprintf (stderr, "ERR:'%s'\n", fn);
if (!(ipfile = fopen (fn, "r"))) if (!(ipfile = fopen (fn, "r")))
graceful_exit (202); graceful_exit (202);
@ -1798,7 +1794,7 @@ authenticate ()
me = cpy_me(tmpme); me = cpy_me(tmpme);
if (passwordgood (pw_buf)) if (passwordgood (pw_buf))
{ {
games = populate_games (-1, &len); games = populate_games (-1, &len, me);
for (i = 0; i < len; i++) for (i = 0; i < len; i++)
if (!strcmp (games[i]->name, user_buf)) if (!strcmp (games[i]->name, user_buf))
{ {

View File

@ -188,7 +188,7 @@ extern struct dg_menu *dgl_find_menu(char *menuname);
extern int dgl_exec_cmdqueue(struct dg_cmdpart *queue, int game, struct dg_user *me); extern int dgl_exec_cmdqueue(struct dg_cmdpart *queue, int game, struct dg_user *me);
extern struct dg_game **populate_games(int game, int *l); extern struct dg_game **populate_games(int game, int *l, struct dg_user *me);
extern struct dg_game **sort_games(struct dg_game **games, int len, dg_sortmode sortmode); extern struct dg_game **sort_games(struct dg_game **games, int len, dg_sortmode sortmode);

View File

@ -40,7 +40,7 @@ struct dg_config defconfig = {
/* shed_gid = */ /*60,*/ /* games:games in Debian */ /* shed_gid = */ /*60,*/ /* games:games in Debian */
/* max = */ /*64000,*/ /* max = */ /*64000,*/
/* savefilefmt = */ /*"",*/ /* don't do this by default */ /* savefilefmt = */ /*"",*/ /* don't do this by default */
/* inprogressdir = */ "inprogress/", /* inprogressdir = */ "%rinprogress/",
/* num_args = */ 0, /* num_args = */ 0,
/* bin_args = */ NULL, /* bin_args = */ NULL,
/* rc_fmt = */ "%rrcfiles/%n.nethackrc", /* [dglroot]rcfiles/[username].nethackrc */ /* rc_fmt = */ "%rrcfiles/%n.nethackrc", /* [dglroot]rcfiles/[username].nethackrc */
@ -303,7 +303,7 @@ dgl_exec_cmdqueue(struct dg_cmdpart *queue, int game, struct dg_user *me)
} }
/* launch program */ /* launch program */
ttyrec_main (userchoice, me->username, gen_ttyrec_filename()); ttyrec_main (userchoice, me->username, dgl_format_str(userchoice, me, "%ruserdata/%n/ttyrec"), gen_ttyrec_filename());
/* lastly, run the generic "do these when a game is left" commands */ /* lastly, run the generic "do these when a game is left" commands */
dgl_exec_cmdqueue(globalconfig.cmdqueue[DGLTIME_GAMEEND], userchoice, me); dgl_exec_cmdqueue(globalconfig.cmdqueue[DGLTIME_GAMEEND], userchoice, me);
@ -360,17 +360,16 @@ sort_games (struct dg_game **games, int len, dg_sortmode sortmode)
} }
struct dg_game ** struct dg_game **
populate_games (int xgame, int *l) populate_games (int xgame, int *l, struct dg_user *me)
{ {
int fd, len, n, is_nhext, pid; int fd, len, n, is_nhext, pid;
DIR *pdir; DIR *pdir;
struct dirent *pdirent; struct dirent *pdirent;
struct stat pstat; struct stat pstat;
char fullname[130], ttyrecname[130], pidws[80]; char fullname[130], ttyrecname[130], pidws[80], playername[30];
char *replacestr, *dir, *p; char *replacestr, *dir, *p;
struct dg_game **games = NULL; struct dg_game **games = NULL;
struct flock fl = { 0 }; struct flock fl = { 0 };
size_t slen;
int game; int game;
@ -383,9 +382,7 @@ populate_games (int xgame, int *l)
for (game = ((xgame < 0) ? 0 : xgame); game < ((xgame <= 0) ? num_games : (xgame+1)); game++) { for (game = ((xgame < 0) ? 0 : xgame); game < ((xgame <= 0) ? num_games : (xgame+1)); game++) {
slen = strlen(globalconfig.dglroot) + strlen(myconfig[game]->inprogressdir) + 1; dir = strdup(dgl_format_str(game, me, myconfig[game]->inprogressdir));
dir = malloc(slen);
snprintf(dir, slen, "%s%s", globalconfig.dglroot, myconfig[game]->inprogressdir);
if (!(pdir = opendir (dir))) if (!(pdir = opendir (dir)))
graceful_exit (140); graceful_exit (140);
@ -397,7 +394,7 @@ populate_games (int xgame, int *l)
is_nhext = !strcmp (pdirent->d_name + strlen (pdirent->d_name) - 6, ".nhext"); is_nhext = !strcmp (pdirent->d_name + strlen (pdirent->d_name) - 6, ".nhext");
snprintf (fullname, 130, "%s%s%s", globalconfig.dglroot, myconfig[game]->inprogressdir, pdirent->d_name); snprintf (fullname, 130, "%s%s", dgl_format_str(game, me, myconfig[game]->inprogressdir), pdirent->d_name);
fd = 0; fd = 0;
/* O_RDWR here should be O_RDONLY, but we need to test for /* O_RDWR here should be O_RDONLY, but we need to test for
@ -409,18 +406,22 @@ populate_games (int xgame, int *l)
/* stat to check idle status */ /* stat to check idle status */
if (!is_nhext) if (!is_nhext)
{ {
snprintf (ttyrecname, 130, "%sttyrec/%s", globalconfig.dglroot, pdirent->d_name); strncpy(playername, pdirent->d_name, 29);
replacestr = strchr (ttyrecname, ':'); playername[29] = '\0';
if (!replacestr) if ((replacestr = strchr(playername, ':')))
graceful_exit (145); *replacestr = '\0';
replacestr[0] = '/';
replacestr = strchr(pdirent->d_name, ':');
if (!replacestr) graceful_exit(145);
replacestr++;
snprintf (ttyrecname, 130, "%suserdata/%s/ttyrec/%s", globalconfig.dglroot, playername, replacestr);
} }
if (is_nhext || !stat (ttyrecname, &pstat)) if (is_nhext || !stat (ttyrecname, &pstat))
{ {
/* now it's a valid game for sure */ /* now it's a valid game for sure */
games = realloc (games, sizeof (struct dg_game) * (len + 1)); games = realloc (games, sizeof (struct dg_game) * (len + 1));
games[len] = malloc (sizeof (struct dg_game)); games[len] = malloc (sizeof (struct dg_game));
games[len]->ttyrec_fn = strdup (pdirent->d_name); games[len]->ttyrec_fn = strdup (ttyrecname);
if (!(replacestr = strchr (pdirent->d_name, ':'))) if (!(replacestr = strchr (pdirent->d_name, ':')))
graceful_exit (146); graceful_exit (146);

View File

@ -1,151 +1,209 @@
#!/bin/sh #!/bin/sh
# Original by joshk@triplehelix.org, modifications by jilles@stack.nl # Ideas and some parts from the original dgl-create-chroot (by joshk@triplehelix.org, modifications by jilles@stack.nl)
# This one by paxed@alt.org
# Settings
# Don't customize here, create a dgl-create-chroot.conf file instead. #
# The defaults should work fine for Debian. # configure dgl with --with-config-file=/path_to_chroot/etc/dgamelaunch.conf, if you want the conf file inside the chroot.
# path for chroot #
chroot_path="/var/lib/dgamelaunch"
# uid/gid (numeric), must agree with dgamelaunch.h
shed_uid=5 # Same as chroot_path in dgl config file
shed_gid=60 CHROOT="/opt/nethack/nethack.alt.org/"
# extra libraries to copy (that ldd doesn't find, such as ld-elf.so.1 on # the user & group from dgamelaunch config file.
# FreeBSD) USRGRP="games:games"
libs="" # COMPRESS from include/config.h; the compression binary to copy. leave blank to skip.
# compression binary to copy (found in $PATH if unqualified) COMPRESSBIN="/bin/gzip"
# (leave blank to skip) # nethack binary to copy into chroot
compress_bin="gzip" NETHACKBIN="/home/paxed/hacking/coding/nethacksource/nethack-3.4.3-nao/nh343/nethack.343-nao"
# nethack binary to copy (leave blank to skip)
nethack_bin="/usr/lib/games/nethack/nethack-console"
# fixed data to copy (leave blank to skip) # fixed data to copy (leave blank to skip)
playground_fixed="/usr/lib/games/nethack" NH_PLAYGROUND_FIXED="/home/paxed/hacking/coding/nethacksource/nethack-3.4.3-nao/nh343/"
# variable data to create (leave blank to skip) (may be equal to previous) # HACKDIR from include/config.h; aka nethack subdir inside chroot
playground_var="/var/games/nethack" NHSUBDIR="/nh343/"
# termcap/terminfo (copied recursively) (leave blank to skip) # VAR_PLAYGROUND from include/unixconf.h
[ -f dgl-create-chroot.conf ] && . ./dgl-create-chroot.conf NH_VAR_PLAYGROUND="/nh343/var/"
if [ -z "$termdata" ]; then # only define this if dgl was configured with --enable-sqlite
for dir in /etc/terminfo /usr/share/lib/terminfo /usr/share/terminfo; do SQLITE_DBFILE="/dgldir/dgamelaunch.db"
if [ -e "$dir/x/xterm" ]; then
termdata=$dir # END OF CONFIG
break ##############################################################################
fi
done errorexit()
if [ -z "$termdata" ]; then {
echo "Error: couldn't find terminfo definitions. Please specify in 'termdata' variable." >&2 echo "Error: $@" >&2
exit 1 exit 1
fi }
fi
findlibs() findlibs()
{ {
for i in "$@"; do for i in "$@"; do
# () to ignore errors echo $(ldd "$i" | awk '{ print $3 }' | egrep -v ^'\(')
( ldd "$i" 2>/dev/null | awk '{ if ($2=="=>" && $1!="linux-gate.so.1") print $3; }' ) echo $(ldd "$i" | grep 'ld-linux' | awk '{ print $1 }')
done done
} }
findinpath()
{ ##############################################################################
local IFS
IFS=: if [ -z "$TERMDATA" ]; then
for dir in $PATH; do SEARCHTERMDATA="/etc/terminfo /usr/share/lib/terminfo /usr/share/terminfo /lib/terminfo"
if [ -f "$dir/$1" ]; then for dir in $SEARCHTERMDATA; do
echo "$dir/$1" if [ -e "$dir/x/xterm" ]; then
return 0 TERMDATA="$TERMDATA $dir"
fi fi
done done
return 1 if [ -z "$TERMDATA" ]; then
} errorexit "Couldn't find terminfo definitions. Please specify in 'TERMDATA' variable."
fi
fi
# remove trailing slash, if any
CHROOT="`echo ${CHROOT%/}`"
set -e set -e
umask 022 umask 022
echo "Setting up the chroot in: $chroot_path" if [ -e "$CHROOT" ]; then
errorexit "Chroot $CHROOT already exists."
mkdir -p $chroot_path/bin $chroot_path/etc $chroot_path/var/mail
# Passwd file
echo "games:*:$shed_uid:$shed_gid:games:/nonexistent:" >$chroot_path/etc/passwd
echo "games:*:$shed_gid:" >$chroot_path/etc/group
# Time zone information, NetHack uses this
[ -f /etc/localtime ] && cp /etc/localtime $chroot_path/etc
# Dungeon directory setup
mkdir -p $chroot_path/dgldir/inprogress
mkdir -p $chroot_path/dgldir/rcfiles
mkdir -p $chroot_path/dgldir/ttyrec
chown -R $shed_uid:$shed_gid $chroot_path/dgldir
chown -R $shed_uid:$shed_gid $chroot_path/var/mail
touch $chroot_path/dgl-login
touch $chroot_path/dgl-lock
# Might want to remove these two for packaging?
cp dgl-default-rcfile $chroot_path
cp dgl-banner $chroot_path
chown $shed_uid:$shed_gid $chroot_path/dgl-*
# Needs gzip to compress
if [ -n "$compress_bin" ]; then
case "$compress_bin" in
/*) : ;;
*) compress_bin=`findinpath $compress_bin` ;;
esac
# NetHack wants the compression binary in the exact directory
mkdir -p $chroot_path`dirname $compress_bin`
cp $compress_bin $chroot_path$compress_bin
libs="$libs `findlibs $compress_bin`"
fi fi
# Copy the nethack binary over CURDIR="`pwd`"
if [ -n "$nethack_bin" ]; then
cp $nethack_bin $chroot_path/bin/nethack if [ ! -e "$CURDIR/dgamelaunch" ]; then
libs="$libs `findlibs $nethack_bin`" errorexit "Cannot find dgamelaunch in $CURDIR"
fi fi
# ...and all the data it needs DGLFILE="dgamelaunch.`date +%Y%m%d`"
if [ -n "$playground_var" ]; then
mkdir -p $chroot_path$playground_var/save $chroot_path$playground_var/dumps echo "Setting up chroot in $CHROOT"
touch $chroot_path$playground_var/record
touch $chroot_path$playground_var/perm LIBS="`findlibs dgamelaunch`"
touch $chroot_path$playground_var/logfile
chown -R $shed_uid:$shed_gid $chroot_path$playground_var sudo mkdir -p "$CHROOT"
cd "$CHROOT"
sudo mkdir dgldir etc lib mail usr
sudo chown "$USRGRP" dgldir mail
sudo cp "$CURDIR/dgamelaunch" "$DGLFILE"
sudo ln -s "$DGLFILE" dgamelaunch
sudo mkdir -p "$CHROOT/dgldir/inprogress-nh343"
sudo mkdir -p "$CHROOT/dgldir/userdata"
sudo chown "$USRGRP" "$CHROOT/dgldir/inprogress-nh343"
sudo chown "$USRGRP" "$CHROOT/dgldir/userdata"
if [ -n "$SQLITE_DBFILE" ]; then
echo "Creating SQLite database at $SQLITE_DBFILE"
SQLITE_DBFILE="`echo ${SQLITE_DBFILE%/}`"
SQLITE_DBFILE="`echo ${SQLITE_DBFILE#/}`"
sudo sqlite3 "$CHROOT/$SQLITE_DBFILE" "create table dglusers (id integer primary key, username text, email text, env text, password text, flags integer);"
sudo chown "$USRGRP" "$CHROOT/$SQLITE_DBFILE"
fi fi
if [ -n "$playground_fixed" ]; then
mkdir -p $chroot_path$playground_fixed if [ -n "$COMPRESSBIN" -a -e "`which $COMPRESSBIN`" ]; then
cp $playground_fixed/license $chroot_path$playground_fixed COMPRESSDIR="`dirname $COMPRESSBIN`"
if [ -e $playground_fixed/nhdat ]; then COMPRESSDIR="`echo ${COMPRESSDIR%/}`"
cp $playground_fixed/nhdat $chroot_path$playground_fixed COMPRESSDIR="`echo ${COMPRESSDIR#/}`"
else echo "Copying $COMPRESSBIN to $COMPRESSDIR"
( sudo mkdir -p "$COMPRESSDIR"
cd $playground_fixed sudo cp "`which $COMPRESSBIN`" "$COMPRESSDIR/"
cp *.dat cmdhelp data dungeon help hh history \ LIBS="$LIBS `findlibs $COMPRESSBIN`"
opthelp options perm recover rumors wizhelp \
$chroot_path$playground_fixed
)
fi fi
sudo mkdir -p dev
cd dev
sudo mknod urandom c 1 9
cd ..
cd etc
sudo cp "$CURDIR/examples/dgamelaunch.conf" .
echo "Edit $CHROOT/etc/dgamelaunch.conf to suit your needs."
[ -f /etc/localtime ] && sudo cp /etc/localtime .
cd ..
sudo cp "$CURDIR/examples/dgl_menu_main_anon.txt" .
sudo cp "$CURDIR/examples/dgl_menu_main_user.txt" .
sudo cp "$CURDIR/examples/dgl-banner" .
sudo cp "$CURDIR/dgl-default-rcfile" "dgl-default-rcfile.nh343"
sudo chmod go+r dgl_menu_main_anon.txt dgl_menu_main_user.txt dgl-banner dgl-default-rcfile.nh343
NHSUBDIR="`echo ${NHSUBDIR%/}`"
NHSUBDIR="`echo ${NHSUBDIR#/}`"
sudo mkdir "$CHROOT/$NHSUBDIR"
if [ ! -e "$NETHACKBIN" ]; then
errorexit "Cannot find NetHack binary $NETHACKBIN"
fi fi
if [ -n "$NETHACKBIN" -a -e "$NETHACKBIN" ]; then
echo "Copying $NETHACKBIN"
sudo cp "$NETHACKBIN" "$NHSUBDIR/"
LIBS="$LIBS `findlibs $NETHACKBIN`"
fi
NH_PLAYGROUND_FIXED="`echo ${NH_PLAYGROUND_FIXED%/}`"
if [ -n "$NH_PLAYGROUND_FIXED" -a -d "$NH_PLAYGROUND_FIXED" ]; then
echo "Copying NetHack playground stuff."
NHFILES="*.lev *.dat cmdhelp data dungeon help hh history license opthelp options oracles recover rumors wizhelp"
for fil in $NHFILES; do
sudo cp $NH_PLAYGROUND_FIXED/$fil "$CHROOT/$NHSUBDIR/"
done
fi
NH_VAR_PLAYGROUND="`echo ${NH_VAR_PLAYGROUND%/}`"
NH_VAR_PLAYGROUND="`echo ${NH_VAR_PLAYGROUND#/}`"
echo "Creating NetHack variable dir stuff."
if [ -n "$NH_VAR_PLAYGROUND" ]; then
sudo mkdir -p "$CHROOT/$NH_VAR_PLAYGROUND"
sudo chown -R "$USRGRP" "$CHROOT/$NH_VAR_PLAYGROUND"
fi
sudo mkdir -p "$CHROOT/$NH_VAR_PLAYGROUND/save"
sudo chown -R "$USRGRP" "$CHROOT/$NH_VAR_PLAYGROUND/save"
sudo touch "$CHROOT/$NH_VAR_PLAYGROUND/logfile"
sudo touch "$CHROOT/$NH_VAR_PLAYGROUND/perm"
sudo touch "$CHROOT/$NH_VAR_PLAYGROUND/record"
sudo touch "$CHROOT/$NH_VAR_PLAYGROUND/xlogfile"
sudo chown -R "$USRGRP" "$CHROOT/$NHSUBDIR"
sudo chown -R "$USRGRP" "$CHROOT/$NH_VAR_PLAYGROUND"
# Curses junk # Curses junk
if [ -n "$termdata" ]; then if [ -n "$TERMDATA" ]; then
mkdir -p $chroot_path`dirname $termdata` echo "Copying termdata files from $TERMDATA"
if [ -d $termdata/. ]; then for termdat in $TERMDATA; do
cp -LR $termdata/. $chroot_path$termdata sudo mkdir -p "$CHROOT`dirname $termdat`"
if [ -d $termdat/. ]; then
sudo cp -LR $termdat/. $CHROOT$termdat
else else
cp $termdata $chroot_path`dirname $termdata` sudo cp $termdat $CHROOT`dirname $termdat`
fi fi
done
fi fi
# Necessary libraries
# previously libs="/lib/libc.so.6 /lib/libncurses.so.5 /lib/ld-linux.so.2" LIBS=`for lib in $LIBS; do echo $lib; done | sort | uniq`
libs=`for lib in $libs; do echo $lib; done | sort | uniq` echo "Copying libraries:" $LIBS
echo "Copying libraries:" $libs for lib in $LIBS; do
for lib in $libs; do sudo mkdir -p "$CHROOT`dirname $lib`"
mkdir -p $chroot_path`dirname $lib` sudo cp $lib "$CHROOT$lib"
cp $lib $chroot_path$lib
done done
echo "Finished." echo "Finished."

View File

@ -24,7 +24,7 @@ maxnicklen = 10
#sortmode = "username" #sortmode = "username"
# Path to a prepared chroot jail. # Path to a prepared chroot jail.
chroot_path = "/var/lib/dgamelaunch/" chroot_path = "/opt/nethack/nethack.alt.org/"
# From inside the jail, dgamelaunch's working directory for rcfiles/ttyrec/etc # From inside the jail, dgamelaunch's working directory for rcfiles/ttyrec/etc
dglroot = "/dgldir/" dglroot = "/dgldir/"
@ -108,15 +108,24 @@ lockfile = "/dgl-lock"
# eg. commands[login] = mkdir "foo", unlink "bar", setenv "Z" "foo" # eg. commands[login] = mkdir "foo", unlink "bar", setenv "Z" "foo"
# #
# create the user's ttyrec dir when they register # create the user's dirs when they register
commands[register] = mkdir "%rttyrec/%n" commands[register] = mkdir "%ruserdata/%n",
mkdir "%ruserdata/%n/dumplog",
mkdir "%ruserdata/%n/ttyrec"
commands[login] = mkdir "%ruserdata/%n",
mkdir "%ruserdata/%n/dumplog",
mkdir "%ruserdata/%n/ttyrec"
# define the main menus. you _must_ define "mainmenu_anon"
# and "mainmenu_user".
# Define the main menus.
# You _must_ define "mainmenu_anon" and "mainmenu_user".
# $VERSION and $SERVERID will be replaced, as per the bannerfile above. # $VERSION and $SERVERID will be replaced, as per the bannerfile above.
# first, the menu shown to anonymous user:
# First, the menu shown to anonymous user:
menu["mainmenu_anon"] { menu["mainmenu_anon"] {
bannerfile = "dgl_menu_main_anon.txt" bannerfile = "dgl_menu_main_anon.txt"
cursor = (5,18) cursor = (5,18)
@ -126,7 +135,7 @@ menu["mainmenu_anon"] {
commands["q"] = quit commands["q"] = quit
} }
# then the menu shown when the user has logged in: # Then the menu shown when the user has logged in:
# $USERNAME in here will be replaced with the user name. # $USERNAME in here will be replaced with the user name.
menu["mainmenu_user"] { menu["mainmenu_user"] {
# contents of this file are written to screen. # contents of this file are written to screen.
@ -152,37 +161,37 @@ menu["mainmenu_user"] {
# Next, we'll define one game's data: # Next, we'll define one game's data:
DEFINE { #DEFINE {
# From inside the jail, the location of the binary to be launched. # # From inside the jail, the location of the binary to be launched.
game_path = "/bin/nethackstub" # game_path = "/bin/nethackstub"
#
# Full name of the game # # Full name of the game
game_name = "NetHack stub" # game_name = "NetHack stub"
#
# Short name, used in the watching menu # # Short name, used in the watching menu
short_name = "NHstb" # short_name = "NHstb"
#
# arguments for when we exec the binary # # arguments for when we exec the binary
game_args = "/bin/nethackstub", # game_args = "/bin/nethackstub",
"foo", # "foo",
"user:%n", # "user:%n",
"shed_uid:%u", # "shed_uid:%u",
"bar" # "bar"
#
# From inside the jail, where dgamelaunch should put mail. # # From inside the jail, where dgamelaunch should put mail.
spooldir = "/var/mail/" # spooldir = "/var/mail/"
#
# From inside the jail, the default .nethackrc that is copied for new users. # # From inside the jail, the default .nethackrc that is copied for new users.
# rc_template = "/dgl-default-rcfile" # # rc_template = "/dgl-default-rcfile"
#
# Make sure the inprogress dir actually exists. default is "inprogress/" # # Make sure the inprogress dir actually exists. default is "inprogress/"
# Each game you define here must have it's own. # # Each game you define here must have it's own.
inprogressdir = "inprogress-nethackstub/" # inprogressdir = "%rinprogress-nethackstub/"
#
# We can also define per-game commands, that are executed # # We can also define per-game commands, that are executed
# when the game starts: # # when the game starts:
# commands = chdir "/dgldir", mkdir "foo_%u_%g" # # commands = chdir "/dgldir", mkdir "foo_%u_%g"
} #}
# #
@ -191,28 +200,29 @@ DEFINE {
# #
DEFINE { DEFINE {
game_path = "/bin/nethack" game_path = "/nh343/nethack.343-nao"
game_name = "NetHack 3.4.3" game_name = "NetHack 3.4.3"
short_name = "NH343" short_name = "NH343"
game_args = "/bin/nethack", "-u", "%n" game_args = "/nh343/nethack.343-nao", "-u", "%n"
spooldir = "/var/mail/" spooldir = "/var/mail/"
rc_template = "/dgl-default-rcfile" rc_template = "/dgl-default-rcfile.nh343"
rc_fmt = "%rrcfiles/%n.nethackrc" rc_fmt = "%ruserdata/%n/%n.nh343rc"
inprogressdir = "%rinprogress-nh343/"
inprogressdir = "inprogress-nethack/"
# back up savefile # back up savefile
commands = cp "/var/games/nethack/save/%u%n.gz" "/var/games/nethack/save/%u%n.gz.bak", commands = cp "/nh343/var/save/%u%n.gz" "/nh343/var/save/%u%n.gz.bak",
# set NETHACKOPTIONS to point to the rcfile # set NETHACKOPTIONS to point to the rcfile
setenv "NETHACKOPTIONS" "@%rrcfiles/%n.nethackrc", setenv "NETHACKOPTIONS" "@%ruserdata/%n/%n.nh343rc",
# set up nethack mail stuff, assuming it's compiled with it... # set up nethack mail stuff, assuming it's compiled with it...
setenv "MAIL" "/var/mail/%n", setenv "MAIL" "/mail/%n",
setenv "SIMPLEMAIL" "1", setenv "SIMPLEMAIL" "1",
# don't let the mail file grow # don't let the mail file grow
unlink "/var/mail/%n" unlink "/mail/%n"
} }
# #
@ -220,41 +230,41 @@ DEFINE {
# #
# #
DEFINE { #DEFINE {
game_path = "/bin/crawlss017" # game_path = "/bin/crawlss017"
game_name = "Crawl Stone Soup 0.1.7" # game_name = "Crawl Stone Soup 0.1.7"
short_name = "Cr017" # short_name = "Cr017"
#
game_args = "/bin/crawlss017", # game_args = "/bin/crawlss017",
"-name", "%n", # "-name", "%n",
"-dir", "/crawlss017/", # "-dir", "/crawlss017/",
"-rc", "%rrcfiles/%n.crawlrc", # "-rc", "%rrcfiles/%n.crawlrc",
"-morgue", "/crawlss017/morgues/", # "-morgue", "/crawlss017/morgues/",
"-macro", "/crawlss017/macros/%n.macro" # "-macro", "/crawlss017/macros/%n.macro"
#
rc_template = "/dgl-default-rcfile.crawl" # rc_template = "/dgl-default-rcfile.crawl"
rc_fmt = "%rrcfiles/%n.crawlrc" # rc_fmt = "%rrcfiles/%n.crawlrc"
inprogressdir = "inprogress-crawlss017/" # inprogressdir = "%rinprogress-crawlss017/"
} #}
# #
# fourth game # fourth game
# #
# #
DEFINE { #DEFINE {
game_path = "/bin/crawlss020" # game_path = "/bin/crawlss020"
game_name = "Crawl Stone Soup 0.2.0" # game_name = "Crawl Stone Soup 0.2.0"
short_name = "Cr020" # short_name = "Cr020"
#
game_args = "/bin/crawlss020", # game_args = "/bin/crawlss020",
"-name", "%n", # "-name", "%n",
"-dir", "/crawlss020/", # "-dir", "/crawlss020/",
"-rc", "/crawlss020/plr/%n/%n.crawlrc", # "-rc", "/crawlss020/plr/%n/%n.crawlrc",
"-morgue", "/crawlss020/plr/%n/", # "-morgue", "/crawlss020/plr/%n/",
"-macro", "/crawlss020/plr/%n/" # "-macro", "/crawlss020/plr/%n/"
#
rc_template = "/dgl-default-rcfile.crawl" # rc_template = "/dgl-default-rcfile.crawl"
rc_fmt = "/crawlss020/plr/%n/%n.crawlrc" # rc_fmt = "/crawlss020/plr/%n/%n.crawlrc"
inprogressdir = "inprogress-crawlss020/" # inprogressdir = "%rinprogress-crawlss020/"
} #}

View File

@ -85,14 +85,16 @@ struct winsize win;
int uflg; int uflg;
int int
ttyrec_main (int game, char *username, char* ttyrec_filename) ttyrec_main (int game, char *username, char *ttyrec_path, char* ttyrec_filename)
{ {
char dirname[100]; char dirname[100];
child = subchild = input_child = 0; child = subchild = input_child = 0;
snprintf (dirname, 100, "%sttyrec/%s/%s", globalconfig.dglroot, username, if (ttyrec_path[strlen(ttyrec_path)-1] == '/')
ttyrec_filename); snprintf (dirname, 100, "%s%s", ttyrec_path, ttyrec_filename);
else
snprintf (dirname, 100, "%s/%s", ttyrec_path, ttyrec_filename);
atexit(&remove_ipfile); atexit(&remove_ipfile);
if ((fscript = fopen (dirname, "w")) == NULL) if ((fscript = fopen (dirname, "w")) == NULL)

View File

@ -21,7 +21,7 @@ extern void doshell (int, char *);
extern void finish (int); extern void finish (int);
extern void remove_ipfile (void); extern void remove_ipfile (void);
extern int ttyrec_main(int, char *username, char *ttyrec_filename); extern int ttyrec_main (int, char *username, char *ttyrec_path, char* ttyrec_filename);
extern pid_t child; /* nethack process */ extern pid_t child; /* nethack process */
extern int master, slave; extern int master, slave;