wok annotate cyrus-imapd/receipt @ rev 24436

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