Skip to content
ais_http.py 14.6 KiB
Newer Older
developer8's avatar
developer8 committed
#!/usr/bin/env python

"""
@author: Vladan S
developer8's avatar
developer8 committed
@version: 2.1.6   (lib:4.9.11)
developer8's avatar
developer8 committed
@copyright: D-Logic   http://www.d-logic.net/nfc-rfid-reader-sdk/
developer8's avatar
developer8 committed
 
"""

import os
import sys
import cgi
import threading
import time
import traceback
import requests
import urllib2,urllib
from platform import platform
from urlparse import urlparse, parse_qs
from BaseHTTPServer import BaseHTTPRequestHandler,HTTPServer
from ctypes import *
from socket import *

developer8's avatar
developer8 committed

from shell.ais_shell import *
from constants import *
developer8's avatar
developer8 committed

def http_request(path, post_attrib):
    try:
developer8's avatar
developer8 committed
        #req_header = ("Content-type", "application/x-www-form-urlencoded")
        #req = requests.get(path,params=post_attrib,headers=req_header)
        
developer8's avatar
developer8 committed
        req = urllib2.Request(path, post_attrib)        
developer8's avatar
developer8 committed
        req.add_header("Content-type", "application/x-www-form-urlencoded")       
        page = urllib2.urlopen(req).read()
developer8's avatar
developer8 committed
        return page
    except Exception as e:
developer8's avatar
developer8 committed
        return e

developer8's avatar
developer8 committed
class GetHandler(BaseHTTPRequestHandler):
developer8's avatar
developer8 committed
   
    global url_query
    
developer8's avatar
developer8 committed
    def do_GET(self):        
        try:            
            f = open(os.curdir + os.sep + "ais_readers.html")
developer8's avatar
developer8 committed
            self.send_response(200)
            self.send_header("Content-type","text/html")
            self.end_headers()
            self.wfile.write(f.read())
            f.close()            
            return
        except IOError:
            self.send_error(404,"File Not Found: %s" % self.path)
        return    
developer8's avatar
developer8 committed
    def do_POST(self):
developer8's avatar
developer8 committed
        try:    
            global url_query                      
            dev = DEV_HND       
            ctype, pdict = cgi.parse_header(self.headers['content-type'])
            if ctype == 'multipart/form-data':
                pq = cgi.parse_multipart(self.rfile, pdict)
            elif ctype == 'application/x-www-form-urlencoded':
                length = int(self.headers['content-length'])
                pq = cgi.parse_qs(self.rfile.read(length), keep_blank_values=1)
            else:
                pq = {}
         
developer8's avatar
developer8 committed
            f = ''.join(pq[FUNCTION])             
developer8's avatar
developer8 committed
            seconds = int(''.join(pq[RTE]))
developer8's avatar
developer8 committed
            device = ''.join(pq[DEVICE])                    
           
            # log_dir = ''.join(pq[LOG_DIR]) #CUR_DIR?
            # read_deb_log = ''.join(pq[READ_DEBUG_LOG])
            # save_deb_log = ''.join(pq[SAVE_DEBUG_LOG])
developer8's avatar
developer8 committed
            
            if GetBaseName() == AIS_MAIN:
developer8's avatar
developer8 committed
                log_dir = ''.join(pq[LOG_DIR]) #CUR_DIR?
                read_deb_log = ''.join(pq[READ_DEBUG_LOG])
                save_deb_log = ''.join(pq[SAVE_DEBUG_LOG])
developer8's avatar
developer8 committed
                if f == "D":               
                    self.send_response(200)
                    self.send_header("Content-type","text/html")
developer8's avatar
developer8 committed
                    self.end_headers()                    
developer8's avatar
developer8 committed
                    #c =  open(os.curdir + os.sep + BBB_DEBUG_LOG)
                    c = open(os.getcwd() + os.sep + log_dir + os.sep +  read_deb_log)
