mirror of
https://github.com/nmasur/dotfiles
synced 2025-04-24 06:52:24 +00:00
Compare commits
No commits in common. "50863e723254491a5723729304d83cca3263a08b" and "e7366f95106a387c7383bb1e45c3203f08f7e029" have entirely different histories.
50863e7232
...
e7366f9510
14
flake.nix
14
flake.nix
@ -321,10 +321,6 @@
|
|||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
|
||||||
x86_64-linux-hosts = (import ./hosts-by-platform nixpkgs).x86_64-linux-hosts;
|
|
||||||
aarch64-linux-hosts = (import ./hosts-by-platform nixpkgs).aarch64-linux-hosts;
|
|
||||||
aarch64-darwin-hosts = (import ./hosts-by-platform nixpkgs).aarch64-darwin-hosts;
|
|
||||||
|
|
||||||
in
|
in
|
||||||
rec {
|
rec {
|
||||||
|
|
||||||
@ -334,8 +330,8 @@
|
|||||||
# Create nixosConfigurations using the different pkgs for each system
|
# Create nixosConfigurations using the different pkgs for each system
|
||||||
# What to do with home config?
|
# What to do with home config?
|
||||||
|
|
||||||
nixosModules = x86_64-linux-hosts // aarch64-linux-hosts;
|
nixosModules = (import ./hosts nixpkgs).nixos-hosts;
|
||||||
darwinModules = aarch64-darwin-hosts;
|
darwinModules = (import ./hosts nixpkgs).darwin-hosts;
|
||||||
|
|
||||||
# Contains my full system builds, including home-manager
|
# Contains my full system builds, including home-manager
|
||||||
# nixos-rebuild switch --flake .#tempest
|
# nixos-rebuild switch --flake .#tempest
|
||||||
@ -346,14 +342,14 @@
|
|||||||
pkgs = pkgsBySystem.x86_64-linux;
|
pkgs = pkgsBySystem.x86_64-linux;
|
||||||
modules = [ module ];
|
modules = [ module ];
|
||||||
}
|
}
|
||||||
) x86_64-linux-hosts)
|
) nixosModules)
|
||||||
// (builtins.mapAttrs (
|
// (builtins.mapAttrs (
|
||||||
name: module:
|
name: module:
|
||||||
buildNixos {
|
buildNixos {
|
||||||
pkgs = pkgsBySystem.aarch64-linux;
|
pkgs = pkgsBySystem.aarch64-linux;
|
||||||
modules = [ module ];
|
modules = [ module ];
|
||||||
}
|
}
|
||||||
) aarch64-linux-hosts);
|
) nixosModules);
|
||||||
# builtins.mapAttrs buildNixos {
|
# builtins.mapAttrs buildNixos {
|
||||||
# pkgs = pkgsBySystem.x86_64-linux;
|
# pkgs = pkgsBySystem.x86_64-linux;
|
||||||
# modules = import ./hosts/x86_64-linux;
|
# modules = import ./hosts/x86_64-linux;
|
||||||
@ -371,7 +367,7 @@
|
|||||||
pkgs = pkgsBySystem.aarch64-darwin;
|
pkgs = pkgsBySystem.aarch64-darwin;
|
||||||
modules = [ module ];
|
modules = [ module ];
|
||||||
}
|
}
|
||||||
) aarch64-darwin-hosts;
|
) darwinModules;
|
||||||
# darwinConfigurations = builtins.mapAttrs buildDarwin {
|
# darwinConfigurations = builtins.mapAttrs buildDarwin {
|
||||||
# pkgs = pkgsBySystem.aarch64-darwin;
|
# pkgs = pkgsBySystem.aarch64-darwin;
|
||||||
# modules = import ./hosts/darwin;
|
# modules = import ./hosts/darwin;
|
||||||
|
@ -1,39 +0,0 @@
|
|||||||
# The Looking Glass
|
|
||||||
# System configuration for my work Macbook
|
|
||||||
|
|
||||||
rec {
|
|
||||||
networking.hostName = "NYCM-NMASUR2";
|
|
||||||
networking.computerName = "NYCM-NMASUR2";
|
|
||||||
|
|
||||||
nmasur.settings = {
|
|
||||||
username = "Noah.Masur";
|
|
||||||
fullName = "Noah Masur";
|
|
||||||
};
|
|
||||||
|
|
||||||
nmasur.profiles = {
|
|
||||||
base.enable = true;
|
|
||||||
work.enable = true;
|
|
||||||
extra.enable = true;
|
|
||||||
gaming.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
home-manager.users."Noah.Masur" = {
|
|
||||||
nmasur.settings = {
|
|
||||||
username = nmasur.settings.username;
|
|
||||||
fullName = nmasur.settings.fullName;
|
|
||||||
};
|
|
||||||
nmasur.profiles = {
|
|
||||||
common.enable = true;
|
|
||||||
darwin-base.enable = true;
|
|
||||||
power-user.enable = true;
|
|
||||||
work.enable = true;
|
|
||||||
experimental.enable = true;
|
|
||||||
};
|
|
||||||
nmasur.presets.programs.git = {
|
|
||||||
name = "Noah-Masur_1701";
|
|
||||||
email = "${nmasur.settings.username}@take2games.com";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
identityFile = "/Users/${nmasur.settings.username}/.ssh/id_ed25519";
|
|
||||||
}
|
|
@ -1,22 +0,0 @@
|
|||||||
# Return a list of all NixOS hosts
|
|
||||||
|
|
||||||
{ nixpkgs, ... }:
|
|
||||||
|
|
||||||
let
|
|
||||||
inherit (nixpkgs) lib;
|
|
||||||
in
|
|
||||||
|
|
||||||
lib.pipe (lib.filesystem.listFilesRecursive ./.) [
|
|
||||||
# Get only files ending in default.nix
|
|
||||||
(builtins.filter (name: lib.hasSuffix "default.nix" name))
|
|
||||||
# Remove this file
|
|
||||||
(builtins.filter (name: name != ./default.nix))
|
|
||||||
# Import each host function
|
|
||||||
map
|
|
||||||
(file: {
|
|
||||||
name = builtins.baseNameOf (builtins.dirOf file);
|
|
||||||
value = import file;
|
|
||||||
})
|
|
||||||
# Convert to an attrset of hostname -> host function
|
|
||||||
(builtins.listToAttrs)
|
|
||||||
]
|
|
@ -1,75 +0,0 @@
|
|||||||
# The Flame
|
|
||||||
# System configuration for an Oracle free server
|
|
||||||
|
|
||||||
# How to install:
|
|
||||||
# https://blog.korfuri.fr/posts/2022/08/nixos-on-an-oracle-free-tier-ampere-machine/
|
|
||||||
# These days, probably use nixos-anywhere instead.
|
|
||||||
|
|
||||||
rec {
|
|
||||||
networking.hostName = "flame";
|
|
||||||
|
|
||||||
nmasur.settings = {
|
|
||||||
username = "noah";
|
|
||||||
fullName = "Noah Masur";
|
|
||||||
# hostnames =
|
|
||||||
# let
|
|
||||||
# baseName = "masu.rs";
|
|
||||||
# in
|
|
||||||
# {
|
|
||||||
# budget = "money.${baseName}";
|
|
||||||
# git = "git.${baseName}";
|
|
||||||
# influxdb = "influxdb.${baseName}";
|
|
||||||
# irc = "irc.${baseName}";
|
|
||||||
# metrics = "metrics.${baseName}";
|
|
||||||
# minecraft = "minecraft.${baseName}";
|
|
||||||
# n8n = "n8n.${baseName}";
|
|
||||||
# notifications = "ntfy.${baseName}";
|
|
||||||
# prometheus = "prom.${baseName}";
|
|
||||||
# secrets = "vault.${baseName}";
|
|
||||||
# status = "status.${baseName}";
|
|
||||||
# };
|
|
||||||
};
|
|
||||||
|
|
||||||
nmasur.profiles = {
|
|
||||||
base.enable = true;
|
|
||||||
server.enable = true;
|
|
||||||
communications.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
home-manager.users."noah" = {
|
|
||||||
nmasur.settings = {
|
|
||||||
username = nmasur.settings.username;
|
|
||||||
fullName = nmasur.settings.fullName;
|
|
||||||
};
|
|
||||||
nmasur.profiles = {
|
|
||||||
common.enable = true;
|
|
||||||
linux-base.enable = true;
|
|
||||||
};
|
|
||||||
home.stateVersion = "23.05";
|
|
||||||
};
|
|
||||||
|
|
||||||
system.stateVersion = "23.05";
|
|
||||||
# File systems must be declared in order to boot
|
|
||||||
|
|
||||||
# This is the root filesystem containing NixOS
|
|
||||||
# I forgot to set a clean label for it
|
|
||||||
fileSystems."/" = {
|
|
||||||
device = "/dev/disk/by-uuid/e1b6bd50-306d-429a-9f45-78f57bc597c3";
|
|
||||||
fsType = "ext4";
|
|
||||||
};
|
|
||||||
|
|
||||||
# This is the boot filesystem for systemd-boot
|
|
||||||
fileSystems."/boot" = {
|
|
||||||
device = "/dev/disk/by-uuid/D5CA-237A";
|
|
||||||
fsType = "vfat";
|
|
||||||
};
|
|
||||||
|
|
||||||
# Allows private remote access over the internet
|
|
||||||
nmasur.presets.services.cloudflared = {
|
|
||||||
tunnel = {
|
|
||||||
id = "bd250ee1-ed2e-42d2-b627-039f1eb5a4d2";
|
|
||||||
credentialsFile = ../../../private/cloudflared-flame.age;
|
|
||||||
ca = "ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNTYAAABBBK/6oyVqjFGX3Uvrc3VS8J9sphxzAnRzKC85xgkHfYgR3TK6qBGXzHrknEj21xeZrr3G2y1UsGzphWJd9ZfIcdA= open-ssh-ca@cloudflareaccess.org";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
@ -1,44 +0,0 @@
|
|||||||
# Return a list of all hosts
|
|
||||||
|
|
||||||
nixpkgs:
|
|
||||||
|
|
||||||
let
|
|
||||||
inherit (nixpkgs) lib;
|
|
||||||
in
|
|
||||||
|
|
||||||
{
|
|
||||||
# darwin-hosts = import ./darwin;
|
|
||||||
aarch64-darwin-hosts = lib.pipe (lib.filesystem.listFilesRecursive ./aarch64-darwin) [
|
|
||||||
# Get only files ending in default.nix
|
|
||||||
(builtins.filter (name: lib.hasSuffix "default.nix" name))
|
|
||||||
# Import each host function
|
|
||||||
(map (file: {
|
|
||||||
name = builtins.baseNameOf (builtins.dirOf file);
|
|
||||||
value = import file;
|
|
||||||
}))
|
|
||||||
# Convert to an attrset of hostname -> host function
|
|
||||||
(builtins.listToAttrs)
|
|
||||||
];
|
|
||||||
aarch64-linux-hosts = lib.pipe (lib.filesystem.listFilesRecursive ./aarch64-linux) [
|
|
||||||
# Get only files ending in default.nix
|
|
||||||
(builtins.filter (name: lib.hasSuffix "default.nix" name))
|
|
||||||
# Import each host function
|
|
||||||
(map (file: {
|
|
||||||
name = builtins.baseNameOf (builtins.dirOf file);
|
|
||||||
value = import file;
|
|
||||||
}))
|
|
||||||
# Convert to an attrset of hostname -> host function
|
|
||||||
(builtins.listToAttrs)
|
|
||||||
];
|
|
||||||
x86_64-linux-hosts = lib.pipe (lib.filesystem.listFilesRecursive ./x86_64-linux) [
|
|
||||||
# Get only files ending in default.nix
|
|
||||||
(builtins.filter (name: lib.hasSuffix "default.nix" name))
|
|
||||||
# Import each host function
|
|
||||||
(map (file: {
|
|
||||||
name = builtins.baseNameOf (builtins.dirOf file);
|
|
||||||
value = import file;
|
|
||||||
}))
|
|
||||||
# Convert to an attrset of hostname -> host function
|
|
||||||
(builtins.listToAttrs)
|
|
||||||
];
|
|
||||||
}
|
|
@ -1,22 +0,0 @@
|
|||||||
# Return a list of all NixOS hosts
|
|
||||||
|
|
||||||
{ nixpkgs, ... }:
|
|
||||||
|
|
||||||
let
|
|
||||||
inherit (nixpkgs) lib;
|
|
||||||
in
|
|
||||||
|
|
||||||
lib.pipe (lib.filesystem.listFilesRecursive ./.) [
|
|
||||||
# Get only files ending in default.nix
|
|
||||||
(builtins.filter (name: lib.hasSuffix "default.nix" name))
|
|
||||||
# Remove this file
|
|
||||||
(builtins.filter (name: name != ./default.nix))
|
|
||||||
# Import each host function
|
|
||||||
map
|
|
||||||
(file: {
|
|
||||||
name = builtins.baseNameOf (builtins.dirOf file);
|
|
||||||
value = import file;
|
|
||||||
})
|
|
||||||
# Convert to an attrset of hostname -> host function
|
|
||||||
(builtins.listToAttrs)
|
|
||||||
]
|
|
@ -1,92 +0,0 @@
|
|||||||
# The Swan
|
|
||||||
# System configuration for my home NAS server
|
|
||||||
|
|
||||||
rec {
|
|
||||||
networking.hostName = "swan";
|
|
||||||
|
|
||||||
nmasur.settings = {
|
|
||||||
username = "noah";
|
|
||||||
fullName = "Noah Masur";
|
|
||||||
# hostnames =
|
|
||||||
# let
|
|
||||||
# baseName = "masu.rs";
|
|
||||||
# in
|
|
||||||
# {
|
|
||||||
# audiobooks = "read.${baseName}";
|
|
||||||
# books = "books.${baseName}";
|
|
||||||
# content = "cloud.${baseName}";
|
|
||||||
# download = "download.${baseName}";
|
|
||||||
# files = "files.${baseName}";
|
|
||||||
# paperless = "paper.${baseName}";
|
|
||||||
# photos = "photos.${baseName}";
|
|
||||||
# prometheus = "prom.${baseName}";
|
|
||||||
# stream = "stream.${baseName}";
|
|
||||||
# };
|
|
||||||
};
|
|
||||||
|
|
||||||
nmasur.profiles = {
|
|
||||||
base.enable = true;
|
|
||||||
server.enable = true;
|
|
||||||
home.enable = true;
|
|
||||||
nas.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
home-manager.users."noah" = {
|
|
||||||
nmasur.settings = {
|
|
||||||
username = nmasur.settings.username;
|
|
||||||
fullName = nmasur.settings.fullName;
|
|
||||||
};
|
|
||||||
nmasur.profiles = {
|
|
||||||
common.enable = true;
|
|
||||||
linux-base.enable = true;
|
|
||||||
};
|
|
||||||
home.stateVersion = "23.05";
|
|
||||||
};
|
|
||||||
|
|
||||||
# Not sure what's necessary but too afraid to remove anything
|
|
||||||
boot.initrd.availableKernelModules = [
|
|
||||||
"xhci_pci"
|
|
||||||
"ahci"
|
|
||||||
"nvme"
|
|
||||||
"usb_storage"
|
|
||||||
"sd_mod"
|
|
||||||
];
|
|
||||||
|
|
||||||
# Required for transcoding
|
|
||||||
boot.initrd.kernelModules = [ "amdgpu" ];
|
|
||||||
boot.kernelParams = [
|
|
||||||
"radeon.si_support=0"
|
|
||||||
"amdgpu.si_support=1"
|
|
||||||
"radeon.cik_support=0"
|
|
||||||
"amdgpu.cik_support=1"
|
|
||||||
"amdgpu.dc=1"
|
|
||||||
];
|
|
||||||
|
|
||||||
# Required binary blobs to boot on this machine
|
|
||||||
hardware.enableRedistributableFirmware = true;
|
|
||||||
|
|
||||||
# Prioritize efficiency over performance
|
|
||||||
powerManagement.cpuFreqGovernor = "powersave";
|
|
||||||
|
|
||||||
# Allow firmware updates
|
|
||||||
hardware.cpu.intel.updateMicrocode = true;
|
|
||||||
|
|
||||||
# ZFS
|
|
||||||
# Generated with: head -c 8 /etc/machine-id
|
|
||||||
networking.hostId = "600279f4"; # Random ID required for ZFS
|
|
||||||
|
|
||||||
# Sets root ext4 filesystem instead of declaring it manually
|
|
||||||
disko = {
|
|
||||||
enableConfig = true;
|
|
||||||
devices = (import ../../disks/root.nix { disk = "/dev/nvme0n1"; });
|
|
||||||
};
|
|
||||||
|
|
||||||
# Allows private remote access over the internet
|
|
||||||
nmasur.presets.services.cloudflared = {
|
|
||||||
tunnel = {
|
|
||||||
id = "646754ac-2149-4a58-b51a-e1d0a1f3ade2";
|
|
||||||
credentialsFile = ../../private/cloudflared-swan.age;
|
|
||||||
ca = "ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNTYAAABBBCHF/UMtJqPFrf6f6GRY0ZFnkCW7b6sYgUTjTtNfRj1RdmNic1NoJZql7y6BrqQinZvy7nsr1UFDNWoHn6ah3tg= open-ssh-ca@cloudflareaccess.org";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
@ -1,117 +0,0 @@
|
|||||||
# The Tempest
|
|
||||||
# System configuration for my desktop
|
|
||||||
|
|
||||||
rec {
|
|
||||||
# Hardware
|
|
||||||
networking.hostName = "tempest";
|
|
||||||
|
|
||||||
nmasur.settings = {
|
|
||||||
username = "noah";
|
|
||||||
fullName = "Noah Masur";
|
|
||||||
# hostnames =
|
|
||||||
# let
|
|
||||||
# baseName = "masu.rs";
|
|
||||||
# in
|
|
||||||
# {
|
|
||||||
# prometheus = "prom.${baseName}";
|
|
||||||
# };
|
|
||||||
};
|
|
||||||
|
|
||||||
nmasur.profiles = {
|
|
||||||
base.enable = true;
|
|
||||||
home.enable = true;
|
|
||||||
gui.enable = true;
|
|
||||||
gaming.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
home-manager.users."noah" = {
|
|
||||||
nmasur.settings = {
|
|
||||||
username = nmasur.settings.username;
|
|
||||||
fullName = nmasur.settings.fullName;
|
|
||||||
};
|
|
||||||
nmasur.profiles = {
|
|
||||||
common.enable = true;
|
|
||||||
linux-base.enable = true;
|
|
||||||
linux-gui.enable = true;
|
|
||||||
linux-gaming.enable = true;
|
|
||||||
power-user.enable = true;
|
|
||||||
developer.enable = true;
|
|
||||||
experimental.enable = true;
|
|
||||||
};
|
|
||||||
nmasur.presets.services.mbsync = {
|
|
||||||
user = nmasur.settings.username;
|
|
||||||
server = "noahmasur.com";
|
|
||||||
};
|
|
||||||
home.stateVersion = "23.05";
|
|
||||||
};
|
|
||||||
|
|
||||||
system.stateVersion = "23.05";
|
|
||||||
# Not sure what's necessary but too afraid to remove anything
|
|
||||||
boot.initrd.availableKernelModules = [
|
|
||||||
"nvme"
|
|
||||||
"xhci_pci"
|
|
||||||
"ahci"
|
|
||||||
"usb_storage"
|
|
||||||
"usbhid"
|
|
||||||
"sd_mod"
|
|
||||||
];
|
|
||||||
|
|
||||||
# Graphics and VMs
|
|
||||||
boot.initrd.kernelModules = [ "amdgpu" ];
|
|
||||||
boot.kernelModules = [ "kvm-amd" ];
|
|
||||||
services.xserver.videoDrivers = [ "amdgpu" ];
|
|
||||||
|
|
||||||
# Required binary blobs to boot on this machine
|
|
||||||
hardware.enableRedistributableFirmware = true;
|
|
||||||
|
|
||||||
# Prioritize performance over efficiency
|
|
||||||
powerManagement.cpuFreqGovernor = "performance";
|
|
||||||
|
|
||||||
# Allow firmware updates
|
|
||||||
hardware.cpu.amd.updateMicrocode = true;
|
|
||||||
|
|
||||||
# Helps reduce GPU fan noise under idle loads
|
|
||||||
hardware.fancontrol.enable = true;
|
|
||||||
hardware.fancontrol.config = ''
|
|
||||||
# Configuration file generated by pwmconfig, changes will be lost
|
|
||||||
INTERVAL=10
|
|
||||||
DEVPATH=hwmon0=devices/pci0000:00/0000:00:03.1/0000:06:00.0/0000:07:00.0/0000:08:00.0
|
|
||||||
DEVNAME=hwmon0=amdgpu
|
|
||||||
FCTEMPS=hwmon0/pwm1=hwmon0/temp1_input
|
|
||||||
FCFANS= hwmon0/pwm1=hwmon0/fan1_input
|
|
||||||
MINTEMP=hwmon0/pwm1=50
|
|
||||||
MAXTEMP=hwmon0/pwm1=70
|
|
||||||
MINSTART=hwmon0/pwm1=100
|
|
||||||
MINSTOP=hwmon0/pwm1=10
|
|
||||||
MINPWM=hwmon0/pwm1=10
|
|
||||||
MAXPWM=hwmon0/pwm1=240
|
|
||||||
'';
|
|
||||||
|
|
||||||
# File systems must be declared in order to boot
|
|
||||||
|
|
||||||
# This is the root filesystem containing NixOS
|
|
||||||
fileSystems."/" = {
|
|
||||||
device = "/dev/disk/by-label/nixos";
|
|
||||||
fsType = "ext4";
|
|
||||||
};
|
|
||||||
|
|
||||||
# This is the boot filesystem for Grub
|
|
||||||
fileSystems."/boot" = {
|
|
||||||
device = "/dev/disk/by-label/boot";
|
|
||||||
fsType = "vfat";
|
|
||||||
};
|
|
||||||
|
|
||||||
# Allows private remote access over the internet
|
|
||||||
nmasur.presets.services.cloudflared = {
|
|
||||||
tunnel = {
|
|
||||||
id = "ac133a82-31fb-480c-942a-cdbcd4c58173";
|
|
||||||
credentialsFile = ../../../private/cloudflared-tempest.age;
|
|
||||||
ca = "ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNTYAAABBBPY6C0HmdFCaxYtJxFr3qV4/1X4Q8KrYQ1hlme3u1hJXK+xW+lc9Y9glWHrhiTKilB7carYTB80US0O47gI5yU4= open-ssh-ca@cloudflareaccess.org";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
# Allows requests to force machine to wake up
|
|
||||||
# This network interface might change, needs to be set specifically for each machine.
|
|
||||||
# Or set usePredictableInterfaceNames = false
|
|
||||||
networking.interfaces.enp5s0.wakeOnLan.enable = true;
|
|
||||||
}
|
|
@ -25,9 +25,8 @@ in
|
|||||||
] ++ (if pkgs.stdenv.isLinux then [ pkgs._1password-gui ] else [ ]);
|
] ++ (if pkgs.stdenv.isLinux then [ pkgs._1password-gui ] else [ ]);
|
||||||
|
|
||||||
# Firefox extension
|
# Firefox extension
|
||||||
programs.firefox.profiles.default.extensions = [
|
programs.firefox.profiles.default.extensions =
|
||||||
pkgs.nur.repos.rycee.firefox-addons.onepassword-password-manager
|
pkgs.nur.repos.rycee.firefox-addons.onepassword-password-manager;
|
||||||
];
|
|
||||||
};
|
};
|
||||||
|
|
||||||
# # https://1password.community/discussion/135462/firefox-extension-does-not-connect-to-linux-app
|
# # https://1password.community/discussion/135462/firefox-extension-does-not-connect-to-linux-app
|
||||||
|
@ -196,7 +196,7 @@ in
|
|||||||
|
|
||||||
xdg.desktopEntries.aerc = lib.mkIf (pkgs.stdenv.isLinux) {
|
xdg.desktopEntries.aerc = lib.mkIf (pkgs.stdenv.isLinux) {
|
||||||
name = "aerc";
|
name = "aerc";
|
||||||
exec = "${lib.getExe config.nmasur.presets.services.i3.terminal} aerc %u";
|
exec = "${config.terminalLaunchCommand} aerc %u";
|
||||||
};
|
};
|
||||||
xsession.windowManager.i3.config.keybindings = lib.mkIf pkgs.stdenv.isLinux {
|
xsession.windowManager.i3.config.keybindings = lib.mkIf pkgs.stdenv.isLinux {
|
||||||
"${config.xsession.windowManager.i3.config.modifier}+Shift+e" = "exec ${
|
"${config.xsession.windowManager.i3.config.modifier}+Shift+e" = "exec ${
|
||||||
@ -205,7 +205,7 @@ in
|
|||||||
pkgs.writeShellScript "focus-mail.sh" ''
|
pkgs.writeShellScript "focus-mail.sh" ''
|
||||||
count=$(ps aux | grep -c aerc)
|
count=$(ps aux | grep -c aerc)
|
||||||
if [ "$count" -eq 1 ]; then
|
if [ "$count" -eq 1 ]; then
|
||||||
i3-msg "exec --no-startup-id ${lib.getExe config.nmasur.presets.services.i3.terminal} start --class aerc -- aerc"
|
i3-msg "exec --no-startup-id ${config.terminal} start --class aerc -- aerc"
|
||||||
sleep 0.25
|
sleep 0.25
|
||||||
fi
|
fi
|
||||||
i3-msg "[class=aerc] focus"
|
i3-msg "[class=aerc] focus"
|
||||||
|
@ -60,21 +60,21 @@ in
|
|||||||
body = # fish
|
body = # fish
|
||||||
''
|
''
|
||||||
git -C ${config.nmasur.presets.programs.dotfiles.path} add --intent-to-add --all
|
git -C ${config.nmasur.presets.programs.dotfiles.path} add --intent-to-add --all
|
||||||
echo "doas nixos-rebuild switch --flake ${config.nmasur.presets.programs.dotfiles.path}"
|
echo "doas nixos-rebuild switch --flake ${config.nmasur.presets.programs.dotfiles.path}#${config.networking.hostName}"
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
rebuild-nixos-offline = lib.mkIf config.nmasur.presets.programs.dotfiles.enable {
|
rebuild-nixos-offline = lib.mkIf config.nmasur.presets.programs.dotfiles.enable {
|
||||||
body = # fish
|
body = # fish
|
||||||
''
|
''
|
||||||
git -C ${config.nmasur.presets.programs.dotfiles.path} add --intent-to-add --all
|
git -C ${config.nmasur.presets.programs.dotfiles.path} add --intent-to-add --all
|
||||||
echo "doas nixos-rebuild switch --option substitute false --flake ${config.nmasur.presets.programs.dotfiles.path}"
|
echo "doas nixos-rebuild switch --option substitute false --flake ${config.nmasur.presets.programs.dotfiles.path}#${config.networking.hostName}"
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
rebuild-home = lib.mkIf config.nmasur.presets.programs.dotfiles.enable {
|
rebuild-home = lib.mkIf config.nmasur.presets.programs.dotfiles.enable {
|
||||||
body = # fish
|
body = # fish
|
||||||
''
|
''
|
||||||
git -C ${config.nmasur.presets.programs.dotfiles.path} add --intent-to-add --all
|
git -C ${config.nmasur.presets.programs.dotfiles.path} add --intent-to-add --all
|
||||||
echo "${lib.getExe pkgs.home-manager} switch --flake ${config.nmasur.presets.programs.dotfiles.path}";
|
echo "${lib.getExe pkgs.home-manager} switch --flake ${config.nmasur.presets.programs.dotfiles.path}#${config.networking.hostName}";
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -184,42 +184,34 @@ in
|
|||||||
# Launchers
|
# Launchers
|
||||||
"${modifier}+Return" =
|
"${modifier}+Return" =
|
||||||
"exec --no-startup-id ${lib.getExe cfg.terminal}; workspace ${ws2}; layout tabbed";
|
"exec --no-startup-id ${lib.getExe cfg.terminal}; workspace ${ws2}; layout tabbed";
|
||||||
"${modifier}+space" = lib.mkIf (
|
"${modifier}+space" =
|
||||||
cfg.commands.launcher != null
|
lib.mkIf cfg.commands.launcher != null "exec --no-startup-id ${cfg.commands.launcher}";
|
||||||
) "exec --no-startup-id ${cfg.commands.launcher}";
|
"${modifier}+Shift+s" =
|
||||||
"${modifier}+Shift+s" = lib.mkIf (
|
lib.mkIf cfg.commands.systemdSearch != null "exec --no-startup-id ${cfg.commands.systemdSearch}";
|
||||||
cfg.commands.systemdSearch != null
|
"${modifier}+Shift+a" =
|
||||||
) "exec --no-startup-id ${cfg.commands.systemdSearch}";
|
lib.mkIf cfg.commands.audioSwitch != null "exec --no-startup-id ${cfg.commands.audioSwitch}";
|
||||||
"${modifier}+Shift+a" = lib.mkIf (
|
"Mod1+Tab" =
|
||||||
cfg.commands.audioSwitch != null
|
lib.mkIf cfg.commands.applicationSwitch
|
||||||
) "exec --no-startup-id ${cfg.commands.audioSwitch}";
|
!= null "exec --no-startup-id ${cfg.commands.applicationSwitch}";
|
||||||
"Mod1+Tab" = lib.mkIf (
|
"${modifier}+Shift+period" =
|
||||||
cfg.commands.applicationSwitch != null
|
lib.mkIf cfg.commands.power != null "exec --no-startup-id ${cfg.commands.power}";
|
||||||
) "exec --no-startup-id ${cfg.commands.applicationSwitch}";
|
"${modifier}+Shift+m" =
|
||||||
"${modifier}+Shift+period" = lib.mkIf (
|
lib.mkIf cfg.commands.brightness != null "exec --no-startup-id ${cfg.commands.brightness}";
|
||||||
cfg.commands.power != null
|
"${modifier}+c" =
|
||||||
) "exec --no-startup-id ${cfg.commands.power}";
|
lib.mkIf cfg.commands.calculator != null "exec --no-startup-id ${cfg.commands.calculator}";
|
||||||
"${modifier}+Shift+m" = lib.mkIf (
|
|
||||||
cfg.commands.brightness != null
|
|
||||||
) "exec --no-startup-id ${cfg.commands.brightness}";
|
|
||||||
"${modifier}+c" = lib.mkIf (
|
|
||||||
cfg.commands.calculator != null
|
|
||||||
) "exec --no-startup-id ${cfg.commands.calculator}";
|
|
||||||
"${modifier}+Shift+c" = "reload";
|
"${modifier}+Shift+c" = "reload";
|
||||||
"${modifier}+Shift+r" = "restart";
|
"${modifier}+Shift+r" = "restart";
|
||||||
"${modifier}+Shift+q" =
|
"${modifier}+Shift+q" =
|
||||||
''exec "i3-nagbar -t warning -m 'You pressed the exit shortcut. Do you really want to exit i3? This will end your X session.' -B 'Yes, exit i3' 'i3-msg exit'"'';
|
''exec "i3-nagbar -t warning -m 'You pressed the exit shortcut. Do you really want to exit i3? This will end your X session.' -B 'Yes, exit i3' 'i3-msg exit'"'';
|
||||||
"${modifier}+Shift+x" = lib.mkIf (
|
"${modifier}+Shift+x" = lib.mkIf cfg.commands.lockScreen != null "exec ${cfg.commands.lockScreen}";
|
||||||
cfg.commands.lockScreen != null
|
|
||||||
) "exec ${cfg.commands.lockScreen}";
|
|
||||||
"${modifier}+Mod1+h" =
|
"${modifier}+Mod1+h" =
|
||||||
"exec --no-startup-id ${lib.getExe cfg.terminal} -e sh -c '${pkgs.home-manager}/bin/home-manager switch --flake ${config.nmasur.presets.programs.dotfiles.path} || read'";
|
"exec --no-startup-id ${lib.getExe cfg.terminal} -e sh -c '${pkgs.home-manager}/bin/home-manager switch --flake ${config.nmasur.presets.programs.dotfiles.path}#${config.networking.hostName} || read'";
|
||||||
"${modifier}+Mod1+r" =
|
"${modifier}+Mod1+r" =
|
||||||
"exec --no-startup-id ${lib.getExe cfg.terminal} -e sh -c 'doas nixos-rebuild switch --flake ${config.nmasur.presets.programs.dotfiles.path} || read'";
|
"exec --no-startup-id ${lib.getExe cfg.terminal} -e sh -c 'doas nixos-rebuild switch --flake ${config.nmasur.presets.programs.dotfiles.path}#${config.networking.hostName} || read'";
|
||||||
|
|
||||||
# Window options
|
# Window options
|
||||||
"${modifier}+q" = "kill";
|
"${modifier}+q" = "kill";
|
||||||
"${modifier}+b" = lib.mkIf (cfg.commands.toggleBar != null) "exec ${cfg.commands.toggleBar}";
|
"${modifier}+b" = lib.mkIf cfg.commands.toggleBar "exec ${cfg.commands.toggleBar}";
|
||||||
"${modifier}+f" = "fullscreen toggle";
|
"${modifier}+f" = "fullscreen toggle";
|
||||||
"${modifier}+h" = "focus left";
|
"${modifier}+h" = "focus left";
|
||||||
"${modifier}+j" = "focus down";
|
"${modifier}+j" = "focus down";
|
||||||
|
@ -57,7 +57,5 @@ in
|
|||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
allowUnfreePackages = config.home-manager.users.${username}.allowUnfreePackages;
|
|
||||||
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user