nixos-configuration/nix-os/core.nix

87 lines
1.7 KiB
Nix
Raw Normal View History

{
inputs,
lib,
pkgs,
...
}:
2023-12-12 00:48:10 +01:00
{
imports = [
./module-overrides.nix
./nix.nix
];
2023-12-22 00:54:40 +01:00
# kernel
2024-12-22 16:37:52 +01:00
boot.kernelPackages = pkgs.linuxPackages_latest;
2023-12-22 00:54:40 +01:00
2023-12-12 00:48:10 +01:00
# Enable networking
networking.networkmanager.enable = true;
# Allow unfree packages
nixpkgs.config.allowUnfree = true;
nix = {
channel.enable = false;
settings.experimental-features = [
"no-url-literals"
];
nixPath = [
"nixpkgs=${pkgs.selfExpr { useConfig = false; }}"
"systemNixpkgs=${pkgs.selfExpr { useConfig = true; name = "systemNixpkgs-self"; }}"
# don't garbage collect the nixpkgs input
"inputsNixpkgs=${inputs.nixpkgs}"
];
};
2023-12-12 00:48:10 +01:00
# List packages installed in system profile. To search, run:
# $ nix search wget
environment.systemPackages = with pkgs; [
waypipe
2023-12-12 00:48:10 +01:00
wget
ffmpeg
yt-dlp
htop
btop
2024-05-02 10:00:04 +02:00
fastfetch
2023-12-12 00:48:10 +01:00
smartmontools
ddrescue
];
2024-05-28 12:22:59 +02:00
programs.git.enable = true;
2024-05-28 12:18:08 +02:00
programs.git.config = {
commit.verbose = true;
2024-05-28 12:18:08 +02:00
init.defaultBranch = "main";
merge.conflictstyle = "diff3";
rerere.enabled = true;
};
2024-07-09 06:35:14 +02:00
# Use nix-index for command-not-found handler
programs.command-not-found.enable = false;
programs.nix-index = {
package = pkgs.nix-index.override {
nix-index-unwrapped = pkgs.nix-index-unwrapped.overrideAttrs (oldAttrs: {
patches = oldAttrs.patches or [] ++ [
../pkgs/by-name/ni/nix-index/cnfOutput.patch
];
});
};
2024-07-09 06:35:14 +02:00
enable = true;
enableBashIntegration = true;
};
2023-12-12 00:48:10 +01:00
# Enable fail2ban because of the OpenSSH server
services.fail2ban = {
enable = true;
maxretry = 10;
bantime = "7d";
};
# Enable the OpenSSH daemon.
services.openssh = {
enable = true;
ports = [
22
8022
];
};
}