219 lines
6.1 KiB
Bash
219 lines
6.1 KiB
Bash
# Copyright 1999-2024 Gentoo Authors
|
|
# Distributed under the terms of the GNU General Public License v2
|
|
|
|
EAPI=8
|
|
|
|
inherit go-module linux-info optfeature systemd toolchain-funcs verify-sig
|
|
|
|
DESCRIPTION="Modern, secure and powerful system container and virtual machine manager"
|
|
HOMEPAGE="https://linuxcontainers.org/incus/introduction/ https://github.com/lxc/incus"
|
|
SRC_URI="https://linuxcontainers.org/downloads/incus/${P}.tar.xz
|
|
verify-sig? ( https://linuxcontainers.org/downloads/incus/${P}.tar.xz.asc )"
|
|
|
|
LICENSE="Apache-2.0 BSD LGPL-3 MIT"
|
|
SLOT="0"
|
|
KEYWORDS="~amd64 ~arm64"
|
|
IUSE="apparmor fuidshift nls"
|
|
|
|
DEPEND="acct-group/incus
|
|
acct-group/incus-admin
|
|
app-arch/xz-utils
|
|
>=app-containers/lxc-5.0.0:=[apparmor?,seccomp(+)]
|
|
dev-db/sqlite:3
|
|
>=dev-libs/cowsql-1.15.6
|
|
dev-libs/lzo
|
|
>=dev-libs/raft-0.22.1:=[lz4]
|
|
>=dev-util/xdelta-3.0[lzma(+)]
|
|
net-dns/dnsmasq[dhcp]
|
|
sys-libs/libcap
|
|
virtual/udev"
|
|
RDEPEND="${DEPEND}
|
|
fuidshift? ( !app-containers/lxd )
|
|
net-firewall/ebtables
|
|
net-firewall/iptables
|
|
sys-apps/iproute2
|
|
sys-fs/fuse:*
|
|
>=sys-fs/lxcfs-5.0.0
|
|
sys-fs/squashfs-tools[lzma]
|
|
virtual/acl"
|
|
BDEPEND=">=dev-lang/go-1.21
|
|
nls? ( sys-devel/gettext )
|
|
verify-sig? ( sec-keys/openpgp-keys-linuxcontainers )"
|
|
|
|
CONFIG_CHECK="
|
|
~CGROUPS
|
|
~IPC_NS
|
|
~NET_NS
|
|
~PID_NS
|
|
|
|
~SECCOMP
|
|
~USER_NS
|
|
~UTS_NS
|
|
|
|
~KVM
|
|
~MACVTAP
|
|
~VHOST_VSOCK
|
|
"
|
|
|
|
ERROR_IPC_NS="CONFIG_IPC_NS is required."
|
|
ERROR_NET_NS="CONFIG_NET_NS is required."
|
|
ERROR_PID_NS="CONFIG_PID_NS is required."
|
|
ERROR_SECCOMP="CONFIG_SECCOMP is required."
|
|
ERROR_UTS_NS="CONFIG_UTS_NS is required."
|
|
|
|
WARNING_KVM="CONFIG_KVM and CONFIG_KVM_AMD/-INTEL is required for virtual machines."
|
|
WARNING_MACVTAP="CONFIG_MACVTAP is required for virtual machines."
|
|
WARNING_VHOST_VSOCK="CONFIG_VHOST_VSOCK is required for virtual machines."
|
|
|
|
# Go magic.
|
|
QA_PREBUILT="/usr/bin/incus
|
|
/usr/bin/lxc-to-incus
|
|
/usr/bin/incus-agent
|
|
/usr/bin/incus-benchmark
|
|
/usr/bin/incus-migrate
|
|
/usr/sbin/fuidshift
|
|
/usr/sbin/lxd-to-incus
|
|
/usr/sbin/incusd"
|
|
|
|
VERIFY_SIG_OPENPGP_KEY_PATH=/usr/share/openpgp-keys/linuxcontainers.asc
|
|
|
|
# The testsuite must be run as root.
|
|
# make: *** [Makefile:156: check] Error 1
|
|
RESTRICT="test"
|
|
|
|
GOPATH="${S}/_dist"
|
|
|
|
src_unpack() {
|
|
verify-sig_src_unpack
|
|
go-module_src_unpack
|
|
}
|
|
|
|
src_prepare() {
|
|
export GOPATH="${S}/_dist"
|
|
|
|
default
|
|
|
|
sed -i \
|
|
-e "s:\./configure:./configure --prefix=/usr --libdir=${EPREFIX}/usr/lib/incus:g" \
|
|
-e "s:make:make ${MAKEOPTS}:g" \
|
|
Makefile || die
|
|
|
|
# Fix hardcoded ovmf file path, see bug 763180
|
|
sed -i \
|
|
-e "s:/usr/share/OVMF:/usr/share/edk2-ovmf:g" \
|
|
-e "s:OVMF_VARS.ms.fd:OVMF_VARS.fd:g" \
|
|
doc/environment.md \
|
|
internal/server/apparmor/instance.go \
|
|
internal/server/apparmor/instance_qemu.go \
|
|
internal/server/instance/drivers/driver_qemu.go || die "Failed to fix hardcoded ovmf paths."
|
|
|
|
# Fix hardcoded virtfs-proxy-helper file path, see bug 798924
|
|
sed -i \
|
|
-e "s:/usr/lib/qemu/virtfs-proxy-helper:/usr/libexec/virtfs-proxy-helper:g" \
|
|
internal/server/device/device_utils_disk.go || die "Failed to fix virtfs-proxy-helper path."
|
|
|
|
cp "${FILESDIR}"/incus-0.4.service "${T}"/incus.service || die
|
|
if use apparmor; then
|
|
sed -i \
|
|
'/^EnvironmentFile=.*/a ExecStartPre=\/usr\/libexec\/lxc\/lxc-apparmor-load' \
|
|
"${T}"/incus.service || die
|
|
fi
|
|
|
|
# Disable -Werror's from go modules.
|
|
find "${S}" -name "cgo.go" -exec sed -i "s/ -Werror / /g" {} + || die
|
|
}
|
|
|
|
src_configure() { :; }
|
|
|
|
src_compile() {
|
|
export GOPATH="${S}/_dist"
|
|
export CGO_LDFLAGS_ALLOW="-Wl,-z,now"
|
|
|
|
for k in incus-benchmark incus-simplestreams incus-user incus lxc-to-incus lxd-to-incus ; do
|
|
ego install -v -x "${S}/cmd/${k}"
|
|
done
|
|
|
|
if use fuidshift ; then
|
|
ego install -v -x "${S}/cmd/fuidshift"
|
|
fi
|
|
|
|
ego install -v -x -tags libsqlite3 "${S}"/cmd/incusd
|
|
|
|
# Needs to be built statically
|
|
CGO_ENABLED=0 go install -v -tags netgo "${S}"/cmd/incus-migrate
|
|
CGO_ENABLED=0 go install -v -tags agent,netgo "${S}"/cmd/incus-agent
|
|
|
|
use nls && emake build-mo
|
|
}
|
|
|
|
src_test() {
|
|
emake check
|
|
}
|
|
|
|
src_install() {
|
|
export GOPATH="${S}/_dist"
|
|
|
|
if tc-is-cross-compiler ; then
|
|
local bindir="_dist/bin/linux_${GOARCH}"
|
|
else
|
|
local bindir="_dist/bin"
|
|
fi
|
|
|
|
newsbin "${FILESDIR}"/incus-startup-0.4.sh incus-startup
|
|
|
|
# Admin tools
|
|
for l in incusd incus-user lxd-to-incus ; do
|
|
dosbin ${bindir}/${l}
|
|
done
|
|
|
|
# User tools
|
|
for m in incus-agent incus-benchmark incus-migrate incus-simplestreams incus lxc-to-incus ; do
|
|
dobin ${bindir}/${m}
|
|
done
|
|
|
|
# fuidshift, should be moved under admin tools at some point
|
|
if use fuidshift ; then
|
|
dosbin ${bindir}/fuidshift
|
|
fi
|
|
|
|
newconfd "${FILESDIR}"/incus-0.4.confd incus
|
|
newinitd "${FILESDIR}"/incus-0.4.initd incus
|
|
newinitd "${FILESDIR}"/incus-user-0.4.initd incus-user
|
|
|
|
systemd_dounit "${T}"/incus.service
|
|
systemd_newunit "${FILESDIR}"/incus-0.4.socket incus.socket
|
|
systemd_newunit "${FILESDIR}"/incus-startup-0.4.service incus-startup.service
|
|
systemd_newunit "${FILESDIR}"/incus-user-0.4.service incus-user.service
|
|
systemd_newunit "${FILESDIR}"/incus-user-0.4.socket incus-user.socket
|
|
|
|
if ! tc-is-cross-compiler; then
|
|
# Generate and install shell completion files.
|
|
mkdir -p "${D}"/usr/share/{bash-completion/completions/,fish/vendor_completions.d/,zsh/site-functions/} || die
|
|
"${bindir}"/incus completion bash > "${D}"/usr/share/bash-completion/completions/incus || die
|
|
"${bindir}"/incus completion fish > "${D}"/usr/share/fish/vendor_completions.d/incus.fish || die
|
|
"${bindir}"/incus completion zsh > "${D}"/usr/share/zsh/site-functions/_incus || die
|
|
else
|
|
ewarn "Shell completion files not installed! Install them manually with incus completion --help"
|
|
fi
|
|
|
|
dodoc AUTHORS
|
|
dodoc -r doc/*
|
|
use nls && domo po/*.mo
|
|
}
|
|
|
|
pkg_postinst() {
|
|
elog
|
|
elog "Please see"
|
|
elog " https://wiki.gentoo.org/wiki/Incus"
|
|
elog " https://wiki.gentoo.org/wiki/Incus#Migrating_from_LXD"
|
|
elog
|
|
optfeature "virtual machine support" app-cdr/cdrtools app-emulation/qemu[spice,usbredir,virtfs]
|
|
optfeature "btrfs storage backend" sys-fs/btrfs-progs
|
|
optfeature "ipv6 support" net-dns/dnsmasq[ipv6]
|
|
optfeature "full incus-migrate support" net-misc/rsync
|
|
optfeature "lvm2 storage backend" sys-fs/lvm2
|
|
optfeature "zfs storage backend" sys-fs/zfs
|
|
elog
|
|
elog "Be sure to add your local user to the incus group."
|
|
elog
|
|
}
|