epicyon/webapp_person_options.py

723 lines
31 KiB
Python
Raw Normal View History

2020-11-09 22:44:03 +00:00
__filename__ = "webapp_person_options.py"
__author__ = "Bob Mottram"
__license__ = "AGPL3+"
2024-01-21 19:01:20 +00:00
__version__ = "1.5.0"
2020-11-09 22:44:03 +00:00
__maintainer__ = "Bob Mottram"
2021-09-10 16:14:50 +00:00
__email__ = "bob@libreserver.org"
2020-11-09 22:44:03 +00:00
__status__ = "Production"
2021-06-15 15:08:12 +00:00
__module_group__ = "Web Interface"
2020-11-09 22:44:03 +00:00
import os
from shutil import copyfile
2021-12-29 21:55:09 +00:00
from petnames import get_pet_name
from person import is_person_snoozed
2021-12-28 19:33:29 +00:00
from posts import is_moderator
from flags import is_featured_writer
from flags import is_dormant
2024-05-12 12:35:26 +00:00
from utils import data_dir
from utils import quote_toots_allowed
2021-12-26 12:45:03 +00:00
from utils import get_full_domain
2021-12-26 14:08:58 +00:00
from utils import get_config_param
2021-12-27 15:43:22 +00:00
from utils import remove_html
2021-12-27 19:05:25 +00:00
from utils import get_domain_from_actor
2021-12-27 22:19:18 +00:00
from utils import get_nickname_from_actor
2021-12-26 12:02:29 +00:00
from utils import acct_dir
from utils import text_in_file
from utils import remove_domain_port
2021-12-29 21:55:09 +00:00
from blocking import is_blocked
from follow import is_follower_of_person
2021-12-28 20:32:11 +00:00
from follow import is_following_actor
2021-12-29 21:55:09 +00:00
from followingCalendar import receiving_calendar_events
from notifyOnPost import notify_when_person_posts
2023-12-20 18:22:28 +00:00
from person import get_person_notes
2021-12-29 21:55:09 +00:00
from webapp_utils import html_header_with_external_style
from webapp_utils import html_footer
from webapp_utils import get_broken_link_substitute
from webapp_utils import html_keyboard_navigation
from webapp_utils import get_banner_file
2022-06-03 21:03:39 +00:00
from webapp_utils import html_hide_from_screen_reader
from webapp_utils import minimizing_attached_images
from blocking import allowed_announce
def _minimize_attached_images(base_dir: str, nickname: str, domain: str,
following_nickname: str,
following_domain: str,
add: bool) -> None:
"""Adds or removes a handle from the following.txt list into a list
indicating whether to minimize images from that account
"""
# check that a following file exists
domain = remove_domain_port(domain)
following_filename = \
acct_dir(base_dir, nickname, domain) + '/following.txt'
if not os.path.isfile(following_filename):
print("WARN: following.txt doesn't exist for " +
nickname + '@' + domain)
return
handle = following_nickname + '@' + following_domain
2022-12-30 20:50:43 +00:00
# check that you are following this handle (not case sensitive)
if not text_in_file(handle + '\n', following_filename, False):
print('WARN: ' + handle + ' is not in ' + following_filename)
return
minimize_filename = \
acct_dir(base_dir, nickname, domain) + '/followingMinimizeImages.txt'
# get the contents of the minimize file, which is
# a set of handles
2022-06-11 16:28:41 +00:00
minimize_handles = ''
if os.path.isfile(minimize_filename):
print('Minimize file exists')
try:
with open(minimize_filename, 'r',
2024-07-14 13:01:46 +00:00
encoding='utf-8') as fp_minimize:
minimize_handles = fp_minimize.read()
except OSError:
print('EX: minimize_attached_images ' + minimize_filename)
else:
# create a new minimize file from the following file
print('Creating minimize file ' + minimize_filename)
if add:
try:
with open(minimize_filename, 'w+',
encoding='utf-8') as fp_min:
2022-06-11 16:28:41 +00:00
fp_min.write('')
except OSError:
print('EX: minimize_attached_images unable to write ' +
minimize_filename)
# already in the minimize file?
2022-06-11 16:28:41 +00:00
if handle + '\n' in minimize_handles:
print(handle + ' exists in followingMinimizeImages.txt')
if add:
# already added
return
# remove from minimize file
2022-06-11 16:28:41 +00:00
minimize_handles = minimize_handles.replace(handle + '\n', '')
try:
with open(minimize_filename, 'w+',
encoding='utf-8') as fp_min:
2022-06-11 16:28:41 +00:00
fp_min.write(minimize_handles)
except OSError:
print('EX: minimize_attached_images 3 ' + minimize_filename)
else:
print(handle + ' not in followingMinimizeImages.txt')
# not already in the minimize file
if add:
# append to the list of handles
2022-06-11 16:28:41 +00:00
minimize_handles += handle + '\n'
try:
with open(minimize_filename, 'w+',
encoding='utf-8') as fp_min:
2022-06-11 16:28:41 +00:00
fp_min.write(minimize_handles)
except OSError:
print('EX: minimize_attached_images 4 ' + minimize_filename)
def person_minimize_images(base_dir: str, nickname: str, domain: str,
following_nickname: str,
following_domain: str) -> None:
"""Images from this person are minimized by default
"""
_minimize_attached_images(base_dir, nickname, domain,
following_nickname, following_domain, True)
def person_undo_minimize_images(base_dir: str, nickname: str, domain: str,
following_nickname: str,
following_domain: str) -> None:
"""Images from this person are no longer minimized by default
"""
_minimize_attached_images(base_dir, nickname, domain,
following_nickname, following_domain, False)
2020-11-09 22:44:03 +00:00
2021-12-31 23:50:29 +00:00
def html_person_options(default_timeline: str,
translate: {}, base_dir: str,
2021-12-29 21:55:09 +00:00
domain: str, domain_full: str,
2022-01-04 10:33:30 +00:00
origin_path_str: str,
options_actor: str,
options_profile_url: str,
options_link: str,
page_number: int,
donate_url: str,
2022-01-04 10:33:30 +00:00
web_address: str,
gemini_link: str,
pronouns: str,
xmpp_address: str,
matrix_address: str,
ssb_address: str,
blog_address: str,
tox_address: str,
briar_address: str,
2021-12-30 20:48:38 +00:00
cwtch_address: str,
enigma_pub_key: str,
pgp_pub_key: str,
pgp_fingerprint: str,
email_address: str,
2021-12-29 21:55:09 +00:00
dormant_months: int,
2022-01-04 10:33:30 +00:00
back_to_path: str,
locked_account: bool,
moved_to: str,
also_known_as: [],
2021-12-29 21:55:09 +00:00
text_mode_banner: str,
news_instance: bool,
authorized: bool,
2021-12-31 21:18:12 +00:00
access_keys: {},
is_group: bool,
2022-11-29 14:03:52 +00:00
theme: str,
2023-08-27 13:02:19 +00:00
blocked_cache: [],
repo_url: str,
sites_unavailable: [],
youtube: str, peertube: str,
pixelfed: str,
discord: str,
2024-08-15 19:58:26 +00:00
music_site_url: str,
art_site_url: str) -> str:
2020-11-09 22:44:03 +00:00
"""Show options for a person: view/follow/block/report
"""
2022-11-30 23:41:22 +00:00
options_link_str = ''
2022-01-04 10:33:30 +00:00
options_domain, options_port = get_domain_from_actor(options_actor)
2022-03-23 22:49:37 +00:00
if not options_domain:
return None
2022-01-04 10:33:30 +00:00
options_domain_full = get_full_domain(options_domain, options_port)
2020-11-09 22:44:03 +00:00
2024-05-12 12:35:26 +00:00
dir_str = data_dir(base_dir)
if os.path.isfile(dir_str + '/options-background-custom.jpg'):
if not os.path.isfile(dir_str + '/options-background.jpg'):
copyfile(dir_str + '/options-background.jpg',
dir_str + '/options-background.jpg')
2020-11-09 22:44:03 +00:00
dormant = False
offline = False
if options_domain in sites_unavailable:
offline = True
2022-01-04 10:33:30 +00:00
follow_str = 'Follow'
if is_group:
follow_str = 'Join'
block_str = 'Block'
2020-11-09 22:44:03 +00:00
nickname = None
2022-01-04 10:33:30 +00:00
options_nickname = None
follows_you = False
if origin_path_str.startswith('/users/'):
nickname = origin_path_str.split('/users/')[1]
2020-11-09 22:44:03 +00:00
if '/' in nickname:
nickname = nickname.split('/')[0]
if '?' in nickname:
nickname = nickname.split('?')[0]
2022-01-04 10:33:30 +00:00
# follower_domain, follower_port = get_domain_from_actor(options_actor)
if is_following_actor(base_dir, nickname, domain, options_actor):
follow_str = 'Unfollow'
if is_group:
follow_str = 'Leave'
if not offline:
dormant = \
is_dormant(base_dir, nickname, domain, options_actor,
dormant_months)
2020-11-09 22:44:03 +00:00
2022-01-04 10:33:30 +00:00
options_nickname = get_nickname_from_actor(options_actor)
if not options_nickname:
return None
2022-01-04 10:33:30 +00:00
options_domain_full = get_full_domain(options_domain, options_port)
follows_you = \
2021-12-29 21:55:09 +00:00
is_follower_of_person(base_dir,
nickname, domain,
2022-01-04 10:33:30 +00:00
options_nickname, options_domain_full)
2021-12-29 21:55:09 +00:00
if is_blocked(base_dir, nickname, domain,
options_nickname, options_domain_full,
None, None):
2022-12-14 21:57:47 +00:00
block_str = 'Unblock'
2020-11-09 22:44:03 +00:00
2022-01-04 10:33:30 +00:00
if options_link:
2022-11-30 22:51:10 +00:00
options_link_str += \
2020-11-09 22:44:03 +00:00
' <input type="hidden" name="postUrl" value="' + \
2022-01-04 10:33:30 +00:00
options_link + '">\n'
2021-12-31 21:18:12 +00:00
css_filename = base_dir + '/epicyon-options.css'
2021-12-25 16:17:53 +00:00
if os.path.isfile(base_dir + '/options.css'):
2021-12-31 21:18:12 +00:00
css_filename = base_dir + '/options.css'
2020-11-09 22:44:03 +00:00
# To snooze, or not to snooze? That is the question
2022-01-04 10:33:30 +00:00
snooze_button_str = 'Snooze'
2020-11-09 22:44:03 +00:00
if nickname:
2022-01-04 10:33:30 +00:00
if is_person_snoozed(base_dir, nickname, domain, options_actor):
snooze_button_str = 'Unsnooze'
2020-11-09 22:44:03 +00:00
2022-01-04 10:33:30 +00:00
donate_str = ''
if donate_url:
2022-01-04 10:33:30 +00:00
donate_str = \
' <a href="' + donate_url + \
2024-08-12 21:25:59 +00:00
'" tabindex="-1">' + translate['Donate'] + '</a>\n'
2020-11-09 22:44:03 +00:00
2022-01-04 10:33:30 +00:00
instance_title = \
2021-12-26 14:08:58 +00:00
get_config_param(base_dir, 'instanceTitle')
2022-01-04 10:33:30 +00:00
options_str = \
html_header_with_external_style(css_filename, instance_title, None)
2022-03-31 10:00:14 +00:00
# show banner
banner_file, _ = \
get_banner_file(base_dir, nickname, domain, theme)
2022-06-03 21:13:57 +00:00
back_path = '/'
if nickname:
back_path = '/users/' + nickname + '/' + default_timeline
if 'moderation' in back_to_path:
back_path = '/users/' + nickname + '/moderation'
if authorized and origin_path_str == '/users/' + nickname:
banner_link = back_path
else:
banner_link = origin_path_str
options_str += \
2022-06-03 21:13:57 +00:00
'<header>\n<a href="' + banner_link + \
'" title="' + translate['Switch to timeline view'] + '" alt="' + \
translate['Switch to timeline view'] + '" ' + \
'tabindex="1" accesskey="' + access_keys['menuTimeline'] + '">\n'
options_str += \
'<img loading="lazy" decoding="async" ' + \
'class="timeline-banner" alt="" ' + \
'src="/users/' + nickname + '/' + banner_file + '" /></a>\n' + \
'</header>\n<br><br>\n'
2022-06-03 21:03:39 +00:00
nav_links = {}
timeline_link_str = html_hide_from_screen_reader('🏠') + ' ' + \
translate['Switch to timeline view']
nav_links[timeline_link_str] = \
'/users/' + nickname + '/' + default_timeline
nav_access_keys = {
}
options_str += \
2024-02-19 18:31:04 +00:00
html_keyboard_navigation(text_mode_banner, nav_links, nav_access_keys,
None, None, None, False)
2022-06-03 21:03:39 +00:00
2022-01-04 10:33:30 +00:00
options_str += '<div class="options">\n'
options_str += ' <div class="optionsAvatar">\n'
options_str += ' <center>\n'
options_str += ' <a href="' + options_actor + '">\n'
2022-03-28 08:47:53 +00:00
options_str += ' <img loading="lazy" decoding="async" ' + \
'src="' + options_profile_url + \
2021-12-29 21:55:09 +00:00
'" alt="" ' + get_broken_link_substitute() + '/></a>\n'
handle_nick = get_nickname_from_actor(options_actor)
if not handle_nick:
return None
handle = handle_nick + '@' + options_domain
2022-01-04 10:33:30 +00:00
handle_shown = handle
if locked_account:
handle_shown += '🔒'
if moved_to:
handle_shown += ''
if dormant:
2022-01-04 10:33:30 +00:00
handle_shown += ' 💤'
if offline:
handle_shown += ' [' + translate['offline'].upper() + ']'
2022-01-04 10:33:30 +00:00
options_str += \
2020-11-09 22:44:03 +00:00
' <p class="optionsText">' + translate['Options for'] + \
2022-01-04 10:33:30 +00:00
' @' + handle_shown + '</p>\n'
# is sending posts to this account blocked?
send_block_filename = \
acct_dir(base_dir, nickname, domain) + '/send_blocks.txt'
if os.path.isfile(send_block_filename):
if text_in_file(options_actor,
send_block_filename, False):
options_str += \
' <p class="optionsText"><b>' + \
translate['FollowAccountWarning'] + '</b></p>\n'
elif text_in_file('://' + options_domain + '\n',
send_block_filename, False):
options_str += \
' <p class="optionsText"><b>' + \
translate['FollowWarning'] + '</b></p>\n'
2022-03-23 22:43:19 +00:00
if follows_you and authorized:
2023-09-19 11:32:28 +00:00
if follow_str != 'Unfollow':
options_str += \
' <p class="optionsText">' + \
translate['Follows you'] + '</p>\n'
else:
options_str += \
' <p class="optionsText">' + translate['Mutuals'] + '</p>\n'
2022-11-30 22:20:21 +00:00
options_str += ' <form method="POST" action="' + \
origin_path_str + '/personoptions">\n'
2022-01-04 10:33:30 +00:00
if moved_to:
new_nickname = get_nickname_from_actor(moved_to)
new_domain, _ = get_domain_from_actor(moved_to)
if new_nickname and new_domain:
new_handle = new_nickname + '@' + new_domain
2022-11-29 14:03:52 +00:00
blocked_icon_str = ''
if is_blocked(base_dir, nickname, domain,
new_nickname, new_domain, blocked_cache,
None):
2022-11-29 14:03:52 +00:00
blocked_icon_str = ''
2022-01-04 10:33:30 +00:00
options_str += \
2021-01-12 11:08:54 +00:00
' <p class="optionsText">' + \
translate['New account'] + \
2022-11-29 14:03:52 +00:00
': <a href="' + moved_to + '">@' + new_handle + '</a>' + \
2022-11-30 21:33:14 +00:00
blocked_icon_str
if follow_str == 'Unfollow' and not blocked_icon_str:
2022-11-30 23:41:22 +00:00
options_str += \
' <input type="hidden" name="movedToActor" value="' + \
moved_to + '">\n'
2022-11-30 21:33:14 +00:00
options_str += \
'<button type="submit" ' + \
'class="button" name="submitMove' + \
'" accesskey="' + access_keys['moveButton'] + '">' + \
translate['Move'] + '</button>'
options_str += '</p>\n'
2022-01-04 10:33:30 +00:00
elif also_known_as:
other_accounts_html = \
2021-01-22 20:35:14 +00:00
' <p class="optionsText">' + \
translate['Other accounts'] + ': '
ctr = 0
2022-01-04 10:33:30 +00:00
if isinstance(also_known_as, list):
for alt_actor in also_known_as:
if alt_actor == options_actor:
continue
2021-01-22 20:35:14 +00:00
if ctr > 0:
2022-01-04 10:33:30 +00:00
other_accounts_html += ' '
2021-01-22 20:35:14 +00:00
ctr += 1
2022-01-04 10:33:30 +00:00
alt_domain, _ = get_domain_from_actor(alt_actor)
2023-01-15 14:33:18 +00:00
if not alt_domain:
continue
2022-01-04 10:33:30 +00:00
other_accounts_html += \
'<a href="' + alt_actor + '">' + alt_domain + '</a>'
elif isinstance(also_known_as, str):
if also_known_as != options_actor:
ctr += 1
2022-01-04 10:33:30 +00:00
alt_domain, _ = get_domain_from_actor(also_known_as)
2023-01-15 14:33:18 +00:00
if alt_domain:
other_accounts_html += \
'<a href="' + also_known_as + '">' + \
alt_domain + '</a>'
2022-01-04 10:33:30 +00:00
other_accounts_html += '</p>\n'
if ctr > 0:
2022-01-04 10:33:30 +00:00
options_str += other_accounts_html
2022-03-31 10:00:14 +00:00
if pronouns:
options_str += \
' <p class="imText">' + translate['Pronouns'] + \
': ' + pronouns + '</a></p>\n'
if email_address:
2022-01-04 10:33:30 +00:00
options_str += \
2022-11-30 22:51:10 +00:00
' <p class="imText">' + translate['Email'] + \
2020-11-09 22:44:03 +00:00
': <a href="mailto:' + \
email_address + '">' + remove_html(email_address) + '</a></p>\n'
2022-01-04 10:36:04 +00:00
if web_address:
2022-05-10 18:56:01 +00:00
web_str = remove_html(web_address)
if '://' not in web_str:
web_str = 'https://' + web_str
2022-01-04 10:36:04 +00:00
options_str += \
2022-11-30 22:51:10 +00:00
' <p class="imText">🌐 <a href="' + web_str + '">' + \
2022-01-04 10:36:04 +00:00
web_address + '</a></p>\n'
2023-08-27 13:02:19 +00:00
if repo_url:
repo_str = remove_html(repo_url)
if '://' not in repo_str:
repo_str = 'https://' + repo_str
options_str += \
' <p class="imText">💻 <a href="' + repo_str + '">' + \
repo_url + '</a></p>\n'
if gemini_link:
gemini_str = remove_html(gemini_link)
if '://' not in gemini_str:
gemini_str = 'gemini://' + gemini_str
options_str += \
2022-11-30 22:51:10 +00:00
' <p class="imText">♊ <a href="' + gemini_str + '">' + \
gemini_link + '</a></p>\n'
if xmpp_address:
2022-01-04 10:33:30 +00:00
options_str += \
2022-11-30 22:51:10 +00:00
' <p class="imText">' + translate['XMPP'] + \
': <a href="xmpp:' + remove_html(xmpp_address) + '">' + \
xmpp_address + '</a></p>\n'
if matrix_address:
2022-01-04 10:33:30 +00:00
options_str += \
2022-11-30 22:51:10 +00:00
' <p class="imText">' + translate['Matrix'] + ': ' + \
remove_html(matrix_address) + '</p>\n'
if ssb_address:
2022-01-04 10:33:30 +00:00
options_str += \
2022-11-30 22:51:10 +00:00
' <p class="imText">SSB: ' + remove_html(ssb_address) + '</p>\n'
if blog_address:
2022-01-04 10:33:30 +00:00
options_str += \
2022-11-30 22:51:10 +00:00
' <p class="imText">Blog: <a href="' + \
remove_html(blog_address) + '">' + \
remove_html(blog_address) + '</a></p>\n'
if pixelfed:
options_str += \
' <p class="imText">Pixelfed' + \
': <a href="' + remove_html(pixelfed) + '">' + \
pixelfed + '</a></p>\n'
if discord:
options_str += \
' <p class="imText">Discord' + \
': <a href="' + remove_html(discord) + '">' + \
discord + '</a></p>\n'
2024-08-15 19:58:26 +00:00
if art_site_url:
options_str += \
' <p class="imText">' + translate['Art'] + \
': <a href="' + remove_html(art_site_url) + '">' + \
art_site_url + '</a></p>\n'
if music_site_url:
options_str += \
' <p class="imText">' + translate['Music'] + \
': <a href="' + remove_html(music_site_url) + '">' + \
music_site_url + '</a></p>\n'
if youtube:
options_str += \
' <p class="imText">YouTube' + \
': <a href="' + remove_html(youtube) + '">' + \
youtube + '</a></p>\n'
if peertube:
options_str += \
' <p class="imText">PeerTube' + \
': <a href="' + remove_html(peertube) + '">' + \
peertube + '</a></p>\n'
if tox_address:
2022-01-04 10:33:30 +00:00
options_str += \
2022-11-30 22:51:10 +00:00
' <p class="imText">Tox: ' + remove_html(tox_address) + '</p>\n'
if briar_address:
if briar_address.startswith('briar://'):
2022-01-04 10:33:30 +00:00
options_str += \
2022-11-30 22:51:10 +00:00
' <p class="imText">' + \
remove_html(briar_address) + '</p>\n'
2020-12-24 17:11:18 +00:00
else:
2022-01-04 10:33:30 +00:00
options_str += \
2022-11-30 22:51:10 +00:00
' <p class="imText">briar://' + \
remove_html(briar_address) + '</p>\n'
2021-12-30 20:48:38 +00:00
if cwtch_address:
2022-01-04 10:33:30 +00:00
options_str += \
2022-11-30 22:51:10 +00:00
' <p class="imText">Cwtch: ' + \
remove_html(cwtch_address) + '</p>\n'
if enigma_pub_key:
2022-01-04 10:33:30 +00:00
options_str += \
2022-11-30 22:51:10 +00:00
' <p class="imText">Enigma: ' + \
remove_html(enigma_pub_key) + '</p>\n'
if pgp_fingerprint:
2024-06-10 12:38:09 +00:00
options_str += '<p class="pgp">' + \
translate['PGP Fingerprint'] + ': ' + \
remove_html(pgp_fingerprint).replace('\n', '<br>') + '</p>\n'
if pgp_pub_key:
2024-06-10 12:38:09 +00:00
options_str += \
'<details><summary class="cw" tabindex="10">' + \
translate['PGP Public Key'] + \
'</summary><div class="pgp">' + \
remove_html(pgp_pub_key).replace('\n', '<br>') + \
'</div></details>\n'
2022-01-04 10:33:30 +00:00
options_str += ' <input type="hidden" name="pageNumber" value="' + \
str(page_number) + '">\n'
options_str += ' <input type="hidden" name="actor" value="' + \
options_actor + '">\n'
options_str += ' <input type="hidden" name="avatarUrl" value="' + \
options_profile_url + '">\n'
2022-03-31 10:00:14 +00:00
2021-02-23 17:29:22 +00:00
if authorized:
2022-01-04 10:33:30 +00:00
if origin_path_str == '/users/' + nickname:
if options_nickname:
# handle = options_nickname + '@' + options_domain_full
2021-12-29 21:55:09 +00:00
petname = get_pet_name(base_dir, nickname, domain, handle)
2022-01-04 10:33:30 +00:00
options_str += \
' ' + translate['Petname'] + ': \n' + \
' <input type="text" name="optionpetname" value="' + \
2021-04-23 12:04:42 +00:00
petname + '" ' + \
2021-12-31 21:18:12 +00:00
'accesskey="' + access_keys['enterPetname'] + '">\n' \
' <button type="submit" class="buttonsmall" ' + \
'name="submitPetname">' + \
translate['Save'] + '</button><br>\n'
2020-11-09 22:44:03 +00:00
# Notify when a post arrives from this person
2022-01-04 10:33:30 +00:00
if is_following_actor(base_dir, nickname, domain, options_actor):
# allow announces
checkbox_str = \
' <input type="checkbox" class="profilecheckbox" ' + \
'name="allowAnnounce" checked> 🔁' + \
translate['Allow announces'] + \
'\n <button type="submit" class="buttonsmall" ' + \
2022-11-08 15:43:26 +00:00
'name="submitAllowAnnounce">' + \
translate['Save'] + '</button><br>\n'
if not allowed_announce(base_dir, nickname, domain,
options_nickname, options_domain_full):
checkbox_str = checkbox_str.replace(' checked>', '>')
options_str += checkbox_str
# allow quote toots
if quote_toots_allowed(base_dir, nickname, domain,
None, None):
checkbox_str = \
' <input type="checkbox" ' + \
'class="profilecheckbox" ' + \
'name="allowQuotes" checked> ' + \
translate['Show quote posts'] + \
'\n <button type="submit" class="buttonsmall" ' + \
'name="submitAllowQuotes">' + \
translate['Save'] + '</button><br>\n'
2024-04-20 13:33:31 +00:00
if not quote_toots_allowed(base_dir, nickname, domain,
options_nickname,
options_domain_full):
checkbox_str = checkbox_str.replace(' checked>', '>')
options_str += checkbox_str
# notify about new posts
2022-01-04 10:33:30 +00:00
checkbox_str = \
' <input type="checkbox" class="profilecheckbox" ' + \
'name="notifyOnPost" checked> 🔔' + \
translate['Notify me when this account posts'] + \
'\n <button type="submit" class="buttonsmall" ' + \
'name="submitNotifyOnPost">' + \
translate['Save'] + '</button><br>\n'
2021-12-29 21:55:09 +00:00
if not notify_when_person_posts(base_dir, nickname, domain,
2022-01-04 10:33:30 +00:00
options_nickname,
options_domain_full):
checkbox_str = checkbox_str.replace(' checked>', '>')
options_str += checkbox_str
# receive calendar events
2022-01-04 10:33:30 +00:00
checkbox_str = \
2021-02-23 17:29:22 +00:00
' <input type="checkbox" ' + \
'class="profilecheckbox" name="onCalendar" checked> ' + \
translate['Receive calendar events from this account'] + \
2021-02-23 17:29:22 +00:00
'\n <button type="submit" class="buttonsmall" ' + \
'name="submitOnCalendar">' + \
translate['Save'] + '</button><br>\n'
2021-12-29 21:55:09 +00:00
if not receiving_calendar_events(base_dir, nickname, domain,
2022-01-04 10:33:30 +00:00
options_nickname,
options_domain_full):
checkbox_str = checkbox_str.replace(' checked>', '>')
options_str += checkbox_str
# minimise images for this handle
checkbox_str = \
' <input type="checkbox" class="profilecheckbox" ' + \
'name="minimizeImages" checked> ' + \
translate['Minimize attached images'] + \
'\n <button type="submit" class="buttonsmall" ' + \
'name="submitMinimizeImages">' + \
translate['Save'] + '</button><br>\n'
if not minimizing_attached_images(base_dir, nickname, domain,
options_nickname,
options_domain_full):
checkbox_str = checkbox_str.replace(' checked>', '>')
options_str += checkbox_str
# checkbox for permission to post to newswire
2022-01-04 10:33:30 +00:00
newswire_posts_permitted = False
if options_domain_full == domain_full:
2021-12-31 21:18:12 +00:00
admin_nickname = get_config_param(base_dir, 'admin')
if (nickname == admin_nickname or
2021-12-28 19:33:29 +00:00
(is_moderator(base_dir, nickname) and
2022-01-04 10:33:30 +00:00
not is_moderator(base_dir, options_nickname))):
newswire_blocked_filename = \
2024-05-12 12:35:26 +00:00
dir_str + '/' + \
2022-01-04 10:33:30 +00:00
options_nickname + '@' + options_domain + \
'/.nonewswire'
checkbox_str = \
' <input type="checkbox" ' + \
'class="profilecheckbox" ' + \
'name="postsToNews" checked> ' + \
translate['Allow news posts'] + \
'\n <button type="submit" class="buttonsmall" ' + \
'name="submitPostToNews">' + \
translate['Save'] + '</button><br>\n'
2022-01-04 10:33:30 +00:00
if os.path.isfile(newswire_blocked_filename):
checkbox_str = checkbox_str.replace(' checked>', '>')
else:
2022-01-04 10:33:30 +00:00
newswire_posts_permitted = True
options_str += checkbox_str
2021-02-13 11:37:02 +00:00
# whether blogs created by this account are moderated on
# the newswire
2022-01-04 10:33:30 +00:00
if newswire_posts_permitted:
moderated_filename = \
2024-05-12 12:35:26 +00:00
dir_str + '/' + \
2022-01-04 10:33:30 +00:00
options_nickname + '@' + \
options_domain + '/.newswiremoderated'
checkbox_str = \
2021-02-23 17:29:22 +00:00
' <input type="checkbox" ' + \
'class="profilecheckbox" name="modNewsPosts" checked> ' + \
translate['News posts are moderated'] + \
2021-02-23 17:29:22 +00:00
'\n <button type="submit" class="buttonsmall" ' + \
'name="submitModNewsPosts">' + \
translate['Save'] + '</button><br>\n'
2022-01-04 10:33:30 +00:00
if not os.path.isfile(moderated_filename):
checkbox_str = checkbox_str.replace(' checked>', '>')
options_str += checkbox_str
2021-02-23 17:29:22 +00:00
# checkbox for permission to post to featured articles
2022-01-04 10:33:30 +00:00
if news_instance and options_domain_full == domain_full:
2021-12-31 21:18:12 +00:00
admin_nickname = get_config_param(base_dir, 'admin')
if (nickname == admin_nickname or
2021-12-28 19:33:29 +00:00
(is_moderator(base_dir, nickname) and
2022-01-04 10:33:30 +00:00
not is_moderator(base_dir, options_nickname))):
checkbox_str = \
' <input type="checkbox" ' + \
'class="profilecheckbox" ' + \
'name="postsToFeatures" checked> ' + \
translate['Featured writer'] + \
'\n <button type="submit" class="buttonsmall" ' + \
'name="submitPostToFeatures">' + \
translate['Save'] + '</button><br>\n'
2022-01-04 10:33:30 +00:00
if not is_featured_writer(base_dir, options_nickname,
options_domain):
checkbox_str = checkbox_str.replace(' checked>', '>')
options_str += checkbox_str
2024-08-12 21:29:35 +00:00
options_str += options_link_str + donate_str
2021-02-23 17:29:22 +00:00
if authorized:
2022-01-04 10:33:30 +00:00
options_str += \
2021-04-23 12:04:42 +00:00
' <button type="submit" class="button" ' + \
'name="submitView" accesskey="' + \
2021-12-31 21:18:12 +00:00
access_keys['viewButton'] + '">' + \
2021-02-23 17:29:22 +00:00
translate['View'] + '</button>\n'
if authorized:
2022-01-04 10:33:30 +00:00
options_str += \
2021-02-23 17:29:22 +00:00
' <button type="submit" class="button" name="submit' + \
2022-01-04 10:33:30 +00:00
follow_str + \
2021-12-31 21:18:12 +00:00
'" accesskey="' + access_keys['followButton'] + '">' + \
2022-01-04 10:33:30 +00:00
translate[follow_str] + '</button>\n'
options_str += \
2021-04-23 12:04:42 +00:00
' <button type="submit" class="button" name="submitDM" ' + \
2021-12-31 21:18:12 +00:00
'accesskey="' + access_keys['menuDM'] + '">' + \
2021-02-23 17:29:22 +00:00
translate['DM'] + '</button>\n'
2022-01-04 10:33:30 +00:00
options_str += \
2021-02-23 17:29:22 +00:00
' <button type="submit" class="button" name="submit' + \
2022-01-04 10:33:30 +00:00
snooze_button_str + '" accesskey="' + \
access_keys['snoozeButton'] + '">' + \
translate[snooze_button_str] + '</button>\n'
options_str += \
2020-12-16 18:24:04 +00:00
' <button type="submit" class="button" ' + \
2021-04-23 12:04:42 +00:00
'name="submitReport" accesskey="' + \
2021-12-31 21:18:12 +00:00
access_keys['reportButton'] + '">' + \
2021-04-23 12:04:42 +00:00
translate['Report'] + '</button>\n'
2020-11-09 22:44:03 +00:00
2021-12-28 19:33:29 +00:00
if is_moderator(base_dir, nickname):
2022-01-04 10:33:30 +00:00
options_str += \
2021-02-23 17:29:22 +00:00
' <button type="submit" class="button" ' + \
2021-04-23 12:04:42 +00:00
'name="submitPersonInfo" accesskey="' + \
2021-12-31 21:18:12 +00:00
access_keys['infoButton'] + '">' + \
2021-02-23 17:29:22 +00:00
translate['Info'] + '</button>\n'
options_str += \
' <button type="submit" class="button" name="submit' + \
block_str + '" accesskey="' + access_keys['blockButton'] + '">' + \
translate[block_str] + '</button>\n'
2020-11-09 22:44:03 +00:00
2022-01-04 10:33:30 +00:00
person_notes = ''
if origin_path_str == '/users/' + nickname:
2023-12-20 18:22:28 +00:00
person_notes = \
get_person_notes(base_dir, nickname, domain, handle)
2021-02-23 17:29:22 +00:00
2022-01-04 10:33:30 +00:00
options_str += \
2021-02-23 17:29:22 +00:00
' <br><br>' + translate['Notes'] + ': \n'
2022-01-04 10:33:30 +00:00
options_str += ' <button type="submit" class="buttonsmall" ' + \
2021-02-23 17:29:22 +00:00
'name="submitPersonNotes">' + \
translate['Save'] + '</button><br>\n'
2022-01-04 10:33:30 +00:00
options_str += \
2021-02-23 17:29:22 +00:00
' <textarea id="message" ' + \
2021-04-23 12:04:42 +00:00
'name="optionnotes" style="height:400px" spellcheck="true" ' + \
2021-12-31 21:18:12 +00:00
'accesskey="' + access_keys['enterNotes'] + '">' + \
2022-01-04 10:33:30 +00:00
person_notes + '</textarea>\n'
2020-11-09 22:44:03 +00:00
2022-01-04 10:33:30 +00:00
options_str += \
2021-07-06 10:00:19 +00:00
' </form>\n' + \
'</center>\n' + \
'</div>\n' + \
'</div>\n'
2022-01-04 10:33:30 +00:00
options_str += html_footer()
return options_str