|
8 | 8 | use Laminas\Diactoros\StreamFactory; |
9 | 9 | use Laminas\Diactoros\UploadedFileFactory; |
10 | 10 | use Symfony\Bridge\PsrHttpMessage\Factory\PsrHttpFactory; |
| 11 | +use TheCodingMachine\GraphQLite\Bundle\UploadMiddlewareUtils\DummyResponseWithRequest; |
| 12 | +use TheCodingMachine\GraphQLite\Bundle\UploadMiddlewareUtils\RequestExtractorMiddleware; |
11 | 13 | use TheCodingMachine\GraphQLite\Http\HttpCodeDecider; |
12 | 14 | use TheCodingMachine\GraphQLite\Http\HttpCodeDeciderInterface; |
13 | 15 | use GraphQL\Executor\ExecutionResult; |
|
30 | 32 | use function json_decode; |
31 | 33 |
|
32 | 34 | /** |
33 | | - * Listens to every single request and forward Graphql requests to Graphql Webonix standardServer. |
| 35 | + * Listens to every single request and forwards GraphQL requests to Webonyx's \GraphQL\Server\StandardServer. |
34 | 36 | */ |
35 | 37 | class GraphQLiteController |
36 | 38 | { |
37 | | - /** |
38 | | - * @var HttpMessageFactoryInterface |
39 | | - */ |
40 | | - private $httpMessageFactory; |
41 | | - /** @var int */ |
42 | | - private $debug; |
43 | | - /** |
44 | | - * @var ServerConfig |
45 | | - */ |
46 | | - private $serverConfig; |
47 | | - /** |
48 | | - * @var HttpCodeDeciderInterface |
49 | | - */ |
50 | | - private $httpCodeDecider; |
| 39 | + private HttpMessageFactoryInterface $httpMessageFactory; |
| 40 | + private int $debug; |
| 41 | + private ServerConfig $serverConfig; |
| 42 | + private HttpCodeDeciderInterface $httpCodeDecider; |
51 | 43 |
|
52 | 44 | public function __construct(ServerConfig $serverConfig, ?HttpMessageFactoryInterface $httpMessageFactory = null, ?int $debug = null, ?HttpCodeDeciderInterface $httpCodeDecider = null) |
53 | 45 | { |
@@ -98,11 +90,12 @@ public function handleRequest(Request $request): Response |
98 | 90 | $psr7Request = $psr7Request->withParsedBody($parsedBody); |
99 | 91 | } |
100 | 92 |
|
101 | | - // Let's parse the request and adapt it for file uploads. |
| 93 | + // Let's parse the request and adapt it for file uploads using an anonymous PSR-15 middleware. |
102 | 94 | if (class_exists(UploadMiddleware::class)) { |
103 | 95 | $uploadMiddleware = new UploadMiddleware(); |
104 | | - $psr7Request = $uploadMiddleware->processRequest($psr7Request); |
105 | | - \assert($psr7Request instanceof ServerRequestInterface); |
| 96 | + $dummyResponseWithRequest = $uploadMiddleware->process($psr7Request, new RequestExtractorMiddleware()); |
| 97 | + assert($dummyResponseWithRequest instanceof DummyResponseWithRequest); |
| 98 | + $psr7Request = $dummyResponseWithRequest->getRequest(); |
106 | 99 | } |
107 | 100 |
|
108 | 101 | return $this->handlePsr7Request($psr7Request, $request); |
|
0 commit comments