wok-next annotate cyrus-imapd/receipt @ rev 2389
cyrus-imapd: fix chroot in post_install
author | Pascal Bellard <pascal.bellard@slitaz.org> |
---|---|
date | Tue Mar 10 08:58:14 2009 +0000 (2009-03-10) |
parents | 79e6c7e5b6d3 |
children | 8d23268c7571 |
rev | line source |
---|---|
pascal@1210 | 1 # SliTaz package receipt. |
pascal@1210 | 2 |
pascal@1210 | 3 PACKAGE="cyrus-imapd" |
pascal@1210 | 4 VERSION="2.2.12" |
pascal@1210 | 5 CATEGORY="network" |
pascal@1210 | 6 SHORT_DESC="IMAP server." |
pascal@1210 | 7 MAINTAINER="pascal.bellard@slitaz.org" |
pascal@1210 | 8 TARBALL="$PACKAGE-$VERSION.tar.gz" |
pascal@1210 | 9 WEB_SITE="http://cyrusimap.web.cmu.edu/" |
pascal@1210 | 10 WGET_URL="ftp://ftp.andrew.cmu.edu/pub/cyrus/$TARBALL" |
pascal@1210 | 11 BUILD_DEPENDS="libcomerr-dev cyrus-sasl cyrus-sasl-dev openssl-dev db-dev" |
pascal@1977 | 12 DEPENDS="libcomerr cyrus-sasl openssl db perl libwrap slitaz-base-files" |
pascal@1210 | 13 CONFIG_FILES="/etc/imapd.conf /etc/cyrus.conf" |
pascal@1210 | 14 |
pascal@1210 | 15 # Rules to configure and make the package. |
pascal@1210 | 16 compile_rules() |
pascal@1210 | 17 { |
pascal@1210 | 18 cd $src |
pascal@1553 | 19 while read arg file; do |
pascal@1553 | 20 [ -f done.$file ] && continue |
pascal@1553 | 21 echo "Apply $file..." |
pascal@1553 | 22 patch $arg < ../stuff/$file |
pascal@1553 | 23 touch done.$file |
pascal@1553 | 24 done << EOT |
pascal@1553 | 25 -p1 50-FTBFS-gcc-4.0-fix.dpatch |
pascal@1553 | 26 -p0 p1.patch |
pascal@1553 | 27 -p0 p2.patch |
pascal@1553 | 28 EOT |
pascal@1210 | 29 ./configure --prefix=/usr --infodir=/usr/share/info \ |
pascal@1553 | 30 --mandir=/usr/share/man $CONFIGURE_ARGS && |
pascal@1553 | 31 make && |
pascal@1210 | 32 make DESTDIR=$PWD/_pkg install |
pascal@1210 | 33 } |
pascal@1210 | 34 |
pascal@1210 | 35 # Rules to gen a SliTaz package suitable for Tazpkg. |
pascal@1210 | 36 genpkg_rules() |
pascal@1210 | 37 { |
pascal@1210 | 38 mkdir -p $fs/usr/lib $fs/var/imap $fs/var/spool/imap/stage. |
pascal@1210 | 39 cp -a $_pkg/usr/bin $fs/usr |
pascal@1210 | 40 cp -a $_pkg/usr/cyrus $fs/usr |
pascal@1210 | 41 cp -a $_pkg/usr/lib/perl5 $fs/usr/lib |
pascal@1210 | 42 strip -s $fs/usr/cyrus/bin/* |
pascal@1210 | 43 cp $src/tools/mkimap $fs/usr/cyrus/bin |
pascal@1210 | 44 cp -a stuff/etc $fs |
pascal@1210 | 45 cp $src/master/conf/small.conf $fs/etc/cyrus.conf |
pascal@1210 | 46 for i in proc db socket log msg ptclient; do |
pascal@1210 | 47 mkdir -m 755 $fs/var/imap/$i |
pascal@1210 | 48 done |
pascal@1210 | 49 } |
pascal@1210 | 50 |
pascal@1210 | 51 # Pre and post install commands for Tazpkg. |
pascal@1210 | 52 post_install() |
pascal@1210 | 53 { |
pascal@1210 | 54 # adduser cyrus if needed |
pascal@1210 | 55 if ! grep -q cyrus $1/etc/passwd; then |
pascal@1210 | 56 echo -n "Adding user cyrus..." |
pascal@1210 | 57 chroot $1/ adduser cyrus -D -H -S -h /tmp |
pascal@2369 | 58 chroot $1/ sh -c 'echo "cyrus:cyrus" | chpasswd > /dev/null' |
pascal@1210 | 59 status |
pascal@1210 | 60 fi |
pascal@1210 | 61 # addgroup mail if needed |
pascal@1210 | 62 if ! grep -q mail $1/etc/group; then |
pascal@1210 | 63 echo -n "Adding group mail..." |
pascal@2369 | 64 chroot $1/ sh -c 'addgroup mail && addgroup cyrus mail' |
pascal@1210 | 65 status |
pascal@1210 | 66 fi |
pascal@2389 | 67 chroot $1/ chown -R cyrus.mail /var/spool/imap /var/imap |
pascal@1210 | 68 while read name port end; do |
pascal@2389 | 69 grep -q $port $1/etc/services || \ |
pascal@2389 | 70 echo "$name $port $end" >> $1/etc/services |
pascal@1210 | 71 done <<EOF |
pascal@1210 | 72 pop3 110/tcp pop-3 |
pascal@1210 | 73 nntp 119/tcp readnews untp |
pascal@1210 | 74 imap 143/tcp imap2 imap4 |
pascal@1210 | 75 imsp 406/tcp |
pascal@1210 | 76 nntps 563/tcp snntp |
pascal@1210 | 77 acap 674/tcp |
pascal@1210 | 78 imaps 993/tcp |
pascal@1210 | 79 pop3s 995/tcp |
pascal@1210 | 80 kpop 1109/tcp |
pascal@1210 | 81 sieve 2000/tcp |
pascal@1210 | 82 lmtp 2003/tcp |
pascal@1210 | 83 fud 4201/udp |
pascal@1210 | 84 EOF |
pascal@1659 | 85 [ -z "$1" ] && /etc/init.d/$PACKAGE start |
pascal@2389 | 86 if [ -f $1/etc/init.d/postfix ]; then |
pascal@2389 | 87 if ! grep -v ^# $1/etc/postfix/main.cf | grep -q lmtp:unix; then |
pascal@1210 | 88 echo "Append to /etc/postfix/main.cf:" |
pascal@1210 | 89 echo -n " " |
pascal@1210 | 90 echo "mailbox_transport = lmtp:unix:/var/imap/socket/lmtp" | \ |
pascal@2389 | 91 tee -a $1/etc/postfix/main.cf |
pascal@2389 | 92 if [ -z "$1" ]; then |
pascal@2389 | 93 /etc/init.d/postfix start || /etc/init.d/postfix reload |
pascal@2389 | 94 fi |
pascal@1210 | 95 fi |
pascal@1210 | 96 fi |
pascal@1210 | 97 msg="Creating mailbox for" |
pascal@2389 | 98 for i in root $(awk -F: '{ if ($3 >= 1000) print $1 }' < $1/etc/passwd); do |
pascal@1210 | 99 echo -n "$msg $i" |
pascal@1210 | 100 msg="," |
pascal@1210 | 101 done |
pascal@1210 | 102 echo "" |
pascal@2389 | 103 for i in root $(awk -F: '{ if ($3 >= 1000) print $1 }' < $1/etc/passwd); do |
pascal@1210 | 104 echo "createmailbox user.$i" |
pascal@2389 | 105 done | chroot $1/ cyradm -u cyrus -w cyrus 127.0.0.1 >/dev/null 2>&1 |
pascal@2389 | 106 chroot $1/ su -c "/usr/cyrus/bin/reconstruct" cyrus >/dev/null 2>&1 |
pascal@1210 | 107 cat <<EOF |
pascal@1210 | 108 ---- |
pascal@1210 | 109 Users must have a password to access the mailbox. |
pascal@1210 | 110 To start $PACKAGE server you can run : |
pascal@1210 | 111 |
pascal@1210 | 112 /etc/init.d/$PACKAGE start |
pascal@1210 | 113 |
pascal@1210 | 114 Or add $PACKAGE to RUN_DAEMONS in /etc/rcS.conf |
pascal@1210 | 115 ---- |
pascal@1210 | 116 EOF |
pascal@1210 | 117 } |
pascal@1210 | 118 |
pascal@1210 | 119 post_remove() |
pascal@1210 | 120 { |
pascal@1210 | 121 deluser cyrus |
pascal@1210 | 122 delgroup mail |
pascal@1210 | 123 } |