wok-tiny view base-tiny/receipt @ rev 83

Add telnet-config
author Pascal Bellard <pascal.bellard@slitaz.org>
date Fri Jul 20 12:32:58 2012 +0200 (2012-07-20)
parents 044813ac0732
children a6d2ddc65590
line source
1 # SliTaz package receipt.
3 PACKAGE="base-tiny"
4 VERSION="1.0"
5 CATEGORY="configuration"
6 SHORT_DESC="Tiny SliTaz base configuration files"
7 MAINTAINER="pascal.bellard@slitaz.org"
8 WEB_SITE="http://tiny.slitaz.org/"
9 AUTO_SELECTION="always"
10 CONFIG_FILES="/etc/network.conf /etc/passwd /etc/shadow \
11 /root/.profile /etc/fstab /etc/init.d/local.sh"
13 # Rules to configure and make the package.
14 compile_rules()
15 {
16 mkdir -p fs/var/lib fs/etc
17 echo "none" > fs/var/lib/detected-modules
18 echo "LANG=C" > fs/etc/locale.conf
19 while read pkg file ; do
20 if [ ! -s $pkg*/fs$file ]; then
21 tazpkg get $pkg
22 tazpkg extract $pkg*.tazpkg
23 fi
24 mkdir -p fs$(dirname $file)
25 mv $pkg*/fs$file fs$(dirname $file) || return 1
26 done << EOT
27 busybox /etc/udhcpd.conf
28 busybox /etc/inetd.conf
29 slitaz-base-files /etc/fstab
30 slitaz-base-files /etc/group
31 slitaz-base-files /etc/passwd
32 slitaz-base-files /etc/shadow
33 slitaz-boot-scripts /etc/inittab
34 slitaz-boot-scripts /etc/network.conf
35 slitaz-boot-scripts /etc/init.d/local.sh
36 slitaz-boot-scripts /etc/rcS.conf
37 EOT
38 sed -i 's/:x:/:!:/' fs/etc/passwd
39 sed -i 's/UDEV=.*/UDEV="no"/;s/hwconf.sh l/l/' fs/etc/rcS.conf
40 }
42 # Rules to gen a SliTaz package suitable for Tazpkg.
43 genpkg_rules()
44 {
45 cp -a fs/. $fs
46 }
48 config_form()
49 {
50 [ -n "$PASSWORD" ] || PASSWORD=root
51 [ -n "$HOSTNAME" ] || HOSTNAME=slitaz
52 [ -n "$INTERFACE" ] || INTERFACE=eth0
53 [ -n "$IP" ] || IP=192.168.0.6
54 [ -n "$NETMASK" ] || NETMASK=255.255.255.0
55 [ -n "$GATEWAY" ] || GATEWAY=192.168.0.1
56 [ -n "$DNS_SERVER" ] || DNS_SERVER='192.168.0.1 192.168.0.2'
57 [ -n "$FSTAB" ] || FSTAB='/dev/hda1 /mnt ext3 defaults 0 2'
58 [ -n "$RC_LOCAL" ] || RC_LOCAL='[ -x /mnt/boot/init ] && /mnt/boot/init'
59 cat <<EOT
60 <table>
61 <tr>
62 <td>Root password</td>
63 <td><input type="text" name="PASSWORD" value="$PASSWORD" /></td>
64 </tr>
65 <tr>
66 <td>Host name</td>
67 <td><input type="text" name="HOSTNAME" value="$HOSTNAME" /></td>
68 </tr>
69 <tr>
70 <td>Interface</td>
71 <td><input type="text" name="INTERFACE" value="$INTERFACE" /></td>
72 </tr>
73 <tr>
74 <td>Network configuration</td>
75 <td><select name="MODE">
76 <option value="STATIC">STATIC</option>
77 <option value="DHCP"$([ "$MODE" == "DHCP" ] && echo ' selected="selected"')>DHCP</option>
78 <option value="DISABLE">DISABLE</option>
79 </select></td>
80 </tr>
81 <tr>
82 <td>Internet address</td>
83 <td><input type="text" name="IP" value="$IP" /></td>
84 </tr>
85 <tr>
86 <td>Netmask</td>
87 <td><input type="text" name="NETMASK" value="$NETMASK" /></td>
88 </tr>
89 <tr>
90 <td>Gateway</td>
91 <td><input type="text" name="GATEWAY" value="$GATEWAY" /></td>
92 </tr>
93 <tr>
94 <td>DNS server(s)</td>
95 <td><input type="text" name="DNS_SERVER" value="$DNS_SERVER" /></td>
96 </tr>
97 <tr>
98 <td>Filesystems</td>
99 <td><textarea name="FSTAB" cols="60" wrap="off">
100 $FSTAB
101 </textarea></td>
102 </tr>
103 <tr>
104 <td>Additional boot commands</td>
105 <td><textarea name="RC_LOCAL" cols="60" wrap="off">
106 $RC_LOCAL
107 </textarea></td>
108 </tr>
109 </table>
110 EOT
111 }
113 post_install()
114 {
115 DHCP="no"
116 STATIC="yes"
117 case "$MODE" in
118 "") return 1;;
119 DISABLE)
120 STATIC="no" ;;
121 DHCP) DHCP="yes"
122 STATIC="no"
123 esac
124 sed -i -e "s/^DNS_SERVER=.*/DNS_SERVER=\"$DNS_SERVER\"/" \
125 -e "s/^INTERFACE=.*/INTERFACE=\"$INTERFACE\"/" \
126 -e "s/^NETMASK=.*/NETMASK=\"$NETMASK\"/" \
127 -e "s/^GATEWAY=.*/GATEWAY=\"$GATEWAY\"/" \
128 -e "s/^STATIC=.*/STATIC=\"$STATIC\"/" \
129 -e "s/^DHCP=.*/DHCP=\"$DHCP\"/" \
130 -e "s/^IP=.*/IP=\"$IP\"/" $1/etc/network.conf
131 if [ -n "$PASSWORD" ]; then
132 mkdir $1/lib
133 cp -a /lib/lib[cm][.-]* /lib/ld* $1/lib
134 cp -a /bin/busybox $1/lib/chpasswd
135 echo "root:$PASSWORD" | chroot $1/ /lib/chpasswd -m
136 rm -rf $1/lib
137 else
138 sed -i 's/^root:[^:]*:/root::/' $1/etc/passwd
139 mkdir $1/root 2> /dev/null
140 cat > $1/root/.profile <<EOT
141 grep -qs ^root:: /etc/passwd /etc/shadow && passwd
142 EOT
143 fi
144 [ -n "$HOSTNAME" ] && echo $HOSTNAME > $1/etc/hostname
145 [ -n "$FSTAB" ] && dos2unix >> $1/etc/fstab <<EOT
146 $FSTAB
147 EOT
148 [ -n "$RC_LOCAL" ] && dos2unix >> $1/etc/init.d/local.sh <<EOT
149 $RC_LOCAL
150 EOT
151 }