Misc optimizations

This commit is contained in:
2025-12-29 01:49:59 -07:00
parent b6d9e944d0
commit a4e61d4446
6 changed files with 77 additions and 37 deletions

View File

@@ -22,43 +22,7 @@ help:
@echo " make edit - edit settings.nix"
init:
@if [ -f "$(SETTINGS)" ]; then \
echo "$(YELLOW)settings.nix exists. overwrite? [y/N]$(NC)"; \
read -r confirm; \
if [ "$$confirm" != "y" ] && [ "$$confirm" != "Y" ]; then \
echo "keeping existing settings"; \
exit 0; \
fi; \
fi
@username=$$(whoami); \
userdesc=$$(getent passwd $$username | cut -d: -f5 | cut -d, -f1); \
userdesc=$${userdesc:-$$username}; \
echo "user: $$username ($$userdesc)"; \
echo ""; \
echo "hostname:"; \
read -r hostname; \
echo "timezone [America/Edmonton]:"; \
read -r tz; \
tz=$${tz:-America/Edmonton}; \
echo "locale [en_CA.UTF-8]:"; \
read -r locale; \
locale=$${locale:-en_CA.UTF-8}; \
echo ""; \
echo "{" > $(SETTINGS); \
echo " hostname = \"$$hostname\";" >> $(SETTINGS); \
echo " username = \"$$username\";" >> $(SETTINGS); \
echo " userDescription = \"$$userdesc\";" >> $(SETTINGS); \
echo " timezone = \"$$tz\";" >> $(SETTINGS); \
echo " locale = \"$$locale\";" >> $(SETTINGS); \
echo " userGroups = [ \"networkmanager\" \"wheel\" \"docker\" \"plugdev\" ];" >> $(SETTINGS); \
echo "}" >> $(SETTINGS); \
echo "wrote settings.nix"
@if [ -f "/etc/nixos/hardware-configuration.nix" ]; then \
cp /etc/nixos/hardware-configuration.nix $(REPO_DIR)/hardware-configuration.nix; \
echo "copied hardware-configuration.nix"; \
else \
echo "$(YELLOW)no hardware-configuration.nix found - run nixos-generate-config first$(NC)"; \
fi
@./scripts/init.sh
@$(MAKE) --no-print-directory link
@echo ""
@echo "done. run 'make rebuild' when ready"

View File

@@ -10,6 +10,7 @@
"nix:push" = "cd /etc/nixos && git add -A && git commit -m \"$(date -u +%s)\" && git push";
"nix:pull" = "cd /etc/nixos && git pull";
"fixaudio" = "systemctl --user restart pipewire pipewire-pulse wireplumber";
"nf" = "neofetch";
};
}

View File

@@ -9,6 +9,8 @@
alsa.enable = true;
alsa.support32Bit = true;
pulse.enable = true;
jack.enable = true;
wireplumber.enable = true;
};
services.pipewire.extraConfig.pipewire."92-low-latency" = {

View File

@@ -15,4 +15,12 @@
boot.tmp.useTmpfs = true;
boot.tmp.tmpfsSize = "4G";
boot.kernel.sysctl = {
"net.ipv4.conf.all.log_martians" = 1;
"net.ipv4.conf.all.rp_filter" = 1;
"net.ipv4.conf.default.log_martians" = 1;
"net.ipv4.conf.default.rp_filter" = 1;
"net.ipv4.icmp_echo_ignore_broadcasts" = 1;
};
}

View File

@@ -11,4 +11,9 @@ in
description = settings.userDescription;
extraGroups = settings.userGroups;
};
# Security
security.sudo.execWheelOnly = true;
security.audit.enable = true;
security.auditd.enable = true;
}

60
scripts/init.sh Executable file
View File

@@ -0,0 +1,60 @@
#!/usr/bin/env bash
SETTINGS="settings.nix"
REPO_DIR=$(pwd)
GREEN='\033[0;32m'
YELLOW='\033[0;33m'
RED='\033[0;31m'
NC='\033[0m' # No Color
# 1. Generate settings.nix
if [ -f "$SETTINGS" ]; then
echo -e "${YELLOW}settings.nix exists. overwrite? [y/N]${NC}"
read -r confirm
if [[ "$confirm" != "y" && "$confirm" != "Y" ]]; then
echo "keeping existing settings"
else
GENERATE=true
fi
else
GENERATE=true
fi
if [ "$GENERATE" = true ]; then
username=$(whoami)
userdesc=$(getent passwd "$username" | cut -d: -f5 | cut -d, -f1)
userdesc=${userdesc:-$username}
echo "user: $username ($userdesc)"
echo ""
echo "hostname:"
read -r hostname
echo "timezone [America/Edmonton]:"
read -r tz
tz=${tz:-America/Edmonton}
echo "locale [en_CA.UTF-8]:"
read -r locale
locale=${locale:-en_CA.UTF-8}
echo ""
echo "{" > "$SETTINGS"
echo " hostname = \"$hostname\";" >> "$SETTINGS"
echo " username = \"$username\";" >> "$SETTINGS"
echo " userDescription = \"$userdesc\";" >> "$SETTINGS"
echo " timezone = \"$tz\";" >> "$SETTINGS"
echo " locale = \"$locale\";" >> "$SETTINGS"
echo " userGroups = [ \"networkmanager\" \"wheel\" \"docker\" \"plugdev\" ];" >> "$SETTINGS"
echo "}" >> "$SETTINGS"
echo "wrote $SETTINGS"
fi
# 2. Copy hardware-configuration.nix
if [ -f "/etc/nixos/hardware-configuration.nix" ]; then
cp /etc/nixos/hardware-configuration.nix "$REPO_DIR/hardware-configuration.nix"
echo "copied hardware-configuration.nix"
else
echo -e "${YELLOW}no hardware-configuration.nix found - run nixos-generate-config first${NC}"
fi