mirror of
https://github.com/zulip/zulip.git
synced 2025-11-04 14:03:30 +00:00
This fixes a regression in93678e89cdanda4979410f9, where the webhooks using authenticated_rest_api_view were migrated to a new model that didn't include setting a custom Client string for the webhook. When restoring these webhooks' client strings, we also fix places where the client string was not capitalized the same was as the product's name.
50 lines
2.0 KiB
Python
50 lines
2.0 KiB
Python
from typing import Any, Mapping, Optional, Text
|
|
|
|
from django.http import HttpRequest, HttpResponse
|
|
|
|
from zerver.decorator import authenticated_rest_api_view
|
|
from zerver.lib.request import REQ, has_request_variables
|
|
from zerver.lib.response import json_success
|
|
from zerver.lib.validator import check_dict
|
|
from zerver.lib.webhooks.common import check_send_webhook_message
|
|
from zerver.lib.webhooks.git import SUBJECT_WITH_BRANCH_TEMPLATE, \
|
|
get_push_commits_event_message
|
|
from zerver.models import UserProfile, get_client
|
|
|
|
@authenticated_rest_api_view(webhook_client_name="Bitbucket")
|
|
@has_request_variables
|
|
def api_bitbucket_webhook(request: HttpRequest, user_profile: UserProfile,
|
|
payload: Mapping[Text, Any]=REQ(validator=check_dict([])),
|
|
branches: Optional[Text]=REQ(default=None)) -> HttpResponse:
|
|
repository = payload['repository']
|
|
|
|
commits = [
|
|
{
|
|
'name': payload.get('user'),
|
|
'sha': commit.get('raw_node'),
|
|
'message': commit.get('message'),
|
|
'url': u'{}{}commits/{}'.format(
|
|
payload.get('canon_url'),
|
|
repository.get('absolute_url'),
|
|
commit.get('raw_node'))
|
|
}
|
|
for commit in payload['commits']
|
|
]
|
|
|
|
if len(commits) == 0:
|
|
# Bitbucket doesn't give us enough information to really give
|
|
# a useful message :/
|
|
subject = repository['name']
|
|
content = (u"%s [force pushed](%s)"
|
|
% (payload['user'],
|
|
payload['canon_url'] + repository['absolute_url']))
|
|
else:
|
|
branch = payload['commits'][-1]['branch']
|
|
if branches is not None and branches.find(branch) == -1:
|
|
return json_success()
|
|
content = get_push_commits_event_message(payload['user'], None, branch, commits)
|
|
subject = SUBJECT_WITH_BRANCH_TEMPLATE.format(repo=repository['name'], branch=branch)
|
|
|
|
check_send_webhook_message(request, user_profile, subject, content)
|
|
return json_success()
|