Compare commits

..

2 Commits

Author SHA1 Message Date
Dustin bfd70ef34e fedora-comon: Update default package set
infra/kickstart/pipeline/head This commit looks good Details
* Install `system-upgrade` plugin for `dnf`, since we'll almost always
  want this in order to be able to update hosts
* Do not install _sshca-cli-systemd_; this package has been deprecated
  and removed in favor of setting up the systemd units from Ansible
* Install _python3-libdnf5_, as this is required by Ansible and will be
  installed by it later, so we can save a bit of time by always having
  it installed.
2025-09-14 15:18:00 -05:00
Dustin d8118e0fce autoprovision: split script+unit into separate files
Now that we're using Jinja to render the kickstart scripts, we can
separate out scripts, systemd unit files, etc. into their own files and
`include` them.  This makes editing them much easier, especially since
syntax highlighting will work correctly.
2025-07-26 07:20:01 -05:00
6 changed files with 34 additions and 31 deletions

16
autoprovision.ks.j2 Normal file
View File

@ -0,0 +1,16 @@
%post
cat > /root/.ssh/authorized_keys <<EOF
expiry-time="$(date -d +1hour +%Y%m%d%H%M)",restrict,pty ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAICoOO/ZYMxRgmyvqZwGN3NM5pHyh3NBdC7iZrXIopt93 Host Provisioner
EOF
cat > /usr/local/libexec/notify-online.sh <<'EOF'
{% include "notify-online.sh" %}
EOF
chmod +x /usr/local/libexec/notify-online.sh
cat > /etc/systemd/system/notify-online.service <<'EOF'
{% include "notify-online.service" %}
EOF
systemctl enable --no-reload notify-online.service
%end

View File

@ -13,7 +13,6 @@ reboot
-NetworkManager
-authconfig
-dhcp-client
-dnf-plugins-core
-dnf-yum
-dracut-config-rescue
-man-db
@ -27,15 +26,17 @@ reboot
-yum
chrony
dnf
dnf-command(system-upgrade)
e2fsprogs
grubby
kitty-terminfo
openssh-server
python3-libdnf5
python3-libselinux
python3-policycoreutils
rng-tools
selinux-policy-targeted
sshca-cli-systemd
sshca-cli
systemd-networkd
%end

View File

@ -2,4 +2,4 @@
ignoredisk --only-use /dev/mmcblk0
{% include "fedora-disk-dch.ks" %}
{% include "fedora-rpi-common.ks.j2" %}
{% include "autoprovision.ks" %}
{% include "autoprovision.ks.j2" %}

View File

@ -16,4 +16,4 @@ qemu-guest-agent
-fwupd
%end
{% include "autoprovision.ks" %}
{% include "autoprovision.ks.j2" %}

View File

@ -1,26 +1,3 @@
%post
cat > /root/.ssh/authorized_keys <<EOF
expiry-time="$(date -d +1hour +%Y%m%d%H%M)",restrict,pty ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAICoOO/ZYMxRgmyvqZwGN3NM5pHyh3NBdC7iZrXIopt93 Host Provisioner
EOF
cat > /usr/local/libexec/notify-online.sh <<'EOF'
#!/bin/sh
set -- \
-F "hostname=$(hostname -f)" \
-F 'sshkeys=<-;type=text/plain'
fw_cfg=/sys/firmware/qemu_fw_cfg/by_name/opt/dch/cfg-branch/raw
if [ -r "${fw_cfg}" ]; then
set -- "$@" -F branch="$(cat "${fw_cfg}")"
fi
cat /etc/ssh/ssh_host_*_key.pub \
| curl -fsS https://webhooks.pyrocufflink.blue/host/online "$@"
EOF
chmod +x /usr/local/libexec/notify-online.sh
cat > /etc/systemd/system/notify-online.service <<'EOF'
[Unit]
Description=Notify infrastructure services that this host is online
ConditionFirstBoot=yes
@ -63,7 +40,3 @@ SystemCallFilter=~@privileged @resources
[Install]
WantedBy=multi-user.target
EOF
systemctl enable --no-reload notify-online.service
%end

13
notify-online.sh Normal file
View File

@ -0,0 +1,13 @@
#!/bin/sh
set -- \
-F "hostname=$(hostname -f)" \
-F 'sshkeys=<-;type=text/plain'
fw_cfg=/sys/firmware/qemu_fw_cfg/by_name/opt/dch/cfg-branch/raw
if [ -r "${fw_cfg}" ]; then
set -- "$@" -F branch="$(cat "${fw_cfg}")"
fi
cat /etc/ssh/ssh_host_*_key.pub \
| curl -fsS https://webhooks.pyrocufflink.blue/host/online "$@"