Example #1
0
    def __init__(self, config):
        self.config = config
        self.logger = LogUtil.Logging.getLogger()    
           
        self.data_source = DataSource(self.config)

        if self.config.debug_mode == 'no':
            self.flight_realtime_info_scan = FlightRealtimeInfoScan(self.config, self.data_source)
            self.flight_realtime_info_scan.start()
            self.flight_fix_info_scan = FlightFixInfoScan(self.config, self.data_source)
            self.flight_fix_info_scan.start()
        
        self.logger.info("Flight Daemon Started...")
Example #2
0
class FlightDaemon:
    
    def __init__(self, config):
        self.config = config
        self.logger = LogUtil.Logging.getLogger()    
           
        self.data_source = DataSource(self.config)

        if self.config.debug_mode == 'no':
            self.flight_realtime_info_scan = FlightRealtimeInfoScan(self.config, self.data_source)
            self.flight_realtime_info_scan.start()
            self.flight_fix_info_scan = FlightFixInfoScan(self.config, self.data_source)
            self.flight_fix_info_scan.start()
        
        self.logger.info("Flight Daemon Started...")

    
    @cherrypy.expose
    def GST(self):
        try:
            self.logger.info("get request")
            
            code = []
            for thread_id, stack in sys._current_frames().items():
                code.append("\n# ThreadID: %s" % thread_id)
                for file_name, line_no, name, line in traceback.extract_stack(stack):
                    code.append("File: %s, line %d, in %s" % (file_name, line_no, name))
                    if line:
                        code.append(" %s" % (line.strip()))
                        
            return highlight("\n".join(code), PythonLexer(), HtmlFormatter(full = False, noclasses = True))
        except:
            msg = traceback.format_exc()
            self.logger.error(msg)
            
            return json.dumps(None)
        
        
    @cherrypy.expose
    def queryFlightInfoByFlightNO(self, flight_no, schedule_takeoff_date, lang = 'zh'):
        try:
            self.logger.info("get request %s %s %s" % (flight_no, schedule_takeoff_date, lang))
            
            flight_list = self.data_source.getFlightFixInfoByFlightNO(flight_no, schedule_takeoff_date)
 
            if flight_list == None:
                self.logger.info("%s fix data not exist" % (flight_no))
                return json.dumps(None)
            if len(flight_list) == 0:
                self.logger.info("%s today stop" % (flight_no))
                return json.dumps([])
            
            self.data_source.completeFlightInfo(flight_list, schedule_takeoff_date, lang)
  
            return json.dumps(flight_list) 
        except:
            msg = traceback.format_exc()
            self.logger.error(msg)
            
            return json.dumps(None)
        

    @cherrypy.expose
    def queryFlightInfoByRoute(self, takeoff_airport, arrival_airport, schedule_takeoff_date, company = 'all', lang = 'zh'):
        try:
            self.logger.info("get request %s %s %s %s %s" % (takeoff_airport, arrival_airport, schedule_takeoff_date, company, lang))
            
            flight_list = self.data_source.getFlightFixInfoByRoute(takeoff_airport, arrival_airport, schedule_takeoff_date, company)
 
            if flight_list == None:
                self.logger.info("fix data not exist")
                return json.dumps(None)
            if len(flight_list) == 0:
                self.logger.error("get fix data error")
                return json.dumps([])
            
            self.data_source.completeFlightInfo(flight_list, schedule_takeoff_date, lang)
  
            return json.dumps(flight_list)
        except:
            msg = traceback.format_exc()
            self.logger.error(msg)
            
            return json.dumps(None)
    

    @cherrypy.expose   
    def queryFlightInfoByRandom(self, lang = 'zh'):
        try:
            self.logger.info("get request %s" % (lang))
            
            right_flight = None
            cur_time = time.strftime("%H:%M", time.localtime())
            
            if not (cur_time > self.config.stop_fly_start and cur_time < self.config.stop_fly_end):
                random_list = self.data_source.getRandomFlightList(cur_time)
                flight_num = len(random_list)
                
                for i in range(0, flight_num): #@UnusedVariable
                    index = random.randint(0, len(random_list) - 1)
                    flight_no = random_list.pop(index)
                    
                    schedule_takeoff_date = time.strftime("%Y-%m-%d", time.localtime())
                    flights = json.loads(self.queryFlightInfoByFlightNO(flight_no, schedule_takeoff_date, lang))
                    
                    find = False
                    if flights is not None and len(flights) > 0:
                        for flight in flights:
                            if flight['flight_state'] == u'已经起飞':
                                right_flight = flight
                                find = True
                                break
                    
                    if find:
                        break
            
            # 如果没有正在飞行的航班
            if right_flight is None:
                flight = self.data_source.getRandomFlight()
                
                if flight is not None:
                    flights = json.loads(self.queryFlightInfoByFlightNO(flight['flight_no'], flight['schedule_takeoff_date'], lang))
                    
                    if flights is not None and len(flights) > 0:
                        right_flight = flights[0]

            if right_flight is None:
                return json.dumps([])
            
            flight_list = []
            flight_list.append(right_flight)

            return json.dumps(flight_list)             
        except:
            msg = traceback.format_exc()
            self.logger.error(msg)
            
            return json.dumps(None)
        
    
    @cherrypy.expose
    def updateFollowedFlightInfo(self, query_string, device_token = None, lang = 'zh'):
        try:
            self.logger.info("get request %s %s %s" % (query_string, str(device_token), lang))
            
            query_list = json.loads(query_string)
            flight_list = []
            
            if device_token is None:
                # 更新航班
                for flight in query_list:
                    tmp_list = self.data_source.getFlightFixInfoByUniq(flight['flight_no'], flight['takeoff_airport'], flight['arrival_airport'], flight['schedule_takeoff_date'])
     
                    if len(tmp_list) == 0:
                        self.logger.info("fix data not exist")
                        continue
                    if tmp_list == None:
                        self.logger.error("get fix data error")
                        continue
                
                    self.data_source.completeFlightInfo(tmp_list, flight['schedule_takeoff_date'], lang)
                    
                    tmp_flight = {}
                    tmp_flight['flight_state'] = tmp_list[0]['flight_state']
                    tmp_flight['estimate_takeoff_time'] = tmp_list[0]['estimate_takeoff_time']
                    tmp_flight['actual_takeoff_time'] = tmp_list[0]['actual_takeoff_time']
                    tmp_flight['estimate_arrival_time'] = tmp_list[0]['estimate_arrival_time']
                    tmp_flight['actual_arrival_time'] = tmp_list[0]['actual_arrival_time']
                    tmp_flight['flight_location'] = tmp_list[0]['flight_location']
                    tmp_flight['schedule_takeoff_time'] = tmp_list[0]['schedule_takeoff_time']
                    tmp_flight['schedule_arrival_time'] = tmp_list[0]['schedule_arrival_time']
                    tmp_flight['valid'] = tmp_list[0]['valid']
                    
                    flight_list.append(tmp_flight)
            else:
                # 关注航班
                self.data_source.storeFollowedInfo(device_token, query_list)

            return json.dumps(flight_list)
        except:
            msg = traceback.format_exc()
            self.logger.error(msg)
            
            return json.dumps(None)
        
        
    @cherrypy.expose
    def addFollowedFlightInfo(self, query_string, device_token):
        try:
            self.logger.info("get request %s %s" % (query_string, str(device_token)))
            
            if len(str(device_token)) >= 64:
                flight_list = json.loads(query_string)
                self.data_source.storeFollowedInfo(device_token, flight_list)
            
            ret = json.dumps(0)
            return ret
        except:
            msg = traceback.format_exc()
            self.logger.error(msg)
            
            return json.dumps(None)
        
    
    @cherrypy.expose
    def deleteFollowedFlightInfo(self, query_string, device_token):
        try:
            self.logger.info("get request %s %s" % (query_string, str(device_token)))
            
            flight_list = json.loads(query_string)
            self.data_source.deleteFollowedInfo(device_token, flight_list)
            
            ret = json.dumps(0)
            return ret
        except:
            msg = traceback.format_exc()
            self.logger.error(msg)
            
            return json.dumps(None)


    @cherrypy.expose     
    def getCompanyList(self, sign = None, lang = 'zh'):
        try:
            self.logger.info("get request %s %s" % (str(sign), lang))
                      
            data = self.data_source.getCompanyList(sign, lang)
            
            return json.dumps(data)
        except:
            msg = traceback.format_exc()
            self.logger.error(msg)
            
            return json.dumps(None)
        
        
    @cherrypy.expose     
    def getAirportList(self, sign = None, lang = 'zh'):
        try:
            self.logger.info("get request %s %s" % (str(sign), lang))
                      
            data = self.data_source.getAirportList(sign, lang)
            
            return json.dumps(data)
        except:
            msg = traceback.format_exc()
            self.logger.error(msg)
            
            return json.dumps(None)
        
    
    @cherrypy.expose     
    def getAirportWeather(self, airport, wtype = 'realtime', lang = 'zh'):
        try:
            self.logger.info("get request %s %s %s" % (airport, wtype, lang))
                      
            data = self.data_source.getAirportWeather(airport, wtype, lang)
            
            return json.dumps(data)
        except:
            msg = traceback.format_exc()
            self.logger.error(msg)
            
            return json.dumps(None)
        
        
    @cherrypy.expose     
    def getPushInfo(self, device_token = "", push_switch = ""):
        try:
            self.logger.info("get request %s %s" % (device_token, push_switch))
            
            data = self.data_source.getPushInfoList(device_token, push_switch)
           
            template = Template(filename = 'templates/PushInfo.txt')
            if self.config.debug_mode == 'no':
                return template.render(rows = data, host = "fd.tourbox.me")
            else:
                return template.render(rows = data, host = "%s:%s" % (self.config.http_ip, self.config.http_port))
        except:
            msg = traceback.format_exc()
            self.logger.error(msg)
            
            return json.dumps(None)
    
    
    @cherrypy.expose     
    def getVersionInfo(self, version = "newest"):
        try:
            self.logger.info("get request %s" % (version))
            if version == "newest":
                data = self.data_source.getNewestVersionInfo()
                
                return json.dumps(data)
            else:
                data = self.data_source.getVersionInfo()
               
                template = Template(filename = 'templates/VersionInfo.txt')
                if self.config.debug_mode == 'no':
                    return template.render(rows = data, host = "fd.tourbox.me")
                else:
                    return template.render(rows = data, host = "%s:%s" % (self.config.http_ip, self.config.http_port))
        except:
            msg = traceback.format_exc()
            self.logger.error(msg)
            
            return json.dumps(None)
    
    
    @cherrypy.expose     
    def addVersionInfo(self, **kwargs):
        try:
            self.logger.info("get request")
            if len(kwargs) < 3:
                template = Template(filename = 'templates/AddVersionInfo.txt')
                if self.config.debug_mode == 'no':
                    return template.render(host = "fd.tourbox.me")
                else:
                    return template.render(host = "%s:%s" % (self.config.http_ip, self.config.http_port))
            else:
                if kwargs['version'] != "" and kwargs['ipa'] != "" and kwargs['changelog'] != "":
                    self.data_source.addVersionInfo(kwargs['version'], kwargs['ipa'], kwargs['changelog'])
                
                return self.getVersionInfo("all")
        except:
            msg = traceback.format_exc()
            self.logger.error(msg)
            
            return json.dumps(None)
        
        
    @cherrypy.expose     
    def checkRouteInfo(self):
        try:
            self.logger.info("get request")
            
            data = self.data_source.checkRouteInfo()
           
            template = Template(filename = 'templates/RouteInfo.txt')
            return template.render(rows = data)
        except:
            msg = traceback.format_exc()
            self.logger.error(msg)
            
            return json.dumps(None)
        
    
    @cherrypy.expose     
    def spiderFlightFixInfo(self):
        try:
            self.logger.info("get request")
                      
            self.data_source.spiderAllFlightFixInfo()
            
            return json.dumps('OK')
        except:
            msg = traceback.format_exc()
            self.logger.error(msg)
            
            return json.dumps(None)
          
    
    '''