Compare commits
3 Commits
f06632f973
...
improvemen
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
20548f94cd | ||
|
|
8cd490ad3b | ||
|
|
4ca7376a20 |
26
flake.lock
generated
26
flake.lock
generated
@@ -60,7 +60,31 @@
|
|||||||
"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"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|||||||
10
flake.nix
10
flake.nix
@@ -16,6 +16,16 @@
|
|||||||
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 = {
|
||||||
|
|||||||
@@ -7,10 +7,13 @@
|
|||||||
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
|
||||||
|
|
||||||
|
|||||||
@@ -73,7 +73,7 @@
|
|||||||
|
|
||||||
zen-browser = {
|
zen-browser = {
|
||||||
enable = true;
|
enable = true;
|
||||||
}
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
# Personal-only packages
|
# Personal-only packages
|
||||||
|
|||||||
@@ -6,11 +6,6 @@
|
|||||||
username,
|
username,
|
||||||
...
|
...
|
||||||
}: {
|
}: {
|
||||||
# Import darwin modules
|
|
||||||
imports = [
|
|
||||||
../modules/darwin/homebrew.nix
|
|
||||||
];
|
|
||||||
|
|
||||||
# Nix configuration
|
# Nix configuration
|
||||||
nix = {
|
nix = {
|
||||||
settings = {
|
settings = {
|
||||||
|
|||||||
@@ -64,6 +64,41 @@ 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 [
|
||||||
|
|||||||
@@ -80,18 +80,26 @@ 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;
|
||||||
};
|
};
|
||||||
|
|
||||||
# Extra configuration
|
# Conditional includes for project-specific configurations
|
||||||
extraConfig = {
|
includes = map (inc: {
|
||||||
|
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";
|
||||||
@@ -144,29 +152,23 @@ in {
|
|||||||
"difftool \"nvimdiff\"" = {
|
"difftool \"nvimdiff\"" = {
|
||||||
cmd = "nvim -d \"$LOCAL\" \"$REMOTE\"";
|
cmd = "nvim -d \"$LOCAL\" \"$REMOTE\"";
|
||||||
};
|
};
|
||||||
};
|
|
||||||
|
|
||||||
# Aliases
|
# Aliases
|
||||||
aliases = {
|
alias = {
|
||||||
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";
|
||||||
cm = "commit -m";
|
cm = "commit -m";
|
||||||
append = "commit --amend --no-edit";
|
append = "commit --amend --no-edit";
|
||||||
sobmodules = "submodule update --init --recursive";
|
sobmodules = "submodule update --init --recursive";
|
||||||
df = "difftool -t nvimdiff -y";
|
df = "difftool -t nvimdiff -y";
|
||||||
last = "log -1 --stat";
|
last = "log -1 --stat";
|
||||||
br = "branch --format='%(HEAD) %(color:yellow)%(refname:short)%(color:reset) - %(contents:subject) %(color:green)(%(committerdate:relative)) [%(authorname)]' --sort=-committerdate";
|
br = "branch --format='%(HEAD) %(color:yellow)%(refname:short)%(color:reset) - %(contents:subject) %(color:green)(%(committerdate:relative)) [%(authorname)]' --sort=-committerdate";
|
||||||
brr = "branch --remote --format='%(HEAD) %(color:yellow)%(refname:short)%(color:reset) - %(contents:subject) %(color:green)(%(committerdate:relative)) [%(authorname)]' --sort=-committerdate";
|
brr = "branch --remote --format='%(HEAD) %(color:yellow)%(refname:short)%(color:reset) - %(contents:subject) %(color:green)(%(committerdate:relative)) [%(authorname)]' --sort=-committerdate";
|
||||||
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;
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
@@ -30,6 +30,7 @@
|
|||||||
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
|
||||||
|
|
||||||
# ========================================================================
|
# ========================================================================
|
||||||
@@ -88,6 +89,8 @@
|
|||||||
k9s # Kubernetes TUI
|
k9s # Kubernetes TUI
|
||||||
istioctl # Istio service mesh CLI
|
istioctl # Istio service mesh CLI
|
||||||
fluxcd # GitOps toolkit
|
fluxcd # GitOps toolkit
|
||||||
|
popeye #
|
||||||
|
argocd
|
||||||
|
|
||||||
# ========================================================================
|
# ========================================================================
|
||||||
# Infrastructure and Cloud Tools
|
# Infrastructure and Cloud Tools
|
||||||
|
|||||||
@@ -69,9 +69,6 @@
|
|||||||
"--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)
|
||||||
@@ -237,12 +234,6 @@
|
|||||||
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
|
||||||
# ==========================================================================
|
# ==========================================================================
|
||||||
|
|||||||
Reference in New Issue
Block a user