CloudWatchLogsClient.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220
  1. <?php
  2. namespace Aws\CloudWatchLogs;
  3. use Aws\AwsClient;
  4. use Aws\CommandInterface;
  5. use Generator;
  6. /**
  7. * This client is used to interact with the **Amazon CloudWatch Logs** service.
  8. *
  9. * @method \Aws\Result associateKmsKey(array $args = [])
  10. * @method \GuzzleHttp\Promise\Promise associateKmsKeyAsync(array $args = [])
  11. * @method \Aws\Result cancelExportTask(array $args = [])
  12. * @method \GuzzleHttp\Promise\Promise cancelExportTaskAsync(array $args = [])
  13. * @method \Aws\Result createDelivery(array $args = [])
  14. * @method \GuzzleHttp\Promise\Promise createDeliveryAsync(array $args = [])
  15. * @method \Aws\Result createExportTask(array $args = [])
  16. * @method \GuzzleHttp\Promise\Promise createExportTaskAsync(array $args = [])
  17. * @method \Aws\Result createLogAnomalyDetector(array $args = [])
  18. * @method \GuzzleHttp\Promise\Promise createLogAnomalyDetectorAsync(array $args = [])
  19. * @method \Aws\Result createLogGroup(array $args = [])
  20. * @method \GuzzleHttp\Promise\Promise createLogGroupAsync(array $args = [])
  21. * @method \Aws\Result createLogStream(array $args = [])
  22. * @method \GuzzleHttp\Promise\Promise createLogStreamAsync(array $args = [])
  23. * @method \Aws\Result deleteAccountPolicy(array $args = [])
  24. * @method \GuzzleHttp\Promise\Promise deleteAccountPolicyAsync(array $args = [])
  25. * @method \Aws\Result deleteDataProtectionPolicy(array $args = [])
  26. * @method \GuzzleHttp\Promise\Promise deleteDataProtectionPolicyAsync(array $args = [])
  27. * @method \Aws\Result deleteDelivery(array $args = [])
  28. * @method \GuzzleHttp\Promise\Promise deleteDeliveryAsync(array $args = [])
  29. * @method \Aws\Result deleteDeliveryDestination(array $args = [])
  30. * @method \GuzzleHttp\Promise\Promise deleteDeliveryDestinationAsync(array $args = [])
  31. * @method \Aws\Result deleteDeliveryDestinationPolicy(array $args = [])
  32. * @method \GuzzleHttp\Promise\Promise deleteDeliveryDestinationPolicyAsync(array $args = [])
  33. * @method \Aws\Result deleteDeliverySource(array $args = [])
  34. * @method \GuzzleHttp\Promise\Promise deleteDeliverySourceAsync(array $args = [])
  35. * @method \Aws\Result deleteDestination(array $args = [])
  36. * @method \GuzzleHttp\Promise\Promise deleteDestinationAsync(array $args = [])
  37. * @method \Aws\Result deleteLogAnomalyDetector(array $args = [])
  38. * @method \GuzzleHttp\Promise\Promise deleteLogAnomalyDetectorAsync(array $args = [])
  39. * @method \Aws\Result deleteLogGroup(array $args = [])
  40. * @method \GuzzleHttp\Promise\Promise deleteLogGroupAsync(array $args = [])
  41. * @method \Aws\Result deleteLogStream(array $args = [])
  42. * @method \GuzzleHttp\Promise\Promise deleteLogStreamAsync(array $args = [])
  43. * @method \Aws\Result deleteMetricFilter(array $args = [])
  44. * @method \GuzzleHttp\Promise\Promise deleteMetricFilterAsync(array $args = [])
  45. * @method \Aws\Result deleteQueryDefinition(array $args = [])
  46. * @method \GuzzleHttp\Promise\Promise deleteQueryDefinitionAsync(array $args = [])
  47. * @method \Aws\Result deleteResourcePolicy(array $args = [])
  48. * @method \GuzzleHttp\Promise\Promise deleteResourcePolicyAsync(array $args = [])
  49. * @method \Aws\Result deleteRetentionPolicy(array $args = [])
  50. * @method \GuzzleHttp\Promise\Promise deleteRetentionPolicyAsync(array $args = [])
  51. * @method \Aws\Result deleteSubscriptionFilter(array $args = [])
  52. * @method \GuzzleHttp\Promise\Promise deleteSubscriptionFilterAsync(array $args = [])
  53. * @method \Aws\Result describeAccountPolicies(array $args = [])
  54. * @method \GuzzleHttp\Promise\Promise describeAccountPoliciesAsync(array $args = [])
  55. * @method \Aws\Result describeDeliveries(array $args = [])
  56. * @method \GuzzleHttp\Promise\Promise describeDeliveriesAsync(array $args = [])
  57. * @method \Aws\Result describeDeliveryDestinations(array $args = [])
  58. * @method \GuzzleHttp\Promise\Promise describeDeliveryDestinationsAsync(array $args = [])
  59. * @method \Aws\Result describeDeliverySources(array $args = [])
  60. * @method \GuzzleHttp\Promise\Promise describeDeliverySourcesAsync(array $args = [])
  61. * @method \Aws\Result describeDestinations(array $args = [])
  62. * @method \GuzzleHttp\Promise\Promise describeDestinationsAsync(array $args = [])
  63. * @method \Aws\Result describeExportTasks(array $args = [])
  64. * @method \GuzzleHttp\Promise\Promise describeExportTasksAsync(array $args = [])
  65. * @method \Aws\Result describeLogGroups(array $args = [])
  66. * @method \GuzzleHttp\Promise\Promise describeLogGroupsAsync(array $args = [])
  67. * @method \Aws\Result describeLogStreams(array $args = [])
  68. * @method \GuzzleHttp\Promise\Promise describeLogStreamsAsync(array $args = [])
  69. * @method \Aws\Result describeMetricFilters(array $args = [])
  70. * @method \GuzzleHttp\Promise\Promise describeMetricFiltersAsync(array $args = [])
  71. * @method \Aws\Result describeQueries(array $args = [])
  72. * @method \GuzzleHttp\Promise\Promise describeQueriesAsync(array $args = [])
  73. * @method \Aws\Result describeQueryDefinitions(array $args = [])
  74. * @method \GuzzleHttp\Promise\Promise describeQueryDefinitionsAsync(array $args = [])
  75. * @method \Aws\Result describeResourcePolicies(array $args = [])
  76. * @method \GuzzleHttp\Promise\Promise describeResourcePoliciesAsync(array $args = [])
  77. * @method \Aws\Result describeSubscriptionFilters(array $args = [])
  78. * @method \GuzzleHttp\Promise\Promise describeSubscriptionFiltersAsync(array $args = [])
  79. * @method \Aws\Result disassociateKmsKey(array $args = [])
  80. * @method \GuzzleHttp\Promise\Promise disassociateKmsKeyAsync(array $args = [])
  81. * @method \Aws\Result filterLogEvents(array $args = [])
  82. * @method \GuzzleHttp\Promise\Promise filterLogEventsAsync(array $args = [])
  83. * @method \Aws\Result getDataProtectionPolicy(array $args = [])
  84. * @method \GuzzleHttp\Promise\Promise getDataProtectionPolicyAsync(array $args = [])
  85. * @method \Aws\Result getDelivery(array $args = [])
  86. * @method \GuzzleHttp\Promise\Promise getDeliveryAsync(array $args = [])
  87. * @method \Aws\Result getDeliveryDestination(array $args = [])
  88. * @method \GuzzleHttp\Promise\Promise getDeliveryDestinationAsync(array $args = [])
  89. * @method \Aws\Result getDeliveryDestinationPolicy(array $args = [])
  90. * @method \GuzzleHttp\Promise\Promise getDeliveryDestinationPolicyAsync(array $args = [])
  91. * @method \Aws\Result getDeliverySource(array $args = [])
  92. * @method \GuzzleHttp\Promise\Promise getDeliverySourceAsync(array $args = [])
  93. * @method \Aws\Result getLogAnomalyDetector(array $args = [])
  94. * @method \GuzzleHttp\Promise\Promise getLogAnomalyDetectorAsync(array $args = [])
  95. * @method \Aws\Result getLogEvents(array $args = [])
  96. * @method \GuzzleHttp\Promise\Promise getLogEventsAsync(array $args = [])
  97. * @method \Aws\Result getLogGroupFields(array $args = [])
  98. * @method \GuzzleHttp\Promise\Promise getLogGroupFieldsAsync(array $args = [])
  99. * @method \Aws\Result getLogRecord(array $args = [])
  100. * @method \GuzzleHttp\Promise\Promise getLogRecordAsync(array $args = [])
  101. * @method \Aws\Result getQueryResults(array $args = [])
  102. * @method \GuzzleHttp\Promise\Promise getQueryResultsAsync(array $args = [])
  103. * @method \Aws\Result listAnomalies(array $args = [])
  104. * @method \GuzzleHttp\Promise\Promise listAnomaliesAsync(array $args = [])
  105. * @method \Aws\Result listLogAnomalyDetectors(array $args = [])
  106. * @method \GuzzleHttp\Promise\Promise listLogAnomalyDetectorsAsync(array $args = [])
  107. * @method \Aws\Result listTagsForResource(array $args = [])
  108. * @method \GuzzleHttp\Promise\Promise listTagsForResourceAsync(array $args = [])
  109. * @method \Aws\Result listTagsLogGroup(array $args = [])
  110. * @method \GuzzleHttp\Promise\Promise listTagsLogGroupAsync(array $args = [])
  111. * @method \Aws\Result putAccountPolicy(array $args = [])
  112. * @method \GuzzleHttp\Promise\Promise putAccountPolicyAsync(array $args = [])
  113. * @method \Aws\Result putDataProtectionPolicy(array $args = [])
  114. * @method \GuzzleHttp\Promise\Promise putDataProtectionPolicyAsync(array $args = [])
  115. * @method \Aws\Result putDeliveryDestination(array $args = [])
  116. * @method \GuzzleHttp\Promise\Promise putDeliveryDestinationAsync(array $args = [])
  117. * @method \Aws\Result putDeliveryDestinationPolicy(array $args = [])
  118. * @method \GuzzleHttp\Promise\Promise putDeliveryDestinationPolicyAsync(array $args = [])
  119. * @method \Aws\Result putDeliverySource(array $args = [])
  120. * @method \GuzzleHttp\Promise\Promise putDeliverySourceAsync(array $args = [])
  121. * @method \Aws\Result putDestination(array $args = [])
  122. * @method \GuzzleHttp\Promise\Promise putDestinationAsync(array $args = [])
  123. * @method \Aws\Result putDestinationPolicy(array $args = [])
  124. * @method \GuzzleHttp\Promise\Promise putDestinationPolicyAsync(array $args = [])
  125. * @method \Aws\Result putLogEvents(array $args = [])
  126. * @method \GuzzleHttp\Promise\Promise putLogEventsAsync(array $args = [])
  127. * @method \Aws\Result putMetricFilter(array $args = [])
  128. * @method \GuzzleHttp\Promise\Promise putMetricFilterAsync(array $args = [])
  129. * @method \Aws\Result putQueryDefinition(array $args = [])
  130. * @method \GuzzleHttp\Promise\Promise putQueryDefinitionAsync(array $args = [])
  131. * @method \Aws\Result putResourcePolicy(array $args = [])
  132. * @method \GuzzleHttp\Promise\Promise putResourcePolicyAsync(array $args = [])
  133. * @method \Aws\Result putRetentionPolicy(array $args = [])
  134. * @method \GuzzleHttp\Promise\Promise putRetentionPolicyAsync(array $args = [])
  135. * @method \Aws\Result putSubscriptionFilter(array $args = [])
  136. * @method \GuzzleHttp\Promise\Promise putSubscriptionFilterAsync(array $args = [])
  137. * @method \Aws\Result startLiveTail(array $args = [])
  138. * @method \GuzzleHttp\Promise\Promise startLiveTailAsync(array $args = [])
  139. * @method \Aws\Result startQuery(array $args = [])
  140. * @method \GuzzleHttp\Promise\Promise startQueryAsync(array $args = [])
  141. * @method \Aws\Result stopQuery(array $args = [])
  142. * @method \GuzzleHttp\Promise\Promise stopQueryAsync(array $args = [])
  143. * @method \Aws\Result tagLogGroup(array $args = [])
  144. * @method \GuzzleHttp\Promise\Promise tagLogGroupAsync(array $args = [])
  145. * @method \Aws\Result tagResource(array $args = [])
  146. * @method \GuzzleHttp\Promise\Promise tagResourceAsync(array $args = [])
  147. * @method \Aws\Result testMetricFilter(array $args = [])
  148. * @method \GuzzleHttp\Promise\Promise testMetricFilterAsync(array $args = [])
  149. * @method \Aws\Result untagLogGroup(array $args = [])
  150. * @method \GuzzleHttp\Promise\Promise untagLogGroupAsync(array $args = [])
  151. * @method \Aws\Result untagResource(array $args = [])
  152. * @method \GuzzleHttp\Promise\Promise untagResourceAsync(array $args = [])
  153. * @method \Aws\Result updateAnomaly(array $args = [])
  154. * @method \GuzzleHttp\Promise\Promise updateAnomalyAsync(array $args = [])
  155. * @method \Aws\Result updateLogAnomalyDetector(array $args = [])
  156. * @method \GuzzleHttp\Promise\Promise updateLogAnomalyDetectorAsync(array $args = [])
  157. */
  158. class CloudWatchLogsClient extends AwsClient {
  159. static $streamingCommands = [
  160. 'StartLiveTail' => true
  161. ];
  162. public function __construct(array $args)
  163. {
  164. parent::__construct($args);
  165. $this->addStreamingFlagMiddleware();
  166. }
  167. private function addStreamingFlagMiddleware()
  168. {
  169. $this->getHandlerList()
  170. -> appendInit(
  171. $this->getStreamingFlagMiddleware(),
  172. 'streaming-flag-middleware'
  173. );
  174. }
  175. private function getStreamingFlagMiddleware(): callable
  176. {
  177. return function (callable $handler) {
  178. return function (CommandInterface $command, $request = null) use ($handler) {
  179. if (!empty(self::$streamingCommands[$command->getName()])) {
  180. $command['@http']['stream'] = true;
  181. }
  182. return $handler($command, $request);
  183. };
  184. };
  185. }
  186. /**
  187. * Helper method for 'startLiveTail' operation that checks for results.
  188. *
  189. * Initiates 'startLiveTail' operation with given arguments, and continuously
  190. * checks response stream for session updates or results, yielding each
  191. * stream chunk when results are not empty. This method abstracts from users
  192. * the need of checking if there are logs entry available to be watched, which means
  193. * that users will always get a next item to be iterated when more log entries are
  194. * available.
  195. *
  196. * @param array $args Command arguments.
  197. *
  198. * @return Generator Yields session update or result stream chunks.
  199. */
  200. public function startLiveTailCheckingForResults(array $args): Generator
  201. {
  202. $response = $this->startLiveTail($args);
  203. foreach ($response['responseStream'] as $streamChunk) {
  204. if (isset($streamChunk['sessionUpdate'])) {
  205. if (!empty($streamChunk['sessionUpdate']['sessionResults'])) {
  206. yield $streamChunk;
  207. }
  208. } else {
  209. yield $streamChunk;
  210. }
  211. }
  212. }
  213. }