opening ports and gnome shell extensions

This commit is contained in:
Danilo Reyes 2023-06-11 22:42:03 -06:00
parent c58d8fc88b
commit bc0c02e004
2 changed files with 699 additions and 707 deletions

View File

@ -3,55 +3,54 @@ let
open_firewall_ports = [ open_firewall_ports = [
80 # http 80 # http
443 # https 443 # https
6969 # HentaiAtHome
25152 # ssh 25152 # ssh
49494 # gerbera 49494 # gerbera
]; ];
open_firewall_port_ranges = [ open_firewall_port_ranges = [{
{ from = 1714; to = 1764; } # kdeconnect from = 1714;
to = 1764;
} # kdeconnect
]; ];
VERSION = "23.05"; VERSION = "23.05";
# "https://github.com/nix-community/home-manager/archive/master.tar.gz"; # "https://github.com/nix-community/home-manager/archive/master.tar.gz";
unstable_tarball = builtins.fetchTarball unstable_tarball =
https://github.com/nixos/nixpkgs/tarball/master; builtins.fetchTarball "https://github.com/nixos/nixpkgs/tarball/master";
unstable = import unstable_tarball { unstable = import unstable_tarball { config = config.nixpkgs.config; };
config = config.nixpkgs.config; nix-gaming = import (builtins.fetchTarball
}; "https://github.com/fufexan/nix-gaming/archive/master.tar.gz");
nix-gaming = import (builtins.fetchTarball "https://github.com/fufexan/nix-gaming/archive/master.tar.gz"); nextcloud_scrapsync = pkgs.writeScriptBin "nextcloud_scrapsync"
nextcloud_scrapsync = pkgs.writeScriptBin (builtins.readFile ./scripts/nextcloud_scrapsync.sh);
"nextcloud_scrapsync" (builtins.readFile ./scripts/nextcloud_scrapsync.sh); manage_library = pkgs.writeScriptBin "manage_library"
manage_library = pkgs.writeScriptBin (builtins.readFile ./scripts/manage_library.fish);
"manage_library" (builtins.readFile ./scripts/manage_library.fish); ffmpeg4discord = pkgs.writeScriptBin "ffmpeg4discord"
ffmpeg4discord = pkgs.writeScriptBin (builtins.readFile ./scripts/ffmpeg4discord.py);
"ffmpeg4discord" (builtins.readFile ./scripts/ffmpeg4discord.py); in { # Remember to close this bracket at the end of the document
in
{ # Remember to close this bracket at the end of the document
imports = [ imports = [
./hardware-configuration.nix ./hardware-configuration.nix
<home-manager/nixos> <home-manager/nixos>
<agenix/modules/age.nix> <agenix/modules/age.nix>
"${nix-gaming}/modules/pipewireLowLatency.nix" "${nix-gaming}/modules/pipewireLowLatency.nix"
]; ];
networking.hostName = "workstation"; networking.hostName = "workstation";
# networking.wireless.enable = true; # networking.wireless.enable = true;
networking.networkmanager.enable = true; networking.networkmanager.enable = true;
time.timeZone = "America/Mexico_City"; time.timeZone = "America/Mexico_City";
i18n = { i18n = {
defaultLocale = "en_CA.UTF-8"; defaultLocale = "en_CA.UTF-8";
extraLocaleSettings = { extraLocaleSettings = { LC_MONETARY = "es_MX.UTF-8"; };
LC_MONETARY = "es_MX.UTF-8";
}; };
}; console = {
console = {
font = "Lat2-Terminus16"; font = "Lat2-Terminus16";
keyMap = "us"; keyMap = "us";
# useXkbConfig = true; # use xkbOptions in tty. # useXkbConfig = true; # use xkbOptions in tty.
}; };
services = { services = {
xserver = { xserver = {
enable = true; enable = true;
videoDrivers = [ "nvidia" ]; videoDrivers = [ "nvidia" ];
@ -60,17 +59,16 @@ services = {
layout = "us"; layout = "us";
libinput.enable = true; # Wacom required? libinput.enable = true; # Wacom required?
}; };
}; };
environment.gnome.excludePackages = (with pkgs; [ environment.gnome.excludePackages = (with pkgs; [
gnome-photos gnome-photos
gnome-tour gnome-tour
gnome-text-editor gnome-text-editor
gnome-connections gnome-connections
# gnome-shell-extensions # gnome-shell-extensions
baobab baobab
]) ]) ++ (with pkgs.gnome; [
++ (with pkgs.gnome; [
# totem # totem
gedit gedit
gnome-music gnome-music
@ -79,19 +77,19 @@ environment.gnome.excludePackages = (with pkgs; [
yelp yelp
gnome-font-viewer gnome-font-viewer
cheese cheese
]); ]);
# Sets up QT to use adwaita themes. # Sets up QT to use adwaita themes.
qt = { qt = {
enable = true; enable = true;
platformTheme = "gnome"; platformTheme = "gnome";
style = "adwaita"; style = "adwaita";
}; };
hardware.pulseaudio.enable = false; hardware.pulseaudio.enable = false;
sound.enable = false; sound.enable = false;
security.rtkit.enable = true; security.rtkit.enable = true;
services.pipewire = { services.pipewire = {
enable = true; enable = true;
alsa.enable = true; alsa.enable = true;
alsa.support32Bit = true; alsa.support32Bit = true;
@ -101,185 +99,190 @@ services.pipewire = {
quantum = 64; quantum = 64;
rate = 48000; rate = 48000;
}; };
}; };
security.sudo = { security.sudo = {
enable = true; enable = true;
wheelNeedsPassword = false; wheelNeedsPassword = false;
}; };
# security.sudo.enable = false; # security.sudo.enable = false;
# security.doas.enable = true; # security.doas.enable = true;
# security.doas.extraRules = [{ # security.doas.extraRules = [{
# users = [ "jawz" ]; # users = [ "jawz" ];
# keepEnv = true; # keepEnv = true;
# #persist = true; # #persist = true;
# noPass = true; # noPass = true;
# }]; # }];
nixpkgs.config = { nixpkgs.config = { allowUnfree = true; };
allowUnfree = true;
};
users.users.jawz = { users.users.jawz = {
isNormalUser = true; isNormalUser = true;
extraGroups = [ "wheel" "networkmanager" "docker" "scanner" "lp" ]; extraGroups = [ "wheel" "networkmanager" "docker" "scanner" "lp" ];
initialPassword = "password"; initialPassword = "password";
shell = pkgs.fish; shell = pkgs.fish;
openssh = { openssh = {
authorizedKeys.keys = [ "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIB5GaQM4N+yGAByibOFQOBVMV/6TjOfaGIP+NunMiK76 gpodeacero\cdreyes@100CDREYES" ]; authorizedKeys.keys = [
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIB5GaQM4N+yGAByibOFQOBVMV/6TjOfaGIP+NunMiK76 gpodeacerocdreyes@100CDREYES"
];
}; };
packages = (with pkgs; [ packages = (with pkgs; [
blender # cgi animation and sculpting blender # cgi animation and sculpting
godot # game development godot # game development
gdtoolkit # gdscript language server gdtoolkit # gdscript language server
krita # art to your heart desire! krita # art to your heart desire!
drawpile # arty party with friends!! drawpile # arty party with friends!!
mypaint # not the best art program mypaint # not the best art program
mypaint-brushes # but it's got some mypaint-brushes # but it's got some
mypaint-brushes1 # nice damn brushes mypaint-brushes1 # nice damn brushes
pureref # create inspiration/reference boards pureref # create inspiration/reference boards
gimp # the coolest bestest art program to never exist gimp # the coolest bestest art program to never exist
lutris # game/emulator manager lutris # game/emulator manager
grapejuice # roblox manager grapejuice # roblox manager
minecraft # minecraft official launcher minecraft # minecraft official launcher
parsec-bin # remote gaming with friends parsec-bin # remote gaming with friends
protonup-qt # update proton-ge protonup-qt # update proton-ge
# nix-gaming.packages.${pkgs.hostPlatform.system}.wine-discord-ipc-bridge # nix-gaming.packages.${pkgs.hostPlatform.system}.wine-discord-ipc-bridge
libreoffice-fresh # office, but based libreoffice-fresh # office, but based
calibre # ugly af eBook library manager calibre # ugly af eBook library manager
foliate # gtk eBook reader foliate # gtk eBook reader
gnome-feeds # feed reader, maybe will replace with nextcloud gnome-feeds # feed reader, maybe will replace with nextcloud
wike # gtk wikipedia wow! wike # gtk wikipedia wow!
furtherance # I made this one tehee track time utility furtherance # I made this one tehee track time utility
gnome.simple-scan # scanner gnome.simple-scan # scanner
# sequeler # friendly SQL client # sequeler # friendly SQL client
blanket # background noise blanket # background noise
czkawka # duplicate finder czkawka # duplicate finder
pika-backup # backups pika-backup # backups
# tilix # used to be my favourite terminal, but it's so outdated, that each time I use it less and less… # tilix # used to be my favourite terminal, but it's so outdated, that each time I use it less and less…
gnome-obfuscate # censor private information gnome-obfuscate # censor private information
metadata-cleaner # remove any metadata and geolocation from files metadata-cleaner # remove any metadata and geolocation from files
gnome-recipes # migrate these to mealie and delete gnome-recipes # migrate these to mealie and delete
denaro # manage your finances denaro # manage your finances
# celeste # sync tool for any cloud provider # celeste # sync tool for any cloud provider
libgda # for pano shell extension libgda # for pano shell extension
celluloid # video player celluloid # video player
cozy # audiobooks player cozy # audiobooks player
gnome-podcasts # podcast player gnome-podcasts # podcast player
handbrake # video converter, may be unnecessary handbrake # video converter, may be unnecessary
curtail # image compressor curtail # image compressor
pitivi # video editor pitivi # video editor
identity # compare images or videos identity # compare images or videos
mousai # poor man shazam mousai # poor man shazam
tagger # tag music files tagger # tag music files
# bottles # wine prefix manager # bottles # wine prefix manager
obs-studio # screen recorder & streamer obs-studio # screen recorder & streamer
shortwave # listen to world radio shortwave # listen to world radio
nextcloud-client # self-hosted google-drive alternative nextcloud-client # self-hosted google-drive alternative
discord # chat discord # chat
google-chrome # web browser with spyware included google-chrome # web browser with spyware included
firefox # web browser that allows to disable spyware firefox # web browser that allows to disable spyware
# librewolf # no spyware web browser # librewolf # no spyware web browser
tor-browser-bundle-bin # dark web, so dark! tor-browser-bundle-bin # dark web, so dark!
# hugo # website engine # hugo # website engine
nicotine-plus # remember Ares? nicotine-plus # remember Ares?
warp # never used, but supposedly cool for sharing files warp # never used, but supposedly cool for sharing files
HentaiAtHome # uh-oh HentaiAtHome # uh-oh
yt-dlp # downloads videos from most video websites yt-dlp # downloads videos from most video websites
unstable.gallery-dl # similar to yt-dlp but for most image gallery websites unstable.gallery-dl # similar to yt-dlp but for most image gallery websites
gdu # disk-space utility, somewhat useful gdu # disk-space utility, somewhat useful
du-dust # rusty du du-dust # rusty du
gocryptfs # encrypted filesystem! shhh!!! gocryptfs # encrypted filesystem! shhh!!!
exa # like ls but with colors exa # like ls but with colors
trash-cli # oop! didn't meant to delete that trash-cli # oop! didn't meant to delete that
ffmpeg_6 # coolest video converter! ffmpeg_6 # coolest video converter!
neofetch # use once for brag, never again neofetch # use once for brag, never again
rmlint # probably my favourite app, amazing dupe finder that integrates well with BTRFS rmlint # probably my favourite app, amazing dupe finder that integrates well with BTRFS
tldr # man for retards tldr # man for retards
# ffmpegthumbnailer # create video thumbnails for nautilus, in absence of totem # ffmpegthumbnailer # create video thumbnails for nautilus, in absence of totem
vcsi # video thumbnails for torrents, can I replace it with ^? vcsi # video thumbnails for torrents, can I replace it with ^?
mediainfo # technical info about videos, needed by some of my scripts mediainfo # technical info about videos, needed by some of my scripts
tree-sitter # code parsing, required by Doom emacs tree-sitter # code parsing, required by Doom emacs
torrenttools # create torrent files from the terminal! torrenttools # create torrent files from the terminal!
lm_sensors # for extension, displays cpu temp lm_sensors # for extension, displays cpu temp
# My own scripts # My own scripts
nextcloud_scrapsync nextcloud_scrapsync
ffmpeg4discord ffmpeg4discord
manage_library manage_library
# required by doom emacs, but still are rather useful. # required by doom emacs, but still are rather useful.
fd # modern find, faster searches fd # modern find, faster searches
fzf # fuzzy finder! super cool and useful fzf # fuzzy finder! super cool and useful
ripgrep # modern grep ripgrep # modern grep
languagetool # proofreader for English. check if works without the service languagetool # proofreader for English. check if works without the service
graphviz # graphs graphviz # graphs
# these two are for doom everywhere # these two are for doom everywhere
xorg.xwininfo xorg.xwininfo
xdotool xdotool
# development environment # development environment
nix-direnv # creates ephimeral environments nix-direnv # creates ephimeral environments
direnv # manages development environment direnv # manages development environment
exercism # learn to code exercism # learn to code
# SH # SH
bats # testing system, required by Exercism bats # testing system, required by Exercism
bashdb # autocomplete bashdb # autocomplete
shellcheck # linting shellcheck # linting
shfmt # a shell parser and formatter shfmt # a shell parser and formatter
file # required by my tasks script? file # required by my tasks script?
gnome.zenity # dependency of my scripts gnome.zenity # dependency of my scripts
xclip # manipulate clipboard from scripts xclip # manipulate clipboard from scripts
# NIX # NIX
nixfmt # linting nixfmt # linting
cachix # why spend time compiling? cachix # why spend time compiling?
# PYTHON. # PYTHON.
python3 # base language python3 # base language
pipenv # python development workflow for humans pipenv # python development workflow for humans
poetry # dependency management made easy poetry # dependency management made easy
# C# & Rust # C# & Rust
# omnisharp-roslyn # c# linter and code formatter # omnisharp-roslyn # c# linter and code formatter
# HASKELL # HASKELL
# cabal-install # haskell interface # cabal-install # haskell interface
# JS # JS
# jq # linting # jq # linting
nodejs # not as bad as I thought nodejs # not as bad as I thought
hunspell hunspell
hunspellDicts.it_IT hunspellDicts.it_IT
hunspellDicts.es_MX hunspellDicts.es_MX
hunspellDicts.en_CA hunspellDicts.en_CA
# Themes # Themes
adw-gtk3 adw-gtk3
# gradience # theme customizer, allows you to modify adw-gtk3 themes # gradience # theme customizer, allows you to modify adw-gtk3 themes
gnome.gnome-tweaks # tweaks for the gnome desktop environment gnome.gnome-tweaks # tweaks for the gnome desktop environment
# Fonts # Fonts
(nerdfonts.override { (nerdfonts.override {
fonts = [ "Agave" "CascadiaCode" "SourceCodePro" "Ubuntu" "FiraCode" "Iosevka" ]; fonts = [
}) "Agave"
symbola "CascadiaCode"
(papirus-icon-theme.override { "SourceCodePro"
color = "adwaita"; "Ubuntu"
}) "FiraCode"
"Iosevka"
];
})
symbola
(papirus-icon-theme.override { color = "adwaita"; })
]) ++ (with pkgs.python3Packages; [ ]) ++ (with pkgs.python3Packages; [
flake8 # wraper for pyflakes, pycodestyle and mccabe flake8 # wraper for pyflakes, pycodestyle and mccabe
isort # sort Python imports isort # sort Python imports
nose # testing and running python scripts nose # testing and running python scripts
@ -295,8 +298,7 @@ symbola
src = ./scripts/download/.; src = ./scripts/download/.;
doCheck = false; doCheck = false;
buildInputs = [ setuptools ]; buildInputs = [ setuptools ];
propagatedBuildInputs = propagatedBuildInputs = [ pyyaml types-pyyaml ];
[ pyyaml types-pyyaml ];
}) })
(buildPythonApplication rec { (buildPythonApplication rec {
pname = "classifier"; pname = "classifier";
@ -307,8 +309,7 @@ symbola
}; };
doCheck = false; doCheck = false;
buildInputs = [ setuptools ]; buildInputs = [ setuptools ];
propagatedBuildInputs = propagatedBuildInputs = [ arrow ];
[ arrow ];
}) })
(buildPythonApplication rec { (buildPythonApplication rec {
pname = "ffpb"; pname = "ffpb";
@ -319,11 +320,10 @@ symbola
}; };
doCheck = false; doCheck = false;
buildInputs = [ setuptools ]; buildInputs = [ setuptools ];
propagatedBuildInputs = propagatedBuildInputs = [ tqdm ];
[ tqdm ];
}) })
]) ++ (with pkgs.bat-extras; [ ]) ++ (with pkgs.bat-extras; [
batman # man pages batman # man pages
batpipe # piping batpipe # piping
batgrep # ripgrep batgrep # ripgrep
@ -331,14 +331,14 @@ symbola
batwatch # probably my next best friend batwatch # probably my next best friend
prettybat # trans your sourcecode! prettybat # trans your sourcecode!
]) ++ (with pkgs.fishPlugins; [ ]) ++ (with pkgs.fishPlugins; [
sponge # keep history clean from typos sponge # keep history clean from typos
fzf-fish # fish command line with fzf keybindings fzf-fish # fish command line with fzf keybindings
colored-man-pages # self explanatory colored-man-pages # self explanatory
autopair-fish # who has time for a closing bracket? autopair-fish # who has time for a closing bracket?
bass # integrate bash utilities on fish bass # integrate bash utilities on fish
]) ++ (with pkgs.gnomeExtensions; [ ]) ++ (with pkgs.gnomeExtensions; [
appindicator # applets for open applications appindicator # applets for open applications
gsconnect # sync data and notifications from your phone gsconnect # sync data and notifications from your phone
freon # hardware temperature monitor freon # hardware temperature monitor
@ -346,37 +346,43 @@ symbola
reading-strip # like putting a finger on every line I read reading-strip # like putting a finger on every line I read
tactile # window manager tactile # window manager
pano # clipboard manager pano # clipboard manager
# ]) ++ (with unstable.pkgs.gnomeExtensions; [ blur-my-shell # make the overview more visually appealing
# forge # window manager
# ]) ++ (with unstable.pkgs.gnomeExtensions; [
]) ++ (with pkgs.nodePackages; [ ]) ++ (with pkgs.nodePackages; [
dockerfile-language-server-nodejs # LSP dockerfile-language-server-nodejs # LSP
bash-language-server # LSP bash-language-server # LSP
pyright # LSP pyright # LSP
markdownlint-cli # Linter markdownlint-cli # Linter
prettier # Linter prettier # Linter
pnpm # Package manager pnpm # Package manager
]); }; # <--- end of package list ]);
}; # <--- end of package list
fonts.fontconfig.enable = true; fonts.fontconfig.enable = true;
home-manager.useUserPackages = true; home-manager.useUserPackages = true;
home-manager.useGlobalPkgs = true; home-manager.useGlobalPkgs = true;
home-manager.users.jawz = { config, pkgs, ... }:{ home-manager.users.jawz = { config, pkgs, ... }: {
home.stateVersion = VERSION; home.stateVersion = VERSION;
home.packages = with pkgs; [ ]; home.packages = with pkgs; [ ];
programs.starship.enable = true; programs.starship.enable = true;
programs.fish = { programs.fish = {
enable = true; enable = true;
# useBabelfish = true; This setting doens't work from inside home-manager # useBabelfish = true; This setting doens't work from inside home-manager
shellAliases = { shellAliases = {
ls = "exa --icons --group-directories-first --no-permissions --no-user --no-time"; ls =
"exa --icons --group-directories-first --no-permissions --no-user --no-time";
edit = "emacsclient -t"; edit = "emacsclient -t";
comic = "download -u jawz -i (cat $lc | fzf --multi --exact -i)"; comic = "download -u jawz -i (cat $lc | fzf --multi --exact -i)";
gallery = "download -u jawz -i (cat $lw | fzf --multi --exact -i)"; gallery = "download -u jawz -i (cat $lw | fzf --multi --exact -i)";
open_gallery = "open (find /mnt/disk2/scrapping/JawZ/gallery-dl -type d | fzf)"; open_gallery =
unique_extensions = "find . -type f | string match -r '([^.\/]+)\$' | sort -u"; "open (find /mnt/disk2/scrapping/JawZ/gallery-dl -type d | fzf)";
unique_extensions =
"find . -type f | string match -r '([^./]+)$' | sort -u";
cp = "cp -i"; cp = "cp -i";
mv = "mv -i"; mv = "mv -i";
mkdir = "mkdir -p"; mkdir = "mkdir -p";
@ -398,34 +404,34 @@ programs.fish = {
}; };
interactiveShellInit = '' interactiveShellInit = ''
function fish_greeting function fish_greeting
~/.local/bin/pokemon-colorscripts -r --no-title ~/.local/bin/pokemon-colorscripts -r --no-title
end end
# Lists # Lists
set -l list_root ${config.home.homeDirectory}/.config/jawz/lists/jawz set -l list_root ${config.home.homeDirectory}/.config/jawz/lists/jawz
set lw $list_root/watch.txt set lw $list_root/watch.txt
set li $list_root/instant.txt set li $list_root/instant.txt
set lc $list_root/comic.txt set lc $list_root/comic.txt
set command_timeout = 30 set command_timeout = 30
set GPG_TTY (tty) set GPG_TTY (tty)
# Set EMACS/VI mode # Set EMACS/VI mode
function fish_user_key_bindings function fish_user_key_bindings
# fish_default_key_bindings # fish_default_key_bindings
fish_vi_key_bindings fish_vi_key_bindings
end end
''; '';
functions = { functions = {
nixos-magic = '' nixos-magic = ''
set -l nix_file "$HOME/Development/NixOS/configuration.nix" set -l nix_file "$HOME/Development/NixOS/configuration.nix"
set -l hardware_file "$HOME/Development/NixOS/hardware-configuration.nix" set -l hardware_file "$HOME/Development/NixOS/hardware-configuration.nix"
nixfmt $nix_file nixfmt $nix_file
nixfmt $hardware_file nixfmt $hardware_file
sudo nixos-rebuild switch -I nixos-config=$nix_file sudo nixos-rebuild switch -I nixos-config=$nix_file
''; '';
mkcd = '' mkcd = ''
@ -435,14 +441,15 @@ sudo nixos-rebuild switch -I nixos-config=$nix_file
''; '';
}; };
}; };
programs = { programs = {
bat = { bat = {
enable = true; enable = true;
config = { config = {
pager = "less -FR"; pager = "less -FR";
theme = "base16"; }; theme = "base16";
};
}; };
git = { git = {
enable = true; enable = true;
@ -453,9 +460,9 @@ programs = {
enable = true; enable = true;
package = pkgs.htop-vim; package = pkgs.htop-vim;
}; };
}; };
xdg = { xdg = {
enable = true; enable = true;
userDirs = { userDirs = {
enable = true; enable = true;
@ -471,30 +478,31 @@ xdg = {
}; };
configFile = { configFile = {
"wgetrc".source = ./dotfiles/wget/wgetrc; "wgetrc".source = ./dotfiles/wget/wgetrc;
"configstore/update-notifier-npm-check.json".source = ./dotfiles/npm/update-notifier-npm-check.json; "configstore/update-notifier-npm-check.json".source =
./dotfiles/npm/update-notifier-npm-check.json;
"npm/npmrc".source = ./dotfiles/npm/npmrc; "npm/npmrc".source = ./dotfiles/npm/npmrc;
"gallery-dl/config.json".source = ./dotfiles/gallery-dl/config.json; "gallery-dl/config.json".source = ./dotfiles/gallery-dl/config.json;
"htop/htoprc".source = ./dotfiles/htop/htoprc; "htop/htoprc".source = ./dotfiles/htop/htoprc;
}; };
}; };
services = { services = {
lorri.enable = true; lorri.enable = true;
emacs = { emacs = {
enable = true; enable = true;
defaultEditor = true; defaultEditor = true;
package = pkgs.emacs; package = pkgs.emacs;
}; };
}; };
}; };
environment.systemPackages = with pkgs; [ environment.systemPackages = with pkgs; [
wget wget
docker-compose # easy way to migrate my docker anywhere! docker-compose # easy way to migrate my docker anywhere!
]; ];
environment.variables = rec { environment.variables = rec {
# PATH # PATH
XDG_CACHE_HOME = "\${HOME}/.cache"; XDG_CACHE_HOME = "\${HOME}/.cache";
XDG_CONFIG_HOME = "\${HOME}/.config"; XDG_CONFIG_HOME = "\${HOME}/.config";
@ -541,15 +549,15 @@ environment.variables = rec {
"\${XDG_DATA_HOME}/npm/bin" "\${XDG_DATA_HOME}/npm/bin"
"\${XDG_DATA_HOME}/pnpm" "\${XDG_DATA_HOME}/pnpm"
]; ];
}; };
virtualisation.docker = { virtualisation.docker = {
enable = true; enable = true;
storageDriver = "btrfs"; storageDriver = "btrfs";
enableNvidia = true; enableNvidia = true;
}; };
snapraid = { snapraid = {
enable = true; enable = true;
touchBeforeSync = true; touchBeforeSync = true;
sync.interval = "02:00"; sync.interval = "02:00";
@ -558,9 +566,7 @@ snapraid = {
olderThan = 10; olderThan = 10;
interval = "4:00"; interval = "4:00";
}; };
parityFiles = [ parityFiles = [ "/mnt/parity/snapraid.parity" ];
"/mnt/parity/snapraid.parity"
];
extraConfig = '' extraConfig = ''
autosave 50 autosave 50
''; '';
@ -580,9 +586,9 @@ snapraid = {
"/mnt/disk1/snapraid.content" "/mnt/disk1/snapraid.content"
"/mnt/disk2/snapraid.content" "/mnt/disk2/snapraid.content"
]; ];
}; };
programs = { programs = {
fish.enable = true; fish.enable = true;
mtr.enable = true; mtr.enable = true;
neovim = { neovim = {
@ -593,17 +599,15 @@ programs = {
enable = true; enable = true;
enableSSHSupport = true; enableSSHSupport = true;
}; };
geary = { geary = { enable = true; };
enable = true;
};
steam = { steam = {
enable = true; enable = true;
remotePlay.openFirewall = true; remotePlay.openFirewall = true;
dedicatedServer.openFirewall = true; dedicatedServer.openFirewall = true;
}; };
}; };
services = { services = {
printing = { printing = {
enable = true; enable = true;
drivers = [ pkgs.hplip pkgs.hplipWithPlugin ]; drivers = [ pkgs.hplip pkgs.hplipWithPlugin ];
@ -613,11 +617,7 @@ services = {
fstrim.enable = true; fstrim.enable = true;
btrfs.autoScrub = { btrfs.autoScrub = {
enable = true; enable = true;
fileSystems = [ fileSystems = [ "/" "/mnt/disk1" "/mnt/disk2" ];
"/"
"/mnt/disk1"
"/mnt/disk2"
];
}; };
openssh = { openssh = {
enable = true; enable = true;
@ -627,12 +627,10 @@ services = {
KbdInteractiveAuthentication = false; KbdInteractiveAuthentication = false;
}; };
startWhenNeeded = true; startWhenNeeded = true;
listenAddresses = [ listenAddresses = [{
{
addr = "0.0.0.0"; addr = "0.0.0.0";
port = 25152; port = 25152;
} }];
];
}; };
# udev.packages = with pkgs; [ gnome.gnome-settings-daemon ]; # udev.packages = with pkgs; [ gnome.gnome-settings-daemon ];
emacs = { emacs = {
@ -640,9 +638,9 @@ services = {
defaultEditor = true; defaultEditor = true;
package = pkgs.emacs; package = pkgs.emacs;
}; };
}; };
systemd.services = { systemd.services = {
"docker-compose" = { "docker-compose" = {
enable = true; enable = true;
restartIfChanged = true; restartIfChanged = true;
@ -653,36 +651,32 @@ systemd.services = {
environment = { environment = {
FILE = "/home/jawz/Development/Docker/docker-compose.yml"; FILE = "/home/jawz/Development/Docker/docker-compose.yml";
}; };
path = [ path = [ pkgs.docker-compose ];
pkgs.docker-compose
];
serviceConfig = { serviceConfig = {
Restart = "on-failure"; Restart = "on-failure";
RestartSec = 30; RestartSec = 30;
ExecStart = "${pkgs.docker-compose}/bin/docker-compose -f \${FILE} up --remove-orphans"; ExecStart =
"${pkgs.docker-compose}/bin/docker-compose -f \${FILE} up --remove-orphans";
ExecStop = "${pkgs.docker-compose}/bin/docker-compose -f \${FILE} down"; ExecStop = "${pkgs.docker-compose}/bin/docker-compose -f \${FILE} down";
}; };
}; };
"nextcloud_scrapsync" = { "nextcloud_scrapsync" = {
description = "Sync scrapped files with nextcloud"; description = "Sync scrapped files with nextcloud";
wantedBy = [ "default.target" ]; wantedBy = [ "default.target" ];
path = [ path = [ pkgs.bash nextcloud_scrapsync ];
pkgs.bash
nextcloud_scrapsync
];
serviceConfig = { serviceConfig = {
RestartSec = 30; RestartSec = 30;
ExecStart = "${nextcloud_scrapsync}/bin/nextcloud_scrapsync"; ExecStart = "${nextcloud_scrapsync}/bin/nextcloud_scrapsync";
}; };
}; };
}; };
systemd.timers = { systemd.timers = {
"nextcloud_scrapsync" = { "nextcloud_scrapsync" = {
enable = true; enable = true;
description = "Sync scrapped files with nextcloud"; description = "Sync scrapped files with nextcloud";
wantedBy = [ "timers.target" ]; wantedBy = [ "timers.target" ];
timerConfig = { timerConfig = {
OnCalendar= [ OnCalendar = [
"*-*-* 01:32:00" "*-*-* 01:32:00"
"*-*-* 08:32:00" "*-*-* 08:32:00"
"*-*-* 14:32:00" "*-*-* 14:32:00"
@ -692,20 +686,18 @@ systemd.timers = {
Persistent = true; Persistent = true;
}; };
}; };
}; };
systemd.user.services = { systemd.user.services = {
"HentaiAtHome" = { "HentaiAtHome" = {
enable = true; enable = true;
restartIfChanged = true; restartIfChanged = true;
description = "Run hentai@home server"; description = "Run hentai@home server";
wantedBy = [ "default.target" ]; wantedBy = [ "default.target" ];
path = [ path = [ pkgs.HentaiAtHome ];
pkgs.HentaiAtHome
];
serviceConfig = { serviceConfig = {
Restart = "on-failure"; Restart = "on-failure";
RestartSec = 30; RestartSec = 30;
WorkingDirectory="/mnt/hnbox"; WorkingDirectory = "/mnt/hnbox";
ExecStart = "${pkgs.HentaiAtHome}/bin/HentaiAtHome"; ExecStart = "${pkgs.HentaiAtHome}/bin/HentaiAtHome";
}; };
}; };
@ -714,29 +706,26 @@ systemd.user.services = {
restartIfChanged = true; restartIfChanged = true;
description = "Run the manage library fish script"; description = "Run the manage library fish script";
wantedBy = [ "default.target" ]; wantedBy = [ "default.target" ];
path = [ path = [ pkgs.fish manage_library ];
pkgs.fish
manage_library
];
serviceConfig = { serviceConfig = {
Restart = "on-failure"; Restart = "on-failure";
RestartSec = 30; RestartSec = 30;
ExecStart = "${manage_library}/bin/manage_library"; ExecStart = "${manage_library}/bin/manage_library";
}; };
}; };
}; };
networking.firewall.allowedTCPPorts = open_firewall_ports; networking.firewall.allowedTCPPorts = open_firewall_ports;
networking.firewall.allowedUDPPorts = open_firewall_ports; networking.firewall.allowedUDPPorts = open_firewall_ports;
networking.firewall.allowedTCPPortRanges = open_firewall_port_ranges; networking.firewall.allowedTCPPortRanges = open_firewall_port_ranges;
networking.firewall.allowedUDPPortRanges = open_firewall_port_ranges; networking.firewall.allowedUDPPortRanges = open_firewall_port_ranges;
# networking.firewall.enable = false; # networking.firewall.enable = false;
system = { system = {
copySystemConfiguration = true; copySystemConfiguration = true;
stateVersion = VERSION; stateVersion = VERSION;
}; };
nix = { nix = {
settings = { settings = {
substituters = [ substituters = [
"https://nix-gaming.cachix.org" "https://nix-gaming.cachix.org"
@ -753,6 +742,6 @@ nix = {
automatic = true; automatic = true;
dates = "weekly"; dates = "weekly";
}; };
}; };
} }

View File

@ -41,6 +41,7 @@ let
open_firewall_ports = [ open_firewall_ports = [
80 # http 80 # http
443 # https 443 # https
6969 # HentaiAtHome
25152 # ssh 25152 # ssh
49494 # gerbera 49494 # gerbera
]; ];
@ -543,6 +544,8 @@ symbola
reading-strip # like putting a finger on every line I read reading-strip # like putting a finger on every line I read
tactile # window manager tactile # window manager
pano # clipboard manager pano # clipboard manager
blur-my-shell # make the overview more visually appealing
# forge # window manager
# ]) ++ (with unstable.pkgs.gnomeExtensions; [ # ]) ++ (with unstable.pkgs.gnomeExtensions; [
#+end_src #+end_src