10 %define release %{taglevel}%{?pldistro:.%{pldistro}}%{?date:.%{date}}
13 Packager: PlanetLab Central <support@planet-lab.org>
14 Distribution: PlanetLab %{plrelease}
15 URL: %(echo %{url} | cut -d ' ' -f 2)
18 %define linux_header 0
20 Summary: Tools for managing Linux kernel packet filtering capabilities.
24 Source: http://www.netfilter.org/%{name}-%{version}.tar.bz2
25 %define SOURCE1 iptables.init
26 %define SOURCE2 iptables-config
27 %define SOURCE3 planetlab-config
28 Group: System Environment/Base
29 #URL: http://www.netfilter.org/
30 BuildRoot: %{_tmppath}/%{name}-buildroot
32 BuildPrereq: /usr/bin/perl
33 Requires: kernel >= 2.4.20
34 Requires(post,postun): chkconfig
36 BuildRequires: kernel-devel
39 Summary: IPv6 support for iptables.
40 Group: System Environment/Base
41 Requires: %{name} = %{version}
45 Summary: Development package for iptables.
46 Group: System Environment/Base
47 Requires: %{name} = %{version}
51 The iptables utility controls the network packet filtering code in the
52 Linux kernel. If you need to set up firewalls and/or IP masquerading,
53 you should install this package.
56 The iptables package contains IPv6 (the next version of the IP
57 protocol) support for iptables. Iptables controls the Linux kernel
58 network packet filtering code, allowing you to set up firewalls and IP
61 Install iptables-ipv6 if you need to set up firewalling for your
62 network and you are using ipv6.
66 The iptables utility controls the network packet filtering code in the
67 Linux kernel. If you need to set up firewalls and/or IP masquerading,
68 you should install this package.
76 # Put it to a reasonable place
77 find . -type f -exec perl -pi -e "s,/usr,%{prefix},g" {} \;
81 OPT="$RPM_OPT_FLAGS -I$TOPDIR/include"
83 %define KERNEL %(rpm -q --qf '%%{VERSION}-%%{RELEASE}-%%{ARCH}\\n' kernel-devel | tail -n 1 )
84 count=$(rpm -q kernel-devel| wc -l)
85 if [ $count -gt 1 ] ; then
86 echo "WARNING: choosing kernel-devel-%{KERNEL}"
87 echo " but there are other kernel-devel packages installed: $(rpm -q kernel-devel)"
90 %define KERNEL_DIR "/usr/src/kernels/%{KERNEL}"
92 make COPT_FLAGS="$OPT" KERNEL_DIR=%{KERNEL_DIR} LIBDIR=/%{_lib}
93 make COPT_FLAGS="$OPT" KERNEL_DIR=%{KERNEL_DIR} LIBDIR=/%{_lib} iptables-save iptables-restore
94 make COPT_FLAGS="$OPT" KERNEL_DIR=%{KERNEL_DIR} LIBDIR=/%{_lib} ip6tables-save ip6tables-restore
97 make install DESTDIR=%{buildroot} KERNEL_DIR=%{KERNEL_DIR} BINDIR=/sbin LIBDIR=/%{_lib} MANDIR=%{_mandir}
99 make install-devel DESTDIR=%{buildroot} KERNEL_DIR=%{KERNEL_DIR} BINDIR=/sbin LIBDIR=%{_libdir} MANDIR=%{_mandir} INCDIR=%{_includedir}
101 cp ip{6,}tables-{save,restore} $RPM_BUILD_ROOT/sbin
102 cp iptables-*.8 $RPM_BUILD_ROOT%{_mandir}/man8
103 mkdir -p $RPM_BUILD_ROOT/etc/rc.d/init.d
104 install -c -m755 %{SOURCE1} $RPM_BUILD_ROOT/etc/rc.d/init.d/iptables
105 sed -e 's;iptables;ip6tables;g' -e 's;IPTABLES;IP6TABLES;g' < %{SOURCE1} > ip6tables.init
106 install -c -m755 ip6tables.init $RPM_BUILD_ROOT/etc/rc.d/init.d/ip6tables
107 mkdir -p $RPM_BUILD_ROOT/etc/sysconfig
108 install -c -m755 %{SOURCE2} $RPM_BUILD_ROOT/etc/sysconfig/iptables-config
109 install -c -m755 %{SOURCE3} $RPM_BUILD_ROOT/etc/sysconfig/iptables
110 sed -e 's;iptables;ip6tables;g' -e 's;IPTABLES;IP6TABLES;g' < %{SOURCE2} > ip6tables-config
111 install -c -m755 ip6tables-config $RPM_BUILD_ROOT/etc/sysconfig/ip6tables-config
114 rm -rf $RPM_BUILD_ROOT
117 /sbin/chkconfig --add iptables
118 if [ "$PL_BOOTCD" != "1" ] ; then
119 /sbin/service iptables restart
123 if [ "$1" = 0 ]; then
124 /sbin/chkconfig --del iptables
128 /sbin/chkconfig --add ip6tables
129 if [ "$PL_BOOTCD" != "1" ] ; then
130 /sbin/service ip6tables restart
134 if [ "$1" = 0 ]; then
135 /sbin/chkconfig --del ip6tables
139 %defattr(-,root,root,0755)
140 %doc COPYING INSTALL INCOMPATIBILITIES
141 %config %attr(0755,root,root) /etc/rc.d/init.d/iptables
142 %config(noreplace) %attr(0600,root,root) /etc/sysconfig/iptables-config
143 %config(noreplace) %attr(0600,root,root) /etc/sysconfig/iptables
145 %{_mandir}/man8/iptables*
146 %dir /%{_lib}/iptables
147 /%{_lib}/iptables/libipt*
149 %{_mandir}/man8/ipset*
151 /%{_lib}/ipset/libipset*
154 %defattr(-,root,root,0755)
155 %config %attr(0755,root,root) /etc/rc.d/init.d/ip6tables
156 %config(noreplace) %attr(0600,root,root) /etc/sysconfig/ip6tables-config
158 %{_mandir}/man8/ip6tables*
159 /%{_lib}/iptables/libip6t*
163 %defattr(-,root,root,0755)
164 %{_includedir}/libipq.h
166 #%{_libdir}/libiptc.a
171 * Wed Apr 14 2010 Thierry Parmentelat <thierry.parmentelat@sophia.inria.fr> - iptables-1.3.8-12
172 - no change but previous tag had screwed up
174 * Thu Jan 28 2010 Talip Baris Metin <Talip-Baris.Metin@sophia.inria.fr> - iptables-1.3.8-10
175 - tag iptables for f12 & gcc4.4 builds.
177 * Wed Sep 10 2008 Thierry Parmentelat <thierry.parmentelat@sophia.inria.fr> - iptables-1.3.8-9
178 - fixes for building on f9/gcc-4.3 - no functional change
180 * Sat Aug 30 2008 Thierry Parmentelat <thierry.parmentelat@sophia.inria.fr> - iptables-1.3.8-8
181 - use PL_BOOTCD to prevent the service from getting started at build-time
183 * Mon Aug 04 2008 Sapan Bhatia <sapanb@cs.princeton.edu> - iptables-1.3.8-7
186 * Mon Jul 28 2008 Faiyaz Ahmed <faiyaza@cs.princeton.edu> - iptables-1.3.8-6
187 - Syntax error in the spec file prevented this package from installing. Fixed.
189 * Fri Jul 25 2008 Andy Bavier <acb@cs.princeton.edu> - iptables-1.3.8-5
190 - * --add-mark action in CLASSIFY target
191 - * Remove chkconfig from .spec file
192 - * Fix iptables-save/-restore bug for MARK with --copy-xid
193 - * Fix default PlanetLab iptables config
195 * Mon Jul 21 2008 Sapan Bhatia <sapanb@cs.princeton.edu> - iptables-1.3.8-4
198 * Tue Jul 15 2008 Sapan Bhatia <sapanb@cs.princeton.edu> - iptables-1.3.8-3
199 - * Load required kernel modules before configuring tun/tap devices
201 * Wed Jul 09 2008 Sapan Bhatia <sapanb@cs.princeton.edu> - iptables-1.3.8-2
202 - Added tuntap support. Let's start it in the iptables initscripts for now.
204 * Wed Apr 23 2008 Stephen Soltesz <soltesz@cs.princeton.edu> - iptables-1.3.8-1
205 - Commit for latest fixes in trunk for the iptables config. This one in
206 - particular loads ip_conntrack in order to have the new vnet support ping right
210 * Tue Mar 02 2004 Elliot Lee <sopwith@redhat.com>
213 * Thu Feb 26 2004 Thomas Woerner <twoerner@redhat.com> 1.2.9-2.3
214 - fixed iptables-restore -c fault if there are no counters (#116421)
216 * Fri Feb 13 2004 Elliot Lee <sopwith@redhat.com>
219 * Sun Jan 25 2004 Dan Walsh <dwalsh@redhat.com> 1.2.9-1.2
220 - Close File descriptors to prevent SELinux error message
222 * Wed Jan 7 2004 Thomas Woerner <twoerner@redhat.com> 1.2.9-1.1
225 * Wed Dec 17 2003 Thomas Woerner <twoerner@redhat.com> 1.2.9-1
227 - new config options in ipXtables-config:
228 IPTABLES_MODULES_UNLOAD
229 - more documentation in ipXtables-config
230 - fix for netlink security issue in libipq (devel package)
231 - print fix for libipt_icmp (#109546)
233 * Thu Oct 23 2003 Thomas Woerner <twoerner@redhat.com> 1.2.8-13
234 - marked all messages in iptables init script for translation (#107462)
235 - enabled devel package (#105884, #106101)
236 - bumped build for fedora for libipt_recent.so (#106002)
238 * Tue Sep 23 2003 Thomas Woerner <twoerner@redhat.com> 1.2.8-12.1
239 - fixed lost udp port range in ip6tables-save (#104484)
240 - fixed non numeric multiport port output in ipXtables-savs
242 * Mon Sep 22 2003 Florian La Roche <Florian.LaRoche@redhat.de> 1.2.8-11
243 - do not link against -lnsl
245 * Wed Sep 17 2003 Thomas Woerner <twoerner@redhat.com> 1.2.8-10
246 - made variables in rmmod_r local
248 * Tue Jul 22 2003 Thomas Woerner <twoerner@redhat.com> 1.2.8-9
249 - fixed permission for init script
251 * Sat Jul 19 2003 Thomas Woerner <twoerner@redhat.com> 1.2.8-8
252 - fixed save when iptables file is missing and iptables-config permissions
254 * Tue Jul 8 2003 Thomas Woerner <twoerner@redhat.com> 1.2.8-7
255 - fixes for ip6tables: module unloading, setting policy only for existing
258 * Thu Jul 3 2003 Thomas Woerner <twoerner@redhat.com> 1.2.8-6
259 - IPTABLES_SAVE_COUNTER defaults to no, now
260 - install config file in /etc/sysconfig
261 - exchange unload of ip_tables and ip_conntrack
262 - fixed start function
264 * Wed Jul 2 2003 Thomas Woerner <twoerner@redhat.com> 1.2.8-5
265 - new config option IPTABLES_SAVE_ON_RESTART
266 - init script: new status, save and restart
267 - fixes #44905, #65389, #80785, #82860, #91040, #91560 and #91374
269 * Mon Jun 30 2003 Thomas Woerner <twoerner@redhat.com> 1.2.8-4
270 - new config option IPTABLES_STATUS_NUMERIC
271 - cleared IPTABLES_MODULES in iptables-config
273 * Mon Jun 30 2003 Thomas Woerner <twoerner@redhat.com> 1.2.8-3
276 * Sat Jun 28 2003 Florian La Roche <Florian.LaRoche@redhat.de>
277 - remove check for very old kernel versions in init scripts
278 - sync up both init scripts and remove some further ugly things
279 - add some docu into rpm
281 * Thu Jun 26 2003 Thomas Woerner <twoerner@redhat.com> 1.2.8-2
284 * Mon Jun 16 2003 Thomas Woerner <twoerner@redhat.com> 1.2.8-1
287 * Wed Jan 22 2003 Tim Powers <timp@redhat.com>
290 * Mon Jan 13 2003 Bill Nottingham <notting@redhat.com> 1.2.7a-1
292 - add a plethora of bugfixes courtesy Michael Schwendt <mschewndt@yahoo.com>
294 * Fri Dec 13 2002 Elliot Lee <sopwith@redhat.com> 1.2.6a-3
297 * Wed Aug 07 2002 Karsten Hopp <karsten@redhat.de>
298 - fixed iptables and ip6tables initscript output, based on #70511
299 - check return status of all iptables calls, not just the last one
302 * Mon Jul 29 2002 Bernhard Rosenkraenzer <bero@redhat.com> 1.2.6a-1
303 - 1.2.6a (bugfix release, #69747)
305 * Fri Jun 21 2002 Tim Powers <timp@redhat.com>
308 * Thu May 23 2002 Tim Powers <timp@redhat.com>
311 * Mon Mar 4 2002 Bernhard Rosenkraenzer <bero@redhat.com> 1.2.5-3
312 - Add some fixes from CVS, fixing bug #60465
314 * Tue Feb 12 2002 Bernhard Rosenkraenzer <bero@redhat.com> 1.2.5-2
315 - Merge ip6tables improvements from Ian Prowell <iprowell@prowell.org>
317 - Update URL (#59354)
318 - Use /sbin/chkconfig rather than chkconfig in %postun script
320 * Fri Jan 11 2002 Bernhard Rosenkraenzer <bero@redhat.com> 1.2.5-1
323 * Wed Jan 09 2002 Tim Powers <timp@redhat.com>
326 * Mon Nov 5 2001 Bernhard Rosenkraenzer <bero@redhat.com> 1.2.4-2
329 * Tue Oct 30 2001 Bernhard Rosenkraenzer <bero@redhat.com> 1.2.4-1
330 - Update to 1.2.4 (various fixes, including security fixes; among others:
331 #42990, #50500, #53325, #54280)
332 - Fix init script (#31133)
334 * Mon Sep 3 2001 Bernhard Rosenkraenzer <bero@redhat.com> 1.2.3-1
335 - 1.2.3 (5 security fixes, some other fixes)
336 - Fix updating (#53032)
338 * Mon Aug 27 2001 Bernhard Rosenkraenzer <bero@redhat.com> 1.2.2-4
340 - Add some fixes from current CVS; should fix #52620
342 * Mon Jul 16 2001 Bernhard Rosenkraenzer <bero@redhat.com> 1.2.2-3
343 - Add some fixes from the current CVS tree; fixes #49154 and some IPv6
346 * Tue Jun 26 2001 Bernhard Rosenkraenzer <bero@redhat.com> 1.2.2-2
347 - Fix iptables-save reject-with (#45632), Patch from Michael Schwendt
348 <mschwendt@yahoo.com>
350 * Tue May 8 2001 Bernhard Rosenkraenzer <bero@redhat.com> 1.2.2-1
353 * Wed Mar 21 2001 Bernhard Rosenkraenzer <bero@redhat.com>
354 - 1.2.1a, fixes #28412, #31136, #31460, #31133
356 * Thu Mar 1 2001 Bernhard Rosenkraenzer <bero@redhat.com>
357 - Yet another initscript fix (#30173)
358 - Fix the fixes; they fixed some issues but broke more important
361 * Tue Feb 27 2001 Bernhard Rosenkraenzer <bero@redhat.com>
362 - Fix up initscript (#27962)
363 - Add fixes from CVS to iptables-{restore,save}, fixing #28412
365 * Fri Feb 09 2001 Karsten Hopp <karsten@redhat.de>
366 - create /etc/sysconfig/iptables mode 600 (same problem as #24245)
368 * Mon Feb 05 2001 Karsten Hopp <karsten@redhat.de>
369 - fix bugzilla #25986 (initscript not marked as config file)
370 - fix bugzilla #25962 (iptables-restore)
371 - mv chkconfig --del from postun to preun
373 * Thu Feb 1 2001 Trond Eivind Glomsrød <teg@redhat.com>
374 - Fix check for ipchains
376 * Mon Jan 29 2001 Bernhard Rosenkraenzer <bero@redhat.com>
377 - Some fixes to init scripts
379 * Wed Jan 24 2001 Bernhard Rosenkraenzer <bero@redhat.com>
380 - Add some fixes from CVS, fixes among other things Bug #24732
382 * Wed Jan 17 2001 Bernhard Rosenkraenzer <bero@redhat.com>
383 - Add missing man pages, fix up init script (Bug #17676)
385 * Mon Jan 15 2001 Bill Nottingham <notting@redhat.com>
388 * Mon Jan 15 2001 Bernhard Rosenkraenzer <bero@redhat.com>
392 - Move the plugins from /usr/lib/iptables to /lib/iptables.
393 This needs to work before /usr is mounted...
394 - Use -O1 on alpha (compiler bug)
396 * Sat Jan 6 2001 Bernhard Rosenkraenzer <bero@redhat.com>
398 - Add IPv6 support (in separate package)
400 * Thu Aug 17 2000 Bill Nottingham <notting@redhat.com>
403 * Tue Jul 25 2000 Bernhard Rosenkraenzer <bero@redhat.com>
406 * Thu Jul 13 2000 Prospector <bugzilla@redhat.com>
409 * Tue Jun 27 2000 Preston Brown <pbrown@redhat.com>
410 - move iptables to /sbin.
411 - excludearch alpha for now, not building there because of compiler bug(?)
413 * Fri Jun 9 2000 Bill Nottingham <notting@redhat.com>
414 - don't obsolete ipchains either
417 * Mon Jun 4 2000 Bill Nottingham <notting@redhat.com>
418 - remove explicit kernel requirement
420 * Tue May 2 2000 Bernhard Rosenkränzer <bero@redhat.com>