1 | <?php |
---|
2 | # -- BEGIN LICENSE BLOCK --------------------------------------- |
---|
3 | # |
---|
4 | # This file is part of Dotclear 2. |
---|
5 | # |
---|
6 | # Copyright (c) 2003-2013 Olivier Meunier & Association Dotclear |
---|
7 | # Licensed under the GPL version 2.0 license. |
---|
8 | # See LICENSE file or |
---|
9 | # http://www.gnu.org/licenses/old-licenses/gpl-2.0.html |
---|
10 | # |
---|
11 | # -- END LICENSE BLOCK ----------------------------------------- |
---|
12 | if (!defined('DC_RC_PATH')) { return; } |
---|
13 | |
---|
14 | class dcMaintenanceSynchpostsmeta extends dcMaintenanceTask |
---|
15 | { |
---|
16 | protected $ajax = true; |
---|
17 | protected $group = 'index'; |
---|
18 | protected $limit = 100; |
---|
19 | protected $step_task; |
---|
20 | |
---|
21 | protected function init() |
---|
22 | { |
---|
23 | $this->name = __('Entries metadata'); |
---|
24 | $this->task = __('Synchronize entries metadata'); |
---|
25 | $this->step_task = __('Next'); |
---|
26 | $this->step = __('Synchronize entry %d to %d.'); |
---|
27 | $this->success = __('Entries metadata synchronize done.'); |
---|
28 | $this->error = __('Failed to synchronize entries metadata.'); |
---|
29 | |
---|
30 | $this->description = __('Synchronize all entries metadata could be useful after importing content in your blog or do bad operation on database tables.'); |
---|
31 | } |
---|
32 | |
---|
33 | public function execute() |
---|
34 | { |
---|
35 | $this->code = $this->synchronizeAllPostsmeta($this->code, $this->limit); |
---|
36 | |
---|
37 | return $this->code ? $this->code : true; |
---|
38 | } |
---|
39 | |
---|
40 | public function task() |
---|
41 | { |
---|
42 | return $this->code ? $this->step_task : $this->task; |
---|
43 | } |
---|
44 | |
---|
45 | public function step() |
---|
46 | { |
---|
47 | return $this->code ? sprintf($this->step, $this->code - $this->limit, $this->code) : null; |
---|
48 | } |
---|
49 | |
---|
50 | public function success() |
---|
51 | { |
---|
52 | return $this->code ? sprintf($this->step, $this->code - $this->limit, $this->code) : $this->success; |
---|
53 | } |
---|
54 | |
---|
55 | protected function synchronizeAllPostsmeta($start=null,$limit=null) |
---|
56 | { |
---|
57 | // Get number of posts |
---|
58 | $rs = $this->core->con->select('SELECT COUNT(post_id) FROM '.$this->core->prefix.'post'); |
---|
59 | $count = $rs->f(0); |
---|
60 | |
---|
61 | // Get posts ids to update |
---|
62 | $req_limit = $start !== null && $limit !== null ? $this->core->con->limit($start, $limit) : ''; |
---|
63 | $rs = $this->core->con->select('SELECT post_id FROM '.$this->core->prefix.'post '.$req_limit, true); |
---|
64 | |
---|
65 | // Update posts meta |
---|
66 | while ($rs->fetch()) { |
---|
67 | $rs_meta = $this->core->con->select('SELECT meta_id, meta_type FROM '.$this->core->prefix.'meta WHERE post_id = '.$rs->post_id.' '); |
---|
68 | |
---|
69 | $meta = array(); |
---|
70 | while ($rs_meta->fetch()) { |
---|
71 | $meta[$rs_meta->meta_type][] = $rs_meta->meta_id; |
---|
72 | } |
---|
73 | |
---|
74 | $cur = $this->core->con->openCursor($this->core->prefix.'post'); |
---|
75 | $cur->post_meta = serialize($meta); |
---|
76 | $cur->update('WHERE post_id = '.$rs->post_id); |
---|
77 | } |
---|
78 | $this->core->blog->triggerBlog(); |
---|
79 | |
---|
80 | // Return next step |
---|
81 | return $start + $limit > $count ? null : $start + $limit; |
---|
82 | } |
---|
83 | } |
---|