nextcloud-swarm-plugin/cli/staging/deploy.sh
2024-10-16 15:54:09 +08:00

137 lines
2.2 KiB
Bash

#!/bin/bash
RED='\033[0;31m'
GREEN='\033[0;32m'
BLUE='\033[0;34m'
YELLOW='\033[0;33m'
NC='\033[0m'
log () {
echo -e "$1"
}
log_message() {
echo -e "${BLUE}$1${NC}"
}
log_note() {
echo -e "${YELLOW}$1${NC}"
}
log_success() {
echo -e "${GREEN}$1${NC}"
}
log_error() {
echo -e "${RED}$1${NC}"
}
log_gap() {
echo -e "-------------------------------------"
}
output=()
buffer() {
local line=$1
output+=("$line")
}
print_buffer() {
for line in "${output[@]}"
do
log "$line"
done
output=()
}
failed() {
local version=$1
local result=$2
print_buffer
log_error "$result"
log_error "failed to deploy hejbit-$version"
log_gap
exit 1
}
action() {
local action=$1
local message=$2
buffer "$(log_message "$message")"
result=$($action) || failed "$version" "$result"
buffer "$result"
}
deploy() {
local version=$1
cd hejbit-"$version" || failed "hejbit-$version not found"
buffer "$(log_note "deploying hejbit-$version")"
action "sync_code" "syncing code"
action "build_app" "building app"
action "nextcloud_upgrade" "upgrading nextcloud"
buffer "$(log_success "deployed hejbit-$version")"
print_buffer
log_gap
}
sync_code() {
git reset --hard > /dev/null 2>&1
git pull 2>&1 || return 1
}
build_app() {
result=$(npm install 2>&1)
status=$?
log "$result"
[ $status -ne 0 ] && return $status
result=$(npm run build 2>&1)
status=$?
log "$result"
return $status
}
nextcloud_upgrade() {
INFO_XML="appinfo/info.xml"
CURRENT_VERSION=$(grep -oPm1 "(?<=<version>)[^<]+" "$INFO_XML")
NEW_VERSION="${CURRENT_VERSION}_${TIMESTAMP}"
sed -i "s/<version>${CURRENT_VERSION}<\/version>/<version>${NEW_VERSION}<\/version>/" "$INFO_XML"
log_message "bumped version to $NEW_VERSION"
result=$(docker exec -u www-data hejbit-"$version"-nextcloud-1 php occ upgrade 2>&1)
status=$?
log "$result"
return $status
}
cd /opt/hejbit || log_error "/opt/hejbit not found"
log_note "deploying hejbit to staging"
log_gap
DEPLOYMENT=()
TIMESTAMP=$(date +%s)
for version in {28..30}; do
deploy "$version" &
DEPLOYMENT+=($!)
done
statuses=0
for pid in "${DEPLOYMENT[@]}"; do
wait "$pid"
statuses+=$?
done
if [ $statuses -ne 0 ]; then
log_error "failed to deploy hejbit to staging"
exit 1
fi
log_success "deployed hejbit to staging"