aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDaniel Golle <daniel@makrotopia.org>2020-09-21 13:47:57 +0100
committerDaniel Golle <daniel@makrotopia.org>2020-09-21 18:40:38 +0100
commit81d895d1f13c0eeff4378579adcca890e5bf6da8 (patch)
treee09b8663ad18da718d44161e2ac4d8a480f31c4e
parent1c6d45644a54e50b6445bbc63eff1ae34b2f1e2e (diff)
downloadupstream-81d895d1f13c0eeff4378579adcca890e5bf6da8.tar.gz
upstream-81d895d1f13c0eeff4378579adcca890e5bf6da8.tar.bz2
upstream-81d895d1f13c0eeff4378579adcca890e5bf6da8.zip
libselinux: split utility packages and add PKG_LICENSE
Split utility packages similar to coreutils in packages feed, adding ALTERNATIVES for those which are also provided by busybox-selinux. Also add missing license information. Signed-off-by: Daniel Golle <daniel@makrotopia.org>
-rw-r--r--package/libs/libselinux/Makefile87
1 files changed, 73 insertions, 14 deletions
diff --git a/package/libs/libselinux/Makefile b/package/libs/libselinux/Makefile
index 450bdfbf3b..20d9225d39 100644
--- a/package/libs/libselinux/Makefile
+++ b/package/libs/libselinux/Makefile
@@ -7,24 +7,69 @@ include $(TOPDIR)/rules.mk
PKG_NAME:=libselinux
PKG_VERSION:=3.1
-PKG_RELEASE:=1
+PKG_RELEASE:=2
PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz
PKG_SOURCE_URL:=https://github.com/SELinuxProject/selinux/releases/download/20200710
PKG_HASH:=ea5dcbb4d859e3f999c26a13c630da2f16dff9462e3cc8cb7b458ac157d112e7
HOST_BUILD_DEPENDS:=libsepol/host pcre/host
+PKG_LICENSE:=libselinux-1.0
+PKG_LICENSE_FILES:=LICENSE
PKG_MAINTAINER:=Thomas Petazzoni <thomas.petazzoni@bootlin.com>
include $(INCLUDE_DIR)/package.mk
include $(INCLUDE_DIR)/host-build.mk
+LIBSELINUX_UTILS := \
+ avcstat \
+ compute_av \
+ compute_create \
+ compute_member \
+ compute_relabel \
+ getconlist \
+ getdefaultcon \
+ getenforce \
+ getfilecon \
+ getpidcon \
+ getsebool \
+ getseuser \
+ matchpathcon \
+ policyvers \
+ sefcontext_compile \
+ selabel_digest \
+ selabel_get_digests_all_partial_matches \
+ selabel_lookup \
+ selabel_lookup_best_match \
+ selabel_partial_match \
+ selinux_check_access \
+ selinux_check_securetty_context \
+ selinuxenabled \
+ selinuxexeccon \
+ setenforce \
+ setfilecon \
+ togglesebool \
+ validatetrans
+
+LIBSELINUX_ALTS := \
+ getenforce \
+ getsebool \
+ matchpathcon \
+ selinuxenabled \
+ setenforce
+
+$(eval $(foreach a,$(LIBSELINUX_ALTS),ALTS_$(a):=300:/usr/sbin/$(a):/usr/sbin/libselinux-$(a)$(newline)))
+
+define Package/libselinux/Default
+ TITLE:=Runtime SELinux library
+ URL:=http://selinuxproject.org/page/Main_Page
+endef
+
define Package/libselinux
+ $(call Package/libselinux/Default)
SECTION:=libs
- DEPENDS:=+libsepol +libpcre +musl-fts
CATEGORY:=Libraries
- TITLE:=Runtime SELinux library
- URL:=http://selinuxproject.org/page/Main_Page
+ DEPENDS:=+libsepol +libpcre +musl-fts
endef
define Package/libselinux/description
@@ -37,14 +82,24 @@ define Package/libselinux/description
older version supported by the kernel) when loading policy.
endef
-define Package/libselinux-utils
- SECTION:=utils
- DEPENDS:=+libselinux
- CATEGORY:=Utilities
- TITLE:=Runtime SELinux utilities
- URL:=http://selinuxproject.org/page/Main_Page
+define GenUtilPkg
+ define Package/$(1)
+ $(call Package/libselinux/Default)
+ TITLE+= $(2) utility
+ SECTION:=utils
+ DEPENDS:=+libselinux
+ CATEGORY:=Utilities
+ SUBMENU:=libselinux tools
+ ALTERNATIVES:=$(ALTS_$(2))
+ endef
+
+ define Package/$(1)/description
+ libselinux version of the $(2) utility.
+ endef
endef
+$(foreach a,$(LIBSELINUX_UTILS),$(eval $(call GenUtilPkg,libselinux-$(a),$(a))))
+
# Needed to link libselinux utilities, which link against
# libselinux.so, which indirectly depends on libpcre.so, installed in
# $(STAGING_DIR_HOSTPKG).
@@ -83,11 +138,15 @@ define Package/libselinux/install
$(CP) $(PKG_INSTALL_DIR)/usr/lib/libselinux.so.* $(1)/usr/lib/
endef
-define Package/libselinux-utils/install
- $(INSTALL_DIR) $(1)/usr/sbin
- $(CP) $(PKG_INSTALL_DIR)/usr/sbin/* $(1)/usr/sbin
+define BuildUtil
+ define Package/$(1)/install
+ $(INSTALL_DIR) $$(1)/usr/sbin
+ $(INSTALL_BIN) $(PKG_INSTALL_DIR)/usr/sbin/$(2) $$(1)/usr/sbin/$(if $(ALTS_$(2)),libselinux-$(2),$(2))
+ endef
+
+ $$(eval $$(call BuildPackage,$(1)))
endef
$(eval $(call HostBuild))
$(eval $(call BuildPackage,libselinux))
-$(eval $(call BuildPackage,libselinux-utils))
+$(foreach a,$(LIBSELINUX_UTILS),$(eval $(call BuildUtil,libselinux-$(a),$(a))))