Go to file
Jilles Tjoelker 9686e206c0 Don't call getpwuid(3)/getgrgid(3) on uids/gids in the config file. The uid/gid
doesn't need to be in /etc/passwd or /etc/group anyway, and this reduces
storage of sensitive information in dgamelaunch's memory space.


git-svn-id: svn://katsu.triplehelix.org/dgamelaunch/trunk@113 db0b04b0-f4d1-0310-9a6d-de3e77497b0e
2004-01-07 12:00:41 +00:00
.cvsignore Ignore nethackstub binary and ktrace.out (output of ktrace syscall tracer). 2004-01-05 14:03:38 +00:00
Bugs Update all of the administrivia to reflect current state 2004-01-02 11:59:50 +00:00
COPYING add io.c to the 4-BSD stuff 2004-01-05 23:26:16 +00:00
Changelog version 1.3.10.1 doesn't allude to how much new crap is in this release. 2004-01-06 01:38:11 +00:00
Makefile stop using indent for a while, breaks small checkins 2004-01-06 05:03:19 +00:00
README wrap at 80, add some helpful install tips 2004-01-06 06:53:02 +00:00
TODO SIGWINCH problems seem to be fixed now. 2004-01-06 15:51:51 +00:00
config.l works! 2004-01-05 09:18:39 +00:00
config.y Don't call getpwuid(3)/getgrgid(3) on uids/gids in the config file. The uid/gid 2004-01-07 12:00:41 +00:00
dgamelaunch.c Reset SIGWINCH to default before starting game to prevent that window resizes 2004-01-06 14:27:56 +00:00
dgamelaunch.conf First try at the config file system. Still need to change usage of all 2004-01-05 01:25:38 +00:00
dgamelaunch.h some fixes 2004-01-05 17:27:49 +00:00
dgl-banner I can't stand it anymore, reindenting with 2 spaces, 2003-12-31 19:47:49 +00:00
dgl-create-chroot Make dgl-create-chroot.conf file clearer in the comments. 2004-01-04 16:42:08 +00:00
dgl-create-chroot.conf.example Make dgl-create-chroot.conf file clearer in the comments. 2004-01-04 16:42:08 +00:00
dgl-default-rcfile initial commit of new dgamelaunch to CVS 2003-12-30 21:30:32 +00:00
io.c I can't stand it anymore, reindenting with 2 spaces, 2003-12-31 19:47:49 +00:00
io.h initial commit of new dgamelaunch to CVS 2003-12-30 21:30:32 +00:00
last_char_is.c I can't stand it anymore, reindenting with 2 spaces, 2003-12-31 19:47:49 +00:00
nethackstub.c Add code to test simplemail. 2004-01-06 13:33:36 +00:00
nh343-simple_mail.diff fix a buffer overflow 2004-01-06 19:04:07 +00:00
stripgfx.c I can't stand it anymore, reindenting with 2 spaces, 2003-12-31 19:47:49 +00:00
stripgfx.h initial commit of new dgamelaunch to CVS 2003-12-30 21:30:32 +00:00
strlcat.c reindentation 2004-01-04 22:49:29 +00:00
strlcpy.c Reindent, and add some error handling for kill 2004-01-04 02:19:12 +00:00
ttyplay.c Some fixes to simplemail. It appears to work for me now. 2004-01-06 13:35:38 +00:00
ttyrec.c It kind of works now. However, we must beware the static buffers that we made 2004-01-05 01:55:08 +00:00
ttyrec.h I can't stand it anymore, reindenting with 2 spaces, 2003-12-31 19:47:49 +00:00
virus.c graceful_exit, does nothing but please deprecate exit(). 2004-01-04 01:45:21 +00:00

README

dgamelaunch
===========

dgamelaunch is a network-based game shell where anyone can sign up for an
account and start playing any game which suits your fancy - currently, though,
it only supports NetHack (see http://www.nethack.org).

It requires the ncurses library and development headers to build and should
compile without issue on Linux and FreeBSD 4/5. Other platforms have not been
tested yet.

dgamelaunch was originally developed by M. Drew Streib <dtype@dtype.org> but
is now a collaborative project. Copyright and contact information is in the 
COPYING file, included with this package.
Mailing list: http://alt.org/mailman/listinfo/nethack/

BASIC SETUP INSTRUCTIONS
========================

1) Setup a chroot jail. There is a helpful script included to accomplish
this, called dgl-create-chroot, in the source directory. The default settings
are viewable by editing the script; to customize the installation, look at
dgl-create-chroot.conf.example (also in the source directory) and edit it to
suit your needs, and save it into the same directory as dgl-create-chroot as
dgl-create-chroot.conf. Depending on what you choose to do you may need to
run the script as root.

If you decide to not use dgl-create-chroot, you're on your own and we assume
you have enough clue to figure out exactly what's needed for the chroot to
operate correctly.

2) Compile nethack. Make sure the directories in the chroot match up with
where nethack thinks everything is. You may need to edit the VAR_PLAYGROUND
variable in include/unixconf.h and/or the HACKDIR variable in include/config.h.

(Note: Try not to, for security, to put anything else in the chroot. You may
need to put gzip in there though if you compile nethack to use it for 
compression.)

3) Edit dgamelaunch.conf. This will contain information for dgamelaunch
about what uid/username, gid/group to shed privileges to at runtime. It
must also contain the path to nethack, and needs to know certain aspects
of your chroot. If you used dgl-create-chroot, the defaults are appropriate,
except of course that you will need to install the nethack binary into the
specified location.

4) Setup dgamelaunch as one of the following:
        a) The shell for a single login.
        b) An (x)inetd service.

If you choose a login shell make sure dgamelaunch is setuid root. (that is,
chmod 755 dgamelaunch.) It will shed privs right after entering the chroot
jail though.

Example xinetd lines:

service telnet
{
  socket_type     = stream
  protocol  = tcp
  wait      = no
  user      = root
  server    = /usr/sbin/in.telnetd
  server_args     = -h -L /opt/nethack/nethack.dtype.org/dgamelaunch /etc/dgamelaunch.conf
  rlimit_cpu      = 3600
  bind      = 64.71.163.206
}

A classic inetd line would look like this:

telnet stream tcp nowait root.root /usr/sbin/tcpd /usr/sbin/in.telnetd -h -L /usr/sbin/dgamelaunch /etc/dgamelaunch.conf

In both cases, the -L specifies an alternate login program (telnetlogin is
invoked by default) and -h prevents revealing of a login banner (for 
example, "Debian GNU/Linux testing/unstable influx") before starting the
login shell.

It goes without saying that the argument after -L must point to dgamelaunch's
exact location. Also, the location of dgamelaunch.conf is variable and of
course should be customized by you.

5) Test your compilation of dgamelaunch by running it as root. If this 
works, a shell login or (x)inetd will work with the correct configuration. 
If you have problems with dgamelaunch's display make sure that your chroot's
/etc/terminfo directory is populated.