mirror of
https://github.com/SociallyDev/Spaces-API.git
synced 2025-08-20 13:23:47 -07:00
spaces.php
This commit is contained in:
parent
7755490b81
commit
eefa32741e
845 changed files with 50409 additions and 0 deletions
42
aws/Aws/S3/GetBucketLocationParser.php
Normal file
42
aws/Aws/S3/GetBucketLocationParser.php
Normal file
|
@ -0,0 +1,42 @@
|
|||
<?php
|
||||
namespace Aws\S3;
|
||||
|
||||
use Aws\Api\Parser\AbstractParser;
|
||||
use Aws\CommandInterface;
|
||||
use Psr\Http\Message\ResponseInterface;
|
||||
|
||||
/**
|
||||
* @internal Decorates a parser for the S3 service to correctly handle the
|
||||
* GetBucketLocation operation.
|
||||
*/
|
||||
class GetBucketLocationParser extends AbstractParser
|
||||
{
|
||||
/** @var callable */
|
||||
private $parser;
|
||||
|
||||
/**
|
||||
* @param callable $parser Parser to wrap.
|
||||
*/
|
||||
public function __construct(callable $parser)
|
||||
{
|
||||
$this->parser = $parser;
|
||||
}
|
||||
|
||||
public function __invoke(
|
||||
CommandInterface $command,
|
||||
ResponseInterface $response
|
||||
) {
|
||||
$fn = $this->parser;
|
||||
$result = $fn($command, $response);
|
||||
|
||||
if ($command->getName() === 'GetBucketLocation') {
|
||||
$location = 'us-east-1';
|
||||
if (preg_match('/>(.+?)<\/LocationConstraint>/', $response->getBody(), $matches)) {
|
||||
$location = $matches[1] === 'EU' ? 'eu-west-1' : $matches[1];
|
||||
}
|
||||
$result['LocationConstraint'] = $location;
|
||||
}
|
||||
|
||||
return $result;
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue