commit:     8e40ca8b0bac68019c4f74d5f301341b9db1cc32
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Nov 27 20:39:36 2020 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Nov 27 20:40:23 2020 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8e40ca8b

app-emulation/snapd: Bump to version 2.48

Package-Manager: Portage-3.0.10, Repoman-3.0.2
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>

 app-emulation/snapd/Manifest          |   1 +
 app-emulation/snapd/snapd-2.48.ebuild | 179 ++++++++++++++++++++++++++++++++++
 2 files changed, 180 insertions(+)

diff --git a/app-emulation/snapd/Manifest b/app-emulation/snapd/Manifest
index 2622b18e103..076c99373bb 100644
--- a/app-emulation/snapd/Manifest
+++ b/app-emulation/snapd/Manifest
@@ -1 +1,2 @@
 DIST snapd-2.47.1.tar.xz 3664756 BLAKE2B 
90cb117ea385890c38c6efdecd3652c115158ad769858ebe1a5035d37c9543da5b2a8768ce4f56cfcee053701d308f826bf7993d9b5f9d5313f2840ca829ab23
 SHA512 
e08dd7057b85b970a1177996c483d3f663b1424cdbf6643a69923a7012d38fc13109b449ce3a2c5c8d65e5836f93a36567f2f641a62caea6e9989a458f7f2892
+DIST snapd-2.48.tar.xz 3757292 BLAKE2B 
4d1fd4b9ff3bd7cf05ebf0e27db4bcc87b5de689be470b4c62758e411e9d99a541ae084c7b1afe4ede44ad6dce19a53b337dcddc18d0b82957ef537f466e720a
 SHA512 
27e1924d86296a969cd18980d6100c8e41be66f2ad0214ac2857580a2686b1e7ef01e2561c6ed532106eadb1ac2d5fd070ef9eb05e5fabfb8fa9a98456259b89

diff --git a/app-emulation/snapd/snapd-2.48.ebuild 
b/app-emulation/snapd/snapd-2.48.ebuild
new file mode 100644
index 00000000000..c1a8f5af38b
--- /dev/null
+++ b/app-emulation/snapd/snapd-2.48.ebuild
@@ -0,0 +1,179 @@
+# Copyright 2020 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=7
+
+EGO_PN="github.com/snapcore/${PN}"
+inherit autotools bash-completion-r1 golang-vcs-snapshot linux-info 
readme.gentoo-r1 systemd xdg-utils
+
+DESCRIPTION="Service and tools for management of snap packages"
+HOMEPAGE="http://snapcraft.io/";
+
+MY_S="${S}/src/github.com/snapcore/${PN}"
+
+SRC_URI="https://github.com/snapcore/${PN}/releases/download/${PV}/${PN}_${PV}.vendor.tar.xz
 -> ${P}.tar.xz"
