180 lines
5.2 KiB
Bash
180 lines
5.2 KiB
Bash
# Copyright 1999-2018 Gentoo Foundation
|
|
# Distributed under the terms of the GNU General Public License v2
|
|
|
|
EAPI=6
|
|
|
|
DESCRIPTION="Fast, dense and secure container management"
|
|
HOMEPAGE="https://linuxcontainers.org/lxd/introduction/"
|
|
|
|
LICENSE="Apache-2.0 BSD BSD-2 LGPL-3 MIT MPL-2.0"
|
|
SLOT="0"
|
|
KEYWORDS="~amd64"
|
|
|
|
IUSE="+daemon +ipv6 +dnsmasq nls test"
|
|
|
|
inherit bash-completion-r1 linux-info systemd user
|
|
|
|
SRC_URI="https://linuxcontainers.org/downloads/${PN}/${P}.tar.gz"
|
|
|
|
DEPEND="
|
|
>=dev-lang/go-1.9.4
|
|
dev-libs/protobuf
|
|
nls? ( sys-devel/gettext )
|
|
test? (
|
|
app-misc/jq
|
|
net-misc/curl
|
|
sys-devel/gettext
|
|
)
|
|
"
|
|
|
|
RDEPEND="
|
|
daemon? (
|
|
app-arch/xz-utils
|
|
>=app-emulation/lxc-2.0.7[seccomp]
|
|
dnsmasq? (
|
|
net-dns/dnsmasq[dhcp,ipv6?]
|
|
)
|
|
net-misc/rsync[xattr]
|
|
sys-apps/iproute2[ipv6?]
|
|
sys-fs/squashfs-tools
|
|
virtual/acl
|
|
)
|
|
"
|
|
|
|
CONFIG_CHECK="
|
|
~BRIDGE
|
|
~DUMMY
|
|
~IP6_NF_NAT
|
|
~IP6_NF_TARGET_MASQUERADE
|
|
~IPV6
|
|
~IP_NF_NAT
|
|
~IP_NF_TARGET_MASQUERADE
|
|
~MACVLAN
|
|
~NETFILTER_XT_MATCH_COMMENT
|
|
~NET_IPGRE
|
|
~NET_IPGRE_DEMUX
|
|
~NET_IPIP
|
|
~NF_NAT_MASQUERADE_IPV4
|
|
~NF_NAT_MASQUERADE_IPV6
|
|
~VXLAN
|
|
"
|
|
|
|
ERROR_BRIDGE="BRIDGE: needed for network commands"
|
|
ERROR_DUMMY="DUMMY: needed for network commands"
|
|
ERROR_IP6_NF_NAT="IP6_NF_NAT: needed for network commands"
|
|
ERROR_IP6_NF_TARGET_MASQUERADE="IP6_NF_TARGET_MASQUERADE: needed for network commands"
|
|
ERROR_IPV6="IPV6: needed for network commands"
|
|
ERROR_IP_NF_NAT="IP_NF_NAT: needed for network commands"
|
|
ERROR_IP_NF_TARGET_MASQUERADE="IP_NF_TARGET_MASQUERADE: needed for network commands"
|
|
ERROR_MACVLAN="MACVLAN: needed for network commands"
|
|
ERROR_NETFILTER_XT_MATCH_COMMENT="NETFILTER_XT_MATCH_COMMENT: needed for network commands"
|
|
ERROR_NET_IPGRE="NET_IPGRE: needed for network commands"
|
|
ERROR_NET_IPGRE_DEMUX="NET_IPGRE_DEMUX: needed for network commands"
|
|
ERROR_NET_IPIP="NET_IPIP: needed for network commands"
|
|
ERROR_NF_NAT_MASQUERADE_IPV4="NF_NAT_MASQUERADE_IPV4: needed for network commands"
|
|
ERROR_NF_NAT_MASQUERADE_IPV6="NF_NAT_MASQUERADE_IPV6: needed for network commands"
|
|
ERROR_VXLAN="VXLAN: needed for network commands"
|
|
|
|
EGO_PN="github.com/lxc/lxd"
|
|
|
|
PATCHES=(
|
|
"${FILESDIR}/ja-translation-newline.patch" # https://github.com/lxc/lxd/pull/4572
|
|
)
|
|
|
|
# LXD tarball is packaged with a nice "dist" folder containing all dependencies
|
|
# that were vendored by upstream at release time. That saves us the trouble of
|
|
# vendoring the dependencies ourselves. This is why there was this drastic drop
|
|
# in ebuild complexity compared to pre 3.0.0-r2 ebuilds.
|
|
src_compile() {
|
|
export GOPATH="${S}/dist"
|
|
|
|
# We don't use the Makefile here because it builds targets with the
|
|
# assumption that `pwd` is in a deep gopath namespace, which we're not.
|
|
# It's simpler to manually call "go install" than patching the Makefile.
|
|
#
|
|
# ABOUT "-tags libsqlite3": we used to link to the system's sqlite3 library
|
|
# but since v3.0.0, LXD depends on github.com/CanonicalLtd/dqlite which
|
|
# at the time of this writing, depends on patched version of sqlite with
|
|
# replication capabilities added. We don't have that patch in dev-db/sqlite.
|
|
# Therefore, we let LXD use its own private copy of sqlite.
|
|
go install -v -x ${EGO_PN}/lxc || die "Failed to build the client"
|
|
|
|
if use daemon; then
|
|
go install -v -x ${EGO_PN}/fuidshift || die "Failed to build fuidshift"
|
|
go install -v -x ${EGO_PN}/lxd || die "Failed to build the daemon"
|
|
fi
|
|
|
|
use nls && emake build-mo
|
|
}
|
|
|
|
src_test() {
|
|
if use daemon; then
|
|
export GOPATH="${S}/dist"
|
|
# This is mostly a copy/paste from the Makefile's "check" rule, but
|
|
# patching the Makefile to work in a non "fully-qualified" go namespace
|
|
# was more complicated than this modest copy/paste.
|
|
# Also: sorry, for now a network connection is needed to run tests.
|
|
# Will properly bundle test dependencies later.
|
|
go get -v -x github.com/rogpeppe/godeps
|
|
go get -v -x github.com/remyoudompheng/go-misc/deadcode
|
|
go get -v -x github.com/golang/lint/golint
|
|
go test -v ${EGO_PN}/lxd
|
|
else
|
|
einfo "No tests to run for client-only builds"
|
|
fi
|
|
}
|
|
|
|
src_install() {
|
|
local bindir="dist/bin"
|
|
dobin ${bindir}/lxc
|
|
if use daemon; then
|
|
dosbin ${bindir}/lxd
|
|
dobin ${bindir}/fuidshift
|
|
fi
|
|
|
|
if use nls; then
|
|
domo po/*.mo
|
|
fi
|
|
|
|
if use daemon; then
|
|
newinitd "${FILESDIR}"/${PN}.initd lxd
|
|
newconfd "${FILESDIR}"/${PN}.confd.1 lxd
|
|
|
|
systemd_newunit "${FILESDIR}"/${PN}.service ${PN}.service
|
|
fi
|
|
|
|
newbashcomp scripts/bash/lxd-client lxc
|
|
|
|
dodoc AUTHORS README.md doc/*
|
|
}
|
|
|
|
pkg_postinst() {
|
|
einfo
|
|
einfo "Consult https://wiki.gentoo.org/wiki/LXD for more information,"
|
|
einfo "including a Quick Start."
|
|
|
|
# The messaging below only applies to daemon installs
|
|
use daemon || return 0
|
|
|
|
# The control socket will be owned by (and writeable by) this group.
|
|
enewgroup lxd
|
|
|
|
# Ubuntu also defines an lxd user but it appears unused (the daemon
|
|
# must run as root)
|
|
|
|
einfo
|
|
einfo "Though not strictly required, some features are enabled at run-time"
|
|
einfo "when the relevant helper programs are detected:"
|
|
einfo "- sys-apps/apparmor"
|
|
einfo "- sys-fs/btrfs-progs"
|
|
einfo "- sys-fs/lvm2"
|
|
einfo "- sys-fs/lxcfs"
|
|
einfo "- sys-fs/zfs"
|
|
einfo "- sys-process/criu"
|
|
einfo
|
|
einfo "Since these features can't be disabled at build-time they are"
|
|
einfo "not USE-conditional."
|
|
einfo
|
|
einfo "Networks with bridge.mode=fan are unsupported due to requiring"
|
|
einfo "a patched kernel and iproute2."
|
|
}
|