This repository has been archived on 2021-09-15. You can view files and clone it, but cannot push or open issues or pull requests.
DUT2PTUT/superTornado.py

220 lines
7.9 KiB
Python
Raw Normal View History

"""Seveur Tornado"""
2014-02-27 15:43:58 +01:00
import tornado.ioloop
import tornado.web
2014-02-27 16:55:33 +01:00
import tornado.httpserver
import tornado.websocket
2014-02-27 23:39:19 +01:00
import tornado.options
from tornado.ioloop import PeriodicCallback
"""Autre """
2014-03-02 23:07:43 +01:00
import sys
2014-02-28 06:55:36 +01:00
import time
2014-02-28 03:16:09 +01:00
import base64
import socket
import os
2014-02-28 04:07:56 +01:00
from urllib import urlopen
"""Nos Fichier"""
from m.loadConf import *
from m.login import *
from m.log import *
2014-02-27 15:43:58 +01:00
"""Global"""
config = LoadConf()
blind = False
2014-03-03 00:13:47 +01:00
ipCamera = ""
portCamera = ""
portServ =""
2014-03-03 13:02:51 +01:00
log = Log()
urlCamera=""
urlSocket=""
2014-02-27 22:45:07 +01:00
2014-03-02 21:53:08 +01:00
class BaseHandler(tornado.web.RequestHandler):
2014-02-27 23:12:23 +01:00
def get_current_user(self):
return self.get_secure_cookie("user")
2014-02-27 22:46:17 +01:00
2014-03-02 22:19:10 +01:00
2014-02-27 23:12:23 +01:00
class MainHandler(BaseHandler):
2014-02-27 16:06:38 +01:00
def get(self):
self.render("v/index.html")
2014-03-02 21:10:30 +01:00
def post(self):
2014-02-27 18:43:55 +01:00
iden = self.get_argument("id","")
mdp = self.get_argument("mdp","")
2014-02-27 20:06:37 +01:00
login = Login()
autorise = login.connexion(iden, mdp)
2014-03-02 22:19:10 +01:00
self.set_secure_cookie("user", iden)
2014-02-27 20:06:37 +01:00
if autorise == True:
self.set_secure_cookie("user", iden,1)
2014-02-27 23:12:23 +01:00
self.redirect("/video")
2014-02-27 20:10:46 +01:00
else:
log.printL("->An unauthorized user try to access : " + self.request.remote_ip,lvl.WARNING)
self.redirect("/unauthorized")
2014-02-27 17:56:39 +01:00
class VideoHandler(BaseHandler):
2014-02-27 20:53:48 +01:00
def get(self):
2014-03-03 15:13:44 +01:00
if not self.current_user :
2014-02-27 23:12:23 +01:00
self.redirect("/")
return
self.render("v/video.html", url=urlSocket)
class UnauthorizedHandler(BaseHandler):
def get(self):
self.render("v/illegal.html")
def post(self):
force = self.get_argument("illegalAccess","")
if force == "1" :
self.set_secure_cookie("user", "IllegalUser",1)
self.redirect("/video")
else :
self.redirect("/")
class DisconnectionHandler(BaseHandler):
def post(self):
self.clear_cookie("user")
self.redirect("/")
class WSocketHandler(BaseHandler,tornado.websocket.WebSocketHandler):
2014-02-28 06:01:10 +01:00
def open(self) :
2014-03-03 15:17:34 +01:00
if not self.current_user :
self.close()
2014-02-28 07:52:19 +01:00
return
2014-03-03 22:14:32 +01:00
log.printL("->Websocket Open : " + self.request.remote_ip,lvl.SUCCESS)
2014-03-02 22:19:10 +01:00
iden = self.current_user
2014-03-03 15:11:38 +01:00
if iden != "IllegalUser":
log.printL("->"+iden + " : Authorized user connection : "+self.request.remote_ip,lvl.INFO)
2014-03-03 14:40:03 +01:00
if blind == True:
log.printL('->Send audio alarm authorized user',lvl.INFO)
2014-03-03 22:09:19 +01:00
self.send_signal_house('maison.request("GET", "micom/say.php?source=toto&text=Connection%20a%20la%20camera%20autorisee")')
2014-03-01 17:41:24 +01:00
else:
log.printL('->Send visual alarm authorized user',lvl.INFO)
2014-03-03 22:09:19 +01:00
self.send_signal_house('maison.request("GET", "micom/lamp.php?room=salon1&order=1")')
2014-03-02 22:19:10 +01:00
else :
log.printL("->"+iden + ": Unauthorized user connection : " + self.request.remote_ip,lvl.WARNING)
2014-03-03 14:40:03 +01:00
if blind == True:
log.printL('->Send audio alarm unauthorized user',lvl.WARNING)
2014-03-03 22:09:19 +01:00
self.send_signal_house('maison.request("GET", "micom/say.php?source=toto&text=Connection%20a%20la%20camera%20non%20autorisee")')
2014-03-02 22:19:10 +01:00
else:
log.printL('->Send visual alarm unauthorized user',lvl.WARNING)
2014-03-03 22:09:19 +01:00
self.send_signal_house('maison.request("GET", "micom/lamp.php?room=salon1&order=1")')
2014-03-02 21:10:30 +01:00
self.send_image()
def on_message(self,mesg):
2014-03-03 22:14:32 +01:00
log.printL("->Demand Data Receive : " + self.request.remote_ip,lvl.INFO)
2014-03-02 21:10:30 +01:00
self.send_image()
2014-02-28 06:02:35 +01:00
def on_close(self):
2014-03-03 22:14:32 +01:00
log.printL("->Websocket Closed : "+self.request.remote_ip,lvl.SUCCESS)
2014-03-02 22:26:37 +01:00
iden = self.current_user
2014-03-03 15:11:38 +01:00
if iden != "IllegalUser":
2014-03-03 22:14:32 +01:00
log.printL("->"+iden+" : Authorized User Deconnection : "+self.request.remote_ip,lvl.INFO)
2014-03-02 22:19:10 +01:00
else :
2014-03-03 22:14:32 +01:00
log.printL("->"+iden +" : Unauthorized User Deconnection : "+self.request.remote_ip,lvl.WARNING)
2014-03-01 17:37:17 +01:00
if blind == True:
2014-03-03 22:14:32 +01:00
log.printL('->Send Audio Alarm Deconnection User', lvl.INFO)
2014-03-03 22:09:19 +01:00
self.send_signal_house('maison.request("GET", "micom/say.php?source=toto&text=Connection%20a%20la%20camera%20rompue")')
2014-03-01 17:37:17 +01:00
else:
2014-03-03 22:14:32 +01:00
log.printL('->Send Visual Alarm Deconnection User ...',lvl.INFO)
2014-03-03 22:09:19 +01:00
self.send_signal_house('maison.request("GET", "micom/lamp.php?room=salon1&order=0")')
2014-02-28 06:01:10 +01:00
2014-03-03 22:07:34 +01:00
def send_signal_house(self, pRq) :
log.printL('maison = httplib.HTTPConnection("192.168.16.150", 80)',lvl.DEBUG)
try :
log.printL('maison.request("GET",'+pRq,lvl.DEBUG)
2014-03-03 22:14:32 +01:00
log.printL("->Signal To House Send Successfully", lvl.SUCCESS)
2014-03-03 22:07:34 +01:00
except Exception, e :
log.printL(e, lvl.FAIL)
2014-03-03 22:14:32 +01:00
log.printL("->Signal To House Send Failed", lvl.FAIL)
2014-03-02 21:10:30 +01:00
def send_image(self) :
try :
socket.setdefaulttimeout(5)
2014-03-03 21:30:41 +01:00
f = urlopen(urlCamera)
2014-03-02 21:10:30 +01:00
data = f.read()
encoded = base64.b64encode(data)
self.write_message(encoded)
2014-03-03 22:14:32 +01:00
log.printL( "->Image Data Send : " + self.request.remote_ip, lvl.INFO)
2014-03-02 21:10:30 +01:00
except Exception, e :
log.printL(e,lvl.FAIL)
2014-03-02 21:10:30 +01:00
self.write_message("error")
2014-02-27 16:06:38 +01:00
application = tornado.web.Application([
(r"/", MainHandler),
2014-02-27 20:54:51 +01:00
(r"/video", VideoHandler),
(r"/unauthorized", UnauthorizedHandler),
(r"/disconnection", DisconnectionHandler),
(r"/socket", WSocketHandler),
2014-03-12 17:04:32 +01:00
(r"/(favicon.ico)", tornado.web.StaticFileHandler,{"path":"./v/images"},),
(r"/style/(.*)", tornado.web.StaticFileHandler,{"path":"./v/style"},),
(r"/images/(.*)", tornado.web.StaticFileHandler,{"path":"./v/images"},),
(r"/js/(.*)", tornado.web.StaticFileHandler,{"path":"./v/js"},)],
2014-02-28 11:20:21 +01:00
cookie_secret="1213215656")
2014-02-27 15:43:58 +01:00
2014-02-27 15:51:19 +01:00
if __name__ == "__main__":
log.printL("->Loading configuration ... ",lvl.INFO)
try :
2014-03-02 23:26:33 +01:00
blind = config.isBlind()
2014-03-03 00:13:47 +01:00
ipCamera = config.ipCamera()
portCamera = config.portCamera()
ipServ = config.ipServ()
2014-03-03 00:13:47 +01:00
portServ = config.portServ()
if blind == "error" :
raise ConfigError("Failed Load Blind Configuration")
if ipCamera == "error" :
raise ConfigError("Failed Load IP Camera Configuration")
if portCamera == "error" :
raise ConfigError("Failed Load Port Camera Configuration")
if ipServ == "error" :
raise ConfigError("Failed Load IP Server Configuration")
2014-03-03 00:13:47 +01:00
if portServ == "error" :
raise ConfigError("Failed Load Port Server Configuration")
except ConfigError as e :
log.printL(e.value,lvl.FAIL)
log.printL("Configuration Loading Failed ! Check Configuration File !",lvl.FAIL)
2014-03-02 23:03:14 +01:00
sys.exit(1)
log.printL("->Configuration Server Load Successfully !",lvl.SUCCESS)
if blind == True:
log.printL(" +Blind unhabitant",lvl.INFO)
2014-02-27 19:56:31 +01:00
else :
log.printL(" +Not blind unhabitant",lvl.INFO)
log.printL(" +Ip Camera : " + ipCamera,lvl.INFO)
log.printL(" +Port Camera : " + portCamera,lvl.INFO)
2014-03-03 22:14:32 +01:00
log.printL(" +Ip Server : " + ipServ,lvl.INFO)
log.printL(" +Port Server : " + portServ,lvl.INFO)
print ""
2014-03-03 21:50:21 +01:00
urlSocket = 'ws://'+ipServ+':'+portCamera+'/socket'
2014-03-03 20:48:12 +01:00
urlCamera = 'http://test:a@'+ipCamera+':'+portCamera+'/image.jpg?cidx=791836195'
2014-03-03 21:50:21 +01:00
2014-03-03 21:30:41 +01:00
log.printL("->Ping camera ...",lvl.INFO)
try :
2014-03-11 16:59:15 +01:00
socket.setdefaulttimeout(30)
2014-03-03 20:54:59 +01:00
f = urlopen(urlCamera)
log.printL( "->Camera OK ", lvl.SUCCESS)
except Exception, e :
2014-03-03 21:30:41 +01:00
log.printL("->WARNING : Camera Unreachable! Check Camera Configuration!",lvl.FAIL)
print ""
2014-03-02 23:31:30 +01:00
try :
log.printL("->Server Start ...",lvl.INFO)
tornado.options.parse_command_line()
2014-03-12 17:04:32 +01:00
print "lol"
2014-03-12 16:49:25 +01:00
http_server = tornado.httpserver.HTTPServer(application,ssl_options={
2014-03-12 16:57:52 +01:00
"certfile": "/ssl/server.crt",
"keyfile": "/ssl/server.key",
2014-03-12 16:49:25 +01:00
})
2014-03-12 17:04:32 +01:00
print "lol1"
2014-03-12 16:57:52 +01:00
http_server.listen(433)
log.printL("->Server Start Successfully !",lvl.SUCCESS)
2014-03-02 23:31:30 +01:00
tornado.ioloop.IOLoop.instance().start()
except Exception, e :
log.printL("Server Start Failed !",lvl.FAIL)
2014-03-02 23:31:30 +01:00
sys.exit(1)