- Fix .198-style fresh installs: systemd service ExecStartPre creates /run/user/1000, enable podman.socket, chmod 644 /etc/hosts - Filebrowser: add /data volume for database (fixes read-only crash), secure auth with random password via backend RPC (no more admin/admin) - AppCard: enrich installing state with marketplace metadata (icon, title, description, tier badge, author, version) - Registry: btcpayserver 1.13.5 → 1.13.7, images mirrored - ReadWritePaths: add home container paths for rootless podman Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
69 lines
2.1 KiB
Bash
Executable File
69 lines
2.1 KiB
Bash
Executable File
#!/bin/bash
|
|
# Podman Installation and Configuration Script for Archipelago
|
|
# Configures Podman for rootless operation
|
|
|
|
set -e
|
|
|
|
echo "🐳 Configuring Podman for rootless operation..."
|
|
|
|
# Ensure archipelago user exists
|
|
if ! id "archipelago" &>/dev/null; then
|
|
echo "Creating archipelago user..."
|
|
adduser -D -s /bin/bash archipelago
|
|
fi
|
|
|
|
# Create Podman configuration directories
|
|
mkdir -p /home/archipelago/.config/containers
|
|
mkdir -p /home/archipelago/.local/share/containers/storage
|
|
|
|
# Configure storage
|
|
cat > /home/archipelago/.config/containers/storage.conf <<EOF
|
|
[storage]
|
|
driver = "overlay"
|
|
runroot = "/run/user/$(id -u archipelago)/containers"
|
|
graphroot = "/home/archipelago/.local/share/containers/storage"
|
|
EOF
|
|
|
|
# Configure registries (use Docker Hub and quay.io)
|
|
mkdir -p /home/archipelago/.config/containers/registries.conf.d
|
|
cat > /home/archipelago/.config/containers/registries.conf.d/000-shortnames.conf <<EOF
|
|
[registries.search]
|
|
registries = ['80.71.235.15:3000', 'docker.io', 'quay.io', 'ghcr.io']
|
|
|
|
[registries.insecure]
|
|
registries = ['80.71.235.15:3000']
|
|
|
|
[registries.block]
|
|
registries = []
|
|
EOF
|
|
|
|
# Set up subuid and subgid for rootless containers
|
|
if ! grep -q "^archipelago:" /etc/subuid; then
|
|
echo "archipelago:100000:65536" >> /etc/subuid
|
|
fi
|
|
|
|
if ! grep -q "^archipelago:" /etc/subgid; then
|
|
echo "archipelago:100000:65536" >> /etc/subgid
|
|
fi
|
|
|
|
# Create systemd user service directory
|
|
mkdir -p /home/archipelago/.config/systemd/user
|
|
|
|
# Enable lingering for archipelago user (allows user services to run without login)
|
|
loginctl enable-linger archipelago || true
|
|
|
|
# Ensure /run/user/1000 exists for podman socket
|
|
mkdir -p /run/user/1000
|
|
chown archipelago:archipelago /run/user/1000
|
|
chmod 700 /run/user/1000
|
|
|
|
# Enable podman API socket for archipelago user (backend connects via this)
|
|
su - archipelago -c "XDG_RUNTIME_DIR=/run/user/1000 systemctl --user enable podman.socket" || true
|
|
su - archipelago -c "XDG_RUNTIME_DIR=/run/user/1000 systemctl --user start podman.socket" || true
|
|
|
|
# Set proper permissions
|
|
chown -R archipelago:archipelago /home/archipelago/.config
|
|
chown -R archipelago:archipelago /home/archipelago/.local
|
|
|
|
echo "✅ Podman configuration complete!"
|