Samx Here
n1udSecurity


Server : Apache
System : Linux webd348.cluster026.gra.hosting.ovh.net 5.15.148-ovh-vps-grsec-zfs-classid #1 SMP Thu Feb 8 09:41:04 UTC 2024 x86_64
User : hednacluml ( 122243)
PHP Version : 8.3.9
Disable Function : _dyuweyrj4,_dyuweyrj4r,dl
Directory :  /home/hednacluml/metiers/ecrire/inc/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home/hednacluml/metiers/ecrire/inc/log.php
<?php

/***************************************************************************\
 *  SPIP, Système de publication pour l'internet                           *
 *                                                                         *
 *  Copyright © avec tendresse depuis 2001                                 *
 *  Arnaud Martin, Antoine Pitrou, Philippe Rivière, Emmanuel Saint-James  *
 *                                                                         *
 *  Ce programme est un logiciel libre distribué sous licence GNU/GPL.     *
\***************************************************************************/

if (!defined('_ECRIRE_INC_VERSION')) {
	return;
}

function inc_log_dist($message, $logname = null, $logdir = null, $logsuf = null) {
	static $test_repertoire = [];
	static $compteur = [];
	static $debugverb = ''; // pour ne pas le recalculer au reappel

	if (is_null($logname) or !is_string($logname)) {
		$logname = defined('_FILE_LOG') ? _FILE_LOG : 'spip';
	}
	if (!isset($compteur[$logname])) {
		$compteur[$logname] = 0;
	}
	if (
		$logname != 'maj'
		and defined('_MAX_LOG')
		and (
			$compteur[$logname]++ > _MAX_LOG
			or !$GLOBALS['nombre_de_logs']
			or !$GLOBALS['taille_des_logs']
		)
	) {
		return;
	}

	// si spip_log() est appelé dans mes_options, toutes les constantes n'ont pas été définies
	$logfile =
		($logdir ?? (defined('_DIR_LOG') ? _DIR_LOG : _DIR_RACINE . _NOM_TEMPORAIRES_INACCESSIBLES))
		. $logname
		. ($logsuf ?? (defined('_FILE_LOG_SUFFIX') ? _FILE_LOG_SUFFIX : '.log'));

	if (!isset($test_repertoire[$d = dirname($logfile)])) {
		$test_repertoire[$d] = false; // eviter une recursivite en cas d'erreur de sous_repertoire
		$test_repertoire[$d] = (@is_dir($d) ? true : (function_exists('sous_repertoire') ? sous_repertoire(
			$d,
			'',
			false,
			true
		) : false));
	}

	// Si le repertoire défini n'existe pas, poser dans tmp/
	if (!$test_repertoire[$d]) {
		$logfile = _DIR_RACINE . _NOM_TEMPORAIRES_INACCESSIBLES . $logname . '.log';
	}

	$rotate = 0;
	$pid = '(pid ' . @getmypid() . ')';

	// accepter spip_log( Array )
	if (!is_string($message)) {
		$message = var_export($message, true);
	}

	if (!$debugverb and defined('_LOG_FILELINE') and _LOG_FILELINE) {
		$debug = debug_backtrace();
		$l = $debug[1]['line'];
		$fi = $debug[1]['file'];
		if (strncmp($fi, _ROOT_RACINE, strlen(_ROOT_RACINE)) == 0) {
			$fi = substr($fi, strlen(_ROOT_RACINE));
		}
		$fu = $debug[2]['function'] ?? '';
		$debugverb = "$fi:L$l:$fu" . '():';
	}

	$m = date('Y-m-d H:i:s') . ' ' . ($GLOBALS['ip'] ?? '') . ' ' . $pid . ' '
		//distinguer les logs prives et publics dans les grep
		. $debugverb
		. (test_espace_prive() ? ':Pri:' : ':Pub:')
		. preg_replace("/\n*$/", "\n", $message);


	if (
		@is_readable($logfile)
		and (!$s = @filesize($logfile) or $s > $GLOBALS['taille_des_logs'] * 1024)
	) {
		$rotate = $GLOBALS['nombre_de_logs'];
		$m .= "[-- rotate --]\n";
	}

	$f = @fopen($logfile, 'ab');
	if ($f) {
		fputs($f, (defined('_LOG_BRUT') and _LOG_BRUT) ? $m : str_replace('<', '&lt;', $m));
		fclose($f);
	}

	if (
		$rotate-- > 0
		and function_exists('spip_unlink')
	) {
		spip_unlink($logfile . '.' . $rotate);
		while ($rotate--) {
			@rename($logfile . ($rotate ? '.' . $rotate : ''), $logfile . '.' . ($rotate + 1));
		}
	}

	// Dupliquer les erreurs specifiques dans le log general
	if (
		defined('_FILE_LOG')
		and ($logname !== _FILE_LOG)
	) {
		inc_log_dist($logname == 'maj' ? 'cf maj.log' : $message);
	}
	$debugverb = '';
}

SAMX