mirror of
https://github.com/containers/podman.git
synced 2025-07-28 10:52:35 +08:00

Remove GOPATH setting as since Go 1.9 it defaults to $HOME/go (for earlier versions it had to be specified explicitly). Remove GOPATH-related code from the spec, using relative paths when compiling packages, and enable Go modules, simplifying the spec. Remove support for multiple paths in GOPATH (which is rarely used and doesn't really work with modules). Remove setting GOBIN, rely on $GOPATH/bin instead. In case GOBIN is explicitly set (which is highly unlikely), forcefully ignore by unsetting it. Remove GOBIN from tools invocation since we added GOPATH/bin to PATH. Signed-off-by: Kir Kolyshkin <kolyshkin@gmail.com>
263 lines
8.3 KiB
Plaintext
263 lines
8.3 KiB
Plaintext
# For automatic rebuilds in COPR
|
|
|
|
# The following tag is to get correct syntax highlighting for this file in vim text editor
|
|
# vim: syntax=spec
|
|
|
|
%global with_debug 1
|
|
|
|
%if 0%{?with_debug}
|
|
%global _find_debuginfo_dwz_opts %{nil}
|
|
%global _dwz_low_mem_die_limit 0
|
|
%else
|
|
%global debug_package %{nil}
|
|
%endif
|
|
|
|
%if ! 0%{?gobuild:1}
|
|
%define gobuild(o:) go build -buildmode pie -compiler gc -tags="rpm_crashtraceback ${BUILDTAGS:-}" -ldflags "${LDFLAGS:-} -B 0x$(head -c20 /dev/urandom|od -An -tx1|tr -d ' \\n') -extldflags '-Wl,-z,relro -Wl,-z,now -specs=/usr/lib/rpm/redhat/redhat-hardened-ld '" -a -v -x %{?**};
|
|
%endif
|
|
|
|
# git_dir_name returns repository name derived from remote Git repository URL
|
|
Name: {{{ git_dir_name }}}
|
|
|
|
Epoch: 101
|
|
|
|
# git_dir_version returns version based on commit and tag history of the Git project
|
|
Version: {{{ git_dir_version }}}
|
|
|
|
# This can be useful later for adding downstream patches
|
|
Release: 1%{?dist}
|
|
|
|
# Basic description of the package
|
|
Summary: Manage Pods, Containers and Container Images
|
|
|
|
# License. We assume GPLv2+ here.
|
|
License: ASL 2.0
|
|
|
|
# Home page of the project. Can also point to the public Git repository page.
|
|
URL: https://github.com/containers/podman
|
|
|
|
# Detailed information about the source Git repository and the source commit
|
|
# for the created rpm package
|
|
VCS: {{{ git_dir_vcs }}}
|
|
|
|
# git_dir_pack macro places the repository content (the source files) into a tarball
|
|
# and returns its filename. The tarball will be used to build the rpm.
|
|
Source: {{{ git_dir_pack }}}
|
|
|
|
%if 0%{?fedora} && ! 0%{?rhel}
|
|
BuildRequires: btrfs-progs-devel
|
|
%endif
|
|
BuildRequires: gcc
|
|
BuildRequires: golang >= 1.16.6
|
|
BuildRequires: glib2-devel
|
|
BuildRequires: glibc-devel
|
|
BuildRequires: glibc-static
|
|
BuildRequires: git-core
|
|
BuildRequires: go-md2man
|
|
%if 0%{?fedora} || 0%{?rhel} >= 9
|
|
BuildRequires: go-rpm-macros
|
|
%endif
|
|
%if 0%{?rhel} <= 8
|
|
BuildRequires: pkgconfig(devmapper)
|
|
%endif
|
|
BuildRequires: gpgme-devel
|
|
BuildRequires: libassuan-devel
|
|
BuildRequires: libgpg-error-devel
|
|
BuildRequires: libseccomp-devel
|
|
BuildRequires: libselinux-devel
|
|
BuildRequires: shadow-utils-subid-devel
|
|
BuildRequires: pkgconfig
|
|
BuildRequires: make
|
|
BuildRequires: ostree-devel
|
|
BuildRequires: systemd
|
|
BuildRequires: systemd-devel
|
|
Requires: conmon >= 2:2.0.30-2
|
|
# containers-common pulled from podman-next copr for f34,
|
|
# from the distro repos for f35+
|
|
%if 0%{?fedora} <= 35
|
|
Requires: containers-common >= 4:1-39
|
|
%else
|
|
Requires: containers-common >= 4:1-46
|
|
%endif
|
|
Requires: iptables
|
|
Requires: nftables
|
|
Recommends: catatonit
|
|
Suggests: qemu-user-static
|
|
|
|
# More detailed description of the package
|
|
%description
|
|
%{name} (Pod Manager) is a fully featured container engine that is a simple
|
|
daemonless tool. %{name} provides a Docker-CLI comparable command line that
|
|
eases the transition from other container engines and allows the management of
|
|
pods, containers and images. Simply put: alias docker=%{name}.
|
|
Most %{name} commands can be run as a regular user, without requiring
|
|
additional privileges.
|
|
|
|
%{name} uses Buildah(1) internally to create container images.
|
|
Both tools share image (not container) storage, hence each can use or
|
|
manipulate images (but not containers) created by the other.
|
|
|
|
%package docker
|
|
Summary: Emulate Docker CLI using %{name}
|
|
BuildArch: noarch
|
|
Requires: %{name} = %{epoch}:%{version}-%{release}
|
|
Conflicts: docker
|
|
Conflicts: docker-latest
|
|
Conflicts: docker-ce
|
|
Conflicts: docker-ee
|
|
Conflicts: moby-engine
|
|
|
|
%description docker
|
|
This package installs a script named docker that emulates the Docker CLI by
|
|
executes %{name} commands, it also creates links between all Docker CLI man
|
|
pages and %{name}.
|
|
|
|
%package tests
|
|
Summary: Tests for %{name}
|
|
Requires: %{name} = %{epoch}:%{version}-%{release}
|
|
Requires: bats
|
|
Requires: jq
|
|
Requires: skopeo
|
|
Requires: nmap-ncat
|
|
Requires: httpd-tools
|
|
Requires: openssl
|
|
Requires: socat
|
|
Requires: buildah
|
|
Requires: gnupg
|
|
|
|
%description tests
|
|
%{summary}
|
|
|
|
This package contains system tests for %{name}
|
|
|
|
%package remote
|
|
Summary: (Experimental) Remote client for managing %{name} containers
|
|
|
|
%description remote
|
|
Remote client for managing %{name} containers.
|
|
|
|
%{name}-remote uses the libpod REST API to connect to a %{name} client to
|
|
manage pods, containers and container images. %{name}-remote supports ssh
|
|
connections as well.
|
|
|
|
# The following four sections already describe the rpm build process itself.
|
|
# prep will extract the tarball defined as Source above and descend into it.
|
|
%prep
|
|
{{{ git_dir_setup_macro }}}
|
|
|
|
# This will invoke `make` command in the directory with the extracted sources.
|
|
%build
|
|
%set_build_flags
|
|
%global gomodulesmode GO111MODULE=on
|
|
export CGO_CFLAGS=$CFLAGS
|
|
# These extra flags present in $CFLAGS have been skipped for now as they break the build
|
|
CGO_CFLAGS=$(echo $CGO_CFLAGS | sed 's/-flto=auto//g')
|
|
CGO_CFLAGS=$(echo $CGO_CFLAGS | sed 's/-Wp,D_GLIBCXX_ASSERTIONS//g')
|
|
CGO_CFLAGS=$(echo $CGO_CFLAGS | sed 's/-specs=\/usr\/lib\/rpm\/redhat\/redhat-annobin-cc1//g')
|
|
|
|
%ifarch x86_64
|
|
export CGO_CFLAGS+=" -m64 -mtune=generic -fcf-protection=full"
|
|
%endif
|
|
|
|
%if 0%{?rhel}
|
|
rm -rf vendor/github.com/containers/storage/drivers/register/register_btrfs.go
|
|
%endif
|
|
|
|
# build date. FIXME: Makefile uses '/v2/libpod', that doesn't work here?
|
|
LDFLAGS="-X ./libpod/define.buildInfo=$(date +%s)"
|
|
|
|
# build rootlessport first
|
|
%gobuild -o bin/rootlessport ./cmd/rootlessport
|
|
|
|
# set base buildtags common to both %%{name} and %%{name}-remote
|
|
export BASEBUILDTAGS="seccomp exclude_graphdriver_devicemapper $(hack/selinux_tag.sh) $(hack/systemd_tag.sh) $(hack/libsubid_tag.sh)"
|
|
|
|
# build %%{name}
|
|
export BUILDTAGS="$BASEBUILDTAGS $(hack/btrfs_installed_tag.sh) $(hack/btrfs_tag.sh)"
|
|
%gobuild -o bin/%{name} ./cmd/%{name}
|
|
|
|
# build %%{name}-remote
|
|
export BUILDTAGS="$BASEBUILDTAGS exclude_graphdriver_btrfs btrfs_noversion remote"
|
|
%gobuild -o bin/%{name}-remote ./cmd/%{name}
|
|
|
|
make docs docker-docs
|
|
|
|
# This will copy the files generated by the `make` command above into
|
|
# the installable rpm package.
|
|
%install
|
|
PODMAN_VERSION=%{version} %{__make} DESTDIR=%{buildroot} PREFIX=%{_prefix} ETCDIR=%{buildroot}%{_sysconfdir} \
|
|
install.bin \
|
|
install.man \
|
|
install.systemd \
|
|
install.completions \
|
|
install.docker \
|
|
install.docker-docs \
|
|
install.remote \
|
|
%if 0%{?fedora} >= 36
|
|
install.modules-load
|
|
%endif
|
|
|
|
install -d -p %{buildroot}/%{_datadir}/%{name}/test/system
|
|
cp -pav test/system %{buildroot}/%{_datadir}/%{name}/test/
|
|
|
|
mv pkg/hooks/README.md pkg/hooks/README-hooks.md
|
|
|
|
# do not include docker and podman-remote man pages in main package
|
|
for file in `find %{buildroot}%{_mandir}/man[15] -type f | sed "s,%{buildroot},," | grep -v -e remote -e docker`; do
|
|
echo "$file*" >> podman.file-list
|
|
done
|
|
|
|
# This lists all the files that are included in the rpm package and that
|
|
# are going to be installed into target system where the rpm is installed.
|
|
%files -f %{name}.file-list
|
|
%license LICENSE
|
|
%doc README.md CONTRIBUTING.md pkg/hooks/README-hooks.md install.md transfer.md
|
|
%{_bindir}/%{name}
|
|
%dir %{_libexecdir}/%{name}
|
|
%{_libexecdir}/%{name}/rootlessport
|
|
%{_datadir}/bash-completion/completions/%{name}
|
|
# By "owning" the site-functions dir, we don't need to Require zsh
|
|
%dir %{_datadir}/zsh/site-functions
|
|
%{_datadir}/zsh/site-functions/_%{name}
|
|
%dir %{_datadir}/fish/vendor_completions.d
|
|
%{_datadir}/fish/vendor_completions.d/%{name}.fish
|
|
%{_unitdir}/%{name}-auto-update.service
|
|
%{_unitdir}/%{name}-auto-update.timer
|
|
%{_unitdir}/%{name}.service
|
|
%{_unitdir}/%{name}.socket
|
|
%{_unitdir}/%{name}-restart.service
|
|
%{_userunitdir}/%{name}-auto-update.service
|
|
%{_userunitdir}/%{name}-auto-update.timer
|
|
%{_userunitdir}/%{name}.service
|
|
%{_userunitdir}/%{name}.socket
|
|
%{_userunitdir}/%{name}-restart.service
|
|
%{_tmpfilesdir}/%{name}.conf
|
|
%if 0%{?fedora} >= 36
|
|
%{_modulesloaddir}/%{name}-iptables.conf
|
|
%endif
|
|
|
|
%files docker
|
|
%{_bindir}/docker
|
|
%{_mandir}/man1/docker*.1*
|
|
%{_mandir}/man5/docker*.5*
|
|
%{_usr}/lib/tmpfiles.d/%{name}-docker.conf
|
|
|
|
%files remote
|
|
%license LICENSE
|
|
%{_bindir}/%{name}-remote
|
|
%{_mandir}/man1/%{name}-remote*.*
|
|
%{_datadir}/bash-completion/completions/%{name}-remote
|
|
%dir %{_datadir}/fish/vendor_completions.d
|
|
%{_datadir}/fish/vendor_completions.d/%{name}-remote.fish
|
|
%dir %{_datadir}/zsh/site-functions
|
|
%{_datadir}/zsh/site-functions/_%{name}-remote
|
|
|
|
%files tests
|
|
%license LICENSE
|
|
%{_datadir}/%{name}/test
|
|
|
|
# Finally, changes from the latest release of your application are generated from
|
|
# your project's Git history. It will be empty until you make first annotated Git tag.
|
|
%changelog
|
|
{{{ git_dir_changelog }}}
|