From c12c714557b67de0e6b2e06603fd6d1050f528e9 Mon Sep 17 00:00:00 2001 From: Abdullah Almsaeed Date: Fri, 8 Dec 2017 08:16:14 -0500 Subject: [PATCH] Uninstall db tables when running pm-uninstall --- includes/Elasticsearch/ESQueue.php | 12 ++++++------ includes/indices_management.form.inc | 6 +++++- tripal_elasticsearch.install | 20 ++++++++++++++++++++ tripal_elasticsearch.module | 1 + 4 files changed, 32 insertions(+), 7 deletions(-) diff --git a/includes/Elasticsearch/ESQueue.php b/includes/Elasticsearch/ESQueue.php index db3a0332..81a2eca4 100644 --- a/includes/Elasticsearch/ESQueue.php +++ b/includes/Elasticsearch/ESQueue.php @@ -62,7 +62,7 @@ public static function progress() { MIN(started_at) AS started_at FROM {' . self::QUEUE_TABLE . '} GROUP BY index_name, priority - ORDER BY index_name ASC'; + ORDER BY index_name ASC, priority ASC'; $queues = db_query($query)->fetchAll(); $progress = []; @@ -72,9 +72,9 @@ public static function progress() { $progress_started_at = time(); foreach ($queues as $queue) { - if ($queue->total === $queue->completed) { - continue; - } +// if ($queue->total === $queue->completed) { +// continue; +// } $last_run = new DateTime(); $last_run->setTimestamp($queue->last_run_at); @@ -87,7 +87,7 @@ public static function progress() { $total += $queue->total; $completed += $queue->completed; - $round_name = ' Round: ' . ($queue->priority === 1 ? 'High' : 'Low'); + $round_name = ' Round: ' . (intval($queue->priority) === 1 ? 'High' : 'Low'); $progress[$queue->index_name . $round_name] = (object) [ 'total' => $queue->total, 'completed' => $queue->completed, @@ -96,6 +96,7 @@ public static function progress() { 'last_run_at' => $last_run, 'started_at' => $started_at, 'time' => $queue->last_run_at - $queue->started_at, + 'priority' => $queue->priority ]; } @@ -180,7 +181,6 @@ public static function initProgress( if ($queue) { return db_query('UPDATE {' . $counter_table . '} SET total=:total, last_run_at=:time, completed=:completed, started_at=:started_at WHERE type=:type', [ ':type' => $type, - ':index_name' => $index_name, ':total' => $total, ':completed' => 0, ':time' => time(), diff --git a/includes/indices_management.form.inc b/includes/indices_management.form.inc index 0373fad9..a8d6cbe7 100644 --- a/includes/indices_management.form.inc +++ b/includes/indices_management.form.inc @@ -901,6 +901,10 @@ function tripal_elasticsearch_progress_page($callback = FALSE) { $data = ESQueue::progress(); + if(!$callback) { + dpm($data); + } + $content .= '

Overall Progress

'; if ($data->remaining === 0) { @@ -954,7 +958,7 @@ function tripal_elasticsearch_update_index_table(&$values) { $index_name = $values['index_name']; $index_table = $values['table_name']; $exposed = $values['exposed'] ? 1 : 0; - $url = $values['url']; + $url = isset($values['url']) ? $values['url'] : ''; try { db_update('tripal_elasticsearch_indices')->fields([ diff --git a/tripal_elasticsearch.install b/tripal_elasticsearch.install index 1e4f00db..4f5212b8 100644 --- a/tripal_elasticsearch.install +++ b/tripal_elasticsearch.install @@ -125,6 +125,26 @@ function tripal_elasticsearch_schema() { return $schema; } +/** + * Uninstall + */ +function tripal_elasticsearch_uninstall() { + // Get the schema + $schema = tripal_elasticsearch_schema(); + + // Auto drop anything in the schema + foreach ($schema as $table => $fields) { + if(db_table_exists($table)) { + db_drop_table($table); + } + } + + // Drop tables that are created in the update functions + if(db_table_exists('tripal_elasticsearch_indices')) { + db_drop_table('tripal_elasticsearch_indices'); + } +} + /** * Run updates on install */ diff --git a/tripal_elasticsearch.module b/tripal_elasticsearch.module index 27e7c418..2d719701 100644 --- a/tripal_elasticsearch.module +++ b/tripal_elasticsearch.module @@ -534,6 +534,7 @@ function tripal_elasticsearch_web_search_results_page_callback($node_type = '' $results = $es->setWebsiteSearchParams($keyword, $node_type, implode(',', $index_name), '') ->paginate($per_page); } catch (\Exception $e) { + tripal_report_error('tripal_elasticsearch', TRIPAL_ERROR, $e->getMessage()); return 'Searching is not available. Please try later.'; }