| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  | #!/usr/bin/env php
 | 
					
						
							|  |  |  | <?php | 
					
						
							|  |  |  | /* | 
					
						
							| 
									
										
										
										
											2009-08-25 18:12:20 -04:00
										 |  |  |  * StatusNet - a distributed open-source microblogging tool | 
					
						
							|  |  |  |  * Copyright (C) 2009, StatusNet, Inc. | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  |  * | 
					
						
							|  |  |  |  * This program is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU Affero General Public License as published by | 
					
						
							|  |  |  |  * the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  |  * (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU Affero General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU Affero General Public License | 
					
						
							|  |  |  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Abort if called from a web server
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | define('INSTALLDIR', realpath(dirname(__FILE__) . '/..')); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-22 17:00:53 -07:00
										 |  |  | $helptext = <<<ENDOFHELP | 
					
						
							|  |  |  | fixup_utf8.php <maxdate> <maxid> <minid> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-25 18:12:20 -04:00
										 |  |  | Fixup records in a database that stored the data incorrectly (pre-0.7.4 for StatusNet). | 
					
						
							| 
									
										
										
										
											2009-06-22 17:00:53 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | ENDOFHELP; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | require_once INSTALLDIR.'/scripts/commandline.inc'; | 
					
						
							|  |  |  | require_once 'DB.php'; | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  | class UTF8FixerUpper | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     var $dbl = null; | 
					
						
							|  |  |  |     var $dbu = null; | 
					
						
							|  |  |  |     var $args = array(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function __construct($args) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->args = $args; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-20 14:25:50 -05:00
										 |  |  |         if (!empty($args['max_date'])) { | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |             $this->max_date = strftime('%Y-%m-%d %H:%M:%S', strtotime($args['max_date'])); | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             $this->max_date = strftime('%Y-%m-%d %H:%M:%S', time()); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |         $this->dbl = $this->doConnect('latin1'); | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |         if (empty($this->dbl)) { | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |         $this->dbu = $this->doConnect('utf8'); | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |         if (empty($this->dbu)) { | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |     function doConnect($charset) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $db = DB::connect(common_config('db', 'database'), | 
					
						
							|  |  |  |                           array('persistent' => false)); | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |         if (PEAR::isError($db)) { | 
					
						
							|  |  |  |             echo "ERROR: " . $db->getMessage() . "\n"; | 
					
						
							|  |  |  |             return NULL; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |         $conn = $db->connection; | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |         $succ = mysqli_set_charset($conn, $charset); | 
					
						
							| 
									
										
										
										
											2009-05-28 16:36:07 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |         if (!$succ) { | 
					
						
							|  |  |  |             echo "ERROR: couldn't set charset\n"; | 
					
						
							|  |  |  |             $db->disconnect(); | 
					
						
							|  |  |  |             return NULL; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-05-30 11:52:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |         $result = $db->autoCommit(true); | 
					
						
							| 
									
										
										
										
											2009-05-28 16:36:07 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |         if (PEAR::isError($result)) { | 
					
						
							|  |  |  |             echo "ERROR: " . $result->getMessage() . "\n"; | 
					
						
							|  |  |  |             $db->disconnect(); | 
					
						
							|  |  |  |             return NULL; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-05-28 16:36:07 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |         return $db; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |     function fixup() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->fixupNotices($this->args['max_notice'], | 
					
						
							|  |  |  |                             $this->args['min_notice']); | 
					
						
							|  |  |  |         $this->fixupProfiles(); | 
					
						
							|  |  |  |         $this->fixupGroups(); | 
					
						
							| 
									
										
										
										
											2009-06-08 10:57:35 -07:00
										 |  |  |         $this->fixupMessages(); | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |     function fixupNotices($max_id, $min_id) { | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |         // Do a separate DB connection
 | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |         $sth = $this->dbu->prepare("UPDATE notice SET content = UNHEX(?), rendered = UNHEX(?) WHERE id = ?"); | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |         if (PEAR::isError($sth)) { | 
					
						
							|  |  |  |             echo "ERROR: " . $sth->getMessage() . "\n"; | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |         $sql = 'SELECT id, content, rendered FROM notice ' . | 
					
						
							|  |  |  |           'WHERE LENGTH(content) != CHAR_LENGTH(content) '. | 
					
						
							|  |  |  |           'AND modified < "'.$this->max_date.'" '; | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |         if (!empty($max_id)) { | 
					
						
							|  |  |  |             $sql .= ' AND id <= ' . $max_id; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |         if (!empty($min_id)) { | 
					
						
							|  |  |  |             $sql .= ' AND id >= ' . $min_id; | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |         $sql .= ' ORDER BY id DESC'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $rn = $this->dbl->query($sql); | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |         if (PEAR::isError($rn)) { | 
					
						
							|  |  |  |             echo "ERROR: " . $rn->getMessage() . "\n"; | 
					
						
							|  |  |  |             return; | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |         echo "Number of rows: " . $rn->numRows() . "\n"; | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |         $notice = array(); | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |         while (DB_OK == $rn->fetchInto($notice)) { | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |             $id = ($notice[0])+0; | 
					
						
							|  |  |  |             $content = bin2hex($notice[1]); | 
					
						
							|  |  |  |             $rendered = bin2hex($notice[2]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             echo "$id..."; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $result =& $this->dbu->execute($sth, array($content, $rendered, $id)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if (PEAR::isError($result)) { | 
					
						
							|  |  |  |                 echo "ERROR: " . $result->getMessage() . "\n"; | 
					
						
							|  |  |  |                 continue; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |             $cnt = $this->dbu->affectedRows(); | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |             if ($cnt != 1) { | 
					
						
							|  |  |  |                 echo "ERROR: 0 rows affected\n"; | 
					
						
							|  |  |  |                 continue; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2009-05-30 12:20:42 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |             $notice = Notice::staticGet('id', $id); | 
					
						
							|  |  |  |             $notice->decache(); | 
					
						
							| 
									
										
										
										
											2009-05-30 21:04:35 -04:00
										 |  |  |             $notice->free(); | 
					
						
							| 
									
										
										
										
											2009-05-30 12:20:42 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |             echo "OK\n"; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |     function fixupProfiles() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         // Do a separate DB connection
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $sth = $this->dbu->prepare("UPDATE profile SET ". | 
					
						
							|  |  |  |                                    "fullname = UNHEX(?),". | 
					
						
							|  |  |  |                                    "location = UNHEX(?), ". | 
					
						
							|  |  |  |                                    "bio = UNHEX(?) ". | 
					
						
							|  |  |  |                                    "WHERE id = ?"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (PEAR::isError($sth)) { | 
					
						
							|  |  |  |             echo "ERROR: " . $sth->getMessage() . "\n"; | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $sql = 'SELECT id, fullname, location, bio FROM profile ' . | 
					
						
							|  |  |  |           'WHERE (LENGTH(fullname) != CHAR_LENGTH(fullname) '. | 
					
						
							|  |  |  |           'OR LENGTH(location) != CHAR_LENGTH(location) '. | 
					
						
							|  |  |  |           'OR LENGTH(bio) != CHAR_LENGTH(bio)) '. | 
					
						
							|  |  |  |           'AND modified < "'.$this->max_date.'" '. | 
					
						
							|  |  |  |           ' ORDER BY modified DESC'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $rn = $this->dbl->query($sql); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (PEAR::isError($rn)) { | 
					
						
							|  |  |  |             echo "ERROR: " . $rn->getMessage() . "\n"; | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |         echo "Number of rows: " . $rn->numRows() . "\n"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $profile = array(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         while (DB_OK == $rn->fetchInto($profile)) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $id = ($profile[0])+0; | 
					
						
							|  |  |  |             $fullname = bin2hex($profile[1]); | 
					
						
							|  |  |  |             $location = bin2hex($profile[2]); | 
					
						
							|  |  |  |             $bio = bin2hex($profile[3]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             echo "$id..."; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $result =& $this->dbu->execute($sth, array($fullname, $location, $bio, $id)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if (PEAR::isError($result)) { | 
					
						
							|  |  |  |                 echo "ERROR: " . $result->getMessage() . "\n"; | 
					
						
							|  |  |  |                 continue; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $cnt = $this->dbu->affectedRows(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if ($cnt != 1) { | 
					
						
							|  |  |  |                 echo "ERROR: 0 rows affected\n"; | 
					
						
							|  |  |  |                 continue; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $profile = Profile::staticGet('id', $id); | 
					
						
							|  |  |  |             $profile->decache(); | 
					
						
							| 
									
										
										
										
											2009-05-30 21:04:35 -04:00
										 |  |  |             $profile->free(); | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |             echo "OK\n"; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  |     function fixupGroups() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         // Do a separate DB connection
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $sth = $this->dbu->prepare("UPDATE user_group SET ". | 
					
						
							|  |  |  |                                    "fullname = UNHEX(?),". | 
					
						
							|  |  |  |                                    "location = UNHEX(?), ". | 
					
						
							|  |  |  |                                    "description = UNHEX(?) ". | 
					
						
							|  |  |  |                                    "WHERE id = ?"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (PEAR::isError($sth)) { | 
					
						
							|  |  |  |             echo "ERROR: " . $sth->getMessage() . "\n"; | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $sql = 'SELECT id, fullname, location, description FROM user_group ' . | 
					
						
							|  |  |  |           'WHERE LENGTH(fullname) != CHAR_LENGTH(fullname) '. | 
					
						
							|  |  |  |           'OR LENGTH(location) != CHAR_LENGTH(location) '. | 
					
						
							|  |  |  |           'OR LENGTH(description) != CHAR_LENGTH(description) '; | 
					
						
							|  |  |  |           'AND modified < "'.$this->max_date.'" '. | 
					
						
							|  |  |  |           'ORDER BY modified DESC'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $rn = $this->dbl->query($sql); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (PEAR::isError($rn)) { | 
					
						
							|  |  |  |             echo "ERROR: " . $rn->getMessage() . "\n"; | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         echo "Number of rows: " . $rn->numRows() . "\n"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $user_group = array(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         while (DB_OK == $rn->fetchInto($user_group)) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $id = ($user_group[0])+0; | 
					
						
							|  |  |  |             $fullname = bin2hex($user_group[1]); | 
					
						
							|  |  |  |             $location = bin2hex($user_group[2]); | 
					
						
							|  |  |  |             $description = bin2hex($user_group[3]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             echo "$id..."; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $result =& $this->dbu->execute($sth, array($fullname, $location, $description, $id)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if (PEAR::isError($result)) { | 
					
						
							|  |  |  |                 echo "ERROR: " . $result->getMessage() . "\n"; | 
					
						
							|  |  |  |                 continue; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $cnt = $this->dbu->affectedRows(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if ($cnt != 1) { | 
					
						
							|  |  |  |                 echo "ERROR: 0 rows affected\n"; | 
					
						
							|  |  |  |                 continue; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $user_group = User_group::staticGet('id', $id); | 
					
						
							|  |  |  |             $user_group->decache(); | 
					
						
							| 
									
										
										
										
											2009-05-30 21:04:35 -04:00
										 |  |  |             $user_group->free(); | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |             echo "OK\n"; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-06-06 09:54:40 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     function fixupMessages() { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // Do a separate DB connection
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $sth = $this->dbu->prepare("UPDATE message SET content = UNHEX(?), rendered = UNHEX(?) WHERE id = ?"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (PEAR::isError($sth)) { | 
					
						
							|  |  |  |             echo "ERROR: " . $sth->getMessage() . "\n"; | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $sql = 'SELECT id, content, rendered FROM message ' . | 
					
						
							|  |  |  |           'WHERE LENGTH(content) != CHAR_LENGTH(content) '. | 
					
						
							|  |  |  |           'AND modified < "'.$this->max_date.'" '. | 
					
						
							|  |  |  |           'ORDER BY id DESC'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $rn = $this->dbl->query($sql); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (PEAR::isError($rn)) { | 
					
						
							|  |  |  |             echo "ERROR: " . $rn->getMessage() . "\n"; | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         echo "Number of rows: " . $rn->numRows() . "\n"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $message = array(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         while (DB_OK == $rn->fetchInto($message)) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $id = ($message[0])+0; | 
					
						
							|  |  |  |             $content = bin2hex($message[1]); | 
					
						
							|  |  |  |             $rendered = bin2hex($message[2]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             echo "$id..."; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $result =& $this->dbu->execute($sth, array($content, $rendered, $id)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if (PEAR::isError($result)) { | 
					
						
							|  |  |  |                 echo "ERROR: " . $result->getMessage() . "\n"; | 
					
						
							|  |  |  |                 continue; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $cnt = $this->dbu->affectedRows(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if ($cnt != 1) { | 
					
						
							|  |  |  |                 echo "ERROR: 0 rows affected\n"; | 
					
						
							|  |  |  |                 continue; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $message = Message::staticGet('id', $id); | 
					
						
							|  |  |  |             $message->decache(); | 
					
						
							|  |  |  |             $message->free(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             echo "OK\n"; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-05-27 19:12:37 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-22 17:00:53 -07:00
										 |  |  | $max_date = (count($args) > 0) ? $args[0] : null; | 
					
						
							|  |  |  | $max_id = (count($args) > 1) ? $args[1] : null; | 
					
						
							|  |  |  | $min_id = (count($args) > 2) ? $args[2] : null; | 
					
						
							| 
									
										
										
										
											2009-05-30 20:58:29 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | $fixer = new UTF8FixerUpper(array('max_date' => $max_date, | 
					
						
							|  |  |  |                                   'max_notice' => $max_id, | 
					
						
							|  |  |  |                                   'min_notice' => $min_id)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | $fixer->fixup(); | 
					
						
							| 
									
										
										
										
											2009-05-28 16:36:07 -04:00
										 |  |  | 
 |