1 | <?php |
||
2 | /** |
||
3 | * @package midcom.services |
||
4 | * @author The Midgard Project, http://www.midgard-project.org |
||
5 | * @copyright The Midgard Project, http://www.midgard-project.org |
||
6 | * @license http://www.gnu.org/licenses/lgpl.html GNU Lesser General Public License |
||
7 | */ |
||
8 | |||
9 | /** |
||
10 | * @package midcom.services |
||
11 | */ |
||
12 | class midcom_cron_purgedeleted extends midcom_baseclasses_components_cron_handler |
||
13 | { |
||
14 | private int $_cutoff; |
||
15 | |||
16 | public function set_cutoff(int $days) |
||
17 | { |
||
18 | $this->_cutoff = strtotime($days . ' days ago'); |
||
19 | } |
||
20 | |||
21 | public function get_cutoff() : int |
||
22 | { |
||
23 | if (empty($this->_cutoff)) { |
||
24 | $this->set_cutoff(midcom::get()->config->get('cron_purge_deleted_after')); |
||
0 ignored issues
–
show
Bug
introduced
by
![]() |
|||
25 | } |
||
26 | return $this->_cutoff; |
||
27 | } |
||
28 | |||
29 | public function get_classes() : array |
||
30 | { |
||
31 | return array_filter(midcom_connection::get_schema_types(), function($mgdschema) { |
||
32 | return midgard_reflector_object::has_metadata_class($mgdschema); |
||
33 | }); |
||
34 | } |
||
35 | |||
36 | public function execute() |
||
37 | { |
||
38 | $cut_off = $this->get_cutoff(); |
||
39 | debug_add('Purging entries deleted before ' . gmdate('Y-m-d H:i:s', $cut_off) . "\n"); |
||
40 | foreach ($this->get_classes() as $mgdschema) { |
||
41 | debug_add("Processing class {$mgdschema}"); |
||
42 | $stats = $this->process_class($mgdschema); |
||
43 | |||
44 | foreach ($stats['errors'] as $error) { |
||
45 | debug_add($error, MIDCOM_LOG_ERROR); |
||
46 | } |
||
47 | if ($stats['found'] > 0) { |
||
48 | debug_add(" Found {$stats['found']} deleted {$mgdschema} objects, purged {$stats['purged']}\n", MIDCOM_LOG_INFO); |
||
49 | } else { |
||
50 | debug_add(" No {$mgdschema} objects deleted before cutoff date found\n"); |
||
51 | } |
||
52 | } |
||
53 | } |
||
54 | |||
55 | public function process_class(string $mgdschema) : array |
||
56 | { |
||
57 | $cut_off = $this->get_cutoff(); |
||
58 | $qb = new midgard_query_builder($mgdschema); |
||
59 | $qb->add_constraint('metadata.deleted', '<>', 0); |
||
60 | $qb->add_constraint('metadata.revised', '<', gmdate('Y-m-d H:i:s', $cut_off)); |
||
61 | $qb->include_deleted(); |
||
62 | |||
63 | $stats = [ |
||
64 | 'found' => 0, |
||
65 | 'purged' => 0, |
||
66 | 'errors' => [] |
||
67 | ]; |
||
68 | |||
69 | foreach ($qb->iterate() as $obj) { |
||
70 | $stats['found']++; |
||
71 | if (!$obj->purge()) { |
||
72 | $stats['errors'][] = "Failed to purge {$obj->guid}, deleted: {$obj->metadata->deleted}, revised: {$obj->metadata->revised}. errstr: " . midcom_connection::get_error_string(); |
||
73 | debug_print_r('Purge failed for object', $obj); |
||
74 | continue; |
||
75 | } |
||
76 | $stats['purged']++; |
||
77 | } |
||
78 | return $stats; |
||
79 | } |
||
80 | } |
||
81 |