main
Bob Mottram 2024-04-28 15:00:08 +01:00
parent 722d243154
commit 94b3dbff78
2 changed files with 125 additions and 61 deletions

View File

@ -5122,7 +5122,48 @@ def daemon_http_get(self) -> None:
getreq_start_time,
cookie, self.server.debug,
curr_session, ua_str,
MAX_POSTS_IN_FEED):
MAX_POSTS_IN_FEED,
self.server.recent_posts_cache,
self.server.positive_voting,
self.server.voting_time_mins,
self.server.full_width_tl_button_header,
self.server.access_keys,
self.server.key_shortcuts,
self.server.shared_items_federated_domains,
self.server.allow_local_network_access,
self.server.twitter_replacement_domain,
self.server.show_published_date_only,
self.server.account_timezone,
self.server.bold_reading,
self.server.reverse_sequence,
self.server.default_timeline,
self.server.max_recent_posts,
self.server.translate,
self.server.cached_webfingers,
self.server.person_cache,
self.server.allow_deletion,
self.server.project_version,
self.server.yt_replace_domain,
self.server.newswire,
self.server.show_publish_as_icon,
self.server.icons_as_buttons,
self.server.rss_icon_at_top,
self.server.publish_button_at_top,
self.server.theme_name,
self.server.peertube_instances,
self.server.text_mode_banner,
self.server.system_language,
self.server.max_like_count,
self.server.signing_priv_key_pem,
self.server.cw_lists,
self.server.lists_enabled,
self.server.dogwhistles,
self.server.min_images_for_accounts,
self.server.buy_sites,
self.server.auto_cw_cache,
self.server.fitness,
self.server.onion_domain,
self.server.i2p_domain):
self.server.getreq_busy = False
return

View File

