Compare commits
97 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
d10b195c7e
|
|||
|
119148c764
|
|||
|
ed8f2b4499
|
|||
|
ecdf754a3c
|
|||
|
8b29dff48f
|
|||
|
2cdcb0d9e7
|
|||
|
1ca6b68089
|
|||
|
d0fb5e86c3
|
|||
|
75fbc04c65
|
|||
|
e759d97779
|
|||
|
dc2be45e90
|
|||
|
495e4752bd
|
|||
|
1bc9f0460d
|
|||
|
9f11a3974d
|
|||
|
f7bcc0913a
|
|||
|
a33720a44f
|
|||
|
51ec1e2fef
|
|||
|
e5196e4e72
|
|||
| 1cf837cd65 | |||
|
8a477b4971
|
|||
|
a808aae26a
|
|||
|
b08e092351
|
|||
| 779d9d1562 | |||
|
e3453983be
|
|||
|
ff1ff5fd1c
|
|||
|
1972b5d4da
|
|||
|
3d49015a7c
|
|||
|
c1ec0f3fcb
|
|||
|
22e089223a
|
|||
|
1466608418
|
|||
|
aa9d3a056f
|
|||
|
8ca46d9edc
|
|||
|
13c29bc696
|
|||
|
1c4be3e470
|
|||
|
a01a2bcc47
|
|||
|
7feacb5179
|
|||
|
08a56d8455
|
|||
|
a5820a0b31
|
|||
|
600ef66012
|
|||
|
5ab17b8357
|
|||
|
602767d3a9
|
|||
|
f9a39d3f7d
|
|||
|
d2f3e70c38
|
|||
|
9d62bcede6
|
|||
|
a20a2d4ef6
|
|||
|
21aed28cf7
|
|||
|
05d30742bd
|
|||
|
c441fc6165
|
|||
|
0cf646c9d3
|
|||
|
a381c4886a
|
|||
|
20ffd3307c
|
|||
|
9bdcd24b29
|
|||
|
fbf8265a08
|
|||
|
9ef5bb82c6
|
|||
|
471478ed6b
|
|||
|
5d01659350
|
|||
|
d202d116c0
|
|||
|
5749c06b20
|
|||
|
cdaf170f6f
|
|||
|
4a4283988f
|
|||
|
4a1e5afd79
|
|||
|
6de66cf1cf
|
|||
|
d37e468ae8
|
|||
|
2797bfee0e
|
|||
|
3e19edc73a
|
|||
|
bc336fd6cf
|
|||
|
8e94344e8a
|
|||
|
33e497672a
|
|||
|
9b3135c378
|
|||
|
7a1caeaaa3
|
|||
|
ccd6b38184
|
|||
|
0ceda0b675
|
|||
|
8229f20975
|
|||
|
6c33f7f53e
|
|||
|
64f2e34018
|
|||
|
ea47a2ca71
|
|||
|
824f75f9cb
|
|||
|
77d520e944
|
|||
|
963b45ffa2
|
|||
|
52b3f2eb5e
|
|||
|
b0787ecfd6
|
|||
|
73fcd3619e
|
|||
|
119a2433b4
|
|||
|
cbd3c408e1
|
|||
|
eb593db0c0
|
|||
|
961afbbff7
|
|||
|
6f25e849f0
|
|||
|
71b1e05b2d
|
|||
|
320cac603d
|
|||
|
a306a8cb9a
|
|||
|
db22304952
|
|||
|
79c70eea54
|
|||
|
598306c57e
|
|||
|
6af15d5a00
|
|||
|
93f81a1f7f
|
|||
|
ba58db5873
|
|||
|
9fbb2574d4
|
@@ -9,3 +9,5 @@ creation_rules:
|
|||||||
- "age1x3lahhkefkap67cdmdjcqaxan9hp62er78akr79v9m73nvgugpeqk0y32a" # laptop-user-doloro
|
- "age1x3lahhkefkap67cdmdjcqaxan9hp62er78akr79v9m73nvgugpeqk0y32a" # laptop-user-doloro
|
||||||
- "age1exzngtk4d9vcsmcq6ap5xx3ca9qacqjkrv86ymged7msx9z6vfyqsf5sjq" # laptop-system
|
- "age1exzngtk4d9vcsmcq6ap5xx3ca9qacqjkrv86ymged7msx9z6vfyqsf5sjq" # laptop-system
|
||||||
- "age1fw4xnh2q52juce94ffn54js708cr6umfwpv0mykuddkea7kr4f0q7a9h05" # rpi5
|
- "age1fw4xnh2q52juce94ffn54js708cr6umfwpv0mykuddkea7kr4f0q7a9h05" # rpi5
|
||||||
|
- "age1pa8cecxaw4y4zea6zjnt0k0mz38g4qunmp6trwy5fvdvw88ttcgsv2dgrv" # laptop-surface-user-doloro
|
||||||
|
- "age1kc0xu0ue2nrrr7w4gam7wlzackv8jv243rxwwndgxjqklgtnp5csdtpgzp" # laptop-surface-system
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
den,
|
den,
|
||||||
__findFile,
|
__findFile,
|
||||||
modules,
|
modules,
|
||||||
|
inputs,
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
{
|
{
|
||||||
@@ -17,13 +18,23 @@
|
|||||||
modules.fonts
|
modules.fonts
|
||||||
<modules/hyprland/doloro-settings>
|
<modules/hyprland/doloro-settings>
|
||||||
(modules.obs {
|
(modules.obs {
|
||||||
virtual_audio_devices = true;
|
audio = true;
|
||||||
autostart = true;
|
autostart = true;
|
||||||
})
|
})
|
||||||
<modules/common/gaming>
|
<modules/common/gaming>
|
||||||
modules.helium
|
# modules.helium
|
||||||
|
(<modules/helium> {
|
||||||
|
default = true;
|
||||||
|
})
|
||||||
|
# modules.niri # Testing
|
||||||
modules.stylix
|
modules.stylix
|
||||||
modules.quickshell
|
modules.quickshell
|
||||||
|
modules.nix-ld
|
||||||
|
modules.spotify
|
||||||
|
modules.easyeffects
|
||||||
|
modules.lavd
|
||||||
|
modules.ai
|
||||||
|
<modules/ai/ollama-cuda>
|
||||||
];
|
];
|
||||||
nixos =
|
nixos =
|
||||||
{ config, pkgs, ... }:
|
{ config, pkgs, ... }:
|
||||||
@@ -54,10 +65,17 @@
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
home.packages = with pkgs; [
|
home.packages = with pkgs; [
|
||||||
legcord
|
equibop
|
||||||
telegram-desktop
|
telegram-desktop
|
||||||
obsidian
|
obsidian
|
||||||
|
# pear-desktop
|
||||||
|
prismlauncher
|
||||||
|
deadlock-mod-manager
|
||||||
|
gamescope
|
||||||
|
android-studio
|
||||||
];
|
];
|
||||||
|
nixpkgs.config.allowUnfree = true;
|
||||||
|
programs.home-manager.enable = true;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,7 +2,9 @@
|
|||||||
den,
|
den,
|
||||||
modules,
|
modules,
|
||||||
pkgs,
|
pkgs,
|
||||||
|
inputs,
|
||||||
__findFile,
|
__findFile,
|
||||||
|
lib,
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
{
|
{
|
||||||
@@ -25,6 +27,7 @@
|
|||||||
networking.hostName = "doloroo-main"; # Define your hostname.
|
networking.hostName = "doloroo-main"; # Define your hostname.
|
||||||
|
|
||||||
boot.kernelPackages = pkgs.linuxPackages_latest;
|
boot.kernelPackages = pkgs.linuxPackages_latest;
|
||||||
|
|
||||||
boot.initrd.verbose = false;
|
boot.initrd.verbose = false;
|
||||||
boot.kernelParams = [
|
boot.kernelParams = [
|
||||||
"boot.shell_on_fail"
|
"boot.shell_on_fail"
|
||||||
@@ -80,14 +83,14 @@
|
|||||||
# supported GPUs is at:
|
# supported GPUs is at:
|
||||||
# https://github.com/NVIDIA/open-gpu-kernel-modules#compatible-gpus
|
# https://github.com/NVIDIA/open-gpu-kernel-modules#compatible-gpus
|
||||||
# Only available from driver 515.43.04+
|
# Only available from driver 515.43.04+
|
||||||
open = false;
|
open = true;
|
||||||
|
|
||||||
# Enable the Nvidia settings menu,
|
# Enable the Nvidia settings menu,
|
||||||
# accessible via `nvidia-settings`.
|
# accessible via `nvidia-settings`.
|
||||||
nvidiaSettings = true;
|
nvidiaSettings = true;
|
||||||
|
|
||||||
# Optionally, you may need to select the appropriate driver version for your specific GPU.
|
# Optionally, you may need to select the appropriate driver version for your specific GPU.
|
||||||
package = config.boot.kernelPackages.nvidiaPackages.latest;
|
package = config.boot.kernelPackages.nvidiaPackages.stable;
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -35,7 +35,7 @@
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
plainSwap = {
|
plainSwap = {
|
||||||
size = "48G";
|
size = "24G";
|
||||||
content = {
|
content = {
|
||||||
type = "swap";
|
type = "swap";
|
||||||
discardPolicy = "both"; # Both "once" and page discard policies
|
discardPolicy = "both"; # Both "once" and page discard policies
|
||||||
|
|||||||
@@ -16,20 +16,22 @@
|
|||||||
}:
|
}:
|
||||||
{
|
{
|
||||||
imports = [
|
imports = [
|
||||||
(modulesPath + "/installer/scan/not-detected.nix")
|
# (modulesPath + "/hardware/cpu/intel-npu.nix")
|
||||||
];
|
# (modulesPath + "/installer/scan/not-detected.nix")
|
||||||
boot.initrd.availableKernelModules = [
|
|
||||||
"xhci_pci"
|
|
||||||
"thunderbolt"
|
|
||||||
"vmd"
|
|
||||||
"nvme"
|
|
||||||
];
|
];
|
||||||
|
# boot.initrd.availableKernelModules = [
|
||||||
|
# "xhci_pci"
|
||||||
|
# "thunderbolt"
|
||||||
|
# "vmd"
|
||||||
|
# "nvme"
|
||||||
|
# ];
|
||||||
boot.initrd.kernelModules = [ ];
|
boot.initrd.kernelModules = [ ];
|
||||||
boot.kernelModules = [ "kvm-intel" ];
|
# boot.kernelModules = [ "kvm-intel" ];
|
||||||
boot.extraModulePackages = [ ];
|
boot.extraModulePackages = [ ];
|
||||||
|
|
||||||
nixpkgs.hostPlatform = lib.mkDefault "x86_64-linux";
|
nixpkgs.hostPlatform = lib.mkDefault "aarch64-linux";
|
||||||
hardware.cpu.intel.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware;
|
# hardware.cpu.intel.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware;
|
||||||
|
# hardware.cpu.intel.npu.enable = true;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
den,
|
den,
|
||||||
__findFile,
|
__findFile,
|
||||||
modules,
|
modules,
|
||||||
|
lib,
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
{
|
{
|
||||||
@@ -13,10 +14,15 @@
|
|||||||
<modules/hyprland/doloro-settings>
|
<modules/hyprland/doloro-settings>
|
||||||
modules.sops
|
modules.sops
|
||||||
modules.fish
|
modules.fish
|
||||||
<modules/zen-browser>
|
(<modules/helium> {
|
||||||
|
default = true;
|
||||||
|
})
|
||||||
modules.kitty
|
modules.kitty
|
||||||
modules.stylix
|
modules.stylix
|
||||||
modules.quickshell
|
modules.quickshell
|
||||||
|
modules.lavd
|
||||||
|
# modules.podman
|
||||||
|
# modules.openvivo
|
||||||
];
|
];
|
||||||
nixos =
|
nixos =
|
||||||
{ config, pkgs, ... }:
|
{ config, pkgs, ... }:
|
||||||
@@ -30,10 +36,31 @@
|
|||||||
homeManager =
|
homeManager =
|
||||||
{ pkgs, ... }:
|
{ pkgs, ... }:
|
||||||
{
|
{
|
||||||
|
wayland.windowManager.hyprland.settings = {
|
||||||
|
# monitor = [
|
||||||
|
# "eDP-1, 2880x1800@120, 0x0, 2"
|
||||||
|
# ];
|
||||||
|
input = {
|
||||||
|
kb_layout = "gb";
|
||||||
|
follow_mouse = 2;
|
||||||
|
sensitivity = 0;
|
||||||
|
};
|
||||||
|
decoration = {
|
||||||
|
blur = lib.mkForce {
|
||||||
|
enabled = false;
|
||||||
|
passes = 1;
|
||||||
|
new_optimizations = true;
|
||||||
|
ignore_opacity = false;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
home.packages = with pkgs; [
|
home.packages = with pkgs; [
|
||||||
telegram-desktop
|
telegram-desktop
|
||||||
legcord
|
equibop
|
||||||
obsidian
|
obsidian
|
||||||
|
# intel-gpu-tools
|
||||||
|
brightnessctl
|
||||||
|
surface-control
|
||||||
];
|
];
|
||||||
nixpkgs.config.allowUnfree = true;
|
nixpkgs.config.allowUnfree = true;
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -2,6 +2,8 @@
|
|||||||
den,
|
den,
|
||||||
modules,
|
modules,
|
||||||
__findFile,
|
__findFile,
|
||||||
|
inputs,
|
||||||
|
lib,
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
{
|
{
|
||||||
@@ -9,8 +11,34 @@
|
|||||||
includes = [
|
includes = [
|
||||||
modules.nix
|
modules.nix
|
||||||
modules.tuigreet
|
modules.tuigreet
|
||||||
<modules/common/laptop-power-management>
|
# <modules/common/laptop-power-management>
|
||||||
modules.fonts
|
modules.fonts
|
||||||
|
modules.surface-patches
|
||||||
|
modules.nikpkgs
|
||||||
|
modules.auto-cpufreq
|
||||||
|
modules.tlp
|
||||||
|
# (modules.tdp {
|
||||||
|
# batt = {
|
||||||
|
# cpu = {
|
||||||
|
# long-term = 13;
|
||||||
|
# short-term = 7;
|
||||||
|
# };
|
||||||
|
# mmio = {
|
||||||
|
# long-term = 10;
|
||||||
|
# short-term = 7;
|
||||||
|
# };
|
||||||
|
# };
|
||||||
|
# ac = {
|
||||||
|
# cpu = {
|
||||||
|
# long-term = 120;
|
||||||
|
# short-term = 120;
|
||||||
|
# };
|
||||||
|
# mmio = {
|
||||||
|
# long-term = 40;
|
||||||
|
# short-term = 20;
|
||||||
|
# };
|
||||||
|
# };
|
||||||
|
# })
|
||||||
];
|
];
|
||||||
nixos =
|
nixos =
|
||||||
{ pkgs, config, ... }:
|
{ pkgs, config, ... }:
|
||||||
@@ -18,17 +46,31 @@
|
|||||||
# Use the systemd-boot EFI boot loader.
|
# Use the systemd-boot EFI boot loader.
|
||||||
boot.loader.systemd-boot.enable = true;
|
boot.loader.systemd-boot.enable = true;
|
||||||
boot.loader.efi.canTouchEfiVariables = true;
|
boot.loader.efi.canTouchEfiVariables = true;
|
||||||
|
services.upower.enable = true;
|
||||||
# boot.kernelPackages = pkgs.linuxPackages_6_12; # Hibernate works on 6.12 but not on latest
|
# boot.kernelPackages = pkgs.linuxPackages_6_12; # Hibernate works on 6.12 but not on latest
|
||||||
boot.kernelPackages = pkgs.linuxPackages_zen; # Unpinned the linux version for now.. as i am not using hibernate that often
|
# boot.kernelPackages = pkgs.linuxPackages_latest; # Unpinned the linux version for now.. as i am not using hibernate that often
|
||||||
|
# boot.kernelPackages =
|
||||||
|
# inputs.nix-cachyos-kernel.legacyPackages.x86_64-linux.linuxPackages-cachyos-latest-lto-x86_64-v3;
|
||||||
networking.hostName = "doloro-nixos-laptop"; # Define your hostname.
|
networking.hostName = "doloro-nixos-laptop"; # Define your hostname.
|
||||||
security.rtkit.enable = true;
|
# security.rtkit.enable = true;
|
||||||
|
|
||||||
# Configure network connections interactively with nmcli or nmtui.
|
# Configure network connections interactively with nmcli or nmtui.
|
||||||
networking.networkmanager.enable = true;
|
networking.networkmanager.enable = true;
|
||||||
|
|
||||||
|
boot.initrd = {
|
||||||
|
systemd = {
|
||||||
|
enable = true;
|
||||||
|
emergencyAccess = true;
|
||||||
|
tpm2.enable = false;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
systemd.units."dev-tpm0.device".enable = false;
|
||||||
|
systemd.units."dev-tpmrm0.device".enable = false;
|
||||||
|
|
||||||
# Set your time zone.
|
# Set your time zone.
|
||||||
# time.timeZone = "Europe/London";
|
# time.timeZone = "Europe/London";
|
||||||
services.automatic-timezoned.enable = true;
|
services.automatic-timezoned.enable = true;
|
||||||
|
networking.wireless.iwd.enable = false;
|
||||||
|
|
||||||
nix.settings = {
|
nix.settings = {
|
||||||
substituters = [
|
substituters = [
|
||||||
@@ -49,25 +91,27 @@
|
|||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
|
||||||
services.gnome.gnome-keyring.enable = true;
|
# services.gnome.gnome-keyring.enable = true;
|
||||||
|
|
||||||
|
nixpkgs.config.packageOverrides = pkgs: {
|
||||||
|
intel-vaapi-driver = pkgs.intel-vaapi-driver.override { enableHybridCodec = true; };
|
||||||
|
};
|
||||||
hardware = {
|
hardware = {
|
||||||
# firmware = [ pkgs.intel-npu-driver ];
|
# firmware = [ pkgs.intel-npu-driver ];
|
||||||
cpu.intel = {
|
|
||||||
# npu.enable = true;
|
|
||||||
};
|
|
||||||
graphics = {
|
graphics = {
|
||||||
enable = true;
|
enable = true;
|
||||||
# https://github.com/intel/libvpl?tab=readme-ov-file#dispatcher-behavior-when-targeting-intel-gpus
|
|
||||||
extraPackages = with pkgs; [
|
extraPackages = with pkgs; [
|
||||||
vpl-gpu-rt
|
|
||||||
intel-media-driver # VA-API (iHD) userspace
|
|
||||||
intel-vaapi-driver
|
|
||||||
# vpl-gpu-rt # oneVPL (QSV) runtime
|
|
||||||
intel-compute-runtime # OpenCL (NEO) + Level Zero for Arc/Xe
|
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
environment.sessionVariables = {
|
||||||
|
LIBVA_DRIVER_NAME = "iHD";
|
||||||
|
}; # Force intel-media-driver
|
||||||
|
|
||||||
|
# services.fwupd = {
|
||||||
|
# enable = true;
|
||||||
|
# };
|
||||||
|
|
||||||
services.openssh = {
|
services.openssh = {
|
||||||
enable = true;
|
enable = true;
|
||||||
settings = {
|
settings = {
|
||||||
@@ -97,7 +141,7 @@
|
|||||||
|
|
||||||
services.libinput.enable = true;
|
services.libinput.enable = true;
|
||||||
|
|
||||||
boot.binfmt.emulatedSystems = [ "aarch64-linux" ];
|
# boot.binfmt.emulatedSystems = [ "aarch64-linux" ];
|
||||||
# Define a user account. Don't forget to set a password with ‘passwd’.
|
# Define a user account. Don't forget to set a password with ‘passwd’.
|
||||||
# users.users.doloro = {
|
# users.users.doloro = {
|
||||||
# isNormalUser = true;
|
# isNormalUser = true;
|
||||||
@@ -116,7 +160,7 @@
|
|||||||
password = "meowmeowmeow";
|
password = "meowmeowmeow";
|
||||||
};
|
};
|
||||||
users.mutableUsers = false;
|
users.mutableUsers = false;
|
||||||
services.system76-scheduler.enable = true;
|
services.system76-scheduler.enable = false;
|
||||||
|
|
||||||
powerManagement = {
|
powerManagement = {
|
||||||
enable = true;
|
enable = true;
|
||||||
@@ -126,20 +170,28 @@
|
|||||||
boot.kernelParams = [
|
boot.kernelParams = [
|
||||||
# "mem_sleep_default=deep"
|
# "mem_sleep_default=deep"
|
||||||
# "i915.fastboot=1"
|
# "i915.fastboot=1"
|
||||||
"ahci.mobile_lpm_policy=1"
|
# "i915.modeset=1"
|
||||||
"intel_idle.max_cstate=11"
|
# "ahci.mobile_lpm_policy=1"
|
||||||
|
# "intel_idle.max_cstate=10"
|
||||||
|
"processor.max_cstate=10"
|
||||||
|
"pci=noaer"
|
||||||
|
# "quiet"
|
||||||
|
# "splash"
|
||||||
# "idle=halt"
|
# "idle=halt"
|
||||||
];
|
];
|
||||||
|
boot.binfmt.emulatedSystems = [
|
||||||
|
"x86_64-linux"
|
||||||
|
];
|
||||||
|
|
||||||
services.logind.settings.Login = {
|
services.logind.settings.Login = {
|
||||||
HandleLidSwitch = "suspend";
|
# HandleLidSwitch = "suspend";
|
||||||
HandleLidSwitchExternalPower = "suspend";
|
# HandleLidSwitchExternalPower = "suspend";
|
||||||
HandleLidSwitchDocked = "ignore";
|
# HandleLidSwitchDocked = "ignore";
|
||||||
};
|
};
|
||||||
systemd.sleep.extraConfig = ''
|
# systemd.sleep.extraConfig = ''
|
||||||
HibernateDelaySec=30min
|
# HibernateDelaySec=30min
|
||||||
SuspendEstimationSec=120
|
# SuspendEstimationSec=120
|
||||||
'';
|
# '';
|
||||||
|
|
||||||
# programs.firefox.enable = true;
|
# programs.firefox.enable = true;
|
||||||
|
|
||||||
|
|||||||
@@ -12,16 +12,25 @@
|
|||||||
modules.tmux
|
modules.tmux
|
||||||
<modules/git/doloro>
|
<modules/git/doloro>
|
||||||
modules.hyfetch
|
modules.hyfetch
|
||||||
|
modules.ssh
|
||||||
];
|
];
|
||||||
homeManager =
|
homeManager =
|
||||||
{ pkgs, ... }:
|
{ pkgs, lib, ... }:
|
||||||
{
|
{
|
||||||
home = {
|
home = {
|
||||||
username = "doloro";
|
username = "doloro";
|
||||||
homeDirectory = "/home/doloro";
|
homeDirectory = "/home/doloro";
|
||||||
packages = with pkgs; [ wl-clipboard ];
|
packages = with pkgs; [
|
||||||
|
wl-clipboard
|
||||||
|
# home-manager
|
||||||
|
btop
|
||||||
|
];
|
||||||
};
|
};
|
||||||
programs.home-manager.enable = true;
|
programs.home-manager.enable = true;
|
||||||
};
|
};
|
||||||
|
nixos =
|
||||||
|
{ lib, ... }:
|
||||||
|
{
|
||||||
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,23 +1,40 @@
|
|||||||
{ den, __findFile, ... }:
|
{
|
||||||
|
den,
|
||||||
|
__findFile,
|
||||||
|
lib,
|
||||||
|
...
|
||||||
|
}:
|
||||||
{
|
{
|
||||||
# Homes
|
# Homes
|
||||||
den.homes.x86_64-linux.doloro-desktop = {
|
den.homes.x86_64-linux.doloro-desktop = {
|
||||||
|
aspect = "doloro-desktop";
|
||||||
userName = "doloro";
|
userName = "doloro";
|
||||||
};
|
};
|
||||||
# TODO
|
# TODO
|
||||||
den.homes.x86_64-linux.doloro-laptop = {
|
den.homes.aarch64-linux.doloro-laptop = {
|
||||||
userName = "doloro";
|
userName = "doloro";
|
||||||
};
|
};
|
||||||
# Machines
|
# Machines
|
||||||
den.hosts.x86_64-linux.desktop = {
|
den.hosts.x86_64-linux.desktop = {
|
||||||
users.doloro = {
|
users.doloro = {
|
||||||
aspect = "doloro-desktop";
|
aspect = "doloro-desktop";
|
||||||
|
home-manager.enable = true;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
# TODO
|
# TODO
|
||||||
den.hosts.x86_64-linux.laptop = {
|
den.hosts.aarch64-linux.laptop = {
|
||||||
users.doloro = {
|
users.doloro = {
|
||||||
aspect = "doloro-laptop";
|
aspect = "doloro-laptop";
|
||||||
|
home-manager.enable = true;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
den.schema.user.classes = lib.mkDefault [ "homeManager" ];
|
||||||
|
|
||||||
|
# Fixes 'The option `flake.homeConfigurations' is defined multiple times while it's expected to be unique.'
|
||||||
|
flake.options.homeConfigurations = lib.mkOption {
|
||||||
|
type = lib.types.attrs;
|
||||||
|
description = "Home Manager configurations for users.";
|
||||||
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
+1
-1
@@ -5,6 +5,6 @@
|
|||||||
url = "github:nix-community/home-manager";
|
url = "github:nix-community/home-manager";
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
};
|
};
|
||||||
den.url = "github:vic/den";
|
den.url = "github:vic/den?ref=8101ec865c0bf4027d40b9fd8951e3e435a86d64";
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,19 @@
|
|||||||
|
{ den, modules, ... }:
|
||||||
|
{
|
||||||
|
modules.ai = {
|
||||||
|
provides = {
|
||||||
|
ollama-cuda = {
|
||||||
|
homeManager =
|
||||||
|
{ pkgs, ... }:
|
||||||
|
{
|
||||||
|
home.packages = [ pkgs.ollama-cuda ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
homeManager =
|
||||||
|
{ pkgs, ... }:
|
||||||
|
{
|
||||||
|
home.packages = [ pkgs.opencode ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -0,0 +1,19 @@
|
|||||||
|
{
|
||||||
|
modules,
|
||||||
|
den,
|
||||||
|
inputs,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
{
|
||||||
|
flake-file.inputs = {
|
||||||
|
nix-cachyos-kernel.url = "github:xddxdd/nix-cachyos-kernel/release";
|
||||||
|
};
|
||||||
|
# inputs.nix-cachyos-kernel.legacyPackages.x86_64-linux.linuxPackages-cachyos-lts-lto;
|
||||||
|
modules.cachyos-kernel = {
|
||||||
|
nixos = {
|
||||||
|
nixpkgs.overlays = [
|
||||||
|
inputs.nix-cachyos-kernel.overlays.pinned
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -0,0 +1,8 @@
|
|||||||
|
{ den, modules, ... }:
|
||||||
|
{
|
||||||
|
modules.easyeffects = {
|
||||||
|
homeManager = {
|
||||||
|
services.easyeffects.enable = true;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -30,6 +30,8 @@
|
|||||||
lsof
|
lsof
|
||||||
(gamescope.overrideAttrs {
|
(gamescope.overrideAttrs {
|
||||||
enableWsi = true;
|
enableWsi = true;
|
||||||
|
# Fixes some games being blurry under wayland backend
|
||||||
|
NIX_CFLAGS_COMPILE = [ "-fno-fast-math" ];
|
||||||
})
|
})
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -2,6 +2,8 @@
|
|||||||
den,
|
den,
|
||||||
modules,
|
modules,
|
||||||
inputs,
|
inputs,
|
||||||
|
lib,
|
||||||
|
stdenv,
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
{
|
{
|
||||||
@@ -11,19 +13,19 @@
|
|||||||
inputs.nixpkgs.follows = "nixpkgs";
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
modules.helium = {
|
modules.helium = settings: {
|
||||||
homeManager =
|
homeManager =
|
||||||
{ pkgs, home, ... }:
|
{ pkgs, ... }:
|
||||||
{
|
{
|
||||||
home.packages = [
|
home.packages = [
|
||||||
inputs.heliumFlake.packages.x86_64-linux.helium
|
inputs.heliumFlake.packages.${pkgs.stdenv.hostPlatform.system}.helium
|
||||||
];
|
];
|
||||||
nixpkgs.config.allowUnfree = true;
|
nixpkgs.config.allowUnfree = true;
|
||||||
# Gives me widevine support. yay
|
# Gives me widevine support. yay
|
||||||
xdg.configFile."net.imput.helium/WidevineCdm/latest-component-updated-widevine-cdm" = {
|
xdg.configFile."net.imput.helium/WidevineCdm/latest-component-updated-widevine-cdm" = {
|
||||||
text = ''{"Path":"${pkgs.widevine-cdm}/share/google/chrome/WidevineCdm"}'';
|
text = ''{"Path":"${pkgs.widevine-cdm}/share/google/chrome/WidevineCdm"}'';
|
||||||
};
|
};
|
||||||
wayland.windowManager.hyprland.settings = {
|
wayland.windowManager.hyprland.settings = lib.mkIf settings.default {
|
||||||
binds = [
|
binds = [
|
||||||
"$mainMod, E, exec, helium"
|
"$mainMod, E, exec, helium"
|
||||||
];
|
];
|
||||||
|
|||||||
@@ -14,6 +14,9 @@
|
|||||||
pkgs.wlogout
|
pkgs.wlogout
|
||||||
pkgs.tofi
|
pkgs.tofi
|
||||||
pkgs.killall
|
pkgs.killall
|
||||||
|
pkgs.grim
|
||||||
|
pkgs.slurp
|
||||||
|
pkgs.wayclip
|
||||||
];
|
];
|
||||||
home.pointerCursor = {
|
home.pointerCursor = {
|
||||||
enable = true;
|
enable = true;
|
||||||
@@ -26,7 +29,6 @@
|
|||||||
"XCURSOR_THEME,BreezeX-RosePine-Linux"
|
"XCURSOR_THEME,BreezeX-RosePine-Linux"
|
||||||
"XCURSOR_SIZE,24"
|
"XCURSOR_SIZE,24"
|
||||||
"HYPRCURSOR_SIZE,24"
|
"HYPRCURSOR_SIZE,24"
|
||||||
"LIBVA_DRIVER_NAME,nvidia"
|
|
||||||
"__GLX_VENDOR_LIBRARY_NAME,nvidia"
|
"__GLX_VENDOR_LIBRARY_NAME,nvidia"
|
||||||
"WEBKIT_DISABLE_DMABUF_RENDERER,1" # maybe disable if nixos fixes alcom
|
"WEBKIT_DISABLE_DMABUF_RENDERER,1" # maybe disable if nixos fixes alcom
|
||||||
];
|
];
|
||||||
@@ -59,6 +61,9 @@
|
|||||||
ignore_opacity = false;
|
ignore_opacity = false;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
cursor = {
|
||||||
|
no_hardware_cursors = true;
|
||||||
|
};
|
||||||
animations = {
|
animations = {
|
||||||
enabled = true;
|
enabled = true;
|
||||||
bezier = [
|
bezier = [
|
||||||
@@ -139,8 +144,12 @@
|
|||||||
"$mainMod, down, movefocus, d"
|
"$mainMod, down, movefocus, d"
|
||||||
"$mainMod, L, exec, wlogout"
|
"$mainMod, L, exec, wlogout"
|
||||||
(
|
(
|
||||||
"$mainMod, S, exec, "
|
let
|
||||||
+ ''wayfreeze --after-freeze-cmd 'grim -g "$(slurp -d)" - | wl-copy -t image/png;killall wayfreeze' --hide-cursor''
|
script = pkgs.writeShellScript "meow" ''
|
||||||
|
fish -c 'grim -g $(slurp) -t png - &| wl-copy -t image/png; killall wayfreeze'
|
||||||
|
'';
|
||||||
|
in
|
||||||
|
"$mainMod, S, exec, " + "wayfreeze --after-freeze-cmd '${script}'"
|
||||||
)
|
)
|
||||||
"$mainMod, F, fullscreen"
|
"$mainMod, F, fullscreen"
|
||||||
"$mainMod, mouse_down, workspace, e+1"
|
"$mainMod, mouse_down, workspace, e+1"
|
||||||
@@ -170,7 +179,6 @@
|
|||||||
windowrule = [
|
windowrule = [
|
||||||
"match:class .*, suppress_event maximize"
|
"match:class .*, suppress_event maximize"
|
||||||
"match:class ^(gamescope)$, workspace 5"
|
"match:class ^(gamescope)$, workspace 5"
|
||||||
"match:class ^(gamescope)$, fullscreen true"
|
|
||||||
"match:class ^(gamescope)$, immediate true"
|
"match:class ^(gamescope)$, immediate true"
|
||||||
"match:class ^(steam)$, workspace 6 silent"
|
"match:class ^(steam)$, workspace 6 silent"
|
||||||
"match:class ^(vesktop)$, workspace 8 silent"
|
"match:class ^(vesktop)$, workspace 8 silent"
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
{
|
{
|
||||||
modules,
|
modules,
|
||||||
inputs,
|
inputs,
|
||||||
|
lib,
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
{
|
{
|
||||||
@@ -17,6 +18,7 @@
|
|||||||
grim
|
grim
|
||||||
slurp
|
slurp
|
||||||
wlogout
|
wlogout
|
||||||
|
ranger
|
||||||
];
|
];
|
||||||
programs.xwayland.enable = true;
|
programs.xwayland.enable = true;
|
||||||
programs.hyprland = {
|
programs.hyprland = {
|
||||||
@@ -28,9 +30,12 @@
|
|||||||
portalPackage =
|
portalPackage =
|
||||||
inputs.hyprland.packages.${pkgs.stdenv.hostPlatform.system}.xdg-desktop-portal-hyprland;
|
inputs.hyprland.packages.${pkgs.stdenv.hostPlatform.system}.xdg-desktop-portal-hyprland;
|
||||||
};
|
};
|
||||||
|
# gtk.enable = lib.mkForce false;
|
||||||
xdg.portal = {
|
xdg.portal = {
|
||||||
enable = true;
|
enable = true;
|
||||||
# extraPortals = [ pkgs.xdg-desktop-portal-cosmic ];
|
extraPortals = [
|
||||||
|
inputs.hyprland.packages.${pkgs.stdenv.hostPlatform.system}.xdg-desktop-portal-hyprland
|
||||||
|
];
|
||||||
};
|
};
|
||||||
environment.sessionVariables.NIXOS_OZONE_WL = "1";
|
environment.sessionVariables.NIXOS_OZONE_WL = "1";
|
||||||
hardware.graphics = {
|
hardware.graphics = {
|
||||||
@@ -44,6 +49,9 @@
|
|||||||
homeManager =
|
homeManager =
|
||||||
{ pkgs, ... }:
|
{ pkgs, ... }:
|
||||||
{
|
{
|
||||||
|
gtk = {
|
||||||
|
enable = true;
|
||||||
|
};
|
||||||
wayland.windowManager.hyprland = {
|
wayland.windowManager.hyprland = {
|
||||||
enable = true;
|
enable = true;
|
||||||
systemd.variables = [ "--all" ];
|
systemd.variables = [ "--all" ];
|
||||||
|
|||||||
@@ -0,0 +1,14 @@
|
|||||||
|
{ den, modules, ... }:
|
||||||
|
{
|
||||||
|
modules.wlsunset = {
|
||||||
|
homeManager =
|
||||||
|
{ pkgs, ... }:
|
||||||
|
{
|
||||||
|
systemd.user.services = {
|
||||||
|
wlsunset = {
|
||||||
|
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -0,0 +1,19 @@
|
|||||||
|
{
|
||||||
|
den,
|
||||||
|
modules,
|
||||||
|
inputs,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
{
|
||||||
|
flake-file.inputs = {
|
||||||
|
nik-pkgs = {
|
||||||
|
url = "git+https://git.scug.io/nikkuss/pkgs.git";
|
||||||
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
modules.nikpkgs = {
|
||||||
|
nixos = {
|
||||||
|
nixpkgs.overlays = [ inputs.nik-pkgs.overlays.default ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -0,0 +1,152 @@
|
|||||||
|
{
|
||||||
|
modules,
|
||||||
|
inputs,
|
||||||
|
lib,
|
||||||
|
den,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
{
|
||||||
|
flake-file.inputs = {
|
||||||
|
niri-flake = {
|
||||||
|
url = "github:sodiboo/niri-flake";
|
||||||
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
modules.niri = {
|
||||||
|
nixos =
|
||||||
|
{ pkgs, ... }:
|
||||||
|
{
|
||||||
|
imports = [ inputs.niri-flake.nixosModules.niri ];
|
||||||
|
programs.niri.enable = true;
|
||||||
|
programs.niri.package = pkgs.niri-unstable;
|
||||||
|
nixpkgs.overlays = [ inputs.niri-flake.overlays.niri ];
|
||||||
|
};
|
||||||
|
homeManager =
|
||||||
|
{ pkgs, ... }:
|
||||||
|
{
|
||||||
|
# The nixos module already imports the hm module
|
||||||
|
# imports = [ inputs.niri-flake.homeModules.niri ];
|
||||||
|
gtk.enable = lib.mkForce false;
|
||||||
|
programs = {
|
||||||
|
niri = {
|
||||||
|
# enable = true;
|
||||||
|
# package = pkgs.niri-unstable;
|
||||||
|
settings = {
|
||||||
|
input = {
|
||||||
|
keyboard = {
|
||||||
|
xkb = {
|
||||||
|
layout = "gb";
|
||||||
|
};
|
||||||
|
numlock = true;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
cursor = {
|
||||||
|
size = 16;
|
||||||
|
};
|
||||||
|
outputs = {
|
||||||
|
DP-3 = {
|
||||||
|
# Philips Consumer Electronics Company PHL 272E1GZ UK02101011104
|
||||||
|
mode = {
|
||||||
|
width = 1920;
|
||||||
|
height = 1080;
|
||||||
|
refresh = 144.0;
|
||||||
|
};
|
||||||
|
focus-at-startup = true;
|
||||||
|
variable-refresh-rate = false;
|
||||||
|
};
|
||||||
|
HDMI-A-1 = {
|
||||||
|
position = {
|
||||||
|
x = -1920;
|
||||||
|
y = 0;
|
||||||
|
};
|
||||||
|
scale = 1;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
binds = {
|
||||||
|
# Navigation
|
||||||
|
"Mod+Shift+WheelScrollDown" = {
|
||||||
|
hotkey-overlay.title = "Workspace Down";
|
||||||
|
cooldown-ms = 150;
|
||||||
|
action.focus-workspace-down = [ ];
|
||||||
|
};
|
||||||
|
"Mod+Shift+WheelScrollUp" = {
|
||||||
|
hotkey-overlay.title = "Workspace Up";
|
||||||
|
cooldown-ms = 150;
|
||||||
|
action.focus-workspace-up = [ ];
|
||||||
|
};
|
||||||
|
"Mod+WheelScrollUp" = {
|
||||||
|
hotkey-overlay.title = "Workspace Left";
|
||||||
|
action.focus-column-right = [ ];
|
||||||
|
};
|
||||||
|
"Mod+WheelScrollDown" = {
|
||||||
|
hotkey-overlay.title = "Workspace Right";
|
||||||
|
action.focus-column-left = [ ];
|
||||||
|
};
|
||||||
|
"Super+Tab" = {
|
||||||
|
hotkey-overlay.title = "Overview";
|
||||||
|
action.toggle-overview = [ ];
|
||||||
|
};
|
||||||
|
# --
|
||||||
|
# Utility
|
||||||
|
"Super+S" = {
|
||||||
|
action.screenshot = [ ];
|
||||||
|
};
|
||||||
|
"Super+C" = {
|
||||||
|
action.close-window = [ ];
|
||||||
|
};
|
||||||
|
"Super+L" = {
|
||||||
|
action.spawn = "wlogout";
|
||||||
|
};
|
||||||
|
# Program Spawning
|
||||||
|
"Mod+E".action.spawn = "helium";
|
||||||
|
|
||||||
|
"Mod+R".action.spawn =
|
||||||
|
let
|
||||||
|
config = pkgs.writeTextFile {
|
||||||
|
name = "config";
|
||||||
|
text = ''
|
||||||
|
width = 100%
|
||||||
|
height = 100%
|
||||||
|
border-width = 0
|
||||||
|
outline-width = 0
|
||||||
|
padding-left = 35%
|
||||||
|
padding-top = 35%
|
||||||
|
result-spacing = 25
|
||||||
|
num-results = 5
|
||||||
|
font = monospace
|
||||||
|
background-color = #000A
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
script = pkgs.writeShellScript "mreow" ''
|
||||||
|
exec $(tofi-drun -c ${config})
|
||||||
|
'';
|
||||||
|
in
|
||||||
|
"${script}";
|
||||||
|
|
||||||
|
"Mod+Q".action.spawn = "kitty";
|
||||||
|
# --
|
||||||
|
};
|
||||||
|
window-rules = [
|
||||||
|
{
|
||||||
|
matches = [ ];
|
||||||
|
geometry-corner-radius = {
|
||||||
|
bottom-left = 3.0;
|
||||||
|
bottom-right = 3.0;
|
||||||
|
top-left = 3.0;
|
||||||
|
top-right = 3.0;
|
||||||
|
};
|
||||||
|
clip-to-geometry = true;
|
||||||
|
draw-border-with-background = false;
|
||||||
|
focus-ring.width = 2;
|
||||||
|
}
|
||||||
|
];
|
||||||
|
xwayland-satellite = {
|
||||||
|
enable = true;
|
||||||
|
path = lib.getExe pkgs.xwayland-satellite;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -0,0 +1,156 @@
|
|||||||
|
{ den, modules, ... }:
|
||||||
|
{
|
||||||
|
modules.nix-ld = {
|
||||||
|
nixos =
|
||||||
|
{ pkgs, ... }:
|
||||||
|
{
|
||||||
|
programs.nix-ld = {
|
||||||
|
enable = true;
|
||||||
|
libraries = with pkgs; [
|
||||||
|
# List by default
|
||||||
|
zlib
|
||||||
|
zstd
|
||||||
|
stdenv.cc.cc
|
||||||
|
curl
|
||||||
|
openssl
|
||||||
|
attr
|
||||||
|
libssh
|
||||||
|
bzip2
|
||||||
|
libxml2
|
||||||
|
acl
|
||||||
|
libsodium
|
||||||
|
util-linux
|
||||||
|
xz
|
||||||
|
systemd
|
||||||
|
|
||||||
|
# My own additions
|
||||||
|
xorg.libXcomposite
|
||||||
|
xorg.libXtst
|
||||||
|
xorg.libXrandr
|
||||||
|
xorg.libXext
|
||||||
|
xorg.libX11
|
||||||
|
xorg.libXfixes
|
||||||
|
libGL
|
||||||
|
libva
|
||||||
|
pipewire
|
||||||
|
xorg.libxcb
|
||||||
|
xorg.libXdamage
|
||||||
|
xorg.libxshmfence
|
||||||
|
xorg.libXxf86vm
|
||||||
|
libelf
|
||||||
|
|
||||||
|
# Required
|
||||||
|
glib
|
||||||
|
gtk2
|
||||||
|
|
||||||
|
# Inspired by steam
|
||||||
|
# https://github.com/NixOS/nixpkgs/blob/master/pkgs/by-name/st/steam/package.nix#L36-L85
|
||||||
|
networkmanager
|
||||||
|
vulkan-loader
|
||||||
|
libgbm
|
||||||
|
libdrm
|
||||||
|
libxcrypt
|
||||||
|
coreutils
|
||||||
|
pciutils
|
||||||
|
zenity
|
||||||
|
# glibc_multi.bin # Seems to cause issue in ARM
|
||||||
|
|
||||||
|
# # Without these it silently fails
|
||||||
|
xorg.libXinerama
|
||||||
|
xorg.libXcursor
|
||||||
|
xorg.libXrender
|
||||||
|
xorg.libXScrnSaver
|
||||||
|
xorg.libXi
|
||||||
|
xorg.libSM
|
||||||
|
xorg.libICE
|
||||||
|
gnome2.GConf
|
||||||
|
nspr
|
||||||
|
nss
|
||||||
|
cups
|
||||||
|
libcap
|
||||||
|
SDL2
|
||||||
|
libusb1
|
||||||
|
dbus-glib
|
||||||
|
ffmpeg
|
||||||
|
# Only libraries are needed from those two
|
||||||
|
libudev0-shim
|
||||||
|
|
||||||
|
# needed to run unity
|
||||||
|
gtk3
|
||||||
|
icu
|
||||||
|
libnotify
|
||||||
|
gsettings-desktop-schemas
|
||||||
|
# https://github.com/NixOS/nixpkgs/issues/72282
|
||||||
|
# https://github.com/NixOS/nixpkgs/blob/2e87260fafdd3d18aa1719246fd704b35e55b0f2/pkgs/applications/misc/joplin-desktop/default.nix#L16
|
||||||
|
# log in /home/leo/.config/unity3d/Editor.log
|
||||||
|
# it will segfault when opening files if you don’t do:
|
||||||
|
# export XDG_DATA_DIRS=/nix/store/0nfsywbk0qml4faa7sk3sdfmbd85b7ra-gsettings-desktop-schemas-43.0/share/gsettings-schemas/gsettings-desktop-schemas-43.0:/nix/store/rkscn1raa3x850zq7jp9q3j5ghcf6zi2-gtk+3-3.24.35/share/gsettings-schemas/gtk+3-3.24.35/:$XDG_DATA_DIRS
|
||||||
|
# other issue: (Unity:377230): GLib-GIO-CRITICAL **: 21:09:04.706: g_dbus_proxy_call_sync_internal: assertion 'G_IS_DBUS_PROXY (proxy)' failed
|
||||||
|
|
||||||
|
# Verified games requirements
|
||||||
|
xorg.libXt
|
||||||
|
xorg.libXmu
|
||||||
|
libogg
|
||||||
|
libvorbis
|
||||||
|
SDL
|
||||||
|
SDL2_image
|
||||||
|
glew110
|
||||||
|
libidn
|
||||||
|
tbb
|
||||||
|
|
||||||
|
# Other things from runtime
|
||||||
|
flac
|
||||||
|
freeglut
|
||||||
|
libjpeg
|
||||||
|
libpng
|
||||||
|
libpng12
|
||||||
|
libsamplerate
|
||||||
|
libmikmod
|
||||||
|
libtheora
|
||||||
|
libtiff
|
||||||
|
pixman
|
||||||
|
speex
|
||||||
|
SDL_image
|
||||||
|
SDL_ttf
|
||||||
|
SDL_mixer
|
||||||
|
SDL2_ttf
|
||||||
|
SDL2_mixer
|
||||||
|
libappindicator-gtk2
|
||||||
|
libdbusmenu-gtk2
|
||||||
|
libindicator-gtk2
|
||||||
|
libcaca
|
||||||
|
libcanberra
|
||||||
|
libgcrypt
|
||||||
|
libvpx
|
||||||
|
librsvg
|
||||||
|
xorg.libXft
|
||||||
|
libvdpau
|
||||||
|
# ...
|
||||||
|
# Some more libraries that I needed to run programs
|
||||||
|
pango
|
||||||
|
cairo
|
||||||
|
atk
|
||||||
|
gdk-pixbuf
|
||||||
|
fontconfig
|
||||||
|
freetype
|
||||||
|
dbus
|
||||||
|
alsa-lib
|
||||||
|
expat
|
||||||
|
# for blender
|
||||||
|
libxkbcommon
|
||||||
|
|
||||||
|
libxcrypt-legacy # For natron
|
||||||
|
libGLU # For natron
|
||||||
|
|
||||||
|
fribidi
|
||||||
|
harfbuzz
|
||||||
|
libgpg-error
|
||||||
|
|
||||||
|
# Appimages need fuse, e.g. https://musescore.org/fr/download/musescore-x86_64.AppImage
|
||||||
|
fuse
|
||||||
|
e2fsprogs
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -13,6 +13,7 @@
|
|||||||
"https://attic.scug.io/pkgs"
|
"https://attic.scug.io/pkgs"
|
||||||
"https://cache.nixos-cuda.org"
|
"https://cache.nixos-cuda.org"
|
||||||
"https://niri.cachix.org"
|
"https://niri.cachix.org"
|
||||||
|
"https://attic.xuyh0120.win/lantian"
|
||||||
];
|
];
|
||||||
trusted-public-keys = [
|
trusted-public-keys = [
|
||||||
"hyprland.cachix.org-1:a7pgxzMz7+chwVL3/pzj6jIBMioiJM7ypFP8PwtkuGc="
|
"hyprland.cachix.org-1:a7pgxzMz7+chwVL3/pzj6jIBMioiJM7ypFP8PwtkuGc="
|
||||||
@@ -20,6 +21,7 @@
|
|||||||
"pkgs:+sRbfiZMMX5R3PuAPtIRz/emowDoGZNpozibrnrAvuc="
|
"pkgs:+sRbfiZMMX5R3PuAPtIRz/emowDoGZNpozibrnrAvuc="
|
||||||
"cache.nixos-cuda.org:74DUi4Ye579gUqzH4ziL9IyiJBlDpMRn9MBN8oNan9M="
|
"cache.nixos-cuda.org:74DUi4Ye579gUqzH4ziL9IyiJBlDpMRn9MBN8oNan9M="
|
||||||
"niri.cachix.org-1:Wv0OmO7PsuocRKzfDoJ3mulSl7Z6oezYhGhR+3W2964="
|
"niri.cachix.org-1:Wv0OmO7PsuocRKzfDoJ3mulSl7Z6oezYhGhR+3W2964="
|
||||||
|
"lantian:EeAUQ+W+6r7EtwnmYjeVwx5kOGEBpjlBfPlzGlTNvHc="
|
||||||
];
|
];
|
||||||
experimental-features = [
|
experimental-features = [
|
||||||
"flakes"
|
"flakes"
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
{
|
{
|
||||||
den,
|
den,
|
||||||
modules,
|
modules,
|
||||||
|
lib,
|
||||||
inputs,
|
inputs,
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
@@ -9,11 +10,15 @@
|
|||||||
flake-file.inputs = {
|
flake-file.inputs = {
|
||||||
nixvim = {
|
nixvim = {
|
||||||
url = "github:nix-community/nixvim";
|
url = "github:nix-community/nixvim";
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
# inputs.nixpkgs.follows = "nixpkgs";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
modules = {
|
modules = {
|
||||||
nixvim = {
|
nixvim = {
|
||||||
|
nixos =
|
||||||
|
{ home-manager, ... }:
|
||||||
|
{
|
||||||
|
};
|
||||||
homeManager =
|
homeManager =
|
||||||
{ pkgs, ... }:
|
{ pkgs, ... }:
|
||||||
{
|
{
|
||||||
@@ -23,6 +28,11 @@
|
|||||||
programs.nixvim = {
|
programs.nixvim = {
|
||||||
enable = true;
|
enable = true;
|
||||||
defaultEditor = true;
|
defaultEditor = true;
|
||||||
|
nixpkgs = {
|
||||||
|
config = {
|
||||||
|
allowUnfree = true;
|
||||||
|
};
|
||||||
|
};
|
||||||
colorschemes.gruvbox-material.enable = true;
|
colorschemes.gruvbox-material.enable = true;
|
||||||
extraPackages = with pkgs; [
|
extraPackages = with pkgs; [
|
||||||
# formatters
|
# formatters
|
||||||
@@ -32,6 +42,7 @@
|
|||||||
ripgrep
|
ripgrep
|
||||||
# misc
|
# misc
|
||||||
nixd
|
nixd
|
||||||
|
tree-sitter
|
||||||
];
|
];
|
||||||
performance.byteCompileLua = {
|
performance.byteCompileLua = {
|
||||||
enable = true;
|
enable = true;
|
||||||
@@ -44,6 +55,7 @@
|
|||||||
todo-comments.enable = true;
|
todo-comments.enable = true;
|
||||||
lsp-status.enable = true;
|
lsp-status.enable = true;
|
||||||
transparent.enable = true;
|
transparent.enable = true;
|
||||||
|
which-key.enable = true;
|
||||||
conform-nvim = {
|
conform-nvim = {
|
||||||
enable = true;
|
enable = true;
|
||||||
settings = {
|
settings = {
|
||||||
@@ -62,6 +74,15 @@
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
# efmls-configs = {
|
||||||
|
# enable = true;
|
||||||
|
# languages = {
|
||||||
|
# scss = {
|
||||||
|
# formatter = "prettier";
|
||||||
|
# linter = "stylelint";
|
||||||
|
# };
|
||||||
|
# };
|
||||||
|
# };
|
||||||
lsp = {
|
lsp = {
|
||||||
enable = true;
|
enable = true;
|
||||||
servers = {
|
servers = {
|
||||||
@@ -85,6 +106,7 @@
|
|||||||
ts_ls = {
|
ts_ls = {
|
||||||
enable = true;
|
enable = true;
|
||||||
};
|
};
|
||||||
|
cssls.enable = true;
|
||||||
svelte.enable = true;
|
svelte.enable = true;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
@@ -174,7 +196,7 @@
|
|||||||
tiny-inline-diagnostic.enable = true;
|
tiny-inline-diagnostic.enable = true;
|
||||||
# persisted.enable = true;
|
# persisted.enable = true;
|
||||||
auto-session = {
|
auto-session = {
|
||||||
enable = true;
|
enable = false;
|
||||||
settings = {
|
settings = {
|
||||||
enabled = true;
|
enabled = true;
|
||||||
auto_save = true;
|
auto_save = true;
|
||||||
@@ -190,6 +212,7 @@
|
|||||||
lua
|
lua
|
||||||
make
|
make
|
||||||
markdown
|
markdown
|
||||||
|
rust
|
||||||
nix
|
nix
|
||||||
regex
|
regex
|
||||||
toml
|
toml
|
||||||
@@ -197,6 +220,7 @@
|
|||||||
vimdoc
|
vimdoc
|
||||||
xml
|
xml
|
||||||
yaml
|
yaml
|
||||||
|
svelte
|
||||||
];
|
];
|
||||||
settings = {
|
settings = {
|
||||||
highlight.enable = true;
|
highlight.enable = true;
|
||||||
|
|||||||
+33
-28
@@ -2,7 +2,12 @@
|
|||||||
{
|
{
|
||||||
modules.obs = settings: {
|
modules.obs = settings: {
|
||||||
homeManager =
|
homeManager =
|
||||||
{ pkgs, config, ... }:
|
{
|
||||||
|
pkgs,
|
||||||
|
lib,
|
||||||
|
config,
|
||||||
|
...
|
||||||
|
}:
|
||||||
{
|
{
|
||||||
programs = {
|
programs = {
|
||||||
obs-studio = {
|
obs-studio = {
|
||||||
@@ -19,32 +24,9 @@
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
systemd.user.services =
|
systemd.user.services =
|
||||||
pkgs.lib.mkIf settings.virtual_audio_devices {
|
let
|
||||||
|
audio-set = lib.mkIf settings.audio {
|
||||||
pw-discordaudio-virtual-device = {
|
pw-discordaudio-virtual-device = {
|
||||||
Install = {
|
|
||||||
WantedBy = [ "hyprland-session.target" ];
|
|
||||||
};
|
|
||||||
Service = {
|
|
||||||
ExecStart = "${pkgs.writeShellScript "discord_audio_virt_device" ''
|
|
||||||
#!/run/current-system/sw/bin/bash
|
|
||||||
pw-loopback -m '[ FL FR]' --capture-props='media.class=Audio/Sink node.name=DiscordSink' -n DiscordSink
|
|
||||||
''}";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
pw-gameaudio-virtual-device = {
|
|
||||||
Install = {
|
|
||||||
WantedBy = [ "hyprland-session.target" ];
|
|
||||||
};
|
|
||||||
Service = {
|
|
||||||
ExecStart = "${pkgs.writeShellScript "game_audio_virt_device" ''
|
|
||||||
#!/run/current-system/sw/bin/bash
|
|
||||||
pw-loopback -m '[ FL FR]' --capture-props='media.class=Audio/Sink node.name=GameAudioSink' -n GameAudioSink
|
|
||||||
''}";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
||||||
// pkgs.lib.mkIf settings.autostart {
|
|
||||||
obs-autostart = {
|
|
||||||
Unit = {
|
Unit = {
|
||||||
Description = "OBS daemon";
|
Description = "OBS daemon";
|
||||||
After = [ "hyprland-session.target" ];
|
After = [ "hyprland-session.target" ];
|
||||||
@@ -53,13 +35,36 @@
|
|||||||
WantedBy = [ "default.target" ];
|
WantedBy = [ "default.target" ];
|
||||||
};
|
};
|
||||||
Service = {
|
Service = {
|
||||||
# wait for hyprland to start
|
ExecStart = "${pkgs.writeShellScript "discord_audio_virt_device" ''
|
||||||
ExecStart = "${config.programs.obs-studio.finalPackage}/bin/obs --startreplaybuffer";
|
pw-loopback -m '[ FL FR]' --capture-props='media.class=Audio/Sink node.name=DiscordSink' -n DiscordSink
|
||||||
|
''}";
|
||||||
|
Restart = "on-failure";
|
||||||
|
RestartSec = "5s";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
pw-gameaudio-virtual-device = {
|
||||||
|
Unit = {
|
||||||
|
Description = "OBS daemon";
|
||||||
|
After = [ "hyprland-session.target" ];
|
||||||
|
};
|
||||||
|
Install = {
|
||||||
|
WantedBy = [ "default.target" ];
|
||||||
|
};
|
||||||
|
Service = {
|
||||||
|
ExecStart = "${pkgs.writeShellScript "game_audio_virt_device" ''
|
||||||
|
pw-loopback -m '[ FL FR]' --capture-props='media.class=Audio/Sink node.name=GameAudioSink' -n GameAudioSink
|
||||||
|
''}";
|
||||||
Restart = "on-failure";
|
Restart = "on-failure";
|
||||||
RestartSec = "5s";
|
RestartSec = "5s";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
in
|
||||||
|
lib.mergeAttrsList [ audio-set ];
|
||||||
|
|
||||||
|
wayland.windowManager.hyprland.settings = {
|
||||||
|
exec-once = [ "${config.programs.obs-studio.finalPackage}/bin/obs --startreplaybuffer" ];
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,35 @@
|
|||||||
|
{
|
||||||
|
den,
|
||||||
|
modules,
|
||||||
|
lib,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
{
|
||||||
|
modules.openvivo = {
|
||||||
|
nixos =
|
||||||
|
{ pkgs, ... }:
|
||||||
|
let
|
||||||
|
llama = pkgs.fetchFromGitHub ({
|
||||||
|
owner = "ravi9";
|
||||||
|
repo = "llama.cpp";
|
||||||
|
rev = "1117e77";
|
||||||
|
hash = "sha256-7NMhKGxfutZ7i16ra3EA4pYEnLl0S23E6TFY7IhVPXU=";
|
||||||
|
});
|
||||||
|
in
|
||||||
|
{
|
||||||
|
virtualisation.oci-containers.backend = "podman";
|
||||||
|
virtualisation.oci-containers.containers = {
|
||||||
|
openvino = {
|
||||||
|
image = "openvino:latest";
|
||||||
|
imageFile = pkgs.dockerTools.buildImage {
|
||||||
|
name = "openvino";
|
||||||
|
tag = "latest";
|
||||||
|
fromImage = "${llama}/.devops/openvino.Dockerfile";
|
||||||
|
};
|
||||||
|
autoStart = true;
|
||||||
|
ports = [ "127.0.0.1:1234:1234" ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -0,0 +1,22 @@
|
|||||||
|
{ den, modules, ... }:
|
||||||
|
{
|
||||||
|
modules.podman = {
|
||||||
|
nixos =
|
||||||
|
{ ... }:
|
||||||
|
{
|
||||||
|
virtualisation = {
|
||||||
|
containers.enable = true;
|
||||||
|
podman = {
|
||||||
|
enable = true;
|
||||||
|
dockerCompat = true;
|
||||||
|
defaultNetwork.settings = {
|
||||||
|
dns_enabled = true;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
users.users."doloro" = {
|
||||||
|
extraGroups = [ "podman" ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -8,6 +8,20 @@
|
|||||||
SUBSYSTEM=="power_supply",ENV{POWER_SUPPLY_ONLINE}=="0", RUN+="/run/current-system/systemd/bin/systemctl start battery.target"
|
SUBSYSTEM=="power_supply",ENV{POWER_SUPPLY_ONLINE}=="0", RUN+="/run/current-system/systemd/bin/systemctl start battery.target"
|
||||||
SUBSYSTEM=="power_supply", ENV{POWER_SUPPLY_ONLINE}=="1", RUN+="/run/current-system/systemd/bin/systemctl start ac.target"
|
SUBSYSTEM=="power_supply", ENV{POWER_SUPPLY_ONLINE}=="1", RUN+="/run/current-system/systemd/bin/systemctl start ac.target"
|
||||||
'';
|
'';
|
||||||
|
systemd.targets = {
|
||||||
|
"ac" = {
|
||||||
|
description = "On AC power";
|
||||||
|
unitConfig = {
|
||||||
|
StopWhenUnneeded = "yes";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
"battery" = {
|
||||||
|
description = "On battery power";
|
||||||
|
unitConfig = {
|
||||||
|
StopWhenUnneeded = "yes";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,11 +3,17 @@
|
|||||||
modules.common.provides = {
|
modules.common.provides = {
|
||||||
laptop-power-management = {
|
laptop-power-management = {
|
||||||
includes = [
|
includes = [
|
||||||
modules.auto-cpufreq
|
# modules.auto-cpufreq
|
||||||
modules.battery-ac-targets
|
modules.battery-ac-targets
|
||||||
modules.intel-mgm
|
modules.intel-mgm
|
||||||
modules.tlp
|
modules.tlp
|
||||||
|
modules.rfkill-sleep
|
||||||
|
# modules.ppd
|
||||||
];
|
];
|
||||||
|
nixos = {
|
||||||
|
services.upower.enable = true;
|
||||||
|
services.thermald.enable = true;
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,22 @@
|
|||||||
|
{ modules, den, ... }:
|
||||||
|
{
|
||||||
|
modules.flash = {
|
||||||
|
nixos = {
|
||||||
|
services.scx = {
|
||||||
|
enable = true;
|
||||||
|
## Commented out because the service impl is bugged and doesnt actually set these
|
||||||
|
# scheduler = "scx_lavd";
|
||||||
|
# extraArgs = [
|
||||||
|
# "--cpu-pref-order 20-21,12-19,0-11"
|
||||||
|
# "--autopilot"
|
||||||
|
# ];
|
||||||
|
};
|
||||||
|
# Most energy efficent scheduler setup..
|
||||||
|
systemd.services.scx.environment = {
|
||||||
|
SCX_SCHEDULER_OVERRIDE = "scx_flash";
|
||||||
|
# Flags are from cachyos sched-ext tutorial
|
||||||
|
SCX_FLAGS_OVERRIDE = "-m powersave -I 10000 -t 1000 -s 10000 -S 1000";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -6,18 +6,18 @@
|
|||||||
{ pkgs, ... }:
|
{ pkgs, ... }:
|
||||||
let
|
let
|
||||||
batt-gpu = pkgs.writeShellScript "batt-igpu" ''
|
batt-gpu = pkgs.writeShellScript "batt-igpu" ''
|
||||||
${pkgs.intel-gpu-tools}/bin/intel_gpu_frequency -e
|
${pkgs.intel-gpu-tools}/bin/intel_gpu_frequency -e;
|
||||||
echo "800" > /sys/class/drm/card1/gt_boost_freq_mhz
|
echo '1250' > /sys/class/drm/card1/gt_boost_freq_mhz;
|
||||||
'';
|
'';
|
||||||
ac-gpu = pkgs.writeShellScript "ac-igpu" ''
|
ac-gpu = pkgs.writeShellScript "ac-igpu" ''
|
||||||
${pkgs.intel-gpu-tools}/bin/intel_gpu_frequency -d
|
${pkgs.intel-gpu-tools}/bin/intel_gpu_frequency -d;
|
||||||
echo "2350" > /sys/class/drm/card1/gt_boost_freq_mhz
|
echo '2350' > /sys/class/drm/card1/gt_boost_freq_mhz;
|
||||||
'';
|
'';
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
systemd.services.gpu-limit-on-batt = {
|
systemd.services.gpu-limit-on-batt = {
|
||||||
enable = true;
|
enable = true;
|
||||||
description = "Using rfkill; disable all rf devices before sleeping.";
|
description = "Gpu Limit";
|
||||||
before = [ "battery.target" ];
|
before = [ "battery.target" ];
|
||||||
|
|
||||||
serviceConfig = {
|
serviceConfig = {
|
||||||
@@ -30,7 +30,7 @@
|
|||||||
};
|
};
|
||||||
systemd.services.gpu-limit-on-ac = {
|
systemd.services.gpu-limit-on-ac = {
|
||||||
enable = true;
|
enable = true;
|
||||||
description = "Using rfkill; disable all rf devices before sleeping.";
|
description = "Gpu Limit";
|
||||||
before = [ "ac.target" ];
|
before = [ "ac.target" ];
|
||||||
|
|
||||||
serviceConfig = {
|
serviceConfig = {
|
||||||
|
|||||||
@@ -0,0 +1,25 @@
|
|||||||
|
{ modules, den, ... }:
|
||||||
|
{
|
||||||
|
modules.lavd = {
|
||||||
|
nixos =
|
||||||
|
{ pkgs, ... }:
|
||||||
|
{
|
||||||
|
nixpkgs.config.allowUnsupportedSystem = true;
|
||||||
|
services.scx = {
|
||||||
|
enable = true;
|
||||||
|
package = pkgs.scx.rustscheds;
|
||||||
|
## Commented out because the service impl is bugged and doesnt actually set these
|
||||||
|
# scheduler = "scx_lavd";
|
||||||
|
# extraArgs = [
|
||||||
|
# "--cpu-pref-order 20-21,12-19,0-11"
|
||||||
|
# "--autopilot"
|
||||||
|
# ];
|
||||||
|
};
|
||||||
|
# Most energy efficent scheduler setup..
|
||||||
|
systemd.services.scx.environment = {
|
||||||
|
SCX_SCHEDULER_OVERRIDE = "scx_lavd";
|
||||||
|
SCX_FLAGS_OVERRIDE = "--powersave --cpu-pref-order=0-4,5-11";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -0,0 +1,11 @@
|
|||||||
|
{ den, modules, ... }:
|
||||||
|
{
|
||||||
|
modules.ppd = {
|
||||||
|
nixos = {
|
||||||
|
services.power-profiles-daemon.enable = true;
|
||||||
|
powerManagement = {
|
||||||
|
cpuFreqGovernor = "schedutil";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -0,0 +1,26 @@
|
|||||||
|
{ den, modules, ... }:
|
||||||
|
{
|
||||||
|
modules.rfkill-sleep = {
|
||||||
|
nixos =
|
||||||
|
{ pkgs, ... }:
|
||||||
|
{
|
||||||
|
# My laptop doesn't like having connectivity when it goes to sleep, it burns through battery
|
||||||
|
systemd.services.sleep-rfkill = {
|
||||||
|
description = "Custom suspend/resume hook";
|
||||||
|
wantedBy = [ "sleep.target" ];
|
||||||
|
before = [ "sleep.target" ];
|
||||||
|
serviceConfig = {
|
||||||
|
Type = "oneshot";
|
||||||
|
# Command to run BEFORE system suspends
|
||||||
|
ExecStart = "${pkgs.util-linux}/bin/rfkill block all";
|
||||||
|
# Command to run AFTER system resumes
|
||||||
|
ExecStop = "${pkgs.util-linux}/bin/rfkill unblock all";
|
||||||
|
RemainAfterExit = true;
|
||||||
|
};
|
||||||
|
unitConfig = {
|
||||||
|
StopWhenUnneeded = true;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -0,0 +1,65 @@
|
|||||||
|
{ modules, den, ... }:
|
||||||
|
{
|
||||||
|
modules.tdp = settings: {
|
||||||
|
nixos =
|
||||||
|
{ pkgs, ... }:
|
||||||
|
let
|
||||||
|
batt-tdp = pkgs.writeShellScript "batt-cpu-tdp" ''
|
||||||
|
${pkgs.powercap}/bin/powercap-set intel-rapl -z 0 -c 0 -l ${
|
||||||
|
toString (settings.batt.cpu.long-term * 1000000)
|
||||||
|
}
|
||||||
|
${pkgs.powercap}/bin/powercap-set intel-rapl -z 0 -c 1 -l ${
|
||||||
|
toString (settings.batt.cpu.short-term * 1000000)
|
||||||
|
}
|
||||||
|
|
||||||
|
${pkgs.powercap}/bin/powercap-set intel-rapl-mmio -z 0 -c 0 -l ${
|
||||||
|
toString (settings.batt.mmio.long-term * 1000000)
|
||||||
|
}
|
||||||
|
${pkgs.powercap}/bin/powercap-set intel-rapl-mmio -z 0 -c 1 -l ${
|
||||||
|
toString (settings.batt.mmio.short-term * 1000000)
|
||||||
|
}
|
||||||
|
'';
|
||||||
|
ac-tdp = pkgs.writeShellScript "ac-cpu-tdp" ''
|
||||||
|
${pkgs.powercap}/bin/powercap-set intel-rapl -z 0 -c 0 -l ${
|
||||||
|
toString (settings.ac.cpu.long-term * 1000000)
|
||||||
|
}
|
||||||
|
${pkgs.powercap}/bin/powercap-set intel-rapl -z 0 -c 1 -l ${
|
||||||
|
toString (settings.ac.cpu.short-term * 1000000)
|
||||||
|
}
|
||||||
|
|
||||||
|
${pkgs.powercap}/bin/powercap-set intel-rapl-mmio -z 0 -c 0 -l ${
|
||||||
|
toString (settings.batt.mmio.long-term * 1000000)
|
||||||
|
}
|
||||||
|
${pkgs.powercap}/bin/powercap-set intel-rapl-mmio -z 0 -c 1 -l ${
|
||||||
|
toString (settings.batt.mmio.short-term * 1000000)
|
||||||
|
}
|
||||||
|
'';
|
||||||
|
in
|
||||||
|
{
|
||||||
|
systemd.services.tdp-on-batt = {
|
||||||
|
enable = true;
|
||||||
|
before = [ "battery.target" ];
|
||||||
|
|
||||||
|
serviceConfig = {
|
||||||
|
Type = "oneshot";
|
||||||
|
ExecStart = "${batt-tdp}";
|
||||||
|
RemainAfterExit = true;
|
||||||
|
};
|
||||||
|
wantedBy = [ "battery.target" ];
|
||||||
|
partOf = [ "battery.target" ];
|
||||||
|
};
|
||||||
|
systemd.services.tdp-on-ac = {
|
||||||
|
enable = true;
|
||||||
|
before = [ "ac.target" ];
|
||||||
|
|
||||||
|
serviceConfig = {
|
||||||
|
Type = "oneshot";
|
||||||
|
ExecStart = "${ac-tdp}";
|
||||||
|
RemainAfterExit = true;
|
||||||
|
};
|
||||||
|
wantedBy = [ "ac.target" ];
|
||||||
|
partOf = [ "ac.target" ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -5,6 +5,7 @@
|
|||||||
nixos = {
|
nixos = {
|
||||||
services.tlp = {
|
services.tlp = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
pd.enable = true;
|
||||||
settings = {
|
settings = {
|
||||||
# Wireless power saving
|
# Wireless power saving
|
||||||
WIFI_PWR_ON_BAT = "on";
|
WIFI_PWR_ON_BAT = "on";
|
||||||
@@ -15,9 +16,6 @@
|
|||||||
# SATA drive power management
|
# SATA drive power management
|
||||||
SATA_LINKPWR_ON_BAT = "min_power";
|
SATA_LINKPWR_ON_BAT = "min_power";
|
||||||
|
|
||||||
# PCI Express Active-State Power Management (ASPM)
|
|
||||||
PCIE_ASPM_ON_BAT = "powersupersave";
|
|
||||||
|
|
||||||
RUNTIME_PM_ON_AC = "auto";
|
RUNTIME_PM_ON_AC = "auto";
|
||||||
RUNTIME_PM_ON_BAT = "auto";
|
RUNTIME_PM_ON_BAT = "auto";
|
||||||
|
|
||||||
@@ -26,21 +24,23 @@
|
|||||||
|
|
||||||
# Restore brightness on battery
|
# Restore brightness on battery
|
||||||
RESTORE_BRIGHTNESS_ON_BAT = "1";
|
RESTORE_BRIGHTNESS_ON_BAT = "1";
|
||||||
PCIE_ASPM_ON_AC = "balanced";
|
PCIE_ASPM_ON_AC = "default";
|
||||||
|
PCIE_ASPM_ON_BAT = "powersave";
|
||||||
DEVICES_TO_DISABLE_ON_BAT_NOT_IN_USE = "bluetooth";
|
DEVICES_TO_DISABLE_ON_BAT_NOT_IN_USE = "bluetooth";
|
||||||
INTEL_GPU_MAX_FREQ_ON_AC = 0;
|
INTEL_GPU_MAX_FREQ_ON_AC = 0;
|
||||||
INTEL_GPU_MAX_FREQ_ON_BAT = 800;
|
INTEL_GPU_MAX_FREQ_ON_BAT = 800;
|
||||||
INTEL_GPU_BOOST_FREQ_ON_AC = 0;
|
INTEL_GPU_BOOST_FREQ_ON_AC = 0;
|
||||||
INTEL_GPU_BOOST_FREQ_ON_BAT = 800;
|
INTEL_GPU_BOOST_FREQ_ON_BAT = 1250;
|
||||||
|
INTEL_GPU_POWER_PROFILE_ON_BAT = "power_saving";
|
||||||
|
|
||||||
CPU_MAX_PERF_ON_BAT = 30;
|
# CPU_MAX_PERF_ON_BAT = 30;
|
||||||
|
|
||||||
CPU_SCALING_GOVERNOR_ON_AC = "performance";
|
# CPU_SCALING_GOVERNOR_ON_AC = "performance";
|
||||||
CPU_SCALING_GOVERNOR_ON_BAT = "powersave";
|
CPU_SCALING_GOVERNOR_ON_BAT = "schedutil";
|
||||||
CPU_HWP_DYN_BOOST_ON_AC = "1";
|
# CPU_HWP_DYN_BOOST_ON_AC = "1";
|
||||||
CPU_HWP_DYN_BOOST_ON_BAT = "0";
|
# CPU_HWP_DYN_BOOST_ON_BAT = "0";
|
||||||
CPU_ENERGY_PERF_POLICY_ON_BAT = "power";
|
# CPU_ENERGY_PERF_POLICY_ON_BAT = "power";
|
||||||
CPU_ENERGY_PERF_POLICY_ON_AC = "performance";
|
# CPU_ENERGY_PERF_POLICY_ON_AC = "performance";
|
||||||
MAX_LOST_WORK_SECS_ON_BAT = "60";
|
MAX_LOST_WORK_SECS_ON_BAT = "60";
|
||||||
MAX_LOST_WORK_SECS_ON_AC = "15";
|
MAX_LOST_WORK_SECS_ON_AC = "15";
|
||||||
DISK_IDLE_SECS_ON_AC = "0";
|
DISK_IDLE_SECS_ON_AC = "0";
|
||||||
@@ -49,6 +49,9 @@
|
|||||||
DISK_IDLE_SECS_ON_BAT = "2";
|
DISK_IDLE_SECS_ON_BAT = "2";
|
||||||
SOUND_POWER_SAVE_ON_BAT = "1";
|
SOUND_POWER_SAVE_ON_BAT = "1";
|
||||||
SOUND_POWER_SAVE_ON_AC = "1";
|
SOUND_POWER_SAVE_ON_AC = "1";
|
||||||
|
SCHED_POWERSAVE_ON_AC = 0;
|
||||||
|
SCHED_POWERSAVE_ON_BAT = 1;
|
||||||
|
NMI_WATCHDOG = 0;
|
||||||
|
|
||||||
PLATFORM_PROFILE_ON_AC = "balanced";
|
PLATFORM_PROFILE_ON_AC = "balanced";
|
||||||
PLATFORM_PROFILE_ON_BAT = "quiet";
|
PLATFORM_PROFILE_ON_BAT = "quiet";
|
||||||
|
|||||||
@@ -9,22 +9,12 @@
|
|||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
{
|
{
|
||||||
home.file.".config/quickshell" = {
|
programs.quickshell = {
|
||||||
recursive = true;
|
systemd.enable = true;
|
||||||
source = config.lib.file.mkOutOfStoreSymlink ./quickshell;
|
enable = true;
|
||||||
};
|
activeConfig = "main";
|
||||||
systemd.user.services.quickshell = {
|
configs = {
|
||||||
Unit = {
|
main = config.lib.file.mkOutOfStoreSymlink "/home/doloro/dotfiles/config/modules/quickshell/quickshell";
|
||||||
Description = "Quickshell daemon";
|
|
||||||
After = [ "hyprland-session.target" ];
|
|
||||||
};
|
|
||||||
Install = {
|
|
||||||
WantedBy = [ "default.target" ];
|
|
||||||
};
|
|
||||||
Service = {
|
|
||||||
ExecStart = "${pkgs.quickshell}/bin/quickshell";
|
|
||||||
Restart = "on-failure";
|
|
||||||
RestartSec = "5s";
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -0,0 +1 @@
|
|||||||
|
/run/user/1000/quickshell/vfs/6e389f6b800776b0595d9d90e42ebd04/.qmlls.ini
|
||||||
@@ -0,0 +1,36 @@
|
|||||||
|
import QtQuick
|
||||||
|
import QtQuick.Layouts
|
||||||
|
import Quickshell
|
||||||
|
import Quickshell.Services.UPower
|
||||||
|
import Quickshell.Services.Pipewire
|
||||||
|
|
||||||
|
Rectangle {
|
||||||
|
id: root
|
||||||
|
property PwNode defaultSpeaker: Pipewire.preferredDefaultAudioSink
|
||||||
|
property PwNode defaultMic: Pipewire.defaultAudioSource
|
||||||
|
|
||||||
|
PwObjectTracker {
|
||||||
|
objects: [root.defaultSpeaker, root.defaultMic]
|
||||||
|
}
|
||||||
|
visible: root.defaultSpeaker.audio.muted || root.defaultMic.audio.muted
|
||||||
|
implicitHeight: 20
|
||||||
|
implicitWidth: content.width
|
||||||
|
color: Colors.backgroundAlt
|
||||||
|
Layout.alignment: Qt.AlignCenter
|
||||||
|
radius: 3.5
|
||||||
|
RowLayout {
|
||||||
|
id: content
|
||||||
|
height: 20
|
||||||
|
anchors.centerIn: parent
|
||||||
|
Text {
|
||||||
|
id: speaker
|
||||||
|
text: root.defaultSpeaker.audio.muted ? "muted" : "unmuted"
|
||||||
|
color: Colors.textPrimary
|
||||||
|
}
|
||||||
|
Text {
|
||||||
|
id: mic
|
||||||
|
text: root.defaultMic.audio.muted ? "muted" : "unmuted"
|
||||||
|
color: Colors.textPrimary
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -28,31 +28,42 @@ Scope {
|
|||||||
left: parent.left
|
left: parent.left
|
||||||
right: parent.right
|
right: parent.right
|
||||||
// bottomMargin: 2
|
// bottomMargin: 2
|
||||||
leftMargin: 5
|
leftMargin: 0
|
||||||
rightMargin: 5
|
rightMargin: 0
|
||||||
}
|
}
|
||||||
RowLayout {
|
RowLayout {
|
||||||
// Left
|
// Left
|
||||||
Layout.alignment: Qt.AlignLeft
|
Layout.alignment: Qt.AlignLeft
|
||||||
|
// To make sure no children mess with the height of all the other children.
|
||||||
|
// because if one widget is too height, it'll ofset all the other children in the bar
|
||||||
|
Layout.preferredHeight: 20
|
||||||
|
Workspaces {}
|
||||||
}
|
}
|
||||||
RowLayout {
|
RowLayout {
|
||||||
// Center
|
// Center
|
||||||
Layout.alignment: Qt.AlignCenter
|
Layout.alignment: Qt.AlignCenter
|
||||||
|
Layout.preferredHeight: 20
|
||||||
}
|
}
|
||||||
RowLayout {
|
RowLayout {
|
||||||
// Right
|
// Right
|
||||||
Layout.alignment: Qt.AlignRight
|
Layout.alignment: Qt.AlignRight
|
||||||
|
Layout.preferredHeight: 20
|
||||||
|
// spacing: 100
|
||||||
|
spacing: 10
|
||||||
|
Audio {}
|
||||||
|
BatteryWidget {}
|
||||||
Rectangle {
|
Rectangle {
|
||||||
width: meow.width
|
implicitWidth: clockText.width
|
||||||
height: meow.height
|
implicitHeight: clockText.height
|
||||||
radius: 3.5
|
radius: 3.5
|
||||||
|
|
||||||
color: "white"
|
color: Colors.backgroundAlt
|
||||||
|
|
||||||
anchors.centerIn: parent
|
Layout.alignment: Qt.AlignCenter
|
||||||
Text {
|
Text {
|
||||||
id: meow
|
id: clockText
|
||||||
// font.pointSize: 24
|
color: Colors.textPrimary
|
||||||
|
font: "CaskaydiaCove NFM"
|
||||||
text: Clock.time
|
text: Clock.time
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,26 @@
|
|||||||
|
import QtQuick
|
||||||
|
import QtQuick.Layouts
|
||||||
|
import Quickshell
|
||||||
|
import Quickshell.Services.UPower
|
||||||
|
|
||||||
|
RowLayout {
|
||||||
|
id: content
|
||||||
|
height: 20
|
||||||
|
anchors.centerIn: root
|
||||||
|
visible: UPower.displayDevice.percentage != 0
|
||||||
|
property string charging: UPower.displayDevice.state == UPowerDeviceState.Charging ? "Charging.." : ""
|
||||||
|
Rectangle {
|
||||||
|
implicitHeight: text.height
|
||||||
|
implicitWidth: text.width
|
||||||
|
color: Colors.backgroundAlt
|
||||||
|
Layout.alignment: Qt.AlignCenter
|
||||||
|
radius: 3.5
|
||||||
|
Text {
|
||||||
|
id: text
|
||||||
|
property int power: UPower.displayDevice.percentage * 100
|
||||||
|
anchors.centerIn: parent
|
||||||
|
text: charging + " " + power + "%"
|
||||||
|
color: Colors.textPrimary
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,109 @@
|
|||||||
|
pragma Singleton
|
||||||
|
import QtQuick 2.15
|
||||||
|
|
||||||
|
// Gruvbox Dark — base24 QML singleton
|
||||||
|
// Notes:
|
||||||
|
// - This is a template for a "base24" palette. Replace the baseNN hex values
|
||||||
|
// with your exact base24 values if you have them.
|
||||||
|
// - Semantic aliases (background, textPrimary, accentBlue, etc.) map to the
|
||||||
|
// palette entries and make QML usage easier.
|
||||||
|
|
||||||
|
// "Thanks CoPilot" - Doloro
|
||||||
|
|
||||||
|
QtObject {
|
||||||
|
id: gruvbox
|
||||||
|
|
||||||
|
// ---- Base24 palette (base00 .. base23) ----
|
||||||
|
// Replace these hex values with exact ones from the base24 palette if needed.
|
||||||
|
property color base00: "#1d2021" // darkest background
|
||||||
|
property color base01: "#282828"
|
||||||
|
property color base02: "#32302f"
|
||||||
|
property color base03: "#3c3836"
|
||||||
|
property color base04: "#504945"
|
||||||
|
property color base05: "#665c54"
|
||||||
|
property color base06: "#7c6f64"
|
||||||
|
property color base07: "#928374"
|
||||||
|
property color base08: "#bdae93"
|
||||||
|
property color base09: "#d5c4a1"
|
||||||
|
property color base10: "#ebdbb2" // main foreground
|
||||||
|
property color base11: "#fbf1c7"
|
||||||
|
property color base12: "#cc241d" // red
|
||||||
|
property color base13: "#d65d0e" // orange
|
||||||
|
property color base14: "#d79921" // yellow
|
||||||
|
property color base15: "#98971a" // green
|
||||||
|
property color base16: "#689d6a" // aqua/green
|
||||||
|
property color base17: "#8ec07c" // light aqua
|
||||||
|
property color base18: "#458588" // blue
|
||||||
|
property color base19: "#b16286" // purple
|
||||||
|
property color base20: "#a89984" // muted
|
||||||
|
property color base21: "#7c6f64" // subtle
|
||||||
|
property color base22: "#504945"
|
||||||
|
property color base23: "#282828" // repeat or very dark
|
||||||
|
|
||||||
|
// ---- Semantic aliases (use these in your QML components) ----
|
||||||
|
property color background: base00
|
||||||
|
property color backgroundAlt: base01
|
||||||
|
property color surface: base02
|
||||||
|
property color surfaceAlt: base03
|
||||||
|
|
||||||
|
property color textPrimary: base10
|
||||||
|
property color textSecondary: base06
|
||||||
|
property color textDisabled: base04
|
||||||
|
property color border: base05
|
||||||
|
property color muted: base20
|
||||||
|
|
||||||
|
// accents
|
||||||
|
property color accentRed: base12
|
||||||
|
property color accentOrange: base13
|
||||||
|
property color accentYellow: base14
|
||||||
|
property color accentGreen: base15
|
||||||
|
property color accentAqua: base16
|
||||||
|
property color accentLightAqua: base17
|
||||||
|
property color accentBlue: base18
|
||||||
|
property color accentPurple: base19
|
||||||
|
|
||||||
|
// Example semantic levels for UI elements
|
||||||
|
property color windowBackground: background
|
||||||
|
property color panelBackground: surface
|
||||||
|
property color cardBackground: surfaceAlt
|
||||||
|
property color primaryText: textPrimary
|
||||||
|
property color secondaryText: textSecondary
|
||||||
|
property color highlight: accentBlue
|
||||||
|
property color danger: accentRed
|
||||||
|
property color success: accentGreen
|
||||||
|
property color warning: accentYellow
|
||||||
|
|
||||||
|
// ---- Helper function ----
|
||||||
|
// Returns a color by semantic name (string). Useful for dynamic lookups.
|
||||||
|
function colorFor(name) {
|
||||||
|
switch (name) {
|
||||||
|
case "background":
|
||||||
|
return gruvbox.background;
|
||||||
|
case "panelBackground":
|
||||||
|
return gruvbox.panelBackground;
|
||||||
|
case "cardBackground":
|
||||||
|
return gruvbox.cardBackground;
|
||||||
|
case "primaryText":
|
||||||
|
return gruvbox.primaryText;
|
||||||
|
case "secondaryText":
|
||||||
|
return gruvbox.secondaryText;
|
||||||
|
case "highlight":
|
||||||
|
return gruvbox.highlight;
|
||||||
|
case "danger":
|
||||||
|
return gruvbox.danger;
|
||||||
|
case "success":
|
||||||
|
return gruvbox.success;
|
||||||
|
case "warning":
|
||||||
|
return gruvbox.warning;
|
||||||
|
case "accentBlue":
|
||||||
|
return gruvbox.accentBlue;
|
||||||
|
case "accentRed":
|
||||||
|
return gruvbox.accentRed;
|
||||||
|
case "accentGreen":
|
||||||
|
return gruvbox.accentGreen;
|
||||||
|
default:
|
||||||
|
// fallback to primary text if unknown
|
||||||
|
return gruvbox.textPrimary;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,19 @@
|
|||||||
|
// Time.qml
|
||||||
|
pragma Singleton
|
||||||
|
|
||||||
|
import Quickshell
|
||||||
|
import QtQuick
|
||||||
|
import Quickshell.Hyprland
|
||||||
|
|
||||||
|
Singleton {
|
||||||
|
id: root
|
||||||
|
|
||||||
|
function getHyprlandWorkspaceById(id) {
|
||||||
|
for (var x of Hyprland.workspaces.values) {
|
||||||
|
if (x.id == id) {
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,69 @@
|
|||||||
|
// Bar.qml
|
||||||
|
import Quickshell
|
||||||
|
import Quickshell.Io
|
||||||
|
import QtQuick
|
||||||
|
import QtQuick.Layouts
|
||||||
|
import Quickshell.Hyprland
|
||||||
|
|
||||||
|
Item {
|
||||||
|
id: root
|
||||||
|
width: row.width
|
||||||
|
height: row.height
|
||||||
|
RowLayout {
|
||||||
|
id: row
|
||||||
|
height: 15
|
||||||
|
Repeater {
|
||||||
|
id: repeater
|
||||||
|
model: 10
|
||||||
|
delegate: Item {
|
||||||
|
id: content
|
||||||
|
required property int index
|
||||||
|
property bool focused: HyprlandHelpers.getHyprlandWorkspaceById(index + 1).focused
|
||||||
|
property bool exists: HyprlandHelpers.getHyprlandWorkspaceById(index + 1) ? true : false
|
||||||
|
state: focused ? "FOCUSED" : (exists ? "EXISTS" : "NOT")
|
||||||
|
states: [
|
||||||
|
State {
|
||||||
|
name: "FOCUSED"
|
||||||
|
PropertyChanges {
|
||||||
|
target: content
|
||||||
|
implicitWidth: 10
|
||||||
|
scale: 1
|
||||||
|
}
|
||||||
|
},
|
||||||
|
State {
|
||||||
|
name: "EXISTS"
|
||||||
|
PropertyChanges {
|
||||||
|
target: content
|
||||||
|
implicitWidth: 10
|
||||||
|
scale: 0.85
|
||||||
|
}
|
||||||
|
},
|
||||||
|
State {
|
||||||
|
name: "NOT"
|
||||||
|
PropertyChanges {
|
||||||
|
target: content
|
||||||
|
implicitWidth: 10
|
||||||
|
scale: 0.75
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
height: 15
|
||||||
|
Rectangle {
|
||||||
|
implicitWidth: parent.width
|
||||||
|
implicitHeight: parent.height
|
||||||
|
radius: 2.5
|
||||||
|
color: {
|
||||||
|
if (HyprlandHelpers.getHyprlandWorkspaceById(index + 1) != null) {
|
||||||
|
if (HyprlandHelpers.getHyprlandWorkspaceById(index + 1).focused) {
|
||||||
|
return Colors.primaryText;
|
||||||
|
}
|
||||||
|
return Colors.textSecondary;
|
||||||
|
} else {
|
||||||
|
return Colors.textDisabled;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1 @@
|
|||||||
|
/nix/store/ynim9hhkc1smj1h2plrw3ap978dlm3qj-home-manager-files/.config/quickshell/main
|
||||||
@@ -1,4 +1,8 @@
|
|||||||
// @ pragma UseQApplication
|
// @ pragma UseQApplication
|
||||||
|
//@ pragma Env QS_NO_RELOAD_POPUP=0
|
||||||
|
//@ pragma Env QT_QUICK_CONTROLS_STYLE=Basic
|
||||||
|
//@ pragma Env QT_QUICK_FLICKABLE_WHEEL_DECELERATION=10000
|
||||||
|
|
||||||
import Quickshell
|
import Quickshell
|
||||||
import QtQuick
|
import QtQuick
|
||||||
|
|
||||||
|
|||||||
@@ -8,47 +8,65 @@ sops:
|
|||||||
- recipient: age1ykcy2r4kk729e7adqxu8s24ujc60z5eux7ma0ca4ruzydwgm5p6qmdp838
|
- recipient: age1ykcy2r4kk729e7adqxu8s24ujc60z5eux7ma0ca4ruzydwgm5p6qmdp838
|
||||||
enc: |
|
enc: |
|
||||||
-----BEGIN AGE ENCRYPTED FILE-----
|
-----BEGIN AGE ENCRYPTED FILE-----
|
||||||
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSAzdGQ5ZHUxUHE4YXF0bllY
|
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSBiZC9ZVlY2T0tXdy90b2hV
|
||||||
dTRsYWc4cllmWEgveGVTLzUvRzJuc0FtUEdvCkNURmxmMnhkaExZcVVNRmRNU1p6
|
dDUxUjNyMjllQStaa0tKRy9YVkNIdFJyWTI4CitYNnhxN3JHQ3lsWXp2Tmgwek9n
|
||||||
UitMYUxNMXgzZC84S3J0SHR4aFV5TGcKLS0tIFB3Skx6UlFDcVJFSlhTd1NRbUl2
|
Qzk1RUExZk5WcnlvUWptcmFQTFJNbWMKLS0tIFBtSkJOZUovTUxYeFZ3cnJ2Ukw0
|
||||||
VGQ3OUpDY0JVaEUyYStHQU83Q1hDYTAKeRgXVA8iWGO8cMMlvBFWGMVIZnaLCpsZ
|
MkVQY3h2OGhGaGNnYkVJUU1kK3F3VWMKs9B74KovGxx8KL5q/lGA/imVRM/i3mo/
|
||||||
hBjWlxG6oUlCNnO+cyckU3jSTecc+z+EIuseFt710nN5uRJeKs2MlA==
|
a6Rbxufscp3WWGMbo70w8tWuRsAnIpUGh3EvWCekZ9nOzeMiVA8I2Q==
|
||||||
-----END AGE ENCRYPTED FILE-----
|
-----END AGE ENCRYPTED FILE-----
|
||||||
- recipient: age1e6vws55p0g23qzthm4qa93hpt6lqmck6670gkygph0sc0j7my4uq5wqjfh
|
- recipient: age1e6vws55p0g23qzthm4qa93hpt6lqmck6670gkygph0sc0j7my4uq5wqjfh
|
||||||
enc: |
|
enc: |
|
||||||
-----BEGIN AGE ENCRYPTED FILE-----
|
-----BEGIN AGE ENCRYPTED FILE-----
|
||||||
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSBtM0wvV3pHTUZYdlhPWnU0
|
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSB0dXJzYndvSC92aElvTVpz
|
||||||
VElBbDI2bUJhQUVCMlBPNjNzOE9tTXJGelI0CjBEdmhWTGlyc2VhODRnbHE3ZGdC
|
SUtTOWFzcUJxOHVrTk5scm5tcGkzRmEvK1hVClNVbmp3ZjBRTW5ZNXVNNGh3dSti
|
||||||
WUoyWU0zcU5BbXhGdm5sVEZHdS80bkkKLS0tIHhpcFZQdkl6eHRUTGhZYmVOSCtz
|
RzdCcTFlVlBld1kwNnR6dVhtcllVMFkKLS0tIG1YK2dLcWdVU3dLUFFlOUtzb3Ex
|
||||||
RE8zeFl2ZVgyWVBsRmhlUElybXEwSEEKEhvMUClOOoN3RdzVOFBIPt7rMrukla1t
|
Tk5Zd0h3OHRpQzZjazJKUStPUVdERzQKGnoKYKq7pPJUrcAWJ4/tm8mSxuthjssz
|
||||||
bVWGKX5e3p/EtK7aYzdBxYYvml+TNUD1n5TpTFhcnH2Jwpey8thz2Q==
|
7IsjH4t6VCyug2c7XnLJpcE64yPD+GrXHYixP0r2qj80WMjpv7N7qA==
|
||||||
-----END AGE ENCRYPTED FILE-----
|
-----END AGE ENCRYPTED FILE-----
|
||||||
- recipient: age1x3lahhkefkap67cdmdjcqaxan9hp62er78akr79v9m73nvgugpeqk0y32a
|
- recipient: age1x3lahhkefkap67cdmdjcqaxan9hp62er78akr79v9m73nvgugpeqk0y32a
|
||||||
enc: |
|
enc: |
|
||||||
-----BEGIN AGE ENCRYPTED FILE-----
|
-----BEGIN AGE ENCRYPTED FILE-----
|
||||||
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSA0ODRGRkE3a09MS3Z0QXNm
|
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSBLbGQ3MkVCUldqa3dYRTg0
|
||||||
OTBlb2JEV28vTmxhcjM5aFpYbVhYM0wyZkd3CmszblZWVEFkVlMwQ1FMZitBd0Rp
|
NjVoUDdIc0RvSU02R0o0ZVk4KzVQMkZmeXpjClJaUUU3WTJVQmJkRzV4UTc3bXFI
|
||||||
MkZpZGViSHlHSko4Tk9rZGNHaWpGWncKLS0tIC9xY1dBSncvQnhHTlhhaEpUK3ZI
|
dmJsV0VhNmdvdVNaaUFTNWcwd1l3eGsKLS0tIG1Gc3FlNVduaXUybUFnSGF4T3lu
|
||||||
Tjgwd0VuVGtjaTdaSE5ERmRIa1dVNEkKkN0vp7xDWCnu4aq8VQu5y8Q/6xsFKhCQ
|
QzhtM3V3VGFzdk9UenV6akxGNDh5d3cKdIKNPvM0GRJamiS4AXRNU+TbuZUnM6K7
|
||||||
ivMqQsqoOBvXSynu7hbNpcGvAsmDHDGcC2b/C9Mkt42OclSYM077bw==
|
FtC1dmHlyU/tXlFHv6TNlMZQtDgIVnE72Jvk48maq3oKiJAXWk11fg==
|
||||||
-----END AGE ENCRYPTED FILE-----
|
-----END AGE ENCRYPTED FILE-----
|
||||||
- recipient: age1exzngtk4d9vcsmcq6ap5xx3ca9qacqjkrv86ymged7msx9z6vfyqsf5sjq
|
- recipient: age1exzngtk4d9vcsmcq6ap5xx3ca9qacqjkrv86ymged7msx9z6vfyqsf5sjq
|
||||||
enc: |
|
enc: |
|
||||||
-----BEGIN AGE ENCRYPTED FILE-----
|
-----BEGIN AGE ENCRYPTED FILE-----
|
||||||
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSBYTmhiUmFWaDFzcnRXcWFp
|
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSBoOHlRcnRwWUYwUGRSVW9s
|
||||||
VjJ1b3VRSk8xN0FQMk13UDY1a2FEV3ZQY2l3Cnd0SmMvM0JDOFhZdmtOL3g0dmNj
|
cmdDZjN1RGFRVWtlODBudGpaemd3UDBZcnhRCksyWlk3VW91a3pnOGNQQVppM09z
|
||||||
UGZleDV1MU1DMXFiYUNmR2htWXZXQnMKLS0tIFBLa3lPL0VieG9ZWFBOU25vZTJ1
|
Wmd3c09LK25OVGpJYWxvcm9XME03RG8KLS0tIEZkdERHZjhFWXkzZWNsM01nQmRs
|
||||||
VVVDclBGZTRSVDZOanRwOGNaK3VVUW8KCvt/rcP0rJD5aCNdGaJeABuGZ7huRbGw
|
bWFTMlhCL2IrZjlEOUFydmE4cHBzSmMKhIk8TZtRsIFKzopZCyp27SWYeHmf6jKn
|
||||||
7FBvo6TvIRh0MCyvfbzfUon2m9d4yU8ddFejpSEK1vucxbXgV7KD8g==
|
VoIXQ6/VRRQjCYBsseZE5N+ycnr4ZC/RpXJ577G4TfGMCcixX67AfA==
|
||||||
-----END AGE ENCRYPTED FILE-----
|
-----END AGE ENCRYPTED FILE-----
|
||||||
- recipient: age1fw4xnh2q52juce94ffn54js708cr6umfwpv0mykuddkea7kr4f0q7a9h05
|
- recipient: age1fw4xnh2q52juce94ffn54js708cr6umfwpv0mykuddkea7kr4f0q7a9h05
|
||||||
enc: |
|
enc: |
|
||||||
-----BEGIN AGE ENCRYPTED FILE-----
|
-----BEGIN AGE ENCRYPTED FILE-----
|
||||||
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSBLU21oQnlTQ3RQWmNzR3Y4
|
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSBuTG9LKzVvUjZEZ1lkMVJN
|
||||||
aWhhdFZ6RFEwVm5ITWluS2xZM0QyUHI5SEdvCmFjdDU2YlhlYTJ6Y2pPaGJkNW01
|
eldHSkRXQ241bnZmbHBmSXFNMU1seGcyaVNRCjNPaS9ITEJtdGRwOENDRytEMFk1
|
||||||
WUVVN0xIRXZ3djdVVkYzRThLSzlCVzAKLS0tIFhISmlJcXB2UHNsb2VQS2tnYVUy
|
L3cvVnRsa2lYUk1hOWZCdDNqT3F3TU0KLS0tIFQ3cU5YNEszQm03ZXFxWkJ2VVVW
|
||||||
aW5ERENRS2JWbGZhaGhNSGtqNVRNTncK0uI8n2L5uP3to/sByeO7y17h3ZrcmnOf
|
WTR2RU9GUVdsZHdleW1Gd2lyRENzSm8KznMUQ6Ah8O03AzZcCXgUIjjrV1cdkAnq
|
||||||
e3CwdzP4/WcSwbFk0CRnS6Cq8J0esUqweSJxvpt2eNBEYvDZ77SSMw==
|
Pbr2BwdLzJvlF5lzmymIZEt35euv/HzhJGWDLWGpYJmYj/N8qZgBuA==
|
||||||
|
-----END AGE ENCRYPTED FILE-----
|
||||||
|
- recipient: age1pa8cecxaw4y4zea6zjnt0k0mz38g4qunmp6trwy5fvdvw88ttcgsv2dgrv
|
||||||
|
enc: |
|
||||||
|
-----BEGIN AGE ENCRYPTED FILE-----
|
||||||
|
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSAxSDNMRlNaMXB2ZXBPTlNu
|
||||||
|
eG5BWE5xRTNnVUFtN2psUFVHejZVbFVCQTBFCkRXQitoL0VJaXZmMlI3Q0JHVWk1
|
||||||
|
Zk1wR0loMVZLbytDdTE2Ky94eGljS0EKLS0tIHFxVGYrZlVVS3FsWENUdzRaVzVY
|
||||||
|
Q0x4bDFBTzV2L0E3UXQxMUdubVJZRTgKcPQZ9zHQAFwP/Odnh5INleUsHSN06U+x
|
||||||
|
X98535uapyJR/Wswxj6ukdciMOou8cLfOInLwJgWOf6mZklEhecVXA==
|
||||||
|
-----END AGE ENCRYPTED FILE-----
|
||||||
|
- recipient: age1kc0xu0ue2nrrr7w4gam7wlzackv8jv243rxwwndgxjqklgtnp5csdtpgzp
|
||||||
|
enc: |
|
||||||
|
-----BEGIN AGE ENCRYPTED FILE-----
|
||||||
|
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSBTaE1mUUlyVUxKQmhPMnlT
|
||||||
|
eS81cE5TeE1WWFVIRkdWT3c0ckhNMnFYZGxrCnp4My9nK20zcGVxUFZ0cnVVTDBS
|
||||||
|
QWtIQmVnM1lRV1ZtVXNGQ0dGdXNyOWsKLS0tIGIwM0JMM0JlZjBNaUQycEdudGlU
|
||||||
|
bzJvaUg2VkFrazBoWmlIY2hKeUdhTjQKbgW+ysm3TWBKfVoKAeqvaPio29SyzjJP
|
||||||
|
61QsSqCuJyEwSPpOzeWa5NChcCjitOUG1jEMsSHlpIslKA1P7g/P9g==
|
||||||
-----END AGE ENCRYPTED FILE-----
|
-----END AGE ENCRYPTED FILE-----
|
||||||
lastmodified: "2026-02-14T00:08:39Z"
|
lastmodified: "2026-02-14T00:08:39Z"
|
||||||
mac: ENC[AES256_GCM,data:lp9ZeDxt5gkOkDmYk+F0VQrVhkR0tQiQlYXbygoA8Dcq+gV0IIKKLwRqr5CVfgfRlo3239IwmKLsGaS6zYC1xX4toZ8oqw3Ic2UvP2CiWt6M7HTrlL+3Y2+PKOUvGl7RAqQxQAw7QaoxB4esqdIiWnMDueVHk5BTKrkay+afhno=,iv:NAMaZ9SMBAtROTBSQtU0RJDB60MAuE82AFoPtDqVHVM=,tag:RGBUTQC1pM+LcBweSJbc6w==,type:str]
|
mac: ENC[AES256_GCM,data:lp9ZeDxt5gkOkDmYk+F0VQrVhkR0tQiQlYXbygoA8Dcq+gV0IIKKLwRqr5CVfgfRlo3239IwmKLsGaS6zYC1xX4toZ8oqw3Ic2UvP2CiWt6M7HTrlL+3Y2+PKOUvGl7RAqQxQAw7QaoxB4esqdIiWnMDueVHk5BTKrkay+afhno=,iv:NAMaZ9SMBAtROTBSQtU0RJDB60MAuE82AFoPtDqVHVM=,tag:RGBUTQC1pM+LcBweSJbc6w==,type:str]
|
||||||
|
|||||||
@@ -5,47 +5,65 @@ sops:
|
|||||||
- recipient: age1ykcy2r4kk729e7adqxu8s24ujc60z5eux7ma0ca4ruzydwgm5p6qmdp838
|
- recipient: age1ykcy2r4kk729e7adqxu8s24ujc60z5eux7ma0ca4ruzydwgm5p6qmdp838
|
||||||
enc: |
|
enc: |
|
||||||
-----BEGIN AGE ENCRYPTED FILE-----
|
-----BEGIN AGE ENCRYPTED FILE-----
|
||||||
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSBSYm92cVo0Ykg2R3hTUWpW
|
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSBaU0s5VEszVDU4UlE2MDRi
|
||||||
UlNOTXF2cFI4Y29uRTh2aXIySFNSTFhZZ0RFCnR4YmRrQTVrY0hkUloxMGgzdFFa
|
eXBGNXU1Si9TZng4U1lrSjMvajQ2WmhIQkgwCitjM2owU0kwTXlGNy90ZHM3TEhY
|
||||||
ejFST0FESytnN3NIZW45blhmWDRMSlkKLS0tIE1MNWlHWWd1WEhNUGtiUm5GZ2pn
|
ZmlnSUtZcXFCUkdCNmxsL0lDWHIwQXMKLS0tIEtaWGVCbWJKOHl0SW5EUWVqRWgz
|
||||||
QUR3aGtVczZYV1FSUFdMRGw4a2lGU2MKh/56SL7neNFXN70dzwtwTHBaECoMvArR
|
bUI2bFdONHBIMTA4Rks4dytIK0NSZmsK6gzcg+iYzt01tnptnuSGXHqBt+T9o9hP
|
||||||
TicJhSPV5S/vUrC9oDmSE3MMYtdzXSZkcRHYPI8fy5LcPOxXVPRARQ==
|
0gqLXgsfB+4OxRoMJVMEyecz9SX5+j6sWNQoRVQY1CGJoIucrpFrpg==
|
||||||
-----END AGE ENCRYPTED FILE-----
|
-----END AGE ENCRYPTED FILE-----
|
||||||
- recipient: age1e6vws55p0g23qzthm4qa93hpt6lqmck6670gkygph0sc0j7my4uq5wqjfh
|
- recipient: age1e6vws55p0g23qzthm4qa93hpt6lqmck6670gkygph0sc0j7my4uq5wqjfh
|
||||||
enc: |
|
enc: |
|
||||||
-----BEGIN AGE ENCRYPTED FILE-----
|
-----BEGIN AGE ENCRYPTED FILE-----
|
||||||
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSB3K3ZxKzdvdVFMYnZLS0Nv
|
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSBmTlN4YlBnTS93ZTh2STFr
|
||||||
bDBkRWRNMkRMS09UWlZlcFYvZ1pEd09VVmlJCk9uMGJyNzd5QnZtWkdxOE40TVdG
|
Nng0YTNmeEw2N0ZXV0N0VVJaQjh4bldNS2xjCnYyMWxOb2hiR0Vwb1FXNmh6eitE
|
||||||
YkJiaGZMaEFlNXljcnFvODVSL3Q2d3cKLS0tIFg5UFFPVElyR0xlbXEvMDNDQmpW
|
N1BMWFpXNElyNkJQNGJ6NUFzT3VOOVEKLS0tIG5MUXgzMEpMWGVGVnBubmRVM0hr
|
||||||
TGo3cUJVQ2NETkhWdmNCazNYSVpyUWcKr4EUvbK28WCiymL1BgYk6N6J27ZnadK8
|
QjdQUkoyWHE2M05nSkZXNWpBTXdnN2cKEB3JndFHK/bFMx7zf3y/wfEALJIDO85u
|
||||||
kQ8tzwVS7iI1frBoHOVzXhCRt2CEg+O3EnXMRJDrahhxwmpqlx6cRA==
|
RCKs6jIAztc3ElNDaKsIYRoF1VmrQSOvpk5ZJ1NytFcetNXvOR1KXw==
|
||||||
-----END AGE ENCRYPTED FILE-----
|
-----END AGE ENCRYPTED FILE-----
|
||||||
- recipient: age1x3lahhkefkap67cdmdjcqaxan9hp62er78akr79v9m73nvgugpeqk0y32a
|
- recipient: age1x3lahhkefkap67cdmdjcqaxan9hp62er78akr79v9m73nvgugpeqk0y32a
|
||||||
enc: |
|
enc: |
|
||||||
-----BEGIN AGE ENCRYPTED FILE-----
|
-----BEGIN AGE ENCRYPTED FILE-----
|
||||||
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSBRWGVsRmkwZGxId0hXQlEv
|
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSB6dDVCcHlKT1hVYUh5bXVk
|
||||||
czdmclRXYWNrL0t4bGpEQ0lmNE0vb1RuZEhjCkhEaGlxY3JKS3l4WGxHS0Uya2tM
|
cGtZWExJWlQxOVNDWkwrWU9hTi9iT2RLVW5RCjEveHczRDVsWkIyRWIvMTEzRyt6
|
||||||
Zm1Lb3RpY2h0K2lKaHR1bjdFL25yQ0UKLS0tIFYvNmkrUWNFekVoMFVLck81bXhl
|
ZWkzUDhqMVZjT1VKM0tvWjlEdy9DZGsKLS0tIDB0T1gyaTZ6a1JIaGF3dVhEcmdZ
|
||||||
WHNSbHpCTTZSS3lkUiszeEE0RGw4QncKTr1ZzIHtkv8aJNKT1v0m+QMJyht43+XJ
|
Yzl6QnAyU3l0QkhJQVpTN1ovY1hEUXMKiEPWh4isOmF2MdU6ENPNmwQgAOV7PleP
|
||||||
0CRxdoZ/HXoymMQ7oZvT8vf6Ehz41aLe1gZHl8ZJPexDHrSl28NCtg==
|
88PLtUx2K6VKjWPIHknIZ5esoXPVjJXeawDAdSj4gz91A1DrcrYXWA==
|
||||||
-----END AGE ENCRYPTED FILE-----
|
-----END AGE ENCRYPTED FILE-----
|
||||||
- recipient: age1exzngtk4d9vcsmcq6ap5xx3ca9qacqjkrv86ymged7msx9z6vfyqsf5sjq
|
- recipient: age1exzngtk4d9vcsmcq6ap5xx3ca9qacqjkrv86ymged7msx9z6vfyqsf5sjq
|
||||||
enc: |
|
enc: |
|
||||||
-----BEGIN AGE ENCRYPTED FILE-----
|
-----BEGIN AGE ENCRYPTED FILE-----
|
||||||
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSBlc0tUVjVGVS85YUZOSmJq
|
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSAwdXcwejJSejkwT3BuSURo
|
||||||
a0pvcGV4UDBEc0N0Zk0xVEhUc1l1ZUFFTGxnClNocURmTE5ZaUorSVdWcE1kbW81
|
MEluK3plUVdmVG8wcmw3SkI2dThBd1FOZDJzCmg2cHRZMEZIWENiTWdvdWtveTY2
|
||||||
U3doQm9ZbHVrdVlsSVhFaEFoSHo5NU0KLS0tIGgvd05PY2tlbnRwbTRrdXpsT0ho
|
TlN3MkhPT0N4enN3RlBJbWNUK1N0QXMKLS0tIEFOT2J6VlpLWmduK2pWalIvOWNo
|
||||||
Zm1jbTlSMnA1WDUrZUVCOHNDWWJ2RFUK+cvqFK49rIVj3FITF/4HtCELvZhvkCZ9
|
NFhiM1lWcExhcXBrZm8rMzc5WXJoeDAKSXHnzBymsLhXaxHipZig+xfpBjYaADu/
|
||||||
8Ss77uE6qtGyhuGWXB0HwnO3fsCpXA62uUt/zv08o9LmIgRi7o7adg==
|
AqOXpfLbZQD15oIMg8+vNR2OOzqRRSq8oY2yI1rhkjZtlTxGiuzANw==
|
||||||
-----END AGE ENCRYPTED FILE-----
|
-----END AGE ENCRYPTED FILE-----
|
||||||
- recipient: age1fw4xnh2q52juce94ffn54js708cr6umfwpv0mykuddkea7kr4f0q7a9h05
|
- recipient: age1fw4xnh2q52juce94ffn54js708cr6umfwpv0mykuddkea7kr4f0q7a9h05
|
||||||
enc: |
|
enc: |
|
||||||
-----BEGIN AGE ENCRYPTED FILE-----
|
-----BEGIN AGE ENCRYPTED FILE-----
|
||||||
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSBuN0dkcExkR2pyaUxhbUlz
|
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSBUMUhGMURUdzh4MFgzNDlC
|
||||||
NkR2WTNWRUpHSWdRTFdUY05jcm4ybDdEbW4wCmR1TTV5VlFudHN1cC8yRG5Nd2ts
|
Nzh0UW5WNUh1MDhEQnBod2E5OEVqMmhiTVVrCitmbk1uWkY5Q09COGZRZ2xhNXBl
|
||||||
K3duNEE1dit0Ym9PdmNaM1pEWjlZZU0KLS0tIHBXaXhzQ0VuTWFxdDQrczQ4YTBM
|
bnlVUmxDb2FQT0xPN0F3SkgyTVRpWjgKLS0tIGdWN1ptVTlhNUZtTU11VDFMSFlM
|
||||||
VlhpZ0N2ZmVkSC90NlowUkNuYWZUclEKzQUfWDETV5lPgrtCxYTLtVP8y7R8RFJj
|
djVyTzMyRHA1QnlvdEtaNE5URXVDS00KH+9tHTwQqI7uLubVWfU1IZ19WWDPA9Br
|
||||||
4J1bei0nJHlsap8V88u+QiYRgFsEthd++hzkYmUDvYPsA48PnzMupw==
|
HrnX4nn0AITQCWUkAqWVyGVP5pk5YmlmazLE6xyBz+i2ETT11DHVMw==
|
||||||
|
-----END AGE ENCRYPTED FILE-----
|
||||||
|
- recipient: age1pa8cecxaw4y4zea6zjnt0k0mz38g4qunmp6trwy5fvdvw88ttcgsv2dgrv
|
||||||
|
enc: |
|
||||||
|
-----BEGIN AGE ENCRYPTED FILE-----
|
||||||
|
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSB2ZGJ4bWNsR0tOa0g5Ym1M
|
||||||
|
UTJlRS9XRnNaOVBOd3dkS0tmaVJlZU5yd2xVClR0WU1nTnZud0RzeHZERUFRYzRE
|
||||||
|
bmp1OXorQ09LRzZyUEs1SXlvenZIOVkKLS0tIHBvakxTSTkxZXdBQmpVRWF5YUtF
|
||||||
|
QnBNcU1ibytoNDZCU1lldzczV0xjUzgK6gIlN6PYv8+ZGhdMuOSVHIkzZ9sU5kvI
|
||||||
|
ZpB+JirAJzFpYEz2IyT21XKNq9phqyj9lzzinvJQQ7wxsI6ixaiBDQ==
|
||||||
|
-----END AGE ENCRYPTED FILE-----
|
||||||
|
- recipient: age1kc0xu0ue2nrrr7w4gam7wlzackv8jv243rxwwndgxjqklgtnp5csdtpgzp
|
||||||
|
enc: |
|
||||||
|
-----BEGIN AGE ENCRYPTED FILE-----
|
||||||
|
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSB6NVU4dUR2Y3hXbWdrdXNN
|
||||||
|
Rjh4VEE2M1NiTTZiWmpjVXQzSGxSS0l3a1I4Ci95ZUVhbTFtTHNLa3BvRnJRUjda
|
||||||
|
aVIyREZiL1phNU16OERZSDBvRGovVVUKLS0tIHpGdkh1L280TVp1MnE0L1Q1Z3FV
|
||||||
|
QnNTaHVsSVh2UmNRVzZ3a082ZjRRbmcKgjnhtWweNUAbmxpb+nN3iL9FOsaXCatu
|
||||||
|
NyS4pTov3WR9c7SLhDLlbqxeeqd7mBDKLhWiuqiW05J5NQ+g5lXf7g==
|
||||||
-----END AGE ENCRYPTED FILE-----
|
-----END AGE ENCRYPTED FILE-----
|
||||||
lastmodified: "2026-02-14T00:09:32Z"
|
lastmodified: "2026-02-14T00:09:32Z"
|
||||||
mac: ENC[AES256_GCM,data:nYWQYK5QOA0u3DYGTozSGFMYhx2uMqkAWoqhthgagRFRnKA/j852fVKqRFcwn+fPSQ4e8i4WpcvoM7FVwuFDC+ixNp7xtz16pnswiNS4N/mNEYXfajkon7wIoUYNtrHahUeYlAnID0vYSQFA3XKgV7ZDD9b4V8X5N+yMlVXex4c=,iv:IW7276v0nnmFBe9Z7HIn6Tl9vX4sDoqWdDfJ1uwKoAY=,tag:YC8OiTcoL+nYV4x8rkivbg==,type:str]
|
mac: ENC[AES256_GCM,data:nYWQYK5QOA0u3DYGTozSGFMYhx2uMqkAWoqhthgagRFRnKA/j852fVKqRFcwn+fPSQ4e8i4WpcvoM7FVwuFDC+ixNp7xtz16pnswiNS4N/mNEYXfajkon7wIoUYNtrHahUeYlAnID0vYSQFA3XKgV7ZDD9b4V8X5N+yMlVXex4c=,iv:IW7276v0nnmFBe9Z7HIn6Tl9vX4sDoqWdDfJ1uwKoAY=,tag:YC8OiTcoL+nYV4x8rkivbg==,type:str]
|
||||||
|
|||||||
@@ -0,0 +1,34 @@
|
|||||||
|
{
|
||||||
|
den,
|
||||||
|
modules,
|
||||||
|
inputs,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
{
|
||||||
|
flake-file.inputs = {
|
||||||
|
spicetify-nix.url = "github:Gerg-L/spicetify-nix";
|
||||||
|
};
|
||||||
|
modules.spotify = {
|
||||||
|
homeManager =
|
||||||
|
{ pkgs, ... }:
|
||||||
|
let
|
||||||
|
spicePkgs = inputs.spicetify-nix.legacyPackages.${pkgs.stdenv.system};
|
||||||
|
in
|
||||||
|
{
|
||||||
|
imports = [
|
||||||
|
# Example for NixOS
|
||||||
|
inputs.spicetify-nix.homeManagerModules.spicetify
|
||||||
|
];
|
||||||
|
programs.spicetify = {
|
||||||
|
enable = true;
|
||||||
|
enabledExtensions = with spicePkgs.extensions; [
|
||||||
|
adblockify
|
||||||
|
hidePodcasts
|
||||||
|
shuffle # shuffle+ (special characters are sanitized out of extension names)
|
||||||
|
];
|
||||||
|
theme = spicePkgs.themes.onepunch;
|
||||||
|
colorScheme = "dark";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -0,0 +1,24 @@
|
|||||||
|
{ den, modules, ... }:
|
||||||
|
{
|
||||||
|
modules.ssh = {
|
||||||
|
homeManager =
|
||||||
|
{ home, ... }:
|
||||||
|
{
|
||||||
|
programs = {
|
||||||
|
ssh = {
|
||||||
|
enable = true;
|
||||||
|
enableDefaultConfig = false;
|
||||||
|
matchBlocks = {
|
||||||
|
"*" = {
|
||||||
|
addKeysToAgent = "yes";
|
||||||
|
identityFile = [
|
||||||
|
"~/.ssh/id_ed25519"
|
||||||
|
"~/.ssh/id_gitea_scug"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -16,6 +16,7 @@
|
|||||||
{ pkgs, ... }:
|
{ pkgs, ... }:
|
||||||
{
|
{
|
||||||
imports = [ inputs.stylix.homeModules.stylix ];
|
imports = [ inputs.stylix.homeModules.stylix ];
|
||||||
|
gtk.gtk4.theme = null;
|
||||||
stylix = {
|
stylix = {
|
||||||
enable = true;
|
enable = true;
|
||||||
autoEnable = false;
|
autoEnable = false;
|
||||||
@@ -35,7 +36,7 @@
|
|||||||
{ pkgs, ... }:
|
{ pkgs, ... }:
|
||||||
{
|
{
|
||||||
imports = [ inputs.stylix.nixosModules.stylix ];
|
imports = [ inputs.stylix.nixosModules.stylix ];
|
||||||
stylix.enable = true;
|
stylix.enable = false;
|
||||||
stylix.autoEnable = false;
|
stylix.autoEnable = false;
|
||||||
stylix.base16Scheme = "${pkgs.base16-schemes}/share/themes/gruvbox-dark-hard.yaml";
|
stylix.base16Scheme = "${pkgs.base16-schemes}/share/themes/gruvbox-dark-hard.yaml";
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -0,0 +1,38 @@
|
|||||||
|
{
|
||||||
|
den,
|
||||||
|
modules,
|
||||||
|
inputs,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
{
|
||||||
|
flake-file.inputs = {
|
||||||
|
x1e-kernel.url = "git+https://git.scug.io/doloro/x1e-nixos.git?ref=bump-7.1-rc1";
|
||||||
|
};
|
||||||
|
modules.surface-patches = {
|
||||||
|
nixos =
|
||||||
|
{ pkgs, lib, ... }:
|
||||||
|
{
|
||||||
|
imports = with inputs; [
|
||||||
|
x1e-kernel.nixosModules.default
|
||||||
|
];
|
||||||
|
|
||||||
|
x1e.model = "15"; # "13" (default) or "15" — selects the correct DTB
|
||||||
|
x1e.cpuParking = false; # loads cpu_parking at boot
|
||||||
|
x1e.ecReboot = true; # loads ec_reboot at boot, exposes /sys/kernel/ec_reboot/reboot
|
||||||
|
|
||||||
|
# Prevent reboot hang - qcom_smd_qrtr workers stuck in D-state
|
||||||
|
systemd.settings.Manager.DefaultTimeoutStopSec = "15s";
|
||||||
|
systemd.settings.Manager.DefaultDeviceTimeoutSec = "15s";
|
||||||
|
|
||||||
|
# Hardware watchdog (SBSA Generic Watchdog) as safety net
|
||||||
|
systemd.settings.Manager = {
|
||||||
|
KExecWatchdogSec = "30s";
|
||||||
|
RebootWatchdogSec = "30s";
|
||||||
|
RuntimeWatchdogSec = "30s";
|
||||||
|
};
|
||||||
|
|
||||||
|
# Override udevd stop timeout (D-state workers can't be killed)
|
||||||
|
systemd.services.systemd-udevd.serviceConfig.TimeoutStopSec = lib.mkForce "10s";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -8,11 +8,21 @@
|
|||||||
enable = true;
|
enable = true;
|
||||||
settings = {
|
settings = {
|
||||||
default_session = {
|
default_session = {
|
||||||
command = "${pkgs.greetd.tuigreet}/bin/tuigreet --sessions ${config.services.xserver.displayManager.sessionData.desktops}/share/xsessions:${config.services.xserver.displayManager.sessionData.desktops}/share/wayland-sessions --remember --remember-user-session";
|
command = "${pkgs.greetd.tuigreet}/bin/tuigreet --sessions ${config.services.xserver.displayManager.sessionData.desktops}/share/xsessions:${config.services.xserver.displayManager.sessionData.desktops}/share/wayland-sessions --remember --remember-user-session --greeting 'meow meow meow' --time";
|
||||||
user = "greeter";
|
user = "greeter";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
systemd.services.greetd.serviceConfig = {
|
||||||
|
Type = "idle";
|
||||||
|
StandardInput = "tty";
|
||||||
|
StandardOutput = "tty";
|
||||||
|
StandardError = "journal"; # Without this errors will spam on screen
|
||||||
|
# Without these bootlogs will spam on screen
|
||||||
|
TTYReset = true;
|
||||||
|
TTYVHangup = true;
|
||||||
|
TTYVTDisallocate = true;
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -9,7 +9,7 @@
|
|||||||
zen-browser.url = "github:youwen5/zen-browser-flake";
|
zen-browser.url = "github:youwen5/zen-browser-flake";
|
||||||
zen-browser.inputs.nixpkgs.follows = "nixpkgs";
|
zen-browser.inputs.nixpkgs.follows = "nixpkgs";
|
||||||
};
|
};
|
||||||
modules.zen-browser = {
|
modules.zen-browser = settings: {
|
||||||
homeManager =
|
homeManager =
|
||||||
{
|
{
|
||||||
home,
|
home,
|
||||||
@@ -42,6 +42,11 @@
|
|||||||
];
|
];
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
|
wayland.windowManager.hyprland.settings = lib.mkIf settings.default {
|
||||||
|
bind = [
|
||||||
|
"$mainMod, E, exec, zen"
|
||||||
|
];
|
||||||
|
};
|
||||||
home.packages = [
|
home.packages = [
|
||||||
(pkgs.wrapFirefox
|
(pkgs.wrapFirefox
|
||||||
inputs.zen-browser.packages.${pkgs.stdenv.hostPlatform.system}.zen-browser-unwrapped
|
inputs.zen-browser.packages.${pkgs.stdenv.hostPlatform.system}.zen-browser-unwrapped
|
||||||
|
|||||||
Generated
+464
-155
File diff suppressed because it is too large
Load Diff
@@ -1,48 +1,51 @@
|
|||||||
# You FAGGOT; Do NOT edit this file !!!!, run 'nix run .#write-flake'
|
# You FAGGOT; Do NOT edit this file !!!!, run 'nix run .#write-flake'
|
||||||
{
|
{
|
||||||
|
|
||||||
outputs = inputs: inputs.flake-parts.lib.mkFlake { inherit inputs; } (inputs.import-tree ./config);
|
outputs = inputs: inputs.flake-parts.lib.mkFlake { inherit inputs; } (inputs.import-tree ./config);
|
||||||
|
|
||||||
inputs = {
|
inputs = {
|
||||||
den.url = "github:vic/den";
|
den.url = "github:vic/den?ref=8101ec865c0bf4027d40b9fd8951e3e435a86d64";
|
||||||
disko.url = "github:nix-community/disko";
|
disko.url = "github:nix-community/disko";
|
||||||
flake-aspects.url = "github:vic/flake-aspects";
|
|
||||||
flake-file.url = "github:vic/flake-file";
|
flake-file.url = "github:vic/flake-file";
|
||||||
flake-parts = {
|
flake-parts = {
|
||||||
inputs.nixpkgs-lib.follows = "nixpkgs-lib";
|
|
||||||
url = "github:hercules-ci/flake-parts";
|
url = "github:hercules-ci/flake-parts";
|
||||||
|
inputs.nixpkgs-lib.follows = "nixpkgs";
|
||||||
};
|
};
|
||||||
font-patcher.url = "github:Doloro1978/nix-nerd-fonts-patcher";
|
font-patcher.url = "github:Doloro1978/nix-nerd-fonts-patcher";
|
||||||
heliumFlake = {
|
heliumFlake = {
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
|
||||||
url = "github:vikingnope/helium-browser-nix-flake";
|
url = "github:vikingnope/helium-browser-nix-flake";
|
||||||
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
};
|
};
|
||||||
home-manager = {
|
home-manager = {
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
|
||||||
url = "github:nix-community/home-manager";
|
url = "github:nix-community/home-manager";
|
||||||
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
};
|
};
|
||||||
hyprland.url = "github:hyprwm/Hyprland";
|
hyprland.url = "github:hyprwm/Hyprland";
|
||||||
import-tree.url = "github:vic/import-tree";
|
import-tree.url = "github:vic/import-tree";
|
||||||
nixpkgs.url = "https://channels.nixos.org/nixpkgs-unstable/nixexprs.tar.xz";
|
nik-pkgs = {
|
||||||
nixpkgs-lib.follows = "nixpkgs";
|
url = "git+https://git.scug.io/nikkuss/pkgs.git";
|
||||||
nixvim = {
|
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
url = "github:nix-community/nixvim";
|
|
||||||
};
|
};
|
||||||
|
niri-flake = {
|
||||||
|
url = "github:sodiboo/niri-flake";
|
||||||
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
|
};
|
||||||
|
nix-cachyos-kernel.url = "github:xddxdd/nix-cachyos-kernel/release";
|
||||||
|
nixpkgs.url = "https://channels.nixos.org/nixpkgs-unstable/nixexprs.tar.xz";
|
||||||
|
nixvim.url = "github:nix-community/nixvim";
|
||||||
raspberry-pi-nix.url = "github:nix-community/raspberry-pi-nix";
|
raspberry-pi-nix.url = "github:nix-community/raspberry-pi-nix";
|
||||||
sops-nix = {
|
sops-nix = {
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
|
||||||
url = "github:Mic92/sops-nix";
|
url = "github:Mic92/sops-nix";
|
||||||
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
};
|
};
|
||||||
|
spicetify-nix.url = "github:Gerg-L/spicetify-nix";
|
||||||
stylix = {
|
stylix = {
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
|
||||||
url = "github:nix-community/stylix";
|
url = "github:nix-community/stylix";
|
||||||
};
|
|
||||||
systems.url = "github:nix-systems/default";
|
|
||||||
zen-browser = {
|
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
|
};
|
||||||
|
x1e-kernel.url = "git+https://git.scug.io/doloro/x1e-nixos.git?ref=bump-7.1-rc1";
|
||||||
|
zen-browser = {
|
||||||
url = "github:youwen5/zen-browser-flake";
|
url = "github:youwen5/zen-browser-flake";
|
||||||
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user