Skip to content
Extraits de code Groupes Projets
Bifurcation depuis spip / spip
17963 validations de retard le dépôt en amont.
inc-public-global.php3 9,67 Kio
<?php

/***************************************************************************\
 *  SPIP, Systeme de publication pour l'internet                           *
 *                                                                         *
 *  Copyright (c) 2001-2006                                                *
 *  Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James  *
 *                                                                         *
 *  Ce programme est un logiciel libre distribue sous licence GNU/GPL.     *
 *  Pour plus de details voir le fichier COPYING.txt ou l'aide en ligne.   *
\***************************************************************************/


if (!defined("_ECRIRE_INC_VERSION")) return;

// fonction principale declenchant tout le service
// elle-meme ne fait que traiter les cas particuliers, puis passe la main.
function calcule_header_et_page ($fond) {
	  global $auteur_session, $forcer_lang, $ignore_auth_http,
	  $var_confirm, $var_mode;
	  global $_GET, $_POST, $_COOKIE, $_SERVER;

	// authentification du visiteur
	if ($_COOKIE['spip_session'] OR
	($_SERVER['PHP_AUTH_USER']  AND !$ignore_auth_http)) {
		include_ecrire ("inc_session");
		verifier_visiteur();
	}
	// multilinguisme
	if ($forcer_lang AND ($forcer_lang!=='non') AND !count($_POST)) {
		include_ecrire('inc_lang');
		verifier_lang_url();
	}
	if ($_GET['lang']) {
		include_ecrire('inc_lang');
		lang_select($_GET['lang']);
	}

	// Si envoi pour un forum, enregistrer puis rediriger

	if (strlen($_POST['confirmer_forum']) > 0
	    OR ($GLOBALS['afficher_texte']=='non' AND $_POST['ajouter_mot'])) {
		include_local('inc-messforum');
		redirige_par_entete(enregistre_forum());
	}

	// si signature de petition, l'enregistrer avant d'afficher la page
	// afin que celle-ci contienne la signature

	if ($_GET['var_confirm']) {
		include_local(find_in_path('inc-formulaire_signature' . _EXTENSION_PHP));
		reponse_confirmation($_GET['id_article'], $var_confirm);
	}

	//  refus du debug si l'admin n'est pas connecte
	if ($var_mode=='debug') {
		if ($auteur_session['statut'] == '0minirezo')
			spip_log('debug !');
		else {
			$link = new Link();
			$link->addvar('var_mode', 'debug');
			redirige_par_entete(generer_url_public('spip_login'), '?url='.urlencode($link->getUrl()));
			exit;
		}
	}

	return afficher_page_globale ($fond);
}

// Remplir les globals pour les boutons d'admin

function restaurer_globales ($contexte) {
	if (is_array($contexte)) {
		foreach ($contexte as $var=>$val) {
			$GLOBALS[$var] = $val;
		}
	}
}

function is_preview()
{
	global $var_mode;
	if ($var_mode !== 'preview') return false;
	$statut = $GLOBALS['auteur_session']['statut'];
	return ($statut=='0minirezo' OR
		($GLOBALS['meta']['preview']=='1comite' AND $statut=='1comite'));
}

