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

163 lines
5.2 KiB
Python
Raw Normal View History

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
2014-02-28 06:55:36 +01:00
import time
2014-02-28 03:16:09 +01:00
import base64
import socket
2014-02-28 04:07:56 +01:00
from urllib import urlopen
from tornado.ioloop import PeriodicCallback
from session import *
2014-02-27 19:57:53 +01:00
from loadConf import *
2014-02-27 20:06:37 +01:00
from login import *
2014-02-28 11:20:21 +01:00
import os
dirname = os.path.dirname(__file__)
2014-02-27 15:43:58 +01:00
2014-02-27 19:55:43 +01:00
confAveug = False
2014-02-27 20:06:37 +01:00
ficLog = Login()
2014-02-27 22:45:07 +01:00
2014-02-28 04:41:59 +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-02-27 23:12:23 +01:00
class MainHandler(BaseHandler):
2014-02-27 16:06:38 +01:00
def get(self):
2014-02-28 11:03:03 +01:00
self.render("index.html")
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)
print 'maison = httplib.HTTPConnection("192.168.16.150", 80)'
2014-02-27 20:06:37 +01:00
if autorise == True:
2014-02-27 23:12:23 +01:00
self.set_secure_cookie("user", iden)
self.redirect("/video")
2014-02-27 20:10:46 +01:00
else:
print "->An unauthorized user try to access"
self.redirect("/unauthorized")
2014-02-27 17:56:39 +01:00
2014-02-27 23:12:23 +01:00
class VideoHandler(BaseHandler):
2014-02-27 20:53:48 +01:00
def get(self):
2014-02-27 23:12:23 +01:00
if not self.current_user :
self.redirect("/")
return
self.render("video.html")
class UnauthorizedHandler(BaseHandler):
def get(self):
2014-02-27 23:39:19 +01:00
self.render("illegal.html")
def post(self):
force = self.get_argument("illegalAccess","")
2014-02-27 23:44:32 +01:00
if force == "1" :
self.set_secure_cookie("user", "illegalUser")
2014-02-27 23:46:53 +01:00
self.redirect("/video")
else :
self.redirect("/")
2014-02-27 17:56:39 +01:00
class DisconnectionHandler(BaseHandler):
def post(self):
2014-02-28 05:10:28 +01:00
if not self.current_user :
2014-03-01 17:37:17 +01:00
self.close()
return
2014-02-28 07:58:57 +01:00
self.clear_cookie("user")
self.redirect("/")
2014-02-28 07:52:19 +01:00
class WSocketHandler(BaseHandler,tornado.websocket.WebSocketHandler):
2014-02-28 06:01:10 +01:00
def open(self) :
2014-02-28 07:52:19 +01:00
if not self.current_user :
self.close()
2014-02-28 07:52:19 +01:00
return
2014-02-28 06:01:10 +01:00
print "->Websocket opened"
2014-03-01 17:41:24 +01:00
if self.current_user == "illegalUser":
iden="IllegalUser"
ficLog.enregDansLog(iden,"Unauthorized user connection","IP TO DO")
if confAveug == True:
print '->Send audio alarm unauthorized user'
print 'maison.request("GET", "micom/say.php?source=toto&text=Connection%20a%20la%20camera%20non%20autorisee")'
else:
print '->Send visual alarm unauthorized user'
print 'maison.request("GET", "micom/lamp.php?room=salon1&order=1")'
else :
iden = self.current_user
ficLog.enregDansLog(iden,"Authorized user connection","IP TO DO")
if confAveug == True:
print '->Send audio alarm authorized user'
print 'maison.request("GET", "micom/say.php?source=toto&text=Connection%20a%20la%20camera%20autorisee")'
else:
print '->Send visual alarm authorized user'
print 'maison.request("GET", "micom/lamp.php?room=salon1&order=1")'
print "->Authorized user access"
2014-02-28 07:49:33 +01:00
try :
socket.setdefaulttimeout(5)
f = urlopen('http://test:a@192.168.0.13/image.jpg?cidx=791836195')
data = f.read()
encoded = base64.b64encode(data)
self.write_message(encoded)
except Exception, e :
print e
self.write_message("error")
def on_message(self,mesg):
print "->Data receive"
try :
socket.setdefaulttimeout(5)
2014-02-28 11:06:44 +01:00
f = urlopen('http://test:a@192.168.0.13/image.jpg?cidx=791836195')
2014-02-28 07:49:33 +01:00
data = f.read()
encoded = base64.b64encode(data)
self.write_message(encoded)
except Exception, e :
print e
self.write_message("error")
2014-02-28 06:02:35 +01:00
def on_close(self):
2014-02-28 06:01:10 +01:00
print "->Websocket closed"
2014-03-01 17:37:17 +01:00
if self.current_user == "illegalUser":
iden="IllegalUser"
ficLog.enregDansLog(iden,"Unauthorized user deconnection","IP TO DO")
else :
iden = self.current_user
ficLog.enregDansLog(iden,"Authorized user deconnection","IP TO DO")
if confAveug == True:
print '->Send audio alarm deconnection user'
print 'maison.request("GET", "micom/say.php?source=toto&text=Connection%20a%20la%20camera%20rompue")'
else:
print '->Send visual alarm deconnection user'
print 'maison.request("GET", "micom/lamp.php?room=salon1&order=0")'
print"->"+iden+" Deconnection"
2014-02-28 06:01:10 +01:00
2014-02-28 06:01:10 +01:00
2014-02-28 03:16:09 +01:00
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),
2014-03-01 21:32:05 +01:00
(r"/socket", WSocketHandler),
2014-03-01 21:33:36 +01:00
(r"/style/(*)", tornado.webStaticFileHandler,{"path":"/style"},)],
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__":
2014-02-27 19:57:53 +01:00
hand = LoadConf()
2014-02-27 19:55:43 +01:00
confAveug = hand.estAveugle()
2014-02-27 19:56:31 +01:00
if confAveug == True:
print "->Blind unhabitant system configuration"
else :
print "->Not blind unhabitant system configuration"
2014-02-27 19:57:53 +01:00
2014-02-27 23:39:19 +01:00
tornado.options.parse_command_line()
2014-02-27 16:56:43 +01:00
http_server = tornado.httpserver.HTTPServer(application)
2014-02-27 16:53:58 +01:00
http_server.listen(80)
2014-02-27 16:06:38 +01:00
tornado.ioloop.IOLoop.instance().start()