pullrequest.py
212 lines
| 7.5 KiB
| text/x-python
|
PythonLexer
r5608 | # Copyright (C) 2016-2024 RhodeCode GmbH | |||
r378 | # | |||
# This program is free software: you can redistribute it and/or modify | ||||
# it under the terms of the GNU Affero General Public License, version 3 | ||||
# (only), as published by the Free Software Foundation. | ||||
# | ||||
# This program is distributed in the hope that it will be useful, | ||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||||
# GNU General Public License for more details. | ||||
# | ||||
# You should have received a copy of the GNU Affero General Public License | ||||
# along with this program. If not, see <http://www.gnu.org/licenses/>. | ||||
# | ||||
# This program is dual-licensed. If you wish to learn more about the | ||||
# RhodeCode Enterprise Edition, including its added features, Support services, | ||||
# and proprietary license terms, please see https://rhodecode.com/licenses/ | ||||
r1424 | import logging | |||
r379 | ||||
r411 | from rhodecode.translation import lazy_ugettext | |||
r5623 | from rhodecode.events.repo import RepoEvent, _commits_as_dict, _issues_as_dict | |||
r378 | ||||
r1424 | log = logging.getLogger(__name__) | |||
r378 | ||||
class PullRequestEvent(RepoEvent): | ||||
""" | ||||
r379 | Base class for pull request events. | |||
r378 | ||||
r379 | :param pullrequest: a :class:`PullRequest` instance | |||
r378 | """ | |||
r5623 | ||||
name = "pullrequest-event" | ||||
display_name = lazy_ugettext("pullrequest generic event") | ||||
description = lazy_ugettext("All events within a context of a pull request") | ||||
r379 | ||||
r5623 | def __init__(self, pullrequest, context=None): | |||
super().__init__(pullrequest.target_repo, context=context) | ||||
r378 | self.pullrequest = pullrequest | |||
r5623 | self.context = self._context | |||
r378 | ||||
r411 | def as_dict(self): | |||
r2588 | from rhodecode.lib.utils2 import md5_safe | |||
r411 | from rhodecode.model.pull_request import PullRequestModel | |||
r5623 | ||||
r5095 | data = super().as_dict() | |||
r411 | ||||
r5623 | commits = _commits_as_dict(self, commit_ids=self.pullrequest.revisions, repos=[self.pullrequest.source_repo]) | |||
r514 | issues = _issues_as_dict(commits) | |||
r2588 | # calculate hashes of all commits for unique identifier of commits | |||
# inside that pull request | ||||
r5623 | commits_hash = md5_safe(":".join(x.get("raw_id", "") for x in commits)) | |||
r411 | ||||
r5623 | data.update( | |||
{ | ||||
"pullrequest": { | ||||
"title": self.pullrequest.title, | ||||
"issues": issues, | ||||
"pull_request_id": self.pullrequest.pull_request_id, | ||||
"url": PullRequestModel().get_url(self.pullrequest, request=self.request), | ||||
"permalink_url": PullRequestModel().get_url(self.pullrequest, request=self.request, permalink=True), | ||||
"shadow_url": PullRequestModel().get_shadow_clone_url(self.pullrequest, request=self.request), | ||||
"status": self.pullrequest.calculated_review_status(), | ||||
"commits_uid": commits_hash, | ||||
"commits": commits, | ||||
}, | ||||
"context": self.context, | ||||
r411 | } | |||
r5623 | ) | |||
r411 | return data | |||
r378 | ||||
class PullRequestCreateEvent(PullRequestEvent): | ||||
""" | ||||
An instance of this class is emitted as an :term:`event` after a pull | ||||
request is created. | ||||
""" | ||||
r5623 | ||||
name = "pullrequest-create" | ||||
display_name = lazy_ugettext("pullrequest created") | ||||
description = lazy_ugettext("Event triggered after pull request was created") | ||||
r378 | ||||
class PullRequestCloseEvent(PullRequestEvent): | ||||
""" | ||||
An instance of this class is emitted as an :term:`event` after a pull | ||||
request is closed. | ||||
""" | ||||
r5623 | ||||
name = "pullrequest-close" | ||||
display_name = lazy_ugettext("pullrequest closed") | ||||
description = lazy_ugettext("Event triggered after pull request was closed") | ||||
r378 | ||||
class PullRequestUpdateEvent(PullRequestEvent): | ||||
""" | ||||
An instance of this class is emitted as an :term:`event` after a pull | ||||
r443 | request's commits have been updated. | |||
r378 | """ | |||
r5623 | ||||
name = "pullrequest-update" | ||||
display_name = lazy_ugettext("pullrequest commits updated") | ||||
description = lazy_ugettext("Event triggered after pull requests was updated") | ||||
r443 | ||||
class PullRequestReviewEvent(PullRequestEvent): | ||||
""" | ||||
An instance of this class is emitted as an :term:`event` after a pull | ||||
r3415 | request review has changed. A status defines new status of review. | |||
r443 | """ | |||
r378 | ||||
r5623 | name = "pullrequest-review" | |||
display_name = lazy_ugettext("pullrequest review changed") | ||||
description = lazy_ugettext("Event triggered after a review status of a pull requests has changed to other.") | ||||
def __init__(self, pullrequest, status, context=None): | ||||
super().__init__(pullrequest, context=context) | ||||
r3415 | self.status = status | |||
r378 | ||||
class PullRequestMergeEvent(PullRequestEvent): | ||||
""" | ||||
An instance of this class is emitted as an :term:`event` after a pull | ||||
request is merged. | ||||
""" | ||||
r5623 | ||||
name = "pullrequest-merge" | ||||
display_name = lazy_ugettext("pullrequest merged") | ||||
description = lazy_ugettext("Event triggered after a successful merge operation was executed on a pull request") | ||||
r378 | ||||
r443 | class PullRequestCommentEvent(PullRequestEvent): | |||
r378 | """ | |||
An instance of this class is emitted as an :term:`event` after a pull | ||||
r443 | request comment is created. | |||
r378 | """ | |||
r443 | ||||
r5623 | name = "pullrequest-comment" | |||
display_name = lazy_ugettext("pullrequest commented") | ||||
description = lazy_ugettext("Event triggered after a comment was made on a code in the pull request") | ||||
def __init__(self, pullrequest, comment, context=None): | ||||
super().__init__(pullrequest, context=context) | ||||
r443 | self.comment = comment | |||
def as_dict(self): | ||||
r1323 | from rhodecode.model.comment import CommentsModel | |||
r5623 | ||||
r5095 | data = super().as_dict() | |||
r378 | ||||
r443 | status = None | |||
if self.comment.status_change: | ||||
r4490 | status = self.comment.review_status | |||
r378 | ||||
r5623 | data.update( | |||
{ | ||||
"comment": { | ||||
"status": status, | ||||
"text": self.comment.text, | ||||
"type": self.comment.comment_type, | ||||
"file": self.comment.f_path, | ||||
"line": self.comment.line_no, | ||||
"version": self.comment.last_version, | ||||
"url": CommentsModel().get_url(self.comment, request=self.request), | ||||
"permalink_url": CommentsModel().get_url(self.comment, request=self.request, permalink=True), | ||||
}, | ||||
"context": self.context, | ||||
r443 | } | |||
r5623 | ) | |||
r443 | return data | |||
r4444 | ||||
class PullRequestCommentEditEvent(PullRequestEvent): | ||||
""" | ||||
An instance of this class is emitted as an :term:`event` after a pull | ||||
request comment is edited. | ||||
""" | ||||
r5623 | ||||
name = "pullrequest-comment-edit" | ||||
display_name = lazy_ugettext("pullrequest comment edited") | ||||
description = lazy_ugettext("Event triggered after a comment was edited on a code in the pull request") | ||||
r4444 | ||||
def __init__(self, pullrequest, comment): | ||||
r5095 | super().__init__(pullrequest) | |||
r4444 | self.comment = comment | |||
def as_dict(self): | ||||
from rhodecode.model.comment import CommentsModel | ||||
r5623 | ||||
r5095 | data = super().as_dict() | |||
r4444 | ||||
status = None | ||||
if self.comment.status_change: | ||||
r4490 | status = self.comment.review_status | |||
r4444 | ||||
r5623 | data.update( | |||
{ | ||||
"comment": { | ||||
"status": status, | ||||
"text": self.comment.text, | ||||
"type": self.comment.comment_type, | ||||
"file": self.comment.f_path, | ||||
"line": self.comment.line_no, | ||||
"version": self.comment.last_version, | ||||
"url": CommentsModel().get_url(self.comment, request=self.request), | ||||
"permalink_url": CommentsModel().get_url(self.comment, request=self.request, permalink=True), | ||||
}, | ||||
"context": self.context | ||||
r4444 | } | |||
r5623 | ) | |||
r4444 | return data | |||