From 32382fb013ecccdf73ed05123156506bf19ec1e2 Mon Sep 17 00:00:00 2001 From: Danilo Reyes Date: Fri, 19 May 2023 21:39:07 -0600 Subject: [PATCH] removed test open-mateo scripts --- configuration.nix | 1286 ++++++++++++++++++++++----------------------- configuration.org | 65 --- 2 files changed, 626 insertions(+), 725 deletions(-) diff --git a/configuration.nix b/configuration.nix index cdc1f7d..619e96a 100644 --- a/configuration.nix +++ b/configuration.nix @@ -3,729 +3,695 @@ let VERSION = "22.11"; # HOME-MANAGER = builtins.fetchTarball # "https://github.com/nix-community/home-manager/archive/master.tar.gz"; - UNSTABLE_TARBALL = - builtins.fetchTarball "https://github.com/nixos/nixpkgs/tarball/master"; - unstable = import UNSTABLE_TARBALL { config = config.nixpkgs.config; }; - nextcloud_scrapsync = pkgs.writeScriptBin "nextcloud_scrapsync" - (builtins.readFile ./scripts/nextcloud_scrapsync.sh); - mateo-current = pkgs.writeScriptBin "mateo-current" - (builtins.readFile ./scripts/current.sh); - mateo-forecast = pkgs.writeScriptBin "mateo-forecast" - (builtins.readFile ./scripts/forecast.sh); - manage_library = pkgs.writeScriptBin "manage_library" - (builtins.readFile ./scripts/manage_library.fish); - ffmpeg4discord = pkgs.writeScriptBin "ffmpeg4discord" - (builtins.readFile ./scripts/ffmpeg4discord.py); -in { # Remember to close this bracket at the end of the document - - imports = [ ./hardware-configuration.nix ]; - - networking.hostName = "workstation"; - - # networking.wireless.enable = true; - networking.networkmanager.enable = true; - - time.timeZone = "America/Mexico_City"; - - i18n = { - defaultLocale = "en_CA.UTF-8"; - extraLocaleSettings = { LC_MONETARY = "es_MX.UTF-8"; }; + UNSTABLE_TARBALL = builtins.fetchTarball + https://github.com/nixos/nixpkgs/tarball/master; + unstable = import UNSTABLE_TARBALL { + config = config.nixpkgs.config; }; - console = { - font = "Lat2-Terminus16"; - keyMap = "us"; - # useXkbConfig = true; # use xkbOptions in tty. + nextcloud_scrapsync = pkgs.writeScriptBin + "nextcloud_scrapsync" (builtins.readFile ./scripts/nextcloud_scrapsync.sh); + manage_library = pkgs.writeScriptBin + "manage_library" (builtins.readFile ./scripts/manage_library.fish); + ffmpeg4discord = pkgs.writeScriptBin + "ffmpeg4discord" (builtins.readFile ./scripts/ffmpeg4discord.py); +in +{ # Remember to close this bracket at the end of the document + +imports = [ + ./hardware-configuration.nix + +]; + +networking.hostName = "workstation"; + +# networking.wireless.enable = true; +networking.networkmanager.enable = true; + +time.timeZone = "America/Mexico_City"; + +i18n = { + defaultLocale = "en_CA.UTF-8"; + extraLocaleSettings = { + LC_MONETARY = "es_MX.UTF-8"; }; +}; +console = { + font = "Lat2-Terminus16"; + keyMap = "us"; + # useXkbConfig = true; # use xkbOptions in tty. +}; - services = { - xserver = { - enable = true; - # videoDrivers = [ "nvidia" "modesetting" ]; - videoDrivers = [ "nvidia" ]; - displayManager.gdm.enable = true; - desktopManager.gnome.enable = true; - # wacom.enable = true; - layout = "us"; - libinput.enable = true; # Wacom required? - # useGlamor = true; - }; - }; - - environment.gnome.excludePackages = (with pkgs; [ - gnome-photos - gnome-tour - gnome-text-editor - gnome-connections - # gnome-shell-extensions - baobab - ]) ++ (with pkgs.gnome; [ - # totem - gedit - gnome-music - epiphany - gnome-characters - yelp - gnome-font-viewer - cheese - ]); - - hardware.pulseaudio.enable = false; - sound.enable = false; - security.rtkit.enable = true; - services.pipewire = { +services = { + xserver = { enable = true; - alsa.enable = true; - alsa.support32Bit = true; - pulse.enable = true; + # videoDrivers = [ "nvidia" "modesetting" ]; + videoDrivers = [ "nvidia" ]; + displayManager.gdm.enable = true; + desktopManager.gnome.enable = true; + # wacom.enable = true; + layout = "us"; + libinput.enable = true; # Wacom required? + # useGlamor = true; }; +}; - security.sudo = { - enable = true; - wheelNeedsPassword = false; +environment.gnome.excludePackages = (with pkgs; [ + gnome-photos + gnome-tour + gnome-text-editor + gnome-connections + # gnome-shell-extensions + baobab +]) +++ (with pkgs.gnome; [ + # totem + gedit + gnome-music + epiphany + gnome-characters + yelp + gnome-font-viewer + cheese +]); + +hardware.pulseaudio.enable = false; +sound.enable = false; +security.rtkit.enable = true; +services.pipewire = { + enable = true; + alsa.enable = true; + alsa.support32Bit = true; + pulse.enable = true; +}; + +security.sudo = { + enable = true; + wheelNeedsPassword = false; +}; + +# security.sudo.enable = false; +# security.doas.enable = true; +# security.doas.extraRules = [{ +# users = [ "jawz" ]; +# keepEnv = true; +# #persist = true; +# noPass = true; +# }]; + +nixpkgs.config = { + allowUnfree = true; +}; + +users.users.jawz = { + isNormalUser = true; + extraGroups = [ "wheel" "networkmanager" "docker" "scanner" "lp" ]; + initialPassword = "password"; + shell = pkgs.fish; + openssh = { + authorizedKeys.keys = [ "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIB5GaQM4N+yGAByibOFQOBVMV/6TjOfaGIP+NunMiK76 gpodeacero\cdreyes@100CDREYES" ]; }; + packages = (with pkgs; [ - # security.sudo.enable = false; - # security.doas.enable = true; - # security.doas.extraRules = [{ - # users = [ "jawz" ]; - # keepEnv = true; - # #persist = true; - # noPass = true; - # }]; +blender # cgi animation and sculpting +godot # game development +unstable.gdtoolkit # gdscript language server +krita # art to your heart desire! +# drawpile # arty party with friends!! +mypaint # not the best art program +mypaint-brushes # but it's got some +mypaint-brushes1 # nice damn brushes +unstable.pureref # create inspiration/reference boards +unstable.gimp # the coolest bestest art program to never exist - nixpkgs.config = { allowUnfree = true; }; +lutris # game/emulator manager +# unstable.grapejuice # roblox manager +minecraft # minecraft official launcher +parsec-bin # remote gaming with friends +unstable.protonup-qt # update proton-ge - users.users.jawz = { - isNormalUser = true; - extraGroups = [ "wheel" "networkmanager" "docker" "scanner" "lp" ]; - initialPassword = "password"; - shell = pkgs.fish; - openssh = { - authorizedKeys.keys = [ - "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIB5GaQM4N+yGAByibOFQOBVMV/6TjOfaGIP+NunMiK76 gpodeacerocdreyes@100CDREYES" - ]; - }; - packages = (with pkgs; [ +libreoffice-fresh # office, but based +calibre # ugly af eBook library manager +foliate # gtk eBook reader +gnome-feeds # feed reader, maybe will replace with nextcloud +# unstable.wike # gtk wikipedia wow! +unstable.furtherance # I made this one tehee track time utility +gnome.simple-scan # scanner - blender # cgi animation and sculpting - godot # game development - unstable.gdtoolkit # gdscript language server - krita # art to your heart desire! - # drawpile # arty party with friends!! - mypaint # not the best art program - mypaint-brushes # but it's got some - mypaint-brushes1 # nice damn brushes - unstable.pureref # create inspiration/reference boards - unstable.gimp # the coolest bestest art program to never exist +# sequeler # friendly SQL client +blanket # background noise +unstable.czkawka # duplicate finder +pika-backup # backups +# 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 +metadata-cleaner # remove any metadata and geolocation from files +gnome-recipes # migrate these to mealie and delete +unstable.denaro # manage your finances +# unstable.celeste # sync tool for any cloud provider +# libgda # for pano shell extension - lutris # game/emulator manager - # unstable.grapejuice # roblox manager - minecraft # minecraft official launcher - parsec-bin # remote gaming with friends - unstable.protonup-qt # update proton-ge +celluloid # video player +cozy # audiobooks player +gnome-podcasts # podcast player +handbrake # video converter, may be unnecessary +curtail # image compressor +pitivi # video editor +unstable.identity # compare images or videos +mousai # poor man shazam +tagger # tag music files +# bottles # wine prefix manager +obs-studio # screen recorder & streamer +shortwave # listen to world radio +nextcloud-client # teehee - libreoffice-fresh # office, but based - calibre # ugly af eBook library manager - foliate # gtk eBook reader - gnome-feeds # feed reader, maybe will replace with nextcloud - # unstable.wike # gtk wikipedia wow! - unstable.furtherance # I made this one tehee track time utility - gnome.simple-scan # scanner +discord # chat +google-chrome # web browser with spyware included +firefox # web browser that allows to disable spyware +librewolf # no spyware web browser +tor-browser-bundle-bin # dark web, so dark! +# hugo # website engine +nicotine-plus # remember Ares? +warp # never used, but supposedly cool for sharing files +HentaiAtHome # uh-oh - # sequeler # friendly SQL client - blanket # background noise - unstable.czkawka # duplicate finder - pika-backup # backups - # 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 - metadata-cleaner # remove any metadata and geolocation from files - gnome-recipes # migrate these to mealie and delete - unstable.denaro # manage your finances - # unstable.celeste # sync tool for any cloud provider - # libgda # for pano shell extension +yt-dlp # downloads videos from most video websites +unstable.gallery-dl # similar to yt-dlp but for most image gallery websites +gdu # disk-space utility, somewhat useful +gocryptfs # encrypted filesystem! shhh!!! +exa # like ls but with colors +trash-cli # oop! didn't meant to delete that +ffmpeg_5 # coolest video converter! +neofetch # use once for brag, never again +rmlint # probably my favourite app, amazing dupe finder that integrates well with BTRFS +tldr # man for retards +# ffmpegthumbnailer # create video thumbnails for nautilus, in absence of totem +vcsi # video thumbnails for torrents, can I replace it with ^? +mediainfo # technical info about videos, needed by some of my scripts +tree-sitter # code parsing, required by Doom emacs +xdg-ninja # help declutter $HOME +torrenttools # create torrent files from the terminal! +lm_sensors # for extension, displays cpu temp - celluloid # video player - cozy # audiobooks player - gnome-podcasts # podcast player - handbrake # video converter, may be unnecessary - curtail # image compressor - pitivi # video editor - unstable.identity # compare images or videos - mousai # poor man shazam - tagger # tag music files - # bottles # wine prefix manager - obs-studio # screen recorder & streamer - shortwave # listen to world radio - nextcloud-client # teehee - discord # chat - google-chrome # web browser with spyware included - firefox # web browser that allows to disable spyware - librewolf # no spyware web browser - tor-browser-bundle-bin # dark web, so dark! - # hugo # website engine - nicotine-plus # remember Ares? - warp # never used, but supposedly cool for sharing files - HentaiAtHome # uh-oh +# My own scripts +nextcloud_scrapsync +ffmpeg4discord +manage_library - yt-dlp # downloads videos from most video websites - unstable.gallery-dl # similar to yt-dlp but for most image gallery websites - gdu # disk-space utility, somewhat useful - gocryptfs # encrypted filesystem! shhh!!! - exa # like ls but with colors - trash-cli # oop! didn't meant to delete that - ffmpeg_5 # coolest video converter! - neofetch # use once for brag, never again - rmlint # probably my favourite app, amazing dupe finder that integrates well with BTRFS - tldr # man for retards - # ffmpegthumbnailer # create video thumbnails for nautilus, in absence of totem - vcsi # video thumbnails for torrents, can I replace it with ^? - mediainfo # technical info about videos, needed by some of my scripts - tree-sitter # code parsing, required by Doom emacs - xdg-ninja # help declutter $HOME - torrenttools # create torrent files from the terminal! - lm_sensors # for extension, displays cpu temp +# required by doom emacs, but still are rather useful. +fd # modern find, faster searches +fzf # fuzzy finder! super cool and useful +ripgrep # modern grep +languagetool # proofreader for English. check if works without the service +graphviz # graphs +# these two are for doom everywhere +xorg.xwininfo +xdotool - # My own scripts - nextcloud_scrapsync - ffmpeg4discord - manage_library - mateo-current - mateo-forecast - jq +# development environment +nix-direnv # creates ephimeral environments +direnv # manages development environment +exercism # learn to code - # required by doom emacs, but still are rather useful. - fd # modern find, faster searches - fzf # fuzzy finder! super cool and useful - ripgrep # modern grep - languagetool # proofreader for English. check if works without the service - graphviz # graphs - # these two are for doom everywhere - xorg.xwininfo - xdotool +# SH +bats # testing system, required by Exercism +bashdb # autocomplete +shellcheck # linting +shfmt # a shell parser and formatter +nodePackages.bash-language-server # LSP support +file # required by my tasks script? +gnome.zenity # dependency of my scripts +xclip # manipulate clipboard from scripts - # development environment - nix-direnv # creates ephimeral environments - direnv # manages development environment - exercism # learn to code +# NIX +nixfmt # linting - # SH - bats # testing system, required by Exercism - bashdb # autocomplete - shellcheck # linting - shfmt # a shell parser and formatter - nodePackages.bash-language-server # LSP support - file # required by my tasks script? - gnome.zenity # dependency of my scripts - xclip # manipulate clipboard from scripts +# PYTHON. +python3 # base language +pipenv # python development workflow for humans - # NIX - nixfmt # linting +# C# & Rust +omnisharp-roslyn # c# linter and code formatter - # PYTHON. - python3 # base language - pipenv # python development workflow for humans +# HASKELL +# cabal-install # haskell interface - # C# & Rust - omnisharp-roslyn # c# linter and code formatter +# JS +# jq # linting +nodejs # not as bad as I thought - # HASKELL - # cabal-install # haskell interface +hunspell +hunspellDicts.it_IT +hunspellDicts.es_MX +hunspellDicts.en_CA - # JS - # jq # linting - nodejs # not as bad as I thought +# Themes +adwaita-qt +unstable.adw-gtk3 +unstable.gradience # theme customizer, allows you to modify adw-gtk3 themes +gnome.gnome-tweaks # tweaks for the gnome desktop environment - hunspell - hunspellDicts.it_IT - hunspellDicts.es_MX - hunspellDicts.en_CA +# Fonts +(nerdfonts.override { + fonts = [ "Agave" "CascadiaCode" "SourceCodePro" "Ubuntu" "FiraCode" "Iosevka" ]; +}) +symbola +(papirus-icon-theme.override { + color = "adwaita"; +}) - # Themes - adwaita-qt - unstable.adw-gtk3 - unstable.gradience # theme customizer, allows you to modify adw-gtk3 themes - gnome.gnome-tweaks # tweaks for the gnome desktop environment +]) ++ (with pkgs.python310Packages; [ + black # Python code formatter + flake8 # wraper for pyflakes, pycodestyle and mccabe + isort # sort Python imports + nose # testing and running python scripts + pipx # install python packages in a virtual environment + poetry # dependency management made easy + pyflakes # checks source code for errors + pylint # bug and style checker for python + pytest # framework for writing tests + speedtest-cli # check internet speed from the comand line + editorconfig # follow rules of contributin - # Fonts - (nerdfonts.override { - fonts = [ - "Agave" - "CascadiaCode" - "SourceCodePro" - "Ubuntu" - "FiraCode" - "Iosevka" - ]; - }) - symbola - (papirus-icon-theme.override { color = "adwaita"; }) +]) ++ (with pkgs.bat-extras; [ + batman # man pages + batpipe # piping + batgrep # ripgrep + batdiff # this is getting crazy! + batwatch # probably my next best friend + prettybat # trans your sourcecode! - ]) ++ (with pkgs.python310Packages; [ - black # Python code formatter - flake8 # wraper for pyflakes, pycodestyle and mccabe - isort # sort Python imports - nose # testing and running python scripts - pipx # install python packages in a virtual environment - poetry # dependency management made easy - pyflakes # checks source code for errors - pylint # bug and style checker for python - pytest # framework for writing tests - speedtest-cli # check internet speed from the comand line - editorconfig # follow rules of contributin +]) ++ (with pkgs.fishPlugins; [ + sponge # keep history clean from typos + fzf-fish # fish command line with fzf keybindings + colored-man-pages # self explanatory + autopair-fish # who has time for a closing bracket? + bass # integrate bash utilities on fish - ]) ++ (with pkgs.bat-extras; [ - batman # man pages - batpipe # piping - batgrep # ripgrep - batdiff # this is getting crazy! - batwatch # probably my next best friend - prettybat # trans your sourcecode! +]) ++ (with pkgs.gnomeExtensions; [ + appindicator + gsconnect + freon + panel-scroll + reading-strip + tactile + pano - ]) ++ (with pkgs.fishPlugins; [ - sponge # keep history clean from typos - fzf-fish # fish command line with fzf keybindings - colored-man-pages # self explanatory - autopair-fish # who has time for a closing bracket? - bass # integrate bash utilities on fish +]) ++ (with pkgs.nodePackages; [ + dockerfile-language-server-nodejs + markdownlint-cli + prettier + pnpm +]); }; # <--- end of package list - ]) ++ (with pkgs.gnomeExtensions; [ - appindicator - gsconnect - freon - panel-scroll - reading-strip - tactile - pano +fonts.fontconfig.enable = true; - ]) ++ (with pkgs.nodePackages; [ - dockerfile-language-server-nodejs - markdownlint-cli - prettier - pnpm - ]); - }; # <--- end of package list +home-manager.useUserPackages = true; +home-manager.useGlobalPkgs = true; - fonts.fontconfig.enable = true; - - home-manager.useUserPackages = true; - home-manager.useGlobalPkgs = true; - - home-manager.users.jawz = { config, pkgs, ... }: { +home-manager.users.jawz = { config, pkgs, ... }:{ # imports = [ ./dotfiles/dconf.nix ]; home.stateVersion = VERSION; home.packages = with pkgs; [ ]; - programs.starship.enable = true; - programs.fish = { - enable = true; - # useBabelfish = true; This setting doens't work from inside home-manager - shellAliases = { - ls = - "exa --icons --group-directories-first --no-permissions --no-user --no-time"; - edit = "emacsclient -t"; - comic = "download -u jawz -i (cat $lc | 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)"; - unique_extensions = - "find . -type f | string match -r '([^./]+)$' | sort -u"; - cp = "cp -i"; - mv = "mv -i"; - mkdir = "mkdir -p"; - rm = "trash"; - ".." = "cd .."; - "..." = "cd ../.."; - ".3" = "cd ../../.."; - ".4" = "cd ../../../.."; - ".5" = "cd ../../../../.."; - }; - shellAbbrs = { - dl = "download -u jawz -i"; - ex = "ls"; - e = "edit"; - c = "cat"; - f = "fzf --multi --exact -i"; - sc = "systemctl --user"; - jc = "journalctl --user -xeu"; - }; - interactiveShellInit = '' - - function fish_greeting - pokemon-colorscripts -r --no-title - end - # Lists - set -l list_root ${config.home.homeDirectory}/.config/jawz/lists/jawz - set lw $list_root/watch.txt - set li $list_root/instant.txt - set lc $list_root/comic.txt - set command_timeout = 30 - - set GPG_TTY (tty) - - # Set EMACS/VI mode - function fish_user_key_bindings - # fish_default_key_bindings - fish_vi_key_bindings - end - - ''; - - functions = { - nixos-magic = '' - - set -l nix_file "$HOME/Development/NixOS/configuration.nix" - set -l hardware_file "$HOME/Development/NixOS/hardware-configuration.nix" - nixfmt $nix_file - nixfmt $hardware_file - sudo nixos-rebuild switch -I nixos-config=$nix_file - - ''; - mkcd = '' - - mkdir -pv $argv - cd $argv - - ''; - }; - }; - - programs = { - bat = { - enable = true; - config = { - # map-syntax = [ "*.jenkinsfile:Groovy" "*.props:Java Properties" ]; - pager = "less -FR"; - theme = "base16"; - }; - }; - git = { - enable = true; - userName = "Danilo Reyes"; - userEmail = "CaptainJawZ@outlook.com"; - }; - # gpg = { - # enable = true; - # homedir = "${config.xdg.dataHome}/gnupg"; - # }; - htop = { - enable = true; - package = pkgs.htop-vim; - }; - }; - - xdg = { - enable = true; - userDirs = { - enable = true; - # createDirectories = true; - desktop = "${config.home.homeDirectory}"; - documents = "${config.home.homeDirectory}/Documents"; - download = "${config.home.homeDirectory}/Downloads"; - music = "${config.home.homeDirectory}/Music"; - pictures = "${config.home.homeDirectory}/Pictures"; - # publicShare = "${config.home.homeDirectory}/.local/hd/Public"; - templates = "${config.home.homeDirectory}/.local/share/Templates"; - videos = "${config.home.homeDirectory}/Videos"; - }; - configFile = { - "wgetrc".source = ./dotfiles/wget/wgetrc; - "configstore/update-notifier-npm-check.json".source = - ./dotfiles/npm/update-notifier-npm-check.json; - "npm/npmrc".source = ./dotfiles/npm/npmrc; - "gallery-dl/config.json".source = ./dotfiles/gallery-dl/config.json; - "htop/htoprc".source = ./dotfiles/htop/htoprc; - }; - }; - - services = { - emacs = { - enable = true; - defaultEditor = true; - package = pkgs.emacs; - }; - }; - +programs.starship.enable = true; +programs.fish = { + enable = true; + # useBabelfish = true; This setting doens't work from inside home-manager + shellAliases = { + ls = "exa --icons --group-directories-first --no-permissions --no-user --no-time"; + edit = "emacsclient -t"; + comic = "download -u jawz -i (cat $lc | 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)"; + unique_extensions = "find . -type f | string match -r '([^.\/]+)\$' | sort -u"; + cp = "cp -i"; + mv = "mv -i"; + mkdir = "mkdir -p"; + rm = "trash"; + ".." = "cd .."; + "..." = "cd ../.."; + ".3" = "cd ../../.."; + ".4" = "cd ../../../.."; + ".5" = "cd ../../../../.."; }; + shellAbbrs = { + dl = "download -u jawz -i"; + ex = "ls"; + e = "edit"; + c = "cat"; + f = "fzf --multi --exact -i"; + sc = "systemctl --user"; + jc = "journalctl --user -xeu"; + }; + interactiveShellInit = '' - environment.systemPackages = with pkgs; [ - wget - docker-compose # easy way to migrate my docker anywhere! +function fish_greeting + ~/.local/bin/pokemon-colorscripts -r --no-title +end +# Lists +set -l list_root ${config.home.homeDirectory}/.config/jawz/lists/jawz +set lw $list_root/watch.txt +set li $list_root/instant.txt +set lc $list_root/comic.txt +set command_timeout = 30 + +set GPG_TTY (tty) + +# Set EMACS/VI mode +function fish_user_key_bindings + # fish_default_key_bindings + fish_vi_key_bindings +end + +''; + +functions = { + nixos-magic = '' + +set -l nix_file "$HOME/Development/NixOS/configuration.nix" +set -l hardware_file "$HOME/Development/NixOS/hardware-configuration.nix" +nixfmt $nix_file +nixfmt $hardware_file +sudo nixos-rebuild switch -I nixos-config=$nix_file + + ''; + mkcd = '' + + mkdir -pv $argv + cd $argv + + ''; + }; +}; + +programs = { + bat = { + enable = true; + config = { + # map-syntax = [ "*.jenkinsfile:Groovy" "*.props:Java Properties" ]; + pager = "less -FR"; + theme = "base16"; }; + }; + git = { + enable = true; + userName = "Danilo Reyes"; + userEmail = "CaptainJawZ@outlook.com"; + }; + # gpg = { + # enable = true; + # homedir = "${config.xdg.dataHome}/gnupg"; + # }; + htop = { + enable = true; + package = pkgs.htop-vim; + }; +}; + +xdg = { + enable = true; + userDirs = { + enable = true; + # createDirectories = true; + desktop = "${config.home.homeDirectory}"; + documents = "${config.home.homeDirectory}/Documents"; + download = "${config.home.homeDirectory}/Downloads"; + music = "${config.home.homeDirectory}/Music"; + pictures = "${config.home.homeDirectory}/Pictures"; + # publicShare = "${config.home.homeDirectory}/.local/hd/Public"; + templates = "${config.home.homeDirectory}/.local/share/Templates"; + videos = "${config.home.homeDirectory}/Videos"; + }; + configFile = { + "wgetrc".source = ./dotfiles/wget/wgetrc; + "configstore/update-notifier-npm-check.json".source = ./dotfiles/npm/update-notifier-npm-check.json; + "npm/npmrc".source = ./dotfiles/npm/npmrc; + "gallery-dl/config.json".source = ./dotfiles/gallery-dl/config.json; + "htop/htoprc".source = ./dotfiles/htop/htoprc; + }; +}; + +services = { + emacs = { + enable = true; + defaultEditor = true; + package = pkgs.emacs; + }; +}; + +}; + +environment.systemPackages = with pkgs; [ + wget + docker-compose # easy way to migrate my docker anywhere! +]; + +environment.variables = rec { + # PATH + XDG_CACHE_HOME = "\${HOME}/.cache"; + XDG_CONFIG_HOME = "\${HOME}/.config"; + XDG_BIN_HOME = "\${HOME}/.local/bin"; + XDG_DATA_HOME = "\${HOME}/.local/share"; + XDG_STATE_HOME = "\${HOME}/.local/state"; + + SCRIPTS = "\${HOME}/Development/Scripts"; + + # DEV PATH + CABAL_CONFIG = "\${XDG_CONFIG_HOME}/cabal/config"; + CABAL_DIR = "\${XDG_CACHE_HOME}/cabal"; + CARGO_HOME = "\${XDG_DATA_HOME}/cargo"; + GEM_HOME = "\${XDG_DATA_HOME}/ruby/gems"; + GEM_PATH = "\${XDG_DATA_HOME}/ruby/gems"; + GEM_SPEC_CACHE = "\${XDG_DATA_HOME}/ruby/specs"; + GOPATH = "\${XDG_DATA_HOME}/go"; + NPM_CONFIG_USERCONFIG = "\${XDG_CONFIG_HOME}/npm/npmrc"; + PNPM_HOME = "\${XDG_DATA_HOME}/pnpm"; + # OPTIONS + HISTFILE = "\${XDG_STATE_HOME}/bash/history"; + LESSHISTFILE = "-"; + GHCUP_USE_XDG_DIRS = "true"; + RIPGREP_CONFIG_PATH = "\${XDG_CONFIG_HOME}/ripgrep/ripgreprc"; + ELECTRUMDIR = "\${XDG_DATA_HOME}/electrum"; + VISUAL = "emacsclient -ca emacs"; + WGETRC = "\${XDG_CONFIG_HOME}/wgetrc"; + XCOMPOSECACHE = "${XDG_CACHE_HOME}/X11/xcompose"; + "_JAVA_OPTIONS" = "-Djava.util.prefs.userRoot=\${XDG_CONFIG_HOME}/java"; + # NVIDIA + CUDA_CACHE_PATH = "\${XDG_CACHE_HOME}/nv"; + # GBM_BACKEND = "nvidia-drm"; + # "__GLX_VENDOR_LIBRARY_NAME" = "nvidia"; + + # Themes + # GTK_THEME = "Adwaita:light"; + # QT_QPA_PLATFORMTHEME = "adwaita"; + # QT_STYLE_OVERRIDE = "adwaita"; + CALIBRE_USE_SYSTEM_THEME = "1"; + + PATH = [ + "\${HOME}/.local/bin" + "\${XDG_CONFIG_HOME}/emacs/bin" + "\${XDG_DATA_HOME}/npm/bin" + "\${XDG_DATA_HOME}/pnpm" ]; +}; - environment.variables = rec { - # PATH - XDG_CACHE_HOME = "\${HOME}/.cache"; - XDG_CONFIG_HOME = "\${HOME}/.config"; - XDG_BIN_HOME = "\${HOME}/.local/bin"; - XDG_DATA_HOME = "\${HOME}/.local/share"; - XDG_STATE_HOME = "\${HOME}/.local/state"; - - SCRIPTS = "\${HOME}/Development/Scripts"; - - # DEV PATH - CABAL_CONFIG = "\${XDG_CONFIG_HOME}/cabal/config"; - CABAL_DIR = "\${XDG_CACHE_HOME}/cabal"; - CARGO_HOME = "\${XDG_DATA_HOME}/cargo"; - GEM_HOME = "\${XDG_DATA_HOME}/ruby/gems"; - GEM_PATH = "\${XDG_DATA_HOME}/ruby/gems"; - GEM_SPEC_CACHE = "\${XDG_DATA_HOME}/ruby/specs"; - GOPATH = "\${XDG_DATA_HOME}/go"; - NPM_CONFIG_USERCONFIG = "\${XDG_CONFIG_HOME}/npm/npmrc"; - PNPM_HOME = "\${XDG_DATA_HOME}/pnpm"; - # OPTIONS - HISTFILE = "\${XDG_STATE_HOME}/bash/history"; - LESSHISTFILE = "-"; - GHCUP_USE_XDG_DIRS = "true"; - RIPGREP_CONFIG_PATH = "\${XDG_CONFIG_HOME}/ripgrep/ripgreprc"; - ELECTRUMDIR = "\${XDG_DATA_HOME}/electrum"; - VISUAL = "emacsclient -ca emacs"; - WGETRC = "\${XDG_CONFIG_HOME}/wgetrc"; - XCOMPOSECACHE = "${XDG_CACHE_HOME}/X11/xcompose"; - "_JAVA_OPTIONS" = "-Djava.util.prefs.userRoot=\${XDG_CONFIG_HOME}/java"; - # NVIDIA - CUDA_CACHE_PATH = "\${XDG_CACHE_HOME}/nv"; - # GBM_BACKEND = "nvidia-drm"; - # "__GLX_VENDOR_LIBRARY_NAME" = "nvidia"; - - # Themes - # GTK_THEME = "Adwaita:light"; - # QT_QPA_PLATFORMTHEME = "adwaita"; - # QT_STYLE_OVERRIDE = "adwaita"; - CALIBRE_USE_SYSTEM_THEME = "1"; - - PATH = [ - "\${HOME}/.local/bin" - "\${XDG_CONFIG_HOME}/emacs/bin" - "\${XDG_DATA_HOME}/npm/bin" - "\${XDG_DATA_HOME}/pnpm" - ]; - }; - - virtualisation.docker = { +virtualisation.docker = { enable = true; storageDriver = "btrfs"; enableNvidia = true; - }; +}; - snapraid = { +snapraid = { + enable = true; + touchBeforeSync = true; + sync.interval = "02:00"; + scrub = { + plan = 10; + olderThan = 10; + interval = "4:00"; + }; + parityFiles = [ + "/mnt/parity/snapraid.parity" + ]; + extraConfig = '' + autosave 50 + ''; + exclude = [ + "/tmp/" + "/lost+found/" + "/multimedia/downloads/" + "/scrapping/nextcloud/" + "/backups/" + ]; + dataDisks = { + d1 = "/mnt/disk1/"; + d2 = "/mnt/disk2/"; + }; + contentFiles = [ + "/var/snapraid.content" + "/mnt/disk1/snapraid.content" + "/mnt/disk2/snapraid.content" + ]; +}; + +programs = { + mtr.enable = true; + neovim = { enable = true; - touchBeforeSync = true; - sync.interval = "02:00"; - scrub = { - plan = 10; - olderThan = 10; - interval = "4:00"; - }; - parityFiles = [ "/mnt/parity/snapraid.parity" ]; - extraConfig = '' - autosave 50 - ''; - exclude = [ - "/tmp/" - "/lost+found/" - "/multimedia/downloads/" - "/scrapping/nextcloud/" - "/backups/" - ]; - dataDisks = { - d1 = "/mnt/disk1/"; - d2 = "/mnt/disk2/"; - }; - contentFiles = [ - "/var/snapraid.content" - "/mnt/disk1/snapraid.content" - "/mnt/disk2/snapraid.content" + vimAlias = true; + }; + gnupg.agent = { + enable = true; + enableSSHSupport = true; + }; + geary = { + enable = true; + }; + steam = { + enable = true; + remotePlay.openFirewall = true; + dedicatedServer.openFirewall = true; + }; +}; + +services = { + printing = { + enable = true; + drivers = [ pkgs.hplip pkgs.hplipWithPlugin ]; + }; + # ipp-usb.enable = true; # usb scanner + avahi.enable = true; + avahi.nssmdns = true; + fstrim.enable = true; + # jellyfin = { + # enable = true; + # group = "jawz"; + # user = "jawz"; + # }; + btrfs.autoScrub = { + enable = true; + fileSystems = [ + "/" + "/mnt/disk1" + "/mnt/disk2" ]; }; - - programs = { - mtr.enable = true; - neovim = { - enable = true; - vimAlias = true; - }; - gnupg.agent = { - enable = true; - enableSSHSupport = true; - }; - geary = { enable = true; }; - steam = { - enable = true; - remotePlay.openFirewall = true; - dedicatedServer.openFirewall = true; - }; - }; - - services = { - printing = { - enable = true; - drivers = [ pkgs.hplip pkgs.hplipWithPlugin ]; - }; - # ipp-usb.enable = true; # usb scanner - avahi.enable = true; - avahi.nssmdns = true; - fstrim.enable = true; - # jellyfin = { - # enable = true; - # group = "jawz"; - # user = "jawz"; - # }; - btrfs.autoScrub = { - enable = true; - fileSystems = [ "/" "/mnt/disk1" "/mnt/disk2" ]; - }; - mediatomb.enable = true; - openssh = { - enable = true; - ports = [ 25152 ]; - passwordAuthentication = false; - kbdInteractiveAuthentication = false; - startWhenNeeded = true; - listenAddresses = [{ + # mediatomb.enable = true; + openssh = { + enable = true; + ports = [ 25152 ]; + passwordAuthentication = false; + kbdInteractiveAuthentication = false; + startWhenNeeded = true; + listenAddresses = [ + { addr = "0.0.0.0"; port = 25152; - }]; - }; - # udev.packages = with pkgs; [ gnome.gnome-settings-daemon ]; - emacs = { - enable = true; - defaultEditor = true; - package = pkgs.emacs; - }; + } + ]; }; + # udev.packages = with pkgs; [ gnome.gnome-settings-daemon ]; + emacs = { + enable = true; + defaultEditor = true; + package = pkgs.emacs; + }; +}; - systemd.services = { - "docker-compose" = { - enable = true; - restartIfChanged = true; - description = "Start docker-compose servers"; - after = [ "docker.service" "docker.socket" ]; - requires = [ "docker.service" "docker.socket" ]; - wantedBy = [ "default.target" ]; - environment = { - FILE = "/home/jawz/Development/Docker/docker-compose.yml"; - }; - path = [ pkgs.docker-compose ]; - serviceConfig = { - Restart = "on-failure"; - RestartSec = 30; - ExecStart = - "${pkgs.docker-compose}/bin/docker-compose -f \${FILE} up --remove-orphans"; - ExecStop = "${pkgs.docker-compose}/bin/docker-compose -f \${FILE} down"; - }; +systemd.services = { + "docker-compose" = { + enable = true; + restartIfChanged = true; + description = "Start docker-compose servers"; + after = [ "docker.service" "docker.socket" ]; + requires = [ "docker.service" "docker.socket" ]; + wantedBy = [ "default.target" ]; + environment = { + FILE = "/home/jawz/Development/Docker/docker-compose.yml"; }; - "mateo-current" = { - enable = true; - restartIfChanged = true; - description = "current weather"; - wantedBy = [ "default.target" ]; - path = [ pkgs.bash pkgs.jq pkgs.curl mateo-current ]; - serviceConfig = { - Restart = "on-failure"; - WorkingDirectory = "/home/jawz/Development/Scripts/open-mateo"; - ExecStart = "${mateo-current}/bin/mateo-current"; - }; - }; - "mateo-forecast" = { - enable = true; - restartIfChanged = true; - description = "forecast weather"; - wantedBy = [ "default.target" ]; - path = [ pkgs.bash pkgs.jq pkgs.curl mateo-forecast ]; - serviceConfig = { - Restart = "on-failure"; - WorkingDirectory = "/home/jawz/Development/Scripts/open-mateo"; - ExecStart = "${mateo-forecast}/bin/mateo-forecast"; - }; - }; - "nextcloud_scrapsync" = { - description = "Sync scrapped files with nextcloud"; - wantedBy = [ "default.target" ]; - path = [ pkgs.bash nextcloud_scrapsync ]; - serviceConfig = { - RestartSec = 30; - ExecStart = "${nextcloud_scrapsync}/bin/nextcloud_scrapsync"; - }; + path = [ + pkgs.docker-compose + ]; + serviceConfig = { + Restart = "on-failure"; + RestartSec = 30; + ExecStart = "${pkgs.docker-compose}/bin/docker-compose -f \${FILE} up --remove-orphans"; + ExecStop = "${pkgs.docker-compose}/bin/docker-compose -f \${FILE} down"; }; }; - systemd.timers = { - "nextcloud_scrapsync" = { - enable = true; - description = "Sync scrapped files with nextcloud"; - wantedBy = [ "timers.target" ]; - timerConfig = { - OnCalendar = [ - "*-*-* 01:32:00" - "*-*-* 08:32:00" - "*-*-* 14:32:00" - "*-*-* 20:32:00" - ]; - RandomizedDelaySec = 30; - Persistent = true; - }; - }; - "mateo-current" = { - enable = true; - description = "Sync scrapped files with nextcloud"; - wantedBy = [ "timers.target" ]; - timerConfig = { - OnBootSec = "1m"; - OnUnitActiveSec = "1h"; - RandomizedDelaySec = 30; - Persistent = true; - }; - }; - "mateo-forecast" = { - enable = true; - description = "Sync scrapped files with nextcloud"; - wantedBy = [ "timers.target" ]; - timerConfig = { - OnCalendar = [ "*-*-* 06:05:00" "*-*-* 18:05:00" ]; - RandomizedDelaySec = 30; - Persistent = true; - }; + "nextcloud_scrapsync" = { + description = "Sync scrapped files with nextcloud"; + wantedBy = [ "default.target" ]; + path = [ + pkgs.bash + nextcloud_scrapsync + ]; + serviceConfig = { + RestartSec = 30; + ExecStart = "${nextcloud_scrapsync}/bin/nextcloud_scrapsync"; }; }; - systemd.user.services = { - "HentaiAtHome" = { - enable = true; - restartIfChanged = true; - description = "Run hentai@home server"; - wantedBy = [ "default.target" ]; - path = [ pkgs.HentaiAtHome ]; - serviceConfig = { - Restart = "on-failure"; - RestartSec = 30; - WorkingDirectory = "/mnt/hnbox"; - ExecStart = "${pkgs.HentaiAtHome}/bin/HentaiAtHome"; - }; - }; - "manage_library" = { - enable = true; - restartIfChanged = true; - description = "Run the manage library fish script"; - wantedBy = [ "default.target" ]; - path = [ pkgs.fish manage_library ]; - serviceConfig = { - Restart = "on-failure"; - RestartSec = 30; - ExecStart = "${manage_library}/bin/manage_library"; - }; +}; +systemd.timers = { + "nextcloud_scrapsync" = { + enable = true; + description = "Sync scrapped files with nextcloud"; + wantedBy = [ "timers.target" ]; + timerConfig = { + OnCalendar= [ + "*-*-* 01:32:00" + "*-*-* 08:32:00" + "*-*-* 14:32:00" + "*-*-* 20:32:00" + ]; + RandomizedDelaySec = 30; + Persistent = true; }; }; +}; +systemd.user.services = { + "HentaiAtHome" = { + enable = true; + restartIfChanged = true; + description = "Run hentai@home server"; + wantedBy = [ "default.target" ]; + path = [ + pkgs.HentaiAtHome + ]; + serviceConfig = { + Restart = "on-failure"; + RestartSec = 30; + WorkingDirectory="/mnt/hnbox"; + ExecStart = "${pkgs.HentaiAtHome}/bin/HentaiAtHome"; + }; + }; + "manage_library" = { + enable = true; + restartIfChanged = true; + description = "Run the manage library fish script"; + wantedBy = [ "default.target" ]; + path = [ + pkgs.fish + manage_library + ]; + serviceConfig = { + Restart = "on-failure"; + RestartSec = 30; + ExecStart = "${manage_library}/bin/manage_library"; + }; + }; +}; - # networking.firewall.allowedTCPPorts = [ ... ]; - # networking.firewall.allowedUDPPorts = [ ... ]; - # Or disable the firewall altogether. - networking.firewall.enable = false; +# networking.firewall.allowedTCPPorts = [ ... ]; +# networking.firewall.allowedUDPPorts = [ ... ]; +# Or disable the firewall altogether. +networking.firewall.enable = false; - system.copySystemConfiguration = true; - nix.gc = { - automatic = true; - dates = "weekly"; - }; +system.copySystemConfiguration = true; +nix.gc = { + automatic = true; + dates = "weekly"; +}; - system.stateVersion = VERSION; +system.stateVersion = VERSION; } diff --git a/configuration.org b/configuration.org index 63a4df0..ad67187 100755 --- a/configuration.org +++ b/configuration.org @@ -50,10 +50,6 @@ let }; nextcloud_scrapsync = pkgs.writeScriptBin "nextcloud_scrapsync" (builtins.readFile ./scripts/nextcloud_scrapsync.sh); - mateo-current = pkgs.writeScriptBin - "mateo-current" (builtins.readFile ./scripts/current.sh); - mateo-forecast = pkgs.writeScriptBin - "mateo-forecast" (builtins.readFile ./scripts/forecast.sh); manage_library = pkgs.writeScriptBin "manage_library" (builtins.readFile ./scripts/manage_library.fish); ffmpeg4discord = pkgs.writeScriptBin @@ -374,9 +370,6 @@ lm_sensors # for extension, displays cpu temp nextcloud_scrapsync ffmpeg4discord manage_library -mateo-current -mateo-forecast -jq #+end_src ** DEVELOPMENT PACKAGES @@ -927,40 +920,6 @@ systemd.services = { ExecStop = "${pkgs.docker-compose}/bin/docker-compose -f \${FILE} down"; }; }; - "mateo-current" = { - enable = true; - restartIfChanged = true; - description = "current weather"; - wantedBy = [ "default.target" ]; - path = [ - pkgs.bash - pkgs.jq - pkgs.curl - mateo-current - ]; - serviceConfig = { - Restart = "on-failure"; - WorkingDirectory="/home/jawz/Development/Scripts/open-mateo"; - ExecStart = "${mateo-current}/bin/mateo-current"; - }; - }; - "mateo-forecast" = { - enable = true; - restartIfChanged = true; - description = "forecast weather"; - wantedBy = [ "default.target" ]; - path = [ - pkgs.bash - pkgs.jq - pkgs.curl - mateo-forecast - ]; - serviceConfig = { - Restart = "on-failure"; - WorkingDirectory="/home/jawz/Development/Scripts/open-mateo"; - ExecStart = "${mateo-forecast}/bin/mateo-forecast"; - }; - }; "nextcloud_scrapsync" = { description = "Sync scrapped files with nextcloud"; wantedBy = [ "default.target" ]; @@ -990,30 +949,6 @@ systemd.timers = { Persistent = true; }; }; - "mateo-current" = { - enable = true; - description = "Sync scrapped files with nextcloud"; - wantedBy = [ "timers.target" ]; - timerConfig = { - OnBootSec = "1m"; - OnUnitActiveSec = "1h"; - RandomizedDelaySec = 30; - Persistent = true; - }; - }; - "mateo-forecast" = { - enable = true; - description = "Sync scrapped files with nextcloud"; - wantedBy = [ "timers.target" ]; - timerConfig = { - OnCalendar= [ - "*-*-* 06:05:00" - "*-*-* 18:05:00" - ]; - RandomizedDelaySec = 30; - Persistent = true; - }; - }; }; systemd.user.services = { "HentaiAtHome" = {