Compare commits
34 Commits
caae54f948
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
|
228e26c760
|
|||
|
5ec65a4cb3
|
|||
|
186d3e8215
|
|||
|
d96734a5d5
|
|||
|
8cdc437607
|
|||
|
dfd71d36f9
|
|||
|
96f57cadc7
|
|||
|
e4a7b92aa8
|
|||
|
661d5c6a96
|
|||
|
69c5cc9060
|
|||
|
4f3d072474
|
|||
|
32616dbb8d
|
|||
|
062dd6fc45
|
|||
|
27d15ba706
|
|||
|
dfd6f9a8c1
|
|||
|
0acff538a3
|
|||
|
d93b8d58c8
|
|||
|
7885e7090c
|
|||
|
0191b8e1e5
|
|||
|
13eabb2a4e
|
|||
|
5ee18a2d47
|
|||
|
a558c558f0
|
|||
|
ba6d171055
|
|||
|
7b87de4700
|
|||
|
7faa4d57b3
|
|||
|
2edea89fd8
|
|||
|
02fe38c5f1
|
|||
|
68f6a120d4
|
|||
|
715bc0b493
|
|||
|
144da5d7d7
|
|||
|
b65e4cbdae
|
|||
|
1a03da12c3
|
|||
|
77e4eb75fa
|
|||
|
3a19bb1dda
|
10
Makefile
Normal file
10
Makefile
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
.PHONY: build update lock
|
||||||
|
|
||||||
|
build:
|
||||||
|
sudo darwin-rebuild switch --flake .#dart
|
||||||
|
|
||||||
|
update:
|
||||||
|
nix flake update
|
||||||
|
|
||||||
|
lock:
|
||||||
|
nix flake lock
|
||||||
6
README.md
Normal file
6
README.md
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
# Lavitz - My NixOS desktop configuration named after Dart from the PS1 classic The Legend of Dragoon
|
||||||
|
|
||||||
|
- Nix Version: 25.11
|
||||||
|
- OS: MacOS
|
||||||
|
- Browser: Librewolf
|
||||||
|
- Terminal: Ghostty
|
||||||
24
flake.lock
generated
24
flake.lock
generated
@@ -7,11 +7,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1771269455,
|
"lastModified": 1772633327,
|
||||||
"narHash": "sha256-BZ31eN5F99YH6vkc4AhzKGE+tJgJ52kl8f01K7wCs8w=",
|
"narHash": "sha256-jl+DJB2DUx7EbWLRng+6HNWW/1/VQOnf0NsQB4PlA7I=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "home-manager",
|
"repo": "home-manager",
|
||||||
"rev": "5f1d42a97b19803041434f66681d5c44c9ae62e3",
|
"rev": "5a75730e6f21ee624cbf86f4915c6e7489c74acc",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -27,11 +27,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1770922915,
|
"lastModified": 1772379624,
|
||||||
"narHash": "sha256-6J/JoK9iL7sHvKJcGW2KId2agaKv1OGypsa7kN+ZBD4=",
|
"narHash": "sha256-NG9LLTWlz4YiaTAiRGChbrzbVxBfX+Auq4Ab/SWmk4A=",
|
||||||
"owner": "LnL7",
|
"owner": "LnL7",
|
||||||
"repo": "nix-darwin",
|
"repo": "nix-darwin",
|
||||||
"rev": "6c5a56295d2a24e43bcd8af838def1b9a95746b2",
|
"rev": "52d061516108769656a8bd9c6e811c677ec5b462",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -42,11 +42,11 @@
|
|||||||
},
|
},
|
||||||
"nixpkgs": {
|
"nixpkgs": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1771177547,
|
"lastModified": 1772674223,
|
||||||
"narHash": "sha256-trTtk3WTOHz7hSw89xIIvahkgoFJYQ0G43IlqprFoMA=",
|
"narHash": "sha256-/suKbHSaSmuC9UY7G0VRQ3aO+QKqxAQPQ19wG7QNkF8=",
|
||||||
"owner": "NixOS",
|
"owner": "NixOS",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"rev": "ac055f38c798b0d87695240c7b761b82fc7e5bc2",
|
"rev": "66d9241e3dc2296726dc522e62dbfe89c7b449f3",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -71,11 +71,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1771211437,
|
"lastModified": 1772679930,
|
||||||
"narHash": "sha256-lcNK438i4DGtyA+bPXXyVLHVmJjYpVKmpux9WASa3ro=",
|
"narHash": "sha256-FxYmdacqrdDVeE9QqZKTIpNLjv2B8GSKssgwlZuTR98=",
|
||||||
"owner": "oxalica",
|
"owner": "oxalica",
|
||||||
"repo": "rust-overlay",
|
"repo": "rust-overlay",
|
||||||
"rev": "c62195b3d6e1bb11e0c2fb2a494117d3b55d410f",
|
"rev": "9b741db17141331fdb26270a1b66b81be8be9edd",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
|||||||
@@ -40,9 +40,9 @@
|
|||||||
./modules/packages/cli.nix
|
./modules/packages/cli.nix
|
||||||
./modules/packages/languages.nix
|
./modules/packages/languages.nix
|
||||||
./modules/packages/media.nix
|
./modules/packages/media.nix
|
||||||
./modules/packages/security.nix
|
|
||||||
./modules/packages/networking.nix
|
./modules/packages/networking.nix
|
||||||
./modules/homebrew.nix
|
./modules/homebrew.nix
|
||||||
|
./modules/librewolf.nix
|
||||||
./modules/home/default.nix
|
./modules/home/default.nix
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -4,10 +4,14 @@
|
|||||||
home-manager = {
|
home-manager = {
|
||||||
useGlobalPkgs = true;
|
useGlobalPkgs = true;
|
||||||
useUserPackages = true;
|
useUserPackages = true;
|
||||||
|
backupFileExtension = "bak";
|
||||||
|
|
||||||
users.atridad = { pkgs, lib, ... }: {
|
users.atridad = { pkgs, lib, ... }: {
|
||||||
imports = [
|
imports = [
|
||||||
./zed.nix
|
./zed.nix
|
||||||
|
./ssh.nix
|
||||||
|
./git.nix
|
||||||
|
./ghostty.nix
|
||||||
];
|
];
|
||||||
|
|
||||||
home = {
|
home = {
|
||||||
|
|||||||
20
modules/home/ghostty.nix
Normal file
20
modules/home/ghostty.nix
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
{ pkgs, lib, ... }:
|
||||||
|
|
||||||
|
let
|
||||||
|
ghosttyStub = (pkgs.runCommand "ghostty-stub" { } "mkdir -p $out/bin")
|
||||||
|
// { meta.mainProgram = "ghostty"; };
|
||||||
|
in
|
||||||
|
{
|
||||||
|
programs.ghostty = {
|
||||||
|
enable = true;
|
||||||
|
package = lib.mkForce ghosttyStub;
|
||||||
|
|
||||||
|
enableZshIntegration = false;
|
||||||
|
enableBashIntegration = false;
|
||||||
|
|
||||||
|
settings = {
|
||||||
|
theme = "Catppuccin Macchiato";
|
||||||
|
background-opacity = "0.95";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
20
modules/home/git.nix
Normal file
20
modules/home/git.nix
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
{ ... }:
|
||||||
|
|
||||||
|
{
|
||||||
|
programs.git = {
|
||||||
|
enable = true;
|
||||||
|
|
||||||
|
signing = {
|
||||||
|
key = "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAILKb+pDgkHEKI7LDWvZbhoLJ11uJMaCmVyAqotDxNOI7 me@atri.dad";
|
||||||
|
signByDefault = true;
|
||||||
|
format = "ssh";
|
||||||
|
};
|
||||||
|
|
||||||
|
settings = {
|
||||||
|
user = {
|
||||||
|
name = "Atridad Lahiji";
|
||||||
|
email = "me@atri.dad";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
31
modules/home/ssh.nix
Normal file
31
modules/home/ssh.nix
Normal file
@@ -0,0 +1,31 @@
|
|||||||
|
{ ... }:
|
||||||
|
|
||||||
|
{
|
||||||
|
programs.ssh = {
|
||||||
|
enable = true;
|
||||||
|
enableDefaultConfig = false;
|
||||||
|
|
||||||
|
matchBlocks = {
|
||||||
|
"*" = {
|
||||||
|
extraOptions = {
|
||||||
|
IdentityAgent = "/Users/atridad/.bitwarden-ssh-agent.sock";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
"localhost" = {
|
||||||
|
userKnownHostsFile = "/dev/null";
|
||||||
|
};
|
||||||
|
"tux" = {
|
||||||
|
hostname = "tuxworld.usask.ca";
|
||||||
|
user = "atl175";
|
||||||
|
};
|
||||||
|
"haschel" = {
|
||||||
|
hostname = "haschel";
|
||||||
|
user = "root";
|
||||||
|
};
|
||||||
|
"lloyd" = {
|
||||||
|
hostname = "lloyd";
|
||||||
|
user = "truenas_admin";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -7,7 +7,7 @@
|
|||||||
|
|
||||||
extensions = [
|
extensions = [
|
||||||
"nix"
|
"nix"
|
||||||
"catppuccin"
|
"dracula"
|
||||||
"catppuccin-icons"
|
"catppuccin-icons"
|
||||||
"toml"
|
"toml"
|
||||||
"elixir"
|
"elixir"
|
||||||
@@ -16,9 +16,12 @@
|
|||||||
"vue"
|
"vue"
|
||||||
"latex"
|
"latex"
|
||||||
"mermaid"
|
"mermaid"
|
||||||
|
"docker"
|
||||||
|
"docker-compose"
|
||||||
];
|
];
|
||||||
|
|
||||||
userSettings = {
|
userSettings = {
|
||||||
|
auto_update = false;
|
||||||
icon_theme = "Catppuccin Macchiato";
|
icon_theme = "Catppuccin Macchiato";
|
||||||
title_bar = {
|
title_bar = {
|
||||||
show_sign_in = false;
|
show_sign_in = false;
|
||||||
@@ -39,11 +42,14 @@
|
|||||||
theme = {
|
theme = {
|
||||||
mode = "system";
|
mode = "system";
|
||||||
light = "One Light";
|
light = "One Light";
|
||||||
dark = "Catppuccin Macchiato";
|
dark = "Dracula";
|
||||||
};
|
};
|
||||||
languages = {
|
languages = {
|
||||||
"Nix" = {
|
"Nix" = {
|
||||||
language_servers = [ "nil" "nixd" ];
|
language_servers = [
|
||||||
|
"nil"
|
||||||
|
"nixd"
|
||||||
|
];
|
||||||
format_on_save = "on";
|
format_on_save = "on";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -6,9 +6,14 @@
|
|||||||
|
|
||||||
onActivation = {
|
onActivation = {
|
||||||
autoUpdate = true;
|
autoUpdate = true;
|
||||||
|
upgrade = true;
|
||||||
cleanup = "zap";
|
cleanup = "zap";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
taps = [
|
||||||
|
"supersonic-app/supersonic"
|
||||||
|
];
|
||||||
|
|
||||||
brews = [
|
brews = [
|
||||||
"gamdl"
|
"gamdl"
|
||||||
"knock"
|
"knock"
|
||||||
@@ -19,11 +24,12 @@
|
|||||||
"android-platform-tools"
|
"android-platform-tools"
|
||||||
"flutter"
|
"flutter"
|
||||||
"ghostty"
|
"ghostty"
|
||||||
"zed"
|
|
||||||
"librewolf"
|
"librewolf"
|
||||||
"ngrok"
|
"ngrok"
|
||||||
"pearcleaner"
|
"pearcleaner"
|
||||||
"zulu@17"
|
"zed"
|
||||||
|
"supersonic"
|
||||||
|
"calibre"
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
113
modules/librewolf.nix
Normal file
113
modules/librewolf.nix
Normal file
@@ -0,0 +1,113 @@
|
|||||||
|
{ pkgs, ... }:
|
||||||
|
|
||||||
|
let
|
||||||
|
policies = {
|
||||||
|
policies = {
|
||||||
|
DisableTelemetry = true;
|
||||||
|
DisableFirefoxStudies = true;
|
||||||
|
DisablePocket = true;
|
||||||
|
DisableFirefoxAccounts = true;
|
||||||
|
OfferToSaveLogins = false;
|
||||||
|
EnableTrackingProtection = true;
|
||||||
|
|
||||||
|
FirefoxHome = {
|
||||||
|
Search = true;
|
||||||
|
TopSites = true;
|
||||||
|
SponsoredTopSites = false;
|
||||||
|
Highlights = false;
|
||||||
|
Pocket = false;
|
||||||
|
SponsoredPocket = false;
|
||||||
|
};
|
||||||
|
|
||||||
|
SanitizeOnShutdown = {
|
||||||
|
Cache = true;
|
||||||
|
Cookies = false;
|
||||||
|
History = false;
|
||||||
|
Sessions = true;
|
||||||
|
SiteSettings = false;
|
||||||
|
OfflineApps = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
SearchEngines = {
|
||||||
|
Default = "Searx Search";
|
||||||
|
Remove = [
|
||||||
|
"Google"
|
||||||
|
"Bing"
|
||||||
|
"Perplexity"
|
||||||
|
"Wikipedia (en)"
|
||||||
|
];
|
||||||
|
Add = [
|
||||||
|
{
|
||||||
|
Name = "Searx Search";
|
||||||
|
URLTemplate = "https://search.atri.dad/search?q={searchTerms}";
|
||||||
|
Method = "GET";
|
||||||
|
IconURL = "https://search.atri.dad/favicon.ico";
|
||||||
|
Alias = "searx";
|
||||||
|
Description = "Searx (search.atri.dad)";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
Name = "DuckDuckGo";
|
||||||
|
URLTemplate = "https://duckduckgo.com/?q={searchTerms}";
|
||||||
|
SuggestURLTemplate = "https://duckduckgo.com/ac/?q={searchTerms}&type=list";
|
||||||
|
Method = "GET";
|
||||||
|
IconURL = "https://duckduckgo.com/favicon.ico";
|
||||||
|
Alias = "ddg";
|
||||||
|
Description = "DuckDuckGo";
|
||||||
|
}
|
||||||
|
];
|
||||||
|
};
|
||||||
|
|
||||||
|
ExtensionSettings = {
|
||||||
|
"{446900e4-71c2-419f-a6a7-df9c091e268b}" = {
|
||||||
|
install_url = "https://addons.mozilla.org/firefox/downloads/latest/bitwarden-password-manager/latest.xpi";
|
||||||
|
installation_mode = "force_installed";
|
||||||
|
};
|
||||||
|
"floccus@handmadeideas.org" = {
|
||||||
|
install_url = "https://addons.mozilla.org/firefox/downloads/latest/floccus/latest.xpi";
|
||||||
|
installation_mode = "force_installed";
|
||||||
|
};
|
||||||
|
"uBlock0@raymondhill.net" = {
|
||||||
|
install_url = "https://addons.mozilla.org/firefox/downloads/latest/ublock-origin/latest.xpi";
|
||||||
|
installation_mode = "force_installed";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
Preferences = {
|
||||||
|
"browser.startup.homepage" = "about:home";
|
||||||
|
"extensions.autoDisableScopes" = 0;
|
||||||
|
"browser.toolbars.bookmarks.visibility" = "always";
|
||||||
|
"network.cookie.cookieBehavior" = 1;
|
||||||
|
"extensions.activeThemeID" = "firefox-alpenglow@mozilla.org";
|
||||||
|
"privacy.resistFingerprinting" = true;
|
||||||
|
"browser.ml.chat.enabled" = false;
|
||||||
|
"browser.ml.chat.sidebar" = false;
|
||||||
|
"browser.tabs.groups.smart.userEnabled" = false;
|
||||||
|
"browser.safebrowsing.malware.enabled" = false;
|
||||||
|
"browser.safebrowsing.phishing.enabled" = false;
|
||||||
|
"browser.safebrowsing.blockedURIs.enabled" = false;
|
||||||
|
"browser.safebrowsing.downloads.enabled" = false;
|
||||||
|
"browser.safebrowsing.provider.google4.gethashURL" = "";
|
||||||
|
"browser.safebrowsing.provider.google4.updateURL" = "";
|
||||||
|
"browser.safebrowsing.provider.google.gethashURL" = "";
|
||||||
|
"browser.safebrowsing.provider.google.updateURL" = "";
|
||||||
|
"browser.newtabpage.activity-stream.newtabWallpapers.wallpaper" = "dark-mountain";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
policiesFile = pkgs.writeText "librewolf-policies.json" (builtins.toJSON policies);
|
||||||
|
in
|
||||||
|
{
|
||||||
|
system.activationScripts.postActivation.text = ''
|
||||||
|
for APP_DIR in "/Applications/LibreWolf.app" "$HOME/Applications/LibreWolf.app"; do
|
||||||
|
if [ -d "$APP_DIR" ]; then
|
||||||
|
DIST_DIR="$APP_DIR/Contents/Resources/distribution"
|
||||||
|
mkdir -p "$DIST_DIR"
|
||||||
|
cp -f ${policiesFile} "$DIST_DIR/policies.json"
|
||||||
|
chmod 644 "$DIST_DIR/policies.json"
|
||||||
|
echo "Applied LibreWolf policies to $APP_DIR"
|
||||||
|
xattr -dr com.apple.quarantine /Applications/LibreWolf.app
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
'';
|
||||||
|
}
|
||||||
@@ -4,23 +4,13 @@
|
|||||||
environment.systemPackages = with pkgs; [
|
environment.systemPackages = with pkgs; [
|
||||||
helix
|
helix
|
||||||
micro
|
micro
|
||||||
lazygit
|
|
||||||
ripgrep
|
|
||||||
fnm
|
fnm
|
||||||
cmake
|
cmake
|
||||||
ninja
|
|
||||||
gradle
|
gradle
|
||||||
netcat-gnu
|
netcat-gnu
|
||||||
bitwarden-cli
|
bitwarden-cli
|
||||||
pwgen
|
|
||||||
qrencode
|
qrencode
|
||||||
sl
|
sl
|
||||||
upx
|
upx
|
||||||
wakeonlan
|
|
||||||
magic-wormhole
|
|
||||||
httpie
|
|
||||||
gh
|
|
||||||
doctl
|
|
||||||
qemu
|
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,7 +2,10 @@
|
|||||||
|
|
||||||
let
|
let
|
||||||
rustToolchain = pkgs.rust-bin.stable.latest.default.override {
|
rustToolchain = pkgs.rust-bin.stable.latest.default.override {
|
||||||
extensions = [ "rust-src" "rust-analyzer" ];
|
extensions = [
|
||||||
|
"rust-src"
|
||||||
|
"rust-analyzer"
|
||||||
|
];
|
||||||
targets = [ "aarch64-apple-darwin" ];
|
targets = [ "aarch64-apple-darwin" ];
|
||||||
};
|
};
|
||||||
in
|
in
|
||||||
@@ -12,10 +15,9 @@ in
|
|||||||
python313
|
python313
|
||||||
openjdk
|
openjdk
|
||||||
openjdk17
|
openjdk17
|
||||||
lua
|
|
||||||
luajit
|
|
||||||
perl
|
|
||||||
ruby
|
ruby
|
||||||
go
|
go
|
||||||
|
nil
|
||||||
|
nixd
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,7 +3,6 @@
|
|||||||
{
|
{
|
||||||
environment.systemPackages = with pkgs; [
|
environment.systemPackages = with pkgs; [
|
||||||
ffmpeg
|
ffmpeg
|
||||||
tesseract
|
|
||||||
tectonic
|
tectonic
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,7 +2,9 @@
|
|||||||
|
|
||||||
{
|
{
|
||||||
environment.systemPackages = with pkgs; [
|
environment.systemPackages = with pkgs; [
|
||||||
freerdp
|
nmap
|
||||||
openmpi
|
nikto
|
||||||
|
john
|
||||||
|
rustscan
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,10 +0,0 @@
|
|||||||
{ pkgs, ... }:
|
|
||||||
|
|
||||||
{
|
|
||||||
environment.systemPackages = with pkgs; [
|
|
||||||
nmap
|
|
||||||
nikto
|
|
||||||
john
|
|
||||||
rustscan
|
|
||||||
];
|
|
||||||
}
|
|
||||||
Reference in New Issue
Block a user