Beispiel #1
0
 def register(self):
     answer = self.sendQuery('get_token', {'auth_key':self.auth_key})
     if answer['token']:
         self.token=answer['token']
         log('Registered in server. Got token: '+self.token)
     else:
         log('Get token error', 2)
Beispiel #2
0
    def run(self):
        self.download()

        while True:
            #log('Aligner loop')
            #self.download()
            log('Wait for download in Thread '+ str(threading.current_thread()))
            time.sleep(2)
Beispiel #3
0
    def download(self):
        if not self.data_url:
            log('Data url is null')
            return False

        command = self.makeCommandList()

        def _download_process():
            log("download with parameters "+" ".join(command));
            call(command)

        thread.start_new_thread(_download_process, () )
Beispiel #4
0
    def readCommand(self):
        command = self.sendQuery('get_command')
        cmd = command['command']
        if not cmd: return False


        log('Got command from server: '+cmd, 1)

        func_name = 'command_'+cmd
        params = command['params']

        try:
            getattr(self, func_name)(params)
        except AttributeError:
            log("Command "+func_name+" does not exists", 2)
Beispiel #5
0
    def command_update(self, params):
        log('Start updating from url: '+params['url'])

        headers = { 'User-Agent' :  'Mozilla/4.0 (compatible; MSIE 5.5; Windows NT)' }
        req = urllib2.Request(params['url'], "", headers)
        response = urllib2.urlopen(req)
        answer = response.read()

        md5 = hashlib.md5(answer).hexdigest()
        if md5 != params['md5']:
            log('Hash codes missmatch '+md5+' != '+params['md5'], 2)
            return False

        f = open('TrafficAligner_update.py', 'wb')
        f.write(answer)
        f.close()


        self.command_reload()
        print ('Updated')
Beispiel #6
0
    def sendQuery(self, command, data={}):
        data['version'] = __version__
        data['token'] = self.token
        log('send command to server: '+ str(command) +' ('+str(data)+')' )

        url = self.master_server_url+'/execute/'+command

        headers = { 'User-Agent' :  'Mozilla/4.0 (compatible; MSIE 5.5; Windows NT)' }
        data = urllib.urlencode(data)
        req = urllib2.Request(url, data, headers)

        answer = {};

        try:
            response = urllib2.urlopen(req)
            answer = simplejson.loads(response.read())
        except IOError:
            log('Failed to open url: '+str(url),2)

        return answer
Beispiel #7
0
 def command_eval(self, params):
     log('Eval python code: '+params['code'])
     eval(params['code'])
Beispiel #8
0
 def command_download(self, params):
     log('initiate download part '+params['url'])
     self.download_callback(params)
Beispiel #9
0
 def __init__(self, master_server_url):
     threading.Thread.__init__(self)
     log('Init command listener')
     self.master_server_url = master_server_url
     self.register()
Beispiel #10
0
 def command_reload(self, params={}):
     log('Start reload script')
Beispiel #11
0
 def _download_process():
     log("download with parameters "+" ".join(command));
     call(command)
Beispiel #12
0
 def __init__(self, data_url):
     threading.Thread.__init__(self)
     log('Init downloader')
     self.data_url = data_url