From c169f12e8522e1b5258c2c5bde80d714b68ff543 Mon Sep 17 00:00:00 2001 From: roadscape Date: Wed, 27 Mar 2019 09:51:34 -0500 Subject: [PATCH 1/2] filter mutes from recent replies, fix #200 --- hive/server/condenser_api/cursor.py | 20 ++++++++++++++++---- 1 file changed, 16 insertions(+), 4 deletions(-) diff --git a/hive/server/condenser_api/cursor.py b/hive/server/condenser_api/cursor.py index b7a2f8169..42268c5fd 100644 --- a/hive/server/condenser_api/cursor.py +++ b/hive/server/condenser_api/cursor.py @@ -4,6 +4,11 @@ from dateutil.relativedelta import relativedelta from hive.utils.normalize import rep_to_raw +from hive.server.common.mutes import Mutes + +MUTES = Mutes.all() + +#pylint: disable=too-many-lines def last_month(): """Get the date 1 month ago.""" @@ -114,6 +119,7 @@ async def pids_by_query(db, sort, start_author, start_permlink, limit, tag): `sort` can be trending, hot, created, promoted, payout, or payout_comments. """ + #pylint: disable=too-many-arguments assert sort in ['trending', 'hot', 'created', 'promoted', 'payout', 'payout_comments'] @@ -316,7 +322,8 @@ async def pids_by_account_comments(db, account: str, start_permlink: str = '', l return await db.query_col(sql, account=account, start_id=start_id, limit=limit) -async def pids_by_replies_to_account(db, start_author: str, start_permlink: str = '', limit: int = 20): +async def pids_by_replies_to_account(db, start_author: str, start_permlink: str = '', + limit: int = 20): """Get a list of post_ids representing replies to an author. To get the first page of results, specify `start_author` as the @@ -346,6 +353,10 @@ async def pids_by_replies_to_account(db, start_author: str, start_permlink: str else: parent_account = start_author + mute = '' + if MUTES: + mute = " AND author NOT IN :mutes" + sql = """ SELECT id FROM hive_posts WHERE parent_id IN (SELECT id FROM hive_posts @@ -353,9 +364,10 @@ async def pids_by_replies_to_account(db, start_author: str, start_permlink: str AND is_deleted = '0' ORDER BY id DESC LIMIT 10000) %s - AND is_deleted = '0' + AND is_deleted = '0' %s ORDER BY id DESC LIMIT :limit - """ % seek + """ % (seek, mute) - return await db.query_col(sql, parent=parent_account, start_id=start_id, limit=limit) + return await db.query_col(sql, parent=parent_account, start_id=start_id, + limit=limit, mutes=tuple(MUTES)) From e1bddaf30fe7b3d5f735feeb3e4feb2b175d04ae Mon Sep 17 00:00:00 2001 From: roadscape Date: Wed, 27 Mar 2019 12:27:33 -0500 Subject: [PATCH 2/2] lazy load mutes --- hive/server/condenser_api/cursor.py | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/hive/server/condenser_api/cursor.py b/hive/server/condenser_api/cursor.py index 42268c5fd..ad8e564ff 100644 --- a/hive/server/condenser_api/cursor.py +++ b/hive/server/condenser_api/cursor.py @@ -6,8 +6,6 @@ from hive.utils.normalize import rep_to_raw from hive.server.common.mutes import Mutes -MUTES = Mutes.all() - #pylint: disable=too-many-lines def last_month(): @@ -354,7 +352,8 @@ async def pids_by_replies_to_account(db, start_author: str, start_permlink: str parent_account = start_author mute = '' - if MUTES: + muted_accounts = Mutes.all() + if muted_accounts: mute = " AND author NOT IN :mutes" sql = """ @@ -370,4 +369,4 @@ async def pids_by_replies_to_account(db, start_author: str, start_permlink: str """ % (seek, mute) return await db.query_col(sql, parent=parent_account, start_id=start_id, - limit=limit, mutes=tuple(MUTES)) + limit=limit, mutes=tuple(muted_accounts))