diff --git a/pungi/dnf_wrapper.py b/pungi/dnf_wrapper.py index 798b2f8f..de12ed1e 100644 --- a/pungi/dnf_wrapper.py +++ b/pungi/dnf_wrapper.py @@ -52,7 +52,8 @@ class DnfWrapper(dnf.Base): self.arch_wrapper = ArchWrapper(self.conf.substitutions["arch"]) self.comps_wrapper = CompsWrapper(self) - def add_repo(self, repoid, baseurl=None, enablegroups=True, lookaside=False): + def add_repo(self, repoid, baseurl=None, enablegroups=True, lookaside=False, + **kwargs): self.repos.add_new_repo( repoid, self.conf, @@ -60,6 +61,7 @@ class DnfWrapper(dnf.Base): enabledgroups=enablegroups, priority=10 if lookaside else 20, module_hotfixes=True, + **kwargs ) diff --git a/pungi/scripts/pungi_gather.py b/pungi/scripts/pungi_gather.py index 2f02b0a7..bb6a6cfd 100644 --- a/pungi/scripts/pungi_gather.py +++ b/pungi/scripts/pungi_gather.py @@ -114,14 +114,25 @@ def main(ns, persistdir, cachedir): # handling in hawkey if ks_repo.name not in gather_opts.lookaside_repos: continue - dnf_obj.add_repo( - ks_repo.name, ks_repo.baseurl, enablegroups=False - ) + + if not ks_repo.metalink: + dnf_obj.add_repo( + ks_repo.name, ks_repo.baseurl, enablegroups=False + ) + else: + dnf_obj.add_repo( + ks_repo.name, ks_repo.baseurl, enablegroups=False, + metalink=ks_repo.metalink + ) for ks_repo in ksparser.handler.repo.repoList: if ks_repo.name in gather_opts.lookaside_repos: continue - dnf_obj.add_repo(ks_repo.name, ks_repo.baseurl) + if not ks_repo.metalink: + dnf_obj.add_repo(ks_repo.name, ks_repo.baseurl) + else: + dnf_obj.add_repo(ks_repo.name, ks_repo.baseurl, + metalink=ks_repo.metalink) with Profiler("DnfWrapper.fill_sack()"): dnf_obj.fill_sack(load_system_repo=False, load_available_repos=True)