Current File : /home/pacjaorg/public_html/nsa/libraries/namespacemap.php
<?php
/**
 * Joomla! Content Management System
 *
 * @copyright  (C) 2017 Open Source Matters, Inc. <https://www.joomla.org>
 * @license    GNU General Public License version 2 or later; see LICENSE.txt
 */

defined('_JEXEC') or die;

use Joomla\CMS\Filesystem\File;
use Joomla\CMS\Filesystem\Folder;
use Joomla\CMS\Log\Log;

/**
 * Class JNamespacePsr4Map
 *
 * @since  4.0.0
 */
class JNamespacePsr4Map
{
	/**
	 * Path to the autoloader
	 *
	 * @var    string
	 * @since  4.0.0
	 */
	protected $file = JPATH_CACHE . '/autoload_psr4.php';

	/**
	 * @var array|null
	 * @since 4.0.0
	 */
	private $cachedMap = null;

	/**
	 * Check if the file exists
	 *
	 * @return  boolean
	 *
	 * @since   4.0.0
	 */
	public function exists()
	{
		return is_file($this->file);
	}

	/**
	 * Check if the namespace mapping file exists, if not create it
	 *
	 * @return  void
	 *
	 * @since   4.0.0
	 */
	public function ensureMapFileExists()
	{
		if (!$this->exists())
		{
			$this->create();
		}
	}

	/**
	 * Create the namespace file
	 *
	 * @return  boolean
	 *
	 * @since   4.0.0
	 */
	public function create()
	{
		$extensions = array_merge(
			$this->getNamespaces('component'),
			$this->getNamespaces('module'),
			$this->getNamespaces('plugin'),
			$this->getNamespaces('library')
		);

		ksort($extensions);

		$this->writeNamespaceFile($extensions);

		return true;
	}

	/**
	 * Load the PSR4 file
	 *
	 * @return  boolean
	 *
	 * @since   4.0.0
	 */
	public function load()
	{
		if (!$this->exists())
		{
			$this->create();
		}

		$map = $this->cachedMap ?: require $this->file;

		$loader = include JPATH_LIBRARIES . '/vendor/autoload.php';

		foreach ($map as $namespace => $path)
		{
			$loader->setPsr4($namespace, $path);
		}

		return true;
	}

	/**
	 * Write the Namespace mapping file
	 *
	 * @param   array  $elements  Array of elements
	 *
	 * @return  void
	 *
	 * @since   4.0.0
	 */
	protected function writeNamespaceFile($elements)
	{
		$content   = array();
		$content[] = "<?php";
		$content[] = 'defined(\'_JEXEC\') or die;';
		$content[] = 'return [';

		foreach ($elements as $namespace => $path)
		{
			$content[] = "\t'" . $namespace . "'" . ' => [' . $path . '],';
		}

		$content[] = '];';

		/**
		 * Backup the current error_reporting level and set a new level
		 *
		 * We do this because file_put_contents can raise a Warning if it cannot write the autoload_psr4.php file
		 * and this will output to the response BEFORE the session has started, causing the session start to fail
		 * and ultimately leading us to a 500 Internal Server Error page just because of the output warning, which
		 * we can safely ignore as we can use an in-memory autoload_psr4 map temporarily, and display real errors later.
		 */
		$error_reporting = error_reporting(0);

		if (!File::write($this->file, implode("\n", $content)))
		{
			Log::add('Could not save ' . $this->file, Log::WARNING);

			$map = [];
			$constants = ['JPATH_ADMINISTRATOR', 'JPATH_API', 'JPATH_SITE', 'JPATH_PLUGINS'];

			foreach ($elements as $namespace => $path)
			{
				foreach ($constants as $constant)
				{
					$path = preg_replace(['/^(' . $constant . ")\s\.\s\'/", '/\'$/'], [constant($constant), ''], $path);
				}

				$namespace = str_replace('\\\\', '\\', $namespace);
				$map[$namespace] = [ $path ];
			}

			$this->cachedMap = $map;
		}

		// Restore previous value of error_reporting
		error_reporting($error_reporting);
	}

