123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105 |
- <?php
- class DelUserQueueHandler extends QueueHandler
- {
- const DELETION_WINDOW = 50;
- public function transport()
- {
- return 'deluser';
- }
- public function handle($user)
- {
- if (!($user instanceof User)) {
- common_log(LOG_ERR, "Got a bogus user, not deleting");
- return true;
- }
- $user = User::getKV('id', $user->id);
- if (!$user) {
- common_log(LOG_INFO, "User {$user->nickname} was deleted before we got here.");
- return true;
- }
- try {
- if (!$user->hasRole(Profile_role::DELETED)) {
- common_log(LOG_INFO, "User {$user->nickname} is not pending deletion; aborting.");
- return true;
- }
- } catch (UserNoProfileException $unp) {
- common_log(LOG_INFO, "Deleting user {$user->nickname} with no profile... probably a good idea!");
- }
- $notice = $this->getNextBatch($user);
- if ($notice->N) {
- common_log(LOG_INFO, "Deleting next {$notice->N} notices by {$user->nickname}");
- while ($notice->fetch()) {
- $del = clone($notice);
- $del->delete();
- }
-
-
-
-
- $qm = QueueManager::get();
- $qm->enqueue($user, 'deluser');
- } else {
-
- try {
- $user->getProfile()->delete();
- } catch (UserNoProfileException $e) {
-
- $user->delete();
- }
- common_log(LOG_INFO, "User $user->id $user->nickname deleted.");
- return true;
- }
- return true;
- }
-
- protected function getNextBatch(User $user)
- {
- $notice = new Notice();
- $notice->profile_id = $user->id;
- $notice->limit(self::DELETION_WINDOW);
- $notice->find();
- return $notice;
- }
- }
|