summaryrefslogtreecommitdiff
path: root/users/timmy/default.nix
blob: 3a8a4e3ed46bc5849a1a3a9b1dbb38376d3798a9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
{ lib, config, pkgs, home-manager, ... }: let
	cfg = config._users.timmy;
	username = "timmy";
	fullname = "Tim Keller";
	home = "/home/${username}";
	sshKeyPaths = [ "${home}/.ssh/id_ed25519" ];
	#sshPublicKeyPaths = lib.map (keyPath: keyPath + ".pub") sshKeyPaths;
	sshPublicKeys = [ "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIDnsnAWcz46OVi1MWSxpOIUtUvwalijDwvW+oEvNjzep" ];
in {
	options._users.${username} = {
		enable = lib.mkEnableOption "create user ${username}";
		autologin.enable = lib.mkEnableOption "enables getty automatic login";
	};

	# FIXME
	imports = [
		./hosts.nix
		./localization.nix
		./nas.nix
		./printing.nix
		./repos.nix
		./user.nix
		./wifi.nix
	];

	config = lib.mkIf cfg.enable {
		# Setup zsh
		programs.zsh = {
			enable = true;
			_zshenv = {
				enable = true;
				exports = {
					ZDOTDIR = "$HOME/.config/zsh";
				};
			};
		};
		#environment.systemPackages = [ pkgs.zsh-fast-syntax-highlighting ];  # TODO

		# Setup normal user
		users.users.${username} = {
			inherit home;
			description = fullname;
			isNormalUser = true;
			shell = pkgs.zsh;
			extraGroups = [
				"nixbld"
				"video"
				"wheel"
			] ++ lib.optionals config.hardware.i2c.enable [
				"i2c"
			] ++ lib.optionals config.virtualisation.libvirtd.enable [
				"libvirtd"
			] ++ lib.optionals config.virtualisation.docker.enable [
				"docker"
			];
		};

		# Configure automatic login with getty
		services.getty = lib.mkIf cfg.autologin.enable {
			autologinUser = username;
		};

		# Configure sops age key paths since age keys are generated via ssh private key
		sops.age = { inherit sshKeyPaths; };

		# Add authorizedKeys to cgit service
		services._cgit.ssh.authorizedKeys = {
			keys = sshPublicKeys;
			#keyFiles = sshPublicKeyPaths;
		};

		# Configure user home
		home-manager.users.${username} = {
			imports = [ ./home.nix ];
			_users.${username}.home.enable = lib.mkDefault true;
		};
	};
}