rearrange firefox and vpn modules
This commit is contained in:
parent
faa530f54f
commit
c8e9d66f51
13 changed files with 8 additions and 478 deletions
|
|
@ -11,7 +11,7 @@
|
|||
../../modules/lazygit.nix
|
||||
../../modules/rsync.nix
|
||||
../../modules/btop.nix
|
||||
../../modules/firefox.nix
|
||||
../../modules/firefox/home.nix
|
||||
../../modules/ghostty.nix
|
||||
../../modules/syncthing.nix
|
||||
../../modules/claude-code.nix
|
||||
|
|
|
|||
|
|
@ -3,7 +3,7 @@
|
|||
./hardware-configuration.nix
|
||||
./containers.nix
|
||||
../system-default.nix
|
||||
../../../modules/tailscale.nix
|
||||
../../../modules/vpn/tailscale.nix
|
||||
../../../modules/podman.nix
|
||||
../../../modules/borg/client.nix
|
||||
../../../modules/login-display.nix
|
||||
|
|
|
|||
|
|
@ -5,7 +5,7 @@
|
|||
./hardware-configuration.nix
|
||||
./containers.nix
|
||||
../system-default.nix
|
||||
../../../modules/tailscale.nix
|
||||
../../../modules/vpn/tailscale.nix
|
||||
../../../modules/podman.nix
|
||||
../../../modules/borg/client.nix
|
||||
../../../modules/media/server.nix
|
||||
|
|
|
|||
|
|
@ -6,7 +6,7 @@
|
|||
./containers.nix
|
||||
../system-default.nix
|
||||
../../../modules/podman.nix
|
||||
../../../modules/tailscale.nix
|
||||
../../../modules/vpn/tailscale.nix
|
||||
../../../modules/borg/client.nix
|
||||
];
|
||||
|
||||
|
|
|
|||
|
|
@ -6,7 +6,7 @@
|
|||
./containers.nix
|
||||
./proxy.nix
|
||||
../system-default.nix
|
||||
../../../modules/tailscale.nix
|
||||
../../../modules/vpn/tailscale.nix
|
||||
../../../modules/podman.nix
|
||||
../../../modules/traefik.nix
|
||||
../../../modules/borg/client.nix
|
||||
|
|
|
|||
|
|
@ -43,13 +43,13 @@ in
|
|||
name = "yanlin";
|
||||
|
||||
# Extensions
|
||||
extensions = import ../config/firefox/extensions.nix args;
|
||||
extensions = import ./extensions.nix args;
|
||||
|
||||
# Bookmarks
|
||||
bookmarks = import ../config/firefox/bookmarks.nix;
|
||||
bookmarks = import ./bookmarks.nix;
|
||||
|
||||
# Search configuration
|
||||
search = import ../config/firefox/search.nix;
|
||||
search = import ./search.nix;
|
||||
|
||||
# Firefox settings
|
||||
settings = {
|
||||
|
|
@ -1,470 +0,0 @@
|
|||
{ config, lib, pkgs, ... }:
|
||||
|
||||
with lib;
|
||||
|
||||
let
|
||||
cfg = config.services.login-display;
|
||||
in
|
||||
|
||||
{
|
||||
options.services.login-display = {
|
||||
enable = mkEnableOption "login information display on SSH sessions";
|
||||
|
||||
showSmartStatus = mkOption {
|
||||
type = types.bool;
|
||||
default = false;
|
||||
description = "Show SMART disk health status";
|
||||
};
|
||||
|
||||
smartDrives = mkOption {
|
||||
type = types.attrsOf types.str;
|
||||
default = {};
|
||||
description = "Drives to monitor for SMART status (device path -> name mapping)";
|
||||
example = {
|
||||
"/dev/disk/by-id/ata-Samsung_SSD" = "System_SSD";
|
||||
};
|
||||
};
|
||||
|
||||
showSystemInfo = mkOption {
|
||||
type = types.bool;
|
||||
default = true;
|
||||
description = "Show basic system information (hostname, uptime, load)";
|
||||
};
|
||||
|
||||
showDiskUsage = mkOption {
|
||||
type = types.bool;
|
||||
default = false;
|
||||
description = "Show disk usage information";
|
||||
};
|
||||
|
||||
diskUsagePaths = mkOption {
|
||||
type = types.listOf types.str;
|
||||
default = [ "/" ];
|
||||
description = "Paths to check for disk usage";
|
||||
};
|
||||
|
||||
showBorgStatus = mkOption {
|
||||
type = types.bool;
|
||||
default = false;
|
||||
description = "Show last borg backup status";
|
||||
};
|
||||
|
||||
showSnapraidStatus = mkOption {
|
||||
type = types.bool;
|
||||
default = false;
|
||||
description = "Show SnapRAID sync and scrub status";
|
||||
};
|
||||
};
|
||||
|
||||
config = mkIf cfg.enable {
|
||||
# Add smartmontools if SMART status is enabled
|
||||
environment.systemPackages = mkIf cfg.showSmartStatus [ pkgs.smartmontools ];
|
||||
|
||||
# Configure shell login initialization
|
||||
programs.zsh.loginShellInit = mkIf config.programs.zsh.enable (
|
||||
let
|
||||
# ANSI color codes for truecolor (using \033 for better compatibility)
|
||||
# Gruvbox Hard Dark theme colors to match nvim
|
||||
colors = {
|
||||
reset = "\\033[0m";
|
||||
dim = "\\033[2m";
|
||||
aqua = "\\033[38;2;142;192;124m"; # Gruvbox aqua #8ec07c
|
||||
blue = "\\033[38;2;131;165;152m"; # Gruvbox blue #83a598
|
||||
green = "\\033[38;2;184;187;38m"; # Gruvbox green #b8bb26
|
||||
yellow = "\\033[38;2;250;189;47m"; # Gruvbox yellow #fabd2f
|
||||
orange = "\\033[38;2;254;128;25m"; # Gruvbox orange #fe8019
|
||||
red = "\\033[38;2;251;73;52m"; # Gruvbox red #fb4934
|
||||
gray = "\\033[38;2;146;131;116m"; # Gruvbox gray #928374
|
||||
};
|
||||
|
||||
# Build SMART status display
|
||||
smartStatusCode = optionalString cfg.showSmartStatus ''
|
||||
${concatStringsSep "\n" (mapAttrsToList (device: name: ''
|
||||
if [[ -e "${device}" ]]; then
|
||||
# Get health status
|
||||
if [[ "${device}" == *"nvme"* ]]; then
|
||||
HEALTH_OUTPUT=$(sudo ${pkgs.smartmontools}/bin/smartctl -d nvme -H "${device}" 2>/dev/null)
|
||||
else
|
||||
HEALTH_OUTPUT=$(sudo ${pkgs.smartmontools}/bin/smartctl -H "${device}" 2>/dev/null)
|
||||
fi
|
||||
|
||||
if HEALTH=$(echo "$HEALTH_OUTPUT" | ${pkgs.gnugrep}/bin/grep -o "PASSED\|FAILED" | head -1); then
|
||||
: # HEALTH is set
|
||||
else
|
||||
HEALTH="UNKNOWN"
|
||||
fi
|
||||
|
||||
# Get temperature and wear percentage
|
||||
TEMP="N/A"
|
||||
WEAR="N/A"
|
||||
if [[ "$HEALTH" == "PASSED" ]]; then
|
||||
if [[ "${device}" == *"nvme"* ]]; then
|
||||
SMART_DATA=$(sudo ${pkgs.smartmontools}/bin/smartctl -d nvme -A "${device}" 2>/dev/null)
|
||||
TEMP=$(echo "$SMART_DATA" | ${pkgs.gawk}/bin/awk '/^Temperature:/ {print $2}' | head -1)
|
||||
[[ -n "$TEMP" && "$TEMP" =~ ^[0-9]+$ ]] && TEMP="''${TEMP}" || TEMP="N/A"
|
||||
WEAR=$(echo "$SMART_DATA" | ${pkgs.gawk}/bin/awk '/^Percentage Used:/ {print $3}' | head -1 | tr -d '%')
|
||||
[[ -n "$WEAR" && "$WEAR" =~ ^[0-9]+$ ]] || WEAR="N/A"
|
||||
else
|
||||
SMART_DATA=$(sudo ${pkgs.smartmontools}/bin/smartctl -A "${device}" 2>/dev/null)
|
||||
TEMP=$(echo "$SMART_DATA" | ${pkgs.gawk}/bin/awk '/Temperature_Celsius/ {print $10}' | head -1)
|
||||
[[ -n "$TEMP" && "$TEMP" =~ ^[0-9]+$ ]] && TEMP="''${TEMP}" || TEMP="N/A"
|
||||
# Try various wear indicators for SATA SSDs (value is remaining life, so subtract from 100)
|
||||
WEAR=$(echo "$SMART_DATA" | ${pkgs.gawk}/bin/awk '/Wear_Leveling_Count|Media_Wearout_Indicator|SSD_Life_Left/ {print 100 - $4; exit}')
|
||||
[[ -n "$WEAR" && "$WEAR" =~ ^[0-9]+$ ]] || WEAR="N/A"
|
||||
fi
|
||||
fi
|
||||
|
||||
# Color-code status and temperature
|
||||
if [[ "$HEALTH" == "PASSED" ]]; then
|
||||
STATUS="\\033[38;2;184;187;38m✓\\033[0m"
|
||||
HEALTH_COLOR="\\033[38;2;184;187;38m"
|
||||
# Color temp based on value
|
||||
if [[ "$TEMP" =~ ^[0-9]+$ ]]; then
|
||||
if [[ $TEMP -ge 70 ]]; then
|
||||
TEMP_COLOR="\\033[38;2;251;73;52m"
|
||||
elif [[ $TEMP -ge 50 ]]; then
|
||||
TEMP_COLOR="\\033[38;2;254;128;25m"
|
||||
else
|
||||
TEMP_COLOR="\\033[38;2;250;189;47m"
|
||||
fi
|
||||
TEMP_STR="$(printf "%b" "''${TEMP_COLOR}''${TEMP}°C\\033[0m")"
|
||||
else
|
||||
TEMP_STR="$(printf "%b" "\\033[2m$TEMP\\033[0m")"
|
||||
fi
|
||||
# Color wear based on value
|
||||
if [[ "$WEAR" =~ ^[0-9]+$ ]]; then
|
||||
if [[ $WEAR -ge 80 ]]; then
|
||||
WEAR_COLOR="\\033[38;2;251;73;52m"
|
||||
elif [[ $WEAR -ge 50 ]]; then
|
||||
WEAR_COLOR="\\033[38;2;254;128;25m"
|
||||
else
|
||||
WEAR_COLOR="\\033[38;2;184;187;38m"
|
||||
fi
|
||||
WEAR_STR="$(printf "%b" "''${WEAR_COLOR}''${WEAR}%\\033[0m")"
|
||||
else
|
||||
WEAR_STR="$(printf "%b" "\\033[2m$WEAR\\033[0m")"
|
||||
fi
|
||||
elif [[ "$HEALTH" == "FAILED" ]]; then
|
||||
STATUS="\\033[38;2;251;73;52m✗\\033[0m"
|
||||
HEALTH_COLOR="\\033[38;2;251;73;52m"
|
||||
TEMP_STR="$(printf "%b" "\\033[2m$TEMP\\033[0m")"
|
||||
WEAR_STR="$(printf "%b" "\\033[2m$WEAR\\033[0m")"
|
||||
else
|
||||
STATUS="\\033[38;2;250;189;47m⚠\\033[0m"
|
||||
HEALTH_COLOR="\\033[38;2;250;189;47m"
|
||||
TEMP_STR="$(printf "%b" "\\033[2m$TEMP\\033[0m")"
|
||||
WEAR_STR="$(printf "%b" "\\033[2m$WEAR\\033[0m")"
|
||||
fi
|
||||
|
||||
printf " %b \\033[2m%-15s\\033[0m %b%-7s\\033[0m %s %s\n" "$STATUS" "${name}" "$HEALTH_COLOR" "$HEALTH" "$TEMP_STR" "$WEAR_STR"
|
||||
else
|
||||
printf " \\033[38;2;250;189;47m⚠\\033[0m \\033[2m%-15s\\033[0m \\033[38;2;251;73;52m%-20s\\033[0m\n" "${name}" "Not found"
|
||||
fi
|
||||
'') cfg.smartDrives)}
|
||||
'';
|
||||
|
||||
# Build system info display
|
||||
systemInfoCode = optionalString cfg.showSystemInfo ''
|
||||
# Parse uptime
|
||||
UPTIME_STR=$(uptime | ${pkgs.gawk}/bin/awk '{
|
||||
match($0, /up\s+(.+?),\s+[0-9]+\s+user/, arr)
|
||||
if (arr[1] != "") {
|
||||
gsub(/^ +| +$/, "", arr[1])
|
||||
# Shorten format: "5 days, 3:42" -> "5d 3h"
|
||||
gsub(/ days?,/, "d", arr[1])
|
||||
gsub(/ hours?,/, "h", arr[1])
|
||||
gsub(/ mins?,/, "m", arr[1])
|
||||
gsub(/:[0-9]+$/, "", arr[1])
|
||||
print arr[1]
|
||||
}
|
||||
}')
|
||||
LOAD=$(uptime | ${pkgs.gawk}/bin/awk -F'load average:' '{gsub(/^ +| +$/, "", $2); print $2}')
|
||||
|
||||
printf " \\033[38;2;142;192;124m%s\\033[0m \\033[2m·\\033[0m \\033[2m↑\\033[0m %s \\033[2m· load\\033[0m %s\n" "$(hostname)" "$UPTIME_STR" "$LOAD"
|
||||
'';
|
||||
|
||||
# Build disk usage display with bar
|
||||
diskUsageCode = optionalString cfg.showDiskUsage ''
|
||||
${concatMapStringsSep "\n" (path: ''
|
||||
DF_OUTPUT=$(df -h "${path}" | ${pkgs.gawk}/bin/awk 'NR==2 {print $3, $2, $5}')
|
||||
read -r USED TOTAL PCT <<< "$DF_OUTPUT"
|
||||
PCT_NUM=''${PCT%\%}
|
||||
|
||||
# Create progress bar (10 chars)
|
||||
FILLED=$((PCT_NUM / 10))
|
||||
EMPTY=$((10 - FILLED))
|
||||
BAR=""
|
||||
for ((i=0; i<FILLED; i++)); do BAR="$BAR█"; done
|
||||
for ((i=0; i<EMPTY; i++)); do BAR="$BAR░"; done
|
||||
|
||||
# Color bar based on usage
|
||||
if [[ $PCT_NUM -ge 90 ]]; then
|
||||
BAR_COLOR="\\033[38;2;251;73;52m"
|
||||
elif [[ $PCT_NUM -ge 70 ]]; then
|
||||
BAR_COLOR="\\033[38;2;254;128;25m"
|
||||
elif [[ $PCT_NUM -ge 50 ]]; then
|
||||
BAR_COLOR="\\033[38;2;250;189;47m"
|
||||
else
|
||||
BAR_COLOR="\\033[38;2;184;187;38m"
|
||||
fi
|
||||
|
||||
printf " \\033[2m%-12s\\033[0m %6s/%-6s %b%s\\033[0m %5s\n" "${path}" "$USED" "$TOTAL" "$BAR_COLOR" "$BAR" "$PCT"
|
||||
'') cfg.diskUsagePaths}
|
||||
'';
|
||||
|
||||
# Build SnapRAID status display
|
||||
snapraidStatusCode = optionalString cfg.showSnapraidStatus ''
|
||||
# Query journalctl for snapraid services
|
||||
SNAPRAID_SYNC_LOG=$(journalctl -u snapraid-sync.service -n 100 --no-pager --output=cat 2>/dev/null || echo "")
|
||||
SNAPRAID_SCRUB_LOG=$(journalctl -u snapraid-scrub.service -n 100 --no-pager --output=cat 2>/dev/null || echo "")
|
||||
|
||||
# Parse sync status
|
||||
if [[ -n "$SNAPRAID_SYNC_LOG" ]]; then
|
||||
# Check for completion messages (Everything OK or Nothing to do both indicate success)
|
||||
if echo "$SNAPRAID_SYNC_LOG" | ${pkgs.gnugrep}/bin/grep -q "Everything OK\|Nothing to do"; then
|
||||
SYNC_STATUS="✓"
|
||||
SYNC_COLOR="\\033[38;2;184;187;38m"
|
||||
|
||||
# Get timestamp from the most recent success message
|
||||
SYNC_TIMESTAMP=$(journalctl -u snapraid-sync.service --output=short-iso -n 100 --no-pager 2>/dev/null | ${pkgs.gnugrep}/bin/grep "Everything OK\|Nothing to do" | tail -1 | ${pkgs.gawk}/bin/awk '{print $1}')
|
||||
|
||||
if [[ -n "$SYNC_TIMESTAMP" ]]; then
|
||||
SYNC_EPOCH=$(date -d "$SYNC_TIMESTAMP" +%s 2>/dev/null || echo "0")
|
||||
NOW_EPOCH=$(date +%s)
|
||||
DIFF_SECONDS=$((NOW_EPOCH - SYNC_EPOCH))
|
||||
|
||||
if [[ $DIFF_SECONDS -lt 3600 ]]; then
|
||||
SYNC_TIME="$((DIFF_SECONDS / 60))m ago"
|
||||
elif [[ $DIFF_SECONDS -lt 86400 ]]; then
|
||||
SYNC_TIME="$((DIFF_SECONDS / 3600))h ago"
|
||||
else
|
||||
SYNC_TIME="$((DIFF_SECONDS / 86400))d ago"
|
||||
fi
|
||||
|
||||
# Adjust color if old
|
||||
if [[ $DIFF_SECONDS -gt 172800 ]]; then
|
||||
SYNC_STATUS="✗"
|
||||
SYNC_COLOR="\\033[38;2;251;73;52m"
|
||||
elif [[ $DIFF_SECONDS -gt 86400 ]]; then
|
||||
SYNC_STATUS="⚠"
|
||||
SYNC_COLOR="\\033[38;2;250;189;47m"
|
||||
fi
|
||||
else
|
||||
SYNC_TIME="Unknown"
|
||||
fi
|
||||
|
||||
# Extract stats
|
||||
FILES_SYNCED=$(echo "$SNAPRAID_SYNC_LOG" | ${pkgs.gnugrep}/bin/grep -oP "equal\s+\K[0-9]+" | tail -1)
|
||||
FILES_ADDED=$(echo "$SNAPRAID_SYNC_LOG" | ${pkgs.gnugrep}/bin/grep -oP "added\s+\K[0-9]+" | tail -1)
|
||||
FILES_REMOVED=$(echo "$SNAPRAID_SYNC_LOG" | ${pkgs.gnugrep}/bin/grep -oP "removed\s+\K[0-9]+" | tail -1)
|
||||
FILES_UPDATED=$(echo "$SNAPRAID_SYNC_LOG" | ${pkgs.gnugrep}/bin/grep -oP "updated\s+\K[0-9]+" | tail -1)
|
||||
|
||||
# Build sync details
|
||||
SYNC_DETAILS=""
|
||||
[[ -n "$FILES_ADDED" && "$FILES_ADDED" != "0" ]] && SYNC_DETAILS="$SYNC_DETAILS, $FILES_ADDED added"
|
||||
[[ -n "$FILES_REMOVED" && "$FILES_REMOVED" != "0" ]] && SYNC_DETAILS="$SYNC_DETAILS, $FILES_REMOVED removed"
|
||||
[[ -n "$FILES_UPDATED" && "$FILES_UPDATED" != "0" ]] && SYNC_DETAILS="$SYNC_DETAILS, $FILES_UPDATED updated"
|
||||
SYNC_DETAILS=$(echo "$SYNC_DETAILS" | sed 's/^, //')
|
||||
|
||||
if [[ -n "$FILES_SYNCED" ]]; then
|
||||
if [[ -n "$SYNC_DETAILS" ]]; then
|
||||
printf " %b%s\\033[0m \\033[2mLast sync\\033[0m %b%s\\033[0m \\033[2m%s files (%s)\\033[0m\n" "$SYNC_COLOR" "$SYNC_STATUS" "$SYNC_COLOR" "$SYNC_TIME" "$FILES_SYNCED" "$SYNC_DETAILS"
|
||||
else
|
||||
printf " %b%s\\033[0m \\033[2mLast sync\\033[0m %b%s\\033[0m \\033[2m%s files\\033[0m\n" "$SYNC_COLOR" "$SYNC_STATUS" "$SYNC_COLOR" "$SYNC_TIME" "$FILES_SYNCED"
|
||||
fi
|
||||
else
|
||||
printf " %b%s\\033[0m \\033[2mLast sync\\033[0m %b%s\\033[0m\n" "$SYNC_COLOR" "$SYNC_STATUS" "$SYNC_COLOR" "$SYNC_TIME"
|
||||
fi
|
||||
|
||||
elif echo "$SNAPRAID_SYNC_LOG" | ${pkgs.gnugrep}/bin/grep -q "error\|Error\|ERROR"; then
|
||||
SYNC_STATUS="✗"
|
||||
SYNC_COLOR="\\033[38;2;251;73;52m"
|
||||
printf " %b%s\\033[0m \\033[2mLast sync\\033[0m %bFAILED\\033[0m\n" "$SYNC_COLOR" "$SYNC_STATUS" "$SYNC_COLOR"
|
||||
else
|
||||
SYNC_STATUS="⚠"
|
||||
printf " %b%s\\033[0m \\033[2mLast sync\\033[0m \\033[38;2;250;189;47mUnknown\\033[0m\n" "$SYNC_STATUS"
|
||||
fi
|
||||
else
|
||||
printf " \\033[38;2;250;189;47m⚠\\033[0m \\033[2mLast sync\\033[0m \\033[2mNever run\\033[0m\n"
|
||||
fi
|
||||
|
||||
# Parse scrub status
|
||||
if [[ -n "$SNAPRAID_SCRUB_LOG" ]]; then
|
||||
if echo "$SNAPRAID_SCRUB_LOG" | ${pkgs.gnugrep}/bin/grep -q "Everything OK\|Nothing to do"; then
|
||||
SCRUB_STATUS="✓"
|
||||
SCRUB_COLOR="\\033[38;2;184;187;38m"
|
||||
|
||||
# Get timestamp
|
||||
SCRUB_TIMESTAMP=$(journalctl -u snapraid-scrub.service --output=short-iso -n 100 --no-pager 2>/dev/null | ${pkgs.gnugrep}/bin/grep "Everything OK\|Nothing to do" | tail -1 | ${pkgs.gawk}/bin/awk '{print $1}')
|
||||
|
||||
if [[ -n "$SCRUB_TIMESTAMP" ]]; then
|
||||
SCRUB_EPOCH=$(date -d "$SCRUB_TIMESTAMP" +%s 2>/dev/null || echo "0")
|
||||
NOW_EPOCH=$(date +%s)
|
||||
DIFF_SECONDS=$((NOW_EPOCH - SCRUB_EPOCH))
|
||||
|
||||
if [[ $DIFF_SECONDS -lt 3600 ]]; then
|
||||
SCRUB_TIME="$((DIFF_SECONDS / 60))m ago"
|
||||
elif [[ $DIFF_SECONDS -lt 86400 ]]; then
|
||||
SCRUB_TIME="$((DIFF_SECONDS / 3600))h ago"
|
||||
else
|
||||
SCRUB_TIME="$((DIFF_SECONDS / 86400))d ago"
|
||||
fi
|
||||
|
||||
# Adjust color if old (scrub is weekly so >10d is concerning)
|
||||
if [[ $DIFF_SECONDS -gt 864000 ]]; then
|
||||
SCRUB_STATUS="⚠"
|
||||
SCRUB_COLOR="\\033[38;2;250;189;47m"
|
||||
fi
|
||||
else
|
||||
SCRUB_TIME="Unknown"
|
||||
fi
|
||||
|
||||
printf " %b%s\\033[0m \\033[2mLast scrub\\033[0m %b%s\\033[0m \\033[2mNo errors\\033[0m\n" "$SCRUB_COLOR" "$SCRUB_STATUS" "$SCRUB_COLOR" "$SCRUB_TIME"
|
||||
|
||||
elif echo "$SNAPRAID_SCRUB_LOG" | ${pkgs.gnugrep}/bin/grep -q "error"; then
|
||||
ERROR_COUNT=$(echo "$SNAPRAID_SCRUB_LOG" | ${pkgs.gnugrep}/bin/grep -oP "[0-9]+\s+error" | ${pkgs.gawk}/bin/awk '{print $1}' | tail -1)
|
||||
SCRUB_STATUS="✗"
|
||||
SCRUB_COLOR="\\033[38;2;251;73;52m"
|
||||
|
||||
if [[ -n "$ERROR_COUNT" ]]; then
|
||||
printf " %b%s\\033[0m \\033[2mLast scrub\\033[0m %b%s error(s)\\033[0m\n" "$SCRUB_COLOR" "$SCRUB_STATUS" "$SCRUB_COLOR" "$ERROR_COUNT"
|
||||
else
|
||||
printf " %b%s\\033[0m \\033[2mLast scrub\\033[0m %bErrors detected\\033[0m\n" "$SCRUB_COLOR" "$SCRUB_STATUS" "$SCRUB_COLOR"
|
||||
fi
|
||||
else
|
||||
printf " \\033[38;2;250;189;47m⚠\\033[0m \\033[2mLast scrub\\033[0m \\033[38;2;250;189;47mUnknown\\033[0m\n"
|
||||
fi
|
||||
else
|
||||
printf " \\033[38;2;250;189;47m⚠\\033[0m \\033[2mLast scrub\\033[0m \\033[2mNever run\\033[0m\n"
|
||||
fi
|
||||
'';
|
||||
|
||||
# Build borg backup status display
|
||||
borgStatusCode = optionalString cfg.showBorgStatus ''
|
||||
# Query journalctl for borg-backup.service
|
||||
BORG_LOG=$(journalctl -u borg-backup.service -n 100 --no-pager --output=cat 2>/dev/null || echo "")
|
||||
|
||||
if [[ -z "$BORG_LOG" ]]; then
|
||||
# Service never ran
|
||||
printf " \\033[38;2;250;189;47m⚠\\033[0m \\033[2mNever run\\033[0m\n"
|
||||
else
|
||||
# Check if last backup succeeded
|
||||
if echo "$BORG_LOG" | ${pkgs.gnugrep}/bin/grep -q "Backup process completed successfully"; then
|
||||
STATUS_SYMBOL="\\033[38;2;184;187;38m✓\\033[0m"
|
||||
STATUS_COLOR="\\033[38;2;184;187;38m"
|
||||
|
||||
# Get timestamp of last successful backup
|
||||
LAST_TIMESTAMP=$(journalctl -u borg-backup.service --output=short-iso -n 100 --no-pager 2>/dev/null | ${pkgs.gnugrep}/bin/grep "Backup process completed successfully" | tail -1 | ${pkgs.gawk}/bin/awk '{print $1}')
|
||||
|
||||
if [[ -n "$LAST_TIMESTAMP" ]]; then
|
||||
# Calculate time ago
|
||||
LAST_EPOCH=$(date -d "$LAST_TIMESTAMP" +%s 2>/dev/null || date -j -f "%Y-%m-%dT%H:%M:%S%z" "$LAST_TIMESTAMP" +%s 2>/dev/null || echo "0")
|
||||
NOW_EPOCH=$(date +%s)
|
||||
DIFF_SECONDS=$((NOW_EPOCH - LAST_EPOCH))
|
||||
|
||||
if [[ $DIFF_SECONDS -lt 3600 ]]; then
|
||||
TIME_AGO="$((DIFF_SECONDS / 60))m ago"
|
||||
elif [[ $DIFF_SECONDS -lt 86400 ]]; then
|
||||
TIME_AGO="$((DIFF_SECONDS / 3600))h ago"
|
||||
else
|
||||
TIME_AGO="$((DIFF_SECONDS / 86400))d ago"
|
||||
fi
|
||||
|
||||
# Adjust color based on age
|
||||
if [[ $DIFF_SECONDS -gt 172800 ]]; then
|
||||
# > 48h - red
|
||||
STATUS_SYMBOL="\\033[38;2;251;73;52m✗\\033[0m"
|
||||
STATUS_COLOR="\\033[38;2;251;73;52m"
|
||||
elif [[ $DIFF_SECONDS -gt 86400 ]]; then
|
||||
# 24-48h - yellow
|
||||
STATUS_SYMBOL="\\033[38;2;250;189;47m⚠\\033[0m"
|
||||
STATUS_COLOR="\\033[38;2;250;189;47m"
|
||||
fi
|
||||
else
|
||||
TIME_AGO="Unknown"
|
||||
fi
|
||||
|
||||
# Extract archive statistics from borg output
|
||||
# Look for lines like: "Archive name: ..." and "This archive: X.XX GB"
|
||||
ARCHIVE_NAME=$(echo "$BORG_LOG" | ${pkgs.gnugrep}/bin/grep -oP "Archive name: \K.*" | tail -1)
|
||||
ARCHIVE_SIZE=$(echo "$BORG_LOG" | ${pkgs.gnugrep}/bin/grep -oP "(Original size|This archive):\s+\K[0-9.]+ [KMGT]?B" | tail -1)
|
||||
COMPRESSED_SIZE=$(echo "$BORG_LOG" | ${pkgs.gnugrep}/bin/grep -oP "Compressed size:\s+\K[0-9.]+ [KMGT]?B" | tail -1)
|
||||
DEDUPLICATED_SIZE=$(echo "$BORG_LOG" | ${pkgs.gnugrep}/bin/grep -oP "Deduplicated size:\s+\K[0-9.]+ [KMGT]?B" | tail -1)
|
||||
FILES_COUNT=$(echo "$BORG_LOG" | ${pkgs.gnugrep}/bin/grep -oP "Number of files:\s+\K[0-9]+" | tail -1)
|
||||
|
||||
# Display main status line
|
||||
printf " %b \\033[2mLast backup\\033[0m %b%s\\033[0m" "$STATUS_SYMBOL" "$STATUS_COLOR" "$TIME_AGO"
|
||||
|
||||
# Add archive size if available
|
||||
if [[ -n "$DEDUPLICATED_SIZE" ]]; then
|
||||
printf " \\033[2m%s\\033[0m" "$DEDUPLICATED_SIZE"
|
||||
elif [[ -n "$ARCHIVE_SIZE" ]]; then
|
||||
printf " \\033[2m%s\\033[0m" "$ARCHIVE_SIZE"
|
||||
fi
|
||||
printf "\n"
|
||||
|
||||
# Display additional details if available
|
||||
if [[ -n "$ARCHIVE_SIZE" ]] && [[ -n "$COMPRESSED_SIZE" ]] && [[ -n "$DEDUPLICATED_SIZE" ]]; then
|
||||
printf " \\033[2m Original: %s Compressed: %s Dedup: %s\\033[0m\n" "$ARCHIVE_SIZE" "$COMPRESSED_SIZE" "$DEDUPLICATED_SIZE"
|
||||
fi
|
||||
|
||||
if [[ -n "$FILES_COUNT" ]]; then
|
||||
printf " \\033[2m Files: %s\\033[0m\n" "$FILES_COUNT"
|
||||
fi
|
||||
|
||||
else
|
||||
# Check for errors
|
||||
if echo "$BORG_LOG" | ${pkgs.gnugrep}/bin/grep -q "ERROR"; then
|
||||
STATUS_SYMBOL="\\033[38;2;251;73;52m✗\\033[0m"
|
||||
STATUS_TEXT="FAILED"
|
||||
ERROR_MSG=$(echo "$BORG_LOG" | ${pkgs.gnugrep}/bin/grep "ERROR" | tail -1 | ${pkgs.gawk}/bin/awk '{print substr($0, index($0,$2))}' | cut -c1-60)
|
||||
printf " %b \\033[2mLast backup\\033[0m \\033[38;2;251;73;52m%s\\033[0m\n" "$STATUS_SYMBOL" "$STATUS_TEXT"
|
||||
if [[ -n "$ERROR_MSG" ]]; then
|
||||
printf " \\033[2m %s\\033[0m\n" "$ERROR_MSG"
|
||||
fi
|
||||
else
|
||||
STATUS_SYMBOL="\\033[38;2;250;189;47m⚠\\033[0m"
|
||||
STATUS_TEXT="Unknown"
|
||||
printf " %b \\033[2mLast backup\\033[0m \\033[38;2;250;189;47m%s\\033[0m\n" "$STATUS_SYMBOL" "$STATUS_TEXT"
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
'';
|
||||
|
||||
# Combine all sections
|
||||
hasDisks = cfg.showSmartStatus && (builtins.length (builtins.attrNames cfg.smartDrives) > 0);
|
||||
hasStorage = cfg.showDiskUsage && (builtins.length cfg.diskUsagePaths > 0);
|
||||
|
||||
in ''
|
||||
if ([[ -n "$SSH_CONNECTION" ]] || [[ -n "$SSH_TTY" ]]) && [[ -z "$TMUX" ]]; then
|
||||
echo ""
|
||||
printf "\\033[38;2;142;192;124m━━ System ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\\033[0m\n"
|
||||
${systemInfoCode}
|
||||
${optionalString hasDisks ''
|
||||
printf "\\033[38;2;131;165;152m━━ Disks ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\\033[0m\n"
|
||||
${smartStatusCode}
|
||||
''}
|
||||
${optionalString hasStorage ''
|
||||
printf "\\033[38;2;131;165;152m━━ Storage ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\\033[0m\n"
|
||||
${diskUsageCode}
|
||||
''}
|
||||
${optionalString cfg.showSnapraidStatus ''
|
||||
printf "\\033[38;2;131;165;152m━━ SnapRAID ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\\033[0m\n"
|
||||
${snapraidStatusCode}
|
||||
''}
|
||||
${optionalString cfg.showBorgStatus ''
|
||||
printf "\\033[38;2;131;165;152m━━ Backup ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\\033[0m\n"
|
||||
${borgStatusCode}
|
||||
''}
|
||||
echo ""
|
||||
fi
|
||||
''
|
||||
);
|
||||
|
||||
# Also support bash if needed
|
||||
programs.bash.loginShellInit = mkIf (!config.programs.zsh.enable) (
|
||||
# Same content as zsh
|
||||
programs.zsh.loginShellInit
|
||||
);
|
||||
};
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue