forked from tabulon-ext/macos-mkjail
-
Notifications
You must be signed in to change notification settings - Fork 0
/
mkjail.sh
executable file
·553 lines (510 loc) · 18.4 KB
/
mkjail.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
#!/usr/bin/env bash
if [[ "${OSTYPE}" != darwin* ]]; then echo "This script is only for macOS."; exit 5;
elif [[ "$(pwd -P)" == *" "* ]]; then echo "Working directory must not contain any spaces."; exit 54;
fi
OWNER_UID="$EUID"
OWNER_NAME="$(whoami)"
absolute_path() {
pushd "$1" &> /dev/null || return 1
pwd -P
PWD_EXIT_CODE=$?
popd &> /dev/null
return ${PWD_EXIT_CODE}
}
fixperms() {
if [[ -z "$1" ]]; then return 1; fi
OWNER_UID="${EUID}"
OWNER_NAME="$(whoami)"
# Start a new shell as root to avoid asking for password multiple times on some systems.
sudo bash <<EOF
SPECIAL_DIRS=("/usr/share" "/usr/bin" "/usr/libexec" "/usr/include" "/usr/lib")
set -e
chown -R 0:0 "$1"
chown -R ${OWNER_UID}:20 "${1}${HOME}" || chown -R ${OWNER_UID}:20 "${1}/Users/${OWNER_NAME}" || echo "W: Unable to set permissions for home folder."
chmod u+s "${1}/bin/ping" || true
chmod 1777 "${1}/tmp"
chmod 666 "${1}/dev/"* || true
for DIR in "\${SPECIAL_DIRS[@]}"
do
chmod -R 1777 "${1}\${DIR}"
if [[ "\${DIR}" != "/usr/share" ]]; then
chmod -R 0755 "${1}\${DIR}/"* &> /dev/null || true
fi
done
chmod -R 1777 "${1}/usr/bin/bashpm.d" &> /dev/null || true
chroot -u 0 "$1" "/bin/ln" -s "/bin/bash" "/bin/sh" &> /dev/null || true
chroot -u 0 "$1" "/bin/ln" -s "/bin/env" "/usr/bin/env" &> /dev/null || true
chroot -u 0 "$1" "/bin/ln" -s "/bin/install" "/usr/bin/install" &> /dev/null || true
echo "Permissions have been set."
EOF
return $?
}
error_exit() {
echo "$1"
exit 1
}
# Everything inside /usr/lib/system will be copied as well.
DYLIBS_TO_COPY=(
"libncurses.5.4.dylib"
"libSystem.B.dylib"
"libiconv.2.dylib"
"libc++.1.dylib"
"libobjc.A.dylib"
"libc++abi.dylib"
"closure/libclosured.dylib"
"libutil.dylib"
"libz.1.dylib"
"libedit.3.dylib"
"libcharset.1.dylib"
)
DYLIB_NREQ=(0 0 0 0 0 0 1 0 0 0 1)
OTHER_FILES_TO_COPY=("/etc/protocols" "/etc/hosts")
SCRIPT_DEPENDS=("sudo" "tar" "curl" "git")
COMMANDS_TO_CHECK=("cc -v" "make -v" "gcc -v" "xcode-select -p")
THING_LINKS=(
"https://ftp.gnu.org/pub/gnu/bash/bash-4.4.18.tar.gz"
"https://ftp.gnu.org/pub/gnu/inetutils/inetutils-1.9.4.tar.xz"
"https://ftp.gnu.org/pub/gnu/coreutils/coreutils-8.30.tar.xz"
)
THINGS_TO_BUILD=("bash" "inetutils" "coreutils")
OPTIONAL=(0 1 0)
MAKE_ARGS=""
# BEGIN - Modify these values to support more stuff #
EXTRA_LINKS=(
"https://ftp.gnu.org/pub/gnu/nano/nano-3.1.tar.xz"
"https://ftp.gnu.org/pub/gnu/less/less-530.tar.gz"
"https://ftp.gnu.org/pub/gnu/make/make-4.2.1.tar.gz"
"https://ftp.gnu.org/pub/gnu/grep/grep-3.1.tar.xz"
"https://ftp.gnu.org/pub/gnu/gzip/gzip-1.9.tar.xz"
"https://netcologne.dl.sourceforge.net/project/zsh/zsh/5.5.1/zsh-5.5.1.tar.xz"
"https://ftp.gnu.org/pub/gnu/tar/tar-1.30.tar.xz"
"https://ftp.gnu.org/pub/gnu/binutils/binutils-2.31.1.tar.xz"
"https://datapacket.dl.sourceforge.net/project/lzmautils/xz-5.2.4.tar.xz"
"https://raw.githubusercontent.com/pixelomer/utility-archive/master/curl-nofw.tar"
"https://raw.githubusercontent.com/pixelomer/utility-archive/master/bzip2.tar"
"https://raw.githubusercontent.com/pixelomer/bashpm/80cf5edc1cb8eaa383a56a744106035656a8f30b/bashpm.sh"
)
CONFIGURE_FLAGS=(
" --disable-libmagic --enable-color --enable-extra --enable-multibuffer --enable-nanorc"
""
""
""
""
" --disable-gdbm"
""
""
""
""
""
""
)
EXTRAS_TO_BUILD=("nano" "less" "make" "grep" "gzip" "zsh" "tar" "binutils" "xz" "curl" "bzip2" "bashpm")
INSTALL_EXTRAS_TO="/usr"
EXTRA_LINK_TYPE=(0 1 1 0 0 0 0 0 0 3 3 4)
# 0: tar.xz archive
# 1: tar.gz archive
# 2: Placeholder for git
# 3: tar archive with precompiled binaries
# 4: Special type for bashpm
STATE=(0 0 0 0 0 3 0 0 0 0 0 4)
# 0: Runs fine
# 1: Doesn't start/unusable
# 2: Runs fine, some features not available
# 3: Starts/runs, not fully tested
# 4: Starts, some core features unavailable
EXTRAS=(0 0 0 0 0 0 0 0 0 1 0 0)
# 0: Extra (not installed by default)
# 1: Recommended (installed by default)
# Binaries to copy from the host system
EXTRA_BINARIES=("/usr/bin/clear")
# END #
EXTRAS_AVAILABLE=0
MANAGE_ARG="-m"
EXTRA_UTIL_ARG="-e"
THREADING_ARG="-j"
BASIC_ARG="-b"
VERSION_ARG="--version"
MKJAIL_PREV_VERSION="v1.0"
MKJAIL_VERSION="v1.0.1"
MKJAIL_CHANGES="- macOS Mojave (10.14) support"
LAST_UPDATE_YEAR="2018"
AUTHOR="PixelOmer"
# No jail_name given, print usage and exit
if [[ -z "$1" || "$1" == "--help" || "$1" == "-h" ]]; then
cat <<EOF
Usage: $0 [${MANAGE_ARG}] <jail_name> [[${EXTRA_UTIL_ARG} <util1> [util2]...] or [${BASIC_ARG}]] [${THREADING_ARG} <threads>]
This script creates a new macOS chroot jail inside jail_name with GNU utilities.
${MANAGE_ARG}: Opens up a basic prompt to modify the chroot. Requires the chroot to be created with this utility.
${EXTRA_UTIL_ARG}: Extra utilities to build and install. Run this script only with this argument to list the supported utilities. Not required if you specify ${MANAGE_ARG}
${THREADING_ARG}: Use this to specify how much threads to use during compilation.
${BASIC_ARG}: Install only required utilities and don't install recommended utilities.
Dont use ${EXTRA_UTIL_ARG} and ${BASIC_ARG} together, only the first one will take effect.
EOF
exit 0
elif [[ "$1" == "${VERSION_ARG}" ]]; then
cat <<EOF
macOS mkjail script ${MKJAIL_VERSION}, ${LAST_UPDATE_YEAR} ${AUTHOR}
Changes since ${MKJAIL_PREV_VERSION}:
${MKJAIL_CHANGES}
EOF
exit 0
elif [[ "$1" == "${EXTRA_UTIL_ARG}" ]]; then
echo "Supported utilities:"
n=0
for util in "${EXTRAS_TO_BUILD[@]}"; do
NS=""
if [[ ${STATE[${n}]} == 1 ]]; then NS=" (does not work)"
elif [[ ${STATE[${n}]} == 2 ]]; then NS=" (not fully functional)"
elif [[ ${STATE[${n}]} == 3 ]]; then NS=" (seems to work, not fully tested)"
elif [[ ${STATE[${n}]} == 4 ]]; then NS=" (some core features unavailable)"; fi
echo "- ${util}${NS}"
((n++))
done
echo "Use \"all\" to install every supported extra utility."
exit 0
fi
# Check if the user is root. Compiling as root can be dangerous and chroot permissions will be broken as well.
if [[ "$EUID" == 0 ]]; then
echo "Do not run this tool as root, building as root can cause problems."
exit 1
fi
# Start the manager
if [[ "$1" == "${MANAGE_ARG}" && ! -z "$2" ]]; then
CHROOT_PATH="$(absolute_path "$2")" || error_exit "Unable to get absolute path for the chroot jail."
while true; do
read -p "mkjail> " answer
answ_array=(${answer}) # TODO: Find a better way to split by space.
case "${answ_array[0]}" in
exit) break ;;
help)
cat <<EOF
exit - Leave jail manager.
fixperms - Sets the right permissions for the chroot jail.
breakperms - Owns the contents of the chroot as the current user. ONLY FOR TESTING.
pwd - Prints the currently selected jail.
clear - Clears the terminal.
EOF
;;
fixperms)
cat <<EOF
Setting permissions. You might be asked for your password.
WARNING: Setting permissions will cause packages that are installed by bashpm to become readonly. This means it will no longer be possible to reinstall those utilities without being root, but they will keep functioning.
Press Control-C if you don't want to fix permissions.
EOF
fixperms "${CHROOT_PATH}"
exitcode="$?"
if [[ "${exitcode}" != 0 ]]; then
echo "Unable to set permissions: ${exitcode}";
fi ;;
breakperms)
echo "Breaking permissions. You might be asked for your password."
sh <<EOC
set -x -e
sudo chown -R 0:0 "${CHROOT_PATH}"
sudo chown -R ${OWNER_UID}:20 "${CHROOT_PATH}/"*
exit &> /dev/null
EOC
exitcode="$?"
if [[ "${exitcode}" != 0 ]]; then
echo "Unable to break permissions: ${exitcode}";
fi ;;
pwd) echo "${CHROOT_PATH}" ;;
clear) clear ;;
*)
if [[ ! -z "${answer// }" ]]; then
echo "$0: ${answer}: command not found"
fi ;;
esac
done
exit 0
elif [[ "$1" == "${MANAGE_ARG}" && -z "$2" ]]; then
error_exit "No jail_name given."
fi
absolute_path "$1"
if [[ $? != 0 ]]; then
echo "Creating a new folder at $1"
mkdir "$1" &> /dev/null || error_exit "Unable to create $1"
absolute_path "$1" || error_exit "Unable to get absolute path for $1"
else error_exit "Refusing to turn an existing directory into a chroot jail."; fi
echo "Removing the newly created folder..."
CHROOT_PATH="$(absolute_path "$1")"
rm -rf "${CHROOT_PATH}"
# Check for dependencies
for dependency in "${SCRIPT_DEPENDS[@]}"
do
printf "${dependency}... "
type "${dependency}" &> /dev/null
if [[ $? != 0 ]]; then
printf "not available\n"
error_exit "E: ${dependency} is required for this script."
else printf "$(type -P ${dependency})\n"
fi
done
printf "brew... "
type "brew" &> /dev/null
if [[ $? == 0 ]]; then
printf "$(type -P brew)\nW: Extra libraries that are installed with homebrew can cause the programs installed inside the jail to not start.\n"
else printf "not available (this is good)\n"
fi
# Check for xcode command line tools by running a few commands
printf "Checking for command line tools... "
for cmd_to_check in "${COMMANDS_TO_CHECK[@]}"
do
${cmd_to_check} &> /dev/null
CMD_EXIT_CODE=$?
if [[ ${CMD_EXIT_CODE} != 0 ]]; then
printf "not installed\n"
echo "E: Xcode command line tools aren't installed. Run this script after installing them."
xcode-select --install
exit 1
fi
done
printf "installed\n"
# Check for extra utilities
j=0
ttb=0
if [[ "$2" == "${EXTRA_UTIL_ARG}" ]]; then
for param in "$@"
do
if [[ ${param} == "${EXTRA_UTIL_ARG}" && ${j} == 0 ]]; then j=1;
elif [[ ${j} == 1 ]]; then
k=0
for extra_util in "${EXTRAS_TO_BUILD[@]}"
do
if [[ "${extra_util}" == "${param}" ]]; then
EXTRAS[${k}]=1
EXTRAS_AVAILABLE=1
if [[ "${param}" == "${EXTRAS_TO_BUILD[11]}" ]]; then
echo "WARNING: BashPM is not really useful at the moment. You need to manually create files for every package, defeating half of the point of a package manager. You have 5 seconds to press Control-C if you want to cancel the jail creation."
sleep 5
echo "Dependencies will also be installed: xz, tar, grep, curl"
EXTRAS[3]=1 # grep
EXTRAS[6]=1 # tar
EXTRAS[8]=1 # xz
EXTRAS[9]=1 # curl
fi
elif [[ "${param}" == "all" ]]; then
echo "Selecting every extra utility"
v=0
EXTRAS_AVAILABLE=1
for unused_var in "${EXTRAS_TO_BUILD[@]}"
do
EXTRAS[${v}]=1
((v++))
done
break
elif [[ "${param}" == "${THREADING_ARG}" ]]; then ttb=1; break; fi
((k++))
done
if [[ "${ttb}" == 1 ]]; then break;
elif [[ ${EXTRAS_AVAILABLE} == 0 ]]; then
error_exit "Unknown utility: ${param}"
fi
fi
done
elif [[ "$2" == "${BASIC_ARG}" ]]; then
for unusedvar in "${EXTRAS_TO_BUILD[@]}"
do
EXTRAS[${j}]=0
((j++))
done
fi
if [[ "${#@}" -gt 2 ]]; then
last_two_args=("${@: -2:1}" "${@: -1}")
# Check if threading argument is passed and if the next argument is an integer
if [[ "${last_two_args[0]}" == "${THREADING_ARG}" ]] && [ "${last_two_args[1]}" -eq "${last_two_args[1]}" ]; then
MAKE_ARGS="${MAKE_ARGS} -j${last_two_args[1]}"
echo "${last_two_args[1]} threads will be used."
fi
fi
# Make temporary directory for this script
rm -rf '.tmpmkjailsh10'
mkdir '.tmpmkjailsh10' || error_exit "E: Unable to create temporary directory."
TEMP_DIR="$(absolute_path ".tmpmkjailsh10")"
cd '.tmpmkjailsh10'
# Download the source code tarballs for the following utilities:
# GNU bash
# GNU coreutils
# GNU inetutils
cd "${TEMP_DIR}"
sh -c "set -e;\
cd \"$(pwd -P)\";\
curl \"${THING_LINKS[2]}\" --output coreutils.tar.xz; \
curl \"${THING_LINKS[0]}\" --output bash.tar.gz; \
curl \"${THING_LINKS[1]}\" --output inetutils.tar.xz;" || error_exit "E: Unable to download the source code tarballs from GNU FTP."
# Create the chroot jail
mkdir "${CHROOT_PATH}"
# Create the chroot tree
pushd "${CHROOT_PATH}"
echo "Creating chroot tree..."
mkdir Applications bin dev etc sbin tmp Users usr var include lib share libexec System Library
mkdir Applications/Utilities Users/Shared usr/bin usr/include usr/lib usr/libexec usr/local usr/sbin usr/share var/db var/folders var/root var/run var/tmp System/Library
mkdir System/Library/Frameworks System/Library/PrivateFrameworks usr/lib/closure usr/lib/system usr/local/opt
# .${HOME} = ./Users/username
mkdir ".${HOME}" || mkdir "Users/$(whoami)" || echo "W: Unable to create home folder."
echo "Adding dyld..."
cp /usr/lib/dyld usr/lib/dyld || error_exit "E: Unable to copy dyld. dyld is required. Without it, it's not possible to run binaries in a macOS jail."
popd
# Download the extras and build them.
cd "${TEMP_DIR}"
if [[ ${EXTRAS_AVAILABLE} == 1 ]]; then
j=0
for util_name in "${EXTRAS_TO_BUILD[@]}"
do
if [[ ${EXTRAS[${j}]} == 1 ]]; then
echo "Downloading ${util_name}..."
extension=".tar.xz"
tar_arg="-xf"
if [[ ${EXTRA_LINK_TYPE[${j}]} == 1 ]]; then
extension=".tar.gz"
tar_arg="-xzf"
fi
if [[ ${EXTRA_LINK_TYPE[${j}]} == 2 ]]; then
error_exit "E: Git functionality not implemented. Unable to compile ${util_name}.";
elif [[ ${EXTRA_LINK_TYPE[${j}]} == 3 ]]; then
sh -c "set -e; \
cd \"$(pwd -P)\"; \
curl \"${EXTRA_LINKS[${j}]}\" --output \"${util_name}.tar\"; " || error_exit "E: Unable to download ${util_name}."
elif [[ ${EXTRA_LINK_TYPE[${j}]} == 4 ]]; then
if [[ "${util_name}" != "bashpm" ]]; then error_exit "E: Something is really wrong. You were about to install ${util_name} with the BashPM method."; fi
sh -c "set -e; \
cd \"$(pwd -P)\"; \
curl \"${EXTRA_LINKS[${j}]}\" --output \"bashpm.sh\"; \
mv bashpm.sh bashpm; \
chmod +x bashpm;" || error_exit "E: Unable to download BashPM."
else
sh -c "set -e; \
cd \"$(pwd -P)\"; \
curl \"${EXTRA_LINKS[${j}]}\" --output \"${util_name}${extension}\"; \
tar ${tar_arg} \"${util_name}${extension}\"; \
mv \"${util_name}-\"* \"${util_name}_src\"; \
mkdir \"${util_name}_build\"; \
cd \"${util_name}_build\"; \
\"../${util_name}_src/configure\" --prefix=\"${CHROOT_PATH}${INSTALL_EXTRAS_TO}\"${CONFIGURE_FLAGS[${j}]}; \
make${MAKE_ARGS};" || error_exit "E: Unable to compile ${util_name}."
fi
fi
((j++))
done
fi
# Extract the tarballs
cd "${TEMP_DIR}"
echo "Extracting the source code files..."
mkdir bash_build coreutils_build inetutils_build
sh -c "set -e;\
cd \"$(pwd -P)\";\
tar -xzf bash.tar.gz;\
tar -xf coreutils.tar.xz;\
tar -xf inetutils.tar.xz;" || error_exit "E: Unable to extract the tarballs."
mv bash-4.4.18 bash_src
mv inetutils-1.9.4 inetutils_src
mv coreutils-8.30 coreutils_src
j=0
for thing in "${THINGS_TO_BUILD[@]}"
do
echo "Building ${thing}..."
sh -c "set -e; \
cd \"$(pwd -P)\"; \
cd \"${thing}_build\"; \
\"../${thing}_src/configure\" --prefix=\"${CHROOT_PATH}\"; \
make${MAKE_ARGS};"
if [[ $? != 0 ]]; then
if [[ ${OPTIONAL[${j}]} == 1 ]]; then
echo "W: Couldn't build ${thing}. Continuing anyway."
else
error_exit "E: Unable to build ${thing}, but it is required. Exiting."
fi
fi
((j++))
done
set -e
echo "Installing utilities..."
j=0
for thing in "${THINGS_TO_BUILD[@]}"
do
echo "Installing ${thing} inside the chroot jail..."
OLD_WD="$(pwd -P)"
cd "${TEMP_DIR}/${thing}_build" || true
if [[ OLD_WD != "$(pwd -P)" ]]; then
if [[ ${OPTIONAL[${j}]} == 1 ]]; then
make install || true
else
make install
fi
else
echo "E: Unable to change directory, please report this."
echo "I: Unable to access \${TEMP_DIR}/${thing}_build"
exit 1
fi
((j++))
done
cd "${TEMP_DIR}"
if [[ ${EXTRAS_AVAILABLE} == 1 ]]; then
j=0
for util_name in "${EXTRAS_TO_BUILD[@]}"
do
if [[ ${EXTRAS[${j}]} == 1 && ${EXTRA_LINK_TYPE[${j}]} < 2 ]]; then
echo "Installing ${util_name} inside the chroot jail..."
sh -c "set -e; \
cd \"$(pwd -P)\"; \
cd \"${util_name}_build\"; \
make install;" || error_exit "E: Unable to install ${util_name}."
elif [[ ${EXTRAS[${j}]} == 1 && ${EXTRA_LINK_TYPE[${j}]} == 3 ]]; then
echo "Unpacking ${util_name} to chroot jail..."
sh -c "set -e; \
cd \"$(pwd -P)\"; \
tar -xvf \"${util_name}.tar\" -C \"${CHROOT_PATH}\"; " || error_exit "E: Unable to install ${util_name}."
if [[ ${j} == 9 ]]; then # Special case for cURL
cp -r "/System/Library/Frameworks/CoreFoundation.framework" "${CHROOT_PATH}/System/Library/Frameworks/CoreFoundation.framework"
fi
elif [[ ${EXTRAS[${j}]} == 1 && ${EXTRA_LINK_TYPE[${j}]} == 4 ]]; then
echo "Installing BashPM and creating bashpm.d..."
sh -c "set -e; \
cd \"$(pwd -P)\"; \
cp bashpm \"${CHROOT_PATH}/usr/bin/bashpm\"; \
mkdir \"${CHROOT_PATH}/usr/bin/bashpm.d\";
mkdir \"${CHROOT_PATH}/usr/bin/bashpm.d/tmp\" \"${CHROOT_PATH}/usr/bin/bashpm.d/packages\"; " || error_exit "E: BashPM installation failed. I don't recommend retrying for now, it's not ready."
fi
((j++))
done
fi
echo "Copying libraries..."
q=0
for curr_lib in "${DYLIBS_TO_COPY[@]}"
do
cp "/usr/lib/${curr_lib}" "${CHROOT_PATH}/usr/lib/${curr_lib}" || [[ "${DYLIB_NREQ[${q}]}" == "1" ]]
((q++))
done
for file in "${OTHER_FILES_TO_COPY[@]}"
do
cp "${file}" "${CHROOT_PATH}${file}" || true
done
echo "Copying some useful utilities from the host system..."
for ext_bin in "${EXTRA_BINARIES[@]}"
do
cp -v "${ext_bin}" "${CHROOT_PATH}${ext_bin}" || true
done
printf "\nAttempting to create character files. You might be asked for your password.\n"
sudo bash <<EOF
MKNOD_NAME=("null" "zero" "random" "urandom")
MKNOD_MAJOR=(3 3 14 14)
MKNOD_MINOR=(2 3 0 1)
p=0
for filename in "\${MKNOD_NAME[@]}"
do
mknod "${CHROOT_PATH}/dev/\${filename}" c "\${MKNOD_MAJOR[\${p}]}" "\${MKNOD_MINOR[\${p}]}"
done
true
EOF
# This folder is needed for the programs to get information about the terminal, and fixes a few programs.
echo "Copying terminfo folder..."
cp -r "/usr/share/terminfo" "${CHROOT_PATH}/usr/share/terminfo"
# Copy every file (not folders) inside /usr/lib/system to the chroot jail
cp /usr/lib/system/* "${CHROOT_PATH}/usr/lib/system/" || true
echo "Setting permissions. You might be asked for your password."
fixperms "${CHROOT_PATH}"
echo "Cleaning up..."
cd "${CHROOT_PATH}"
rm -rf "${TEMP_DIR}" || echo "W: Unable to remove the temporary folder \"${TEMP_DIR}\"."
echo "The jail was created succesfully. To chroot into the created directory, run the following command:"
echo "\$ sudo chroot -u $(whoami) \"${CHROOT_PATH}\" /bin/bash"