Dans un premier temps, vous devez avoir installé les mêmes fichiers que l’installation en mode standalone. Vous devez suivre cette partie de l’installation jusqu’à l’avant dernière étape. Cette explication remplace la dernière étape dans sa totalité.
Installation du plugin de mutualisation officiel de SPIP
Récupération du plugin
Dans un premier temps il est nécessaire d’ajouter à la racine du site le plugin "Mutualisation" de SPIP via son archive zip ou via svn de la sorte :
- svn co svn://zone.spip.org/spip-zone/_plugins_/mutualisation
Configuration du plugin mutualisation
Il est ensuite nécessaire de créer un fichier config/mes_options.php
central dont un fichier d’exemple est dans les fichiers récupérés du plugin "Mutualisation" (mutualisation/mes_options.php.txt
).
Pour continuer, nous conseillons de créer un nouvel utilisateur MySQL disposant de tous les droits (création de bases et création d’autres utilisateurs spécifique). Cela permettra :
- de ne pas mettre le mot de passe root directement dans un fichier de conf ;
- de pouvoir créer un utilisateur SQL pour chaque site de la ferme afin que chacun ne puisse se connecter aux bases de données d’autres utilisateurs ;
Les valeurs à impérativement personnaliser sont :
-
define ('_INSTALL_USER_DB_ROOT', 'user_sql_root');
en indiquant un nom d’utilisateur du serveur MySQL pouvant créer base et utilisateurs ; -
define ('_INSTALL_PASS_DB_ROOT', 'pass_user_sql_root');
en indiquant le mot de passe de l’utilisateur ci-dessus ; -
define ('_SITES_ADMIN_MUTUALISATION', 'admin.domaine.ext');
en indiquant le site de la ferme qui servira de site central de la ferme ; -
'code' => 'mot_de_passe_admin',
en indiquant un mot de passe central permettant de créer un site ; -
'url_hebergeur' => 'http://admin.domaine.ext',
en indiquant l’adresse du site central de la ferme ;
Le fichier de configuration final devra ressembler à cela :
- <?php
- require _DIR_RACINE.'mutualisation/mutualiser.php';
- $site = $_SERVER['HTTP_HOST'];
- if ($site != $_SERVER['HTTP_HOST']) {
- include_spip('inc/headers');
- redirige_par_entete('http://'.$site.'/');
- }
- include_spip('inc/acces');
- }
- verifier_htaccess('config/');
- /*
- * Creer automatiquement les users SQL (pg|mysql)
- *
- * Cela permet
- * - d'avoir un utilisateur root possedant les droits
- * de creation de bases
- * - de creer des utilisateurs sql automatiquement
- * ne possedant que les droits d'administation
- * de leur base de donnee qui sera créée
- */
- /*
- * Inscrire ici le nom du site d'administration du tableau de bord
- * de la mutualisation (ou plusieurs, separes par des virgules)
- * pour autoriser tous les sites, ne pas definir la constante ;
- * Si le site maitre n'est pas dans sites/ mais a la racine, mettre ''
- * et ajouter 'mutualisation' dans $dossier_squelettes
- */
- demarrer_site($site,
- 'creer_site' => true, // Créer ou non le site s'il n'existe pas (defaut: false)
- 'creer_base' => true, // Créer ou non la base de donnee si elle n'existe pas (false)
- 'creer_user_base' => true, // Céeer ou non un utilisateur pour la nouvelle base de donnee (false)
- 'mail' => 'admin@domaine.ext', // Adresse mail pour recevoir un mail lors d'une creation de site
- 'code' => 'mot_de_passe_admin', // Code d'activation utilisable par tout un chacun pour créer n'importe quel site
- 'table_prefix' => false, // Définir automatiquement le prefixe de table (false) ...
- 'cookie_prefix' => true, // Definir automatiquement le prefixe de cookie (false)
- 'repertoire' => 'sites', // Nom du répertoire contenant les sites mutualisés ('sites')
- 'url_img_courtes' => true, // Utiliser la redirection des URL d'images courtes dans la partie publique (false)
- 'utiliser_panel' => true, // Utiliser le plugin de gestion de mutualisation
- 'annonce' => '', // Texte a afficher en bas du formulaire d'activation de la mutualisation
- 'url_hebergeur' => 'http://admin.domaine.ext',
- 'url_contact_hebergeur' => ''
- )
- );
- $quota_cache = 50;
- ?>
Créer votre première instance de mutualisation
La première instance à créer est celle qui servira de site central de la ferme. On se rend donc sur son adresse http://admin.domaine.ext
(dans notre cas). et on met dans le champ demandant le mot de passe mot_de_passe_admin
(dans notre cas à nouveau).
Cette étape lance l’installation de SPIP qui est plus ou moins automatique jusqu’à la fin si les données que vous avez fourni dans le fichier config/mes_options.php
sont correctes. Il sera demandé :
- de choisir la langue ;
- de donner les informations du premier utilisateur ;
- uniquement de valider les autres étapes ;
À la dernière étape, il sera nécessaire de télécharger les librairies nécessaires.
Installation du plugin de gestion de la mutualisation
Il est ensuite nécessaire de définir que ce site en question peut avoir des plugins supplémentaires et ajouter le plugin de gestion de mutualisation accessible uniquement pour lui. Dans les lignes suivantes pensez à modifier les valeurs de admin.domaine.ext
par votre valeurs à vous.
Dans un premier temps on va créer un fichier mes_options.php
spécifique à ce site là dans le répertoire sites/admin.domaine.ext/config
qui a dû être créé par l’installation précédente. Le contenu de ce fichier doit être :
Puis on va créer le répertoire sites/admin.domaine.ext/plugins/
et y installer le plugin de gestion de mutualisation dans son propre répertoire de plugins dédié soit en récupérant le fichier zip plus haut, soit par svn :
- cd sites/admin.domaine.ext/plugins
- svn co http://svn.aires-de-confluxence.info/svn/plugins_spip/gestion_mutu
Vous devez alors activer ce plugin dans l’espace privé du site.