mirror of
				https://github.com/zulip/zulip.git
				synced 2025-11-03 21:43:21 +00:00 
			
		
		
		
	actions: Split out zerver.actions.muted_users.
Signed-off-by: Anders Kaseorg <anders@zulip.com>
This commit is contained in:
		
							
								
								
									
										49
									
								
								zerver/actions/muted_users.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								zerver/actions/muted_users.py
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,49 @@
 | 
				
			|||||||
 | 
					import datetime
 | 
				
			||||||
 | 
					from typing import Optional
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import orjson
 | 
				
			||||||
 | 
					from django.utils.timezone import now as timezone_now
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					from zerver.actions.message_flags import do_mark_muted_user_messages_as_read
 | 
				
			||||||
 | 
					from zerver.lib.user_mutes import add_user_mute, get_user_mutes
 | 
				
			||||||
 | 
					from zerver.models import MutedUser, RealmAuditLog, UserProfile
 | 
				
			||||||
 | 
					from zerver.tornado.django_api import send_event
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					def do_mute_user(
 | 
				
			||||||
 | 
					    user_profile: UserProfile,
 | 
				
			||||||
 | 
					    muted_user: UserProfile,
 | 
				
			||||||
 | 
					    date_muted: Optional[datetime.datetime] = None,
 | 
				
			||||||
 | 
					) -> None:
 | 
				
			||||||
 | 
					    if date_muted is None:
 | 
				
			||||||
 | 
					        date_muted = timezone_now()
 | 
				
			||||||
 | 
					    add_user_mute(user_profile, muted_user, date_muted)
 | 
				
			||||||
 | 
					    do_mark_muted_user_messages_as_read(user_profile, muted_user)
 | 
				
			||||||
 | 
					    event = dict(type="muted_users", muted_users=get_user_mutes(user_profile))
 | 
				
			||||||
 | 
					    send_event(user_profile.realm, event, [user_profile.id])
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    RealmAuditLog.objects.create(
 | 
				
			||||||
 | 
					        realm=user_profile.realm,
 | 
				
			||||||
 | 
					        acting_user=user_profile,
 | 
				
			||||||
 | 
					        modified_user=user_profile,
 | 
				
			||||||
 | 
					        event_type=RealmAuditLog.USER_MUTED,
 | 
				
			||||||
 | 
					        event_time=date_muted,
 | 
				
			||||||
 | 
					        extra_data=orjson.dumps({"muted_user_id": muted_user.id}).decode(),
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					def do_unmute_user(mute_object: MutedUser) -> None:
 | 
				
			||||||
 | 
					    user_profile = mute_object.user_profile
 | 
				
			||||||
 | 
					    muted_user = mute_object.muted_user
 | 
				
			||||||
 | 
					    mute_object.delete()
 | 
				
			||||||
 | 
					    event = dict(type="muted_users", muted_users=get_user_mutes(user_profile))
 | 
				
			||||||
 | 
					    send_event(user_profile.realm, event, [user_profile.id])
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    RealmAuditLog.objects.create(
 | 
				
			||||||
 | 
					        realm=user_profile.realm,
 | 
				
			||||||
 | 
					        acting_user=user_profile,
 | 
				
			||||||
 | 
					        modified_user=user_profile,
 | 
				
			||||||
 | 
					        event_type=RealmAuditLog.USER_UNMUTED,
 | 
				
			||||||
 | 
					        event_time=timezone_now(),
 | 
				
			||||||
 | 
					        extra_data=orjson.dumps({"unmuted_user_id": muted_user.id}).decode(),
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
@@ -14,10 +14,7 @@ from typing_extensions import TypedDict
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
from confirmation.models import Confirmation, create_confirmation_link, generate_key
 | 
					from confirmation.models import Confirmation, create_confirmation_link, generate_key
 | 
				
			||||||
from zerver.actions.custom_profile_fields import do_remove_realm_custom_profile_fields
 | 
					from zerver.actions.custom_profile_fields import do_remove_realm_custom_profile_fields
 | 
				
			||||||
from zerver.actions.message_flags import (
 | 
					from zerver.actions.message_flags import do_update_mobile_push_notification
 | 
				
			||||||
    do_mark_muted_user_messages_as_read,
 | 
					 | 
				
			||||||
    do_update_mobile_push_notification,
 | 
					 | 
				
			||||||
)
 | 
					 | 
				
			||||||
from zerver.actions.message_send import (
 | 
					from zerver.actions.message_send import (
 | 
				
			||||||
    filter_presence_idle_user_ids,
 | 
					    filter_presence_idle_user_ids,
 | 
				
			||||||
    get_recipient_info,
 | 
					    get_recipient_info,
 | 
				
			||||||
@@ -76,7 +73,6 @@ from zerver.lib.types import EditHistoryEvent
 | 
				
			|||||||
from zerver.lib.user_counts import realm_user_count_by_role
 | 
					from zerver.lib.user_counts import realm_user_count_by_role
 | 
				
			||||||
from zerver.lib.user_groups import create_system_user_groups_for_realm
 | 
					from zerver.lib.user_groups import create_system_user_groups_for_realm
 | 
				
			||||||
from zerver.lib.user_message import UserMessageLite, bulk_insert_ums
 | 
					from zerver.lib.user_message import UserMessageLite, bulk_insert_ums
 | 
				
			||||||
from zerver.lib.user_mutes import add_user_mute, get_user_mutes
 | 
					 | 
				
			||||||
from zerver.lib.user_topics import get_users_muting_topic, remove_topic_mute
 | 
					from zerver.lib.user_topics import get_users_muting_topic, remove_topic_mute
 | 
				
			||||||
from zerver.lib.widget import is_widget_message
 | 
					from zerver.lib.widget import is_widget_message
 | 
				
			||||||
from zerver.models import (
 | 
					from zerver.models import (
 | 
				
			||||||
@@ -84,7 +80,6 @@ from zerver.models import (
 | 
				
			|||||||
    Attachment,
 | 
					    Attachment,
 | 
				
			||||||
    DefaultStream,
 | 
					    DefaultStream,
 | 
				
			||||||
    Message,
 | 
					    Message,
 | 
				
			||||||
    MutedUser,
 | 
					 | 
				
			||||||
    Reaction,
 | 
					    Reaction,
 | 
				
			||||||
    Realm,
 | 
					    Realm,
 | 
				
			||||||
    RealmAuditLog,
 | 
					    RealmAuditLog,
 | 
				
			||||||
@@ -1775,45 +1770,6 @@ def email_not_system_bot(email: str) -> None:
 | 
				
			|||||||
        )
 | 
					        )
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
def do_mute_user(
 | 
					 | 
				
			||||||
    user_profile: UserProfile,
 | 
					 | 
				
			||||||
    muted_user: UserProfile,
 | 
					 | 
				
			||||||
    date_muted: Optional[datetime.datetime] = None,
 | 
					 | 
				
			||||||
) -> None:
 | 
					 | 
				
			||||||
    if date_muted is None:
 | 
					 | 
				
			||||||
        date_muted = timezone_now()
 | 
					 | 
				
			||||||
    add_user_mute(user_profile, muted_user, date_muted)
 | 
					 | 
				
			||||||
    do_mark_muted_user_messages_as_read(user_profile, muted_user)
 | 
					 | 
				
			||||||
    event = dict(type="muted_users", muted_users=get_user_mutes(user_profile))
 | 
					 | 
				
			||||||
    send_event(user_profile.realm, event, [user_profile.id])
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    RealmAuditLog.objects.create(
 | 
					 | 
				
			||||||
        realm=user_profile.realm,
 | 
					 | 
				
			||||||
        acting_user=user_profile,
 | 
					 | 
				
			||||||
        modified_user=user_profile,
 | 
					 | 
				
			||||||
        event_type=RealmAuditLog.USER_MUTED,
 | 
					 | 
				
			||||||
        event_time=date_muted,
 | 
					 | 
				
			||||||
        extra_data=orjson.dumps({"muted_user_id": muted_user.id}).decode(),
 | 
					 | 
				
			||||||
    )
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
def do_unmute_user(mute_object: MutedUser) -> None:
 | 
					 | 
				
			||||||
    user_profile = mute_object.user_profile
 | 
					 | 
				
			||||||
    muted_user = mute_object.muted_user
 | 
					 | 
				
			||||||
    mute_object.delete()
 | 
					 | 
				
			||||||
    event = dict(type="muted_users", muted_users=get_user_mutes(user_profile))
 | 
					 | 
				
			||||||
    send_event(user_profile.realm, event, [user_profile.id])
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    RealmAuditLog.objects.create(
 | 
					 | 
				
			||||||
        realm=user_profile.realm,
 | 
					 | 
				
			||||||
        acting_user=user_profile,
 | 
					 | 
				
			||||||
        modified_user=user_profile,
 | 
					 | 
				
			||||||
        event_type=RealmAuditLog.USER_UNMUTED,
 | 
					 | 
				
			||||||
        event_time=timezone_now(),
 | 
					 | 
				
			||||||
        extra_data=orjson.dumps({"unmuted_user_id": muted_user.id}).decode(),
 | 
					 | 
				
			||||||
    )
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@transaction.atomic(durable=True)
 | 
					@transaction.atomic(durable=True)
 | 
				
			||||||
def do_add_realm_domain(
 | 
					def do_add_realm_domain(
 | 
				
			||||||
    realm: Realm, domain: str, allow_subdomains: bool, *, acting_user: Optional[UserProfile]
 | 
					    realm: Realm, domain: str, allow_subdomains: bool, *, acting_user: Optional[UserProfile]
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -46,6 +46,7 @@ from zerver.actions.invites import (
 | 
				
			|||||||
    do_revoke_user_invite,
 | 
					    do_revoke_user_invite,
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
from zerver.actions.message_flags import do_update_message_flags
 | 
					from zerver.actions.message_flags import do_update_message_flags
 | 
				
			||||||
 | 
					from zerver.actions.muted_users import do_mute_user, do_unmute_user
 | 
				
			||||||
from zerver.actions.presence import do_update_user_presence, do_update_user_status
 | 
					from zerver.actions.presence import do_update_user_presence, do_update_user_status
 | 
				
			||||||
from zerver.actions.reactions import do_add_reaction, do_remove_reaction
 | 
					from zerver.actions.reactions import do_add_reaction, do_remove_reaction
 | 
				
			||||||
from zerver.actions.realm_emoji import check_add_realm_emoji, do_remove_realm_emoji
 | 
					from zerver.actions.realm_emoji import check_add_realm_emoji, do_remove_realm_emoji
 | 
				
			||||||
@@ -99,7 +100,6 @@ from zerver.lib.actions import (
 | 
				
			|||||||
    do_change_realm_plan_type,
 | 
					    do_change_realm_plan_type,
 | 
				
			||||||
    do_deactivate_realm,
 | 
					    do_deactivate_realm,
 | 
				
			||||||
    do_delete_messages,
 | 
					    do_delete_messages,
 | 
				
			||||||
    do_mute_user,
 | 
					 | 
				
			||||||
    do_remove_realm_domain,
 | 
					    do_remove_realm_domain,
 | 
				
			||||||
    do_set_realm_authentication_methods,
 | 
					    do_set_realm_authentication_methods,
 | 
				
			||||||
    do_set_realm_message_editing,
 | 
					    do_set_realm_message_editing,
 | 
				
			||||||
@@ -107,7 +107,6 @@ from zerver.lib.actions import (
 | 
				
			|||||||
    do_set_realm_property,
 | 
					    do_set_realm_property,
 | 
				
			||||||
    do_set_realm_signup_notifications_stream,
 | 
					    do_set_realm_signup_notifications_stream,
 | 
				
			||||||
    do_set_realm_user_default_setting,
 | 
					    do_set_realm_user_default_setting,
 | 
				
			||||||
    do_unmute_user,
 | 
					 | 
				
			||||||
    do_update_embedded_data,
 | 
					    do_update_embedded_data,
 | 
				
			||||||
    do_update_message,
 | 
					    do_update_message,
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -16,6 +16,7 @@ from zerver.actions.custom_profile_fields import (
 | 
				
			|||||||
    do_update_user_custom_profile_data_if_changed,
 | 
					    do_update_user_custom_profile_data_if_changed,
 | 
				
			||||||
    try_add_realm_custom_profile_field,
 | 
					    try_add_realm_custom_profile_field,
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					from zerver.actions.muted_users import do_mute_user
 | 
				
			||||||
from zerver.actions.presence import do_update_user_presence, do_update_user_status
 | 
					from zerver.actions.presence import do_update_user_presence, do_update_user_status
 | 
				
			||||||
from zerver.actions.reactions import check_add_reaction, do_add_reaction
 | 
					from zerver.actions.reactions import check_add_reaction, do_add_reaction
 | 
				
			||||||
from zerver.actions.realm_emoji import check_add_realm_emoji
 | 
					from zerver.actions.realm_emoji import check_add_realm_emoji
 | 
				
			||||||
@@ -25,7 +26,7 @@ from zerver.actions.user_activity import do_update_user_activity, do_update_user
 | 
				
			|||||||
from zerver.actions.user_topics import do_mute_topic
 | 
					from zerver.actions.user_topics import do_mute_topic
 | 
				
			||||||
from zerver.actions.users import do_deactivate_user
 | 
					from zerver.actions.users import do_deactivate_user
 | 
				
			||||||
from zerver.lib import upload
 | 
					from zerver.lib import upload
 | 
				
			||||||
from zerver.lib.actions import do_change_realm_plan_type, do_mute_user
 | 
					from zerver.lib.actions import do_change_realm_plan_type
 | 
				
			||||||
from zerver.lib.avatar_hash import user_avatar_path
 | 
					from zerver.lib.avatar_hash import user_avatar_path
 | 
				
			||||||
from zerver.lib.bot_config import set_bot_config
 | 
					from zerver.lib.bot_config import set_bot_config
 | 
				
			||||||
from zerver.lib.bot_lib import StateHandler
 | 
					from zerver.lib.bot_lib import StateHandler
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -153,7 +153,7 @@ class MutedUsersTests(ZulipTestCase):
 | 
				
			|||||||
            result = self.api_post(hamlet, url)
 | 
					            result = self.api_post(hamlet, url)
 | 
				
			||||||
            self.assert_json_success(result)
 | 
					            self.assert_json_success(result)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        with mock.patch("zerver.lib.actions.timezone_now", return_value=mute_time):
 | 
					        with mock.patch("zerver.actions.muted_users.timezone_now", return_value=mute_time):
 | 
				
			||||||
            # To test that `RealmAuditLog` entry has correct `event_time`.
 | 
					            # To test that `RealmAuditLog` entry has correct `event_time`.
 | 
				
			||||||
            url = f"/api/v1/users/me/muted_users/{cordelia.id}"
 | 
					            url = f"/api/v1/users/me/muted_users/{cordelia.id}"
 | 
				
			||||||
            result = self.api_delete(hamlet, url)
 | 
					            result = self.api_delete(hamlet, url)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -15,6 +15,7 @@ from confirmation.models import Confirmation
 | 
				
			|||||||
from zerver.actions.create_user import do_create_user, do_reactivate_user
 | 
					from zerver.actions.create_user import do_create_user, do_reactivate_user
 | 
				
			||||||
from zerver.actions.invites import do_create_multiuse_invite_link, do_invite_users
 | 
					from zerver.actions.invites import do_create_multiuse_invite_link, do_invite_users
 | 
				
			||||||
from zerver.actions.message_send import get_recipient_info
 | 
					from zerver.actions.message_send import get_recipient_info
 | 
				
			||||||
 | 
					from zerver.actions.muted_users import do_mute_user
 | 
				
			||||||
from zerver.actions.users import (
 | 
					from zerver.actions.users import (
 | 
				
			||||||
    change_user_is_active,
 | 
					    change_user_is_active,
 | 
				
			||||||
    do_change_can_create_users,
 | 
					    do_change_can_create_users,
 | 
				
			||||||
@@ -22,7 +23,7 @@ from zerver.actions.users import (
 | 
				
			|||||||
    do_deactivate_user,
 | 
					    do_deactivate_user,
 | 
				
			||||||
    do_delete_user,
 | 
					    do_delete_user,
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
from zerver.lib.actions import do_mute_user, do_set_realm_property
 | 
					from zerver.lib.actions import do_set_realm_property
 | 
				
			||||||
from zerver.lib.avatar import avatar_url, get_gravatar_url
 | 
					from zerver.lib.avatar import avatar_url, get_gravatar_url
 | 
				
			||||||
from zerver.lib.bulk_create import create_users
 | 
					from zerver.lib.bulk_create import create_users
 | 
				
			||||||
from zerver.lib.create_user import copy_default_settings
 | 
					from zerver.lib.create_user import copy_default_settings
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -6,8 +6,8 @@ from django.http import HttpRequest, HttpResponse
 | 
				
			|||||||
from django.utils.timezone import now as timezone_now
 | 
					from django.utils.timezone import now as timezone_now
 | 
				
			||||||
from django.utils.translation import gettext as _
 | 
					from django.utils.translation import gettext as _
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					from zerver.actions.muted_users import do_mute_user, do_unmute_user
 | 
				
			||||||
from zerver.actions.user_topics import do_mute_topic, do_unmute_topic
 | 
					from zerver.actions.user_topics import do_mute_topic, do_unmute_topic
 | 
				
			||||||
from zerver.lib.actions import do_mute_user, do_unmute_user
 | 
					 | 
				
			||||||
from zerver.lib.exceptions import JsonableError
 | 
					from zerver.lib.exceptions import JsonableError
 | 
				
			||||||
from zerver.lib.request import REQ, has_request_variables
 | 
					from zerver.lib.request import REQ, has_request_variables
 | 
				
			||||||
from zerver.lib.response import json_success
 | 
					from zerver.lib.response import json_success
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user