123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176 |
- <?php
- namespace Aws\ClientSideMonitoring;
- use Aws\CommandInterface;
- use Aws\Exception\AwsException;
- use Aws\MonitoringEventsInterface;
- use Aws\ResultInterface;
- use Psr\Http\Message\RequestInterface;
- /**
- * @internal
- */
- class ApiCallMonitoringMiddleware extends AbstractMonitoringMiddleware
- {
- /**
- * Api Call Attempt event keys for each Api Call event key
- *
- * @var array
- */
- private static $eventKeys = [
- 'FinalAwsException' => 'AwsException',
- 'FinalAwsExceptionMessage' => 'AwsExceptionMessage',
- 'FinalSdkException' => 'SdkException',
- 'FinalSdkExceptionMessage' => 'SdkExceptionMessage',
- 'FinalHttpStatusCode' => 'HttpStatusCode',
- ];
- /**
- * Standard middleware wrapper function with CSM options passed in.
- *
- * @param callable $credentialProvider
- * @param mixed $options
- * @param string $region
- * @param string $service
- * @return callable
- */
- public static function wrap(
- callable $credentialProvider,
- $options,
- $region,
- $service
- ) {
- return function (callable $handler) use (
- $credentialProvider,
- $options,
- $region,
- $service
- ) {
- return new static(
- $handler,
- $credentialProvider,
- $options,
- $region,
- $service
- );
- };
- }
- /**
- * {@inheritdoc}
- */
- public static function getRequestData(RequestInterface $request)
- {
- return [];
- }
- /**
- * {@inheritdoc}
- */
- public static function getResponseData($klass)
- {
- if ($klass instanceof ResultInterface) {
- $data = [
- 'AttemptCount' => self::getResultAttemptCount($klass),
- 'MaxRetriesExceeded' => 0,
- ];
- } elseif ($klass instanceof \Exception) {
- $data = [
- 'AttemptCount' => self::getExceptionAttemptCount($klass),
- 'MaxRetriesExceeded' => self::getMaxRetriesExceeded($klass),
- ];
- } else {
- throw new \InvalidArgumentException('Parameter must be an instance of ResultInterface or Exception.');
- }
- return $data + self::getFinalAttemptData($klass);
- }
- private static function getResultAttemptCount(ResultInterface $result) {
- if (isset($result['@metadata']['transferStats']['http'])) {
- return count($result['@metadata']['transferStats']['http']);
- }
- return 1;
- }
- private static function getExceptionAttemptCount(\Exception $e) {
- $attemptCount = 0;
- if ($e instanceof MonitoringEventsInterface) {
- foreach ($e->getMonitoringEvents() as $event) {
- if (isset($event['Type']) &&
- $event['Type'] === 'ApiCallAttempt') {
- $attemptCount++;
- }
- }
- }
- return $attemptCount;
- }
- private static function getFinalAttemptData($klass)
- {
- $data = [];
- if ($klass instanceof MonitoringEventsInterface) {
- $finalAttempt = self::getFinalAttempt($klass->getMonitoringEvents());
- if (!empty($finalAttempt)) {
- foreach (self::$eventKeys as $callKey => $attemptKey) {
- if (isset($finalAttempt[$attemptKey])) {
- $data[$callKey] = $finalAttempt[$attemptKey];
- }
- }
- }
- }
- return $data;
- }
- private static function getFinalAttempt(array $events)
- {
- for (end($events); key($events) !== null; prev($events)) {
- $current = current($events);
- if (isset($current['Type'])
- && $current['Type'] === 'ApiCallAttempt'
- ) {
- return $current;
- }
- }
- return null;
- }
- private static function getMaxRetriesExceeded($klass)
- {
- if ($klass instanceof AwsException && $klass->isMaxRetriesExceeded()) {
- return 1;
- }
- return 0;
- }
- /**
- * {@inheritdoc}
- */
- protected function populateRequestEventData(
- CommandInterface $cmd,
- RequestInterface $request,
- array $event
- ) {
- $event = parent::populateRequestEventData($cmd, $request, $event);
- $event['Type'] = 'ApiCall';
- return $event;
- }
- /**
- * {@inheritdoc}
- */
- protected function populateResultEventData(
- $result,
- array $event
- ) {
- $event = parent::populateResultEventData($result, $event);
- $event['Latency'] = (int) (floor(microtime(true) * 1000) - $event['Timestamp']);
- return $event;
- }
- }
|