diff options
-rwxr-xr-x | .graveyard/autowifi/autowifi (renamed from autowifi/autowifi) | 0 | ||||
-rw-r--r-- | .graveyard/autowifi/confdir/blacklist (renamed from autowifi/confdir/blacklist) | 0 | ||||
-rwxr-xr-x | .graveyard/autowifi/confdir/cracks/00profile (renamed from autowifi/confdir/cracks/00profile) | 0 | ||||
-rwxr-xr-x | .graveyard/autowifi/confdir/cracks/01open (renamed from autowifi/confdir/cracks/01open) | 0 | ||||
-rwxr-xr-x | .graveyard/autowifi/confdir/hooks/wlan0/post/00tinc-up (renamed from autowifi/confdir/hooks/wlan0/post/00tinc-up) | 0 | ||||
-rwxr-xr-x | .graveyard/autowifi/confdir/hooks/wlan0/pre/00changemac (renamed from autowifi/confdir/hooks/wlan0/pre/00changemac) | 0 | ||||
-rw-r--r-- | .graveyard/cholerab-live/README (renamed from cholerab/cholerab-live/README) | 0 | ||||
-rw-r--r-- | .graveyard/cholerab-live/chol_net.py (renamed from cholerab/cholerab-live/chol_net.py) | 0 | ||||
-rw-r--r-- | .graveyard/cholerab-live/chol_net.pyc (renamed from cholerab/cholerab-live/chol_net.pyc) | bin | 4361 -> 4361 bytes | |||
-rwxr-xr-x | .graveyard/cholerab-live/cholerab.py (renamed from cholerab/cholerab-live/cholerab.py) | 0 | ||||
-rwxr-xr-x | .graveyard/cholerab-live/live.sh (renamed from cholerab/too_old/live.sh) | 0 | ||||
-rw-r--r-- | .graveyard/cholerab-live/makefu/README | 6 | ||||
-rw-r--r-- | .graveyard/cholerab-live/makefu/chol_net.py | 82 | ||||
-rwxr-xr-x | .graveyard/cholerab-live/makefu/cholerab.py | 36 | ||||
-rw-r--r-- | .graveyard/cholerab-live/makefu/view.py (renamed from cholerab/cholerab-live/view.py) | 0 | ||||
-rwxr-xr-x | .graveyard/cholerab-live/ttycnser.sh (renamed from cholerab/too_old/ttycnser.sh) | 0 | ||||
-rw-r--r-- | .graveyard/cholerab-live/view.py | 112 | ||||
-rw-r--r-- | .graveyard/noise/Makefile (renamed from noise/Makefile) | 0 | ||||
-rw-r--r-- | .graveyard/noise/TODO (renamed from noise/TODO) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/cron/bin/zeit (renamed from noise/cron/bin/zeit) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/init.d/noise (renamed from noise/init.d/noise) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/cat (renamed from noise/modules/cat) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/chat (renamed from noise/modules/chat) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/date (renamed from noise/modules/date) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/echo (renamed from noise/modules/echo) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/ein_mal_eins (renamed from noise/modules/ein_mal_eins) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/espeak (renamed from noise/modules/espeak) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/help (renamed from noise/modules/help) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/join (renamed from noise/modules/join) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/lang (renamed from noise/modules/lang) | 0 | ||||
l--------- | .graveyard/noise/modules/licht (renamed from noise/modules/licht) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/mpc (renamed from noise/modules/mpc) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/names (renamed from noise/modules/names) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/nick (renamed from noise/modules/nick) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/overlord (renamed from noise/modules/overlord) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/part (renamed from noise/modules/part) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/ping (renamed from noise/modules/ping) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/play (renamed from noise/modules/play) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/pong (renamed from noise/modules/pong) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/query (renamed from noise/modules/query) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/send_to_channel (renamed from noise/modules/send_to_channel) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/sendmail (renamed from noise/modules/sendmail) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/shackstatus (renamed from noise/modules/shackstatus) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/sleep (renamed from noise/modules/sleep) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/stream (renamed from noise/modules/stream) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/temp (renamed from noise/modules/temp) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/test (renamed from noise/modules/test) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/twitter (renamed from noise/modules/twitter) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/vvs (renamed from noise/modules/vvs) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/wall (renamed from noise/modules/wall) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/modules/zeit (renamed from noise/modules/zeit) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/noise (renamed from noise/noise) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/noise-as-user (renamed from noise/noise-as-user) | 0 | ||||
-rwxr-xr-x | .graveyard/noise/noise-server (renamed from noise/noise-server) | 0 | ||||
-rw-r--r-- | .graveyard/temper/.gitignore (renamed from god/temper/.gitignore) | 0 | ||||
-rw-r--r-- | .graveyard/temper/99-tempsensor.rules (renamed from god/temper/99-tempsensor.rules) | 0 | ||||
-rw-r--r-- | .graveyard/temper/Makefile (renamed from god/temper/Makefile) | 4 | ||||
-rwxr-xr-x | .graveyard/temper/collectd-temper.sh (renamed from god/temper/collectd-temper.sh) | 0 | ||||
-rw-r--r-- | .graveyard/temper/temper.c (renamed from god/temper/temper.c) | 2 | ||||
-rw-r--r-- | .graveyard/temper/temper.h (renamed from god/temper/temper.h) | 0 | ||||
-rwxr-xr-x | god/streams/bin/relaxxapi.py | 4 | ||||
-rwxr-xr-x | god/streams/bin/streams | 2 | ||||
-rw-r--r-- | ship/lib/network | 4 |
63 files changed, 244 insertions, 8 deletions
diff --git a/autowifi/autowifi b/.graveyard/autowifi/autowifi index 5bdbde22..5bdbde22 100755 --- a/autowifi/autowifi +++ b/.graveyard/autowifi/autowifi diff --git a/autowifi/confdir/blacklist b/.graveyard/autowifi/confdir/blacklist index f0e5c6a1..f0e5c6a1 100644 --- a/autowifi/confdir/blacklist +++ b/.graveyard/autowifi/confdir/blacklist diff --git a/autowifi/confdir/cracks/00profile b/.graveyard/autowifi/confdir/cracks/00profile index c2ad6ec7..c2ad6ec7 100755 --- a/autowifi/confdir/cracks/00profile +++ b/.graveyard/autowifi/confdir/cracks/00profile diff --git a/autowifi/confdir/cracks/01open b/.graveyard/autowifi/confdir/cracks/01open index 7bd98e20..7bd98e20 100755 --- a/autowifi/confdir/cracks/01open +++ b/.graveyard/autowifi/confdir/cracks/01open diff --git a/autowifi/confdir/hooks/wlan0/post/00tinc-up b/.graveyard/autowifi/confdir/hooks/wlan0/post/00tinc-up index 3fd786e4..3fd786e4 100755 --- a/autowifi/confdir/hooks/wlan0/post/00tinc-up +++ b/.graveyard/autowifi/confdir/hooks/wlan0/post/00tinc-up diff --git a/autowifi/confdir/hooks/wlan0/pre/00changemac b/.graveyard/autowifi/confdir/hooks/wlan0/pre/00changemac index c3e0632f..c3e0632f 100755 --- a/autowifi/confdir/hooks/wlan0/pre/00changemac +++ b/.graveyard/autowifi/confdir/hooks/wlan0/pre/00changemac diff --git a/cholerab/cholerab-live/README b/.graveyard/cholerab-live/README index b778b98c..b778b98c 100644 --- a/cholerab/cholerab-live/README +++ b/.graveyard/cholerab-live/README diff --git a/cholerab/cholerab-live/chol_net.py b/.graveyard/cholerab-live/chol_net.py index ee0f5378..ee0f5378 100644 --- a/cholerab/cholerab-live/chol_net.py +++ b/.graveyard/cholerab-live/chol_net.py diff --git a/cholerab/cholerab-live/chol_net.pyc b/.graveyard/cholerab-live/chol_net.pyc Binary files differindex 0694ad6d..0694ad6d 100644 --- a/cholerab/cholerab-live/chol_net.pyc +++ b/.graveyard/cholerab-live/chol_net.pyc diff --git a/cholerab/cholerab-live/cholerab.py b/.graveyard/cholerab-live/cholerab.py index eb9e66df..eb9e66df 100755 --- a/cholerab/cholerab-live/cholerab.py +++ b/.graveyard/cholerab-live/cholerab.py diff --git a/cholerab/too_old/live.sh b/.graveyard/cholerab-live/live.sh index 62a2c3cf..62a2c3cf 100755 --- a/cholerab/too_old/live.sh +++ b/.graveyard/cholerab-live/live.sh diff --git a/.graveyard/cholerab-live/makefu/README b/.graveyard/cholerab-live/makefu/README new file mode 100644 index 00000000..b778b98c --- /dev/null +++ b/.graveyard/cholerab-live/makefu/README @@ -0,0 +1,6 @@ + +view.py: contains view classes for cholerab +cholerab.py: main file + +start with : +python cholerab.py diff --git a/.graveyard/cholerab-live/makefu/chol_net.py b/.graveyard/cholerab-live/makefu/chol_net.py new file mode 100644 index 00000000..ee0f5378 --- /dev/null +++ b/.graveyard/cholerab-live/makefu/chol_net.py @@ -0,0 +1,82 @@ +from socket import socket, AF_INET,SOCK_DGRAM,IPPROTO_UDP,SOL_SOCKET,SO_REUSEADDR,IP_MULTICAST_TTL,IP_MULTICAST_LOOP,INADDR_ANY,inet_aton,IP_ADD_MEMBERSHIP,IPPROTO_IP +import struct +import threading +import logging +log = None +from select import select +GROUP = '224.110.42.23' +PORT = 42023 +log = logging.getLogger('CholerabNet') +class CholerabMulicastNet(threading.Thread): + def __init__(self,cholerab,group=GROUP,port=PORT): + threading.Thread.__init__(self) + self.cholerab=cholerab + self.group=group + self.port=port + self.initSocket() + def send_char(self,x,y,char): + """ translates given params into network message """ + self.send_mc("%s %d %d" %(str(ord(char)),x,y)) + def send_mc(self,arg): + """ Sends message via multicast""" + try: + log.debug("Sending '%s' to %s:%d" % (arg,self.group,self.port)) + self.ignore_next += 1# we need this to work together correctly with reused sockets + self.s.sendto("%s" % arg,0,(self.group,self.port)) + except Exception ,e: + self.ignore_next -=1 + log.error("IN send_mc:%s"%str(e)) + + def initSocket (self,rcv=1): + ''' Initializes a Multicast socket ''' + host = '' + log.debug("Setting up Multicast Socket") + self.s = socket(AF_INET,SOCK_DGRAM, IPPROTO_UDP) + self.s.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1) + self.s.setsockopt(IPPROTO_IP, IP_MULTICAST_TTL, 32) + self.s.setsockopt(IPPROTO_IP,IP_MULTICAST_LOOP,1) # we do not want our own packets to be replayed + if rcv==1: + log.debug("Configuring for Read AND Write") + self.s.bind((host,PORT)) + mreq = struct.pack("4sl", inet_aton(GROUP), INADDR_ANY) + self.s.setsockopt(IPPROTO_IP,IP_ADD_MEMBERSHIP,mreq) + def run(self): + self.running = 1 + self.ignore_next = 0 + while self.running: + # break if we do not want to loop on + ready,output,exception = select([self.s],[],[],1) # try every second + for r in ready: + if r == self.s: + log.debug(str(self.ignore_next)) + (data,addr) = self.s.recvfrom(1024) + if not self.ignore_next: + log.debug("Received Data from %s, data %s"%(str(addr),str(data))) + self.receive_net(addr,data) + else: + self.ignore_next -= 1 + + def send_stupid(self,addr): + """ sends YOU ARE MADE OF STUPID to the right host """ + #TODO implement me + pass + + def receive_net(self,addr,data): + """ resolves which nick sent the message + TODO handle user resolution in mulicast """ + try: + address,port = addr + arr = str(data).split() + char = arr[0] + x = arr[1] + y = arr[2] + self.cholerab.write_char(int(x),int(y),chr(int(char))) + except Exception, e: + log.error("Triggered YOU ARE MADE OF STUPID: %s" % str(e)) + self.send_stupid(addr) + + def stop(self): + ''' + stops the whole treading stuff gracefully + ''' + self.running=0 diff --git a/.graveyard/cholerab-live/makefu/cholerab.py b/.graveyard/cholerab-live/makefu/cholerab.py new file mode 100755 index 00000000..eb9e66df --- /dev/null +++ b/.graveyard/cholerab-live/makefu/cholerab.py @@ -0,0 +1,36 @@ +#!/usr/bin/python2 +# -*- coding: utf-8 -*- +import curses,time +from view import CursesView +from chol_net import CholerabMulicastNet +import logging +logging.basicConfig(filename='here.log',level=logging.DEBUG) +log = logging.getLogger('main') +class Cholerab: + def __init__(self): + self.view = CursesView(cholerab=self) + self.transport = CholerabMulicastNet(cholerab=self) + def send_char(self,x,y,char): + log.info("Sending %s at (%d,%d) to connected peers" %(char,x,y)) + self.transport.send_char(x,y,char) + + def write_char(self,x,y,char): + log.info("Writing %s at (%d,%d) to view" %(char,x,y)) + self.view.write_char(x,y,char,user=2) + def stop(self): + self.view.stop() + self.transport.stop() + def main(self): + self.view.start() + self.transport.start() + self.view.join() + #after view dies, kill the transport as well + self.transport.stop() + self.transport.join() +def main(): + log.debug('started main') + chol = Cholerab() + chol.main() + +if __name__ == "__main__": + main() diff --git a/cholerab/cholerab-live/view.py b/.graveyard/cholerab-live/makefu/view.py index 6a75f655..6a75f655 100644 --- a/cholerab/cholerab-live/view.py +++ b/.graveyard/cholerab-live/makefu/view.py diff --git a/cholerab/too_old/ttycnser.sh b/.graveyard/cholerab-live/ttycnser.sh index 0972dbbb..0972dbbb 100755 --- a/cholerab/too_old/ttycnser.sh +++ b/.graveyard/cholerab-live/ttycnser.sh diff --git a/.graveyard/cholerab-live/view.py b/.graveyard/cholerab-live/view.py new file mode 100644 index 00000000..6a75f655 --- /dev/null +++ b/.graveyard/cholerab-live/view.py @@ -0,0 +1,112 @@ +#!/usr/bin/python2 + +from curses import * +import socket +import threading +import logging +log = logging.getLogger('cholerab-curses') + +class CursesView(threading.Thread): + def addch(self,char): + """ + adds a char at the current cursor position + abstraction to the curses win.addch() + """ + try: self.win.addch(char) + except: pass + self.cholerab.send_char(self.x,self.y,chr(char)) + def stop(self): + #TODO setting back the whole terminal currently does not work correctly, fix me harder + self.running = False + self.clear() + self.win.refresh() + nocbreak(); self.scr.keypad(0); echo() + #endwin() + + def run(self): + """ + input loop + + TODO add Unicode Input Support + """ + self.running = True + def try_move(x,y): + if x >= self.width: x = 0;y = y+1 + if x < 0 : x = self.width-1; y= y-1 + if y >= self.height : x = x+1;y = 0 + if y < 0 : x = x-1; y = self.height-1 + self.win.move(y,x); return x,y + + while self.running: + c = self.scr.getch() #get_char(self.scr) + #TODO UTF8 here, get_wch not yet implemented + log.debug("Pressed : %d" % c) + if c == KEY_LEFT : self.x -=1 + elif c == KEY_RIGHT : self.x +=1 + elif c == KEY_UP : self.y -=1 + elif c == KEY_DOWN : self.y +=1 + elif c == ord('q') : self.stop() + elif c == 127 or c == KEY_BACKSPACE: + log.info('backspace pressed') + self.x -=1; + self.x,self.y = try_move(self.x,self.y) + self.addch(ord(' ')) + elif c == ord('\n'): + log.info('enter pressed') + self.y +=1; + self.x,self.y = try_move(self.x,self.y) + else : + self.addch(c) + self.x +=1 + self.x,self.y = try_move(self.x,self.y) + self.refresh() + + def write_char(self,x,y,char,user=1): + user = user % 3 + 1 + self.win.addch(y,x,char,color_pair(user)) + self.win.move(self.y,self.x) + self.refresh() + def write_str(self,x,y,string,user=1): + self.win.addstr(y,x,string,color_pair(user)) + self.win.move(self.y,self.x) + self.refresh() + def refresh(self): + self.scr.refresh() + self.win.refresh() + def clear(self): + self.win.clear() + pass + def write_field(self,ar): + """ + writes the whole field with given 2-dimensional array + """ + self.clear() + pass + + def __init__(self,height=24,width=80,cholerab=None,scr=None): + # TODO handle sessions somehow + if scr: + self.scr = scr + else: + self.scr = initscr() + start_color() + init_pair(1,COLOR_WHITE,COLOR_BLACK) + init_pair(2,COLOR_RED,COLOR_BLACK) + init_pair(3,COLOR_GREEN,COLOR_BLACK) + init_pair(3,COLOR_CYAN,COLOR_BLACK) + threading.Thread.__init__(self) + self.cholerab = cholerab + + noecho() + cbreak() + self.scr.keypad(1) + try: curs_set(2) + except: pass # go home with your non-standard terminals! + + begin_x = 0;begin_y = 0 + self.height = height + self.width = width + self.x = 0 ; self.y = 0 + + self.win = newwin(height,width,begin_y,begin_x) + self.clear() diff --git a/noise/Makefile b/.graveyard/noise/Makefile index 0d72b2e9..0d72b2e9 100644 --- a/noise/Makefile +++ b/.graveyard/noise/Makefile diff --git a/noise/TODO b/.graveyard/noise/TODO index a20f74e9..a20f74e9 100644 --- a/noise/TODO +++ b/.graveyard/noise/TODO diff --git a/noise/cron/bin/zeit b/.graveyard/noise/cron/bin/zeit index 168a7b7b..168a7b7b 100755 --- a/noise/cron/bin/zeit +++ b/.graveyard/noise/cron/bin/zeit diff --git a/noise/init.d/noise b/.graveyard/noise/init.d/noise index 075e47d7..075e47d7 100755 --- a/noise/init.d/noise +++ b/.graveyard/noise/init.d/noise diff --git a/noise/modules/cat b/.graveyard/noise/modules/cat index e090acba..e090acba 100755 --- a/noise/modules/cat +++ b/.graveyard/noise/modules/cat diff --git a/noise/modules/chat b/.graveyard/noise/modules/chat index e5badc36..e5badc36 100755 --- a/noise/modules/chat +++ b/.graveyard/noise/modules/chat diff --git a/noise/modules/date b/.graveyard/noise/modules/date index 8cd1b0c1..8cd1b0c1 100755 --- a/noise/modules/date +++ b/.graveyard/noise/modules/date diff --git a/noise/modules/echo b/.graveyard/noise/modules/echo index 344dd963..344dd963 100755 --- a/noise/modules/echo +++ b/.graveyard/noise/modules/echo diff --git a/noise/modules/ein_mal_eins b/.graveyard/noise/modules/ein_mal_eins index e21612a5..e21612a5 100755 --- a/noise/modules/ein_mal_eins +++ b/.graveyard/noise/modules/ein_mal_eins diff --git a/noise/modules/espeak b/.graveyard/noise/modules/espeak index 815d9d99..815d9d99 100755 --- a/noise/modules/espeak +++ b/.graveyard/noise/modules/espeak diff --git a/noise/modules/help b/.graveyard/noise/modules/help index 0763f3a0..0763f3a0 100755 --- a/noise/modules/help +++ b/.graveyard/noise/modules/help diff --git a/noise/modules/join b/.graveyard/noise/modules/join index 68afcb66..68afcb66 100755 --- a/noise/modules/join +++ b/.graveyard/noise/modules/join diff --git a/noise/modules/lang b/.graveyard/noise/modules/lang index 07b6802e..07b6802e 100755 --- a/noise/modules/lang +++ b/.graveyard/noise/modules/lang diff --git a/noise/modules/licht b/.graveyard/noise/modules/licht index 7f170fe2..7f170fe2 120000 --- a/noise/modules/licht +++ b/.graveyard/noise/modules/licht diff --git a/noise/modules/mpc b/.graveyard/noise/modules/mpc index 20abf19b..20abf19b 100755 --- a/noise/modules/mpc +++ b/.graveyard/noise/modules/mpc diff --git a/noise/modules/names b/.graveyard/noise/modules/names index f5922064..f5922064 100755 --- a/noise/modules/names +++ b/.graveyard/noise/modules/names diff --git a/noise/modules/nick b/.graveyard/noise/modules/nick index 5ed1e9d9..5ed1e9d9 100755 --- a/noise/modules/nick +++ b/.graveyard/noise/modules/nick diff --git a/noise/modules/overlord b/.graveyard/noise/modules/overlord index ded8627a..ded8627a 100755 --- a/noise/modules/overlord +++ b/.graveyard/noise/modules/overlord diff --git a/noise/modules/part b/.graveyard/noise/modules/part index d35ac501..d35ac501 100755 --- a/noise/modules/part +++ b/.graveyard/noise/modules/part diff --git a/noise/modules/ping b/.graveyard/noise/modules/ping index acf2529f..acf2529f 100755 --- a/noise/modules/ping +++ b/.graveyard/noise/modules/ping diff --git a/noise/modules/play b/.graveyard/noise/modules/play index 180c1e0c..180c1e0c 100755 --- a/noise/modules/play +++ b/.graveyard/noise/modules/play diff --git a/noise/modules/pong b/.graveyard/noise/modules/pong index eb2df46d..eb2df46d 100755 --- a/noise/modules/pong +++ b/.graveyard/noise/modules/pong diff --git a/noise/modules/query b/.graveyard/noise/modules/query index ceeff8a5..ceeff8a5 100755 --- a/noise/modules/query +++ b/.graveyard/noise/modules/query diff --git a/noise/modules/send_to_channel b/.graveyard/noise/modules/send_to_channel index 4a0470af..4a0470af 100755 --- a/noise/modules/send_to_channel +++ b/.graveyard/noise/modules/send_to_channel diff --git a/noise/modules/sendmail b/.graveyard/noise/modules/sendmail index 182d96e3..182d96e3 100755 --- a/noise/modules/sendmail +++ b/.graveyard/noise/modules/sendmail diff --git a/noise/modules/shackstatus b/.graveyard/noise/modules/shackstatus index a5058f0a..a5058f0a 100755 --- a/noise/modules/shackstatus +++ b/.graveyard/noise/modules/shackstatus dif |