56 Commits

Author SHA1 Message Date
105fa3a0ae Various fixes and move to hyprland lua config 2026-06-13 23:05:38 +02:00
a353993421 feature/26-05 (#17)
Reviewed-on: #17
Co-authored-by: Armel van Ravels <armel@armel.nl>
Co-committed-by: Armel van Ravels <armel@armel.nl>
2026-06-12 15:47:01 +02:00
Armel van Ravels
93d29bbdb3 Install continue.continue in vscode 2026-06-08 10:51:47 +02:00
e01ac689f2 remove vim style from vscode 2026-06-05 23:11:38 +02:00
Armel van Ravels
5ff41ad33b enable devenv on work, and some vscode settings 2026-06-05 14:32:42 +02:00
c20adcd820 Merge pull request 'add devenv to blarog' (#16) from feature/devenv into master
Reviewed-on: #16
2026-05-31 20:54:55 +02:00
71dd48ff08 add devenv to blarog 2026-05-31 20:51:24 +02:00
Armel van Ravels
45fef55476 flake update 2026-05-27 10:19:38 +02:00
Armel van Ravels
65784f1228 Use unstablePkgs for vscode 2026-05-11 11:21:53 +02:00
5878b54ff3 flake update 2026-05-11 08:59:47 +02:00
8e552b7c4d arduino IDE on balrog 2026-05-03 20:58:40 +02:00
6dd46c0844 Add Arduino IDE 2026-05-03 13:24:47 +02:00
f8bec207a9 Use latest kernel at balrog 2026-05-02 15:29:58 +02:00
2b54d7907f Use latest kernel on Gandalf 2026-05-01 15:58:30 +02:00
Armel van Ravels
170cd1ece9 Use latest kernel on work machine 2026-05-01 11:14:40 +02:00
2ba7c69389 Update flake.lock 2026-05-01 08:58:38 +02:00
a705cac5de configure macbook pro screen 2026-04-28 20:51:43 +02:00
2f0c7750de Add mouse support to tmux 2026-04-28 09:55:18 +02:00
8afeda2e9a flake update 2026-04-28 09:24:13 +02:00
93431732c5 bluetooth manager for balrog 2026-04-25 15:59:35 +02:00
affe3c9b79 Add balrog to README 2026-04-25 12:33:45 +02:00
0a46b57485 Add balrog config 2026-04-25 12:27:27 +02:00
e8ec456ffd Merge branch 'feature/ollama-unstable' 2026-04-24 14:08:29 +02:00
Armel van Ravels
1b75b1bc9a Add bambu-studio the flatpak nix way 2026-04-24 14:06:47 +02:00
f20066a0af ollama via unstable channel 2026-04-24 13:52:09 +02:00
bd857c77dd Drop bambu-studio and add flatpak 2026-04-23 16:07:46 +02:00
Armel van Ravels
b1a13b64f7 Add unstable channel and jq 2026-04-23 16:07:04 +02:00
deed82f96b Add openscad 2026-04-15 11:15:50 +02:00
Armel van Ravels
6425616f8c New background 2026-04-15 11:15:08 +02:00
80cb7a6bd2 Add bambu studio 2026-04-13 21:04:57 +02:00
fc91df833a Set initial password 2026-04-13 17:32:51 +02:00
958a973ab5 flake update 2026-04-13 10:41:26 +02:00
4a19d10559 flake update 2026-04-09 20:22:58 +02:00
Armel van Ravels
4ff894e086 Add Enova DNS to Work machine 2026-04-08 15:01:57 +02:00
57dee45cb3 Update flake.lock 2026-04-08 00:54:41 +02:00
Armel van Ravels
eb948732a8 Hyprland start once for work 2026-04-07 10:44:34 +02:00
ff77b81b59 Just run kitty instead of kitty tmux as i can not attach it 2026-04-05 00:16:42 +02:00
a567d88667 Merge pull request 'Add gimp to gandalf system' (#15) from feature/add-gimp-to-gandalf into master
Reviewed-on: #15
2026-04-04 21:27:06 +02:00
e4f8c5e916 Add gimp to gandalf system 2026-04-04 21:25:28 +02:00
edfd6e1200 Merge pull request 'Autostart is configurable' (#14) from feature/hyprland-autostart into master
Reviewed-on: #14
2026-04-04 21:17:56 +02:00
ffd4894ab9 Autostart is configurable 2026-04-04 18:54:19 +02:00
6fe61afbaa Add qbittorrent and drop zen kernel 2026-03-31 22:53:50 +02:00
84b80ee811 Update flake.lock 2026-03-31 15:30:55 +02:00
7506054ebb Update flake 2026-03-30 21:04:47 +02:00
302c904cd2 Remove unused file 2026-03-27 21:53:00 +01:00
60267a5515 drop RDP 2026-03-27 21:46:55 +01:00
9aaba131e1 Add gimp.nix to work machine 2026-03-27 10:05:33 +01:00
8b9bb7ae90 Create gimp.nix module 2026-03-27 10:03:53 +01:00
Armel van Ravels
82a77971b0 Update flake.lock 2026-03-26 15:43:26 +01:00
f0e25ae7ae Enable X11 forwarding on gandalf 2026-03-26 15:17:29 +01:00
Armel van Ravels
b3e4978f10 Add postman 2026-03-26 10:08:12 +01:00
Armel van Ravels
13082612ed configurable git email and name 2026-03-26 10:02:22 +01:00
da793609a7 Add RDP to gandalf 2026-03-25 10:08:07 +01:00
Armel van Ravels
37e2708326 Add wireguard tools 2026-03-23 10:32:07 +01:00
Armel van Ravels
69c8b59c6a Update flake.lock 2026-03-23 10:28:10 +01:00
c666c4739c Add ollama and webui 2026-03-20 22:38:44 +01:00
37 changed files with 540 additions and 222 deletions

View File

@@ -10,6 +10,7 @@ Each system has its own dedicated configuration module.
| **gandalf** | Personal system configuration for `gandalf`. | | **gandalf** | Personal system configuration for `gandalf`. |
| **frodo** | Personal system configuration for `frodo`. | | **frodo** | Personal system configuration for `frodo`. |
| **legolas** | Personal system configuration for `legolas`. | | **legolas** | Personal system configuration for `legolas`. |
| **balrog** | Personal system configuration for `balrog`. |
| **work** | Work-oriented system configuration for `work`. | | **work** | Work-oriented system configuration for `work`. |
@@ -18,7 +19,7 @@ Each system has its own dedicated configuration module.
To rebuild and switch to a specific system: To rebuild and switch to a specific system:
```bash ```bash
# Replace <system> with gandalf, frodo, legolas, or work # Replace <system> with gandalf, frodo, legolas, balrog or work
sudo nixos-rebuild switch --flake .#<system> sudo nixos-rebuild switch --flake .#<system>
``` ```

51
flake.lock generated
View File

@@ -7,32 +7,63 @@
] ]
}, },
"locked": { "locked": {
"lastModified": 1773681845, "lastModified": 1781184346,
"narHash": "sha256-o8hrZrigP0JYcwnglCp8Zi8jQafWsxbDtRRPzuVwFxY=", "narHash": "sha256-cZRlW47U6A2nWvAmnZeeO6Xvq23gxYbVLel4KxqOrcQ=",
"owner": "nix-community", "owner": "nix-community",
"repo": "home-manager", "repo": "home-manager",
"rev": "0759e0e137305bc9d0c52c204c6d8dffe6f601a6", "rev": "ea6d221d7aa85652d014b6f719dddf036037515b",
"type": "github" "type": "github"
}, },
"original": { "original": {
"owner": "nix-community", "owner": "nix-community",
"ref": "release-25.11", "ref": "release-26.05",
"repo": "home-manager", "repo": "home-manager",
"type": "github" "type": "github"
} }
}, },
"nix-flatpak": {
"locked": {
"lastModified": 1780908363,
"narHash": "sha256-llGS4y3Qh1eUkli3/Y2VY9FV3GOUKFZR1E2BDftt45Q=",
"owner": "gmodena",
"repo": "nix-flatpak",
"rev": "1df08625f0f8c7d6e300a0e5df7955bbb877d809",
"type": "github"
},
"original": {
"owner": "gmodena",
"repo": "nix-flatpak",
"type": "github"
}
},
"nixpkgs": { "nixpkgs": {
"locked": { "locked": {
"lastModified": 1773814637, "lastModified": 1780902259,
"narHash": "sha256-GNU+ooRmrHLfjlMsKdn0prEKVa0faVanm0jrgu1J/gY=", "narHash": "sha256-q8yYEC5f1mFlQO9RGna4LTc9QrcvWunX6FYp83munkQ=",
"owner": "nixos", "owner": "nixos",
"repo": "nixpkgs", "repo": "nixpkgs",
"rev": "fea3b367d61c1a6592bc47c72f40a9f3e6a53e96", "rev": "bd0ff2d3eac24699c3664d5966b9ef36f388e2ca",
"type": "github" "type": "github"
}, },
"original": { "original": {
"owner": "nixos", "owner": "nixos",
"ref": "nixos-25.11", "ref": "nixos-26.05",
"repo": "nixpkgs",
"type": "github"
}
},
"nixpkgs-unstable": {
"locked": {
"lastModified": 1781141223,
"narHash": "sha256-Eye4UQJjC4TLobclolFCMl6MrjgiF6Bk1cOI5x8SH00=",
"owner": "NixOS",
"repo": "nixpkgs",
"rev": "b503dde361500433ca25a32e8f4d218bf58fb659",
"type": "github"
},
"original": {
"owner": "NixOS",
"ref": "nixpkgs-unstable",
"repo": "nixpkgs", "repo": "nixpkgs",
"type": "github" "type": "github"
} }
@@ -40,7 +71,9 @@
"root": { "root": {
"inputs": { "inputs": {
"home-manager": "home-manager", "home-manager": "home-manager",
"nixpkgs": "nixpkgs" "nix-flatpak": "nix-flatpak",
"nixpkgs": "nixpkgs",
"nixpkgs-unstable": "nixpkgs-unstable"
} }
} }
}, },

