Projet

Général

Profil

Paste
Télécharger (5,23 ko) Statistiques
| Branche: | Révision:

root / bin / creation_sites_D7.sh @ 4908f694

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 le nom du site
23
#On génère le mot de passe
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 le nom du site est bien passé en argument.
28
if [ -z $1 ]
29
then
30
    echo 'Le nom du site doit être donné en paramètre'
31
    echo 'creation_site_D7.sh NOM_SITE'
32
    exit 1
33
fi
34

    
35
#On vérifie que la longueur du nom du site est <= 16 caractères. Sinon mysql ne peut pas créer l’utilisateur
36
if [ $(echo $1 | wc -n) -le 16 ]
37
then
38
    echo 'Le nom du site ne peut exéder 16 caractères'
39
    exit 1
40
fi
41

    
42

    
43
vers_home="/users/guest/assos"
44
cd $vers_home
45

    
46
#On récupère le nom du site donné en paramètre
47
nom_site=$1
48

    
49
site_rep="$vers_home/htmltest/sites/assos.centrale-marseille.fr.$1"
50
site_settings="$site_rep/settings.php"
51

    
52
settings_default="settings-D7-bddinde-template.php"
53
template_settings="$vers_home/Desktop/$settings_default"
54

    
55
nom_serveurbdd="myassos.serv.int"
56
user_bdd="assos"
57

    
58
#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à.
59
#Pour ce faire, on va envoyer une requête mysql vide.
60
mdp_assos="pourquemysqldemandepas"
61

    
62
#requête mysql fantoche
63
#l’option -h permet de sélectionner le serveur
64
#l’option -e permet d’exécuter la commande mysql qui suit (on met le mdp après)
65
while ! mysql -h $nom_serveurbdd -u $user_bdd -p$mdp_assos -e "" 2>/dev/null;
66
do
67
    mdp_assos=$(askpasswd "Entrer le mot de passe la base de donnée MySQL :")
68
    echo ""
69
done
70

    
71

    
72
#on génère le mdp
73
#        *avec des caractères spéciaux*. On se protège du caractère / qui
74
#signifie que l’expression régulière de sed est finie (voir plus bas). On boucle
75
#tant que le mot de passe contient /
76
mdp_site='/'
77
taille_mdp=20
78
while echo "$mdp_site" | grep -Fq '/'
79
do
80
    mdp_site=`dd if=/dev/urandom count=1 | uuencode -m - | head -n 2 | tail -n 1 | cut -c-$taille_mdp`
81
done
82

    
83
#On ajoute des précaution :
84
# - On teste si le dossier existe déjà, s’il n’existe pas, on s’arrête
85
# - On vérifie que la base de données n’existe pas
86

    
87
#Vérifie base de donnée
88
if ! mysql -h $nom_serveurbdd -u $user_bdd -e "USE $nom_site" -p$mdp_assos 2>/dev/null
89
then
90
    #On vérifie pour le dossier
91
    if ! [ -d $site_rep ]
92
    then
93
	#on crée le dossier
94
	mkdir $site_rep
95

    
96
	#mysql (besoin du mot de passe assos)
97
	mysql -h $nom_serveurbdd -u $user_bdd -e "CREATE DATABASE $nom_site" -p$mdp_assos
98

    
99
        #la ligne suivante vient de http://www.siteduzero.com/tutoriel-3-613143-syntaxe-sql-et-premieres-commandes.html
100
        #voir là-bas pour les explications
101
	mysql -h $nom_serveurbdd -u $user_bdd -e "GRANT ALL PRIVILEGES ON $1.* TO '$nom_site'@'%' IDENTIFIED BY '$mdp_site'" -p$mdp_assos
102

    
103

    
104

    
105
#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%%)
106
	sed "s/\%\%DBUSER\%\%/$nom_site/ ; s/\%\%DBNAME\%\%/$nom_site/ ; s/\%\%DBPASS\%\%/$mdp_site/ ; s/\%\%nomsite\%\%/$nom_site/" < $template_settings > $site_settings
107

    
108
	#on crée le lien symbolique (on doit se placer dans le bon répertoire !)
109
	cd $site_rep
110
	cd ./../..
111
	ln -s . $nom_site
112
	#on retourne dans home
113
	cd $vers_home
114

    
115
	#On affiche le lien
116
	echo "Suivez les instructions de http://assos.centrale-marseille.fr/$nom_site/install.php pour continuer."
117
	echo "Pressez entrée une fois les actions effectuées"
118
	read touche
119

    
120
	#On appelle init_var.sh
121
	cd $site_rep
122
	init_var.sh
123

    
124
	#On active piwik l’outil de statistique
125
	drush -y vset piwik_site_id "101"
126
	drush -y vset piwik_url_http "http://piwik.centrale-marseille.fr/"
127
	drush -y vset piwik_url_https "https://piwik.centrale-marseille.fr/"
128
        # active le cache local du javascript
129
	drush -y vset piwik_cache 1
130
	drush -y vset piwik_visibility_roles "1"
131
        # active les stats pour anonymous et authentifié
132
	drush -y vset --format=json piwik_roles '{"1":0,"2":0}'
133
	drush -y vset piwik_page_title_hierarchy 1
134
        # si la recherche locale est activée
135
	drush -y vset piwik_site_search 1
136
        # on active le module
137
	drush -y en piwik
138

    
139
	#On met les bons droits unix
140
	chmod -R 755 $site_rep
141
	chmod 400 $site_settings
142

    
143
	#On donne les dernières instructions
144
	echo "Quelques dernières instructions :"
145
	echo "- Conseiller à l'administrateur de ne pas laisser les inscriptions ouvertes à son site"
146
	echo "- Donner à l'administrateur le lien des tutoriels écrits par le club Drupal "
147
	echo "\n"
148
	echo "Référencement du site"
149
	echo "- créer un contenu de type \"Site\" sur la page du projet multiassos"
150
	echo "- demander à l'administrateur du site de s’inscrire sur la liste de diffusion webmasters@listes.centrale-marseille.fr (l’inscription est automatique)"
151

    
152
    else
153
	echo "Le dossier $site_rep existe déjà"
154
	exit 1
155
    fi
156
else
157
    echo "La base de donnée existe déjà"
158
    exit 1
159
fi