mirror of
https://github.com/searxng/searxng
synced 2024-11-01 15:40:29 +00:00
8205f170ff
Signed-off-by: Markus Heiser <markus.heiser@darmarit.de>
60 lines
1.7 KiB
Python
60 lines
1.7 KiB
Python
# SPDX-License-Identifier: AGPL-3.0-or-later
|
|
"""Tootfinder (social media)
|
|
"""
|
|
|
|
from datetime import datetime
|
|
from json import loads
|
|
from searx.utils import html_to_text
|
|
|
|
about = {
|
|
'website': "https://www.tootfinder.ch",
|
|
'official_api_documentation': "https://wiki.tootfinder.ch/index.php?name=the-tootfinder-rest-api",
|
|
'use_official_api': True,
|
|
'require_api_key': False,
|
|
'results': "JSON",
|
|
}
|
|
categories = ['social media']
|
|
|
|
base_url = "https://www.tootfinder.ch"
|
|
|
|
|
|
def request(query, params):
|
|
params['url'] = f"{base_url}/rest/api/search/{query}"
|
|
return params
|
|
|
|
|
|
def response(resp):
|
|
results = []
|
|
|
|
# the API of tootfinder has an issue that errors on server side are appended to the API response as HTML
|
|
# thus we're only looking for the line that contains the actual json data and ignore everything else
|
|
json_str = ""
|
|
for line in resp.text.split("\n"):
|
|
if line.startswith("[{"):
|
|
json_str = line
|
|
break
|
|
|
|
for result in loads(json_str):
|
|
thumbnail = None
|
|
|
|
attachments = result.get('media_attachments', [])
|
|
images = [attachment['preview_url'] for attachment in attachments if attachment['type'] == 'image']
|
|
if len(images) > 0:
|
|
thumbnail = images[0]
|
|
|
|
title = result.get('card', {}).get('title')
|
|
if not title:
|
|
title = html_to_text(result['content'])[:75]
|
|
|
|
results.append(
|
|
{
|
|
'url': result['url'],
|
|
'title': title,
|
|
'content': html_to_text(result['content']),
|
|
'thumbnail': thumbnail,
|
|
'publishedDate': datetime.strptime(result['created_at'], '%Y-%m-%d %H:%M:%S'),
|
|
}
|
|
)
|
|
|
|
return results
|