# SPDX-License-Identifier: GPL-3.0-or-later
-# shellcheck source=/a/bin/ds/.bashrc
-export LC_USEBASHRC=t; if [[ -s ~/.bashrc ]]; then . ~/.bashrc; fi
+# shellcheck disable=SC2317 # false positive
+export LC_USEBASHRC=t
+source /a/bin/ds/.bashrc
### setup
source /a/bin/bash-bear-trap/bash-bear
done
if $doupdate; then
tmpdir=$(mktemp -d)
- cd $tmpdir
- # cant apt get the keyring without doing an update, can't update
- # without the keyring, this is a stupid chicken and egg problem
- # that apt should have some feature to solve, but doesn't as far
- # as I know.
- f=debian-archive-keyring_2023.3+deb12u1_all.deb
- wget http://ftp.debian.org/debian/pool/main/d/debian-archive-keyring/$f
- sudo dpkg -i $f
+ (
+ cd $tmpdir
+ # cant apt get the keyring without doing an update, can't update
+ # without the keyring, this is a stupid chicken and egg problem
+ # that apt should have some feature to solve, but doesn't as far
+ # as I know.
+ f=debian-archive-keyring_2023.3+deb12u1_all.deb
+ wget http://ftp.debian.org/debian/pool/main/d/debian-archive-keyring/$f
+ sudo dpkg -i $f
+ )
p update
- cd -
rm -rf $tmpdir
fi
- if [[ ! -e /usr/share/debootstrap/scripts/bookworm ]]; then
- t=$(mktemp -d)
- cd $t
- m aptitude download debootstrap/bookworm
- m ex ./*
- sudo cp ./usr/share/debootstrap/scripts/* /usr/share/debootstrap/scripts
+ if [[ ! -e /usr/share/debootstrap/scripts/noble ]]; then
+ # noble debootstrap as of 2024-07-05. not going to bother
+ # adding a whole repo for one package which doesn't seem to generally change within a single distro version.
+ sudo dpkg -i /a/opt/debootstrap_1.0.134ubuntu1_all.deb
fi
;;&
esac
case $codename_compat in
- jammy)
+ jammy|noble)
s systemctl enable --now ssh-agent-iank
;;
esac
dnsb8
fi
- sudo /c/roles/prom_export/files/simple/usr/local/bin/fsf-install-node-exporter -l 127.0.0.1
+ sudo /a/f/ans/roles/prom_export/files/simple/usr/local/bin/fsf-install-node-exporter -l 127.0.0.1
# ex for exporter
web-conf -p 9101 -f 9100 - apache2 ${HOSTNAME}ex.b8.nz <<'EOF'
client-to-client
EOF
-
- ngset
- files=(/etc/openvpn/client-config-hole/*)
- if (( ${#files[@]} >= 1 )); then
- rm -f ${files[@]}
- fi
- ngreset
- for host in ${!vpn_ips[@]}; do
- sd /etc/openvpn/client-config-hole/$host <<EOF
-ifconfig-push 10.5.5.${vpn_ips[$host]} 255.255.255.0
-EOF
- done
+ # note client-config files are setup in brc2 update-host-info
# for adding cert to system with /p
# Pin-Priority: 1001
# EOF
#
- # TODO: I had to uninstall linux-image-generic-hwe-20.04 because of a conflict
- # about linux-firmware. Should probably install it to begin with in fai if
- # i'm going to use.
- pi system76-driver system76-firmware
+ # fwupdmgr get-updates
+ # says I have 3 "devices with no available firmware updates"
+ # if there were updates, install with: s fwupdmgr update
+
+ check_downgrade=false
+ if [[ ! -e /etc/apt/preferences.d/system76-apt-preferences ]]; then
+ check_downgrade=true
+ fi
+ # note this installs a kernel
+ pi system76-firmware system76-driver
+ pi-nostart fwupd
+ # some other service starts it. note: this still needs testing.
+ ser mask fwupd
+ if $check_downgrade && [[ -e /etc/apt/preferences.d/system76-apt-preferences ]]; then
+ # driver installs a preferences file to give s76 packages
+ # priority so we may need to downgrade here.
+ pup --allow-downgrades
+ fi
+ # system76-driver: on a modern kernel, it seems to mainly just do
+ # some power settings, I haven't looked entirely through it. Of
+ # its recommended packages, system76-power is the only one I
+ # haven't looked at, the others do nothing for laptops i
+ # have. they have models hardcoded in source, so you can just grep
+ # for it. pkx package; caf | less. I'm rather annoyed that
+ # com.system76.PowerDaemon.service is regularly taking up the
+ # most power. I wonder what it is actually doing, it really
+ # doesn't say, just has cryptic messages when I turn on
+ # debug logs, and has no documentation. Similar deal with
+ # system76-driver.service.
+ #
# if you get a notice about a firmware update, the notifier on i3
- # is too dumb to do anything when you click it. so to see
- # a changelog, cd to
+ # is too dumb to do anything when you click it.
+ #
+ # To see current version: cat /sys/class/dmi/id/bios_version
+ # ref: https://support.system76.com/articles/transition-firmware/
+ #
+ # to manually get new firmware,
+ # system76-firmware-cli schedule --open
+ # to see a changelog, cd to
# /var/cache/system76-firmware-daemon
# extract the xz files there, one will contain a changelog.
# then to install an update:
# box type: scale to width of bounds. alignment in bounding box:
# bottom left. bounding box size 1920 x 1080.
- # ppa:obsproject/obs-studio
- if [[ ! -s /etc/apt/sources.list.d/obs.list ]]; then
- # https://blog.zackad.dev/en/2017/08/17/add-ppa-simple-way.html
- sd /etc/apt/sources.list.d/obs.list <<EOF
+ # as of 2024-06, noble repo doesn't exist yet
+ if [[ $codename_compat != noble ]]; then
+ # ppa:obsproject/obs-studio
+ if [[ ! -s /etc/apt/sources.list.d/obs.list ]]; then
+ # https://blog.zackad.dev/en/2017/08/17/add-ppa-simple-way.html
+ sd /etc/apt/sources.list.d/obs.list <<EOF
deb http://ppa.launchpad.net/obsproject/obs-studio/ubuntu $codename_compat main
deb-src http://ppa.launchpad.net/obsproject/obs-studio/ubuntu $codename_compat main
EOF
- trysleep 4 15 s apt-key adv --keyserver keyserver.ubuntu.com --recv-keys BC7345F522079769F5BBE987EFC71127F425E228
- p update
+ trysleep 4 15 s apt-key adv --keyserver keyserver.ubuntu.com --recv-keys BC7345F522079769F5BBE987EFC71127F425E228
+ p update
+ fi
fi
;;
jammy)
# not yet bothering with mate
pi lightdm-gtk-greeter lightdm
+ case $HOSTNAME in
+ sy|bo)
+ # todo: try removing this. also, see if system76-driver fixes this.
+
+ # on newer laptop, this config makes xorg load an intel module
+ # in Xorg.0.log and display nothing. background:
+ #
+ # I dropped lightdm as I was trying to figure this out, why xorg was
+ # displaying nothing. I did a diff of a working Xorg.0.log from a
+ # popos is, which is in ~/.local/share/xorg/Xorg.0.log if it runs as
+ # a regular user. I noticed 2 differences, on the failing one it was
+ # loading the intel xorg module. On the successful one, it had a
+ # line systemd-logind: got fd for /dev/dri/card1 226:1, on the
+ # failing one it had a line about systemd-logind not knowing the
+ # seat or session or something. There was no search results about
+ # that, switching to xinit made that go away. Note: gpg-agent seems
+ # to be working ok as an ssh agent. xsession has an option
+ # use-ssh-agent but perhaps it decides to leave gpg agent in charge.
+ cat >/etc/X11/xorg.conf.d/20-intel.conf <<'EOF'
+# iank:
+# https://forums.linuxmint.com/viewtopic.php?f=208&t=224942#p1197049
+# prevents konsole from being borderline unusable on system76 intel graphics + i3
+Section "Device"
+ Identifier "Intel Graphics"
+ Driver "intel"
+ Option "TearFree" "true"
+EndSection
+EOF
+ ;;
+ esac
+ ;;
+ noble)
+ pi xinit
;;
esac
esac
;;
ubuntu)
+ case $codename in
+ noble)
+ if pcheck ubuntu-system-adjustments; then
+ # mint firefox has a dependency which is totally not really
+ # needed, just some mint branding and maybe a random firefox
+ # setting.
+ tmpdir="$(mktemp -d)"
+ # it puts the deb in .., so use a subdir to stay contained
+ mkdir $tmpdir/sub
+ cd "$tmpdir/sub"
+ # edited from output of equivs-control ubuntu-system-adjustments
+ cat >ubuntu-system-adjustments <<'EOF'
+Section: misc
+Priority: optional
+Version: 2030
+Standards-Version: 3.9.2
+Package: ubuntu-system-adjustments
+Description: ubuntu-system-adjustments-dummy
+EOF
+ equivs-build ubuntu-system-adjustments
+ sudo dpkg -i ../ubuntu-system-adjustments_2030_all.deb
+ cd
+ rm -r "$tmpdir"
+ fi
+ ;;
+ esac
pi firefox
;;
debian)
esac
+case $codename_compat in
+ aramo|buster)
+ # https://wiki.archlinux.org/title/bluetooth
+ pi pavucontrol paprefs pulseaudio-module-bluetooth pulsemixer
+ ;;
+ noble|bookworm)
+ pi pipewire-audio
+ # having pipewire installed prevents the recommends in these from installing pulse
+ pi pulsemixer pavucontrol
+ ;;
+esac
+
+
# TODO: some of the X programs can be removed from pall when using wayland
# depends gcc is a way to install suggests. this is apparently the only
# I dont want that.
pi-nostart schroot
+## note: this bug doesn't exist in t12+
# fix systemd unit failure. i dont know of any actual impact
# other than systemd showing in degraded state. So, we dont bother
# fixing the current state, let it fix on the next reboot.
# https://gitlab.com/cjwatson/binfmt-support/-/commit/54f0e1af8a
-tmp=$(systemctl cat binfmt-support.service | grep ^After=)
-if [[ $tmp != *systemd-binfmt.service* ]]; then
- s u /etc/systemd/system/binfmt-support.service.d/override.conf <<EOF
+if pcheck binfmt-support; then
+ tmp=$(systemctl cat binfmt-support.service | grep ^After=)
+ if [[ $tmp != *systemd-binfmt.service* ]]; then
+ s u /etc/systemd/system/binfmt-support.service.d/override.conf <<EOF
[Unit]
$tmp systemd-binfmt.service
EOF
+ fi
fi
-
# commented, not worth the hassle i think.
#seru enable psd
#seru start psd
sudo rm -fv /etc/systemd/system/profanity.service
case $HOSTNAME in
kd)
+ # i dunno why i put it here
ln -sfT /d/p/profanity ~/.local/share/profanity
ln -sfT /d/p/profanity-config ~/.config/profanity
source /a/bin/bash_unpublished/source-state
# it asks if it should make users in it's group capture packets without root,
# which is arguably more secure than running wireshark as root. default is no,
# which is what i prefer, since I plan to use tcpdump to input to wireshark.
-s DEBIAN_FRONTEND=noninteractive pi wireshark-gtk
+# note: t10 called this wireshark-gtk, i don't care about t10 anymore.
+s DEBIAN_FRONTEND=noninteractive pi wireshark
# /run and /dev/shm are listed as required for pulseaudio. All 4 in the group
# listed in the default config as suggested.
# /run/usr/1000 i noticed was missing for pulseaudio
# /run/user/0 just seemed like a not bad idea, given the above
+#
+# /root gives us our bashrc, making various things a lot more
+# convenient
tu /etc/schroot/desktop/fstab <<'EOF'
+/root /root none rw,bind 0 0
/p /p none rw,bind 0 0
/a /a none rw,bind 0 0
/run /run none rw,bind 0 0
-# for my roommate
+# for testing firefox specific issues
case $distro in
- trisquel)
+ trisquel|ubuntu)
m mkschroot -s /a/bin/fai/fai/config/files/etc/apt/sources.list.d/bookworm.list/BOOKWORM_FREE \
- debian bookworm firefox-esr pulseaudio chromium
+ debian bookworm chromium fonts-noto-color-emoji
;;
debian)
- pi chromium
+ # fonts are for emojis, which tend to get used as buttons on the web.
+ pi chromium fonts-noto-color-emoji
;;
esac
pi --no-install-recommends kdeconnect
-### kdeconnect for gnome. started in /a/bin/distro-setup/desktop-20-autostart.sh
-### but gnome + xmonad not working in flidas, so i disabled it
-# pi libgtk-3-dev python3-requests-oauthlib valac cmake python-nautilus libappindicator3-dev
-# cd /a/opt/indicator-kdeconnect
-# mkdir -p build
-# cd build
-# cmake .. -DCMAKE_INSTALL_PREFIX=/usr
-# make
-# sudo make install
-# # we can start it manually with /usr/lib/x86_64-linux-gnu/libexec/kdeconnectd
-# # it seems, according to
-# # /etc/xdg/autostart/kdeconnectd.desktop
-# # I'm not seeing the icon, but the clipboard replication is working
### begin model 01 arduino support ###
########### misc stuff
-xdg-settings set default-web-browser abrowser.desktop
# see current with:
# xdg-settings get default-web-browser
+# not sure this is needed.
+#
+# These are some old files that made xdg-open open firefox from a chroot.
+rm -f ~/.local/share/applications/{firefox,chromium}*
+case $distro in
+ trisquel)
+ xdg-settings set default-web-browser abrowser.desktop
+ ;;
+ ubuntu)
+ xdg-settings set default-web-browser firefox.desktop
+ ;;
+esac
+
# pressing tab after sdf here:
# scp sdfbash: set +o noglob: command not found
rm -fv /home/iank/.mpv/watch_later
rm -rf /home/iank/.mpv
-if [[ ! -e ~/.local/bin/pip ]]; then
- tmp=$(mktemp)
- wget -O$tmp https://bootstrap.pypa.io/get-pip.py
- python3 $tmp --user
- hash -r
-fi
+# apparently pip is deprecated in debian. try venv or pipx.
+## begin u24 message upon pip install
+# If you wish to install a non-Debian-packaged Python package,
+# create a virtual environment using python3 -m venv path/to/venv.
+# Then use path/to/venv/bin/python and path/to/venv/bin/pip. Make
+# sure you have python3-full installed.
+
+# If you wish to install a non-Debian packaged Python application,
+# it may be easiest to use pipx install xyz, which will manage a
+# virtual environment for you. Make sure you have pipx installed.
+
+# See /usr/share/doc/python3.12/README.venv for more information.
+## end
+
+# if [[ ! -e ~/.local/bin/pip ]]; then
+# tmp=$(mktemp)
+# wget -O$tmp https://bootstrap.pypa.io/get-pip.py
+# python3 $tmp --user
+# hash -r
+# fi
+
## begin beets
# soo, apt install beets fails due to wanting a pip package,
# as of 2023-02, the tox dependency was removed in debian unstable, so
# this hack will probably go away in t12.
-if pcheck beets; then
- tmpdir="$(mktemp -d)"
- cd "$tmpdir"
- # edited from output of equivs-control tox
- cat >tox <<'EOF'
+case $(debian-codename) in
+ aramo)
+ if pcheck tox; then
+ tmpdir="$(mktemp -d)"
+ cd "$tmpdir"
+ # edited from output of equivs-control tox
+ cat >tox <<'EOF'
Section: python
Priority: optional
Standards-Version: 3.9.2
Package: tox
Description: tox-dummy
EOF
- equivs-build tox
- sudo dpkg -i tox_1.0_all.deb
- rm -rf ./tox*
- pi beets python3-discogs-client
- cd
- rm -r "$tmpdir"
-fi
+ equivs-build tox
+ sudo dpkg -i tox_1.0_all.deb
+ rm -rf ./tox*
+ pi beets
+ cd
+ rm -r "$tmpdir"
+ fi
+ ;;
+esac
# get rid of annoying message
s sed -ri "s/^([[:space:]]*ui.print_\('Playing)/#\1/" /usr/share/beets/beetsplug/play.py
# ser list-timers
+### begin ansible
+
+## commented because fsf relies on using an old ansible for now.
+# if [[ ! -e /etc/apt/sources.list.d/ansible-ubuntu-ansible-$codename_compat.sources ]]; then
+# s add-apt-repository --yes --update ppa:ansible/ansible
+# pi ansible
+# fi
+
+### end ansible
+
### begin prometheus ###
case $HOSTNAME in
kd)
# Font awesome is needed for the alertmanager ui.
pi prometheus-alertmanager prometheus fonts-font-awesome
- /c/roles/prom/files/simple/usr/local/bin/fsf-install-prometheus
+ /a/f/ans/roles/prom/files/simple/usr/local/bin/fsf-install-prometheus
+
# make it available for other machines
rsync -a /usr/local/bin/amtool /a/opt/bin
web-conf -p 9091 -f 9090 - apache2 b8.nz <<'EOF'
ser restart prometheus-alertmanager
fi
- s /c/roles/prom_export/files/simple/usr/local/bin/fsf-install-node-exporter -l 127.0.0.1
+ s /a/f/ans/roles/prom_export/files/simple/usr/local/bin/fsf-install-node-exporter -l 127.0.0.1
for ser in prometheus-node-exporter prometheus-alertmanager prometheus; do
sysd-prom-fail-install $ser
;;
*)
- s /c/roles/prom_export/files/simple/usr/local/bin/fsf-install-node-exporter
+ s /a/f/ans/roles/prom_export/files/simple/usr/local/bin/fsf-install-node-exporter
;;
esac
-# cleanup old files. 2023-02
-x=(/var/lib/prometheus/node-exporter/*.premerge)
-if [[ -e ${x[0]} ]]; then
- s rm /var/lib/prometheus/node-exporter/*
+# user specific file isn't installed until the user exists
+if [[ ! -e /etc/prometheus/ssl/prom_node_key.pem ]]; then
+ conflink
fi
wgip=$(command sudo sed -rn 's,^ *Address *= *([^/]+).*,\1,p' /etc/wireguard/wghole.conf)
# old filename. remove once all hosts are updated.
s rm -fv /etc/apache2/sites-enabled/${HOSTNAME}wg.b8.nz.conf
- web-conf -i -a $wgip -p 9101 -f 9100 - apache2 ${HOSTNAME}wg.b8.nz <<'EOF'
+ s bash -x web-conf -i -a $wgip -p 9101 -f 9100 - apache2 ${HOSTNAME}wg.b8.nz <<'EOF'
<Location "/">
AuthType Basic
AuthName "basic_auth"
### end prometheus ###
-### begin bitcoin ###
-
-case $HOSTNAME in
- sy|kd|so)
- sudo install -m 0755 -o root -g root -t /usr/bin /a/opt/bitcoin-27.0/bin/*
- # Note: i leave it to system-status to start and stop bitcoin.
- # note: the bitcoin user & group are setup in fai
- sudo usermod -a -G bitcoin iank
- # todo: make bitcoin have a stable uid/gid
- sudo mkdir -p /var/lib/bitcoind
- sudo chown bitcoin:bitcoin /var/lib/bitcoind
- # 710 comes from the upstream bitcoin unit file
- sudo chmod 710 /var/lib/bitcoind
- # note, there exists
- # /a/bin/ds/disabled/bitcoin
- ;;
-esac
+# disabled
+# ### begin bitcoin ###
+
+# case $HOSTNAME in
+# sy|kd|so)
+# sudo install -m 0755 -o root -g root -t /usr/bin /a/opt/bitcoin-27.0/bin/*
+# # Note: i leave it to system-status to start and stop bitcoin.
+# # note: the bitcoin user & group are setup in fai
+# sudo usermod -a -G bitcoin iank
+# # todo: make bitcoin have a stable uid/gid
+# sudo mkdir -p /var/lib/bitcoind
+# sudo chown bitcoin:bitcoin /var/lib/bitcoind
+# # 710 comes from the upstream bitcoin unit file
+# sudo chmod 710 /var/lib/bitcoind
+# # note, there exists
+# # /a/bin/ds/disabled/bitcoin
+# ;;
+# esac
-### end bitcoin
+# ### end bitcoin
### begin live streaming ###
### end gh ####
+##### begin docker install
+if ! pcheck "$@"; then
+ # https://docs.docker.com/engine/install/ubuntu/
+ # Add Docker's official GPG key:
+ sudo curl -fsSL https://download.docker.com/linux/ubuntu/gpg -o /etc/apt/keyrings/docker.asc
+ sudo chmod a+r /etc/apt/keyrings/docker.asc
+
+ # Add the repository to Apt sources:
+ echo \
+ "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] https://download.docker.com/linux/ubuntu \
+ $(debian-codename-compat) stable" | \
+ sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
+
+ p update
+
+
+ # docker eats up a fair amount of cpu when doing nothing, so don't enable it unless
+ # we really need it.
+ pi-nostart docker-ce
+
+fi
+##### end docker install #####
+
# remove trisquel banner. it is cool but takes up too much space.
sudo rm -f /etc/update-motd.d/01-banner
sudo exportfs -rav
fi
+case $codename_compat in
+ noble)
+ # this fails on startup. i don't use resolvconf, so it is totally pointless.
+ soff unbound-resolvconf.service
+ ;;
+esac
+
+hiup
# if I was going to create a persistent vm, i might do it like this:
# variant=something # from: virt-install --os-variant list