//
// calculer la page principale et envoyer les entetes
//
function afficher_page_globale ($fond) {
	global $flag_dynamique, $flag_ob, $flag_preserver,$lastmodified,
		$use_cache, $var_mode, $var_preview;
	global $_COOKIE, $_SERVER;

	include_local("inc-cache");

	// Peut-on utiliser un fichier cache ?
	list($chemin_cache, $page, $lastmodified) = 
		determiner_cache($use_cache, NULL, $fond);

	if (!$chemin_cache || !$lastmodified) $lastmodified = time();

	// demande de previsualisation ?
	// -> inc-calcul n'enregistrera pas les fichiers caches
	// -> inc-boucles acceptera les objets non 'publie'
	if (is_preview()) {
			$var_mode = 'recalcul';
			$var_preview = true;
			spip_log('preview !');
		} else	$var_preview = false;

	$headers_only = ($_SERVER['REQUEST_METHOD'] == 'HEAD');

	// une perennite valide a meme reponse qu'une requete HEAD

	if ($GLOBALS['HTTP_IF_MODIFIED_SINCE'] AND !$var_mode
	AND $chemin_cache AND !$flag_dynamique) {
		if (!preg_match(',IIS/,', $_SERVER['SERVER_SOFTWARE'])) {
			$since = preg_replace('/;.*/', '',
				$GLOBALS['HTTP_IF_MODIFIED_SINCE']);
			$since = str_replace('GMT', '', $since);
			if (trim($since) == http_gmoddate($lastmodified)) {
				$status = 304;
				$headers_only = true;
			}
		}
	}

	// si le last-modified (mis + bas) est suffisant, ne meme pas mettre
	// de content-type (pour contrer le bouton admin de inc-public)

	if ($headers_only) {
		$page['entetes']["Connection"] = "close";
	} else {
		if (!$use_cache)
			restaurer_globales($page['contexte']);
		else {
			include_local('inc-calcul');
			$page = calculer_page_globale ($chemin_cache, $fond);
			if ($chemin_cache)
				creer_cache($page, $chemin_cache, $use_cache);
		}

		if ($chemin_cache) $page['cache'] = $chemin_cache;

		// compatibilite. devrait pouvoir sauter
		if ($page['process_ins'] == 'php') {
			auto_content_type($page['texte']);
			auto_expire($page['texte']);
		}

		$flag_preserver |=  (headers_sent());

	// Definir les entetes si ce n'est fait 

		if (!$flag_preserver) {

			if (!isset($page['entetes']['Content-Type'])) {
				$page['entetes']['Content-Type'] = 
					"text/html; charset="
					. $GLOBALS['meta']['charset'];
			}
			if ($flag_ob) {
			// Si la page est vide, produire l'erreur 404
				if (trim($page['texte']) === ''
				    AND $var_mode != 'debug') {
					$page = message_erreur_404();
					$status = 404;
					$flag_dynamique = true;
				}
	// pas de cache client en mode 'observation (ou si deja indique)
				if ($flag_dynamique  OR $var_mode) {
				  $page['entetes']["Cache-Control"]= "no-cache,must-revalidate";
				  $page['entetes']["Pragma"] = "no-cache";
				} 
			}
		}
	}
	// toujours utile
	$page['entetes']["Last-Modified"]=http_gmoddate($lastmodified)." GMT";
	$page['status'] = $status;

	return $page;
}

//
// 2 fonctions pour compatibilite arriere. Sont probablement superflues
//

function auto_content_type($code)
{
	global $flag_preserver;
	if (!isset($flag_preserver))
		$flag_preserver = preg_match("/header\s*\(\s*.content\-type:/isx",$code);
}

function auto_expire($code)
{
	global $flag_dynamique;
	if (!isset($flag_dynamique)) {
		if (preg_match("/header\s*\(\s*.Expire:([\s\d])*.\s*\)/is",$code, $r))
			$flag_dynamique = (intval($r[1]) === 0);
	}
}

