propelorm/Propel2

View on GitHub
src/Propel/Runtime/ActiveQuery/InstancePoolTrait.php

Summary

Maintainability
A
45 mins
Test Coverage
<?php

/**
 * MIT License. This file is part of the Propel package.
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace Propel\Runtime\ActiveQuery;

use Countable;
use Propel\Runtime\Propel;

trait InstancePoolTrait
{
    /**
     * @var array<object>
     */
    public static $instances = [];

    /**
     * @param object $object
     * @param string|null $key
     *
     * @return void
     */
    public static function addInstanceToPool(object $object, ?string $key = null): void
    {
        if (!Propel::isInstancePoolingEnabled()) {
            return;
        }
        if ($key === null) {
            $key = static::getInstanceKey($object);
        }
        if (!$key) {
            return;
        }
        self::$instances[$key] = $object;
    }

    /**
     * @param mixed $value
     *
     * @return string|null
     */
    public static function getInstanceKey($value): ?string
    {
        if (!($value instanceof Criteria) && is_object($value)) {
            $pk = $value->getPrimaryKey();
            if (
                ((is_array($pk) || $pk instanceof Countable) && count($pk) > 1)
                || is_object($pk)
            ) {
                $pk = serialize($pk);
            }

            return (string)$pk;
        }

        if (is_scalar($value)) {
            // assume we've been passed a primary key
            return (string)$value;
        }

        return null;
    }

    /**
     * @param mixed $value
     *
     * @return void
     */
    public static function removeInstanceFromPool($value): void
    {
        if (Propel::isInstancePoolingEnabled() && $value !== null) {
            $key = static::getInstanceKey($value);
            if ($key) {
                unset(self::$instances[$key]);
            } else {
                self::clearInstancePool();
            }
        }
    }

    /**
     * @param string|null $key
     *
     * @return object|null
     */
    public static function getInstanceFromPool(?string $key): ?object
    {
        if ($key === null || !Propel::isInstancePoolingEnabled()) {
            return null;
        }

        if (!isset(self::$instances[$key])) {
            return null;
        }

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

    /**
     * @return void
     */
    public static function clearInstancePool(): void
    {
        self::$instances = [];
    }

    /**
     * @return void
     */
    public static function clearRelatedInstancePool(): void
    {
    }
}