sys-libs/libsemanage: bump to 3.0
authorJason Zaman <perfinion@gentoo.org>
Sun, 8 Dec 2019 14:17:32 +0000 (22:17 +0800)
committerJason Zaman <perfinion@gentoo.org>
Sun, 8 Dec 2019 17:26:10 +0000 (01:26 +0800)
Package-Manager: Portage-2.3.79, Repoman-2.3.16
Signed-off-by: Jason Zaman <perfinion@gentoo.org>
sys-libs/libsemanage/Manifest
sys-libs/libsemanage/libsemanage-3.0.ebuild [new file with mode: 0644]

index e35e6a1ccfd0321a9ee12cfefdeee151dd4f3c64..bb70a1bd9e76918a41c0efc6679d4862c9413973 100644 (file)
@@ -1,3 +1,4 @@
 DIST libsemanage-2.8.tar.gz 154200 BLAKE2B db987e42aed7177cd9b3d1e495c97878a816fe78d7c73631f475649d0ab4182e5966a9ee691f2d59863eab2b7a62f608bc00f0789f22401a54f18b41f6ebfb68 SHA512 53f09c79da168a79b853f55e0f1c20a96229df9d82929c514bcaf72697446ae836f7f0457fc0056d2418cc6d0712157faf0152881518fe84a1b1b9b9af17e7ef
 DIST libsemanage-2.9.tar.gz 157690 BLAKE2B 98a7800a4f4a5b6eeaad8be9870a49bc697cec6cd053cb44bcd618d22146ed1adc32b432667f8fd245ac073a458e048894cbaf68903b79577bc8596b1c255f56 SHA512 ea2924e8ce97d376519d40d499145b3db413cf9cc1eb995ed338b95c131e043d8c43b87b2012cee2bb6354a6e3161ebf5ce4a1200278d3ecd4294b43d177a5c2
 DIST libsemanage-3.0-rc2.tar.gz 180773 BLAKE2B f45b95f40774aea22f1648ae7c6b409b861a9f5453dfc26b4dad358e9cf60f1b3d981c695e58c861b4b496f8e88e0b3fc17a7ec5d86cb9d9ace7bec397e53d08 SHA512 8abe6fffe7a79a15430f4a36c325a7d0d10310ff1e57d2428ac61144eb16a0fe7807a78d8f1a6793bbb5c7e2a0c136528406fcbcb2d37596b8be6dfd36a3a1be
