let's break all the things! (use distros to generate repos)
Signed-off-by: InsanePrawn <insane.prawny@gmail.com>
This commit is contained in:
parent
becde79172
commit
f6678181b8
8 changed files with 129 additions and 37 deletions
126
distro.py
126
distro.py
|
@ -1,5 +1,5 @@
|
|||
from copy import deepcopy
|
||||
from constants import ARCHES, BASE_DISTROS
|
||||
from constants import ARCHES, BASE_DISTROS, REPOSITORIES, KUPFER_HTTPS
|
||||
from config import config
|
||||
|
||||
|
||||
|
@ -28,19 +28,28 @@ class PackageInfo:
|
|||
self.resolved_url = resolved_url
|
||||
|
||||
|
||||
class Repo:
|
||||
name: str
|
||||
class RepoInfo:
|
||||
options: dict[str, str] = {}
|
||||
url_template: str
|
||||
|
||||
def __init__(self, url_template: str, options: dict[str, str] = {}):
|
||||
self.url_template = url_template
|
||||
self.options.update(options)
|
||||
|
||||
|
||||
class Repo(RepoInfo):
|
||||
name: str
|
||||
resolved_url: str
|
||||
arch: str
|
||||
packages: dict[str, PackageInfo]
|
||||
options: dict[str, str]
|
||||
remote: bool
|
||||
scanned: bool = False
|
||||
|
||||
def scan(self):
|
||||
self.resolved_url = resolve_url(self.url_template, repo_name=self.repo_name, arch=self.arch)
|
||||
self.resolved_url = resolve_url(self.url_template, repo_name=self.name, arch=self.arch)
|
||||
self.remote = not self.resolved_url.startswith('file://')
|
||||
# TODO
|
||||
self.scanned = True
|
||||
|
||||
def __init__(self, name: str, url_template: str, arch: str, options={}, scan=True):
|
||||
self.name = name
|
||||
|
@ -54,14 +63,8 @@ class Repo:
|
|||
options = {'Server': self.url_template} | self.options.items()
|
||||
return ('[%s]\n' % self.name) + '\n'.join([f"{key} = {value}" for key, value in options])
|
||||
|
||||
|
||||
class RepoInfo:
|
||||
options: dict[str, str] = {}
|
||||
url_template: str
|
||||
|
||||
def __init__(self, url_template: str, options: dict[str, str] = {}):
|
||||
self.url_template = url_template
|
||||
self.options.update(options)
|
||||
def get_RepoInfo(self):
|
||||
return RepoInfo(url_template=self.url_template, options=self.options)
|
||||
|
||||
|
||||
class Distro:
|
||||
|
@ -89,11 +92,85 @@ class Distro:
|
|||
for package in repo.packages:
|
||||
results[package.name] = package
|
||||
|
||||
def config_snippet(self) -> str:
|
||||
return '\n'.join(repo.config_snippet() for repo in self.repos)
|
||||
def _repos_config_snippet(self, extra_repos: dict[str, RepoInfo] = {}) -> str:
|
||||
extras = [Repo(name, url_template=info.url_template, options=info.options, scan=False) for name, info in extra_repos.items()]
|
||||
return '\n'.join(repo.config_snippet() for repo in (self.repos.values + extras))
|
||||
|
||||
def get_pacman_conf(self, extra_repos: dict[str, RepoInfo] = []):
|
||||
header = f'''
|
||||
#
|
||||
# /etc/pacman.conf
|
||||
#
|
||||
# See the pacman.conf(5) manpage for option and repository directives
|
||||
|
||||
#
|
||||
# GENERAL OPTIONS
|
||||
#
|
||||
[options]
|
||||
# The following paths are commented out with their default values listed.
|
||||
# If you wish to use different paths, uncomment and update the paths.
|
||||
#RootDir = /
|
||||
#DBPath = /var/lib/pacman/
|
||||
#CacheDir = /var/cache/pacman/pkg/
|
||||
#LogFile = /var/log/pacman.log
|
||||
#GPGDir = /etc/pacman.d/gnupg/
|
||||
#HookDir = /etc/pacman.d/hooks/
|
||||
HoldPkg = pacman glibc
|
||||
#XferCommand = /usr/bin/curl -L -C - -f -o %o %u
|
||||
#XferCommand = /usr/bin/wget --passive-ftp -c -O %o %u
|
||||
#CleanMethod = KeepInstalled
|
||||
Architecture = {self.arch}
|
||||
|
||||
# Pacman won't upgrade packages listed in IgnorePkg and members of IgnoreGroup
|
||||
#IgnorePkg =
|
||||
#IgnoreGroup =
|
||||
|
||||
#NoUpgrade =
|
||||
#NoExtract =
|
||||
|
||||
# Misc options
|
||||
#UseSyslog
|
||||
Color
|
||||
#NoProgressBar
|
||||
CheckSpace
|
||||
VerbosePkgLists
|
||||
ParallelDownloads = 8
|
||||
|
||||
# By default, pacman accepts packages signed by keys that its local keyring
|
||||
# trusts (see pacman-key and its man page), as well as unsigned packages.
|
||||
SigLevel = Required DatabaseOptional
|
||||
LocalFileSigLevel = Optional
|
||||
#RemoteFileSigLevel = Required
|
||||
|
||||
# NOTE: You must run `pacman-key --init` before first using pacman; the local
|
||||
# keyring can then be populated with the keys of all official Arch Linux ARM
|
||||
# packagers with `pacman-key --populate archlinuxarm`.
|
||||
|
||||
#
|
||||
# REPOSITORIES
|
||||
# - can be defined here or included from another file
|
||||
# - pacman will search repositories in the order defined here
|
||||
# - local/custom mirrors can be added here or in separate files
|
||||
# - repositories listed first will take precedence when packages
|
||||
# have identical names, regardless of version number
|
||||
# - URLs will have $repo replaced by the name of the current repo
|
||||
# - URLs will have $arch replaced by the name of the architecture
|
||||
#
|
||||
# Repository entries are of the format:
|
||||
# [repo-name]
|
||||
# Server = ServerName
|
||||
# Include = IncludePath
|
||||
#
|
||||
# The header [repo-name] is crucial - it must be present and
|
||||
# uncommented to enable the repo.
|
||||
#
|
||||
|
||||
'''
|
||||
return header + self._repos_config_snippet(extra_repos)
|
||||
|
||||
|
||||
_base_distros: dict[str, Distro] = None
|
||||
_kupfer_distros: dict[str, Distro] = {}
|
||||
|
||||
|
||||
def get_base_distros() -> dict[str, Distro]:
|
||||
|
@ -105,3 +182,22 @@ def get_base_distros() -> dict[str, Distro]:
|
|||
_distros[arch] = Distro(arch=arch, repo_infos=repos, scan=False)
|
||||
_base_distros = _distros
|
||||
return _base_distros
|
||||
|
||||
|
||||
def get_kupfer(arch: str, url_template: str) -> Distro:
|
||||
global _kupfer_distros
|
||||
if arch not in _kupfer_distros:
|
||||
repos = {name: RepoInfo(url_template=url_template, options={'SigLevel': 'Never'}) for name in REPOSITORIES}
|
||||
_kupfer_distros[arch] = Distro(
|
||||
arch=arch,
|
||||
repo_infos=repos,
|
||||
)
|
||||
return _kupfer_distros[arch]
|
||||
|
||||
|
||||
def get_kupfer_https(arch: str) -> Distro:
|
||||
return get_kupfer(arch, KUPFER_HTTPS)
|
||||
|
||||
|
||||
def get_kupfer_local(arch: str) -> Distro:
|
||||
return get_kupfer(arch, f"file://{config.file['paths']['packages']}/$repo")
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue