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