buildbot-transifex/buildbot_gitea/webhook.py

145 lines
5.5 KiB
Python
Raw Permalink Normal View History

import json
import re
from buildbot.util import bytes2unicode
from buildbot.www.hooks.base import BaseHookHandler
from twisted.python import log
2018-09-04 12:58:05 +02:00
from dateutil.parser import parse as dateparse
_HEADER_EVENT_TYPE = 'X-Gitea-Event'
class GiteaHandler(BaseHookHandler):
def processPushEvent(self, payload, event_type, codebase):
refname = payload["ref"]
changes = []
# We only care about regular heads or tags
match = re.match(r"^refs/(heads|tags)/(.+)$", refname)
if not match:
log.msg("Ignoring refname '{}': Not a branch or tag".format(refname))
return changes
branch = match.group(2)
2018-09-04 15:04:29 +02:00
repository = payload['repository']
repo_url = repository['ssh_url']
project = repository['full_name']
commits = payload['commits']
if isinstance(self.options, dict) and self.options.get('onlyIncludePushCommit', False):
commits = commits[:1]
for commit in commits:
2018-09-04 15:04:29 +02:00
timestamp = dateparse(commit['timestamp'])
change = {
2018-09-04 15:10:46 +02:00
'author': '{} <{}>'.format(commit['author']['name'],
commit['author']['email']),
'comments': commit['message'],
'revision': commit['id'],
'when_timestamp': timestamp,
'branch': branch,
'revlink': commit['url'],
'repository': repo_url,
'project': project,
'category': event_type,
'properties': {
'event': event_type,
2018-09-27 14:46:35 +02:00
'repository_name': repository['name'],
'owner': repository["owner"]["username"]
},
}
if codebase is not None:
change['codebase'] = codebase
changes.append(change)
return changes
2018-09-04 15:04:29 +02:00
def processPullRequestEvent(self, payload, event_type, codebase):
action = payload['action']
# Only handle potential new stuff, ignore close/.
# Merge itself is handled by the regular branch push message
if action not in ['opened', 'synchronized', 'edited', 'reopened']:
log.msg("Gitea Pull Request event '{}' ignored".format(action))
return []
pull_request = payload['pull_request']
if not pull_request['mergeable']:
log.msg("Gitea Pull Request ignored because it is not mergeable.")
return []
if pull_request['merged']:
log.msg("Gitea Pull Request ignored because it is already merged.")
return []
2018-09-04 15:04:29 +02:00
timestamp = dateparse(pull_request['updated_at'])
base = pull_request['base']
head = pull_request['head']
repository = payload['repository']
2018-09-04 15:04:29 +02:00
change = {
2018-09-04 15:10:46 +02:00
'author': '{} <{}>'.format(pull_request['user']['full_name'],
pull_request['user']['email']),
2018-09-04 15:16:30 +02:00
'comments': 'PR#{}: {}\n\n{}'.format(
pull_request['number'],
pull_request['title'],
pull_request['body']),
'revision': head['sha'],
2018-09-04 15:04:29 +02:00
'when_timestamp': timestamp,
'branch': head['ref'],
'revlink': pull_request['html_url'],
'repository': repository['ssh_url'],
'project': repository['full_name'],
'category': event_type,
'properties': {
'event': event_type,
'base_branch': base['ref'],
'base_sha': base['sha'],
'base_repo_id': base['repo_id'],
'base_repository': base['repo']['clone_url'],
'base_git_ssh_url': base['repo']['ssh_url'],
2018-09-04 15:04:29 +02:00
'head_branch': head['ref'],
'head_sha': head['sha'],
'head_repo_id': head['repo_id'],
'head_repository': head['repo']['clone_url'],
'head_git_ssh_url': head['repo']['ssh_url'],
2018-09-04 15:04:29 +02:00
'pr_id': pull_request['id'],
'pr_number': pull_request['number'],
2018-09-27 14:46:35 +02:00
'repository_name': repository['name'],
'owner': repository["owner"]["username"],
2018-09-04 15:04:29 +02:00
},
}
if codebase is not None:
change['codebase'] = codebase
return [change]
def getChanges(self, request):
secret = None
if isinstance(self.options, dict):
2018-09-04 15:04:29 +02:00
secret = self.options.get('secret')
try:
content = request.content.read()
payload = json.loads(bytes2unicode(content))
except Exception as exception:
raise ValueError('Error loading JSON: ' + str(exception))
2018-09-04 15:04:29 +02:00
if secret is not None and secret != payload['secret']:
raise ValueError('Invalid secret')
event_type = bytes2unicode(request.getHeader(_HEADER_EVENT_TYPE))
2018-09-04 15:04:29 +02:00
log.msg("Received event '{}' from gitea".format(event_type))
2018-09-04 15:04:29 +02:00
codebases = request.args.get('codebase', [None])
codebase = bytes2unicode(codebases[0])
2018-09-04 15:04:29 +02:00
changes = []
if event_type == 'push':
changes = self.processPushEvent(
payload, event_type, codebase)
elif event_type == 'pull_request':
changes = self.processPullRequestEvent(
payload, event_type, codebase)
else:
log.msg("Ignoring gitea event '{}'".format(event_type))
return (changes, 'git')
# Plugin name
gitea = GiteaHandler