developer8's avatar
developer8 committed
                    self.wfile.write("<html><head><title>Read Debug Log</title></head><body>")
                    for line in c:                    
                        l = line.encode("utf-8") 
                        self.wfile.write("<p>%s</p>" % l)                                   
                    c.close()
                    self.wfile.write("</body></html>")
                    self.wfile.close()
                    return
            
            if GetBaseName() == AIS_MAIN:
developer8's avatar
developer8 committed
                log_dir = ''.join(pq[LOG_DIR]) #CUR_DIR?
                read_deb_log = ''.join(pq[READ_DEBUG_LOG])
                save_deb_log = ''.join(pq[SAVE_DEBUG_LOG]) 
                if f == "SD":                  
                    c = open(os.path.join(os.curdir,os.sep,log_dir,save_debug_log))
developer8's avatar
developer8 committed
                    self.send_response(200)
                    self.send_header("Content-type","text/json")
                    self.end_headers()
                    self.wfile.write(c.read())
                    c.close() 
developer8's avatar
developer8 committed
                    self.wfile.close()                                       
developer8's avatar
developer8 committed
                    return
developer8's avatar
developer8 committed


developer8's avatar
developer8 committed
            # if device == None or device == "":
                # dev.hnd  = HND_LIST[0]
                # device   = dev.idx          
            # else:                                            
                # dev.hnd = HND_LIST[int(device) -1]
                      
developer8's avatar
developer8 committed
            if len(HND_LIST) == 0:
                self.wfile.write(">> NO DEVICES FOUND " )
                return
            if not device.isdigit():                 
developer8's avatar
developer8 committed
                dev.hnd = HND_LIST[0]
developer8's avatar
developer8 committed
            elif int(device) > len(HND_LIST) or int(device) == 0:
developer8's avatar
developer8 committed
                self.wfile.write("dev[%s] : NO DEVICE FOUND " % device)
                return
            else:
developer8's avatar
developer8 committed
                dev.hnd = HND_LIST[int(device) -1]
developer8's avatar
developer8 committed
                                                                         
            if pq[START_INDEX] != None or pq[END_INDEX] != None:
               start_index = (''.join(pq[START_INDEX]))
               end_index   = (''.join(pq[END_INDEX]))
              
developer8's avatar
developer8 committed
            
developer8's avatar
developer8 committed
            if pq[START_TIME] != None or pq[END_TIME] != None:
               start_time = (''.join(pq[START_TIME]))        
               end_time   = (''.join(pq[END_TIME]))
             
               
            if pq[WHITE_LIST_WRITE] != None:            
                white_list_write = ''.join(pq[WHITE_LIST_WRITE])
               
developer8's avatar
developer8 committed
            
developer8's avatar
developer8 committed
            if pq[BLACK_LIST_WRITE]!= None:
                black_list_write = ''.join(pq[BLACK_LIST_WRITE])  
            
            if pq[DEFAULT_APP_PASS] != None:
                set_def_pass = ''.join(pq[DEFAULT_APP_PASS])
developer8's avatar
developer8 committed
                
developer8's avatar
developer8 committed
            if pq[NEW_PASS] != None:
                new_pass  = ''.join(pq[NEW_PASS])
                       
            if pq[UNREAD_LOG] != None:                 
                get_unread_log = (''.join(pq[UNREAD_LOG]))
developer8's avatar
developer8 committed
            if pq[LIGHTS] != None:
                lights_choise = ''.join(pq[LIGHTS])   
                               
            if pq[EDIT_LIST] != None:
                edit_list_choise = ''.join(pq[EDIT_LIST])
               
                      
            if pq[DEVICE_TYPE] != None:
                device_type = ''.join(pq[DEVICE_TYPE])
developer8's avatar
developer8 committed
            if pq[DEVICE_ID] != None:
                device_id  = ''.join(pq[DEVICE_ID])
 
            if f == 'q':                           
                self.wfile.write(GetListInformation())
                
            elif f == 'o':                            
                pass                
                self.wfile.write(AISOpen())                
                    
            elif f == 'c':
                self.wfile.write(AISClose())
developer8's avatar
developer8 committed
            if f == 'd':                             
                self.wfile.write('GET DEVICES COUNT > %s\n' % AISUpdateAndGetCount())                        
        
            elif f == 't': 
                self.wfile.write(active_device()) 
                self.wfile.write(AISGetTime())       
