Compare commits

..

190 Commits
master ... test

Author SHA1 Message Date
sean acf94c1c70 tweaks
7 years ago
sean fc27be9805 tweaks
7 years ago
sean 08dea28243 tweaks
7 years ago
sean 2506714ae8 tweaks
7 years ago
sean b51e5f1db5 tweaks
7 years ago
sean b09786d730 tweaks
7 years ago
sean 89977b70a4 change part2 to part1
7 years ago
sean 0a9ace0897 tweaks
7 years ago
sean 9c8c803090 tweaks
7 years ago
sean 9f9168ae6b new booting tweaks
7 years ago
sean c089338005 tweaks
7 years ago
sean 2865672f33 tweaks
7 years ago
sean 49dba6f48a tweaks
7 years ago
sean 129f6b2970 tweaks
7 years ago
sean 6706bccb92 tweaks
7 years ago
sean 624cfea8a5 tweaks
7 years ago
sean b08b102551 tweaks
7 years ago
sean 26d691a7b5 tweaks
7 years ago
sean c228adfa5c tweaks
7 years ago
sean f6d197b89e swap and basic OS
7 years ago
sean e7c202fafd tweaks
7 years ago
sean 2e5bba4fef tweaks
7 years ago
sean ed60d2c4fa tweaks
7 years ago
sean bf751b3e79 quick whiptail test
7 years ago
sean bf0f2a8945 tweaks
7 years ago
sean 22320ecd08 twaeks
7 years ago
sean 9ea1f3754b tweaks
7 years ago
sean 547ef2c399 try this version that erases stuff
7 years ago
sean 64b786598e tweaks
7 years ago
sean 08120c6022 tweaks
7 years ago
sean 3f2810e0c0 tweaks
7 years ago
sean 614c4815d9 Fixes to the installer
7 years ago
sean 124dfa2609 tweaks
7 years ago
sean 40009a0e2f tweaks
7 years ago
sean 2e5f5e5be9 tweaks
7 years ago
sean 72a6416048 tweaks
7 years ago
sean b9739f9fc8 tweaks
7 years ago
sean 5964f78755 tweaks
7 years ago
sean 521d71aabc tweaks
7 years ago
sean 88a5e6779f tweaks
7 years ago
sean 985cdf59fc tweaks
7 years ago
sean e097ca1003 tweak
7 years ago
sean 82fe1cea2b tweaks
7 years ago
sean 14aa5291fc tweaks
7 years ago
sean 14d9242f49 tweaks
7 years ago
sean 3b7417de3e tweaks
7 years ago
sean 274ce549af more tweaks
7 years ago
sean 10ce137b51 tweaks
7 years ago
sean 49aa016158 tweaks
7 years ago
sean dac9f123aa tweaks
7 years ago
sean 55afef2ada tweaks
7 years ago
sean 026fab7bfc tweaks
7 years ago
sean 341ff01a46 tweaks
7 years ago
sean 4126eb0d23 tweaks
7 years ago
sean 102f3507d9 tweaks
7 years ago
sean 837fb851c4 tweaks
7 years ago
sean 6d712ebf2d tweaks
7 years ago
sean 8fa6bfcc71 tweaks
7 years ago
sean 26d8e157a2 tweaks
7 years ago
sean cca57584f9 tweaks
7 years ago
sean 1d26b2113d tweaks
7 years ago
sean c9aed3491d tweaks
7 years ago
sean 0e2ad7847a tweaks
7 years ago
sean 1eb1a912d3 tweaks
7 years ago
sean 94de536f04 tweaks
7 years ago
sean a9fdf8d65b tweaks
7 years ago
sean 3d8c48c2dd twaeks
7 years ago
sean 9beb27fce4 tweaks
7 years ago
sean 5b29ab32ca test
7 years ago
sean 89943c4092 tweaks
7 years ago
sean 3362506cd6 domain name tweaks that might fix email
7 years ago
sean da4d00c069 tweaks
7 years ago
sean 8d83e8741f tweaks
7 years ago
sean c530d4c897 tweaks
7 years ago
sean 00cb3c9ac4 tweaks
7 years ago
sean bcd3cd6192 tweaks with ufw
7 years ago
sean 13e896fdb8 tweaks
7 years ago
sean 12c9b1e6ef tweaks
7 years ago
sean 74c23a7cd4 tweaks
7 years ago
sean 9a27129139 tweaks
7 years ago
sean fe1fa3ca71 tweaks
7 years ago
sean 9b83b389ab tweaks
7 years ago
sean 281eebf280 tweaks
7 years ago
sean aaa83b5ed0 tweaks
7 years ago
sean a679eacab8 tweaks
7 years ago
sean 81ed906d7f tweaks
7 years ago
sean 856a40b3f0 tweaks
7 years ago
sean 181806cdd3 tweaks
7 years ago
sean c266522598 tweaks
7 years ago
sean 86773da268 tweaks
7 years ago
sean 66a138da7d tweaks
7 years ago
sean a76bb31df6 tweaks
7 years ago
sean 79bb54a0ed tweaks
7 years ago
sean f1c8182874 test
7 years ago
sean 83b39edceb tweaks
7 years ago
sean 35874960e8 tweaks
7 years ago
sean 3ce1abf59a tweak test
7 years ago
sean efee43b963 tweaks
7 years ago
sean ed89525714 tweaks
7 years ago
sean a5e5808f70 tweaks
7 years ago
sean b072c25ba8 tweaks
7 years ago
sean af77235f61 tweaks
7 years ago
sean f99caea570 tweaks
7 years ago
sean ae4a906da2 tweaks
7 years ago
sean 2e799692f5 tweaks
7 years ago
sean 8fe7616b38 tweaks
7 years ago
sean 2144e4fc1c tweaks
7 years ago
sean c0137c0e73 tweaks
7 years ago
sean 4e5b347e84 tweaks
7 years ago
sean 1500c65c38 tweaks
7 years ago
sean f0135901c9 tweaks
7 years ago
sean e655a8de82 tweaks
7 years ago
sean ecf1868cd1 testing
7 years ago
sean c483ef23f2 tweaks
7 years ago
sean 2fca3e6dd4 tweaks
7 years ago
sean 0f14bed2d3 tweaks
7 years ago
sean 9981f01ceb tweaks
7 years ago
sean 1c607bd09a tweaks
7 years ago
sean cadf53b85c tweaks
7 years ago
sean 7f1fbd3039 tweaks
7 years ago
sean 5c4982b1c7 tweaks
7 years ago
sean 197bbbe770 tweaks
7 years ago
sean 7b7853ecb8 tweaks
7 years ago
sean c3c45019bc tweaks
7 years ago
sean 9289844c99 tweaks
7 years ago
sean de7b8b3acd tweaks
7 years ago
sean 9ec289c136 tweaks
7 years ago
sean 6617d2f84d tweaks
7 years ago
sean 2ba9cb07da test tweaks
7 years ago
sean fac4a088ae tweaks
7 years ago
sean 0b33dd6be9 tweaks
7 years ago
sean a3c89343ac bad line endings?
7 years ago
sean def54b1a4f tweaks
7 years ago
sean b75109612f tweaks
7 years ago
sean 9e4fc3b35c tweaks
7 years ago
sean f212017cb4 tweaks
7 years ago
sean 71c1d92ed9 tweaks
7 years ago
sean 4d4d715fc1 tweaks
7 years ago
sean ebd0d89da9 tweaks
7 years ago
sean 394b8999df tweaks
7 years ago
sean 0fc329a922 tweaks
7 years ago
sean 791c10684f tweaks
7 years ago
sean a3de013ecb tweaks
7 years ago
sean 9ceac41631 tweaks
7 years ago
sean 63656fb07a tweaks
7 years ago
sean 19281f3ee6 tweaks
7 years ago
sean 2a91f9e118 tweaks
7 years ago
sean 1579bf11e8 tweaks
7 years ago
sean a0bc8b8ed1 tweaks
7 years ago
sean 8f6ae4707d tweaks
7 years ago
sean a896b8b888 tweaks
7 years ago
sean 7c12d73eec new tweaks
7 years ago
sean 19d8d7ce33 tweaks
7 years ago
sean c8f3c3d62b Tweaks
7 years ago
sean e26290c9e8 testing
7 years ago
sean 74a71e86c4 this was the problem
7 years ago
sean 474075ff87 test tweak
7 years ago
sean 74054d9634 tweaks
7 years ago
sean 45b20879eb tweaks
7 years ago
sean 74985dfc81 tweaks
7 years ago
sean dcd2fc35eb tweaks
7 years ago
sean 422e5f71fe testing another tweak
7 years ago
sean d95da849f8 tweaks
7 years ago
sean bf368d0d25 tweaks but not really
7 years ago
sean 5e45529a0d tweaks
7 years ago
sean c58ae06775 tweaks
7 years ago
sean 386b7a00e4 tweaks
7 years ago
sean 563a7328f4 tweaks
7 years ago
sean c0ac3d7a12 irritating tweaks
7 years ago
sean 17ebeaa3f7 tweaks
7 years ago
sean 6863e39c9c test
7 years ago
sean a55e02e1e0 tweak
7 years ago
sean 27ea4b4411 tweaks
7 years ago
sean 059249eed2 tweaks and tests
7 years ago
sean c0b5434f44 tweaks
7 years ago
sean edf841a06e tweaks
7 years ago
sean dc0f7796b2 tweaks
7 years ago
sean 9438c07e25 tweaks test
7 years ago
sean f08d10d009 test tweak
7 years ago
sean f369fb70a7 tweaks
7 years ago
sean a02cf785e5 tweaks
7 years ago
sean 5e83fbf3d2 tweaks
7 years ago
sean 8ca216cae2 tweaks
7 years ago
sean 43bea157fe tweaks
7 years ago
sean 96fa360d27 tweak
7 years ago
sean 9c3bc33373 tweaks
7 years ago
sean 0d60a61c39 tweaks
7 years ago
sean 5857371570 Fixed line endings, utf8 encoding
7 years ago
sean bc0d29539d Untested - unfinished, just saving state
7 years ago
sean d4d0debe30 mods
7 years ago

