e9a93b5705
Drop obsolete varlink.patch - Update to v3.0.1 * Changes - Several frequently-occurring WARN level log messages have been downgraded to INFO or DEBUG to not clutter terminal output. Bugfixes - Fixed a bug where the Created field of podman ps --format=json was formatted as a string instead of an Unix timestamp (integer) (#9315). - Fixed a bug where failing lookups of individual layers during the podman images command would cause the whole command to fail without printing output. - Fixed a bug where --cgroups=split did not function properly on cgroups v1 systems. - Fixed a bug where mounting a volume over an directory in the container that existed, but was empty, could fail (#9393). - Fixed a bug where mounting a volume over a directory in the container that existed could copy the entirety of the container's rootfs, instead of just the directory mounted over, into the volume (#9415). - Fixed a bug where Podman would treat the --entrypoint=[""] option to podman run and podman create as a literal empty string in the entrypoint, when instead it should have been ignored (#9377). - Fixed a bug where Podman would set the HOME environment variable to "" when the container ran as a user without an assigned home directory (#9378). - Fixed a bug where specifying a pod infra image that had no tags (by using its ID) would cause podman pod create to panic (#9374). - Fixed a bug where the --runtime option was not properly handled by the podman build command (#9365). - Fixed a bug where Podman would incorrectly print an error message related to the remote API when the remote API was not in use and starting Podman failed. - Fixed a bug where Podman would change ownership of a container's working directory, even if it already existed (#9387). - Fixed a bug where the podman generate systemd --new command would incorrectly escape %t when generating the path for the PID file (#9373). - Fixed a bug where Podman could, when run inside a Podman container with the host's containers/storage directory mounted into the container, erroneously detect a reboot and reset container state if the temporary directory was not also mounted in (#9191). - Fixed a bug where some options of the podman build command (including but not limited to --jobs) were nonfunctional (#9247). * API - Fixed a breaking change to the Libpod Wait API for Containers where the Conditions parameter changed type in Podman v3.0 (#9351). - Fixed a bug where the Compat Create endpoint for Containers did not properly handle forwarded ports that did not specify a host port. - Fixed a bug where the Libpod Wait endpoint for Containers could write duplicate headers after an error occurred. - Fixed a bug where the Compat Create endpoint for Images would not pull images that already had a matching tag present locally, even if a more recent version was available at the registry (#9232). - The Compat Create endpoint for Images has had its compatibility with Docker improved, allowing its use with the docker-java library. * Misc - Updated Buildah to v1.19.4 - Updated the containers/storage library to v1.24.6 - Changes from v3.0.0 OBS-URL: https://build.opensuse.org/request/show/874870 OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/podman?expand=0&rev=75
216 lines
7.0 KiB
RPMSpec
216 lines
7.0 KiB
RPMSpec
#
|
|
# spec file for package podman
|
|
#
|
|
# Copyright (c) 2021 SUSE LLC
|
|
#
|
|
# All modifications and additions to the file contributed by third parties
|
|
# remain the property of their copyright owners, unless otherwise agreed
|
|
# upon. The license for this file, and modifications and additions to the
|
|
# file, is the same license as for the pristine package itself (unless the
|
|
# license for the pristine package is not an Open Source License, in which
|
|
# case the license is the MIT License). An "Open Source License" is a
|
|
# license that conforms to the Open Source Definition (Version 1.9)
|
|
# published by the Open Source Initiative.
|
|
|
|
# Please submit bugfixes or comments via https://bugs.opensuse.org/
|
|
#
|
|
|
|
|
|
%define project github.com/containers/podman
|
|
# Build with libostree-devel in Tumbleweed, Leap 15 and SLES 15
|
|
%if 0%{?suse_version} >= 1500
|
|
%define with_libostree 1
|
|
%endif
|
|
Name: podman
|
|
Version: 3.0.1
|
|
Release: 0
|
|
Summary: Daemon-less container engine for managing containers, pods and images
|
|
License: Apache-2.0
|
|
Group: System/Management
|
|
URL: https://github.com/containers/libpod
|
|
Source0: %{name}-%{version}.tar.xz
|
|
Source1: podman.conf
|
|
Source3: %{name}-rpmlintrc
|
|
Source4: README.SUSE.SLES
|
|
BuildRequires: bash-completion
|
|
BuildRequires: cni
|
|
BuildRequires: device-mapper-devel
|
|
BuildRequires: fdupes
|
|
BuildRequires: git-core
|
|
BuildRequires: glib2-devel-static
|
|
BuildRequires: glibc-devel-static
|
|
BuildRequires: go-go-md2man
|
|
BuildRequires: golang-packaging
|
|
BuildRequires: libapparmor-devel
|
|
BuildRequires: libassuan-devel
|
|
BuildRequires: libbtrfs-devel
|
|
BuildRequires: libcontainers-common
|
|
BuildRequires: libgpgme-devel
|
|
BuildRequires: libseccomp-devel
|
|
BuildRequires: golang(API) = 1.13
|
|
BuildRequires: pkgconfig(libselinux)
|
|
BuildRequires: pkgconfig(libsystemd)
|
|
# Build fails with PIE enabled on ppc64le due to boo#1098017
|
|
%ifarch ppc64le
|
|
#!BuildIgnore: gcc-PIE
|
|
%endif
|
|
Recommends: apparmor-parser
|
|
Recommends: apparmor-abstractions
|
|
Requires: catatonit
|
|
Requires: cni
|
|
Requires: cni-plugins
|
|
Requires: conmon
|
|
Requires: fuse-overlayfs
|
|
Requires: iptables
|
|
Requires: libcontainers-common >= 20200727
|
|
Requires: runc >= 1.0.0~rc4
|
|
Requires: slirp4netns >= 0.4.0
|
|
Requires: timezone
|
|
Recommends: %{name}-cni-config = %{version}
|
|
Suggests: katacontainers
|
|
%{go_nostrip}
|
|
%if 0%{?with_libostree}
|
|
BuildRequires: libostree-devel
|
|
%endif
|
|
|
|
%description
|
|
Podman is a container engine for managing pods, containers, and container
|
|
images.
|
|
It is a standalone tool and it directly manipulates containers without the need
|
|
of a container engine daemon.
|
|
Podman is able to interact with container images create in buildah, cri-o, and
|
|
skopeo, as they all share the same datastore backend.
|
|
|
|
%prep
|
|
%setup -q
|
|
|
|
%package cni-config
|
|
Summary: Basic CNI configuration for podman
|
|
Group: System/Management
|
|
Requires: %{name} = %{version}
|
|
# iproute2 is needed by the %triggerun scriplet
|
|
Requires: iproute2
|
|
BuildArch: noarch
|
|
|
|
%description cni-config
|
|
A "basic" CNI configuration for podman that makes networking usable for basic
|
|
setups. In more complicated setups, users are recommended to write their own
|
|
CNI configurations.
|
|
|
|
%build
|
|
# Build podman
|
|
BUILDFLAGS="-buildmode=pie" make
|
|
|
|
# Build manpages
|
|
make %{?_smp_mflags} docs
|
|
|
|
%check
|
|
# Too many tests fail due to the restricted permissions in the build enviroment.
|
|
# Updates must be tested manually.
|
|
|
|
%install
|
|
make DESTDIR=%{buildroot} PREFIX=/usr install
|
|
make DESTDIR=%{buildroot} PREFIX=/usr install.completions
|
|
|
|
# packaged in libcontainers-common
|
|
rm %{buildroot}/usr/share/man/man5/containers-mounts.conf.* %{buildroot}/usr/share/man/man5/oci-hooks.*
|
|
|
|
# Add podman modprobe.d drop-in config
|
|
mkdir -p %{buildroot}%{_prefix}/lib/modules-load.d
|
|
install -m 0644 -t %{buildroot}%{_prefix}/lib/modules-load.d/ %{SOURCE1}
|
|
|
|
# README.SUSE is SLES specifc currently
|
|
%if !0%{?is_opensuse}
|
|
install -D -m 0644 %{SOURCE4} %{buildroot}%{_docdir}/%{name}/README.SUSE
|
|
%endif
|
|
|
|
%fdupes %{buildroot}/%{_prefix}
|
|
|
|
%files
|
|
%if !0%{?is_opensuse}
|
|
%doc %{_docdir}/%{name}
|
|
%endif
|
|
# Binaries
|
|
%{_bindir}/podman
|
|
%{_bindir}/podman-remote
|
|
# Manpages
|
|
%{_mandir}/man1/podman*.1*
|
|
# Configs
|
|
%dir %{_prefix}/lib/modules-load.d
|
|
%{_prefix}/lib/modules-load.d/podman.conf
|
|
%{_tmpfilesdir}/podman.conf
|
|
# Completion
|
|
%{_datadir}/bash-completion/completions/podman
|
|
%{_datadir}/bash-completion/completions/podman-remote
|
|
%{_datadir}/zsh/site-functions/_podman
|
|
%{_datadir}/zsh/site-functions/_podman-remote
|
|
%{_datadir}/fish/
|
|
%{_datadir}/fish/vendor_completions.d/podman.fish
|
|
%{_datadir}/fish/vendor_completions.d/podman-remote.fish
|
|
%{_unitdir}/podman.service
|
|
%{_unitdir}/podman.socket
|
|
%{_unitdir}/podman-auto-update.service
|
|
%{_unitdir}/podman-auto-update.timer
|
|
%{_userunitdir}/podman.service
|
|
%{_userunitdir}/podman.socket
|
|
%{_userunitdir}/podman-auto-update.service
|
|
%{_userunitdir}/podman-auto-update.timer
|
|
%ghost /run/podman
|
|
%ghost %{_localstatedir}/adm/update-messages/%{name}-%{version}-%{release}-libpodconf
|
|
%license LICENSE
|
|
|
|
%files cni-config
|
|
%config %{_sysconfdir}/cni/net.d/87-podman-bridge.conflist
|
|
%license LICENSE
|
|
|
|
%pre
|
|
%service_add_pre podman.service podman.socket
|
|
# move away any old rpmsave config file to avoid having it re-activated again in
|
|
# %posttrans
|
|
test -f /etc/containers/libpod.conf.rpmsave && mv -v /etc/containers/libpod.conf.rpmsave /etc/containers/libpod.conf.rpmsave.old ||:
|
|
|
|
%post
|
|
%service_add_post podman.service podman.socket
|
|
%tmpfiles_create %{_tmpfilesdir}/podman.conf
|
|
|
|
%preun
|
|
%service_del_preun podman.service podman.socket
|
|
|
|
%postun
|
|
%service_del_postun podman.service podman.socket
|
|
|
|
%posttrans
|
|
# if libpod.conf.rpmsave was created move it back into place and set an update
|
|
# message informing about the libpod.conf -> containers.conf change
|
|
if test -f /etc/containers/libpod.conf.rpmsave ; then
|
|
mv -v /etc/containers/libpod.conf.rpmsave /etc/containers/libpod.conf ||:
|
|
cat >> %{_localstatedir}/adm/update-messages/%{name}-%{version}-%{release}-libpodconf << EOF
|
|
WARNING: Podman configuration file changes
|
|
|
|
With version 2.0 Podman changed to a slightly different configuration file format.
|
|
Also the name of default configuration file has been changed. The new format is
|
|
documented in the containers.conf(5) man-page and changes should usually be
|
|
straight-forward.
|
|
|
|
The new default configuration is located in /usr/share/containers/containers.conf.
|
|
In order to override setting from that file you can create
|
|
/etc/containers/containers.conf with your changed settings.
|
|
|
|
For backwards compatibility Podman 2.0 is still able to read libpod.conf. The support
|
|
for this will go away in future releases. Please migrate your configuration to the new
|
|
format as soon as possible.
|
|
EOF
|
|
fi
|
|
|
|
%triggerun cni-config -- %{name}-cni-config < 1.6.0
|
|
# The name of the network bridge changed from cni0 to podman-cni0 with
|
|
# podman 1.6. We need to rename the existing bridge to the new name to
|
|
# to avoid network issues after upgrade
|
|
if ip link show dev cni0 > /dev/null 2>&1; then
|
|
ip link set dev cni0 down
|
|
ip link set dev cni0 name cni-podman0
|
|
ip link set dev cni-podman0 up
|
|
fi
|
|
|
|
%changelog
|