developer8's avatar
developer8 committed
            
developer8's avatar
developer8 committed
            elif f == 'T':             
                self.wfile.write(sys_get_timezone_info()+ "\n")
                self.wfile.write(AISSetTime())
developer8's avatar
developer8 committed
            
developer8's avatar
developer8 committed
            elif f == 'r':
                pass                
                stop_time = c_uint64()
                stop_time = time.time() + seconds #10
                dev = DEV_HND
                self.wfile.write("Wait for RTE for %d sec ...\n" % seconds)       
                while (time.ctime(time.time()) < time.ctime(stop_time)) :
                    for hnd in HND_LIST:
                        dev.hnd = hnd            
                        r, rte = MainLoop()                       
                        self.wfile.write(rte)
                    time.sleep(THD_SLEEP)     
                self.wfile.write ("End RTE listen")    
                
developer8's avatar
developer8 committed
                  
developer8's avatar
developer8 committed
            elif f == 'l':                         
developer8's avatar
developer8 committed
                self.wfile.write(log_get(dev.hnd))
developer8's avatar
developer8 committed
                
           
            elif f == 'n':                                                          
developer8's avatar
developer8 committed
                self.wfile.write(log_by_index(int(start_index), int(end_index), dev.hnd))               
developer8's avatar
developer8 committed
               
                
            elif f == 'N':                                                       
developer8's avatar
developer8 committed
                self.wfile.write(log_by_time(int(start_time), int(end_time), dev.hnd))  
developer8's avatar
developer8 committed
                
                
            elif f == 'u':                
                get_unread_log = int(get_unread_log)                                
                self.wfile.write(get_unread_log_one(get_unread_log))
           
            elif f == 'v':            
                self.wfile.write("AIS_GetDLLVersion() >> %s\n" % AISGetLibraryVersionStr())
                      
            elif f == 'w':               
                self.wfile.write(whitelist_read())
                
            elif f == 'b':                
                self.wfile.write(blacklist_read())
developer8's avatar
developer8 committed

developer8's avatar
developer8 committed
            elif f == 'W':                                    
                self.wfile.write(whitelist_write(white_list_write))                                  
developer8's avatar
developer8 committed

developer8's avatar
developer8 committed
            elif f == 'B':                                                
                self.wfile.write(blacklist_write(black_list_write))                                 
developer8's avatar
developer8 committed

developer8's avatar
developer8 committed
            elif f == 'L':                          
                self.wfile.write(TestLights(lights_choise))
                
            elif f == 'g':               
                self.wfile.write(get_io_state())
            elif f == 'G':               
                self.wfile.write(lock_open())
            elif f == 'y':               
                self.wfile.write(relay_toogle())
          
developer8's avatar
developer8 committed
            elif f == 'P':
                global PASS
developer8's avatar
developer8 committed
                self.wfile.write("Actual application password is :%s\n" % PASS)
                if  len(set_def_pass) == 0:
                    self.wfile.write("Patch - new pass = default pass\n")
                    set_def_pass = PASS
                PASS = set_def_pass                    
                self.wfile.write(password_set_default(set_def_pass)) 
                
            elif f == 'p':
developer8's avatar
developer8 committed
                global PASS
developer8's avatar
developer8 committed
                self.wfile.write("Old password is actual application password: %s\n" % PASS)           
                self.wfile.write("New password for units ( and application ): %s\n" % new_pass)
                if  len(new_pass) == 0:
                    self.wfile.write ("Patch - new pass = default pass\n")
                    new_pass = PASS 
                self.wfile.write("Try set new password for units= %s\n" % (new_pass))
                self.wfile.write(password_change(new_pass))                       

            elif f == 'd':
                self.wfile.write(AISGetDevicesForCheck()) 
          
            elif f == 'f':               
                self.wfile.write(AISGetVersion())
developer8's avatar
developer8 committed
            
