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
sidya82 3b35eb183c modifié: superTornado.py
modifié:         video.html
2014-02-28 04:19:03 +01:00

116 lines
3.5 KiB
Python

import tornado.ioloop
import tornado.web
import tornado.httpserver
import tornado.websocket
import tornado.options
import base64
from urllib import urlopen
from tornado.ioloop import PeriodicCallback
from session import *
from loadConf import *
from login import *
confAveug = False
ficLog = Login()
class BaseHandler(tornado.web.RequestHandler):
def get_current_user(self):
return self.get_secure_cookie("user")
class MainHandler(BaseHandler):
def get(self):
self.render("index.html")
def post(self):
iden = self.get_argument("id","")
mdp = self.get_argument("mdp","")
login = Login()
autorise = login.connexion(iden, mdp)
#maison = httplib.HTTPConnection("192.168.16.150", 80)
if autorise == True:
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"
self.set_secure_cookie("user", iden)
self.redirect("/video")
else:
print "->An unauthorized user try to access"
self.redirect("/unauthorized")
class VideoHandler(BaseHandler):
def get(self):
if not self.current_user :
self.redirect("/")
return
self.render("video.html")
class UnauthorizedHandler(BaseHandler):
def get(self):
self.render("illegal.html")
def post(self):
force = self.get_argument("illegalAccess","")
if force == "1" :
self.set_secure_cookie("user", "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")'
self.redirect("/video")
else :
self.redirect("/")
class AJAXHandler(BaseHandler):
def post(self):
if not self.current_user :
self.redirect("/")
return
f =urlopen('http://test:a@192.168.1.15/image.jpg?cidx=791836195', 'image/temp.jpg')
data = f.read()
encoded = base64.b64encode(data)
print encoded
self.write(encoded)
self.finish()
class DisconnectionHandler(BaseHandler):
def post(self):
self.set_cookie("user", 0)
self.redirect("/")
application = tornado.web.Application([
(r"/", MainHandler),
(r"/video", VideoHandler),
(r"/unauthorized", UnauthorizedHandler),
(r"/ajax", AJAXHandler),
(r"/disconnection", DisconnectionHandler),
], cookie_secret="1213215656")
if __name__ == "__main__":
hand = LoadConf()
confAveug = hand.estAveugle()
if confAveug == True:
print "->Blind unhabitant system configuration"
else :
print "->Not blind unhabitant system configuration"
tornado.options.parse_command_line()
http_server = tornado.httpserver.HTTPServer(application)
http_server.listen(80)
tornado.ioloop.IOLoop.instance().start()