143 lines
3.7 KiB
Nix
143 lines
3.7 KiB
Nix
{
|
|
pkgs,
|
|
lib,
|
|
config,
|
|
...
|
|
}:
|
|
|
|
# Define 'aires'
|
|
let
|
|
cfg = config.aux.system.users.aires;
|
|
in
|
|
{
|
|
options = {
|
|
aux.system.users.aires = {
|
|
enable = lib.mkEnableOption "Enables aires user account";
|
|
autologin = lib.mkEnableOption "Automatically logs aires in on boot";
|
|
|
|
services.syncthing = {
|
|
enable = lib.mkEnableOption "Enables Syncthing";
|
|
enableTray = lib.mkEnableOption "Enables the Syncthing Tray application";
|
|
home = lib.mkOption {
|
|
default = "${config.users.users.aires.home}/.config/syncthing";
|
|
type = lib.types.str;
|
|
description = "Where to store Syncthing's configuration files";
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
config = lib.mkIf cfg.enable (
|
|
lib.mkMerge [
|
|
{
|
|
users.users.aires = {
|
|
isNormalUser = true;
|
|
description = "Aires";
|
|
uid = 1000;
|
|
hashedPassword = config.secrets.users.aires.hashedPassword;
|
|
extraGroups = [
|
|
"input"
|
|
"networkmanager"
|
|
"plugdev"
|
|
"tss"
|
|
"wheel"
|
|
]; # tss group has access to TPM devices
|
|
|
|
# Allow systemd services to run even while aires is logged out
|
|
linger = true;
|
|
};
|
|
|
|
# Configure home-manager
|
|
home-manager.users.aires = {
|
|
imports = [
|
|
../common/home-manager/gnome.nix
|
|
../common/home-manager/zsh.nix
|
|
];
|
|
|
|
home = {
|
|
# The state version is required and should stay at the version you originally installed.
|
|
stateVersion = "24.05";
|
|
|
|
# Basic setup
|
|
username = "aires";
|
|
homeDirectory = "/home/aires";
|
|
|
|
# Create .face file
|
|
file.".face".source = ./face.png;
|
|
};
|
|
|
|
programs = {
|
|
# Let home Manager install and manage itself.
|
|
home-manager.enable = true;
|
|
|
|
# Set up git
|
|
git = {
|
|
enable = true;
|
|
userName = config.secrets.users.aires.firstName;
|
|
userEmail = config.secrets.users.aires.email;
|
|
extraConfig.push.autoSetupRemote = "true";
|
|
};
|
|
|
|
# Set up SSH
|
|
ssh = {
|
|
enable = true;
|
|
matchBlocks = config.secrets.users.aires.sshConfig;
|
|
};
|
|
|
|
# Set up Zsh
|
|
zsh = {
|
|
oh-my-zsh = {
|
|
theme = "gentoo";
|
|
};
|
|
shellAliases = {
|
|
nos = "nixos-upgrade-script";
|
|
z = "zellij";
|
|
update = "upgrade";
|
|
upgrade = "nos";
|
|
};
|
|
loginExtra = "fastfetch --memory-percent-green 75 --memory-percent-yellow 90";
|
|
};
|
|
};
|
|
};
|
|
}
|
|
|
|
# Autologin aires
|
|
(lib.mkIf cfg.autologin {
|
|
services.displayManager.autoLogin = {
|
|
enable = true;
|
|
user = "aires";
|
|
};
|
|
systemd.services = {
|
|
"getty@tty1".enable = false;
|
|
"autovt@tty1".enable = false;
|
|
};
|
|
})
|
|
|
|
# Enable Syncthing
|
|
(lib.mkIf cfg.services.syncthing.enable {
|
|
users.users.aires.packages = [
|
|
pkgs.syncthing
|
|
(lib.mkIf cfg.services.syncthing.enableTray pkgs.syncthingtray)
|
|
];
|
|
|
|
# Open port 8080
|
|
networking.firewall.allowedTCPPorts = [ 8080 ];
|
|
|
|
home-manager.users.aires = {
|
|
# Syncthing options
|
|
services.syncthing = {
|
|
enable = true;
|
|
extraOptions = [
|
|
"--gui-address=0.0.0.0:8080"
|
|
"--home=${cfg.services.syncthing.home}"
|
|
"--no-default-folder"
|
|
];
|
|
};
|
|
|
|
systemd.user.services."syncthing".Unit.RequiresMountsFor = cfg.services.syncthing.home;
|
|
};
|
|
})
|
|
]
|
|
);
|
|
}
|