Resolves: https://issues.redhat.com/browse/RHEL-33751 Conflict: Upstream has -libs subpackage Upstream Status: https://src.fedoraproject.org/rpms/ima-evm-utils.git commit 8980421a049c776e2b77e534793aafb925b3ad48 Author: Coiby Xu <coiby.xu@gmail.com> Date: Mon May 6 17:48:52 2024 +0800 Add some IMA setup tools Some IMA setup tools are added to ease IMA setup which will do the following tasks, - add IMA signatures to installed packages files - load IMA keys and policy - enable the dracut integrity module to load IMA keys and policy automatically Two IMA polices as suggested by Stefan Berger are also provided which will be signed automatically with other package files. Thanks to Marko Myllynen for coming up with the idea to have a tool similar to fips-mode-setup. And thanks to Mimi Zohar and Stefan Berger for providing the feedback! Signed-off-by: Coiby Xu <coxu@redhat.com> Signed-off-by: Coiby Xu <coxu@redhat.com>
282 lines
9.5 KiB
RPMSpec
282 lines
9.5 KiB
RPMSpec
# If the soname gets bumped we need to ship a compat library to be able
|
|
# to bootstrap and rebuild rpm else we end up with chicken and egg problem.
|
|
%global bootstrap 0
|
|
|
|
%if 0%{bootstrap}
|
|
%global compat_soversion 3
|
|
%endif
|
|
|
|
Name: ima-evm-utils
|
|
Version: 1.5
|
|
Release: 1%{?dist}
|
|
Summary: IMA/EVM support utilities
|
|
License: GPLv2
|
|
Url: http://linux-ima.sourceforge.net/
|
|
Source0: https://github.com/mimizohar/ima-evm-utils/releases/download/v%{version}/%{name}-%{version}.tar.gz
|
|
|
|
# IMA setup tools
|
|
Source2: dracut-98-integrity.conf
|
|
Source3: ima-add-sigs.sh
|
|
Source4: ima-setup.sh
|
|
Source100: policy-01-appraise-exectuables-and-lib-signatures
|
|
Source101: policy-02-keylime-remote-attestation
|
|
Source200: policy_list
|
|
|
|
%if 0%{bootstrap}
|
|
# compat source and patches
|
|
Source10: ima-evm-utils-1.4.tar.gz
|
|
%endif
|
|
|
|
BuildRequires: asciidoc
|
|
BuildRequires: autoconf
|
|
BuildRequires: automake
|
|
BuildRequires: gcc
|
|
BuildRequires: keyutils-libs-devel
|
|
BuildRequires: libtool
|
|
BuildRequires: libxslt
|
|
BuildRequires: make
|
|
BuildRequires: openssl-devel
|
|
BuildRequires: tpm2-tss-devel
|
|
Requires: rpm-plugin-ima
|
|
Requires: keyutils
|
|
Requires: attr
|
|
|
|
%description
|
|
The Trusted Computing Group(TCG) run-time Integrity Measurement Architecture
|
|
(IMA) maintains a list of hash values of executables and other sensitive
|
|
system files, as they are read or executed. These are stored in the file
|
|
systems extended attributes. The Extended Verification Module (EVM) prevents
|
|
unauthorized changes to these extended attributes on the file system.
|
|
ima-evm-utils is used to prepare the file system for these extended attributes.
|
|
|
|
%package devel
|
|
Summary: Development files for %{name}
|
|
Requires: %{name} = %{version}-%{release}
|
|
|
|
%description devel
|
|
This package provides the header files for %{name}
|
|
|
|
%prep
|
|
%setup -q
|
|
|
|
%if 0%{bootstrap}
|
|
mkdir compat/
|
|
pushd compat/
|
|
tar -zxf %{SOURCE10} --strip-components=1
|
|
popd
|
|
%endif
|
|
|
|
%build
|
|
autoreconf -vif
|
|
%configure --disable-static
|
|
%make_build
|
|
|
|
%if 0%{bootstrap}
|
|
pushd compat/
|
|
autoreconf -vif
|
|
%configure --disable-static --disable-engine
|
|
%make_build
|
|
popd
|
|
%endif
|
|
|
|
%install
|
|
%make_install
|
|
find %{buildroot} -type f -name "*.la" -print -delete
|
|
|
|
%if 0%{bootstrap}
|
|
pushd compat/src/.libs/
|
|
install -p libimaevm.so.%{compat_soversion}.0.0 %{buildroot}%{_libdir}/libimaevm.so.%{compat_soversion}.0.0
|
|
ln -s -f %{buildroot}%{_libdir}/libimaevm.so.%{compat_soversion}.0.0 %{buildroot}%{_libdir}/libimaevm.so.%{compat_soversion}
|
|
popd
|
|
%endif
|
|
|
|
%ldconfig_scriptlets
|
|
|
|
# IMA setup tools
|
|
install -D -m 644 %{SOURCE2} $RPM_BUILD_ROOT%{_datadir}/ima/dracut-98-integrity.conf
|
|
|
|
mkdir -p -m 755 $RPM_BUILD_ROOT%{_datadir}/ima/policies
|
|
while IFS= read -r policy_file
|
|
do
|
|
install -m 644 %{_sourcedir}/policy-"$policy_file" $RPM_BUILD_ROOT%{_datadir}/ima/policies/"$policy_file"
|
|
done < %{SOURCE200}
|
|
|
|
install -D %{SOURCE3} $RPM_BUILD_ROOT%{_bindir}/ima-add-sigs
|
|
install -D %{SOURCE4} $RPM_BUILD_ROOT%{_bindir}/ima-setup
|
|
|
|
%files
|
|
%license COPYING
|
|
%doc NEWS README AUTHORS
|
|
%{_bindir}/evmctl
|
|
%{_mandir}/man1/evmctl*
|
|
|
|
# IMA setup tools
|
|
%{_datadir}/ima/policies
|
|
%{_datadir}/ima/dracut-98-integrity.conf
|
|
%{_bindir}/ima-add-sigs
|
|
%{_bindir}/ima-setup
|
|
|
|
# if you need to bump the soname version, coordinate with dependent packages
|
|
%{_libdir}/libimaevm.so.4*
|
|
%if 0%{bootstrap}
|
|
%{_libdir}/libimaevm.so.%{compat_soversion}
|
|
%{_libdir}/libimaevm.so.%{compat_soversion}.0.0
|
|
%endif
|
|
|
|
%files devel
|
|
%{_pkgdocdir}/*.sh
|
|
%{_includedir}/imaevm.h
|
|
%{_libdir}/libimaevm.so
|
|
|
|
%changelog
|
|
* Tue Jun 04 2024 Coiby Xu <coxu@redhat.com> - 1.5-1
|
|
- Disable compat build (RHEL-2969)
|
|
|
|
* Fri Apr 12 2024 Coiby Xu <coxu@redhat.com> - 1.5-0.1
|
|
- Update to upstream 1.5 (RHEL-2969)
|
|
|
|
* Mon Dec 13 2021 Bruno Meneguele <bmeneg@redhat.com> - 1.4-4
|
|
- Fix compat bcond_with value check.
|
|
|
|
* Fri Dec 10 2021 Bruno Meneguele <bmeneg@redhat.com> - 1.4-3
|
|
- Remove compat subpkg from compose (rhbz#2026028)
|
|
|
|
* Tue Dec 07 2021 Bruno Meneguele <bmeneg@redhat.com> - 1.4-2
|
|
- Add compat subpkg for helping building dependencies (rhbz#2026028)
|
|
|
|
* Thu Dec 02 2021 Bruno Meneguele <bmeneg@redhat.com> - 1.4-1
|
|
- Modify some pieces to get closer to Fedora's specfile
|
|
- Remove patch handling memory leak: solved in the rebase
|
|
- Remove patch handling SHA-256 default hash: solved in the rebase
|
|
- Rebase to upstream release v1.4 (rhbz#2026028)
|
|
|
|
* Fri Aug 20 2021 Bruno Meneguele <bmeneg@redhat.com> - 1.3.2-9
|
|
- Use upstream accepted patch for the memory leak
|
|
- Make SHA-256 the default hash algorithm (rhbz#1934949)
|
|
|
|
* Mon Aug 09 2021 Mohan Boddu <mboddu@redhat.com> - 1.3.2-6
|
|
- Rebuilt for IMA sigs, glibc 2.34, aarch64 flags
|
|
Related: rhbz#1991688
|
|
|
|
* Thu Jul 08 2021 Bruno Meneguele <bmeneg@redhat.com> - 1.3.2-5
|
|
- Add patch fixing memory leak (rhbz#1938742)
|
|
|
|
* Wed Jun 16 2021 Mohan Boddu <mboddu@redhat.com> - 1.3.2-4
|
|
- Rebuilt for RHEL 9 BETA for openssl 3.0
|
|
Related: rhbz#1971065
|
|
|
|
* Fri Apr 16 2021 Mohan Boddu <mboddu@redhat.com> - 1.3.2-3
|
|
- Rebuilt for RHEL 9 BETA on Apr 15th 2021. Related: rhbz#1947937
|
|
|
|
* Tue Jan 26 2021 Fedora Release Engineering <releng@fedoraproject.org> - 1.3.2-2
|
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_34_Mass_Rebuild
|
|
|
|
* Wed Oct 28 2020 Bruno Meneguele <bmeneg@redhat.com> - 1.3.2-1
|
|
- Rebase to new upstream v1.3.2 minor release
|
|
|
|
* Tue Aug 11 2020 Bruno Meneguele <bmeneg@redhat.com> - 1.3.1-1
|
|
- Rebase to new upstream v1.3.1 minor release
|
|
|
|
* Tue Jul 28 2020 Fedora Release Engineering <releng@fedoraproject.org> - 1.3-3
|
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_33_Mass_Rebuild
|
|
|
|
* Sun Jul 26 2020 Peter Robinson <pbrobinson@fedoraproject.org> - 1.3-2
|
|
- Fix devel deps
|
|
|
|
* Sun Jul 26 2020 Peter Robinson <pbrobinson@fedoraproject.org> - 1.3-1
|
|
- Update to 1.3
|
|
- Use tpm2-tss instead of tss2
|
|
- Minor spec cleanups
|
|
|
|
* Mon Jul 13 2020 Tom Stellard <tstellar@redhat.com> - 1.2.1-4
|
|
- Use make macros
|
|
- https://fedoraproject.org/wiki/Changes/UseMakeBuildInstallMacro
|
|
|
|
* Wed Jan 29 2020 Fedora Release Engineering <releng@fedoraproject.org> - 1.2.1-3
|
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_32_Mass_Rebuild
|
|
|
|
* Wed Jul 31 2019 Bruno E. O. Meneguele <bmeneg@redhat.com> - 1.2.1-2
|
|
- Add pull request to correct lib soname version, wich was bumped to 1.0.0
|
|
|
|
* Wed Jul 31 2019 Bruno E. O. Meneguele <bmeneg@redhat.com> - 1.2.1-1
|
|
- Rebase to upstream v1.2.1
|
|
- Remove both patches that were already solved in upstream version
|
|
- Add runtime dependency of tss2 to retrieve PCR bank data from TPM2.0
|
|
|
|
* Thu Jul 25 2019 Fedora Release Engineering <releng@fedoraproject.org> - 1.1-6
|
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_31_Mass_Rebuild
|
|
|
|
* Fri Feb 01 2019 Fedora Release Engineering <releng@fedoraproject.org> - 1.1-5
|
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_30_Mass_Rebuild
|
|
|
|
* Fri Jul 20 2018 Bruno E. O. Meneguele <brdeoliv@redhat.com> - 1.1-4
|
|
- Add patch to remove dependency from libattr-devel package
|
|
|
|
* Fri Jul 13 2018 Fedora Release Engineering <releng@fedoraproject.org> - 1.1-3
|
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_29_Mass_Rebuild
|
|
|
|
* Fri Mar 02 2018 Bruno E. O. Meneguele <brdeoliv@redhat.com> - 1.1-2
|
|
- Remove libtool files
|
|
- Run ldconfig scriptlets after un/installing
|
|
- Add -devel subpackage to handle include files and examples
|
|
- Disable any static file in the package
|
|
|
|
* Fri Feb 16 2018 Bruno E. O. Meneguele <brdeoliv@redhat.com> - 1.1-1
|
|
- New upstream release
|
|
- Support for OpenSSL 1.1 was added directly to the source code in upstream,
|
|
thus removing specific patch for it
|
|
- Docbook xsl stylesheet updated to a local path
|
|
|
|
* Wed Feb 07 2018 Fedora Release Engineering <releng@fedoraproject.org> - 1.0-5
|
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_28_Mass_Rebuild
|
|
|
|
* Fri Feb 02 2018 Igor Gnatenko <ignatenkobrain@fedoraproject.org> - 1.0-4
|
|
- Switch to %%ldconfig_scriptlets
|
|
|
|
* Fri Dec 01 2017 Bruno E. O. Meneguele <brdeoliv@redhat.com> - 1.0-3
|
|
- Add OpenSSL 1.1 API support for the package, avoiding the need of
|
|
compat-openssl10-devel package
|
|
|
|
* Mon Nov 20 2017 Bruno E. O. Meneguele <brdeoliv@redhat.com> - 1.0-2
|
|
- Adjusted docbook xsl path to match the correct stylesheet
|
|
- Remove only *.la files, considering there aren't any *.a files
|
|
|
|
* Tue Sep 05 2017 Bruno E. O. Meneguele <brdeoliv@redhat.com> - 1.0-1
|
|
- New upstream release
|
|
- Add OpenSSL 1.0 compatibility package, due to issues with OpenSSL 1.1
|
|
- Remove libtool files
|
|
- Run ldconfig after un/installation to update *.so files
|
|
- Add -devel subpackage to handle include files and examples
|
|
|
|
* Wed Aug 02 2017 Fedora Release Engineering <releng@fedoraproject.org> - 0.9-7
|
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_27_Binutils_Mass_Rebuild
|
|
|
|
* Wed Jul 26 2017 Fedora Release Engineering <releng@fedoraproject.org> - 0.9-6
|
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_27_Mass_Rebuild
|
|
|
|
* Fri Feb 10 2017 Fedora Release Engineering <releng@fedoraproject.org> - 0.9-5
|
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_26_Mass_Rebuild
|
|
|
|
* Thu Feb 04 2016 Fedora Release Engineering <releng@fedoraproject.org> - 0.9-4
|
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_24_Mass_Rebuild
|
|
|
|
* Tue Jan 26 2016 Lubomir Rintel <lkundrak@v3.sk> - 0.9-3
|
|
- Fix FTBFS
|
|
|
|
* Wed Jun 17 2015 Fedora Release Engineering <rel-eng@lists.fedoraproject.org> - 0.9-2
|
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_23_Mass_Rebuild
|
|
|
|
* Fri Oct 31 2014 Avesh Agarwal <avagarwa@redhat.com> - 0.9-1
|
|
- New upstream release
|
|
- Applied a patch to fix man page issues.
|
|
- Updated spec file
|
|
|
|
* Sat Aug 16 2014 Fedora Release Engineering <rel-eng@lists.fedoraproject.org> - 0.6-3
|
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_21_22_Mass_Rebuild
|
|
|
|
* Sat Jun 07 2014 Fedora Release Engineering <rel-eng@lists.fedoraproject.org> - 0.6-2
|
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_21_Mass_Rebuild
|
|
|
|
* Tue Aug 27 2013 Vivek Goyal <vgoyal@redhat.com> - 0.6-1
|
|
- Initial package
|