123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161 |
- <?php
- namespace Aws;
- use Psr\Http\Message\RequestInterface;
- use Aws\Exception\AwsException;
- /**
- * Represents a history container that is required when using the history
- * middleware.
- */
- class History implements \Countable, \IteratorAggregate
- {
- private $maxEntries;
- private $entries = array();
- /**
- * @param int $maxEntries Maximum number of entries to store.
- */
- public function __construct($maxEntries = 10)
- {
- $this->maxEntries = $maxEntries;
- }
- /**
- * @return int
- */
- #[\ReturnTypeWillChange]
- public function count()
- {
- return count($this->entries);
- }
- #[\ReturnTypeWillChange]
- public function getIterator()
- {
- return new \ArrayIterator(array_values($this->entries));
- }
- /**
- * Get the last finished command seen by the history container.
- *
- * @return CommandInterface
- * @throws \LogicException if no commands have been seen.
- */
- public function getLastCommand()
- {
- if (!$this->entries) {
- throw new \LogicException('No commands received');
- }
- return end($this->entries)['command'];
- }
- /**
- * Get the last finished request seen by the history container.
- *
- * @return RequestInterface
- * @throws \LogicException if no requests have been seen.
- */
- public function getLastRequest()
- {
- if (!$this->entries) {
- throw new \LogicException('No requests received');
- }
- return end($this->entries)['request'];
- }
- /**
- * Get the last received result or exception.
- *
- * @return ResultInterface|AwsException
- * @throws \LogicException if no return values have been received.
- */
- public function getLastReturn()
- {
- if (!$this->entries) {
- throw new \LogicException('No entries');
- }
- $last = end($this->entries);
- if (isset($last['result'])) {
- return $last['result'];
- }
- if (isset($last['exception'])) {
- return $last['exception'];
- }
- throw new \LogicException('No return value for last entry.');
- }
- /**
- * Initiate an entry being added to the history.
- *
- * @param CommandInterface $cmd Command be executed.
- * @param RequestInterface $req Request being sent.
- *
- * @return string Returns the ticket used to finish the entry.
- */
- public function start(CommandInterface $cmd, RequestInterface $req)
- {
- $ticket = uniqid();
- $this->entries[$ticket] = [
- 'command' => $cmd,
- 'request' => $req,
- 'result' => null,
- 'exception' => null,
- ];
- return $ticket;
- }
- /**
- * Finish adding an entry to the history container.
- *
- * @param string $ticket Ticket returned from the start call.
- * @param mixed $result The result (an exception or AwsResult).
- */
- public function finish($ticket, $result)
- {
- if (!isset($this->entries[$ticket])) {
- throw new \InvalidArgumentException('Invalid history ticket');
- }
- if (isset($this->entries[$ticket]['result'])
- || isset($this->entries[$ticket]['exception'])
- ) {
- throw new \LogicException('History entry is already finished');
- }
- if ($result instanceof \Exception) {
- $this->entries[$ticket]['exception'] = $result;
- } else {
- $this->entries[$ticket]['result'] = $result;
- }
- if (count($this->entries) >= $this->maxEntries) {
- $this->entries = array_slice($this->entries, -$this->maxEntries, null, true);
- }
- }
- /**
- * Flush the history
- */
- public function clear()
- {
- $this->entries = [];
- }
- /**
- * Converts the history to an array.
- *
- * @return array
- */
- public function toArray()
- {
- return array_values($this->entries);
- }
- }
|