From 68c52fe102950329148971098d38adeec49e94ab Mon Sep 17 00:00:00 2001 From: Fabio Manganiello Date: Sat, 28 Apr 2018 19:11:14 +0200 Subject: [PATCH] - Importing Flask.request as http_request to prevent name clashes with SQLAlchemy's request module - All SQLAlchemy engine and connection setup done within get_new_items to prevent different threads from creating and using the db instance - Added check_same_thread to sqlite connection line to prevent different-thread exceptions when the Flask main thread does some cleanup --- platypush/backend/http/__init__.py | 6 +++--- .../backend/http/request/rss/__init__.py | 19 +++++++++++++------ 2 files changed, 16 insertions(+), 9 deletions(-) diff --git a/platypush/backend/http/__init__.py b/platypush/backend/http/__init__.py index 2d78fb7e5..e6a89e08e 100644 --- a/platypush/backend/http/__init__.py +++ b/platypush/backend/http/__init__.py @@ -7,7 +7,7 @@ import time from threading import Thread from multiprocessing import Process -from flask import Flask, abort, jsonify, request, render_template, send_from_directory +from flask import Flask, abort, jsonify, request as http_request, render_template, send_from_directory from platypush.config import Config from platypush.message import Message @@ -80,8 +80,8 @@ class HttpBackend(Backend): @app.route('/execute', methods=['POST']) def execute(): - args = json.loads(request.data.decode('utf-8')) - token = request.headers['X-Token'] if 'X-Token' in request.headers else None + args = json.loads(http_request.data.decode('utf-8')) + token = http_request.headers['X-Token'] if 'X-Token' in http_request.headers else None if token != self.token: abort(401) msg = Message.build(args) diff --git a/platypush/backend/http/request/rss/__init__.py b/platypush/backend/http/request/rss/__init__.py index 412e28928..a2dcbf681 100644 --- a/platypush/backend/http/request/rss/__init__.py +++ b/platypush/backend/http/request/rss/__init__.py @@ -37,11 +37,6 @@ class RssUpdates(HttpRequest): os.makedirs(os.path.expanduser(os.path.dirname(self.dbfile)), exist_ok=True) - self.engine = create_engine('sqlite:///{}'.format(self.dbfile)) - Base.metadata.create_all(self.engine) - Session.configure(bind=self.engine) - self._get_or_create_source(session=Session()) - if headers is None: headers = {} headers['User-Agent'] = self.user_agent @@ -54,7 +49,6 @@ class RssUpdates(HttpRequest): super().__init__(*args, skip_first_call=False, args=request_args, **kwargs) - def _get_or_create_source(self, session): record = session.query(FeedSource).filter_by(url=self.url).first() if record is None: @@ -79,6 +73,13 @@ class RssUpdates(HttpRequest): def get_new_items(self, response): + engine = create_engine('sqlite:///{}'.format(self.dbfile), + connect_args = { 'check_same_thread': False }) + + Base.metadata.create_all(engine) + Session.configure(bind=engine) + self._get_or_create_source(session=Session()) + feed = feedparser.parse(response.text) session = Session() source_record = self._get_or_create_source(session=session) @@ -97,11 +98,17 @@ class RssUpdates(HttpRequest): datetime.datetime.now().strftime('%d %B %Y, %H:%M') ) + logging.info('Parsed {:d} items from RSS feed <{}>' + .format(len(feed.entries), self.url)) + for entry in feed.entries: entry_timestamp = datetime.datetime(*entry.published_parsed[:6]) if source_record.last_updated_at is None \ or entry_timestamp > source_record.last_updated_at: + logging.info('Processed new item from RSS feed <{}>: "{}"' + .format(self.url, entry.title)) + if self.mercury_api_key: entry.content = self._parse_entry_content(entry.link) elif hasattr(entry, 'summary'):