2022-02-01 16:47:08 +00:00
|
|
|
# Building from fedora dependencies not possible
|
|
|
|
# Latest upstream rtnetlink frequently required
|
|
|
|
# sha2, zbus, zvariant are currently out of date
|
|
|
|
|
2023-02-08 15:45:41 +00:00
|
|
|
%global with_debug 1
|
|
|
|
|
|
|
|
%if 0%{?with_debug}
|
|
|
|
%global _find_debuginfo_dwz_opts %{nil}
|
|
|
|
%global _dwz_low_mem_die_limit 0
|
|
|
|
%else
|
2022-02-01 16:47:08 +00:00
|
|
|
%global debug_package %{nil}
|
2023-02-08 15:45:41 +00:00
|
|
|
%endif
|
2022-02-01 16:47:08 +00:00
|
|
|
|
2024-01-31 20:43:43 +00:00
|
|
|
# Minimum X.Y dep for aardvark-dns
|
|
|
|
%define major_minor %((v=%{version}; echo ${v%.*}))
|
|
|
|
|
2024-08-05 06:04:47 +00:00
|
|
|
# Set default firewall to nftables on CentOS Stream 10+, RHEL 10+, Fedora 41+
|
2024-05-31 12:08:09 +00:00
|
|
|
# and default to iptables on all other environments
|
|
|
|
# The `rhel` macro is defined on CentOS Stream, RHEL as well as Fedora ELN.
|
2024-08-05 06:04:47 +00:00
|
|
|
%if (%{defined rhel} && 0%{?rhel} >= 10) || (%{defined fedora} && 0%{?fedora} >= 41)
|
2024-05-31 12:08:09 +00:00
|
|
|
%define default_fw nftables
|
|
|
|
%else
|
|
|
|
%define default_fw iptables
|
|
|
|
%endif
|
|
|
|
|
2022-02-01 16:47:08 +00:00
|
|
|
Name: netavark
|
2023-06-29 13:56:28 +00:00
|
|
|
# Set a different Epoch for copr builds
|
2023-09-27 18:33:15 +00:00
|
|
|
%if %{defined copr_username}
|
2023-06-29 13:56:28 +00:00
|
|
|
Epoch: 102
|
2024-01-31 20:43:43 +00:00
|
|
|
%else
|
2024-07-09 10:28:22 +00:00
|
|
|
Epoch: 2
|
2023-06-29 13:56:28 +00:00
|
|
|
%endif
|
2024-08-20 09:07:13 +00:00
|
|
|
Version: 1.12.2
|
2024-08-05 06:04:47 +00:00
|
|
|
Release: 1%{?dist}
|
2023-09-27 18:33:15 +00:00
|
|
|
# The `AND` needs to be uppercase in the License for SPDX compatibility
|
|
|
|
License: Apache-2.0 AND BSD-3-Clause AND MIT
|
2023-06-29 13:56:28 +00:00
|
|
|
%if %{defined golang_arches_future}
|
2023-03-06 11:25:00 +00:00
|
|
|
ExclusiveArch: %{golang_arches_future}
|
2023-06-29 13:56:28 +00:00
|
|
|
%else
|
|
|
|
ExclusiveArch: aarch64 ppc64le s390x x86_64
|
|
|
|
%endif
|
2022-05-18 14:45:14 +00:00
|
|
|
Summary: OCI network stack
|
2022-02-01 16:47:08 +00:00
|
|
|
URL: https://github.com/containers/%{name}
|
2022-10-04 14:42:33 +00:00
|
|
|
# Tarballs fetched from upstream's release page
|
2023-06-29 13:56:28 +00:00
|
|
|
Source0: %{url}/archive/v%{version}.tar.gz
|
|
|
|
Source1: %{url}/releases/download/v%{version}/%{name}-v%{version}-vendor.tar.gz
|
2022-02-01 16:47:08 +00:00
|
|
|
BuildRequires: cargo
|
2023-09-27 18:33:15 +00:00
|
|
|
BuildRequires: %{_bindir}/go-md2man
|
2024-01-31 20:43:43 +00:00
|
|
|
# aardvark-dns and %%{name} are usually released in sync
|
2024-05-31 12:08:09 +00:00
|
|
|
Requires: aardvark-dns >= %{epoch}:%{major_minor}
|
2022-05-18 14:45:14 +00:00
|
|
|
Provides: container-network-stack = 2
|
2024-08-05 06:04:47 +00:00
|
|
|
%if "%{default_fw}" == "nftables"
|
|
|
|
Requires: nftables
|
|
|
|
%else
|
|
|
|
Requires: iptables
|
|
|
|
%endif
|
2022-02-01 16:47:08 +00:00
|
|
|
BuildRequires: make
|
2023-02-08 15:15:41 +00:00
|
|
|
BuildRequires: protobuf-c
|
|
|
|
BuildRequires: protobuf-compiler
|
2023-05-30 19:51:30 +00:00
|
|
|
%if %{defined rhel}
|
2023-09-27 18:33:15 +00:00
|
|
|
# rust-toolset requires the `local` repo enabled on non-koji ELN build environments
|
2023-05-30 19:51:30 +00:00
|
|
|
BuildRequires: rust-toolset
|
|
|
|
%else
|
2023-02-08 15:45:41 +00:00
|
|
|
BuildRequires: rust-packaging
|
2022-02-01 16:47:08 +00:00
|
|
|
BuildRequires: rust-srpm-macros
|
2023-05-30 19:51:30 +00:00
|
|
|
%endif
|
2022-02-01 16:47:08 +00:00
|
|
|
BuildRequires: git-core
|
2023-04-12 12:27:43 +00:00
|
|
|
BuildRequires: systemd
|
|
|
|
BuildRequires: systemd-devel
|
2022-02-01 16:47:08 +00:00
|
|
|
|
|
|
|
%description
|
|
|
|
%{summary}
|
|
|
|
|
|
|
|
Netavark is a rust based network stack for containers. It is being
|
|
|
|
designed to work with Podman but is also applicable for other OCI
|
|
|
|
container management applications.
|
|
|
|
|
|
|
|
Netavark is a tool for configuring networking for Linux containers.
|
|
|
|
Its features include:
|
|
|
|
* Configuration of container networks via JSON configuration file
|
|
|
|
* Creation and management of required network interfaces,
|
|
|
|
including MACVLAN networks
|
|
|
|
* All required firewall configuration to perform NAT and port
|
|
|
|
forwarding as required for containers
|
|
|
|
* Support for iptables and firewalld at present, with support
|
|
|
|
for nftables planned in a future release
|
|
|
|
* Support for rootless containers
|
|
|
|
* Support for IPv4 and IPv6
|
|
|
|
* Support for container DNS resolution via aardvark-dns.
|
|
|
|
|
|
|
|
%prep
|
2023-06-29 13:56:28 +00:00
|
|
|
%autosetup -Sgit %{name}-%{version}
|
|
|
|
# Following steps are only required on environments like koji which have no
|
|
|
|
# network access and thus depend on the vendored tarball. Copr pulls
|
|
|
|
# dependencies directly from the network.
|
2023-09-27 18:33:15 +00:00
|
|
|
%if !%{defined copr_username}
|
2022-02-25 16:22:16 +00:00
|
|
|
tar fx %{SOURCE1}
|
2024-08-05 06:04:47 +00:00
|
|
|
%if 0%{?fedora} || 0%{?rhel} >= 10
|
|
|
|
%cargo_prep -v vendor
|
|
|
|
%else
|
|
|
|
%cargo_prep -V 1
|
|
|
|
%endif
|
2023-06-29 13:56:28 +00:00
|
|
|
%endif
|
2022-02-01 16:47:08 +00:00
|
|
|
|
|
|
|
%build
|
2024-05-31 12:08:09 +00:00
|
|
|
NETAVARK_DEFAULT_FW=%{default_fw} %{__make} CARGO="%{__cargo}" build
|
2024-08-05 06:04:47 +00:00
|
|
|
%if (0%{?fedora} || 0%{?rhel} >= 10) && !%{defined copr_username}
|
|
|
|
%cargo_license_summary
|
|
|
|
%{cargo_license} > LICENSE.dependencies
|
|
|
|
%cargo_vendor_manifest
|
|
|
|
%endif
|
2022-02-01 16:47:08 +00:00
|
|
|
|
2022-05-18 14:45:14 +00:00
|
|
|
cd docs
|
2023-09-27 18:33:15 +00:00
|
|
|
%{__make}
|
2022-02-01 16:47:08 +00:00
|
|
|
|
|
|
|
%install
|
|
|
|
%{__make} DESTDIR=%{buildroot} PREFIX=%{_prefix} install
|
|
|
|
|
2023-04-11 17:28:58 +00:00
|
|
|
%preun
|
|
|
|
%systemd_preun %{name}-dhcp-proxy.service
|
2023-11-27 14:19:04 +00:00
|
|
|
%systemd_preun %{name}-firewalld-reload.service
|
2023-04-11 17:28:58 +00:00
|
|
|
|
|
|
|
%postun
|
|
|
|
%systemd_postun %{name}-dhcp-proxy.service
|
2023-11-27 14:19:04 +00:00
|
|
|
%systemd_postun %{name}-firewalld-reload.service
|
2023-04-11 17:28:58 +00:00
|
|
|
|
2022-02-01 16:47:08 +00:00
|
|
|
%files
|
|
|
|
%license LICENSE
|
2024-08-05 06:04:47 +00:00
|
|
|
%if (0%{?fedora} || 0%{?rhel} >= 10) && !%{defined copr_username}
|
|
|
|
%license LICENSE.dependencies
|
|
|
|
%license cargo-vendor.txt
|
|
|
|
%endif
|
2022-02-01 16:47:08 +00:00
|
|
|
%dir %{_libexecdir}/podman
|
2023-03-06 11:23:58 +00:00
|
|
|
%{_libexecdir}/podman/%{name}*
|
2022-02-01 16:47:08 +00:00
|
|
|
%{_mandir}/man1/%{name}.1*
|
2023-04-11 17:28:58 +00:00
|
|
|
%{_unitdir}/%{name}-dhcp-proxy.service
|
|
|
|
%{_unitdir}/%{name}-dhcp-proxy.socket
|
2023-11-27 14:19:04 +00:00
|
|
|
%{_unitdir}/%{name}-firewalld-reload.service
|
2022-02-01 16:47:08 +00:00
|
|
|
|
|
|
|
%changelog
|
|
|
|
%autochangelog
|