Added support for packages outside of pkgmgr and git.

This commit is contained in:
antux18 2024-07-10 17:06:54 +02:00
parent 03c6602db3
commit 7dfe12ed80
3 changed files with 33 additions and 21 deletions

38
ecg.py
View File

@ -60,19 +60,19 @@ def download_sources(config):
Returns Returns
------- -------
tempdir: tempfile.TemporaryDirectory temp_dir: tempfile.TemporaryDirectory
The directory where the artifact is downloaded to. The directory where the artifact is downloaded to.
""" """
url = config["artifact_url"] url = config["artifact_url"]
logging.info(f"Downloading sources from {url}") logging.info(f"Downloading artifact from {url}")
temp_dir = tempfile.TemporaryDirectory() temp_dir = tempfile.TemporaryDirectory()
req = requests.get(url) req = requests.get(url)
if config["type"] == "zip": if config["type"] == "zip":
artefact = zipfile.ZipFile(io.BytesIO(req.content)) artifact = zipfile.ZipFile(io.BytesIO(req.content))
elif config["type"] == "tgz": elif config["type"] == "tgz":
artefact = tarfile.open(fileobj=io.BytesIO(req.content)) artifact = tarfile.open(fileobj=io.BytesIO(req.content))
artefact.extractall(temp_dir.name) logging.info(f"Extracting artifact at {temp_dir.name}")
logging.info(f"Extracting sources at {temp_dir.name}") artifact.extractall(temp_dir.name)
return temp_dir return temp_dir
def build_image(config, src_dir): def build_image(config, src_dir):
@ -98,10 +98,9 @@ def build_image(config, src_dir):
path = os.path.join(src_dir, config["location"]) path = os.path.join(src_dir, config["location"])
build_command = "docker build -t " + config["name"] + " ." build_command = "docker build -t " + config["name"] + " ."
# subprocess.check_call(config["build_command"].split(" "), cwd=path) # subprocess.check_call(config["build_command"].split(" "), cwd=path)
build_process = subprocess.run(build_command.split(" "), cwd=path, capture_output=True) build_process = subprocess.run(build_command.split(" "), cwd=path, capture_output=False)
return_code = build_process.returncode return_code = build_process.returncode
stderr = build_process.stderr logging.info(f"Command '{build_command}' exited with code {return_code}")
logging.info(f"Command {build_command} exited with code {return_code} ({stderr})")
return return_code == 0 return return_code == 0
def check_env(config, src_dir): def check_env(config, src_dir):
@ -129,17 +128,26 @@ def check_env(config, src_dir):
path = os.path.join(src_dir, config["location"]) path = os.path.join(src_dir, config["location"])
for pkgmgr in config["package_managers"]: for pkgmgr in config["package_managers"]:
logging.info(f"Checking '{pkgmgr}'") logging.info(f"Checking '{pkgmgr}'")
check_process = subprocess.run(["docker", "run", "--rm", config["name"]] + pkgmgr_cmd[pkgmgr][0].split(" "), cwd=path, capture_output=True) pkglist_process = subprocess.run(["docker", "run", "--rm", config["name"]] + pkgmgr_cmd[pkgmgr][0].split(" "), cwd=path, capture_output=True)
format_process = subprocess.run("cat << EOF | " + pkgmgr_cmd[pkgmgr][1] + "\n" + check_process.stdout.decode("utf-8") + "EOF", cwd=path, capture_output=True, shell=True) format_process = subprocess.run("cat << EOF | " + pkgmgr_cmd[pkgmgr][1] + "\n" + pkglist_process.stdout.decode("utf-8") + "EOF", cwd=path, capture_output=True, shell=True)
pkglist = format_process.stdout.decode("utf-8") pkglist = format_process.stdout.decode("utf-8")
pkglist_file.write(pkglist) pkglist_file.write(pkglist)
if "git_packages" in config.keys(): if "git_packages" in config.keys():
pkglist = ""
logging.info("Checking Git packages") logging.info("Checking Git packages")
for repo in config["git_packages"]: for repo in config["git_packages"]:
check_process = subprocess.run(["docker", "run", "--rm", "-w", repo["location"], config["name"]] + gitcmd.split(" "), cwd=path, capture_output=True) pkglist_process = subprocess.run(["docker", "run", "--rm", "-w", repo["location"], config["name"]] + gitcmd.split(" "), cwd=path, capture_output=True)
repo_row = repo["name"] + "," + check_process.stdout.decode("utf-8") + ",git" repo_row = repo["name"] + "," + pkglist_process.stdout.decode("utf-8") + ",git"
pkglist_file.write(repo_row) pkglist_file.write(repo_row + "\n")
if "misc_packages" in config.keys():
logging.info("Checking packages obtained outside of a package manager or VCS")
for pkg in config["misc_packages"]:
logging.info(f"Downloading package {pkg["name"]} from {pkg["url"]}")
req = requests.get(pkg["url"])
pkg_file = tempfile.NamedTemporaryFile()
pkg_file.write(req.content)
pkglist_process = subprocess.run("sha256sum " + pkg_file.name + " | cut -zd ' ' -f 1", cwd=path, capture_output=True, shell=True)
pkg_row = pkg["name"] + "," + pkglist_process.stdout.decode("utf-8") + ",misc"
pkglist_file.write(pkg_row + "\n")
pkglist_file.close() pkglist_file.close()
def remove_image(config): def remove_image(config):

View File

@ -8,8 +8,8 @@ dockerfiles:
- "dpkg" # Possible values: dpkg, rpm, pacman, pip, conda - "dpkg" # Possible values: dpkg, rpm, pacman, pip, conda
git_packages: git_packages:
- name: "pkg1" - name: "pkg1"
location: "path/to/git/package" location: "path/to/git/repo"
- name: "image2:version" misc_packages:
location: "path/to/docker/folder" - name: "mpkg1"
package_managers: url: "https://example.com/package1.zip"
- "dpkg" type: "zip" # Possible values: zip, tgz

View File

@ -10,3 +10,7 @@ dockerfiles:
git_packages: git_packages:
- name: "pkg1" - name: "pkg1"
location: "/pkg1" location: "/pkg1"
misc_packages:
- name: "mpkg1"
url: "http://localhost/package1.zip"
type: "zip"