Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/streamcommon/promise
PHP Promises/A+ implementation
https://github.com/streamcommon/promise
php-async php-extension php7 promise promises-aplus promisesaplus swoole
Last synced: 2 months ago
JSON representation
PHP Promises/A+ implementation
- Host: GitHub
- URL: https://github.com/streamcommon/promise
- Owner: streamcommon
- License: bsd-3-clause
- Created: 2019-03-03T18:50:54.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2020-06-28T15:21:47.000Z (over 4 years ago)
- Last Synced: 2024-11-08T01:36:53.151Z (3 months ago)
- Topics: php-async, php-extension, php7, promise, promises-aplus, promisesaplus, swoole
- Language: PHP
- Homepage:
- Size: 202 KB
- Stars: 15
- Watchers: 2
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# PHP Promises/A+ implementation
[![PHP >= 7.2 ][PHP image]](http://php.net)
[![Swoole >= 4.2][Swoole image]](https://github.com/swoole/swoole-src)
[![Latest Stable Version](https://poser.pugx.org/streamcommon/promise/v/stable)](https://packagist.org/packages/streamcommon/promise)
[![Total Downloads](https://poser.pugx.org/streamcommon/promise/downloads)](https://packagist.org/packages/streamcommon/promise)
[![License](https://poser.pugx.org/streamcommon/promise/license)](./LICENSE)This package provides [Promise/A+](https://github.com/promises-aplus/promises-spec) PHP implementation.
# Branches
[![Master][Master branch image]][Master branch] [![Build Status][Master image]][Master] [![Coverage Status][Master coverage image]][Master coverage][![Develop][Develop branch image]][Develop branch] [![Build Status][Develop image]][Develop] [![Coverage Status][Develop coverage image]][Develop coverage]
## Installation
Console run:
```console
composer require streamcommon/promise
```
Or add into your `composer.json`:
```json
"require": {
"streamcommon/promise": "*"
}
```
> If you want see TRUE promise then install [Swoole](http://php.net/manual/en/swoole.installation.php) extension.
> For more info visit the [Swoole repo](https://github.com/swoole/swoole-src)
>> NOTE: TRUE promise work only in CLI mode## Promise
Promise is a library which provides [Promise/A+](https://github.com/promises-aplus/promises-spec) PHP implementation.All Promise it a special PHP classes that contains its state:
- `pending` - PromiseInterface::STATE_PENDING
- `fulfilled` - PromiseInterface::STATE_FULFILLED
- `rejected` - PromiseInterface::STATE_REJECTEDTo initiate a new promise, you can use static method `PromiseInterface::create` or create with new.
All resulting `Promise` has `PromiseInterface::STATE_PENDING` state.
```php
$promise = new Promise(function(callable $resolve, callable $reject));
// OR
$promise = Promise::create(function(callable $resolve, callable $reject))
```When `function($resolve, $reject)` executor finishes the job, it should call one of the functions:
- `$resolve` to indicate that the job finished successfully and set `Promise` state to `PromiseInterface::STATE_FULFILLED`
```php
$resolve = function ($value) {
$this->setState(PromiseInterface::STATE_FULFILLED);
$this->setResult($value);
};
```
- `$reject` to indicate that an error occurred and set `Promise` state to `PromiseInterface::STATE_REJECTED`
```php
$reject = function ($value) {
$this->setState(PromiseInterface::STATE_REJECTED);
$this->setResult($value);
};
```Method `PromiseInterface::then()` it be called after promise change stage. In terms of our analogy: this is the “subscription".
```php
public function then(?callable $onFulfilled = null, ?callable $onRejected = null): PromiseInterface;
```
- `$onFulfilled` run when the `Promise` is resolved and it has `PromiseInterface::STATE_FULFILLED` state.
- `$onFulfilled` run when the `Promise` is rejected and it has `PromiseInterface::STATE_REJECTED` state.
> NOTE: If `$onFulfilled` or `$onFulfilled` is not a callable function it was ignoreCalling `PromiseInterface::resolve()` creates a successfully executed promise with the result value.
```php
public static function resolve($value): PromiseInterface;
```
It is similar to:
```php
$promise = new Promise(function(callable $resolve) {
$resolve($value)
});
```
Similarly `PromiseInterface::reject()` creates an already executed promise with an error value.
```php
public static function reject($value): PromiseInterface;
```
It is similar to:
```php
$promise = new Promise(function(callable $resolve, callable $reject) {
$reject($value)
});
```
## Sub promise
When `function($resolve, $reject)` executor finishes the job, it can return `PromiseInterface`.
```php
$promise = Promise::create(function (callable $resolve) {
$resolve(Promise::create(function (callable $subResolve) {
$subResolve(42);
}));
});
```
In this case, it will wait for the execution of sub promise.Method `PromiseInterface::then()` can return `PromiseInterface` to.
```php
$promise->then(function ($value) {
return Promise::create(function (callable $resolve) use ($value) {
$resolve($value + 1);
});
});
```
For more info check [example](/example) scripts.## Example
> Standard Promise
```php
use Streamcommon\Promise\Promise;
$promise = Promise::create(function (callable $resolve) {
$resolve(41);
});
$newPromise = $promise->then(function ($value) {
return $value + 1;
});
$promise->then(function ($value) {
echo $value . ' === 41' . PHP_EOL;
});
$newPromise->then(function ($value) {
echo $value . ' === 42' . PHP_EOL;
});
$promise->wait(); // promise execution
```> If you want see TRUE promise then install [Swoole](http://php.net/manual/en/swoole.installation.php) extension.
> For more info visit the [Swoole repo](https://github.com/swoole/swoole-src)
>> NOTE: TRUE promise work only in CLI mode```php
use Streamcommon\Promise\ExtSwoolePromise;
// be careful with this
\Swoole\Runtime::enableCoroutine(); // IF YOU WANT REALY ASYNC
$promise = ExtSwoolePromise::create(function (callable $resolve) {
// the function is executed automatically when the promise is constructed
$resolve(41);
});
$promise->then(function ($value) {
// the function is executed automatically after __constructor job
return $value + 1;
})->then(function ($value) {
// the function is executed automatically after ::then()
echo $value . PHP_EOL;
});
```
> Sub promise
```php
use Streamcommon\Promise\Promise;$promise = Promise::create(function (callable $resolve) {
$resolve(Promise::create(function (callable $resolve) {
$resolve(42);
}));
});
$newPromise = $promise->then(function ($value) {
return $value + 1;
});
$superNewPromise = $promise->then(function ($value) {
return Promise::create(function (callable $resolve) use ($value) {
$resolve($value + 2);
});
});
$promise->then(function ($value) {
echo $value . ' === 42' . PHP_EOL;
});
$newPromise->then(function ($value) {
echo $value . ' === 43' . PHP_EOL;
});
$superNewPromise->then(function ($value) {
echo $value . ' === 44' . PHP_EOL;
});
$promise->wait();
```
> Sub async promise
```php
use Streamcommon\Promise\ExtSwoolePromise;
// be careful with this
\Swoole\Runtime::enableCoroutine(); // IF YOU WANT REALY ASYNC
$promise = ExtSwoolePromise::create(function (callable $resolve) {
$promise = ExtSwoolePromise::create(function (callable $resolve) {
$resolve(41);
});
$promise->then(function ($value) use ($resolve) {
$resolve($value);
});
});
$promise->then(function ($value) {
return $value + 1;
})->then(function ($value) {
echo $value . PHP_EOL;
});
```
> If use `ExtSwoolePromise` with `daemon|cycle|loop` you must use `Swoole\Runtime::wait()`
```php
\Swoole\Runtime::enableCoroutine();
while (true) {
///
Some code with ExtSwoolePromise
///
\Swoole\Runtime::wait();
}
```
[PHP image]: https://img.shields.io/badge/php-%3E%3D%207.2-blue.svg
[Swoole image]: https://img.shields.io/badge/swoole-%3E%3D%204.2-blue.svg
[Master branch]: https://github.com/streamcommon/promise/tree/master
[Master branch image]: https://img.shields.io/badge/branch-master-blue.svg
[Develop branch]: https://github.com/streamcommon/promise/tree/develop
[Develop branch image]: https://img.shields.io/badge/branch-develop-blue.svg
[Master image]: https://travis-ci.org/streamcommon/promise.svg?branch=master
[Master]: https://travis-ci.org/streamcommon/promise
[Master coverage image]: https://coveralls.io/repos/github/streamcommon/promise/badge.svg?branch=master
[Master coverage]: https://coveralls.io/github/streamcommon/promise?branch=master
[Develop image]: https://travis-ci.org/streamcommon/promise.svg?branch=develop
[Develop]: https://travis-ci.org/streamcommon/promise
[Develop coverage image]: https://coveralls.io/repos/github/streamcommon/promise/badge.svg?branch=develop
[Develop coverage]: https://coveralls.io/github/streamcommon/promise?branch=develop