156 lines
3.7 KiB
Nix
156 lines
3.7 KiB
Nix
# Edit this configuration file to define what should be installed on
|
|
# your system. Help is available in the configuration.nix(5) man page and in the NixOS manual (accessible by running `nixos-help`).
|
|
{
|
|
config,
|
|
pkgs,
|
|
lib,
|
|
inputs,
|
|
outputs,
|
|
...
|
|
}: {
|
|
imports = [
|
|
# Include the results of the hardware scan.
|
|
./hardware-configuration.nix
|
|
];
|
|
|
|
# required for hostname specific configurations
|
|
networking.hostName = "sakotop"; # Define your hostname.
|
|
|
|
modules = {
|
|
desktop = {
|
|
wireguard.enable = true;
|
|
kitty.enable = true;
|
|
xmonad.enable = false;
|
|
bspwm = {
|
|
enable = false;
|
|
polybar.enable = true;
|
|
};
|
|
exwm.enable = true;
|
|
picom.enable = true;
|
|
dunst.enable = true;
|
|
browsers = {
|
|
firefox.enable = true;
|
|
qutebrowser.enable = false;
|
|
chromium.enable = true;
|
|
};
|
|
chat = {
|
|
whatsapp.enable = true;
|
|
zoom.enable = true;
|
|
discord.enable = true;
|
|
teams.enable = true;
|
|
telegram.enable = true;
|
|
};
|
|
apps = {
|
|
nemo.enable = true;
|
|
pass.enable = true;
|
|
keepassxc.enable = true;
|
|
bitwarden.enable = true;
|
|
rssguard.enable = true;
|
|
nicotineplus.enable = true;
|
|
transmission.enable = true;
|
|
calibre.enable = true;
|
|
kindle-comic-converter.enable = true;
|
|
mangal.enable = true;
|
|
obs.enable = true;
|
|
nextcloud.enable = true;
|
|
};
|
|
game = {
|
|
wine.enable = true;
|
|
lutris.enable = true;
|
|
steam.enable = true;
|
|
grapejuice.enable = true;
|
|
};
|
|
media = {
|
|
gimp.enable = true;
|
|
blender.enable = true;
|
|
kdenlive.enable = true;
|
|
mpv.enable = true;
|
|
};
|
|
};
|
|
hardware = {
|
|
nvidia = {
|
|
enable = true;
|
|
prime = {
|
|
enable = true;
|
|
intelBusId = "PCI:0:2:0";
|
|
nvidiaBusId = "PCI:1:0:0";
|
|
};
|
|
};
|
|
intelgputools.enable = true;
|
|
pipewire.enable = true;
|
|
bluetooth.enable = true;
|
|
};
|
|
dev = {
|
|
editors = {
|
|
nvim.enable = true;
|
|
emacs = {
|
|
enable = true;
|
|
daemon = true;
|
|
};
|
|
};
|
|
nil.enable = true;
|
|
cc.enable = true;
|
|
javascript.enable = true;
|
|
python.enable = true;
|
|
rust.enable = true;
|
|
lua.enable = true;
|
|
};
|
|
shell = {
|
|
nix = {
|
|
# makes nix search nixpkgs <example>
|
|
# ALOT faster
|
|
search.enable = true;
|
|
# optimize store
|
|
optimize.enable = true;
|
|
};
|
|
zsh.enable = true;
|
|
tmux.enable = true;
|
|
newsboat.enable = true;
|
|
ranger.enable = true;
|
|
};
|
|
media = {
|
|
mpd.enable = false;
|
|
mopidy.enable = false;
|
|
ncmpcpp.enable = true;
|
|
};
|
|
work = {
|
|
libreoffice.enable = true;
|
|
onlyoffice.enable = true;
|
|
};
|
|
security = {
|
|
age.enable = true;
|
|
sops.enable = true;
|
|
certs.enable = true;
|
|
};
|
|
};
|
|
|
|
# Enable CUPS to print documents.
|
|
# services.printing.enable = true;
|
|
|
|
services.xserver.videoDrivers = ["nvidia"];
|
|
|
|
# homelab
|
|
sops = {
|
|
# we need to setup wireguard with this soon
|
|
age.sshKeyPaths = ["/home/sako/.ssh/id_ed25519"];
|
|
};
|
|
|
|
networking.wireguard.interfaces = {
|
|
};
|
|
|
|
# Enable the OpenSSH daemon.
|
|
# services.openssh.enable = true;
|
|
|
|
# Open ports in the firewall.
|
|
# networking.firewall.allowedTCPPorts = [ ... ];
|
|
# networking.firewall.allowedUDPPorts = [ ... ];
|
|
# Or disable the firewall altogether.
|
|
# networking.firewall.enable = false;
|
|
|
|
# DO NOT CHANGE THIS!!!!
|
|
# ONLY CHANGE WHEN FULLY REINSTALLING
|
|
# OR USING NEW SYSTEMS
|
|
home-manager.users.sako.home.stateVersion = "23.05";
|
|
|
|
system.stateVersion = "23.05";
|
|
}
|