mirror of https://gitlab.com/bashrc2/epicyon
main
commit
8cec9cbb01
|
@ -2195,8 +2195,11 @@ def run_desktop_client(base_dir: str, proxy_type: str, http_prefix: str,
|
|||
post_summary = ''
|
||||
if post_json_object['object'].get('summary'):
|
||||
post_summary = post_json_object['object']['summary']
|
||||
attachment = []
|
||||
if post_json_object['object'].get('attachment'):
|
||||
attachment = post_json_object['object']['attachment']
|
||||
if not disallow_announce(post_summary + ' ' +
|
||||
post_content):
|
||||
post_content, attachment):
|
||||
if post_json_object.get('id'):
|
||||
post_id = post_json_object['id']
|
||||
announce_actor = \
|
||||
|
|
17
utils.py
17
utils.py
|
@ -3895,7 +3895,7 @@ def is_i2p_request(calling_domain: str, referer_domain: str,
|
|||
return False
|
||||
|
||||
|
||||
def disallow_announce(content: str) -> bool:
|
||||
def disallow_announce(content: str, attachment: []) -> bool:
|
||||
"""Are announces/boosts not allowed for the given post?
|
||||
"""
|
||||
disallow_strings = (
|
||||
|
@ -3919,6 +3919,21 @@ def disallow_announce(content: str) -> bool:
|
|||
for diss in disallow_strings:
|
||||
if diss in content_lower:
|
||||
return True
|
||||
|
||||
# check for attached images without descriptions
|
||||
if isinstance(attachment, list):
|
||||
for item in attachment:
|
||||
if not isinstance(item, dict):
|
||||
continue
|
||||
if not item.get('mediaType'):
|
||||
continue
|
||||
if not item.get('url'):
|
||||
continue
|
||||
if not item['mediaType'].startswith('image/'):
|
||||
continue
|
||||
if not item.get('name'):
|
||||
# no image description
|
||||
return True
|
||||
return False
|
||||
|
||||
|
||||
|
|
|
@ -98,7 +98,9 @@ def html_conversation_view(post_id: str,
|
|||
dogwhistles,
|
||||
minimize_all_images, None)
|
||||
if post_str:
|
||||
conv_str += text_mode_separator + separator_str + post_str
|
||||
# check for "HTTP/1.1 303 See Other Server"
|
||||
if not post_str.startswith('HTTP/'):
|
||||
conv_str += text_mode_separator + separator_str + post_str
|
||||
|
||||
conv_str += text_mode_separator + html_footer()
|
||||
return conv_str
|
||||
|
|
|
@ -2441,9 +2441,12 @@ def individual_post_as_html(signing_priv_key_pem: str,
|
|||
dogwhistles, translate)
|
||||
|
||||
content_all_str = str(summary_str) + ' ' + content_str
|
||||
# does an emoji indicate a no boost preference?
|
||||
# if so then don't show the repeat/announce icon
|
||||
if disallow_announce(content_all_str):
|
||||
# does an emoji or lack of alt text on an image indicate a
|
||||
# no boost preference? if so then don't show the repeat/announce icon
|
||||
attachment = []
|
||||
if post_json_object['object'].get('attachment'):
|
||||
attachment = post_json_object['object']['attachment']
|
||||
if disallow_announce(content_all_str, attachment):
|
||||
announce_str = ''
|
||||
# does an emoji indicate a no replies preference?
|
||||
# if so then don't show the reply icon
|
||||
|
|
Loading…
Reference in New Issue