diff options
author | Filipp Lepalaan <f@230.to> | 2014-02-13 09:48:51 +0200 |
---|---|---|
committer | Filipp Lepalaan <f@230.to> | 2014-02-13 09:48:51 +0200 |
commit | b512e81120bb79bb60e8fad116ffbfac3d268acc (patch) | |
tree | c78b55683e731a8c38da708f2e922bd9eed79715 /app.py | |
download | intercheck-b512e81120bb79bb60e8fad116ffbfac3d268acc.tar.gz intercheck-b512e81120bb79bb60e8fad116ffbfac3d268acc.tar.bz2 intercheck-b512e81120bb79bb60e8fad116ffbfac3d268acc.zip |
Initial commit
Diffstat (limited to 'app.py')
-rw-r--r-- | app.py | 30 |
1 files changed, 30 insertions, 0 deletions
@@ -0,0 +1,30 @@ +import re +import subprocess +import tornado.ioloop +import tornado.web +from tornado import template + +class MainHandler(tornado.web.RequestHandler): + def initialize(self): + self.loader = template.Loader('/Users/filipp/Projects/intercheck') + + def get(self): + self.write(self.loader.load("index.html").generate()) + + +class ScanHandler(tornado.web.RequestHandler): + def get(self): + result = subprocess.check_output(['nmap', self.request.remote_ip]) + for r in re.finditer(r'(\d+/[a-z]{3})\s([a-z]+)\s+(.+)', result): + t = r.groups() + self.write({'port': t[0], 'state': t[1], 'service': t[2]}) + + +application = tornado.web.Application([ + (r'/', MainHandler), + (r'/scan/', ScanHandler), +]) + +if __name__ == '__main__': + application.listen(8888) + tornado.ioloop.IOLoop.instance().start() |