Added Cage as interface
This commit is contained in:
2
.gitignore
vendored
2
.gitignore
vendored
@@ -1,6 +1,7 @@
|
||||
# Nix build results
|
||||
result
|
||||
result-*
|
||||
*.qcow2
|
||||
|
||||
# Ignore everything in the secrets directory
|
||||
secrets/*
|
||||
@@ -24,6 +25,7 @@ secrets/ssh-private
|
||||
# secrets (encrypted via sops, but extra safety)
|
||||
secrets/*.yaml~
|
||||
|
||||
|
||||
# Editor
|
||||
.direnv/
|
||||
.envrc
|
||||
|
||||
@@ -12,6 +12,7 @@
|
||||
../../nixos/roles/gitea.nix
|
||||
../../nixos/roles/vaultwarden.nix
|
||||
../../nixos/roles/frontpage
|
||||
../../nixos/roles/cage.nix
|
||||
];
|
||||
|
||||
networking = {
|
||||
|
||||
48
nixos/roles/cage.nix
Normal file
48
nixos/roles/cage.nix
Normal file
@@ -0,0 +1,48 @@
|
||||
{ pkgs, ... }:
|
||||
let
|
||||
kiosk-url = "https://www.cyperpunk.de";
|
||||
kiosk-user = "kiosk";
|
||||
kiosk-program =
|
||||
"${pkgs.chromium}/bin/chromium "
|
||||
+ "--kiosk "
|
||||
+ "--app=${kiosk-url} "
|
||||
+ "--noerrdialogs "
|
||||
+ "--disable-infobars "
|
||||
+ "--no-first-run "
|
||||
+ "--disable-translate "
|
||||
+ "--disable-features=TranslateUI "
|
||||
+ "--autoplay-policy=no-user-gesture-required "
|
||||
+ "--enable-features=WebUIDarkMode "
|
||||
+ "--force-dark-mode ";
|
||||
in
|
||||
{
|
||||
environment = {
|
||||
systemPackages = [
|
||||
pkgs.cage
|
||||
pkgs.chromium
|
||||
];
|
||||
|
||||
variables = {
|
||||
XKB_DEFAULT_LAYOUT = "de";
|
||||
XKB_DEFAULT_VARIANT = "mac";
|
||||
XKB_DEFAULT_OPTIONS = "terminate:ctrl_alt_bksp";
|
||||
};
|
||||
|
||||
loginShellInit = ''
|
||||
if [ "$(tty)" = "/dev/tty1" ] && [ "$USER" = "${kiosk-user}" ]; then
|
||||
export XDG_CONFIG_HOME=/home/${kiosk-user}/.config
|
||||
export XDG_CACHE_HOME=/home/${kiosk-user}/.cache
|
||||
exec ${pkgs.cage}/bin/cage -s -- ${kiosk-program}
|
||||
fi
|
||||
'';
|
||||
};
|
||||
|
||||
services.getty.autologinUser = kiosk-user;
|
||||
|
||||
users.users.${kiosk-user} = {
|
||||
isNormalUser = true;
|
||||
home = "/home/${kiosk-user}";
|
||||
createHome = true;
|
||||
};
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user