aports/community/docker/APKBUILD
Jake Buchholz Göktürk 6b816c6a7b fix trailing spaces
2025-06-01 14:11:43 +00:00

207 lines
6 KiB
Text

# Contributor: Eivind Uggedal <eu@eju.no>
# Contributor: Jake Buchholz Göktürk <tomalok@gmail.com>
# Maintainer: Jake Buchholz Göktürk <tomalok@gmail.com>
pkgname=docker
pkgver=28.2.2
_cli_commit=e6534b4eb700e592f25e7213568a02f3ce37460d # https://github.com/docker/cli/releases/tag/v$pkgver
_moby_commit=45873be4ae3f5488c9498b3d9f17deaddaf609f4 # https://github.com/moby/moby/cli/releases/tag/v$pkgver
pkgrel=0
pkgdesc="Pack, ship and run any application as a lightweight container"
url="https://www.docker.io/"
arch="all"
license="Apache-2.0"
_engine_deps="ca-certificates containerd iptables tini-static"
depends="docker-engine=$pkgver-r$pkgrel docker-cli=$pkgver-r$pkgrel docker-cli-buildx"
makedepends="go btrfs-progs-dev bash linux-headers coreutils lvm2-dev libtool libseccomp-dev
$_engine_deps"
options="net chmod-clean"
install="$pkgname-engine.pre-install"
# secfixes:
# 27.1.1-r0:
# - CVE-2024-41110
# 26.0.2-r0:
# - CVE-2024-32473
# 26.0.0-r0:
# - CVE-2024-29018
# 25.0.2-r0:
# - CVE-2024-23651
# - CVE-2024-23652
# - CVE-2024-23653
# - CVE-2024-23650
# - CVE-2024-24557
# 23.0.3-r0:
# - CVE-2023-28840
# - CVE-2023-28841
# - CVE-2023-28842
# 23.0.2-r0:
# - CVE-2023-26054
# 20.10.20-r0:
# - CVE-2022-39253
# 20.10.18-r0:
# - CVE-2022-36109
# 20.10.16-r0:
# - CVE-2022-29526
# 20.10.14-r0:
# - CVE-2022-24769
# 20.10.11-r0:
# - CVE-2021-41190
# 20.10.9-r0:
# - CVE-2021-41089
# - CVE-2021-41091
# - CVE-2021-41092
# 20.10.3-r0:
# - CVE-2021-21285
# - CVE-2021-21284
# 19.03.14-r0:
# - CVE-2020-15257
# 19.03.11-r0:
# - CVE-2020-13401
# 19.03.1-r0:
# - CVE-2019-14271
# 18.09.8-r0:
# - CVE-2019-13509
# 18.09.7-r0:
# - CVE-2018-15664
subpackages="
$pkgname-engine:engine
$pkgname-openrc:engine_openrc:noarch
$pkgname-cli:cli
$pkgname-doc:cli_doc:noarch
$pkgname-bash-completion
$pkgname-fish-completion
$pkgname-zsh-completion
$pkgname-rootless-extras:rootless
"
source="
cli-$pkgver.tar.gz::https://github.com/docker/cli/archive/v$pkgver.tar.gz
moby-$pkgver.tar.gz::https://github.com/moby/moby/archive/v$pkgver.tar.gz
docker.initd
docker.confd
docker-rootless-extras.conf
"
builddir="$srcdir"
_cli_builddir="$srcdir/cli-$pkgver"
_moby_builddir="$srcdir/moby-$pkgver"
_buildtags="seccomp"
export GO111MODULE=off # go1.16 defaults to on
export GOCACHE="${GOCACHE:-"$srcdir/go-cache"}"
export GOTMPDIR="${GOTMPDIR:-"$srcdir"}"
export GOMODCACHE="${GOMODCACHE:-"$srcdir/go"}"
export CGO_ENABLED=1 # go1.22 needs this
build() {
export AUTO_GOPATH=1
export GITCOMMIT=$_cli_commit # for cli
export DOCKER_GITCOMMIT=$_moby_commit # for moby
export DOCKER_BUILDTAGS=$_buildtags
export DISABLE_WARN_OUTSIDE_CONTAINER=1
unset CC # prevent possible ccache issues
case "$CARCH" in
armv7) export GOARM=7;;
esac
# engine (moby)
msg "building engine"
cd "$_moby_builddir"
mkdir -p src/github.com/docker/
ln -sf "$_moby_builddir" src/github.com/docker/docker
GOPATH="$PWD" VERSION="$pkgver" hack/make.sh dynbinary
# Required for building man-pages
export GOPATH="$_cli_builddir"
export GOBIN="$GOPATH/bin"
export PATH="$GOBIN:$PATH"
# cli
msg "building cli"
cd "$_cli_builddir"
mkdir -p "$GOPATH"/src/github.com/docker/
ln -sf "$_cli_builddir" "$GOPATH"/src/github.com/docker/cli
LDFLAGS="" make VERSION="$pkgver" dynbinary
# docker man
msg "building docker man pages"
make manpages
}
package() {
install -Dm644 "$_cli_builddir"/contrib/completion/fish/$pkgname.fish \
"$pkgdir"/usr/share/fish/vendor_completions.d/$pkgname.fish
install -Dm644 "$_cli_builddir"/contrib/completion/zsh/_$pkgname \
"$pkgdir"/usr/share/zsh/site-functions/_$pkgname
install -Dm644 "$_cli_builddir"/contrib/completion/bash/$pkgname \
"$pkgdir"/usr/share/bash-completion/completions/$pkgname
install -Dm644 "$_cli_builddir"/man/man1/* \
-t "$pkgdir"/usr/share/man/man1/
# 'build/docker' is a symlink to 'docker-linux-$arch' e.g. 'docker-linux-amd64'
install -Dm755 "$_cli_builddir"/build/docker \
"$pkgdir"/usr/bin/docker
install -Dm755 -t "$pkgdir"/usr/bin \
"$_moby_builddir"/bundles/dynbinary-daemon/dockerd \
"$_moby_builddir"/bundles/dynbinary-daemon/docker-proxy
# symlink externally provided tini-static binary
ln -sf /sbin/tini-static "$pkgdir"/usr/bin/docker-init
install -Dm755 "$srcdir"/docker.initd "$pkgdir"/etc/init.d/docker
install -Dm644 "$srcdir"/docker.confd "$pkgdir"/etc/conf.d/docker
}
engine() {
pkgdesc="Docker Engine (dockerd)"
depends="$_engine_deps"
amove \
usr/bin/dockerd \
usr/bin/docker-init \
usr/bin/docker-proxy
}
engine_openrc() {
default_openrc
depends="log_proxy"
install_if="openrc $pkgname-engine=$pkgver-r$pkgrel"
}
cli() {
pkgdesc="Docker CLI"
depends="ca-certificates"
amove usr/bin/docker
}
cli_doc() {
default_doc
pkgdesc="Documentation for Docker"
install_if="docs $pkgname-cli=$pkgver-r$pkgrel"
}
rootless() {
pkgdesc="Extras to run docker as in rootless mode"
url="https://docs.docker.com/engine/security/rootless/"
arch="noarch"
depends="$pkgname rootlesskit slirp4netns fuse-overlayfs"
install -Dm755 "$srcdir/moby-$pkgver/contrib/dockerd-rootless.sh" "$subpkgdir/usr/bin/dockerd-rootless"
install -Dm644 "$srcdir/docker-rootless-extras.conf" "$subpkgdir/etc/modules-load.d/docker-rootless-extras.conf"
}
sha512sums="
1ba62398322c65e6994c0c6821b912c9a9b215083593d63557c5255064c407bd25f72044336ebb19977fe6d03215ec47174c6617890a817b9e34ed010535fb6b cli-28.2.2.tar.gz
e63ce38bb7badb01de918f678ad9fb216b279170177fe7d7c4120c8a1196add485cc974f9dff239a274220ebab60a2dc6852f07dc2ddafe8cec07c65dbd19a49 moby-28.2.2.tar.gz
dd499b92058fc4d7d19e0c9030b1f390f58ac40be423442732cb7d02067ed2e43c464511772a21d4f347ec34f037ddd00cc1243dc41c8ce85151ac6142611d61 docker.initd
43432a05e5776910d45364aee9070932aa89f70eb9e69d3b7ed8e17d9a70eaed4c8c29b3524888214c7ddba592399e781a72255f7eb8fafd80c9f532a9481fac docker.confd
45499bbd9d607cb782b014a2d5697d7279f327ac630accf249a13785d91e15fb0ba1ae2edc10b6b42fcf40b7ce23ef160a40d8cda17b3084d68fe8c54a84b8f4 docker-rootless-extras.conf
"