From c8c9cf02d275dbd97fb187751cd0f51a7205ab5a Mon Sep 17 00:00:00 2001 From: Alex Bradbury Date: Mon, 9 Sep 2013 23:55:22 +0100 Subject: [PATCH] support boot to scratch and applying language/keyboard settings from noobs --- raspi-config | 210 +++++++++++++++++++++++++++++++++++++++++++++------ 1 file changed, 186 insertions(+), 24 deletions(-) diff --git a/raspi-config b/raspi-config index 8406b28..5baa436 100755 --- a/raspi-config +++ b/raspi-config @@ -379,23 +379,105 @@ do_ssh() { fi } +disable_raspi_config_at_boot() { + if [ -e /etc/profile.d/raspi-config.sh ]; then + rm -f /etc/profile.d/raspi-config.sh + sed -i /etc/inittab \ + -e "s/^#\(.*\)#\s*RPICFG_TO_ENABLE\s*/\1/" \ + -e "/#\s*RPICFG_TO_DISABLE/d" + telinit q + fi +} + +enable_boot_to_scratch() { + if [ -e /etc/profile.d/boottoscratch.sh ]; then + printf "/etc/profile.d/boottoscratch.sh exists, so assuming boot to scratch enabled\n" + return 0; + fi + sed -i /etc/inittab -e "s|^\(1:2345.*getty.*tty1.*\)|\ +#\1 # BTS_TO_ENABLE\n1:2345:respawn:/bin/login -f pi tty1 /dev/tty1 2>\&1 # BTS_TO_DISABLE|" + cat <<\EOF > /etc/profile.d/boottoscratch.sh +#!/bin/sh +# Part of raspi-config http://github.com/asb/raspi-config +# +# See LICENSE file for copyright and license details + +# Should be installed to /etc/profile.d/boottoscratch.sh to force scratch to run upon boot + +# You may also want to set automatic login in /etc/inittab on tty1 by adding a +# line such as the following (raspi-config does this for you): +# 1:2345:respawn:/bin/login -f pi tty1 /dev/tty1 2>&1 # BTS_TO_DISABLE + +if [ $(tty) = "/dev/tty1" ]; then + printf "openbox --config-file /home/pi/boottoscratch/openbox_rc.xml & scratch" | xinit /dev/stdin + printf "\n\n\nShutting down in 5 seconds, hit ctrl-C to cancel\n" && sleep 5 && sudo shutdown -h now +fi +EOF + + mkdir -p /home/pi/boottoscratch + cat <<\EOF > /home/pi/boottoscratch/openbox_rc.xml + + + + + yes + yes + + + +EOF + telinit q +} + +disable_boot_to_scratch() { + if [ -e /etc/profile.d/boottoscratch.sh ]; then + rm -f /etc/profile.d/boottoscratch.sh + sed -i /etc/inittab \ + -e "s/^#\(.*\)#\s*BTS_TO_ENABLE\s*/\1/" \ + -e "/#\s*BTS_TO_DISABLE/d" + telinit q + fi +} + do_boot_behaviour() { - if [ -e /etc/init.d/lightdm ]; then - whiptail --yesno "Should we boot straight to desktop?" 20 60 2 - RET=$? - if [ $RET -eq 0 ]; then # yes - update-rc.d lightdm enable 2 - sed /etc/lightdm/lightdm.conf -i -e "s/^#autologin-user=.*/autologin-user=pi/" - ASK_TO_REBOOT=1 - elif [ $RET -eq 1 ]; then # no - update-rc.d lightdm disable 2 - ASK_TO_REBOOT=1 - else # user hit escape - return 1 - fi - else - whiptail --msgbox "Do sudo apt-get install lightdm to allow configuration of boot to desktop" 20 60 2 - return 1 + BOOTOPT=$(whiptail --menu "Chose boot option" 20 60 10 \ + "Console" "Text console, requiring login (default)" \ + "Desktop" "Log in as user 'pi' at the graphical desktop" \ + "Scratch" "Start the Scratch programming environment upon boot" \ + 3>&1 1>&2 2>&3) + if [ $? -eq 0 ]; then + case "$BOOTOPT" in + Console) + [ -e /etc/init.d/lightdm ] && update-rc.d lightdm disable 2 + disable_boot_to_scratch + ;; + Desktop) + if [ -e /etc/init.d/lightdm ]; then + update-rc.d lightdm enable 2 + sed /etc/lightdm/lightdm.conf -i -e "s/^#autologin-user=.*/autologin-user=pi/" + disable_boot_to_scratch + disable_raspi_config_at_boot + else + whiptail --msgbox "Do sudo apt-get install lightdm to allow configuration of boot to desktop" 20 60 2 + return 1 + fi + ;; + Scratch) + if [ -e /usr/bin/scratch ]; then + [ -e /etc/init.d/lightdm ] && update-rc.d lightdm disable 2 + enable_boot_to_scratch + disable_raspi_config_at_boot + else + whiptail --msgbox "Do sudo apt-get install scratch to allow configuration of boot to scratch" 20 60 2 + fi + ;; + *) + whiptail --msgbox "Programmer error, unrecognised boot option" 20 60 2 + return 1 + ;; + esac + ASK_TO_REBOOT=1 fi } @@ -470,13 +552,7 @@ do_update() { } do_finish() { - if [ -e /etc/profile.d/raspi-config.sh ]; then - rm -f /etc/profile.d/raspi-config.sh - sed -i /etc/inittab \ - -e "s/^#\(.*\)#\s*RPICFG_TO_ENABLE\s*/\1/" \ - -e "/#\s*RPICFG_TO_DISABLE/d" - telinit q - fi + disable_raspi_config_at_boot if [ $ASK_TO_REBOOT -eq 1 ]; then whiptail --yesno "Would you like to reboot now?" 20 60 2 if [ $? -eq 0 ]; then # yes @@ -487,6 +563,87 @@ do_finish() { exit 0 } +# $1 = filename, $2 = key name +get_json_string_val() { + sed -n -e "s/^[[:space:]]*\"$2\"[[:space:]]*:[[:space:]]*\"\(.*\)\"[[:space:]]*,$/\1/p" $1 +} + +do_apply_os_config() { + [ -e /boot/os_config.json ] || return 0 + NOOBSFLAVOUR=$(get_json_string_val /boot/os_config.json flavour) + NOOBSLANGUAGE=$(get_json_string_val /boot/os_config.json language) + NOOBSKEYBOARD=$(get_json_string_val /boot/os_config.json keyboard) + + if [ -n "$NOOBSFLAVOUR" ]; then + printf "Setting flavour to %s based on os_config.json from NOOBS. May take a while\n" "$NOOBSFLAVOUR" + + if [ "$NOOBSFLAVOUR" = "Scratch" ]; then + disable_raspi_config_at_boot + enable_boot_to_scratch + else + printf "Unrecognised flavour. Ignoring\n" + fi + fi + + # TODO: currently ignores en_gb settings as we assume we are running in a + # first boot context, where UK English settings are default + case "$NOOBSLANGUAGE" in + "en") + if [ "$NOOBSKEYBOARD" = "gb" ]; then + DEBLANGUAGE="" # UK english is the default, so ignore + else + DEBLANGUAGE="en_US.UTF-8" + fi + ;; + "de") + DEBLANGUAGE="de_DE.UTF-8" + ;; + "fi") + DEBLANGUAGE="fi_FI.UTF-8" + ;; + "fr") + DEBLANGUAGE="fr_FR.UTF-8" + ;; + "hu") + DEBLANGUAGE="hu_HU.UTF-8" + ;; + "ja") + DEBLANGUAGE="ja_JP.UTF-8" + ;; + "nl") + DEBLANGUAGE="nl_NL.UTF-8" + ;; + "pt") + DEBLANGUAGE="pt_PT.UTF-8" + ;; + *) + printf "Language '%s' not handled currently. Run sudo raspi-config to set up" "$NOOBSLANGUAGE" + ;; + esac + + if [ -n "$DEBLANGUAGE" ]; then + printf "Setting language to %s based on os_config.json from NOOBS. May take a while\n" "$DEBLANGUAGE" + # TODO: map noobs language to Debian spec + cat << EOF | debconf-set-selections +locales locales/locales_to_be_generated multiselect fr_FR.UTF-8 UTF-8 +EOF + rm /etc/locale.gen + dpkg-reconfigure -f noninteractive locales + update-locale LANG=fr_FR.UTF-8 + cat << EOF | debconf-set-selections +locales locales/default_environment_locale select fr_FR.UTF-8 +EOF + fi + + if [ -n "$NOOBSKEYBOARD" -a "$NOOBSKEYBOARD" != "gb" ]; then + printf "Setting keyboard layout to %s based on os_config.json from NOOBS. May take a while\n" "$NOOBSKEYBOARD" + sed -i /etc/default/keyboard -e "s/^XKBLAYOUT.*/XKBLAYOUT=\"$NOOBSKEYBOARD\"/" + dpkg-reconfigure -f noninteractive keyboard-configuration + invoke-rc.d keyboard-setup start + fi + return 0 +} + # # Command line options for non-interactive use # @@ -509,6 +666,11 @@ do printf "Please reboot\n" exit 0 ;; + --apply-os-config) + INTERACTIVE=False + do_apply_os_config + exit $? + ;; *) # unknown option ;; @@ -585,7 +747,7 @@ while true; do FUN=$(whiptail --title "Raspberry Pi Software Configuration Tool (raspi-config)" --menu "Setup Options" $WT_HEIGHT $WT_WIDTH $WT_MENU_HEIGHT --cancel-button Finish --ok-button Select \ "1 Expand Filesystem" "Ensures that all of the SD card storage is available to the OS" \ "2 Change User Password" "Change password for the default user (pi)" \ - "3 Enable Boot to Desktop" "Choose whether to boot into a desktop environment or the command-line" \ + "3 Enable Boot to Desktop/Scratch" "Choose whether to boot into a desktop environment, Scratch, or the command-line" \ "4 Internationalisation Options" "Set up language and regional settings to match your location" \ "5 Enable Camera" "Enable this Pi to work with the Raspberry Pi Camera" \ "6 Add to Rastrack" "Add this Pi to the online Raspberry Pi Map (Rastrack)" \