xwords/xwords4/relay/xwrelay.sh

177 lines
3.7 KiB
Bash
Raw Normal View History

#!/bin/sh
set -e -u
DIR=$(pwd)
XWRELAY=${DIR}/xwrelay
PIDFILE=${DIR}/xwrelay.pid
CONFFILE=${DIR}/xwrelay.conf
IDFILE=${DIR}/nextid.txt
2009-07-31 12:58:47 +00:00
LOGFILE=/tmp/xwrelay_log_$$.txt
#LOGFILE=/dev/null
date > $LOGFILE
usage() {
echo "usage: $0 start | stop | restart | mkdb | debs_install"
}
2020-02-07 14:37:27 -08:00
setup_user() {
sudo -u postgres createuser --createdb $USER || true
if id | grep -q postgres; then
echo "user $USER already member of postgres group"
else
echo "adding $USER to group postgres; will need to login again to take advantage"
sudo usermod -a -G postgres $USER
fi
}
make_db() {
2020-02-07 14:37:27 -08:00
setup_user
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 <<-EOF | psql $DBNAME --file -
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
cat <<-EOF | psql $DBNAME --file -
CREATE TABLE games (
cid integer
,room VARCHAR(32)
,dead BOOLEAN DEFAULT FALSE
,lang INTEGER
,pub BOOLEAN
,connName VARCHAR(64) UNIQUE PRIMARY KEY
,nTotal INTEGER
,clntVers INTEGER[]
,nPerDevice INTEGER[]
,seeds INTEGER[]
,ack VARCHAR(1)[]
,nsents INTEGER[] DEFAULT '{0,0,0,0}'
2010-10-14 22:15:41 -07:00
,ctime TIMESTAMP (0) DEFAULT CURRENT_TIMESTAMP
,mtimes TIMESTAMP(0)[]
,addrs INET[]
,devids INTEGER[]
,tokens INTEGER[]
);
2010-09-23 06:31:42 -07:00
EOF
cat <<-EOF | psql $DBNAME --file -
2010-09-23 06:31:42 -07:00
CREATE TABLE msgs (
id SERIAL
,connName VARCHAR(64)
,hid INTEGER
,token INTEGER
2010-10-18 20:19:09 -07:00
,ctime TIMESTAMP DEFAULT CURRENT_TIMESTAMP
,stime TIMESTAMP DEFAULT 'epoch'
,devid INTEGER
,msg BYTEA
,msg64 TEXT
,msglen INTEGER
2014-01-07 07:17:48 -08:00
, UNIQUE ( connName, hid, msg64, stime )
2010-09-23 06:31:42 -07:00
);
EOF
cat <<-EOF | psql $DBNAME --file -
CREATE TABLE devices (
id INTEGER UNIQUE PRIMARY KEY
,devTypes INTEGER[]
,devids TEXT[]
,clntVers INTEGER
,versDesc TEXT
,model TEXT
,osvers TEXT
,variantCode INTEGER DEFAULT 0
,ctime TIMESTAMP DEFAULT CURRENT_TIMESTAMP
,mtimes TIMESTAMP[]
,unreg BOOLEAN DEFAULT FALSE
);
EOF
}
do_start() {
if [ -f $PIDFILE ] && [ -f /proc/$(cat $PIDFILE)/exe ]; then
echo "already running: pid=$(cat $PIDFILE)" | tee -a $LOGFILE
elif pidof $XWRELAY >/dev/null; then
echo "already running: pid($XWRELAY)=>$(pidof $XWRELAY)" | tee -a $LOGFILE
else
if [ ! -e $CONFFILE ]; then
echo "unable to find $CONFFILE"
exit 1
fi
echo "starting..." | tee -a $LOGFILE
2013-01-11 20:42:57 -08:00
echo "running $XWRELAY $@ -f $CONFFILE" | tee -a $LOGFILE
$XWRELAY $@ -f $CONFFILE &
NEWPID=$!
2009-12-04 07:54:14 +00:00
echo -n $NEWPID > $PIDFILE
sleep 1
echo "running with pid=$(cat $PIDFILE)" | tee -a $LOGFILE
fi
}
install_debs() {
2020-02-07 14:37:27 -08:00
sudo apt-get install postgresql-client postgresql libpq-dev
}
case $1 in
stop)
shift
if [ -f $PIDFILE ] && [ -f /proc/$(cat $PIDFILE)/exe ]; then
sync
echo "killing pid=$(cat $PIDFILE)" | tee -a $LOGFILE
kill $(cat $PIDFILE)
else
echo "not running or $PIDFILE not found" | tee -a $LOGFILE
PID=$(pidof $XWRELAY || true)
2009-12-04 07:54:14 +00:00
if [ -n "$PID" ]; then
echo "maybe it's $PID; killing them" | tee -a $LOGFILE
kill $PID
fi
fi
rm -f $PIDFILE
;;
restart)
shift
$0 stop
sleep 1
$0 start $@
;;
start)
shift
do_start $@
;;
mkdb)
make_db
;;
debs_install)
install_debs
;;
*)
usage
exit 0
;;
esac