Kiosk: различия между версиями
Vovan (обсуждение | вклад) (→Обновление ОС и ядра) |
Vovan (обсуждение | вклад) (→Обновление ОС и ядра) |
||
Строка 53: | Строка 53: | ||
apt-get install update-kernel | apt-get install update-kernel | ||
− | update-kernel - | + | update-kernel -f |
==Установка необходимых пакетов через apt-get== | ==Установка необходимых пакетов через apt-get== |
Версия 12:19, 16 сентября 2022
Содержание
- 1 Киоск на базе пустого образа Alt jeos
- 1.1 Образ для установки
- 1.2 Обновление ОС и ядра
- 1.3 Установка необходимых пакетов через apt-get
- 1.4 Установка браузера google-chrome через epm
- 1.5 Установка необходимых пакетов через npm
- 1.6 Установка LTS версии платформы nodejs и её пакетного менеджера npm
- 1.7 Создание и настройка пользователя kiosk
- 1.8 Создание стартового скрипта в домашнем каталоге пользователя kiosk
- 1.9 Конфигурирование оконного менеджера awesome на запуск единственного приложения в полноэкранном режиме
- 1.10 Конфигурирование X-сессии для запуска в дисплей менеджере gdm
- 1.11 Конфигурирование автоматического входа в систему под пользователем kiosk и установка по умолчанию сессии kiosk.desktop
Киоск на базе пустого образа Alt jeos
Образ для установки
Качаем отсюда, например средствами wget
wget https://mirror.yandex.ru/altlinux-starterkits/x86_64/release/alt-p10-jeos-systemd-20220910-x86_64.img.xz
Распаковываем (получим файл без .xz на конце)
unxz alt-p10-jeos-systemd-20220910-x86_64.img.xz
Пишем на носитель (например его у вас зовут /dev/sdb)
dd if=alt-p10-jeos-systemd-20220910-x86_64.img of=/dev/sdb
После записи не лишним будет взглянуть на носитель через gparted и увеличить файловую систему до физических размеров носителя (если нужно место в корне будущей ОС)
Рутовый пароль по умолчанию:
altlinux
Обновление ОС и ядра
В этом разделе всё делается в рутовой консоли. Т.к. sudo по умолчанию в ОС Альт не присутствует (ниже мы его добавим)
Примечание: Лучше сразу переключить репозиторий на зеркало яндекса. Для этого закоментируем всё в файле
/etc/apt/sources.list.d/alt.list
а файле
/etc/apt/sources.list.d/yandex.list
раскоментируем следующие строчки:
rpm [p10] http://mirror.yandex.ru/altlinux p10/branch/x86_64 classic rpm [p10] http://mirror.yandex.ru/altlinux p10/branch/x86_64-i586 classic rpm [p10] http://mirror.yandex.ru/altlinux p10/branch/noarch classic
Обновим индекс репозитория
apt-get update
Обновим дистрибутив (в рамках одной рабочей ветки. Например, P10)
apt-get dist-upgrade
Обновим ядро
apt-get install update-kernel update-kernel -f
Установка необходимых пакетов через apt-get
apt-get install nano xorg xorg-server xorg-server openssh sudo su xterm gnome3-minimal xhost awesome git npm gcc10-c++ gcc-c++ make
Установка браузера google-chrome через epm
epm play chrome
Установка необходимых пакетов через npm
да-да: npm умеет себя обновлять сам...
npm install -g npm
а этот пакет глобально устанавливается чтобы иметь возможность установки различных версий патформы nodejs
npm install -g n
Ещё важное отличие репозитория ОС Альт в том, что устанавливая npm оно не тащит за собой 100500 зависимостей и древнюю node из репозитория, а ставит только npm.
Установка LTS версии платформы nodejs и её пакетного менеджера npm
n lts
Создание и настройка пользователя kiosk
useradd kiosk
установка пароля делается командой
passwd kiosk
делаем sudo su без пароля для пользователя kiosk. Просто бросьте это в рутовую консоль:
cat << EOF > /etc/sudoers User_Alias WHEEL_USERS = %wheel User_Alias XGRP_USERS = %xgrp Defaults:XGRP_USERS env_keep += "DISPLAY XAUTHORITY" kiosk ALL=(ALL) NOPASSWD: ALL @includedir /etc/sudoers.d EOF
добавляем пользователя kiosk в группу wheel (для sudo su)
usermod kiosk -aG wheel
и в группу dialout (для доступа к устройствам /dev/tty*)
usermod kiosk -aG dialout
Создание стартового скрипта в домашнем каталоге пользователя kiosk
Скрипт запускает браузер google-chrome в режиме киоска и подгружает в него стартовую страницу ya.ru (в реальном применении здесь может быть запущено веб приложение, стартующее на локальном хосте (для этого стоит платформа nodejs))
Просто бросьте это в рутовый терминал:
cat << EOF > /home/kiosk/start.sh #!/bin/bash google-chrome --kiosk --disable-pinch "https://ya.ru" EOF
затем делаем хозяином скрипта пользователя kiosk и делаем его исполняемым
chown kiosk: /home/kiosk/start.sh chmod +x /home/kiosk/start.sh
Конфигурирование оконного менеджера awesome на запуск единственного приложения в полноэкранном режиме
Просто бросьте это в рутовую консоль:
cat << EOF > /etc/xdg/awesome/rc.lua -- If LuaRocks is installed, make sure that packages installed through it are -- found (e.g. lgi). If LuaRocks is not installed, do nothing. pcall(require, "luarocks.loader") -- Standard awesome library local gears = require("gears") local awful = require("awful") require("awful.autofocus") -- Widget and layout library local wibox = require("wibox") -- Theme handling library local beautiful = require("beautiful") require("menu") -- Notification library local naughty = require("naughty") local menubar = require("menubar") local hotkeys_popup = require("awful.hotkeys_popup") -- Enable hotkeys help widget for VIM and other apps -- when client with a matching name is opened: require("awful.hotkeys_popup.keys") -- {{{ Error handling -- Check if awesome encountered an error during startup and fell back to -- another config (This code will only ever execute for the fallback config) if awesome.startup_errors then naughty.notify({ preset = naughty.config.presets.critical, title = "Oops, there were errors during startup!", text = awesome.startup_errors }) end -- Handle runtime errors after startup do local in_error = false awesome.connect_signal("debug::error", function (err) -- Make sure we don't go into an endless error loop if in_error then return end in_error = true naughty.notify({ preset = naughty.config.presets.critical, title = "Oops, an error happened!", text = tostring(err) }) in_error = false end) end -- }}} -- {{{ Variable definitions -- Themes define colours, icons, font and wallpapers. beautiful.init(gears.filesystem.get_themes_dir() .. "default/theme.lua") -- This is used later as the default terminal and editor to run. terminal = "xterm" editor = os.getenv("EDITOR") or "nano" editor_cmd = terminal .. " -e " .. editor awful.screen.connect_for_each_screen(function(s) -- Each screen has its own tag table. awful.tag({ "1" }, s, awful.layout.layouts[1]) -- Create a promptbox for each screen s.mypromptbox = awful.widget.prompt() -- Create an imagebox widget which will contain an icon indicating which layout we're using. -- We need one layoutbox per screen. s.mylayoutbox = awful.widget.layoutbox(s) s.mylayoutbox:buttons(gears.table.join( awful.button({ }, 1, function () awful.layout.inc( 1) end), awful.button({ }, 3, function () awful.layout.inc(-1) end), awful.button({ }, 4, function () awful.layout.inc( 1) end), awful.button({ }, 5, function () awful.layout.inc(-1) end))) -- Create a taglist widget s.mytaglist = awful.widget.taglist { screen = s, filter = awful.widget.taglist.filter.all, buttons = taglist_buttons } -- Create a tasklist widget s.mytasklist = awful.widget.tasklist { screen = s, filter = awful.widget.tasklist.filter.currenttags, buttons = tasklist_buttons } -- Create the wibox s.mywibox = awful.wibar({ position = "top", screen = s }) -- Add widgets to the wibox s.mywibox:setup { layout = wibox.layout.align.horizontal, { -- Left widgets layout = wibox.layout.fixed.horizontal, mylauncher, s.mytaglist, s.mypromptbox, }, s.mytasklist, -- Middle widget { -- Right widgets layout = wibox.layout.fixed.horizontal, mykeyboardlayout, wibox.widget.systray(), mytextclock, s.mylayoutbox, }, } end) -- }}} -- {{{ Rules -- Rules to apply to new clients (through the "manage" signal). awful.rules.rules = { -- All clients will match this rule. { rule = { }, properties = { border_width = beautiful.border_width, border_color = beautiful.border_normal, focus = awful.client.focus.filter, raise = true, size_hints_honor = false, keys = clientkeys, buttons = clientbuttons, screen = awful.screen.preferred, placement = awful.placement.no_overlap+awful.placement.no_offscreen } }, } -- }}} -- {{{ Signals -- Signal function to execute when a new client appears. client.connect_signal("manage", function (c) -- Set the windows at the slave, -- i.e. put it at the end of others instead of setting it master. -- if not awesome.startup then awful.client.setslave(c) end if awesome.startup and not c.size_hints.user_position and not c.size_hints.program_position then -- Prevent clients from being unreachable after screen count changes. awful.placement.no_offscreen(c) end end) -- }}} awful.spawn("/home/kiosk/start.sh") EOF
Конфигурирование X-сессии для запуска в дисплей менеджере gdm
Просто бросьте это в рутовую консоль:
cat << EOF > /usr/share/xsessions/kiosk.desktop [Desktop Entry] Name=KIOSK Exec=/usr/bin/awesome TryExec=/usr/bin/gnome-session Type=Application DesktopNames=KIOSK X-GDM-SessionRegisters=true EOF
Конфигурирование автоматического входа в систему под пользователем kiosk и установка по умолчанию сессии kiosk.desktop
Просто бросьте это в консоль:
cat << EOF > /etc/X11/gdm/custom.conf # GDM configuration storage [daemon] # Uncomment the line below to force the login screen to use Xorg WaylandEnable=false AutomaticLoginEnable=true AutomaticLogin=kiosk #DefaultSession=gnome.desktop DefaultSession=kiosk.desktop [security] [xdmcp] [chooser] [debug] # Uncomment the line below to turn on debugging #Enable=true EOF