mirror of
https://github.com/zulip/zulip.git
synced 2025-11-11 01:16:19 +00:00
This needs to be deployed to both staging and prod at the same off-peak time (and the schema migration run). At the time it is deployed, we need to make a few changes directly in the database: (1) UPDATE django_content_type set app_label='zerver' where app_label='zephyr'; (2) UPDATE south_migrationhistory set app_name='zerver' where app_name='zephyr'; (imported from commit eb3fd719571740189514ef0b884738cb30df1320)
25 lines
643 B
Python
25 lines
643 B
Python
import re
|
|
|
|
from django.db.models import F, Q
|
|
import zerver.models
|
|
|
|
# Match multi-word string between @** ** or match any one-word
|
|
# sequences after @
|
|
find_mentions = r'(?<![^\s\'\"\(,:<])@(?:\*\*([^\*]+)\*\*|(\w+))'
|
|
|
|
wildcards = ['all', 'everyone']
|
|
|
|
def find_user_for_mention(mention, realm):
|
|
if mention in wildcards:
|
|
return (True, None)
|
|
|
|
try:
|
|
user = zerver.models.UserProfile.objects.filter(
|
|
Q(full_name__iexact=mention) | Q(short_name__iexact=mention),
|
|
is_active=True,
|
|
realm=realm).order_by("id")[0]
|
|
except IndexError:
|
|
user = None
|
|
|
|
return (False, user)
|