@ -1149,13 +1149,54 @@ def show_bookmarks_timeline(self, authorized: bool,
getreq_start_time,
cookie: str, debug: str,
curr_session, ua_str: str,
max_posts_in_feed: int) -> bool:
max_posts_in_feed: int,
recent_posts_cache: {},
positive_voting: bool,
voting_time_mins: int,
full_width_tl_button_header: bool,
access_keys: {},
key_shortcuts: {},
shared_items_federated_domains: [],
allow_local_network_access: bool,
twitter_replacement_domain: str,
show_published_date_only: bool,
account_timezone: {},
bold_reading_nicknames: {},
reverse_sequence_nicknames: [],
default_timeline: str,
max_recent_posts: int,
translate: {},
cached_webfingers: {},
person_cache: {},
allow_deletion: bool,
project_version: str,
yt_replace_domain: str,
newswire: {},
show_publish_as_icon: bool,
icons_as_buttons: bool,
rss_icon_at_top: bool,
publish_button_at_top: bool,
theme_name: str,
peertube_instances: [],
text_mode_banner: str,
system_language: str,
max_like_count: int,
signing_priv_key_pem: str,
cw_lists: {},
lists_enabled: {},
dogwhistles: {},
min_images_for_accounts: [],
buy_sites: [],
auto_cw_cache: {},
fitness: {},
onion_domain: str,
i2p_domain: str) -> bool:
"""Shows the bookmarks timeline
"""
if '/users/' in path:
if authorized:
bookmarks_feed = \
person_box_json(self.server.recent_posts_cache,
person_box_json(recent_posts_cache,
base_dir,
domain,
port,
@ -1163,8 +1204,8 @@ def show_bookmarks_timeline(self, authorized: bool,
http_prefix,
max_posts_in_feed, 'tlbookmarks',
authorized,
0, self.server.positive_voting,
self.server.voting_time_mins)
0, positive_voting,
voting_time_mins)
if bookmarks_feed:
if request_http(self.headers, debug):
nickname = path.replace('/users/', '')
@ -1185,7 +1226,7 @@ def show_bookmarks_timeline(self, authorized: bool,
if 'page=' not in path:
# if no page was specified then show the first
bookmarks_feed = \
person_box_json(self.server.recent_posts_cache,
person_box_json(recent_posts_cache,
base_dir,
domain,
port,
@ -1194,95 +1235,79 @@ def show_bookmarks_timeline(self, authorized: bool,
max_posts_in_feed,
'tlbookmarks',
authorized,
0, self.server.positive_voting,
self.server.voting_time_mins)
full_width_tl_button_header = \
self.server.full_width_tl_button_header
0, positive_voting,
voting_time_mins)
minimal_nick = is_minimal(base_dir, domain, nickname)
access_keys = self.server.access_keys
if self.server.key_shortcuts.get(nickname):
access_keys = \
self.server.key_shortcuts[nickname]
if key_shortcuts.get(nickname):
access_keys = key_shortcuts[nickname]
shared_items_federated_domains = \
self.server.shared_items_federated_domains
allow_local_network_access = \
self.server.allow_local_network_access
twitter_replacement_domain = \
self.server.twitter_replacement_domain
show_published_date_only = \
self.server.show_published_date_only
timezone = None
if self.server.account_timezone.get(nickname):
timezone = \
self.server.account_timezone.get(nickname)
if account_timezone.get(nickname):
timezone = account_timezone.get(nickname)
bold_reading = False
if self.server.bold_reading.get(nickname):
if bold_reading_nicknames.get(nickname):
bold_reading = True
reverse_sequence = False
if nickname in self.server.reverse_sequence:
if nickname in reverse_sequence_nicknames:
reverse_sequence = True
msg = \
html_bookmarks(self.server.default_timeline,
self.server.recent_posts_cache,
self.server.max_recent_posts,
self.server.translate,
html_bookmarks(default_timeline,
recent_posts_cache,
max_recent_posts,
translate,
page_number, max_posts_in_feed,
curr_session,
base_dir,
self.server.cached_webfingers,
self.server.person_cache,
cached_webfingers,
person_cache,
nickname,
domain,
port,
bookmarks_feed,
self.server.allow_deletion,
allow_deletion,
http_prefix,
self.server.project_version,
project_version,
minimal_nick,
self.server.yt_replace_domain,
yt_replace_domain,
twitter_replacement_domain,
show_published_date_only,
self.server.newswire,
self.server.positive_voting,
self.server.show_publish_as_icon,
newswire,
positive_voting,
show_publish_as_icon,
full_width_tl_button_header,
self.server.icons_as_buttons,
self.server.rss_icon_at_top,
self.server.publish_button_at_top,
icons_as_buttons,
rss_icon_at_top,
publish_button_at_top,
authorized,
self.server.theme_name,
self.server.peertube_instances,
theme_name,
peertube_instances,
allow_local_network_access,
self.server.text_mode_banner,
text_mode_banner,
access_keys,
self.server.system_language,
self.server.max_like_count,
system_language,
max_like_count,
shared_items_federated_domains,
self.server.signing_priv_key_pem,
self.server.cw_lists,
self.server.lists_enabled,
signing_priv_key_pem,
cw_lists,
lists_enabled,
timezone, bold_reading,
self.server.dogwhistles, ua_str,
self.server.min_images_for_accounts,
dogwhistles, ua_str,
min_images_for_accounts,
reverse_sequence,
self.server.buy_sites,
self.server.auto_cw_cache)
buy_sites,
auto_cw_cache)
msg = msg.encode('utf-8')
msglen = len(msg)
set_headers(self, 'text/html', msglen,
cookie, calling_domain, False)
write2(self, msg)
fitness_performance(getreq_start_time,
self.server.fitness,
fitness_performance(getreq_start_time, fitness,
'_GET', '_show_bookmarks_timeline',
debug)
else:
# don't need authorized fetch here because
# there is already the authorization check
onion_domain = self.server.onion_domain
i2p_domain = self.server.i2p_domain
msg_str = json.dumps(bookmarks_feed,
ensure_ascii=False)
msg_str = convert_domains(calling_domain,
@ -1299,9 +1324,7 @@ def show_bookmarks_timeline(self, authorized: bool,
set_headers(self, protocol_str, msglen,
None, calling_domain, False)
write2(self, msg)
fitness_performance(getreq_start_time,
self.server.fitness,
'_GET',
fitness_performance(getreq_start_time, fitness, '_GET',
'_show_bookmarks_timeline json',
debug)
return True