forked from extern/nix-config
334 lines
8.4 KiB
Nix
334 lines
8.4 KiB
Nix
{ config, pkgs, lib, ... }:
|
|
|
|
{
|
|
imports = [ ./hosts/laptop.nix ];
|
|
|
|
boot.loader.systemd-boot.enable = true;
|
|
boot.loader.efi.canTouchEfiVariables = true;
|
|
|
|
networking.hostName = "nixos";
|
|
networking.networkmanager.enable = true;
|
|
networking.networkmanager.unmanaged = [ "interface-name:ve-*" ];
|
|
networking.networkmanager.dns = "none";
|
|
networking.useHostResolvConf = true;
|
|
services.udisks2.enable = true;
|
|
security.pam.services.swaylock = { };
|
|
|
|
services.vnstat.enable = true;
|
|
services.tumbler.enable = true;
|
|
services.xserver.displayManager.sddm.enable = true;
|
|
|
|
programs.fish.enable = true;
|
|
users.defaultUserShell = pkgs.fish;
|
|
environment.shells = with pkgs; [ fish ];
|
|
programs.fish.shellAbbrs = {
|
|
g = "git";
|
|
ga = "git add";
|
|
gaa = "git add --all";
|
|
gap = "git add --patch";
|
|
gb = "git branch"; # List all branches
|
|
gc = "git commit -m";
|
|
gca = "git commit --amend";
|
|
gcl = "git clone";
|
|
gco = "git checkout";
|
|
gd = "git diff"; # Show all file changes not staged yet
|
|
gdi = "git difftool --no-symlinks --dir-diff";
|
|
gds = "git diff --staged"; # Show changes staged but not committed
|
|
gdsi = "git difftool --no-symlinks --dir-diff --staged";
|
|
gi = "git init";
|
|
gl = "git log --oneline --decorate --all --graph -n 10";
|
|
gm = "git merge";
|
|
gp = "git push"; # Push your commits to a remote server
|
|
gr = "git reset HEAD~"; # Undo the last commit but keep changed files
|
|
gra = "git remote add";
|
|
gre = "git remote --verbose"; # List all remotes
|
|
grh = "git reset HEAD";
|
|
grr =
|
|
"git reset --hard HEAD~"; # Remove the last commit and all changes with it
|
|
gs = "git status";
|
|
gst = "git stash";
|
|
gstp = "git stash pop";
|
|
gt = "git tag";
|
|
gts = "git tag -s";
|
|
|
|
d = "sudo docker";
|
|
dc = "sudo docker-compose";
|
|
dcu = "sudo docker-compose up";
|
|
dcd = "sudo docker-compose down";
|
|
dcp = "sudo docker-compose pull";
|
|
dcl = "sudo docker-compose logs";
|
|
|
|
y = "yarn";
|
|
ya = "yarn add";
|
|
yar = "yarn remove";
|
|
yi = "yarn init";
|
|
yin = "yarn install";
|
|
yu = "yarn upgrade-interactive";
|
|
|
|
v = "vagrant";
|
|
vu = "vagrant up";
|
|
vh = "vagrant halt";
|
|
vs = "vagrant ssh";
|
|
vp = "vagrant provision";
|
|
|
|
dl = "yt-dlp";
|
|
vol =
|
|
"amixer set 'Master'"; # Change the volume, e.g. vol 10%+, vol 10%-, vol 100%
|
|
copy = "xclip -sel clip <"; # Easily copy the contents of any file
|
|
cf = "tput reset"; # Clear the terminal completely
|
|
nf =
|
|
"tput reset; and neofetch --size 56%; and xdotool key --delay 100 Ctrl+Shift+Page_Up";
|
|
df = "df --human-readable --type=ext4 --total";
|
|
du = "du --human-readable --summarize";
|
|
jis =
|
|
"recode shift_jis..utf8"; # Easily convert shift_jis-encoded files to utf8
|
|
utf16 =
|
|
"recode utf16..utf8"; # Rarely, some files from Japan are utf16 instead
|
|
jp = "LANG=ja_JP.UTF-8 LC_ALL=ja_JP.UTF-8";
|
|
|
|
a = "ansible-playbook";
|
|
b = "feh --bg-fill"; # Change the background
|
|
c = "clear"; # Because 5 letters is too much
|
|
e = "exit";
|
|
k = "kitty @ set-colors -c -a ~/.cache/wal/kitty";
|
|
l = "ls -l";
|
|
p = "paru";
|
|
r = "ranger";
|
|
w = "wal -o ~/.config/wal/done.sh";
|
|
T = "tree";
|
|
|
|
nano = "vim"; # The explanation is in the name
|
|
emacs = "vim"; # No need to start another operating system
|
|
};
|
|
|
|
time.timeZone = "America/New_York";
|
|
|
|
i18n.defaultLocale = "en_US.UTF-8";
|
|
i18n.supportedLocales =
|
|
[ "en_US.UTF-8/UTF-8" "ja_JP.UTF-8/UTF-8" "fr_FR.UTF-8/UTF-8" ];
|
|
|
|
services.xserver.enable = true;
|
|
programs.thunar.enable = true;
|
|
|
|
programs.starship = {
|
|
enable = true;
|
|
settings = {
|
|
add_newline = false;
|
|
directory = {
|
|
style = "purple";
|
|
read_only = " ro";
|
|
};
|
|
|
|
git_branch = {
|
|
style = "yellow";
|
|
symbol = "";
|
|
};
|
|
|
|
character = {
|
|
#success_symbol = "[➤](red)[➤](green)[➤](blue)";
|
|
#error_symbol = "[➤](cyan)[➤](purple)[➤](yellow)";
|
|
success_symbol = "[>](red)[>](green)[>](blue)";
|
|
error_symbol = "[>](cyan)[>](purple)[>](yellow)";
|
|
vicmd_symbol = "[<](bold green)";
|
|
};
|
|
|
|
line_break = { disabled = true; };
|
|
|
|
nodejs = {
|
|
format = "with [$symbol($version )]($style)";
|
|
symbol = "node ";
|
|
version_format = "\${major}";
|
|
disabled = true;
|
|
};
|
|
|
|
};
|
|
};
|
|
programs.neovim.enable = true;
|
|
programs.git.enable = true;
|
|
programs.firejail.enable = true;
|
|
|
|
nix.package = pkgs.nixFlakes;
|
|
nix.settings.experimental-features = [ "nix-command" "flakes" ];
|
|
environment.systemPackages = with pkgs; [
|
|
fluent-icon-theme
|
|
fluent-gtk-theme
|
|
maple-mono-NF
|
|
tmux
|
|
fish
|
|
wget
|
|
librewolf
|
|
kitty
|
|
mullvad-vpn
|
|
mullvad-browser
|
|
papirus-icon-theme
|
|
mediainfo
|
|
pywal
|
|
mpv
|
|
neofetch
|
|
anki
|
|
htop-vim
|
|
logseq
|
|
wl-clipboard
|
|
sox
|
|
spek
|
|
ripgrep
|
|
phinger-cursors
|
|
rsync
|
|
jq
|
|
keepassxc
|
|
feh
|
|
stow
|
|
lf
|
|
exa
|
|
fd
|
|
fzf
|
|
unar
|
|
gdu
|
|
ranger
|
|
nixfmt
|
|
whois
|
|
wofi
|
|
];
|
|
|
|
fonts.enableDefaultFonts = true;
|
|
fonts.fonts = with pkgs; [
|
|
noto-fonts
|
|
noto-fonts-cjk-sans
|
|
noto-fonts-cjk-serif
|
|
noto-fonts-emoji
|
|
hack-font
|
|
];
|
|
|
|
fonts.fontconfig = {
|
|
defaultFonts = {
|
|
serif = [ "Noto Serif CJK JP" "Noto Serif" ];
|
|
sansSerif = [ "Noto Sans CJK JP" "Noto Sans" ];
|
|
monospace = [ "Noto Mono CJK JP" "Noto Mono" ];
|
|
};
|
|
};
|
|
|
|
fonts.fontconfig.hinting.style = "hintfull";
|
|
|
|
i18n.inputMethod.enabled = "fcitx5";
|
|
|
|
services.mullvad-vpn.enable = true;
|
|
services.mullvad-vpn.enableExcludeWrapper = false;
|
|
|
|
networking.networkmanager.wifi.macAddress = "random";
|
|
networking.networkmanager.ethernet.macAddress = "random";
|
|
services.resolved.llmnr = "false";
|
|
|
|
environment.defaultPackages = [ ];
|
|
services.xserver.excludePackages = [ pkgs.xterm ];
|
|
|
|
# Force containers to use mullvad
|
|
networking.nat.enable = true;
|
|
networking.nat.internalInterfaces = ["ve-+"];
|
|
networking.nat.externalInterface = "wg-mullvad";
|
|
|
|
services.interception-tools = {
|
|
enable = true;
|
|
plugins = [ pkgs.interception-tools-plugins.dual-function-keys ];
|
|
udevmonConfig = ''
|
|
- JOB: "${pkgs.interception-tools}/bin/intercept -g $DEVNODE | ${pkgs.interception-tools-plugins.dual-function-keys}/bin/dual-function-keys -c /etc/dual-function-keys.yaml | ${pkgs.interception-tools}/bin/uinput -d $DEVNODE"
|
|
DEVICE:
|
|
EVENTS:
|
|
EV_KEY: [KEY_CAPSLOCK, KEY_ESC]
|
|
'';
|
|
};
|
|
|
|
environment.etc."dual-function-keys.yaml".text = ''
|
|
TIMING:
|
|
- TAP_MILLISEC: 1000
|
|
- DOUBLE_TAP_MILLISEC: 0
|
|
MAPPINGS:
|
|
- KEY: KEY_CAPSLOCK
|
|
TAP: KEY_ESC
|
|
HOLD: KEY_LEFTCTRL
|
|
- KEY: KEY_SYSRQ
|
|
TAP: KEY_SYSRQ
|
|
HOLD: KEY_RIGHTMETA
|
|
'';
|
|
|
|
containers.test = let hostCfg = config;
|
|
in {
|
|
autoStart = true;
|
|
privateNetwork = true;
|
|
hostAddress = "192.168.100.10";
|
|
localAddress = "192.168.100.11";
|
|
|
|
bindMounts = {
|
|
waylandDisplay = rec {
|
|
hostPath = "/run/user/1000";
|
|
mountPoint = hostPath;
|
|
};
|
|
};
|
|
|
|
config = { config, pkgs, ... }: {
|
|
programs.fish.enable = true;
|
|
users.defaultUserShell = pkgs.fish;
|
|
environment.shells = with pkgs; [ fish ];
|
|
|
|
programs.npm.enable = true;
|
|
|
|
nix.package = pkgs.nixFlakes;
|
|
nix.settings.experimental-features = [ "nix-command" "flakes" ];
|
|
environment.systemPackages = with pkgs; [
|
|
p7zip
|
|
kitty
|
|
neovim
|
|
git
|
|
unzip
|
|
ripgrep
|
|
gcc
|
|
trashy
|
|
mullvad-browser
|
|
alacritty
|
|
logseq
|
|
feh
|
|
wget
|
|
exa
|
|
fd
|
|
fzf
|
|
gdu
|
|
ranger
|
|
wofi
|
|
lf
|
|
];
|
|
|
|
environment.variables = { TERM = "xterm-kitty"; };
|
|
|
|
environment.sessionVariables = {
|
|
WAYLAND_DISPLAY = "wayland-1";
|
|
QT_QPA_PLATFORM = "wayland";
|
|
QT_WAYLAND_DISABLE_WINDOWDECORATION = "1";
|
|
SDL_VIDEODRIVER = "wayland";
|
|
CLUTTER_BACKEND = "wayland";
|
|
MOZ_ENABLE_WAYLAND = "1";
|
|
XDG_RUNTIME_DIR = "/run/user/1000";
|
|
DISPLAY = ":1";
|
|
};
|
|
|
|
services.xserver.enable = true;
|
|
|
|
hardware.opengl = {
|
|
enable = true;
|
|
extraPackages = hostCfg.hardware.opengl.extraPackages;
|
|
};
|
|
|
|
users.mutableUsers = false;
|
|
users.allowNoPasswordLogin = true;
|
|
|
|
users.users.user = {
|
|
isNormalUser = true;
|
|
home = "/home/user";
|
|
};
|
|
|
|
environment.defaultPackages = [ ];
|
|
system.stateVersion = "22.11";
|
|
};
|
|
};
|
|
|
|
system.stateVersion = "22.11";
|
|
}
|