antidot-fw / react-framework
Antidot React Framework
Fund package maintenance!
kpicaza
Installs: 1 322
Dependents: 1
Suggesters: 0
Security: 0
Stars: 8
Watchers: 2
Forks: 1
Open Issues: 3
Requires
- php: ^7.4|>=8.0
- antidot-fw/framework: ^1.0
- beberlei/assert: ^3.3
- drift/server: ^0.1.20
- psr/container: ^1.0.0
- ramsey/uuid: ^4.1
- react/http: ^1.2
Requires (Dev)
- clue/block-react: ^1.4
- infection/infection: ^0.20
- phpro/grumphp: ^1.0.0
- phpunit/phpunit: ^8.0 || ^9.0
- squizlabs/php_codesniffer: ^3.4
- symfony/var-dumper: ^5.1
- vimeo/psalm: ^4.4
Suggests
- react/filesystem: ^0.1.2
README
Requirements
- PHP ^7.4|^8.0
- Antidot Framework
- DriftPHP Server
- React Http
- React Promises
- Ramsey Uuid
Description
This package allows running asynchronous PHP following PSR-15 middleware standard approach.
Install
The preferred way to install this library is using the reactive-antidot-starter
project.
composer create-project antidot-fw/reactive-antidot-starter
To install it on a existing Antidot Framework Project installation we need to tweak some configurations and replace or create new index.php
file.
composer require antidot-fw/react-framework
Config
- Disable LaminasRequest Handler Runner
- Load Antidot React Config Provider after Antidot Framework provider
Example config from starter project
<?php // config/config.php declare(strict_types=1); use Antidot\DevTools\Container\Config\ConfigProvider as DevToolsConfigProvider; use Antidot\SymfonyConfigTranslator\Container\Config\ConfigAggregator; use Antidot\Yaml\YamlConfigProvider; use Laminas\ConfigAggregator\ArrayProvider; use Laminas\ConfigAggregator\PhpFileProvider; // To enable or disable caching, set the `ConfigAggregator::ENABLE_CACHE` boolean in // `config/autoload/local.php`. $cacheConfig = [ 'config_cache_path' => 'var/cache/config-cache.php', ]; $aggregator = new ConfigAggregator([ \WShafer\PSR11MonoLog\ConfigProvider::class, \Antidot\Event\Container\Config\ConfigProvider::class, \Antidot\Logger\Container\Config\ConfigProvider::class, \Antidot\Cli\Container\Config\ConfigProvider::class, \Antidot\Fast\Router\Container\Config\ConfigProvider::class, \Antidot\Container\Config\ConfigProvider::class, \Antidot\React\Container\Config\ConfigProvider::class, class_exists(DevToolsConfigProvider::class) ? DevToolsConfigProvider::class : fn() => [], new PhpFileProvider(realpath(__DIR__).'/services/{{,*.}prod,{,*.}local,{,*.}dev}.php'), new YamlConfigProvider(realpath(__DIR__).'/services/{{,*.}prod,{,*.}local,{,*.}dev}.yaml'), new ArrayProvider($cacheConfig), ], $cacheConfig['config_cache_path']); return $aggregator->getMergedConfig();
Default Config:
<?php $config = [ 'server' => [ 'host' => '0.0.0.0', 'port' => 5555, 'buffer_size' => 4096, 'max_concurrency' => 100, 'workers' => 1, 'static_folder' => 'public' ] ]
Usage
It allows executing promises inside PSR-15 and PSR-7 Middlewares and request handlers
PSR-15 Middleware
<?php declare(strict_types = 1); namespace App; use Antidot\React\PromiseResponse; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; use Psr\Http\Server\MiddlewareInterface; use Psr\Http\Server\RequestHandlerInterface; class SomeMiddleware implements MiddlewareInterface { public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface { return new PromiseResponse( resolve($request) ->then(static fn(ServerrequestInsterface $request) => $handler->handle($request)) ); } }
PSR-7 Request Handler
<?php declare(strict_types = 1); namespace App; use Antidot\React\PromiseResponse; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; use Psr\Http\Server\RequestHandlerInterface; class SomeMiddleware implements RequestHandlerInterface { public function process(ServerRequestInterface $request): ResponseInterface { return resolve($request)->then( function(ServerrequestInterface $request): ResponseInterface { return new Response('Hello World!!!'); } );; } }
Server
Two new commands will be added to the Antidot Framework CLI tool, to allow running the application on top of Drift server
server:run
: Run Drift HTTP Serverserver:watch
: Watch Drift HTTP Server for development purposes
$ bin/console
...
server
server:run Run Drift HTTP Server
server:watch Watch Drift HTTP Server for development purposes
$ bin/console server:run -h Description: Run Drift HTTP Server Usage: server:run [options] [--] [<path>] Arguments: path The server will start listening to this address [default: "0.0.0.0:5555"] Options: --static-folder[=STATIC-FOLDER] Static folder path [default: "public"] --no-static-folder Disable static folder --debug Enable debug --no-header Disable the header --no-cookies Disable cookies --no-file-uploads Disable file uploads --concurrent-requests[=CONCURRENT-REQUESTS] Limit of concurrent requests [default: 100] --request-body-buffer[=REQUEST-BODY-BUFFER] Limit of the buffer used for the Request body. In KiB. [default: 4096] --adapter[=ADAPTER] Server Adapter [default: "Antidot\React\DriftKernelAdapter"] --allowed-loop-stops[=ALLOWED-LOOP-STOPS] Number of allowed loop stops [default: 0] --workers[=WORKERS] Number of workers. Use -1 to get as many workers as physical thread available for your system. Maximum of 128 workers. Option disabled for watch command. [default: 16] -q, --quiet Do not output any message
$ bin/console server:watch -h Description: Watch Drift HTTP Server for development purposes Usage: server:watch [options] [--] [<path>] Arguments: path The server will start listening to this address [default: "0.0.0.0:5555"] Options: --static-folder[=STATIC-FOLDER] Static folder path [default: "public"] --no-static-folder Disable static folder --debug Enable debug --no-header Disable the header --no-cookies Disable cookies --no-file-uploads Disable file uploads --concurrent-requests[=CONCURRENT-REQUESTS] Limit of concurrent requests [default: 512] --request-body-buffer[=REQUEST-BODY-BUFFER] Limit of the buffer used for the Request body. In KiB. [default: 2048] --adapter[=ADAPTER] Server Adapter [default: "drift"] --allowed-loop-stops[=ALLOWED-LOOP-STOPS] Number of allowed loop stops [default: 0] --workers[=WORKERS] Number of workers. Use -1 to get as many workers as physical thread available for your system. Maximum of 128 workers. Option disabled for watch command. [default: 1] -q, --quiet Do not output any message