2016-03-13 13:15:21 +01:00
|
|
|
# Webhooks for external integrations.
|
2019-02-02 23:53:55 +01:00
|
|
|
from typing import Any, Dict, Optional
|
2016-05-25 15:02:02 +02:00
|
|
|
|
2016-06-05 23:18:47 +02:00
|
|
|
from django.http import HttpRequest, HttpResponse
|
2016-05-25 15:02:02 +02:00
|
|
|
|
2017-10-31 04:25:48 +01:00
|
|
|
from zerver.decorator import api_key_only_webhook_view
|
2020-08-19 22:26:38 +02:00
|
|
|
from zerver.lib.exceptions import UnsupportedWebhookEventType
|
2017-10-31 04:25:48 +01:00
|
|
|
from zerver.lib.request import REQ, has_request_variables
|
2019-02-02 23:53:55 +01:00
|
|
|
from zerver.lib.response import json_success
|
2016-03-13 13:15:21 +01:00
|
|
|
from zerver.lib.validator import check_dict
|
2020-08-19 22:14:40 +02: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:15:21 +01:00
|
|
|
|
2019-04-17 23:26:31 +02:00
|
|
|
ALERT_TEMPLATE = "{long_description} ([view alert]({alert_url}))."
|
|
|
|
|
|
|
|
DEPLOY_TEMPLATE = """
|
|
|
|
**{revision}** deployed by **{deployed_by}**:
|
|
|
|
|
|
|
|
``` quote
|
|
|
|
{description}
|
|
|
|
```
|
|
|
|
|
|
|
|
Changelog:
|
|
|
|
|
|
|
|
``` quote
|
|
|
|
{changelog}
|
|
|
|
```
|
|
|
|
""".strip()
|
|
|
|
|
2016-05-12 22:49:36 +02:00
|
|
|
@api_key_only_webhook_view("NewRelic")
|
2016-03-13 13:15:21 +01:00
|
|
|
@has_request_variables
|
2017-12-05 18:42:33 +01:00
|
|
|
def api_newrelic_webhook(request: HttpRequest, user_profile: UserProfile,
|
|
|
|
alert: Optional[Dict[str, Any]]=REQ(validator=check_dict([]), default=None),
|
python: Use trailing commas consistently.
Automatically generated by the following script, based on the output
of lint with flake8-comma:
import re
import sys
last_filename = None
last_row = None
lines = []
for msg in sys.stdin:
m = re.match(
r"\x1b\[35mflake8 \|\x1b\[0m \x1b\[1;31m(.+):(\d+):(\d+): (\w+)", msg
)
if m:
filename, row_str, col_str, err = m.groups()
row, col = int(row_str), int(col_str)
if filename == last_filename:
assert last_row != row
else:
if last_filename is not None:
with open(last_filename, "w") as f:
f.writelines(lines)
with open(filename) as f:
lines = f.readlines()
last_filename = filename
last_row = row
line = lines[row - 1]
if err in ["C812", "C815"]:
lines[row - 1] = line[: col - 1] + "," + line[col - 1 :]
elif err in ["C819"]:
assert line[col - 2] == ","
lines[row - 1] = line[: col - 2] + line[col - 1 :].lstrip(" ")
if last_filename is not None:
with open(last_filename, "w") as f:
f.writelines(lines)
Signed-off-by: Anders Kaseorg <anders@zulipchat.com>
2020-04-10 05:23:40 +02:00
|
|
|
deployment: Optional[Dict[str, Any]]=REQ(validator=check_dict([]), default=None),
|
2019-01-31 14:32:37 +01:00
|
|
|
) -> HttpResponse:
|
2016-03-13 13:15:21 +01:00
|
|
|
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']
|
2019-04-17 23:26:31 +02:00
|
|
|
content = ALERT_TEMPLATE.format(**alert)
|
2016-03-13 13:15:21 +01:00
|
|
|
elif deployment:
|
2020-06-10 06:41:04 +02:00
|
|
|
subject = "{} deploy".format(deployment['application_name'])
|
2019-04-17 23:26:31 +02:00
|
|
|
content = DEPLOY_TEMPLATE.format(**deployment)
|
2016-03-13 13:15:21 +01:00
|
|
|
else:
|
2020-08-19 22:26:38 +02:00
|
|
|
raise UnsupportedWebhookEventType('New Relic', 'Unknown Event Type')
|
2016-03-13 13:15:21 +01:00
|
|
|
|
2018-03-16 22:53:50 +01:00
|
|
|
check_send_webhook_message(request, user_profile, subject, content)
|
2016-03-13 13:15:21 +01:00
|
|
|
return json_success()
|