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 * detecteur de robot d'indexation
88 * utilise en divers endroits, centralise ici si l'ecran l'a pas deja fait
90 if (!defined('_IS_BOT'))
92 isset($_SERVER['HTTP_USER_AGENT'])
93 AND preg_match(',bot|slurp|crawler|spider|webvac|yandex|INA dlweb|EC2LinkFinder|80legs,i',
94 $_SERVER['HTTP_USER_AGENT'])
98 // *** Parametrage par defaut de SPIP ***
100 // Les globales qui suivent peuvent etre modifiees
101 // dans le fichier de personnalisation indique ci-dessus.
102 // Il suffit de copier les lignes ci-dessous, et ajouter le marquage de debut
103 // et fin de fichier PHP ("< ?php" et "? >", sans les espaces)
104 // Ne pas les rendre indefinies.
106 # comment on logge, defaut 4 tmp/spip.log de 100k, 0 ou 0 suppriment le log
108 $taille_des_logs = 100;
110 // Definir les niveaux de log
111 defined('_LOG_HS') ||
define('_LOG_HS', 0);
112 defined('_LOG_ALERTE_ROUGE') ||
define('_LOG_ALERTE_ROUGE', 1);
113 defined('_LOG_CRITIQUE') ||
define('_LOG_CRITIQUE', 2);
114 defined('_LOG_ERREUR') ||
define('_LOG_ERREUR', 3);
115 defined('_LOG_AVERTISSEMENT') ||
define('_LOG_AVERTISSEMENT', 4);
116 defined('_LOG_INFO_IMPORTANTE') ||
define ('_LOG_INFO_IMPORTANTE', 5);
117 defined('_LOG_INFO') ||
define('_LOG_INFO', 6);
118 defined('_LOG_DEBUG') ||
define('_LOG_DEBUG', 7);
120 // on peut definir _LOG_FILTRE_GRAVITE dans mes_options.php
122 // Prefixe des tables dans la base de donnees
123 // (a modifier pour avoir plusieurs sites SPIP dans une seule base)
124 $table_prefix = "spip";
126 // Prefixe des cookies
127 // (a modifier pour installer des sites SPIP dans des sous-repertoires)
128 $cookie_prefix = "spip";
130 // Dossier des squelettes
131 // (a modifier si l'on veut passer rapidement d'un jeu de squelettes a un autre)
132 $dossier_squelettes = "";
134 // Pour le javascript, trois modes : parano (-1), prive (0), ok (1)
135 // parano le refuse partout, ok l'accepte partout
136 // le mode par defaut le signale en rouge dans l'espace prive
137 // Si < 1, les fichiers SVG sont traites s'ils emanent d'un redacteur
138 $filtrer_javascript = 0;
139 // PS: dans les forums, petitions, flux syndiques... c'est *toujours* securise
142 // 'page': spip.php?article123 [c'est la valeur par defaut pour SPIP 2.0]
143 // 'html': article123.html
144 // 'propres': Titre-de-l-article
145 // 'propres2' : Titre-de-l-article.html (base sur 'propres')
146 // 'arbo' : /article/Titre
147 $type_urls = 'page'; // 'page' => surcharge possible par configuration
149 #la premiere date dans le menu deroulant de date de publication
150 # null: automatiquement (affiche les 8 dernieres annees)
151 # 0: affiche un input libre
152 # 1997: le menu commence a 1997 jusqu'a annee en cours
153 $debut_date_publication = null;
158 // On note le numero IP du client dans la variable $ip
160 if (isset($_SERVER['HTTP_X_FORWARDED_FOR'])) $ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
161 if (isset($_SERVER['REMOTE_ADDR'])) $ip = $_SERVER['REMOTE_ADDR'];
163 // Pour renforcer la privacy, decommentez la ligne ci-dessous (ou recopiez-la
164 // dans le fichier config/mes_options) : SPIP ne pourra alors conserver aucun
165 // numero IP, ni temporairement lors des visites (pour gerer les statistiques
166 // ou dans spip.log), ni dans les forums (responsabilite)
167 # $ip = substr(md5($ip),0,16);
170 // faut-il faire des connexions completes rappelant le nom du serveur et/ou de
171 // la base MySQL ? (utile si vos squelettes appellent d'autres bases MySQL)
172 // (A desactiver en cas de soucis de connexion chez certains hebergeurs)
173 // Note: un test a l'installation peut aussi avoir desactive
174 // $mysql_rappel_nom_base directement dans le fichier inc_connect
175 $mysql_rappel_connexion = true;
176 $mysql_rappel_nom_base = true;
178 // faut-il afficher en rouge les chaines non traduites ?
181 // faut-il ignorer l'authentification par auth http/remote_user ?
182 $ignore_auth_http = false;
183 $ignore_remote_user = true; # methode obsolete et risquee
185 // Invalider les caches a chaque modification du contenu ?
186 // Si votre site a des problemes de performance face a une charge tres elevee,
187 // vous pouvez mettre cette globale a false (dans mes_options).
188 $derniere_modif_invalide = true;
190 // Quota : la variable $quota_cache, si elle est > 0, indique la taille
191 // totale maximale desiree des fichiers contenus dans le cache ; ce quota n'est
192 // pas "dur" : si le site necessite un espace plus important, il le prend
199 $home_server = 'http://www.spip.net';
200 $help_server = array($home_server . '/aide');
201 # glossaire pour raccourci [?X]. Aussi: [?X#G] et definir glossaire_G
202 $url_glossaire_externe = "http://@lang@.wikipedia.org/wiki/%s";
205 $tex_server = 'http://math.spip.org/tex.php';
206 # MathML (pas pour l'instant: manque un bon convertisseur)
207 // $mathml_server = 'http://arno.rezo.net/tex2mathml/latex.php';
209 // Produire du TeX ou du MathML ?
210 $traiter_math = 'tex';
212 // Appliquer un indenteur XHTML aux espaces public et/ou prive ?
216 // Vignettes de previsulation des referers
217 // dans les statistiques
218 // 2 de trouves, possibilite de switcher
219 // - Alexa, equivalent Thumbshots, avec vignettes beaucoup plus grandes mais avertissement si pas de preview
220 // Pour Alexa, penser a indiquer l'url du site dans l'id.
221 // Dans Alexa, si on supprimer size=small, alors vignettes tres grandes
222 // - apercite.fr : on conserve exactement la même expression pour insérer l'url du site
223 $source_vignettes = "http://www.apercite.fr/api/apercite/120x90/oui/oui/http://";
224 // $source_vignettes = "http://pthumbnails.alexa.com/image_server.cgi?id=www.monsite.net&size=small&url=http://";
226 $formats_logos = array ('gif', 'jpg', 'png');
228 // Controler les dates des item dans les flux RSS ?
229 $controler_dates_rss = true;
233 // Pipelines & plugins
235 # les pipeline standards (traitements derivables aka points d'entree)
236 # ils seront compiles par la suite
237 # note: un pipeline non reference se compile aussi, mais uniquement
238 # lorsqu'il est rencontre
239 // http://doc.spip.org/@Tuto-Se-servir-des-points-d-entree
240 $spip_pipeline = array();
242 # la matrice standard (fichiers definissant les fonctions a inclure)
243 $spip_matrice = array ();
244 # les plugins a activer
245 $plugins = array(); // voir le contenu du repertoire /plugins/
246 # les surcharges de include_spip()
247 $surcharges = array(); // format 'inc_truc' => '/plugins/chose/inc_truc2.php'
249 // Variables du compilateur de squelettes
251 $exceptions_des_tables = array();
252 $tables_principales = array();
253 $table_des_tables = array();
254 $tables_auxiliaires = array();
255 $table_primary = array();
256 $table_date = array();
257 $table_titre = array();
258 $tables_jointures = array();
260 // Liste des statuts.
261 $liste_des_statuts = array(
262 "info_administrateurs" => '0minirezo',
263 "info_redacteurs" =>'1comite',
264 "info_visiteurs" => '6forum',
265 "texte_statut_poubelle" => '5poubelle'
268 $liste_des_etats = array(
269 'texte_statut_en_cours_redaction' => 'prepa',
270 'texte_statut_propose_evaluation' => 'prop',
271 'texte_statut_publie' => 'publie',
272 'texte_statut_poubelle' => 'poubelle',
273 'texte_statut_refuse' => 'refuse'
276 // liste des methodes d'authentifications
277 $liste_des_authentifications = array(
282 // Experimental : pour supprimer systematiquement l'affichage des numeros
283 // de classement des titres, recopier la ligne suivante dans mes_options :
284 # $table_des_traitements['TITRE'][]= 'typo(supprimer_numero(%s), "TYPO", $connect)';
286 // Droits d'acces maximum par defaut
289 // numero de branche, utilise par les plugins
290 // pour specifier les versions de SPIP necessaires
291 // il faut s'en tenir a un nombre de decimales fixe
292 // ex : 2.0.0, 2.0.0-dev, 2.0.0-beta, 2.0.0-beta2
293 $spip_version_branche = "3.0.17";
294 // version des signatures de fonctions PHP
295 // (= numero SVN de leur derniere modif cassant la compatibilite et/ou necessitant un recalcul des squelettes)
296 $spip_version_code = 17873;
297 // version de la base SQL (= numero SVN de sa derniere modif)
298 $spip_version_base = 19268;
300 // version de l'interface a la base
301 $spip_sql_version = 1;
303 // version de spip en chaine
304 // 1.xxyy : xx00 versions stables publiees, xxyy versions de dev
305 // (ce qui marche pour yy ne marchera pas forcement sur une version plus ancienne)
306 $spip_version_affichee = "$spip_version_branche";
309 $visiteur_session = $auteur_session = $connect_statut = $connect_toutes_rubriques = $hash_recherche = $hash_recherche_strict = $ldap_present ='';
310 $meta = $connect_id_rubrique = array();
312 // *** Fin des globales *** //
315 // Charger les fonctions liees aux serveurs Http et Sql.
317 require_once _ROOT_RESTREINT
. 'inc/utils.php';
318 require_once _ROOT_RESTREINT
. 'base/connect_sql.php';
320 // Definition personnelles eventuelles
322 if (_FILE_OPTIONS
) {include_once _FILE_OPTIONS
;}
324 // Masquer les warning
325 if (!defined('E_DEPRECATED')) define('E_DEPRECATED', 8192); // compatibilite PHP 5.3
326 if (!defined('SPIP_ERREUR_REPORT')) define('SPIP_ERREUR_REPORT', E_ALL ^ E_NOTICE ^ E_DEPRECATED
);
327 error_reporting(SPIP_ERREUR_REPORT
);
329 // Initialisations critiques non surchargeables par les plugins
330 // INITIALISER LES REPERTOIRES NON PARTAGEABLES ET LES CONSTANTES
331 // (charge aussi inc/flock)
333 // mais l'inclusion precedente a peut-etre deja appele cette fonction
334 // ou a defini certaines des constantes que cette fonction doit definir
335 // ===> on execute en neutralisant les messages d'erreur
337 spip_initialisation_core(
338 (_DIR_RACINE
. _NOM_PERMANENTS_INACCESSIBLES
),
339 (_DIR_RACINE
. _NOM_PERMANENTS_ACCESSIBLES
),
340 (_DIR_RACINE
. _NOM_TEMPORAIRES_INACCESSIBLES
),
341 (_DIR_RACINE
. _NOM_TEMPORAIRES_ACCESSIBLES
)
345 // chargement des plugins : doit arriver en dernier
346 // car dans les plugins on peut inclure inc-version
347 // qui ne sera pas execute car _ECRIRE_INC_VERSION est defini
348 // donc il faut avoir tout fini ici avant de charger les plugins
350 if (@is_readable
(_CACHE_PLUGINS_OPT
) AND @is_readable
(_CACHE_PLUGINS_PATH
)){
351 // chargement optimise precompile
352 include_once(_CACHE_PLUGINS_OPT
);
354 spip_initialisation_suite();
355 include_spip('inc/plugin');
356 // generer les fichiers php precompiles
357 // de chargement des plugins et des pipelines
358 actualise_plugins_actifs();
360 // Initialisations non critiques surchargeables par les plugins
361 spip_initialisation_suite();
363 // niveau maxi d'enregistrement des logs
364 defined('_LOG_FILTRE_GRAVITE') ||
define('_LOG_FILTRE_GRAVITE', _LOG_INFO_IMPORTANTE
);
366 if (!defined('_OUTILS_DEVELOPPEURS'))
367 define('_OUTILS_DEVELOPPEURS',false);
369 // charger systematiquement inc/autoriser dans l'espace restreint
370 if (test_espace_prive())
371 include_spip('inc/autoriser');
373 // Installer Spip si pas installe... sauf si justement on est en train
376 OR autoriser_sans_cookie(_request('exec'))
377 OR _request('action') == 'cookie'
378 OR _request('action') == 'converser'
379 OR _request('action') == 'test_dirs')) {
381 // Si on peut installer, on lance illico
382 if (test_espace_prive()) {
383 include_spip('inc/headers');
384 redirige_url_ecrire("install");
386 // Si on est dans le site public, dire que qq s'en occupe
387 include_spip('inc/minipres');
388 utiliser_langue_visiteur();
389 echo minipres(_T('info_travaux_titre'), "<p style='text-align: center;'>"._T('info_travaux_texte')."</p>");
392 // autrement c'est une install ad hoc (spikini...), on sait pas faire
396 // Vanter notre art de la composition typographique
397 // La globale $spip_header_silencieux permet de rendre le header minimal pour raisons de securite
398 if (!defined('_HEADER_COMPOSED_BY')) define('_HEADER_COMPOSED_BY', "Composed-By: SPIP");
399 if (!headers_sent()) {
400 header("Vary: Cookie, Accept-Encoding");
401 if (!isset($GLOBALS['spip_header_silencieux']) OR !$GLOBALS['spip_header_silencieux'])
402 header(_HEADER_COMPOSED_BY
. " $spip_version_affichee @ www.spip.net" . (isset($GLOBALS['meta']['plugin_header'])?
(" + ".$GLOBALS['meta']['plugin_header']):""));
403 else // header minimal
404 header(_HEADER_COMPOSED_BY
. " @ www.spip.net");
407 spip_log($_SERVER['REQUEST_METHOD'].' '.self() . ' - '._FILE_CONNECT
,_LOG_DEBUG
);