mirror of
https://github.com/srid/nixos-config.git
synced 2025-12-28 16:36:28 +08:00
116 lines
3.8 KiB
Nix
116 lines
3.8 KiB
Nix
{
|
|
description = "Srid's NixOS configuration";
|
|
|
|
inputs = {
|
|
# To update nixpkgs (and thus NixOS), pick the nixos-unstable rev from
|
|
# https://status.nixos.org/
|
|
#
|
|
# This ensures that we always use the official nix cache.
|
|
nixpkgs.url = "github:nixos/nixpkgs/2deb07f3ac4eeb5de1c12c4ba2911a2eb1f6ed61";
|
|
|
|
nixos-hardware.url = github:NixOS/nixos-hardware/master;
|
|
home-manager.url = "github:nix-community/home-manager";
|
|
home-manager.inputs.nixpkgs.follows = "nixpkgs";
|
|
nixos-vscode-server = {
|
|
url = "github:iosmanthus/nixos-vscode-server/add-flake";
|
|
};
|
|
himalaya.url = "github:soywod/himalaya";
|
|
emacs-overlay.url = "github:nix-community/emacs-overlay";
|
|
neovim-nightly-overlay.url = "github:nix-community/neovim-nightly-overlay";
|
|
nix-doom-emacs.url = "github:vlaci/nix-doom-emacs";
|
|
emanote.url = "github:srid/emanote";
|
|
};
|
|
|
|
outputs = inputs@{ self, home-manager, nixpkgs, ... }:
|
|
let
|
|
system = "x86_64-linux";
|
|
mkComputer = configurationNix: extraModules: nixpkgs.lib.nixosSystem {
|
|
inherit system;
|
|
# Arguments to pass to all modules.
|
|
specialArgs = { inherit system inputs; };
|
|
modules = (
|
|
[
|
|
# System configuration for this host
|
|
configurationNix
|
|
|
|
# Configuration common to all of my systems (servers, desktops, laptops)
|
|
./features/self-ide.nix
|
|
./features/takemessh
|
|
./features/caches
|
|
./features/current-location.nix
|
|
./features/passwordstore.nix
|
|
|
|
# home-manager configuration
|
|
home-manager.nixosModules.home-manager
|
|
{
|
|
home-manager.useGlobalPkgs = true;
|
|
home-manager.useUserPackages = true;
|
|
home-manager.users.srid = import ./home.nix {
|
|
inherit inputs system;
|
|
pkgs = import nixpkgs { inherit system; };
|
|
};
|
|
}
|
|
] ++ extraModules
|
|
);
|
|
};
|
|
in
|
|
{
|
|
# The "name" in nixosConfigurations.${name} should match the `hostname`
|
|
#
|
|
nixosConfigurations = {
|
|
thick = mkComputer
|
|
./hosts/thick.nix
|
|
[
|
|
inputs.nixos-hardware.nixosModules.lenovo-thinkpad-p53
|
|
./features/server/harden.nix
|
|
./features/server/devserver.nix
|
|
./features/server/unlaptop.nix
|
|
./features/ema/emanote.nix
|
|
./features/lxd.nix
|
|
./features/docker.nix
|
|
];
|
|
thin = mkComputer
|
|
./hosts/thin.nix
|
|
[
|
|
inputs.nixos-hardware.nixosModules.lenovo-thinkpad-x1-7th-gen
|
|
./features/server/harden.nix
|
|
#./features/distributed-build.nix
|
|
./features/kde.nix
|
|
./features/desktopish/guiapps.nix
|
|
./features/desktopish/fonts.nix
|
|
./features/protonvpn.nix
|
|
#./features/ema/emanote.nix
|
|
];
|
|
thebeast = mkComputer
|
|
./hosts/thebeast.nix
|
|
[
|
|
./features/server/devserver.nix
|
|
./features/ema/emanote.nix
|
|
];
|
|
};
|
|
|
|
# non-NixOS systems
|
|
homeConfigurations =
|
|
let
|
|
username = "srid";
|
|
baseConfiguration = {
|
|
programs.home-manager.enable = true;
|
|
home.username = "srid";
|
|
home.homeDirectory = "/home/srid";
|
|
};
|
|
mkHomeConfig = cfg: home-manager.lib.homeManagerConfiguration {
|
|
inherit username system;
|
|
homeDirectory = "/home/${username}";
|
|
configuration = baseConfiguration // cfg;
|
|
};
|
|
in
|
|
{
|
|
# FIXME: This is broken on Clear Linux
|
|
"x1c7" = mkHomeConfig {
|
|
programs.git = import ./home/git.nix;
|
|
programs.tmux = import ./home/tmux.nix;
|
|
};
|
|
};
|
|
};
|
|
|
|
}
|