summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authortv <tv@also>2011-08-05 01:44:39 +0200
committertv <tv@also>2011-08-05 01:44:39 +0200
commit181fbc7593a9df30e9c22d3acc81a26347afc872 (patch)
tree2911a9a780797866611b92516360aedad6887087
parent982964799abad608109e3b35febe569706171c61 (diff)
parent20aabdf4ce7a3d6c558d135b4ae4cedd776aa82b (diff)
Merge branch 'master' of github.com:krebscode/painload
-rwxr-xr-xstreams/streams51
1 files changed, 37 insertions, 14 deletions
diff --git a/streams/streams b/streams/streams
index eb1e6674..c5e9e471 100755
--- a/streams/streams
+++ b/streams/streams
@@ -1,6 +1,10 @@
#! /bin/bash
HERE=$(dirname $(readlink -f $0))
URLS=`cat $HERE/stream.db`
+CURRENT_STREAM="no stream" #will be set when calling `status`
+if [ ! `id -u` -eq "0" ]; then
+ exec sudo "$0" "$@"
+fi
#if [ ! `id -u` -eq "0" ]; then
# echo "we are going sudo..."
@@ -11,7 +15,7 @@ function start() {
# start the given stream von $1
REQ=$1
tmux start-server
- if status; then
+ if status &>/dev/null ; then
echo "!! Stream already running!"
exit 1
fi
@@ -30,15 +34,39 @@ function start() {
function stop()
{
#stops every stream
- tmux kill-session -t streams || echo "!! killing session failed"
+ if status &>/dev/null; then
+ status | cut -d\ -f2 | xargs printf "** killing %s\n"
+ tmux kill-session -t streams 2>/dev/null || echo "!! killing session failed"
+ else
+ echo "** no stream running";
+ return 1
+ fi
}
function status()
{
- tmux has-session -t streams 2>/dev/null
- RET=$?
- tmux list-sessions 2>/dev/null
- return $RET
+ #tmux has-session -t streams 2>/dev/null
+ #RET=$?
+
+ #tmux list-sessions 2>/dev/null
+ #return $RET
+ EV="`ps -ef | grep tmux`"
+ if echo "$URLS" | while read URL NAME; do
+ if [ "`echo "$EV" | grep \"$URL\"`" ] ;then
+ echo "** $NAME running ($URL)"
+ exit 1
+ fi
+ done; then
+ echo "** no stream running"
+ return 1
+ else
+ return 0
+ fi
+}
+function current()
+{
+
+ return 1
}
function list()
{
@@ -74,18 +102,13 @@ case "$1" in
stop)
stop
;;
- restart)
+ (switch|restart)
stop
start $2
;;
status)
- if status; then
- echo "** stream running"
- exit 0
- else
- echo "** Stream not running"
- exit 1
- fi
+ status
+ exit $?
;;
list)
list