2021-08-24 16:18:00 +02:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
# Post-installation de scodoc
|
|
|
|
# ici, le répertoire /opt/scodoc vient d'être installé
|
|
|
|
|
2021-08-25 16:55:30 +02:00
|
|
|
cd /opt/scodoc || (echo "Error chdir to /opt/scodoc"; exit 1)
|
|
|
|
|
2021-08-24 16:18:00 +02:00
|
|
|
# On peut donc charger la config:
|
|
|
|
source /opt/scodoc/tools/config.sh
|
|
|
|
source /opt/scodoc/tools/utils.sh
|
|
|
|
|
|
|
|
# -- Création au besoin de notre utilisateur
|
2021-08-24 18:55:58 +02:00
|
|
|
# adduser --system "${SCODOC_USER}"
|
|
|
|
check_create_scodoc_user
|
2021-08-24 16:18:00 +02:00
|
|
|
|
|
|
|
# -- Répertoires /opt/scodoc donné à scodoc
|
|
|
|
change_scodoc_file_ownership
|
2021-08-27 17:03:47 +02:00
|
|
|
# --- Création au besoin de /opt/scodoc-data
|
2021-08-24 16:18:00 +02:00
|
|
|
set_scodoc_var_dir
|
|
|
|
|
2021-08-26 15:35:08 +02:00
|
|
|
# ------------ LOCALES (pour compat bases ScoDoc 7 et plus anciennes)
|
|
|
|
for locname in "en_US.UTF-8"
|
|
|
|
do
|
|
|
|
outname=$(echo ${locname//-/} | tr '[A-Z]' '[a-z]')
|
|
|
|
if [ "$(locale -a | grep -E -i ^${outname}$ | wc -l)" -lt 1 ]
|
|
|
|
then
|
|
|
|
echo adding $locname
|
|
|
|
echo "$locname ${locname##*.}" >> /etc/locale.gen
|
|
|
|
/usr/sbin/locale-gen --keep-existing
|
|
|
|
systemctl restart postgresql
|
|
|
|
fi
|
|
|
|
done
|
2021-08-24 16:18:00 +02:00
|
|
|
|
2021-08-25 21:55:27 +02:00
|
|
|
# Le numero de version complet, genre 9.0.0
|
|
|
|
SCODOC_RELEASE=$(grep SCOVERSION $SCODOC_DIR/sco_version.py | awk '{ print substr($3, 2, length($3)-2) }')
|
|
|
|
if [ -e "${SCODOC_VERSION_DIR}/scodoc.sn" ]
|
|
|
|
then
|
|
|
|
# upgrading
|
|
|
|
echo "mode: upgrade"
|
|
|
|
mode=upgrade
|
|
|
|
SN=$(cat "${SCODOC_VERSION_DIR}"/scodoc.sn)
|
|
|
|
if [[ ! "${SN}" =~ ^[0-9].* ]]
|
|
|
|
then
|
|
|
|
SN='' # fix for invalid previous replies
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
# first install
|
|
|
|
echo "mode: install"
|
|
|
|
mode=install
|
|
|
|
SN=""
|
|
|
|
fi
|
2021-08-24 16:18:00 +02:00
|
|
|
|
2021-08-25 21:55:27 +02:00
|
|
|
CMD="curl --fail --connect-timeout 5 --silent http://scodoc.iutv.univ-paris13.fr/scodoc-installmgr/version?mode=$mode\&release=${SCODOC_RELEASE}\&sn=${SN}"
|
|
|
|
|
|
|
|
SVERSION="$(${CMD})"
|
|
|
|
if [ "$?" == 0 ]; then
|
|
|
|
#echo "answer=${SVERSION}"
|
|
|
|
echo "${SVERSION}" > "${SCODOC_VERSION_DIR}"/scodoc.sn
|
|
|
|
else
|
|
|
|
echo 'Warning: cannot connect to scodoc release server'
|
|
|
|
fi
|
|
|
|
|
|
|
|
# ------------ LIEN VERS .env
|
|
|
|
# Pour conserver le .env entre les mises à jour, on le génère dans
|
|
|
|
# /opt/scodoc-data/;env et on le lie:
|
|
|
|
if [ ! -e "$SCODOC_DIR/.env" ] && [ ! -L "$SCODOC_DIR/.env" ]
|
|
|
|
then
|
|
|
|
ln -s "$SCODOC_VAR_DIR/.env" "$SCODOC_DIR"
|
|
|
|
fi
|
2021-08-24 23:36:58 +02:00
|
|
|
|
|
|
|
# ------------ CREATION DU VIRTUALENV
|
2021-08-25 21:55:27 +02:00
|
|
|
# donc re-créé sur le client à chaque install ou upgrade
|
2021-08-24 23:36:58 +02:00
|
|
|
#echo "Creating python3 virtualenv..."
|
2021-08-27 17:03:47 +02:00
|
|
|
su -c "(cd $SCODOC_DIR && python3 -m venv venv)" "$SCODOC_USER" || die "Error creating Python 3 virtualenv"
|
2021-08-24 23:36:58 +02:00
|
|
|
|
|
|
|
# ------------ INSTALL DES PAQUETS PYTHON (3.9)
|
|
|
|
# pip in our env, as user "scodoc"
|
2021-08-27 17:03:47 +02:00
|
|
|
su -c "(cd $SCODOC_DIR && source venv/bin/activate && pip install wheel && pip install -r requirements-3.9.txt)" "$SCODOC_USER" || die "Error installing python packages"
|
2021-08-24 23:36:58 +02:00
|
|
|
|
2021-08-25 16:55:30 +02:00
|
|
|
# --- NGINX
|
2021-08-25 21:55:27 +02:00
|
|
|
if [ ! -L /etc/nginx/sites-enabled/scodoc9.nginx ]
|
|
|
|
then
|
2021-08-27 10:41:22 +02:00
|
|
|
echo "Enabling scodoc9 in nginx"
|
2021-08-25 21:55:27 +02:00
|
|
|
ln -s /etc/nginx/sites-available/scodoc9.nginx /etc/nginx/sites-enabled/
|
|
|
|
fi
|
2021-08-25 16:55:30 +02:00
|
|
|
/bin/rm -f /etc/nginx/sites-enabled/default
|
2021-08-24 23:36:58 +02:00
|
|
|
|
2021-08-27 10:41:22 +02:00
|
|
|
# ------------ POSTGRESQL
|
2021-08-24 16:18:00 +02:00
|
|
|
# --- Ensure postgres user "scodoc" ($POSTGRES_USER) exists
|
|
|
|
init_postgres_user
|
|
|
|
|
2021-08-27 17:03:47 +02:00
|
|
|
# ------------ BASE DE DONNEES
|
|
|
|
# gérées avec Flask-Migrate (Alembic/SQLAlchemy)
|
|
|
|
# Si la base SCODOC existe, tente de la mettre à jour
|
|
|
|
# (Ne gère pas les bases DEV et TEST)
|
|
|
|
n=$(su -c "psql -l | grep -c -E '^[[:blank:]]*SCODOC[[:blank:]]*\|'" "$SCODOC_USER")
|
|
|
|
if [ "$n" == 1 ]
|
|
|
|
then
|
|
|
|
echo "Upgrading existing SCODOC database..."
|
|
|
|
# utilise les scripts dans migrations/version/
|
|
|
|
# pour mettre à jour notre base (en tant qu'utilisateur scodoc)
|
|
|
|
export SQLALCHEMY_DATABASE_URI="postgresql:///SCODOC"
|
|
|
|
su -c "(cd $SCODOC_DIR && source venv/bin/activate && flask db upgrade)" "$SCODOC_USER"
|
|
|
|
fi
|
2021-08-27 10:41:22 +02:00
|
|
|
|
|
|
|
# ------------ CONFIG SERVICE SCODOC
|
|
|
|
echo
|
|
|
|
echo "Installation du service systemd scodoc9..."
|
|
|
|
cp "$SCODOC_DIR"/tools/etc/scodoc9.service /etc/systemd/system/
|
|
|
|
systemctl daemon-reload
|
|
|
|
|
|
|
|
# ------------ MISES A JOUR
|
2021-08-25 23:51:07 +02:00
|
|
|
cp "$SCODOC_DIR"/tools/etc/scodoc-updater.service /etc/systemd/system
|
|
|
|
cp "$SCODOC_DIR"/tools/etc/scodoc-updater.timer /etc/systemd/system
|
|
|
|
systemctl enable scodoc-updater.timer
|
|
|
|
systemctl start scodoc-updater.timer
|
|
|
|
|
2021-08-25 21:55:27 +02:00
|
|
|
# --- SYSTEMD: on a (peut-être) installé un fichier de service
|
2021-08-24 16:18:00 +02:00
|
|
|
systemctl daemon-reload
|
2021-08-25 23:05:41 +02:00
|
|
|
systemctl enable scodoc9
|
|
|
|
|