pks.spec 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  1. ##
  2. ## pks.spec -- OpenPKG RPM Specification
  3. ## Copyright (c) 2000-2003 Cable & Wireless Deutschland GmbH
  4. ## Copyright (c) 2000-2003 The OpenPKG Project <http://www.openpkg.org/>
  5. ## Copyright (c) 2000-2003 Ralf S. Engelschall <rse@engelschall.com>
  6. ##
  7. ## Permission to use, copy, modify, and distribute this software for
  8. ## any purpose with or without fee is hereby granted, provided that
  9. ## the above copyright notice and this permission notice appear in all
  10. ## copies.
  11. ##
  12. ## THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
  13. ## WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
  14. ## MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
  15. ## IN NO EVENT SHALL THE AUTHORS AND COPYRIGHT HOLDERS AND THEIR
  16. ## CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  17. ## SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  18. ## LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
  19. ## USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
  20. ## ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  21. ## OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
  22. ## OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  23. ## SUCH DAMAGE.
  24. ##
  25. # package information
  26. Name: pks
  27. Summary: OpenPGP Key Server
  28. URL: http://pks.sourceforge.net/
  29. Vendor: Marc Horowitz et al.
  30. Packager: The OpenPKG Project
  31. Distribution: OpenPKG [PLUS]
  32. Group: Cryptography
  33. License: GPL
  34. Version: 0.9.6
  35. Release: 20030708
  36. # package options
  37. %option with_fsl yes
  38. # list of sources
  39. Source0: http://osdn.dl.sourceforge.net/sourceforge/pks/pks-%{version}.tar.gz
  40. Source1: fsl.pks
  41. Source2: rc.pks
  42. Source3: pksd.conf
  43. Source4: pks-mail.c
  44. Source5: pks.html
  45. Source6: pks-apache.conf
  46. # build information
  47. Prefix: %{l_prefix}
  48. BuildRoot: %{l_buildroot}
  49. BuildPreReq: OpenPKG, openpkg >= 20030415
  50. PreReq: OpenPKG, openpkg >= 20030415, MTA
  51. %if "%{with_fsl}" == "yes"
  52. BuildPreReq: fsl
  53. PreReq: fsl
  54. %endif
  55. AutoReq: no
  56. AutoReqProv: no
  57. %description
  58. PKS is an OpenPGP (RFC 2440) compliant Public Key server, originally
  59. developed by Marc Horowitz for http://pgp.mit.edu/.
  60. %prep
  61. %setup -q
  62. %build
  63. # configure and build programs
  64. echo "ac_cv_path_SENDMAIL=%{l_prefix}/sbin/sendmail" >config.cache
  65. CC="%{l_cc}" \
  66. CFLAGS="%{l_cflags -O}" \
  67. CPPFLAGS="%{l_cppflags}" \
  68. LDFLAGS="%{l_ldflags} %{l_fsl_ldflags}" \
  69. ./configure \
  70. --cache-file=./config.cache \
  71. --prefix=%{l_prefix} \
  72. --sysconfdir=%{l_prefix}/etc/pks \
  73. --localstatedir=%{l_prefix}/var/pks \
  74. --datadir=%{l_prefix}/share/pks
  75. %{l_make} %{l_mflags} \
  76. LDFLAGS="%{l_ldflags} %{l_fsl_ldflags}"
  77. # build suid wrapper for pks-mail
  78. %{l_cc} %{l_cflags} %{l_ldflags} '-DL_PREFIX="%{l_prefix}"' \
  79. -o pks-mail %{SOURCE pks-mail.c}
  80. %install
  81. rm -rf $RPM_BUILD_ROOT
  82. # install programs
  83. %{l_make} %{l_mflags} install DESTDIR=$RPM_BUILD_ROOT
  84. # strip installation files and adjust paths
  85. rm -rf $RPM_BUILD_ROOT%{l_prefix}/include/db2
  86. rm -rf $RPM_BUILD_ROOT%{l_prefix}/lib/db2
  87. rm -f $RPM_BUILD_ROOT%{l_prefix}/bin/db_*
  88. rm -f $RPM_BUILD_ROOT%{l_prefix}/var/pks/index.html
  89. mv $RPM_BUILD_ROOT%{l_prefix}/bin/pks-queue-run.sh \
  90. $RPM_BUILD_ROOT%{l_prefix}/bin/pks-queue-run
  91. mv $RPM_BUILD_ROOT%{l_prefix}/var/pks/incoming \
  92. $RPM_BUILD_ROOT%{l_prefix}/var/pks/queue
  93. strip $RPM_BUILD_ROOT%{l_prefix}/bin/* >/dev/null 2>&1 || true
  94. # install HTML top-level page
  95. %{l_shtool} mkdir -f -p -m 755 \
  96. $RPM_BUILD_ROOT%{l_prefix}/pub/pks
  97. %{l_shtool} install -c -m 644 \
  98. %{SOURCE pks.html} $RPM_BUILD_ROOT%{l_prefix}/pub/pks/index.html
  99. # install suid wrapper for pks-mail
  100. %{l_shtool} mkdir -f -p -m 755 \
  101. $RPM_BUILD_ROOT%{l_prefix}/libexec/pks
  102. mv $RPM_BUILD_ROOT%{l_prefix}/bin/pks-mail.sh \
  103. $RPM_BUILD_ROOT%{l_prefix}/libexec/pks/pks-mail
  104. %{l_shtool} install -c -s -m 755 \
  105. pks-mail $RPM_BUILD_ROOT%{l_prefix}/bin/
  106. # install run-command script
  107. %{l_shtool} mkdir -f -p -m 755 \
  108. $RPM_BUILD_ROOT%{l_prefix}/etc/rc.d
  109. %{l_shtool} install -c -m 755 \
  110. -e 's;@l_prefix@;%{l_prefix};g' \
  111. -e 's;@l_rusr@;%{l_rusr};g' \
  112. -e 's;@l_rgrp@;%{l_rgrp};g' \
  113. %{SOURCE rc.pks} $RPM_BUILD_ROOT%{l_prefix}/etc/rc.d/
  114. # override default configuration
  115. %{l_shtool} install -c -m 644 \
  116. -e 's;@l_prefix@;%{l_prefix};g' \
  117. %{SOURCE pksd.conf} $RPM_BUILD_ROOT%{l_prefix}/etc/pks/
  118. %{l_shtool} install -c -m 644 \
  119. -e 's;@l_prefix@;%{l_prefix};g' \
  120. %{SOURCE pks-apache.conf} $RPM_BUILD_ROOT%{l_prefix}/etc/pks/
  121. # install OSSP fsl configuration
  122. %{l_shtool} mkdir -f -p -m 755 $RPM_BUILD_ROOT%{l_prefix}/etc/fsl
  123. %{l_shtool} install -c -m 644 \
  124. -e 's;@l_prefix@;%{l_prefix};g' \
  125. %{SOURCE fsl.pks} \
  126. $RPM_BUILD_ROOT%{l_prefix}/etc/fsl/
  127. # determine installation files
  128. %{l_rpmtool} files -v -ofiles -r$RPM_BUILD_ROOT \
  129. %{l_files_std} \
  130. '%not %dir %{l_prefix}/etc/fsl' \
  131. '%config %{l_prefix}/etc/fsl/fsl.pks' \
  132. '%config %{l_prefix}/etc/pks/pksd.conf' \
  133. '%attr(4755,%{l_rusr},%{l_mgrp}) %{l_prefix}/bin/pks-mail' \
  134. '%dir %attr(755,%{l_rusr},%{l_mgrp}) %{l_prefix}/var/pks' \
  135. '%dir %attr(755,%{l_rusr},%{l_mgrp}) %{l_prefix}/var/pks/db' \
  136. '%dir %attr(755,%{l_rusr},%{l_mgrp}) %{l_prefix}/var/pks/queue'
  137. %files -f files
  138. %clean
  139. rm -rf $RPM_BUILD_ROOT
  140. %post
  141. if [ $1 -eq 1 ]; then
  142. # create initial database
  143. su - %{l_rusr} -c "%{l_prefix}/bin/pksclient \
  144. %{l_prefix}/var/pks/db create" >/dev/null 2>&1
  145. su - %{l_rusr} -c "%{l_prefix}/bin/pksclient \
  146. %{l_prefix}/var/pks/db add %{l_prefix}/etc/openpkg/openpkg.pgp" >/dev/null 2>&1
  147. # activate in MTA configuration
  148. mta_aliases_file=`%{l_prefix}/etc/rc --query mta_aliases_file`
  149. mta_aliases_update=`%{l_prefix}/etc/rc --query mta_aliases_update`
  150. if [ ".$mta_aliases_file" != . ]; then
  151. ( echo "pks: pks-request"
  152. echo "pks-request: \"|%{l_prefix}/bin/pks-mail %{l_prefix}/etc/pks/pksd.conf\""
  153. echo "pks-daemon: MAILER-DAEMON"
  154. echo "pks-admin: postmaster"
  155. echo "pgp-public-keys: pks-request"
  156. echo "pgp: pks-request"
  157. ) | %{l_rpmtool} config -a -i "%{l_prefix}:pks" $mta_aliases_file
  158. fi
  159. if [ ".$mta_aliases_update" != . ]; then
  160. eval $mta_aliases_update
  161. fi
  162. fi
  163. %preun
  164. if [ $1 -eq 0 ]; then
  165. # stop perhaps still running server
  166. %{l_prefix}/etc/rc pks stop >/dev/null 2>&1 || true
  167. # deactivate in MTA configuration
  168. mta_aliases_file=`%{l_prefix}/etc/rc --query mta_aliases_file`
  169. mta_aliases_update=`%{l_prefix}/etc/rc --query mta_aliases_update`
  170. if [ ".$mta_aliases_file" != . ]; then
  171. %{l_rpmtool} config -r -i "%{l_prefix}:pks" $mta_aliases_file
  172. fi
  173. if [ ".$mta_aliases_update" != . ]; then
  174. eval $mta_aliases_update
  175. fi
  176. # remove generated files
  177. rm -f %{l_prefix}/var/pks/pksd.ctl >/dev/null 2>&1 || true
  178. rm -f %{l_prefix}/var/pks/pksd.log >/dev/null 2>&1 || true
  179. rm -f %{l_prefix}/var/pks/pks-queue-run.pid >/dev/null 2>&1 || true
  180. rm -f %{l_prefix}/var/pks/queue/* >/dev/null 2>&1 || true
  181. rm -f %{l_prefix}/var/pks/db/* >/dev/null 2>&1 || true
  182. fi