refpolicy: new package
The patch is for adding selinux reference policy (refpolicy). It is a complete SELinux policy that can be used as the system policy for a variety of systems and used as the basis for creating other policies. Signed-off-by: Adam Duskett <Adamduskett@outlook.com> Tested-by: Matt Weber <matthew.weber@rockwellcollins.com> Acked-by: Matt Weber <matthew.weber@rockwellcollins.com> [Thomas: - add entry to DEVELOPERS file - remove redundant dependencies - drop unused REFPOLICY_PYINC option - use SPDX tag for license - minor formatting fixes.] Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
This commit is contained in:
parent
d44bf71d2c
commit
bb442abdf1
@ -39,6 +39,7 @@ F: package/libsepol/
|
||||
F: package/nginx-naxsi/
|
||||
F: package/policycoreutils/
|
||||
F: package/python-mutagen/
|
||||
F: package/refpolicy/
|
||||
F: package/sepolgen/
|
||||
F: package/setools/
|
||||
F: package/sngrep/
|
||||
|
@ -1765,6 +1765,7 @@ endmenu
|
||||
menu "Security"
|
||||
source "package/checkpolicy/Config.in"
|
||||
source "package/policycoreutils/Config.in"
|
||||
source "package/refpolicy/Config.in"
|
||||
source "package/sepolgen/Config.in"
|
||||
source "package/setools/Config.in"
|
||||
endmenu
|
||||
|
35
package/refpolicy/Config.in
Normal file
35
package/refpolicy/Config.in
Normal file
@ -0,0 +1,35 @@
|
||||
config BR2_PACKAGE_REFPOLICY
|
||||
bool "refpolicy"
|
||||
depends on BR2_TOOLCHAIN_HAS_THREADS # policycoreutils
|
||||
depends on BR2_TOOLCHAIN_USES_GLIBC # policycoreutils
|
||||
depends on BR2_PACKAGE_AUDIT_ARCH_SUPPORTS # policycoreutils
|
||||
depends on !BR2_STATIC_LIBS # policycoreutils
|
||||
depends on !BR2_arc # policycoreutils
|
||||
select BR2_PACKAGE_POLICYCOREUTILS
|
||||
select BR2_PACKAGE_BUSYBOX_SELINUX if BR2_PACKAGE_BUSYBOX
|
||||
help
|
||||
The SELinux Reference Policy project (refpolicy) is a
|
||||
complete SELinux policy that can be used as the system
|
||||
policy for a variety of systems and used as the basis for
|
||||
creating other policies. Reference Policy was originally
|
||||
based on the NSA example policy, but aims to accomplish many
|
||||
additional goals.
|
||||
|
||||
The current refpolicy does not fully support Buildroot and
|
||||
needs modifications to work with the default system file
|
||||
layout. These changes should be added as patches to the
|
||||
refpolicy that modify a single SELinux policy.
|
||||
|
||||
The refpolicy works for the most part in permissive
|
||||
mode. Only the basic set of utilities are enabled in the
|
||||
example policy config and some of the pathing in the
|
||||
policies is not correct. Individual policies would need to
|
||||
be tweaked to get everything functioning properly.
|
||||
|
||||
https://github.com/TresysTechnology/refpolicy
|
||||
|
||||
comment "refpolicy needs a glibc toolchain w/ threads, dynamic library"
|
||||
depends on !BR2_arc
|
||||
depends on BR2_PACKAGE_AUDIT_ARCH_SUPPORTS
|
||||
depends on BR2_STATIC_LIBS || !BR2_TOOLCHAIN_HAS_THREADS || \
|
||||
!BR2_TOOLCHAIN_USES_GLIBC
|
2
package/refpolicy/refpolicy.hash
Normal file
2
package/refpolicy/refpolicy.hash
Normal file
@ -0,0 +1,2 @@
|
||||
#From https://github.com/TresysTechnology/refpolicy/wiki/DownloadRelease
|
||||
sha256 08f9e2afc5e4939c23e56deeec7c47da029d7b85d82fb4ded01a36eb5da0651e refpolicy-RELEASE_2_20170204.tar.gz
|
51
package/refpolicy/refpolicy.mk
Normal file
51
package/refpolicy/refpolicy.mk
Normal file
@ -0,0 +1,51 @@
|
||||
################################################################################
|
||||
#
|
||||
# refpolicy
|
||||
#
|
||||
################################################################################
|
||||
|
||||
REFPOLICY_VERSION = RELEASE_2_20170204
|
||||
|
||||
# Do not use GitHub helper as git submodules are needed for refpolicy-contrib
|
||||
REFPOLICY_SITE = https://github.com/TresysTechnology/refpolicy.git
|
||||
REFPOLICY_SITE_METHOD = git
|
||||
REFPOLICY_GIT_SUBMODULES = y # Required for refpolicy-contrib
|
||||
REFPOLICY_LICENSE = GPL-2.0
|
||||
REFPOLICY_LICENSE_FILES = COPYING
|
||||
REFPOLICY_INSTALL_STAGING = YES
|
||||
REFPOLICY_DEPENDENCIES = \
|
||||
host-m4 \
|
||||
host-checkpolicy \
|
||||
host-policycoreutils \
|
||||
host-setools \
|
||||
host-gawk \
|
||||
host-python \
|
||||
policycoreutils
|
||||
|
||||
# Cannot use multiple threads to build the reference policy
|
||||
REFPOLICY_MAKE = \
|
||||
TEST_TOOLCHAIN=$(HOST_DIR) \
|
||||
PYTHON="$(HOST_DIR)/usr/bin/python2" \
|
||||
$(TARGET_MAKE_ENV) \
|
||||
$(MAKE1)
|
||||
|
||||
define REFPOLICY_CONFIGURE_CMDS
|
||||
$(SED) "/OUTPUT_POLICY/c\OUTPUT_POLICY = 30" $(@D)/build.conf
|
||||
$(SED) "/MONOLITHIC/c\MONOLITHIC = y" $(@D)/build.conf
|
||||
$(SED) "/NAME/c\NAME = targeted" $(@D)/build.conf
|
||||
endef
|
||||
|
||||
define REFPOLICY_BUILD_CMDS
|
||||
$(REFPOLICY_MAKE) -C $(@D) DESTDIR=$(STAGING_DIR) bare conf
|
||||
endef
|
||||
|
||||
define REFPOLICY_INSTALL_STAGING_CMDS
|
||||
$(REFPOLICY_MAKE) -C $(@D) DESTDIR=$(STAGING_DIR) \
|
||||
install-src install-headers
|
||||
endef
|
||||
|
||||
define REFPOLICY_INSTALL_TARGET_CMDS
|
||||
$(REFPOLICY_MAKE) -C $(@D) DESTDIR=$(TARGET_DIR) install
|
||||
endef
|
||||
|
||||
$(eval $(generic-package))
|
Loading…
Reference in New Issue
Block a user