336 lines
11 KiB
Nix
336 lines
11 KiB
Nix
# docs:
|
|
# https://rycee.gitlab.io/home-manager/
|
|
# https://rycee.gitlab.io/home-manager/options.html
|
|
# man home-configuration.nix
|
|
#
|
|
|
|
{ home-manager, lib, config, pkgs, ... }:
|
|
|
|
with lib;
|
|
let
|
|
cfg = config.colinsane.home-manager;
|
|
in
|
|
{
|
|
imports = [
|
|
home-manager.nixosModule
|
|
];
|
|
|
|
options = {
|
|
colinsane.home-manager.enable = mkOption {
|
|
default = false;
|
|
type = types.bool;
|
|
};
|
|
colinsane.home-manager.extraPackages = mkOption {
|
|
default = [ ];
|
|
type = types.listOf types.package;
|
|
};
|
|
colinsane.home-manager.windowManager = mkOption {
|
|
default = {};
|
|
type = types.attrs;
|
|
};
|
|
colinsane.home-manager.programs = mkOption {
|
|
default = {};
|
|
type = types.attrs;
|
|
};
|
|
};
|
|
|
|
config = lib.mkIf cfg.enable {
|
|
sops.secrets."aerc_accounts" = {
|
|
owner = config.users.users.colin.name;
|
|
sopsFile = ../../../secrets/universal/aerc_accounts.conf;
|
|
format = "binary";
|
|
};
|
|
|
|
home-manager.useGlobalPkgs = true;
|
|
home-manager.useUserPackages = true;
|
|
|
|
# XXX this weird rename + closure is to get home-manager's `config.lib.file` to exist.
|
|
# see: https://github.com/nix-community/home-manager/issues/589#issuecomment-950474105
|
|
home-manager.users.colin = let sysconfig = config; in { config, ... }: {
|
|
home.stateVersion = "21.11";
|
|
home.username = "colin";
|
|
home.homeDirectory = "/home/colin";
|
|
|
|
# XDG defines things like ~/Desktop, ~/Downloads, etc.
|
|
# these clutter the home, so i mostly don't use them.
|
|
xdg.userDirs = {
|
|
enable = true;
|
|
createDirectories = false; # on headless systems, most xdg dirs are noise
|
|
desktop = "$HOME/.xdg/Desktop";
|
|
documents = "$HOME/dev";
|
|
download = "$HOME/tmp";
|
|
music = "$HOME/Music";
|
|
pictures = "$HOME/Pictures";
|
|
publicShare = "$HOME/.xdg/Public";
|
|
templates = "$HOME/.xdg/Templates";
|
|
videos = "$HOME/Videos";
|
|
};
|
|
xdg.mimeApps.enable = true;
|
|
xdg.mimeApps.defaultApplications = {
|
|
"text/html" = [ "librewolf.desktop" ];
|
|
"x-scheme-handler/http" = [ "librewolf.desktop" ];
|
|
"x-scheme-handler/https" = [ "librewolf.desktop" ];
|
|
"x-scheme-handler/about" = [ "librewolf.desktop" ];
|
|
"x-scheme-handler/unknown" = [ "librewolf.desktop" ];
|
|
};
|
|
|
|
# convenience
|
|
home.file."knowledge".source = config.lib.file.mkOutOfStoreSymlink "/home/colin/dev/knowledge";
|
|
home.file."nixos".source = config.lib.file.mkOutOfStoreSymlink "/home/colin/dev/nixos";
|
|
|
|
xdg.configFile."aerc/accounts.conf".source =
|
|
config.lib.file.mkOutOfStoreSymlink sysconfig.sops.secrets.aerc_accounts.path;
|
|
|
|
programs = {
|
|
home-manager.enable = true; # this lets home-manager manage dot-files in user dirs, i think
|
|
|
|
zsh = {
|
|
enable = true;
|
|
enableSyntaxHighlighting = true;
|
|
enableVteIntegration = true;
|
|
dotDir = ".config/zsh";
|
|
|
|
initExtraBeforeCompInit = ''
|
|
# p10k instant prompt
|
|
# run p10k configure to configure, but it can't write out its file :-(
|
|
POWERLEVEL9K_DISABLE_CONFIGURATION_WIZARD=true
|
|
'';
|
|
|
|
# prezto = oh-my-zsh fork; controls prompt, auto-completion, etc.
|
|
# see: https://github.com/sorin-ionescu/prezto
|
|
prezto = {
|
|
enable = true;
|
|
pmodules = [
|
|
"environment"
|
|
"terminal"
|
|
"editor"
|
|
"history"
|
|
"directory"
|
|
"spectrum"
|
|
"utility"
|
|
"completion"
|
|
"prompt"
|
|
"git"
|
|
];
|
|
prompt = {
|
|
theme = "powerlevel10k";
|
|
};
|
|
};
|
|
};
|
|
kitty = {
|
|
enable = true;
|
|
settings.enable_audio_bell = false;
|
|
};
|
|
git = {
|
|
enable = true;
|
|
userName = "colin";
|
|
userEmail = "colin@uninsane.org";
|
|
};
|
|
|
|
vim = {
|
|
enable = true;
|
|
extraConfig = ''
|
|
" wtf vim project: NOBODY LIKES MOUSE FOR VISUAL MODE
|
|
set mouse-=a
|
|
" copy/paste to system clipboard
|
|
set clipboard=unnamedplus
|
|
" <tab> completion menu settings
|
|
set wildmenu
|
|
set wildmode=longest,list,full
|
|
" highlight all matching searches (using / and ?)
|
|
set hlsearch
|
|
" allow backspace to delete empty lines in insert mode
|
|
set backspace=indent,eol,start
|
|
" built-in syntax highlighting
|
|
syntax enable
|
|
" show line/col number in bottom right
|
|
set ruler
|
|
" highlight trailing space & related syntax errors (does this work?)
|
|
let c_space_errors=1
|
|
let python_space_errors=1
|
|
'';
|
|
};
|
|
|
|
firefox = lib.mkIf (sysconfig.colinsane.gui.enable) {
|
|
# common settings to toggle (at runtime, in about:config):
|
|
# > security.ssl.require_safe_negotiation
|
|
enable = true;
|
|
# librewolf is a forked firefox which patches firefox to allow more things
|
|
# (like default search engines) to be configurable at runtime.
|
|
# many of the settings below won't have effect without those patches.
|
|
# see: https://gitlab.com/librewolf-community/settings/-/blob/master/distribution/policies.json
|
|
package = pkgs.wrapFirefox pkgs.librewolf-unwrapped {
|
|
# inherit the default librewolf.cfg
|
|
# it can be further customized via ~/.librewolf/librewolf.overrides.cfg
|
|
inherit (pkgs.librewolf-unwrapped) extraPrefsFiles;
|
|
libName = "librewolf";
|
|
extraPolicies = {
|
|
NoDefaultBookmarks = true;
|
|
SearchEngines = {
|
|
Default = "DuckDuckGo";
|
|
};
|
|
AppUpdateURL = "https://localhost";
|
|
DisableAppUpdate = true;
|
|
OverrideFirstRunPage = "";
|
|
OverridePostUpdatePage = "";
|
|
DisableSystemAddonUpdate = true;
|
|
DisableFirefoxStudies = true;
|
|
DisableTelemetry = true;
|
|
DisableFeedbackCommands = true;
|
|
DisablePocket = true;
|
|
DisableSetDesktopBackground = false;
|
|
Extensions = {
|
|
Install = [
|
|
"https://addons.mozilla.org/firefox/downloads/latest/ublock-origin/latest.xpi"
|
|
"https://addons.mozilla.org/firefox/downloads/latest/i-dont-care-about-cookies/latest.xpi"
|
|
"https://addons.mozilla.org/firefox/downloads/latest/sponsorblock/latest.xpi"
|
|
"https://addons.mozilla.org/firefox/downloads/latest/bypass-paywalls-clean/latest.xpi"
|
|
"https://addons.mozilla.org/firefox/downloads/latest/sidebery/latest.xpi"
|
|
"https://addons.mozilla.org/firefox/downloads/latest/ether-metamask/latest.xpi"
|
|
];
|
|
# remove many default search providers
|
|
Uninstall = [
|
|
"google@search.mozilla.org"
|
|
"bing@search.mozilla.org"
|
|
"amazondotcom@search.mozilla.org"
|
|
"ebay@search.mozilla.org"
|
|
"twitter@search.mozilla.org"
|
|
];
|
|
};
|
|
# XXX doesn't seem to have any effect...
|
|
# docs: https://github.com/mozilla/policy-templates#homepage
|
|
# Homepage = {
|
|
# HomepageURL = "https://uninsane.org/";
|
|
# StartPage = "homepage";
|
|
# };
|
|
# NewTabPage = true;
|
|
# docs: https://chromeenterprise.google/policies/?policy=ManagedBookmarks
|
|
# docs: https://github.com/mozilla/policy-templates#managedbookmarks
|
|
ManagedBookmarks = [
|
|
{
|
|
toplevel_name = "bookmarks";
|
|
}
|
|
{
|
|
name = "Pleroma";
|
|
url = "https://fed.uninsane.org/";
|
|
}
|
|
{
|
|
name = "Home Manager Config";
|
|
url = "https://nix-community.github.io/home-manager/options.html";
|
|
}
|
|
{
|
|
name = "Delightful Apps";
|
|
url = "https://delightful.club/";
|
|
}
|
|
{
|
|
name = "Linux Phone Apps";
|
|
url = "https://linuxphoneapps.org/mobile-compatibility/5/";
|
|
}
|
|
{
|
|
name = "Crowdsupply";
|
|
url = "https://www.crowdsupply.com/";
|
|
}
|
|
{
|
|
name = "Mempool";
|
|
url = "https://jochen-hoenicke.de/queue";
|
|
}
|
|
];
|
|
};
|
|
};
|
|
};
|
|
|
|
# "command not found" will cause the command to be searched in nixpkgs
|
|
nix-index.enable = true;
|
|
} // cfg.programs;
|
|
|
|
home.shellAliases = {
|
|
":q" = "exit";
|
|
# common typos
|
|
"cd.." = "cd ..";
|
|
"cd../" = "cd ../";
|
|
};
|
|
|
|
wayland.windowManager = cfg.windowManager;
|
|
|
|
# devtools:
|
|
# bison
|
|
# dtc
|
|
# flex
|
|
# gcc-arm-embedded
|
|
# gcc_multi
|
|
# swig
|
|
|
|
home.packages = with pkgs; [
|
|
backblaze-b2
|
|
duplicity
|
|
gcc
|
|
gnumake
|
|
ifuse
|
|
ipfs
|
|
libimobiledevice
|
|
lm_sensors # for sensors-detect
|
|
mix2nix
|
|
networkmanager
|
|
nixpkgs-review
|
|
# nixos-generators
|
|
# nettools
|
|
oathToolkit # for oathtool
|
|
# ponymix
|
|
pulsemixer
|
|
python3
|
|
rmlint
|
|
rustup
|
|
sane-scripts
|
|
snapper
|
|
sops
|
|
ssh-to-age
|
|
sudo
|
|
wireguard-tools
|
|
youtube-dl
|
|
zola
|
|
]
|
|
++ (if sysconfig.colinsane.gui.enable then
|
|
with pkgs;
|
|
[
|
|
# GUI only
|
|
aerc # email client
|
|
audacity
|
|
chromium
|
|
clinfo
|
|
element-desktop # broken on phosh
|
|
evince # works on phosh
|
|
font-manager
|
|
gimp # broken on phosh
|
|
gnome.dconf-editor
|
|
gnome-feeds # RSS reader (with claimed mobile support)
|
|
gnome.file-roller
|
|
gnome.gnome-maps # works on phosh
|
|
gnome.nautilus
|
|
gnome-podcasts
|
|
gnome.gnome-terminal # works on phosh
|
|
inkscape
|
|
libreoffice-fresh # XXX colin: maybe don't want this on mobile
|
|
mesa-demos
|
|
networkmanagerapplet
|
|
obsidian
|
|
playerctl
|
|
tdesktop # broken on phosh
|
|
vlc # works on phosh
|
|
whalebird # pleroma client. input is broken on phosh
|
|
xterm # broken on phosh
|
|
] else [])
|
|
++ (if sysconfig.colinsane.gui.enable && pkgs.system == "x86_64-linux" then
|
|
with pkgs;
|
|
[
|
|
# x86_64 only
|
|
discord
|
|
kaiteki # Pleroma client
|
|
gnome.zenity # for kaiteki (it will use qarma, kdialog, or zenity)
|
|
signal-desktop
|
|
spotify
|
|
] else [])
|
|
++ cfg.extraPackages;
|
|
};
|
|
};
|
|
}
|