# # spec file for package nftables # # Copyright (c) 2024 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/ # # configure subpackage rewriter for the python3XX-nftables bindings %define python_subpackage_only 1 # check py/src/nftable.py:NFTABLES_VERSION %define pyversion 0.1 Name: nftables Version: 1.1.1 Release: 0 Summary: Userspace utility to access the nf_tables packet filter License: GPL-2.0-only Group: Productivity/Networking/Security URL: https://netfilter.org/projects/nftables/ #Git-Clone: git://git.netfilter.org/nftables Source: http://ftp.netfilter.org/pub/%name/%name-%version.tar.xz Source2: http://ftp.netfilter.org/pub/%name/%name-%version.tar.xz.sig Source3: %name.keyring Source4: nftables.rpmlintrc Source5: main.nft Source6: nftables.service Source7: README.SUSE BuildRequires: %{python_module pip} BuildRequires: %{python_module setuptools} BuildRequires: %{python_module wheel} BuildRequires: asciidoc BuildRequires: bison BuildRequires: fdupes BuildRequires: flex BuildRequires: gmp-devel BuildRequires: libtool BuildRequires: pkg-config >= 0.21 BuildRequires: python-rpm-macros BuildRequires: pkgconfig(jansson) BuildRequires: pkgconfig(libedit) BuildRequires: pkgconfig(libmnl) >= 1.0.4 BuildRequires: pkgconfig(libnftnl) >= 1.2.8 BuildRequires: pkgconfig(xtables) >= 1.6.1 %python_subpackages %description nf_tables is a firewalling mechanism in the Linux kernel, running independently of and parallel to ip_tables, ip6_tables, arp_tables and ebtables. nftables is the corresponsing userspace frontend. The nftables frontend features support for sets and dictionaries of arbitrary types, meta data types, atomic incremental and full ruleset updates, and, similar to iptables, support for different protocols, access to connection tracking and NAT and logging. %package -n libnftables1 Summary: nftables firewalling command interface Group: System/Libraries %description -n libnftables1 libnftables is the nftables command line interface placed into a library. %package devel Summary: Development files for the nftables command line interface Group: Development/Libraries/C and C++ Requires: libnftables1 = %version %description devel libnftables is the nftables command line interface placed into a library. This package contains the header files for the library. %package -n python-nftables Summary: Python bindings for nftables Group: Development/Languages/Python # uses dlopen Requires: libnftables1 BuildArch: noarch %description -n python-nftables Python bindings for nftables %prep %autosetup -p1 # remove unused shebang sed -i '1{/bin/d}' py/src/nftables.py %build autoreconf -fi mkdir bin ln -s "%_bindir/docbook-to-man" bin/docbook2x-man export PATH="$PATH:$PWD/bin" mkdir obj pushd obj/ %define _configure ../configure %configure --disable-silent-rules --disable-static --docdir="%_docdir/%name" \ --includedir="%_includedir/%name" --with-json \ --enable-python --with-python-bin="$(which python3)" %make_build popd pushd py %pyproject_wheel popd cp %{SOURCE7} . %install b="%buildroot" %make_install -C obj pushd py %pyproject_install %python_expand %fdupes %buildroot/%{$python_sitelib} popd rm -f "%buildroot/%_libdir"/*.la mkdir -p "$b/%_docdir/%name/examples" mv -v "$b/%_datadir/nftables"/*.nft "$b/%_docdir/%name/examples/" # create directories and install files for static firewall setup via nftables.service install -D -d -m 0755 $b/%{_sysconfdir}/%{name}/rules $b/%{_distconfdir}/%{name}/rules $b/%{_unitdir} install -m 0755 %{SOURCE5} $b/%{_docdir}/%name/ install -m 0644 %{SOURCE6} $b/%{_unitdir}/ %ldconfig_scriptlets -n libnftables1 %pre %service_add_pre nftables.service %post %service_add_post nftables.service %preun %service_del_preun nftables.service %postun %service_del_postun nftables.service %files %license COPYING %_sysconfdir/nftables/ %_sysconfdir/nftables/rules %_sbindir/nft %_mandir/man5/*.5* %_mandir/man8/nft* %_docdir/%name/ %doc README.SUSE %_unitdir/nftables.service %files -n libnftables1 %_libdir/libnftables.so.1* %files devel %_includedir/%name/ %_libdir/libnftables.so %_libdir/pkgconfig/*.pc %_mandir/man3/*.3* %files %{python_files nftables} %python_sitelib/nftables %python_sitelib/nftables-%pyversion.dist-info %changelog