This commit is contained in:
xqtc 2024-10-08 11:19:34 +02:00
parent 590734a38b
commit 828989b482
12 changed files with 180 additions and 138 deletions

View file

@ -1,11 +1,11 @@
{inputs, ...}: {
perSystem = { system, ...}: {
perSystem = {system, ...}: {
_module.args.pkgs = import inputs.nixpkgs {
inherit system;
config.allowUnfree = true;
# The allowUnfreePredicate is due to home-manager#2942 (I haven't actually checked that it is necessary)
# https://github.com/nix-community/home-manager/issues/2942
config.allowUnfreePredicate = (_: true);
config.allowUnfreePredicate = _: true;
};
};
}

View file

@ -1,21 +1,26 @@
{ lib, flake-parts-lib, ... }:
let
inherit (lib)
{
lib,
flake-parts-lib,
...
}: let
inherit
(lib)
mkOption
types
;
inherit (flake-parts-lib)
inherit
(flake-parts-lib)
mkTransposedPerSystemModule
;
in
mkTransposedPerSystemModule {
mkTransposedPerSystemModule {
name = "homeConfigurations";
option = mkOption {
type = types.raw;
default = { };
default = {};
description = ''
home-manager configs
'';
};
file = ./hm-flake-part.nix;
}
}

View file

@ -1,8 +1,19 @@
{inputs, lib, ...}: {
{
inputs,
lib,
...
}: {
imports = [
./hm-flake-part.nix
];
perSystem = { config, self', inputs', pkgs, system, ... }: let
perSystem = {
config,
self',
inputs',
pkgs,
system,
...
}: let
# split system (e.g. x86_64-linux) into os and arch
splitSystem = lib.splitString "-" system;
os = builtins.elemAt splitSystem 0;
@ -14,7 +25,7 @@
../home
inputs.nixvim.homeManagerModules.nixvim
inputs.sops-nix.homeManagerModules.sops
{ inherit os arch; }
{inherit os arch;}
];
extraSpecialArgs = {inherit inputs;};
};

View file

@ -1,7 +1,17 @@
{inputs, lib, ...}: {
flake.nixosConfigurations = lib.genAttrs [
"asmodeus" "seraphim" "lilith" "lambda" "beleth"
] (name: inputs.nixpkgs.lib.nixosSystem {
{
inputs,
lib,
...
}: {
flake.nixosConfigurations =
lib.genAttrs [
"asmodeus"
"seraphim"
"lilith"
"lambda"
"beleth"
] (name:
inputs.nixpkgs.lib.nixosSystem {
system = "x86_64-linux";
modules = [
../hosts/x86_64-linux/${name}

View file

@ -42,14 +42,22 @@
};
#inputs.agenix.url = "github:ryantm/agenix";
outputs = inputs@{ flake-parts, ... }: flake-parts.lib.mkFlake { inherit inputs; } {
outputs = inputs @ {flake-parts, ...}:
flake-parts.lib.mkFlake {inherit inputs;} {
imports = [
./flake-mods/hm.nix
./flake-mods/nixosHosts.nix
./flake-mods/allowUnfree.nix
];
systems = [ "x86_64-linux" "aarch64-linux" "aarch64-darwin" "x86_64-darwin" ];
perSystem = { config, self', inputs', pkgs, system, ... }: {};
systems = ["x86_64-linux" "aarch64-linux" "aarch64-darwin" "x86_64-darwin"];
perSystem = {
config,
self',
inputs',
pkgs,
system,
...
}: {};
flake = {};
};
}

View file

@ -10,7 +10,10 @@
./system.nix
];
home.username = "xqtc";
home.homeDirectory = if config.os == "linux" then "/home/xqtc" else "/Users/xqtc";
home.homeDirectory =
if config.os == "linux"
then "/home/xqtc"
else "/Users/xqtc";
programs.wezterm = {
enable = true;

View file

@ -7,7 +7,10 @@
...
}:
with inputs; {
home.sessionVariables.DEFAULT_BROWSER = if (config.os == "linux") then "${pkgs.firefox}/bin/firefox" else "firefox";
home.sessionVariables.DEFAULT_BROWSER =
if (config.os == "linux")
then "${pkgs.firefox}/bin/firefox"
else "firefox";
programs.firefox = lib.mkIf (config.os == "linux") {
enable = true;

View file

@ -9,7 +9,8 @@
maxfetch = pkgs.writeScriptBin "maxfetch" (builtins.readFile ../config-files/maxfetch.sh);
startdwl = pkgs.writeScriptBin "startdwl" (builtins.readFile ../config-files/startdwl.sh);
in {
home.packages = (lib.optionals (config.os == "linux") (with pkgs; [
home.packages =
(lib.optionals (config.os == "linux") (with pkgs; [
yubioath-flutter
steam
heroic
@ -41,7 +42,8 @@ in {
signal-desktop
# ida-free
# spotify
])) ++ (with pkgs; [
]))
++ (with pkgs; [
nh
ncspot
@ -74,20 +76,15 @@ in {
moodle-dl
obsidian
prismlauncher
# marked as broken
# syncthingtray
rbw
nodejs
# cabal
@ -97,7 +94,6 @@ in {
# rizin
# (cutter.withPlugins (ps: with ps; [jsdec rz-ghidra sigdb]))
nerdfonts
ipafont

View file

@ -5,7 +5,10 @@
...
}: {
programs = {
zsh.enable = if config.os == "linux" then true else false;
zsh.enable =
if config.os == "linux"
then true
else false;
atuin = {
enable = true;
enableNushellIntegration = true;

View file

@ -10,7 +10,10 @@
age = {
sshKeyPaths = ["/etc/ssh/ssh_host_ed25519_key"];
keyFile = if (config.os == "linux") then "/home/xqtc/.config/sops/age/keys.txt" else "/Users/xqtc/.config/sops/age/keys.txt";
keyFile =
if (config.os == "linux")
then "/home/xqtc/.config/sops/age/keys.txt"
else "/Users/xqtc/.config/sops/age/keys.txt";
generateKey = true;
};
};