mirror of https://github.com/zulip/zulip.git
actions: Split out zerver.actions.user_activity.
Signed-off-by: Anders Kaseorg <anders@zulip.com>
This commit is contained in:
parent
df4849bb15
commit
6168c0110a
|
@ -37,6 +37,7 @@ from zerver.actions.invites import (
|
||||||
do_resend_user_invite_email,
|
do_resend_user_invite_email,
|
||||||
do_revoke_user_invite,
|
do_revoke_user_invite,
|
||||||
)
|
)
|
||||||
|
from zerver.actions.user_activity import update_user_activity_interval
|
||||||
from zerver.lib.actions import (
|
from zerver.lib.actions import (
|
||||||
do_activate_mirror_dummy_user,
|
do_activate_mirror_dummy_user,
|
||||||
do_create_realm,
|
do_create_realm,
|
||||||
|
@ -46,7 +47,6 @@ from zerver.lib.actions import (
|
||||||
do_mark_stream_messages_as_read,
|
do_mark_stream_messages_as_read,
|
||||||
do_reactivate_user,
|
do_reactivate_user,
|
||||||
do_update_message_flags,
|
do_update_message_flags,
|
||||||
update_user_activity_interval,
|
|
||||||
)
|
)
|
||||||
from zerver.lib.create_user import create_user
|
from zerver.lib.create_user import create_user
|
||||||
from zerver.lib.exceptions import InvitationError
|
from zerver.lib.exceptions import InvitationError
|
||||||
|
|
|
@ -0,0 +1,54 @@
|
||||||
|
import datetime
|
||||||
|
|
||||||
|
from zerver.decorator import statsd_increment
|
||||||
|
from zerver.lib.queue import queue_json_publish
|
||||||
|
from zerver.lib.timestamp import datetime_to_timestamp
|
||||||
|
from zerver.models import UserActivity, UserActivityInterval, UserProfile
|
||||||
|
|
||||||
|
|
||||||
|
def do_update_user_activity_interval(
|
||||||
|
user_profile: UserProfile, log_time: datetime.datetime
|
||||||
|
) -> None:
|
||||||
|
effective_end = log_time + UserActivityInterval.MIN_INTERVAL_LENGTH
|
||||||
|
# This code isn't perfect, because with various races we might end
|
||||||
|
# up creating two overlapping intervals, but that shouldn't happen
|
||||||
|
# often, and can be corrected for in post-processing
|
||||||
|
try:
|
||||||
|
last = UserActivityInterval.objects.filter(user_profile=user_profile).order_by("-end")[0]
|
||||||
|
# Two intervals overlap iff each interval ends after the other
|
||||||
|
# begins. In this case, we just extend the old interval to
|
||||||
|
# include the new interval.
|
||||||
|
if log_time <= last.end and effective_end >= last.start:
|
||||||
|
last.end = max(last.end, effective_end)
|
||||||
|
last.start = min(last.start, log_time)
|
||||||
|
last.save(update_fields=["start", "end"])
|
||||||
|
return
|
||||||
|
except IndexError:
|
||||||
|
pass
|
||||||
|
|
||||||
|
# Otherwise, the intervals don't overlap, so we should make a new one
|
||||||
|
UserActivityInterval.objects.create(
|
||||||
|
user_profile=user_profile, start=log_time, end=effective_end
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
@statsd_increment("user_activity")
|
||||||
|
def do_update_user_activity(
|
||||||
|
user_profile_id: int, client_id: int, query: str, count: int, log_time: datetime.datetime
|
||||||
|
) -> None:
|
||||||
|
(activity, created) = UserActivity.objects.get_or_create(
|
||||||
|
user_profile_id=user_profile_id,
|
||||||
|
client_id=client_id,
|
||||||
|
query=query,
|
||||||
|
defaults={"last_visit": log_time, "count": count},
|
||||||
|
)
|
||||||
|
|
||||||
|
if not created:
|
||||||
|
activity.count += count
|
||||||
|
activity.last_visit = log_time
|
||||||
|
activity.save(update_fields=["last_visit", "count"])
|
||||||
|
|
||||||
|
|
||||||
|
def update_user_activity_interval(user_profile: UserProfile, log_time: datetime.datetime) -> None:
|
||||||
|
event = {"user_profile_id": user_profile.id, "time": datetime_to_timestamp(log_time)}
|
||||||
|
queue_json_publish("user_activity_interval", event)
|
|
@ -45,6 +45,7 @@ from zerver.actions.default_streams import (
|
||||||
get_default_streams_for_realm,
|
get_default_streams_for_realm,
|
||||||
)
|
)
|
||||||
from zerver.actions.invites import notify_invites_changed, revoke_invites_generated_by_user
|
from zerver.actions.invites import notify_invites_changed, revoke_invites_generated_by_user
|
||||||
|
from zerver.actions.user_activity import update_user_activity_interval
|
||||||
from zerver.actions.user_groups import (
|
from zerver.actions.user_groups import (
|
||||||
do_send_user_group_members_update_event,
|
do_send_user_group_members_update_event,
|
||||||
update_users_in_full_members_system_group,
|
update_users_in_full_members_system_group,
|
||||||
|
@ -216,8 +217,6 @@ from zerver.models import (
|
||||||
Service,
|
Service,
|
||||||
Stream,
|
Stream,
|
||||||
Subscription,
|
Subscription,
|
||||||
UserActivity,
|
|
||||||
UserActivityInterval,
|
|
||||||
UserGroup,
|
UserGroup,
|
||||||
UserGroupMembership,
|
UserGroupMembership,
|
||||||
UserMessage,
|
UserMessage,
|
||||||
|
@ -5397,49 +5396,6 @@ def get_default_subs(user_profile: UserProfile) -> List[Stream]:
|
||||||
return get_default_streams_for_realm(user_profile.realm_id)
|
return get_default_streams_for_realm(user_profile.realm_id)
|
||||||
|
|
||||||
|
|
||||||
def do_update_user_activity_interval(
|
|
||||||
user_profile: UserProfile, log_time: datetime.datetime
|
|
||||||
) -> None:
|
|
||||||
effective_end = log_time + UserActivityInterval.MIN_INTERVAL_LENGTH
|
|
||||||
# This code isn't perfect, because with various races we might end
|
|
||||||
# up creating two overlapping intervals, but that shouldn't happen
|
|
||||||
# often, and can be corrected for in post-processing
|
|
||||||
try:
|
|
||||||
last = UserActivityInterval.objects.filter(user_profile=user_profile).order_by("-end")[0]
|
|
||||||
# Two intervals overlap iff each interval ends after the other
|
|
||||||
# begins. In this case, we just extend the old interval to
|
|
||||||
# include the new interval.
|
|
||||||
if log_time <= last.end and effective_end >= last.start:
|
|
||||||
last.end = max(last.end, effective_end)
|
|
||||||
last.start = min(last.start, log_time)
|
|
||||||
last.save(update_fields=["start", "end"])
|
|
||||||
return
|
|
||||||
except IndexError:
|
|
||||||
pass
|
|
||||||
|
|
||||||
# Otherwise, the intervals don't overlap, so we should make a new one
|
|
||||||
UserActivityInterval.objects.create(
|
|
||||||
user_profile=user_profile, start=log_time, end=effective_end
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
@statsd_increment("user_activity")
|
|
||||||
def do_update_user_activity(
|
|
||||||
user_profile_id: int, client_id: int, query: str, count: int, log_time: datetime.datetime
|
|
||||||
) -> None:
|
|
||||||
(activity, created) = UserActivity.objects.get_or_create(
|
|
||||||
user_profile_id=user_profile_id,
|
|
||||||
client_id=client_id,
|
|
||||||
query=query,
|
|
||||||
defaults={"last_visit": log_time, "count": count},
|
|
||||||
)
|
|
||||||
|
|
||||||
if not created:
|
|
||||||
activity.count += count
|
|
||||||
activity.last_visit = log_time
|
|
||||||
activity.save(update_fields=["last_visit", "count"])
|
|
||||||
|
|
||||||
|
|
||||||
def send_presence_changed(user_profile: UserProfile, presence: UserPresence) -> None:
|
def send_presence_changed(user_profile: UserProfile, presence: UserPresence) -> None:
|
||||||
# Most presence data is sent to clients in the main presence
|
# Most presence data is sent to clients in the main presence
|
||||||
# endpoint in response to the user's own presence; this results
|
# endpoint in response to the user's own presence; this results
|
||||||
|
@ -5534,11 +5490,6 @@ def do_update_user_presence(
|
||||||
send_presence_changed(user_profile, presence)
|
send_presence_changed(user_profile, presence)
|
||||||
|
|
||||||
|
|
||||||
def update_user_activity_interval(user_profile: UserProfile, log_time: datetime.datetime) -> None:
|
|
||||||
event = {"user_profile_id": user_profile.id, "time": datetime_to_timestamp(log_time)}
|
|
||||||
queue_json_publish("user_activity_interval", event)
|
|
||||||
|
|
||||||
|
|
||||||
def update_user_presence(
|
def update_user_presence(
|
||||||
user_profile: UserProfile,
|
user_profile: UserProfile,
|
||||||
client: Client,
|
client: Client,
|
||||||
|
|
|
@ -14,6 +14,7 @@ from zerver.actions.alert_words import do_add_alert_words
|
||||||
from zerver.actions.realm_emoji import check_add_realm_emoji
|
from zerver.actions.realm_emoji import check_add_realm_emoji
|
||||||
from zerver.actions.realm_icon import do_change_icon_source
|
from zerver.actions.realm_icon import do_change_icon_source
|
||||||
from zerver.actions.realm_logo import do_change_logo_source
|
from zerver.actions.realm_logo import do_change_logo_source
|
||||||
|
from zerver.actions.user_activity import do_update_user_activity, do_update_user_activity_interval
|
||||||
from zerver.actions.user_topics import do_mute_topic
|
from zerver.actions.user_topics import do_mute_topic
|
||||||
from zerver.lib import upload
|
from zerver.lib import upload
|
||||||
from zerver.lib.actions import (
|
from zerver.lib.actions import (
|
||||||
|
@ -23,8 +24,6 @@ from zerver.lib.actions import (
|
||||||
do_create_user,
|
do_create_user,
|
||||||
do_deactivate_user,
|
do_deactivate_user,
|
||||||
do_mute_user,
|
do_mute_user,
|
||||||
do_update_user_activity,
|
|
||||||
do_update_user_activity_interval,
|
|
||||||
do_update_user_custom_profile_data_if_changed,
|
do_update_user_custom_profile_data_if_changed,
|
||||||
do_update_user_presence,
|
do_update_user_presence,
|
||||||
do_update_user_status,
|
do_update_user_status,
|
||||||
|
|
|
@ -48,12 +48,11 @@ from zulip_bots.lib import extract_query_without_mention
|
||||||
|
|
||||||
from zerver.actions.invites import do_send_confirmation_email
|
from zerver.actions.invites import do_send_confirmation_email
|
||||||
from zerver.actions.realm_export import notify_realm_export
|
from zerver.actions.realm_export import notify_realm_export
|
||||||
|
from zerver.actions.user_activity import do_update_user_activity, do_update_user_activity_interval
|
||||||
from zerver.context_processors import common_context
|
from zerver.context_processors import common_context
|
||||||
from zerver.lib.actions import (
|
from zerver.lib.actions import (
|
||||||
do_mark_stream_messages_as_read,
|
do_mark_stream_messages_as_read,
|
||||||
do_update_embedded_data,
|
do_update_embedded_data,
|
||||||
do_update_user_activity,
|
|
||||||
do_update_user_activity_interval,
|
|
||||||
do_update_user_presence,
|
do_update_user_presence,
|
||||||
internal_send_private_message,
|
internal_send_private_message,
|
||||||
render_incoming_message,
|
render_incoming_message,
|
||||||
|
|
Loading…
Reference in New Issue