2013-06-07 11:44:37 +02:00
|
|
|
<?php
|
2013-07-12 15:00:59 +02:00
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
2013-06-07 11:44:37 +02:00
|
|
|
/**
|
2013-07-12 15:00:59 +02:00
|
|
|
* Icinga 2 Web - Head for multiple monitoring frontends
|
|
|
|
* Copyright (C) 2013 Icinga Development Team
|
2013-06-07 11:44:37 +02:00
|
|
|
*
|
2013-07-12 15:00:59 +02:00
|
|
|
* This program 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.
|
2013-06-07 11:44:37 +02:00
|
|
|
*
|
2013-07-12 15:00:59 +02:00
|
|
|
* This program 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.
|
2013-06-07 11:44:37 +02:00
|
|
|
*
|
2013-07-12 15:00:59 +02:00
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
2013-06-07 11:44:37 +02:00
|
|
|
*
|
2013-07-12 15:00:59 +02:00
|
|
|
* @copyright 2013 Icinga Development Team <info@icinga.org>
|
|
|
|
* @author Icinga Development Team <info@icinga.org>
|
2013-06-07 11:44:37 +02:00
|
|
|
*/
|
2013-07-12 15:00:59 +02:00
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
|
|
|
|
namespace Icinga\Application;
|
|
|
|
|
|
|
|
use Icinga\Exception\ProgrammingError;
|
|
|
|
|
2013-06-07 11:44:37 +02:00
|
|
|
class Loader
|
|
|
|
{
|
2013-07-12 15:00:59 +02:00
|
|
|
/**
|
|
|
|
* Namespace separator
|
|
|
|
*/
|
|
|
|
const NAMESPACE_SEPARATOR = '\\';
|
2013-06-07 11:44:37 +02:00
|
|
|
|
|
|
|
/**
|
2013-07-12 15:00:59 +02:00
|
|
|
* List of namespaces
|
|
|
|
* @var array
|
2013-06-07 11:44:37 +02:00
|
|
|
*/
|
2013-07-12 15:00:59 +02:00
|
|
|
private $namespaces = array();
|
|
|
|
|
|
|
|
public function __destruct()
|
2013-06-07 11:44:37 +02:00
|
|
|
{
|
2013-07-12 15:00:59 +02:00
|
|
|
$this->unRegister();
|
2013-06-07 11:44:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2013-07-12 15:00:59 +02:00
|
|
|
* Register new namespace for directory
|
|
|
|
* @param string $namespace
|
|
|
|
* @param string $directory
|
|
|
|
* @throws \Icinga\Exception\ProgrammingError
|
2013-06-07 11:44:37 +02:00
|
|
|
*/
|
2013-07-12 15:00:59 +02:00
|
|
|
public function registerNamespace($namespace, $directory)
|
2013-06-07 11:44:37 +02:00
|
|
|
{
|
2013-07-12 15:00:59 +02:00
|
|
|
if (!is_dir($directory)) {
|
|
|
|
throw new ProgrammingError('Directory does not exist: '. $directory);
|
2013-06-07 11:44:37 +02:00
|
|
|
}
|
2013-07-12 15:00:59 +02:00
|
|
|
|
|
|
|
$this->namespaces[$namespace] = $directory;
|
2013-06-07 11:44:37 +02:00
|
|
|
}
|
|
|
|
|
2013-07-12 15:00:59 +02:00
|
|
|
/**
|
|
|
|
* Test if a namespace exists
|
|
|
|
* @param string $namespace
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function hasNamespace($namespace)
|
2013-06-07 11:44:37 +02:00
|
|
|
{
|
2013-07-12 15:00:59 +02:00
|
|
|
return array_key_exists($namespace, $this->namespaces);
|
2013-06-07 11:44:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Class loader
|
|
|
|
*
|
|
|
|
* Ignores all but classes in the Icinga namespace.
|
|
|
|
*
|
2013-07-12 15:00:59 +02:00
|
|
|
* @param string $class
|
2013-06-07 11:44:37 +02:00
|
|
|
* @return boolean
|
|
|
|
*/
|
|
|
|
public function loadClass($class)
|
|
|
|
{
|
2013-07-12 15:00:59 +02:00
|
|
|
$namespace = $this->getNamespaceForClass($class);
|
|
|
|
|
|
|
|
if ($namespace) {
|
|
|
|
$file = $this->namespaces[$namespace]
|
|
|
|
. '/'
|
|
|
|
. preg_replace('/^'. preg_quote($namespace). '/', '', $class);
|
|
|
|
|
|
|
|
$file = (str_replace(self::NAMESPACE_SEPARATOR, '/', $file). '.php');
|
|
|
|
if (@file_exists($file)) {
|
|
|
|
require_once $file;
|
|
|
|
return true;
|
|
|
|
}
|
2013-06-07 11:44:37 +02:00
|
|
|
}
|
2013-07-12 15:00:59 +02:00
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test if we have a registered namespaces for this class
|
|
|
|
*
|
|
|
|
* Return is the longest match in the array found
|
|
|
|
*
|
|
|
|
* @param string $className
|
|
|
|
* @return bool|string
|
|
|
|
*/
|
|
|
|
private function getNamespaceForClass($className)
|
|
|
|
{
|
|
|
|
$testNamespace = '';
|
|
|
|
$testLength = 0;
|
|
|
|
|
|
|
|
foreach ($this->namespaces as $namespace => $directory) {
|
|
|
|
$stub = preg_replace('/^'. preg_quote($namespace). '/', '', $className);
|
|
|
|
$length = strlen($className) - strlen($stub);
|
|
|
|
if ($length > $testLength) {
|
|
|
|
$testLength = $length;
|
|
|
|
$testNamespace = $namespace;
|
2013-06-07 11:44:37 +02:00
|
|
|
}
|
|
|
|
}
|
2013-07-12 15:00:59 +02:00
|
|
|
|
|
|
|
if ($testLength > 0) {
|
|
|
|
return $testNamespace;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
2013-06-07 11:44:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Effectively registers the autoloader the PHP/SPL way
|
|
|
|
*/
|
2013-07-12 15:00:59 +02:00
|
|
|
public function register()
|
2013-06-07 11:44:37 +02:00
|
|
|
{
|
2013-07-12 15:00:59 +02:00
|
|
|
// Think about to add class pathes to php include path
|
|
|
|
// this could be faster (tg)
|
|
|
|
spl_autoload_register(array(&$this, 'loadClass'));
|
2013-06-07 11:44:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2013-07-12 15:00:59 +02:00
|
|
|
* Detach autoloader from spl registration
|
2013-06-07 11:44:37 +02:00
|
|
|
*/
|
2013-07-12 15:00:59 +02:00
|
|
|
public function unRegister()
|
2013-06-07 11:44:37 +02:00
|
|
|
{
|
2013-07-12 15:00:59 +02:00
|
|
|
spl_autoload_unregister(array(&$this, 'loadClass'));
|
2013-06-07 11:44:37 +02:00
|
|
|
}
|
|
|
|
}
|