mirror of
https://github.com/ail-project/ail-framework.git
synced 2025-01-19 00:36:14 +00:00
88 lines
3.1 KiB
Bash
88 lines
3.1 KiB
Bash
#!/bin/bash
|
|
|
|
DIR="$(dirname "$0")"
|
|
SERVICE_FILE="ailbuilder.service"
|
|
SERVICE_PATH="/etc/systemd/system/"
|
|
AILBUILDER_PATH="/opt/ailbuilder"
|
|
BUILD_DIR="${DIR}/../../build"
|
|
BATCH_FILE="/tmp/key_batch"
|
|
SIGN_CONFIG_FILE="../conf/sign.json"
|
|
|
|
log() {
|
|
echo "[$(date +'%Y-%m-%dT%H:%M:%S%z')]: $*"
|
|
}
|
|
|
|
echo "Start setting up ailbuilder service ..."
|
|
|
|
if [[ $EUID -ne 0 ]]; then
|
|
log "This script must be run as root or with sudo privileges"
|
|
exit 1
|
|
fi
|
|
|
|
if [[ ! -d "$AILBUILDER_PATH" ]]; then
|
|
mkdir -p "$AILBUILDER_PATH"/images || { log "Failed to create directory $AILBUILDER_PATH"; exit 1; }
|
|
fi
|
|
|
|
if [[ -d "$BUILD_DIR" ]]; then
|
|
cp -r "$BUILD_DIR" "$AILBUILDER_PATH/" || { log "Failed to copy build directory"; exit 1; }
|
|
else
|
|
log "Build directory $BUILD_DIR does not exist"
|
|
exit 1
|
|
fi
|
|
|
|
# Create user if it doesn't exist
|
|
if ! id "ailbuilder" &>/dev/null; then
|
|
useradd -r -s /bin/false ailbuilder || { log "Failed to create user ailbuilder"; exit 1; }
|
|
fi
|
|
|
|
# Set ownership and permissions
|
|
chown -R ailbuilder: "$AILBUILDER_PATH" || { log "Failed to change ownership"; exit 1; }
|
|
chmod -R u+x "$AILBUILDER_PATH/build/"*.py || { log "Failed to set execute permission on scripts"; exit 1; }
|
|
chmod -R u+x "$AILBUILDER_PATH/build/"*.sh || { log "Failed to set execute permission on scripts"; exit 1; }
|
|
chmod -R u+w "$AILBUILDER_PATH/images/" || { log "Failed to set execute permission on images dir"; exit 1; }
|
|
|
|
# Add user to lxd group
|
|
sudo usermod -aG lxd ailbuilder || { log "Failed to add user ailbuilder to lxd group"; exit 1; }
|
|
mkdir -p /home/ailbuilder || { log "Failed to create directory /home/ailbuilder"; exit 1; }
|
|
chown -R ailbuilder: "/home/ailbuilder" || { log "Failed to change ownership"; exit 1; }
|
|
chmod -R u+w "/home/ailbuilder" || { log "Failed to set execute permission on home dir"; exit 1; }
|
|
|
|
# Setup GPG key
|
|
KEY_NAME=$(jq -r '.NAME' "$SIGN_CONFIG_FILE")
|
|
KEY_EMAIL=$(jq -r '.EMAIL' "$SIGN_CONFIG_FILE")
|
|
KEY_COMMENT=$(jq -r '.COMMENT' "$SIGN_CONFIG_FILE")
|
|
KEY_EXPIRE=$(jq -r '.EXPIRE_DATE' "$SIGN_CONFIG_FILE")
|
|
KEY_PASSPHRASE=$(jq -r '.PASSPHRASE' "$SIGN_CONFIG_FILE")
|
|
|
|
if ! sudo -u ailbuilder bash -c "gpg --list-keys | grep -q $KEY_EMAIL"; then
|
|
cat > "$BATCH_FILE" <<EOF
|
|
%echo Generating a basic OpenPGP key
|
|
Key-Type: default
|
|
Subkey-Type: default
|
|
Name-Real: ${KEY_NAME}
|
|
Name-Comment: ${KEY_COMMENT}
|
|
Name-Email: ${KEY_EMAIL}
|
|
Expire-Date: ${KEY_EXPIRE}
|
|
Passphrase: ${KEY_PASSPHRASE}
|
|
%commit
|
|
%echo done
|
|
EOF
|
|
|
|
sudo -u ailbuilder gpg --batch --generate-key "$BATCH_FILE" || { log "Failed to generate GPG key"; exit 1; }
|
|
rm "$BATCH_FILE" || { log "Failed to remove batch file"; exit 1; }
|
|
fi
|
|
|
|
# Copy service file
|
|
if [[ -f "$SERVICE_FILE" ]]; then
|
|
cp "${SERVICE_FILE}" "${SERVICE_PATH}" || { log "Failed to copy service file"; exit 1; }
|
|
else
|
|
log "Service file $SERVICE_FILE not found"
|
|
exit 1
|
|
fi
|
|
|
|
# Reload systemd, enable and start the service
|
|
systemctl daemon-reload || { log "Failed to reload systemd daemon"; exit 1; }
|
|
systemctl enable "${SERVICE_FILE}" || { log "Failed to enable service"; exit 1; }
|
|
systemctl start "${SERVICE_FILE}" || { log "Failed to start service"; exit 1; }
|
|
|
|
log "Service setup completed successfully."
|