File "ModuleInterface.php"
Full Path: /home/siazco/grocery.siazco.se/wp-content/plugins/woocommerce-paypal-payments/vendor/dhii/module-interface/src/ModuleInterface.php
File size: 2.2 KB
MIME-type: text/x-php
Charset: utf-8
<?php
declare(strict_types=1);
namespace Dhii\Modular\Module;
use Dhii\Modular\Module\Exception\ModuleExceptionInterface;
use Interop\Container\ServiceProviderInterface;
use Psr\Container\ContainerInterface;
/**
* Something that represents an application module.
*
* @since 0.2
*/
interface ModuleInterface
{
/**
* Performs module-specific setup and provides a service provider.
*
* This method SHOULD be called at least once before {@link ModuleInterface::run()} may be invoked for a particular
* module instance. The returned service provider instance SHOULD be incorporated by the application into the
* container instance that is then given to this module's {@link ModuleInterface::run()} method.
*
* The application MAY also incorporate the service provider into the container instance given to other modules,
* but this is not required. As such, services factories in the returned service provider should not assume the
* existence of other module's services. Use proxy services together with {@link ContainerInterface::has()} for
* optionally integrating with other modules.
*
* @since 0.2
*
* @return ServiceProviderInterface A service provider instance for this module's services.
*
* @throws ModuleExceptionInterface If module setup failed and/or a service provider instance could not be returned.
*/
public function setup(): ServiceProviderInterface;
/**
* Runs the module.
*
* This method MUST be called after the module has been set up using {@link ModuleInterface::setup()}. A services
* container MUST be given to this method, and MUST incorporate the services from the service provider returned
* by the same module's {@link ModuleInterface::setup()} method. This container instance is not guaranteed to be
* the same instance given to other modules. As such, it is strongly advised to assume it is not, and to avoid
* referencing services from other modules.
*
* @since 0.2
*
* @param ContainerInterface $c A services container instance.
*
* @throws ModuleExceptionInterface If the module failed to run.
*/
public function run(ContainerInterface $c): void;
}