2020-03-11 23:04:01 -04:00
|
|
|
<?php declare(strict_types=1);
|
|
|
|
/**
|
2020-03-12 11:45:11 -04:00
|
|
|
* Hummingbird Anime List Client
|
2020-03-11 23:04:01 -04:00
|
|
|
*
|
2020-03-12 11:45:11 -04:00
|
|
|
* An API client for Kitsu to manage anime and manga watch lists
|
2020-03-11 23:04:01 -04:00
|
|
|
*
|
2021-02-04 11:57:01 -05:00
|
|
|
* PHP version 8
|
2020-03-11 23:04:01 -04:00
|
|
|
*
|
2022-03-04 15:50:35 -05:00
|
|
|
* @copyright 2015 - 2022 Timothy J. Warren <tim@timshome.page>
|
2020-03-11 23:04:01 -04:00
|
|
|
* @license http://www.opensource.org/licenses/mit-license.html MIT License
|
2020-12-10 17:06:50 -05:00
|
|
|
* @version 5.2
|
2022-03-04 15:50:35 -05:00
|
|
|
* @link https://git.timshome.page/timw4mail/HummingBirdAnimeClient
|
2020-03-11 23:04:01 -04:00
|
|
|
*/
|
|
|
|
|
|
|
|
namespace Aviat\Ion\Di;
|
|
|
|
|
|
|
|
use Psr\Log\LoggerInterface;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Interface for the Dependency Injection Container
|
|
|
|
*
|
|
|
|
* Based on container-interop interface, but return types and
|
|
|
|
* scalar type hints make the interface incompatible to the PHP parser
|
|
|
|
*
|
|
|
|
* @see https://github.com/container-interop/container-interop
|
|
|
|
*/
|
2022-03-03 17:26:09 -05:00
|
|
|
interface ContainerInterface
|
|
|
|
{
|
2020-03-11 23:04:01 -04:00
|
|
|
/**
|
|
|
|
* Finds an entry of the container by its identifier and returns it.
|
|
|
|
*
|
|
|
|
* @param string $id Identifier of the entry to look for.
|
2022-03-03 17:26:09 -05:00
|
|
|
* @throws Exception\NotFoundException No entry was found for this identifier.
|
2020-03-11 23:04:01 -04:00
|
|
|
* @throws Exception\ContainerException Error while retrieving the entry.
|
|
|
|
* @return mixed Entry.
|
|
|
|
*/
|
2021-02-26 14:42:07 -05:00
|
|
|
public function get(string $id): mixed;
|
2020-03-11 23:04:01 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns true if the container can return an entry for the given identifier.
|
|
|
|
* Returns false otherwise.
|
|
|
|
*
|
|
|
|
* @param string $id Identifier of the entry to look for.
|
|
|
|
*/
|
2021-02-26 14:42:07 -05:00
|
|
|
public function has(string $id): bool;
|
2020-03-11 23:04:01 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a factory to the container
|
|
|
|
*
|
2022-03-03 17:26:09 -05:00
|
|
|
* @param callable $value - a factory callable for the item
|
2020-03-11 23:04:01 -04:00
|
|
|
*/
|
2022-03-03 17:26:09 -05:00
|
|
|
public function set(string $id, callable $value): ContainerInterface;
|
2020-03-11 23:04:01 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set a specific instance in the container for an existing factory
|
|
|
|
*/
|
2021-02-26 14:42:07 -05:00
|
|
|
public function setInstance(string $id, mixed $value): ContainerInterface;
|
2020-03-11 23:04:01 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get a new instance of the specified item
|
|
|
|
*/
|
2021-02-26 14:42:07 -05:00
|
|
|
public function getNew(string $id): mixed;
|
2020-03-11 23:04:01 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Determine whether a logger channel is registered
|
|
|
|
*
|
2022-03-03 17:26:09 -05:00
|
|
|
* @param string $id The logger channel
|
2020-03-11 23:04:01 -04:00
|
|
|
*/
|
|
|
|
public function hasLogger(string $id = 'default'): bool;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a logger to the Container
|
|
|
|
*
|
2022-03-03 17:26:09 -05:00
|
|
|
* @param string $id The logger 'channel'
|
2020-03-11 23:04:01 -04:00
|
|
|
*/
|
|
|
|
public function setLogger(LoggerInterface $logger, string $id = 'default'): ContainerInterface;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieve a logger for the selected channel
|
|
|
|
*
|
2022-03-03 17:26:09 -05:00
|
|
|
* @param string $id The logger to retrieve
|
2020-03-11 23:04:01 -04:00
|
|
|
*/
|
|
|
|
public function getLogger(string $id = 'default'): ?LoggerInterface;
|
2022-03-03 17:26:09 -05:00
|
|
|
}
|