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