30 Commits

Author SHA1 Message Date
3fa0090ab7 don't use build cache
Some checks failed
Docker Image CI / build (openrc) (push) Failing after 1m25s
2024-02-17 20:06:46 -05:00
ab1625a02e add back seemingly useless whitespace
Some checks failed
Docker Image CI / build (openrc) (push) Failing after 1m11s
2024-02-17 20:01:33 -05:00
0239c5b2de revert more
Some checks failed
Docker Image CI / build (openrc) (push) Failing after 1m35s
2024-02-15 03:39:18 -05:00
be481798e3 Revert changes
Some checks failed
Docker Image CI / build (openrc) (push) Failing after 1m9s
2024-02-15 03:24:59 -05:00
0af0e488c3 maybe GITHUB_RUN_ID not imlemented?
Some checks failed
Docker Image CI / build (openrc) (push) Failing after 1m7s
2024-02-15 03:16:16 -05:00
5802d1df18 De-complicate sed operation
Some checks failed
Docker Image CI / build (openrc) (push) Failing after 1m5s
2024-02-15 03:01:41 -05:00
3d299997e7 debug Dockerfile
Some checks failed
Docker Image CI / build (openrc) (push) Failing after 1m5s
2024-02-15 02:58:17 -05:00
227e322a36 alright, I give. sed the values into the dockerfile
Some checks failed
Docker Image CI / build (openrc) (push) Failing after 1m5s
2024-02-15 02:46:54 -05:00
fcb4c34b2b let's get creative
All checks were successful
Docker Image CI / build (openrc) (push) Successful in 3m30s
2024-02-15 02:24:20 -05:00
bc09bcff14 "List type is a newline-delimited string"
All checks were successful
Docker Image CI / build (openrc) (push) Successful in 3m33s
2024-02-15 01:53:43 -05:00
27aa056a39 push image pls
All checks were successful
Docker Image CI / build (openrc) (push) Successful in 3m21s
2024-02-15 01:25:12 -05:00
96e4d2d536 test pipeline
All checks were successful
Docker Image CI / build (openrc) (push) Successful in 2m34s
2024-02-15 01:18:58 -05:00
f610178d89 labels, other changes
All checks were successful
Docker Image CI / build (devel) (pull_request) Successful in 2m53s
Docker Image CI / build (dinit) (pull_request) Successful in 2m28s
Docker Image CI / build (openrc) (pull_request) Successful in 2m21s
Docker Image CI / build (runit) (pull_request) Successful in 2m26s
Docker Image CI / build (s6) (pull_request) Successful in 2m19s
set labels, move makefile logic into dockerfile, pr pipeline
2024-02-12 03:30:35 -05:00
268e4df510 use alias in Docker Hub readme
All checks were successful
Docker Image CI / build (devel) (push) Successful in 9m0s
Docker Image CI / build (dinit) (push) Successful in 5m24s
Docker Image CI / build (openrc) (push) Successful in 7m3s
Docker Image CI / build (runit) (push) Successful in 6m35s
Docker Image CI / build (s6) (push) Successful in 4m35s
Docker Hub Description / build (push) Successful in 9s
2024-02-10 19:19:44 -05:00
be35e1c544 Merge pull request 'Create action to update Docker readme' (#6) from docker-readme-pipeline into master
All checks were successful
Docker Image CI / build (devel) (push) Successful in 3m15s
Docker Image CI / build (dinit) (push) Successful in 2m29s
Docker Image CI / build (openrc) (push) Successful in 2m23s
Docker Image CI / build (runit) (push) Successful in 2m9s
Docker Image CI / build (s6) (push) Successful in 2m9s
Docker Hub Description / build (push) Successful in 6s
Reviewed-on: #6
2024-02-10 07:34:08 +01:00
84f57afe42 update conditions 2024-02-10 01:32:54 -05:00
54d67e3818 push Docker Hub description
All checks were successful
Docker Hub Description / build (push) Successful in 14s
maybe this works
2024-02-10 01:31:28 -05:00
2289204113 add purpose 2024-02-09 13:01:39 -05:00
646b27c9b4 add readme for Docker Hub 2024-02-08 20:17:06 -05:00
cb80995d9a Merge pull request 'feature: push images to Docker Hub' (#4) from dockerhub into master
All checks were successful
Docker Image CI / build (devel) (push) Successful in 2m57s
Docker Image CI / build (dinit) (push) Successful in 2m17s
Docker Image CI / build (openrc) (push) Successful in 2m21s
Docker Image CI / build (runit) (push) Successful in 2m1s
Docker Image CI / build (s6) (push) Successful in 2m5s
Reviewed-on: #4
2024-02-09 00:47:19 +01:00
a3b3ee7bdf Fix step name, remove feature branch 2024-02-08 18:16:13 -05:00
3d4337409a publish to new dockerhub image
All checks were successful
Docker Image CI / build (devel) (push) Successful in 2m48s
Docker Image CI / build (dinit) (push) Successful in 2m42s
Docker Image CI / build (openrc) (push) Successful in 2m20s
Docker Image CI / build (runit) (push) Successful in 2m7s
Docker Image CI / build (s6) (push) Successful in 2m30s
2024-02-08 18:09:36 -05:00
32715458f5 push to Docker Hub 2024-02-08 18:08:08 -05:00
0dfec54557 build on demand
All checks were successful
Docker Image CI / build (devel) (push) Successful in 2m6s
Docker Image CI / build (dinit) (push) Successful in 1m55s
Docker Image CI / build (openrc) (push) Successful in 1m44s
Docker Image CI / build (runit) (push) Successful in 1m34s
Docker Image CI / build (s6) (push) Successful in 1m34s
2024-02-07 20:33:27 -05:00
f18e18bc83 Merge pull request 'Build image with actions' (#3) from corysanin/artixlinux-docker:develop into master
All checks were successful
artixdocker/artixlinux-docker/pipeline/head This commit looks good
Docker Image CI / build (devel) (push) Successful in 2m12s
Docker Image CI / build (dinit) (push) Successful in 1m51s
Docker Image CI / build (openrc) (push) Successful in 1m46s
Docker Image CI / build (runit) (push) Successful in 1m40s
Docker Image CI / build (s6) (push) Successful in 1m52s
Reviewed-on: #3
2024-02-06 16:58:42 +01:00
072c6f86cb remove feature branch 2024-02-06 03:41:07 -05:00
d8fbaa9219 Build image with actions
Co-authored-by: Cory Sanin <corysanin@outlook.com>
Co-committed-by: Cory Sanin <corysanin@outlook.com>
2024-02-06 09:39:36 +01:00
74c6f1d96c update readme
All checks were successful
artixdocker/artixlinux-docker/pipeline/tag This commit looks good
artixdocker/artixlinux-docker/pipeline/head This commit looks good
2023-05-15 16:16:19 +02:00
010c9f59eb reset lib template
Some checks failed
artixdocker/artixlinux-docker/pipeline/tag This commit looks good
artixdocker/artixlinux-docker/pipeline/head There was a failure building this commit
2023-05-14 12:20:53 +02:00
4307a682e3 update lib template
All checks were successful
artixdocker/artixlinux-docker/pipeline/head This commit looks good
artixdocker/artixlinux-docker/pipeline/tag This commit looks good
2023-05-14 11:46:10 +02:00
7 changed files with 238 additions and 7 deletions

View File

@@ -0,0 +1,90 @@
name: Docker Image CI
on:
workflow_dispatch:
branches: [ main ]
push:
branches: [ master, verbose-dockerfile-pipeline-test ]
pull_request:
branches: [ master ]
schedule:
- cron: '0 5 * * 3'
jobs:
build:
runs-on: ubuntu-latest
timeout-minutes: 90
strategy:
fail-fast: true
matrix:
images:
[
openrc
]
env:
REGISTRY: gitea.artixlinux.org
DH_REGISTRY: docker.io
REPO_ORG: ${{ gitea.repository_owner }}
IMAGE_NAME: artixlinux
ABSOLUTE_IMAGE: ${{ env.REGISTRY }}/${{ env.REPO_ORG }}/${{ env.IMAGE_NAME }}
ABSOLUTE_DH_IMAGE: ${{ env.DH_REGISTRY }}/artixlinux/${{ env.IMAGE_NAME }}
permissions:
contents: read
packages: write
steps:
- name: Checkout repository
uses: https://github.com/actions/checkout@v4
- name: Set up docker
run: curl -fsSL https://get.docker.com | sh
# - name: Define metadata variables
# run: |
# sed -i "s/ARG version=.*/ARG version=$(date +'%Y%m%d').0.${{ gitea.sha }}/" Dockerfile
# sed -i "s/ARG githash=.*/ARG githash=${{ gitea.sha }}/" Dockerfile
# sed -i "s/ARG created=.*/ARG created=$(date -u +'%Y-%m-%dT%H:%M:%S%:z')/" Dockerfile
# cat Dockerfile
- name: Build Docker image
uses: https://github.com/docker/build-push-action@v5
with:
push: false
pull: true
no-cache: true
context: .
build-args: |
img=${{ matrix.images }}
tags: "${{ env.ABSOLUTE_IMAGE }}:base-${{ matrix.images }}-test,${{ env.ABSOLUTE_DH_IMAGE }}:${{ matrix.images }}-test"
- name: Create latest tag
if: matrix.images == 'devel'
uses: https://github.com/docker/build-push-action@v5
with:
push: false
pull: false
context: .
build-args: |
img=${{ matrix.images }}
tags: "${{ env.ABSOLUTE_IMAGE }}:latest,${{ env.ABSOLUTE_DH_IMAGE }}:latest"
- name: Log in to the Container registry
uses: https://github.com/docker/login-action@v2
with:
registry: ${{ env.REGISTRY }}
username: ${{ gitea.actor }}
password: ${{ secrets.PAT }}
- name: Push to Gitea
if: ( gitea.event_name == 'push' && github.ref == 'refs/heads/master' ) || gitea.event_name == 'schedule'
run: docker push "${{ env.ABSOLUTE_IMAGE }}:base-${{ matrix.images }}-test"
- name: Push latest tag
if: ( ( gitea.event_name == 'push' && github.ref == 'refs/heads/master' ) || gitea.event_name == 'schedule' ) && matrix.images == 'devel'
run: docker push "${{ env.ABSOLUTE_IMAGE }}:latest"
- name: Log in to the Docker Hub
uses: https://github.com/docker/login-action@v2
with:
registry: ${{ env.DH_REGISTRY }}
username: ${{ secrets.DOCKERHUB_USER }}
password: ${{ secrets.DOCKERHUB }}
- name: Push to Docker Hub
if: ( gitea.event_name == 'push' && github.ref == 'refs/heads/master' ) || gitea.event_name == 'schedule'
run: docker push "${{ env.ABSOLUTE_DH_IMAGE }}:${{ matrix.images }}-test"
- name: Push latest tag
if: ( ( gitea.event_name == 'push' && github.ref == 'refs/heads/master' ) || gitea.event_name == 'schedule' ) && matrix.images == 'devel'
run: docker push "${{ env.ABSOLUTE_DH_IMAGE }}:latest"

View File

@@ -0,0 +1,25 @@
name: Docker Hub Description
on:
push:
branches: [ master ]
paths: [ dockerhub-readme.md ]
jobs:
build:
runs-on: ubuntu-latest
timeout-minutes: 90
steps:
- name: Checkout repository
uses: https://github.com/actions/checkout@v4
- name: Push Docker Hub description
uses: https://github.com/christian-korneck/update-container-description-action@v1
env:
DOCKER_USER: ${{ secrets.DOCKERHUB_USER }}
DOCKER_PASS: ${{ secrets.DOCKERHUB }}
with:
destination_container_repo: artixlinux/artixlinux
provider: dockerhub
short_description: 'Artix Linux is a fork of Arch Linux that respects init freedom.'
readme_file: 'dockerhub-readme.md'

59
Dockerfile Normal file
View File

@@ -0,0 +1,59 @@
FROM gitea.artixlinux.org/artixdocker/artixlinux:latest as base
RUN pacman -Syu --noconfirm && \
pacman -Sy --noconfirm artools curl make fakechroot fakeroot
WORKDIR /usr/artixlinux-docker
COPY . .
FROM base as build
ARG img=base-devel
ENV working=/usr/artixlinux-docker
ENV BUILDDIR=${working}/build
ENV OUTPUTDIR=${working}/output
WORKDIR ${working}
RUN mkdir -vp ${BUILDDIR}/alpm-hooks/usr/share/libalpm/hooks && \
find /usr/share/libalpm/hooks -exec ln -sf /dev/null ${BUILDDIR}/alpm-hooks{} \; && \
mkdir -vp ${BUILDDIR}/var/lib/pacman/ ${OUTPUTDIR} && \
install -Dm644 /usr/share/artools/pacman.conf.d/galaxy-x86_64.conf ${BUILDDIR}/etc/pacman.conf && \
cat pacman-conf.d-noextract.conf >> ${BUILDDIR}/etc/pacman.conf && \
fakechroot fakeroot pacman -Sy -r ${BUILDDIR} --noconfirm --dbpath ${BUILDDIR}/var/lib/pacman --config ${BUILDDIR}/etc/pacman.conf --noscriptlet --hookdir ${BUILDDIR}/alpm-hooks/usr/share/libalpm/hooks/ ${img} && \
rsync -rt --backup --suffix=.pacnew rootfs/* ${BUILDDIR}/ && \
fakechroot fakeroot chroot ${BUILDDIR} update-ca-trust && \
fakechroot fakeroot chroot ${BUILDDIR} sh -c 'pacman-key --init && pacman-key --populate && rm -rf etc/pacman.d/gnupg/{openpgp-revocs.d/,private-keys-v1.d/,pubring.gpg~,gnupg.S.}*' && \
ln -fs /usr/lib/os-release ${BUILDDIR}/etc/os-release && \
sed -i -e 's/^root::/root:!:/' "${BUILDDIR}/etc/shadow" && \
fakeroot tar --numeric-owner --xattrs --acls --exclude-from=exclude -C ${BUILDDIR} -c . -f ${OUTPUTDIR}/${img}.tar
WORKDIR ${OUTPUTDIR}
RUN zstd --long -T0 -8 ${img}.tar; sha256sum ${img}.tar.zst > ${img}.tar.zst.SHA256
WORKDIR ${OUTPUTDIR}
RUN ROOTFS=${img}.tar.zst && \
sha256sum -c ${img}.tar.zst.SHA256 && \
mkdir /rootfs && \
tar -C /rootfs --extract --file "${ROOTFS}"
FROM scratch AS root
ARG img=base-devel
ARG version=VERSION
ARG githash=REVISION
ARG created=CREATED
LABEL org.opencontainers.image.title="Artix Linux ${img} Image"
LABEL org.opencontainers.image.description="Official containerd image of Artix Linux, a fork of Arch Linux that respects init freedom."
LABEL org.opencontainers.image.vendor="Artix Linux"
LABEL org.opencontainers.image.authors="Cory Sanin <corysanin@artixlinux.org>, artoo <artoo@artixlinux.org>, Chris Cromer <cromer@artixlinux.org>"
LABEL org.opencontainers.image.url="https://gitea.artixlinux.org/artixdocker"
LABEL org.opencontainers.image.documentation="https://wiki.artixlinux.org/"
LABEL org.opencontainers.image.source="https://gitea.artixlinux.org/artixdocker/artixlinux-docker"
LABEL org.opencontainers.image.licenses="GPL-3.0-or-later"
LABEL org.opencontainers.image.version="${version}"
LABEL org.opencontainers.image.revision="${githash}"
LABEL org.opencontainers.image.created="${created}"
COPY --from=build /rootfs/ /
RUN ldconfig && \
sed -i "/BUILD_ID/a VERSION_ID=${version}" /etc/os-release
ENV LANG=C.UTF-8
CMD ["/usr/bin/bash"]

2
Jenkinsfile vendored
View File

@@ -1,3 +1,3 @@
@Library('docker-ci@base-openrc') import org.artixlinux.DockerImage
@Library('docker-ci') import org.artixlinux.DockerImage
ImagePipeline(new DockerImage(this))

View File

@@ -9,7 +9,7 @@ define rootfs
find /usr/share/libalpm/hooks -exec ln -sf /dev/null $(BUILDDIR)/alpm-hooks{} \;
mkdir -vp $(BUILDDIR)/var/lib/pacman/ $(OUTPUTDIR)
install -Dm644 /usr/share/artools/pacman-default.conf $(BUILDDIR)/etc/pacman.conf
install -Dm644 /usr/share/artools/pacman.conf.d/galaxy-x86_64.conf $(BUILDDIR)/etc/pacman.conf
cat pacman-conf.d-noextract.conf >> $(BUILDDIR)/etc/pacman.conf
fakechroot fakeroot pacman -Sy -r $(BUILDDIR) \
@@ -28,7 +28,7 @@ define rootfs
ln -fs /usr/lib/os-release $(BUILDDIR)/etc/os-release
# add system users
fakechroot fakeroot chroot $(BUILDDIR) /usr/bin/sysusers --root "/"
#fakechroot fakeroot chroot $(BUILDDIR) /usr/bin/sysusers --root "/"
# remove passwordless login for root (see CVE-2019-5021 for reference)
sed -i -e 's/^root::/root:!:/' "$(BUILDDIR)/etc/shadow"

View File

@@ -6,16 +6,35 @@ This repository contains all scripts and files needed to create a Docker images
Install the following Artix Linux packages:
* make
* artools
* fakechroot
* docker
* fakeroot
* artools
## Usage
Run `make docker-image` to build the base image.
Run `make image-base-devel` to build the base devel image.
Run `make docker-image-openrc` to build the openrc image.
Run `make image-base-openrc` to build the openrc base image.
Run `make docker-image-runit` to build the runit image.
Run `make image-base-runit` to build the runit base image.
Run `make image-base-s6` to build the s6 base image.
Run `make image-base-dinit` to build the dinit base image.
Alternatively:
Run `make dockerfile-base-devel` to build the base devel dockerfile.
Run `make dockerfile-base-openrc` to build the openrc base dockerfile.
Run `make dockerfile-base-runit` to build the runit base dockerfile.
Run `make dockerfile-base-s6` to build the s6 base dockerfile.
Run `make dockerfile-base-dinit` to build the dinit base dockerfile.
## Purpose

38
dockerhub-readme.md Normal file
View File

@@ -0,0 +1,38 @@
# Quick reference
* **Maintained by**:
[Cory Sanin](https://artixlinux.org/kotnr.php#Cory%20Sanin), [artoo](https://artixlinux.org/kotor.php#Marcus%20von%20Ditfurth), [Chris Cromer](https://artixlinux.org/kotor.php#Chris%20Cromer)
* **Where to get help**:
[Artix Wiki](https://wiki.artixlinux.org/), [Artix Linux Forum](https://forum.artixlinux.org/)
# Supported tags
* latest, devel
* dinit
* openrc
* runit
* s6
## Dockerfile repo
[artixlinux-docker](https://gitea.artixlinux.org/artixdocker/artixlinux-docker)
# Purpose
* Provide Artix Linux in a Docker Image
* Provide the most simple but complete image to base every other upon
* `pacman` needs to work out of the box
* All installed packages have to be kept unmodified
# How to run
```
docker pull artixlinux/artixlinux:devel
docker run -it --rm artixlinux/artixlinux:devel /bin/bash
```
Note that `--rm` removes the container on exit.