mirror of https://github.com/friendica/friendica
64 lines
2.6 KiB
PHP
64 lines
2.6 KiB
PHP
<?php
|
|
/**
|
|
* @copyright Copyright (C) 2010-2023, the Friendica project
|
|
*
|
|
* @license GNU AGPL version 3 or any later version
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Affero General Public License as
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
* License, or (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Affero General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
*
|
|
*/
|
|
|
|
namespace Friendica\Core\Hooks\Capabilities;
|
|
|
|
use Friendica\Core\Hooks\Exceptions\HookRegisterArgumentException;
|
|
|
|
/**
|
|
* Register strategies and decorator/treatment handling for given classes
|
|
*/
|
|
interface ICanRegisterInstances
|
|
{
|
|
/**
|
|
* Register a class(strategy) for a given interface with a unique name.
|
|
*
|
|
* @see https://refactoring.guru/design-patterns/strategy
|
|
*
|
|
* @param string $interface The interface, which the given class implements
|
|
* @param string $class The fully-qualified given class name
|
|
* A placeholder for dependencies is possible as well
|
|
* @param ?string $name An arbitrary identifier for the given class, which will be used for factories, dependency injections etc.
|
|
*
|
|
* @return $this This interface for chain-calls
|
|
*
|
|
* @throws HookRegisterArgumentException in case the given class for the interface isn't valid or already set
|
|
*/
|
|
public function registerStrategy(string $interface, string $class, ?string $name = null): self;
|
|
|
|
/**
|
|
* Register a new decorator for a given class or interface
|
|
*
|
|
* @see https://refactoring.guru/design-patterns/decorator
|
|
*
|
|
* @note Decorator attach new behaviors to classes without changing them or without letting them know about it.
|
|
*
|
|
* @param string $class The fully-qualified class or interface name, which gets decorated by a class
|
|
* @param string $decoratorClass The fully-qualified name of the class which mimics the given class or interface and adds new functionality
|
|
* A placeholder for dependencies is possible as well
|
|
*
|
|
* @return $this This interface for chain-calls
|
|
*
|
|
* @throws HookRegisterArgumentException in case the given class for the class or interface isn't valid
|
|
*/
|
|
public function registerDecorator(string $class, string $decoratorClass): self;
|
|
}
|