self: { config, lib, pkgs, ... }: let unstable = import self.inputs.nixpkgs-unstable { system = pkgs.system; }; in { imports = [ ./firefox ./mail ./secrets.nix ./windowManagers self.homeManagerModules.default self.inputs.agenix.homeManagerModules.default self.inputs.nur.hmModules.nur ]; home = { homeDirectory = "/home/aly"; file = { "${config.xdg.cacheHome}/keepassxc/keepassxc.ini".text = lib.generators.toINI {} { General.LastActiveDatabase = "${config.home.homeDirectory}/sync/Passwords.kdbx"; }; }; packages = [ pkgs.browsh pkgs.curl pkgs.fractal pkgs.git pkgs.nicotine-plus pkgs.obsidian pkgs.picard pkgs.tauon pkgs.transmission-remote-gtk pkgs.webcord ]; stateVersion = "24.05"; username = "aly"; }; programs = { password-store = { enable = true; package = pkgs.pass.withExtensions (exts: with exts; [ pass-checkup pass-file pass-genphrase pass-otp pass-update ]); }; git = { enable = true; lfs.enable = true; userName = "Aly Raffauf"; userEmail = "aly@raffauflabs.com"; extraConfig = { color.ui = true; core.editor = "${lib.getExe unstable.zed-editor} --wait"; github.user = "alyraffauf"; push.autoSetupRemote = true; }; }; gitui.enable = true; home-manager.enable = true; }; systemd.user.startServices = "legacy"; # Needed for auto-mounting agenix secrets. ar.home = { apps = { backblaze = { enable = true; keyIdFile = config.age.secrets.backblazeKeyId.path; keyFile = config.age.secrets.backblazeKey.path; }; bash.enable = true; chromium.enable = true; fastfetch.enable = true; firefox.enable = true; helix.enable = true; keepassxc.enable = true; kitty.enable = true; tmux.enable = true; yazi.enable = true; zed = { enable = true; package = unstable.zed-editor; }; }; defaultApps = { enable = true; editor = config.ar.home.apps.zed.package; }; theme = { enable = true; wallpaper = "${config.xdg.dataHome}/backgrounds/wallhaven-5g6g33.jpg"; }; }; }