Compare commits
57 Commits
568c80a05e
...
modularize
| Author | SHA1 | Date | |
|---|---|---|---|
|
2ebb72620b
|
|||
|
25afed7541
|
|||
|
b8b5918feb
|
|||
|
fd177fa071
|
|||
|
aaa209a056
|
|||
|
38dc3ab73a
|
|||
|
3c8719450d
|
|||
|
e8c745a307
|
|||
|
00324dfb5d
|
|||
|
e03ff714a7
|
|||
|
6e1670ac6a
|
|||
|
3e233de780
|
|||
|
b57734ddbb
|
|||
|
e78d63fee7
|
|||
|
ee2967c522
|
|||
|
023c12cb8e
|
|||
|
d1bbf9889b
|
|||
|
e3428baed2
|
|||
|
1e378f8fe1
|
|||
|
56b4fbd596
|
|||
|
7e9c59750b
|
|||
|
f7cdd0c419
|
|||
|
8b892d207d
|
|||
|
8d3c013539
|
|||
|
a6abd9e365
|
|||
|
a09f66e4a7
|
|||
|
f41eb46966
|
|||
|
df9a67caea
|
|||
|
2b1a2f29ee
|
|||
|
3e7a7a5788
|
|||
|
9a32510698
|
|||
|
d186c475b0
|
|||
|
90fefb094e
|
|||
|
dff8209e31
|
|||
|
a4f6ea6f9c
|
|||
|
86e9244590
|
|||
|
e1b75419c9
|
|||
|
8347198afe
|
|||
|
5c3cd838a9
|
|||
|
9b90ca2273
|
|||
|
e952c663ad
|
|||
|
0b562b0ccf
|
|||
|
99f90d47c8
|
|||
|
74f884f7a0
|
|||
|
fd1a033bd9
|
|||
|
44c7813b22
|
|||
|
13f87e00dd
|
|||
|
07caef3f2c
|
|||
|
7ea1035154
|
|||
|
781a2a9143
|
|||
|
79d53e948b
|
|||
|
0609f35f91
|
|||
|
db6c05fbe3
|
|||
|
b6c2455aaa
|
|||
|
feb638b9f1
|
|||
|
4d223b8815
|
|||
|
a918ccf2e7
|
14
README.md
14
README.md
@@ -6,13 +6,13 @@ The purpose of this branch is to modularize as many functions of the scripts as
|
|||||||
|
|
||||||
## Checklist
|
## Checklist
|
||||||
[X] Rename all `base-` scripts to remove `base-`
|
[X] Rename all `base-` scripts to remove `base-`
|
||||||
[ ] Move (at least almost) all Debian related commands and tasks to `debian.sh`
|
[X] Move (at least almost) all Debian related commands and tasks to `debian.sh`
|
||||||
[ ] Move (at least almost) all Fedora related commands and tasks to `fedora.sh`
|
[X] Move (at least almost) all Fedora related commands and tasks to `fedora.sh`
|
||||||
[ ] Move (at least almost) all elementary OS related commands and tasks to `elementary.sh`
|
[X] Move (at least almost) all elementary OS related commands and tasks to `elementary.sh`
|
||||||
[ ] Rename flags in all distro specific scripts from numbered (i.e. `-1`, `-2`) to descriptive (i.e. `--mmdebstrap`, `--network-interfaces`)
|
[X] Rename flags in all distro specific scripts from numbered (i.e. `-1`, `-2`) to descriptive (i.e. `--mmdebstrap`, `--network-interfaces`)
|
||||||
[X] Move all EFI related commands and tasks to a new `efi.sh` script
|
[X] Move all EFI related commands and tasks to a new `efi.sh` script
|
||||||
[X] Rename `mkfs.zfs.sh` to `zfs.sh`
|
[X] Rename `mkfs.zfs.sh` to `zfs.sh`
|
||||||
[ ] Point any distro-specific commands/tasks that are shared with Debian to use `debian.sh` to avoid any unnecessary duplication
|
[X] Point any distro-specific commands/tasks that are shared with Debian to use `debian.sh` to avoid any unnecessary duplication
|
||||||
[ ] Rewrite `README.md`
|
[ ] Rewrite `README.md`
|
||||||
[ ] Rename all script-specific variables to lowercase with singular capital letters to seperate words in variable name
|
[X] Rename all script-specific variables to lowercase with singular capital letters to seperate words in variable name
|
||||||
[ ] Update how `baseDir` is set using `realpath $(basedir "${0}")`
|
[X] Update how `baseDir` is set using `realpath $(dirname "${0}")`
|
||||||
|
|||||||
52
adduser.sh
Executable file
52
adduser.sh
Executable file
@@ -0,0 +1,52 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
baseDir="$(realpath "$(dirname "${0}")")"
|
||||||
|
|
||||||
|
source \
|
||||||
|
/etc/os-release
|
||||||
|
source \
|
||||||
|
"${baseDir}/system.conf"
|
||||||
|
|
||||||
|
|
||||||
|
printf \
|
||||||
|
'Adding user account...\n'
|
||||||
|
|
||||||
|
adduser ${username}
|
||||||
|
|
||||||
|
if [[ "${ID}" == 'fedora' ]]; then
|
||||||
|
printf \
|
||||||
|
'\033[?47h\033[2J\033[H'
|
||||||
|
|
||||||
|
cat << EOF
|
||||||
|
|
||||||
|
Enter a password for the new user account:
|
||||||
|
EOF
|
||||||
|
passwd \
|
||||||
|
${username}
|
||||||
|
|
||||||
|
printf \
|
||||||
|
'\033[?47l'
|
||||||
|
|
||||||
|
usermod \
|
||||||
|
-a \
|
||||||
|
-G \
|
||||||
|
audio,cdrom,dip,floppy,wheel,video,dialout \
|
||||||
|
${username}
|
||||||
|
else
|
||||||
|
if [[ -z "$(cat /etc/group | grep 'lpadmin')" ]]; then
|
||||||
|
groupadd --gid 108 lpadmin
|
||||||
|
fi
|
||||||
|
|
||||||
|
groups='audio,cdrom,dip,floppy,plugdev,sudo,video,dialout,lpadmin'
|
||||||
|
|
||||||
|
if [[ "${ID}" == 'debian' ]]; then
|
||||||
|
groups+=',netdev'
|
||||||
|
fi
|
||||||
|
|
||||||
|
usermod \
|
||||||
|
-a \
|
||||||
|
-G \
|
||||||
|
${groups} \
|
||||||
|
${username}
|
||||||
|
fi
|
||||||
28
apt-snapshot.sh
Executable file
28
apt-snapshot.sh
Executable file
@@ -0,0 +1,28 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
|
||||||
|
cat << EOF | tee /usr/bin/zfs-system-snapshot-apt &> /dev/null
|
||||||
|
#!/bin/bash
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
|
||||||
|
TIMESTAMP="\$(date +%Y_%m_%d-%H_%M_%S)"
|
||||||
|
|
||||||
|
|
||||||
|
if [[ -z "\$(zfs list -t snapshot | grep 'apt-\${TIMESTAMP}')" ]]; then
|
||||||
|
zfs snapshot \$(zfs mount | grep 'ROOT' | sed 's| .*||')@apt-\${TIMESTAMP} && printf "\n- Snapshot taken\n\n"
|
||||||
|
fi
|
||||||
|
EOF
|
||||||
|
|
||||||
|
chmod \
|
||||||
|
+x \
|
||||||
|
/usr/bin/zfs-system-snapshot-apt
|
||||||
|
|
||||||
|
printf \
|
||||||
|
'DPkg::Pre-Install-Pkgs {"/usr/bin/zfs-system-snapshot-apt";};\n' | \
|
||||||
|
tee /etc/apt/apt.conf.d/90-zfs_system-snapshot &> /dev/null
|
||||||
|
|
||||||
|
printf \
|
||||||
|
'DPkg::Post-Invoke {"apt moo";};\n' | \
|
||||||
|
tee /etc/apt/apt.conf.d/99-apt_moo &> /dev/null
|
||||||
22
boilerplate.sh
Executable file
22
boilerplate.sh
Executable file
@@ -0,0 +1,22 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
baseDir="$(realpath "$(dirname "${0}")")"
|
||||||
|
|
||||||
|
|
||||||
|
printf "Enter name of new script (without file extension):\n${baseDir}/"
|
||||||
|
read -r newScript
|
||||||
|
|
||||||
|
cat << EOF | tee "${baseDir}/${newScript}.sh" &> /dev/null
|
||||||
|
#!/bin/bash
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
baseDir="\$(realpath "\$(dirname "\${0}")")"
|
||||||
|
|
||||||
|
source \\
|
||||||
|
/etc/os-release
|
||||||
|
source \\
|
||||||
|
"\${baseDir}/system.conf"
|
||||||
|
EOF
|
||||||
|
|
||||||
|
chmod +x "${baseDir}/${newScript}.sh"
|
||||||
71
debian.sh
71
debian.sh
@@ -10,7 +10,7 @@ source \
|
|||||||
|
|
||||||
|
|
||||||
if [[ "${1}" == '--live' ]]; then
|
if [[ "${1}" == '--live' ]]; then
|
||||||
if [[ ! "$(hostname)" == "debian-live" ]]; then
|
if [[ "${ID}" == 'debian' ]] && [[ ! "$(hostname)" == "debian-live" ]]; then
|
||||||
cat << EOF | tee /etc/apt/sources.list.d/contrib.sources 1> /dev/null
|
cat << EOF | tee /etc/apt/sources.list.d/contrib.sources 1> /dev/null
|
||||||
Enabled: yes
|
Enabled: yes
|
||||||
Types: deb
|
Types: deb
|
||||||
@@ -27,11 +27,15 @@ EOF
|
|||||||
--yes \
|
--yes \
|
||||||
mmdebstrap \
|
mmdebstrap \
|
||||||
gdisk \
|
gdisk \
|
||||||
|
linux-headers-generic \
|
||||||
systemd-timesyncd \
|
systemd-timesyncd \
|
||||||
whois \
|
whois \
|
||||||
zfsutils-linux
|
zfsutils-linux
|
||||||
elif [[ "${1}" == '--mmdebstrap' ]]; then
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--mmdebstrap' ]]; then
|
||||||
packages=(\
|
packages=(\
|
||||||
|
ca-certificates \
|
||||||
console-setup \
|
console-setup \
|
||||||
cryptsetup \
|
cryptsetup \
|
||||||
curl \
|
curl \
|
||||||
@@ -49,6 +53,8 @@ network-manager \
|
|||||||
openssh-{client,server} \
|
openssh-{client,server} \
|
||||||
popularity-contest \
|
popularity-contest \
|
||||||
printer-driver-all \
|
printer-driver-all \
|
||||||
|
rsync \
|
||||||
|
sudo \
|
||||||
systemd-timesyncd \
|
systemd-timesyncd \
|
||||||
tasksel \
|
tasksel \
|
||||||
zfs-initramfs \
|
zfs-initramfs \
|
||||||
@@ -69,7 +75,9 @@ zstd\
|
|||||||
${include} \
|
${include} \
|
||||||
"${VERSION_CODENAME}" \
|
"${VERSION_CODENAME}" \
|
||||||
/mnt
|
/mnt
|
||||||
elif [[ "${1}" == '--network-interfaces' ]]; then
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--network-interfaces' ]]; then
|
||||||
networkInterface=($(ip -br addr show | sed 's| .*$||g' | grep -v '^lo' | grep -v 'tailscale' | grep -v '^wg'))
|
networkInterface=($(ip -br addr show | sed 's| .*$||g' | grep -v '^lo' | grep -v 'tailscale' | grep -v '^wg'))
|
||||||
shopt -s extglob
|
shopt -s extglob
|
||||||
|
|
||||||
@@ -79,7 +87,9 @@ allow-hotplug ${networkInterface[$i]}
|
|||||||
iface ${networkInterface[$i]} inet dhcp
|
iface ${networkInterface[$i]} inet dhcp
|
||||||
EOF
|
EOF
|
||||||
done
|
done
|
||||||
elif [[ "${1}" == '--sources' ]]; then
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--sources' ]]; then
|
||||||
cat << EOF | tee /mnt/etc/apt/sources.list.d/${VERSION_CODENAME}.sources &> /dev/null
|
cat << EOF | tee /mnt/etc/apt/sources.list.d/${VERSION_CODENAME}.sources &> /dev/null
|
||||||
# ${VERSION_CODENAME^}
|
# ${VERSION_CODENAME^}
|
||||||
Enabled: yes
|
Enabled: yes
|
||||||
@@ -107,7 +117,9 @@ Signed-By: /usr/share/keyrings/debian-archive-keyring.gpg
|
|||||||
EOF
|
EOF
|
||||||
|
|
||||||
rm /mnt/etc/apt/sources.list
|
rm /mnt/etc/apt/sources.list
|
||||||
elif [[ "${1}" == '--dpkg-reconfigure' ]]; then
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--dpkg-reconfigure' ]]; then
|
||||||
cat << EOF
|
cat << EOF
|
||||||
|
|
||||||
Regardless of the language(s) you choose, be sure to enable 'en_US.UTF-8'!
|
Regardless of the language(s) you choose, be sure to enable 'en_US.UTF-8'!
|
||||||
@@ -121,12 +133,16 @@ EOF
|
|||||||
tzdata \
|
tzdata \
|
||||||
keyboard-configuration \
|
keyboard-configuration \
|
||||||
console-setup
|
console-setup
|
||||||
elif [[ "${1}" == '--purge-os-prober' ]]; then
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--purge-os-prober' ]]; then
|
||||||
apt \
|
apt \
|
||||||
purge \
|
purge \
|
||||||
--yes \
|
--yes \
|
||||||
os-prober
|
os-prober
|
||||||
elif [[ "${1}" == '--network-manager' ]]; then
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--network-manager' ]]; then
|
||||||
cp \
|
cp \
|
||||||
/etc/NetworkManager/NetworkManager.conf \
|
/etc/NetworkManager/NetworkManager.conf \
|
||||||
/etc/NetworkManager/NetworkManager.conf.orig
|
/etc/NetworkManager/NetworkManager.conf.orig
|
||||||
@@ -135,7 +151,9 @@ elif [[ "${1}" == '--network-manager' ]]; then
|
|||||||
/etc/NetworkManager/NetworkManager.conf.orig | \
|
/etc/NetworkManager/NetworkManager.conf.orig | \
|
||||||
sed 's|managed=false|managed=true|' | \
|
sed 's|managed=false|managed=true|' | \
|
||||||
tee /etc/NetworkManager/NetworkManager.conf &> /dev/null
|
tee /etc/NetworkManager/NetworkManager.conf &> /dev/null
|
||||||
elif [[ "${1}" == '--contrib' ]]; then
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--contrib' ]]; then
|
||||||
cat << EOF | tee --append /etc/apt/sources.list.d/${VERSION_CODENAME}.sources &> /dev/null
|
cat << EOF | tee --append /etc/apt/sources.list.d/${VERSION_CODENAME}.sources &> /dev/null
|
||||||
|
|
||||||
# ${VERSION_CODENAME^} Backports
|
# ${VERSION_CODENAME^} Backports
|
||||||
@@ -165,7 +183,9 @@ Pin: release n=${VERSION_CODENAME}-backports
|
|||||||
Pin-Priority: -1
|
Pin-Priority: -1
|
||||||
EOF
|
EOF
|
||||||
fi
|
fi
|
||||||
elif [[ "${1}" == '--tasksel' ]]; then
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--tasksel' ]]; then
|
||||||
if [[ ! -f /usr/bin/tasksel ]]; then
|
if [[ ! -f /usr/bin/tasksel ]]; then
|
||||||
apt \
|
apt \
|
||||||
--update \
|
--update \
|
||||||
@@ -177,3 +197,36 @@ elif [[ "${1}" == '--tasksel' ]]; then
|
|||||||
tasksel \
|
tasksel \
|
||||||
--new-install
|
--new-install
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--initramfs' ]]; then
|
||||||
|
printf \
|
||||||
|
"UMASK=0077\n" | \
|
||||||
|
tee /etc/initramfs-tools/conf.d/umask.conf &> /dev/null
|
||||||
|
|
||||||
|
update-initramfs \
|
||||||
|
-c \
|
||||||
|
-k all
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--logrotate' ]]; then
|
||||||
|
for file in /etc/logrotate.d/* ; do
|
||||||
|
if grep -Eq "(^|[^#y])compress" "$file" ; then
|
||||||
|
sed -i -r "s/(^|[^#y])(compress)/\1#\2/" "$file"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--systemctl-enable' ]]; then
|
||||||
|
systemctl \
|
||||||
|
enable \
|
||||||
|
zfs.target
|
||||||
|
systemctl \
|
||||||
|
enable \
|
||||||
|
zfs-import-cache
|
||||||
|
systemctl \
|
||||||
|
enable \
|
||||||
|
zfs-mount
|
||||||
|
systemctl \
|
||||||
|
enable \
|
||||||
|
zfs-import.target
|
||||||
|
fi
|
||||||
|
|||||||
2
efi.sh
Normal file → Executable file
2
efi.sh
Normal file → Executable file
@@ -2,7 +2,7 @@
|
|||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
|
|
||||||
baseDir="$(realpath "$(basename "${0}")")"
|
baseDir="$(realpath "$(dirname "${0}")")"
|
||||||
|
|
||||||
|
|
||||||
source \
|
source \
|
||||||
|
|||||||
100
elementary.sh
100
elementary.sh
@@ -26,6 +26,7 @@ nano \
|
|||||||
network-manager \
|
network-manager \
|
||||||
openssh-{client,server} \
|
openssh-{client,server} \
|
||||||
popularity-contest \
|
popularity-contest \
|
||||||
|
rsync \
|
||||||
zfs-initramfs \
|
zfs-initramfs \
|
||||||
zstd\
|
zstd\
|
||||||
)
|
)
|
||||||
@@ -44,7 +45,9 @@ zstd\
|
|||||||
${include} \
|
${include} \
|
||||||
"${UBUNTU_VERSION_CODENAME}" \
|
"${UBUNTU_VERSION_CODENAME}" \
|
||||||
/mnt
|
/mnt
|
||||||
elif [[ "${1}" == '--sources' ]]; then
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--sources' ]]; then
|
||||||
cat <<EOF >/mnt/etc/apt/sources.list.d/${UBUNTU_VERSION_CODENAME}.sources
|
cat <<EOF >/mnt/etc/apt/sources.list.d/${UBUNTU_VERSION_CODENAME}.sources
|
||||||
# ${UBUNTU_VERSION_CODENAME^}
|
# ${UBUNTU_VERSION_CODENAME^}
|
||||||
Enabled: yes
|
Enabled: yes
|
||||||
@@ -90,11 +93,15 @@ Signed-By: /etc/apt/trusted.gpg.d/patches.key.asc
|
|||||||
EOF
|
EOF
|
||||||
|
|
||||||
rm /mnt/etc/apt/sources.list
|
rm /mnt/etc/apt/sources.list
|
||||||
elif [[ "${1}" == '--skel' ]]; then
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--skel' ]]; then
|
||||||
rsync -pogAXtlHrDx \
|
rsync -pogAXtlHrDx \
|
||||||
/etc/skel \
|
/etc/skel \
|
||||||
/mnt/etc
|
/mnt/etc
|
||||||
elif [[ "${1}" == '--elementary' ]]; then
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--elementary' ]]; then
|
||||||
cp \
|
cp \
|
||||||
/etc/os-release \
|
/etc/os-release \
|
||||||
/mnt/etc
|
/mnt/etc
|
||||||
@@ -103,3 +110,90 @@ elif [[ "${1}" == '--elementary' ]]; then
|
|||||||
/etc/apt/trusted.gpg.d/{elementary,patches}.key.asc \
|
/etc/apt/trusted.gpg.d/{elementary,patches}.key.asc \
|
||||||
/mnt/etc/apt/trusted.gpg.d/
|
/mnt/etc/apt/trusted.gpg.d/
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--network' ]]; then
|
||||||
|
mkdir \
|
||||||
|
-p \
|
||||||
|
/mnt/run/systemd/resolve/
|
||||||
|
|
||||||
|
mount \
|
||||||
|
--bind \
|
||||||
|
/run/systemd/resolve/ \
|
||||||
|
/mnt/run/systemd/resolve/
|
||||||
|
|
||||||
|
touch \
|
||||||
|
/mnt/etc/NetworkManager/conf.d/10-globally-managed-devices.conf
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--apps' ]]; then
|
||||||
|
app=(\
|
||||||
|
io.elementary.calculator \
|
||||||
|
io.elementary.camera \
|
||||||
|
io.elementary.capnet-assist \
|
||||||
|
io.elementary.maps \
|
||||||
|
io.elementary.music \
|
||||||
|
io.elementary.screenshot \
|
||||||
|
io.elementary.videos \
|
||||||
|
org.gnome.Epiphany \
|
||||||
|
org.gnome.Evince \
|
||||||
|
org.gnome.FileRoller \
|
||||||
|
org.gnome.font-viewer\
|
||||||
|
)
|
||||||
|
|
||||||
|
apps="app/${app[0]}/x86_64/stable"
|
||||||
|
|
||||||
|
for ((i=1;i<${#app[@]};i++)); do
|
||||||
|
apps+=" app/${app[${i}]}/x86_64/stable"
|
||||||
|
done
|
||||||
|
|
||||||
|
flatpak \
|
||||||
|
install \
|
||||||
|
appcenter \
|
||||||
|
-y \
|
||||||
|
${apps}
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--purge' ]]; then
|
||||||
|
apt \
|
||||||
|
purge \
|
||||||
|
--yes \
|
||||||
|
--autoremove \
|
||||||
|
gnome-software \
|
||||||
|
snapd
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--desktop' ]]; then
|
||||||
|
apt \
|
||||||
|
install \
|
||||||
|
--yes \
|
||||||
|
elementary-desktop
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--namarupa' ]]; then
|
||||||
|
curl \
|
||||||
|
--progress \
|
||||||
|
--location \
|
||||||
|
--remote-name \
|
||||||
|
--continue-at - \
|
||||||
|
--output-dir '/tmp' \
|
||||||
|
'https://github.com/lenemter/wingpanel-indicator-namarupa/raw/main/com.github.lenemter.wingpanel-indicator-namarupa.deb'
|
||||||
|
|
||||||
|
apt \
|
||||||
|
--update \
|
||||||
|
install \
|
||||||
|
--yes \
|
||||||
|
'/tmp/com.github.lenemter.wingpanel-indicator-namarupa.deb'
|
||||||
|
|
||||||
|
mkdir \
|
||||||
|
-p \
|
||||||
|
/home/${username}/.config/autostart
|
||||||
|
|
||||||
|
cp \
|
||||||
|
/etc/xdg/autostart/indicator-application.desktop \
|
||||||
|
/home/${username}/.config/autostart/
|
||||||
|
|
||||||
|
sed \
|
||||||
|
-i \
|
||||||
|
's/^OnlyShowIn.*/OnlyShowIn=Unity;GNOME;Pantheon;/' \
|
||||||
|
/home/${username}/.config/autostart/indicator-application.desktop
|
||||||
|
fi
|
||||||
|
|||||||
74
fedora.sh
74
fedora.sh
@@ -35,7 +35,9 @@ if [[ "${1}" == '--live' ]]; then
|
|||||||
|
|
||||||
modprobe \
|
modprobe \
|
||||||
zfs
|
zfs
|
||||||
elif [[ "${1}" == '--rsync' ]]; then
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--rsync' ]]; then
|
||||||
mkdir -p /run/install
|
mkdir -p /run/install
|
||||||
|
|
||||||
if [[ "${VERSION_ID}" -lt '41' ]]; then
|
if [[ "${VERSION_ID}" -lt '41' ]]; then
|
||||||
@@ -50,13 +52,77 @@ elif [[ "${1}" == '--rsync' ]]; then
|
|||||||
--exclude=/etc/machine-id \
|
--exclude=/etc/machine-id \
|
||||||
--info=progress2 \
|
--info=progress2 \
|
||||||
/run/install/ /mnt
|
/run/install/ /mnt
|
||||||
elif [[ "${1}" == '--resolv-conf' ]]; then
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--resolv-conf' ]]; then
|
||||||
mv /mnt/etc/resolv.conf \
|
mv /mnt/etc/resolv.conf \
|
||||||
/mnt/etc/resolv.conf.orig
|
/mnt/etc/resolv.conf.orig
|
||||||
|
|
||||||
cp -L \
|
cp -L \
|
||||||
/etc/resolv.conf \
|
/etc/resolv.conf \
|
||||||
/mnt/etc
|
/mnt/etc
|
||||||
elif [[ "${1}" == '-3' ]]; then
|
fi
|
||||||
#
|
|
||||||
|
if [[ "${1}" == '--dracut' ]]; then
|
||||||
|
dracut \
|
||||||
|
--force \
|
||||||
|
--regenerate-all
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--zfs-install' ]]; then
|
||||||
|
if [[ "${encryption}" == 'yes' ]]; then
|
||||||
|
cat << EOF | tee /etc/dracut.conf.d/zol.conf &> /dev/null
|
||||||
|
nofsck="yes"
|
||||||
|
add_dracutmodules+=" zfs "
|
||||||
|
omit_dracutmodules+=" btrfs "
|
||||||
|
install_items+=" /etc/zfs/keys/${hostname,,}.key "
|
||||||
|
EOF
|
||||||
|
else
|
||||||
|
cat <<EOF >/etc/dracut.conf.d/zol.conf
|
||||||
|
nofsck="yes"
|
||||||
|
add_dracutmodules+=" zfs "
|
||||||
|
omit_dracutmodules+=" btrfs "
|
||||||
|
EOF
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "${VERSION_ID}" -lt '41' ]]; then
|
||||||
|
dnf \
|
||||||
|
config-manager \
|
||||||
|
--disable \
|
||||||
|
updates
|
||||||
|
else
|
||||||
|
dnf \
|
||||||
|
config-manager \
|
||||||
|
setopt \
|
||||||
|
updates.enabled=0
|
||||||
|
fi
|
||||||
|
|
||||||
|
dnf \
|
||||||
|
install \
|
||||||
|
-y \
|
||||||
|
https://dl.fedoraproject.org/pub/fedora/linux/releases/${VERSION_ID}/Everything/x86_64/os/Packages/k/kernel-devel-$(uname -r).rpm
|
||||||
|
|
||||||
|
dnf \
|
||||||
|
--releasever=${VERSION_ID} \
|
||||||
|
install \
|
||||||
|
-y \
|
||||||
|
https://zfsonlinux.org/fedora/zfs-release-${ZOL_FEDORA_VER}$(rpm --eval "%{dist}").noarch.rpm
|
||||||
|
|
||||||
|
dnf \
|
||||||
|
install \
|
||||||
|
-y \
|
||||||
|
zfs \
|
||||||
|
zfs-dracut
|
||||||
|
|
||||||
|
if [[ "${VERSION_ID}" -lt '41' ]]; then
|
||||||
|
dnf \
|
||||||
|
config-manager \
|
||||||
|
--enable \
|
||||||
|
updates
|
||||||
|
else
|
||||||
|
dnf \
|
||||||
|
config-manager \
|
||||||
|
setopt \
|
||||||
|
updates.enabled=1
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
|
|
||||||
BASEDIR="$(dirname "${0}" | sed "s|^\.|${PWD}|")"
|
baseDir="$(realpath "$(dirname "${0}")")"
|
||||||
|
|
||||||
|
|
||||||
printf '\033[?47l\012'
|
printf '\033[?47l\012'
|
||||||
|
|||||||
2
home-fix-setup.sh
Normal file → Executable file
2
home-fix-setup.sh
Normal file → Executable file
@@ -44,7 +44,7 @@ if [[ "${ID}" == 'fedora' ]]; then
|
|||||||
printf \
|
printf \
|
||||||
"@reboot\tsudo -u ${username} '${baseDir}/finalize.sh'\n@reboot\t/usr/bin/home-fix.sh\n" | \
|
"@reboot\tsudo -u ${username} '${baseDir}/finalize.sh'\n@reboot\t/usr/bin/home-fix.sh\n" | \
|
||||||
tee /var/spool/cron/root &> /dev/null
|
tee /var/spool/cron/root &> /dev/null
|
||||||
elif [[ "${ID}" == 'debian' ]]; then
|
elif [[ "${ID}" == 'debian' ]] || [[ "${ID}" == 'elementary' ]]; then
|
||||||
printf \
|
printf \
|
||||||
"@reboot\tsudo -u ${username} '${baseDir}/finalize.sh'\n@reboot\t/usr/bin/home-fix.sh\n" | \
|
"@reboot\tsudo -u ${username} '${baseDir}/finalize.sh'\n@reboot\t/usr/bin/home-fix.sh\n" | \
|
||||||
tee /var/spool/cron/crontabs/root &> /dev/null
|
tee /var/spool/cron/crontabs/root &> /dev/null
|
||||||
|
|||||||
0
host-id.sh
Normal file → Executable file
0
host-id.sh
Normal file → Executable file
6
hostname.sh
Normal file → Executable file
6
hostname.sh
Normal file → Executable file
@@ -2,6 +2,12 @@
|
|||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
|
|
||||||
|
baseDir="$(realpath "$(dirname "${0}")")"
|
||||||
|
|
||||||
|
source \
|
||||||
|
"${baseDir}/system.conf"
|
||||||
|
|
||||||
|
|
||||||
printf \
|
printf \
|
||||||
"${hostname}\n" | tee /mnt/etc/hostname &> /dev/null
|
"${hostname}\n" | tee /mnt/etc/hostname &> /dev/null
|
||||||
|
|
||||||
|
|||||||
142
install.sh
142
install.sh
@@ -1,7 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
baseDir="$(dirname "${0}" | sed "s|^\.|${PWD}|")"
|
baseDir="$(realpath "$(dirname "${0}")")"
|
||||||
|
|
||||||
printf \
|
printf \
|
||||||
'\033[?47l\012'
|
'\033[?47l\012'
|
||||||
@@ -29,103 +29,34 @@ source \
|
|||||||
source \
|
source \
|
||||||
"${baseDir}/system.conf"
|
"${baseDir}/system.conf"
|
||||||
|
|
||||||
if [[ ! "${disk}" == **/dev/disk/by-id/** ]]; then
|
|
||||||
if [[ "${disk}" == **/dev/nvme** ]]; then
|
|
||||||
part1='p1'
|
|
||||||
part2='p2'
|
|
||||||
else
|
|
||||||
part1='1'
|
|
||||||
part2='2'
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
part1='-part1'
|
|
||||||
part2='-part2'
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ ! -f "/etc/mtab" ]]; then
|
if [[ ! -f "/etc/mtab" ]]; then
|
||||||
"${baseDir}/mtab.sh"
|
"${baseDir}/mtab.sh"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ "${ID}" == 'debian' ]] || [[ "${ID}" == 'elementary' ]]; then
|
|
||||||
apt \
|
|
||||||
update
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ "${ID}" == 'fedora' ]]; then
|
if [[ "${ID}" == 'fedora' ]]; then
|
||||||
if [[ "${ENCRYPTION}" == 'yes' ]]; then
|
"${baseDir}/fedora.sh" --zfs-install
|
||||||
cat << EOF | tee /etc/dracut.conf.d/zol.conf &> /dev/null
|
|
||||||
nofsck="yes"
|
|
||||||
add_dracutmodules+=" zfs "
|
|
||||||
omit_dracutmodules+=" btrfs "
|
|
||||||
install_items+=" /etc/zfs/keys/${hostname,,}.key "
|
|
||||||
EOF
|
|
||||||
else
|
|
||||||
cat <<EOF >/etc/dracut.conf.d/zol.conf
|
|
||||||
nofsck="yes"
|
|
||||||
add_dracutmodules+=" zfs "
|
|
||||||
omit_dracutmodules+=" btrfs "
|
|
||||||
EOF
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ "${VERSION_ID}" -lt '41' ]]; then
|
|
||||||
dnf \
|
|
||||||
config-manager \
|
|
||||||
--disable \
|
|
||||||
updates
|
|
||||||
else
|
|
||||||
dnf \
|
|
||||||
config-manager \
|
|
||||||
setopt \
|
|
||||||
updates.enabled=0
|
|
||||||
fi
|
|
||||||
|
|
||||||
dnf \
|
|
||||||
install \
|
|
||||||
-y \
|
|
||||||
https://dl.fedoraproject.org/pub/fedora/linux/releases/${VERSION_ID}/Everything/x86_64/os/Packages/k/kernel-devel-$(uname -r).rpm
|
|
||||||
|
|
||||||
dnf \
|
|
||||||
--releasever=${VERSION_ID} \
|
|
||||||
install \
|
|
||||||
-y \
|
|
||||||
https://zfsonlinux.org/fedora/zfs-release-${ZOL_FEDORA_VER}$(rpm --eval "%{dist}").noarch.rpm
|
|
||||||
|
|
||||||
dnf \
|
|
||||||
install \
|
|
||||||
-y \
|
|
||||||
zfs \
|
|
||||||
zfs-dracut
|
|
||||||
|
|
||||||
if [[ "${VERSION_ID}" -lt '41' ]]; then
|
|
||||||
dnf \
|
|
||||||
config-manager \
|
|
||||||
--enable \
|
|
||||||
updates
|
|
||||||
else
|
|
||||||
dnf \
|
|
||||||
config-manager \
|
|
||||||
setopt \
|
|
||||||
updates.enabled=1
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ "${ID}" == 'debian' ]] || [[ "${ID}" == 'elementary' ]]; then
|
if [[ "${ID}" == 'debian' ]] || [[ "${ID}" == 'elementary' ]]; then
|
||||||
"${baseDir}/debian.sh" --dpkg-reconfigure
|
"${baseDir}/debian.sh" --dpkg-reconfigure
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# if [[ "${ID}" == 'debian' ]]; then
|
|
||||||
# printf \
|
|
||||||
# 'REMAKE_INITRD=yes\n' | \
|
|
||||||
# tee /etc/dkms/zfs.conf &> /dev/null
|
|
||||||
# fi
|
|
||||||
|
|
||||||
if [[ ! "${*}" = *--no-part* ]]; then
|
|
||||||
"${baseDir}/partition.sh" --efi
|
"${baseDir}/partition.sh" --efi
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ "${ID}" == 'debian' ]] || [[ "${ID}" == 'elementary' ]]; then
|
if [[ "${ID}" == 'debian' ]] || [[ "${ID}" == 'elementary' ]]; then
|
||||||
|
if [[ -e '/usr/bin/os-prober' ]]; then
|
||||||
"${baseDir}/debian.sh" --purge-os-prober
|
"${baseDir}/debian.sh" --purge-os-prober
|
||||||
fi
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "${ID}" == 'elementary' ]]; then
|
||||||
|
"${baseDir}/elementary.sh" --desktop
|
||||||
|
|
||||||
|
"${baseDir}/elementary.sh" --purge
|
||||||
|
|
||||||
|
"${baseDir}/elementary.sh" --apps
|
||||||
|
fi
|
||||||
|
|
||||||
printf \
|
printf \
|
||||||
'\033[?47h\033[2J\033[H'
|
'\033[?47h\033[2J\033[H'
|
||||||
@@ -140,65 +71,28 @@ passwd
|
|||||||
printf \
|
printf \
|
||||||
'\033[?47l'
|
'\033[?47l'
|
||||||
|
|
||||||
if [[ "${enableSwap}" == "yes" ]]; then
|
"${baseDir}/swap.sh"
|
||||||
printf \
|
|
||||||
"swap\t${disk}${part2}\t/dev/random\tswap,cipher=aes-xts-plain64,size=512\n" | \
|
|
||||||
tee /etc/crypttab &> /dev/null
|
|
||||||
|
|
||||||
printf \
|
|
||||||
'dev/mapper/swap\tnone\tswap\tsw\t0\t0\n' | \
|
|
||||||
tee --append /etc/fstab &> /dev/null
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ "${ID}" == 'debian' ]]; then
|
if [[ "${ID}" == 'debian' ]]; then
|
||||||
"${baseDir}/debian.sh" --network-manager
|
"${baseDir}/debian.sh" --network-manager
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ "${ID}" == 'debian' ]] || [[ "${ID}" == 'elementary' ]]; then
|
if [[ "${ID}" == 'debian' ]] || [[ "${ID}" == 'elementary' ]]; then
|
||||||
printf \
|
"${baseDir}/debian.sh" --initramfs
|
||||||
"UMASK=0077\n" | \
|
|
||||||
tee /etc/initramfs-tools/conf.d/umask.conf &> /dev/null
|
|
||||||
|
|
||||||
update-initramfs \
|
|
||||||
-c \
|
|
||||||
-k all
|
|
||||||
elif [[ "${ID}" == 'fedora' ]]; then
|
elif [[ "${ID}" == 'fedora' ]]; then
|
||||||
dracut \
|
"${baseDir}/fedora.sh" --dracut
|
||||||
--force \
|
|
||||||
--regenerate-all
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
zfs \
|
"${baseDir}/zfs.sh" --splash
|
||||||
set \
|
|
||||||
org.zfsbootmenu:commandline='quiet splash rhgb noresume' \
|
|
||||||
${hostname,,}/ROOT/${ID}
|
|
||||||
|
|
||||||
if [[ ! "${*}" = *--no-part* ]]; then
|
|
||||||
if [[ ! -z "$(zfs list | grep 'keystore')" ]]; then
|
if [[ ! -z "$(zfs list | grep 'keystore')" ]]; then
|
||||||
zfs \
|
"${baseDir}/zfs.sh" --keystore
|
||||||
set \
|
|
||||||
org.zfsbootmenu:keysource=${hostname,,}/keystore \
|
|
||||||
${hostname,,}
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ ! "${*}" = *--no-part* ]]; then
|
|
||||||
"${baseDir}/efi.sh"
|
"${baseDir}/efi.sh"
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ "${ID}" == 'debian' ]] || [[ "${ID}" == 'elementary' ]]; then
|
if [[ "${ID}" == 'debian' ]] || [[ "${ID}" == 'elementary' ]]; then
|
||||||
systemctl \
|
"${baseDir}/debian.sh" --systemctl-enable
|
||||||
enable \
|
|
||||||
zfs.target
|
|
||||||
systemctl \
|
|
||||||
enable \
|
|
||||||
zfs-import-cache
|
|
||||||
systemctl \
|
|
||||||
enable \
|
|
||||||
zfs-mount
|
|
||||||
systemctl \
|
|
||||||
enable \
|
|
||||||
zfs-import.target
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
zfs \
|
zfs \
|
||||||
|
|||||||
16
list.sh
16
list.sh
@@ -2,18 +2,18 @@
|
|||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
|
|
||||||
BASEDIR="$(dirname "${0}" | sed "s|^\.|${PWD}|")"
|
baseDir="$(realpath "$(dirname "${0}")")"
|
||||||
|
|
||||||
|
|
||||||
DISKS_BY_ID="$(ls -Ago /dev/disk/by-id/ | grep -v 'sr' | grep -v 'dm-' | grep -v 'nvme-eui.' | grep -v '\-part' | grep -v 'wwn-' | grep -v '_[1-9] -> ' | grep -v 'total' | sed -e 's|^.*\:[0-5][0-9] ||g')"
|
disksById="$(ls -Ago /dev/disk/by-id/ | grep -v 'sr' | grep -v 'dm-' | grep -v 'nvme-eui.' | grep -v '\-part' | grep -v 'wwn-' | grep -v '_[1-9] -> ' | grep -v 'total' | sed -e 's|^.*\:[0-5][0-9] ||g')"
|
||||||
DISKS="$(lsblk -do name | grep -v 'loop' | grep -v 'sr' | grep -v 'zram' | grep -v 'NAME')"
|
disks="$(lsblk -do name | grep -v 'loop' | grep -v 'sr' | grep -v 'zram' | grep -v 'NAME')"
|
||||||
NETWORK_INTERFACES="$(ip -br addr show | sed -e 's| .*$||g' | grep -v '^lo' | grep -v 'tailscale' | grep -v '^wg')"
|
networkInterfaces="$(ip -br addr show | sed -e 's| .*$||g' | grep -v '^lo' | grep -v 'tailscale' | grep -v '^wg')"
|
||||||
|
|
||||||
|
|
||||||
cat << EOF
|
cat << EOF
|
||||||
#######################################
|
#######################################
|
||||||
## ##
|
## ##
|
||||||
## $(cat "${BASEDIR}/title") Script ##
|
## $(cat "${baseDir}/title") Script ##
|
||||||
## ##
|
## ##
|
||||||
## Jean <jean@easthighnerd.net> ##
|
## Jean <jean@easthighnerd.net> ##
|
||||||
## ##
|
## ##
|
||||||
@@ -34,13 +34,13 @@ EOF
|
|||||||
cat << EOF
|
cat << EOF
|
||||||
|
|
||||||
Available disks (/dev/disk/by-id/):
|
Available disks (/dev/disk/by-id/):
|
||||||
${DISKS_BY_ID}
|
${disksById}
|
||||||
|
|
||||||
Available disks (/dev/):
|
Available disks (/dev/):
|
||||||
${DISKS}
|
${disks}
|
||||||
|
|
||||||
Available network interfaces:
|
Available network interfaces:
|
||||||
${NETWORK_INTERFACES}
|
${networkInterfaces}
|
||||||
|
|
||||||
|
|
||||||
Press any key to return to the main menu
|
Press any key to return to the main menu
|
||||||
|
|||||||
38
menu.sh
38
menu.sh
@@ -2,17 +2,17 @@
|
|||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
|
|
||||||
BASEDIR="$(dirname "${0}" | sed "s|^\.|${PWD}|")"
|
baseDir="$(realpath "$(dirname "${0}")")"
|
||||||
OPTION='start'
|
option='start'
|
||||||
|
|
||||||
|
|
||||||
while [[ ! "${OPTION}" == 'Exit' ]]; do
|
while [[ ! "${option}" == 'Exit' ]]; do
|
||||||
printf '\033[?47h\033[2J\033[H'
|
printf '\033[?47h\033[2J\033[H'
|
||||||
|
|
||||||
cat << EOF
|
cat << EOF
|
||||||
#######################################
|
#######################################
|
||||||
## ##
|
## ##
|
||||||
## $(cat "${BASEDIR}/title") Script ##
|
## $(cat "${baseDir}/title") Script ##
|
||||||
## ##
|
## ##
|
||||||
## Jean <jean@easthighnerd.net> ##
|
## Jean <jean@easthighnerd.net> ##
|
||||||
## ##
|
## ##
|
||||||
@@ -26,10 +26,10 @@ while [[ ! "${OPTION}" == 'Exit' ]]; do
|
|||||||
#################
|
#################
|
||||||
|
|
||||||
EOF
|
EOF
|
||||||
select OPTION in 'List' 'Configure' 'Pre Install' 'Install' 'WiFi Setup' 'Post Install' 'Finalize' 'Exit'
|
select option in 'List' 'Configure' 'Install' 'Finalize' 'WiFi Setup' 'Exit'
|
||||||
do
|
do
|
||||||
case "${OPTION}" in
|
case "${option}" in
|
||||||
'List'|'Configure'|'Pre Install'|'Install'|'WiFi Setup'|'Post Install'|'Finalize'|'Exit')
|
'List'|'Configure'|'Install'|'Finalize'|'WiFi Setup'|'Exit')
|
||||||
break
|
break
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
@@ -40,20 +40,16 @@ EOF
|
|||||||
|
|
||||||
printf '\033[2J\033[H'
|
printf '\033[2J\033[H'
|
||||||
|
|
||||||
if [[ "${OPTION}" == 'List' ]]; then
|
if [[ "${option}" == 'List' ]]; then
|
||||||
"${BASEDIR}/list.sh"
|
"${baseDir}/list.sh"
|
||||||
elif [[ "${OPTION}" == 'Configure' ]]; then
|
elif [[ "${option}" == 'Configure' ]]; then
|
||||||
"${BASEDIR}/configure.sh"
|
"${baseDir}/configure.sh"
|
||||||
elif [[ "${OPTION}" == 'Pre Install' ]]; then
|
elif [[ "${option}" == 'Install' ]]; then
|
||||||
"${BASEDIR}/pre-inst.sh"
|
"${baseDir}/pre-inst.sh"
|
||||||
elif [[ "${OPTION}" == 'Install' ]]; then
|
elif [[ "${option}" == 'Finalize' ]]; then
|
||||||
"${BASEDIR}/install.sh"
|
"${baseDir}/finalize.sh"
|
||||||
elif [[ "${OPTION}" == 'WiFi Setup' ]]; then
|
elif [[ "${option}" == 'WiFi Setup' ]]; then
|
||||||
"${BASEDIR}/wifi.sh"
|
"${baseDir}/wifi.sh"
|
||||||
elif [[ "${OPTION}" == 'Post Install' ]]; then
|
|
||||||
"${BASEDIR}/post-inst.sh"
|
|
||||||
elif [[ "${OPTION}" == 'Finalize' ]]; then
|
|
||||||
"${BASEDIR}/finalize.sh"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
printf '\033[?47h\033[2J\033[H'
|
printf '\033[?47h\033[2J\033[H'
|
||||||
|
|||||||
0
mkdir-tmpfs.sh
Normal file → Executable file
0
mkdir-tmpfs.sh
Normal file → Executable file
28
mount.sh
Executable file
28
mount.sh
Executable file
@@ -0,0 +1,28 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
|
||||||
|
mount \
|
||||||
|
--types proc \
|
||||||
|
proc \
|
||||||
|
/mnt/proc
|
||||||
|
|
||||||
|
mount \
|
||||||
|
--types sysfs \
|
||||||
|
sys \
|
||||||
|
/mnt/sys
|
||||||
|
|
||||||
|
mount \
|
||||||
|
--bind \
|
||||||
|
/dev \
|
||||||
|
/mnt/dev
|
||||||
|
|
||||||
|
mount \
|
||||||
|
--types devpts \
|
||||||
|
pts \
|
||||||
|
/mnt/dev/pts
|
||||||
|
|
||||||
|
mount \
|
||||||
|
--types efivarfs \
|
||||||
|
efivarfs \
|
||||||
|
/mnt/sys/firmware/efi/efivars
|
||||||
23
partition.sh
23
partition.sh
@@ -1,13 +1,15 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
BASEDIR="$(dirname "${0}" | sed "s|^\.|${PWD}|")"
|
baseDir="$(realpath "$(dirname "${0}")")"
|
||||||
|
|
||||||
source \
|
source \
|
||||||
/etc/os-release
|
/etc/os-release
|
||||||
source \
|
source \
|
||||||
"${BASEDIR}/system.conf"
|
"${baseDir}/system.conf"
|
||||||
|
|
||||||
|
|
||||||
|
if [[ "${1}" == '--disk' ]]; then
|
||||||
if [[ ! "${disk}" == **/dev/disk/by-id/** ]]; then
|
if [[ ! "${disk}" == **/dev/disk/by-id/** ]]; then
|
||||||
if [[ "${disk}" == **/dev/nvme** ]]; then
|
if [[ "${disk}" == **/dev/nvme** ]]; then
|
||||||
part3='p3'
|
part3='p3'
|
||||||
@@ -44,8 +46,8 @@ sgdisk \
|
|||||||
if [[ "${enableSwap}" == "yes" ]]; then
|
if [[ "${enableSwap}" == "yes" ]]; then
|
||||||
swapSize="$(((($(vmstat -sS M | grep 'total memory' | sed 's/ M total memory//') / 1024) + 1) * 2))"
|
swapSize="$(((($(vmstat -sS M | grep 'total memory' | sed 's/ M total memory//') / 1024) + 1) * 2))"
|
||||||
|
|
||||||
if [[ "${swapSize#}" -gt '32' ]]; then
|
if [[ "${swapSize#}" -gt '16' ]]; then
|
||||||
swapSize='32'
|
swapSize='16'
|
||||||
fi
|
fi
|
||||||
|
|
||||||
sgdisk \
|
sgdisk \
|
||||||
@@ -60,8 +62,19 @@ sgdisk \
|
|||||||
-t3:BF00 \
|
-t3:BF00 \
|
||||||
-c3:${ID} \
|
-c3:${ID} \
|
||||||
${disk}
|
${disk}
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--efi' ]]; then
|
||||||
|
if [[ ! "${disk}" == **/dev/disk/by-id/** ]]; then
|
||||||
|
if [[ "${disk}" == **/dev/nvme** ]]; then
|
||||||
|
part1='p1'
|
||||||
|
else
|
||||||
|
part1='1'
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
part1='-part1'
|
||||||
|
fi
|
||||||
|
|
||||||
if [[ "${*}" == *--efi* ]]; then
|
|
||||||
mkdosfs \
|
mkdosfs \
|
||||||
-F 32 \
|
-F 32 \
|
||||||
-s 1 \
|
-s 1 \
|
||||||
|
|||||||
128
post-inst.sh
128
post-inst.sh
@@ -33,148 +33,34 @@ cat << EOF
|
|||||||
EOF
|
EOF
|
||||||
|
|
||||||
|
|
||||||
source \
|
"${baseDir}/zfs.sh" --home
|
||||||
/etc/os-release
|
|
||||||
|
|
||||||
source \
|
"${baseDir}/adduser.sh"
|
||||||
"${baseDir}/system.conf"
|
|
||||||
|
|
||||||
|
|
||||||
# if [[ ! "${*}" = *--no-part* ]]; then
|
|
||||||
zfs create\
|
|
||||||
${hostname,,}/home/${username}
|
|
||||||
|
|
||||||
zfs create\
|
|
||||||
${hostname,,}/home/${username}/.config
|
|
||||||
|
|
||||||
zfs create\
|
|
||||||
-o canmount=off\
|
|
||||||
${hostname,,}/home/${username}/.var
|
|
||||||
|
|
||||||
zfs create\
|
|
||||||
${hostname,,}/home/${username}/.var/app
|
|
||||||
|
|
||||||
zfs create\
|
|
||||||
-o canmount=off\
|
|
||||||
${hostname,,}/home/${username}/.local
|
|
||||||
|
|
||||||
zfs create\
|
|
||||||
-o canmount=off\
|
|
||||||
${hostname,,}/home/${username}/.local/share
|
|
||||||
|
|
||||||
zfs create\
|
|
||||||
${hostname,,}/home/${username}/.local/share/flatpak
|
|
||||||
|
|
||||||
printf \
|
|
||||||
'Adding user account...\n'
|
|
||||||
|
|
||||||
adduser ${username}
|
|
||||||
# else
|
|
||||||
# adduser --no-create-home ${username}
|
|
||||||
# fi
|
|
||||||
|
|
||||||
if [[ "${ID}" == 'fedora' ]]; then
|
|
||||||
printf \
|
|
||||||
'\033[?47h\033[2J\033[H'
|
|
||||||
|
|
||||||
cat << EOF
|
|
||||||
|
|
||||||
Enter a password for the new user account:
|
|
||||||
EOF
|
|
||||||
passwd \
|
|
||||||
${username}
|
|
||||||
|
|
||||||
printf \
|
|
||||||
'\033[?47l'
|
|
||||||
|
|
||||||
usermod \
|
|
||||||
-a \
|
|
||||||
-G \
|
|
||||||
audio,cdrom,dip,floppy,wheel,video,dialout \
|
|
||||||
${username}
|
|
||||||
else
|
|
||||||
if [[ -z "$(cat /etc/group | grep 'lpadmin')" ]]; then
|
|
||||||
groupadd --gid 108 lpadmin
|
|
||||||
fi
|
|
||||||
|
|
||||||
usermod \
|
|
||||||
-a \
|
|
||||||
-G \
|
|
||||||
audio,cdrom,dip,floppy,netdev,plugdev,sudo,video,dialout,lpadmin \
|
|
||||||
${username}
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ "${ID}" == 'elementary' ]]; then
|
if [[ "${ID}" == 'elementary' ]]; then
|
||||||
cat << EOF > /etc/apt/sources.list.d/backports.list
|
"${baseDir}/elementary.sh" --namarupa
|
||||||
deb http://archive.ubuntu.com/ubuntu/ ${UBUNTU_VERSION_CODENAME}-backports main restricted universe multiverse
|
|
||||||
deb-src http://archive.ubuntu.com/ubuntu/ ${UBUNTU_VERSION_CODENAME}-backports main restricted universe multiverse
|
|
||||||
EOF
|
|
||||||
|
|
||||||
cat << EOF > /etc/apt/preferences.d/backports.pref
|
|
||||||
Package: *
|
|
||||||
Pin: release n=${UBUNTU_VERSION_CODENAME}*
|
|
||||||
Pin-Priority: 990
|
|
||||||
|
|
||||||
Package: linux* /wayland/
|
|
||||||
Pin: release n=${UBUNTU_VERSION_CODENAME}-backports
|
|
||||||
Pin-Priority: -1
|
|
||||||
EOF
|
|
||||||
elif [[ "${ID}" == 'debian' ]]; then
|
elif [[ "${ID}" == 'debian' ]]; then
|
||||||
"${baseDir}/debian.sh" --contrib
|
"${baseDir}/debian.sh" --contrib
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ "${ID}" == 'debian' ]] || [[ "${ID}" == 'elementary' ]]; then
|
if [[ "${ID}" == 'debian' ]] || [[ "${ID}" == 'elementary' ]]; then
|
||||||
apt \
|
apt \
|
||||||
|
--update \
|
||||||
dist-upgrade \
|
dist-upgrade \
|
||||||
--yes
|
--yes
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ "${ID}" == 'elementary' ]]; then
|
if [[ "${ID}" = 'debian' ]]; then
|
||||||
apt \
|
|
||||||
install \
|
|
||||||
--yes \
|
|
||||||
--autoremove \
|
|
||||||
elementary-desktop
|
|
||||||
elif [[ "${ID}" = 'debian' ]]; then
|
|
||||||
"${baseDir}/debian.sh" --tasksel
|
"${baseDir}/debian.sh" --tasksel
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ "${ID}" == 'debian' ]] || [[ "${ID}" == 'elementary' ]]; then
|
if [[ "${ID}" == 'debian' ]] || [[ "${ID}" == 'elementary' ]]; then
|
||||||
for file in /etc/logrotate.d/* ; do
|
"${baseDir}/debian.sh" --logrotate
|
||||||
if grep -Eq "(^|[^#y])compress" "$file" ; then
|
|
||||||
sed -i -r "s/(^|[^#y])(compress)/\1#\2/" "$file"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
cat << EOF | tee /usr/bin/zfs-system-snapshot-apt &> /dev/null
|
"${baseDir}/apt-snapshot.sh"
|
||||||
#!/bin/bash
|
|
||||||
set -euo pipefail
|
|
||||||
|
|
||||||
|
|
||||||
TIMESTAMP="\$(date +%Y_%m_%d-%H_%M_%S)"
|
|
||||||
|
|
||||||
|
|
||||||
if [[ -z "\$(zfs list -t snapshot | grep 'apt-\${TIMESTAMP}')" ]]; then
|
|
||||||
zfs snapshot \$(zfs mount | grep 'ROOT' | sed 's| .*||')@apt-\${TIMESTAMP} && printf "\n- Snapshot taken\n\n"
|
|
||||||
fi
|
|
||||||
EOF
|
|
||||||
|
|
||||||
chmod \
|
|
||||||
+x \
|
|
||||||
/usr/bin/zfs-system-snapshot-apt
|
|
||||||
|
|
||||||
printf \
|
|
||||||
'DPkg::Pre-Install-Pkgs {"/usr/bin/zfs-system-snapshot-apt";};\n' | \
|
|
||||||
tee /etc/apt/apt.conf.d/90-zfs_system-snapshot &> /dev/null
|
|
||||||
|
|
||||||
printf \
|
|
||||||
'DPkg::Post-Invoke {"apt moo";};\n' | \
|
|
||||||
tee /etc/apt/apt.conf.d/99-apt_moo &> /dev/null
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# if [[ ! "${*}" = *--no-part* ]]; then
|
|
||||||
"${baseDir}/home-fix-setup.sh"
|
"${baseDir}/home-fix-setup.sh"
|
||||||
# fi
|
|
||||||
|
|
||||||
if [[ ! -f '/usr/bin/shutdown' ]]; then
|
if [[ ! -f '/usr/bin/shutdown' ]]; then
|
||||||
ln -s /sbin/shutdown /usr/bin/shutdown
|
ln -s /sbin/shutdown /usr/bin/shutdown
|
||||||
|
|||||||
12
pre-inst.sh
12
pre-inst.sh
@@ -52,11 +52,13 @@ if [[ ! "$(hostname)" == "debian-live" ]]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
"${baseDir}/partition.sh"
|
"${baseDir}/partition.sh" --disk
|
||||||
|
|
||||||
sleep 5
|
sleep 5
|
||||||
|
|
||||||
"${baseDir}/zfs.sh"
|
"${baseDir}/zfs.sh" --format
|
||||||
|
|
||||||
|
"${baseDir}/zfs.sh" --create
|
||||||
|
|
||||||
"${baseDir}/mkdir-tmpfs.sh"
|
"${baseDir}/mkdir-tmpfs.sh"
|
||||||
|
|
||||||
@@ -72,6 +74,8 @@ fi
|
|||||||
|
|
||||||
if [[ "${ID}" == 'debian' ]]; then
|
if [[ "${ID}" == 'debian' ]]; then
|
||||||
"${baseDir}/debian.sh" --network-interfaces
|
"${baseDir}/debian.sh" --network-interfaces
|
||||||
|
elif [[ "${ID}" == 'elementary' ]]; then
|
||||||
|
"${baseDir}/elementary.sh" --network
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ "${ID}" == 'elementary' ]]; then
|
if [[ "${ID}" == 'elementary' ]]; then
|
||||||
@@ -80,7 +84,7 @@ elif [[ "${ID}" == 'debian' ]]; then
|
|||||||
"${baseDir}/debian.sh" --sources
|
"${baseDir}/debian.sh" --sources
|
||||||
fi
|
fi
|
||||||
|
|
||||||
"${baseDir}/rbind.sh"
|
"${baseDir}/mount.sh"
|
||||||
|
|
||||||
"${baseDir}/host-id.sh"
|
"${baseDir}/host-id.sh"
|
||||||
|
|
||||||
@@ -94,11 +98,9 @@ if [[ "${ID}" == 'elementary' ]]; then
|
|||||||
"${baseDir}/elementary.sh" --skel
|
"${baseDir}/elementary.sh" --skel
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# if [[ ! "${*}" = *--no-part* ]]; then
|
|
||||||
if [[ -f "/etc/zfs/keys/${hostname,,}.key" ]]; then
|
if [[ -f "/etc/zfs/keys/${hostname,,}.key" ]]; then
|
||||||
"${baseDir}/zfs.sh" --key
|
"${baseDir}/zfs.sh" --key
|
||||||
fi
|
fi
|
||||||
# fi
|
|
||||||
|
|
||||||
if [[ "${ID}" == 'elementary' ]]; then
|
if [[ "${ID}" == 'elementary' ]]; then
|
||||||
"${baseDir}/elementary.sh" --elementary
|
"${baseDir}/elementary.sh" --elementary
|
||||||
|
|||||||
29
swap.sh
Executable file
29
swap.sh
Executable file
@@ -0,0 +1,29 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
baseDir="$(realpath "$(dirname "${0}")")"
|
||||||
|
|
||||||
|
source \
|
||||||
|
"${baseDir}/system.conf"
|
||||||
|
|
||||||
|
|
||||||
|
if [[ ! "${disk}" == **/dev/disk/by-id/** ]]; then
|
||||||
|
if [[ "${disk}" == **/dev/nvme** ]]; then
|
||||||
|
part2='p2'
|
||||||
|
else
|
||||||
|
part2='2'
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
part2='-part2'
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
if [[ "${enableSwap}" == "yes" ]]; then
|
||||||
|
printf \
|
||||||
|
"swap\t${disk}${part2}\t/dev/random\tswap,cipher=aes-xts-plain64,size=512\n" | \
|
||||||
|
tee /etc/crypttab &> /dev/null
|
||||||
|
|
||||||
|
printf \
|
||||||
|
'dev/mapper/swap\tnone\tswap\tsw\t0\t0\n' | \
|
||||||
|
tee --append /etc/fstab &> /dev/null
|
||||||
|
fi
|
||||||
8
wifi.sh
8
wifi.sh
@@ -7,13 +7,13 @@ set -euo pipefail
|
|||||||
# resolvectl status | grep 'Link' | sed -e 's|^.*(||g; s|).*||g' | while read -r INTERFACE; do resolvectl dns ${INTERFACE} 9.9.9.9; done && sleep 3 && nmcli device status | grep -v 'DEVICE' | grep -v 'lo' | sed -e 's| .*||g' | while read -r INTERFACE; do nmcli device disconnect ${INTERFACE}; sleep 1; nmcli device connect ${INTERFACE}; done
|
# resolvectl status | grep 'Link' | sed -e 's|^.*(||g; s|).*||g' | while read -r INTERFACE; do resolvectl dns ${INTERFACE} 9.9.9.9; done && sleep 3 && nmcli device status | grep -v 'DEVICE' | grep -v 'lo' | sed -e 's| .*||g' | while read -r INTERFACE; do nmcli device disconnect ${INTERFACE}; sleep 1; nmcli device connect ${INTERFACE}; done
|
||||||
|
|
||||||
|
|
||||||
BASEDIR="$(dirname "${0}" | sed "s|^\.|${PWD}|")"
|
baseDir="$(realpath "$(dirname "${0}")")"
|
||||||
|
|
||||||
|
|
||||||
cat << EOF
|
cat << EOF
|
||||||
#######################################
|
#######################################
|
||||||
## ##
|
## ##
|
||||||
## $(cat "${BASEDIR}/title") Script ##
|
## $(cat "${baseDir}/title") Script ##
|
||||||
## ##
|
## ##
|
||||||
## Jean <jean@easthighnerd.net> ##
|
## Jean <jean@easthighnerd.net> ##
|
||||||
## ##
|
## ##
|
||||||
@@ -35,9 +35,9 @@ nmcli radio wifi on
|
|||||||
nmcli device wifi list
|
nmcli device wifi list
|
||||||
|
|
||||||
printf "Enter the SSID of the WiFi network you wish to connect to:\n"
|
printf "Enter the SSID of the WiFi network you wish to connect to:\n"
|
||||||
read -r WIFI_NAME
|
read -r wifiName
|
||||||
|
|
||||||
nmcli --ask device wifi connect ${WIFI_NAME}
|
nmcli --ask device wifi connect "${wifiName}"
|
||||||
|
|
||||||
cat << EOF
|
cat << EOF
|
||||||
|
|
||||||
|
|||||||
130
zfs.sh
130
zfs.sh
@@ -20,7 +20,7 @@ else
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
# if [[ ! "${*}" = *--no-part* ]]; then
|
if [[ "${1}" == '--format' ]]; then
|
||||||
if [[ "${encryption}" == 'yes' ]]; then
|
if [[ "${encryption}" == 'yes' ]]; then
|
||||||
zpoolPassword='A'
|
zpoolPassword='A'
|
||||||
zpoolPasswordVerify='B'
|
zpoolPasswordVerify='B'
|
||||||
@@ -30,14 +30,14 @@ fi
|
|||||||
|
|
||||||
while [[ ! "${zpoolPassword}" == "${zpoolPasswordVerify}" ]] || [[ -z "${zpoolPassword}" ]] || [[ "${#zpoolPassword}" -lt '8' ]]; do
|
while [[ ! "${zpoolPassword}" == "${zpoolPasswordVerify}" ]] || [[ -z "${zpoolPassword}" ]] || [[ "${#zpoolPassword}" -lt '8' ]]; do
|
||||||
printf \
|
printf \
|
||||||
"\nEnter a password to encrypt your root pool (minimum 8 characters):\n"
|
"Enter a password to encrypt your root pool (minimum 8 characters):\n"
|
||||||
read \
|
read \
|
||||||
-r \
|
-r \
|
||||||
-s \
|
-s \
|
||||||
zpoolPassword
|
zpoolPassword
|
||||||
|
|
||||||
printf \
|
printf \
|
||||||
"\nVerify the password to encrypt your root pool:\n"
|
"Verify the password to encrypt your root pool:\n"
|
||||||
read \
|
read \
|
||||||
-r \
|
-r \
|
||||||
-s \
|
-s \
|
||||||
@@ -45,13 +45,13 @@ fi
|
|||||||
|
|
||||||
if [[ ! "${zpoolPassword}" == "${zpoolPasswordVerify}" ]]; then
|
if [[ ! "${zpoolPassword}" == "${zpoolPasswordVerify}" ]]; then
|
||||||
printf \
|
printf \
|
||||||
"ERROR:\tPasswords do not match!\n"
|
"ERROR:\tPasswords do not match!\n\n"
|
||||||
elif [[ -z "${zpoolPassword}" ]]; then
|
elif [[ -z "${zpoolPassword}" ]]; then
|
||||||
printf \
|
printf \
|
||||||
"ERROR:\tPassword is empty!\n"
|
"ERROR:\tPassword is empty!\n\n"
|
||||||
elif [[ "${#zpoolPassword}" -lt '8' ]]; then
|
elif [[ "${#zpoolPassword}" -lt '8' ]]; then
|
||||||
printf \
|
printf \
|
||||||
"ERROR:\tPassword is too short!\n"
|
"ERROR:\tPassword is too short!\n\n"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
@@ -105,23 +105,13 @@ fi
|
|||||||
${hostname,,} \
|
${hostname,,} \
|
||||||
${disk}${part3}
|
${disk}${part3}
|
||||||
fi
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--create' ]]; then
|
||||||
zfs create \
|
zfs create \
|
||||||
-o canmount=off \
|
-o canmount=off \
|
||||||
-o mountpoint=none \
|
-o mountpoint=none \
|
||||||
${hostname,,}/ROOT
|
${hostname,,}/ROOT
|
||||||
# else
|
|
||||||
# zpool import \
|
|
||||||
# -N \
|
|
||||||
# -R \
|
|
||||||
# /mnt \
|
|
||||||
# ${hostname,,}
|
|
||||||
#
|
|
||||||
# zfs load-key \
|
|
||||||
# -r \
|
|
||||||
# -L prompt \
|
|
||||||
# ${hostname,,}
|
|
||||||
# fi
|
|
||||||
|
|
||||||
zfs create \
|
zfs create \
|
||||||
-o canmount=noauto \
|
-o canmount=noauto \
|
||||||
@@ -131,7 +121,6 @@ zfs create \
|
|||||||
zfs mount \
|
zfs mount \
|
||||||
${hostname,,}/ROOT/${ID}
|
${hostname,,}/ROOT/${ID}
|
||||||
|
|
||||||
# if [[ ! "${*}" = *--no-part* ]]; then
|
|
||||||
zfs create \
|
zfs create \
|
||||||
${hostname,,}/home
|
${hostname,,}/home
|
||||||
|
|
||||||
@@ -213,84 +202,77 @@ zfs mount \
|
|||||||
zpool set \
|
zpool set \
|
||||||
bootfs=${hostname,,}/ROOT/${ID} \
|
bootfs=${hostname,,}/ROOT/${ID} \
|
||||||
${hostname,,}
|
${hostname,,}
|
||||||
# else
|
|
||||||
# zfs mount \
|
|
||||||
# ${hostname,,}/home
|
|
||||||
#
|
|
||||||
# zfs mount \
|
|
||||||
# ${hostname,,}/home/root
|
|
||||||
#
|
|
||||||
# zfs mount \
|
|
||||||
# ${hostname,,}/var/log
|
|
||||||
#
|
|
||||||
# zfs mount \
|
|
||||||
# ${hostname,,}/var/spool
|
|
||||||
#
|
|
||||||
# zfs mount \
|
|
||||||
# ${hostname,,}/var/cache
|
|
||||||
#
|
|
||||||
# zfs mount \
|
|
||||||
# ${hostname,,}/var/lib/nfs
|
|
||||||
#
|
|
||||||
# zfs mount \
|
|
||||||
# ${hostname,,}/var/tmp
|
|
||||||
#
|
|
||||||
# zfs mount \
|
|
||||||
# ${hostname,,}/srv
|
|
||||||
#
|
|
||||||
# zfs mount \
|
|
||||||
# ${hostname,,}/usr/local
|
|
||||||
#
|
|
||||||
# zfs mount \
|
|
||||||
# ${hostname,,}/var/games
|
|
||||||
#
|
|
||||||
# zfs mount \
|
|
||||||
# ${hostname,,}/var/lib/AccountsService
|
|
||||||
#
|
|
||||||
# zfs mount \
|
|
||||||
# ${hostname,,}/var/lib/NetworkManager
|
|
||||||
#
|
|
||||||
# zfs mount \
|
|
||||||
# ${hostname,,}/var/www
|
|
||||||
#
|
|
||||||
# zfs mount \
|
|
||||||
# ${hostname,,}/keystore
|
|
||||||
# fi
|
|
||||||
|
|
||||||
if [[ "${ID}" == 'fedora' ]]; then
|
if [[ "${ID}" == 'fedora' ]]; then
|
||||||
"${baseDir}/fedora.sh" -1
|
"${baseDir}/fedora.sh" --rsync
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# if [[ ! "${*}" = *--no-part* ]]; then
|
|
||||||
zfs create \
|
zfs create \
|
||||||
${hostname,,}/var/mail
|
${hostname,,}/var/mail
|
||||||
|
|
||||||
chmod \
|
chmod \
|
||||||
1777 \
|
1777 \
|
||||||
/mnt/tmp
|
/mnt/tmp
|
||||||
# else
|
fi
|
||||||
# zfs mount \
|
|
||||||
# ${hostname,,}/var/mail
|
|
||||||
# fi
|
|
||||||
|
|
||||||
if [[ "${1}" == '--key' ]]; then
|
if [[ "${1}" == '--key' ]]; then
|
||||||
cp \
|
cp \
|
||||||
/etc/zfs/keys/${hostname,,}.key \
|
/etc/zfs/keys/${hostname,,}.key \
|
||||||
/mnt/etc/zfs/keys/
|
/mnt/etc/zfs/keys/
|
||||||
elif [[ "${1}" == '--unmount' ]]; then
|
fi
|
||||||
mount | grep -v zfs | tac | awk '/\/mnt/ {print $3}' | xargs -I {} umount -Rlf {}
|
|
||||||
|
|
||||||
if [[ "${ID}" == 'fedora' ]]; then
|
if [[ "${1}" == '--unmount' ]]; then
|
||||||
umount \
|
umount \
|
||||||
-nR \
|
-nR \
|
||||||
/mnt
|
/mnt
|
||||||
fi
|
|
||||||
|
|
||||||
zpool \
|
zpool \
|
||||||
export \
|
export \
|
||||||
-a
|
${hostname,,}
|
||||||
elif [[ "${1}" == '--host-id' ]]; then
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--host-id' ]]; then
|
||||||
zgenhostid \
|
zgenhostid \
|
||||||
-f \
|
-f \
|
||||||
0x00bab10c
|
0x00bab10c
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--home' ]]; then
|
||||||
|
zfs create\
|
||||||
|
${hostname,,}/home/${username}
|
||||||
|
|
||||||
|
zfs create\
|
||||||
|
${hostname,,}/home/${username}/.config
|
||||||
|
|
||||||
|
zfs create\
|
||||||
|
-o canmount=off\
|
||||||
|
${hostname,,}/home/${username}/.var
|
||||||
|
|
||||||
|
zfs create\
|
||||||
|
${hostname,,}/home/${username}/.var/app
|
||||||
|
|
||||||
|
zfs create\
|
||||||
|
-o canmount=off\
|
||||||
|
${hostname,,}/home/${username}/.local
|
||||||
|
|
||||||
|
zfs create\
|
||||||
|
-o canmount=off\
|
||||||
|
${hostname,,}/home/${username}/.local/share
|
||||||
|
|
||||||
|
zfs create\
|
||||||
|
${hostname,,}/home/${username}/.local/share/flatpak
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--keystore' ]]; then
|
||||||
|
zfs \
|
||||||
|
set \
|
||||||
|
org.zfsbootmenu:keysource=${hostname,,}/keystore \
|
||||||
|
${hostname,,}
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "${1}" == '--splash' ]]; then
|
||||||
|
zfs \
|
||||||
|
set \
|
||||||
|
org.zfsbootmenu:commandline='quiet splash rhgb noresume' \
|
||||||
|
${hostname,,}/ROOT/${ID}
|
||||||
|
fi
|
||||||
|
|||||||
Reference in New Issue
Block a user