nixos/hosts/sakowsl/configuration.nix
2024-10-12 22:42:23 +04:00

153 lines
3.6 KiB
Nix

{ lib, pkgs, config, modulesPath, inputs, outputs, ... }: {
imports = [
inputs.home-manager.nixosModules.default
"${modulesPath}/profiles/minimal.nix"
outputs.nixosModules.desktop
outputs.nixosModules.shell
outputs.nixosModules.hardware
outputs.nixosModules.dev
outputs.nixosModules.media
outputs.nixosModules.security
];
wsl = {
enable = true;
wslConf = {
automount = {
root = "/mnt";
# Allows writing to linux network section in Explorer
options = "metadata,uid=1000,gid=100,umask=22,fmask=11";
};
};
defaultUser = "sako";
startMenuLaunchers = true;
# Native systemd for wsl
nativeSystemd = true;
# Enable native Docker support
# docker-native.enable = true;
# Enable integration with Docker Desktop (needs to be installed)
# docker-desktop.enable = true;
};
users.users.sako.isNormalUser = true;
networking.hostName = "sakowsl";
# Enable nix flakes
nix.package = pkgs.nixFlakes;
nix.extraOptions = ''
experimental-features = nix-command flakes
'';
# nix.settings.experimental-features = ["nix-command" "flakes"];
nix.settings = {
experimental-features = [ "nix-command" "flakes" ];
substituters =
[ "https://cache.garnix.io" "https://nix-community.cachix.org" ];
trusted-public-keys = [
"cache.garnix.io:CTFPyKSLcx5RMJKfLo5EEPUObbA78b0YQ2DTCJXqr9g="
"nix-community.cachix.org-1:mB9FSh9qf2dCimDSUo8Zy7bkq5CX+/rkCWyvRCYg3Fs="
];
};
# Home manager setup
home-manager.useUserPackages = true;
home-manager.users.sako = { pkgs, ... }: {
home.stateVersion = "22.05";
home.packages = [ ];
home.username = "sako";
home.homeDirectory = "/home/sako";
xdg.configFile.git = { source = ../../config/git; };
# cure my sanity
home.pointerCursor = {
name = "Catppuccin-Mocha-Dark";
size = 16;
x11 = { enable = true; };
gtk.enable = true;
package = pkgs.catppuccin-cursors.mochaDark;
};
gtk = {
enable = true;
theme.name = "vimix-dark-ruby";
iconTheme.name = "Vimix Ruby Dark";
};
};
# gtk themes
programs.dconf.enable = true;
programs.gnupg.agent = {
enable = true;
#pinentryPackage = null;
settings = {
# pinentry-program = "/mnt/c/Program Files (x86)/Gpg4win/bin/pinentry.exe";
allow-emacs-pinentry = "";
allow-loopback-pinentry = "";
};
};
# bare minimum
environment.systemPackages = with pkgs; [
vim # backup
wget # double u get
killall # die processes
unzip # zip file
gh # github
htop # htop
tree # trees
wsl-open # wsl-open
];
programs.git = {
enable = true;
package = pkgs.gitFull;
};
modules = {
desktop = {
apps = {
nextcloud.enable = true;
pass.enable = true;
};
chat = { weechat.enable = true; };
};
dev = {
editors = {
nvim.enable = true;
emacs = {
enable = true;
daemon = true;
package = pkgs.emacs-unstable-pgtk;
};
};
cc.enable = true;
nil.enable = true;
lua.enable = true;
python.enable = true;
rust.enable = true;
javascript.enable = true;
};
shell = {
zsh.enable = true;
tmux.enable = true;
ranger.enable = true;
nix = {
optimize.enable = true;
search.enable = true;
};
};
security = { certs.enable = true; };
};
services.gnome.gnome-keyring.enable = true;
# for wsl-open
environment.sessionVariables = rec { BROWSER = "wsl-open"; };
security.sudo.wheelNeedsPassword = true;
system.stateVersion = "22.05";
}