recipe 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. # Build recipe for iptables.
  2. #
  3. # Copyright (c) 2017-2022 Matias Fonzo, <selk@dragora.org>.
  4. #
  5. # Licensed under the Apache License, Version 2.0 (the "License");
  6. # you may not use this file except in compliance with the License.
  7. # You may obtain a copy of the License at
  8. #
  9. # http://www.apache.org/licenses/LICENSE-2.0
  10. #
  11. # Unless required by applicable law or agreed to in writing, software
  12. # distributed under the License is distributed on an "AS IS" BASIS,
  13. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. # See the License for the specific language governing permissions and
  15. # limitations under the License.
  16. # Exit immediately on any error
  17. set -e
  18. program=iptables
  19. version=1.8.8
  20. release=1
  21. # Define a category for the output of the package name
  22. pkgcategory=networking
  23. tarname=${program}-${version}.tar.bz2
  24. # Remote source(s)
  25. fetch=https://www.netfilter.org/projects/iptables/files/$tarname
  26. description="
  27. The main firewall program in GNU/Linux.
  28. iptables is the userspace command line program used to configure the
  29. Linux 2.4.x and later packet filtering ruleset. It is targeted towards
  30. system administrators.
  31. Since Network Address Translation is also configured from the packet
  32. filter ruleset, iptables is used for this, too.
  33. The iptables package also includes ip6tables. ip6tables is used for
  34. configuring the IPv6 packet filter.
  35. "
  36. homepage=https://www.netfilter.org/projects/iptables/index.html
  37. license="GPLv2 only"
  38. # Source documentation
  39. docs="COMMIT_NOTES COPYING INCOMPATIBILITIES"
  40. docsdir="${docdir}/${program}-${version}"
  41. build()
  42. {
  43. unpack "${tardir}/$tarname"
  44. cd "$srcdir"
  45. # Apply fixes from "Alpine Linux" in order to build IPTables against Musl
  46. patch -Np1 -i "${worktree}/patches/iptables/fix-u_int16_t.patch"
  47. patch -Np1 -i "${worktree}/patches/iptables/fix-xtables.patch"
  48. # Set sane permissions
  49. chmod -R u+w,go-w,a+rX-s .
  50. ./configure CPPFLAGS="$QICPPFLAGS" \
  51. CFLAGS="$QICFLAGS" LDFLAGS="$QILDFLAGS" \
  52. $configure_args \
  53. --libdir=/usr/lib${libSuffix} \
  54. --docdir=$docsdir \
  55. --mandir=$mandir \
  56. --enable-devel \
  57. --enable-libipq \
  58. --enable-bpf-compiler \
  59. --enable-nfsynproxy \
  60. --with-xt-lock-name=/var/lock/xtables.lock \
  61. --without-kernel \
  62. --build="$(gcc -dumpmachine)"
  63. make -j${jobs} V=1
  64. make -j${jobs} DESTDIR="$destdir" install
  65. # Manage dot new config file
  66. touch "${destdir}/etc/.graft-config"
  67. # Compress and link man pages (if needed)
  68. if test -d "${destdir}/$mandir"
  69. then
  70. (
  71. cd "${destdir}/$mandir"
  72. find . -type f -exec lzip -9 {} +
  73. find . -type l | while read -r file
  74. do
  75. ln -sf "$(readlink -- "$file").lz" "${file}.lz"
  76. rm -- "$file"
  77. done
  78. )
  79. fi
  80. # Copy documentation
  81. mkdir -p "${destdir}/$docsdir"
  82. cp -p $docs "${destdir}/$docsdir"
  83. }