243 lines
6.2 KiB
Nix
243 lines
6.2 KiB
Nix
{
|
|
inputs = {
|
|
nixpkgs.url = "nixpkgs/nixos-24.05";
|
|
nixpkgs-unstable.url = "nixpkgs/nixos-unstable";
|
|
|
|
home-manager = {
|
|
url = "github:nix-community/home-manager/release-24.05";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
};
|
|
|
|
dotfiles = {
|
|
url = "git+https://git.pvv.ntnu.no/oysteikt/dotfiles?ref=master";
|
|
flake = false;
|
|
};
|
|
|
|
sops-nix = {
|
|
url = "github:Mic92/sops-nix";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
};
|
|
|
|
osuchan = {
|
|
url = "git+file:///home/h7x4/git/osuchan-line-bot";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
};
|
|
|
|
# TODO: fix website
|
|
# website = {
|
|
# url = "git+https://git.pvv.ntnu.no/oysteikt/nani.wtf?ref=main";
|
|
# url = "path:/home/h7x4/git/nani.wtf";
|
|
# inputs.nixpkgs.follows = "nixpkgs";
|
|
# };
|
|
|
|
maunium-stickerpicker = {
|
|
url = "github:h7x4/maunium-stickerpicker-nix/0.1.0";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
};
|
|
|
|
minecraft = {
|
|
url = "github:infinidoge/nix-minecraft";
|
|
inputs.nixpkgs.follows = "nixpkgs-unstable";
|
|
};
|
|
|
|
matrix-synapse-next = {
|
|
url = "github:dali99/nixos-matrix-modules/v0.6.0";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
};
|
|
|
|
vscode-server = {
|
|
url = "github:nix-community/nixos-vscode-server";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
};
|
|
|
|
# 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@{
|
|
self,
|
|
nixpkgs,
|
|
nixpkgs-unstable,
|
|
home-manager,
|
|
|
|
dotfiles,
|
|
matrix-synapse-next,
|
|
maunium-stickerpicker,
|
|
minecraft,
|
|
osuchan,
|
|
secrets,
|
|
sops-nix,
|
|
vscode-server,
|
|
# website
|
|
}: let
|
|
system = "x86_64-linux";
|
|
|
|
pkgs-config = {
|
|
inherit system;
|
|
|
|
config = {
|
|
allowUnfree = true;
|
|
android_sdk.accept_license = true;
|
|
segger-jlink.acceptLicense = true;
|
|
permittedInsecurePackages = [
|
|
"segger-jlink-qt4-794l"
|
|
];
|
|
};
|
|
|
|
overlays = let
|
|
nonrecursive-unstable-pkgs = import nixpkgs-unstable {
|
|
inherit system;
|
|
config.allowUnfree = true;
|
|
config.segger-jlink.acceptLicense = true;
|
|
config.permittedInsecurePackages = [
|
|
"segger-jlink-qt4-794s"
|
|
];
|
|
};
|
|
in [
|
|
(self: super: {
|
|
inherit (nonrecursive-unstable-pkgs)
|
|
atuin
|
|
wstunnel
|
|
nrf-udev
|
|
nrfutil
|
|
;
|
|
})
|
|
|
|
# https://github.com/NixOS/nixpkgs/pull/251706
|
|
(self: super: {
|
|
mozc = self.qt6Packages.callPackage ./package-overrides/mozc.nix { };
|
|
fcitx5-mozc = self.callPackage ./package-overrides/fcitx5-mozc.nix { };
|
|
})
|
|
|
|
(self: super: {
|
|
mpv-unwrapped = super.mpv-unwrapped.override {
|
|
ffmpeg = super.ffmpeg_6-full;
|
|
};
|
|
})
|
|
];
|
|
};
|
|
|
|
pkgs = import nixpkgs pkgs-config;
|
|
unstable-pkgs = import nixpkgs-unstable pkgs-config;
|
|
in {
|
|
extendedLib = import ./lib { stdlib = pkgs.lib; };
|
|
|
|
inherit pkgs;
|
|
|
|
packages.${system} = {
|
|
inherit (pkgs) kanidm pcloud;
|
|
};
|
|
|
|
devShells.${system}.default = pkgs.mkShell {
|
|
packages = with pkgs; [ sops ];
|
|
};
|
|
|
|
homeConfigurations = {
|
|
h7x4 = home-manager.lib.homeManagerConfiguration {
|
|
inherit system;
|
|
inherit pkgs;
|
|
|
|
username = "h7x4";
|
|
homeDirectory = "/home/h7x4";
|
|
stateVersion = "22.05";
|
|
configuration = {
|
|
imports = [
|
|
./home/home.nix
|
|
./modules/machineVars.nix
|
|
];
|
|
|
|
machineVars = {
|
|
headless = false;
|
|
fixDisplayCommand = "echo 'not available'";
|
|
gaming = true;
|
|
development = true;
|
|
laptop = false;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
nixosConfigurations = let
|
|
nixSys = name: extraConfig:
|
|
nixpkgs.lib.nixosSystem
|
|
({
|
|
inherit system;
|
|
inherit pkgs;
|
|
inherit (pkgs) lib;
|
|
|
|
specialArgs = {
|
|
inherit inputs;
|
|
inherit unstable-pkgs;
|
|
inherit (self) extendedLib;
|
|
secrets = secrets.outputs.settings;
|
|
} // (extraConfig.specialArgs or { });
|
|
|
|
modules = [
|
|
"${home-manager}/nixos"
|
|
|
|
./hosts/common
|
|
./hosts/${name}/configuration.nix
|
|
|
|
./modules/machineVars.nix
|
|
./modules/socketActivation.nix
|
|
|
|
secrets.outputs.nixos-config
|
|
sops-nix.nixosModules.sops
|
|
|
|
({ config, ... }:
|
|
{
|
|
home-manager = {
|
|
useGlobalPkgs = true;
|
|
extraSpecialArgs = {
|
|
inherit inputs;
|
|
inherit unstable-pkgs;
|
|
inherit (self) extendedLib;
|
|
inherit (config) machineVars;
|
|
secrets = secrets.outputs.settings;
|
|
};
|
|
|
|
sharedModules = [
|
|
inputs.sops-nix.homeManagerModules.sops
|
|
];
|
|
|
|
users.h7x4.imports = [
|
|
./home/home.nix
|
|
./hosts/${name}/home
|
|
];
|
|
};
|
|
})
|
|
] ++ (extraConfig.modules or [ ]);
|
|
}
|
|
//
|
|
(builtins.removeAttrs extraConfig [
|
|
"modules"
|
|
"specialArgs"
|
|
]));
|
|
in {
|
|
dosei = nixSys "dosei" { };
|
|
kasei = nixSys "kasei" { };
|
|
europa = nixSys "europa" { };
|
|
tsuki = nixSys "tsuki" {
|
|
modules = [
|
|
matrix-synapse-next.nixosModules.default
|
|
osuchan.outputs.nixosModules.default
|
|
vscode-server.nixosModules.default
|
|
maunium-stickerpicker.nixosModules.default
|
|
|
|
(args: import minecraft.outputs.nixosModules.minecraft-servers (args // {
|
|
pkgs = unstable-pkgs;
|
|
lib = unstable-pkgs.lib;
|
|
}))
|
|
];
|
|
};
|
|
};
|
|
};
|
|
}
|