1
0
mirror of https://github.com/openSUSE/osc.git synced 2025-01-24 22:06:14 +01:00

rdelete: Migrate to pop_project_package_from_args()

This commit is contained in:
Daniel Mach 2023-01-02 16:25:55 +01:00
parent be2c33d86f
commit 5d31fc1486
2 changed files with 31 additions and 38 deletions

View File

@ -3811,51 +3811,26 @@ Please submit there instead, or use --nodevelproject to force direct submission.
well use \'--force\' switch.
usage:
osc rdelete [-r] [-f] PROJECT|. [PACKAGE]
osc rdelete [-r] [-f] PROJECT [PACKAGE]
"""
args = slash_split(args)
if len(args) < 1 or len(args) > 2:
raise oscerr.WrongArgs('Wrong number of arguments')
apiurl = self.get_api_url()
prj = self._process_project_name(args[0])
msg = ''
if opts.message:
msg = opts.message
else:
msg = edit_message()
args = list(args)
project, package = pop_project_package_from_args(
args, package_is_optional=True
)
ensure_no_remaining_args(args)
msg = opts.message or edit_message()
# empty arguments result in recursive project delete ...
if not prj:
if not project:
raise oscerr.WrongArgs('Project argument is empty')
if len(args) > 1:
pkg = args[1]
if not pkg:
raise oscerr.WrongArgs('Package argument is empty')
# FIXME: core.py:commitDelPackage() should have something similar
rlist = get_request_collection(apiurl, project=prj, package=pkg)
for rq in rlist:
print(rq)
if len(rlist) >= 1 and not opts.force:
print('Package has pending requests. Deleting the package will break them. '
'They should be accepted/declined/revoked before deleting the package. '
'Or just use \'--force\'.', file=sys.stderr)
sys.exit(1)
delete_package(apiurl, prj, pkg, opts.force, msg)
elif (not opts.recursive) and len(meta_get_packagelist(apiurl, prj)) >= 1:
print('Project contains packages. It must be empty before deleting it. '
'If you are sure that you want to remove this project and all its '
'packages use the \'--recursive\' switch.', file=sys.stderr)
sys.exit(1)
if package:
delete_package(apiurl, project, package, opts.force, msg)
else:
delete_project(apiurl, prj, opts.force, msg)
delete_project(apiurl, project, opts.force, msg, recursive=opts.recursive)
@cmdln.option('-m', '--message', metavar='TEXT',
help='specify log message TEXT')

View File

@ -6033,6 +6033,15 @@ def undelete_project(apiurl: str, prj: str, msg=None):
def delete_package(apiurl: str, prj: str, pac: str, force=False, msg=None):
if not force:
requests = get_request_collection(apiurl, project=prj, package=pac)
if requests:
error_msg = \
"Package has pending requests. Deleting the package will break them. " \
"They should be accepted/declined/revoked before deleting the package. " \
"Or just use the 'force' option"
raise oscerr.PackageError(prj, pac, error_msg)
query = {}
if force:
query['force'] = "1"
@ -6042,7 +6051,16 @@ def delete_package(apiurl: str, prj: str, pac: str, force=False, msg=None):
http_DELETE(u)
def delete_project(apiurl: str, prj: str, force=False, msg=None):
def delete_project(apiurl: str, prj: str, force=False, msg=None, recursive=False):
if not recursive:
packages = meta_get_packagelist(apiurl, project)
if packages:
error_msg = \
"Project contains packages. It must be empty before deleting it. " \
"If you are sure that you want to remove this project and all its " \
"packages use the 'recursive' option."
raise oscerr.ProjectError(prj, error_msg)
query = {}
if force:
query['force'] = "1"