thinknix: enable guest user as a module

Introduce a guest user module that sets up a guest user with the default
desktop home packages through the home-manager NixOS module.

Enabled on thinknix.
This commit is contained in:
Trolli Schmittlauch 2024-08-07 00:32:03 +02:00
parent 8911511edc
commit 83858d6d11
4 changed files with 77 additions and 1 deletions

View file

@ -15,6 +15,7 @@ in
./nitrokey.nix ./nitrokey.nix
./nix-settings.nix ./nix-settings.nix
./upgrade-diff.nix ./upgrade-diff.nix
./guest.nix
]; ];
services.davfs2.enable = true; services.davfs2.enable = true;

66
common/guest.nix Normal file
View file

@ -0,0 +1,66 @@
{
config,
lib,
system,
...
}:
let
inputs = config.inputInjection.flake-inputs;
in
{
# interesting: this causes an infinite recursion
#imports = [ config.inputInjection.flake-inputs.home-manager.nixosModules.home-manager ];
options.schmittlauch.guestUser.enable = lib.options.mkEnableOption "Provide a guest user account";
config = lib.mkIf config.schmittlauch.guestUser.enable {
users.extraUsers.gast = {
isNormalUser = true;
group = "gast";
hashedPassword = "$y$j9T$pPCjU8ZvVYo0aY4jtrHPj1$NxUWOP/YTcqJ1PYaP1Hy5MwTeDcNjg0k369R5rE5M48";
};
users.groups.gast = { };
# a basic home-manager configuration to share installed packages of other accounts
# reason: keeping a separate config checkout for guests and requiring them to run
# their own `home-manager` instance does not make sense.
home-manager =
let
gast = config.users.extraUsers.gast;
in
{
useGlobalPkgs = false; # to allow usage of home-level overlays
# FIXME: possibly expose home modules through flake outputs instead of brittle path traversals
users.gast = {
imports = [
inputs.nur.hmModules.nur
../home/modules/packages.nix
];
home = {
username = gast.name;
homeDirectory = gast.home;
stateVersion = "24.05";
};
schmittlauch = {
packages = {
graphics = true;
multimedia = true;
nixHelpers = true;
devTools = true;
pythonTools = true;
games = true;
desktopLinux = true;
kde = true;
};
};
};
# Optionally use extraSpecialArgs
# to pass through arguments to home.nix
extraSpecialArgs = {
inherit inputs system;
};
};
};
}

View file

@ -59,7 +59,13 @@
flake-inputs = inputs; flake-inputs = inputs;
}; };
}; };
defaultModules = system: [ inputInjection ]; defaultModules = system: [
inputInjection
# for some reason, `imports`-ing the home-manager module via inputInjection
# from a sub-module causes infinite recursion, so importing it here instead
home-manager.nixosModules.home-manager
];
mkSystem = mkSystem =
system: extraModules: system: extraModules:
nixpkgs.lib.nixosSystem rec { nixpkgs.lib.nixosSystem rec {
@ -115,6 +121,7 @@
modules = [ modules = [
./darwin/configuration.nix ./darwin/configuration.nix
inputInjection inputInjection
]; ];
}; };
homeConfigurations = { homeConfigurations = {

View file

@ -22,6 +22,8 @@
speed = 180; speed = 180;
}; };
schmittlauch.guestUser.enable = true;
networking.hostName = "thinknix"; networking.hostName = "thinknix";
# This value determines the NixOS release with which your system is to be # This value determines the NixOS release with which your system is to be