2016-12-25 00:44:26 +01:00
|
|
|
from __future__ import absolute_import
|
|
|
|
|
2016-11-03 18:49:00 +01:00
|
|
|
from django.http import HttpRequest, HttpResponse
|
|
|
|
from django.utils.translation import ugettext as _
|
2016-12-25 00:44:26 +01:00
|
|
|
from typing import Text
|
2016-11-03 18:49:00 +01:00
|
|
|
|
|
|
|
from zerver.decorator import authenticated_json_post_view,\
|
|
|
|
has_request_variables, REQ, to_non_negative_int
|
2016-11-30 08:14:46 +01:00
|
|
|
from zerver.lib.actions import do_add_reaction, do_remove_reaction
|
2016-11-03 18:49:00 +01:00
|
|
|
from zerver.lib.bugdown import emoji_list
|
|
|
|
from zerver.lib.message import access_message
|
|
|
|
from zerver.lib.request import JsonableError
|
|
|
|
from zerver.lib.response import json_success
|
2016-12-31 02:45:16 +01:00
|
|
|
from zerver.models import Reaction, Realm, UserProfile
|
|
|
|
|
|
|
|
def check_valid_emoji(realm, emoji_name):
|
|
|
|
# type: (Realm, Text) -> None
|
|
|
|
if emoji_name in set(realm.get_emoji().keys()):
|
|
|
|
return
|
|
|
|
if emoji_name in emoji_list:
|
|
|
|
return
|
|
|
|
raise JsonableError(_("Emoji '%s' does not exist" % (emoji_name,)))
|
2016-11-03 18:49:00 +01:00
|
|
|
|
|
|
|
@has_request_variables
|
2016-12-04 10:50:32 +01:00
|
|
|
def add_reaction_backend(request, user_profile, message_id, emoji_name):
|
2016-12-25 00:44:26 +01:00
|
|
|
# type: (HttpRequest, UserProfile, int, Text) -> HttpResponse
|
2016-11-03 18:49:00 +01:00
|
|
|
|
|
|
|
# access_message will throw a JsonableError exception if the user
|
|
|
|
# cannot see the message (e.g. for messages to private streams).
|
|
|
|
message = access_message(user_profile, message_id)[0]
|
|
|
|
|
2016-12-31 02:45:16 +01:00
|
|
|
check_valid_emoji(message.sender.realm, emoji_name)
|
2016-11-03 18:49:00 +01:00
|
|
|
|
|
|
|
# We could probably just make this check be a try/except for the
|
|
|
|
# IntegrityError from it already existing, but this is a bit cleaner.
|
|
|
|
if Reaction.objects.filter(user_profile=user_profile,
|
|
|
|
message=message,
|
|
|
|
emoji_name=emoji_name).exists():
|
|
|
|
raise JsonableError(_("Reaction already exists"))
|
|
|
|
|
|
|
|
do_add_reaction(user_profile, message, emoji_name)
|
|
|
|
|
|
|
|
return json_success()
|
2016-11-30 08:14:46 +01:00
|
|
|
|
|
|
|
@has_request_variables
|
2016-12-04 10:50:32 +01:00
|
|
|
def remove_reaction_backend(request, user_profile, message_id, emoji_name):
|
2016-12-25 00:44:26 +01:00
|
|
|
# type: (HttpRequest, UserProfile, int, Text) -> HttpResponse
|
2016-11-30 08:14:46 +01:00
|
|
|
|
|
|
|
# access_message will throw a JsonableError exception if the user
|
|
|
|
# cannot see the message (e.g. for messages to private streams).
|
|
|
|
message = access_message(user_profile, message_id)[0]
|
|
|
|
|
2016-12-31 02:45:16 +01:00
|
|
|
check_valid_emoji(message.sender.realm, emoji_name)
|
2016-11-30 08:14:46 +01:00
|
|
|
|
|
|
|
# We could probably just make this check be a try/except for the
|
|
|
|
# IntegrityError from it already existing, but this is a bit cleaner.
|
|
|
|
if not Reaction.objects.filter(user_profile=user_profile,
|
|
|
|
message=message,
|
|
|
|
emoji_name=emoji_name).exists():
|
|
|
|
raise JsonableError(_("Reaction does not exist"))
|
|
|
|
|
|
|
|
do_remove_reaction(user_profile, message, emoji_name)
|
|
|
|
|
|
|
|
return json_success()
|