From 495c8039fb736ae358b83e2a522c4b2eda9466f1 Mon Sep 17 00:00:00 2001 From: paulober <44974737+paulober@users.noreply.github.com> Date: Wed, 16 Oct 2024 19:10:07 +0100 Subject: [PATCH] Raspberry Pi OS cloud-init support Signed-off-by: paulober <44974737+paulober@users.noreply.github.com> --- src/OptionsPopup.qml | 64 +++++++++++++++++++++++++++++++------------- src/main.qml | 2 +- 2 files changed, 47 insertions(+), 19 deletions(-) diff --git a/src/OptionsPopup.qml b/src/OptionsPopup.qml index 197e6883..4bbefe3a 100644 --- a/src/OptionsPopup.qml +++ b/src/OptionsPopup.qml @@ -712,21 +712,35 @@ Window { addCloudInit("") } + var isRpiosCloudInit = imageWriter.checkSWCapability("rpios_cloudinit"); + if (chkSSH.checked || chkSetUser.checked) { // First user may not be called 'pi' on all distributions, so look username up addFirstRun("FIRSTUSER=`getent passwd 1000 | cut -d: -f1`"); addFirstRun("FIRSTUSERHOME=`getent passwd 1000 | cut -d: -f6`") - addCloudInit("users:") - addCloudInit("- name: "+fieldUserName.text) - addCloudInit(" groups: users,adm,dialout,audio,netdev,video,plugdev,cdrom,games,input,gpio,spi,i2c,render,sudo") - addCloudInit(" shell: /bin/bash") - var cryptedPassword; if (chkSetUser.checked) { cryptedPassword = fieldUserPassword.alreadyCrypted ? fieldUserPassword.text : imageWriter.crypt(fieldUserPassword.text) - addCloudInit(" lock_passwd: false") - addCloudInit(" passwd: "+cryptedPassword) + } + + if (isRpiosCloudInit && cryptedPassword) { + addCloudInit("rpi_userconf:") + addCloudInit(" password: " + cryptedPassword) + addCloudInit(" user: " + fieldUserName.text) + addCloudInit("") + } + + addCloudInit("users:") + addCloudInit("- name: " + fieldUserName.text) + if (!isRpiosCloudInit) { + addCloudInit(" groups: users,adm,dialout,audio,netdev,video,plugdev,cdrom,games,input,gpio,spi,i2c,render,sudo") + addCloudInit(" shell: /bin/bash") + + if (chkSetUser.checked) { + addCloudInit(" lock_passwd: false") + addCloudInit(" passwd: "+cryptedPassword) + } } if (chkSSH.checked && radioPubKeyAuthentication.checked) { @@ -759,7 +773,12 @@ Window { addCloudInit(" - "+pk) } } - addCloudInit(" sudo: ALL=(ALL) NOPASSWD:ALL") + if (!isRpiosCloudInit) { + addCloudInit(" sudo: ALL=(ALL) NOPASSWD:ALL") + } else { + addCloudInit("\nrpi_interfaces:") + addCloudInit(" ssh: true") + } } addCloudInit("") @@ -795,6 +814,14 @@ Window { addFirstRun("fi") } addCloudInit("") + + /*if (chkSetUser.checked) { + addCloudInit("final_message: \"Setup wizard has been skiped.\"") + addCloudInit("power_state:") + addCloudInit(" mode: reboot") + addCloudInit(" message: Rebooting machine") + addCloudInit("") + }*/ } if (chkWifi.checked) { var wpaconfig = "country="+fieldWifiCountry.editText+"\n" @@ -830,17 +857,18 @@ Window { addFirstRun("fi") - cloudinitnetwork = "version: 2\n" - cloudinitnetwork += "wifis:\n" - cloudinitnetwork += " renderer: networkd\n" - cloudinitnetwork += " wlan0:\n" - cloudinitnetwork += " dhcp4: true\n" - cloudinitnetwork += " optional: true\n" - cloudinitnetwork += " access-points:\n" - cloudinitnetwork += " \""+fieldWifiSSID.text+"\":\n" - cloudinitnetwork += " password: \""+cryptedPsk+"\"\n" + cloudinitnetwork = "network:\n" + cloudinitnetwork += " version: 2\n" + cloudinitnetwork += " renderer: " + (isRpiosCloudInit ? "NetworkManager" : "networkd") + "\n" + cloudinitnetwork += " wifis:\n" + cloudinitnetwork += " wlan0:\n" + cloudinitnetwork += " dhcp4: true\n" + cloudinitnetwork += " optional: true\n" + cloudinitnetwork += " access-points:\n" + cloudinitnetwork += " \""+fieldWifiSSID.text+"\":\n" + cloudinitnetwork += " password: \""+cryptedPsk+"\"\n" if (chkWifiSSIDHidden.checked) { - cloudinitnetwork += " hidden: true\n" + cloudinitnetwork += " hidden: true\n" } addCmdline("cfg80211.ieee80211_regdom="+fieldWifiCountry.editText) diff --git a/src/main.qml b/src/main.qml index 4c5c9f3a..9c6c19e5 100644 --- a/src/main.qml +++ b/src/main.qml @@ -1226,7 +1226,7 @@ ApplicationWindow { confirmwritepopup.askForConfirmation() } onNo: { - imageWriter.setImageCustomization("", "", "", "", "") + imageWriter.setImageCustomization("", "", "", "", "", false, false) confirmwritepopup.askForConfirmation() } onNoClearSettings: {