Fix correct username not being set

Rather than set username in flake.nix, set a default value in
default.nix (since it's always called), and set appropriate values in
personal.nix (pixelifytica) and work.nix (elitherl), since the two
files are mutually exclusive and only one or the other will be
imported.
This commit is contained in:
Evie Litherland-Smith 2024-06-24 09:15:17 +01:00
parent dc2ccdc7ea
commit c6a8a7c34e
4 changed files with 75 additions and 62 deletions

View file

@ -1,4 +1,8 @@
{username, ...}: { {
config,
lib,
...
}: {
imports = [ imports = [
# Programs # Programs
./programs/desktop/default.nix ./programs/desktop/default.nix
@ -14,8 +18,8 @@
programs.home-manager.enable = true; programs.home-manager.enable = true;
nixpkgs.config.allowUnfree = true; nixpkgs.config.allowUnfree = true;
home = { home = {
inherit username; username = lib.mkDefault "pixelifytica";
homeDirectory = "/home/${username}"; homeDirectory = "/home/${config.home.username}";
stateVersion = "23.05"; stateVersion = "23.05";
}; };
} }

View file

@ -38,12 +38,10 @@
... ...
}: let }: let
defaultExtraSpecialArgs = { defaultExtraSpecialArgs = {
system ? "x86_64-linux", hostname,
hostname ? "Atlas", system,
username ? "pixelifytica",
...
}: rec { }: rec {
inherit hostname username; inherit hostname;
inherit (plasma-manager.packages.${system}) rc2nix; inherit (plasma-manager.packages.${system}) rc2nix;
accentColourName = "base0D"; accentColourName = "base0D";
altAccentColourName = "base0C"; altAccentColourName = "base0C";
@ -90,53 +88,58 @@
}; };
homeConfigurations = { homeConfigurations = {
# Server # Server
"pixelifytica@Legion" = home-manager.lib.homeManagerConfiguration { "pixelifytica@Legion" = let
pkgs = import nixpkgs {system = "x86_64-linux";}; hostname = "Legion";
modules = defaultModules; system = "x86_64-linux";
extraSpecialArgs = defaultExtraSpecialArgs { in
system = "x86_64-linux"; home-manager.lib.homeManagerConfiguration {
hostname = "Legion"; pkgs = import nixpkgs {inherit system;};
modules = defaultModules;
extraSpecialArgs = defaultExtraSpecialArgs {inherit hostname system;};
}; };
};
# Personal # Personal
"pixelifytica@Northstar" = home-manager.lib.homeManagerConfiguration { "pixelifytica@Northstar" = let
pkgs = import nixpkgs {system = "x86_64-linux";}; hostname = "Northstar";
modules = system = "x86_64-linux";
defaultModules in
++ [ home-manager.lib.homeManagerConfiguration {
./personal.nix pkgs = import nixpkgs {inherit system;};
{programs.plasma.configFile.kcminputrc."Libinput/1739/52759/SYNA32AA:00 06CB:CE17 Touchpad".NaturalScroll = true;} modules =
]; defaultModules
extraSpecialArgs = defaultExtraSpecialArgs { ++ [
system = "x86_64-linux"; ./personal.nix
hostname = "Northstar"; {programs.plasma.configFile.kcminputrc."Libinput/1739/52759/SYNA32AA:00 06CB:CE17 Touchpad".NaturalScroll = true;}
];
extraSpecialArgs = defaultExtraSpecialArgs {inherit hostname system;};
}; };
}; "pixelifytica@Vanguard" = let
"pixelifytica@Vanguard" = home-manager.lib.homeManagerConfiguration { hostname = "Vanguard";
pkgs = import nixpkgs {system = "x86_64-linux";}; system = "x86_64-linux";
modules = defaultModules ++ [./personal.nix]; in
extraSpecialArgs = defaultExtraSpecialArgs { home-manager.lib.homeManagerConfiguration {
system = "x86_64-linux"; pkgs = import nixpkgs {inherit system;};
hostname = "Vanguard"; modules = defaultModules ++ [./personal.nix];
extraSpecialArgs = defaultExtraSpecialArgs {inherit hostname system;};
}; };
};
# Work # Work
"elitherl@Tone" = home-manager.lib.homeManagerConfiguration { "elitherl@Tone" = let
pkgs = import nixpkgs {system = "x86_64-linux";}; hostname = "Tone";
modules = defaultModules ++ [./work.nix]; system = "x86_64-linux";
extraSpecialArgs = defaultExtraSpecialArgs { in
system = "x86_64-linux"; home-manager.lib.homeManagerConfiguration {
hostname = "Tone"; pkgs = import nixpkgs {inherit system;};
modules = defaultModules ++ [./work.nix];
extraSpecialArgs = defaultExtraSpecialArgs {inherit hostname system;};
}; };
}; "elitherl@Scorch" = let
"elitherl@Scorch" = home-manager.lib.homeManagerConfiguration { hostname = "Scorch";
pkgs = import nixpkgs {system = "x86_64-linux";}; system = "x86_64-linux";
modules = defaultModules ++ [./work.nix]; in
extraSpecialArgs = defaultExtraSpecialArgs { home-manager.lib.homeManagerConfiguration {
system = "x86_64-linux"; pkgs = import nixpkgs {inherit system;};
hostname = "Scorch"; modules = defaultModules ++ [./work.nix];
extraSpecialArgs = defaultExtraSpecialArgs {inherit hostname system;};
}; };
};
}; };
}; };
} }

View file

@ -4,12 +4,15 @@
./programs/games/default.nix ./programs/games/default.nix
./programs/streaming/default.nix ./programs/streaming/default.nix
]; ];
home.packages = with pkgs; home = {
with kdePackages; [ username = "pixelifytica";
blender packages = with pkgs;
freecad with kdePackages; [
prusa-slicer blender
ktorrent freecad
noson prusa-slicer
]; ktorrent
noson
];
};
} }

View file

@ -4,12 +4,15 @@
pkgs, pkgs,
... ...
}: { }: {
home.packages = with pkgs; [ home = {
twinkle username = "elitherl";
teams-for-linux packages = with pkgs; [
(writeShellScriptBin "ukaea-vpn-connect" twinkle
"sudo ${openfortivpn}/bin/openfortivpn -c ${./ukaea-vpn.conf}") teams-for-linux
]; (writeShellScriptBin "ukaea-vpn-connect"
"sudo ${openfortivpn}/bin/openfortivpn -c ${./ukaea-vpn.conf}")
];
};
programs = { programs = {
git.userEmail = config.accounts.email.accounts.outlook.address; git.userEmail = config.accounts.email.accounts.outlook.address;
firefox.policies.Homepage.URL = "https://nucleus.ukaea.uk"; firefox.policies.Homepage.URL = "https://nucleus.ukaea.uk";