wok-next annotate cyrus-imapd/receipt @ rev 20834

prosody: interesting, requires lua 5.1, and not 5.3
author Erkan Yilmaz <erkan@slitaz.org>
date Sun Jun 17 19:14:11 2018 +0000 (2018-06-17)
parents 2985612f2b3f
children d958fec46c9f
rev   line source
al@20459 1 # SliTaz package receipt v2.
pascal@1210 2
pascal@1210 3 PACKAGE="cyrus-imapd"
pascal@17211 4 VERSION="2.4.17"
pascal@1210 5 CATEGORY="network"
al@20459 6 SHORT_DESC="IMAP server"
pascal@1210 7 MAINTAINER="pascal.bellard@slitaz.org"
pascal@15579 8 LICENSE="BSD"
al@20459 9 WEB_SITE="http://cyrusimap.web.cmu.edu/"
al@20459 10
pascal@1210 11 TARBALL="$PACKAGE-$VERSION.tar.gz"
pascal@13010 12 WGET_URL="ftp://ftp.cyrusimap.org/$PACKAGE/$TARBALL"
pascal@15579 13
pascal@11855 14 BUILD_DEPENDS="libcomerr libcomerr-dev cyrus-sasl cyrus-sasl-dev openssl-dev \
al@20097 15 db-dev perl-dev zlib-dev"
al@20459 16 SPLIT="cyrus-imapd-dev"
pascal@1210 17
al@20459 18 compile_rules() {
pascal@18736 19 export LDFLAGS="$LDFLAGS -lpthread"
al@20459 20 ./configure \
al@20459 21 --prefix=/usr \
al@20459 22 --infodir=/usr/share/info \
al@20459 23 --with-service-path=/usr/lib/cyrus \
al@20459 24 --with-cyrus-prefix=/usr/lib/cyrus \
al@20459 25 --with-com_err=yes \
al@20459 26 --enable-murder \
al@20459 27 --enable-replication \
al@20459 28 --mandir=/usr/share/man \
al@20459 29 $CONFIGURE_ARGS &&
pascal@1553 30 make &&
pascal@13008 31 make DESTDIR=$DESTDIR install
pascal@1210 32 }
pascal@1210 33
al@20459 34 genpkg_rules() {
al@20459 35 case $PACKAGE in
al@20459 36 cyrus-imapd)
al@20459 37 mkdir -p $fs/usr/lib $fs/var/imap $fs/var/spool/imap/stage.
al@20459 38 cp -a $install/usr/bin $fs/usr
al@20459 39 cp -a $install/usr/lib/cyrus $fs/usr/lib
al@20459 40 cp -a $install/usr/lib/perl5 $fs/usr/lib
al@20459 41 strip -s $fs/usr/lib/cyrus/*
al@20459 42 cp $src/tools/mkimap $fs/usr/lib/cyrus
al@20459 43 cp -a $stuff/etc $fs
al@20459 44 cp $src/master/conf/small.conf $fs/etc/cyrus.conf
al@20459 45 for i in proc db socket log msg ptclient; do
al@20459 46 mkdir -m 755 $fs/var/imap/$i
al@20459 47 done
al@20459 48 CONFIG_FILES="/etc/imapd.conf /etc/cyrus.conf"
al@20459 49 DEPENDS="libcomerr cyrus-sasl openssl db perl libwrap \
al@20459 50 slitaz-base-files net-snmp"
al@20459 51 ;;
al@20459 52 *-dev)
al@20459 53 mkdir -p $fs/usr/lib
al@20459 54 cp -a $install/usr/lib/lib* $fs/usr/lib
al@20459 55 cp -a $install/usr/include $fs/usr
al@20459 56 ;;
al@20459 57 esac
pascal@1210 58 }
pascal@1210 59
al@20459 60 post_install_cyrus_imapd() {
al@20459 61 # adduser cyrus if needed
pascal@18730 62 if ! grep -q cyrus "$1/etc/passwd"; then
pascal@1210 63 echo -n "Adding user cyrus..."
pascal@18730 64 chroot "$1/" adduser cyrus -D -H -S -h /tmp
pascal@18730 65 chroot "$1/" sh -c 'echo "cyrus:cyrus" | chpasswd -m > /dev/null'
pascal@1210 66 status
pascal@1210 67 fi
pascal@1210 68 # addgroup mail if needed
pascal@18730 69 if ! grep -q mail "$1/etc/group"; then
pascal@1210 70 echo -n "Adding group mail..."
pascal@18730 71 chroot "$1/" sh -c 'addgroup mail && addgroup cyrus mail'
pascal@1210 72 status
pascal@1210 73 fi
pascal@18730 74 chroot "$1/" chown -R cyrus.mail /var/spool/imap /var/imap
pascal@1210 75 while read name port end; do
pascal@18730 76 grep -q $port "$1/etc/services" || \
pascal@18730 77 echo "$name $port $end" >> "$1/etc/services"
pascal@1210 78 done <<EOF
pascal@1210 79 pop3 110/tcp pop-3
pascal@1210 80 nntp 119/tcp readnews untp
pascal@1210 81 imap 143/tcp imap2 imap4
pascal@1210 82 imsp 406/tcp
pascal@1210 83 nntps 563/tcp snntp
pascal@1210 84 acap 674/tcp
pascal@1210 85 imaps 993/tcp
pascal@1210 86 pop3s 995/tcp
pascal@1210 87 kpop 1109/tcp
pascal@1210 88 sieve 2000/tcp
pascal@1210 89 lmtp 2003/tcp
pascal@1210 90 fud 4201/udp
pascal@1210 91 EOF
pascal@18730 92 [ "$1" ] || /etc/init.d/$PACKAGE start
pascal@18730 93 if [ -f "$1/etc/init.d/postfix" ]; then
pascal@18730 94 if ! grep -v ^# "$1/etc/postfix/main.cf" | grep -q lmtp:unix; then
pascal@1210 95 echo "Append to /etc/postfix/main.cf:"
pascal@1210 96 echo -n " "
pascal@1210 97 echo "mailbox_transport = lmtp:unix:/var/imap/socket/lmtp" | \
pascal@18730 98 tee -a "$1/etc/postfix/main.cf"
pascal@2389 99 if [ -z "$1" ]; then
pascal@2389 100 /etc/init.d/postfix start || /etc/init.d/postfix reload
pascal@2389 101 fi
pascal@1210 102 fi
pascal@1210 103 fi
pascal@1210 104 msg="Creating mailbox for"
pascal@18730 105 for i in root $(awk -F: '{ if ($3 >= 1000) print $1 }' < "$1/etc/passwd"); do
pascal@1210 106 echo -n "$msg $i"
pascal@1210 107 msg=","
pascal@1210 108 done
pascal@1210 109 echo ""
pascal@18730 110 for i in root $(awk -F: '{ if ($3 >= 1000) print $1 }' < "$1/etc/passwd"); do
pascal@1210 111 echo "createmailbox user.$i"
pascal@18730 112 done | chroot "$1/" cyradm -u cyrus -w cyrus 127.0.0.1 >/dev/null 2>&1
pascal@18730 113 chroot "$1/" su -c "/usr/lib/cyrus/bin/reconstruct" cyrus >/dev/null 2>&1
pascal@1210 114 cat <<EOF
pascal@1210 115
al@20459 116 .---------------------------------------------------.
al@20459 117 | Users must have a password to access the mailbox. |
al@20459 118 |---------------------------------------------------|
al@20459 119 | To start $PACKAGE server you can run: |
al@20459 120 | |
al@20459 121 | /etc/init.d/$PACKAGE start |
al@20459 122 | |
al@20459 123 | Or add $PACKAGE to RUN_DAEMONS in /etc/rcS.conf |
al@20459 124 '---------------------------------------------------'
pascal@1210 125 EOF
pascal@15502 126
pascal@15502 127 # A security hole with ssh...
pascal@18730 128 [ -f "$1/etc/ssh/sshd_config" ] &&
pascal@18730 129 ! grep -q cyrus "$1/etc/ssh/sshd_config" &&
pascal@18730 130 echo "DenyUsers cyrus" >> "$1/etc/ssh/sshd_config"
pascal@1210 131 }
pascal@1210 132
al@20459 133 post_remove_cyrus_imapd() {
pascal@1210 134 deluser cyrus
pascal@1210 135 delgroup mail
pascal@1210 136 }