Compare commits

...
Sign in to create a new pull request.

7 commits

Author SHA1 Message Date
vieta
2ee43d2269 base desktop + preseed v03 2025-12-28 16:40:15 +01:00
vieta
5663982dac base desktop + preseed v02 2025-12-28 16:18:12 +01:00
f397cb8a1c Merge pull request 'main' (#5) from vieta/preseed:main into main
Reviewed-on: #5
2025-12-28 15:49:58 +01:00
vieta
b29e81fe29 base desktop + preseed v01 2025-12-27 15:25:20 +01:00
vieta
4cf6e46a7b base desktop 2025-12-27 15:18:10 +01:00
2d771638b4
feat: Replaces nix dependencies from container 2025-12-26 16:00:55 +01:00
b828dcd15f
feat: Adds build pipeline 2025-12-26 12:06:44 +01:00
19 changed files with 398 additions and 3 deletions

49
.github/workflows/kiosk-iso.yml vendored Normal file
View file

@ -0,0 +1,49 @@
name: Build NixOS Kiosk ISO
on:
push:
branches: [ profile-install ]
workflow_dispatch:
jobs:
flake-check:
runs-on: ubuntu-latest
env:
NIX_CONFIG: extra-experimental-features = nix-command flakes
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Install Nix
run: |
curl -L https://nixos.org/nix/install | sh
. /home/runner/.nix-profile/etc/profile.d/nix.sh
nix --version
- name: Flake check
run: nix flake check -L
build-iso:
runs-on: ubuntu-latest
needs: [ flake-check ]
env:
NIX_CONFIG: extra-experimental-features = nix-command flakes
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Install Nix
run: |
curl -L https://nixos.org/nix/install | sh
. /home/runner/.nix-profile/etc/profile.d/nix.sh
nix --version
- name: Build ISO
run: |
nix --version
nix build .#iso -L --system x86_64-linux
ls -la result
mkdir -p artifacts
cp -v result/iso/*.iso artifacts/
- name: Upload ISO artifact
uses: actions/upload-artifact@v4
with:
name: kiosk-iso
path: artifacts/*.iso
if-no-files-found: error

8
desktop/README.md Normal file
View file

@ -0,0 +1,8 @@
# Kioskmodus
- Firefox autostart
- Sway
- Restart Firefox via short cut: ALT+Enter
- Close Firefox via short cut: ALT+Q
## Systemd Service für restart
- Inaktiv wegen wayland

20
desktop/config.toml Executable file
View file

@ -0,0 +1,20 @@
[terminal]
# The VT to run the greeter on. Can be "next", "current" or a number
# designating the VT.
vt = 1
# The default session, also known as the greeter.
[default_session]
# with whatever you want started, such as `sway`.
command = "sway --config /etc/kiosk-setting/sway/config"
# if using wlgreet
#command = "sway --config /etc/greetd/sway-config"
# The user to run the command as. The privileges this user must have depends
# on the greeter. A graphical greeter may for example require the user to be
# in the `video` group.
user = "kiosk"
[initial_session]
command = "sway'"
user = "kiosk"

2
desktop/firefox.sh Executable file
View file

@ -0,0 +1,2 @@
#!/bin/bash
killall firefox && firefox --kiosk mahn.ke/kiosk

163
desktop/kiosk-setting/sway/config Executable file
View file

@ -0,0 +1,163 @@
# Default config for sway
#
# Copy this to ~/.config/sway/config and edit it to your liking.
#
# Read `man 5 sway` for a complete reference.
#exec firefox kiosk mahn.ke/kiosk
### Variables
#
# Logo key. Use Mod1 for Alt.
set $mod Mod1
# Home row direction keys, like vim
#set $left h
#set $down j
#set $up k
#set $right l
# Your preferred application launcher
set $menu wmenu-run
include /etc/sway/config-vars.d/*
bindsym $mod+Return firefox kiosk mahn.ke/kiosk
bindsym $mod+q kill
# Start your launcher
# bindsym $mod+d exec $menu
# floating_modifier $mod normal
# Reload the configuration file
# bindsym $mod+Shift+c reload
# Exit sway (logs you out of your Wayland session)
bindsym $mod+Shift+e exec swaynag -t warning -m 'You pressed the exit shortcut. Do you really want to exit sway? This will end your Wayland session.' -B 'Yes, exit sway' 'swaymsg exit'
#
# Move your focus around
#bindsym $mod+$left focus left
#bindsym $mod+$down focus down
#bindsym $mod+$up focus up
#bindsym $mod+$right focus right
# Or use $mod+[up|down|left|right]
#bindsym $mod+Left focus left
#bindsym $mod+Down focus down
#bindsym $mod+Up focus up
#bindsym $mod+Right focus right
# Move the focused window with the same, but add Shift
#bindsym $mod+Shift+$left move left
#bindsym $mod+Shift+$down move down
#bindsym $mod+Shift+$up move up
#bindsym $mod+Shift+$right move right
# Ditto, with arrow keys
# bindsym $mod+Shift+Left move left
# bindsym $mod+Shift+Down move down
# bindsym $mod+Shift+Up move up
#bindsym $mod+Shift+Right move right
#
# Workspaces:
#
# Switch to workspace
# bindsym $mod+1 workspace number 1
# bindsym $mod+2 workspace number 2
# bindsym $mod+3 workspace number 3
# bindsym $mod+4 workspace number 4
# bindsym $mod+5 workspace number 5
#bindsym $mod+6 workspace number 6
#bindsym $mod+7 workspace number 7
#bindsym $mod+8 workspace number 8
#bindsym $mod+9 workspace number 9
#bindsym $mod+0 workspace number 10
# Move focused container to workspace
#bindsym $mod+Shift+1 move container to workspace number 1
#bindsym $mod+Shift+2 move container to workspace number 2
#bindsym $mod+Shift+3 move container to workspace number 3
#bindsym $mod+Shift+4 move container to workspace number 4
#bindsym $mod+Shift+5 move container to workspace number 5
#bindsym $mod+Shift+6 move container to workspace number 6
#bindsym $mod+Shift+7 move container to workspace number 7
#bindsym $mod+Shift+8 move container to workspace number 8
#bindsym $mod+Shift+9 move container to workspace number 9
#bindsym $mod+Shift+0 move container to workspace number 10
# Note: workspaces can have any name you want, not just numbers.
# We just use 1-10 as the default.
#
# Layout stuff:
#
# You can "split" the current object of your focus with
# $mod+b or $mod+v, for horizontal and vertical splits
# respectively.
#bindsym $mod+b splith
#bindsym $mod+v splitv
# Switch the current container between different layout styles
#bindsym $mod+s layout stacking
#bindsym $mod+w layout tabbed
#bindsym $mod+e layout toggle split
# Make the current focus fullscreen
#bindsym $mod+f fullscreen
# Toggle the current focus between tiling and floating mode
#bindsym $mod+Shift+space floating toggle
# Swap focus between the tiling area and the floating area
#bindsym $mod+space focus mode_toggle
# Move focus to the parent container
#bindsym $mod+a focus parent
#
# Scratchpad:
#
# Sway has a "scratchpad", which is a bag of holding for windows.
# You can send windows there and get them back later.
# Move the currently focused window to the scratchpad
#bindsym $mod+Shift+minus move scratchpad
# Show the next scratchpad window or hide the focused scratchpad window.
# If there are multiple scratchpad windows, this command cycles through them.
#bindsym $mod+minus scratchpad show
#
# Resizing containers:
#
#mode "resize" {
# left will shrink the containers width
# right will grow the containers width
# up will shrink the containers height
# down will grow the containers height
# bindsym $left resize shrink width 10px
# bindsym $down resize grow height 10px
# bindsym $up resize shrink height 10px
# bindsym $right resize grow width 10px
# Ditto, with arrow keys
# bindsym Left resize shrink width 10px
# bindsym Down resize grow height 10px
# bindsym Up resize shrink height 10px
# bindsym Right resize grow width 10px
# Return to default mode
# bindsym Return mode "default"
# bindsym Escape mode "default"
#}
#bindsym $mod+r mode "resize"
#
# Utilities:
#
# Special keys to adjust volume via PulseAudio
# bindsym --locked XF86AudioMute exec pactl set-sink-mute \@DEFAULT_SINK@ toggle
# bindsym --locked XF86AudioLowerVolume exec pactl set-sink-volume \@DEFAULT_SINK@ -5%
# bindsym --locked XF86AudioRaiseVolume exec pactl set-sink-volume \@DEFAULT_SINK@ +5%
#bindsym --locked XF86AudioMicMute exec pactl set-source-mute \@DEFAULT_SOURCE@ toggle
# Special keys to adjust brightness via brightnessctl
# bindsym --locked XF86MonBrightnessDown exec brightnessctl set 5%-
# bindsym --locked XF86MonBrightnessUp exec brightnessctl set 5%+
# Special key to take a screenshot with grim
# bindsym Print exec grim
#
# Status Bar:
#
# Read `man 5 sway-bar` for more information about this section.
include /etc/sway/config.d/*

View file

@ -0,0 +1,9 @@
# import variables into system-user enviroment
# based on the instructions in the sway wiki
# see also https://github.com/swaywm/sway/issues/5732
# and https://github.com/systemd/systemd/blob/dfc637d0ff756889e8e5b7cb4ec991eb06069aa1/xorg/50-systemd-user.sh
exec systemctl --user import-environment DISPLAY WAYLAND_DISPLAY SWAYSOCK XDG_CURRENT_DESKTOP
exec hash dbus-update-activation-environment 2>/dev/null && \
dbus-update-activation-environment --systemd DISPLAY WAYLAND_DISPLAY SWAYSOCK XDG_CURRENT_DESKTOP=sway

View file

@ -0,0 +1,5 @@
#!/bin/bash
while true; do
./firefox.sh
sleep 1
done

6
desktop/setup.sh Executable file
View file

@ -0,0 +1,6 @@
#!/bin/sh
sudo apt install greetd sway && \
sudo cp -r desktop/kiosk-setting/ /etc/ && \
sudo cp config.toml /etc/greetd/config.toml && \
sudo reboot

BIN
desktop/sway/.config.swp Executable file

Binary file not shown.

104
desktop/sway/config Executable file
View file

@ -0,0 +1,104 @@
set $mod Mod4
# Home row direction keys, like vim
set $left h
set $down j
set $up k
set $right l
# Your preferred terminal emulator
set $term konsole
# Your preferred application launcher
set $menu wmenu-run
default_border none
include /etc/sway/config-vars.d/*
exec firefox-esr
# Basics:
#
# Start a terminal
bindsym $mod+Space exec firefox-esr
bindsym $mod+Return exec killall firefox-esr && firefox-esr
# Kill focused window
bindsym $mod+Shift+q kill
# Start your launcher
# Drag floating windows by holding down $mod and left mouse button.
# Resize them with right mouse button + $mod.
# Despite the name, also works for non-floating windows.
# Change normal to inverse to use left mouse button for resizing and right
# mouse button for dragging.
floating_modifier $mod normal
# Reload the configuration file
bindsym $mod+Shift+c reload
# Exit sway (logs you out of your Wayland session)
bindsym $mod+Shift+e exec swaynag -t warning -m 'You pressed the exit shortcut. Do you really want to exit sway? This will end your Wayland session.' -B 'Yes, exit sway' 'swaymsg exit'
# Move your focus around
bindsym $mod+$left focus left
bindsym $mod+$down focus down
bindsym $mod+$up focus up
bindsym $mod+$right focus right
# Or use $mod+[up|down|left|right]
bindsym $mod+Left focus left
bindsym $mod+Down focus down
bindsym $mod+Up focus up
bindsym $mod+Right focus right
# Move the focused window with the same, but add Shift
bindsym $mod+Shift+$left move left
bindsym $mod+Shift+$down move down
bindsym $mod+Shift+$up move up
bindsym $mod+Shift+$right move right
# Ditto, with arrow keys
bindsym $mod+Shift+Left move left
bindsym $mod+Shift+Down move down
bindsym $mod+Shift+Up move up
bindsym $mod+Shift+Right move right
# Show the next scratchpad window or hide the focused scratchpad window.
# If there are multiple scratchpad windows, this command cycles through them.
bindsym $mod+minus scratchpad show
#
# Resizing containers:
#
mode "resize" {
# left will shrink the containers width
# right will grow the containers width
# up will shrink the containers height
# down will grow the containers height
bindsym $left resize shrink width 10px
bindsym $down resize grow height 10px
bindsym $up resize shrink height 10px
bindsym $right resize grow width 10px
# Ditto, with arrow keys
bindsym Left resize shrink width 10px
bindsym Down resize grow height 10px
bindsym Up resize shrink height 10px
bindsym Right resize grow width 10px
# Return to default mode
bindsym Return mode "default"
bindsym Escape mode "default"
}
#
# Utilities:
#
# Special keys to adjust volume via PulseAudio
bindsym --locked XF86AudioMute exec pactl set-sink-mute \@DEFAULT_SINK@ toggle
bindsym --locked XF86AudioLowerVolume exec pactl set-sink-volume \@DEFAULT_SINK@ -5%
bindsym --locked XF86AudioRaiseVolume exec pactl set-sink-volume \@DEFAULT_SINK@ +5%
bindsym --locked XF86AudioMicMute exec pactl set-source-mute \@DEFAULT_SOURCE@ toggle
# Special keys to adjust brightness via brightnessctl
bindsym --locked XF86MonBrightnessDown exec brightnessctl set 5%-
bindsym --locked XF86MonBrightnessUp exec brightnessctl set 5%+
# Special key to take a screenshot with grim
bindsym Print exec grim
#
# Status Bar:
#
include /etc/sway/config.d/*

View file

@ -0,0 +1,9 @@
# import variables into system-user enviroment
# based on the instructions in the sway wiki
# see also https://github.com/swaywm/sway/issues/5732
# and https://github.com/systemd/systemd/blob/dfc637d0ff756889e8e5b7cb4ec991eb06069aa1/xorg/50-systemd-user.sh
exec systemctl --user import-environment DISPLAY WAYLAND_DISPLAY SWAYSOCK XDG_CURRENT_DESKTOP
exec hash dbus-update-activation-environment 2>/dev/null && \
dbus-update-activation-environment --systemd DISPLAY WAYLAND_DISPLAY SWAYSOCK XDG_CURRENT_DESKTOP=sway

11
desktop/sway/ffrun.sh Executable file
View file

@ -0,0 +1,11 @@
#!/usr/bin/env bash
APP_NAME="firefox-esr"
APP_COMMAND="firefox-esr"
while true; do
if ! pgrep -x "$APP_NAME" > /dev/null; then
swaymsg exec "$APP_COMMAND"
fi
sleep 1 # Wait a second before checking again
done

1
desktop/sway/preseed Submodule

@ -0,0 +1 @@
Subproject commit 84281c058648cd18ee702d772766cf1a170670e8

8
post_install.sh → profile/post_install.sh Normal file → Executable file
View file

@ -1,4 +1,6 @@
#!/usr/bin/env bash
printf "[daemon]\nAutomaticLoginEnable=true\nAutomaticLogin=kiosk\n\n[security]\n\n[xdmcp]\n\n[chooser]\n\n[debug]\n" > /etc/gdm3/daemon.conf printf "[daemon]\nAutomaticLoginEnable=true\nAutomaticLogin=kiosk\n\n[security]\n\n[xdmcp]\n\n[chooser]\n\n[debug]\n" > /etc/gdm3/daemon.conf
mkdir -p /usr/lib/firefox-esr/distribution mkdir -p /usr/lib/firefox-esr/distribution
tee /usr/lib/firefox-esr/distribution/policies.json > /dev/null <<'EOF' tee /usr/lib/firefox-esr/distribution/policies.json > /dev/null <<'EOF'
{ {
@ -6,7 +8,7 @@ tee /usr/lib/firefox-esr/distribution/policies.json > /dev/null <<'EOF'
"DisableDeveloperTools": true, "DisableDeveloperTools": true,
"BlockAboutAddons": true, "BlockAboutAddons": true,
"BlockAboutConfig": true, "BlockAboutConfig": true,
"BlockAboutProfiles": true, "BlockAboutProf#!/usr/bin/env basshiles": true,
"BlockAboutSupport": true, "BlockAboutSupport": true,
"DisableFirefoxAccounts": true, "DisableFirefoxAccounts": true,
"DisablePrivateBrowsing": true, "DisablePrivateBrowsing": true,
@ -57,6 +59,6 @@ chown -R kiosk:kiosk /home/kiosk/.config
tee /home/kiosk/.bash_profile > /dev/null <<'EOF' tee /home/kiosk/.bash_profile > /dev/null <<'EOF'
if [ -z "$WAYLAND_DISPLAY" ] && [ "$(tty)" = "/dev/tty1" ]; then if [ -z "$WAYLAND_DISPLAY" ] && [ "$(tty)" = "/dev/tty1" ]; then
exec cage firefox --kiosk https://c3nav.de exec cage firefox --kiosk mahn.ke/kiosk
fi fi
EOF EOF

6
setup.sh Executable file
View file

@ -0,0 +1,6 @@
#!/usr/bin/env bash
apt install gdm3 greetd sway && \
cp -r desktop/kiosk-setting/ /etc/ && \
cp config.toml /etc/greetd/config.toml && \
systemctl enable gdm3 && \ # greetd if gdm3 is buggy
./profile/post_install.sh