1 |
commit: 1245cf9ab1b337e86000f52a76723e247ce9a1f4 |
2 |
Author: Zac Medico <zmedico <AT> gentoo <DOT> org> |
3 |
AuthorDate: Fri Dec 2 04:14:26 2022 +0000 |
4 |
Commit: Zac Medico <zmedico <AT> gentoo <DOT> org> |
5 |
CommitDate: Fri Dec 2 04:14:48 2022 +0000 |
6 |
URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1245cf9a |
7 |
|
8 |
app-containers/snapd: add 2.58 |
9 |
|
10 |
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org> |
11 |
|
12 |
app-containers/snapd/Manifest | 1 + |
13 |
app-containers/snapd/snapd-2.58.ebuild | 179 +++++++++++++++++++++++++++++++++ |
14 |
2 files changed, 180 insertions(+) |
15 |
|
16 |
diff --git a/app-containers/snapd/Manifest b/app-containers/snapd/Manifest |
17 |
index e71239cee87f..74411fae3f80 100644 |
18 |
--- a/app-containers/snapd/Manifest |
19 |
+++ b/app-containers/snapd/Manifest |
20 |
@@ -1 +1,2 @@ |
21 |
DIST snapd-2.57.6.tar.xz 6889052 BLAKE2B 5d1190f3d1ccc6446f950cc95c09180707c3a96285bcdd197aef06b2d69cfef6daf85a93844f105dd434b29b73d3b9c832dfcbebcdc2451443eb5421046de849 SHA512 cd74fa92cddff3452448a50536ded504c68ca6f786b465b8561ccc43c02856742a895efb71bf92b8d125173e0d083faf61ca563f69da03ebf3c4df1b0b0b8d5e |
22 |
+DIST snapd-2.58.tar.xz 6980916 BLAKE2B d3de507513db808fa4f85498b5c238de143f06660f1d677186c8c763b38643a2486e25b747977b3eb584619d79ea0a12e88dc5a909045a853c1d8f849f2c1638 SHA512 555915b8b4d9d2d91a3ba19e9e78cf6b19d9683a9f390ad225aa5876320cb8595b464d6133706c4923fc15fbe04ba2b65a47e403c9a2d8859adae827f8ec000a |
23 |
|
24 |
diff --git a/app-containers/snapd/snapd-2.58.ebuild b/app-containers/snapd/snapd-2.58.ebuild |
25 |
new file mode 100644 |
26 |
index 000000000000..e6878325b6d7 |
27 |
--- /dev/null |
28 |
+++ b/app-containers/snapd/snapd-2.58.ebuild |
29 |
@@ -0,0 +1,179 @@ |
30 |
+# Copyright 2020-2022 Gentoo Authors |
31 |
+# Distributed under the terms of the GNU General Public License v2 |
32 |
+ |
33 |
+EAPI=7 |
34 |
+ |
35 |
+inherit autotools bash-completion-r1 flag-o-matic go-module linux-info readme.gentoo-r1 systemd tmpfiles xdg-utils |
36 |
+ |
37 |
+DESCRIPTION="Service and tools for management of snap packages" |
38 |
+HOMEPAGE="http://snapcraft.io/" |
39 |
+ |
40 |
+SRC_URI="https://github.com/snapcore/${PN}/releases/download/${PV}/${PN}_${PV}.vendor.tar.xz -> ${P}.tar.xz" |
41 |
+MY_PV=${PV} |
42 |
+KEYWORDS="~amd64" |
43 |
+ |
44 |
+LICENSE="GPL-3 Apache-2.0 BSD BSD-2 LGPL-3-with-linking-exception MIT" |
45 |
+SLOT="0" |
46 |
+IUSE="apparmor +forced-devmode gtk kde systemd" |
47 |
+REQUIRED_USE="!forced-devmode? ( apparmor ) systemd" |
48 |
+ |
49 |
+CONFIG_CHECK="~CGROUPS |
50 |
+ ~CGROUP_DEVICE |
51 |
+ ~CGROUP_FREEZER |
52 |
+ ~NAMESPACES |
53 |
+ ~SQUASHFS |
54 |
+ ~SQUASHFS_ZLIB |
55 |
+ ~SQUASHFS_LZO |
56 |
+ ~SQUASHFS_XZ |
57 |
+ ~BLK_DEV_LOOP |
58 |
+ ~SECCOMP |
59 |
+ ~SECCOMP_FILTER" |
60 |
+ |
61 |
+RDEPEND=" |
62 |
+ sys-libs/libseccomp:= |
63 |
+ apparmor? ( |
64 |
+ sec-policy/apparmor-profiles |
65 |
+ sys-apps/apparmor:= |
66 |
+ ) |
67 |
+ dev-libs/glib |
68 |
+ virtual/libudev |
69 |
+ systemd? ( sys-apps/systemd ) |
70 |
+ sys-libs/libcap:= |
71 |
+ sys-fs/squashfs-tools[lzma]" |
72 |
+ |
73 |
+DEPEND="${RDEPEND}" |
74 |
+ |
75 |
+BDEPEND=" |
76 |
+ >=dev-lang/go-1.9 |
77 |
+ dev-python/docutils |
78 |
+ sys-devel/gettext |
79 |
+ sys-fs/xfsprogs" |
80 |
+ |
81 |
+PDEPEND="sys-auth/polkit[gtk?,kde?]" |
82 |
+ |
83 |
+README_GENTOO_SUFFIX="" |
84 |
+ |
85 |
+pkg_setup() { |
86 |
+ if use apparmor; then |
87 |
+ CONFIG_CHECK+=" ~SECURITY_APPARMOR" |
88 |
+ fi |
89 |
+ linux-info_pkg_setup |
90 |
+ |
91 |
+ # Seems to have issues building with -O3, switch to -O2 |
92 |
+ replace-flags -O3 -O2 |
93 |
+} |
94 |
+ |
95 |
+src_prepare() { |
96 |
+ default |
97 |
+ # Update apparmor profile to allow libtinfow.so* |
98 |
+ sed -i 's/libtinfo/libtinfo{,w}/' \ |
99 |
+ "cmd/snap-confine/snap-confine.apparmor.in" || die |
100 |
+ |
101 |
+ if ! use forced-devmode; then |
102 |
+ sed -e 's#return !apparmorFull#if !apparmorFull {\n\t\tpanic("USE=forced-devmode is disabled")\n\t}\n\treturn false#' \ |
103 |
+ -i "sandbox/forcedevmode.go" || die |
104 |
+ grep -q 'panic("USE=forced-devmode is disabled")' "sandbox/forcedevmode.go" || die "failed to disable forced-devmode" |
105 |
+ fi |
106 |
+ |
107 |
+ sed -i 's:command -v git >/dev/null:false:' -i "mkversion.sh" || die |
108 |
+ |
109 |
+ ./mkversion.sh "${PV}" |
110 |
+ pushd "cmd" >/dev/null || die |
111 |
+ eautoreconf |
112 |
+} |
113 |
+ |
114 |
+src_configure() { |
115 |
+ SNAPD_MAKEARGS=( |
116 |
+ "BINDIR=${EPREFIX}/usr/bin" |
117 |
+ "DBUSSERVICESDIR=${EPREFIX}/usr/share/dbus-1/services" |
118 |
+ "LIBEXECDIR=${EPREFIX}/usr/lib" |
119 |
+ "SNAP_MOUNT_DIR=${EPREFIX}/var/lib/snapd/snap" |
120 |
+ "SYSTEMDSYSTEMUNITDIR=$(systemd_get_systemunitdir)" |
121 |
+ ) |
122 |
+ export CGO_ENABLED="1" |
123 |
+ export CGO_CFLAGS="${CFLAGS}" |
124 |
+ export CGO_CPPFLAGS="${CPPFLAGS}" |
125 |
+ export CGO_CXXFLAGS="${CXXFLAGS}" |
126 |
+ |
127 |
+ pushd "${S}/cmd" >/dev/null || die |
128 |
+ econf --libdir="${EPREFIX}/usr/lib" \ |
129 |
+ --libexecdir="${EPREFIX}/usr/lib/snapd" \ |
130 |
+ $(use_enable apparmor) \ |
131 |
+ --enable-nvidia-biarch \ |
132 |
+ --with-snap-mount-dir="${EPREFIX}/var/lib/snapd/snap" |
133 |
+} |
134 |
+ |
135 |
+src_compile() { |
136 |
+ export -n GOCACHE XDG_CACHE_HOME |
137 |
+ export GOBIN="${S}/bin" |
138 |
+ |
139 |
+ local file |
140 |
+ for file in "${S}/po/"*.po; do |
141 |
+ msgfmt "${file}" -o "${file%.po}.mo" || die |
142 |
+ done |
143 |
+ |
144 |
+ emake -C "${S}/data" "${SNAPD_MAKEARGS[@]}" |
145 |
+ |
146 |
+ local -a flags=(-buildmode=pie -ldflags "-s -linkmode external -extldflags '${LDFLAGS}'" -trimpath) |
147 |
+ local -a staticflags=(-buildmode=pie -ldflags "-s -linkmode external -extldflags '${LDFLAGS} -static'" -trimpath) |
148 |
+ |
149 |
+ local cmd |
150 |
+ for cmd in snap snapd snapd-apparmor snap-bootstrap snap-failure snap-preseed snap-recovery-chooser snap-repair snap-seccomp; do |
151 |
+ go build ${GOFLAGS} -mod=vendor -o "${GOBIN}/${cmd}" "${flags[@]}" \ |
152 |
+ -v -x "github.com/snapcore/${PN}/cmd/${cmd}" |
153 |
+ [[ -e "${GOBIN}/${cmd}" ]] || die "failed to build ${cmd}" |
154 |
+ done |
155 |
+ for cmd in snapctl snap-exec snap-update-ns; do |
156 |
+ go build ${GOFLAGS} -mod=vendor -o "${GOBIN}/${cmd}" "${staticflags[@]}" \ |
157 |
+ -v -x "github.com/snapcore/${PN}/cmd/${cmd}" |
158 |
+ [[ -e "${GOBIN}/${cmd}" ]] || die "failed to build ${cmd}" |
159 |
+ done |
160 |
+} |
161 |
+ |
162 |
+src_install() { |
163 |
+ emake -C "${S}/data" install "${SNAPD_MAKEARGS[@]}" DESTDIR="${D}" |
164 |
+ emake -C "${S}/cmd" install "${SNAPD_MAKEARGS[@]}" DESTDIR="${D}" |
165 |
+ |
166 |
+ if use apparmor; then |
167 |
+ mv "${ED}/etc/apparmor.d/usr.lib.snapd.snap-confine"{,.real} || die |
168 |
+ keepdir /var/lib/snapd/apparmor/profiles |
169 |
+ fi |
170 |
+ keepdir /var/lib/snapd/{apparmor/snap-confine,cache,cookie,snap,void} |
171 |
+ fperms 700 /var/lib/snapd/{cache,cookie} |
172 |
+ |
173 |
+ dobin "${GOBIN}/"{snap,snapctl} |
174 |
+ ln "${ED}/usr/bin/snapctl" "${ED}/usr/lib/snapd/snapctl" || die |
175 |
+ |
176 |
+ exeinto /usr/lib/snapd |
177 |
+ doexe "${GOBIN}/"{snapd,snapd-apparmor,snap-bootstrap,snap-failure,snap-exec,snap-preseed,snap-recovery-chooser,snap-repair,snap-seccomp,snap-update-ns} \ |
178 |
+ "${S}/"{cmd/snap-discard-ns/snap-discard-ns,cmd/snap-gdb-shim/snap-gdb-shim,cmd/snap-mgmt/snap-mgmt} \ |
179 |
+ "${S}/data/completion/bash/"{complete.sh,etelpmoc.sh,} |
180 |
+ |
181 |
+ dobashcomp "${S}/data/completion/bash/snap" |
182 |
+ |
183 |
+ insinto /usr/share/zsh/site-functions |
184 |
+ doins "${S}/data/completion/zsh/_snap" |
185 |
+ |
186 |
+ insinto "/usr/share/polkit-1/actions" |
187 |
+ doins "${S}/data/polkit/io.snapcraft.snapd.policy" |
188 |
+ |
189 |
+ dodoc "${S}/packaging/ubuntu-16.04/changelog" |
190 |
+ domo "${S}/po/"*.mo |
191 |
+ |
192 |
+ readme.gentoo_create_doc |
193 |
+} |
194 |
+ |
195 |
+pkg_postinst() { |
196 |
+ readme.gentoo_print_elog |
197 |
+ xdg_desktop_database_update |
198 |
+ tmpfiles_process snapd.conf |
199 |
+ |
200 |
+ if use apparmor && [[ -z ${ROOT} && -e /sys/kernel/security/apparmor/profiles && |
201 |
+ $(wc -l < /sys/kernel/security/apparmor/profiles) -gt 0 ]]; then |
202 |
+ apparmor_parser -r "${EPREFIX}/etc/apparmor.d/usr.lib.snapd.snap-confine.real" |
203 |
+ fi |
204 |
+} |
205 |
+ |
206 |
+pkg_postrm() { |
207 |
+ xdg_desktop_database_update |
208 |
+} |