249 lines
7.6 KiB
RPMSpec
249 lines
7.6 KiB
RPMSpec
|
%global forgeurl https://github.com/osbuild/osbuild
|
||
|
%global selinuxtype targeted
|
||
|
|
||
|
Version: 18
|
||
|
|
||
|
%forgemeta
|
||
|
|
||
|
%global pypi_name osbuild
|
||
|
%global pkgdir %{_prefix}/lib/%{pypi_name}
|
||
|
|
||
|
Name: %{pypi_name}
|
||
|
Release: 3%{?dist}
|
||
|
License: ASL 2.0
|
||
|
|
||
|
URL: %{forgeurl}
|
||
|
|
||
|
Source0: %{forgesource}
|
||
|
Patch0: no-floats-in-sources.patch
|
||
|
Patch1: selinux-allow-nnp-and-nosuid-transitions.patch
|
||
|
BuildArch: noarch
|
||
|
Summary: A build system for OS images
|
||
|
|
||
|
BuildRequires: make
|
||
|
BuildRequires: python3-devel
|
||
|
BuildRequires: python3-docutils
|
||
|
|
||
|
Requires: bash
|
||
|
Requires: coreutils
|
||
|
Requires: curl
|
||
|
Requires: dnf
|
||
|
Requires: e2fsprogs
|
||
|
Requires: glibc
|
||
|
Requires: policycoreutils
|
||
|
Requires: qemu-img
|
||
|
Requires: systemd
|
||
|
Requires: systemd-container
|
||
|
Requires: tar
|
||
|
Requires: util-linux
|
||
|
Requires: python3-%{pypi_name} = %{version}-%{release}
|
||
|
Requires: (%{name}-selinux if selinux-policy-%{selinuxtype})
|
||
|
|
||
|
# Turn off dependency generators for assemblers, runners and stages.
|
||
|
# They run in a container, so there's no reason to generate dependencies
|
||
|
# from them. As of 2020-03-25 this filters out python3.6 dependency generated
|
||
|
# by rhel runner.
|
||
|
%global __requires_exclude_from ^%{pkgdir}/(assemblers|runners|stages)/.*$
|
||
|
|
||
|
%{?python_enable_dependency_generator}
|
||
|
|
||
|
%description
|
||
|
A build system for OS images
|
||
|
|
||
|
%package -n python3-%{pypi_name}
|
||
|
Summary: %{summary}
|
||
|
%{?python_provide:%python_provide python3-%{pypi_name}}
|
||
|
|
||
|
%description -n python3-%{pypi_name}
|
||
|
A build system for OS images
|
||
|
|
||
|
%package ostree
|
||
|
Summary: OSTree support
|
||
|
Requires: %{name} = %{version}-%{release}
|
||
|
Requires: ostree
|
||
|
Requires: rpm-ostree
|
||
|
|
||
|
%description ostree
|
||
|
Contains the necessary stages, assembler and source
|
||
|
to build OSTree based images.
|
||
|
|
||
|
%package selinux
|
||
|
Summary: SELinux policies
|
||
|
Requires: %{name} = %{version}-%{release}
|
||
|
BuildRequires: selinux-policy
|
||
|
BuildRequires: selinux-policy-devel
|
||
|
%{?selinux_requires}
|
||
|
|
||
|
%description selinux
|
||
|
Contains the necessary SELinux policies that allows
|
||
|
osbuild to use labels unknown to the host inside the
|
||
|
containers it uses to build OS artifacts.
|
||
|
|
||
|
%prep
|
||
|
%forgesetup
|
||
|
%patch0 -p1
|
||
|
%patch1 -p1
|
||
|
|
||
|
%build
|
||
|
%py3_build
|
||
|
make man
|
||
|
|
||
|
# SELinux
|
||
|
make -f /usr/share/selinux/devel/Makefile osbuild.pp
|
||
|
bzip2 -9 osbuild.pp
|
||
|
|
||
|
%pre
|
||
|
%selinux_relabel_pre -s %{selinuxtype}
|
||
|
|
||
|
%install
|
||
|
%py3_install
|
||
|
|
||
|
mkdir -p %{buildroot}%{pkgdir}/stages
|
||
|
install -p -m 0755 $(find stages -type f) %{buildroot}%{pkgdir}/stages/
|
||
|
|
||
|
mkdir -p %{buildroot}%{pkgdir}/assemblers
|
||
|
install -p -m 0755 $(find assemblers -type f) %{buildroot}%{pkgdir}/assemblers/
|
||
|
|
||
|
mkdir -p %{buildroot}%{pkgdir}/runners
|
||
|
install -p -m 0755 $(find runners -type f -or -type l) %{buildroot}%{pkgdir}/runners
|
||
|
|
||
|
mkdir -p %{buildroot}%{pkgdir}/sources
|
||
|
install -p -m 0755 $(find sources -type f) %{buildroot}%{pkgdir}/sources
|
||
|
|
||
|
# mount point for bind mounting the osbuild library
|
||
|
mkdir -p %{buildroot}%{pkgdir}/osbuild
|
||
|
|
||
|
# schemata
|
||
|
mkdir -p %{buildroot}%{_datadir}/osbuild/schemas
|
||
|
install -p -m 0755 $(find schemas/*.json) %{buildroot}%{_datadir}/osbuild/schemas
|
||
|
ln -s %{_datadir}/osbuild/schemas %{buildroot}%{pkgdir}/schemas
|
||
|
|
||
|
# documentation
|
||
|
mkdir -p %{buildroot}%{_mandir}/man1
|
||
|
mkdir -p %{buildroot}%{_mandir}/man5
|
||
|
install -p -m 0644 -t %{buildroot}%{_mandir}/man1/ docs/*.1
|
||
|
install -p -m 0644 -t %{buildroot}%{_mandir}/man5/ docs/*.5
|
||
|
|
||
|
# SELinux
|
||
|
install -D -m 644 -t %{buildroot}%{_datadir}/selinux/packages/%{selinuxtype} %{name}.pp.bz2
|
||
|
install -D -m 644 -t %{buildroot}%{_mandir}/man8 selinux/%{name}_selinux.8
|
||
|
|
||
|
%check
|
||
|
exit 0
|
||
|
# We have some integration tests, but those require running a VM, so that would
|
||
|
# be an overkill for RPM check script.
|
||
|
|
||
|
%files
|
||
|
%license LICENSE
|
||
|
%{_bindir}/osbuild
|
||
|
%{_mandir}/man1/%{name}.1*
|
||
|
%{_mandir}/man5/%{name}-manifest.5*
|
||
|
%{_datadir}/osbuild/schemas
|
||
|
%{pkgdir}
|
||
|
# the following files are in the ostree sub-package
|
||
|
%exclude %{pkgdir}/assemblers/org.osbuild.ostree.commit
|
||
|
%exclude %{pkgdir}/sources/org.osbuild.ostree
|
||
|
%exclude %{pkgdir}/stages/org.osbuild.ostree
|
||
|
%exclude %{pkgdir}/stages/org.osbuild.rpm-ostree
|
||
|
|
||
|
%files -n python3-%{pypi_name}
|
||
|
%license LICENSE
|
||
|
%doc README.md NEWS.md
|
||
|
%{python3_sitelib}/%{pypi_name}-*.egg-info/
|
||
|
%{python3_sitelib}/%{pypi_name}/
|
||
|
|
||
|
%files ostree
|
||
|
%{pkgdir}/assemblers/org.osbuild.ostree.commit
|
||
|
%{pkgdir}/sources/org.osbuild.ostree
|
||
|
%{pkgdir}/stages/org.osbuild.ostree
|
||
|
%{pkgdir}/stages/org.osbuild.rpm-ostree
|
||
|
|
||
|
%files selinux
|
||
|
%{_datadir}/selinux/packages/%{selinuxtype}/%{name}.pp.bz2
|
||
|
%{_mandir}/man8/%{name}_selinux.8.*
|
||
|
%ghost %{_sharedstatedir}/selinux/%{selinuxtype}/active/modules/200/%{name}
|
||
|
|
||
|
%post selinux
|
||
|
%selinux_modules_install -s %{selinuxtype} %{_datadir}/selinux/packages/%{selinuxtype}/%{name}.pp.bz2
|
||
|
|
||
|
%postun selinux
|
||
|
if [ $1 -eq 0 ]; then
|
||
|
%selinux_modules_uninstall -s %{selinuxtype} %{name}
|
||
|
fi
|
||
|
|
||
|
%posttrans selinux
|
||
|
%selinux_relabel_post -s %{selinuxtype}
|
||
|
|
||
|
|
||
|
%changelog
|
||
|
* Thu Aug 13 2020 Christian Kellner <ckellner@redhat.com> - 18-3
|
||
|
- Add patch to allow nnp and nosuid domain transitions
|
||
|
https://github.com/osbuild/osbuild/pull/495
|
||
|
|
||
|
* Fri Jun 26 2020 Christian Kellner <ckellner@redhat.com> - 18-2
|
||
|
- Add patch to not pass floats to curl in the files source
|
||
|
https://github.com/osbuild/osbuild/pull/459
|
||
|
|
||
|
* Tue Jun 23 2020 Christian Kellner <ckellner@redhat.com> - 18-1
|
||
|
- Upstream release 18
|
||
|
- All RHEL runners now use platform-python.
|
||
|
|
||
|
* Wed Jun 10 2020 Christian Kellner <ckellner@redhat.com> - 17-1
|
||
|
- Upstream release 17
|
||
|
- Add custom SELinux policy that lets osbuild set labels inside
|
||
|
the build root that are unknown to the host.
|
||
|
|
||
|
* Thu Jun 4 2020 Christian Kellner <christian@kellner.me> - 16-1
|
||
|
- Upstream release 16
|
||
|
- Drop sources-fix-break-when-secrets-is-None.patch included in
|
||
|
osbuild-16.
|
||
|
|
||
|
* Tue May 26 2020 Christian Kellner <ckellner@redhat.com> - 15-2
|
||
|
- Add a patch to allow org.osbuild.files source in the new format
|
||
|
but without actually containing the secrets key.
|
||
|
Taken from merged PR: https://github.com/osbuild/osbuild/pull/416
|
||
|
|
||
|
* Thu May 21 2020 Christian Kellner <ckellner@redhat.com> - 15-1
|
||
|
- New upstream release 15
|
||
|
- Drop draft4-validator.json patch, included in osbuild-15
|
||
|
|
||
|
* Wed May 13 2020 Christian Kellner <ckellner@redhat.com> - 14-2
|
||
|
- Add draft4-validator.json patch
|
||
|
python3-jsonschema in RHEL currently has version 2.6.0 which
|
||
|
has support validating up to and including draft4 of jsonschema.
|
||
|
See https://github.com/osbuild/osbuild/pull/394
|
||
|
|
||
|
* Wed May 13 2020 Christian Kellner <ckellner@redhat.com> - 14-1
|
||
|
- Upstream release 14
|
||
|
- Install schemata to <datadir>/osbuild/schemas and include a
|
||
|
symlink to it in /usr/lib/osbuild/schemas
|
||
|
- The directories /usr/lib/osbuild/{assemblers, stages}/osbuild
|
||
|
got removed. Changes to osbuild made them obsolete.
|
||
|
|
||
|
* Wed Apr 15 2020 Christian Kellner <ckellner@redhat.com> - 12-1
|
||
|
- Sync with Fedora and use upstream release 12
|
||
|
- Specify the exact version in the 'python3-osbuild' requirement
|
||
|
to avoid the library and the main binary being out of sync.
|
||
|
- osbuild-ostree sub-package with the necessary bits to create
|
||
|
OSTree based images
|
||
|
- Turn off dependency generator for internal components
|
||
|
- Add NEWS.md file with the release notes and man pages
|
||
|
|
||
|
* Mon Dec 16 2019 Lars Karlitski <lars@karlitski.net> - 7-1
|
||
|
- New upstream release
|
||
|
|
||
|
* Sun Dec 1 2019 Tom Gundersen <teg@jklm.no> - 6-2
|
||
|
- New upstream release
|
||
|
|
||
|
* Thu Oct 24 2019 Lars Karlitski <lueberni@redhat.com> - 3-2
|
||
|
- add gating infra and tests
|
||
|
|
||
|
* Mon Aug 19 2019 Miro Hrončok <mhroncok@redhat.com> - 1-3
|
||
|
- Rebuilt for Python 3.8
|
||
|
|
||
|
* Mon Jul 29 2019 Martin Sehnoutka <msehnout@redhat.com> - 1-2
|
||
|
- update upstream URL to the new Github organization
|
||
|
|
||
|
* Wed Jul 17 2019 Martin Sehnoutka <msehnout@redhat.com> - 1-1
|
||
|
- Initial package
|