mirror of
https://github.com/caperren/nixos-configs.git
synced 2025-11-09 04:01:15 +00:00
Deduplicate all applications and system settings
This commit is contained in:
8
modules/application-groups/3d-design.nix
Normal file
8
modules/application-groups/3d-design.nix
Normal file
@@ -0,0 +1,8 @@
|
||||
{ config, pkgs, ... }:
|
||||
{
|
||||
environment.systemPackages = with pkgs; [
|
||||
prusa-slicer
|
||||
freecad
|
||||
];
|
||||
|
||||
}
|
||||
5
modules/application-groups/android.nix
Normal file
5
modules/application-groups/android.nix
Normal file
@@ -0,0 +1,5 @@
|
||||
{ config, pkgs, ... }:
|
||||
{
|
||||
programs.adb.enable = true;
|
||||
virtualisation.waydroid.enable = true;
|
||||
}
|
||||
7
modules/application-groups/downloads.nix
Normal file
7
modules/application-groups/downloads.nix
Normal file
@@ -0,0 +1,7 @@
|
||||
{ pkgs, ... }:
|
||||
{
|
||||
environment.systemPackages = with pkgs; [
|
||||
transmission_4-qt
|
||||
yt-dlp
|
||||
];
|
||||
}
|
||||
@@ -1,5 +1,32 @@
|
||||
{ ... }: {
|
||||
imports = [
|
||||
../applications/steam.nix
|
||||
{ pkgs, ... }:
|
||||
{
|
||||
# Support steam hardware like the index and steam controller
|
||||
hardware.steam-hardware.enable = true;
|
||||
|
||||
# Steam
|
||||
programs.steam = {
|
||||
enable = true;
|
||||
remotePlay.openFirewall = true;
|
||||
dedicatedServer.openFirewall = true;
|
||||
gamescopeSession.enable = true;
|
||||
};
|
||||
|
||||
# Valve's micro-compositor
|
||||
programs.gamescope = {
|
||||
enable = true;
|
||||
capSysNice = true;
|
||||
};
|
||||
|
||||
# Open source OpenXR runtime for VR
|
||||
services.monado = {
|
||||
enable = true;
|
||||
defaultRuntime = true;
|
||||
highPriority = true;
|
||||
};
|
||||
|
||||
environment.systemPackages = with pkgs; [
|
||||
bs-manager
|
||||
heroic
|
||||
monado
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
4
modules/application-groups/homelab.nix
Normal file
4
modules/application-groups/homelab.nix
Normal file
@@ -0,0 +1,4 @@
|
||||
{ pkgs, ... }:
|
||||
{
|
||||
services.meshcentral.enable = true;
|
||||
}
|
||||
39
modules/application-groups/media.nix
Normal file
39
modules/application-groups/media.nix
Normal file
@@ -0,0 +1,39 @@
|
||||
{ config, pkgs, ... }:
|
||||
{
|
||||
boot = {
|
||||
# Make v4l2loopback kernel module available to NixOS.
|
||||
extraModulePackages = with config.boot.kernelPackages; [
|
||||
v4l2loopback
|
||||
];
|
||||
# Activate kernel module(s).
|
||||
kernelModules = [
|
||||
# Virtual camera.
|
||||
"v4l2loopback"
|
||||
# Virtual Microphone. Custom DroidCam v4l2loopback driver needed for audio.
|
||||
# "snd-aloop"
|
||||
];
|
||||
};
|
||||
|
||||
boot.extraModprobeConfig = ''
|
||||
# exclusive_caps: Skype, Zoom, Teams etc. will only show device when actually streaming
|
||||
# card_label: Name of virtual camera, how it'll show up in Skype, Zoom, Teams
|
||||
# https://github.com/umlaeute/v4l2loopback
|
||||
options v4l2loopback exclusive_caps=1 card_label="Virtual Camera"
|
||||
'';
|
||||
|
||||
environment.systemPackages = with pkgs; [
|
||||
deadbeef
|
||||
vlc
|
||||
sox
|
||||
audacity
|
||||
glava
|
||||
spotify-player
|
||||
projectm_3
|
||||
obs-studio
|
||||
darktable
|
||||
|
||||
# Encountering build failures
|
||||
# plex-desktop
|
||||
];
|
||||
|
||||
}
|
||||
8
modules/application-groups/pcb-design.nix
Normal file
8
modules/application-groups/pcb-design.nix
Normal file
@@ -0,0 +1,8 @@
|
||||
{ config, pkgs, ... }:
|
||||
{
|
||||
environment.systemPackages = with pkgs; [
|
||||
kicad
|
||||
pcb2gcode
|
||||
];
|
||||
|
||||
}
|
||||
6
modules/application-groups/productivity.nix
Normal file
6
modules/application-groups/productivity.nix
Normal file
@@ -0,0 +1,6 @@
|
||||
{ pkgs, ... }:
|
||||
{
|
||||
environment.systemPackages = with pkgs; [
|
||||
obsidian
|
||||
];
|
||||
}
|
||||
41
modules/application-groups/programming.nix
Normal file
41
modules/application-groups/programming.nix
Normal file
@@ -0,0 +1,41 @@
|
||||
{ config, pkgs, ... }:
|
||||
{
|
||||
environment.systemPackages = with pkgs; [
|
||||
vscode-with-extensions
|
||||
nixfmt-rfc-style
|
||||
platformio
|
||||
jetbrains-toolbox
|
||||
arduino-ide
|
||||
python311Full
|
||||
gcc
|
||||
nodejs
|
||||
stm32cubemx
|
||||
stm32flash
|
||||
python3Full
|
||||
nix-update
|
||||
nixos-generators
|
||||
teensy-udev-rules
|
||||
];
|
||||
|
||||
services.udev.extraRules = ''
|
||||
# ST-LINK V2
|
||||
SUBSYSTEMS=="usb", ATTRS{idVendor}=="0483", ATTRS{idProduct}=="3748", MODE="600", TAG+="uaccess", SYMLINK+="stlinkv2_%n"
|
||||
|
||||
# ST-LINK V2.1
|
||||
SUBSYSTEMS=="usb", ATTRS{idVendor}=="0483", ATTRS{idProduct}=="374b", MODE="600", TAG+="uaccess", SYMLINK+="stlinkv2-1_%n"
|
||||
SUBSYSTEMS=="usb", ATTRS{idVendor}=="0483", ATTRS{idProduct}=="3752", MODE="600", TAG+="uaccess", SYMLINK+="stlinkv2-1_%n"
|
||||
|
||||
# ST-LINK V3
|
||||
SUBSYSTEMS=="usb", ATTRS{idVendor}=="0483", ATTRS{idProduct}=="374d", MODE="600", TAG+="uaccess", SYMLINK+="stlinkv3loader_%n"
|
||||
SUBSYSTEMS=="usb", ATTRS{idVendor}=="0483", ATTRS{idProduct}=="374e", MODE="600", TAG+="uaccess", SYMLINK+="stlinkv3_%n"
|
||||
SUBSYSTEMS=="usb", ATTRS{idVendor}=="0483", ATTRS{idProduct}=="374f", MODE="600", TAG+="uaccess", SYMLINK+="stlinkv3_%n"
|
||||
SUBSYSTEMS=="usb", ATTRS{idVendor}=="0483", ATTRS{idProduct}=="3753", MODE="600", TAG+="uaccess", SYMLINK+="stlinkv3_%n"
|
||||
|
||||
# CP2101 - CP 2104
|
||||
SUBSYSTEMS=="usb", ATTRS{idVendor}=="10c4", ATTRS{idProduct}=="ea60", MODE="600", TAG+="uaccess", SYMLINK+="usb2ser_%n"
|
||||
|
||||
# ATEN UC-232A
|
||||
SUBSYSTEMS=="usb", ATTRS{idVendor}=="0557", ATTRS{idProduct}=="2008", MODE="600", TAG+="uaccess", SYMLINK+="usb2ser_aten_%n"
|
||||
'';
|
||||
|
||||
}
|
||||
10
modules/application-groups/sdr.nix
Normal file
10
modules/application-groups/sdr.nix
Normal file
@@ -0,0 +1,10 @@
|
||||
{ config, pkgs, ... }:
|
||||
{
|
||||
hardware.rtl-sdr.enable = true;
|
||||
|
||||
environment.systemPackages = with pkgs; [
|
||||
soapysdr
|
||||
soapyrtlsdr
|
||||
];
|
||||
|
||||
}
|
||||
9
modules/application-groups/social.nix
Normal file
9
modules/application-groups/social.nix
Normal file
@@ -0,0 +1,9 @@
|
||||
{ pkgs, ... }:
|
||||
{
|
||||
|
||||
environment.systemPackages = with pkgs; [
|
||||
telegram-desktop
|
||||
discord
|
||||
];
|
||||
|
||||
}
|
||||
57
modules/application-groups/system-utilities.nix
Normal file
57
modules/application-groups/system-utilities.nix
Normal file
@@ -0,0 +1,57 @@
|
||||
{ config, pkgs, ... }:
|
||||
{
|
||||
programs.thunar.enable = true;
|
||||
programs.thunar.plugins = with pkgs.xfce; [
|
||||
thunar-archive-plugin
|
||||
thunar-volman
|
||||
];
|
||||
services.gvfs.enable = true; # Mount, trash, and other functionalities
|
||||
services.tumbler.enable = true; # Thumbnail support for images
|
||||
|
||||
programs.ydotool.enable = true;
|
||||
|
||||
services.openssh.enable = true;
|
||||
services.printing.enable = true;
|
||||
|
||||
hardware.logitech.wireless.enable = true;
|
||||
hardware.logitech.wireless.enableGraphical = true;
|
||||
hardware.keyboard.qmk.enable = true;
|
||||
|
||||
services.hardware.openrgb.enable = true;
|
||||
|
||||
environment.systemPackages = with pkgs; [
|
||||
kitty
|
||||
lf
|
||||
git
|
||||
htop
|
||||
iftop
|
||||
iotop
|
||||
util-linux
|
||||
usbutils
|
||||
dnsutils
|
||||
unzip
|
||||
killall
|
||||
wget
|
||||
jq
|
||||
speedcrunch
|
||||
gparted
|
||||
ffmpeg-full
|
||||
xfce.mousepad
|
||||
imagemagick
|
||||
nvtopPackages.full
|
||||
ncdu
|
||||
s-tui
|
||||
nmap
|
||||
pciutils
|
||||
desktop-file-utils
|
||||
rpi-imager
|
||||
rpiboot
|
||||
streamdeck-ui
|
||||
scrcpy
|
||||
openrgb-with-all-plugins
|
||||
networkmanagerapplet
|
||||
rofi-bluetooth
|
||||
networkmanager
|
||||
];
|
||||
|
||||
}
|
||||
12
modules/application-groups/virtualization.nix
Normal file
12
modules/application-groups/virtualization.nix
Normal file
@@ -0,0 +1,12 @@
|
||||
{ config, pkgs, ... }:
|
||||
{
|
||||
virtualisation.podman = {
|
||||
enable = true;
|
||||
dockerCompat = true;
|
||||
};
|
||||
|
||||
environment.systemPackages = with pkgs; [
|
||||
distrobox
|
||||
];
|
||||
|
||||
}
|
||||
8
modules/application-groups/web.nix
Normal file
8
modules/application-groups/web.nix
Normal file
@@ -0,0 +1,8 @@
|
||||
{ config, pkgs, ... }:
|
||||
{
|
||||
programs.firefox.enable = true;
|
||||
|
||||
environment.systemPackages = with pkgs; [
|
||||
google-chrome
|
||||
];
|
||||
}
|
||||
Reference in New Issue
Block a user