Configuracion inicial completa del entorno personal
Modulos de restauracion: - bootstrap: instala yq, age y dependencias base (curl, wget, git, nano, gpg) - ssh: descifra e instala claves SSH desde secrets/sshKeys.tar.gz.age - registry: aplica paquetes apt/snap/flatpak, dotfiles, servicios y configs Docker - thunderbird: instala Thunderbird snap y restaura perfil desde ZIP - claudeCode: configura repositorio apt de Anthropic e instala claude-code - easyEffects: restaura configuracion y presets desde ZIP - wireplumber: restaura dispositivo Bluetooth por defecto y perfiles de audio - cups: restaura impresoras y drivers PPD desde ZIP Scripts de captura (correr antes de push): - scripts/encryptSsh.sh: cifra ~/.ssh con age - scripts/thunderbird/capture.sh: captura perfil de Thunderbird snap - scripts/easyEffects/capture.sh: captura config de EasyEffects flatpak - scripts/wireplumber/capture.sh: captura estado de WirePlumber - scripts/cups/capture.sh: captura impresoras CUPS y PPDs (requiere sudo) Registro de aplicaciones (config/registry.yaml): - 9 paquetes apt, 1 snap (dbeaver-ce), 22 flatpaks incluyendo VSCodium, Bitwarden, Inkscape, LibreOffice, OBS Studio, Nextcloud Desktop, entre otros Secretos incluidos: - secrets/sshKeys.tar.gz.age: claves SSH cifradas con age - secrets/thunderbirdProfile.zip: perfil de Thunderbird sin emails ni cache - secrets/easyEffectsConfig.zip: ajustes y presets de salida de audio - secrets/wireplumberState.zip: estado de audio incluyendo auriculares Bluetooth - secrets/cupsConfig.zip: 5 impresoras configuradas con sus drivers Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -0,0 +1,54 @@
|
||||
#!/usr/bin/env bash
|
||||
set -euo pipefail
|
||||
stpRoot="$(cd "$(dirname "${BASH_SOURCE[0]}")/../.." && pwd)"
|
||||
source "$stpRoot/lib/log.sh"
|
||||
source "$stpRoot/lib/utils.sh"
|
||||
|
||||
readonly outputFile="$stpRoot/secrets/cupsConfig.zip"
|
||||
|
||||
cupsIsInstalled() {
|
||||
util::cmdExists lpstat
|
||||
}
|
||||
|
||||
printersAreConfigured() {
|
||||
sudo test -s /etc/cups/printers.conf
|
||||
}
|
||||
|
||||
copyFilesToTemporaryDirectory() {
|
||||
local temporaryDirectory="$1"
|
||||
sudo cp /etc/cups/printers.conf "$temporaryDirectory/printers.conf"
|
||||
if sudo test -d /etc/cups/ppd && sudo test -n "$(sudo ls /etc/cups/ppd/)"; then
|
||||
sudo cp -r /etc/cups/ppd "$temporaryDirectory/ppd"
|
||||
fi
|
||||
sudo chown -R "$USER" "$temporaryDirectory"
|
||||
}
|
||||
|
||||
if ! cupsIsInstalled; then
|
||||
log::warn "CUPS no instalado"
|
||||
exit 0
|
||||
fi
|
||||
|
||||
util::requireSudo
|
||||
|
||||
if ! printersAreConfigured; then
|
||||
log::warn "No hay impresoras configuradas en /etc/cups/printers.conf"
|
||||
exit 0
|
||||
fi
|
||||
|
||||
log::step "Capturando configuración de CUPS"
|
||||
mkdir -p "$stpRoot/secrets"
|
||||
rm -f "$outputFile"
|
||||
|
||||
temporaryDirectory="$(mktemp -d)"
|
||||
trap 'rm -rf "$temporaryDirectory"' EXIT
|
||||
|
||||
copyFilesToTemporaryDirectory "$temporaryDirectory"
|
||||
|
||||
(
|
||||
cd "$temporaryDirectory"
|
||||
find . -not -type d | sed 's|^\./||' | zip -q "$outputFile" -@
|
||||
)
|
||||
|
||||
log::ok "Guardado: secrets/cupsConfig.zip ($(du -sh "$outputFile" | cut -f1))"
|
||||
log::info "Impresoras respaldadas: $(lpstat -a | awk '{print $1}' | tr '\n' ' ')"
|
||||
log::info "Commiteá secrets/cupsConfig.zip antes de hacer push"
|
||||
Reference in New Issue
Block a user