forked from fengoffice/fengoffice
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrebuild_sharing_table.php
67 lines (53 loc) · 2.2 KB
/
rebuild_sharing_table.php
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
<?php
chdir(dirname(__FILE__));
header("Content-type: text/plain");
define("CONSOLE_MODE", true);
include "init.php";
Env::useHelper('format');
define('SCRIPT_MEMORY_LIMIT', 1024 * 1024 * 1024); // 1 GB
@set_time_limit(0);
ini_set('memory_limit', ((SCRIPT_MEMORY_LIMIT / (1024*1024))+50).'M');
DB::execute("CREATE TABLE IF NOT EXISTS `fixed_objects` (
`object_id` INTEGER UNSIGNED,
PRIMARY KEY (`object_id`)
) ENGINE = InnoDB;");
$drop_tmp_table = true;
//$object_ids = Objects::instance()->findAll(array('columns' => array('id','object_type_id'), 'conditions' => 'id NOT IN (SELECT object_id FROM fixed_objects)'));
$objects = DB::executeAll("
SELECT id, object_type_id, member_id
FROM ".TABLE_PREFIX."objects o
LEFT JOIN ".TABLE_PREFIX."object_members om ON o.id = om.object_id
WHERE id NOT IN (SELECT object_id FROM fixed_objects)
GROUP BY o.id
");
$processed_objects = array();
$i = 0;
$msg = "";
echo "\nObjects to process: " . count($objects) . "\n-----------------------------------------------------------------";
foreach ($objects as $key => $object) {
ContentDataObjects::addObjToSharingTable($object['id'],$object['object_type_id'],!is_null($object['member_id']));
$processed_objects[] = $object['id'];
$i++;
$memory_limit_exceeded = memory_get_usage(true) > SCRIPT_MEMORY_LIMIT;
if ($i % 100 == 0 || $memory_limit_exceeded) {
echo "\n$i objects processed. Mem usage: " . format_filesize(memory_get_usage(true));
if (count($processed_objects) > 0) {
DB::execute("INSERT INTO fixed_objects (object_id) VALUES (".implode('),(', $processed_objects).");");
$processed_objects = array();
}
ob_flush();
if ($memory_limit_exceeded) {
$msg = "Memory limit exceeded: " . format_filesize(memory_get_usage(true));
$drop_tmp_table = false;
break;
}
}
}
echo "\n-----------------------------------------------------------------\nFinished: $i objects processed. $msg\n";
if (count($processed_objects) > 0) {
DB::execute("INSERT INTO fixed_objects (object_id) VALUES (".implode('),(', $processed_objects).");");
$processed_objects = array();
if ($drop_tmp_table) {
DB::execute("DROP TABLE `fixed_objects`;");
}
}