[2044] | 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 | |
---|
[3340] | 37 | return $this->code ?: true; |
---|
[2044] | 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 | } |
---|