From 30e4f6b266777039faaacc5e5aad2e9ae6b079fc Mon Sep 17 00:00:00 2001 From: "nathan@archer" Date: Sun, 3 Apr 2016 16:21:00 +0100 Subject: [PATCH 1/2] Add catch for failure when system doesn't have required SSL certificates. --- wanikaniburned.py | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) diff --git a/wanikaniburned.py b/wanikaniburned.py index 7ee230e..de435bf 100644 --- a/wanikaniburned.py +++ b/wanikaniburned.py @@ -118,11 +118,15 @@ class User(db.Model): def update_all(self): # pragma: no cover logger.info("Updating all info for %s", self.api_key) if (datetime.utcnow() - self.last_updated) > timedelta(hours=1): - self.parse_radicals_and_userdata() - self.parse_kanji() - self.parse_vocabulary() - self.last_updated = datetime.utcnow() - db.session.commit() + try: + self.parse_radicals_and_userdata() + self.parse_kanji() + self.parse_vocabulary() + self.last_updated = datetime.utcnow() + db.session.commit() + except requests.exceptions.SSLError: + logger.error("%s received an SSL error trying to update. Ensure SSL certs are installed.", self.api_key) + raise ValueError('Backend SSL Certificate Error, contact administrator.') else: logger.warn("%s tried to update too frequently", self.api_key) raise ValueError('Cannot refresh now, try again later.') From 2205c29c549e60d401bc56aca5a2d5f9c87b192d Mon Sep 17 00:00:00 2001 From: "nathan@archer" Date: Sun, 3 Apr 2016 16:33:50 +0100 Subject: [PATCH 2/2] Added debug level console logging. --- wanikaniburned.py | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/wanikaniburned.py b/wanikaniburned.py index de435bf..7fa2d01 100644 --- a/wanikaniburned.py +++ b/wanikaniburned.py @@ -2,6 +2,7 @@ import ujson as json import re from datetime import datetime, timedelta import logging +import sys import flask from flask.ext.login import LoginManager, login_user, login_required, current_user, logout_user, login_fresh, \ @@ -14,11 +15,15 @@ from wtforms.validators import DataRequired logger = logging.getLogger(__name__) logger.setLevel(logging.INFO) +console_handler = logging.StreamHandler(sys.stdout) +console_handler.setLevel(logging.DEBUG) handler = logging.FileHandler('wkburned.log') handler.setLevel(logging.WARN) formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s') handler.setFormatter(formatter) +console_handler.setFormatter(formatter) logger.addHandler(handler) +logger.addHandler(console_handler) app = flask.Flask(__name__) logger.debug("Configuring application.")