2018-03-01 12:13:15 +01:00
|
|
|
# Webhooks for external integrations.
|
2020-01-14 22:06:24 +01:00
|
|
|
from django.http import HttpRequest, HttpResponse
|
|
|
|
|
2021-07-16 22:11:10 +02:00
|
|
|
from zerver.decorator import webhook_view
|
|
|
|
from zerver.lib.request import REQ, has_request_variables
|
2018-03-01 12:13:15 +01:00
|
|
|
from zerver.lib.response import json_success
|
2022-03-30 17:55:53 +02:00
|
|
|
from zerver.lib.validator import WildValue, check_string, to_wild_value
|
2018-03-13 23:43:02 +01:00
|
|
|
from zerver.lib.webhooks.common import check_send_webhook_message
|
2018-03-01 12:13:15 +01:00
|
|
|
from zerver.models import UserProfile
|
|
|
|
|
2021-02-12 08:19:30 +01:00
|
|
|
|
2021-02-12 08:20:45 +01:00
|
|
|
@webhook_view("Flock")
|
2018-03-01 12:13:15 +01:00
|
|
|
@has_request_variables
|
2021-02-12 08:19:30 +01:00
|
|
|
def api_flock_webhook(
|
|
|
|
request: HttpRequest,
|
|
|
|
user_profile: UserProfile,
|
2022-03-30 17:55:53 +02:00
|
|
|
payload: WildValue = REQ(argument_type="body", converter=to_wild_value),
|
2021-02-12 08:19:30 +01:00
|
|
|
) -> HttpResponse:
|
2022-03-30 17:55:53 +02:00
|
|
|
text = payload["text"].tame(check_string)
|
|
|
|
if len(text) != 0:
|
|
|
|
message_body = text
|
2018-03-01 12:13:15 +01:00
|
|
|
else:
|
2022-03-30 17:55:53 +02:00
|
|
|
message_body = payload["notification"].tame(check_string)
|
2018-03-13 23:43:02 +01:00
|
|
|
|
2021-02-12 08:20:45 +01:00
|
|
|
topic = "Flock notifications"
|
2020-06-09 00:25:09 +02:00
|
|
|
body = f"{message_body}"
|
2018-03-01 12:13:15 +01:00
|
|
|
|
2018-03-13 23:43:02 +01:00
|
|
|
check_send_webhook_message(request, user_profile, topic, body)
|
2018-03-01 12:13:15 +01:00
|
|
|
|
2022-01-31 13:44:02 +01:00
|
|
|
return json_success(request)
|