aboutsummaryrefslogtreecommitdiff
path: root/mod/garbagecollector/start.php
blob: f92248cc03227d117dd82ea5db53af0e80a1f470 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
<?php
	/**
	 * Elgg garbage collector.
	 * 
	 * @package ElggGarbageCollector
	 * @license http://www.gnu.org/licenses/old-licenses/gpl-2.0.html GNU Public License version 2
	 * @author Curverider Ltd
	 * @copyright Curverider Ltd 2008
	 * @link http://elgg.com/
	 */

	/**
	 * Initialise the plugin.
	 *
	 */
	function garbagecollector_init()
	{
		$period = get_plugin_setting('period','garbagecollector');
		switch ($period)
		{
			case 'weekly':
			case 'monthly' :
			case 'yearly' : 
			break;
			default: $period = 'monthly';
		}
		
		// Register cron hook
		register_plugin_hook('cron', $period, 'garbagecollector_cron');
	}
	
	/**
	 * Cron job
	 *
	 */
	function garbagecollector_cron($hook, $entity_type, $returnvalue, $params)
	{
		global $CONFIG;
		
		$resulttext = elgg_echo('garbagecollector');
		
		// Garbage collect metastrings
		$resulttext .= elgg_echo('garbagecollector:gc:metastrings');
		$query = "
			DELETE 
			from {$CONFIG->dbprefix}metastrings where 
			( 
				(id not in (select name_id from {$CONFIG->dbprefix}metadata)) AND 
				(id not in (select value_id from {$CONFIG->dbprefix}metadata)) AND 
				(id not in (select name_id from {$CONFIG->dbprefix}annotations)) AND 
				(id not in (select value_id from {$CONFIG->dbprefix}annotations))   
			)";
		if (delete_data($query)!==false) {
			$resulttext .= elgg_echo('garbagecollector:ok');
		} else
			$resulttext .= elgg_echo('garbagecollector:error');
			
		$resulttext .= "\n";
		
		// Now we optimize all tables
		$tables = get_db_tables();
		foreach ($tables as $table) {
			$resulttext .= sprintf(elgg_echo('garbagecollector:optimize'), $table);
			
			if (update_data("optimize table $table")!==false)
				$resulttext .= elgg_echo('garbagecollector:ok');
			else
				$resulttext .= elgg_echo('garbagecollector:error');

			$resulttext .= "\n";
		}
			
		$resulttext .= elgg_echo('garbagecollector:done');
			
		return $returnvalue . $resulttext;
	}
	
	// Initialise plugin
	register_elgg_event_handler('init','system','garbagecollector_init');
?>