mirror of
https://github.com/zulip/zulip.git
synced 2025-11-06 06:53:25 +00:00
This commit migrates all of our webhooks to use
check_send_webhook_message, except the following:
beeminder: Rishi wanted to wait on this one.
teamcity: This one is slightly more work.
yo: This one is PM-only. I am still trying to decide whether we
should have a force_private argument or something in
check_send_webhook_message.
facebook: No point in migrating this, will be removed as part of
#8433.
slack: Slightly more work too with the `channel_to_topics` feature.
Warrants a longer discussion.
37 lines
1.5 KiB
Python
37 lines
1.5 KiB
Python
# Webhooks for external integrations.
|
|
from typing import Any, Callable, Dict, Iterable, Optional, Text, Tuple
|
|
|
|
from django.http import HttpRequest, HttpResponse
|
|
from django.utils.translation import ugettext as _
|
|
|
|
from zerver.decorator import api_key_only_webhook_view
|
|
from zerver.lib.request import REQ, has_request_variables
|
|
from zerver.lib.response import json_error, json_success
|
|
from zerver.lib.webhooks.common import check_send_webhook_message
|
|
from zerver.lib.validator import check_dict
|
|
from zerver.models import Stream, UserProfile
|
|
|
|
@api_key_only_webhook_view("NewRelic")
|
|
@has_request_variables
|
|
def api_newrelic_webhook(request: HttpRequest, user_profile: UserProfile,
|
|
alert: Optional[Dict[str, Any]]=REQ(validator=check_dict([]), default=None),
|
|
deployment: Optional[Dict[str, Any]]=REQ(validator=check_dict([]), default=None)
|
|
)-> HttpResponse:
|
|
if alert:
|
|
# Use the message as the subject because it stays the same for
|
|
# "opened", "acknowledged", and "closed" messages that should be
|
|
# grouped.
|
|
subject = alert['message']
|
|
content = "%(long_description)s\n[View alert](%(alert_url)s)" % (alert)
|
|
elif deployment:
|
|
subject = "%s deploy" % (deployment['application_name'])
|
|
content = """`%(revision)s` deployed by **%(deployed_by)s**
|
|
%(description)s
|
|
|
|
%(changelog)s""" % (deployment)
|
|
else:
|
|
return json_error(_("Unknown webhook request"))
|
|
|
|
check_send_webhook_message(request, user_profile, subject, content)
|
|
return json_success()
|