system/users/jan/default.nix

176 lines
5.1 KiB
Nix
Raw Normal View History

2024-08-16 01:37:26 +03:00
{ config, pkgs, lib, inputs, globalData, packagesPath, ... }:
2024-04-16 02:51:46 +03:00
{
2024-05-21 20:39:19 +03:00
imports = [./davmail.secret.nix];
2024-04-16 02:51:46 +03:00
nixpkgs.overlays = lib.mkAfter [
inputs.nil.overlays.nil
2024-04-16 02:51:46 +03:00
inputs.wired.overlays.default
];
programs.zsh.enable = true;
nix.settings.trusted-users = lib.mkAfter [ "jan" ];
age.secrets.users-jan-passfile.file = ./users-jan-passfile.age;
users.users.jan = {
isNormalUser = true;
extraGroups = [
"wheel" # Enable sudo for the user.
(lib.mkIf config.networking.networkmanager.enable "networkmanager")
(lib.mkIf config.virtualisation.docker.enable "docker")
(lib.mkIf config.services.transmission.enable "transmission")
(lib.mkIf config.services.kubo.enable config.services.kubo.group)
(lib.mkIf config.programs.adb.enable "adbusers")
(lib.mkIf config.programs.adb.enable "plugdev")
(lib.mkIf config.hardware.pulseaudio.systemWide "pulse-access")
];
shell = pkgs.zsh;
hashedPasswordFile = config.age.secrets.users-jan-passfile.path;
openssh.authorizedKeys.keys = globalData.publicKeys.users.jan;
};
users.groups.plugdev = lib.mkIf config.programs.adb.enable { };
networking.firewall.allowedUDPPorts =
let lanMouseCfg = config.home-manager.users.jan.local.services.lan-mouse;
in lib.optional lanMouseCfg.enable lanMouseCfg.settings.port;
2024-05-21 20:39:19 +03:00
# Required to use MS Exchange in aerc
services.davmail = {
enable = true;
url = "https://outlook.office365.com/EWS/Exchange.asmx";
config.davmail = {
allowRemote = false;
ssl = {
nosecurecaldav = false;
nosecureimap = false;
nosecureldap = false;
nosecuresmtp = false;
};
mode = "O365Manual";
};
};
2024-04-16 02:51:46 +03:00
home-manager.users.jan = {
imports = [
./email_accounts.secret.nix
2024-05-21 23:13:44 +03:00
./calendars.secret.nix
2024-08-05 17:04:53 +03:00
./ssh.secret.nix
2024-04-16 02:51:46 +03:00
./git
];
################################################################################
# Configs
################################################################################
local.keyboard = {
enable = true;
variant = "dvorak,";
};
local.window-manager = {
2024-04-22 23:43:16 +03:00
xmonad.enable = lib.mkDefault true;
polybar.enable = lib.mkDefault true;
2024-04-16 02:51:46 +03:00
};
2024-04-22 23:43:16 +03:00
xdg.enable = lib.mkDefault true;
2024-04-16 02:51:46 +03:00
2024-04-22 23:43:16 +03:00
local.shell.enable = lib.mkDefault true;
2024-04-16 02:51:46 +03:00
################################################################################
# Programs
################################################################################
2024-04-24 01:03:36 +03:00
local.programs.terminals = {
wezterm.enable = lib.mkDefault config.local.window-manager.xmonad.enable;
foot.enable = lib.mkDefault (!config.local.window-manager.xmonad.enable);
};
2024-04-16 02:51:46 +03:00
local.programs.editors.neovim = {
enable = lib.mkDefault true;
defaultEditor = lib.mkDefault true;
ltex.enable = lib.mkDefault true;
};
2024-04-16 02:51:46 +03:00
local.programs.file-managers.vifm.enable = lib.mkDefault true;
2024-09-05 18:46:53 +03:00
local.programs.file-managers.nnn = {
enable = true;
package = pkgs.unstable.nnn;
};
2024-04-16 02:51:46 +03:00
local.programs.aerc.enable = lib.mkDefault true;
local.programs.dev-tools = {
base.enable = lib.mkDefault true;
nix.enable = lib.mkDefault true;
web.enable = lib.mkDefault true;
psql = {
enable = lib.mkDefault true;
2024-09-05 18:46:53 +03:00
package = lib.mkDefault pkgs.postgresql_16;
2024-04-16 02:51:46 +03:00
};
eza.enable = lib.mkDefault true;
direnv.enable = lib.mkDefault true;
zoxide.enable = lib.mkDefault true;
};
local.programs.share-files.croc.enable = lib.mkDefault true;
local.programs.flameshot.enable = lib.mkDefault true;
local.programs.argos-translate.enable = lib.mkDefault true;
################################################################################
# Services
################################################################################
local.services.wired.enable = lib.mkDefault true;
local.services.lan-mouse = {
# x11 input capture not available: not implemented
enable = lib.mkDefault false;
settings = {
# releaseBind = [ "KeyLeftCtrl" "KeyLeftShift" "KeyF1" ];
port = lib.mkDefault 32000;
frontend = "cli";
};
};
2024-04-16 02:51:46 +03:00
2024-04-18 16:01:30 +03:00
services.pass-secret-service = lib.mkIf config.local.programs.pass.enable {
enable = true;
storePath = config.home-manager.users.jan.home.sessionVariables.PASSWORD_STORE_DIR;
};
home.sessionVariables = lib.mkIf config.local.programs.pass.enable {
PASSWORD_STORE_DIR = "${config.home-manager.users.jan.xdg.dataHome}/pass/store";
};
2024-04-16 02:51:46 +03:00
################################################################################
# Packages
################################################################################
home.packages = with pkgs.unstable; [
image-roll
# vlc
2024-04-16 02:51:46 +03:00
# tools
procs
bottom
2024-05-23 01:38:13 +03:00
jq
2024-08-07 02:42:16 +03:00
nodePackages.vscode-langservers-extracted # html, css, json, eslint
2024-08-16 01:37:26 +03:00
(pkgs.callPackage (packagesPath + /micro-agent) {})
2024-04-16 02:51:46 +03:00
];
home.file = {
"pictures/wallpapers" = {
source = ./wallpapers;
recursive = true;
};
};
home.stateVersion = config.system.stateVersion;
};
}