From 709c4d66e0b107ca606941b988bad717c0b45d9b Mon Sep 17 00:00:00 2001 From: Denys Dmytriyenko Date: Tue, 17 Mar 2009 14:32:59 -0400 Subject: rename packages/ to recipes/ per earlier agreement See links below for more details: http://thread.gmane.org/gmane.comp.handhelds.openembedded/21326 http://thread.gmane.org/gmane.comp.handhelds.openembedded/21816 Signed-off-by: Denys Dmytriyenko Acked-by: Mike Westerhof Acked-by: Philip Balister Acked-by: Khem Raj Acked-by: Marcin Juszkiewicz Acked-by: Koen Kooi Acked-by: Frans Meulenbroeks --- recipes/postfix/files/install.patch | 63 ++++++++++++++++ recipes/postfix/files/internal_recipient | 2 + recipes/postfix/files/main.cf_2.0 | 101 ++++++++++++++++++++++++++ recipes/postfix/files/makedefs.patch | 16 ++++ recipes/postfix/files/postfix | 31 ++++++++ recipes/postfix/files/volatiles | 15 ++++ recipes/postfix/postfix-2.0.20/.mtn2git_empty | 0 recipes/postfix/postfix-native_2.0.20.bb | 10 +++ recipes/postfix/postfix-native_2.2.12.bb | 10 +++ recipes/postfix/postfix.inc | 81 +++++++++++++++++++++ recipes/postfix/postfix_2.0.20.bb | 3 + recipes/postfix/postfix_2.2.12.bb | 1 + 12 files changed, 333 insertions(+) create mode 100644 recipes/postfix/files/install.patch create mode 100644 recipes/postfix/files/internal_recipient create mode 100644 recipes/postfix/files/main.cf_2.0 create mode 100644 recipes/postfix/files/makedefs.patch create mode 100755 recipes/postfix/files/postfix create mode 100644 recipes/postfix/files/volatiles create mode 100644 recipes/postfix/postfix-2.0.20/.mtn2git_empty create mode 100644 recipes/postfix/postfix-native_2.0.20.bb create mode 100644 recipes/postfix/postfix-native_2.2.12.bb create mode 100644 recipes/postfix/postfix.inc create mode 100644 recipes/postfix/postfix_2.0.20.bb create mode 100644 recipes/postfix/postfix_2.2.12.bb (limited to 'recipes/postfix') diff --git a/recipes/postfix/files/install.patch b/recipes/postfix/files/install.patch new file mode 100644 index 0000000000..baffcce0e8 --- /dev/null +++ b/recipes/postfix/files/install.patch @@ -0,0 +1,63 @@ + +# +# Patch managed by http://www.holgerschurig.de/patcher.html +# + +--- postfix-2.0.15/postfix-install~install.patch ++++ postfix-2.0.15/postfix-install +@@ -187,8 +187,8 @@ + exit 1 + } + +-test -x bin/postconf || { +- echo $0: Error: no bin/postconf file. Did you forget to run \"make\"? 1>&2 ++test -x $POSTCONF || { ++ echo $0: Error: no $POSTCONF file. Did you forget to run \"make\"? 1>&2 + exit 1 + } + +@@ -336,7 +336,7 @@ + + : ${install_root=/} + : ${tempdir=`pwd`} +-: ${config_directory=`bin/postconf -h -d config_directory`} ++: ${config_directory=`$POSTCONF -h -d config_directory`} + + # Find out the location of installed configuration files. + +@@ -399,7 +399,7 @@ + case "$junk" in + "") eval unset $name;; + esac +- eval : \${$name=\`bin/postconf -c $CONFIG_DIRECTORY -h $name\`} || ++ eval : \${$name=\`$POSTCONF -c $CONFIG_DIRECTORY -h $name\`} || + exit 1 + done + } +@@ -414,7 +414,7 @@ + case "$junk" in + "") eval unset $name;; + esac +- eval : \${$name=\`bin/postconf -d -h $name\`} || exit 1 ++ eval : \${$name=\`$POSTCONF -d -h $name\`} || exit 1 + done + + # Override settings manually. +@@ -521,6 +521,8 @@ + SAMPLE_DIRECTORY=$install_root$sample_directory + README_DIRECTORY=$install_root$readme_directory + ++test "x$POSTCONF" != "x" || POSTCONF="bin/postconf" ++ + # Avoid repeated tests for existence of these; default permissions suffice. + + test -d $DAEMON_DIRECTORY || mkdir -p $DAEMON_DIRECTORY || exit 1 +@@ -639,7 +641,7 @@ + # Postfix releases, and software should not suddenly be installed in + # the wrong place when Postfix is being upgraded. + +-bin/postconf -c $CONFIG_DIRECTORY -e \ ++$POSTCONF -c $CONFIG_DIRECTORY -e \ + "daemon_directory = $daemon_directory" \ + "command_directory = $command_directory" \ + "queue_directory = $queue_directory" \ diff --git a/recipes/postfix/files/internal_recipient b/recipes/postfix/files/internal_recipient new file mode 100644 index 0000000000..0d11944beb --- /dev/null +++ b/recipes/postfix/files/internal_recipient @@ -0,0 +1,2 @@ +root@ permit_mynetworks,reject + diff --git a/recipes/postfix/files/main.cf_2.0 b/recipes/postfix/files/main.cf_2.0 new file mode 100644 index 0000000000..1a6ddabbf3 --- /dev/null +++ b/recipes/postfix/files/main.cf_2.0 @@ -0,0 +1,101 @@ +#!/bin/sh +cat < include file found." 1>&2 + echo "Install the appropriate db*-devel package first." 1>&2 + echo "See the RELEASE_NOTES file for more information." 1>&2 +- exit 1 ++ #exit 1 + fi + # GDBM locks the DBM .pag file after open. This breaks postmap. + # if [ -f /usr/include/gdbm-ndbm.h ] diff --git a/recipes/postfix/files/postfix b/recipes/postfix/files/postfix new file mode 100755 index 0000000000..2fd5ba7007 --- /dev/null +++ b/recipes/postfix/files/postfix @@ -0,0 +1,31 @@ +#!/bin/sh + +case "$1" in + + start) + echo "Starting Postfix..." + postfix start + ;; + + stop) + echo "Stopping Postfix..." + postfix stop + ;; + + reload) + echo "Reloading Postfix..." + postfix reload + ;; + + restart) + $0 stop + sleep 1 + $0 start + ;; + + *) + echo "Usage: $0 {start|stop|reload|restart}" + exit 1 + ;; +esac + diff --git a/recipes/postfix/files/volatiles b/recipes/postfix/files/volatiles new file mode 100644 index 0000000000..bc330c99bd --- /dev/null +++ b/recipes/postfix/files/volatiles @@ -0,0 +1,15 @@ +d postfix nogroup 2755 /var/spool/mail none +d root postfix 0755 /var/spool/postfix none +d postfix root 0700 /var/spool/postfix/active none +d postfix root 0700 /var/spool/postfix/bounce none +d postfix root 0700 /var/spool/postfix/corrupt none +d postfix root 0700 /var/spool/postfix/defer none +d postfix root 0700 /var/spool/postfix/deferred none +d postfix root 0700 /var/spool/postfix/flush none +d postfix root 0700 /var/spool/postfix/hold none +d postfix root 0700 /var/spool/postfix/incoming none +d postfix postdrop 0730 /var/spool/postfix/maildrop none +d root root 0755 /var/spool/postfix/pid none +d postfix root 0700 /var/spool/postfix/private none +d postfix postdrop 0710 /var/spool/postfix/public none +d root root 0755 /var/spool/vmail none diff --git a/recipes/postfix/postfix-2.0.20/.mtn2git_empty b/recipes/postfix/postfix-2.0.20/.mtn2git_empty new file mode 100644 index 0000000000..e69de29bb2 diff --git a/recipes/postfix/postfix-native_2.0.20.bb b/recipes/postfix/postfix-native_2.0.20.bb new file mode 100644 index 0000000000..66ff65de4c --- /dev/null +++ b/recipes/postfix/postfix-native_2.0.20.bb @@ -0,0 +1,10 @@ +require postfix_${PV}.bb + +inherit native +FILESDIR = "${@os.path.dirname(bb.data.getVar('FILE',d,1))}/postfix-${PV}" +DEPENDS = "virtual/db-native libpcre-native" +export DIRS = "src/util src/global src/postconf" + +do_stage () { + install -m 0755 src/postconf/postconf ${STAGING_BINDIR}/ +} diff --git a/recipes/postfix/postfix-native_2.2.12.bb b/recipes/postfix/postfix-native_2.2.12.bb new file mode 100644 index 0000000000..66ff65de4c --- /dev/null +++ b/recipes/postfix/postfix-native_2.2.12.bb @@ -0,0 +1,10 @@ +require postfix_${PV}.bb + +inherit native +FILESDIR = "${@os.path.dirname(bb.data.getVar('FILE',d,1))}/postfix-${PV}" +DEPENDS = "virtual/db-native libpcre-native" +export DIRS = "src/util src/global src/postconf" + +do_stage () { + install -m 0755 src/postconf/postconf ${STAGING_BINDIR}/ +} diff --git a/recipes/postfix/postfix.inc b/recipes/postfix/postfix.inc new file mode 100644 index 0000000000..0371f62957 --- /dev/null +++ b/recipes/postfix/postfix.inc @@ -0,0 +1,81 @@ +SECTION = "console/network" +DEPENDS = "virtual/db libpcre postfix-native" +LICENSE = "IPL" + +SRC_URI = "ftp://ftp.porcupine.org/mirrors/postfix-release/official/postfix-${PV}.tar.gz \ + file://${FILESDIR}/makedefs.patch;patch=1 \ + file://${FILESDIR}/install.patch;patch=1 \ + file://main.cf_2.0 \ + file://volatiles \ + file://postfix \ + file://internal_recipient \ + " + +S = "${WORKDIR}/postfix-${PV}" + +inherit update-rc.d + +INITSCRIPT_NAME = "postfix" +INITSCRIPT_PARAMS = "start 58 3 4 5 . stop 13 0 1 6 ." + +#FIXME: this is broken because the native build won't work on systems where +# native bdb does not require libpthread. ARM doesn't require libpthread +# because it uses an assembler mutex implementation. +LIBBDB_EXTRA = "-lpthread" +LIBBDB_EXTRA_arm = "" +LIBBDB_EXTRA_armeb = "" + +export SYSLIBS = "-lpcre -ldb ${LIBBDB_EXTRA} -lnsl -lresolv ${LDFLAGS}" +export EXPORT = "AUXLIBS='-lpcre' CCARGS='-DHAS_PCRE ${CFLAGS}' OPT='' DEBUG='-g'" +export CC_append = " -DHAS_PCRE ${CFLAGS}" +export EXTRA_OEMAKE = "-e" +export POSTCONF = "${STAGING_BINDIR_NATIVE}/postconf" + +do_compile () { + unset CFLAGS CPPFLAGS CXXFLAGS + oe_runmake makefiles + oe_runmake +} + +do_install () { + sh ./postfix-install 'install_root=${D}' -non-interactive + rm -rf ${D}${localstatedir}/spool/postfix + mv ${D}${sysconfdir}/postfix/main.cf ${D}${sysconfdir}/postfix/sample-main.cf + install -d ${D}${localstatedir}/tmp + install -d ${D}${sysconfdir}/default/volatiles + install -d ${D}${sysconfdir}/init.d + install -m 755 ${WORKDIR}/main.cf_2.0 ${D}${localstatedir}/tmp/main_cf.sh + install -m 644 ${WORKDIR}/volatiles ${D}${sysconfdir}/default/volatiles/01_postfix + install -m 755 ${WORKDIR}/postfix ${D}${sysconfdir}/init.d/postfix + install -m 644 ${WORKDIR}/internal_recipient ${D}${sysconfdir}/postfix/internal_recipient + mv ${D}${sbindir}/sendmail ${D}${sbindir}/sendmail.${PN} +} + +pkg_postinst () { + update-alternatives --install ${sbindir}/sendmail sendmail sendmail.${PN} 40 + grep postfix /etc/group || addgroup postfix + grep postdrop /etc/group || addgroup postdrop + grep vmail /etc/group || addgroup vmail + grep postfix /etc/passwd || adduser --disabled-password --home=/var/spool/postfix --ingroup postfix -g "Postfix" postfix + grep vmail /etc/passwd || adduser --disabled-password --home=/var/spool/vmail --ingroup vmail -g "Postfix" vmail + chgrp postdrop /usr/sbin/postqueue + chgrp postdrop /usr/sbin/postdrop + chmod g+s /usr/sbin/postqueue + chmod g+s /usr/sbin/postdrop + /var/tmp/main_cf.sh >/etc/postfix/main.cf + rm -f /var/tmp/main_cf.sh + chmod 644 /etc/postfix/main.cf + [ -d /var/spool/postfix ] && rmdir /var/spool/postfix + /etc/init.d/populate-volatile.sh update + touch /etc/aliases + newaliases +} + +pkg_postrm () { + update-alternatives --remove sendmail sendmail.${PN} +} + +# Exclude .debug directories from the main package +FILES_${PN} = "${sysconfdir} ${localstatedir} ${bindir}/* ${sbindir}/* \ + ${libexecdir}/postfix/*" +FILES_${PN}-dbg += "${libexecdir}/postfix/.debug" diff --git a/recipes/postfix/postfix_2.0.20.bb b/recipes/postfix/postfix_2.0.20.bb new file mode 100644 index 0000000000..8cafc344f2 --- /dev/null +++ b/recipes/postfix/postfix_2.0.20.bb @@ -0,0 +1,3 @@ +require postfix.inc + +PR = "r13" diff --git a/recipes/postfix/postfix_2.2.12.bb b/recipes/postfix/postfix_2.2.12.bb new file mode 100644 index 0000000000..3f1039a83d --- /dev/null +++ b/recipes/postfix/postfix_2.2.12.bb @@ -0,0 +1 @@ +require postfix.inc -- cgit v1.2.3