1
0
mirror of https://github.com/openSUSE/osc.git synced 2025-11-26 14:39:50 +01:00

Add 'git-obs pr close' and 'git-obs pr reopen' commands

This commit is contained in:
2025-08-27 08:33:27 +02:00
parent 4f082a4618
commit de39324e35
3 changed files with 138 additions and 5 deletions

View File

@@ -0,0 +1,49 @@
import osc.commandline_git
class PullRequestCloseCommand(osc.commandline_git.GitObsCommand):
"""
Close pull requests
"""
name = "close"
parent = "PullRequestCommand"
def init_arguments(self):
self.add_argument(
"id",
nargs="+",
help="Pull request ID in <owner>/<repo>#<number> format",
)
self.add_argument(
"-m",
"--message",
help="Text of the comment",
)
def run(self, args):
from osc import gitea_api
self.print_gitea_settings()
pull_request_ids = args.id
for pr_index, pr_id in enumerate(pull_request_ids):
print(f"Closing {pr_id} ...")
owner, repo, number = gitea_api.PullRequest.split_id(pr_id)
gitea_api.PullRequest.close(
self.gitea_conn,
owner,
repo,
number,
)
if args.message:
gitea_api.PullRequest.add_comment(
self.gitea_conn,
owner,
repo,
number,
msg=args.message,
)

View File

@@ -0,0 +1,49 @@
import osc.commandline_git
class PullRequestReopenCommand(osc.commandline_git.GitObsCommand):
"""
Reopen pull requests
"""
name = "reopen"
parent = "PullRequestCommand"
def init_arguments(self):
self.add_argument(
"id",
nargs="+",
help="Pull request ID in <owner>/<repo>#<number> format",
)
self.add_argument(
"-m",
"--message",
help="Text of the comment",
)
def run(self, args):
from osc import gitea_api
self.print_gitea_settings()
pull_request_ids = args.id
for pr_index, pr_id in enumerate(pull_request_ids):
print(f"Reopening {pr_id} ...")
owner, repo, number = gitea_api.PullRequest.split_id(pr_id)
gitea_api.PullRequest.reopen(
self.gitea_conn,
owner,
repo,
number,
)
if args.message:
gitea_api.PullRequest.add_comment(
self.gitea_conn,
owner,
repo,
number,
msg=args.message,
)

View File

@@ -4,17 +4,14 @@ from typing import List
from typing import Optional
from typing import Tuple
from .common import GiteaModel
from .connection import Connection
from .connection import GiteaHTTPResponse
from .user import User
@functools.total_ordering
class PullRequest:
def __init__(self, data, *, response: Optional[GiteaHTTPResponse] = None):
self._data = data
self._response = response
class PullRequest(GiteaModel):
def __eq__(self, other):
(self.base_owner, self.base_repo, self.number) == (other.base_owner, other.base_repo, other.number)
@@ -558,3 +555,41 @@ class PullRequest:
# the error message is the same and it's not possible to distinguish between the two cases.
if e.status != 404:
raise
@classmethod
def close(
cls,
conn: Connection,
owner: str,
repo: str,
number: int,
) -> "PullRequest":
"""
Close a pull request.
"""
url = conn.makeurl("repos", owner, repo, "pulls", str(number))
json_data = {
"state": "closed",
}
response = conn.request("PATCH", url, json_data=json_data, context={"owner": owner, "repo": repo})
obj = cls(response.json(), response=response, conn=conn)
return obj
@classmethod
def reopen(
cls,
conn: Connection,
owner: str,
repo: str,
number: int,
) -> "PullRequest":
"""
Reopen a pull request.
"""
url = conn.makeurl("repos", owner, repo, "pulls", str(number))
json_data = {
"state": "open",
}
response = conn.request("PATCH", url, json_data=json_data, context={"owner": owner, "repo": repo})
obj = cls(response.json(), response=response, conn=conn)
return obj