1 | <?php declare(strict_types=1); |
||
12 | class FrameParser |
||
13 | { |
||
14 | |||
15 | /** |
||
16 | * Mapping of constants to the classes |
||
17 | * |
||
18 | * @var array |
||
19 | */ |
||
20 | protected static $classMapping = [ |
||
21 | FCGI::BEGIN_REQUEST => FCGI\Record\BeginRequest::class, |
||
22 | FCGI::ABORT_REQUEST => FCGI\Record\AbortRequest::class, |
||
23 | FCGI::END_REQUEST => FCGI\Record\EndRequest::class, |
||
24 | FCGI::PARAMS => FCGI\Record\Params::class, |
||
25 | FCGI::STDIN => FCGI\Record\Stdin::class, |
||
26 | FCGI::STDOUT => FCGI\Record\Stdout::class, |
||
27 | FCGI::STDERR => FCGI\Record\Stderr::class, |
||
28 | FCGI::DATA => FCGI\Record\Data::class, |
||
29 | FCGI::GET_VALUES => FCGI\Record\GetValues::class, |
||
30 | FCGI::GET_VALUES_RESULT => FCGI\Record\GetValuesResult::class, |
||
31 | FCGI::UNKNOWN_TYPE => FCGI\Record\UnknownType::class, |
||
32 | ]; |
||
33 | |||
34 | /** |
||
35 | * Checks if the buffer contains a valid frame to parse |
||
36 | * |
||
37 | * @param string $buffer Binary buffer |
||
38 | * |
||
39 | * @return bool |
||
40 | */ |
||
41 | public static function hasFrame(string $buffer): bool |
||
55 | |||
56 | /** |
||
57 | * Parses a frame from the binary buffer |
||
58 | * |
||
59 | * @param string $buffer Binary buffer |
||
60 | * |
||
61 | * @return Record One of the corresponding FCGI record |
||
62 | */ |
||
63 | public static function parseFrame(string &$buffer): Record |
||
85 | |||
86 | } |
||
87 |