xref: /OK3568_Linux_fs/yocto/meta-openembedded/meta-oe/recipes-security/audit/audit_2.8.5.bb (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593SmuzhiyunSUMMARY = "User space tools for kernel auditing"
2*4882a593SmuzhiyunDESCRIPTION = "The audit package contains the user space utilities for \
3*4882a593Smuzhiyunstoring and searching the audit records generated by the audit subsystem \
4*4882a593Smuzhiyunin the Linux kernel."
5*4882a593SmuzhiyunHOMEPAGE = "http://people.redhat.com/sgrubb/audit/"
6*4882a593SmuzhiyunSECTION = "base"
7*4882a593SmuzhiyunLICENSE = "GPL-2.0-or-later & LGPL-2.0-or-later"
8*4882a593SmuzhiyunLIC_FILES_CHKSUM = "file://COPYING;md5=94d55d512a9ba36caa9b7df079bae19f"
9*4882a593Smuzhiyun
10*4882a593SmuzhiyunSRC_URI = "git://github.com/linux-audit/${BPN}-userspace.git;branch=2.8_maintenance;protocol=https \
11*4882a593Smuzhiyun           file://0001-Add-substitue-functions-for-strndupa-rawmemchr.patch \
12*4882a593Smuzhiyun           file://0002-Fixed-swig-host-contamination-issue.patch \
13*4882a593Smuzhiyun           file://0003-Header-definitions-need-to-be-external-when-building.patch \
14*4882a593Smuzhiyun           file://auditd \
15*4882a593Smuzhiyun           file://auditd.service \
16*4882a593Smuzhiyun           file://audit-volatile.conf \
17*4882a593Smuzhiyun"
18*4882a593Smuzhiyun
19*4882a593SmuzhiyunS = "${WORKDIR}/git"
20*4882a593SmuzhiyunSRCREV = "5fae55c1ad15b3cefe6890eba7311af163e9133c"
21*4882a593Smuzhiyun
22*4882a593Smuzhiyuninherit autotools python3native update-rc.d systemd
23*4882a593Smuzhiyun
24*4882a593SmuzhiyunUPDATERCPN = "auditd"
25*4882a593SmuzhiyunINITSCRIPT_NAME = "auditd"
26*4882a593SmuzhiyunINITSCRIPT_PARAMS = "defaults"
27*4882a593Smuzhiyun
28*4882a593SmuzhiyunSYSTEMD_PACKAGES = "auditd"
29*4882a593SmuzhiyunSYSTEMD_SERVICE:auditd = "auditd.service"
30*4882a593Smuzhiyun
31*4882a593SmuzhiyunDEPENDS = "python3 tcp-wrappers libcap-ng linux-libc-headers swig-native"
32*4882a593Smuzhiyun
33*4882a593SmuzhiyunEXTRA_OECONF = "--without-prelude \
34*4882a593Smuzhiyun        --with-libwrap \
35*4882a593Smuzhiyun        --enable-gssapi-krb5=no \
36*4882a593Smuzhiyun        --with-libcap-ng=yes \
37*4882a593Smuzhiyun        --with-python3=yes \
38*4882a593Smuzhiyun        --libdir=${base_libdir} \
39*4882a593Smuzhiyun        --sbindir=${base_sbindir} \
40*4882a593Smuzhiyun        --without-python \
41*4882a593Smuzhiyun        --without-golang \
42*4882a593Smuzhiyun        --disable-zos-remote \
43*4882a593Smuzhiyun        --with-arm=yes \
44*4882a593Smuzhiyun        --with-aarch64=yes \
45*4882a593Smuzhiyun        "
46*4882a593Smuzhiyun
47*4882a593SmuzhiyunEXTRA_OEMAKE = "PYLIBVER='python${PYTHON_BASEVERSION}' \
48*4882a593Smuzhiyun	PYINC='${STAGING_INCDIR}/$(PYLIBVER)' \
49*4882a593Smuzhiyun	pyexecdir=${libdir}/python${PYTHON_BASEVERSION}/site-packages \
50*4882a593Smuzhiyun	STDINC='${STAGING_INCDIR}' \
51*4882a593Smuzhiyun	pkgconfigdir=${libdir}/pkgconfig \
52*4882a593Smuzhiyun	"
53*4882a593Smuzhiyun
54*4882a593SmuzhiyunSUMMARY:audispd-plugins = "Plugins for the audit event dispatcher"
55*4882a593SmuzhiyunDESCRIPTION:audispd-plugins = "The audispd-plugins package provides plugins for the real-time \
56*4882a593Smuzhiyuninterface to the audit system, audispd. These plugins can do things \
57*4882a593Smuzhiyunlike relay events to remote machines or analyze events for suspicious \
58*4882a593Smuzhiyunbehavior."
59*4882a593Smuzhiyun
60*4882a593SmuzhiyunPACKAGES =+ "audispd-plugins"
61*4882a593SmuzhiyunPACKAGES += "auditd ${PN}-python"
62*4882a593Smuzhiyun
63*4882a593SmuzhiyunFILES:${PN} = "${sysconfdir}/libaudit.conf ${base_libdir}/libaudit.so.1* ${base_libdir}/libauparse.so.*"
64*4882a593SmuzhiyunFILES:auditd = "${bindir}/* ${base_sbindir}/* ${sysconfdir}/*"
65*4882a593SmuzhiyunFILES:audispd-plugins = "${sysconfdir}/audisp/audisp-remote.conf \
66*4882a593Smuzhiyun	${sysconfdir}/audisp/plugins.d/au-remote.conf \
67*4882a593Smuzhiyun	${base_sbindir}/audisp-remote ${localstatedir}/spool/audit \
68*4882a593Smuzhiyun	"
69*4882a593SmuzhiyunFILES:${PN}-dbg += "${libdir}/python${PYTHON_BASEVERSION}/*/.debug"
70*4882a593SmuzhiyunFILES:${PN}-python = "${libdir}/python${PYTHON_BASEVERSION}"
71*4882a593Smuzhiyun
72*4882a593SmuzhiyunCONFFILES:auditd = "${sysconfdir}/audit/audit.rules"
73*4882a593SmuzhiyunRDEPENDS:auditd = "bash"
74*4882a593Smuzhiyun
75*4882a593Smuzhiyundo_install:append() {
76*4882a593Smuzhiyun	rm -f ${D}/${libdir}/python${PYTHON_BASEVERSION}/site-packages/*.a
77*4882a593Smuzhiyun	rm -f ${D}/${libdir}/python${PYTHON_BASEVERSION}/site-packages/*.la
78*4882a593Smuzhiyun
79*4882a593Smuzhiyun	# reuse auditd config
80*4882a593Smuzhiyun	[ ! -e ${D}/etc/default ] && mkdir ${D}/etc/default
81*4882a593Smuzhiyun	mv ${D}/etc/sysconfig/auditd ${D}/etc/default
82*4882a593Smuzhiyun	rmdir ${D}/etc/sysconfig/
83*4882a593Smuzhiyun
84*4882a593Smuzhiyun	# replace init.d
85*4882a593Smuzhiyun	install -D -m 0755 ${WORKDIR}/auditd ${D}/etc/init.d/auditd
86*4882a593Smuzhiyun	rm -rf ${D}/etc/rc.d
87*4882a593Smuzhiyun
88*4882a593Smuzhiyun	if ${@bb.utils.contains('DISTRO_FEATURES', 'systemd', 'true', 'false', d)}; then
89*4882a593Smuzhiyun		# install systemd unit files
90*4882a593Smuzhiyun		install -d ${D}${systemd_unitdir}/system
91*4882a593Smuzhiyun		install -m 0644 ${WORKDIR}/auditd.service ${D}${systemd_unitdir}/system
92*4882a593Smuzhiyun
93*4882a593Smuzhiyun		install -d ${D}${sysconfdir}/tmpfiles.d/
94*4882a593Smuzhiyun		install -m 0644 ${WORKDIR}/audit-volatile.conf ${D}${sysconfdir}/tmpfiles.d/
95*4882a593Smuzhiyun	fi
96*4882a593Smuzhiyun
97*4882a593Smuzhiyun	# audit-2.5 doesn't install any rules by default, so we do that here
98*4882a593Smuzhiyun	mkdir -p ${D}/etc/audit ${D}/etc/audit/rules.d
99*4882a593Smuzhiyun	cp ${S}/rules/10-base-config.rules ${D}/etc/audit/rules.d/audit.rules
100*4882a593Smuzhiyun
101*4882a593Smuzhiyun	chmod 750 ${D}/etc/audit ${D}/etc/audit/rules.d
102*4882a593Smuzhiyun	chmod 640 ${D}/etc/audit/auditd.conf ${D}/etc/audit/rules.d/audit.rules
103*4882a593Smuzhiyun
104*4882a593Smuzhiyun	# Based on the audit.spec "Copy default rules into place on new installation"
105*4882a593Smuzhiyun	cp ${D}/etc/audit/rules.d/audit.rules ${D}/etc/audit/audit.rules
106*4882a593Smuzhiyun
107*4882a593Smuzhiyun	# Create /var/spool/audit directory for audisp-remote
108*4882a593Smuzhiyun	install -m 0700 -d ${D}${localstatedir}/spool/audit
109*4882a593Smuzhiyun}
110