Dropping snapshot functionality, superseeded by awesome custom mount persistence.
[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 /usr/share/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 # Directories
58 mkdir -p "${DESTDIR}"/lib/live-boot
59
60 # klibc dependencies
61 for FILE in /lib/libacl* /lib/libblkid* /lib/libuuid* /lib/libdevmapper* /lib/libattr*
62 do
63         if [ ! -e "${DESTDIR}"/"${FILE}" ] && ls ${FILE} > /dev/null 2>&1
64         then
65                 cp -a "${FILE}" "${DESTDIR}"/"${FILE}"
66         fi
67 done
68
69 # udev dependencies (squeeze and newer)
70 for FILE in /lib/udev/*_id
71 do
72         if [ ! -e "${DESTDIR}/${FILE}" ]
73         then
74                 mkdir -p "${DESTDIR}/lib/udev"
75                 copy_exec "${FILE}" /lib/udev
76         fi
77 done
78
79 if [ -e /lib/udev/rules.d/60-cdrom_id.rules ]
80 then
81         mkdir -p ${DESTDIR}/lib/udev/rules.d
82         cp -p /lib/udev/rules.d/60-cdrom_id.rules ${DESTDIR}/lib/udev/rules.d
83 fi
84
85 # Handling other stuff
86
87 [ "${QUIET}" ] || echo -n " "filesystems
88 # Configuration: keymap (usefull when using encryption)
89 if [ -x /bin/loadkeys ] && [ -r /etc/console/boottime.kmap.gz ]
90 then
91         copy_exec /bin/loadkeys /bin
92
93         mkdir -p "${DESTDIR}"/etc
94         cp /etc/console/boottime.kmap.gz "${DESTDIR}"/etc
95 fi
96
97 # Configuration: Unique ID
98 if [ -n "${LIVE_GENERATE_UUID}" ]
99 then
100         mkdir -p "${DESTDIR}"/conf
101         uuidgen -r > "${DESTDIR}"/conf/uuid.conf
102 fi
103
104 # Filesystem: btrfs
105 manual_add_modules btrfs
106
107 # Filesystem: cifs
108 if [ -x /sbin/mount.cifs ]
109 then
110         copy_exec /sbin/mount.cifs /sbin
111         manual_add_modules cifs
112 fi
113
114 # Filesystem: ext3/ext4
115 manual_add_modules ext3
116 manual_add_modules ext4
117
118 # Filesystem: jffs2
119 manual_add_modules jffs2
120
121 if [ -x /usr/bin/rsync ]
122 then
123         copy_exec /usr/bin/rsync /bin
124 fi
125
126 # Filesystem: squashfs
127 copy_exec /sbin/losetup /sbin
128 manual_add_modules loop
129 manual_add_modules squashfs
130 manual_add_modules sqlzma
131 manual_add_modules unlzma
132
133 # Filesystem: aufs/overlayfs/unionfs
134 manual_add_modules aufs
135 manual_add_modules overlayfs
136 manual_add_modules unionfs
137
138 # Filesystem: unionfs-fuse
139 if [ -x /usr/bin/unionfs-fuse ]
140 then
141         copy_exec /usr/bin/unionfs-fuse /bin
142 fi
143
144 # Filesystem: vfat
145 manual_add_modules nls_cp437
146 manual_add_modules nls_iso8859-1
147 manual_add_modules nls_utf8
148 manual_add_modules vfat
149
150 # Filesystem: ntfs
151 manual_add_modules ntfs
152
153 [ "${QUIET}" ] || echo -n " "devices
154 # Hardware: cdrom
155 manual_add_modules ide-cd
156 manual_add_modules ide-generic
157 manual_add_modules ohci1394
158 manual_add_modules sbp2
159 manual_add_modules sr_mod
160
161 # Hardware: usb
162 manual_add_modules sd_mod
163
164 # Hardware: network
165 auto_add_modules net
166
167 # Program: eject
168 if [ -x /usr/bin/eject ]
169 then
170         copy_exec /usr/bin/eject /bin
171 fi
172
173 [ "${QUIET}" ] || echo -n " "utils
174
175 # Feature: Verify Checksums
176 copy_exec /usr/bin/sha256sum /bin
177 copy_exec /usr/bin/md5sum /bin
178
179 # Program: memdisk
180 if [ -x /usr/bin/memdiskfind ]
181 then
182 [ "${QUIET}" ] || echo -n :memdisk
183         copy_exec /usr/bin/memdiskfind
184         manual_add_modules phram
185         manual_add_modules mtdblock
186 fi
187
188 # Program: udev
189 if [ -x /sbin/udevadm ]
190 then
191         [ "${QUIET}" ] || echo -n " "udev
192         copy_exec /sbin/udevadm /sbin
193 fi
194 if [ -x /usr/bin/udevinfo ]
195 then
196         [ "${QUIET}" ] || echo -n " "udev
197         copy_exec /usr/bin/udevinfo /bin
198 fi
199
200 # Program: wget
201 if [ -x /usr/bin/wget ]
202 then
203         [ "${QUIET}" ] || echo -n " "wget
204         copy_exec /usr/bin/wget /bin
205 fi
206
207 # Program: blockdev
208 if [ -x /sbin/blockdev ]
209 then
210         [ "${QUIET}" ] || echo -n " "blockdev
211         copy_exec /sbin/blockdev /sbin
212 fi
213
214 # FUSE kernel module
215 manual_add_modules fuse
216
217 # FUSE filesystem: httpfs2
218 if [ -x /usr/bin/httpfs2_ssl ]
219 then
220         [ "${QUIET}" ] || echo -n " "httpfs:ssl
221         copy_exec /usr/bin/httpfs2_ssl /bin/httpfs
222 elif [ -x /usr/bin/httpfs2 ]
223 then
224         [ "${QUIET}" ] || echo -n " "httpfs
225         copy_exec /usr/bin/httpfs2 /bin/httpfs
226 fi
227
228 # FUSE filesystem: curlftpfs
229 if [ -x /usr/bin/curlftpfs ]
230 then
231         [ "${QUIET}" ] || echo -n " "ftpfs
232         copy_exec /usr/bin/curlftpfs /bin
233 fi
234
235 # iSCSI
236 if [ -x /usr/sbin/iscsistart ]
237 then
238         [ "${QUIET}" ] || echo -n " "iscsi
239         copy_exec /usr/sbin/iscsistart /bin
240         #manual_add_modules ib_iser
241         manual_add_modules iscsi_tcp
242         manual_add_modules crc32c
243 fi
244
245 if [ "${LIVE_DNS}" = "true" ]
246 then
247         [ "${QUIET}" ] || echo -n " "dns
248         #copy_exec /lib/libnss_files.so.*      /lib  # /etc/hosts and /etc/passwd
249         copy_exec /lib/libnss_dns.so.*      /lib  # DNS server
250         #copy_exec /lib/libnss_compat.so.*      /lib  # /etc/passwd
251
252         # Configuration file - may be needed if /etc/hosts is used.
253         #mkdir -p $DESTDIR/etc
254         #cp -p /etc/nsswitch.conf $DESTDIR/etc
255 fi
256
257 if [ "${LIVE_UNIONMOUNT}" = "true" ]
258 then
259         [ "${QUIET}" ] || echo -n " "unionmount
260         # UnionMount
261         # only mount from patched util-linux can do this currently
262         copy_exec /bin/mount /bin/mount_full
263 fi
264
265 [ "${QUIET}" ] || echo .