3 /***************************************************************************\
4 * SPIP, Systeme de publication pour l'internet *
6 * Copyright (c) 2001-2014 *
7 * Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James *
9 * Ce programme est un logiciel libre distribue sous licence GNU/GPL. *
10 * Pour plus de details voir le fichier COPYING.txt ou l'aide en ligne. *
11 \***************************************************************************/
14 if (defined('_ECRIRE_INC_VERSION')) return;
15 define('_ECRIRE_INC_VERSION', "1");
17 # masquer les eventuelles erreurs sur les premiers define
18 error_reporting(E_ALL ^ E_NOTICE
);
20 # version PHP minimum exigee (cf. inc/utils)
21 define ('_PHP_MIN', '5.1.0');
23 # le nom du repertoire ecrire/
24 if (!defined('_DIR_RESTREINT_ABS')) define('_DIR_RESTREINT_ABS', 'ecrire/');
25 # sommes-nous dans ecrire/ ?
26 define('_DIR_RESTREINT',
27 (!is_dir(_DIR_RESTREINT_ABS
) ?
"" : _DIR_RESTREINT_ABS
));
29 define('_DIR_RACINE', _DIR_RESTREINT ?
'' : '../');
32 define('_ROOT_RACINE', dirname(dirname(__FILE__
)).'/');
33 define('_ROOT_CWD', getcwd().'/');
34 define('_ROOT_RESTREINT', _ROOT_CWD
. _DIR_RESTREINT
);
37 # nom du dossier images
38 if (!defined('_NOM_IMG_PACK')) define('_NOM_IMG_PACK', 'images/');
39 # le chemin http (relatif) vers les images standard
40 define('_DIR_IMG_PACK', (_DIR_RACINE
. 'prive/' . _NOM_IMG_PACK
));
42 # le chemin php (absolu) vers les images standard (pour hebergement centralise)
43 define('_ROOT_IMG_PACK', dirname(dirname(__FILE__
)) . '/prive/' . _NOM_IMG_PACK
);
45 # le nom du repertoire des bibliotheques JavaScript
46 if (!defined('_JAVASCRIPT')) define('_JAVASCRIPT', 'javascript/'); // utilisable avec #CHEMIN et find_in_path
47 define('_DIR_JAVASCRIPT', (_DIR_RACINE
. 'prive/' . _JAVASCRIPT
));
49 # Le nom des 4 repertoires modifiables par les scripts lances par httpd
50 # Par defaut ces 4 noms seront suffixes par _DIR_RACINE (cf plus bas)
51 # mais on peut les mettre ailleurs et changer completement les noms
53 # le nom du repertoire des fichiers Temporaires Inaccessibles par http://
54 if (!defined('_NOM_TEMPORAIRES_INACCESSIBLES')) define('_NOM_TEMPORAIRES_INACCESSIBLES', "tmp/");
55 # le nom du repertoire des fichiers Temporaires Accessibles par http://
56 if (!defined('_NOM_TEMPORAIRES_ACCESSIBLES')) define('_NOM_TEMPORAIRES_ACCESSIBLES', "local/");
57 # le nom du repertoire des fichiers Permanents Inaccessibles par http://
58 if (!defined('_NOM_PERMANENTS_INACCESSIBLES')) define('_NOM_PERMANENTS_INACCESSIBLES', "config/");
59 # le nom du repertoire des fichiers Permanents Accessibles par http://
60 if (!defined('_NOM_PERMANENTS_ACCESSIBLES')) define('_NOM_PERMANENTS_ACCESSIBLES', "IMG/");
63 // Le nom du fichier de personnalisation
64 if (!defined('_NOM_CONFIG')) define('_NOM_CONFIG', 'mes_options');
66 // Son emplacement absolu si on le trouve
67 if (@file_exists
($f = _ROOT_RACINE
. _NOM_PERMANENTS_INACCESSIBLES
. _NOM_CONFIG
. '.php')
68 OR (@file_exists
($f = _ROOT_RESTREINT
. _NOM_CONFIG
. '.php'))) {
69 define('_FILE_OPTIONS', $f);
70 } else define('_FILE_OPTIONS', '');
72 // les modules par defaut pour la traduction.
73 // Constante utilisee par le compilateur et le decompilateur
74 // sa valeur etant traitee par inc_traduire_dist
76 if (!defined('MODULES_IDIOMES')) define('MODULES_IDIOMES', 'public|spip|ecrire');
78 // *** Fin des define *** //
81 // Inclure l'ecran de securite
82 if (!defined('_ECRAN_SECURITE')
83 AND @file_exists
($f = _ROOT_RACINE
. _NOM_PERMANENTS_INACCESSIBLES
. 'ecran_securite.php'))
87 * Détecteur de robot d'indexation
89 if (!defined('_IS_BOT')){
91 isset($_SERVER['HTTP_USER_AGENT'])
94 ',bot|slurp|crawler|spider|webvac|yandex|'
96 . '80legs|accoona|AltaVista|ASPSeek|Baidu|Charlotte|EC2LinkFinder|eStyle|Google|Genieo|INA dlweb|InfegyAtlas|Java VM|LiteFinder|Lycos|Rambler|Scooter|ScrubbyBloglines|Yahoo|Yeti'
97 . ',i', (string)$_SERVER['HTTP_USER_AGENT'])
102 // *** Parametrage par defaut de SPIP ***
104 // Les globales qui suivent peuvent etre modifiees
105 // dans le fichier de personnalisation indique ci-dessus.
106 // Il suffit de copier les lignes ci-dessous, et ajouter le marquage de debut
107 // et fin de fichier PHP ("< ?php" et "? >", sans les espaces)
108 // Ne pas les rendre indefinies.
110 # comment on logge, defaut 4 tmp/spip.log de 100k, 0 ou 0 suppriment le log
112 $taille_des_logs = 100;
114 // Definir les niveaux de log
115 defined('_LOG_HS') ||
define('_LOG_HS', 0);
116 defined('_LOG_ALERTE_ROUGE') ||
define('_LOG_ALERTE_ROUGE', 1);
117 defined('_LOG_CRITIQUE') ||
define('_LOG_CRITIQUE', 2);
118 defined('_LOG_ERREUR') ||
define('_LOG_ERREUR', 3);
119 defined('_LOG_AVERTISSEMENT') ||
define('_LOG_AVERTISSEMENT', 4);
120 defined('_LOG_INFO_IMPORTANTE') ||
define ('_LOG_INFO_IMPORTANTE', 5);
121 defined('_LOG_INFO') ||
define('_LOG_INFO', 6);
122 defined('_LOG_DEBUG') ||
define('_LOG_DEBUG', 7);
124 // on peut definir _LOG_FILTRE_GRAVITE dans mes_options.php
126 // Prefixe des tables dans la base de donnees
127 // (a modifier pour avoir plusieurs sites SPIP dans une seule base)
128 $table_prefix = "spip";
130 // Prefixe des cookies
131 // (a modifier pour installer des sites SPIP dans des sous-repertoires)
132 $cookie_prefix = "spip";
134 // Dossier des squelettes
135 // (a modifier si l'on veut passer rapidement d'un jeu de squelettes a un autre)
136 $dossier_squelettes = "";
138 // Pour le javascript, trois modes : parano (-1), prive (0), ok (1)
139 // parano le refuse partout, ok l'accepte partout
140 // le mode par defaut le signale en rouge dans l'espace prive
141 // Si < 1, les fichiers SVG sont traites s'ils emanent d'un redacteur
142 $filtrer_javascript = 0;
143 // PS: dans les forums, petitions, flux syndiques... c'est *toujours* securise
146 // 'page': spip.php?article123 [c'est la valeur par defaut pour SPIP 2.0]
147 // 'html': article123.html
148 // 'propres': Titre-de-l-article
149 // 'propres2' : Titre-de-l-article.html (base sur 'propres')
150 // 'arbo' : /article/Titre
151 $type_urls = 'page'; // 'page' => surcharge possible par configuration
153 #la premiere date dans le menu deroulant de date de publication
154 # null: automatiquement (affiche les 8 dernieres annees)
155 # 0: affiche un input libre
156 # 1997: le menu commence a 1997 jusqu'a annee en cours
157 $debut_date_publication = null;
162 // On note le numero IP du client dans la variable $ip
164 if (isset($_SERVER['HTTP_X_FORWARDED_FOR'])) $ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
165 if (isset($_SERVER['REMOTE_ADDR'])) $ip = $_SERVER['REMOTE_ADDR'];
167 // Pour renforcer la privacy, decommentez la ligne ci-dessous (ou recopiez-la
168 // dans le fichier config/mes_options) : SPIP ne pourra alors conserver aucun
169 // numero IP, ni temporairement lors des visites (pour gerer les statistiques
170 // ou dans spip.log), ni dans les forums (responsabilite)
171 # $ip = substr(md5($ip),0,16);
174 // faut-il faire des connexions completes rappelant le nom du serveur et/ou de
175 // la base MySQL ? (utile si vos squelettes appellent d'autres bases MySQL)
176 // (A desactiver en cas de soucis de connexion chez certains hebergeurs)
177 // Note: un test a l'installation peut aussi avoir desactive
178 // $mysql_rappel_nom_base directement dans le fichier inc_connect
179 $mysql_rappel_connexion = true;
180 $mysql_rappel_nom_base = true;
182 // faut-il afficher en rouge les chaines non traduites ?
185 // faut-il ignorer l'authentification par auth http/remote_user ?
186 $ignore_auth_http = false;
187 $ignore_remote_user = true; # methode obsolete et risquee
189 // Invalider les caches a chaque modification du contenu ?
190 // Si votre site a des problemes de performance face a une charge tres elevee,
191 // vous pouvez mettre cette globale a false (dans mes_options).
192 $derniere_modif_invalide = true;
194 // Quota : la variable $quota_cache, si elle est > 0, indique la taille
195 // totale maximale desiree des fichiers contenus dans le cache ; ce quota n'est
196 // pas "dur" : si le site necessite un espace plus important, il le prend
203 $home_server = 'http://www.spip.net';
204 $help_server = array($home_server . '/aide');
205 # glossaire pour raccourci [?X]. Aussi: [?X#G] et definir glossaire_G
206 $url_glossaire_externe = "http://@lang@.wikipedia.org/wiki/%s";
209 $tex_server = 'http://math.spip.org/tex.php';
210 # MathML (pas pour l'instant: manque un bon convertisseur)
211 // $mathml_server = 'http://arno.rezo.net/tex2mathml/latex.php';
213 // Produire du TeX ou du MathML ?
214 $traiter_math = 'tex';
216 // Appliquer un indenteur XHTML aux espaces public et/ou prive ?
220 // Vignettes de previsulation des referers
221 // dans les statistiques
222 // 2 de trouves, possibilite de switcher
223 // - Alexa, equivalent Thumbshots, avec vignettes beaucoup plus grandes mais avertissement si pas de preview
224 // Pour Alexa, penser a indiquer l'url du site dans l'id.
225 // Dans Alexa, si on supprimer size=small, alors vignettes tres grandes
226 // - apercite.fr : on conserve exactement la même expression pour insérer l'url du site
227 $source_vignettes = "http://www.apercite.fr/api/apercite/120x90/oui/oui/http://";
228 // $source_vignettes = "http://pthumbnails.alexa.com/image_server.cgi?id=www.monsite.net&size=small&url=http://";
230 $formats_logos = array ('gif', 'jpg', 'png');
232 // Controler les dates des item dans les flux RSS ?
233 $controler_dates_rss = true;
237 // Pipelines & plugins
239 # les pipeline standards (traitements derivables aka points d'entree)
240 # ils seront compiles par la suite
241 # note: un pipeline non reference se compile aussi, mais uniquement
242 # lorsqu'il est rencontre
243 // http://doc.spip.org/@Tuto-Se-servir-des-points-d-entree
244 $spip_pipeline = array();
246 # la matrice standard (fichiers definissant les fonctions a inclure)
247 $spip_matrice = array ();
248 # les plugins a activer
249 $plugins = array(); // voir le contenu du repertoire /plugins/
250 # les surcharges de include_spip()
251 $surcharges = array(); // format 'inc_truc' => '/plugins/chose/inc_truc2.php'
253 // Variables du compilateur de squelettes
255 $exceptions_des_tables = array();
256 $tables_principales = array();
257 $table_des_tables = array();
258 $tables_auxiliaires = array();
259 $table_primary = array();
260 $table_date = array();
261 $table_titre = array();
262 $tables_jointures = array();
264 // Liste des statuts.
265 $liste_des_statuts = array(
266 "info_administrateurs" => '0minirezo',
267 "info_redacteurs" =>'1comite',
268 "info_visiteurs" => '6forum',
269 "texte_statut_poubelle" => '5poubelle'
272 $liste_des_etats = array(
273 'texte_statut_en_cours_redaction' => 'prepa',
274 'texte_statut_propose_evaluation' => 'prop',
275 'texte_statut_publie' => 'publie',
276 'texte_statut_poubelle' => 'poubelle',
277 'texte_statut_refuse' => 'refuse'
280 // liste des methodes d'authentifications
281 $liste_des_authentifications = array(
286 // Experimental : pour supprimer systematiquement l'affichage des numeros
287 // de classement des titres, recopier la ligne suivante dans mes_options :
288 # $table_des_traitements['TITRE'][]= 'typo(supprimer_numero(%s), "TYPO", $connect)';
290 // Droits d'acces maximum par defaut
293 // numero de branche, utilise par les plugins
294 // pour specifier les versions de SPIP necessaires
295 // il faut s'en tenir a un nombre de decimales fixe
296 // ex : 2.0.0, 2.0.0-dev, 2.0.0-beta, 2.0.0-beta2
297 $spip_version_branche = "3.0.19";
298 // version des signatures de fonctions PHP
299 // (= numero SVN de leur derniere modif cassant la compatibilite et/ou necessitant un recalcul des squelettes)
300 $spip_version_code = 17873;
301 // version de la base SQL (= numero SVN de sa derniere modif)
302 $spip_version_base = 19268;
304 // version de l'interface a la base
305 $spip_sql_version = 1;
307 // version de spip en chaine
308 // 1.xxyy : xx00 versions stables publiees, xxyy versions de dev
309 // (ce qui marche pour yy ne marchera pas forcement sur une version plus ancienne)
310 $spip_version_affichee = "$spip_version_branche";
313 $visiteur_session = $auteur_session = $connect_statut = $connect_toutes_rubriques = $hash_recherche = $hash_recherche_strict = $ldap_present ='';
314 $meta = $connect_id_rubrique = array();
316 // *** Fin des globales *** //
319 // Charger les fonctions liees aux serveurs Http et Sql.
321 require_once _ROOT_RESTREINT
. 'inc/utils.php';
322 require_once _ROOT_RESTREINT
. 'base/connect_sql.php';
324 // Definition personnelles eventuelles
326 if (_FILE_OPTIONS
) {include_once _FILE_OPTIONS
;}
328 // Masquer les warning
329 if (!defined('E_DEPRECATED')) define('E_DEPRECATED', 8192); // compatibilite PHP 5.3
330 if (!defined('SPIP_ERREUR_REPORT')) define('SPIP_ERREUR_REPORT', E_ALL ^ E_NOTICE ^ E_DEPRECATED
);
331 error_reporting(SPIP_ERREUR_REPORT
);
333 // Initialisations critiques non surchargeables par les plugins
334 // INITIALISER LES REPERTOIRES NON PARTAGEABLES ET LES CONSTANTES
335 // (charge aussi inc/flock)
337 // mais l'inclusion precedente a peut-etre deja appele cette fonction
338 // ou a defini certaines des constantes que cette fonction doit definir
339 // ===> on execute en neutralisant les messages d'erreur
341 spip_initialisation_core(
342 (_DIR_RACINE
. _NOM_PERMANENTS_INACCESSIBLES
),
343 (_DIR_RACINE
. _NOM_PERMANENTS_ACCESSIBLES
),
344 (_DIR_RACINE
. _NOM_TEMPORAIRES_INACCESSIBLES
),
345 (_DIR_RACINE
. _NOM_TEMPORAIRES_ACCESSIBLES
)
349 // chargement des plugins : doit arriver en dernier
350 // car dans les plugins on peut inclure inc-version
351 // qui ne sera pas execute car _ECRIRE_INC_VERSION est defini
352 // donc il faut avoir tout fini ici avant de charger les plugins
354 if (@is_readable
(_CACHE_PLUGINS_OPT
) AND @is_readable
(_CACHE_PLUGINS_PATH
)){
355 // chargement optimise precompile
356 include_once(_CACHE_PLUGINS_OPT
);
358 spip_initialisation_suite();
359 include_spip('inc/plugin');
360 // generer les fichiers php precompiles
361 // de chargement des plugins et des pipelines
362 actualise_plugins_actifs();
364 // Initialisations non critiques surchargeables par les plugins
365 spip_initialisation_suite();
367 // niveau maxi d'enregistrement des logs
368 defined('_LOG_FILTRE_GRAVITE') ||
define('_LOG_FILTRE_GRAVITE', _LOG_INFO_IMPORTANTE
);
370 if (!defined('_OUTILS_DEVELOPPEURS'))
371 define('_OUTILS_DEVELOPPEURS',false);
373 // charger systematiquement inc/autoriser dans l'espace restreint
374 if (test_espace_prive())
375 include_spip('inc/autoriser');
377 // Installer Spip si pas installe... sauf si justement on est en train
380 OR autoriser_sans_cookie(_request('exec'))
381 OR _request('action') == 'cookie'
382 OR _request('action') == 'converser'
383 OR _request('action') == 'test_dirs')) {
385 // Si on peut installer, on lance illico
386 if (test_espace_prive()) {
387 include_spip('inc/headers');
388 redirige_url_ecrire("install");
390 // Si on est dans le site public, dire que qq s'en occupe
391 include_spip('inc/minipres');
392 utiliser_langue_visiteur();
393 echo minipres(_T('info_travaux_titre'), "<p style='text-align: center;'>"._T('info_travaux_texte')."</p>");
396 // autrement c'est une install ad hoc (spikini...), on sait pas faire
400 // Vanter notre art de la composition typographique
401 // La globale $spip_header_silencieux permet de rendre le header minimal pour raisons de securite
402 if (!defined('_HEADER_COMPOSED_BY')) define('_HEADER_COMPOSED_BY', "Composed-By: SPIP");
403 if (!headers_sent()) {
404 header("Vary: Cookie, Accept-Encoding");
405 if (!isset($GLOBALS['spip_header_silencieux']) OR !$GLOBALS['spip_header_silencieux'])
406 header(_HEADER_COMPOSED_BY
. " $spip_version_affichee @ www.spip.net" . (isset($GLOBALS['meta']['plugin_header'])?
(" + ".$GLOBALS['meta']['plugin_header']):""));
407 else // header minimal
408 header(_HEADER_COMPOSED_BY
. " @ www.spip.net");
411 spip_log($_SERVER['REQUEST_METHOD'].' '.self() . ' - '._FILE_CONNECT
,_LOG_DEBUG
);