| 
									
										
										
										
											2010-04-08 17:05:02 -07:00
										 |  |  | #!/usr/bin/env php
 | 
					
						
							|  |  |  | <?php | 
					
						
							| 
									
										
										
										
											2020-06-08 18:31:22 +03:00
										 |  |  | // This file is part of GNU social - https://www.gnu.org/software/social
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // GNU social 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.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // GNU social 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 GNU social.  If not, see <http://www.gnu.org/licenses/>.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * @copyright 2009-2010 StatusNet, Inc. | 
					
						
							|  |  |  |  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later | 
					
						
							| 
									
										
										
										
											2010-04-08 17:05:02 -07:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-15 04:10:29 +01:00
										 |  |  | define('INSTALLDIR', dirname(__DIR__)); | 
					
						
							|  |  |  | define('PUBLICDIR', INSTALLDIR . DIRECTORY_SEPARATOR . 'public'); | 
					
						
							| 
									
										
										
										
											2010-04-08 17:05:02 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | $shortoptions = 'i::n::y'; | 
					
						
							| 
									
										
										
										
											2010-04-09 11:36:02 -07:00
										 |  |  | $longoptions = array('id=', 'nickname=', 'yes', 'dry-run', 'all'); | 
					
						
							| 
									
										
										
										
											2010-04-08 17:05:02 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | $helptext = <<<END_OF_HELP | 
					
						
							|  |  |  | strip_geo.php [options] | 
					
						
							|  |  |  | Removes geolocation info from the given user's notices. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   -i --id       ID of the user (may be a remote profile) | 
					
						
							|  |  |  |   -n --nickname nickname of the user | 
					
						
							|  |  |  |   -y --yes      do not wait for confirmation | 
					
						
							|  |  |  |      --dry-run  list affected notices without deleting | 
					
						
							| 
									
										
										
										
											2010-04-09 11:36:02 -07:00
										 |  |  |      --all      run over and decache all messages, even if they don't | 
					
						
							|  |  |  |                 have geo data now (helps to fix cache bugs) | 
					
						
							| 
									
										
										
										
											2010-04-08 17:05:02 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | END_OF_HELP; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | require_once INSTALLDIR.'/scripts/commandline.inc'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if (have_option('i', 'id')) { | 
					
						
							|  |  |  |     $id = get_option_value('i', 'id'); | 
					
						
							| 
									
										
										
										
											2013-08-18 13:04:58 +02:00
										 |  |  |     $profile = Profile::getKV('id', $id); | 
					
						
							| 
									
										
										
										
											2010-04-08 17:05:02 -07:00
										 |  |  |     if (empty($profile)) { | 
					
						
							|  |  |  |         print "Can't find local or remote profile with ID $id\n"; | 
					
						
							|  |  |  |         exit(1); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-06-08 18:31:22 +03:00
										 |  |  | } elseif (have_option('n', 'nickname')) { | 
					
						
							| 
									
										
										
										
											2010-04-08 17:05:02 -07:00
										 |  |  |     $nickname = get_option_value('n', 'nickname'); | 
					
						
							| 
									
										
										
										
											2013-08-18 13:04:58 +02:00
										 |  |  |     $user = User::getKV('nickname', $nickname); | 
					
						
							| 
									
										
										
										
											2010-04-08 17:05:02 -07:00
										 |  |  |     if (empty($user)) { | 
					
						
							|  |  |  |         print "Can't find local user with nickname '$nickname'\n"; | 
					
						
							|  |  |  |         exit(1); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     $profile = $user->getProfile(); | 
					
						
							|  |  |  | } else { | 
					
						
							|  |  |  |     print "You must provide either an ID or a nickname.\n\n"; | 
					
						
							|  |  |  |     show_help(); | 
					
						
							|  |  |  |     exit(1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if (!have_option('y', 'yes') && !have_option('--dry-run')) { | 
					
						
							|  |  |  |     print "About to PERMANENTLY remove geolocation data from user '{$profile->nickname}' ({$profile->id})'s notices. Are you sure? [y/N] "; | 
					
						
							|  |  |  |     $response = fgets(STDIN); | 
					
						
							|  |  |  |     if (strtolower(trim($response)) != 'y') { | 
					
						
							|  |  |  |         print "Aborting.\n"; | 
					
						
							|  |  |  |         exit(0); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // @fixme for a very prolific poster this could be too many.
 | 
					
						
							|  |  |  | $notice = new Notice(); | 
					
						
							|  |  |  | $notice->profile_id = $profile->id; | 
					
						
							| 
									
										
										
										
											2010-04-09 11:36:02 -07:00
										 |  |  | if (have_option('--all')) { | 
					
						
							|  |  |  |     print "Finding all notices by $profile->nickname..."; | 
					
						
							|  |  |  | } else { | 
					
						
							|  |  |  |     print "Finding notices by $profile->nickname with geolocation data..."; | 
					
						
							| 
									
										
										
										
											2020-06-08 18:31:22 +03:00
										 |  |  |     $notice->whereAdd("lat <> ''"); | 
					
						
							| 
									
										
										
										
											2010-04-09 11:36:02 -07:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2010-04-08 17:05:02 -07:00
										 |  |  | $notice->find(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if ($notice->N) { | 
					
						
							|  |  |  |     print " $notice->N found.\n"; | 
					
						
							|  |  |  |     while ($notice->fetch()) { | 
					
						
							|  |  |  |         print "notice id $notice->id "; | 
					
						
							|  |  |  |         if (have_option('v') || have_option('--verbose')) { | 
					
						
							|  |  |  |             print "({$notice->lat},{$notice->lon}) "; | 
					
						
							|  |  |  |             if ($notice->location_ns) { | 
					
						
							|  |  |  |                 print "ns {$notice->location_ns} id {$notice->location_id} "; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (have_option('--dry-run')) { | 
					
						
							|  |  |  |             // sucka
 | 
					
						
							|  |  |  |             echo "(skipped)"; | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             // note: setting fields to null and calling update() doesn't save the nulled fields
 | 
					
						
							|  |  |  |             $orig = clone($notice); | 
					
						
							|  |  |  |             $update = clone($notice); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // In theory we could hit a chunk of notices at once in the UPDATE,
 | 
					
						
							|  |  |  |             // but we're going to have to decache them individually anyway and
 | 
					
						
							|  |  |  |             // it doesn't hurt to make sure we don't hold up replication with
 | 
					
						
							|  |  |  |             // what might be a very slow single UPDATE.
 | 
					
						
							| 
									
										
										
										
											2020-07-27 19:10:33 +03:00
										 |  |  |             $ok = $update->query(sprintf( | 
					
						
							|  |  |  |                 <<<'END' | 
					
						
							|  |  |  |                 UPDATE notice | 
					
						
							|  |  |  |                   SET lat = NULL, lon = NULL, location_ns = NULL, location_id = NULL | 
					
						
							|  |  |  |                       modified = CURRENT_TIMESTAMP | 
					
						
							|  |  |  |                   WHERE id = %d | 
					
						
							|  |  |  |                 END, | 
					
						
							|  |  |  |                 $notice->getID() | 
					
						
							|  |  |  |             )); | 
					
						
							| 
									
										
										
										
											2010-04-08 17:05:02 -07:00
										 |  |  |             if ($ok) { | 
					
						
							|  |  |  |                 // And now we decache him manually, as query() doesn't know what we're doing...
 | 
					
						
							| 
									
										
										
										
											2010-04-09 11:36:02 -07:00
										 |  |  |                 $orig->decache(); | 
					
						
							| 
									
										
										
										
											2010-04-08 17:05:02 -07:00
										 |  |  |                 echo "(removed)"; | 
					
						
							|  |  |  |             } else { | 
					
						
							| 
									
										
										
										
											2010-04-09 11:36:02 -07:00
										 |  |  |                 echo "(unchanged?)"; | 
					
						
							| 
									
										
										
										
											2010-04-08 17:05:02 -07:00
										 |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         print "\n"; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } else { | 
					
						
							|  |  |  |     print " none found.\n"; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | print "DONE.\n"; |