summaryrefslogtreecommitdiff
path: root/src/ssh_login_attempts.py
diff options
context:
space:
mode:
Diffstat (limited to 'src/ssh_login_attempts.py')
-rw-r--r--src/ssh_login_attempts.py50
1 files changed, 50 insertions, 0 deletions
diff --git a/src/ssh_login_attempts.py b/src/ssh_login_attempts.py
new file mode 100644
index 0000000..cb5f477
--- /dev/null
+++ b/src/ssh_login_attempts.py
@@ -0,0 +1,50 @@
+import logging
+
+import flask
+
+import db_handler
+
+
+class CustomFormatter(logging.Formatter):
+ grey = "\x1b[90;20m"
+ blue = "\x1b[34;20m"
+ yellow = "\x1b[33;20m"
+ red = "\x1b[31;20m"
+ bold_red = "\x1b[31;1m"
+ reset = "\x1b[0m"
+ format = "%(asctime)s,%(msecs)03d %(levelname)-8s [%(filename)s:%(lineno)d] %(message)s"
+
+ FORMATS = {
+ logging.DEBUG: grey + format + reset,
+ logging.INFO: blue + format + reset,
+ logging.WARNING: yellow + format + reset,
+ logging.ERROR: red + format + reset,
+ logging.CRITICAL: bold_red + format + reset
+ }
+
+ def format(self, record):
+ log_fmt = self.FORMATS.get(record.levelno)
+ formatter = logging.Formatter(log_fmt)
+ return formatter.format(record)
+
+
+logger = logging.getLogger(__name__)
+logger.root.setLevel(logging.INFO)
+
+stream_handler = logging.StreamHandler()
+stream_handler.setFormatter(CustomFormatter())
+logger.root.addHandler(stream_handler)
+
+app = flask.Flask(__name__, template_folder='templates', static_folder='static', static_url_path='')
+
+
+@app.route("/")
+def index():
+ latest_loging_attempts = db_handler.get_latest_login_attempts()
+ top_usernames = db_handler.get_top('username')
+ top_passwords = db_handler.get_top('password')
+ return flask.render_template(
+ 'index.html',
+ latest_login_attempts=latest_loging_attempts,
+ top_usernames=top_usernames,
+ top_passwords=top_passwords)