function inclure_page($fond, $contexte_inclus, $cache_incluant='') {
	global $lastmodified;
	// Peut-on utiliser un fichier cache ?
	list($chemin_cache, $page, $lastinclude) = 
		determiner_cache($use_cache, $contexte_inclus, $fond);

	// Si on a inclus sans fixer le critere de lang, de deux choses l'une :
	// - on est dans la langue du site, et pas besoin d'inclure inc_lang
	// - on n'y est pas, et alors il faut revenir dans la langue par defaut
	if (($lang = $contexte_inclus['lang'])
	|| ($GLOBALS['spip_lang'] != ($lang = $GLOBALS['meta']['langue_site']))) {
		include_ecrire('inc_lang');
		lang_select($lang);
		$lang_select = true; // pour lang_dselect en sortie
	}

	// Une fois le chemin-cache decide, on ajoute la date (et date_redac)
	// dans le contexte inclus, pour que les criteres {age} etc fonctionnent
	if (!isset($contexte_inclus['date']))
		$contexte_inclus['date'] = date('Y-m-d H:i:s');
	if (!isset($contexte_inclus['date_redac']))
		$contexte_inclus['date_redac'] = $contexte_inclus['date'];

	// On va ensuite chercher la page
	if (!$use_cache) {
		$lastmodified = max($lastmodified, $lastinclude);
	} else {
		include_local('inc-calcul');
		$page = cherche_page($chemin_cache, $contexte_inclus, $fond, false);
		$lastmodified = time();
		if ($chemin_cache) creer_cache($page, $chemin_cache, $use_cache);
	}

	$page['lang_select'] = $lang_select;

	return $page;
}


# Attention, un appel explicite a cette fonction suppose certains include
# (voir l'exemple de spip_inscription et spip_pass)
# $echo = faut-il faire echo ou return

function inclure_balise_dynamique($texte, $echo=true, $ligne=0) {
	global $contexte_inclus; # provisoire : c'est pour le debuggueur

	if (!is_string($texte))
	  {
	    // Revoir l'API des balises dynamiques:
	    // leurs squelettes sont petits et sans boucle,
	    // la gestion du delai est donc superfetatoire
		list($fond, $delainc, $contexte_inclus) = $texte;

		if ((!$contexte_inclus['lang']) AND
		($GLOBALS['spip_lang'] != $GLOBALS['meta']['langue_site']))
			$contexte_inclus['lang'] = $GLOBALS['spip_lang'];

		$f = find_in_path("inc-cache" . _EXTENSION_PHP);
		if ($f && is_readable($f)) {
		  if (!$GLOBALS['included_files']['inc-cache']++) include($f);
		} else include_local("inc-cache");

		$d = $GLOBALS['delais'];
		$GLOBALS['delais'] = $delainc;
		$page = inclure_page($fond, $contexte_inclus);
		$GLOBALS['delais'] = $d;

		if ($page['process_ins'] == 'html') {
				$texte = $page['texte'];
		} else {
				ob_start();
				eval('?' . '>' . $page['texte']);
				$texte = ob_get_contents();
				ob_end_clean();
		}

		if ($page['lang_select'])
			lang_dselect();

	  }

	if ($GLOBALS['var_mode'] == 'debug')
	    $GLOBALS['debug_objets']['resultat'][$ligne] = $texte;

	if ($echo)
			echo $texte;
	else
			return $texte;

}


function message_erreur_404 ($erreur= "") {
	if (!$erreur) {
		if (isset($GLOBALS['id_article']))
		$erreur = 'public:aucun_article';
		else if (isset($GLOBALS['id_rubrique']))
		$erreur = 'public:aucune_rubrique';
		else if (isset($GLOBALS['id_breve']))
		$erreur = 'public:aucune_breve';
		else if (isset($GLOBALS['id_auteur']))
		$erreur = 'public:aucun_auteur';
		else if (isset($GLOBALS['id_syndic']))
		$erreur = 'public:aucun_site';
	}
	return array('texte' => '<'.'?php
			$contexte_inclus = array("fond" => 404,
 				"erreur" => _T("' . $erreur  . '"));
			include(\'page' . _EXTENSION_PHP .'\'); ?'.'>',
		     'process_ins' => 'php');
}

//
// pour calcul du nom du fichier cache et autres
//

function nettoyer_uri() {
	return eregi_replace
		('[?&](PHPSESSID|(var_[^=&]*))=[^&]*',
		'', 
		 $GLOBALS['REQUEST_URI']);
}

// Renvoie le _GET ou le _POST emis par l'utilisateur
function _request($var) {
	global $_GET, $_POST;
	if (isset($_GET[$var])) return $_GET[$var];
	if (isset($_POST[$var])) return $_POST[$var];
	return NULL;
}
?>