From 9e24cf1941f87a294e5f9d212caac643ded27209 Mon Sep 17 00:00:00 2001 From: root Date: Sat, 8 May 2010 02:18:52 +0200 Subject: zeit: s/1/ein/ --- modules/zeit | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'modules') diff --git a/modules/zeit b/modules/zeit index 4c41fa10..9fbc33e4 100755 --- a/modules/zeit +++ b/modules/zeit @@ -5,7 +5,7 @@ case "$1" in echo "say current time" ;; (*) exec >>$NOISE_linefeed - k=`date +%k` + k=`date +%k|sed 's/^[[:space:]]*1[[:space:]]*$/ein/'` M=`date +%M|sed 's/0*//'` echo /set pitch 10 case "$lang" in -- cgit v1.2.3 From 758be77cd81c4d9f44eae1506e5dc929df4daa3b Mon Sep 17 00:00:00 2001 From: root Date: Sat, 8 May 2010 02:57:21 +0200 Subject: wall: use /echo instead the (now dead) /msg --- modules/wall | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'modules') diff --git a/modules/wall b/modules/wall index 7c32d01d..c73744ea 100755 --- a/modules/wall +++ b/modules/wall @@ -3,6 +3,6 @@ case "$1" in (--help) : ;; (?*) for linefeed in /tmp/noise/*/linefeed ; do - echo /msg "$*" >$linefeed + echo /echo "$*" >$linefeed done esac -- cgit v1.2.3 From 3f77df40b1d127e54bab735bbc14cd57a56b78ca Mon Sep 17 00:00:00 2001 From: root Date: Sat, 25 Sep 2010 01:08:39 +0000 Subject: play: changed "file not found"-comment --- modules/play | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) (limited to 'modules') diff --git a/modules/play b/modules/play index dcb8749f..749b450a 100755 --- a/modules/play +++ b/modules/play @@ -22,9 +22,13 @@ case "$1" in esac && break done || cat< Date: Tue, 28 Dec 2010 21:10:35 +0100 Subject: route espeak through paplay --- modules/espeak | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'modules') diff --git a/modules/espeak b/modules/espeak index 1f5c901d..4aad90b9 100755 --- a/modules/espeak +++ b/modules/espeak @@ -18,7 +18,7 @@ case "$1" in print_var amplitude $a print_var gap $g #echo "espeak -p \"$pitch\" -v \"$lang\" \"$*\"" >&2 - espeak -a $a -k $k -p $p -v $v -g $g< Date: Tue, 28 Dec 2010 21:11:36 +0100 Subject: write stderr of help to /dev/null --- modules/help | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'modules') diff --git a/modules/help b/modules/help index e9dba2fe..bc4c2931 100755 --- a/modules/help +++ b/modules/help @@ -4,7 +4,7 @@ case "$1" in ('') { for directory in `echo "$NOISE_PATH" | tr : \ ` ; do for module in "$directory"/* ; do echo `basename "$module"` `$module --help` - done + done 2>/dev/null done ## print all documented built-in commands sed -rn 's:^noise_([a-z]+)\(\) \{ # (.+)?$:\1 \2:p' "$NOISE" -- cgit v1.2.3 From e4c30a56130bf9c8885ce46e58de81e2756ae650 Mon Sep 17 00:00:00 2001 From: unknown Date: Tue, 28 Dec 2010 21:12:38 +0100 Subject: hardcoded MPD_HOST=mpd.shack into mpc module --- modules/mpc | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'modules') diff --git a/modules/mpc b/modules/mpc index 6626532b..0ab72058 100755 --- a/modules/mpc +++ b/modules/mpc @@ -10,5 +10,5 @@ case "$1" in ##echo test-module called with following arguments: "$@" ## send command for re-evaluation: ##echo /espeak test >$NOISE_linefeed - mpc $@ + MPD_HOST=mpd.shack mpc $@ esac -- cgit v1.2.3 From ee245224a41f66c1d370e45d07a7cd2bed44ef57 Mon Sep 17 00:00:00 2001 From: unknown Date: Tue, 28 Dec 2010 21:13:49 +0100 Subject: Inverted if-then-else logic in sleep --- modules/sleep | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) (limited to 'modules') diff --git a/modules/sleep b/modules/sleep index b8d350f7..89712cac 100755 --- a/modules/sleep +++ b/modules/sleep @@ -2,9 +2,9 @@ case "$1" in (--help) echo "pause for NUMBER seconds" ;; (*) - if ! echo "$1" | grep -Eq '^([0-9]+(\.[0-9]*)?|[0-9]*\.[0-9]+)$' ; then - echo 'FAIL: $1 is not a number' - else + if echo "$1" | grep -Eq '^([0-9]+(\.[0-9]*)?|[0-9]*\.[0-9]+)$' ; then sleep "$1" + else + echo 'FAIL: $1 is not a number' fi esac -- cgit v1.2.3 From d6d9deb733392e09b6b3f480eb6d5c90d2e973db Mon Sep 17 00:00:00 2001 From: chris Date: Tue, 28 Dec 2010 21:15:54 +0100 Subject: added modules: shackstatus, stream --- modules/shackstatus | 127 ++++++++++++++++++++++++++++++++++++++++++++++++++++ modules/stream | 50 +++++++++++++++++++++ 2 files changed, 177 insertions(+) create mode 100755 modules/shackstatus create mode 100755 modules/stream (limited to 'modules') diff --git a/modules/shackstatus b/modules/shackstatus new file mode 100755 index 00000000..d05dba87 --- /dev/null +++ b/modules/shackstatus @@ -0,0 +1,127 @@ +#! /bin/bash +inputdir=$HOME/noise/streams + +speak () { + echo "$@" >> $NOISE_linefeed +} + +wochentag () { + case $(date +%a) in + Mon) echo Montag ;; + Tue) echo Dienstag ;; + Wed) echo Mittwoch ;; + Thu) echo Donnerstag ;; + Fri) echo Freitag ;; + Sat) echo Samstag ;; + Sun) echo Sonntag ;; + esac +} + +tag () { + case $(date +%d) in + 1) echo erste ;; + 2) echo zweite ;; + 3) echo dritte ;; + 4) echo vierte ;; + 5) echo fünfte ;; + 6) echo sechste ;; + 7) echo siebte ;; + 8) echo achte ;; + 9) echo neunte ;; + 10) echo zehnte ;; + 11) echo elfte ;; + 12) echo zwölfte ;; + 13) echo dreizehnte ;; + 14) echo vierzehnte ;; + 15) echo fünfzehnte ;; + 16) echo sechzehnte ;; + 17) echo siebzehnte ;; + 18) echo achtzehnte ;; + 19) echo neunzehnte ;; + 20) echo zwanzigste ;; + 21) echo einundzwanzigste ;; + 22) echo zweiundzwanzigste ;; + 23) echo dreiundzwanzigste ;; + 24) echo vierundzwanzigste ;; + 25) echo füfundzwanzigste ;; + 26) echo sechsundzwanzigste ;; + 27) echo siebenundzwanzigste ;; + 28) echo achtundzwanzigste ;; + 29) echo neunundzwanzigste ;; + 30) echo dreissigste ;; + 31) echo einunddreissigste ;; + esac +} + +monat () { + case $(date +%b) in + Jan) echo Januar ;; + Feb) echo Februar ;; + Mar) echo März ;; + Apr) echo April ;; + May) echo Mai ;; + Jun) echo Juni ;; + Jul) echo Juli ;; + Aug) echo August ;; + Sep) echo September ;; + Oct) echo Oktober ;; + Nov) echo November ;; + Dec) echo Dezember ;; + esac +} + +case "$1" in + (--help) + echo "report status of all shack services." + ;; + (*) +# just a multiline comment +cat << EOF > /dev/null + /set pitch 10 + /espeak Hallo. Krietscher hat seinen Meister vermisst. + /espeak Heute ist `wochentag`, der `tag` --- `monat` -- `date +%Y` + /zeit + /espeak check der systeme: + /espeak Energie versorgung -- aktiv + /espeak schäckhost -- läuft + /espeak telnet -- läuft + /espeak interner - de - enn -- es, interne domein -- $STAT_DNS_I + /espeak interner - de - enn -- es, externe domein -- $STAT_DNS_E + /espeak externer - de - enn -- es - $STAT_DNS_X + /espeak Leitungsqualität - $STAT_LINE prozent. + /espeak Die Aussen temper atur beträgt $STAT_TEMP + /espeak Willkommen zu Hause, -- Meister +EOF + +[ $( dig +short localhost @10.42.0.10 ) = "127.0.0.1" ] && STAT_DNS_I="läuft" || STAT_DNS_I="antwortet nicht" +[ $( dig +short shackspace.de @10.42.0.10 ) = "141.31.176.214" ] && STAT_DNS_E="läuft"|| STAT_DNS_E="antwortet nicht" +[ $( dig +short shackspace.de @141.31.176.214 ) = "141.31.176.214" ] && STAT_DNS_X="läuft"|| STAT_DNS_X="antwortet nicht" + +STAT_LINE=$( ping -c 5 -i 0.2 -q 141.31.176.214 | awk '/packet loss/ { print 100-$6}' ) +STAT_TEMP=$( dig +short txt outside.elwood.temp.citecs.de | + sed 's/^"DEG //; + s/"$//; + s/^-/minus /; + s/\./ komma /; + s/\(.\)$/ \1 grad zelsius/ + ' +) + +cat <<-EOF >> $NOISE_linefeed + /set pitch 10 + /espeak Hallo. Krietscher hat seinen Meister vermisst. + /espeak Heute ist `wochentag`, der `tag` --- `monat` -- `date +%Y` + /zeit + /espeak check der systeme: + /espeak Energie versorgung -- aktiv + /espeak schäckhost -- läuft + /espeak telnet -- läuft + /espeak interner - de - enn -- es, interne domein -- $STAT_DNS_I + /espeak interner - de - enn -- es, externe domein -- $STAT_DNS_E + /espeak externer - de - enn -- es - $STAT_DNS_X + /espeak Leitungsqualität - $STAT_LINE prozent. + /espeak Die Aussen temper atur beträgt $STAT_TEMP + /espeak Willkommen zu Hause, -- Meister +EOF + ;; +esac 2>&1 diff --git a/modules/stream b/modules/stream new file mode 100755 index 00000000..76e86317 --- /dev/null +++ b/modules/stream @@ -0,0 +1,50 @@ +#! /bin/sh +inputdir=$HOME/noise/streams +case "$1" in + (--help) + echo "play an audio stream" ;; + (*) + exec 2>&1 + ffs='xml' + + if test -z "$*" ; then + echo -e "\x1B[32m/stream off \x1B[33m- turn stream off\x1B[m" + for i in `ls $inputdir` ; do + filename="$inputdir/$i" + shortcut=`xmlstarlet sel -t -v /station/@shortcut "$inputdir/$i"` + title=`xmlstarlet sel -t -v /station/@title "$inputdir/$i"` + topic=`xmlstarlet sel -t -v /station/@topic "$inputdir/$i"` + stream=`xmlstarlet sel -t -v /station/@stream "$inputdir/$i"` + echo -e "\x1B[32m/stream $shortcut \x1B[33m- $title \x1B[35m$topic\x1B[m" + done + else if [ "$1" = "off" ]; then + [ ! -d /tmp/noise ] || ( echo "no directory /tmp/noise; aborting" ; exit 1 ) + [ -f /tmp/noise/stream.pid ] && ( kill ` cat /tmp/noise/stream.pid ` ) + [ -e /tmp/noise/stream.pid ] && rm /tmp/noise/stream.pid || ( echo "can't remove /tmp/noise/stream.pid; aborting" ; exit 1 ) + else + for i in `ls $inputdir` ; do + filename="$inputdir/$i" + shortcut=`xmlstarlet sel -t -v /station/@shortcut "$inputdir/$i"` + stream=`xmlstarlet sel -t -v /station/@stream "$inputdir/$i"` + if [ "$shortcut" == "$1" ]; then + [ ! -d /tmp/noise ] || ( umask 077 ; mkdir /tmp/noise ) || ( echo "can't create /tmp/noise; aborting" ; exit 1 ) + [ -f /tmp/noise/stream.pid ] && ( kill ` cat /tmp/noise/stream.pid ` ) + [ -e /tmp/noise/stream.pid ] && rm /tmp/noise/stream.pid || ( echo "can't remove /tmp/noise/stream.pid; aborting" ; exit 1 ) + mplayer -cache 2048 -quiet "$stream" & + ( umask 077 ; echo $! > /tmp/noise/stream.pid ) + break + fi + done || cat< Date: Tue, 28 Dec 2010 21:17:26 +0100 Subject: added module: sendmail --- modules/sendmail | 55 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 55 insertions(+) create mode 100755 modules/sendmail (limited to 'modules') diff --git a/modules/sendmail b/modules/sendmail new file mode 100755 index 00000000..182d96e3 --- /dev/null +++ b/modules/sendmail @@ -0,0 +1,55 @@ +#!/usr/bin/python +import os,sys,smtplib,string +''' + Mail Plugin for the noise telnet suite + See: http://docs.python.org/library/smtplib.html + Author: Felix +''' + +# help +if len(sys.argv) == 2: + if sys.argv[1] == "--help": + print "send an e-mail ( \"TO(s)\" \"SUBJECT\" [string instead of EOF])" + sys.exit(0) + +# sanity +if len(sys.argv) <= 2: + print "wrong number of parameters, see help" + sys.exit(1) + +# write variables +# check of EOF +if len(sys.argv) == 4 : + EOFstring="%s\n"% sys.argv[3] +else: + EOFstring="EOF\n" + +fromaddr=u"Karl Koch" +toaddrs=sys.argv[1] +subject=sys.argv[2] + + +#write header: +msg = u"From: %s\r\nTo: %s\r\nSubject: %s\r\n\r\n" % (fromaddr, toaddrs,subject) +print "Write your text now, finish with %s" % EOFstring +sys.stdout.flush() # flushing is important to make sure the line is written + +while 1: + try: + line = sys.stdin.readline() + if line == EOFstring: + break + msg = msg + line + except EOFError: + break + +msg = msg + "[!] Written with NOISE telnet" + +print "Thank you for your message! Delivering it now..." +sys.stdout.flush() +server = smtplib.SMTP('localhost') +#server.set_debuglevel(1) +server.sendmail(fromaddr,toaddrs.split(','),msg) +server.quit() +print "mail send successfully" +sys.exit(0) -- cgit v1.2.3 From 6b09e03faff764fef2c867877e410357f43bf543 Mon Sep 17 00:00:00 2001 From: tv Date: Tue, 28 Dec 2010 21:19:47 +0100 Subject: added modules: ping, pong --- modules/ping | 24 ++++++++++++++++++++++++ modules/pong | 26 ++++++++++++++++++++++++++ 2 files changed, 50 insertions(+) create mode 100755 modules/ping create mode 100755 modules/pong (limited to 'modules') diff --git a/modules/ping b/modules/ping new file mode 100755 index 00000000..acf2529f --- /dev/null +++ b/modules/ping @@ -0,0 +1,24 @@ +#! /bin/sh +cd /tmp/noise +case "$1" in + (--help) : ;; + ('') + . $NOISE_pid/environment + ping_timestamp=${ping_timestamp-0} + ping_challenger=${ping_challenger-0} + if test $ping_challenger != 0 ; then + echo There is already a ping challange running + else + timestamp=`date +%s%N` + for client in * ; do + echo /ping $NOISE_pid $timestamp >$client/linefeed & + done + fi + ;; + (*) + echo "/set -q ping_timestamp $2" >$NOISE_pid/linefeed + if test $NOISE_pid != $1 ; then + echo "/set -q ping_challenger $1" >$NOISE_pid/linefeed + echo "PING?" + fi +esac diff --git a/modules/pong b/modules/pong new file mode 100755 index 00000000..eb2df46d --- /dev/null +++ b/modules/pong @@ -0,0 +1,26 @@ +#! /bin/sh +cd /tmp/noise +case "$1" in + (--help) : ;; + ('') + . $NOISE_pid/environment + ping_timestamp=${ping_timestamp-0} + ping_challenger=${ping_challenger-0} + if test $ping_challenger = 0 ; then + echo There is no ping challange running + else + timestamp=`date +%s%N` + echo /pong $NOISE_pid $timestamp >$ping_challenger/linefeed + ## reset ping TODO /unset + echo /set -q ping_timestamp 0 >$NOISE_pid/linefeed + echo /set -q ping_challenger 0 >$NOISE_pid/linefeed + fi + ;; + (*) + . $1/environment + # XXX is attendee the right counterpart to 'challenger'? + attendee_nick=$chat_nick + . $NOISE_pid/environment + time=`echo "scale=3; ($2 - $ping_timestamp)/10^9" | bc` + echo "PONG! $attendee_nick ${time}s" +esac -- cgit v1.2.3 From 0d7c646f54ceb6cc4e2f3c85017a55d357f42bd4 Mon Sep 17 00:00:00 2001 From: tv Date: Tue, 28 Dec 2010 21:22:45 +0100 Subject: added module: ein_mal_eins --- modules/ein_mal_eins | 38 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100755 modules/ein_mal_eins (limited to 'modules') diff --git a/modules/ein_mal_eins b/modules/ein_mal_eins new file mode 100755 index 00000000..1715eb3d --- /dev/null +++ b/modules/ein_mal_eins @@ -0,0 +1,38 @@ +#! /bin/bash + +R() { + echo "`od -t d -N 1 /dev/urandom | sed -rn '1s/^[0-9]+ +//p'` % $@" | bc +} + + + + +case "$1" in + (--help) echo Stellt eine einfache Aufgabe ;; + (*) + a="`R 69`" + b="`R 69`" + op="`echo "\ +Was ist, A hoch B +Was ist, A plus B +Was ist, A minus B +Was ist, A mal B +Was ist, sinus von 0 +Was ist, Pi halbe mal 2 +Was ist, 2 hoch 8 +Was ist, 2 hoch 16 +Was ist, 2 hoch 32 +Was ist, 42 geteilt durch Pi mal 100 +Was ist, l n von 1 +Was ist, 42 +Was ist, 23 +Starte den Server neu +Löte ein Kabel an einen Kompjuter +Was ist, A geteilt durch B"`" + o="$(R `echo "$op" | wc -l` + 1)" + + aufgabe=`echo "$op" | sed -n "$o{s/A/$a/;s/B/$b/;p}"` + + echo "Löse die Aufgabe: $aufgabe?" | + espeak -v de --stdout | paplay +esac -- cgit v1.2.3 From d9961c9d04abd9e15cd1a3035dab6b94bae30a6f Mon Sep 17 00:00:00 2001 From: unknown Date: Tue, 28 Dec 2010 21:23:30 +0100 Subject: added module: cat --- modules/cat | 14 ++++++++++++++ 1 file changed, 14 insertions(+) create mode 100755 modules/cat (limited to 'modules') diff --git a/modules/cat b/modules/cat new file mode 100755 index 00000000..e090acba --- /dev/null +++ b/modules/cat @@ -0,0 +1,14 @@ +#! /bin/sh +case "$1" in + (--help) : ;; + (*) + while read line ; do + case "$line" in + (/quit) + break 2 + ;; + (*) + echo "[$line]" + esac + done +esac -- cgit v1.2.3 From 691cb5ba3d5d22d15b2894572c83eac58a21dccb Mon Sep 17 00:00:00 2001 From: root Date: Tue, 28 Dec 2010 21:23:57 +0100 Subject: disabled the twitter module: it need oauth --- modules/twitter | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) (limited to 'modules') diff --git a/modules/twitter b/modules/twitter index 49d092fb..5b1b0be9 100755 --- a/modules/twitter +++ b/modules/twitter @@ -1,6 +1,10 @@ #!/usr/bin/python #encode=utf8 +print "Bug Robert to implement Twitter-OAuth!" +exit(1) + + import sys, twitter sys.stderr = sys.stdout @@ -57,7 +61,6 @@ if len(sys.argv) > 1 and sys.argv[1] == "--help": - api = twitter.Api(username="shackspam", password="sh4ckit") #api.SetXTwitterHeaders("Shackspace UTTERANCE","","0.00.0.01.42") -- cgit v1.2.3