nix-dotfiles/flake.nix

152 lines
3.6 KiB
Nix
Raw Normal View History

2022-03-07 16:01:52 +01:00
{
description = "Mmmmmh, Spaghetti";
inputs = {
2022-06-12 00:23:10 +02:00
nixpkgs.url = "nixpkgs/nixos-22.05";
nixpkgs-unstable.url = "nixpkgs/nixos-unstable";
2022-03-07 16:01:52 +01:00
home-manager = {
2022-06-12 00:23:10 +02:00
url = "github:nix-community/home-manager/release-22.05";
# url = "git+file:///home/h7x4/git/home-manager";
2022-03-07 16:01:52 +01:00
inputs.nixpkgs.follows = "nixpkgs";
};
2022-03-22 16:37:19 +01:00
dotfiles = {
url = "github:h7x4abk3g/dotfiles";
flake = false;
};
2022-03-07 16:01:52 +01:00
fonts = {
url = "path:/home/h7x4/git/fonts";
flake = false;
};
2022-03-22 23:05:42 +01:00
website = {
url = "git+https://git.nani.wtf/h7x4/nani.wtf?ref=main";
# url = "path:/home/h7x4/git/nani.wtf";
inputs.nixpkgs.follows = "nixpkgs";
};
vscode-server = {
url = "github:msteen/nixos-vscode-server";
flake = false;
};
2022-03-07 16:01:52 +01:00
# Nix expressions and keys (TODO: move keys to another solution like agenix)
# which should be kept from the main repo for privacy reasons.
#
# Includes stuff like usernames, emails, ports, other server users, ssh hosts, etc.
secrets = {
# TODO: Push this to a remote.
url = "git+file:///home/h7x4/git/nix-secrets";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs = inputs@{
2022-03-22 23:05:42 +01:00
self,
nixpkgs,
nixpkgs-unstable,
2022-03-22 23:05:42 +01:00
home-manager,
vscode-server,
2022-03-22 23:05:42 +01:00
secrets,
fonts,
2022-03-22 23:05:42 +01:00
dotfiles,
website
2022-03-22 23:05:42 +01:00
}: let
2022-03-07 16:01:52 +01:00
system = "x86_64-linux";
pkgs-config = {
2022-03-07 16:01:52 +01:00
inherit system;
config = {
allowUnfree = true;
android_sdk.accept_license = true;
};
# overlays = [ self.overlays.lib ];
2022-08-18 23:15:50 +02:00
};
pkgs = import nixpkgs pkgs-config;
unstable-pkgs = import nixpkgs-unstable pkgs-config;
2022-03-07 16:01:52 +01:00
in {
extendedLib = import ./lib { stdlib = pkgs.lib; };
2022-03-07 16:01:52 +01:00
homeConfigurations = {
h7x4 = home-manager.lib.homeManagerConfiguration {
inherit system;
inherit pkgs;
username = "h7x4";
homeDirectory = "/home/h7x4";
2022-06-12 00:23:10 +02:00
stateVersion = "22.05";
2022-03-07 16:01:52 +01:00
configuration = {
imports = [
./home/home.nix
./modules
2022-03-07 16:01:52 +01:00
];
machineVars = {
headless = false;
fixDisplayCommand = "echo 'not available'";
gaming = true;
development = true;
laptop = false;
};
2022-03-07 16:01:52 +01:00
};
};
};
nixosConfigurations = let
nixSys = name:
2022-03-07 16:01:52 +01:00
nixpkgs.lib.nixosSystem {
inherit system;
inherit pkgs;
inherit (pkgs) lib;
2022-03-07 16:01:52 +01:00
modules = [
"${home-manager}/nixos"
./modules
./hosts/common.nix
2022-03-07 16:01:52 +01:00
./hosts/${name}/configuration.nix
"${vscode-server}/default.nix"
secrets.outputs.nixos-config
2022-08-18 23:15:50 +02:00
{
config._module.args = {
inherit inputs;
inherit unstable-pkgs;
inherit (self) extendedLib;
secrets = secrets.outputs.settings;
2022-08-18 23:15:50 +02:00
};
}
({ config, ... }:
{
home-manager = {
useGlobalPkgs = true;
extraSpecialArgs = {
inherit inputs;
inherit (self) extendedLib;
secrets = secrets.outputs.settings;
};
users.h7x4 = import ./home/home.nix {
inherit pkgs;
inherit inputs;
inherit (pkgs) lib;
inherit (config) machineVars colors;
inherit (self) extendedLib;
};
};
})
2022-03-07 16:01:52 +01:00
];
};
2022-03-07 16:01:52 +01:00
in {
Tsuki = nixSys "tsuki";
Eisei = nixSys "eisei";
kasei = nixSys "kasei";
2022-03-07 16:01:52 +01:00
};
};
}