HEX
Server: LiteSpeed
System: Linux server53.web-hosting.com 4.18.0-513.24.1.lve.1.el8.x86_64 #1 SMP Thu May 9 15:10:09 UTC 2024 x86_64
User: nahevttf (6494)
PHP: 8.0.30
Disabled: NONE
Upload Files
File: //home/nahevttf/www/wp-content/plugins/woocommerce/src/Internal/DependencyManagement/Definition.php
<?php
/**
 * An extension to the Definition class to prevent constructor injection from being possible.
 */

namespace Automattic\WooCommerce\Internal\DependencyManagement;

use Automattic\WooCommerce\Vendor\League\Container\Definition\Definition as BaseDefinition;

/**
 * An extension of the definition class that replaces constructor injection with method injection.
 */
class Definition extends BaseDefinition {

	/**
	 * The standard method that we use for dependency injection.
	 */
	public const INJECTION_METHOD = 'init';

	/**
	 * Resolve a class using method injection instead of constructor injection.
	 *
	 * @param string $concrete The concrete to instantiate.
	 *
	 * @return object
	 */
	protected function resolveClass( string $concrete ) {
		$instance = new $concrete();
		$this->invokeInit( $instance );
		return $instance;
	}

	/**
	 * Invoke methods on resolved instance, including 'init'.
	 *
	 * @param object $instance The concrete to invoke methods on.
	 *
	 * @return object
	 */
	protected function invokeMethods( $instance ) {
		$this->invokeInit( $instance );
		parent::invokeMethods( $instance );
		return $instance;
	}

	/**
	 * Invoke the 'init' method on a resolved object.
	 *
	 * Constructor injection causes backwards compatibility problems
	 * so we will rely on method injection via an internal method.
	 *
	 * @param object $instance The resolved object.
	 * @return void
	 */
	private function invokeInit( $instance ) {
		$resolved = $this->resolveArguments( $this->arguments );

		if ( method_exists( $instance, static::INJECTION_METHOD ) ) {
			call_user_func_array( array( $instance, static::INJECTION_METHOD ), $resolved );
		}
	}

	/**
	 * Forget the cached resolved object, so the next time it's requested
	 * it will be resolved again.
	 */
	public function forgetResolved() {
		$this->resolved = null;
	}
}