developer8's avatar
developer8 committed
            elif f == 'i':              
                self.wfile.write(AISGetVersion())
                self.wfile.write(AISGetTime())
                self.wfile.write(sys_get_timezone_info()+ "\n")
           
            elif f == 'Q':             
                if edit_list_choise == AVAILABLE_DEVICES :            
                    self.wfile.write(edit_device_list(1))
                elif edit_list_choise == ACTUAL_LIST:
                    self.wfile.write(edit_device_list(2))
                elif edit_list_choise == CLEAR_LIST:
                    self.wfile.write(edit_device_list(3))
                elif edit_list_choise == ADD_DEVICE:
                    self.wfile.write("AIS_List_AddDevicesForCheck() ...\n")
                    self.wfile.write(edit_device_list(4,"AIS_List_AddDeviceForCheck",int(device_type),int(device_id)))
                elif edit_list_choise == ERASE_DEVICE:
                    self.wfile.write("AIS_List_EraseDeviceForCheck()...\n")
                    self.wfile.write(edit_device_list(5,"AIS_List_EraseDeviceForCheck",int(device_type),int(device_id)))
             
                else:
                    self.wfile.write("")
           
            elif f == 'E':
                self.wfile.write(ee_lock())
developer8's avatar
developer8 committed
            
developer8's avatar
developer8 committed
            elif f == 'e':
                self.wfile.write(ee_unlock())
           
            elif f == 'F': 
                bin_fname = ''.join(pq[BIN_FNAME])          
                self.wfile.write(fw_update(fw_name=bin_fname))
                
            elif f == 's':
                conf_file_rd = ''.join(pq[CONFIG_FILE_READ])
                self.wfile.write(config_file_rd(fname=conf_file_rd))
                
            elif f == 'S':
                conf_file_wr = ''.join(pq[CONFIG_FILE_WRITE])
                self.wfile.write(config_file_wr(fname=conf_file_wr))
developer8's avatar
developer8 committed
         
developer8's avatar
developer8 committed
            elif f == 'x':
                self.wfile.write("\nServer stopped !\nClose program !\n")            
                shut_event.set()
                httpd.server_close()                
                if sys.platform.startswith('linux'):
                    os.system('pkill -9 python')
                elif sys.platform.startswith('win'):                    
                    sys.exit(0)                
            return
                
        except (Exception) as error_mess:                    
            self.wfile.write(error_mess)
developer8's avatar
developer8 committed
           # self.wfile.write(traceback.print_exc())
developer8's avatar
developer8 committed
        
def RunAll():   
    serv = threading.Thread(target=handler_server)   
developer8's avatar
developer8 committed
    serv.start()       
    while True:
developer8's avatar
developer8 committed
        try:                  
            if serv.isAlive():            
developer8's avatar
developer8 committed
                serv.join(timeout = SERV_JOIN)                             
developer8's avatar
developer8 committed
        except (KeyboardInterrupt,SystemExit,Exception) as e:
            httpd.server_close()
            print '\nServer stopped\nProgram close',e
developer8's avatar
developer8 committed
            shut_event.set()
            if sys.platform.startswith('linux'):
                os.system('pkill -9 python')
            elif sys.platform.startswith('win'):            
                sys.exit(0)            
developer8's avatar
developer8 committed
            break
            

def handler_server():
developer8's avatar
developer8 committed
    global httpd
developer8's avatar
developer8 committed
    while not shut_event.is_set():        
        my_lock.acquire()                                                         
        httpd.handle_request()
        my_lock.release()
        time.sleep(THD_SLEEP)

def init():   
    print AISGetLibraryVersionStr() 
developer8's avatar
developer8 committed
    global httpd   
developer8's avatar
developer8 committed
    #dev_list() 
    list_device()    
developer8's avatar
developer8 committed
    httpd = HTTPServer((HTTP_SERVER_NAME,HTTP_SERVER_PORT),GetHandler) 
    httpd.socket.setsockopt(SOL_SOCKET,SO_REUSEADDR,1) 
    RunAll() 



my_lock = threading.Lock()
shut_event = threading.Event()

if __name__ == '__main__': 
developer8's avatar
developer8 committed
    global httpd