4 |
aurelien |
1 |
#!/bin/bash
|
|
|
2 |
###############################################################################
|
|
|
3 |
# But : Créer un rapport de base de données et le transférer sur le serveur par ftp.
|
|
|
4 |
# Auteur : Jean-Pascal Milcent <jpm@tela-botanica.org> (translate bat file to shell script)
|
|
|
5 |
# License : GPL v3
|
|
|
6 |
# Création : 22 décembre 2008
|
|
|
7 |
# Version: 0.1
|
|
|
8 |
# $Id$
|
|
|
9 |
###############################################################################
|
|
|
10 |
# Constante
|
|
|
11 |
NBREPARAM=$#
|
|
|
12 |
|
|
|
13 |
# Aide
|
|
|
14 |
E_OPTERR=65
|
|
|
15 |
if [ "$1" = '--help' ]
|
|
|
16 |
then # Le script a besoin d'au moins un argument sur la ligne de commande
|
|
|
17 |
echo "Usage $0 -[parameters -u, -p , -mu, -mp]"
|
|
|
18 |
echo "Paramétres : "
|
|
|
19 |
echo " -h: indiquer l'hote ftp"
|
|
|
20 |
echo " -u: indiquer le nom de l'utilisateur ftp"
|
|
|
21 |
echo " -p: indiquer le mot de passe de l'utilisateur ftp"
|
|
|
22 |
echo " -mu: indiquer le nom de l'utilisateur mysql"
|
|
|
23 |
echo " -mp: indiquer le mot de passe de l'utilisateur mysql"
|
|
|
24 |
exit $E_OPTERR
|
|
|
25 |
fi
|
|
|
26 |
|
|
|
27 |
# Récupération des paramètres et des options de la ligne de commande
|
|
|
28 |
TEMP=`getopt -o u:p:h: -l help:,mu:,mp: -- "$@"`
|
|
|
29 |
if [ $? != 0 ] ; then echo "Terminating..." >&2 ; exit 1 ; fi
|
|
|
30 |
eval set -- "$TEMP"
|
|
|
31 |
while [ ! -z "$1" ] ; do
|
|
|
32 |
#echo $1" # "$2
|
|
|
33 |
case "$1" in
|
|
|
34 |
-h) HOST=$2;;
|
|
|
35 |
-u) FTP_USER=$2;;
|
|
|
36 |
-p) FTP_PASSWD=$2;;
|
|
|
37 |
--mu) MYSQL_USER=$2;;
|
|
|
38 |
--mp) MYSQL_PASSWD=$2;;
|
|
|
39 |
--) shift ; break ;;
|
|
|
40 |
*) echo "Internal error!" ; exit 1 ;;
|
|
|
41 |
esac
|
|
|
42 |
shift 2
|
|
|
43 |
done
|
|
|
44 |
|
|
|
45 |
# Nous devons être dans le dossier de ce script pour que tout fonctionne
|
|
|
46 |
echo "Vérifions que nous sommes bien dans le dossier du fichier rapport_annuaire.sh : ";
|
|
|
47 |
pwd
|
|
|
48 |
echo "Déplacement dans le dossier contenant les scripts Perl";
|
|
|
49 |
cd ../..;
|
|
|
50 |
|
|
|
51 |
echo "Création du rapport";
|
|
|
52 |
perl rapportdbd.pl -m r -e ~/web/annuaire/doc/bdd/annuaire.xml -c ./modules/dbd_analyse/configuration/annuaire.ini
|
|
|
53 |
|
|
|
54 |
echo "Création du fichier SQL";
|
|
|
55 |
/opt/lampp/bin/php script.php dbd_analyse -a sql -p annuaire -e ~/web/annuaire/doc/bdd/annuaire.xml
|
|
|
56 |
|
|
|
57 |
|
|
|
58 |
fi;
|
|
|
59 |
|
|
|
60 |
echo "Compression du fichier sql"
|
|
|
61 |
if [ -f ~/web/annuaire/doc/bdd/annuaire.sql.bz2 ]; then
|
|
|
62 |
rm -f ~/web/annuaire/doc/bdd/annuaire.sql.bz2;
|
|
|
63 |
fi;
|
|
|
64 |
bzip2 -q ~/web/annuaire/doc/bdd/annuaire.sql
|
|
|
65 |
|
|
|
66 |
echo "Transfert sur le serveur"
|
|
|
67 |
if [ $NBREPARAM -eq 0 ]; then
|
|
|
68 |
echo "Pas de transfert sur le serveur. Utiliser --help pour voir les options de transfert."
|
|
|
69 |
else
|
|
|
70 |
lftp ftp://$FTP_USER:$FTP_PASSWD@$HOST -e "set ftp:passive off; mirror -e -R -x .svn ~/web/annuaire/doc/bdd /www/devel/doc/bdd/annuaire/annuaire_bdd_v1.0 ; quit"
|
|
|
71 |
fi
|