2016-03-13 13:25:04 +01:00
|
|
|
# Webhooks for external integrations.
|
2016-06-05 19:54:31 +02:00
|
|
|
from django.http import HttpRequest, HttpResponse
|
2017-10-31 04:25:48 +01:00
|
|
|
|
|
|
|
from zerver.decorator import authenticated_rest_api_view
|
2017-11-16 00:43:10 +01:00
|
|
|
from zerver.lib.response import json_success
|
2023-08-12 09:34:31 +02:00
|
|
|
from zerver.lib.typed_endpoint import typed_endpoint
|
2018-03-13 23:43:02 +01:00
|
|
|
from zerver.lib.webhooks.common import check_send_webhook_message
|
2019-02-02 23:53:55 +01:00
|
|
|
from zerver.models import UserProfile
|
2016-03-13 13:25:04 +01:00
|
|
|
|
2020-01-14 22:06:24 +01:00
|
|
|
|
2016-03-13 13:25:04 +01:00
|
|
|
# Desk.com's integrations all make the user supply a template, where it fills
|
|
|
|
# in stuff like {{customer.name}} and posts the result as a "data" parameter.
|
|
|
|
# There's no raw JSON for us to work from. Thus, it makes sense to just write
|
|
|
|
# a template Zulip message within Desk.com and have the webhook extract that
|
|
|
|
# from the "data" param and post it, which this does.
|
2018-03-16 23:37:32 +01:00
|
|
|
@authenticated_rest_api_view(webhook_client_name="Desk")
|
2023-08-12 09:34:31 +02:00
|
|
|
@typed_endpoint
|
2021-02-12 08:19:30 +01:00
|
|
|
def api_deskdotcom_webhook(
|
2023-08-12 09:34:31 +02:00
|
|
|
request: HttpRequest,
|
|
|
|
user_profile: UserProfile,
|
|
|
|
*,
|
|
|
|
data: str,
|
2021-02-12 08:19:30 +01:00
|
|
|
) -> HttpResponse:
|
2018-03-13 23:43:02 +01:00
|
|
|
topic = "Desk.com notification"
|
|
|
|
check_send_webhook_message(request, user_profile, topic, data)
|
2022-01-31 13:44:02 +01:00
|
|
|
return json_success(request)
|