123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117 |
- <?php
- namespace Enqueue\Stomp;
- use Stomp\Client;
- use Stomp\Transport\Frame;
- class BufferedStompClient extends Client
- {
-
- private $buffer;
-
- private $bufferSize;
-
- private $currentBufferSize;
-
- public function __construct($broker, $bufferSize = 1000)
- {
- parent::__construct($broker);
- $this->bufferSize = $bufferSize;
- $this->buffer = [];
- $this->currentBufferSize = 0;
- }
-
- public function getBufferSize()
- {
- return $this->bufferSize;
- }
-
- public function readMessageFrame(string $subscriptionId, int $timeout): ?Frame
- {
-
- if (isset($this->buffer[$subscriptionId]) && ($frame = array_shift($this->buffer[$subscriptionId]))) {
- --$this->currentBufferSize;
- return $frame;
- }
-
- if ($this->currentBufferSize >= $this->bufferSize) {
- return null;
- }
- $startTime = microtime(true);
- $remainingTimeout = $timeout * 1000;
- while (true) {
- $this->getConnection()->setReadTimeout(0, $remainingTimeout);
-
- if (false === $frame = $this->readFrame()) {
- return null;
- }
- if ('MESSAGE' !== $frame->getCommand()) {
- throw new \LogicException(sprintf('Unexpected frame was received: "%s"', $frame->getCommand()));
- }
- $headers = $frame->getHeaders();
- if (false == isset($headers['subscription'])) {
- throw new \LogicException('Got message frame with missing subscription header');
- }
-
- if ($headers['subscription'] !== $subscriptionId) {
- $this->buffer[$headers['subscription']][] = $frame;
- ++$this->currentBufferSize;
- $remainingTimeout -= (microtime(true) - $startTime) * 1000000;
- if ($remainingTimeout <= 0) {
- return null;
- }
- continue;
- }
- return $frame;
- }
- }
-
- public function disconnect($sync = false)
- {
- parent::disconnect($sync);
- $this->buffer = [];
- $this->currentBufferSize = 0;
- }
- }
|