@ -1,8 +1,5 @@
Server Setup Script
=====================
#Setup#
#Use#
wget -qO - https://code.totosearch.org/Sean/ServerSetup/raw/branch/master/setup.sh | sudo bash
#Maintenance#
wget -qO - https://code.totosearch.org/Sean/ServerSetup/raw/branch/master/maintenance.sh | sudo bash

@ -1,67 +0,0 @@
#! /bin/bash
echo ""
echo "Updating local packages..."
errors=`apt-add-repository universe >/dev/null 2>/dev/null && apt-get update 2>&1 >/dev/null && apt-get install -y zfs-initramfs`
if [ "$?" = "0" ]; then
echo "Done."
else
echo "Failed to add universal repository, update apt repository - $errors"
exit 1
fi
echo ""
echo "Importing boot pool and main OS pool..."
errors=$(zpool export -a 2>&1 1>/dev/null && zpool import -N -R /mnt rpool 2>&1 1>/dev/null && zpool import -N -R /mnt bpool 2>&1 1>/dev/null && zfs mount rpool/ROOT/ubuntu 2>&1 1>/dev/null)
# && zfs mount -a 2>&1 1>/dev/null
if [ "$?" = "0" ]; then
echo "Done."
else
echo "Failed to mount bpool or rpool - $errors"
exit 2
fi
echo ""
echo "Binding mounts..."
errors=`mount --rbind /dev /mnt/dev 2>&1 1>/dev/null && mount --rbind /proc /mnt/proc 2>&1 1>/dev/null && mount --rbind /sys /mnt/sys 2>&1 1>/dev/null`
if ! [ "$?" = "0" ]; then
echo "Failed to bind mounts - $errors"
exit 4
fi
echo "Done."
echo ""
echo "Entering chroot, type \"exit\" to leave..."
echo ""
echo "#!/bin/bash" > /mnt/maintenance.sh
chmod +x /mnt/maintenance.sh
echo "zfs mount -a && mount /boot" >> /mnt/maintenance.sh
echo "/bin/bash" >> /mnt/maintenance.sh
echo "umount /boot" >> /mnt/maintenance.sh
echo "zfs umount -a" >> /mnt/maintenance.sh
chroot /mnt /maintenance.sh --login < /dev/tty
rm /mnt/maintenance.sh
if ! [ "$?" = "0" ]; then
echo "Chroot failed with an error"
exit $?
fi
echo ""
echo "Unbinding mounts..."
errors=`mount | grep -v zfs | tac | awk '/\\/mnt/ {print \$3}' | xargs -i{} umount -lf \{\} 2>&1 1>/dev/null && zpool export -a 2>&1 1>/dev/null`
if ! [ "$?" = "0" ]; then
echo "Failed to unbind mounts - $errors"
exit 4
fi
echo "Done."
echo ""
exit 0

