Added Cage as interface
This commit is contained in:
2
.gitignore
vendored
2
.gitignore
vendored
@@ -1,6 +1,7 @@
|
|||||||
# Nix build results
|
# Nix build results
|
||||||
result
|
result
|
||||||
result-*
|
result-*
|
||||||
|
*.qcow2
|
||||||
|
|
||||||
# Ignore everything in the secrets directory
|
# Ignore everything in the secrets directory
|
||||||
secrets/*
|
secrets/*
|
||||||
@@ -24,6 +25,7 @@ secrets/ssh-private
|
|||||||
# secrets (encrypted via sops, but extra safety)
|
# secrets (encrypted via sops, but extra safety)
|
||||||
secrets/*.yaml~
|
secrets/*.yaml~
|
||||||
|
|
||||||
|
|
||||||
# Editor
|
# Editor
|
||||||
.direnv/
|
.direnv/
|
||||||
.envrc
|
.envrc
|
||||||
|
|||||||
@@ -12,6 +12,7 @@
|
|||||||
../../nixos/roles/gitea.nix
|
../../nixos/roles/gitea.nix
|
||||||
../../nixos/roles/vaultwarden.nix
|
../../nixos/roles/vaultwarden.nix
|
||||||
../../nixos/roles/frontpage
|
../../nixos/roles/frontpage
|
||||||
|
../../nixos/roles/cage.nix
|
||||||
];
|
];
|
||||||
|
|
||||||
networking = {
|
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