Compare commits

..

1 Commits

Author SHA1 Message Date
Morten Olsen
f06632f973 improved system setup 2025-12-16 19:54:31 +01:00
9 changed files with 46 additions and 108 deletions

26
flake.lock generated
View File

@@ -60,31 +60,7 @@
"inputs": { "inputs": {
"home-manager": "home-manager", "home-manager": "home-manager",
"nix-darwin": "nix-darwin", "nix-darwin": "nix-darwin",
"nixpkgs": "nixpkgs", "nixpkgs": "nixpkgs"
"zen-browser": "zen-browser"
}
},
"zen-browser": {
"inputs": {
"home-manager": [
"home-manager"
],
"nixpkgs": [
"nixpkgs"
]
},
"locked": {
"lastModified": 1765895443,
"narHash": "sha256-yftYGV0skUwV5neT1BJrs7RRbXPKozQTzC7d9c7kEFs=",
"owner": "0xc000022070",
"repo": "zen-browser-flake",
"rev": "bc7dfff92cb7919dfb213ea78c11ea0a4d265a56",
"type": "github"
},
"original": {
"owner": "0xc000022070",
"repo": "zen-browser-flake",
"type": "github"
} }
} }
}, },

View File

@@ -16,16 +16,6 @@
url = "github:LnL7/nix-darwin"; url = "github:LnL7/nix-darwin";
inputs.nixpkgs.follows = "nixpkgs"; inputs.nixpkgs.follows = "nixpkgs";
}; };
zen-browser = {
url = "github:0xc000022070/zen-browser-flake";
inputs = {
# IMPORTANT: we're using "libgbm" and is only available in unstable so ensure
# to have it up-to-date or simply don't specify the nixpkgs input
nixpkgs.follows = "nixpkgs";
home-manager.follows = "home-manager";
};
};
}; };
outputs = { outputs = {

View File

@@ -7,13 +7,10 @@
pkgs, pkgs,
lib, lib,
username, username,
inputs,
... ...
}: { }: {
# Import shared modules # Import shared modules
imports = [ imports = [
inputs.zen-browser.homeModules.beta
# Shell configuration (zsh, starship, atuin, direnv, zoxide, fzf, pyenv) # Shell configuration (zsh, starship, atuin, direnv, zoxide, fzf, pyenv)
../modules/home/shell.nix ../modules/home/shell.nix

View File

@@ -73,7 +73,7 @@
zen-browser = { zen-browser = {
enable = true; enable = true;
}; }
}; };
# Personal-only packages # Personal-only packages

View File

@@ -6,6 +6,11 @@
username, username,
... ...
}: { }: {
# Import darwin modules
imports = [
../modules/darwin/homebrew.nix
];
# Nix configuration # Nix configuration
nix = { nix = {
settings = { settings = {

View File

@@ -64,41 +64,6 @@ in {
}; };
config = lib.mkIf cfg.enable { config = lib.mkIf cfg.enable {
programs.zen-browser = lib.mkIf cfg.zen-browser.enable {
enable = true;
policies = let
mkExtensionSettings = builtins.mapAttrs (_: pluginId: {
install_url = "https://addons.mozilla.org/firefox/downloads/latest/${pluginId}/latest.xpi";
installation_mode = "force_installed";
});
in {
AutofillAddressEnabled = true;
AutofillCreditCardEnabled = false;
DisableAppUpdate = true;
DisableFeedbackCommands = true;
DisableFirefoxStudies = true;
DisablePocket = true;
DisableTelemetry = true;
DontCheckDefaultBrowser = true;
NoDefaultBookmarks = true;
OfferToSaveLogins = false;
EnableTrackingProtection = {
Value = true;
Locked = true;
Cryptomining = true;
Fingerprinting = true;
};
ExtensionSettings = mkExtensionSettings {
"78272b6fa58f4a1abaac99321d503a20@proton.me" = "proton-pass";
"{d7742d87-e61d-4b78-b8a1-b469842139fa}" = "vimium-ff";
"readeck@readeck.com" = "readeck";
"@testpilot-containers" = "multi-account-containers";
"uBlock0@raymondhill.net" = "ublock-origin";
};
};
};
# Aerospace window manager configuration (macOS) # Aerospace window manager configuration (macOS)
# Placed at ~/.aerospace.toml # Placed at ~/.aerospace.toml
home.file = lib.mkMerge [ home.file = lib.mkMerge [

View File

@@ -80,26 +80,18 @@ in {
programs.git = { programs.git = {
enable = true; enable = true;
# User configuration
userName = cfg.userName;
userEmail = cfg.userEmail;
# Signing configuration with 1Password # Signing configuration with 1Password
signing = { signing = {
key = cfg.signingKey; key = cfg.signingKey;
signByDefault = true; signByDefault = true;
}; };
# Conditional includes for project-specific configurations # Extra configuration
includes = map (inc: { extraConfig = {
condition = inc.condition;
path = inc.path;
}) cfg.includes;
# All git settings using the new unified settings option
settings = {
# User configuration
user = {
name = cfg.userName;
email = cfg.userEmail;
};
# Core settings (pager is set by programs.delta) # Core settings (pager is set by programs.delta)
core = { core = {
hooksPath = "/dev/null"; hooksPath = "/dev/null";
@@ -152,9 +144,10 @@ in {
"difftool \"nvimdiff\"" = { "difftool \"nvimdiff\"" = {
cmd = "nvim -d \"$LOCAL\" \"$REMOTE\""; cmd = "nvim -d \"$LOCAL\" \"$REMOTE\"";
}; };
};
# Aliases # Aliases
alias = { aliases = {
graph = "log --graph --color --pretty=format:\"%C(yellow)%H%C(green)%d%C(reset)%n%x20%cd%n%x20%cn%C(blue)%x20(%ce)%x20%C(cyan)[gpg:%GK%x20%G?]%C(reset)%n%x20%s%n\""; graph = "log --graph --color --pretty=format:\"%C(yellow)%H%C(green)%d%C(reset)%n%x20%cd%n%x20%cn%C(blue)%x20(%ce)%x20%C(cyan)[gpg:%GK%x20%G?]%C(reset)%n%x20%s%n\"";
ll = "log --oneline"; ll = "log --oneline";
st = "status -sb"; st = "status -sb";
@@ -168,7 +161,12 @@ in {
undo = "reset HEAD~1 --mixed"; undo = "reset HEAD~1 --mixed";
unstage = "reset HEAD --"; unstage = "reset HEAD --";
}; };
};
# Conditional includes for project-specific configurations
includes = map (inc: {
condition = inc.condition;
path = inc.path;
}) cfg.includes;
}; };
}; };
} }

View File

@@ -30,7 +30,6 @@
duf # A better df alternative duf # A better df alternative
hyperfine # A command-line benchmarking tool. hyperfine # A command-line benchmarking tool.
choose # A human-friendly and fast alternative to cut and (sometimes) awk choose # A human-friendly and fast alternative to cut and (sometimes) awk
coreutils
yazi # File manager yazi # File manager
# ======================================================================== # ========================================================================
@@ -89,7 +88,6 @@
k9s # Kubernetes TUI k9s # Kubernetes TUI
istioctl # Istio service mesh CLI istioctl # Istio service mesh CLI
fluxcd # GitOps toolkit fluxcd # GitOps toolkit
popeye #
# ======================================================================== # ========================================================================
# Infrastructure and Cloud Tools # Infrastructure and Cloud Tools

View File

@@ -69,6 +69,9 @@
"--color=fg:#cdd6f4,header:#f38ba8,info:#cba6f7,pointer:#f5e0dc" "--color=fg:#cdd6f4,header:#f38ba8,info:#cba6f7,pointer:#f5e0dc"
"--color=marker:#f5e0dc,fg+:#cdd6f4,prompt:#cba6f7,hl+:#f38ba8" "--color=marker:#f5e0dc,fg+:#cdd6f4,prompt:#cba6f7,hl+:#f38ba8"
]; ];
# NVM directory
NVM_DIR = "$HOME/.nvm";
}; };
# Shell aliases (migrated from 01-env.sh and 01-nvim.sh) # Shell aliases (migrated from 01-env.sh and 01-nvim.sh)
@@ -234,6 +237,12 @@
enableZshIntegration = true; enableZshIntegration = true;
}; };
# ==========================================================================
# NVM - Node Version Manager
# ==========================================================================
# NVM is installed via Homebrew and sourced in the shell
# This allows managing multiple Node.js versions per project
# ========================================================================== # ==========================================================================
# Pyenv - Python version management # Pyenv - Python version management
# ========================================================================== # ==========================================================================