2007-11-13 03:50:41 +00:00
|
|
|
#!/bin/sh
|
|
|
|
|
2011-06-25 21:32:18 -07:00
|
|
|
set -e -u
|
|
|
|
|
2010-10-07 19:41:02 -07:00
|
|
|
DIR=$(pwd)
|
2008-12-31 04:26:37 +00:00
|
|
|
XWRELAY=${DIR}/xwrelay
|
|
|
|
PIDFILE=${DIR}/xwrelay.pid
|
|
|
|
CONFFILE=${DIR}/xwrelay.conf
|
|
|
|
IDFILE=${DIR}/nextid.txt
|
2009-07-31 12:58:47 +00:00
|
|
|
|
2010-10-07 19:48:38 -07:00
|
|
|
LOGFILE=/tmp/xwrelay_log_$$.txt
|
2009-07-30 12:46:40 +00:00
|
|
|
#LOGFILE=/dev/null
|
|
|
|
|
|
|
|
date > $LOGFILE
|
2007-11-13 03:50:41 +00:00
|
|
|
|
2010-09-14 21:18:04 -07:00
|
|
|
usage() {
|
|
|
|
echo "usage: $0 start | stop | restart | mkdb"
|
|
|
|
}
|
|
|
|
|
|
|
|
make_db() {
|
2011-06-25 21:32:18 -07:00
|
|
|
if [ ! -e $CONFFILE ]; then
|
|
|
|
echo "unable to find $CONFFILE"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
DBNAME=$(grep '^DB_NAME' $CONFFILE | sed 's,^.*=,,')
|
|
|
|
if [ -z "$DBNAME" ]; then
|
|
|
|
echo "DB_NAME keyword not found"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
createdb $DBNAME
|
|
|
|
cat | psql $DBNAME --file - <<EOF
|
2010-09-28 18:06:50 -07:00
|
|
|
create or replace function sum_array( DECIMAL [] )
|
|
|
|
returns decimal
|
|
|
|
as \$\$
|
|
|
|
select sum(\$1[i])
|
|
|
|
from generate_series(
|
|
|
|
array_lower(\$1,1),
|
|
|
|
array_upper(\$1,1)
|
|
|
|
) g(i);
|
|
|
|
\$\$ language sql immutable;
|
|
|
|
EOF
|
|
|
|
|
2011-06-25 21:32:18 -07:00
|
|
|
cat | psql $DBNAME --file - <<EOF
|
2010-09-14 21:18:04 -07:00
|
|
|
CREATE TABLE games (
|
2010-10-06 21:45:05 -07:00
|
|
|
cid integer
|
|
|
|
,room VARCHAR(32)
|
2010-11-11 06:29:21 -08:00
|
|
|
,dead BOOLEAN DEFAULT FALSE
|
2010-10-06 21:45:05 -07:00
|
|
|
,lang INTEGER
|
|
|
|
,pub BOOLEAN
|
|
|
|
,connName VARCHAR(64) UNIQUE PRIMARY KEY
|
|
|
|
,nTotal INTEGER
|
2012-01-26 05:43:54 -08:00
|
|
|
,clntVers INTEGER[]
|
2010-10-06 21:45:05 -07:00
|
|
|
,nPerDevice INTEGER[]
|
|
|
|
,seeds INTEGER[]
|
2011-06-20 18:10:07 -07:00
|
|
|
,ack VARCHAR(1)[]
|
2010-10-06 21:45:05 -07:00
|
|
|
,nSent INTEGER DEFAULT 0
|
2010-10-14 22:15:41 -07:00
|
|
|
,ctime TIMESTAMP (0) DEFAULT CURRENT_TIMESTAMP
|
2010-12-01 21:09:25 -08:00
|
|
|
,mtimes TIMESTAMP(0)[]
|
2012-01-04 18:14:12 -08:00
|
|
|
,addrs INET[]
|
2012-11-03 10:58:01 -07:00
|
|
|
,devids INTEGER[]
|
2013-01-15 18:41:17 -08:00
|
|
|
,tokens INTEGER[]
|
2010-09-14 21:18:04 -07:00
|
|
|
);
|
2010-09-23 06:31:42 -07:00
|
|
|
EOF
|
|
|
|
|
2011-06-25 21:32:18 -07:00
|
|
|
cat | psql $DBNAME --file - <<EOF
|
2010-09-23 06:31:42 -07:00
|
|
|
CREATE TABLE msgs (
|
2010-09-24 05:46:30 -07:00
|
|
|
id SERIAL
|
|
|
|
,connName VARCHAR(64)
|
|
|
|
,hid INTEGER
|
2013-01-19 14:34:04 -08:00
|
|
|
,token INTEGER
|
2010-10-18 20:19:09 -07:00
|
|
|
,ctime TIMESTAMP DEFAULT CURRENT_TIMESTAMP
|
2012-12-01 10:31:55 -08:00
|
|
|
,stime TIMESTAMP DEFAULT NULL
|
2012-11-03 10:58:01 -07:00
|
|
|
,devid INTEGER
|
2010-09-24 05:46:30 -07:00
|
|
|
,msg BYTEA
|
2011-01-21 06:46:49 -08:00
|
|
|
,msglen INTEGER
|
2010-11-03 18:14:19 -07:00
|
|
|
,UNIQUE ( connName, hid, msg )
|
2010-09-23 06:31:42 -07:00
|
|
|
);
|
2012-11-03 10:58:01 -07:00
|
|
|
EOF
|
|
|
|
|
|
|
|
cat | psql $DBNAME --file - <<EOF
|
|
|
|
CREATE TABLE devices (
|
|
|
|
id INTEGER UNIQUE PRIMARY KEY
|
|
|
|
,devType INTEGER
|
|
|
|
,devid TEXT
|
|
|
|
,ctime TIMESTAMP DEFAULT CURRENT_TIMESTAMP
|
2013-01-19 14:34:04 -08:00
|
|
|
,mtime TIMESTAMP
|
2012-12-01 10:31:55 -08:00
|
|
|
,unreg BOOLEAN DEFAULT FALSE
|
2012-11-03 10:58:01 -07:00
|
|
|
);
|
2010-09-14 21:18:04 -07:00
|
|
|
EOF
|
|
|
|
}
|
|
|
|
|
2008-12-31 04:26:37 +00:00
|
|
|
do_start() {
|
|
|
|
if [ -f $PIDFILE ] && [ -f /proc/$(cat $PIDFILE)/exe ]; then
|
2009-07-30 12:46:40 +00:00
|
|
|
echo "already running: pid=$(cat $PIDFILE)" | tee -a $LOGFILE
|
2009-11-10 14:37:42 +00:00
|
|
|
elif pidof $XWRELAY >/dev/null; then
|
2010-10-07 19:41:02 -07:00
|
|
|
echo "already running: pid($XWRELAY)=>$(pidof $XWRELAY)" | tee -a $LOGFILE
|
2008-12-31 04:26:37 +00:00
|
|
|
else
|
2011-11-28 18:14:39 -08:00
|
|
|
if [ ! -e $CONFFILE ]; then
|
|
|
|
echo "unable to find $CONFFILE"
|
|
|
|
exit 1
|
|
|
|
fi
|
2009-07-30 12:46:40 +00:00
|
|
|
echo "starting..." | tee -a $LOGFILE
|
2013-01-11 20:42:57 -08:00
|
|
|
echo "running $XWRELAY $@ -f $CONFFILE" | tee -a $LOGFILE
|
|
|
|
$XWRELAY $@ -f $CONFFILE &
|
2008-12-31 04:26:37 +00:00
|
|
|
NEWPID=$!
|
2009-12-04 07:54:14 +00:00
|
|
|
echo -n $NEWPID > $PIDFILE
|
2008-12-31 04:26:37 +00:00
|
|
|
sleep 1
|
2009-07-30 12:46:40 +00:00
|
|
|
echo "running with pid=$(cat $PIDFILE)" | tee -a $LOGFILE
|
2008-12-31 04:26:37 +00:00
|
|
|
fi
|
|
|
|
}
|
2007-11-13 03:50:41 +00:00
|
|
|
|
2008-12-31 04:26:37 +00:00
|
|
|
case $1 in
|
2007-11-13 03:50:41 +00:00
|
|
|
|
|
|
|
stop)
|
2008-12-31 04:26:37 +00:00
|
|
|
shift
|
2007-11-22 04:59:11 +00:00
|
|
|
if [ -f $PIDFILE ] && [ -f /proc/$(cat $PIDFILE)/exe ]; then
|
2007-11-13 03:50:41 +00:00
|
|
|
sync
|
2009-07-30 12:46:40 +00:00
|
|
|
echo "killing pid=$(cat $PIDFILE)" | tee -a $LOGFILE
|
2007-11-13 03:50:41 +00:00
|
|
|
kill $(cat $PIDFILE)
|
|
|
|
else
|
2009-07-30 12:46:40 +00:00
|
|
|
echo "not running or $PIDFILE not found" | tee -a $LOGFILE
|
2009-11-10 14:37:42 +00:00
|
|
|
PID=$(pidof $XWRELAY || true)
|
2009-12-04 07:54:14 +00:00
|
|
|
if [ -n "$PID" ]; then
|
2009-07-30 12:46:40 +00:00
|
|
|
echo "maybe it's $PID; killing them" | tee -a $LOGFILE
|
2008-12-31 04:26:37 +00:00
|
|
|
kill $PID
|
|
|
|
fi
|
2007-11-13 03:50:41 +00:00
|
|
|
fi
|
2008-12-31 04:26:37 +00:00
|
|
|
rm -f $PIDFILE
|
2007-11-13 03:50:41 +00:00
|
|
|
;;
|
|
|
|
|
|
|
|
restart)
|
2008-12-31 04:26:37 +00:00
|
|
|
shift
|
2007-11-13 03:50:41 +00:00
|
|
|
$0 stop
|
|
|
|
sleep 1
|
2007-11-22 04:59:11 +00:00
|
|
|
$0 start $@
|
2007-11-13 03:50:41 +00:00
|
|
|
;;
|
|
|
|
|
2008-12-31 04:26:37 +00:00
|
|
|
start)
|
|
|
|
shift
|
|
|
|
do_start $@
|
|
|
|
;;
|
2010-09-14 21:18:04 -07:00
|
|
|
|
|
|
|
mkdb)
|
|
|
|
make_db
|
|
|
|
;;
|
|
|
|
|
2008-12-31 04:26:37 +00:00
|
|
|
*)
|
2010-09-14 21:18:04 -07:00
|
|
|
usage
|
|
|
|
exit 0
|
2007-11-13 03:50:41 +00:00
|
|
|
;;
|
|
|
|
|
|
|
|
esac
|