comparison debian/postinst @ 395:056d5fcb7f4b noffle

[svn] updated deb'configuration
author godisch
date Thu, 29 May 2003 15:44:56 +0100
parents a23b37308063
children 71801bfc07c2
comparison
equal deleted inserted replaced
394:3d3a0dab6011 395:056d5fcb7f4b
1 #!/bin/sh 1 #!/bin/sh
2 # $Id: postinst 499 2003-03-29 06:57:20Z godisch $ 2 # $Id: postinst 537 2003-05-29 14:44:56Z godisch $
3 3
4 set -e 4 set -e
5 5
6 [ "$1" = configure ] || exit 0 6 [ "$1" = configure ] || exit 0
7
8 . /usr/share/debconf/confmodule
9 db_version 2.0
10 7
11 server_config=/etc/news/noffle.conf 8 server_config=/etc/news/noffle.conf
12 debian_config=/etc/default/noffle 9 debian_config=/etc/default/noffle
13 10
14 maxfetch_default=300 11 maxfetch_default=300
33 # 1.1.2-1 was in unstable only, don't notify 30 # 1.1.2-1 was in unstable only, don't notify
34 mv -f /etc/noffle.conf $server_config || : 31 mv -f /etc/noffle.conf $server_config || :
35 mv -f /etc/noffle.conf.old $server_config.old 2> /dev/null || : 32 mv -f /etc/noffle.conf.old $server_config.old 2> /dev/null || :
36 fi 33 fi
37 34
38 db_get noffle/debconf 35 if [ -e /usr/share/debconf/confmodule ]; then
39 if [ "$RET" != false ]; then 36 . /usr/share/debconf/confmodule
40 db_get noffle/port 37 db_version 2.0
41 port="$RET" 38 db_get noffle/debconf
42 [ -z "$port" -o "$port" = 119 ] && port=nntp || : 39 if [ "$RET" = true ]; then
43 # maybe disabled only, e.g. dpkg -r noffle 40 db_get noffle/port
44 update-inetd --remove "/usr/bin/noffle -r" || : 41 port="$RET"
45 update-inetd --group MAIL --add "$port\tstream\ttcp\tnowait\tnews\t/usr/sbin/tcpd /usr/bin/noffle -r" 42 [ -z "$port" -o "$port" = 119 ] && port=nntp || :
46 db_get noffle/server 43 # maybe disabled only, e.g. dpkg -r noffle
47 server="$RET" 44 update-inetd --remove "/usr/bin/noffle -r" || :
48 [ "$server" ] || server=news 45 update-inetd --group MAIL --add "$port\tstream\ttcp\tnowait\tnews\t/usr/sbin/tcpd /usr/bin/noffle -r"
49 db_get noffle/username 46 db_get noffle/server
50 username="$RET" 47 server="$RET"
51 db_get noffle/password 48 [ "$server" ] || server=news
52 password="$RET" 49 db_get noffle/username
53 db_get noffle/fetchmode 50 username="$RET"
54 fetchmode="$RET" 51 db_get noffle/password
55 [ "$fetchmode" ] || if [ -x /usr/sbin/pppd ]; then 52 password="$RET"
56 fetchmode=ppp 53 db_get noffle/fetchmode
57 else 54 fetchmode="$RET"
58 fetchmode=cron 55 [ "$fetchmode" ] || if [ -x /usr/sbin/pppd ]; then
56 fetchmode=ppp
57 else
58 fetchmode=cron
59 fi
60 db_get noffle/maxfetch
61 maxfetch="$RET"
62 [ "$maxfetch" ] || maxfetch="$maxfetch_default"
63 db_get noffle/default-expire
64 defexpire="$RET"
65 [ "$defexpire" ] || defexpire="$defexpire_default"
66 # try to be idempotent
67 if [ ! -e $server_config.new -a ! -e $debian_config.new ]; then
68 # make some backup files
69 cmp -s $server_config $server_config.old || \
70 cp -pf $server_config $server_config.old 2> /dev/null || :
71 cmp -s $debian_config $debian_config.old || \
72 cp -pf $debian_config $debian_config.old 2> /dev/null || :
73 fi
74 # $server_config may contain sensitive information for NNTP authentication
75 umask 027
76 # we need to use sed instead of Perl to avoid another package dependency
77 cat /usr/share/noffle/noffle.conf | \
78 sed "s/^server[[:space:]].*/server $server $username $password/" | \
79 sed "s/^max-fetch[[:space:]].*/max-fetch $maxfetch/" | \
80 sed "s/^default-expire[[:space:]].*/default-expire $defexpire/" \
81 > $server_config.new
82 chgrp news $server_config.new
83 umask 022
84 cat /usr/share/noffle/conf.debian | \
85 sed "s/^NOFFLE_FETCHMODE=.*/NOFFLE_FETCHMODE=$fetchmode/" \
86 > $debian_config.new
87 mv -f $server_config.new $server_config
88 mv -f $debian_config.new $debian_config
59 fi 89 fi
60 db_get noffle/maxfetch 90 db_stop
61 maxfetch="$RET" 91 else
62 [ "$maxfetch" ] || maxfetch="$maxfetch_default" 92 # no debconf available
63 db_get noffle/default-expire 93 if [ ! -e $server_config ]; then
64 defexpire="$RET" 94 umask 027
65 [ "$defexpire" ] || defexpire="$defexpire_default" 95 cp -f /usr/share/noffle/noffle.conf $server_config.new
66 # try to be idempotent 96 chgrp news $server_config.new
67 if [ ! -e $server_config.new -a ! -e $debian_config.new ]; then 97 mv -fb $server_config.new $server_config
68 # make some backup files
69 cmp -s $server_config $server_config.old || \
70 cp -pf $server_config $server_config.old 2> /dev/null || :
71 cmp -s $debian_config $debian_config.old || \
72 cp -pf $debian_config $debian_config.old 2> /dev/null || :
73 fi 98 fi
74 # $server_config may contain sensitive information for NNTP authentication 99 if [ ! -e $debian_config ]; then
75 umask 027 100 umask 022
76 # we need to use sed instead of Perl to avoid another package dependency 101 cp -f /usr/share/noffle/conf.debian $debian_config.new
77 cat /usr/share/noffle/noffle.conf | \ 102 mv -fb $debian_config.new $debian_config
78 sed "s/^server[[:space:]].*/server $server $username $password/" | \ 103 fi
79 sed "s/^max-fetch[[:space:]].*/max-fetch $maxfetch/" | \
80 sed "s/^default-expire[[:space:]].*/default-expire $defexpire/" \
81 > $server_config.new
82 chgrp news $server_config.new
83 umask 022
84 cat /usr/share/noffle/conf.debian | \
85 sed "s/^NOFFLE_FETCHMODE=.*/NOFFLE_FETCHMODE=$fetchmode/" \
86 > $debian_config.new
87 mv -f $server_config.new $server_config
88 mv -f $debian_config.new $debian_config
89 fi 104 fi
90 105
91 # sanity checks 106 # sanity checks
92 chown -R news:news /var/lock/noffle /var/spool/noffle 107 chown -R news:news /var/lock/noffle /var/spool/noffle
93 chmod -R go-w /var/lock/noffle /var/spool/noffle 108 chmod -R go-w /var/lock/noffle /var/spool/noffle
108 echo "information how to do this." 123 echo "information how to do this."
109 echo "" 124 echo ""
110 sleep 2 125 sleep 2
111 fi 126 fi
112 127
113 db_stop
114 exit 0 128 exit 0