Files
MYSOPHAL/inc/autoload.function.php
2025-08-07 13:15:31 +01:00

406 lines
11 KiB
PHP

<?php
/**
* ---------------------------------------------------------------------
* GLPI - Gestionnaire Libre de Parc Informatique
* Copyright (C) 2015-2020 Teclib' and contributors.
*
* http://glpi-project.org
*
* based on GLPI - Gestionnaire Libre de Parc Informatique
* Copyright (C) 2003-2014 by the INDEPNET Development Team.
*
* ---------------------------------------------------------------------
*
* LICENSE
*
* This file is part of GLPI.
*
* GLPI is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* GLPI is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with GLPI. If not, see <http://www.gnu.org/licenses/>.
* ---------------------------------------------------------------------
*/
if (!defined('GLPI_ROOT')) {
die("Sorry. You can't access this file directly");
}
define ('NS_GLPI', 'Glpi\\');
define ('NS_PLUG', 'GlpiPlugin\\');
/**
* Is the script launch in Command line?
*
* @return boolean
*/
function isCommandLine() {
return (PHP_SAPI == 'cli');
}
/**
* Is the script launched From API?
*
* @return boolean
*/
function isAPI() {
global $CFG_GLPI;
$called_url = (!empty($_SERVER['HTTPS'] ?? "") && ($_SERVER['HTTPS'] ?? "") !== 'off'
? 'https'
: 'http').
'://' . ($_SERVER['HTTP_HOST'] ?? "").
($_SERVER['REQUEST_URI'] ?? "");
if (strpos($called_url, $CFG_GLPI['url_base_api'] ?? "") !== false) {
return true;
}
$script = isset($_SERVER['SCRIPT_FILENAME']) ? $_SERVER['SCRIPT_FILENAME'] : '';
if (strpos($script, 'apirest.php') !== false) {
return true;
}
if (strpos($script, 'apixmlrpc.php') !== false) {
return true;
}
return false;
}
/**
* Determine if an class name is a plugin one
*
* @param string $classname Class name to analyze
*
* @return boolean|array False or an array containing plugin name and class name
*/
function isPluginItemType($classname) {
/** @var array $matches */
if (preg_match("/Plugin([A-Z][a-z0-9]+)([A-Z]\w+)/", $classname, $matches)) {
$plug = [];
$plug['plugin'] = $matches[1];
$plug['class'] = $matches[2];
return $plug;
} else if (substr($classname, 0, \strlen(NS_PLUG)) === NS_PLUG) {
$tab = explode('\\', $classname, 3);
$plug = [];
$plug['plugin'] = $tab[1];
$plug['class'] = $tab[2];
return $plug;
}
// Standard case
return false;
}
/**
* Translate a string
*
* @since 0.84
*
* @param string $str String to translate
* @param string $domain domain used (default is glpi, may be plugin name)
*
* @return string translated string
*/
function __($str, $domain = 'glpi') {
global $TRANSLATE;
if (is_null($TRANSLATE)) { // before login
return $str;
}
$trans = $TRANSLATE->translate($str, $domain);
// Wrong call when plural defined
if (is_array($trans)) {
return $trans[0];
}
return $trans;
}
/**
* Translate a string and escape HTML entities
*
* @since 0.84
*
* @param string $str String to translate
* @param string $domain domain used (default is glpi, may be plugin name)
*
* @return string
*/
function __s($str, $domain = 'glpi') {
return htmlentities(__($str, $domain), ENT_QUOTES, 'UTF-8');
}
/**
* Translate a contextualized string and escape HTML entities
*
* @since 0.84
*
* @param string $ctx context
* @param string $str to translate
* @param string $domain domain used (default is glpi, may be plugin name)
*
* @return string protected string (with htmlentities)
*/
function _sx($ctx, $str, $domain = 'glpi') {
return htmlentities(_x($ctx, $str, $domain), ENT_QUOTES, 'UTF-8');
}
/**
* Pluralized translation
*
* @since 0.84
*
* @param string $sing in singular
* @param string $plural in plural
* @param integer $nb to select singular or plural
* @param string $domain domain used (default is glpi, may be plugin name)
*
* @return string translated string
*/
function _n($sing, $plural, $nb, $domain = 'glpi') {
global $TRANSLATE;
if (is_null($TRANSLATE)) { // before login
if ($nb == 0 || $nb > 1) {
return $plural;
} else {
return $sing;
}
}
return $TRANSLATE->translatePlural($sing, $plural, $nb, $domain);
}
/**
* Pluralized translation with HTML entities escaped
*
* @since 0.84
*
* @param string $sing in singular
* @param string $plural in plural
* @param integer $nb to select singular or plural
* @param string $domain domain used (default is glpi, may be plugin name)
*
* @return string protected string (with htmlentities)
*/
function _sn($sing, $plural, $nb, $domain = 'glpi') {
return htmlentities(_n($sing, $plural, $nb, $domain), ENT_QUOTES, 'UTF-8');
}
/**
* Contextualized translation
*
* @since 0.84
*
* @param string $ctx context
* @param string $str to translate
* @param string $domain domain used (default is glpi, may be plugin name)
*
* @return string
*/
function _x($ctx, $str, $domain = 'glpi') {
// simulate pgettext
$msg = $ctx."\004".$str;
$trans = __($msg, $domain);
if ($trans == $msg) {
// No translation
return $str;
}
return $trans;
}
/**
* Pluralized contextualized translation
*
* @since 0.84
*
* @param string $ctx context
* @param string $sing in singular
* @param string $plural in plural
* @param integer $nb to select singular or plural
* @param string $domain domain used (default is glpi, may be plugin name)
*
* @return string
*/
function _nx($ctx, $sing, $plural, $nb, $domain = 'glpi') {
// simulate pgettext
$singmsg = $ctx."\004".$sing;
$pluralmsg = $ctx."\004".$plural;
$trans = _n($singmsg, $pluralmsg, $nb, $domain);
if ($trans == $singmsg) {
// No translation
return $sing;
}
if ($trans == $pluralmsg) {
// No translation
return $plural;
}
return $trans;
}
/**
* Classes loader
*
* @param string $classname : class to load
*
* @return void|boolean
*/
function glpi_autoload($classname) {
global $DEBUG_AUTOLOAD;
static $notfound = ['xStates' => true,
'xAllAssets' => true, ];
// empty classname or non concerted plugin or classname containing dot (leaving GLPI main treee)
if (empty($classname) || is_numeric($classname) || (strpos($classname, '.') !== false)) {
trigger_error(
sprintf('Trying to load a forbidden class name "%1$s"', $classname),
E_USER_ERROR
);
return false;
}
if ($classname === 'phpCAS'
&& file_exists(stream_resolve_include_path("CAS.php"))) {
include_once('CAS.php');
return true;
}
$dir = GLPI_ROOT . "/inc/";
// Deprecation warn for Computer_Software* classes
if ($classname === 'Computer_SoftwareLicense') {
Toolbox::deprecated('Computer_SoftwareLicense has been replaced by Item_SoftwareLicense.');
}
if ($classname === 'Computer_SoftwareVersion') {
Toolbox::deprecated('Computer_SoftwareVersion has been replaced by Item_SoftwareVersion.');
}
if ($plug = isPluginItemType($classname)) {
$plugname = strtolower($plug['plugin']);
// check plugin exists and is enabled
if (!Plugin::isPluginLoaded($plugname)) {
// Do not load plugin class if plugin is not loaded
return false;
}
$item = str_replace('\\', '/', strtolower($plug['class']));
// load from first found directory
foreach (PLUGINS_DIRECTORIES as $base_dir) {
$dir = "$base_dir/$plugname/inc/";
if (is_dir($dir)) {
break;
}
}
} else if (strpos($classname, 'Glpi\Tests\Web\Deprecated') !== false) {
// Special case to autoload files in the tests dir that have a namespace
// and are not an atoum test case
$dir = GLPI_ROOT . "/tests/";
// Convert classname to array
$path = explode('\\', $classname);
// Remove first two items (Glpi\Tests)
array_splice($path, 0, 2);
// Extract file name
$item = array_pop($path);
// Convert all remaining path to lowercase
$path = array_map(function($folder) {
return strtolower($folder);
}, $path);
// Revert to string and add to dir path
$dir .= implode('/', $path) . '/';
} else {
$item = strtolower($classname);
if (substr($classname, 0, \strlen(NS_GLPI)) === NS_GLPI) {
$item = str_replace('\\', '/', substr($item, \strlen(NS_GLPI)));
}
}
if (file_exists("$dir$item.class.php")) {
include_once("$dir$item.class.php");
if (isset($_SESSION['glpi_use_mode'])
&& ($_SESSION['glpi_use_mode'] == Session::DEBUG_MODE)) {
$DEBUG_AUTOLOAD[] = $classname;
}
} else if (!isset($notfound["x$classname"])) {
// trigger an error to get a backtrace, but only once (use prefix 'x' to handle empty case)
// trigger_error("GLPI autoload : file $dir$item.class.php not founded trying to load class '$classname'");
$notfound["x$classname"] = true;
}
}
// Check if dependencies are up to date
$needrun = false;
// composer dependencies
$autoload = GLPI_ROOT . '/vendor/autoload.php';
if (!file_exists($autoload)) {
$needrun = true;
} else if (file_exists(GLPI_ROOT . '/composer.lock')) {
if (!file_exists(GLPI_ROOT . '/.composer.hash')) {
/* First time */
$needrun = true;
} else if (sha1_file(GLPI_ROOT . '/composer.lock') != file_get_contents(GLPI_ROOT . '/.composer.hash')) {
/* update */
$needrun = true;
}
}
// node dependencies
if (!file_exists(GLPI_ROOT . '/public/lib')) {
$needrun = true;
} else if (file_exists(GLPI_ROOT . '/package-lock.json')) {
if (!file_exists(GLPI_ROOT . '/.package.hash')) {
/* First time */
$needrun = true;
} else if (sha1_file(GLPI_ROOT . '/package-lock.json') != file_get_contents(GLPI_ROOT . '/.package.hash')) {
/* update */
$needrun = true;
}
}
if ($needrun) {
$deps_install_msg = 'Application dependencies are not up to date.' . PHP_EOL
. 'Run "php bin/console dependencies install" in the glpi tree to fix this.' . PHP_EOL;
if (isCommandLine()) {
echo $deps_install_msg;
} else {
echo nl2br($deps_install_msg);
}
die(1);
}
require_once $autoload;
// Use spl autoload to allow stackable autoload.
spl_autoload_register('glpi_autoload', false, true);