1
0
mirror of https://github.com/openSUSE/osc.git synced 2025-01-01 04:36:13 +01:00

Migrate core.create_submit_request() to obs_api.Request

This commit is contained in:
Daniel Mach 2024-03-01 20:34:06 +01:00
parent 9078bc257c
commit d768eff371
2 changed files with 51 additions and 45 deletions

View File

@ -4634,53 +4634,37 @@ def create_submit_request(
src_package: Optional[str] = None, src_package: Optional[str] = None,
dst_project: Optional[str] = None, dst_project: Optional[str] = None,
dst_package: Optional[str] = None, dst_package: Optional[str] = None,
message="", message: str = "",
orev=None, orev: Optional[str] = None,
src_update=None, src_update: Optional[str] = None,
dst_updatelink=None, dst_updatelink: Optional[bool] = None,
): ):
options_block = "" from . import obs_api
package = ""
if src_package:
package = f"""package="{src_package}" """
options_block = "<options>"
if src_update:
options_block += f"""<sourceupdate>{src_update}</sourceupdate>"""
if dst_updatelink:
options_block += """<updatelink>true</updatelink>"""
options_block += "</options>"
# Yes, this kind of xml construction is horrible req = obs_api.Request(
targetxml = "" action_list=[
if dst_project: {
packagexml = "" "type": "submit",
if dst_package: "source": {
packagexml = f"""package="{dst_package}" """ "project": src_project,
targetxml = f"""<target project="{dst_project}" {packagexml} /> """ "package": src_package,
# XXX: keep the old template for now in order to work with old obs instances "rev": orev or show_upstream_rev(apiurl, src_project, src_package),
xml = """\ },
<request> "target": {
<action type="submit"> "project": dst_project,
<source project="%s" %s rev="%s"/> "package": dst_package,
%s },
%s "options": {
</action> "sourceupdate": src_update,
<state name="new"/> "updatelink": "true" if dst_updatelink else None,
<description>%s</description> }
</request> },
""" % (src_project, ],
package, description=message,
orev or show_upstream_rev(apiurl, src_project, src_package), )
targetxml,
options_block,
_html_escape(message))
u = makeurl(apiurl, ["request"], query={"cmd": "create"})
r = None
try: try:
f = http_POST(u, data=xml) new_req = req.cmd_create(apiurl)
root = ET.parse(f).getroot()
r = root.get('id')
except HTTPError as e: except HTTPError as e:
if e.hdrs.get('X-Opensuse-Errorcode') == "submit_request_rejected": if e.hdrs.get('X-Opensuse-Errorcode') == "submit_request_rejected":
print('WARNING: As the project is in maintenance, a maintenance incident request is') print('WARNING: As the project is in maintenance, a maintenance incident request is')
@ -4700,11 +4684,11 @@ def create_submit_request(
raise oscerr.APIError("Server did not define a default maintenance project, can't submit.") raise oscerr.APIError("Server did not define a default maintenance project, can't submit.")
tproject = project.get('name') tproject = project.get('name')
r = create_maintenance_request(apiurl, src_project, [src_package], tproject, dst_project, src_update, message, rev=orev) r = create_maintenance_request(apiurl, src_project, [src_package], tproject, dst_project, src_update, message, rev=orev)
r = r.reqid return r.reqid
else: else:
raise raise
return r return new_req.id
def get_request(apiurl: str, reqid): def get_request(apiurl: str, reqid):

View File

@ -116,3 +116,25 @@ class Request(XmlModel):
for issue in action.sourcediff.issue_list or []: for issue in action.sourcediff.issue_list or []:
result.append(issue) result.append(issue)
return result return result
def cmd_create(self,
apiurl: str,
*,
add_revision: Optional[bool] = None,
enforce_branching: Optional[bool] = None,
ignore_build_state: Optional[bool] = None,
ignore_delegate: Optional[bool] = None,
):
"""
:param add_revision: Ask the server to add revisions of the current sources to the request.
:param ignore_build_state: Skip the build state check.
:param ignore_delegate: Enforce a new package instance in a project which has OBS:DelegateRequestTarget set.
"""
url_path = ["request"]
url_query = {
"cmd": "create",
"addrevision": add_revision,
"ignore_delegate": ignore_delegate,
}
response = self.xml_request("POST", apiurl, url_path, url_query, data=self.to_string())
return Request.from_file(response, apiurl=apiurl)