spqr/vendor/cakephp/datasource/FactoryLocator.php

104 lines
3.2 KiB
PHP
Raw Permalink Normal View History

2024-11-05 12:10:06 +08:00
<?php
declare(strict_types=1);
/**
* CakePHP(tm) : Rapid Development Framework (https://cakephp.org)
* Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
*
* Licensed under The MIT License
* For full copyright and license information, please see the LICENSE.txt
* Redistributions of files must retain the above copyright notice.
*
* @copyright Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
* @link https://cakephp.org CakePHP(tm) Project
* @since 3.3.0
* @license https://opensource.org/licenses/mit-license.php MIT License
*/
namespace Cake\Datasource;
use Cake\Datasource\Locator\LocatorInterface;
use Cake\ORM\Locator\TableLocator;
use InvalidArgumentException;
use function Cake\Core\deprecationWarning;
use function Cake\Core\getTypeName;
/**
* Class FactoryLocator
*/
class FactoryLocator
{
/**
* A list of model factory functions.
*
* @var array<callable|\Cake\Datasource\Locator\LocatorInterface>
*/
protected static $_modelFactories = [];
/**
* Register a callable to generate repositories of a given type.
*
* @param string $type The name of the repository type the factory function is for.
* @param \Cake\Datasource\Locator\LocatorInterface|callable $factory The factory function used to create instances.
* @return void
*/
public static function add(string $type, $factory): void
{
if ($factory instanceof LocatorInterface) {
static::$_modelFactories[$type] = $factory;
return;
}
if (is_callable($factory)) {
deprecationWarning(
'Using a callable as a locator has been deprecated.'
. ' Use an instance of Cake\Datasource\Locator\LocatorInterface instead.'
);
static::$_modelFactories[$type] = $factory;
return;
}
throw new InvalidArgumentException(sprintf(
'`$factory` must be an instance of Cake\Datasource\Locator\LocatorInterface or a callable.'
. ' Got type `%s` instead.',
getTypeName($factory)
));
}
/**
* Drop a model factory.
*
* @param string $type The name of the repository type to drop the factory for.
* @return void
*/
public static function drop(string $type): void
{
unset(static::$_modelFactories[$type]);
}
/**
* Get the factory for the specified repository type.
*
* @param string $type The repository type to get the factory for.
* @throws \InvalidArgumentException If the specified repository type has no factory.
* @return \Cake\Datasource\Locator\LocatorInterface|callable The factory for the repository type.
*/
public static function get(string $type)
{
if (!isset(static::$_modelFactories['Table'])) {
static::$_modelFactories['Table'] = new TableLocator();
}
if (!isset(static::$_modelFactories[$type])) {
throw new InvalidArgumentException(sprintf(
'Unknown repository type "%s". Make sure you register a type before trying to use it.',
$type
));
}
return static::$_modelFactories[$type];
}
}