Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/josantonius/php-hook
PHP library for hook management
https://github.com/josantonius/php-hook
actions handling-hooks php php-hooks
Last synced: 3 months ago
JSON representation
PHP library for hook management
- Host: GitHub
- URL: https://github.com/josantonius/php-hook
- Owner: josantonius
- License: mit
- Created: 2017-03-16T02:40:41.000Z (almost 8 years ago)
- Default Branch: main
- Last Pushed: 2022-09-29T17:02:58.000Z (over 2 years ago)
- Last Synced: 2024-10-11T23:14:52.638Z (4 months ago)
- Topics: actions, handling-hooks, php, php-hooks
- Language: PHP
- Homepage: https://josantonius.dev
- Size: 1.82 MB
- Stars: 22
- Watchers: 4
- Forks: 8
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: .github/CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Code of conduct: .github/CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# PHP Hook library
[![Latest Stable Version](https://poser.pugx.org/josantonius/hook/v/stable)](https://packagist.org/packages/josantonius/hook)
[![License](https://poser.pugx.org/josantonius/hook/license)](LICENSE)
[![Total Downloads](https://poser.pugx.org/josantonius/hook/downloads)](https://packagist.org/packages/josantonius/hook)
[![CI](https://github.com/josantonius/php-hook/actions/workflows/ci.yml/badge.svg?branch=main)](https://github.com/josantonius/php-hook/actions/workflows/ci.yml)
[![CodeCov](https://codecov.io/gh/josantonius/php-hook/branch/main/graph/badge.svg)](https://codecov.io/gh/josantonius/php-hook)
[![PSR1](https://img.shields.io/badge/PSR-1-f57046.svg)](https://www.php-fig.org/psr/psr-1/)
[![PSR4](https://img.shields.io/badge/PSR-4-9b59b6.svg)](https://www.php-fig.org/psr/psr-4/)
[![PSR12](https://img.shields.io/badge/PSR-12-1abc9c.svg)](https://www.php-fig.org/psr/psr-12/)**Translations**: [Español](.github/lang/es-ES/README.md)
Library for handling hooks in PHP.
---
- [Requirements](#requirements)
- [Installation](#installation)
- [Available Classes](#available-classes)
- [Action Instance](#action-instance)
- [Hook Class](#hook-class)
- [Priority Class](#priority-class)
- [Exceptions Used](#exceptions-used)
- [Usage](#usage)
- [Tests](#tests)
- [TODO](#todo)
- [Changelog](#changelog)
- [Contribution](#contribution)
- [Sponsor](#sponsor)
- [License](#license)---
## Requirements
- Operating System: Linux | Windows.
- PHP versions: 8.1 | 8.2.
## Installation
The preferred way to install this extension is through [Composer](http://getcomposer.org/download/).
To install **PHP Hook library**, simply:
```console
composer require josantonius/hook
```The previous command will only install the necessary files,
if you prefer to **download the entire source code** you can use:```console
composer require josantonius/hook --prefer-source
```You can also **clone the complete repository** with Git:
```console
git clone https://github.com/josantonius/php-hook.git
```## Available Classes
### Action Instance
`Josantonius\Hook\Action`
Gets action priority:
```php
public function getPriority(): int;
```Gets action callback result:
```php
public function getResult(): mixed;
```Checks if the action is done once:
```php
public function isOnce(): bool;
```Checks if the action has already been done:
```php
public function wasDone(): bool;
```### Hook Class
`Josantonius\Hook\Hook`
Register new hook:
```php
public function __construct(private string $name);
```Adds action on the hook:
```php
/**
* Action will be maintained after performing actions and will be available if are done again.
*
* @see https://www.php.net/manual/en/functions.first_class_callable_syntax.php
*
* @return Action Added action.
*/
public function addAction(callable $callback, int $priority = Priority::NORMAL): Action;
```Adds action once on the hook:
```php
/**
* Action will only be done once and will be deleted after it is done.
*
* It is recommended to use this method to release the actions
* from memory if the hook actions will only be done once.
*
* @return Action Added action.
*/
public function addActionOnce(callable $callback, int $priority = Priority::NORMAL): Action;
```Runs the added actions for the hook:
```php
/**
* @throws HookException if the actions have already been done.
* @throws HookException if no actions were added for the hook.
*
* @return Action[] Done actions.
*/
public function doActions(mixed ...$arguments): array;
```Checks if the hook has actions:
```php
/**
* True if the hook has any action even if the action has been
* done before (recurring actions created with addAction).
*/
public function hasActions(): bool;
```Checks if the hook has undone actions:
```php
/**
* True if the hook has some action left undone.
*/
public function hasUndoneActions(): bool;
```Checks if the actions were done at least once:
```php
/**
* If doActions was executed at least once.
*/
public function hasDoneActions(): bool;
```Gets hook name:
```php
public function getName(): string;
```### Priority Class
`Josantonius\Hook\Priority`
Available constants:
```php
public const HIGHEST = 50;
public const HIGH = 100;
public const NORMAL = 150;
public const LOW = 200;
public const LOWEST = 250;
```## Exceptions Used
```php
use Josantonius\Hook\Exceptions\HookException;
```## Usage
Example of use for this library:
### Register new hook
```php
use Josantonius\Hook\Hook;$hook = new Hook('name');
```### Adds actions on the hook
```php
use Josantonius\Hook\Hook;class Foo {
public static function bar() { /* do something */ }
public static function baz() { /* do something */ }
}$hook = new Hook('name');
$hook->addAction(Foo::bar(...));
$hook->addAction(Foo::baz(...));
```### Add actions with custom priority in the hook
```php
use Josantonius\Hook\Hook;
use Josantonius\Hook\Priority;class Foo {
public static function bar() { /* do something */ }
public static function baz() { /* do something */ }
}$hook = new Hook('name');
$hook->addAction(Foo::bar(...), Priority::LOW);
$hook->addAction(Foo::baz(...), Priority::HIGH);
```### Adds actions once on the hook
```php
use Josantonius\Hook\Hook;class Foo {
public function bar() { /* do something */ }
public function baz() { /* do something */ }
}$foo = new Foo();
$hook = new Hook('name');$hook->addActionOnce($foo->bar(...));
$hook->addActionOnce($foo->baz(...));
```### Adds actions once with custom priority in the hook
```php
use Josantonius\Hook\Hook;
use Josantonius\Hook\Priority;class Foo {
public function bar() { /* do something */ }
public function baz() { /* do something */ }
}$foo = new Foo();
$hook = new Hook('name');$hook->addActionOnce($foo->bar(...), Priority::LOW);
$hook->addActionOnce($foo->baz(...), Priority::HIGH);
```### Do actions with the same priority
```php
use Josantonius\Hook\Hook;function one() { /* do something */ }
function two() { /* do something */ }$hook = new Hook('name');
$hook->addAction(one(...));
$hook->addAction(two(...));/**
* The actions will be executed according to their natural order:
*
* one(), two()...
*/
$hook->doActions();
```### Do actions with different priority
```php
use Josantonius\Hook\Hook;
use Josantonius\Hook\Priority;function a() { /* do something */ }
function b() { /* do something */ }
function c() { /* do something */ }$hook = new Hook('name');
$hook->addAction(a(...), priority::LOW);
$hook->addAction(b(...), priority::NORMAL);
$hook->addAction(c(...), priority::HIGHEST);/**
* Actions will be executed according to their priority:
*
* c(), b(), a()...
*/
$hook->doActions();
```### Do actions with arguments
```php
use Josantonius\Hook\Hook;function foo($foo, $bar) { /* do something */ }
$hook = new Hook('name');
$hook->addAction(foo(...));
$hook->doActions('foo', 'bar');
```### Do actions recurrently
```php
use Josantonius\Hook\Hook;function a() { /* do something */ }
function b() { /* do something */ }
function c() { /* do something */ }$hook = new Hook('name');
$hook->addAction(a(...));
$hook->addAction(b(...));
$hook->addActionOnce(c(...)); // Will be done only once$hook->doActions(); // a(), b(), c()
$hook->doActions(); // a(), b()
```### Do actions only once
```php
use Josantonius\Hook\Hook;function one() { /* do something */ }
function two() { /* do something */ }$hook = new Hook('name');
$hook->addActionOnce(one(...));
$hook->addActionOnce(tho(...));$hook->doActions();
// $hook->doActions(); Throw exception since there are no actions to be done
```### Checks if the hook has actions
```php
use Josantonius\Hook\Hook;function foo() { /* do something */ }
$hook = new Hook('name');
$hook->addAction(foo());
$hook->hasActions(); // true
$hook->doActions();
$hook->hasActions(); // True since the action is recurrent and remains stored
```### Checks if the hook has undone actions
```php
use Josantonius\Hook\Hook;function foo() { /* do something */ }
$hook = new Hook('name');
$hook->addAction(foo());
$hook->hasUndoneActions(); // true
$hook->doActions();
$hook->hasUndoneActions(); // False since there are no undone actions
```### Checks if the actions were done at least once
```php
use Josantonius\Hook\Hook;function foo() { /* do something */ }
$hook = new Hook('name');
$hook->addAction(foo());
$hook->hasDoneActions(); // false
$hook->doActions();
$hook->hasDoneActions(); // True since the actions were done
```### Gets hook name
```php
use Josantonius\Hook\Hook;$hook = new Hook('foo');
$name = $hook->getName(); // foo
```#### Gets action priority
```php
use Josantonius\Hook\Hook;function foo() { /* do something */ }
$hook = new Hook('name');
$action = $hook->addAction(foo());
$action->getPriority();
```#### Gets action callback result
```php
use Josantonius\Hook\Hook;function foo() { /* do something */ }
$hook = new Hook('name');
$action = $hook->addAction(foo());
$action->getResult();
```#### Checks if the action is done once
```php
use Josantonius\Hook\Hook;function foo() { /* do something */ }
$hook = new Hook('name');
$action = $hook->addAction(foo());
$action->isOnce(); // false
$action = $hook->addActionOnce(foo());
$action->isOnce(); // true
```#### Checks if the action has already been done
```php
use Josantonius\Hook\Hook;function foo() { /* do something */ }
$hook = new Hook('name');
$action = $hook->addAction(foo());
$action->wasDone(); // false
$hook->doActions();
$action->wasDone(); // true
```## Tests
To run [tests](tests) you just need [composer](http://getcomposer.org/download/)
and to execute the following:```console
git clone https://github.com/josantonius/php-hook.git
``````console
cd php-hook
``````console
composer install
```Run unit tests with [PHPUnit](https://phpunit.de/):
```console
composer phpunit
```Run code standard tests with [PHPCS](https://github.com/squizlabs/PHP_CodeSniffer):
```console
composer phpcs
```Run [PHP Mess Detector](https://phpmd.org/) tests to detect inconsistencies in code style:
```console
composer phpmd
```Run all previous tests:
```console
composer tests
```## TODO
- [ ] Add new feature
- [ ] Improve tests
- [ ] Improve documentation
- [ ] Improve English translation in the README file
- [ ] Refactor code for disabled code style rules (see phpmd.xml and phpcs.xml)
- [ ] Make Action->runCallback() accessible only to the Hook class
- [ ] Add method to remove action?
- [ ] Add option to add ID in actions?## Changelog
Detailed changes for each release are documented in the
[release notes](https://github.com/josantonius/php-hook/releases).## Contribution
Please make sure to read the [Contributing Guide](.github/CONTRIBUTING.md), before making a pull
request, start a discussion or report a issue.Thanks to all [contributors](https://github.com/josantonius/php-hook/graphs/contributors)! :heart:
## Sponsor
If this project helps you to reduce your development time,
[you can sponsor me](https://github.com/josantonius#sponsor) to support my open source work :blush:## License
This repository is licensed under the [MIT License](LICENSE).
Copyright © 2017-present, [Josantonius](https://github.com/josantonius#contact)