functional home assistant

This commit is contained in:
mjallen18
2025-07-18 14:50:13 -05:00
parent 407f8ede87
commit 91be65bc39
41 changed files with 337 additions and 304 deletions

View File

@@ -159,6 +159,26 @@
]; ];
}; };
}; };
overlays = with inputs; [ nix-vscode-extensions.overlays.default ];
homes = {
modules = with inputs; [
sops-nix.homeManagerModules.sops
];
overlays = with inputs; [
nix-vscode-extensions.overlays.default
];
users = {
"deck@deck" = {
modules = with inputs; [
steam-rom-manager.homeManagerModules.default
];
};
};
};
}; };
# Configure Snowfall Lib, all of these settings are optional. # Configure Snowfall Lib, all of these settings are optional.

View File

@@ -1,4 +1,4 @@
{ ... }: { config, lib, ... }:
let let
shellAliases = { shellAliases = {
update-boot = "nixos-rebuild boot --max-jobs 10"; update-boot = "nixos-rebuild boot --max-jobs 10";
@@ -6,13 +6,10 @@ let
}; };
in in
{ {
imports = [ home = {
../home/defaults.nix username = "root";
../home/git.nix homeDirectory = lib.mkForce "/${config.home.username}";
../home/shell.nix };
];
home.username = "root";
programs = { programs = {
zsh.shellAliases = shellAliases; zsh.shellAliases = shellAliases;

View File

@@ -1,7 +1,7 @@
{ config, lib, namespace, ... }: { config, lib, ... }:
with lib; with lib;
let let
cfg = config.${namespace}.desktop.extra.btop; cfg = config.mjallen.desktop.extra.btop;
nord = import ../../theme/nord.nix; nord = import ../../theme/nord.nix;
in in
{ {

View File

@@ -1,7 +1,7 @@
{ lib, namespace, ... }: { lib, ... }:
with lib; with lib;
{ {
options.${namespace}.desktop.extra.btop = { options.mjallen.desktop.extra.btop = {
enable = mkEnableOption "enable btop"; enable = mkEnableOption "enable btop";
}; };
} }

View File

@@ -1,7 +1,7 @@
{ lib, config, namespace, ... }: { lib, config, ... }:
with lib; with lib;
let let
cfg = config.${namespace}.desktop.extra.kitty; cfg = config.mjallen.desktop.extra.kitty;
in in
{ {
imports = [ ./options.nix ]; imports = [ ./options.nix ];

View File

@@ -1,7 +1,7 @@
{ lib, namespace, ... }: { lib, ... }:
with lib; with lib;
{ {
options.${namespace}.desktop.extra.kitty = { options.mjallen.desktop.extra.kitty = {
enable = mkEnableOption "enable kitty terminal"; enable = mkEnableOption "enable kitty terminal";
font = { font = {

View File

@@ -1,7 +1,7 @@
{ config, lib, namespace, ... }: { config, lib, ... }:
with lib; with lib;
let let
cfg = config.${namespace}.desktop.extra.mako; cfg = config.mjallen.desktop.extra.mako;
nord = import ../../theme/nord.nix; nord = import ../../theme/nord.nix;
in in
{ {

View File

@@ -1,7 +1,7 @@
{ lib, namespace, ... }: { lib, ... }:
with lib; with lib;
{ {
options.${namespace}.desktop.extra.mako = { options.mjallen.desktop.extra.mako = {
enable = mkEnableOption "enable mako"; enable = mkEnableOption "enable mako";
fontName = mkOption { fontName = mkOption {

View File

@@ -1,7 +1,7 @@
{ config, lib, namespace, ... }: { config, lib, ... }:
with lib; with lib;
let let
cfg = config.${namespace}.desktop.extra.nwg-dock; cfg = config.mjallen.desktop.extra.nwg-dock;
nord = import ../../theme/nord.nix; nord = import ../../theme/nord.nix;
in in
{ {

View File

@@ -1,7 +1,7 @@
{ lib, namespace, ... }: { lib, ... }:
with lib; with lib;
{ {
options.${namespace}.desktop.extra.nwg-dock = { options.mjallen.desktop.extra.nwg-dock = {
enable = mkEnableOption "enable nwg-dock"; enable = mkEnableOption "enable nwg-dock";
}; };
} }

View File

@@ -1,7 +1,7 @@
{ config, lib, namespace, ... }: { config, lib, ... }:
with lib; with lib;
let let
cfg = config.${namespace}.desktop.extra.nwg-drawer; cfg = config.mjallen.desktop.extra.nwg-drawer;
nord = import ../../theme/nord.nix; nord = import ../../theme/nord.nix;
in in
{ {

View File

@@ -1,7 +1,7 @@
{ lib, namespace, ... }: { lib, ... }:
with lib; with lib;
{ {
options.${namespace}.desktop.extra.nwg-drawer = { options.mjallen.desktop.extra.nwg-drawer = {
enable = mkEnableOption "enable nwg-drawer"; enable = mkEnableOption "enable nwg-drawer";
}; };
} }

View File

@@ -1,7 +1,7 @@
{ config, lib, namespace, ... }: { config, lib, ... }:
with lib; with lib;
let let
cfg = config.${namespace}.desktop.extra.nwg-dock; cfg = config.mjallen.desktop.extra.nwg-dock;
in in
{ {
imports = [ ./options.nix ]; imports = [ ./options.nix ];

View File

@@ -1,7 +1,7 @@
{ lib, namespace, ... }: { lib, ... }:
with lib; with lib;
{ {
options.${namespace}.desktop.extra.nwg-panel = { options.mjallen.desktop.extra.nwg-panel = {
enable = mkEnableOption "enable nwg-panel"; enable = mkEnableOption "enable nwg-panel";
defaultApps = mkOption { defaultApps = mkOption {

View File

@@ -1,7 +1,7 @@
{ config, lib, namespace, ... }: { config, lib, ... }:
with lib; with lib;
let let
cfg = config.${namespace}.desktop.extra.waybar; cfg = config.mjallen.desktop.extra.waybar;
nord = import ../../theme/nord.nix; nord = import ../../theme/nord.nix;
defaultOpacity = "opacity: 0.85;"; defaultOpacity = "opacity: 0.85;";
@@ -33,13 +33,13 @@ let
''; '';
in in
{ {
imports = [ ./options.nix ];
config = mkIf cfg.enable {
imports = [ imports = [
./options.nix
./scripts/hass.nix ./scripts/hass.nix
./scripts/weather.nix ./scripts/weather.nix
]; ];
config = mkIf cfg.enable {
# https://github.com/Alexays/Waybar/wiki/Module:-Hyprland # https://github.com/Alexays/Waybar/wiki/Module:-Hyprland
# https://www.nerdfonts.com/cheat-sheet # https://www.nerdfonts.com/cheat-sheet

View File

@@ -1,7 +1,7 @@
{ lib, namespace, ... }: { lib, ... }:
with lib; with lib;
{ {
options.${namespace}.desktop.extra.waybar = { options.mjallen.desktop.extra.waybar = {
enable = mkEnableOption "enable waybar"; enable = mkEnableOption "enable waybar";
layer = mkOption { layer = mkOption {

View File

@@ -1,43 +1,10 @@
{ pkgs, ... }: { config, lib, namespace, ... }:
with lib;
let let
homeassistant-api = pkgs.python3.pkgs.buildPythonPackage rec { cfg = config.mjallen.desktop.extra.waybar;
pname = "homeassistant_api";
version = "5.0.0";
format = "pyproject";
src = pkgs.fetchPypi {
inherit pname version;
sha256 = "sha256-UNKTtgInrVJtjHb1WVlUbcbhjBOtTX00eHmm54ww0rY=";
};
# do not run tests
doCheck = false;
nativeBuildInputs = with pkgs.python3.pkgs; [ poetry-core requests-cache ];
dependencies = with pkgs.python3.pkgs; [
requests-cache
pydantic
websockets
];
propagatedBuildInputs = with pkgs.python3.pkgs; [
aiohttp
aiohttp-client-cache
pydantic
requests
requests-cache
simplejson
websockets
];
pythonRelaxDeps = [
"requests-cache"
"pydantic"
"websockets"
];
pythonImportsCheck = [
"homeassistant_api"
];
};
pythonEnv = pkgs.python3.withPackages (ps: [ pythonEnv = pkgs.python3.withPackages (ps: [
homeassistant-api pkgs.${namespace}.homeassistant-api
]); ]);
waybar-hass = pkgs.writeScriptBin "waybar-hass" '' waybar-hass = pkgs.writeScriptBin "waybar-hass" ''
@@ -102,5 +69,9 @@ let
''; '';
in in
{ {
imports = [ ../options.nix ];
config = lib.mkIf cfg.enable {
home.packages = [ waybar-hass ]; home.packages = [ waybar-hass ];
};
} }

View File

@@ -1,5 +1,8 @@
{ pkgs, ... }: { config, lib, namespace, ... }:
with lib;
let let
cfg = config.mjallen.desktop.extra.waybar;
waybar-weather = pkgs.writeScriptBin "waybar-weather" '' waybar-weather = pkgs.writeScriptBin "waybar-weather" ''
#!/usr/bin/env nix-shell #!/usr/bin/env nix-shell
#! nix-shell -i python3 --pure #! nix-shell -i python3 --pure
@@ -429,5 +432,9 @@ let
''; '';
in in
{ {
imports = [ ../options.nix ];
config = lib.mkIf cfg.enable {
home.packages = [ waybar-weather ]; home.packages = [ waybar-weather ];
};
} }

View File

@@ -1,7 +1,7 @@
{ config, lib, namespace, ... }: { config, lib, ... }:
with lib; with lib;
let let
cfg = config.${namespace}.desktop.extra.wlogout; cfg = config.mjallen.desktop.extra.wlogout;
nord = import ../../theme/nord.nix; nord = import ../../theme/nord.nix;
in in
{ {

View File

@@ -1,8 +1,8 @@
{ lib, namespace, ... }: { lib, ... }:
with lib; with lib;
{ {
options.${namespace}.desktop.extra.wofi = { options.mjallen.desktop.extra.wlogout = {
enable = mkEnableOption "enable wofi"; enable = mkEnableOption "enable wlogout";
fontName = mkOption { fontName = mkOption {
type = types.str; type = types.str;

View File

@@ -1,11 +1,12 @@
{ config, lib, namespace, ... }: { config, lib, ... }:
with lib; with lib;
let let
cfg = config.${namespace}.desktop.extra.wofi; cfg = config.mjallen.desktop.extra.wofi;
nord = import ../../theme/nord.nix; nord = import ../../theme/nord.nix;
in in
{ {
imports = [ ./options.nix ]; imports = [ ./options.nix ];
config = mkIf cfg.enable { config = mkIf cfg.enable {
programs.wofi = { programs.wofi = {
enable = true; enable = true;

View File

@@ -1,7 +1,7 @@
{ lib, namespace, ... }: { lib, ... }:
with lib; with lib;
{ {
options.${namespace}.desktop.extra.wofi = { options.mjallen.desktop.extra.wofi = {
enable = mkEnableOption "enable wofi"; enable = mkEnableOption "enable wofi";
fontName = mkOption { fontName = mkOption {

View File

@@ -1,6 +1,6 @@
{ config, lib, pkgs, namespace, ... }: { config, lib, pkgs, ... }:
let let
cfg = config.${namespace}.desktop.gnome; cfg = config.mjallen.desktop.gnome;
in in
{ {
imports = [ ./options.nix ]; imports = [ ./options.nix ];

View File

@@ -1,7 +1,7 @@
{ lib, namespace, ... }: { lib, ... }:
with lib; with lib;
{ {
options.${namespace}.desktop.gnome = { options.mjallen.desktop.gnome = {
enable = mkEnableOption "enable gnome settings"; enable = mkEnableOption "enable gnome settings";
}; };
} }

View File

@@ -1,22 +1,19 @@
{ config, lib, namespace, pkgs, ... }: { config, lib, pkgs, ... }:
with lib; with lib;
let let
cfg = config.${namespace}.desktop.hyprland; cfg = config.mjallen.desktop.hyprland;
drawer = "nwg-drawer -fm nautilus -term kitty -mb 10 -mt 10 -ml 10 -mr 10 -pbuseicontheme -i ${config.home-manager.users.matt.gtk.iconTheme.name}"; drawer = "nwg-drawer -fm nautilus -term kitty -mb 10 -mt 10 -ml 10 -mr 10 -pbuseicontheme -i ${config.home-manager.users.matt.gtk.iconTheme.name}";
in in
{ {
imports = [ ./options.nix ];
config = mkIf cfg.enable {
imports = [ imports = [
./services/hypridle ./options.nix
./services/hyprlock
./services/hyprpaper
./packages.nix ./packages.nix
./theme.nix ./theme.nix
./variables.nix ./variables.nix
]; ];
config = mkIf cfg.enable {
services = { services = {
hyprpolkitagent.enable = true; hyprpolkitagent.enable = true;
}; };

View File

@@ -1,7 +1,7 @@
{ lib, namespace, ... }: { lib, pkgs, ... }:
with lib; with lib;
{ {
options.${namespace}.desktop.hyprland = { options.mjallen.desktop.hyprland = {
enable = mkEnableOption "enable hyprland desktop"; enable = mkEnableOption "enable hyprland desktop";
primaryDisplay = mkOption { primaryDisplay = mkOption {
@@ -45,8 +45,19 @@ with lib;
}; };
defaultApps = mkOption { defaultApps = mkOption {
type = attrs; type = types.submodule {
default = { }; options = {
browser = mkOption { type = types.package; default = pkgs.firefox; };
editor = mkOption { type = types.package; default = pkgs.micro; };
fileExplorer = mkOption { type = types.package; default = pkgs.nemo; };
visual = mkOption { type = types.package; default = pkgs.vscodium; };
terminal = mkOption { type = types.package; default = pkgs.kitty; };
office = mkOption { type = types.package; default = pkgs.onlyoffice-bin_latest; };
video = mkOption { type = types.package; default = pkgs.vlc; };
imageViewer = mkOption { type = types.package; default = pkgs.gnome-photos; };
};
};
description = "Default applications used across the system.";
}; };
hyprIdle = { hyprIdle = {

View File

@@ -1,5 +1,10 @@
{ pkgs, ... }: { config, lib, pkgs, ... }:
with lib;
let
cfg = config.mjallen.desktop.hyprland;
in
{ {
config = mkIf cfg.enable {
home.packages = with pkgs; [ home.packages = with pkgs; [
box64 box64
brightnessctl brightnessctl
@@ -57,4 +62,5 @@
xsettingsd xsettingsd
xwayland xwayland
]; ];
};
} }

View File

@@ -1,5 +1,8 @@
{ pkgs, ... }: { config, lib, pkgs, ... }:
with lib;
let let
cfg = config.mjallen.desktop.hyprland;
themeSize = "compact"; # [ "standard" "compact" ] themeSize = "compact"; # [ "standard" "compact" ]
themeAccent = "all"; # [ "default" "purple" "pink" "red" "orange" "yellow" "green" "teal" "grey" "all" ] themeAccent = "all"; # [ "default" "purple" "pink" "red" "orange" "yellow" "green" "teal" "grey" "all" ]
themeVariant = "nord"; # [ "nord" "dracula" "gruvbox" "everforest" "catppuccin" "all" "black" "rimless" "normal" "float" ] themeVariant = "nord"; # [ "nord" "dracula" "gruvbox" "everforest" "catppuccin" "all" "black" "rimless" "normal" "float" ]
@@ -39,6 +42,7 @@ let
fontSize = 12; fontSize = 12;
in in
{ {
config = mkIf cfg.enable {
home = { home = {
pointerCursor = { pointerCursor = {
gtk.enable = true; gtk.enable = true;
@@ -90,4 +94,5 @@ in
size = fontSize; size = fontSize;
}; };
}; };
};
} }

View File

@@ -1,10 +1,11 @@
{ config, lib, ... }: { config, lib, ... }:
with lib; with lib;
let let
cfg = config.desktop.hyprland; cfg = config.mjallen.desktop.hyprland;
in in
{ {
sessionVariables = { config = mkIf cfg.enable {
home.sessionVariables = {
BROWSER = "${cfg.defaultApps.browser.pname}"; BROWSER = "${cfg.defaultApps.browser.pname}";
CLUTTER_BACKEND = "wayland"; CLUTTER_BACKEND = "wayland";
EDITOR = "${cfg.defaultApps.editor.pname}"; EDITOR = "${cfg.defaultApps.editor.pname}";
@@ -34,4 +35,5 @@ in
XDG_SESSION_DESKTOP = "Hyprland"; XDG_SESSION_DESKTOP = "Hyprland";
XDG_SESSION_TYPE = "wayland"; XDG_SESSION_TYPE = "wayland";
}; };
};
} }

View File

@@ -40,7 +40,8 @@ in
vscode-extensions.yy0931.vscode-sqlite3-editor vscode-extensions.yy0931.vscode-sqlite3-editor
# open-remote-ssh # open-remote-ssh
nix-vscode-extensions.open-vsx.jeanp413.open-remote-ssh # nix-vscode-extensions.open-vsx.jeanp413.open-remote-ssh
# open-vsx.jeanp413.open-remote-ssh
] ++ pkgs.vscode-utils.extensionsFromVscodeMarketplace [ ] ++ pkgs.vscode-utils.extensionsFromVscodeMarketplace [
{ {
name = "copilot-mcp"; name = "copilot-mcp";

View File

@@ -34,6 +34,7 @@ in
"adguard" "adguard"
"apple_tv" "apple_tv"
"analytics" "analytics"
"backup"
"bluetooth" "bluetooth"
"bluetooth_adapters" "bluetooth_adapters"
"bluetooth_le_tracker" "bluetooth_le_tracker"

View File

@@ -13,6 +13,12 @@
"/var/lib/waydroid" "/var/lib/waydroid"
"/var/lib/systemd/coredump" "/var/lib/systemd/coredump"
"/etc/NetworkManager/system-connections" "/etc/NetworkManager/system-connections"
"/var/lib/tailscale"
"/var/lib/homeassistant"
"/var/lib/mosquitto"
"/var/lib/music-assistant"
"/var/lib/postgresql"
"/var/lib/zigbee2mqtt"
{ {
directory = "/var/lib/colord"; directory = "/var/lib/colord";
user = "colord"; user = "colord";

View File

@@ -0,0 +1,36 @@
{ python3Packages, fetchPypi, ... }:
python3Packages.buildPythonPackage rec {
pname = "homeassistant_api";
version = "5.0.0";
format = "pyproject";
src = fetchPypi {
inherit pname version;
sha256 = "sha256-UNKTtgInrVJtjHb1WVlUbcbhjBOtTX00eHmm54ww0rY=";
};
# do not run tests
doCheck = false;
nativeBuildInputs = with python3Packages; [ poetry-core requests-cache ];
dependencies = with python3Packages; [
requests-cache
pydantic
websockets
];
propagatedBuildInputs = with python3Packages; [
aiohttp
aiohttp-client-cache
pydantic
requests
requests-cache
simplejson
websockets
];
pythonRelaxDeps = [
"requests-cache"
"pydantic"
"websockets"
];
pythonImportsCheck = [
"homeassistant_api"
];
}

View File

@@ -20,7 +20,10 @@
enable = true; enable = true;
}; };
${namespace}.services.home-assistant.enable = true; ${namespace} = {
services.home-assistant.enable = true;
hardware.disko.enable = true;
};
# Enable nix flakes and nix-command tools # Enable nix flakes and nix-command tools
nix = { nix = {

View File

@@ -1,37 +0,0 @@
{ ... }:
{
# Set up impernance configuration for things like bluetooth
# In this configuration with /etc and /var/log being persistent, only directories outside of that need to be done here. See hardware configuration for all mountpoints.
environment.persistence."/nix/persist/system" = {
hideMounts = true;
directories = [
"/var/lib/bluetooth"
"/var/lib/nixos"
"/var/lib/tailscale"
"/var/lib/homeassistant"
"/var/lib/mosquitto"
"/var/lib/music-assistant"
"/var/lib/postgresql"
"/var/lib/zigbee2mqtt"
"/var/lib/systemd/coredump"
"/etc/NetworkManager/system-connections"
"/etc/secureboot"
{
directory = "/var/lib/private";
mode = "u=rwx,g=rx,o=";
}
{
directory = "/var/lib/colord";
user = "colord";
group = "colord";
mode = "u=rwx,g=rx,o=";
}
];
};
security.sudo.extraConfig = ''
# rollback results in sudo lectures after each reboot
Defaults lecture = never
'';
}

View File

@@ -10,7 +10,8 @@ in
mutableUsers = false; mutableUsers = false;
# Admin account # Admin account
users."${user}" = { users = {
"${user}" = {
isNormalUser = true; isNormalUser = true;
linger = true; linger = true;
extraGroups = [ extraGroups = [
@@ -35,6 +36,11 @@ in
]; ];
}; };
users.root.shell = pkgs.zsh; root = {
isSystemUser = true;
isNormalUser = false;
shell = pkgs.zsh;
};
};
}; };
} }