9c2ec69333f0002319526be1a4a0c6174290c83e
[live-boot-grml.git] / backend / initramfs-tools / live.hook
1 #!/bin/sh
2
3 set -e
4
5 . /usr/share/initramfs-tools/hook-functions
6
7 [ "${QUIET}" ] || echo -n "live-boot:"
8
9 # Reading configuration file from filesystem and live-media
10 for _FILE in /etc/live/boot.conf /etc/live/boot/* \
11              /lib/live/mount/media/live/boot.conf /lib/live/mount/media/live/boot/*
12 do
13         if [ -e "${_FILE}" ]
14         then
15                 . "${_FILE}"
16         fi
17 done
18
19 # Grml version information:
20 if [ -r /etc/grml_version ]
21 then
22        cp /etc/grml_version "${DESTDIR}"/etc
23 fi
24
25 # Checking live-boot
26 if [ ! -e /bin/live-boot ]
27 then
28         echo
29         echo "W: live-boot-initramfs-tools (backend) installed without live-boot,"
30         echo "W: this initramfs will *NOT* have live support."
31         exit 0
32 fi
33
34 [ "${QUIET}" ] || echo -n " core"
35
36 mkdir -p "${DESTDIR}/bin"
37 cp -a /bin/live-boot /lib/live/boot "${DESTDIR}/bin"
38
39 mkdir -p "${DESTDIR}/lib/live"
40 cp -a /lib/live/boot "${DESTDIR}/lib/live"
41
42 mkdir -p "${DESTDIR}/etc/live"
43 if [ -e /etc/live/boot.conf ]
44 then
45         cp -a /etc/live/boot.conf "${DESTDIR}/etc/live"
46 fi
47 if [ -e /etc/live/boot ]
48 then
49         cp -a /etc/live/boot "${DESTDIR}/etc/live"
50 fi
51
52 # klibc dependencies
53 for FILE in /lib/libacl* /lib/libblkid* /lib/libuuid* /lib/libdevmapper* /lib/libattr*
54 do
55         if [ ! -e "${DESTDIR}/${FILE}" ] && ls "${FILE}" > /dev/null 2>&1
56         then
57                 cp -a "${FILE}" "${DESTDIR}/${FILE}"
58         fi
59 done
60
61 # udev dependencies
62 for FILE in /lib/udev/*_id
63 do
64         copy_exec "${FILE}"
65 done
66
67 if [ -e /lib/udev/rules.d/60-cdrom_id.rules ]
68 then
69         mkdir -p "${DESTDIR}/lib/udev/rules.d"
70         cp -p /lib/udev/rules.d/60-cdrom_id.rules "${DESTDIR}/lib/udev/rules.d"
71 fi
72
73 [ "${QUIET}" ] || echo -n " filesystems"
74
75 # Configuration: keymap (usefull when using encryption)
76 if [ -x /bin/loadkeys ] && [ -r /etc/console/boottime.kmap.gz ]
77 then
78         copy_exec /bin/loadkeys
79
80         mkdir -p "${DESTDIR}/etc"
81         cp /etc/console/boottime.kmap.gz "${DESTDIR}/etc"
82 fi
83
84 # Configuration: Unique ID
85 if [ -n "${LIVE_GENERATE_UUID}" ]
86 then
87         mkdir -p "${DESTDIR}/conf"
88         uuidgen -r > "${DESTDIR}/conf/uuid.conf"
89 fi
90
91 # Filesystem: btrfs
92 manual_add_modules btrfs
93
94 # Filesystem: cifs
95 if [ -x /sbin/mount.cifs ]
96 then
97         copy_exec /sbin/mount.cifs
98         manual_add_modules cifs
99 fi
100
101 # Filesystem: ext3/ext4
102 manual_add_modules ext3
103 manual_add_modules ext4
104
105 # Filesystem: hfs/hfsplus
106 manual_add_modules hfs
107 manual_add_modules hfsplus
108
109 # Filesystem: jffs2
110 manual_add_modules jffs2
111
112 if [ -x /usr/bin/rsync ]
113 then
114         copy_exec /usr/bin/rsync /bin
115 fi
116
117 # Filesystem: squashfs
118 copy_exec /sbin/losetup
119 manual_add_modules loop
120 manual_add_modules squashfs
121 manual_add_modules sqlzma
122 manual_add_modules unlzma
123
124 # Filesystem: aufs/overlay
125 manual_add_modules aufs
126 manual_add_modules overlay
127
128 # Filesystem: vfat
129 manual_add_modules nls_cp437
130 manual_add_modules nls_iso8859-1
131 manual_add_modules nls_utf8
132 manual_add_modules nls_ascii
133 manual_add_modules vfat
134
135 # Filesystem: ntfs
136 manual_add_modules ntfs
137
138 [ "${QUIET}" ] || echo -n " devices"
139 # Hardware: cdrom
140 manual_add_modules ide-cd
141 manual_add_modules ide-generic
142 manual_add_modules ohci1394
143 manual_add_modules sbp2
144 manual_add_modules sr_mod
145
146 # Hardware: usb
147 manual_add_modules sd_mod
148
149 # Hardware: network
150 auto_add_modules net
151
152 # Program: eject
153 if [ -x /usr/bin/eject ]
154 then
155         copy_exec /usr/bin/eject /bin
156 fi
157
158 # Program: mount
159 # fuse does not work with klibc mount
160 copy_exec /bin/mount /bin/mount.util-linux
161
162 [ "${QUIET}" ] || echo -n " utils"
163
164 # Feature: Verify Checksums
165 if [ -e /etc/progress-linux_version ]
166 then
167         copy_exec /usr/bin/sha256sum /bin
168 else
169         copy_exec /usr/bin/md5sum /bin
170 fi
171
172 # Program: memdisk
173 if [ -x /usr/bin/memdiskfind ]
174 then
175 [ "${QUIET}" ] || echo -n " memdisk"
176         copy_exec /usr/bin/memdiskfind
177         manual_add_modules phram
178         manual_add_modules mtdblock
179 fi
180
181 # Program: udev
182 if [ -x /sbin/udevadm ]
183 then
184         [ "${QUIET}" ] || echo -n " udev"
185         copy_exec /sbin/udevadm
186 fi
187
188 # Program: wget
189 if [ -x /usr/bin/wget ]
190 then
191         [ "${QUIET}" ] || echo -n " wget"
192         copy_exec /usr/bin/wget /bin
193 fi
194
195 # Program: blockdev
196 if [ -x /sbin/blockdev ]
197 then
198         [ "${QUIET}" ] || echo -n " blockdev"
199         copy_exec /sbin/blockdev
200 fi
201
202 # FUSE kernel module
203 manual_add_modules fuse
204
205 # FUSE filesystem: httpfs2
206 if [ -x /usr/bin/httpfs2_ssl ]
207 then
208         [ "${QUIET}" ] || echo -n " httpfs:ssl"
209         copy_exec /usr/bin/httpfs2_ssl /bin/httpfs
210 elif [ -x /usr/bin/httpfs2 ]
211 then
212         [ "${QUIET}" ] || echo -n " httpfs"
213         copy_exec /usr/bin/httpfs2 /bin/httpfs
214 fi
215
216 # FUSE filesystem: curlftpfs
217 if [ -x /usr/bin/curlftpfs ]
218 then
219         [ "${QUIET}" ] || echo -n " ftpfs"
220         copy_exec /usr/bin/curlftpfs /bin
221 fi
222
223 # iSCSI
224 if [ -x /usr/sbin/iscsistart ]
225 then
226         [ "${QUIET}" ] || echo -n " iscsi"
227         copy_exec /usr/sbin/iscsistart /bin
228         #manual_add_modules ib_iser
229         manual_add_modules iscsi_tcp
230         manual_add_modules crc32c
231 fi
232
233 # Some experimental stuff
234
235 [ "${QUIET}" ] || echo -n " dns"
236
237 # /lib/libnss_dns.so.*:a   DNS
238 # /lib/libnss_files.so.*:  /etc/hosts and /etc/passwd
239 # /lib/libnss_compat.so.*: /etc/passwd
240
241 for _SHLIB in $(find /lib -name 'libnss_dns.so.*')
242 do
243         copy_exec "${_SHLIB}"
244 done
245
246 # might be needed if /etc/hosts is used
247 #mkdir -p "${DESTDIR}/etc"
248 #cp -p /etc/nsswitch.conf "${DESTDIR}/etc"
249
250 # vlan support
251 if [ -x /sbin/vconfig ]
252 then
253         copy_exec /sbin/vconfig
254         manual_add_modules 8021q
255 fi
256
257 [ "${QUIET}" ] || echo .