Skip to content

Commit

Permalink
backend, frontend: implement support for Pulp manual createrepo
Browse files Browse the repository at this point in the history
Fix #3498
  • Loading branch information
FrostyX committed Dec 6, 2024
1 parent ed088ee commit 883af5b
Show file tree
Hide file tree
Showing 3 changed files with 59 additions and 6 deletions.
22 changes: 22 additions & 0 deletions backend/copr_backend/pulp.py
Original file line number Diff line number Diff line change
Expand Up @@ -187,6 +187,19 @@ def delete_content(self, repository, artifacts):
data = {"remove_content_units": artifacts}
return requests.post(url, json=data, **self.request_params)

def copy_content(self, repository, repository_version, units):

Check warning

Code scanning / vcs-diff-lint

PulpClient.copy_content: Unused argument 'repository_version' Warning

PulpClient.copy_content: Unused argument 'repository_version'
"""
Copy a list of content units (RPM packages) into this repository
The "copy" isn't the right word because the actual data isn't touched
at all. Only a new database entry pointing to the data is created.
So regardless of the number of units, this operation should be fast.
https://pulpproject.org/pulp_rpm/restapi/#tag/Repositories:-Rpm/operation/repositories_rpm_rpm_modify
"""
path = os.path.join(repository, "modify/")
url = self.config["base_url"] + path
data = {"add_content_units": units}
return requests.post(url, json=data, **self.request_params)

def delete_repository(self, repository):
"""
Delete an RPM repository
Expand Down Expand Up @@ -229,3 +242,12 @@ def list_distributions(self, prefix):
url = self.url("api/v3/distributions/rpm/rpm/?")
url += urlencode({"name__startswith": prefix})
return requests.get(url, **self.request_params)

def list_packages(self, repository_version):
"""
Get a list of RPM packages provided by a given repository
https://pulpproject.org/pulp_rpm/restapi/#tag/Content:-Advisories/operation/content_rpm_advisories_list
"""
url = self.url("api/v3/content/rpm/packages/?")
url += urlencode({"repository_version": repository_version})
return requests.get(url, **self.request_params)
37 changes: 33 additions & 4 deletions backend/copr_backend/storage.py
Original file line number Diff line number Diff line change
Expand Up @@ -200,8 +200,37 @@ def init_project(self, dirname, chroot):
distribution, response.text)
return False

# TODO Move this somewhere else
devel_repository_name = "/".join([
self.owner,
dirname or self.project,
chroot + "_devel",
])
response = self.client.get_repository(devel_repository_name)
results = response.json()["results"]

if not self.devel and results:
devel_repository = results[0]
devel_repository_version = devel_repository["latest_version_href"]
response = self.client.list_packages(devel_repository_version)
hrefs = [x["pulp_href"] for x in response.json()["results"]]
response = self.client.copy_content(repository, None, hrefs)
if not response.ok:
self.log.error(
"Failed to copy packages into the %s repository: %s",
repository, hrefs,
)
return False
# <------ The ^^ code should be in a separate function

response = self.client.create_publication(repository)
return response.ok
if not response.ok:
self.log.error(
"Failed to create a Pulp publication for %s because of %s",
repository, response.text,
)
return False
return True

def upload_build_results(self, chroot, results_dir, target_dir_name):
resources = []
Expand Down Expand Up @@ -343,16 +372,16 @@ def delete_builds(self, dirname, chroot_builddirs, build_ids):
return result

def _repository_name(self, chroot, dirname=None):
# On backend we use /devel but Pulp has a problem with that
suffix = "_devel" if self.devel else ""
return "/".join([
self.owner,
dirname or self.project,
chroot,
chroot + suffix,
])

def _distribution_name(self, chroot):
repository = self._repository_name(chroot)
if self.devel:
return "{0}-devel".format(repository)
return repository

def _get_repository(self, chroot):
Expand Down
6 changes: 4 additions & 2 deletions frontend/coprs_frontend/coprs/logic/complex_logic.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
import flask
import sqlalchemy

from copr_common.enums import StatusEnum
from copr_common.enums import StatusEnum, StorageEnum
from coprs import app
from coprs import db
from coprs import helpers
Expand Down Expand Up @@ -610,9 +610,11 @@ def generate_build_config(cls, copr, chroot_id):
repos[0]["module_hotfixes"] = True

if not copr.auto_createrepo:
suffix = "_devel" if copr.storage == StorageEnum.pulp else "/devel"
baseurl = copr.repo_url + "/{0}{1}/".format(chroot_id, suffix)
repos.append({
"id": "copr_base_devel",
"baseurl": copr.repo_url + "/{}/devel/".format(chroot_id),
"baseurl": baseurl,
"name": "Copr buildroot",
})

Expand Down

0 comments on commit 883af5b

Please sign in to comment.