forked from alt/image-forge
Compare commits
14 Commits
test_workf
...
master
Author | SHA1 | Date | |
---|---|---|---|
cb91ecc9f6 | |||
761fda61c1 | |||
6cbde103dd | |||
14c787b0db | |||
d161930947 | |||
0c426721dd | |||
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)
|
org=$(echo $EV | jq '.ref' -r | sed 's/refs\/tags\///g' | cut -d '_' -f 2)
|
||||||
echo "ORG=$org" >> ${GITHUB_ENV}
|
echo "ORG=$org" >> ${GITHUB_ENV}
|
||||||
echo "ORG=$org"
|
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)
|
- name: Set repo for c10f2 (Temporary)
|
||||||
if: ${{ contains(github.ref_name, 'c10f2') }}
|
if: ${{ contains(github.ref_name, 'c10f2') }}
|
||||||
run: |
|
run: |
|
||||||
@ -50,8 +61,6 @@ jobs:
|
|||||||
echo "10.4.0.3 update.altsp.su" >> /etc/hosts
|
echo "10.4.0.3 update.altsp.su" >> /etc/hosts
|
||||||
echo "cat /etc/hosts"
|
echo "cat /etc/hosts"
|
||||||
cat /etc/hosts
|
cat /etc/hosts
|
||||||
- name: Check out current repo
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
- name: Login podman gitea
|
- name: Login podman gitea
|
||||||
run: |
|
run: |
|
||||||
echo "podman login ${{ env.URL }}"
|
echo "podman login ${{ env.URL }}"
|
||||||
|
155
.gitea/workflows/wf_multiple.yaml
Normal file
155
.gitea/workflows/wf_multiple.yaml
Normal file
@ -0,0 +1,155 @@
|
|||||||
|
name: Building alt images
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
tags:
|
||||||
|
- '**'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build-process:
|
||||||
|
runs-on: alt-sisyphus
|
||||||
|
outputs:
|
||||||
|
branch: ${{ env.BRANCH }}
|
||||||
|
image: ${{ env.IMAGE }}
|
||||||
|
url: ${{ env.URL }}
|
||||||
|
repo: ${{ env.REPO }}
|
||||||
|
buildres: ${{ steps.build-script.outcome }}
|
||||||
|
test: ${{ env.TEST }}
|
||||||
|
steps:
|
||||||
|
- name: Check workspace
|
||||||
|
run: |
|
||||||
|
repourl=$(echo $GU | cut -d '/' -f 3)
|
||||||
|
echo "URL=$repourl" >> ${GITHUB_ENV}
|
||||||
|
echo "URL=$repourl"
|
||||||
|
reponame=$(echo $GR | cut -d '/' -f 1)
|
||||||
|
echo "REPO=$reponame" >> ${GITHUB_ENV}
|
||||||
|
echo "REPO=$reponame"
|
||||||
|
env:
|
||||||
|
GU: ${{ gitea.server_url }}
|
||||||
|
GR: ${{ gitea.repository }}
|
||||||
|
- name: Set repo for c10f2 (Temporary)
|
||||||
|
if: ${{ contains(github.ref_name, 'c10f2') }}
|
||||||
|
run: |
|
||||||
|
echo "event tag=${{ github.ref_name }}"
|
||||||
|
echo "10.4.0.3 update.altsp.su" >> /etc/hosts
|
||||||
|
echo "cat /etc/hosts"
|
||||||
|
cat /etc/hosts
|
||||||
|
- name: Update apt
|
||||||
|
uses: actions/init-alt-env@v1
|
||||||
|
- name: Install requires
|
||||||
|
run: |
|
||||||
|
echo "apt-get install -y python3-module-tomli python3-module-jinja2 python3-module-yaml python3-module-requests podman buildah jq curl"
|
||||||
|
apt-get install -y python3-module-tomli python3-module-jinja2 python3-module-yaml python3-module-requests podman buildah jq curl
|
||||||
|
echo "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"
|
||||||
|
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: Login podman gitea
|
||||||
|
run: |
|
||||||
|
echo "podman login ${{ env.URL }}"
|
||||||
|
podman login --username $P_USER --password $P_PASS ${{ env.URL }}
|
||||||
|
env:
|
||||||
|
P_USER: ${{ secrets.PODMAN_USER }}
|
||||||
|
P_PASS: ${{ secrets.PODMAN_PASS }}
|
||||||
|
- name: Check files in the repository
|
||||||
|
run: |
|
||||||
|
ls -a ${{ gitea.workspace }}
|
||||||
|
- name: Parse target branch and tag from events context, save to env
|
||||||
|
env:
|
||||||
|
EV: ${{ toJson(gitea.event) }}
|
||||||
|
run: |
|
||||||
|
branch="$(echo $EV | jq '.ref' -r | sed "s|refs/tags/||g" | cut -d '_' -f 1)"
|
||||||
|
echo "BRANCH=$branch"
|
||||||
|
|
||||||
|
rest="$(echo $EV | jq '.ref' -r | sed "s|refs/tags/||g" | cut -d '_' -f 2-)"
|
||||||
|
IFS='_' read -ra parts <<< "$rest"
|
||||||
|
|
||||||
|
images=()
|
||||||
|
declare -A versions
|
||||||
|
|
||||||
|
for part in "${parts[@]}"; do
|
||||||
|
if [[ "$part" == *@* ]]; then
|
||||||
|
image="${part%@*}"
|
||||||
|
version="${part#*@}"
|
||||||
|
images+=("$image")
|
||||||
|
versions["$image"]="$version"
|
||||||
|
else
|
||||||
|
image="$part"
|
||||||
|
images+=("$image")
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
image_args="${images[*]}"
|
||||||
|
|
||||||
|
package_versions="{"
|
||||||
|
first=1
|
||||||
|
for image in "${!versions[@]}"; do
|
||||||
|
[[ $first -eq 0 ]] && package_versions+=","
|
||||||
|
package_versions+="\"$image\": \"${versions[$image]}\""
|
||||||
|
first=0
|
||||||
|
done
|
||||||
|
package_versions+="}"
|
||||||
|
|
||||||
|
echo "IMAGES=$image_args"
|
||||||
|
echo "PACKAGE_VERSIONS=$package_versions"
|
||||||
|
|
||||||
|
echo "BRANCH=$branch" >> ${GITHUB_ENV}
|
||||||
|
echo "IMAGES=$image_args" >> $GITHUB_ENV
|
||||||
|
echo "PACKAGE_VERSIONS=$package_versions" >> $GITHUB_ENV
|
||||||
|
- 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: Run building script
|
||||||
|
id: build-script
|
||||||
|
run: |
|
||||||
|
echo "${{ gitea.workspace }}/build.py \
|
||||||
|
--log-level debug \
|
||||||
|
--skip-stages push \
|
||||||
|
--branch $BRANCH \
|
||||||
|
--registry gitea.basealt.ru/alt \
|
||||||
|
--arches amd64 \
|
||||||
|
-i $IMAGES \
|
||||||
|
--package-versions \"$PACKAGE_VERSIONS\""
|
||||||
|
|
||||||
|
${{ gitea.workspace }}/build.py \
|
||||||
|
--log-level debug \
|
||||||
|
--skip-stages push \
|
||||||
|
--branch $BRANCH \
|
||||||
|
--registry gitea.basealt.ru/alt \
|
||||||
|
--arches amd64 \
|
||||||
|
-i $IMAGES \
|
||||||
|
--package-versions "$PACKAGE_VERSIONS"
|
||||||
|
env:
|
||||||
|
BRANCH: ${{ env.BRANCH }}
|
||||||
|
IMAGES: ${{ env.IMAGES }}
|
||||||
|
PACKAGE_VERSIONS: ${{ env.PACKAGE_VERSIONS }}
|
||||||
|
continue-on-error: true
|
||||||
|
# - name: Send notification if build crashed
|
||||||
|
# if: ${{ steps.build-script.outcome != 'success' }}
|
||||||
|
# run: |
|
||||||
|
# issueid=1
|
||||||
|
# body="Building image $IM finish with some errors."
|
||||||
|
# curl -X 'POST' "$URL/api/v1/repos/$REPO/image-forge/issues/$issueid/comments?token=$T" -H 'accept: application/json' -H 'Content-Type: application/json' -d "{ \"body\": \"$body\" }" -s
|
||||||
|
# echo "notification about test error is sent to issue $issueid"
|
||||||
|
# env:
|
||||||
|
# T: ${{ secrets.TOKEN }}
|
||||||
|
# BR: ${{ env.BRANCH }}
|
||||||
|
# URL: ${{ gitea.server_url }}
|
||||||
|
# REPO: ${{ env.REPO }}
|
||||||
|
# IM: ${{ env.IMAGE }}
|
||||||
|
- name: Delete event tag
|
||||||
|
run: |
|
||||||
|
tagname=$(echo $EV | jq '.ref' -r | sed "s|refs/tags/||g")
|
||||||
|
curl -X 'DELETE' "$URL/api/v1/repos/$REPO/image-forge/tags/$tagname" -H "Authorization: token $T" -H 'accept: application/json' -s
|
||||||
|
echo "tag $tagname is deleted"
|
||||||
|
env:
|
||||||
|
T: ${{ secrets.TOKEN }}
|
||||||
|
BR: ${{ env.BRANCH }}
|
||||||
|
URL: ${{ gitea.server_url }}
|
||||||
|
REPO: ${{ env.REPO }}
|
||||||
|
EV: ${{ toJson(gitea.event) }}
|
@ -68,6 +68,15 @@ jobs:
|
|||||||
ver=$(echo $EV | jq '.ref' -r | sed 's/refs\/tags\///g' | cut -d '_' -f 3)
|
ver=$(echo $EV | jq '.ref' -r | sed 's/refs\/tags\///g' | cut -d '_' -f 3)
|
||||||
echo "VER=$ver" >> ${GITHUB_ENV}
|
echo "VER=$ver" >> ${GITHUB_ENV}
|
||||||
echo "VER=$ver"
|
echo "VER=$ver"
|
||||||
|
- 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: Get test for image
|
- name: Get test for image
|
||||||
run: |
|
run: |
|
||||||
if test -f ${{ gitea.workspace }}/org/$IM/test; then testscript=$(cat ${{ gitea.workspace }}/org/$IM/test); else testscript=""; fi
|
if test -f ${{ gitea.workspace }}/org/$IM/test; then testscript=$(cat ${{ gitea.workspace }}/org/$IM/test); else testscript=""; fi
|
||||||
|
11
README.md
11
README.md
@ -86,7 +86,7 @@ source_packages:
|
|||||||
./build.py -i k8s/pause
|
./build.py -i k8s/pause
|
||||||
```
|
```
|
||||||
|
|
||||||
#### org/alt/etcd
|
#### org/k8s/etcd
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
is_versioned: true
|
is_versioned: true
|
||||||
@ -95,16 +95,11 @@ version_template:
|
|||||||
- "{{ version }}"
|
- "{{ version }}"
|
||||||
- "{{ version }}-0"
|
- "{{ version }}-0"
|
||||||
source_packages:
|
source_packages:
|
||||||
- >
|
- etcd-for-kubernetes{{ version }}
|
||||||
{% if branch in ["sisyphus", "p11"] %}
|
|
||||||
{% raw %}etcd{{ version }}{% endraw %}
|
|
||||||
{% else %}
|
|
||||||
etcd
|
|
||||||
{% endif %}
|
|
||||||
```
|
```
|
||||||
|
|
||||||
```bash
|
```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
|
## Dependencies
|
||||||
|
81
build.py
81
build.py
@ -4,13 +4,16 @@ import argparse
|
|||||||
import functools
|
import functools
|
||||||
import json
|
import json
|
||||||
import logging
|
import logging
|
||||||
|
import os
|
||||||
import re
|
import re
|
||||||
import subprocess
|
import subprocess
|
||||||
import textwrap
|
import textwrap
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
from dataclasses import dataclass
|
from dataclasses import dataclass
|
||||||
from graphlib import TopologicalSorter
|
from graphlib import TopologicalSorter
|
||||||
|
from http import HTTPStatus
|
||||||
from pathlib import Path
|
from pathlib import Path
|
||||||
|
from typing import Optional, Union
|
||||||
|
|
||||||
import requests
|
import requests
|
||||||
import tomli
|
import tomli
|
||||||
@ -21,7 +24,7 @@ logger = logging.getLogger(__name__)
|
|||||||
|
|
||||||
ORG_DIR = Path("org")
|
ORG_DIR = Path("org")
|
||||||
|
|
||||||
PKG_VERSIONS: dict | None = None
|
PKG_VERSIONS: Optional[dict] = None
|
||||||
|
|
||||||
# Jinja2 custom fail filter
|
# Jinja2 custom fail filter
|
||||||
def fail(message: str):
|
def fail(message: str):
|
||||||
@ -33,9 +36,9 @@ JINJA_ENV.filters['fail'] = fail
|
|||||||
@dataclass
|
@dataclass
|
||||||
class Image:
|
class Image:
|
||||||
canonical_name: str
|
canonical_name: str
|
||||||
is_versioned: bool | None
|
is_versioned: Optional[bool]
|
||||||
version_template: list[str] | str | None
|
version_template: Union[list[str], str, None]
|
||||||
source_packages: list[str] | None
|
source_packages: Optional[list[str]]
|
||||||
|
|
||||||
def __init__(self, canonical_name: str):
|
def __init__(self, canonical_name: str):
|
||||||
self.canonical_name = canonical_name
|
self.canonical_name = canonical_name
|
||||||
@ -140,14 +143,14 @@ def api_get_source_package_version_from_task(task_id: str, package_name: str):
|
|||||||
|
|
||||||
|
|
||||||
class Tags:
|
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:
|
if tags_file is None:
|
||||||
self._tags = None
|
self._tags = None
|
||||||
else:
|
else:
|
||||||
self._tags = tomli.loads(Path(tags_file).read_text())
|
self._tags = tomli.loads(Path(tags_file).read_text())
|
||||||
self._latest = latest
|
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 self._tags is None:
|
||||||
if image.is_versioned is None:
|
if image.is_versioned is None:
|
||||||
tags = [branch]
|
tags = [branch]
|
||||||
@ -157,9 +160,7 @@ class Tags:
|
|||||||
elif image.is_versioned and image.source_packages:
|
elif image.is_versioned and image.source_packages:
|
||||||
package_name = image.source_packages[0]
|
package_name = image.source_packages[0]
|
||||||
|
|
||||||
if re.search("{%.*%}", package_name):
|
context_version = ""
|
||||||
package_name = JINJA_ENV.from_string(package_name).render(branch=branch).strip()
|
|
||||||
|
|
||||||
if re.search("{{.*}}", package_name):
|
if re.search("{{.*}}", package_name):
|
||||||
if PKG_VERSIONS is None:
|
if PKG_VERSIONS is None:
|
||||||
raise RuntimeError(
|
raise RuntimeError(
|
||||||
@ -176,8 +177,12 @@ class Tags:
|
|||||||
f"invalid version for image {image.canonical_name!r}: {PKG_VERSIONS[image.canonical_name]!r}"
|
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(
|
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:
|
if tasks is not None:
|
||||||
@ -414,6 +419,7 @@ class DockerBuilder:
|
|||||||
install_packages=install_packages,
|
install_packages=install_packages,
|
||||||
organization=organization,
|
organization=organization,
|
||||||
registry=registry,
|
registry=registry,
|
||||||
|
pkg_versions=PKG_VERSIONS,
|
||||||
**kwargs,
|
**kwargs,
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -662,7 +668,7 @@ class DockerBuilder:
|
|||||||
build_arches = set(arches) - set(
|
build_arches = set(arches) - set(
|
||||||
self.images_info.skip_arches(image.canonical_name)
|
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])
|
manifest = self.render_full_tag(image, tags[0])
|
||||||
|
|
||||||
msg = "Building image {} for {} arches".format(
|
msg = "Building image {} for {} arches".format(
|
||||||
@ -944,6 +950,23 @@ def parse_args():
|
|||||||
choices=log_levels,
|
choices=log_levels,
|
||||||
help="log messages above specified level",
|
help="log messages above specified level",
|
||||||
)
|
)
|
||||||
|
|
||||||
|
parser.add_argument(
|
||||||
|
"--run-workflow",
|
||||||
|
action="store_true",
|
||||||
|
help="run gitea workflow to build oci images",
|
||||||
|
)
|
||||||
|
parser.add_argument(
|
||||||
|
"--workflow-repo",
|
||||||
|
default="stepchenkoas/image-forge",
|
||||||
|
help="path to gitea repository where to activate workflow",
|
||||||
|
)
|
||||||
|
parser.add_argument(
|
||||||
|
"--workflow-branch",
|
||||||
|
default="master",
|
||||||
|
help="branch in gitea repository where to activate workflow",
|
||||||
|
)
|
||||||
|
|
||||||
args = parser.parse_args()
|
args = parser.parse_args()
|
||||||
|
|
||||||
args.stages = set(args.stages) - set(args.skip_stages)
|
args.stages = set(args.stages) - set(args.skip_stages)
|
||||||
@ -967,6 +990,42 @@ def main():
|
|||||||
|
|
||||||
logger.info("PKG_VERSIONS=%s", PKG_VERSIONS)
|
logger.info("PKG_VERSIONS=%s", PKG_VERSIONS)
|
||||||
|
|
||||||
|
if args.run_workflow:
|
||||||
|
gitea_token = os.environ.get("GITEA_TOKEN")
|
||||||
|
if gitea_token is None:
|
||||||
|
raise RuntimeError("Gitea authorization token is not provided through the environment variable GITEA_TOKEN")
|
||||||
|
|
||||||
|
api_url = f"https://gitea.basealt.ru/api/v1/repos/{args.workflow_repo}/tags"
|
||||||
|
headers = {
|
||||||
|
"Accept": "application/json",
|
||||||
|
"Content-Type": "application/json",
|
||||||
|
"Authorization": f"token {gitea_token}",
|
||||||
|
}
|
||||||
|
|
||||||
|
tag_name = list(args.branches)[0]
|
||||||
|
for image in args.images:
|
||||||
|
tag_name += "_" + image
|
||||||
|
if PKG_VERSIONS is not None:
|
||||||
|
if (version := PKG_VERSIONS.get(image)) is not None:
|
||||||
|
tag_name += "@" + version
|
||||||
|
|
||||||
|
logger.debug("tag_name=\"%s\"", tag_name)
|
||||||
|
|
||||||
|
json = {
|
||||||
|
"message": "workflow trigger",
|
||||||
|
"target": args.workflow_branch,
|
||||||
|
"tag_name": tag_name,
|
||||||
|
}
|
||||||
|
|
||||||
|
response = requests.post(api_url, json=json, headers=headers)
|
||||||
|
if response.status_code != HTTPStatus.CREATED:
|
||||||
|
print(f"{response.status_code=}")
|
||||||
|
raise RuntimeError(
|
||||||
|
f"failed to run workflow: {response.text!r}"
|
||||||
|
)
|
||||||
|
|
||||||
|
return
|
||||||
|
|
||||||
arches = args.arches
|
arches = args.arches
|
||||||
images_info = ImagesInfo()
|
images_info = ImagesInfo()
|
||||||
tags = Tags(args.tags, args.latest)
|
tags = Tags(args.tags, args.latest)
|
||||||
|
@ -1,13 +0,0 @@
|
|||||||
dockerfiles-alt-etcd
|
|
||||||
=========================
|
|
||||||
|
|
||||||
ALT dockerfile for etcd.
|
|
||||||
|
|
||||||
Copy Dockerfile somewhere and build the image:
|
|
||||||
`$ docker build --rm -t <username>/etcd.`
|
|
||||||
|
|
||||||
And launch the etcd container:
|
|
||||||
`docker run -d -v <etcd data dir>:/data <username>/etcd`
|
|
||||||
|
|
||||||
If etcdclt watnted it could be run via:
|
|
||||||
`docker run --entrypoint etcdctl <username>/etcd`
|
|
@ -1 +0,0 @@
|
|||||||
etcd --version
|
|
@ -3,9 +3,9 @@ is_versioned: true
|
|||||||
version_template: "{{ version }}"
|
version_template: "{{ version }}"
|
||||||
source_packages:
|
source_packages:
|
||||||
- >
|
- >
|
||||||
{% if branch in [ "p10", "c10f1", "c10f2"] %}
|
{%- if branch in [ "p10", "c10f1", "c10f2"] -%}
|
||||||
{% raw %}php8.2{% endraw %}
|
php8.2
|
||||||
{% else %}
|
{%- else -%}
|
||||||
php8.3
|
php8.3
|
||||||
{% endif %}
|
{%- endif -%}
|
||||||
...
|
...
|
||||||
|
@ -3,9 +3,9 @@ is_versioned: true
|
|||||||
version_template: "{{ version }}"
|
version_template: "{{ version }}"
|
||||||
source_packages:
|
source_packages:
|
||||||
- >
|
- >
|
||||||
{% if branch in ["p10", "c10f2", "c10f1"] %}
|
{%- if branch in ["p10", "c10f2", "c10f1"] -%}
|
||||||
{% raw %}ruby{% endraw %}
|
ruby
|
||||||
{% else %}
|
{%- else -%}
|
||||||
gem-irb
|
gem-irb
|
||||||
{% endif %}
|
{%- endif -%}
|
||||||
...
|
...
|
||||||
|
@ -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.licenses="Apache-2.0"
|
||||||
LABEL org.opencontainers.image.vendor="ALT Linux Team"
|
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
|
ARG PKG_VERSION
|
||||||
|
|
||||||
{{ install_packages("coredns${PKG_VERSION}") }}
|
{{ install_packages("coredns${PKG_VERSION}") }}
|
||||||
|
@ -3,9 +3,13 @@ is_versioned: true
|
|||||||
version_template: v{{ version }}
|
version_template: v{{ version }}
|
||||||
source_packages:
|
source_packages:
|
||||||
- >
|
- >
|
||||||
{% if branch in ["sisyphus", "p11", "c10f2"] %}
|
{%- set version_parts = version.split('.') -%}
|
||||||
{% raw %}coredns{{ version }}{% endraw %}
|
{%- set version_major = version_parts[1] | int -%}
|
||||||
{% else %}
|
{%- 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
|
coredns
|
||||||
{% endif %}
|
{%- endif -%}
|
||||||
...
|
...
|
||||||
|
@ -8,15 +8,13 @@ LABEL org.opencontainers.image.source="https://github.com/etcd-io/etcd"
|
|||||||
LABEL org.opencontainers.image.licenses="Apache-2.0"
|
LABEL org.opencontainers.image.licenses="Apache-2.0"
|
||||||
LABEL org.opencontainers.image.vendor="ALT Linux Team"
|
LABEL org.opencontainers.image.vendor="ALT Linux Team"
|
||||||
|
|
||||||
{% if branch in ["sisyphus"] %}
|
|
||||||
ARG PKG_VERSION
|
ARG PKG_VERSION
|
||||||
|
|
||||||
{{ install_packages("etcd${PKG_VERSION}") }}
|
{{ install_packages("etcd-for-kubernetes${PKG_VERSION}") }}
|
||||||
{% else %}
|
|
||||||
{{ install_packages("etcd") }}
|
|
||||||
{% endif %}
|
|
||||||
|
|
||||||
RUN ln -s /usr/sbin/etcd /usr/local/bin/etcd
|
RUN ln -s /usr/sbin/etcd /usr/local/bin/etcd && ln -s /usr/bin/etcdctl /usr/local/bin/etcdctl
|
||||||
|
|
||||||
|
EXPOSE 2379 2380
|
||||||
|
|
||||||
VOLUME /data
|
VOLUME /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
|
||||||
|
```
|
@ -5,10 +5,5 @@ version_template:
|
|||||||
- "{{ version }}"
|
- "{{ version }}"
|
||||||
- "{{ version }}-0"
|
- "{{ version }}-0"
|
||||||
source_packages:
|
source_packages:
|
||||||
- >
|
- etcd-for-kubernetes{{ version }}
|
||||||
{% if branch in ["sisyphus"] %}
|
|
||||||
{% raw %}etcd{{ version }}{% endraw %}
|
|
||||||
{% else %}
|
|
||||||
etcd
|
|
||||||
{% endif %}
|
|
||||||
...
|
...
|
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