|
| 1 | +<?php |
| 2 | + |
| 3 | +namespace Hengebytes\SoapCoreAsyncBundle\Cache\Middleware\Response; |
| 4 | + |
| 5 | +use Hengebytes\SoapCoreAsyncBundle\Handler\SoapAsyncRequestHandler; |
| 6 | +use Hengebytes\SoapCoreAsyncBundle\Request\SoapWSRequest; |
| 7 | +use Hengebytes\WebserviceCoreAsyncBundle\Cache\Middleware\Response\ReloadLockedResponseResponseModifier as BaseModifier; |
| 8 | +use Hengebytes\WebserviceCoreAsyncBundle\Callback\OnResponseReceivedCallback; |
| 9 | +use Hengebytes\WebserviceCoreAsyncBundle\Middleware\ResponseModificationInterface; |
| 10 | +use Hengebytes\WebserviceCoreAsyncBundle\Response\AsyncResponse; |
| 11 | +use Hengebytes\WebserviceCoreAsyncBundle\Response\ParsedResponse; |
| 12 | +use Symfony\Component\DependencyInjection\ContainerInterface; |
| 13 | +use Symfony\Component\DependencyInjection\Attribute\AsDecorator; |
| 14 | +use Symfony\Component\HttpFoundation\Response; |
| 15 | + |
| 16 | +#[AsDecorator(decorates: BaseModifier::class, onInvalid: ContainerInterface::IGNORE_ON_INVALID_REFERENCE)] |
| 17 | +readonly class ReloadLockedResponseResponseModifier implements ResponseModificationInterface |
| 18 | +{ |
| 19 | + public function __construct( |
| 20 | + #[AutowireDecorated] |
| 21 | + private ?BaseModifier $inner, |
| 22 | + private SoapAsyncRequestHandler $requestHandler, |
| 23 | + ) { |
| 24 | + } |
| 25 | + |
| 26 | + public function modify(AsyncResponse $response): void |
| 27 | + { |
| 28 | + if ($response->WSRequest instanceof SoapWSRequest) { |
| 29 | + $response->addOnResponseReceivedCallback(new OnResponseReceivedCallback( |
| 30 | + function (ParsedResponse $parsedResponse) { |
| 31 | + if ( |
| 32 | + $parsedResponse->response |
| 33 | + || $parsedResponse->headers |
| 34 | + || $parsedResponse->mainAsyncResponse->WSResponse->getStatusCode() !== Response::HTTP_LOCKED |
| 35 | + ) { |
| 36 | + return; |
| 37 | + } |
| 38 | + $parsedResponse->mainAsyncResponse->WSResponse = $this->requestHandler->request($parsedResponse->mainAsyncResponse->WSRequest)->WSResponse; |
| 39 | + } |
| 40 | + )); |
| 41 | + |
| 42 | + return; |
| 43 | + } |
| 44 | + |
| 45 | + |
| 46 | + $this->inner->modify($response); |
| 47 | + } |
| 48 | + |
| 49 | + public function supports(AsyncResponse $response): bool |
| 50 | + { |
| 51 | + if (!$this->inner) { |
| 52 | + return false; // if original disabled - we assume lock mechanism is disabled as well |
| 53 | + } |
| 54 | + |
| 55 | + return $this->inner->supports($response); |
| 56 | + } |
| 57 | + |
| 58 | + public static function getPriority(): int |
| 59 | + { |
| 60 | + return BaseModifier::getPriority(); |
| 61 | + } |
| 62 | +} |
0 commit comments