recipe 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. # Build recipe for libressl.
  2. #
  3. # Copyright (c) 2017-2019, 2021-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=libressl
  19. version=3.4.2
  20. release=1
  21. # Define a category for the output of the package name
  22. pkgcategory=networking
  23. tarname=${program}-${version}.tar.gz
  24. # Remote source(s)
  25. fetch=https://ftp.openbsd.org/pub/OpenBSD/LibreSSL/$tarname
  26. description="
  27. A version of the TLS/crypto stack.
  28. LibreSSL is a version of the TLS/crypto stack forked from OpenSSL in
  29. 2014, with goals of modernizing the codebase, improving security, and
  30. applying best practice development processes.
  31. Primary development occurs inside the OpenBSD source tree with the
  32. usual care the project is known for. On a regular basis the code
  33. is re-packaged for portable use by other operating systems (Linux,
  34. FreeBSD, Windows, etc).
  35. "
  36. homepage=https://www.libressl.org
  37. license=Custom
  38. # Source documentation
  39. docs="COPYING ChangeLog README.md VERSION"
  40. docsdir="${docdir}/${program}-${version}"
  41. build()
  42. {
  43. unpack "${tardir}/$tarname"
  44. cd "$srcdir"
  45. # Set sane permissions
  46. chmod -R u+w,go-w,a+rX-s .
  47. ./configure CPPFLAGS="$QICPPFLAGS" \
  48. CFLAGS="$QICFLAGS" LDFLAGS="$QILDFLAGS" \
  49. $configure_args \
  50. --libdir=/usr/lib${libSuffix} \
  51. --mandir=$mandir \
  52. --docdir=$docsdir \
  53. --enable-hardening \
  54. --enable-nc \
  55. --with-openssldir=/etc/ssl \
  56. --build="$(gcc -dumpmachine)"
  57. make -j${jobs} V=1
  58. make -j${jobs} DESTDIR="$destdir" install-strip
  59. # This is provided by the ca-certificates package
  60. rm -f "${destdir}/etc/ssl/cert.pem"
  61. rmdir "${destdir}/etc/ssl/certs"
  62. # To manage config file(s)
  63. touch "${destdir}/etc/ssl/.graft-config"
  64. # Compress and link man pages (if needed)
  65. if test -d "${destdir}/$mandir"
  66. then
  67. (
  68. cd "${destdir}/$mandir"
  69. find . -type f -exec lzip -9 {} +
  70. find . -type l | while read -r file
  71. do
  72. ln -sf "$(readlink -- $file).lz" "${file}.lz"
  73. rm -- "$file"
  74. done
  75. )
  76. fi
  77. # Remove broken symlinks
  78. find "${destdir}/$mandir" -print | while read -r file
  79. do
  80. if test -L "$file" && test ! -e "$file"
  81. then
  82. echo "Deleting dangling symlink: $file"
  83. rm -f -- "$file"
  84. fi
  85. done
  86. # Copy documentation
  87. mkdir -p "${destdir}/$docsdir"
  88. cp -p $docs "${destdir}/$docsdir"
  89. }