c7ae46f86c
Nuevas primitivas para gestionar servicios systemd del sistema desde
el registry (antes solo había versiones remotas via SSH para deploy VPS):
bash/functions/infra/
systemd_local_install_unit — escribir unit en /etc/systemd/system + daemon-reload
systemd_local_enable — systemctl enable
systemd_local_start — systemctl start + MainPID
systemd_local_restart — systemctl restart + MainPID
systemd_local_status — ActiveState/SubState/pid/enabled + journal tail (no sudo)
systemd_local_uninstall — stop + disable + rm unit + daemon-reload (idempotente)
bash/functions/pipelines/
install_systemd_service — pipeline que compone las anteriores; args
--name --exec [--workdir --user --env KEY=VAL
--after --restart --type]
Requisito: sudo sin password para systemctl + escritura en /etc/systemd/system/.
En WSL: systemd=true en /etc/wsl.conf.
Registrado sqlite_api como servicio del sistema con este pipeline, queda
vivo al arrancar WSL. Dashboard ya no necesita arrancar la API manualmente.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
22 lines
648 B
Bash
22 lines
648 B
Bash
#!/usr/bin/env bash
|
|
# systemd_local_enable — Habilita un servicio systemd local (arranque automático).
|
|
set -euo pipefail
|
|
|
|
systemd_local_enable() {
|
|
local name="$1"
|
|
|
|
if [[ -z "$name" ]]; then
|
|
echo "systemd_local_enable: se requiere name" >&2
|
|
return 1
|
|
fi
|
|
|
|
# systemctl enable imprime "Created symlink ..." en stdout — redirigir a stderr
|
|
# para que $(systemd_local_enable ...) capture sólo el JSON final.
|
|
if ! sudo systemctl enable "${name}.service" >&2; then
|
|
echo "systemd_local_enable: enable falló para '$name'" >&2
|
|
return 1
|
|
fi
|
|
|
|
printf '{"name":"%s","enabled":true}\n' "$name"
|
|
}
|