Compare commits
No commits in common. "master" and "v0.2.0" have entirely different histories.
99
.drone.yml
99
.drone.yml
@ -1,70 +1,43 @@
|
||||
---
|
||||
kind: pipeline
|
||||
name: dockerhub-build-trigger
|
||||
|
||||
platform:
|
||||
arch: amd64
|
||||
|
||||
trigger:
|
||||
exclude:
|
||||
event: pull_request
|
||||
|
||||
steps:
|
||||
- name: call webhook
|
||||
pull: always
|
||||
image: curlimages/curl:latest
|
||||
environment:
|
||||
ENDPOINT:
|
||||
from_secret: dockerhub_endpoint
|
||||
commands:
|
||||
- curl -s -X POST $ENDPOINT
|
||||
|
||||
---
|
||||
kind: pipeline
|
||||
type: docker
|
||||
name: testing
|
||||
name: kaniko-build
|
||||
|
||||
platform:
|
||||
os: linux
|
||||
arch: amd64
|
||||
|
||||
depends_on:
|
||||
- dockerhub-build-trigger
|
||||
|
||||
steps:
|
||||
- name: hadolint
|
||||
- name: build
|
||||
pull: always
|
||||
image: docker.io/hadolint/hadolint:v2.12.0-alpine
|
||||
commands:
|
||||
- hadolint --version
|
||||
- hadolint Dockerfile
|
||||
when:
|
||||
ref:
|
||||
- refs/heads/master
|
||||
- "refs/heads/feature-**"
|
||||
- "refs/pull/**"
|
||||
- "refs/tags/**"
|
||||
event:
|
||||
exclude: [cron]
|
||||
|
||||
- name: kaniko-build
|
||||
pull: always
|
||||
image: docker.io/immawanderer/drone-kaniko:linux-amd64
|
||||
image: banzaicloud/drone-kaniko
|
||||
settings:
|
||||
dockerfile: Dockerfile
|
||||
context: .
|
||||
args:
|
||||
- BUILD_DATE="$(date -u +"%Y-%m-%dT%H:%M:%SZ")"
|
||||
- VCS_REF=${DRONE_COMMIT_SHA:0:7}
|
||||
when:
|
||||
ref:
|
||||
- "refs/heads/feature-**"
|
||||
- "refs/pull/**"
|
||||
- "refs/tags/**"
|
||||
event:
|
||||
exclude: [cron]
|
||||
|
||||
- name: kaniko-publish
|
||||
pull: always
|
||||
image: docker.io/immawanderer/drone-kaniko:linux-amd64
|
||||
settings:
|
||||
dockerfile: Dockerfile
|
||||
context: .
|
||||
args:
|
||||
- BUILD_DATE="$(date -u +"%Y-%m-%dT%H:%M:%SZ")"
|
||||
- VCS_REF=${DRONE_COMMIT_SHA:0:7}
|
||||
tags:
|
||||
- latest
|
||||
- linux-amd64
|
||||
- ${DRONE_COMMIT_SHA:0:8}
|
||||
repo: immawanderer/archlinux
|
||||
username:
|
||||
from_secret: docker_username
|
||||
password:
|
||||
from_secret: docker_password
|
||||
when:
|
||||
ref:
|
||||
- refs/heads/master
|
||||
event:
|
||||
exclude: [pull_request, tag]
|
||||
trigger:
|
||||
event: [push, pull_request, cron, tag]
|
||||
|
||||
---
|
||||
kind: pipeline
|
||||
@ -89,12 +62,12 @@ trigger:
|
||||
- cron
|
||||
|
||||
depends_on:
|
||||
- testing
|
||||
- kaniko-build
|
||||
|
||||
steps:
|
||||
- name: discord
|
||||
pull: if-not-exists
|
||||
image: docker.io/appleboy/drone-discord:latest
|
||||
image: appleboy/drone-discord:latest
|
||||
settings:
|
||||
message: "{{#success build.status}} ✅ [Build #{{build.number}}]({{build.link}}) of `{{repo.name}}` succeeded.\nevent: **`{{build.event}}`**\ncommit [`${DRONE_COMMIT_SHA:0:7}`](https://git.dotya.ml/${DRONE_REPO}/commit/${DRONE_COMMIT_SHA}) by {{commit.author}} on `{{commit.branch}}`\n```{{commit.message}}``` {{else}} ❌ [Build #{{build.number}}]({{build.link}}) of `{{repo.name}}` failed.\nevent: **`${DRONE_BUILD_EVENT}`**\ncommit [`${DRONE_COMMIT_SHA:0:7}`](https://git.dotya.ml/${DRONE_REPO}/commit/${DRONE_COMMIT_SHA}) by {{commit.author}} on `{{commit.branch}}`\n```{{commit.message}}``` {{/success}}\n"
|
||||
webhook_id:
|
||||
@ -119,27 +92,21 @@ trigger:
|
||||
event:
|
||||
- cron
|
||||
cron:
|
||||
- nightly-build
|
||||
- hourly-build
|
||||
status:
|
||||
- success
|
||||
- failure
|
||||
|
||||
depends_on:
|
||||
- testing
|
||||
- kaniko-build
|
||||
|
||||
steps:
|
||||
- name: discord
|
||||
pull: always
|
||||
image: docker.io/appleboy/drone-discord:latest
|
||||
image: appleboy/drone-discord:latest
|
||||
settings:
|
||||
message: "{{#success build.status}} ✅ [Scheduled build #{{build.number}}]({{build.link}}) of `{{repo.name}}` succeeded.\nevent: **`{{build.event}}`**\ncommit [`${DRONE_COMMIT_SHA:0:7}`](https://git.dotya.ml/${DRONE_REPO}/commit/${DRONE_COMMIT_SHA}) by {{commit.author}} on `{{commit.branch}}`\n {{else}} ❌ [Scheduled build #{{build.number}}]({{build.link}}) of `{{repo.name}}` failed.\nevent: **`${DRONE_BUILD_EVENT}`**\ncommit [`${DRONE_COMMIT_SHA:0:7}`](https://git.dotya.ml/${DRONE_REPO}/commit/${DRONE_COMMIT_SHA}) by {{commit.author}} on `{{commit.branch}}`\n {{/success}}\n"
|
||||
message: "{{#success build.status}} ✅ [Hourly build #{{build.number}}]({{build.link}}) of `{{repo.name}}` succeeded.\nevent: **`{{build.event}}`**\ncommit [`${DRONE_COMMIT_SHA:0:7}`](https://git.dotya.ml/${DRONE_REPO}/commit/${DRONE_COMMIT_SHA}) by {{commit.author}} on `{{commit.branch}}`\n {{else}} ❌ [Hourly build #{{build.number}}]({{build.link}}) of `{{repo.name}}` failed.\nevent: **`${DRONE_BUILD_EVENT}`**\ncommit [`${DRONE_COMMIT_SHA:0:7}`](https://git.dotya.ml/${DRONE_REPO}/commit/${DRONE_COMMIT_SHA}) by {{commit.author}} on `{{commit.branch}}`\n {{/success}}\n"
|
||||
webhook_id:
|
||||
from_secret: discord_webhook_hourly_id
|
||||
webhook_token:
|
||||
from_secret: discord_webhook_hourly_token
|
||||
|
||||
---
|
||||
kind: signature
|
||||
hmac: bc36fd53d1d57053f660e05df07722e8cb2e82edc732ec8898d7308ad891b905
|
||||
|
||||
...
|
||||
|
@ -1,2 +0,0 @@
|
||||
---
|
||||
ignored:
|
43
Dockerfile
43
Dockerfile
@ -1,35 +1,24 @@
|
||||
# syntax=docker/dockerfile:1.3
|
||||
# refs:
|
||||
# https://docs.docker.com/develop/develop-images/build_enhancements/#overriding-default-frontends
|
||||
# https://pythonspeed.com/articles/docker-buildkit/
|
||||
|
||||
FROM docker.io/library/archlinux:base-devel
|
||||
FROM archlinux:latest
|
||||
|
||||
ARG BUILD_DATE
|
||||
ARG VCS_REF
|
||||
|
||||
# as per https://github.com/opencontainers/image-spec/blob/main/annotations.md,
|
||||
# keep Label Schema labels for backward compatibility.
|
||||
LABEL description="hourly updated archlinux base(-devel) image" \
|
||||
org.label-schema.build-date=$BUILD_DATE \
|
||||
LABEL description="Hourly updated archlinux base image"
|
||||
|
||||
LABEL org.label-schema.build-date=$BUILD_DATE \
|
||||
org.label-schema.vcs-url="https://git.dotya.ml/wanderer/docker-archlinux.git" \
|
||||
org.label-schema.vcs-ref=$VCS_REF \
|
||||
org.label-schema.license=GPL-3.0 \
|
||||
org.opencontainers.image.title="docker-archlinux" \
|
||||
org.opencontainers.image.description="hourly updated archlinux base(-devel) image" \
|
||||
org.opencontainers.image.created=$BUILD_DATE \
|
||||
org.opencontainers.image.authors=wanderer \
|
||||
org.opencontainers.image.url="https://git.dotya.ml/wanderer/docker-archlinux.git" \
|
||||
org.opencontainers.image.source="https://git.dotya.ml/wanderer/docker-archlinux.git" \
|
||||
org.opencontainers.image.revision=$VCS_REF \
|
||||
org.opencontainers.image.licenses=GPL-3.0
|
||||
org.label-schema.license=GPL-3.0
|
||||
|
||||
# if you need the WORKAROUND for glibc 2.33 and old Docker
|
||||
# have a look at https://git.dotya.ml/wanderer/docker-archlinux/commit/bd4c5abe4dca475965548cb8332ef9b9d2a4953c
|
||||
# WORKAROUND for glibc 2.33 and old Docker
|
||||
# See https://github.com/actions/virtual-environments/issues/2658
|
||||
# Thanks to https://github.com/lxqt/lxqt-panel/pull/1562
|
||||
ENV patched_glibc glibc-linux4-2.33-4-x86_64.pkg.tar.zst
|
||||
RUN curl -LO "https://repo.archlinuxcn.org/x86_64/$patched_glibc" && \
|
||||
bsdtar -C / -xvf "$patched_glibc"
|
||||
RUN pacman --version
|
||||
|
||||
RUN pacman --version && \
|
||||
\
|
||||
\
|
||||
pacman -Syu --noconfirm --needed && \
|
||||
pacman --noconfirm -Rn "$(pacman -Qdtq)" || true && \
|
||||
pacman -Scc && rm -rf /var/cache/pacman/* /var/lib/pacman/sync/*
|
||||
RUN pacman -Syu --ignore glibc --noconfirm --needed
|
||||
RUN pacman --noconfirm -Rn $(pacman -Qdtq) || true
|
||||
RUN pacman -Scc && rm -rfv /var/cache/pacman/* /var/lib/pacman/sync/* \
|
||||
rm -rv /tmp/* || true
|
||||
|
2
LICENSE
2
LICENSE
@ -2,7 +2,7 @@ GNU GENERAL PUBLIC LICENSE
|
||||
|
||||
Version 3, 29 June 2007
|
||||
|
||||
Copyright © 2020-2021 Adam Mirre <a_mirre@utb.cz>
|
||||
Copyright © 2007 Free Software Foundation, Inc. <https://fsf.org/>
|
||||
|
||||
Everyone is permitted to copy and distribute verbatim copies of this license
|
||||
document, but changing it is not allowed.
|
||||
|
34
Makefile
34
Makefile
@ -1,34 +0,0 @@
|
||||
dcmd = docker
|
||||
dfile = Dockerfile
|
||||
dtag = immawanderer/archlinux:testbuild
|
||||
dargs = build -t $(dtag) --no-cache --pull - < $(dfile)
|
||||
cleanargs = image rm -f $(dtag)
|
||||
pruneargs = system prune -af
|
||||
dargskaniko = run --rm -it -w=$(kanikowdir) -v $$PWD:$(kanikowdir):z
|
||||
kanikoexecutorimg = gcr.io/kaniko-project/executor:v1.8.1-debug
|
||||
kanikowdir = /src
|
||||
kanikocontext = .
|
||||
kanikoargs = -f=$(dfile) -c=$(kanikocontext) --use-new-run --snapshotMode=redo --build-arg BUILD_DATE=$(build_date) --build-arg VCS_REF=$(vcs_ref) --no-push
|
||||
vcs_ref = $$(git rev-parse --short HEAD)
|
||||
build_date= $$(date -u +"%Y-%m-%dT%H:%M:%SZ")
|
||||
hadolintimg = docker.io/hadolint/hadolint
|
||||
hadolinttag = v2.12.0-alpine
|
||||
hadolintargs = run --rm -i -v $$PWD:/src:z --workdir=/src
|
||||
.PHONY: hadolint build kaniko clean test prune
|
||||
|
||||
hadolint:
|
||||
$(dcmd) $(hadolintargs) $(hadolintimg):$(hadolinttag) < $(dfile)
|
||||
|
||||
kaniko:
|
||||
$(dcmd) $(dargskaniko) $(kanikoexecutorimg) $(kanikoargs)
|
||||
|
||||
build:
|
||||
$(dcmd) $(dargs)
|
||||
|
||||
clean:
|
||||
$(dcmd) $(cleanargs)
|
||||
|
||||
test: hadolint build kaniko
|
||||
|
||||
prune:
|
||||
$(dcmd) $(pruneargs)
|
15
README.md
15
README.md
@ -1,14 +1,13 @@
|
||||
# docker-archlinux
|
||||
|
||||
[![Build Status](https://drone.dotya.ml/api/badges/wanderer/docker-archlinux/status.svg)](https://drone.dotya.ml/wanderer/docker-archlinux)
|
||||
[![Docker Image Version (latest by date)](https://img.shields.io/docker/v/immawanderer/archlinux)](https://hub.docker.com/r/immawanderer/archlinux/tags/?page=1&ordering=last_updated)
|
||||
[![Docker Image Version (tag latest semver)](https://img.shields.io/docker/v/immawanderer/archlinux/linux-amd64)](https://hub.docker.com/r/immawanderer/archlinux/tags/?page=1&ordering=last_updated&name=linux-amd64)
|
||||
[![Docker Image Size (tag)](https://img.shields.io/docker/image-size/immawanderer/archlinux/linux-amd64)](https://hub.docker.com/r/immawanderer/archlinux/tags/?page=1&ordering=last_updated&name=linux-amd64)
|
||||
[![Docker pulls](https://img.shields.io/docker/pulls/immawanderer/archlinux)](https://hub.docker.com/r/immawanderer/archlinux/)
|
||||
[![Build Status](https://drone.dotya.ml/api/badges/wanderer/docker-archlinux-hugo/status.svg)](https://drone.dotya.ml/wanderer/docker-archlinux-hugo)
|
||||
[![Docker Cloud Build Status](https://img.shields.io/docker/cloud/build/immawanderer/archlinux)](https://hub.docker.com/r/immawanderer/archlinux/builds)
|
||||
[![](https://images.microbadger.com/badges/version/immawanderer/archlinux.svg)](https://microbadger.com/images/immawanderer/archlinux)
|
||||
[![](https://images.microbadger.com/badges/commit/immawanderer/archlinux.svg)](https://microbadger.com/images/immawanderer/archlinux)
|
||||
|
||||
This repository provides a Dockerfile to create an *updated* Arch Linux base(-devel) image.
|
||||
This repository provides the Dockerfile to create an updated Arch Linux base image.
|
||||
|
||||
The image is rebuilt nightly to ensure it always has the latest packages.
|
||||
The image is rebuilt approximately every hour to ensure it always has the latest packages.
|
||||
|
||||
push mirror lives in [this GitHub repo](https://github.com/wULLSnpAXbWZGYDYyhWTKKspEQoaYxXyhoisqHf/docker-archlinux)
|
||||
development happens on [this Gitea instance](https://git.dotya.ml/wanderer/docker-archlinux)
|
||||
@ -22,7 +21,7 @@ That's just it. This makes it possible to just grab the image and install whatev
|
||||
* Arch Linux image with freshly updated package base to build upon
|
||||
|
||||
## Running the image
|
||||
* edit the `yourlocalpath` and `containerpath` variables or remove them entirely (along with `-v`) if you have *nothing to mount*
|
||||
* edit the `yourlocalpath` and `containerpath` variabled or remove them entirely (along with `-v`) if you have *nothing to mount*
|
||||
|
||||
```bash
|
||||
docker run -it -v yourlocalpath:containerpath immawanderer/archlinux:latest
|
||||
|
@ -4,7 +4,6 @@
|
||||
|
||||
# $IMAGE_NAME var is injected into the build so the tag is correct.
|
||||
|
||||
export DOCKER_BUILDKIT=1
|
||||
echo "Build hook running"
|
||||
docker build --build-arg BUILD_DATE=`date -u +"%Y-%m-%dT%H:%M:%SZ"` \
|
||||
--build-arg VCS_REF=`git rev-parse --short HEAD` \
|
||||
|
Loading…
Reference in New Issue
Block a user