| 
									
										
										
										
											2011-09-07 18:20:14 -04:00
										 |  |  | #!/usr/bin/env php
 | 
					
						
							|  |  |  | <?php | 
					
						
							|  |  |  | /* | 
					
						
							|  |  |  |  * StatusNet - a distributed open-source microblogging tool | 
					
						
							|  |  |  |  * Copyright (C) 2008-2011, StatusNet, Inc. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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/>. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | define('INSTALLDIR', realpath(dirname(__FILE__) . '/..')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | $shortoptions = ''; | 
					
						
							|  |  |  | $longoptions = array(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | $helptext = <<<END_OF_UPDATEURLS_HELP | 
					
						
							|  |  |  | updateurls.php [options] | 
					
						
							|  |  |  | update stored URLs in the system | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | END_OF_UPDATEURLS_HELP; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | require_once INSTALLDIR.'/scripts/commandline.inc'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function main() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     updateUserUrls(); | 
					
						
							|  |  |  |     updateGroupUrls(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function updateUserUrls() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     printfnq("Updating user URLs...\n"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // XXX: only update user URLs where out-of-date
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     $user = new User(); | 
					
						
							|  |  |  |     if ($user->find()) { | 
					
						
							|  |  |  |         while ($user->fetch()) { | 
					
						
							|  |  |  |             printfv("Updating user {$user->nickname}..."); | 
					
						
							|  |  |  |             try { | 
					
						
							|  |  |  |                 $profile = $user->getProfile(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 updateProfileUrl($profile); | 
					
						
							|  |  |  |                 updateAvatarUrls($profile); | 
					
						
							|  |  |  |             } catch (Exception $e) { | 
					
						
							| 
									
										
										
										
											2013-10-20 21:02:47 +02:00
										 |  |  |                 echo "Error updating URLs: " . $e->getMessage(); | 
					
						
							| 
									
										
										
										
											2011-09-07 18:20:14 -04:00
										 |  |  |             } | 
					
						
							|  |  |  |             printfv("DONE."); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function updateProfileUrl($profile) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     $orig = clone($profile); | 
					
						
							|  |  |  |     $profile->profileurl = common_profile_url($profile->nickname); | 
					
						
							|  |  |  |     $profile->update($orig); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function updateAvatarUrls($profile) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     $avatar = new Avatar(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     $avatar->profile_id = $profile->id; | 
					
						
							|  |  |  |     if ($avatar->find()) { | 
					
						
							|  |  |  |         while ($avatar->fetch()) { | 
					
						
							|  |  |  |             $orig_url = $avatar->url; | 
					
						
							|  |  |  |             $avatar->url = Avatar::url($avatar->filename); | 
					
						
							|  |  |  |             if ($avatar->url != $orig_url) { | 
					
						
							|  |  |  |                 $sql = | 
					
						
							|  |  |  |                   "UPDATE avatar SET url = '" . $avatar->url . "' ". | 
					
						
							|  |  |  |                   "WHERE profile_id = " . $avatar->profile_id . " ". | 
					
						
							|  |  |  |                   "AND width = " . $avatar->width . " " . | 
					
						
							|  |  |  |                   "AND height = " . $avatar->height . " "; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 if ($avatar->original) { | 
					
						
							|  |  |  |                     $sql .= "AND original = 1 "; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 if (!$avatar->query($sql)) { | 
					
						
							|  |  |  |                     throw new Exception("Can't update avatar for user " . $profile->nickname . "."); | 
					
						
							|  |  |  |                 } else { | 
					
						
							|  |  |  |                     $touched = true; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function updateGroupUrls() | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-09-07 18:53:06 -04:00
										 |  |  |     printfnq("Updating group URLs...\n"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-07 18:20:14 -04:00
										 |  |  |     $group = new User_group(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if ($group->find()) { | 
					
						
							|  |  |  |         while ($group->fetch()) { | 
					
						
							|  |  |  |             try { | 
					
						
							| 
									
										
										
										
											2011-09-07 18:53:06 -04:00
										 |  |  |                 printfv("Updating group {$group->nickname}..."); | 
					
						
							| 
									
										
										
										
											2013-08-18 13:04:58 +02:00
										 |  |  |                 $orig = User_group::getKV('id', $group->id); | 
					
						
							| 
									
										
										
										
											2011-09-07 18:20:14 -04:00
										 |  |  |                 if (!empty($group->original_logo)) { | 
					
						
							|  |  |  |                     $group->original_logo = Avatar::url(basename($group->original_logo)); | 
					
						
							|  |  |  |                     $group->homepage_logo = Avatar::url(basename($group->homepage_logo)); | 
					
						
							|  |  |  |                     $group->stream_logo = Avatar::url(basename($group->stream_logo)); | 
					
						
							|  |  |  |                     $group->mini_logo = Avatar::url(basename($group->mini_logo)); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 // XXX: this is a hack to see if a group is local or not
 | 
					
						
							|  |  |  |                 $localUri = common_local_url('groupbyid', | 
					
						
							|  |  |  |                                              array('id' => $group->id)); | 
					
						
							|  |  |  |                 if ($group->getUri() != $localUri) { | 
					
						
							|  |  |  |                     $group->mainpage = common_local_url('showgroup', | 
					
						
							|  |  |  |                                                         array('nickname' => $group->nickname)); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 $group->update($orig); | 
					
						
							| 
									
										
										
										
											2011-09-07 18:53:06 -04:00
										 |  |  |                 printfv("DONE."); | 
					
						
							| 
									
										
										
										
											2011-09-07 18:20:14 -04:00
										 |  |  |             } catch (Exception $e) { | 
					
						
							| 
									
										
										
										
											2013-10-20 21:02:47 +02:00
										 |  |  |                 echo "Can't update avatars for group " . $group->nickname . ": ". $e->getMessage(); | 
					
						
							| 
									
										
										
										
											2011-09-07 18:20:14 -04:00
										 |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2011-09-07 18:53:06 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | main(); |