#!/bin/sh APP=/app DATA=/data mkdir -p "$DATA/log" "$DATA/config" "$DATA/ssl" "$DATA/test_case" "$DATA/public/upload" "$DATA/public/avatar" "$DATA/public/website" if [ ! -f "$DATA/config/secret.key" ]; then echo "$(head -c 32 /dev/urandom | md5sum | head -c 32)" > "$DATA/config/secret.key" fi if [ ! -f "$DATA/public/avatar/default.png" ]; then cp data/public/avatar/default.png "$DATA/public/avatar" fi if [ ! -f "$DATA/public/website/favicon.ico" ]; then cp data/public/website/favicon.ico "$DATA/public/website" fi SSL="$DATA/ssl" if [ ! -f "$SSL/server.key" ]; then openssl req -x509 -newkey rsa:2048 -keyout "$SSL/server.key" -out "$SSL/server.crt" -days 1000 \ -subj "/C=CN/ST=Beijing/L=Beijing/O=Beijing OnlineJudge Technology Co., Ltd./OU=Service Infrastructure Department/CN=$(hostname)" -nodes fi cd "$APP/deploy/nginx" ln -sf locations.conf https_locations.conf if [ -z "$FORCE_HTTPS" ]; then ln -sf locations.conf http_locations.conf else ln -sf https_redirect.conf http_locations.conf fi if [ -n "$LOWER_IP_HEADER" ]; then sed -i "s/__IP_HEADER__/\$http_$LOWER_IP_HEADER/g" api_proxy.conf; else sed -i "s/__IP_HEADER__/\$remote_addr/g" api_proxy.conf; fi if [ -z "$MAX_WORKER_NUM" ]; then CPU_CORE_NUM=$(grep -c ^processor /proc/cpuinfo) export CPU_CORE_NUM if [ "$CPU_CORE_NUM" -lt 2 ]; then export MAX_WORKER_NUM=2 else export MAX_WORKER_NUM="$CPU_CORE_NUM" fi fi cd "$APP/dist" if [ -n "$STATIC_CDN_HOST" ]; then find . -name "*.*" -type f -exec sed -i "s/__STATIC_CDN_HOST__/\/$STATIC_CDN_HOST/g" {} \; else find . -name "*.*" -type f -exec sed -i "s/__STATIC_CDN_HOST__\///g" {} \; fi cd "$APP" n=0 while [ $n -lt 5 ] do python manage.py migrate --no-input && python manage.py inituser --username=root --password=rootroot --action=create_super_admin && echo "from options.options import SysOptions; SysOptions.judge_server_token='$JUDGE_SERVER_TOKEN'" | python manage.py shell && echo "from conf.models import JudgeServer; JudgeServer.objects.update(task_number=0)" | python manage.py shell && break n=$((n + 1)) echo "Failed to migrate, going to retry..." sleep 8 done if ! getent group spj >/dev/null; then groupadd --system --gid 903 spj fi if ! id -u server >/dev/null 2>&1; then useradd --system --uid 900 --gid spj --no-create-home --shell /usr/sbin/nologin server fi chown -R server:spj "$DATA" "$APP/dist" find "$DATA/test_case" -type d -exec chmod 710 {} \; find "$DATA/test_case" -type f -exec chmod 640 {} \; exec supervisord -c /app/deploy/supervisord.conf