Skip to content
Extraits de code Groupes Projets
Bifurcation depuis spip / spip
18150 validations de retard le dépôt en amont.
inc-public-global.php3 9,78 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);
}

function obtenir_page_ancienne ($chemin_cache, $fond, $inclusion=false) {

		//
		// Lire le fichier cache
		//
		lire_fichier ($chemin_cache, $page['texte']);
		$lastmodified = max($lastmodified, @filemtime($chemin_cache));
		# spip_log ("cache $chemin_cache $lastmodified");

		//
		// Lire sa carte d'identite & fixer le contexte global
		//
		if (preg_match("/^<!-- ([^\n]*) -->\n(.*)/ms", $page['texte'], $match)
		AND is_array($meta_donnees = unserialize($match[1]))) {
			foreach ($meta_donnees as $var=>$val)
				$page[$var] = $val;

			$page['texte'] = $match[2];

			// Remplir les globals pour les boutons d'admin
			if (!$inclusion AND is_array($page['contexte']))
			  foreach ($page['contexte'] as $var=>$val) {
					$GLOBALS[$var] = $val;
			  }
		}
	return $page;
}

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, $recherche, $use_cache, $var_mode, $var_preview;
	global $_GET, $_POST, $_COOKIE, $_SERVER;

	include_local("inc-cache");

	// Peut-on utiliser un fichier cache ?
	$chemin_cache = determiner_cache($use_cache, '', $fond);

	// 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;

	// Repondre gentiment aux requetes sympas
	// (ici on ne tient pas compte d'une obsolence du cache ou des
	// eventuels fichiers inclus modifies depuis la date
	// HTTP_IF_MODIFIED_SINCE du client)
	if ($GLOBALS['HTTP_IF_MODIFIED_SINCE'] AND !$var_mode
	AND $chemin_cache AND !$flag_dynamique) {
		$lastmodified = @filemtime($chemin_cache);
		$headers_only = http_last_modified($lastmodified);
	}
	$headers_only |= ($_SERVER['REQUEST_METHOD'] == 'HEAD');

	if ($headers_only) {
		if ($chemin_cache)
			$t = @filemtime($chemin_cache);
		else
			$t = time();
		@header('Last-Modified: '.http_gmoddate($t).' GMT');
		@header('Connection: close');
		// Pas de bouton admin pour un HEAD
		$flag_preserver = true;
	}
	else {
		// Obtenir la page
	  if (!$use_cache)
	    $page =  obtenir_page_ancienne ($chemin_cache, $fond, false);
	  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;

	if ($page['process_ins'] == 'php') {
		if (!isset($flag_preserver))
			$flag_preserver = preg_match("/header\s*\(\s*.content\-type:/isx",$page['texte']);

		$expire = preg_match("/header\s*\(\s*.Expire:([\s\d])*.\s*\)/is",$php, $r);
		if (!isset($flag_dynamique))
		      $flag_dynamique = $expire && (intval($r[1]) === 0);
	}

	if ($var_preview AND !$flag_preserver) {
		include_ecrire('inc_minipres');
		$page['texte'] .= afficher_bouton_preview();
	}
	//
	// Envoyer les entetes appropries
	// a condition d'etre sur de pouvoir le faire
	//
	if (!headers_sent() AND !$flag_preserver) {

		// Content-type: par defaut html+charset (poss surcharge par la suite)
		header("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();	
			}
			// Interdire au client de cacher un login, un admin ou un recalcul
			else if ($flag_dynamique OR $var_mode
			OR $_COOKIE['spip_admin']) {
				header("Cache-Control: no-cache,must-revalidate");
				header("Pragma: no-cache");
			}
			// Pour les autres donner l'heure de modif
			else if ($lastmodified) {
				header("Last-Modified: ".http_gmoddate($lastmodified)." GMT");
			}
		}
	}

	return $page;
}

function inclure_page($fond, $contexte_inclus, $cache_incluant='') {

	// Peut-on utiliser un fichier cache ?
	$chemin_cache = 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
	}

	  if (!$use_cache)
	    $page =  obtenir_page_ancienne ($chemin_cache, $fond, false);
	  else {
	    include_local('inc-calcul');
	    $page = cherche_page($chemin_cache, $contexte_inclus, $fond, false);
	    $page['signal']['process_ins'] = $page['process_ins'];
	    $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';
	}
	include_ecrire('inc_headers');
	http_status(404);

	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;
}
?>