2016-03-13 15:10:12 +01:00
|
|
|
# Webhooks for external integrations.
|
2017-11-16 00:43:10 +01:00
|
|
|
from typing import Text
|
|
|
|
|
|
|
|
from django.http import HttpRequest, HttpResponse
|
|
|
|
|
2017-10-31 04:25:48 +01:00
|
|
|
from zerver.decorator import authenticated_rest_api_view
|
2017-09-30 04:18:16 +02:00
|
|
|
from zerver.lib.actions import check_send_stream_message
|
2017-10-31 04:25:48 +01:00
|
|
|
from zerver.lib.request import REQ, has_request_variables
|
2017-11-16 00:43:10 +01:00
|
|
|
from zerver.lib.response import json_success
|
|
|
|
from zerver.models import UserProfile, get_client
|
2016-03-13 15:10:12 +01:00
|
|
|
|
2017-11-04 07:47:46 +01:00
|
|
|
def truncate(string: Text, length: int) -> Text:
|
2016-03-13 15:10:12 +01:00
|
|
|
if len(string) > length:
|
|
|
|
string = string[:length-3] + '...'
|
|
|
|
return string
|
|
|
|
|
2016-05-18 20:35:35 +02:00
|
|
|
@authenticated_rest_api_view(is_webhook=True)
|
2016-05-07 20:07:48 +02:00
|
|
|
@has_request_variables
|
2017-12-25 10:27:18 +01:00
|
|
|
def api_zendesk_webhook(request: HttpRequest, user_profile: UserProfile,
|
|
|
|
ticket_title: str=REQ(), ticket_id: str=REQ(),
|
|
|
|
message: str=REQ(), stream: str=REQ(default="zendesk")) -> HttpResponse:
|
2016-03-13 15:10:12 +01:00
|
|
|
"""
|
|
|
|
Zendesk uses trigers with message templates. This webhook uses the
|
|
|
|
ticket_id and ticket_title to create a subject. And passes with zendesk
|
|
|
|
user's configured message to zulip.
|
|
|
|
"""
|
|
|
|
subject = truncate('#%s: %s' % (ticket_id, ticket_title), 60)
|
2017-09-30 04:18:16 +02:00
|
|
|
check_send_stream_message(user_profile, get_client('ZulipZenDeskWebhook'),
|
|
|
|
stream, subject, message)
|
2016-03-13 15:10:12 +01:00
|
|
|
return json_success()
|