2024-11-11 05:01:57 +00:00
# Edit this configuration file to define what should be installed on
# your system. Help is available in the configuration.nix(5) man page
# and in the NixOS manual (accessible by running ‘ nixos-help’ ).
{ config , pkgs , . . . }:
{
imports =
[ # Include the results of the hardware scan.
./hardware-configuration.nix
# <home-manager/nixos>
] ;
2024-11-12 13:39:04 +00:00
# List packages installed in system profile. To search, run:
2024-12-30 21:29:10 +00:00
# $ nix search example
2024-11-12 13:39:04 +00:00
environment . systemPackages = with pkgs ; [
# vim # Do not forget to add an editor to edit configuration.nix! The Nano editor is also installed by default.
2024-12-19 11:23:11 +00:00
ansible
2025-01-14 01:40:16 +00:00
authenticator # 2-factor auth, it's for Gnome but it's the only good one (can scan in from the phone etc)
2024-11-19 04:27:05 +00:00
birdtray
2024-11-12 13:39:04 +00:00
bitwarden-cli
bitwarden-desktop
bitwarden-menu
brave
btop
calibre
2024-11-14 14:38:01 +00:00
contrast
2024-11-12 13:39:04 +00:00
curl
ddev
diffr
2025-01-14 01:40:37 +00:00
dig
2024-12-17 20:03:59 +00:00
dmidecode
2024-11-12 13:39:04 +00:00
docker
2024-12-31 22:39:18 +00:00
# dog # breaks build
espanso-wayland # breaks build???
2025-01-14 01:40:55 +00:00
et # 'egg timer' command-line-ish timer app; mpris-timer is a Gnome graphical alternative in the surprisingly sparse set of timer options (cannot find one built into KDE?)
exif
2024-11-12 13:39:04 +00:00
fish
fishPlugins . done
firefoxpwa
2024-12-25 00:24:32 +00:00
floorp
2024-11-12 13:39:04 +00:00
fsearch
2024-12-25 00:25:09 +00:00
getxbook
2024-12-31 22:39:18 +00:00
# gimp-with-plugins # Currently breaks bulid
2024-11-12 13:39:04 +00:00
git
git-open
gnucash
2024-11-14 20:26:43 +00:00
gnumake
2025-01-14 01:41:56 +00:00
handbrake
2024-12-13 18:03:54 +00:00
htop
2024-11-28 16:25:44 +00:00
hunspell
hunspellDicts . en_US-large
hunspellDicts . es_MX
2024-12-25 00:25:47 +00:00
# jitsi - this is unusuable with a regular Jitsi Meet server like May First?
2024-12-31 22:39:18 +00:00
# jitsi-meet-electron # currently breaks build
2024-12-04 03:39:28 +00:00
jq
2024-12-20 19:39:07 +00:00
just
2025-01-14 01:41:56 +00:00
kdePackages . audex
2024-11-12 13:39:04 +00:00
kdePackages . filelight
kdePackages . isoimagewriter
2024-12-15 01:38:53 +00:00
kdePackages . kasts
2024-12-13 18:03:54 +00:00
kdePackages . kcalc
kdePackages . kcolorchooser
2024-11-30 14:41:40 +00:00
# kdePackages.kdenetwork-filesharing
# kdePackages.keysmith
2024-11-12 13:39:04 +00:00
kdePackages . konqueror
2024-12-13 18:03:54 +00:00
kdePackages . kontrast
2024-11-14 00:40:34 +00:00
kdePackages . krecorder
2024-12-02 02:15:07 +00:00
kdePackages . kruler
2024-12-31 22:39:18 +00:00
kdePackages . kweather
2024-12-26 06:40:44 +00:00
kdePackages . neochat # For matrix but relying on insecure olm-3.2.16
2024-11-12 13:39:04 +00:00
kdePackages . partitionmanager
keepassxc
2024-11-26 17:36:16 +00:00
kirc
2025-01-14 01:42:13 +00:00
kupfer # a nice launcher, installed because my main desktop screen is broken and i needed a way to see what apps i was picking
2024-12-17 20:03:59 +00:00
libinput
2025-01-14 01:44:15 +00:00
libreoffice-qt6-still # this is basically unusable, graphics all mis-aligned
2024-11-15 20:11:43 +00:00
# light
2024-12-17 20:03:59 +00:00
lshw
2024-11-12 13:39:04 +00:00
magic-wormhole
2024-12-13 18:03:54 +00:00
md2pdf
2024-12-25 00:26:15 +00:00
mdbook
2024-11-12 13:39:04 +00:00
meld
mkcert
2024-11-28 16:27:48 +00:00
mmv
2024-12-31 22:40:07 +00:00
neovim # aka nvim
2024-11-12 13:39:04 +00:00
nextcloud-client
2024-12-26 06:40:44 +00:00
nheko # For matrix but relying on insecure olm-3.2.16
2024-11-12 13:39:04 +00:00
# nfs-utils
nix-search-cli
2025-01-14 01:44:15 +00:00
onlyoffice-desktopeditors
openshot-qt # Video editing, http://www.openshot.org/
2024-12-25 00:26:38 +00:00
peruse # Read comic books, zines, graphic novels a bit more easily
2025-01-14 01:44:48 +00:00
photini # digital photograph metadata editing
2024-11-12 13:39:04 +00:00
php # does PHP 8.2 currently and there's php81, php83, and php84 alternatives
2024-12-19 11:31:41 +00:00
php82Packages . composer
2025-01-14 01:45:55 +00:00
# php84Packages.composer ansible_2_16
2024-11-25 17:54:46 +00:00
( python3 . withPackages ( ps : with ps ; [ numpy pandas python-dotenv ] ) ) # https://github.com/NixOS/nixpkgs/blob/master/doc/languages-frameworks/python.section.md#environment-defined-in-etcnixosconfigurationnix-environment-defined-in-etcnixosconfigurationnix (note this is literally the last thing they wanted me to do, would rather it not be global)
2024-12-13 18:03:54 +00:00
poppins
2024-12-20 01:46:03 +00:00
postgresql
2024-12-20 19:27:38 +00:00
qrscan
2024-12-18 02:28:15 +00:00
radiotray-ng # Prefer shortwave for real radio
2024-11-12 13:39:04 +00:00
recoll
2024-11-15 20:13:39 +00:00
reveal-md
2024-12-17 20:04:26 +00:00
rink
2024-11-19 17:19:45 +00:00
rofi
2024-11-12 13:39:04 +00:00
samba
2024-12-31 22:40:07 +00:00
sassc # Convenient to use directly, though it is deprecated in favor of dart-sass i think
2024-12-17 20:05:19 +00:00
shortwave
2025-01-14 01:46:23 +00:00
shotwell # Even though i'm not on Gnome anymore, really don't see the need to switch to KPhotoAlbum (NixOS has to download more for that anyway). The other option is digikam and if getting into RAW and editing more, darktable
2024-11-12 13:39:04 +00:00
signal-desktop
2024-12-17 20:05:19 +00:00
slack
2024-12-25 00:26:59 +00:00
sly # simple image editing
2024-11-12 13:39:04 +00:00
strawberry-qt6
2024-12-04 14:21:03 +00:00
textpieces
2024-11-12 13:39:04 +00:00
thunderbird
2024-12-25 00:27:14 +00:00
toot
2024-12-13 18:03:54 +00:00
tor-browser
2024-11-14 20:25:26 +00:00
transmission_4-qt
2024-11-12 13:39:04 +00:00
trashy
2024-12-25 00:27:14 +00:00
tuba
2024-12-31 22:40:27 +00:00
ungoogled-chromium
2024-11-16 00:27:44 +00:00
vimPlugins . vim-fetch
2024-11-12 13:39:04 +00:00
vimPlugins . vim-wayland-clipboard
wget
whois
2024-11-14 01:07:54 +00:00
vlc
2024-11-12 13:39:04 +00:00
vscodium
2024-12-17 20:04:26 +00:00
# wcalc - command-line calculator but rink does that plus unit conversion!
2024-11-12 13:39:04 +00:00
wl-clipboard-rs
2024-12-13 18:03:54 +00:00
xorg . xkill
2024-11-14 01:07:54 +00:00
yt-dlp
2024-11-12 13:39:04 +00:00
zoxide
zulip
zulip-term
] ;
environment . pathsToLink = [ " / s h a r e / f i s h " ] ;
2024-12-04 02:10:01 +00:00
# Add ~/.local/bin/ to $PATH
environment . localBinInPath = true ;
2024-12-04 04:13:03 +00:00
environment . homeBinInPath = true ;
# Only this works, from https://github.com/NixOS/nixpkgs/issues/157383#issuecomment-1186081648
environment . shellInit = ''
export PATH = " $ P A T H : $ H O M E / . l o c a l / b i n "
'' ;
2024-12-04 02:10:01 +00:00
2024-11-20 16:46:04 +00:00
# Needed for Slack but probably helps other stuff too.
# See https://wiki.nixos.org/wiki/Slack
environment . sessionVariables . NIXOS_OZONE_WL = " 1 " ;
2024-11-12 13:39:04 +00:00
# Make it possible for ddev to modify the /etc/hosts file.
# Otherwise you'll have to manually change the
# hosts configuration after creating a new ddev project.
environment . etc . hosts . mode = " 0 6 4 4 " ;
2024-11-11 05:01:57 +00:00
# Bootloader.
boot . loader . systemd-boot . enable = true ;
boot . loader . efi . canTouchEfiVariables = true ;
networking . hostName = " n i x o s " ; # Define your hostname.
# networking.wireless.enable = true; # Enables wireless support via wpa_supplicant.
# Configure network proxy if necessary
# networking.proxy.default = "http://user:password@proxy:port/";
# networking.proxy.noProxy = "127.0.0.1,localhost,internal.domain";
# Enable networking
networking . networkmanager . enable = true ;
# Set your time zone.
time . timeZone = " A m e r i c a / N e w _ Y o r k " ;
# Select internationalisation properties.
i18n . defaultLocale = " e n _ U S . U T F - 8 " ;
i18n . extraLocaleSettings = {
LC_ADDRESS = " e n _ U S . U T F - 8 " ;
LC_IDENTIFICATION = " e n _ U S . U T F - 8 " ;
LC_MEASUREMENT = " e n _ U S . U T F - 8 " ;
LC_MONETARY = " e n _ U S . U T F - 8 " ;
LC_NAME = " e n _ U S . U T F - 8 " ;
LC_NUMERIC = " e n _ U S . U T F - 8 " ;
LC_PAPER = " e n _ U S . U T F - 8 " ;
LC_TELEPHONE = " e n _ U S . U T F - 8 " ;
LC_TIME = " e n _ U S . U T F - 8 " ;
} ;
2024-12-04 04:13:36 +00:00
# Just make bin/bash work, see https://github.com/Mic92/envfs
# via the long, sad https://discourse.nixos.org/t/add-bin-bash-to-avoid-unnecessary-pain/5673/37
services . envfs . enable = true ;
2024-11-11 05:01:57 +00:00
# Via https://github.com/NixOS/nixos-hardware/tree/master/framework
services . fwupd . enable = true ;
services . fwupd . extraRemotes = [ " l v f s - t e s t i n g " ] ;
# Might be necessary once to make the update succeed
services . fwupd . uefiCapsuleSettings . DisableCapsuleUpdateOnDisk = true ;
# Enable the X11 windowing system.
# You can disable this if you're only using the Wayland session.
services . xserver . enable = true ;
# Enable the KDE Plasma Desktop Environment.
services . displayManager . sddm . enable = true ;
services . desktopManager . plasma6 . enable = true ;
# Configure keymap in X11
services . xserver . xkb = {
layout = " u s " ;
variant = " d v o r a k - a l t - i n t l " ;
} ;
# Configure console keymap
console . keyMap = " d v o r a k " ;
# Enable CUPS to print documents.
2024-11-30 14:41:40 +00:00
# services.printing.enable = true;
2024-11-11 05:01:57 +00:00
# Enable sound with pipewire.
hardware . pulseaudio . enable = false ;
security . rtkit . enable = true ;
# Enable samba network filesharing in Dolphin
# security.wrappers = {
# mount.source = "${pkgs.utillinux}/bin/mount";
# umount.source = "${pkgs.utillinux}/bin/umount";
#};
#security.wrappers."mount.nfs".source = "${pkgs.nfs-utils.out}/bin/mount.nfs";
services . pipewire = {
enable = true ;
alsa . enable = true ;
alsa . support32Bit = true ;
pulse . enable = true ;
# If you want to use JACK applications, uncomment this
#jack.enable = true;
# use the example session manager (no others are packaged yet so this is enabled by default,
# no need to redefine it in your config for now)
#media-session.enable = true;
} ;
# Install & enable docker.
virtualisation . docker . enable = true ;
# Enable touchpad support (enabled default in most desktopManager).
# services.xserver.libinput.enable = true;
# Define a user account. Don't forget to set a password with ‘ passwd’ .
users . users . mlncn = {
isNormalUser = true ;
description = " m l n c n " ;
extraGroups = [ " n e t w o r k m a n a g e r " " w h e e l " " d o c k e r " ] ;
packages = with pkgs ; [
2024-12-04 02:09:31 +00:00
discord
2024-11-11 05:01:57 +00:00
kdePackages . kate
logseq
] ;
# Per Chris for SSHing from the old machine to here
openssh . authorizedKeys . keys = [ " s s h - e d 2 5 5 1 9 s s h - e d 2 5 5 1 9 A A A A C 3 N z a C 1 l Z D I 1 N T E 5 A A A A I I c / p c 2 o L 8 0 X j I e e a z z T 5 Y O C r E a P W 7 u o h A / q l m G r 5 c M 6 m l n c n @ d 6 4 " ] ;
} ;
# home-manager.users.mlncn = { pkgs, ... }: {
# home.packages = [
# pkgs.atool
# pkgs.httpie
# ];
# programs.bash.enable = true;
# programs.fish.enable = true;
# The state version is required and should stay at the version you
# originally installed.
# home.stateVersion = "24.05";
# };
# home-manager.useUserPackages = true;
# home-manager.useGlobalPkgs = true;
# Install firefox.
programs . firefox . enable = true ;
programs . firefox . nativeMessagingHosts . packages = [ pkgs . firefoxpwa ] ;
programs . fish . enable = true ;
programs . bash = {
interactiveShellInit = ''
if [ [ $ ( $ { pkgs . procps } /bin/ps - - no-header - - pid = $ PPID - - format = comm ) != " f i s h " && - z '' ${ BASH_EXECUTION_STRING } ] ]
then
shopt - q login_shell && LOGIN_OPTION = ' - - login' || LOGIN_OPTION = " "
exec $ { pkgs . fish } /bin/fish $ LOGIN_OPTION
fi
'' ;
} ;
# Allow unfree packages
nixpkgs . config . allowUnfree = true ;
# TODO remove this when Logseq gets its act together
nixpkgs . config . permittedInsecurePackages = [
" e l e c t r o n - 2 7 . 3 . 1 1 "
2024-12-26 06:40:44 +00:00
" o l m - 3 . 2 . 1 6 "
2024-11-11 05:01:57 +00:00
] ;
# Some programs need SUID wrappers, can be configured further or are
# started in user sessions.
# programs.mtr.enable = true;
# programs.gnupg.agent = {
# enable = true;
# enableSSHSupport = true;
# };
# List services that you want to enable:
# Enable the OpenSSH daemon.
services . openssh . enable = true ;
# Open ports in the firewall.
# networking.firewall.allowedTCPPorts = [ ... ];
# networking.firewall.allowedUDPPorts = [ ... ];
# Or disable the firewall altogether.
# networking.firewall.enable = false;
networking . firewall . allowedTCPPorts = [ 9003 ] ;
# This value determines the NixOS release from which the default
# settings for stateful data, like file locations and database versions
# on your system were taken. It‘ s perfectly fine and recommended to leave
# this value at the release version of the first install of this system.
# Before changing this value read the documentation for this option
# (e.g. man configuration.nix or on https://nixos.org/nixos/options.html).
system . stateVersion = " 2 4 . 0 5 " ; # Did you read the comment?
}