123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 |
- <?php
- namespace Aws\Auth;
- use Aws\Api\Service;
- use Aws\CommandInterface;
- use Closure;
- use GuzzleHttp\Promise\Promise;
- /**
- * Handles auth scheme resolution. If a service models and auth scheme using
- * the `auth` trait and the operation or metadata levels, this middleware will
- * attempt to select the first compatible auth scheme it encounters and apply its
- * signature version to the command's `@context` property bag.
- *
- * IMPORTANT: this middleware must be added to the "build" step.
- *
- * @internal
- */
- class AuthSelectionMiddleware
- {
- /** @var callable */
- private $nextHandler;
- /** @var AuthSchemeResolverInterface */
- private $authResolver;
- /** @var Service */
- private $api;
- /**
- * Create a middleware wrapper function
- *
- * @param AuthSchemeResolverInterface $authResolver
- * @param Service $api
- * @return Closure
- */
- public static function wrap(
- AuthSchemeResolverInterface $authResolver,
- Service $api
- ): Closure
- {
- return function (callable $handler) use ($authResolver, $api) {
- return new self($handler, $authResolver, $api);
- };
- }
- /**
- * @param callable $nextHandler
- * @param $authResolver
- * @param callable $identityProvider
- * @param Service $api
- */
- public function __construct(
- callable $nextHandler,
- AuthSchemeResolverInterface $authResolver,
- Service $api
- )
- {
- $this->nextHandler = $nextHandler;
- $this->authResolver = $authResolver;
- $this->api = $api;
- }
- /**
- * @param CommandInterface $command
- *
- * @return Promise
- */
- public function __invoke(CommandInterface $command)
- {
- $nextHandler = $this->nextHandler;
- $serviceAuth = $this->api->getMetadata('auth') ?: [];
- $operation = $this->api->getOperation($command->getName());
- $operationAuth = $operation['auth'] ?? [];
- $unsignedPayload = $operation['unsignedpayload'] ?? false;
- $resolvableAuth = $operationAuth ?: $serviceAuth;
- if (!empty($resolvableAuth)) {
- if (isset($command['@context']['auth_scheme_resolver'])
- && $command['@context']['auth_scheme_resolver'] instanceof AuthSchemeResolverInterface
- ){
- $resolver = $command['@context']['auth_scheme_resolver'];
- } else {
- $resolver = $this->authResolver;
- }
- $selectedAuthScheme = $resolver->selectAuthScheme(
- $resolvableAuth,
- ['unsigned_payload' => $unsignedPayload]
- );
- if (!empty($selectedAuthScheme)) {
- $command['@context']['signature_version'] = $selectedAuthScheme;
- }
- }
- return $nextHandler($command);
- }
- }
|