Subversion Repositories Applications.gtt

Compare Revisions

Ignore whitespace Rev 170 → Rev 171

/trunk/scripts/installgtt.sh/clonegtt.sh
1,6 → 1,6
#!/bin/bash
 
# Crée une instance de GTT pour l'année à venir.
# Installe GTT à partir du code en cours.
#
# Nécessite de remplir config.sh à partir de config.defaut.sh.
# Si un fichier "htaccess" est présent, il sera renommé en ".htaccess" dans le
7,9 → 7,9
# dossier de destination de la nouvelle instance
#
# Utilisation :
# ./clonegtt.sh 2016 trunk clonebdd
# ./installgtt.sh [prefixe]
#
# Mathias - 2015-12-23
# Mathias - 2015-12-28
 
# ligne magique trouvee sur http://stackoverflow.com/questions/59895/can-a-bash-script-tell-what-directory-its-stored-in
SCRIPTDIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
23,82 → 23,48
. "$SCRIPTDIR/config.sh"
 
function notice {
echo "Utilisation: $SCRIPTNAME annee branche [clonebdd]"
echo " annee: cree une instance de GTT pour l'annee fournie (ex: 2016), dans un nouveau dossier correspondant"
echo " branche: utilise une branche particuliere du SVN (ex: trunk, branches/v1.2-democrite)"
echo " clonebdd (optionnel): si mentionne, copiera les donnees (utilisateurs, projets, categories) de l'installation, dont le prefixe est specifie dans config.sh"
echo "Utilisation: $SCRIPTNAME [prefixe]"
echo " prefixe (optionnel): prefixe les tables de GTT dans la base de donnees"
echo "Exemples:"
echo " $SCRIPTNAME 2016 trunk clonebdd"
echo " $SCRIPTNAME 2016 branches/v1.2-democrite"
echo " $SCRIPTNAME"
echo " $SCRIPTNAME gtt_2016_"
}
 
function copie_table {
REQ="TRUNCATE ${PREFIXE}$1; INSERT INTO ${PREFIXE}$1 SELECT * FROM ${BDD_SOURCEPREFIXE}$1;"
#echo "$REQ"
CMD="$CHEMIN_MYSQL/mysql -h$BDD_HOTE -u$BDD_LOGIN -p$BDD_MDP -e \"$REQ\" $BDD_BASE"
eval "$CMD"
}
function install_gtt {
PREFIXE="$1"
 
function clone_gtt {
ANNEE="$1"
PREFIXE="gtt_${ANNEE}_"
echo "installation de GTT - prefixe: [$PREFIXE]"
 
echo "deploiement d'une instance de GTT pour l'ANNEE [$ANNEE]"
 
# copie du code
dossier_svn="trunk"
if [ "$#" -gt 1 ]; then
echo "recuperation de la branche [$2]";
dossier_svn="$2"
else
echo "recuperation du [trunk]"
fi
svn co "http://svn.tela-botanica.net/svn/applications/gtt/$dossier_svn" "$ANNEE"
 
# copie du .htaccess
if [ -e "$SCRIPTDIR/htaccess" ]; then
echo "copie du .htaccess de reference"
cp "$SCRIPTDIR/htaccess" "$ANNEE/.htaccess"
cp "$SCRIPTDIR/htaccess" "../.htaccess"
fi
 
# creation de la config
echo "creation de la config"
echo "<?php
// cree par clonegtt le $DATE
// cree par installgtt le $DATE
define('GTT_BDD_NOM', '$BDD_BASE');
define('GTT_BDD_DSN', 'mysql://$BDD_LOGIN:$BDD_MDP@$BDD_HOTE/'.GTT_BDD_NOM);
define('GTT_BDD_PREFIXE', '$PREFIXE');
define('GTT_DEBOGAGE', false);
define('GTT_DEBOGAGE_SQL', false);
?>" > "$ANNEE/config.inc.php"
?>" > "../config.inc.php"
 
# modification des fichiers .sql pour ajouter le prefixe, et insertion dans la base
# "sort" sert a s'assurer que "installation" est execute avant "maj" @WARNING bancal comme systeme !
find "$ANNEE/documentation" -name "*.sql" | sort | while read line; do
find "../documentation" -name "*.sql" | sort | while read line; do
echo "Insertion de $line"
sed "s/gestion_/${PREFIXE}gestion_/" "$line" > "${line}_${ANNEE}.sql"
CMD="$CHEMIN_MYSQL/mysql -h$BDD_HOTE -u$BDD_LOGIN -p$BDD_MDP $BDD_BASE < ${line}_${ANNEE}.sql"
sed "s/gestion_/${PREFIXE}gestion_/" "$line" > "${line}_${PREFIXE}.sql"
CMD="$CHEMIN_MYSQL/mysql -h$BDD_HOTE -u$BDD_LOGIN -p$BDD_MDP $BDD_BASE < ${line}_${PREFIXE}.sql"
eval $CMD
rm "${line}_${ANNEE}.sql"
rm "${line}_${PREFIXE}.sql"
done
 
# copie de l'ancienne base vers la nouvelle (configurer)
if [ "$#" -gt 2 ]; then
if [ "$3" = "clonebdd" ]; then
echo "clonage de la base precedente (prefixe [$BDD_SOURCE_PREFIXE])"
# copies SQL des tables a recuperer
copie_table "gestion_absence_motif"
copie_table "gestion_projet"
copie_table "gestion_projet_categorie"
copie_table "gestion_utilisateur"
copie_table "gestion_utilisateur_a_projet"
copie_table "gestion_utilisateur_statut"
fi
fi
}
 
if [ "$#" -lt 1 ]; then
if [ "$1" = "help" ]; then
notice
else
clone_gtt $@
install_gtt $@
fi