deep-web-solutions/wordpress-framework-foundations

View on GitHub
src/includes/Hierarchy/Actions/AddContainerChildrenTrait.php

Summary

Maintainability
A
1 hr
Test Coverage
<?php

namespace DeepWebSolutions\Framework\Foundations\Hierarchy\Actions;

use DeepWebSolutions\Framework\Foundations\Actions\Initializable\InitializableExtensionTrait;
use DeepWebSolutions\Framework\Foundations\Actions\Initializable\InitializationFailureException;
use DeepWebSolutions\Framework\Foundations\DependencyInjection\ContainerAwareInterface;
use DeepWebSolutions\Framework\Foundations\Hierarchy\ParentInterface;
use DeepWebSolutions\Framework\Foundations\PluginAwareInterface;
use Psr\Container\ContainerInterface;

\defined( 'ABSPATH' ) || exit;

/**
 * Initialization extension trait for adding children to oneself from the DI container.
 *
 * @since   1.1.0
 * @version 1.5.0
 * @author  Antonius Hegyes <a.hegyes@deep-web-solutions.com>
 * @package DeepWebSolutions\WP-Framework\Foundations\Hierarchy\Actions
 */
trait AddContainerChildrenTrait {
    // region TRAITS

    use InitializableExtensionTrait;

    // endregion

    // region METHODS

    /**
     * During the initialization process, adds children to one's self from the dependency injection container.
     *
     * @since   1.1.0
     * @version 1.5.0
     *
     * @return  InitializationFailureException|null
     */
    protected function add_container_children(): ?InitializationFailureException {
        $init_result = null;

        if ( $this instanceof ParentInterface ) {
            $di_container = null;

            if ( $this instanceof ContainerAwareInterface ) {
                $di_container = $this->get_container();
            } elseif ( $this instanceof PluginAwareInterface && $this->get_plugin() instanceof ContainerAwareInterface ) {
                /* @noinspection PhpUndefinedMethodInspection */
                $di_container = $this->get_plugin()->get_container();
            }

            if ( $di_container instanceof ContainerInterface ) {
                $children = \array_filter( $this->get_di_container_children(), '\is_string' );
                foreach ( $children as $child ) {
                    $result = $this->add_child( $di_container->get( $child ) );
                    if ( $result instanceof InitializationFailureException ) {
                        $init_result = $result;
                        break;
                    }
                }
            }
        }

        return $init_result;
    }

    // endregion

    // region HELPERS

    /**
     * Using classes should return their DI children here.
     *
     * @since   1.1.0
     * @version 1.1.0
     *
     * @return  string[]
     */
    protected function get_di_container_children(): array {
        return array();
    }

    // endregion
}