This also includes a new `login` command. The signing and CI logic is now using the Driver trait system along with a new experimental sigstore signing driver. New static macros have also been created to make implementation management easier for `Command` usage and `Driver` trait implementation calls. --------- Co-authored-by: xyny <60004820+xynydev@users.noreply.github.com>
42 lines
1.5 KiB
Django/Jinja
42 lines
1.5 KiB
Django/Jinja
{%- import "modules/modules.j2" as modules -%}
|
|
{%- include "stages.j2" %}
|
|
|
|
# Main image
|
|
FROM {{ recipe.base_image }}:{{ recipe.image_version }} AS {{ recipe.name|replace('/', "-") }}
|
|
|
|
ARG RECIPE={{ recipe_path.display() }}
|
|
ARG IMAGE_REGISTRY={{ registry }}
|
|
|
|
{%- if self::files_dir_exists() %}
|
|
ARG CONFIG_DIRECTORY="/tmp/files"
|
|
{%- else if self::config_dir_exists() %}
|
|
ARG CONFIG_DIRECTORY="/tmp/config"
|
|
{%- endif %}
|
|
ARG MODULE_DIRECTORY="/tmp/modules"
|
|
ARG IMAGE_NAME="{{ recipe.name }}"
|
|
ARG BASE_IMAGE="{{ recipe.base_image }}"
|
|
|
|
# Key RUN
|
|
RUN --mount=type=bind,from=stage-keys,src=/keys,dst=/tmp/keys \
|
|
mkdir -p /etc/pki/containers/ \
|
|
mkdir -p /usr/etc/pki/containers/ \
|
|
&& cp /tmp/keys/* /etc/pki/containers/ \
|
|
&& cp /tmp/keys/* /usr/etc/pki/containers/ \
|
|
&& ostree container commit
|
|
|
|
# Bin RUN
|
|
RUN --mount=type=bind,from=stage-bins,src=/bins,dst=/tmp/bins \
|
|
mkdir -p /usr/bin/ \
|
|
&& cp /tmp/bins/* /usr/bin/ \
|
|
&& ostree container commit
|
|
|
|
{% call modules::main_modules_run(recipe.modules_ext, os_version) %}
|
|
|
|
RUN rm -fr /tmp/* /var/* && ostree container commit
|
|
|
|
# Labels are added last since they cause cache misses with buildah
|
|
LABEL {{ blue_build_utils::constants::BUILD_ID_LABEL }}="{{ build_id }}"
|
|
LABEL org.opencontainers.image.title="{{ recipe.name }}"
|
|
LABEL org.opencontainers.image.description="{{ recipe.description }}"
|
|
LABEL org.opencontainers.image.source="{{ repo }}"
|
|
LABEL io.artifacthub.package.readme-url=https://raw.githubusercontent.com/blue-build/cli/main/README.md
|