[prev in list] [next in list] [prev in thread] [next in thread]
List: openpkg-cvs
Subject: [CVS] OpenPKG: openpkg-src/milter-dkim/ fsl.milter-dkim milter-dkim.sp...
From: "Ralf S. Engelschall" <rse () openpkg ! org>
Date: 2006-12-30 22:16:11
Message-ID: 20061230221612.8C22D1B5047 () master ! openpkg ! org
[Download RAW message or body]
OpenPKG CVS Repository
http://cvs.openpkg.org/
____________________________________________________________________________
Server: cvs.openpkg.org Name: Ralf S. Engelschall
Root: /v/openpkg/cvs Email: rse@openpkg.org
Module: openpkg-src Date: 30-Dec-2006 23:16:11
Branch: HEAD Handle: 2006123022161000
Added files:
openpkg-src/milter-dkim fsl.milter-dkim milter-dkim.spec rc.milter-dkim
Log:
new package: milter-dkim 0.5.2 (Mail Filter for DomainKeys Identified
Mail (DKIM))
Summary:
Revision Changes Path
1.1 +16 -0 openpkg-src/milter-dkim/fsl.milter-dkim
1.1 +157 -0 openpkg-src/milter-dkim/milter-dkim.spec
1.1 +81 -0 openpkg-src/milter-dkim/rc.milter-dkim
____________________________________________________________________________
patch -p0 <<'@@ .'
Index: openpkg-src/milter-dkim/fsl.milter-dkim
============================================================================
$ cvs diff -u -r0 -r1.1 fsl.milter-dkim
--- /dev/null 2006-12-30 23:15:14 +0100
+++ fsl.milter-dkim 2006-12-30 23:16:10 +0100
@@ -0,0 +1,16 @@
+##
+## fsl.milter-dkim -- OSSP fsl configuration
+##
+
+ident (dkim-filter)/.+ q{
+ prefix(
+ prefix="%b %d %H:%M:%S %N <%L> $1[%P]: "
+ )
+ -> {
+ debug: file(
+ path="@l_prefix@/var/milter-dkim/milter-dkim.log",
+ perm=0644
+ )
+ }
+};
+
@@ .
patch -p0 <<'@@ .'
Index: openpkg-src/milter-dkim/milter-dkim.spec
============================================================================
$ cvs diff -u -r0 -r1.1 milter-dkim.spec
--- /dev/null 2006-12-30 23:15:14 +0100
+++ milter-dkim.spec 2006-12-30 23:16:10 +0100
@@ -0,0 +1,157 @@
+##
+## milter-dkim.spec -- OpenPKG RPM Package Specification
+## Copyright (c) 2000-2006 OpenPKG Foundation e.V. <http://openpkg.net/>
+## Copyright (c) 2000-2006 Ralf S. Engelschall <http://engelschall.com/>
+##
+## Permission to use, copy, modify, and distribute this software for
+## any purpose with or without fee is hereby granted, provided that
+## the above copyright notice and this permission notice appear in all
+## copies.
+##
+## THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
+## WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+## MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+## IN NO EVENT SHALL THE AUTHORS AND COPYRIGHT HOLDERS AND THEIR
+## CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+## SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+## LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
+## USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+## ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+## OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
+## OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+## SUCH DAMAGE.
+##
+
+# package information
+Name: milter-dkim
+Summary: Mail Filter for DomainKeys Identified Mail (DKIM)
+URL: http://dk-milter.sourceforge.net/
+Vendor: Sendmail, Inc.
+Packager: OpenPKG Foundation e.V.
+Distribution: OpenPKG Community
+Class: EVAL
+Group: Mail
+License: Open Source
+Version: 0.5.2
+Release: 20061230
+
+# package options
+%option with_fsl yes
+
+# list of sources
+Source0: http://switch.dl.sourceforge.net/dkim-milter/dkim-milter-%{version}.tar.gz
+Source1: rc.milter-dkim
+Source2: fsl.milter-dkim
+Source3: milter-dkim-genkey.sh
+Patch0: milter-dkim.patch
+
+# build information
+Prefix: %{l_prefix}
+BuildRoot: %{l_buildroot}
+BuildPreReq: OpenPKG, openpkg >= 20060823
+PreReq: OpenPKG, openpkg >= 20060823
+BuildPreReq: milter, openssl
+PreReq: milter, openssl
+%if "%{with_fsl}" == "yes"
+BuildPreReq: fsl >= 1.2.0
+PreReq: fsl >= 1.2.0
+%endif
+AutoReq: no
+AutoReqProv: no
+
+%description
+ This is a DomainKeys Identified Mail (DKIM) based mail sender
+ authentication based on the MILTER API of MTAs. DKIM is the a merger
+ and enhancement of Yahoo! DomainKeys and Cisco Identified Internet
+ Mail (IIM). DKIM is upward compatible with existing DomainKeys DNS
+ records.
+
+%track
+ prog milter-dkim = {
+ version = %{version}
+ url = http://prdownloads.sourceforge.net/dkim-milter/
+ regex = dkim-milter-(__VER__)\.tar\.gz
+ }
+
+%prep
+ %setup -q -n dkim-milter-%{version}
+ %patch -p0
+
+%build
+ # configure program
+ extlibs="%{l_fsl_libs}"
+ case "%{l_platform -t}" in
+ *-sunos* ) extlibs="$extlibs -lrt" ;;
+ esac
+ ( echo "define(\`confCC', \`%{l_cc} %{l_cflags}')dnl"
+ echo "APPENDDEF(\`confINCDIRS', \`%{l_cppflags}')dnl"
+ echo "APPENDDEF(\`confLIBDIRS', \`%{l_ldflags} %{l_fsl_ldflags}')dnl"
+ echo "APPENDDEF(\`confLIBS', \`$extlibs')dnl"
+ ) >devtools/Site/site.config.m4
+
+ # build program
+ ./Build
+
+%install
+ # create installation hierarchy
+ rm -rf $RPM_BUILD_ROOT
+ %{l_shtool} mkdir -f -p -m 755 \
+ $RPM_BUILD_ROOT%{l_prefix}/etc/rc.d \
+ $RPM_BUILD_ROOT%{l_prefix}/etc/fsl \
+ $RPM_BUILD_ROOT%{l_prefix}/etc/milter-dkim \
+ $RPM_BUILD_ROOT%{l_prefix}/sbin \
+ $RPM_BUILD_ROOT%{l_prefix}/man/man8 \
+ $RPM_BUILD_ROOT%{l_prefix}/var/milter-dkim/tmp
+
+ # install program
+ %{l_shtool} install -c -s -m 755 \
+ obj.*/dkim-filter/dkim-filter $RPM_BUILD_ROOT%{l_prefix}/sbin/
+ %{l_shtool} install -c -m 755 %{l_value -s -a} \
+ %{SOURCE milter-dkim-genkey.sh} $RPM_BUILD_ROOT%{l_prefix}/sbin/milter-dkim-genkey
+
+ # install manual page
+ %{l_shtool} install -c -m 644 \
+ dkim-filter/dkim-filter.8 $RPM_BUILD_ROOT%{l_prefix}/man/man8/
+
+ # install run-command script
+ %{l_shtool} install -c -m 755 %{l_value -s -a} \
+ %{SOURCE rc.milter-dkim} $RPM_BUILD_ROOT%{l_prefix}/etc/rc.d/
+
+ # install OSSP fsl configuration
+ %{l_shtool} install -c -m 644 %{l_value -s -a} \
+ %{SOURCE fsl.milter-dkim} $RPM_BUILD_ROOT%{l_prefix}/etc/fsl/
+
+ # determine installation files
+ %{l_rpmtool} files -v -ofiles -r$RPM_BUILD_ROOT \
+ %{l_files_std} \
+ '%config %{l_prefix}/etc/fsl/*' \
+ '%attr(755,%{l_rusr},%{l_mgrp}) %{l_prefix}/var/milter-dkim/*' \
+ '%attr(755,%{l_rusr},%{l_mgrp}) %{l_prefix}/var/milter-dkim'
+
+%files -f files
+
+%clean
+ rm -rf $RPM_BUILD_ROOT
+
+%post
+ # after upgrade, restart service
+ if [ $1 -eq 1 ]; then
+ if [ ! -f $RPM_INSTALL_PREFIX/etc/milter-dkim/main.example.com.pem ]; then
+ $RPM_INSTALL_PREFIX/sbin/milter-dkim-genkey \
+ main example.com $RPM_INSTALL_PREFIX/etc/milter-dkim/main.example.com.pem 1024
+ fi
+ elif [ $1 -eq 2 ]; then
+ eval `%{l_rc} milter-dkim status 2>/dev/null`
+ [ ".$milter_dkim_active" = .yes ] && %{l_rc} milter-dkim restart
+ fi
+ exit 0
+
+%preun
+ # before erase, stop service and remove log files
+ if [ $1 -eq 0 ]; then
+ %{l_rc} milter-dkim stop 2>/dev/null
+ rm -f $RPM_INSTALL_PREFIX/etc/milter-dkim/main.example.com.pem >/dev/null 2>&1 || true
+ rm -f $RPM_INSTALL_PREFIX/var/milter-dkim/* >/dev/null 2>&1 || true
+ fi
+ exit 0
+
@@ .
patch -p0 <<'@@ .'
Index: openpkg-src/milter-dkim/rc.milter-dkim
============================================================================
$ cvs diff -u -r0 -r1.1 rc.milter-dkim
--- /dev/null 2006-12-30 23:15:14 +0100
+++ rc.milter-dkim 2006-12-30 23:16:11 +0100
@@ -0,0 +1,81 @@
+#!@l_prefix@/bin/openpkg rc
+##
+## rc.milter-dkim -- Run-Commands
+##
+
+%config
+ milter_dkim_enable="$openpkg_rc_def"
+ milter_dkim_selector="main"
+ milter_dkim_domain="example.com"
+ milter_dkim_keyfile="@l_prefix@/etc/milter-dkim/main.example.com.pem"
+ milter_dkim_flags="-c relaxed"
+ milter_dkim_prolog="true"
+ milter_dkim_epilog="true"
+ milter_dkim_numfiles="10"
+ milter_dkim_minsize="1M"
+ milter_dkim_complevel="9"
+
+%common
+ milter_dkim_dkfile="@l_prefix@/etc/milter-dkim/milter-dkim.pem"
+ milter_dkim_tmpdir="@l_prefix@/var/milter-dkim/milter-dkim.tmp"
+ milter_dkim_pidfile="@l_prefix@/var/milter-dkim/milter-dkim.pid"
+ milter_dkim_logfile="@l_prefix@/var/milter-dkim/milter-dkim.log"
+ milter_dkim_socket="@l_prefix@/var/milter-dkim/milter-dkim.socket"
+ milter_dkim_signal () {
+ [ -f $milter_dkim_pidfile ] && kill -$1 `cat $milter_dkim_pidfile`
+ }
+
+%status -u @l_susr@ -o
+ milter_dkim_usable="unknown"
+ milter_dkim_active="no"
+ rcService milter-dkim enable yes && \
+ milter_dkim_signal 0 && milter_dkim_active="yes"
+ echo "milter_dkim_enable=\"$milter_dkim_enable\""
+ echo "milter_dkim_usable=\"$milter_dkim_usable\""
+ echo "milter_dkim_active=\"$milter_dkim_active\""
+
+%start -u @l_susr@
+ rcService milter-dkim enable yes || exit 0
+ rcService milter-dkim active yes && exit 0
+ cmd="@l_prefix@/sbin/dkim-filter"
+ cmd="$cmd -l -u @l_rusr@"
+ cmd="$cmd -p local:$milter_dkim_socket"
+ cmd="$cmd -P $milter_dkim_pidfile"
+ if [ ".$milter_dkim_selector" != . ]; then
+ cmd="$cmd -s \"$milter_dkim_selector\""
+ fi
+ if [ ".$milter_dkim_domain" != . ]; then
+ cmd="$cmd -d \"$milter_dkim_domain\""
+ fi
+ if [ ".$milter_dkim_keyfile" != . ]; then
+ cmd="$cmd -k \"$milter_dkim_keyfile\""
+ fi
+ cmd="$cmd $milter_dkim_flags"
+ ( umask 002
+ export DK_TMPDIR="$milter_dkim_tmpdir"
+ rm -f $milter_dkim_socket >/dev/null 2>&2 || true
+ eval $cmd
+ ) || exit $?
+
+%stop -u @l_susr@
+ rcService milter-dkim enable yes || exit 0
+ rcService milter-dkim active no && exit 0
+ milter_dkim_signal TERM
+ sleep 2
+ rm -f $milter_dkim_pidfile >/dev/null 2>&1 || true
+ rm -f $milter_dkim_socket >/dev/null 2>&1 || true
+
+%restart -u @l_susr@
+ rcService milter-dkim enable yes || exit 0
+ rcService milter-dkim active no && exit 0
+ rc milter-dkim stop start
+
+%daily -u @l_susr@
+ rcService milter-dkim enable yes || exit 0
+ shtool rotate -f \
+ -n $milter_dkim_numfiles -s $milter_dkim_minsize -d \
+ -z $milter_dkim_complevel -m 644 -o @l_rusr@ -g @l_rgrp@ \
+ -P "$milter_dkim_prolog" \
+ -E "$milter_dkim_epilog; rc milter-dkim restart" \
+ $milter_dkim_logfile
+
@@ .
______________________________________________________________________
The OpenPKG Project www.openpkg.org
CVS Repository Commit List openpkg-cvs@openpkg.org
[prev in list] [next in list] [prev in thread] [next in thread]
Configure |
About |
News |
Add a list |
Sponsored by KoreLogic