/**
  * Format event data into something human-readable
  *
  * @param $events
  *
  * @return array
  */
 private function format_events($events)
 {
     $formatted_events = array();
     foreach ($events as $event) {
         $event_data = \Automattic\WP\Cron_Control\Events::instance()->get_event($event['timestamp'], $event['action'], $event['instance']);
         $formatted_events[] = array('timestamp' => $event_data['timestamp'], 'action' => $event_data['action'], 'instance' => $event_data['instance'], 'scheduled_for' => date(TIME_FORMAT, $event_data['timestamp']), 'internal_event' => \Automattic\WP\Cron_Control\is_internal_event($event_data['action']) ? __('true', 'automattic-cron-control') : '', 'schedule_name' => false === $event_data['schedule'] ? __('n/a', 'automattic-cron-control') : $event_data['schedule'], 'event_args' => maybe_serialize($event_data['args']));
     }
     return $formatted_events;
 }
 /**
  * Internal events should be scheduled
  */
 function test_events()
 {
     \Automattic\WP\Cron_Control\Internal_Events::instance()->schedule_internal_events();
     $events = \Automattic\WP\Cron_Control\collapse_events_array(get_option('cron'));
     // Check that the plugin scheduled the expected number of events
     $this->assertEquals(count($events), 4);
     // Confirm that the scheduled jobs came from the Internal Events class
     foreach ($events as $event) {
         $this->assertTrue(\Automattic\WP\Cron_Control\is_internal_event($event['action']));
     }
 }
 /**
  * Delete all events of the same action
  */
 private function delete_event_by_action($args, $assoc_args)
 {
     $action = $assoc_args['action'];
     // Validate entry
     if (empty($action)) {
         \WP_CLI::error(__('Invalid action', 'automattic-cron-control'));
     }
     // Warning about Internal Events
     if (\Automattic\WP\Cron_Control\is_internal_event($action)) {
         \WP_CLI::warning(__('This is an event created by the Cron Control plugin. It will recreated automatically.', 'automattic-cron-control'));
     }
     // Set defaults needed to gather all events
     $assoc_args['page'] = 1;
     $assoc_args['limit'] = 50;
     // Gather events
     \WP_CLI::line(__('Gathering events...', 'automattic-cron-control'));
     $events_to_delete = array();
     $events = $this->get_events($args, $assoc_args);
     \WP_CLI::line(sprintf(_n('Found one event to check', 'Found %s events to check', $events['total_items'], 'automattic-cron-control'), number_format_i18n($events['total_items'])));
     $search_progress = \WP_CLI\Utils\make_progress_bar(sprintf(__('Searching events for those with the action `%s`', 'automattic-cron-control'), $action), $events['total_items']);
     // Loop and pull out events to be deleted
     do {
         if (!is_array($events) || empty($events['items'])) {
             break;
         }
         // Check events for those that should be deleted
         foreach ($events['items'] as $single_event) {
             $event_details = $this->get_event_details_from_post_title($single_event->post_title);
             if ($event_details['action'] === $action) {
                 $events_to_delete[] = array_merge($event_details, array('ID' => (int) $single_event->ID, 'post_date_gmt' => $single_event->post_date_gmt, 'post_modified_gmt' => $single_event->post_modified_gmt));
             }
             $search_progress->tick();
         }
         // Proceed to next batch
         $assoc_args['page']++;
         if ($assoc_args['page'] > $events['total_pages']) {
             break;
         }
         $events = $this->get_events($args, $assoc_args);
     } while ($events['page'] <= $events['total_pages']);
     $search_progress->finish();
     \WP_CLI::line('');
     // Nothing more to do
     if (empty($events_to_delete)) {
         \WP_CLI::error(sprintf(__('No events with action `%s` found', 'automattic-cron-control'), $action));
     }
     // List the items to remove
     $total_to_delete = count($events_to_delete);
     \WP_CLI::line(sprintf(_n('Found one event with action `%2$s`:', 'Found %1$s events with action `%2$s`:', $total_to_delete, 'automattic-cron-control'), number_format_i18n($total_to_delete), $action));
     if ($total_to_delete <= $assoc_args['limit']) {
         \WP_CLI\Utils\format_items('table', $events_to_delete, array('ID', 'post_date_gmt', 'post_modified_gmt', 'timestamp', 'instance'));
     } else {
         \WP_CLI::warning(sprintf(__('Events are not displayed as there are more than %s to remove', 'automattic-cron-control'), number_format_i18n($assoc_args['limit'])));
     }
     \WP_CLI::line('');
     \WP_CLI::confirm(_n('Are you sure you want to delete this event?', 'Are you sure you want to delete these events?', $total_to_delete, 'automattic-cron-control'));
     // Remove the items
     $delete_progress = \WP_CLI\Utils\make_progress_bar(__('Deleting events', 'automattic-cron-control'), $total_to_delete);
     $events_deleted = array();
     $events_deleted_count = $events_failed_delete = 0;
     foreach ($events_to_delete as $event_to_delete) {
         $deleted = wp_delete_post($event_to_delete['ID'], true);
         $events_deleted[] = array('ID' => $event_to_delete['ID'], 'deleted' => false === $deleted ? 'no' : 'yes');
         if ($deleted) {
             $events_deleted_count++;
         } else {
             $events_failed_delete++;
         }
         $delete_progress->tick();
     }
     $delete_progress->finish();
     // When deletes succeed, sync internal caches
     if ($events_deleted_count > 0) {
         \Automattic\WP\Cron_Control\_flush_internal_caches();
     }
     // List the removed items
     \WP_CLI::line("\n" . __('RESULTS:', 'automattic-cron-control'));
     if (1 === $total_to_delete && 1 === $events_deleted_count) {
         \WP_CLI::success(sprintf(__('Deleted one event: %d', 'automattic-cron-control'), $events_deleted[0]['ID']));
     } else {
         if ($events_deleted_count === $total_to_delete) {
             \WP_CLI::success(sprintf(__('Deleted %s events', 'automattic-cron-control'), number_format_i18n($events_deleted_count)));
         } else {
             \WP_CLI::warning(sprintf(__('Expected to delete %1$s events, but could only delete %2$s events. It\'s likely that some events were executed while this command ran.', 'automattic-cron-control'), number_format_i18n($total_to_delete), number_format_i18n($events_deleted_count)));
         }
         // Limit just to failed deletes when many events are removed
         if (count($events_deleted) > $assoc_args['limit']) {
             $events_deleted_unfiltered = $events_deleted;
             $events_deleted = array_filter($events_deleted, function ($event) {
                 if ('no' === $event['deleted']) {
                     return $event;
                 } else {
                     return false;
                 }
             });
             if (count($events_deleted) > 0) {
                 \WP_CLI::line("\n" . __('Events that couldn\'t be deleted:', 'automattic-cron-control'));
             }
         } else {
             \WP_CLI::line("\n" . __('Events deleted:', 'automattic-cron-control'));
         }
         // Don't display a table if there's nothing to display
         if (count($events_deleted) > 0) {
             \WP_CLI\Utils\format_items('table', $events_deleted, array('ID', 'deleted'));
         }
     }
     return;
 }