b0y-101 Mini Shell


Current Path : E:/www/km/09/administrator/components/com_akeeba/BackupEngine/Core/
File Upload :
Current File : E:/www/km/09/administrator/components/com_akeeba/BackupEngine/Core/Database.php

<?php
/**
 * Akeeba Engine
 * The modular PHP5 site backup engine
 * @copyright Copyright (c)2006-2017 Nicholas K. Dionysopoulos / Akeeba Ltd
 * @license   GNU GPL version 3 or, at your option, any later version
 * @package   akeebaengine
 *
 */

namespace Akeeba\Engine\Core;

// Protection against direct access
defined('AKEEBAENGINE') or die();

use Akeeba\Engine\Base\Object;
use Akeeba\Engine\Driver\Base as DriverBase;
use Akeeba\Engine\Platform;

/**
 * A utility class to return a database connection object
 */
class Database extends Object
{
    private static $instances = array();

	/**
	 * Returns a database connection object. It caches the created objects for future use.
	 *
	 * @param array $options Options to use when instantiating the database connection
	 *
	 * @return DriverBase
	 */
	public static function &getDatabase($options, $unset = false)
	{
		if (!is_array(self::$instances))
		{
            self::$instances = array();
		}

		$signature = serialize($options);

		if ($unset)
		{
			if (!empty(self::$instances[$signature]))
			{
				$db = self::$instances[$signature];
				$db = null;
				unset(self::$instances[$signature]);
			}
			$null = null;

			return $null;
		}

		if (empty(self::$instances[$signature]))
		{
			$driver = array_key_exists('driver', $options) ? $options['driver'] : '';
			$select = array_key_exists('select', $options) ? $options['select'] : true;
			$database = array_key_exists('database', $options) ? $options['database'] : null;

			$driver = preg_replace('/[^A-Z0-9_\\\.-]/i', '', $driver);

			if (empty($driver))
			{
				// No driver specified; try to guess
				$default_signature = serialize(Platform::getInstance()->get_platform_database_options());
				if ($signature == $default_signature)
				{
					$driver = Platform::getInstance()->get_default_database_driver(true);
				}
				else
				{
					$driver = Platform::getInstance()->get_default_database_driver(false);
				}
			}
			else
			{
				// Make sure a full driver name was given
				if ((substr($driver, 0, 7) != '\\Akeeba') && substr($driver, 0, 7) != 'Akeeba\\')
				{
					$driver = '\\Akeeba\\Engine\\Driver\\' . ucfirst($driver);
				}
			}

			// Useful for PHP 7 which does NOT have the ancient mysql adapter
			if (($driver == '\\Akeeba\\Engine\\Driver\\Mysql') && !function_exists('mysql_connect'))
			{
				$driver = '\\Akeeba\\Engine\\Driver\\Mysqli';
			}

            self::$instances[$signature] = new $driver($options);
		}

		return self::$instances[$signature];
	}

	public static function unsetDatabase($options)
	{
		self::getDatabase($options, true);
	}

    /**
     * Forces a specific instance. This is supposed to be used only in Unit Tests.
     *
     * @param $key
     * @param $instance
     *
     * @throws \Exception
     */
    public static function forceInstance($key, $instance)
    {
        if (!interface_exists('PHPUnit_Exception', false))
        {
            $method = __METHOD__;
            throw new \Exception("You can only use $method in Unit Tests", 500);
        }

        self::$instances[$key] = $instance;
    }

    /**
     * Reset all the instances. This is supposed to be used only in Unit Tests.
     *
     * @throws \Exception
     */
    public static function nukeInstances()
    {
        if (!interface_exists('PHPUnit_Exception', false))
        {
            $method = __METHOD__;
            throw new \Exception("You can only use $method in Unit Tests", 500);
        }

        self::$instances = array();
    }
}

Copyright © 2019 by b0y-101