mirror of
https://github.com/SociallyDev/Spaces-API.git
synced 2025-07-14 17:13:01 -07:00
* Simplifies & beautifies everything * Introduces a new Class system. * Errors are defaulted to AWS's handler. * New function names & more efficient handling. * Should fix a majority of the errors. Please read the README for more!
126 lines
3.5 KiB
PHP
126 lines
3.5 KiB
PHP
<?php
|
|
namespace Aws\S3Control;
|
|
|
|
use Aws\CommandInterface;
|
|
use Psr\Http\Message\RequestInterface;
|
|
|
|
/**
|
|
* Used to update the URL used for S3 Control requests to support S3 Control
|
|
* DualStack. It will build to host style paths, including for S3 Control
|
|
* DualStack.
|
|
*
|
|
* IMPORTANT: this middleware must be added after the "build" step.
|
|
*
|
|
* @internal
|
|
*/
|
|
class S3ControlEndpointMiddleware
|
|
{
|
|
const NO_PATTERN = 0;
|
|
const DUALSTACK = 1;
|
|
|
|
/** @var bool */
|
|
private $dualStackByDefault;
|
|
/** @var string */
|
|
private $region;
|
|
/** @var callable */
|
|
private $nextHandler;
|
|
|
|
/**
|
|
* Create a middleware wrapper function
|
|
*
|
|
* @param string $region
|
|
* @param array $options
|
|
*
|
|
* @return callable
|
|
*/
|
|
public static function wrap($region, array $options)
|
|
{
|
|
return function (callable $handler) use ($region, $options) {
|
|
return new self($handler, $region, $options);
|
|
};
|
|
}
|
|
|
|
public function __construct(
|
|
callable $nextHandler,
|
|
$region,
|
|
array $options
|
|
) {
|
|
$this->dualStackByDefault = isset($options['dual_stack'])
|
|
? (bool) $options['dual_stack'] : false;
|
|
$this->region = (string) $region;
|
|
$this->nextHandler = $nextHandler;
|
|
}
|
|
|
|
public function __invoke(CommandInterface $command, RequestInterface $request)
|
|
{
|
|
if ($this->isDualStackRequest($command, $request)) {
|
|
$request = $this->applyDualStackEndpoint($command, $request);
|
|
}
|
|
$request = $this->applyHostStyleEndpoint($command, $request)
|
|
->withoutHeader('x-amz-account-id');
|
|
unset($command['AccountId']);
|
|
|
|
$nextHandler = $this->nextHandler;
|
|
return $nextHandler($command, $request);
|
|
}
|
|
|
|
private function isDualStackRequest(
|
|
CommandInterface $command,
|
|
RequestInterface $request
|
|
) {
|
|
return isset($command['@use_dual_stack_endpoint'])
|
|
? $command['@use_dual_stack_endpoint'] : $this->dualStackByDefault;
|
|
}
|
|
|
|
private function getDualStackHost($host)
|
|
{
|
|
$parts = explode(".{$this->region}.", $host);
|
|
return $parts[0] . ".dualstack.{$this->region}." . $parts[1];
|
|
}
|
|
|
|
private function applyDualStackEndpoint(
|
|
CommandInterface $command,
|
|
RequestInterface $request
|
|
) {
|
|
$uri = $request->getUri();
|
|
return $request->withUri(
|
|
$uri->withHost($this->getDualStackHost(
|
|
$uri->getHost()
|
|
))
|
|
);
|
|
}
|
|
|
|
private function getAccountIdStyleHost(CommandInterface $command, $host)
|
|
{
|
|
if (!\Aws\is_valid_hostname($command['AccountId'])) {
|
|
throw new \InvalidArgumentException(
|
|
"The supplied parameters result in an invalid hostname: '{$command['AccountId']}.{$host}'."
|
|
);
|
|
}
|
|
return "{$command['AccountId']}.{$host}";
|
|
}
|
|
|
|
private function getAccountIdlessPath($path, CommandInterface $command)
|
|
{
|
|
$pattern = '/^\\/' . preg_quote($command['AccountId'], '/') . '/';
|
|
return preg_replace($pattern, '', $path) ?: '/';
|
|
}
|
|
|
|
private function applyHostStyleEndpoint(
|
|
CommandInterface $command,
|
|
RequestInterface $request
|
|
) {
|
|
$uri = $request->getUri();
|
|
$request = $request->withUri(
|
|
$uri->withHost($this->getAccountIdStyleHost(
|
|
$command,
|
|
$uri->getHost()
|
|
))
|
|
->withPath($this->getAccountIdlessPath(
|
|
$uri->getPath(),
|
|
$command
|
|
))
|
|
);
|
|
return $request;
|
|
}
|
|
}
|