unreads: Add support for web public guests.

This handles the case of web public guests by returning
RawUnreadMessagesResult with empty initalized values.
This commit is contained in:
Aman Agrawal
2020-09-27 22:42:52 +05:30
committed by Tim Abbott
parent e02f0fb1c4
commit 18d852de49
2 changed files with 29 additions and 29 deletions

View File

@@ -27,6 +27,7 @@ from zerver.lib.integrations import EMBEDDED_BOTS, WEBHOOK_INTEGRATIONS
from zerver.lib.message import (
aggregate_unread_data,
apply_unread_message_event,
extract_unread_data_from_um_rows,
get_raw_unread_data,
get_recent_conversations_recipient_id,
get_recent_private_conversations,
@@ -337,20 +338,14 @@ def fetch_initial_state_data(user_profile: Optional[UserProfile],
# message updates. This is due to the fact that new messages will not
# generate a flag update so we need to use the flags field in the
# message event.
if user_profile is None:
# TODO: We should deduplicate this logic by extracting the
# row-processing part of get_raw_unread_data as a helper
# function, and calling that with an empty list.
state['raw_unread_msgs'] = {
'pm_dict': {},
'stream_dict': {},
'muted_stream_ids': [],
'unmuted_stream_msgs': set(),
'huddle_dict': {},
'mentions': set()
}
else:
if user_profile is not None:
state['raw_unread_msgs'] = get_raw_unread_data(user_profile)
else:
# For logged-out visitors, we treat all messages as read;
# calling this helper lets us return empty objects in the
# appropriate format.
state['raw_unread_msgs'] = extract_unread_data_from_um_rows([], user_profile)
if want('starred_messages'):
state['starred_messages'] = [] if user_profile is None else get_starred_message_ids(user_profile)

View File

@@ -840,7 +840,6 @@ def get_starred_message_ids(user_profile: UserProfile) -> List[int]:
).values_list('message_id', flat=True)[0:10000])
def get_raw_unread_data(user_profile: UserProfile) -> RawUnreadMessagesResult:
excluded_recipient_ids = get_inactive_recipient_ids(user_profile)
user_msgs = UserMessage.objects.filter(
@@ -867,10 +866,29 @@ def get_raw_unread_data(user_profile: UserProfile) -> RawUnreadMessagesResult:
def extract_unread_data_from_um_rows(
rows: List[Dict[str, Any]],
user_profile: UserProfile
user_profile: Optional[UserProfile]
) -> RawUnreadMessagesResult:
pm_dict: Dict[int, Any] = {}
stream_dict: Dict[int, Any] = {}
unmuted_stream_msgs: Set[int] = set()
huddle_dict: Dict[int, Any] = {}
mentions: Set[int] = set()
raw_unread_messages: RawUnreadMessagesResult = dict(
pm_dict=pm_dict,
stream_dict=stream_dict,
muted_stream_ids=[],
unmuted_stream_msgs=unmuted_stream_msgs,
huddle_dict=huddle_dict,
mentions=mentions,
)
if user_profile is None:
return raw_unread_messages # nocoverage
muted_stream_ids = get_muted_stream_ids(user_profile)
raw_unread_messages['muted_stream_ids'] = muted_stream_ids
topic_mute_checker = build_topic_mute_checker(user_profile)
@@ -893,12 +911,6 @@ def extract_unread_data_from_um_rows(
huddle_cache[recipient_id] = user_ids_string
return user_ids_string
pm_dict = {}
stream_dict = {}
unmuted_stream_msgs = set()
huddle_dict = {}
mentions = set()
for row in rows:
message_id = row['message_id']
msg_type = row['message__recipient__type']
@@ -952,14 +964,7 @@ def extract_unread_data_from_um_rows(
else: # nocoverage # TODO: Test wildcard mentions in PMs.
mentions.add(message_id)
return dict(
pm_dict=pm_dict,
stream_dict=stream_dict,
muted_stream_ids=muted_stream_ids,
unmuted_stream_msgs=unmuted_stream_msgs,
huddle_dict=huddle_dict,
mentions=mentions,
)
return raw_unread_messages
def aggregate_unread_data(raw_data: RawUnreadMessagesResult) -> UnreadMessagesResult: