1
|
#!/bin/sh
|
2
|
|
3
|
#Ce script est une automatisation de ce qui est détaillé ici :
|
4
|
#https://forge.centrale-marseille.fr/projects/clubdrupal/wiki/Utilisation_de_Drupal_multi-site#Cr%C3%A9ation-du-site-drupal-7
|
5
|
#Ce script ne crée que des sites sur le sous domaine assos.
|
6
|
|
7
|
|
8
|
#fonction de demande de mot de passe (entree cachee)
|
9
|
# usage: pass=$(askpasswd "Tu me pretes ton mot de passe ?")
|
10
|
askpasswd() {
|
11
|
echo $1 >&2
|
12
|
echo -n ">" >&2
|
13
|
stty_avant=$(stty -g)
|
14
|
stty -echo
|
15
|
read p
|
16
|
stty $stty_avant
|
17
|
echo "$p"
|
18
|
unset p
|
19
|
}
|
20
|
|
21
|
|
22
|
#Prend comme paramètre (facultatif) le nom du site et éventuellement le mot de passe de la base de donnée associée.
|
23
|
#Si le mdp n’est pas spécifié, on le génère
|
24
|
#on se place dans le home de asso en début de script
|
25
|
#les fichiers par défaut sont sur le bureau de assos
|
26
|
|
27
|
#On vérifie que la longueur du nom du site est <= 16 caractères. Sinon mysql ne peut pas créer l’utilisateur
|
28
|
if [ $(echo $1 | wc -n) -le 16 ]
|
29
|
then
|
30
|
echo 'Le nom du site ne peut exéder 16 caractères'
|
31
|
exit 1
|
32
|
fi
|
33
|
|
34
|
|
35
|
vers_home="/users/guest/assos"
|
36
|
cd $vers_home
|
37
|
|
38
|
#On récupère le nom du site donné en paramètre
|
39
|
nom_site=$1
|
40
|
|
41
|
site_rep="$vers_home/htmltest/sites/assos.centrale-marseille.fr.$1"
|
42
|
site_settings="$site_rep/settings.php"
|
43
|
|
44
|
settings_default="settings-D7-bddinde-template.php"
|
45
|
template_settings="$vers_home/Desktop/$settings_default"
|
46
|
|
47
|
nom_serveurbdd="myassos.serv.int"
|
48
|
user_bdd="assos"
|
49
|
|
50
|
#on récupère le mot de passe, je ne prétends pas qu’il s’agit de la meilleure méthode loin de là.
|
51
|
#Pour ce faire, on va envoyer une requête mysql vide.
|
52
|
mdp_assos="pourquemysqldemandepas"
|
53
|
|
54
|
#requête mysql fantoche
|
55
|
#l’option -h permet de sélectionner le serveur
|
56
|
#l’option -e permet d’exécuter la commande mysql qui suit (on met le mdp après)
|
57
|
while ! mysql -h $nom_serveurbdd -u $user_bdd -p$mdp_assos -e "" 2>/dev/null;
|
58
|
do
|
59
|
mdp_assos=$(askpasswd "Entrer le mot de passe la base de donnée MySQL :")
|
60
|
echo ""
|
61
|
done
|
62
|
|
63
|
|
64
|
#on génère le mdp
|
65
|
# *avec des caractères spéciaux*. On se protège du caractère / qui
|
66
|
#signifie que l’expression régulière de sed est finie (voir plus bas). On boucle
|
67
|
#tant que le mot de passe contient /
|
68
|
mdp_site='/'
|
69
|
taille_mdp=20
|
70
|
while echo "$mdp_site" | grep -Fq '/'
|
71
|
do
|
72
|
mdp_site=`dd if=/dev/urandom count=1 | uuencode -m - | head -n 2 | tail -n 1 | cut -c-$taille_mdp`
|
73
|
done
|
74
|
|
75
|
#On ajoute des précaution :
|
76
|
# - On teste si le dossier existe déjà, s’il n’existe pas, on s’arrête
|
77
|
# - On vérifie que la base de données n’existe pas
|
78
|
|
79
|
#Vérifie base de donnée
|
80
|
if ! mysql -h $nom_serveurbdd -u $user_bdd -e "USE $nom_site" -p$mdp_assos 2>/dev/null
|
81
|
then
|
82
|
#On vérifie pour le dossier
|
83
|
if ! [ -d $site_rep ]
|
84
|
then
|
85
|
#on crée le dossier
|
86
|
mkdir $site_rep
|
87
|
|
88
|
#mysql (besoin du mot de passe assos)
|
89
|
mysql -h $nom_serveurbdd -u $user_bdd -e "CREATE DATABASE $nom_site" -p$mdp_assos
|
90
|
|
91
|
#la ligne suivante vient de http://www.siteduzero.com/tutoriel-3-613143-syntaxe-sql-et-premieres-commandes.html
|
92
|
#voir là-bas pour les explications
|
93
|
mysql -h $nom_serveurbdd -u $user_bdd -e "GRANT ALL PRIVILEGES ON $1.* TO '$nom_site'@'%' IDENTIFIED BY '$mdp_site'" -p$mdp_assos
|
94
|
|
95
|
|
96
|
|
97
|
#on veut modifer le nom de la base de donnée (%%DBNAME%%), le nom de l’utilisateur (%%DBUSER%%), son mot de passe (%%DBPASS%%) et base_url (%%nomdusite%%)
|
98
|
sed "s/\%\%DBUSER\%\%/$nom_site/ ; s/\%\%DBNAME\%\%/$nom_site/ ; s/\%\%DBPASS\%\%/$mdp_site/ ; s/\%\%nomsite\%\%/$nom_site/" < $template_settings > $site_settings
|
99
|
|
100
|
#on crée le lien symbolique (on doit se placer dans le bon répertoire !)
|
101
|
cd $site_rep
|
102
|
cd ./../..
|
103
|
ln -s . $nom_site
|
104
|
#on retourne dans home
|
105
|
cd $vers_home
|
106
|
|
107
|
#On affiche le lien
|
108
|
echo "Suivez les instructions de http://assos.centrale-marseille.fr/$nom_site/install.php pour continuer."
|
109
|
echo "Pressez entrée une fois les actions effectuées"
|
110
|
read touche
|
111
|
|
112
|
#On appelle init_var.sh
|
113
|
cd $site_rep
|
114
|
init_var.sh
|
115
|
|
116
|
#On active piwik l’outil de statistique
|
117
|
drush -y vset piwik_site_id "101"
|
118
|
drush -y vset piwik_url_http "http://piwik.centrale-marseille.fr/"
|
119
|
drush -y vset piwik_url_https "https://piwik.centrale-marseille.fr/"
|
120
|
# active le cache local du javascript
|
121
|
drush -y vset piwik_cache 1
|
122
|
drush -y vset piwik_visibility_roles "1"
|
123
|
# active les stats pour anonymous et authentifié
|
124
|
drush -y vset --format=json piwik_roles '{"1":0,"2":0}'
|
125
|
drush -y vset piwik_page_title_hierarchy 1
|
126
|
# si la recherche locale est activée
|
127
|
drush -y vset piwik_site_search 1
|
128
|
# on active le module
|
129
|
drush -y en piwik
|
130
|
|
131
|
#On donne les dernières instructions
|
132
|
echo "Quelques dernières instructions :"
|
133
|
echo "- Conseiller à l'administrateur de ne pas laisser les inscriptions ouvertes à son site"
|
134
|
echo "- Donner à l'administrateur le lien des tutoriels écrits par le club Drupal "
|
135
|
echo "\n"
|
136
|
echo "Référencement du site"
|
137
|
echo "- créer un contenu de type \"Site\" sur la page du projet multiassos"
|
138
|
echo "- demander à l'administrateur du site de s’inscrire sur la liste de diffusion webmasters@listes.centrale-marseille.fr (l’inscription est automatique)"
|
139
|
else
|
140
|
echo "Le dossier $site_rep existe déjà"
|
141
|
fi
|
142
|
else
|
143
|
echo "La base de donnée existe déjà"
|
144
|
fi
|