From 81deb6cd8ee7f62b0f8116b926d3b4ac0ea2e5df Mon Sep 17 00:00:00 2001 From: SpeedProg Date: Thu, 11 Jan 2018 16:19:32 +0100 Subject: [PATCH 1/4] fixed an exception that could occure when some ones UI did get our of sync and he tried to remove a fit that was on on waitlist anymore --- waitlist/blueprints/api/fittings/self.py | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/waitlist/blueprints/api/fittings/self.py b/waitlist/blueprints/api/fittings/self.py index f80c3ffe..dc89ed8b 100644 --- a/waitlist/blueprints/api/fittings/self.py +++ b/waitlist/blueprints/api/fittings/self.py @@ -17,6 +17,13 @@ def self_remove_fit(fitid): # remove one of your fittings by id fit = db.session.query(Shipfit).filter(Shipfit.id == fitid).first() + # this fit is not on any waitlist + # if we get this case it means some ones UI did not update + if fit.waitlist is None: + logger.info(f"{current_user.get_eve_name()} tried to remove own fit with id={fit.id}" + f" while it was not on any waitlist anymore") + return "This fit is not on a waitlist anymore" + wlentry = db.session.query(WaitlistEntry).filter(WaitlistEntry.id == fit.waitlist.id).first() if wlentry.user == current_user.get_eve_id(): From 115306bfdc89abffb6d3a4ef93c94bfe95076736 Mon Sep 17 00:00:00 2001 From: SpeedProg Date: Mon, 15 Jan 2018 11:45:58 +0100 Subject: [PATCH 2/4] handle 400 error for an invalid/revoked token --- waitlist/utility/swagger/patch.py | 31 +++++++++++++++++++++++++++++-- 1 file changed, 29 insertions(+), 2 deletions(-) diff --git a/waitlist/utility/swagger/patch.py b/waitlist/utility/swagger/patch.py index 501dbc6d..bf24613d 100644 --- a/waitlist/utility/swagger/patch.py +++ b/waitlist/utility/swagger/patch.py @@ -8,14 +8,24 @@ from esipy.cache import DictCache, BaseCache, DummyCache from esipy.events import api_call_stats +from esipy.exceptions import APIException +from flask_login import current_user from pyswagger.core import BaseClient from requests import Session, Request import six from requests.adapters import HTTPAdapter +from waitlist import db + logger = logging.getLogger(__name__) +class DummyResp(object): + def __init__(self, resp, status_code): + self.data = resp + self.status = status_code + + class EsiClient(BaseClient): __schemes__ = {'https'} @@ -90,8 +100,25 @@ def request(self, req_and_resp, raw_body_only=None, opt=None): if opt is None: opt = {} - # required because of inheritance - request, response = super(EsiClient, self).request(req_and_resp, opt) + + try: + # required because of inheritance + request, response = super(EsiClient, self).request(req_and_resp, opt) + except APIException as e: + logger.info("Failed to execute request", e) + ermsg = "No Message" + if 'error' in e.response: + ermsg = e.response['error'] + elif 'message' in e.response: + ermsg = e.response['message'] + + if e.status_code == 400 and ermsg == "invalid_token": + # since the token is invalid lets delete it + db.session.remove(current_user.ssoToken) + db.session.commit() + + # fake a response that has the fields as expected + return DummyResp(e.response, e.status_code) # check cache here so we have all headers, formed url and params cache_key = self.__make_cache_key(request) From c8db8a3c429d6aac2d214c2a826192f4ef7228ef Mon Sep 17 00:00:00 2001 From: SpeedProg Date: Mon, 15 Jan 2018 12:14:08 +0100 Subject: [PATCH 3/4] 1.1.4 changelog added --- CHANGELOG.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index bfd75d0a..3d6aca2b 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,4 +1,7 @@ #Changelog +* 1.1.4 + * Fixes + * Fixed error handling for invalidated refresh tokens * 1.1.3 * Fixes * Fixed error in handling sse requests From 4f683f9bbcf921e692a50f3933d0cf268661b3a2 Mon Sep 17 00:00:00 2001 From: SpeedProg Date: Mon, 15 Jan 2018 12:14:19 +0100 Subject: [PATCH 4/4] version change to 1.1.4 --- waitlist/data/version.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/waitlist/data/version.py b/waitlist/data/version.py index 34c05dc0..0a800830 100644 --- a/waitlist/data/version.py +++ b/waitlist/data/version.py @@ -1 +1 @@ -version = "1.1.3-$Format:%h$" +version = "1.1.4-$Format:%h$"