View File

@@ -3,11 +3,20 @@
inputs = { inputs = {
nixpkgs = { nixpkgs = {
url = "github:nixos/nixpkgs/nixos-25.11"; url = "github:nixos/nixpkgs/nixos-26.05";
};
nixpkgs-unstable = {
url = "github:NixOS/nixpkgs/nixpkgs-unstable";
}; };
home-manager = { home-manager = {
url = "github:nix-community/home-manager/release-25.11"; url = "github:nix-community/home-manager/release-26.05";
inputs.nixpkgs.follows = "nixpkgs";
};
nix-flatpak = {
url = "github:gmodena/nix-flatpak";
inputs.nixpkgs.follows = "nixpkgs"; inputs.nixpkgs.follows = "nixpkgs";
}; };
}; };

View File

@@ -1,31 +1,70 @@
{ nixpkgs, home-manager, ... }: { nixpkgs, nixpkgs-unstable, home-manager, nix-flatpak, ... }:
let
mkPkgsUnstable = system: import nixpkgs-unstable {
inherit system;
config.allowUnfree = true;
};
in
{ {
nixosConfigurations = { nixosConfigurations = {
"gandalf" = nixpkgs.lib.nixosSystem { "gandalf" = nixpkgs.lib.nixosSystem {
system = "x86_64-linux"; system = "x86_64-linux";
specialArgs = {
pkgsUnstable = mkPkgsUnstable "x86_64-linux";
nixFlatpak = nix-flatpak;
};
modules = [ modules = [
nix-flatpak.nixosModules.nix-flatpak
home-manager.nixosModules.home-manager home-manager.nixosModules.home-manager
./systems/gandalf ./systems/gandalf
]; ];
}; };
"frodo" = nixpkgs.lib.nixosSystem { "frodo" = nixpkgs.lib.nixosSystem {
system = "x86_64-linux"; system = "x86_64-linux";
specialArgs = {
pkgsUnstable = mkPkgsUnstable "x86_64-linux";
nixFlatpak = nix-flatpak;
};
modules = [ modules = [
nix-flatpak.nixosModules.nix-flatpak
home-manager.nixosModules.home-manager home-manager.nixosModules.home-manager
./systems/frodo ./systems/frodo
]; ];
}; };
"legolas" = nixpkgs.lib.nixosSystem { "legolas" = nixpkgs.lib.nixosSystem {
system = "x86_64-linux"; system = "x86_64-linux";
specialArgs = {
pkgsUnstable = mkPkgsUnstable "x86_64-linux";
nixFlatpak = nix-flatpak;
};
modules = [ modules = [
nix-flatpak.nixosModules.nix-flatpak
home-manager.nixosModules.home-manager home-manager.nixosModules.home-manager
./systems/legolas ./systems/legolas
]; ];
}; };
"balrog" = nixpkgs.lib.nixosSystem {
system = "x86_64-linux";
specialArgs = {
pkgsUnstable = mkPkgsUnstable "x86_64-linux";
nixFlatpak = nix-flatpak;
};
modules = [
nix-flatpak.nixosModules.nix-flatpak
home-manager.nixosModules.home-manager
./systems/balrog
];
};
"work" = nixpkgs.lib.nixosSystem { "work" = nixpkgs.lib.nixosSystem {
system = "x86_64-linux"; system = "x86_64-linux";
specialArgs = {
pkgsUnstable = mkPkgsUnstable "x86_64-linux";
nixFlatpak = nix-flatpak;
};
modules = [ modules = [
nix-flatpak.nixosModules.nix-flatpak
home-manager.nixosModules.home-manager home-manager.nixosModules.home-manager
./systems/work ./systems/work
]; ];

View File

@@ -0,0 +1,57 @@
# Edit this configuration file to define what should be installed on
# your system. Help is available in the configuration.nix(5) man page, on
# https://search.nixos.org/options and in the NixOS manual (`nixos-help`).
{ config, lib, pkgs, ... }:
{
imports =
[ # Include the results of the hardware scan.
./hardware-configuration.nix
../modules/home-manager.nix
../modules/common.nix
../modules/users.nix
../modules/locales.nix
../modules/services.nix
../modules/programs.nix
../modules/docker.nix
../modules/printing.nix
../modules/bambu-studio-flatpak.nix
../modules/arduino-ide.nix
../modules/devenv.nix
# ../modules/bitwarden.nix
];
boot.kernelPackages = pkgs.linuxPackages_latest;
boot.loader.systemd-boot.enable = false;
boot.loader = {
efi = {
canTouchEfiVariables = true;
efiSysMountPoint = "/boot/efi"; # ← use the same mount point here.
};
grub = {
efiSupport = true;
device = "nodev";
};
};
networking.hostName = "balrog";
networking.networkmanager.enable = true;
networking.nameservers = [ "192.168.68.56" "1.1.1.1" "8.8.8.8" ];
hardware.enableAllFirmware = true;
boot.initrd.kernelModules = [ "wl" ]; boot.kernelModules = [ "wl" "kvm-intel" ];
boot.extraModulePackages = with config.boot.kernelPackages; [
broadcom_sta
];
nixpkgs.config = {
allowInsecurePredicate = pkg: builtins.elem (lib.getName pkg) ["broadcom-sta"];
};
hardware.bluetooth.enable = true;
services.blueman.enable = true;
system.stateVersion = "25.11"; # Did you read the comment?
}

View File

@@ -0,0 +1,31 @@
# Do not modify this file! It was generated by nixos-generate-config
# and may be overwritten by future invocations. Please make changes
# to /etc/nixos/configuration.nix instead.
{ config, lib, pkgs, modulesPath, ... }:
{
imports =
[ (modulesPath + "/installer/scan/not-detected.nix")
];
boot.initrd.availableKernelModules = [ "xhci_pci" "ahci" "usbhid" "usb_storage" "sd_mod" ];
boot.initrd.kernelModules = [ ];
boot.kernelModules = [ "kvm-intel" ];
boot.extraModulePackages = [ ];
fileSystems."/" =
{ device = "/dev/disk/by-uuid/6795dc19-3130-4693-b04c-a2c56fbdbd55";
fsType = "ext4";
};
fileSystems."/boot" =
{ device = "/dev/disk/by-uuid/A202-E19C";
fsType = "vfat";
options = [ "fmask=0022" "dmask=0022" ];
};
swapDevices = [ ];
nixpkgs.hostPlatform = lib.mkDefault "x86_64-linux";
hardware.cpu.intel.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware;
}

View File

@@ -18,7 +18,17 @@
../modules/matrix.nix ../modules/matrix.nix
../modules/kdenlive.nix ../modules/kdenlive.nix
../modules/audacity.nix ../modules/audacity.nix
../modules/ollama.nix
../modules/wireguard.nix
../modules/qbittorrent.nix
../modules/gimp.nix
../modules/openscad.nix
../modules/bambu-studio-flatpak.nix
../modules/arduino-ide.nix
../modules/bitwarden.nix
]; ];
boot.kernelPackages = pkgs.linuxPackages_latest;
boot.loader.systemd-boot.enable = true; boot.loader.systemd-boot.enable = true;
boot.loader.efi.canTouchEfiVariables = true; boot.loader.efi.canTouchEfiVariables = true;
@@ -26,11 +36,20 @@
networking.hostName = "gandalf"; networking.hostName = "gandalf";
networking.networkmanager.enable = true; networking.networkmanager.enable = true;
networking.nameservers = [ "192.168.68.56" "1.1.1.1" "8.8.8.8" ]; networking.nameservers = [ "192.168.68.56" "1.1.1.1" "8.8.8.8" ];
networking.firewall.enable = false;
home-manager.users.avravels.home.hyprland.execOnce = [
"waybar"
"[workspace 1 silent] kitty"
"[workspace 1 silent] spotify"
"[workspace 2 silent] firefox"
];
networking.interfaces.enp130s0.wakeOnLan.enable = true; networking.interfaces.enp130s0.wakeOnLan.enable = true;
networking.firewall.allowedUDPPorts = [ 9 ]; networking.firewall.allowedUDPPorts = [ 9 ];
services.xserver.videoDrivers = ["nvidia"]; services.xserver.videoDrivers = ["nvidia"];
services.openssh.settings.X11Forwarding = true;
hardware = { hardware = {
graphics.enable = true; graphics.enable = true;
@@ -47,12 +66,6 @@
virtualisation.libvirtd.enable = true; virtualisation.libvirtd.enable = true;
specialisation = {
zen.configuration = {
boot.kernelPackages = pkgs.linuxPackages_zen;
};
};
services = { services = {
# Bluetooth fixes # Bluetooth fixes
# Can be removed when https://github.com/NixOS/nixpkgs/pull/499670 is merged and in 25.11 # Can be removed when https://github.com/NixOS/nixpkgs/pull/499670 is merged and in 25.11

View File

@@ -0,0 +1,8 @@
{ config, pkgs, ... }:
{
environment.systemPackages = with pkgs; [
arduino-ide
];
}

View File

@@ -0,0 +1,8 @@
{ pkgs, ...}:
{
services.flatpak.enable = true;
services.flatpak.packages = [
"com.bambulab.BambuStudio"
];
}

View File

@@ -0,0 +1,12 @@
{ config, pkgs, ... }:
{
nixpkgs.config.permittedInsecurePackages = [
"electron-39.8.10"
];
environment.systemPackages = with pkgs; [
bitwarden-desktop
];
}

View File

@@ -10,9 +10,9 @@
environment.systemPackages = with pkgs; [ environment.systemPackages = with pkgs; [
chromium chromium
gnumake gnumake
git
jetbrains-toolbox jetbrains-toolbox
fastfetch fastfetch
jq
]; ];
security.rtkit.enable = true; security.rtkit.enable = true;

View File

@@ -0,0 +1,10 @@
{ config, pkgsUnstable, ... } :
{
environment.systemPackages = with pkgsUnstable; [
devenv
];
nix.settings.trusted-users = [ "root" "avravels" ];
}

12
systems/modules/enova.nix Normal file
View File

@@ -0,0 +1,12 @@
{ pkgs, ... }:
{
services.dnsmasq = {
enable = true;
settings = {
server = [ "1.1.1.1" "8.8.8.8" ];
address = [ "/.enova.local/127.0.0.1" ];
};
};
}

7
systems/modules/gimp.nix Normal file
View File

@@ -0,0 +1,7 @@
{ config, pkgs, ... } :
{
environment.systemPackages = with pkgs; [
gimp
];
}

View File

@@ -1,10 +0,0 @@
{ pkgs, ... }:
{
home-manager = {
useGlobalPkgs = true;
useUserPackages = true;
users.avravels = import home/home-work.nix;
};
}

View File

@@ -1,9 +1,12 @@
{ pkgs, ... }: { pkgs, pkgsUnstable, ... }:
{ {
home-manager = { home-manager = {
useGlobalPkgs = true; useGlobalPkgs = true;
useUserPackages = true; useUserPackages = true;
extraSpecialArgs = {
inherit pkgsUnstable;
};
users.avravels = import home/home.nix; users.avravels = import home/home.nix;
}; };

Binary file not shown.

After

Width:  |  Height:  |  Size: 10 MiB

View File

@@ -1,32 +0,0 @@
{ pkgs, lib, ... }:
{
# Home Manager state version
home.stateVersion = "25.11";
home.username = "avravels";
home.homeDirectory = "/home/avravels";
imports = [
./other/fonts.nix
./programs/bitwarden.nix
./programs/kitty.nix
./programs/zsh.nix
./programs/direnv.nix
./programs/firefox.nix
./programs/tmux.nix
./programs/git-work.nix
./programs/libreoffice.nix
./programs/nvim.nix
./programs/ripgrep.nix
./programs/vscode.nix
./wm/rofi.nix
./wm/cursor.nix
./wm/dconf.nix
./wm/gtk.nix
./wm/waybar.nix
./wm/hyprland.nix
./wm/hyprpaper.nix
];
}

View File

@@ -9,7 +9,7 @@
imports = [ imports = [
./other/fonts.nix ./other/fonts.nix
./programs/bitwarden.nix # ./programs/bitwarden.nix
./programs/kitty.nix ./programs/kitty.nix
./programs/zsh.nix ./programs/zsh.nix
./programs/direnv.nix ./programs/direnv.nix

View File

@@ -1,9 +1,9 @@
{ pkgs, ... }: { pkgs, config, ... }:
{ {
programs.firefox = { programs.firefox = {
enable = true; enable = true;
configPath = "${config.xdg.configHome}/mozilla/firefox";
profiles.default = { profiles.default = {
settings = { settings = {
"extensions.activeThemeID" = "firefox-compact-dark@mozilla.org"; "extensions.activeThemeID" = "firefox-compact-dark@mozilla.org";

View File

@@ -1,11 +0,0 @@
{ pkgs, ... } :
{
programs.git = {
enable = true;
settings.user = {
name = "Armel van Ravels";
email = "armel@webavance.nl";
};
};
}

View File

@@ -1,11 +1,28 @@
{ pkgs, ... } : { lib, pkgsUnstable, config, ... }:
{ {
programs.git = { options.home.git = {
enable = true; userName = lib.mkOption {
settings.user = { type = lib.types.str;
name = "Armel van Ravels"; default = "Armel van Ravels";
email = "armel@armel.nl"; description = "Default git user.name for this user";
};
userEmail = lib.mkOption {
type = lib.types.str;
default = "armel@armel.nl";
description = "Default git user.email for this user";
};
};
config = {
programs.git = {
enable = true;
package = pkgsUnstable.git;
settings.user = {
name = config.home.git.userName;
email = config.home.git.userEmail;
};
}; };
}; };
} }

View File

@@ -3,6 +3,8 @@
{ {
programs.neovim = { programs.neovim = {
enable = true; enable = true;
withRuby = false;
withPython3 = false;
defaultEditor = true; defaultEditor = true;
extraLuaPackages = ps: [ ps.magick ]; extraLuaPackages = ps: [ ps.magick ];
extraPackages = [ extraPackages = [
@@ -27,7 +29,7 @@
image-nvim image-nvim
]; ];
extraLuaConfig = '' initLua = ''
vim.cmd("colorscheme catppuccin-mocha") vim.cmd("colorscheme catppuccin-mocha")
-- Basic settings -- Basic settings
vim.o.number = true vim.o.number = true

View File

@@ -1,5 +1,8 @@
{ pkgs, ... }: { pkgs, ... }:
{ {
programs.tmux.enable = true; programs.tmux = {
enable = true;
mouse = true;
};
} }

View File

@@ -1,18 +1,24 @@
{ pkgs, ... }: { pkgs, pkgsUnstable, ... }:
{ {
programs.vscode = { programs.vscode = {
enable = true; enable = true;
package = pkgs.vscode.fhs; package = pkgsUnstable.vscode.fhs;
profiles.default.extensions = with pkgs.vscode-extensions; [ profiles.default.extensions = with pkgs.vscode-extensions; [
ms-dotnettools.csharp ms-dotnettools.csharp
ms-dotnettools.csdevkit ms-dotnettools.csdevkit
ms-dotnettools.vscode-dotnet-runtime ms-dotnettools.vscode-dotnet-runtime
mkhl.direnv # Direnv integration for VSCode mkhl.direnv # Direnv integration for VSCode
catppuccin.catppuccin-vsc
bmewburn.vscode-intelephense-client
continue.continue
]; ];
profiles.default.userSettings = { profiles.default.userSettings = {
"editor.lineNumbers" = "relative";
"workbench.colorTheme" = "Catppuccin Mocha";
"workbench.editor.enablePreview" = false;
"direnv.restart.automatic" = true; "direnv.restart.automatic" = true;
"terminal.integrated.defaultProfile.linux" = "zsh"; "terminal.integrated.defaultProfile.linux" = "zsh";
"terminal.integrated.profiles.linux" = { "terminal.integrated.profiles.linux" = {

View File

@@ -15,6 +15,7 @@
name = "Adwaita"; name = "Adwaita";
package = pkgs.adwaita-icon-theme; package = pkgs.adwaita-icon-theme;
}; };
gtk4.theme = null;
}; };
home.sessionVariables = { home.sessionVariables = {

View File

@@ -1,143 +1,169 @@
{ pkgs, ... }: { lib, pkgs, config, ... }:
let
cfg = config.home.hyprland;
in
{ {
home.packages = with pkgs; [ options.home.hyprland = {
bzmenu execOnce = lib.mkOption {
hyprshot type = lib.types.listOf lib.types.str;
hyprlock default = [ "waybar" ];
playerctl description = "Commands to run once when Hyprland starts (maps to Hyprland `exec-once`).";
speedcrunch };
]; };
config = {
home.packages = with pkgs; [
bzmenu
hyprshot
hyprlock
playerctl
speedcrunch
];
wayland.windowManager.hyprland = { wayland.windowManager.hyprland = {
enable = true; enable = true;
configType = "lua";
settings =
let
mkLuaInline = lib.generators.mkLuaInline;
toLua = lib.generators.toLua;
mkArgs = args: { _args = args; };
bind =
keys: dispatcher: options:
mkArgs [
keys
dispatcher
options
];
dsp = {
exec_cmd = app: mkLuaInline ''hl.dsp.exec_cmd("${app}")'';
focus = arg: mkLuaInline "hl.dsp.focus(${toLua { } arg})";
window = {
move = arg: mkLuaInline "hl.dsp.window.move(${toLua { } arg})";
drag = mkLuaInline "hl.dsp.window.drag()";
resize = mkLuaInline "hl.dsp.window.resize()";
close = mkLuaInline "hl.dsp.window.close()";
kill = mkLuaInline "hl.dsp.window.kill()";
fullscreen = mkLuaInline "hl.dsp.window.fullscreen()";
};
exit = mkLuaInline "hl.dsp.exit()";
workspace = {
move = arg: mkLuaInline "hl.dsp.workspace.move(${toLua { } arg})";
};
};
mod = "SUPER";
workspaces = lib.stringToCharacters "abcdefgimnopqrstuvwxyz";
in
{
config = {
general = {
resize_on_border = true;
allow_tearing = true;
};
settings = { animations.enabled = true;
### MONITOR
monitor = [
",preferred,auto,1"
];
### VARIABLES decoration = {
"$mod" = "SUPER"; inactive_opacity = 0.8;
"$terminal" = "kitty"; active_opacity = 0.9;
"$menu" = "rofi -show drun"; rounding = 5;
"$bluetoothMenu" = "bzmenu --launcher rofi"; rounding_power = 2.5;
"$files" = "rofi -show filebrowser"; blur = {
enabled = true;
brightness = 1.0;
contrast = 1.0;
noise = 0.01;
### BASIC LAYOUT vibrancy = 0.2;
general = { vibrancy_darkness = 0.5;
layout = "dwindle";
resize_on_border = true;
};
decoration = { passes = 4;
inactive_opacity = 0.8; size = 7;
active_opacity = 0.9;
rounding = 5;
rounding_power = 2.5;
blur = {
enabled = true;
brightness = 1.0;
contrast = 1.0;
noise = 0.01;
vibrancy = 0.2; popups = true;
vibrancy_darkness = 0.5; popups_ignorealpha = 0.2;
};
shadow = {
enabled = true;
color = "rgba(00000055)";
offset = "0 15";
range = 100;
render_power = 2;
scale = 0.97;
};
};
passes = 4; misc = {
size = 7; focus_on_activate = true;
};
popups = true;
popups_ignorealpha = 0.2;
}; };
shadow = { bind = lib.flatten [
enabled = true; (bind "${mod} + Q" (dsp.window.kill) { })
color = "rgba(00000055)"; (bind "${mod} + L" (dsp.exec_cmd "hyprlock") { })
ignore_window = true; (bind "${mod} + D" (dsp.exec_cmd "rofi -show drun") { })
offset = "0 15"; (bind "${mod} + B" (dsp.exec_cmd "bzmenu --launcher rofi") { })
range = 100; (bind "${mod} + F" (dsp.window.fullscreen) { })
render_power = 2; (bind "${mod} + Z" (dsp.exec_cmd "hyprshot -m region") { })
scale = 0.97; (bind "${mod} + M" (dsp.exit) { })
}; (bind "${mod} + SPACE" (dsp.exec_cmd "firefox") { })
(bind "${mod} + RETURN" (dsp.exec_cmd "kitty") { })
(bind "${mod} + SHIFT + LEFT" (dsp.window.move { direction = "l"; }) { })
(bind "${mod} + SHIFT + DOWN" (dsp.window.move { direction = "d"; }) { })
(bind "${mod} + SHIFT + UP" (dsp.window.move { direction = "u"; }) { })
(bind "${mod} + SHIFT + RIGHT" (dsp.window.move { direction = "r"; }) { })
(bind "${mod} + LEFT" (dsp.focus { direction = "l"; }) { })
(bind "${mod} + DOWN" (dsp.focus { direction = "d"; }) { })
(bind "${mod} + UP" (dsp.focus { direction = "u"; }) { })
(bind "${mod} + RIGHT" (dsp.focus { direction = "r"; }) { })
(bind "${mod} + 1" (dsp.focus { workspace = 1; }) {})
(bind "${mod} + 2" (dsp.focus { workspace = 2; }) {})
(bind "${mod} + 3" (dsp.focus { workspace = 3; }) {})
(bind "${mod} + 4" (dsp.focus { workspace = 4; }) {})
(bind "${mod} + 5" (dsp.focus { workspace = 5; }) {})
(bind "${mod} + 6" (dsp.focus { workspace = 6; }) {})
(bind "${mod} + 7" (dsp.focus { workspace = 7; }) {})
(bind "${mod} + 8" (dsp.focus { workspace = 8; }) {})
(bind "${mod} + 9" (dsp.focus { workspace = 9; }) {})
(bind "${mod} + SHIFT + 1" (dsp.window.move { workspace = 1; }) {})
(bind "${mod} + SHIFT + 2" (dsp.window.move { workspace = 2; }) {})
(bind "${mod} + SHIFT + 3" (dsp.window.move { workspace = 3; }) {})
(bind "${mod} + SHIFT + 4" (dsp.window.move { workspace = 4; }) {})
(bind "${mod} + SHIFT + 5" (dsp.window.move { workspace = 5; }) {})
(bind "${mod} + SHIFT + 6" (dsp.window.move { workspace = 6; }) {})
(bind "${mod} + SHIFT + 7" (dsp.window.move { workspace = 7; }) {})
(bind "${mod} + SHIFT + 8" (dsp.window.move { workspace = 8; }) {})
(bind "${mod} + SHIFT + 9" (dsp.window.move { workspace = 9; }) {})
(bind "XF86AudioLowerVolume" (dsp.exec_cmd "wpctl set-volume @DEFAULT_AUDIO_SINK@ 5%-") {
repeating = true;
locked = true;
})
(bind "XF86AudioRaiseVolume" (dsp.exec_cmd "wpctl set-volume @DEFAULT_AUDIO_SINK@ 5%+") {
repeating = true;
locked = true;
})
(bind "XF86AudioPlay" (dsp.exec_cmd "playerctl play-pause") { locked = true; })
(bind "XF86AudioPrev" (dsp.exec_cmd "playerctl previous") { locked = true; })
(bind "XF86AudioNext" (dsp.exec_cmd "playerctl next") { locked = true; })
(bind "${mod} + mouse:272" dsp.window.drag { mouse = true; })
(bind "${mod} + mouse:273" dsp.window.resize { mouse = true; })
];
on = mkArgs [
"hyprland.start"
(mkLuaInline ''
function()
hl.exec_cmd("waybar")
end'')
];
}; };
exec-once = [
"waybar"
];
### INPUT
input = {
kb_layout = "us";
};
### KEYBINDINGS
bind = [
# Apps
"$mod, RETURN, exec, $terminal"
"$mod, D, exec, $menu"
"$mod, B, exec, $bluetoothMenu"
"$mod, G, exec, $files"
"$mod, Q, killactive"
"$mod, F, fullscreen"
"$mod, M, exit"
"$mod, L, exec, hyprlock"
# show/hide waybar
"$mod, W, exec, pkill -SIGUSR1 -f '^waybar$'"
# Focus
"$mod, LEFT, movefocus, l"
"$mod, RIGHT, movefocus, r"
"$mod, UP, movefocus, u"
"$mod, DOWN, movefocus, d"
# Workspaces
"$mod, 1, workspace, 1"
"$mod, 2, workspace, 2"
"$mod, 3, workspace, 3"
"$mod, 4, workspace, 4"
"$mod, 5, workspace, 5"
"$mod, 6, workspace, 6"
"$mod, 7, workspace, 7"
"$mod, 8, workspace, 8"
"$mod, 9, workspace, 9"
"$mod SHIFT, 1, movetoworkspace, 1"
"$mod SHIFT, 2, movetoworkspace, 2"
"$mod SHIFT, 3, movetoworkspace, 3"
"$mod SHIFT, 4, movetoworkspace, 4"
"$mod SHIFT, 5, movetoworkspace, 5"
"$mod SHIFT, 6, movetoworkspace, 6"
"$mod SHIFT, 7, movetoworkspace, 7"
"$mod SHIFT, 8, movetoworkspace, 8"
"$mod SHIFT, 9, movetoworkspace, 9"
# Window movement
"$mod SHIFT, LEFT, movewindow, l"
"$mod SHIFT, RIGHT, movewindow, r"
"$mod SHIFT, UP, movewindow, u"
"$mod SHIFT, DOWN, movewindow, d"
# Hyprshot
"$mod, Z, exec, hyprshot -m region"
# Media keys
", XF86AudioPlay, exec, playerctl play-pause"
", XF86AudioMute, exec, wpctl set-mute @DEFAULT_AUDIO_SINK@ toggle"
", XF86AudioRaiseVolume, exec, wpctl set-volume @DEFAULT_AUDIO_SINK@ 5%+"
", XF86AudioLowerVolume, exec, wpctl set-volume @DEFAULT_AUDIO_SINK@ 5%-"
", XF86AudioNext, exec, playerctl next"
", XF86AudioPrev, exec, playerctl previous"
", XF86Calculator, exec, speedcrunch"
];
bindm = [
"$mod, mouse:272, movewindow"
"$mod, mouse:273, resizewindow"
];
}; };
}; };
} }

View File

@@ -3,6 +3,7 @@
let let
wallpaper = builtins.toString ../backgrounds/monkey.jpg; wallpaper = builtins.toString ../backgrounds/monkey.jpg;
wallpaper2 = builtins.toString ../backgrounds/bird.jpg; wallpaper2 = builtins.toString ../backgrounds/bird.jpg;
wallpaper3 = builtins.toString ../backgrounds/nix.png;
in in
{ {
services.hyprpaper = { services.hyprpaper = {
@@ -12,10 +13,10 @@ in
preload = [ preload = [
wallpaper wallpaper
wallpaper2 wallpaper2
wallpaper3
]; ];
wallpaper = [ wallpaper = [
"DP-2,${wallpaper2}" ",${wallpaper3}"
",${wallpaper}"
]; ];
}; };
}; };

7
systems/modules/jq.nix Normal file
View File

@@ -0,0 +1,7 @@
{ config, pkgs, ... } :
{
environment.systemPackages = with pkgs; [
jq
];
}

View File

@@ -0,0 +1,8 @@
{ pkgsUnstable, ... }:
{
services.ollama = {
enable = true;
package = pkgsUnstable.ollama-cuda;
};
}

View File

@@ -0,0 +1,8 @@
{ config, pkgs, ... } :
{
environment.systemPackages = with pkgs; [
openscad
];
}

View File

@@ -0,0 +1,7 @@
{ pkgs, ... }:
{
environment.systemPackages = with pkgs; [
postman
];
}

View File

@@ -0,0 +1,7 @@
{ pkgs, ... }:
{
environment.systemPackages = with pkgs; [
qbittorrent
];
}

View File

@@ -0,0 +1,7 @@
{ pkgs, ... }:
{
environment.systemPackages = with pkgs; [
remmina
];
}

View File

@@ -2,14 +2,15 @@
{ {
users.users.avravels = { users.users.avravels = {
initialPassword = "welcome";
isNormalUser = true; isNormalUser = true;
description = "Armel van Ravels"; description = "Armel van Ravels";
extraGroups = [ "networkmanager" "wheel" "libvirtd" ]; extraGroups = [ "networkmanager" "wheel" "libvirtd" "dialout"];
packages = with pkgs; [ packages = with pkgs; [
home-manager home-manager
legcord legcord
spotify spotify
protonvpn-gui proton-vpn
]; ];
shell = pkgs.zsh; shell = pkgs.zsh;
}; };

View File

@@ -0,0 +1,7 @@
{ pkgs, ... }:
{
environment.systemPackages = with pkgs; [
wireguard-tools
];
}

View File

@@ -4,7 +4,7 @@
imports = imports =
[ [
./hardware-configuration.nix ./hardware-configuration.nix
../modules/home-manager-work.nix ../modules/home-manager.nix
../modules/common.nix ../modules/common.nix
../modules/users.nix ../modules/users.nix
../modules/locales.nix ../modules/locales.nix
@@ -16,8 +16,18 @@
../modules/teams-for-linux.nix ../modules/teams-for-linux.nix
../modules/azure-data-studio.nix ../modules/azure-data-studio.nix
../modules/filezilla.nix ../modules/filezilla.nix
../modules/wireguard.nix
../modules/remmina.nix
../modules/postman.nix
../modules/gimp.nix
../modules/jq.nix
../modules/enova.nix
../modules/devenv.nix
../modules/bitwarden.nix
]; ];
boot.kernelPackages = pkgs.linuxPackages_latest;
boot.loader.systemd-boot.enable = true; boot.loader.systemd-boot.enable = true;
boot.loader.efi.canTouchEfiVariables = true; boot.loader.efi.canTouchEfiVariables = true;
@@ -26,11 +36,21 @@
boot.initrd.systemd.enable = true; boot.initrd.systemd.enable = true;
programs.nix-ld.enable = true; programs.nix-ld.enable = true;
networking.hostName = "laptop-armel"; networking.hostName = "laptop-armel";
home-manager.users.avravels.home.hyprland.execOnce = [
"waybar"
"[workspace 1 silent] kitty"
"[workspace 2 silent] firefox"
"[workspace 2 silent] teams-for-linux"
"[workspace 3 silent] spotify"
];
home-manager.users.avravels.home.git.userName = "Armel van Ravels";
home-manager.users.avravels.home.git.userEmail = "armel@webavance.nl";
networking.networkmanager.enable = true; networking.networkmanager.enable = true;
networking.nameservers = [ "192.168.68.56" "1.1.1.1" "8.8.8.8" ]; networking.nameservers = [ "127.0.0.1" "192.168.68.56" "1.1.1.1" "8.8.8.8" ];
networking.firewall.enable = false; networking.firewall.enable = false;
hardware.graphics.enable = true; hardware.graphics.enable = true;