+MY_PV=${PV}
+KEYWORDS="~amd64"
+
+LICENSE="GPL-3 Apache-2.0 BSD BSD-2 LGPL-3-with-linking-exception MIT"
+SLOT="0"
+IUSE="apparmor +cgroup-hybrid +forced-devmode gtk kde systemd"
+REQUIRED_USE="!forced-devmode? ( apparmor cgroup-hybrid ) systemd"
+
+CONFIG_CHECK="~CGROUPS
+               ~CGROUP_DEVICE
+               ~CGROUP_FREEZER
+               ~NAMESPACES
+               ~SQUASHFS
+               ~SQUASHFS_ZLIB
+               ~SQUASHFS_LZO
+               ~SQUASHFS_XZ
+               ~BLK_DEV_LOOP
+               ~SECCOMP
+               ~SECCOMP_FILTER"
+
+RDEPEND="
+       sys-libs/libseccomp:=
+       apparmor? (
+               sec-policy/apparmor-profiles
+               sys-apps/apparmor:=
+       )
+       dev-libs/glib
+       virtual/libudev
+       systemd? ( sys-apps/systemd[cgroup-hybrid(+)?] )
+       sys-libs/libcap:=
+       sys-fs/squashfs-tools"
+
+DEPEND="${RDEPEND}"
+
+BDEPEND="
+       >=dev-lang/go-1.9
+       dev-python/docutils
+       sys-devel/gettext"
+
+PDEPEND="sys-auth/polkit[gtk?,kde?]"
+
+README_GENTOO_SUFFIX=""
+
+pkg_setup() {
+       if use apparmor; then
+               CONFIG_CHECK+=" ~SECURITY_APPARMOR"
+       fi
+       linux-info_pkg_setup
+}
+
+src_prepare() {
+       default
+       # Update apparmor profile to allow libtinfow.so*
+       sed -i 's/libtinfo/libtinfo{,w}/' \
+               "${MY_S}/cmd/snap-confine/snap-confine.apparmor.in" || die
+
+       if ! use forced-devmode; then
+               sed -e 's#return \(!apparmorFull || cgroupv2\)#//\1\n\tif 
!apparmorFull || cgroupv2 {\n\t\tpanic("USE=forced-devmode is 
disabled")\n\t}\n\treturn false#' \
+                       -i "${MY_S}/sandbox/forcedevmode.go" || die
+               grep -q 'panic("USE=forced-devmode is disabled")' 
"${MY_S}/sandbox/forcedevmode.go" || die "failed to disable forced-devmode"
+       fi
+
+       sed -i 's:command -v git >/dev/null:false:' -i "${MY_S}/mkversion.sh" 
|| die
+
+       pushd "${MY_S}" >/dev/null || die
+       ./mkversion.sh "${PV}"
+       popd >/dev/null || die
+       pushd "${MY_S}/cmd" >/dev/null || die
+       eautoreconf
+}
+
+src_configure() {
+       SNAPD_MAKEARGS=(
+               "BINDIR=${EPREFIX}/usr/bin"
+               "DBUSSERVICESDIR=${EPREFIX}/usr/share/dbus-1/services"
+               "LIBEXECDIR=${EPREFIX}/usr/lib"
+               "SNAP_MOUNT_DIR=${EPREFIX}/var/lib/snapd/snap"
+               "SYSTEMDSYSTEMUNITDIR=$(systemd_get_systemunitdir)"
+       )
+       export CGO_ENABLED="1"
+       export CGO_CFLAGS="${CFLAGS}"
+       export CGO_CPPFLAGS="${CPPFLAGS}"
+       export CGO_CXXFLAGS="${CXXFLAGS}"
+
+       pushd "${MY_S}/cmd" >/dev/null || die
+       econf --libdir="${EPREFIX}/usr/lib" \
+               --libexecdir="${EPREFIX}/usr/lib/snapd" \
+               $(use_enable apparmor) \
+               --enable-nvidia-biarch \
+               --with-snap-mount-dir="${EPREFIX}/var/lib/snapd/snap"
+}
+
+src_compile() {
+       export -n GOCACHE XDG_CACHE_HOME
+       export GO111MODULE=off GOBIN="${S}/bin" GOPATH="${S}"
+
+       local file
+       for file in "${MY_S}/po/"*.po; do
+               msgfmt "${file}" -o "${file%.po}.mo" || die
+       done
+
+       emake -C "${MY_S}/data" "${SNAPD_MAKEARGS[@]}"
+
+       local -a flags=(-buildmode=pie -ldflags "-s -linkmode external 
-extldflags '${LDFLAGS}'" -trimpath)
+       local -a staticflags=(-buildmode=pie -ldflags "-s -linkmode external 
-extldflags '${LDFLAGS} -static'" -trimpath)
+
+       local cmd
+       for cmd in snap snapd snap-bootstrap snap-failure snap-preseed 
snap-recovery-chooser snap-repair snap-seccomp; do
+               go build -o "${GOBIN}/${cmd}" "${flags[@]}" \
+                   -v -x "github.com/snapcore/${PN}/cmd/${cmd}"
+               [[ -e "${GOBIN}/${cmd}" ]] || die "failed to build ${cmd}"
+       done
+       for cmd in snapctl snap-exec snap-update-ns; do
+               go build -o "${GOBIN}/${cmd}" "${staticflags[@]}" \
+                   -v -x "github.com/snapcore/${PN}/cmd/${cmd}"
+               [[ -e "${GOBIN}/${cmd}" ]] || die "failed to build ${cmd}"
+       done
+}
+
+src_install() {
+       emake -C "${MY_S}/data" install "${SNAPD_MAKEARGS[@]}" DESTDIR="${D}"
+       emake -C "${MY_S}/cmd" install "${SNAPD_MAKEARGS[@]}" DESTDIR="${D}"
+
+       if use apparmor; then
+               mv "${ED}/etc/apparmor.d/usr.lib.snapd.snap-confine"{,.real} || 
die
+               keepdir /var/lib/snapd/apparmor/profiles
+       fi
+       keepdir /var/lib/snapd/{apparmor/snap-confine,cache,cookie,snap,void}
+       fperms 700 /var/lib/snapd/{cache,cookie}
+
+       dobin "${GOBIN}/"{snap,snapctl}
+       ln "${ED}/usr/bin/snapctl" "${ED}/usr/lib/snapd/snapctl" || die
+
+       exeinto /usr/lib/snapd
+       doexe 
"${GOBIN}/"{snapd,snap-bootstrap,snap-failure,snap-exec,snap-preseed,snap-recovery-chooser,snap-repair,snap-seccomp,snap-update-ns}
 \
+               
"${MY_S}/"{cmd/snap-confine/snap-device-helper,cmd/snap-discard-ns/snap-discard-ns,cmd/snap-gdb-shim/snap-gdb-shim,cmd/snap-mgmt/snap-mgmt}
 \
+               "${MY_S}/data/completion/bash/"{complete.sh,etelpmoc.sh,}
+
+       dobashcomp "${MY_S}/data/completion/bash/snap"
+
+       insinto /usr/share/zsh/site-functions
+       doins "${MY_S}/data/completion/zsh/_snap"
+
+       insinto "/usr/share/polkit-1/actions"
+       doins "${MY_S}/data/polkit/io.snapcraft.snapd.policy"
+
+       dodoc "${MY_S}/packaging/ubuntu-16.04/changelog"
+       domo "${MY_S}/po/"*.mo
+
+       readme.gentoo_create_doc
+}
+
+pkg_postinst() {
+       readme.gentoo_print_elog
+       xdg_desktop_database_update
+
+       if use apparmor && [[ -z ${ROOT} && -e 
/sys/kernel/security/apparmor/profiles &&
+               $(wc -l < /sys/kernel/security/apparmor/profiles) -gt 0 ]]; then
+               apparmor_parser -r 
"${EPREFIX}/etc/apparmor.d/usr.lib.snapd.snap-confine.real"
+       fi
+}
+
+pkg_postrm() {
+       xdg_desktop_database_update
+}

Reply via email to