mirror of https://github.com/zulip/zulip.git
actions: Split out zerver.actions.realm_linkifiers.
Signed-off-by: Anders Kaseorg <anders@zulip.com>
This commit is contained in:
parent
e887abcf41
commit
975f5a3c2d
|
@ -0,0 +1,59 @@
|
|||
from typing import Dict, Optional
|
||||
|
||||
from zerver.models import (
|
||||
Realm,
|
||||
RealmFilter,
|
||||
active_user_ids,
|
||||
linkifiers_for_realm,
|
||||
realm_filters_for_realm,
|
||||
)
|
||||
from zerver.tornado.django_api import send_event
|
||||
|
||||
|
||||
def notify_linkifiers(realm: Realm) -> None:
|
||||
realm_linkifiers = linkifiers_for_realm(realm.id)
|
||||
event: Dict[str, object] = dict(type="realm_linkifiers", realm_linkifiers=realm_linkifiers)
|
||||
send_event(realm, event, active_user_ids(realm.id))
|
||||
|
||||
# Below is code for backwards compatibility. The now deprecated
|
||||
# "realm_filters" event-type is used by older clients, and uses
|
||||
# tuples.
|
||||
realm_filters = realm_filters_for_realm(realm.id)
|
||||
event = dict(type="realm_filters", realm_filters=realm_filters)
|
||||
send_event(realm, event, active_user_ids(realm.id))
|
||||
|
||||
|
||||
# NOTE: Regexes must be simple enough that they can be easily translated to JavaScript
|
||||
# RegExp syntax. In addition to JS-compatible syntax, the following features are available:
|
||||
# * Named groups will be converted to numbered groups automatically
|
||||
# * Inline-regex flags will be stripped, and where possible translated to RegExp-wide flags
|
||||
def do_add_linkifier(realm: Realm, pattern: str, url_format_string: str) -> int:
|
||||
pattern = pattern.strip()
|
||||
url_format_string = url_format_string.strip()
|
||||
linkifier = RealmFilter(realm=realm, pattern=pattern, url_format_string=url_format_string)
|
||||
linkifier.full_clean()
|
||||
linkifier.save()
|
||||
notify_linkifiers(realm)
|
||||
|
||||
return linkifier.id
|
||||
|
||||
|
||||
def do_remove_linkifier(
|
||||
realm: Realm, pattern: Optional[str] = None, id: Optional[int] = None
|
||||
) -> None:
|
||||
if pattern is not None:
|
||||
RealmFilter.objects.get(realm=realm, pattern=pattern).delete()
|
||||
else:
|
||||
RealmFilter.objects.get(realm=realm, id=id).delete()
|
||||
notify_linkifiers(realm)
|
||||
|
||||
|
||||
def do_update_linkifier(realm: Realm, id: int, pattern: str, url_format_string: str) -> None:
|
||||
pattern = pattern.strip()
|
||||
url_format_string = url_format_string.strip()
|
||||
linkifier = RealmFilter.objects.get(realm=realm, id=id)
|
||||
linkifier.pattern = pattern
|
||||
linkifier.url_format_string = url_format_string
|
||||
linkifier.full_clean()
|
||||
linkifier.save(update_fields=["pattern", "url_format_string"])
|
||||
notify_linkifiers(realm)
|
|
@ -239,7 +239,6 @@ from zerver.models import (
|
|||
RealmAuditLog,
|
||||
RealmDomain,
|
||||
RealmEmoji,
|
||||
RealmFilter,
|
||||
RealmUserDefault,
|
||||
Recipient,
|
||||
ScheduledEmail,
|
||||
|
@ -279,9 +278,7 @@ from zerver.models import (
|
|||
get_user_by_delivery_email,
|
||||
get_user_profile_by_id,
|
||||
is_cross_realm_bot_email,
|
||||
linkifiers_for_realm,
|
||||
query_for_ids,
|
||||
realm_filters_for_realm,
|
||||
validate_attachment_request,
|
||||
)
|
||||
from zerver.tornado.django_api import send_event
|
||||
|
@ -7724,55 +7721,6 @@ def do_mark_hotspot_as_read(user: UserProfile, hotspot: str) -> None:
|
|||
send_event(user.realm, event, [user.id])
|
||||
|
||||
|
||||
def notify_linkifiers(realm: Realm) -> None:
|
||||
realm_linkifiers = linkifiers_for_realm(realm.id)
|
||||
event: Dict[str, object] = dict(type="realm_linkifiers", realm_linkifiers=realm_linkifiers)
|
||||
send_event(realm, event, active_user_ids(realm.id))
|
||||
|
||||
# Below is code for backwards compatibility. The now deprecated
|
||||
# "realm_filters" event-type is used by older clients, and uses
|
||||
# tuples.
|
||||
realm_filters = realm_filters_for_realm(realm.id)
|
||||
event = dict(type="realm_filters", realm_filters=realm_filters)
|
||||
send_event(realm, event, active_user_ids(realm.id))
|
||||
|
||||
|
||||
# NOTE: Regexes must be simple enough that they can be easily translated to JavaScript
|
||||
# RegExp syntax. In addition to JS-compatible syntax, the following features are available:
|
||||
# * Named groups will be converted to numbered groups automatically
|
||||
# * Inline-regex flags will be stripped, and where possible translated to RegExp-wide flags
|
||||
def do_add_linkifier(realm: Realm, pattern: str, url_format_string: str) -> int:
|
||||
pattern = pattern.strip()
|
||||
url_format_string = url_format_string.strip()
|
||||
linkifier = RealmFilter(realm=realm, pattern=pattern, url_format_string=url_format_string)
|
||||
linkifier.full_clean()
|
||||
linkifier.save()
|
||||
notify_linkifiers(realm)
|
||||
|
||||
return linkifier.id
|
||||
|
||||
|
||||
def do_remove_linkifier(
|
||||
realm: Realm, pattern: Optional[str] = None, id: Optional[int] = None
|
||||
) -> None:
|
||||
if pattern is not None:
|
||||
RealmFilter.objects.get(realm=realm, pattern=pattern).delete()
|
||||
else:
|
||||
RealmFilter.objects.get(realm=realm, id=id).delete()
|
||||
notify_linkifiers(realm)
|
||||
|
||||
|
||||
def do_update_linkifier(realm: Realm, id: int, pattern: str, url_format_string: str) -> None:
|
||||
pattern = pattern.strip()
|
||||
url_format_string = url_format_string.strip()
|
||||
linkifier = RealmFilter.objects.get(realm=realm, id=id)
|
||||
linkifier.pattern = pattern
|
||||
linkifier.url_format_string = url_format_string
|
||||
linkifier.full_clean()
|
||||
linkifier.save(update_fields=["pattern", "url_format_string"])
|
||||
notify_linkifiers(realm)
|
||||
|
||||
|
||||
@transaction.atomic(durable=True)
|
||||
def do_add_realm_domain(
|
||||
realm: Realm, domain: str, allow_subdomains: bool, *, acting_user: Optional[UserProfile]
|
||||
|
|
|
@ -4,7 +4,7 @@ from typing import Any
|
|||
|
||||
from django.core.management.base import CommandError
|
||||
|
||||
from zerver.lib.actions import do_add_linkifier, do_remove_linkifier
|
||||
from zerver.actions.realm_linkifiers import do_add_linkifier, do_remove_linkifier
|
||||
from zerver.lib.management import ZulipBaseCommand
|
||||
from zerver.models import linkifiers_for_realm
|
||||
|
||||
|
|
|
@ -10,13 +10,9 @@ from typing import Any, Callable, Dict, List, Optional, Set, Tuple
|
|||
|
||||
from django.utils.timezone import now as timezone_now
|
||||
|
||||
from zerver.actions.realm_linkifiers import do_add_linkifier
|
||||
from zerver.actions.realm_playgrounds import do_add_realm_playground
|
||||
from zerver.lib.actions import (
|
||||
do_add_linkifier,
|
||||
do_add_reaction,
|
||||
do_create_user,
|
||||
update_user_presence,
|
||||
)
|
||||
from zerver.lib.actions import do_add_reaction, do_create_user, update_user_presence
|
||||
from zerver.lib.events import do_events_register
|
||||
from zerver.lib.initial_password import initial_password
|
||||
from zerver.lib.test_classes import ZulipTestCase
|
||||
|
|
|
@ -13,6 +13,11 @@ from unittest import mock
|
|||
import orjson
|
||||
from django.utils.timezone import now as timezone_now
|
||||
|
||||
from zerver.actions.realm_linkifiers import (
|
||||
do_add_linkifier,
|
||||
do_remove_linkifier,
|
||||
do_update_linkifier,
|
||||
)
|
||||
from zerver.actions.realm_playgrounds import do_add_realm_playground, do_remove_realm_playground
|
||||
from zerver.actions.submessage import do_add_submessage
|
||||
from zerver.actions.typing import check_send_typing_notification, do_send_stream_typing_notification
|
||||
|
@ -31,7 +36,6 @@ from zerver.lib.actions import (
|
|||
check_add_realm_emoji,
|
||||
do_add_alert_words,
|
||||
do_add_default_stream,
|
||||
do_add_linkifier,
|
||||
do_add_reaction,
|
||||
do_add_realm_domain,
|
||||
do_add_streams_to_default_stream_group,
|
||||
|
@ -72,7 +76,6 @@ from zerver.lib.actions import (
|
|||
do_remove_alert_words,
|
||||
do_remove_default_stream,
|
||||
do_remove_default_stream_group,
|
||||
do_remove_linkifier,
|
||||
do_remove_reaction,
|
||||
do_remove_realm_custom_profile_field,
|
||||
do_remove_realm_domain,
|
||||
|
@ -90,7 +93,6 @@ from zerver.lib.actions import (
|
|||
do_unmute_topic,
|
||||
do_unmute_user,
|
||||
do_update_embedded_data,
|
||||
do_update_linkifier,
|
||||
do_update_message,
|
||||
do_update_message_flags,
|
||||
do_update_outgoing_webhook_service,
|
||||
|
|
|
@ -2,8 +2,12 @@ from django.core.exceptions import ValidationError
|
|||
from django.http import HttpRequest, HttpResponse
|
||||
from django.utils.translation import gettext as _
|
||||
|
||||
from zerver.actions.realm_linkifiers import (
|
||||
do_add_linkifier,
|
||||
do_remove_linkifier,
|
||||
do_update_linkifier,
|
||||
)
|
||||
from zerver.decorator import require_realm_admin
|
||||
from zerver.lib.actions import do_add_linkifier, do_remove_linkifier, do_update_linkifier
|
||||
from zerver.lib.exceptions import JsonableError, ValidationFailureError
|
||||
from zerver.lib.request import REQ, has_request_variables
|
||||
from zerver.lib.response import json_success
|
||||
|
|
Loading…
Reference in New Issue