wok annotate cyrus-imapd/receipt @ rev 24451
updated cyrus-imapd and cyrus-imapd-dev (3.0.13 -> 3.4.3)
author | Hans-G?nter Theisgen |
---|---|
date | Tue Feb 15 14:10:08 2022 +0100 (2022-02-15) |
parents | 2a0479881723 |
children | 92d14c9730a8 |
rev | line source |
---|---|
pascal@1210 | 1 # SliTaz package receipt. |
pascal@1210 | 2 |
pascal@1210 | 3 PACKAGE="cyrus-imapd" |
Hans-G?nter@24451 | 4 VERSION="3.4.3" |
pascal@1210 | 5 CATEGORY="network" |
pascal@1210 | 6 SHORT_DESC="IMAP server." |
pascal@1210 | 7 MAINTAINER="pascal.bellard@slitaz.org" |
pascal@15579 | 8 LICENSE="BSD" |
Hans-G?nter@24451 | 9 WEB_SITE="https://cyrusimap.org/" |
Hans-G?nter@22625 | 10 |
pascal@1210 | 11 TARBALL="$PACKAGE-$VERSION.tar.gz" |
Hans-G?nter@24451 | 12 WGET_URL="https://github.com/cyrusimap/$PACKAGE/releases/download/$PACKAGE-$VERSION/$TARBALL" |
Hans-G?nter@22625 | 13 |
Hans-G?nter@24451 | 14 DEPENDS="cyrus-sasl db gcc83-lib-base jansson libcomerr libwrap net-snmp openssl |
Hans-G?nter@24451 | 15 perl slitaz-base-files" |
Hans-G?nter@24451 | 16 BUILD_DEPENDS="cyrus-sasl-dev db-dev gcc83 icu-dev jansson-dev libcomerr-dev |
Hans-G?nter@22625 | 17 openssl-dev perl util-linux-uuid-dev" |
Hans-G?nter@22625 | 18 |
pascal@15579 | 19 CONFIG_FILES="/etc/imapd.conf /etc/cyrus.conf" |
pascal@15579 | 20 |
pascal@24436 | 21 # What is the latest version available today? |
pascal@24436 | 22 current_version() |
pascal@24436 | 23 { |
pascal@24436 | 24 wget -O - https://github.com/cyrusimap/cyrus-imapd/releases 2>/dev/null | \ |
pascal@24436 | 25 sed '/archive.*tar/!d;s|.*/[a-z-]*\(.*\).tar.*|\1|;q' |
pascal@24436 | 26 } |
pascal@24436 | 27 |
pascal@1210 | 28 # Rules to configure and make the package. |
pascal@1210 | 29 compile_rules() |
pascal@1210 | 30 { |
pascal@18736 | 31 export LDFLAGS="$LDFLAGS -lpthread" |
Hans-G?nter@22625 | 32 |
Hans-G?nter@24451 | 33 # 3.4.3 unrecognised |
Hans-G?nter@24451 | 34 # --with-service-path=/usr/lib/cyrus |
Hans-G?nter@24451 | 35 # --with-cyrus-prefix=/usr/lib/cyrus |
Hans-G?nter@24451 | 36 |
Hans-G?nter@22625 | 37 ./configure \ |
Hans-G?nter@24451 | 38 CC=gcc-83 \ |
Hans-G?nter@24451 | 39 CXX=g++-83 \ |
Hans-G?nter@22625 | 40 --prefix=/usr \ |
Hans-G?nter@22625 | 41 --infodir=/usr/share/info \ |
Hans-G?nter@22625 | 42 --with-com_err=yes \ |
Hans-G?nter@22625 | 43 --enable-murder \ |
Hans-G?nter@22625 | 44 --enable-replication \ |
Hans-G?nter@22625 | 45 --mandir=/usr/share/man \ |
Hans-G?nter@22625 | 46 $CONFIGURE_ARGS && |
pascal@1553 | 47 make && |
Hans-G?nter@24451 | 48 make install DESTDIR=$DESTDIR |
pascal@1210 | 49 } |
pascal@1210 | 50 |
pascal@1210 | 51 # Rules to gen a SliTaz package suitable for Tazpkg. |
pascal@1210 | 52 genpkg_rules() |
pascal@1210 | 53 { |
Hans-G?nter@22625 | 54 mkdir -p $fs/usr/lib/cyrus |
Hans-G?nter@22625 | 55 mkdir -p $fs/var/imap |
Hans-G?nter@22625 | 56 mkdir -p $fs/var/spool/imap/stage. |
Hans-G?nter@22625 | 57 |
Hans-G?nter@22625 | 58 cp -a $install/usr/bin $fs/usr |
Hans-G?nter@22625 | 59 cp -a $install/usr/lib/libcyrus*.so* $fs/usr/lib |
Hans-G?nter@22625 | 60 cp -a $install/usr/lib/perl5 $fs/usr/lib |
Hans-G?nter@22625 | 61 strip -s $fs/usr/lib/lib* |
Hans-G?nter@22625 | 62 cp $src/tools/mkimap $fs/usr/lib/cyrus |
Hans-G?nter@22625 | 63 cp -a $stuff/etc $fs |
Hans-G?nter@22625 | 64 cp $src/doc/examples/cyrus_conf/small.conf \ |
Hans-G?nter@22625 | 65 $fs/etc/cyrus.conf |
Hans-G?nter@22625 | 66 for i in proc db socket log msg ptclient |
Hans-G?nter@22625 | 67 do |
pascal@1210 | 68 mkdir -m 755 $fs/var/imap/$i |
Hans-G?nter@22625 | 69 done |
pascal@1210 | 70 } |
pascal@1210 | 71 |
pascal@1210 | 72 # Pre and post install commands for Tazpkg. |
pascal@1210 | 73 post_install() |
pascal@1210 | 74 { |
pascal@1210 | 75 # adduser cyrus if needed |
Hans-G?nter@22625 | 76 if ! grep -q cyrus "$1/etc/passwd" |
Hans-G?nter@22625 | 77 then |
pascal@20319 | 78 echo |
pascal@1210 | 79 echo -n "Adding user cyrus..." |
pascal@18730 | 80 chroot "$1/" adduser cyrus -D -H -S -h /tmp |
pascal@18730 | 81 chroot "$1/" sh -c 'echo "cyrus:cyrus" | chpasswd -m > /dev/null' |
pascal@1210 | 82 status |
pascal@1210 | 83 fi |
Hans-G?nter@22625 | 84 |
pascal@1210 | 85 # addgroup mail if needed |
Hans-G?nter@22625 | 86 if ! grep -q mail "$1/etc/group" |
Hans-G?nter@22625 | 87 then |
pascal@20319 | 88 echo |
pascal@1210 | 89 echo -n "Adding group mail..." |
pascal@18730 | 90 chroot "$1/" sh -c 'addgroup mail && addgroup cyrus mail' |
pascal@1210 | 91 status |
pascal@1210 | 92 fi |
Hans-G?nter@22625 | 93 |
pascal@18730 | 94 chroot "$1/" chown -R cyrus.mail /var/spool/imap /var/imap |
Hans-G?nter@22625 | 95 while read name port end |
Hans-G?nter@22625 | 96 do |
pascal@18730 | 97 grep -q $port "$1/etc/services" || \ |
pascal@18730 | 98 echo "$name $port $end" >> "$1/etc/services" |
Hans-G?nter@22625 | 99 done <<EOF |
pascal@1210 | 100 pop3 110/tcp pop-3 |
pascal@1210 | 101 nntp 119/tcp readnews untp |
pascal@1210 | 102 imap 143/tcp imap2 imap4 |
pascal@1210 | 103 imsp 406/tcp |
pascal@1210 | 104 nntps 563/tcp snntp |
pascal@1210 | 105 acap 674/tcp |
pascal@1210 | 106 imaps 993/tcp |
pascal@1210 | 107 pop3s 995/tcp |
pascal@1210 | 108 kpop 1109/tcp |
pascal@1210 | 109 sieve 2000/tcp |
pascal@1210 | 110 lmtp 2003/tcp |
pascal@1210 | 111 fud 4201/udp |
pascal@1210 | 112 EOF |
Hans-G?nter@22625 | 113 |
pascal@18730 | 114 [ "$1" ] || /etc/init.d/$PACKAGE start |
Hans-G?nter@22625 | 115 if [ -f "$1/etc/init.d/postfix" ] |
Hans-G?nter@22625 | 116 then |
Hans-G?nter@22625 | 117 if ! grep -v ^# "$1/etc/postfix/main.cf" | grep -q lmtp:unix |
Hans-G?nter@22625 | 118 then |
pascal@20319 | 119 echo |
pascal@1210 | 120 echo "Append to /etc/postfix/main.cf:" |
pascal@1210 | 121 echo -n " " |
pascal@1210 | 122 echo "mailbox_transport = lmtp:unix:/var/imap/socket/lmtp" | \ |
pascal@18730 | 123 tee -a "$1/etc/postfix/main.cf" |
Hans-G?nter@22625 | 124 if [ -z "$1" ] |
Hans-G?nter@22625 | 125 then |
pascal@2389 | 126 /etc/init.d/postfix start || /etc/init.d/postfix reload |
pascal@2389 | 127 fi |
pascal@1210 | 128 fi |
pascal@1210 | 129 fi |
Hans-G?nter@22625 | 130 |
pascal@20319 | 131 msg="\\nCreating mailbox for" |
Hans-G?nter@22625 | 132 for i in root $(awk -F: '{ if ($3 >= 1000) print $1 }' < "$1/etc/passwd") |
Hans-G?nter@22625 | 133 do |
pascal@20319 | 134 echo -en "$msg $i" |
pascal@1210 | 135 msg="," |
Hans-G?nter@22625 | 136 done |
pascal@1210 | 137 echo "" |
Hans-G?nter@22625 | 138 |
Hans-G?nter@22625 | 139 for i in root $(awk -F: '{ if ($3 >= 1000) print $1 }' < "$1/etc/passwd") |
Hans-G?nter@22625 | 140 do |
pascal@1210 | 141 echo "createmailbox user.$i" |
Hans-G?nter@22625 | 142 done | chroot "$1/" cyradm -u cyrus -w cyrus 127.0.0.1 >/dev/null 2>&1 |
pascal@18730 | 143 chroot "$1/" su -c "/usr/lib/cyrus/bin/reconstruct" cyrus >/dev/null 2>&1 |
Hans-G?nter@22625 | 144 |
pascal@1210 | 145 cat <<EOF |
pascal@1210 | 146 ---- |
pascal@1210 | 147 Users must have a password to access the mailbox. |
pascal@1210 | 148 To start $PACKAGE server you can run : |
pascal@1210 | 149 |
pascal@1210 | 150 /etc/init.d/$PACKAGE start |
pascal@1210 | 151 |
pascal@1210 | 152 Or add $PACKAGE to RUN_DAEMONS in /etc/rcS.conf |
pascal@1210 | 153 ---- |
pascal@1210 | 154 EOF |
pascal@15502 | 155 |
pascal@15502 | 156 # A security hole with ssh... |
pascal@18730 | 157 [ -f "$1/etc/ssh/sshd_config" ] && |
pascal@18730 | 158 ! grep -q cyrus "$1/etc/ssh/sshd_config" && |
pascal@18730 | 159 echo "DenyUsers cyrus" >> "$1/etc/ssh/sshd_config" |
pascal@1210 | 160 } |
pascal@1210 | 161 |
pascal@1210 | 162 post_remove() |
pascal@1210 | 163 { |
pascal@1210 | 164 deluser cyrus |
pascal@1210 | 165 delgroup mail |
pascal@1210 | 166 } |