Blame view

sources/apps/files_external/3rdparty/aws-sdk-php/Guzzle/Batch/BatchCommandTransfer.php 2.17 KB
31b7f2792   Kload   Upgrade to ownclo...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
  <?php
  
  namespace Guzzle\Batch;
  
  use Guzzle\Batch\BatchTransferInterface;
  use Guzzle\Batch\BatchDivisorInterface;
  use Guzzle\Common\Exception\InvalidArgumentException;
  use Guzzle\Service\Command\CommandInterface;
  use Guzzle\Service\Exception\InconsistentClientTransferException;
  
  /**
   * Efficiently transfers multiple commands in parallel per client
   * This class is to be used with {@see Guzzle\Batch\BatchInterface}
   */
  class BatchCommandTransfer implements BatchTransferInterface, BatchDivisorInterface
  {
      /** @var int Size of each command batch */
      protected $batchSize;
  
      /**
       * @param int $batchSize Size of each batch
       */
      public function __construct($batchSize = 50)
      {
          $this->batchSize = $batchSize;
      }
  
      /**
       * Creates batches by grouping commands by their associated client
       * {@inheritdoc}
       */
      public function createBatches(\SplQueue $queue)
      {
          $groups = new \SplObjectStorage();
          foreach ($queue as $item) {
              if (!$item instanceof CommandInterface) {
                  throw new InvalidArgumentException('All items must implement Guzzle\Service\Command\CommandInterface');
              }
              $client = $item->getClient();
              if (!$groups->contains($client)) {
                  $groups->attach($client, new \ArrayObject(array($item)));
              } else {
                  $groups[$client]->append($item);
              }
          }
  
          $batches = array();
          foreach ($groups as $batch) {
              $batches = array_merge($batches, array_chunk($groups[$batch]->getArrayCopy(), $this->batchSize));
          }
  
          return $batches;
      }
  
      public function transfer(array $batch)
      {
          if (empty($batch)) {
              return;
          }
  
          // Get the client of the first found command
          $client = reset($batch)->getClient();
  
          // Keep a list of all commands with invalid clients
          $invalid = array_filter($batch, function ($command) use ($client) {
              return $command->getClient() !== $client;
          });
  
          if (!empty($invalid)) {
              throw new InconsistentClientTransferException($invalid);
          }
  
          $client->execute($batch);
      }
  }