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

Add tcc
author Pascal Bellard <pascal.bellard@slitaz.org>
date Wed Feb 02 23:12:23 2011 +0100 (2011-02-02)
parents 78eec5d0bbfd
children 4ba2d11dfa87
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://mirror.slitaz.org/pizza/tiny/"
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-boot-scripts /etc/inittab
32 slitaz-boot-scripts /etc/network.conf
33 slitaz-boot-scripts /etc/init.d/local.sh
34 slitaz-boot-scripts /etc/rcS.conf
35 EOT
36 }
38 # Rules to gen a SliTaz package suitable for Tazpkg.
39 genpkg_rules()
40 {
41 cp -a fs/. $fs
42 }
44 config_form()
45 {
46 [ -n "$PASSWORD" ] || PASSWORD=root
47 [ -n "$INTERFACE" ] || INTERFACE=eth0
48 [ -n "$IP" ] || IP=192.168.0.6
49 [ -n "$NETMASK" ] || NETMASK=255.255.255.0
50 [ -n "$GATEWAY" ] || GATEWAY=192.168.0.1
51 [ -n "$DNS_SERVER" ] || DNS_SERVER='192.168.0.1 192.168.0.2'
52 [ -n "$FSTAB" ] || FSTAB='/dev/hda1 /mnt ext3 defaults 0 2'
53 [ -n "$RC_LOCAL" ] || RC_LOCAL='[ -x /mnt/boot/init ] && /mnt/boot/init'
54 cat <<EOT
55 <table>
56 <tr>
57 <td>Root password</td>
58 <td><input type="text" name="PASSWORD" value="$PASSWORD" /></td>
59 </tr>
60 <tr>
61 <td>Interface</td>
62 <td><input type="text" name="INTERFACE" value="$INTERFACE" /></td>
63 </tr>
64 <tr>
65 <td>Network configuration</td>
66 <td><select name="MODE">
67 <option value="STATIC">STATIC</option>
68 <option value="DHCP"$([ "$MODE" == "DHCP" ] && echo ' selected="selected"')>DHCP</option>
69 </select></td>
70 </tr>
71 <tr>
72 <td>Internet address</td>
73 <td><input type="text" name="IP" value="$IP" /></td>
74 </tr>
75 <tr>
76 <td>Netmask</td>
77 <td><input type="text" name="NETMASK" value="$NETMASK" /></td>
78 </tr>
79 <tr>
80 <td>Gateway</td>
81 <td><input type="text" name="GATEWAY" value="$GATEWAY" /></td>
82 </tr>
83 <tr>
84 <td>DNS server(s)</td>
85 <td><input type="text" name="DNS_SERVER" value="$DNS_SERVER" /></td>
86 </tr>
87 <tr>
88 <td>Filesystems</td>
89 <td><textarea name="FSTAB" cols="60" wrap="off">
90 $FSTAB
91 </textarea></td>
92 </tr>
93 <tr>
94 <td>Additionnal boot commands</td>
95 <td><textarea name="RC_LOCAL" cols="60" wrap="off">
96 $RC_LOCAL
97 </textarea></td>
98 </tr>
99 </table>
100 EOT
101 }
103 post_install()
104 {
105 DHCP="no"
106 STATIC="yes"
107 case "$MODE" in
108 "") return 1;;
109 DHCP) DHCP="yes"
110 STATIC="no"
111 esac
112 sed -i -e "s/^DNS_SERVER=.*/DNS_SERVER=\"$DNS_SERVER\"/" \
113 -e "s/^INTERFACE=.*/INTERFACE=\"$INTERFACE\"/" \
114 -e "s/^NETMASK=.*/NETMASK=\"$NETMASK\"/" \
115 -e "s/^GATEWAY=.*/GATEWAY=\"$GATEWAY\"/" \
116 -e "s/^STATIC=.*/STATIC=\"$STATIC\"/" \
117 -e "s/^DHCP=.*/DHCP=\"$DHCP\"/" \
118 -e "s/^IP=.*/IP=\"$IP\"/" $1/etc/network.conf
119 if [ -n "$PASSWORD" ]; then
120 chroot $1/ "echo 'root:$PASSWORD' | chpasswd"
121 else
122 sed -i 's/^root:[^:]*:/root::/' $1/etc/passwd
123 cat > $1/root/.profile <<EOT
124 grep -qs ^root:: /etc/passwd /etc/shadow && passwd
125 EOT
126 fi
127 [ -n "$FSTAB" ] && dos2unix >> $1/etc/fstab <<EOT
128 $FSTAB
129 EOT
130 [ -n "$RC_LOCAL" ] && dos2unix >> $1/etc/init.d/local.sh <<EOT
131 $RC_LOCAL
132 EOT
133 }