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 } |