index : archinstall32 | |
Archlinux32 installer | gitolite user |
summaryrefslogtreecommitdiff |
author | Anton Hvornum <anton.feeds+github@gmail.com> | 2020-10-18 09:58:33 +0200 |
---|---|---|
committer | Anton Hvornum <anton.feeds+github@gmail.com> | 2020-10-18 09:58:33 +0200 |
commit | 1a10fe3f51f7555bf8c29046c707719d7dccb33c (patch) | |
tree | df39147ea4c5afeab1e9bc3a8f38321767634ba0 | |
parent | 60aaae4337c90bea3d485f58f7ab206cb1539a74 (diff) |
-rw-r--r-- | archinstall/lib/packages.py | 18 |
diff --git a/archinstall/lib/packages.py b/archinstall/lib/packages.py index 3a671784..29728abc 100644 --- a/archinstall/lib/packages.py +++ b/archinstall/lib/packages.py @@ -1,5 +1,6 @@ import urllib.request, urllib.parse import ssl, json +from .lib.exceptions import * BASE_URL = 'https://www.archlinux.org/packages/search/json/?name={package}' @@ -24,4 +25,19 @@ def find_packages(*names): result = {} for package in names: result[package] = find_package(package) - return result
\ No newline at end of file + return result + +def validate_package_list(packages :list): + """ + Validates a list of given packages. + Raises `RequirementError` if one or more packages are not found. + """ + invalid_packages = [] + for package in packages: + if not find_package(package)['results']: + invalid_packages.append(package) + + if invalid_packages: + raise RequirementError(f"Invalid package names: {invalid_packages}") + + return True
\ No newline at end of file |