+DIST libsemanage-3.0.tar.gz 180745 BLAKE2B a7e7f0c98e365fcc132e2e66de736db29b46599be2da227dbf1384110a607120f141975b859e55073f734e3ff533bdf90b7bbefd79f7bc5857bbb0722a75ad4e SHA512 f960e1bd6815d3c9f000efa7ae717bc7937e742af5a7fea4aa865cf1aee49486e34897d83dbdb9cf77975a09a5ad77e5512d47690a74512a468a89432b72a42c
diff --git a/sys-libs/libsemanage/libsemanage-3.0.ebuild b/sys-libs/libsemanage/libsemanage-3.0.ebuild
new file mode 100644 (file)
index 0000000..61acc2a
--- /dev/null
@@ -0,0 +1,135 @@
+# Copyright 1999-2019 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI="6"
+PYTHON_COMPAT=( python{3_5,3_6,3_7,3_8} )
+
+inherit multilib python-r1 toolchain-funcs multilib-minimal
+
+MY_P="${P//_/-}"
+MY_RELEASEDATE="20191204"
+
+SEPOL_VER="${PV}"
+SELNX_VER="${PV}"
+
+DESCRIPTION="SELinux kernel and policy management library"
+HOMEPAGE="https://github.com/SELinuxProject/selinux/wiki"
+
+if [[ ${PV} == 9999 ]]; then
+       inherit git-r3
+       EGIT_REPO_URI="https://github.com/SELinuxProject/selinux.git"
+       S="${WORKDIR}/${MY_P}/${PN}"
+else
+       SRC_URI="https://github.com/SELinuxProject/selinux/releases/download/${MY_RELEASEDATE}/${MY_P}.tar.gz"
+       KEYWORDS="~amd64 ~arm ~arm64 ~mips ~x86"
+       S="${WORKDIR}/${MY_P}"
+fi
+
+LICENSE="GPL-2"
+SLOT="0"
+IUSE="python"
+REQUIRED_USE="python? ( ${PYTHON_REQUIRED_USE} )"
+
+RDEPEND=">=sys-libs/libsepol-${SEPOL_VER}[${MULTILIB_USEDEP}]
+       >=sys-libs/libselinux-${SELNX_VER}[${MULTILIB_USEDEP}]
+       >=sys-process/audit-2.2.2[${MULTILIB_USEDEP}]
+       >=dev-libs/ustr-1.0.4-r2[${MULTILIB_USEDEP}]
+       python? ( ${PYTHON_DEPS} )"
+DEPEND="${RDEPEND}
+       sys-devel/bison
+       sys-devel/flex
+       python? (
+               >=dev-lang/swig-2.0.4-r1
+               virtual/pkgconfig
+       )"
+
+# tests are not meant to be run outside of the
+# full SELinux userland repo
+RESTRICT="test"
+
+src_prepare() {
+       eapply_user
+
+       echo >> "${S}/src/semanage.conf"
+       echo "# Set this to true to save the linked policy." >> "${S}/src/semanage.conf"
+       echo "# This is normally only useful for analysis" >> "${S}/src/semanage.conf"
+       echo "# or debugging of policy." >> "${S}/src/semanage.conf"
+       echo "save-linked=false" >> "${S}/src/semanage.conf"
+       echo >> "${S}/src/semanage.conf"
+       echo "# Set this to 0 to disable assertion checking." >> "${S}/src/semanage.conf"
+       echo "# This should speed up building the kernel policy" >> "${S}/src/semanage.conf"
+       echo "# from policy modules, but may leave you open to" >> "${S}/src/semanage.conf"
+       echo "# dangerous rules which assertion checking" >> "${S}/src/semanage.conf"
+       echo "# would catch." >> "${S}/src/semanage.conf"
+       echo "expand-check=1" >> "${S}/src/semanage.conf"
+       echo >> "${S}/src/semanage.conf"
+       echo "# Modules in the module store can be compressed" >> "${S}/src/semanage.conf"
+       echo "# with bzip2.  Set this to the bzip2 blocksize" >> "${S}/src/semanage.conf"
+       echo "# 1-9 when compressing.  The higher the number," >> "${S}/src/semanage.conf"
+       echo "# the more memory is traded off for disk space." >> "${S}/src/semanage.conf"
+       echo "# Set to 0 to disable bzip2 compression." >> "${S}/src/semanage.conf"
+       echo "bzip-blocksize=0" >> "${S}/src/semanage.conf"
+       echo >> "${S}/src/semanage.conf"
+       echo "# Reduce memory usage for bzip2 compression and" >> "${S}/src/semanage.conf"
+       echo "# decompression of modules in the module store." >> "${S}/src/semanage.conf"
+       echo "bzip-small=true" >> "${S}/src/semanage.conf"
+
+       multilib_copy_sources
+}
+
+multilib_src_compile() {
+       emake \
+               AR="$(tc-getAR)" \
+               CC="$(tc-getCC)" \
+               LIBDIR="${EPREFIX}/usr/$(get_libdir)" \
+               all
+
+       if multilib_is_native_abi && use python; then
+               building_py() {
+                       emake \
+                               AR="$(tc-getAR)" \
+                               CC="$(tc-getCC)" \
+                               LIBDIR="${EPREFIX}/usr/$(get_libdir)" \
+                               "$@"
+               }
+               python_foreach_impl building_py swigify
+               python_foreach_impl building_py pywrap
+       fi
+}
+
+multilib_src_install() {
+       emake \
+               LIBDIR="${EPREFIX}/usr/$(get_libdir)" \
+               DESTDIR="${ED}" install
+
+       if multilib_is_native_abi && use python; then
+               installation_py() {
+                       emake DESTDIR="${ED}" \
+                               LIBDIR="${EPREFIX}/usr/$(get_libdir)" \
+                               install-pywrap
+                       python_optimize # bug 531638
+               }
+               python_foreach_impl installation_py
+       fi
+}
+
+pkg_postinst() {
+       # Migrate the SELinux semanage configuration store if not done already
+       local selinuxtype=$(awk -F'=' '/SELINUXTYPE=/ {print $2}' "${EROOT}"/etc/selinux/config 2>/dev/null)
+       if [ -n "${selinuxtype}" ] && [ ! -d "${EROOT}"/var/lib/selinux/${selinuxtype}/active ] ; then
+               ewarn "Since the 2.4 SELinux userspace, the policy module store is moved"
+               ewarn "from /etc/selinux to /var/lib/selinux. The migration will be run now."
+               ewarn "If there are any issues, it can be done manually by running:"
+               ewarn "/usr/libexec/selinux/semanage_migrate_store"
+               ewarn "For more information, please see"
+               ewarn "- https://github.com/SELinuxProject/selinux/wiki/Policy-Store-Migration"
+       fi
+
+       # Run the store migration without rebuilds
+       for POLICY_TYPE in ${POLICY_TYPES} ; do
+               if [ ! -d "${EROOT}/var/lib/selinux/${POLICY_TYPE}/active" ] ; then
+                       einfo "Migrating store ${POLICY_TYPE} (without policy rebuild)."
+                       "${EROOT}/usr/libexec/selinux/semanage_migrate_store" -n -s "${POLICY_TYPE}" || die "Failed to migrate store ${POLICY_TYPE}"
+               fi
+       done
+}