From 7e9ba1b437dcf4a1b08060f67e47bf3581d91682 Mon Sep 17 00:00:00 2001 From: Myned Date: Wed, 18 Mar 2020 02:36:01 -0400 Subject: [PATCH 1/2] Change fetch method to raise AssertionError if response error --- src/utils/scraper.py | 5 +++++ src/utils/utils.py | 6 +++--- 2 files changed, 8 insertions(+), 3 deletions(-) diff --git a/src/utils/scraper.py b/src/utils/scraper.py index 99780d7..8e3721a 100644 --- a/src/utils/scraper.py +++ b/src/utils/scraper.py @@ -49,6 +49,11 @@ async def query_kheina(url): source = re.search('\\d+$', content['results'][0]['sources'][0]['source']).group(0) export = await u.fetch(f'https://faexport.spangle.org.uk/submission/{source}.json', json=True) + try: + export = await u.fetch(f'https://faexport.spangle.org.uk/submission/{submission}.json', json=True) + thumbnail = export['full'] + except AssertionError: + thumbnail = '' result = { 'source': content['results'][0]['sources'][0]['source'], diff --git a/src/utils/utils.py b/src/utils/utils.py index f9ab5ea..17e20a8 100644 --- a/src/utils/utils.py +++ b/src/utils/utils.py @@ -91,9 +91,9 @@ async def fetch(url, *, post={}, response=False, text=False, json=False): if post: async with asession.post(url, data=post, headers={ 'User-Agent': 'Myned/Modufur (https://github.com/Myned/Modufur)'}, ssl=False) as r: - if r.status != 200: - return r.status - elif response: + assert r.status == 200 + + if response: return r elif text: return await r.text() From 689b94fa0a1f85c0d281e3cde4112918efc208b1 Mon Sep 17 00:00:00 2001 From: Myned Date: Wed, 18 Mar 2020 02:37:15 -0400 Subject: [PATCH 2/2] Add check for furaffinity before requesting submission info --- src/utils/scraper.py | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/src/utils/scraper.py b/src/utils/scraper.py index 8e3721a..3f6539c 100644 --- a/src/utils/scraper.py +++ b/src/utils/scraper.py @@ -47,18 +47,20 @@ async def query_kheina(url): if similarity < 55: return None - source = re.search('\\d+$', content['results'][0]['sources'][0]['source']).group(0) - export = await u.fetch(f'https://faexport.spangle.org.uk/submission/{source}.json', json=True) + if tld.extract(content['results'][0]['sources'][0]['source']).domain == 'furaffinity': + submission = re.search('\\d+$', content['results'][0]['sources'][0]['source']).group(0) try: export = await u.fetch(f'https://faexport.spangle.org.uk/submission/{submission}.json', json=True) thumbnail = export['full'] except AssertionError: thumbnail = '' + else: + thumbnail = '' result = { 'source': content['results'][0]['sources'][0]['source'], 'artist': content['results'][0]['sources'][0]['artist'], - 'thumbnail': '' if isinstance(export, int) and export != 200 else export['full'], + 'thumbnail': thumbnail, 'similarity': str(similarity), 'database': tld.extract(content['results'][0]['sources'][0]['source']).domain }