@ -2,7 +2,7 @@
echo ""
echo "Updating local packages..."
errors=`apt-add-repository universe >/dev/null 2>&1 1>/dev/null && apt update 2>&1 >/dev/null`
errors=`apt-add-repository universe >/dev/null 2>/dev/null && apt update 2>&1 >/dev/null`
if [ "$?" = "0" ]; then
echo "Done."
else
@ -58,12 +58,7 @@ swapspace=$(($swapspace * `getconf PAGESIZE`))
# 20% swap space with 2G minimum
if [ "$swapspace" -lt "2048000" ]; then swapspace="2048000" ; fi
nics=`dialog --separate-output --no-cancel --no-items --title "Bridged network devices" --checklist "Select the network devices to be bridged to bridge - select none for no bridge:" $height $width ${window}$nicdevices 2>&1 1>/dev/tty`
if [ -z "$nics" ]; then
bridgedevice=`dialog --no-cancel --no-items --title "Configure network devices" --radiolist "NO BRIDGE MODE!\nSelect the network device to configure:" $height $width ${window}$nicdevices 2>&1 1>/dev/tty`
else
bridgedevice="br0"
fi
nics=`dialog --separate-output --no-cancel --no-items --title "Bridged network devices" --checklist "Select the network devices to be bridged to br0:" $height $width ${window}$nicdevices 2>&1 1>/dev/tty`
networktype=`dialog --no-items --no-cancel --title "Network type" --radiolist "Select the network type:" 9 40 2 dhcp off static off 2>&1 1>/dev/tty`
if [ "$networktype" = "static" ]; then
address=""; while [ -z "$address" ]; do address=`dialog --no-cancel --inputbox "IP Address:" 8 40 2>&1 >/dev/tty`; done
@ -340,7 +335,7 @@ echo "cp /usr/share/zoneinfo/$timezone /etc/localtime" >> /mnt/setup-chroot.sh
echo "echo \"Done.\"" >> /mnt/setup-chroot.sh
echo "echo \"\"" >> /mnt/setup-chroot.sh
echo "echo \"Installing linux image, ifupdown, dnsutils, nfs-kernel-server, apparmor-profiles, vim, libvirt-bin, bridge-utils, net-tools, bash, screen, tmux, zfs-initramfs, dosfstools, mailutils, ssmtp, openssh-server, ufw, docker.io, sharutils...\"" >> /mnt/setup-chroot.sh
echo "echo \"Installing linux image, ifupdown dnsutils nfs-kernel-server apparmor-profiles vim, libvirt-bin, bridge-utils, net-tools, bash, screen, tmux, zfs-initramfs, dosfstools, mailutils, ssmtp, openssh-server, ufw, docker.io, sharutils...\"" >> /mnt/setup-chroot.sh
echo "errors=\$(DEBCONF_FRONTEND='noninteractive' apt install -y --no-install-recommends linux-image-generic 2>&1 1>/dev/null && apt purge -y netplan 2>&1 1>/dev/null && apt autoremove -y 2>&1 1>/dev/null && DEBCONF_FRONTEND='noninteractive' apt install -y ifupdown efibootmgr htop iotop smartmontools dnsutils nfs-kernel-server apparmor-profiles vim libvirt-bin bridge-utils net-tools bash screen tmux zfs-initramfs dosfstools mailutils ssmtp openssh-server ufw docker.io sharutils 2>&1 1>/dev/null)" >> /mnt/setup-chroot.sh
echo 'if ! [ \"$?\" = \"0\" ]; then '>> /mnt/setup-chroot.sh
@ -498,6 +493,27 @@ echo "chown -R ${admin}:${admin} \"/home/${admin}\"/.ssh" >> /mnt/setup-chroot.s
echo "HOME=\"/root\"" >> /mnt/setup-chroot.sh
echo "HOSTNAME=\"$hostname\"" >> /mnt/setup-chroot.sh
echo "echo \"FromLineOverride=YES\" > /etc/ssmtp/ssmtp.conf" >> /mnt/setup-chroot.sh
echo "echo \"root=admin\" >> /etc/ssmtp/ssmtp.conf" >> /mnt/setup-chroot.sh
echo "echo \"hostname=${fqdn}\" >> /etc/ssmtp/ssmtp.conf" >> /mnt/setup-chroot.sh
echo "echo \"AuthUser=${email}\" >> /etc/ssmtp/ssmtp.conf" >> /mnt/setup-chroot.sh
echo "echo \"AuthPass=${emailpassword}\" >> /etc/ssmtp/ssmtp.conf" >> /mnt/setup-chroot.sh
echo "echo \"mailhub=${smtp}\" >> /etc/ssmtp/ssmtp.conf" >> /mnt/setup-chroot.sh
echo "echo \"UseSTARTTLS=YES\" >> /etc/ssmtp/ssmtp.conf" >> /mnt/setup-chroot.sh
echo "echo \"root:${admins}\" >> /etc/ssmtp/revaliases" >> /mnt/setup-chroot.sh
echo "chfn -f '${email}' root" >> /mnt/setup-chroot.sh
echo "echo \"\"" >> /mnt/setup-chroot.sh
echo "echo \"Sending SSH key via e-mail...\"" >> /mnt/setup-chroot.sh
if [ "$networktype" = "dhcp" ]; then
connection="`hostname -I` (`wget -qO - ifconfig.me`)"
else
connection="$address"
fi
echo "serverinfo=\`cat \"/home/${admin}/.ssh/id_rsa\"\`" >> /mnt/setup-chroot.sh
echo "serverinfo=\"Server available at $connection\\n\\n\$serverinfo\"; echo -e \"\$serverinfo\" | mail -s \"$hostname SSH key\" -r \"${email}\" \"\`cat /admins\`\"" >> /mnt/setup-chroot.sh
echo "echo \"Done.\"" >> /mnt/setup-chroot.sh
errors=`chmod +x /mnt/setup-chroot.sh 2>&1 1>/dev/null`
if ! [ "$?" = "0" ]; then
echo "Failed to set execution permission on chroot script - $errors"
@ -536,27 +552,6 @@ echo " exit 122">> /mnt/setup-chroot.sh
echo "fi">> /mnt/setup-chroot.sh
echo "echo \"Done.\"" >> /mnt/setup-chroot.sh
echo "echo \"\"" >> /mnt/setup-chroot.sh
echo "echo \"Sending SSH key via e-mail...\"" >> /mnt/setup-chroot.sh
if [ "$networktype" = "dhcp" ]; then
connection="`hostname -I` (`wget -qO - ifconfig.me`)"
else
connection="$address"
fi
echo "echo \"FromLineOverride=YES\" > /etc/ssmtp/ssmtp.conf" >> /mnt/setup-chroot.sh
echo "echo \"root=admin\" >> /etc/ssmtp/ssmtp.conf" >> /mnt/setup-chroot.sh
echo "echo \"hostname=${fqdn}\" >> /etc/ssmtp/ssmtp.conf" >> /mnt/setup-chroot.sh
echo "echo \"AuthUser=${email}\" >> /etc/ssmtp/ssmtp.conf" >> /mnt/setup-chroot.sh
echo "echo \"AuthPass=${emailpassword}\" >> /etc/ssmtp/ssmtp.conf" >> /mnt/setup-chroot.sh
echo "echo \"mailhub=${smtp}\" >> /etc/ssmtp/ssmtp.conf" >> /mnt/setup-chroot.sh
echo "echo \"UseSTARTTLS=YES\" >> /etc/ssmtp/ssmtp.conf" >> /mnt/setup-chroot.sh
echo "echo \"root:${admins}\" >> /etc/ssmtp/revaliases" >> /mnt/setup-chroot.sh
echo "chfn -f '${email}' root" >> /mnt/setup-chroot.sh
echo "serverinfo=\`cat \"/home/${admin}/.ssh/id_rsa\"\`" >> /mnt/setup-chroot.sh
echo "serverinfo=\"Server available at $connection\\n\\n\$serverinfo\"; echo -e \"\$serverinfo\" | mail -s \"$hostname SSH key\" -r \"${email}\" \"\`cat /admins\`\"" >> /mnt/setup-chroot.sh
echo "echo \"Done.\"" >> /mnt/setup-chroot.sh
echo "exit 0" >> /mnt/setup-chroot.sh
@ -579,31 +574,29 @@ echo ""
echo "Writing network interfaces file..."
macaddr=$(echo $hostname|md5sum|sed 's/^\(..\)\(..\)\(..\)\(..\)\(..\).*$/02:\1:\2:\3:\4:\5/')
mkdir -p /mnt/etc/network && mkdir -p /mnt/etc/network/interfaces.d
echo "auto lo $bridgedevice" > /mnt/etc/network/interfaces.d/$bridgedevice
echo "iface lo inet loopback" >> /mnt/etc/network/interfaces.d/$bridgedevice
echo "auto lo br0" > /mnt/etc/network/interfaces.d/br0
echo "iface lo inet loopback" >> /mnt/etc/network/interfaces.d/br0
niclist=""
for nic in `echo "$nics"`; do
echo "iface ${nic} inet manual" >> /mnt/etc/network/interfaces.d/$bridgedevice
echo "iface ${nic} inet manual" >> /mnt/etc/network/interfaces.d/br0
niclist="$niclist $nic"
done
if [ "$networktype" = "dhcp" ]; then
echo "iface $bridgedevice inet dhcp" >> /mnt/etc/network/interfaces.d/$bridgedevice
echo "iface br0 inet dhcp" >> /mnt/etc/network/interfaces.d/br0
else
echo "iface $bridgedevice inet static" >> /mnt/etc/network/interfaces.d/$bridgedevice
echo " address $address" >> /mnt/etc/network/interfaces.d/$bridgedevice
echo " netmask $subnet" >> /mnt/etc/network/interfaces.d/$bridgedevice
echo " gateway $gateway" >> /mnt/etc/network/interfaces.d/$bridgedevice
echo "iface br0 inet static" >> /mnt/etc/network/interfaces.d/br0
echo " address $address" >> /mnt/etc/network/interfaces.d/br0
echo " netmask $subnet" >> /mnt/etc/network/interfaces.d/br0
echo " gateway $gateway" >> /mnt/etc/network/interfaces.d/br0
sed -ir "s/^#DNS=.*/DNS=${dns1}/g" /mnt/etc/systemd/resolved.conf
if ! [ -z "$dns2" ]; then sed -ir "s/^#FallbackDNS=.*/FallbackDNS=${dns2}/g" /mnt/etc/systemd/resolved.conf ; fi
fi
#echo " bridge_hw $macaddr" >> /mnt/etc/network/interfaces.d/br0
echo " dns-nameservers 127.0.0.53" >> /mnt/etc/network/interfaces.d/$bridgedevice
if [ "$bridgedevice" = "br0" ]; then
echo " bridge_waitport 0" >> /mnt/etc/network/interfaces.d/$bridgedevice
echo " bridge_fd 0" >> /mnt/etc/network/interfaces.d/$bridgedevice
echo " bridge_ports${niclist}" >> /mnt/etc/network/interfaces.d/$bridgedevice
echo " bridge_stp on" >> /mnt/etc/network/interfaces.d/$bridgedevice
fi
echo " dns-nameservers 127.0.0.53" >> /mnt/etc/network/interfaces.d/br0
echo " bridge_waitport 0" >> /mnt/etc/network/interfaces.d/br0
echo " bridge_fd 0" >> /mnt/etc/network/interfaces.d/br0
echo " bridge_ports${niclist}" >> /mnt/etc/network/interfaces.d/br0
echo " bridge_stp on" >> /mnt/etc/network/interfaces.d/br0
echo "source-directory /etc/network/interfaces.d" > /mnt/etc/network/interfaces
echo "Done."
@ -611,7 +604,7 @@ echo "Done."
echo ""
echo "Opening SSH port on firewall..."
sed -ir 's/### RULES ###/### RULES ###\n-A ufw-user-input -p tcp --dport 22 -j ACCEPT/g' /mnt/etc/ufw/user.rules 2>&1 1>/dev/null
sed -ir 's/### RULES ###/### RULES ###\n-A ufw-user-input -i br0 -p tcp --dport 22 -j ACCEPT/g' /mnt/etc/ufw/user.rules 2>&1 1>/dev/null
echo "Done."
# commented out for debugging
echo ""

Loading…
Cancel
Save