	/**
	 * Get an array of namespaces with their respective path for the given extension type.
	 *
	 * @param   string  $type  The extension type
	 *
	 * @return  array
	 *
	 * @since   4.0.0
	 */
	private function getNamespaces(string $type): array
	{
		if (!in_array($type, ['component', 'module', 'plugin', 'library'], true))
		{
			return [];
		}

		// Select directories containing extension manifest files.
		if ($type === 'component')
		{
			$directories = [JPATH_ADMINISTRATOR . '/components'];
		}
		elseif ($type === 'module')
		{
			$directories = [JPATH_SITE . '/modules', JPATH_ADMINISTRATOR . '/modules'];
		}
		elseif ($type === 'plugin')
		{
			$directories = Folder::folders(JPATH_PLUGINS, '.', false, true);
		}
		else
		{
			$directories = [JPATH_LIBRARIES];
		}

		$extensions = [];

		foreach ($directories as $directory)
		{
			foreach (Folder::folders($directory) as $extension)
			{
				// Compile the extension path
				$extensionPath = $directory . '/' . $extension . '/';

				// Strip the com_ from the extension name for components
				$name = str_replace('com_', '', $extension, $count);
				$file = $extensionPath . $name . '.xml';

				// If there is no manifest file, ignore. If it was a component check if the xml was named with the com_ prefix.
				if (!is_file($file))
				{
					if (!$count)
					{
						continue;
					}

					$file = $extensionPath . $extension . '.xml';

					if (!is_file($file))
					{
						continue;
					}
				}

				// Load the manifest file
				$xml = simplexml_load_file($file);

				// When invalid, ignore
				if (!$xml)
				{
					continue;
				}

				// The namespace node
				$namespaceNode = $xml->namespace;

				// The namespace string
				$namespace = (string) $namespaceNode;

				// Ignore when the string is empty
				if (!$namespace)
				{
					continue;
				}

				// Normalize the namespace string
				$namespace     = str_replace('\\', '\\\\', $namespace) . '\\\\';
				$namespacePath = rtrim($extensionPath . $namespaceNode->attributes()->path, '/');

				if ($type === 'plugin' || $type === 'library')
				{
					$baseDir = $type === 'plugin' ? 'JPATH_PLUGINS . \'' : 'JPATH_LIBRARIES . \'';
					$path    = str_replace($type === 'plugin' ? JPATH_PLUGINS : JPATH_LIBRARIES, '', $namespacePath);

					// Set the namespace
					$extensions[$namespace] = $baseDir . $path . '\'';

					continue;
				}

				// Check if we need to use administrator path
				$isAdministrator = strpos($namespacePath, JPATH_ADMINISTRATOR) === 0;
				$path            = str_replace($isAdministrator ? JPATH_ADMINISTRATOR : JPATH_SITE, '', $namespacePath);

				// Add the site path when a component
				if ($type === 'component')
				{
					if (is_dir(JPATH_SITE . $path))
					{
						$extensions[$namespace . 'Site\\\\'] = 'JPATH_SITE . \'' . $path . '\'';
					}

					if (is_dir(JPATH_API . $path))
					{
						$extensions[$namespace . 'Api\\\\'] = 'JPATH_API . \'' . $path . '\'';
					}
				}

				// Add the application specific segment when a component or module
				$baseDir    = $isAdministrator ? 'JPATH_ADMINISTRATOR . \'' : 'JPATH_SITE . \'';
				$namespace .= $isAdministrator ? 'Administrator\\\\' : 'Site\\\\';

				// Set the namespace
				$extensions[$namespace] = $baseDir . $path . '\'';
			}
		}

		// Return the namespaces
		return $extensions;
	}
}
Site is undergoing maintenance

PACJA Events

Maintenance mode is on

Site will be available soon. Thank you for your patience!