forked from alt/image-forge
Compare commits
9 Commits
test_workf
...
coredns-do
| Author | SHA1 | Date | |
|---|---|---|---|
| 6bbd2c463f | |||
| 0d08c6f88f | |||
| a56bc4eb06 | |||
| 739b5d8eba | |||
| 941b8fb599 | |||
| aacaf22d79 | |||
|
|
2d5df6ea4c | ||
|
|
626b6feb4c | ||
|
|
69e7c13ea2 |
@@ -43,6 +43,17 @@ jobs:
|
||||
org=$(echo $EV | jq '.ref' -r | sed 's/refs\/tags\///g' | cut -d '_' -f 2)
|
||||
echo "ORG=$org" >> ${GITHUB_ENV}
|
||||
echo "ORG=$org"
|
||||
- name: Check out current repo
|
||||
uses: actions/checkout@v4
|
||||
- name: Change vendor label for c10f
|
||||
if: ${{ contains(github.ref_name, 'c10f') }}
|
||||
run: |
|
||||
echo "sed -i 's/ALT Linux Team/BaseALT LLC/g' ${{ gitea.workspace }}/org/$ORG/*/Dockerfile.template ||:"
|
||||
sed -i 's/ALT Linux Team/BaseALT LLC/g' ${{ gitea.workspace }}/org/$ORG/*/Dockerfile.template ||:
|
||||
echo "sed -i 's/ALT Linux Team/BaseALT LLC/g' ${{ gitea.workspace }}/org/$ORG/*/distroless.toml ||:"
|
||||
sed -i 's/ALT Linux Team/BaseALT LLC/g' ${{ gitea.workspace }}/org/$ORG/*/distroless.toml ||:
|
||||
env:
|
||||
ORG: ${{ env.ORG }}
|
||||
- name: Set repo for c10f2 (Temporary)
|
||||
if: ${{ contains(github.ref_name, 'c10f2') }}
|
||||
run: |
|
||||
@@ -50,8 +61,6 @@ jobs:
|
||||
echo "10.4.0.3 update.altsp.su" >> /etc/hosts
|
||||
echo "cat /etc/hosts"
|
||||
cat /etc/hosts
|
||||
- name: Check out current repo
|
||||
uses: actions/checkout@v4
|
||||
- name: Login podman gitea
|
||||
run: |
|
||||
echo "podman login ${{ env.URL }}"
|
||||
|
||||
@@ -43,6 +43,15 @@ jobs:
|
||||
apt-get install -y qemu-user-static-binfmt-aarch64 qemu-user-static-binfmt-arm qemu-user-static-binfmt-ppc qemu-user-static-binfmt-riscv qemu-user-static-binfmt-loongarch
|
||||
- name: Check out current repo
|
||||
uses: actions/checkout@v4
|
||||
- name: Change vendor label for c10f
|
||||
if: ${{ contains(github.ref_name, 'c10f') }}
|
||||
run: |
|
||||
echo "sed -i 's/ALT Linux Team/BaseALT LLC/g' ${{ gitea.workspace }}/org/$ORG/*/Dockerfile.template ||:"
|
||||
sed -i 's/ALT Linux Team/BaseALT LLC/g' ${{ gitea.workspace }}/org/$ORG/*/Dockerfile.template ||:
|
||||
echo "sed -i 's/ALT Linux Team/BaseALT LLC/g' ${{ gitea.workspace }}/org/$ORG/*/distroless.toml ||:"
|
||||
sed -i 's/ALT Linux Team/BaseALT LLC/g' ${{ gitea.workspace }}/org/$ORG/*/distroless.toml ||:
|
||||
env:
|
||||
ORG: ${{ env.ORG }}
|
||||
- name: Login podman gitea
|
||||
run: |
|
||||
echo "podman login ${{ env.URL }}"
|
||||
|
||||
11
README.md
11
README.md
@@ -86,7 +86,7 @@ source_packages:
|
||||
./build.py -i k8s/pause
|
||||
```
|
||||
|
||||
#### org/alt/etcd
|
||||
#### org/k8s/etcd
|
||||
|
||||
```yaml
|
||||
is_versioned: true
|
||||
@@ -95,16 +95,11 @@ version_template:
|
||||
- "{{ version }}"
|
||||
- "{{ version }}-0"
|
||||
source_packages:
|
||||
- >
|
||||
{% if branch in ["sisyphus", "p11"] %}
|
||||
{% raw %}etcd{{ version }}{% endraw %}
|
||||
{% else %}
|
||||
etcd
|
||||
{% endif %}
|
||||
- etcd-for-kubernetes{{ version }}
|
||||
```
|
||||
|
||||
```bash
|
||||
./build.py -b sisyphus -i alt/etcd --package-version '{"alt/etcd": "3.5.15"}'
|
||||
./build.py -b sisyphus -i k8s/etcd --package-version '{"k8s/etcd": "1.32"}'
|
||||
```
|
||||
|
||||
## Dependencies
|
||||
|
||||
26
build.py
26
build.py
@@ -11,6 +11,7 @@ from datetime import datetime
|
||||
from dataclasses import dataclass
|
||||
from graphlib import TopologicalSorter
|
||||
from pathlib import Path
|
||||
from typing import Optional, Union
|
||||
|
||||
import requests
|
||||
import tomli
|
||||
@@ -21,7 +22,7 @@ logger = logging.getLogger(__name__)
|
||||
|
||||
ORG_DIR = Path("org")
|
||||
|
||||
PKG_VERSIONS: dict | None = None
|
||||
PKG_VERSIONS: Optional[dict] = None
|
||||
|
||||
# Jinja2 custom fail filter
|
||||
def fail(message: str):
|
||||
@@ -33,9 +34,9 @@ JINJA_ENV.filters['fail'] = fail
|
||||
@dataclass
|
||||
class Image:
|
||||
canonical_name: str
|
||||
is_versioned: bool | None
|
||||
version_template: list[str] | str | None
|
||||
source_packages: list[str] | None
|
||||
is_versioned: Optional[bool]
|
||||
version_template: Union[list[str], str, None]
|
||||
source_packages: Optional[list[str]]
|
||||
|
||||
def __init__(self, canonical_name: str):
|
||||
self.canonical_name = canonical_name
|
||||
@@ -140,14 +141,14 @@ def api_get_source_package_version_from_task(task_id: str, package_name: str):
|
||||
|
||||
|
||||
class Tags:
|
||||
def __init__(self, tags_file: str | None, latest: str):
|
||||
def __init__(self, tags_file: Optional[str], latest: str):
|
||||
if tags_file is None:
|
||||
self._tags = None
|
||||
else:
|
||||
self._tags = tomli.loads(Path(tags_file).read_text())
|
||||
self._latest = latest
|
||||
|
||||
def tags(self, branch: str, image: Image, tasks: Tasks | None = None):
|
||||
def tags(self, branch: str, image: Image, tasks: Optional[Tasks] = None):
|
||||
if self._tags is None:
|
||||
if image.is_versioned is None:
|
||||
tags = [branch]
|
||||
@@ -157,9 +158,7 @@ class Tags:
|
||||
elif image.is_versioned and image.source_packages:
|
||||
package_name = image.source_packages[0]
|
||||
|
||||
if re.search("{%.*%}", package_name):
|
||||
package_name = JINJA_ENV.from_string(package_name).render(branch=branch).strip()
|
||||
|
||||
context_version = ""
|
||||
if re.search("{{.*}}", package_name):
|
||||
if PKG_VERSIONS is None:
|
||||
raise RuntimeError(
|
||||
@@ -176,8 +175,12 @@ class Tags:
|
||||
f"invalid version for image {image.canonical_name!r}: {PKG_VERSIONS[image.canonical_name]!r}"
|
||||
)
|
||||
|
||||
context_version = PKG_VERSIONS[image.canonical_name]
|
||||
|
||||
if re.search("{%.*%}", package_name) or re.search("{{.*}}", package_name):
|
||||
package_name = JINJA_ENV.from_string(package_name).render(
|
||||
version=PKG_VERSIONS[image.canonical_name]
|
||||
branch=branch,
|
||||
version=context_version,
|
||||
)
|
||||
|
||||
if tasks is not None:
|
||||
@@ -414,6 +417,7 @@ class DockerBuilder:
|
||||
install_packages=install_packages,
|
||||
organization=organization,
|
||||
registry=registry,
|
||||
pkg_versions=PKG_VERSIONS,
|
||||
**kwargs,
|
||||
)
|
||||
|
||||
@@ -662,7 +666,7 @@ class DockerBuilder:
|
||||
build_arches = set(arches) - set(
|
||||
self.images_info.skip_arches(image.canonical_name)
|
||||
)
|
||||
tags = self.tags.tags(self.branch, image)
|
||||
tags = self.tags.tags(self.branch, image, self.tasks)
|
||||
manifest = self.render_full_tag(image, tags[0])
|
||||
|
||||
msg = "Building image {} for {} arches".format(
|
||||
|
||||
@@ -8,7 +8,16 @@ LABEL org.opencontainers.image.source="https://github.com/coredns/coredns"
|
||||
LABEL org.opencontainers.image.licenses="Apache-2.0"
|
||||
LABEL org.opencontainers.image.vendor="ALT Linux Team"
|
||||
|
||||
{% if branch in ["sisyphus", "p11", "c10f2"] %}
|
||||
{% if pkg_versions and "k8s/coredns" in pkg_versions %}
|
||||
{% set version_parts = pkg_versions["k8s/coredns"].split('.') | length %}
|
||||
{% else %}
|
||||
{% set version_parts = 0 %}
|
||||
{% endif %}
|
||||
{% if branch in ["sisyphus"] and version_parts == 2 %}
|
||||
ARG PKG_VERSION
|
||||
|
||||
{{ install_packages("coredns-for-kubernetes${PKG_VERSION}") }}
|
||||
{% elif branch in ["sisyphus", "p11", "c10f2"] and version_parts == 3 %}
|
||||
ARG PKG_VERSION
|
||||
|
||||
{{ install_packages("coredns${PKG_VERSION}") }}
|
||||
|
||||
@@ -3,9 +3,13 @@ is_versioned: true
|
||||
version_template: v{{ version }}
|
||||
source_packages:
|
||||
- >
|
||||
{% if branch in ["sisyphus", "p11", "c10f2"] %}
|
||||
{% raw %}coredns{{ version }}{% endraw %}
|
||||
{% else %}
|
||||
{%- set version_parts = version.split('.') -%}
|
||||
{%- set version_major = version_parts[1] | int -%}
|
||||
{%- if branch in ["sisyphus"] and version_parts | length == 2 and version_major >= 33 -%}
|
||||
coredns-for-kubernetes{{ version }}
|
||||
{%- elif branch in ["sisyphus", "p11", "c10f2"] -%}
|
||||
coredns{{ version }}
|
||||
{%- else -%}
|
||||
coredns
|
||||
{% endif %}
|
||||
{%- endif -%}
|
||||
...
|
||||
|
||||
21
org/k8s/etcd/Dockerfile.template
Normal file
21
org/k8s/etcd/Dockerfile.template
Normal file
@@ -0,0 +1,21 @@
|
||||
FROM {{ registry }}{{ branch }}/{{ alt_image }}:latest
|
||||
|
||||
MAINTAINER alt-cloud
|
||||
|
||||
LABEL org.opencontainers.image.title="etcd"
|
||||
LABEL org.opencontainers.image.description="Distributed reliable key-value store for the most critical data of a distributed system"
|
||||
LABEL org.opencontainers.image.source="https://github.com/etcd-io/etcd"
|
||||
LABEL org.opencontainers.image.licenses="Apache-2.0"
|
||||
LABEL org.opencontainers.image.vendor="ALT Linux Team"
|
||||
|
||||
ARG PKG_VERSION
|
||||
|
||||
{{ install_packages("etcd-for-kubernetes${PKG_VERSION}") }}
|
||||
|
||||
RUN ln -s /usr/sbin/etcd /usr/local/bin/etcd && ln -s /usr/bin/etcdctl /usr/local/bin/etcdctl
|
||||
|
||||
EXPOSE 2379 2380
|
||||
|
||||
VOLUME /data
|
||||
|
||||
ENTRYPOINT ["/usr/sbin/etcd", "--data-dir", "/data"]
|
||||
19
org/k8s/etcd/README.md
Normal file
19
org/k8s/etcd/README.md
Normal file
@@ -0,0 +1,19 @@
|
||||
dockerfiles-alt-etcd
|
||||
=========================
|
||||
|
||||
ALT dockerfile for etcd.
|
||||
|
||||
Copy Dockerfile somewhere and build the image:
|
||||
```console
|
||||
$ podman build --rm -t <username>/etcd.
|
||||
```
|
||||
|
||||
And launch the etcd container:
|
||||
```console
|
||||
$ podman run -d -v <etcd data dir>:/data <username>/etcd
|
||||
```
|
||||
|
||||
If etcdclt is wanted, it could be run via:
|
||||
```console
|
||||
$ podman run --entrypoint etcdctl <username>/etcd
|
||||
```
|
||||
9
org/k8s/etcd/info.yaml
Normal file
9
org/k8s/etcd/info.yaml
Normal file
@@ -0,0 +1,9 @@
|
||||
---
|
||||
is_versioned: true
|
||||
version_template:
|
||||
- "v{{ version }}"
|
||||
- "{{ version }}"
|
||||
- "{{ version }}-0"
|
||||
source_packages:
|
||||
- etcd-for-kubernetes{{ version }}
|
||||
...
|
||||
1
org/k8s/etcd/test
Normal file
1
org/k8s/etcd/test
Normal file
@@ -0,0 +1 @@
|
||||
etcd --version && etcdctl --version
|
||||
Reference in New Issue
Block a user