2025-05-31 14:00:12 -03:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
HOST_BASE="/opt/gbo/tenants/$PARAM_TENANT/alm"
|
|
|
|
HOST_DATA="$HOST_BASE/data"
|
|
|
|
HOST_CONF="$HOST_BASE/conf"
|
|
|
|
HOST_LOGS="$HOST_BASE/logs"
|
2025-05-31 22:47:41 -03:00
|
|
|
ALM_PATH=/opt/gbo/bin
|
2025-05-31 14:00:12 -03:00
|
|
|
|
|
|
|
mkdir -p "$HOST_DATA" "$HOST_CONF" "$HOST_LOGS"
|
|
|
|
chmod -R 750 "$HOST_BASE"
|
|
|
|
|
|
|
|
lxc launch images:debian/12 "$PARAM_TENANT"-alm -c security.privileged=true
|
|
|
|
sleep 15
|
|
|
|
|
|
|
|
lxc exec "$PARAM_TENANT"-alm -- bash -c "
|
|
|
|
apt-get update && apt-get install -y git git-lfs wget
|
2025-05-31 22:47:41 -03:00
|
|
|
mkdir -p /opt/gbo/bin
|
|
|
|
wget https://codeberg.org/forgejo/forgejo/releases/download/v10.0.2/forgejo-10.0.2-linux-amd64 -O $ALM_PATH/forgejo
|
|
|
|
chmod +x $ALM_PATH/forgejo
|
|
|
|
useradd --system --no-create-home --shell /bin/false alm
|
2025-05-31 14:00:12 -03:00
|
|
|
"
|
|
|
|
|
2025-05-31 22:47:41 -03:00
|
|
|
FORGEJO_UID=$(lxc exec "$PARAM_TENANT"-alm -- id -u alm)
|
|
|
|
FORGEJO_GID=$(lxc exec "$PARAM_TENANT"-alm -- id -g alm)
|
2025-05-31 14:00:12 -03:00
|
|
|
HOST_FORGEJO_UID=$((100000 + FORGEJO_UID))
|
|
|
|
HOST_FORGEJO_GID=$((100000 + FORGEJO_GID))
|
|
|
|
chown -R "$HOST_FORGEJO_UID:$HOST_FORGEJO_GID" "$HOST_BASE"
|
|
|
|
|
2025-05-31 22:47:41 -03:00
|
|
|
lxc config device add "$PARAM_TENANT"-alm almdata disk source="$HOST_DATA" path=/opt/gbo/data
|
|
|
|
lxc config device add "$PARAM_TENANT"-alm almconf disk source="$HOST_CONF" path=/opt/gbo/conf
|
|
|
|
lxc config device add "$PARAM_TENANT"-alm almlogs disk source="$HOST_LOGS" path=/opt/gbo/logs
|
2025-05-31 14:00:12 -03:00
|
|
|
|
|
|
|
lxc exec "$PARAM_TENANT"-alm -- bash -c "
|
2025-05-31 22:47:41 -03:00
|
|
|
mkdir -p /opt/gbo/data /opt/gbo/conf /opt/gbo/logs
|
2025-06-01 21:06:42 -03:00
|
|
|
chown -R alm:alm /opt/gbo
|
|
|
|
|
2025-05-31 14:00:12 -03:00
|
|
|
|
2025-05-31 22:47:41 -03:00
|
|
|
cat > /etc/systemd/system/alm.service <<EOF
|
2025-05-31 14:00:12 -03:00
|
|
|
[Unit]
|
2025-05-31 22:47:41 -03:00
|
|
|
Description=alm
|
2025-05-31 14:00:12 -03:00
|
|
|
After=network.target
|
|
|
|
|
|
|
|
[Service]
|
2025-05-31 22:47:41 -03:00
|
|
|
User=alm
|
|
|
|
Group=alm
|
|
|
|
WorkingDirectory=/opt/gbo/data
|
|
|
|
ExecStart=/opt/gbo/bin/forgejo web --config /opt/gbo/conf/app.ini
|
2025-05-31 14:00:12 -03:00
|
|
|
Restart=always
|
2025-05-31 22:47:41 -03:00
|
|
|
Environment=USER=alm HOME=/opt/gbo/data
|
|
|
|
StandardOutput=append:/opt/gbo/logs/stdout.log
|
|
|
|
StandardError=append:/opt/gbo/logs/stderr.log
|
2025-05-31 14:00:12 -03:00
|
|
|
|
|
|
|
[Install]
|
|
|
|
WantedBy=multi-user.target
|
|
|
|
EOF
|
|
|
|
|
|
|
|
systemctl daemon-reload
|
2025-05-31 22:47:41 -03:00
|
|
|
systemctl enable alm
|
|
|
|
systemctl start alm
|
2025-05-31 14:00:12 -03:00
|
|
|
"
|
|
|
|
|
|
|
|
lxc config device remove "$PARAM_TENANT"-alm alm-proxy 2>/dev/null || true
|
|
|
|
lxc config device add "$PARAM_TENANT"-alm alm-proxy proxy \
|
|
|
|
listen=tcp:0.0.0.0:"$PARAM_ALM_PORT" \
|
|
|
|
connect=tcp:127.0.0.1:"$PARAM_ALM_PORT"
|