2023-07-26 09:06:51 +02:00
{ pkgs , . . . }:
{
2023-07-26 10:48:52 +02:00
# Many settings should be handled by home manager. System-wide settings are however managed here.
2023-11-16 14:37:23 +01:00
imports = [
./yabai.nix
] ;
2023-07-26 10:48:52 +02:00
2023-07-26 15:22:24 +02:00
nixpkgs . config . allowUnfree = true ;
nix = {
2023-08-21 23:54:18 +02:00
# gc = {
# automatic = true;
# options = "--delete-older-than 2d";
# };
2023-07-26 15:22:24 +02:00
2023-09-13 23:20:31 +02:00
settings = {
allow-dirty = true ;
2024-12-01 12:42:38 +01:00
experimental-features = [ " n i x - c o m m a n d " " f l a k e s " ] ;
2023-09-13 23:20:31 +02:00
builders-use-substitutes = true ;
2024-05-30 10:39:02 +02:00
extra-platforms = [ " x 8 6 _ 6 4 - d a r w i n " " a a r c h 6 4 - d a r w i n " ] ;
2023-09-13 23:20:31 +02:00
log-lines = 50 ;
2024-02-09 21:26:15 +01:00
# https://github.com/NixOS/nix/issues/7273
# auto-optimise-store = true;
2023-09-13 23:20:31 +02:00
} ;
buildMachines = [
2023-11-16 14:37:23 +01:00
{
2023-12-25 01:37:05 +01:00
hostName = " d e f i a n t . h o m e . f e a l . n o " ;
2023-11-16 14:37:23 +01:00
system = " x 8 6 _ 6 4 - l i n u x " ;
maxJobs = 6 ;
2024-02-09 21:26:15 +01:00
supportedFeatures = [ " k v m " " b i g - p a r a l l e l " " b e n c h m a r k " " n i x o s - t e s t " ] ;
2023-11-16 14:37:23 +01:00
mandatoryFeatures = [ ] ;
2024-09-22 10:23:55 +02:00
sshUser = " f e l i x a l b " ;
sshKey = " / v a r / r o o t / . s s h / n i x - b u i l d e r " ;
}
{
hostName = " c h a l l e n g e r . h o m e . f e a l . n o " ;
system = " x 8 6 _ 6 4 - l i n u x " ;
maxJobs = 6 ;
supportedFeatures = [ " k v m " " b i g - p a r a l l e l " " b e n c h m a r k " " n i x o s - t e s t " ] ;
mandatoryFeatures = [ ] ;
2023-11-16 14:37:23 +01:00
sshUser = " f e l i x a l b " ;
sshKey = " / v a r / r o o t / . s s h / n i x - b u i l d e r " ;
2023-09-13 23:20:31 +02:00
}
] ;
distributedBuilds = true ;
extraOptions = " b u i l d e r s - u s e - s u b s t i t u t e s = t r u e " ;
2023-07-26 15:22:24 +02:00
} ;
2023-07-26 10:48:52 +02:00
# System packages for all users
2023-07-27 11:33:44 +02:00
environment = {
systemPackages = with pkgs ; [
2024-03-18 18:08:43 +01:00
eza
2023-07-27 13:13:03 +02:00
findutils
gnugrep
2023-12-07 10:22:35 +01:00
jq
2024-05-30 10:39:02 +02:00
nix-output-monitor
2024-10-05 00:52:57 +02:00
nixpkgs-review
2023-07-27 11:33:44 +02:00
ripgrep
2024-05-30 10:39:02 +02:00
skhd
2023-08-08 08:51:20 +02:00
sshfs
2023-12-07 10:22:35 +01:00
wget
2023-07-27 11:33:44 +02:00
] ;
variables = {
EDITOR = " n v i m " ;
VISUAL = " n v i m " ;
} ;
} ;
2023-07-26 09:06:51 +02:00
2023-07-26 10:48:52 +02:00
users . users . felixalb = {
home = " / U s e r s / f e l i x a l b " ;
shell = pkgs . zsh ;
} ;
programs . zsh . enable = true ;
system . activationScripts . postActivation . text = '' s u d o c h s h - s ${ pkgs . zsh } / b i n / z s h '' ; # Since it's not possible to declare default shell, run this command after build
2023-07-27 11:33:44 +02:00
2024-07-30 19:07:24 +02:00
fonts . packages = with pkgs ; [
noto-fonts
font-awesome
fira-code
hack-font
( nerdfonts . override {
fonts = [
" H a c k "
] ;
} )
] ;
2023-07-27 11:33:44 +02:00
2023-07-26 15:22:24 +02:00
system . defaults = {
# login window settings
loginwindow = {
# disable guest account
GuestEnabled = false ;
# show name instead of username
SHOWFULLNAME = false ;
} ;
finder = {
AppleShowAllExtensions = true ;
FXEnableExtensionChangeWarning = true ;
_FXShowPosixPathInTitle = true ;
} ;
# firewall settings
alf = {
# 0 = disabled 1 = enabled 2 = blocks all connections except for essential services
globalstate = 1 ;
loggingenabled = 0 ;
stealthenabled = 1 ;
} ;
# dock settings
dock = {
autohide = true ;
autohide-delay = 0 .0 ;
autohide-time-modifier = 1 .0 ;
2023-08-08 08:51:20 +02:00
tilesize = 45 ;
2023-07-26 15:22:24 +02:00
static-only = false ;
showhidden = false ;
show-recents = false ;
show-process-indicators = true ;
orientation = " b o t t o m " ;
mru-spaces = false ;
} ;
} ;
system . keyboard = {
enableKeyMapping = true ;
remapCapsLockToControl = true ;
} ;
2023-07-26 09:06:51 +02:00
# Auto upgrade nix package and the daemon service.
services . nix-daemon . enable = true ;
nix . package = pkgs . nix ;
2024-10-05 00:52:57 +02:00
system . stateVersion = 5 ;
2023-07-26 09:06:51 +02:00
}