xref: /OK3568_Linux_fs/yocto/meta-openembedded/meta-oe/recipes-security/audit/audit_3.0.8.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=master;protocol=https \
11*4882a593Smuzhiyun           file://Fixed-swig-host-contamination-issue.patch \
12*4882a593Smuzhiyun           file://auditd \
13*4882a593Smuzhiyun           file://auditd.service \
14*4882a593Smuzhiyun           file://audit-volatile.conf \
15*4882a593Smuzhiyun"
16*4882a593Smuzhiyun
17*4882a593SmuzhiyunS = "${WORKDIR}/git"
18*4882a593SmuzhiyunSRCREV = "54a62e78792fe583267cf80da717ee480b8f42bc"
19*4882a593Smuzhiyun
20*4882a593Smuzhiyuninherit autotools python3native update-rc.d systemd
21*4882a593Smuzhiyun
22*4882a593SmuzhiyunUPDATERCPN = "auditd"
23*4882a593SmuzhiyunINITSCRIPT_NAME = "auditd"
24*4882a593SmuzhiyunINITSCRIPT_PARAMS = "defaults"
25*4882a593Smuzhiyun
26*4882a593SmuzhiyunSYSTEMD_PACKAGES = "auditd"
27*4882a593SmuzhiyunSYSTEMD_SERVICE:auditd = "auditd.service"
28*4882a593Smuzhiyun
29*4882a593SmuzhiyunDEPENDS = "python3 tcp-wrappers libcap-ng linux-libc-headers swig-native"
30*4882a593Smuzhiyun
31*4882a593SmuzhiyunEXTRA_OECONF = " --with-libwrap \
32*4882a593Smuzhiyun        --enable-gssapi-krb5=no \
33*4882a593Smuzhiyun        --with-libcap-ng=yes \
34*4882a593Smuzhiyun        --with-python3=yes \
35*4882a593Smuzhiyun        --libdir=${base_libdir} \
36*4882a593Smuzhiyun        --sbindir=${base_sbindir} \
37*4882a593Smuzhiyun        --without-python \
38*4882a593Smuzhiyun        --without-golang \
39*4882a593Smuzhiyun        --disable-zos-remote \
40*4882a593Smuzhiyun        --with-arm=yes \
41*4882a593Smuzhiyun        --with-aarch64=yes \
42*4882a593Smuzhiyun        "
43*4882a593Smuzhiyun
44*4882a593SmuzhiyunEXTRA_OEMAKE = "PYLIBVER='python${PYTHON_BASEVERSION}' \
45*4882a593Smuzhiyun	PYINC='${STAGING_INCDIR}/$(PYLIBVER)' \
46*4882a593Smuzhiyun	pyexecdir=${libdir}/python${PYTHON_BASEVERSION}/site-packages \
47*4882a593Smuzhiyun	STDINC='${STAGING_INCDIR}' \
48*4882a593Smuzhiyun	pkgconfigdir=${libdir}/pkgconfig \
49*4882a593Smuzhiyun	"
50*4882a593Smuzhiyun
51*4882a593SmuzhiyunSUMMARY:audispd-plugins = "Plugins for the audit event dispatcher"
52*4882a593SmuzhiyunDESCRIPTION:audispd-plugins = "The audispd-plugins package provides plugins for the real-time \
53*4882a593Smuzhiyuninterface to the audit system, audispd. These plugins can do things \
54*4882a593Smuzhiyunlike relay events to remote machines or analyze events for suspicious \
55*4882a593Smuzhiyunbehavior."
56*4882a593Smuzhiyun
57*4882a593SmuzhiyunPACKAGES =+ "audispd-plugins"
58*4882a593SmuzhiyunPACKAGES += "auditd ${PN}-python"
59*4882a593Smuzhiyun
60*4882a593SmuzhiyunFILES:${PN} = "${sysconfdir}/libaudit.conf ${base_libdir}/libaudit.so.1* ${base_libdir}/libauparse.so.*"
61*4882a593SmuzhiyunFILES:auditd = "${bindir}/* ${base_sbindir}/* ${sysconfdir}/* ${datadir}/audit/*"
62*4882a593SmuzhiyunFILES:audispd-plugins = "${sysconfdir}/audit/audisp-remote.conf \
63*4882a593Smuzhiyun	${sysconfdir}/audit/plugins.d/au-remote.conf \
64*4882a593Smuzhiyun	${sysconfdir}/audit/plugins.d/syslog.conf \
65*4882a593Smuzhiyun	${base_sbindir}/audisp-remote \
66*4882a593Smuzhiyun	${base_sbindir}/audisp-syslog \
67*4882a593Smuzhiyun	${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*4882a593Smuzhiyun
74*4882a593Smuzhiyundo_configure:prepend() {
75*4882a593Smuzhiyun	sed -e 's|buf\[];|buf[0];|g'  ${STAGING_INCDIR}/linux/audit.h > ${S}/lib/audit.h
76*4882a593Smuzhiyun        sed -i -e 's|#include <linux/audit.h>|#include "audit.h"|g' ${S}/lib/libaudit.h
77*4882a593Smuzhiyun}
78*4882a593Smuzhiyun
79*4882a593Smuzhiyundo_install:append() {
80*4882a593Smuzhiyun        sed -i -e 's|#include "audit.h"|#include <linux/audit.h>|g' ${D}${includedir}/libaudit.h
81*4882a593Smuzhiyun
82*4882a593Smuzhiyun	rm -f ${D}/${libdir}/python${PYTHON_BASEVERSION}/site-packages/*.a
83*4882a593Smuzhiyun	rm -f ${D}/${libdir}/python${PYTHON_BASEVERSION}/site-packages/*.la
84*4882a593Smuzhiyun
85*4882a593Smuzhiyun	# reuse auditd config
86*4882a593Smuzhiyun	[ ! -e ${D}/etc/default ] && mkdir ${D}/etc/default
87*4882a593Smuzhiyun	mv ${D}/etc/sysconfig/auditd ${D}/etc/default
88*4882a593Smuzhiyun	rmdir ${D}/etc/sysconfig/
89*4882a593Smuzhiyun
90*4882a593Smuzhiyun	# replace init.d
91*4882a593Smuzhiyun	install -D -m 0755 ${WORKDIR}/auditd ${D}/etc/init.d/auditd
92*4882a593Smuzhiyun	rm -rf ${D}/etc/rc.d
93*4882a593Smuzhiyun
94*4882a593Smuzhiyun	if ${@bb.utils.contains('DISTRO_FEATURES', 'systemd', 'true', 'false', d)}; then
95*4882a593Smuzhiyun		# install systemd unit files
96*4882a593Smuzhiyun		install -d ${D}${systemd_unitdir}/system
97*4882a593Smuzhiyun		install -m 0644 ${WORKDIR}/auditd.service ${D}${systemd_unitdir}/system
98*4882a593Smuzhiyun
99*4882a593Smuzhiyun		install -d ${D}${sysconfdir}/tmpfiles.d/
100*4882a593Smuzhiyun		install -m 0644 ${WORKDIR}/audit-volatile.conf ${D}${sysconfdir}/tmpfiles.d/
101*4882a593Smuzhiyun	fi
102*4882a593Smuzhiyun
103*4882a593Smuzhiyun	# audit-2.5 doesn't install any rules by default, so we do that here
104*4882a593Smuzhiyun	mkdir -p ${D}/etc/audit ${D}/etc/audit/rules.d
105*4882a593Smuzhiyun	cp ${S}/rules/10-base-config.rules ${D}/etc/audit/rules.d/audit.rules
106*4882a593Smuzhiyun
107*4882a593Smuzhiyun	chmod 750 ${D}/etc/audit ${D}/etc/audit/rules.d
108*4882a593Smuzhiyun	chmod 640 ${D}/etc/audit/auditd.conf ${D}/etc/audit/rules.d/audit.rules
109*4882a593Smuzhiyun
110*4882a593Smuzhiyun	# Based on the audit.spec "Copy default rules into place on new installation"
111*4882a593Smuzhiyun	cp ${D}/etc/audit/rules.d/audit.rules ${D}/etc/audit/audit.rules
112*4882a593Smuzhiyun
113*4882a593Smuzhiyun	# Create /var/spool/audit directory for audisp-remote
114*4882a593Smuzhiyun	install -m 0700 -d ${D}${localstatedir}/spool/audit
115*4882a593Smuzhiyun}
116