forked from GNUsocial/gnu-social
		
	[DATABASE] Introduce a bool type in schema
PostgreSQL has a clear distinction between integers and booleans, so it makes sense to draw a clear line.
This commit is contained in:
		| @@ -1,20 +1,22 @@ | ||||
| <?php | ||||
| /* | ||||
|  * StatusNet - the distributed open-source microblogging tool | ||||
|  * Copyright (C) 2013 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/>. | ||||
| // 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 2013 StatusNet, Inc. | ||||
|  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later | ||||
|  */ | ||||
|  | ||||
| define('INSTALLDIR', realpath(dirname(__FILE__) . '/../../..')); | ||||
| @@ -33,13 +35,13 @@ END_OF_SILENCESPAMMER_HELP; | ||||
|  | ||||
| require_once INSTALLDIR.'/scripts/commandline.inc'; | ||||
|  | ||||
| function testAllUsers($filter, $minimum, $percent) { | ||||
| function testAllUsers($filter, $minimum, $percent) | ||||
| { | ||||
|     $found = false; | ||||
|     $offset = 0; | ||||
|     $limit  = 1000; | ||||
|  | ||||
|     do { | ||||
|  | ||||
|         $user = new User(); | ||||
|         $user->orderBy('created'); | ||||
|         $user->limit($offset, $limit); | ||||
| @@ -56,37 +58,36 @@ function testAllUsers($filter, $minimum, $percent) { | ||||
|             } | ||||
|             $offset += $found; | ||||
|         } | ||||
|  | ||||
|     } while ($found > 0); | ||||
| } | ||||
|  | ||||
| function silencespammer($filter, $user, $minimum, $percent) { | ||||
|  | ||||
| function silencespammer($filter, $user, $minimum, $percent) | ||||
| { | ||||
|     printfnq("Testing user %s\n", $user->nickname); | ||||
|  | ||||
|     $profile = Profile::getKV('id', $user->id); | ||||
|  | ||||
|     if ($profile->isSilenced()) { | ||||
| 	printfnq("Already silenced %s\n", $user->nickname); | ||||
| 	return; | ||||
|         printfnq("Already silenced %s\n", $user->nickname); | ||||
|         return; | ||||
|     } | ||||
|      | ||||
|     $cnt = $profile->noticeCount(); | ||||
|  | ||||
|     if ($cnt < $minimum) { | ||||
|         printfnq("Only %d notices posted (minimum %d); skipping\n", $cnt, $minimum); | ||||
| 	return; | ||||
|         return; | ||||
|     } | ||||
|  | ||||
|     $ss = new Spam_score(); | ||||
|  | ||||
|     $ss->query(sprintf("SELECT count(*) as spam_count ". | ||||
|                        "FROM notice join spam_score on notice.id = spam_score.notice_id ". | ||||
|                        "WHERE notice.profile_id = %d AND spam_score.is_spam = 1", $profile->id)); | ||||
|                        'WHERE notice.profile_id = %d AND spam_score.is_spam = TRUE', $profile->id)); | ||||
|  | ||||
|     while ($ss->fetch()) { | ||||
|         $spam_count = $ss->spam_count; | ||||
|     }                  | ||||
|     } | ||||
|  | ||||
|     $spam_percent = ($spam_count * 100.0 / $cnt); | ||||
|  | ||||
| @@ -94,10 +95,10 @@ function silencespammer($filter, $user, $minimum, $percent) { | ||||
|         printfnq("Silencing user %s (%d/%d = %0.2f%% spam)\n", $user->nickname, $spam_count, $cnt, $spam_percent); | ||||
|         try { | ||||
|             $profile->silence(); | ||||
|         } catch(Exception $e) { | ||||
|         } catch (Exception $e) { | ||||
|             printfnq("Error: %s", $e->getMessage()); | ||||
|         }        | ||||
|     }     | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| try { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user