// Invalid activation code
         $message = $l->g('invalid_activation_code');
     }
 } elseif (isset($activate_account)) {
     // New account activation
     if ($user->_db_getList('id,language_id', 'activated = n', 'activation_code = ' . md5($activation_code), 1)) {
         // Load language
         if ($l->id != $user->_db_list[0]['language_id']) {
             $old_language_id = $l->id;
             if (true !== $l->setLanguage($user->_db_list[0]['language_id'])) {
                 $l->setLanguage($old_language_id);
             }
         }
         // Activate user account
         $user_id = $user->_db_list[0]['id'];
         $user->_db_freeList();
         if ($user->activateUser($user_id)) {
             $user->_db_loadObj($user_id);
             $message = $l->g('your_account_activated');
             if (!empty($session->_conf_all['new_user_notification'])) {
                 // Send notification to admins
                 $old_language_id = $l->id;
                 if ($current_user->_db_getList('email,language_id', 'is_admin = y')) {
                     $users = $current_user->_db_list;
                     $current_user->_db_freeList();
                     // Group users by language
                     $language_emails = array();
                     foreach ($users as $data) {
                         if (!isset($language_users[$data['language_id']])) {
                             $language_emails[$data['language_id']] = array();
                         }
 /**
  * "Kill" timed out sessions, set "Away" online status for sessions with ping older than (updater_interval+N) seconds
  */
 function _s_cleanUp()
 {
     // Store current state
     $this_vars = $this->_db_getFromObject();
     // Get sessions
     $sessions = array();
     $query = $this->_db_makeQuery(2100, date('Y-m-d H:i:s', time() - 1800), date('Y-m-d H:i:s', time() - $this->_conf_all['session_timeout']), date('Y-m-d H:i:s', time() - 5));
     $result = $this->_db_query($query);
     while ($data = $this->_db_fetch($result, MYSQL_ASSOC)) {
         $sessions[] = $data;
     }
     $this->_db_freeResult($result);
     $this->_db_freeList();
     if (!empty($sessions)) {
         _pcpin_loadClass('session');
         $session = new PCPIN_Session($this, '', true);
         foreach ($sessions as $sessiondata) {
             $session->_db_setObject($sessiondata);
             $session->_s_logOut();
         }
     }
     // Delete old messages
     if (!empty($this->_conf_all['message_lifetime'])) {
         _pcpin_loadClass('message');
         $message = new PCPIN_Message($this);
         $message->deleteMessages(null, time() - $this->_conf_all['message_lifetime']);
     }
     // Unmute users
     _pcpin_loadClass('user');
     $user = new PCPIN_User($this);
     if ($user->_db_getList('id', 'global_muted_until > 0000-00-00 00:00:00', 'global_muted_until < ' . date('Y-m-d H:i:s'))) {
         $user_ids = $user->_db_list;
         $user->_db_freeList();
         foreach ($user_ids as $data) {
             // Unmute user
             $user->globalMuteUnmute($data['id'], 0);
         }
         // Add system messages
         _pcpin_loadClass('message');
         $message = new PCPIN_Message($this);
         foreach ($user_ids as $data) {
             if ($this->_db_getList('_s_room_id', '_s_user_id = ' . $data['id'], 1)) {
                 $message->addMessage(10111, 'n', 0, '', 0, 0, $data['id'] . '/0', date('Y-m-d H:i:s'), 0, '');
             }
         }
     }
     // Clean unbanned users
     if ($result = $this->_db_query($this->_db_makeQuery(2080, date('Y-m-d H:i:s')))) {
         $this->_db_freeResult($result);
     }
     // Clean not activated email addresses
     if (!empty($this->_conf_all['activate_new_emails'])) {
         _pcpin_loadClass('user');
         $user = new PCPIN_User($this);
         if ($user->_db_getList('id', 'email_new != ', 'email_new_date < ' . date('Y-m-d H:i:s', time() - 3600 * $this->_conf_all['new_email_activation_timeout']))) {
             $user_ids = $user->_db_list;
             $user->_db_freeList();
             foreach ($user_ids as $data) {
                 $user->_db_updateRow($data['id'], 'id', array('email_new' => '', 'email_new_date' => '', 'email_new_activation_code' => ''));
             }
         }
     }
     // Delete idle and/or not activated user accounts
     if (!PCPIN_SLAVE_MODE && $this->_conf_all['activate_new_accounts'] == 1 || !empty($this->_conf_all['account_pruning'])) {
         _pcpin_loadClass('user');
         $user = new PCPIN_User($this);
         $query = $this->_db_makeQuery(2060, $this->_conf_all['activate_new_accounts'] == 1 ? date('Y-m-d H:i:s', time() - 3600 * $this->_conf_all['new_account_activation_timeout']) : '', !empty($this->_conf_all['account_pruning']) ? date('Y-m-d H:i:s', time() - $this->_conf_all['account_pruning'] * 86400) : '');
         $user_ids = array();
         if ($result = $this->_db_query($query)) {
             while ($data = $this->_db_fetch($result, MYSQL_ASSOC)) {
                 $user_ids[] = $data['id'];
             }
             $this->_db_freeResult($result);
         }
         if (!empty($user_ids)) {
             foreach ($user_ids as $id) {
                 $user->deleteUser($id);
             }
         }
     }
     // Delete empty and timed out user rooms
     _pcpin_loadClass('room');
     $room = new PCPIN_Room($this);
     if ($room->_db_getList('id', 'type = u', 'users_count <= 0', 'last_ping < ' . date('Y-m-d H:i:s', time() - $this->_conf_all['empty_userroom_lifetime']))) {
         $rooms = $room->_db_list;
         $room->_db_freeList();
         foreach ($rooms as $data) {
             $room->deleteRoom($data['id']);
         }
         // Add system message
         _pcpin_loadClass('message');
         $message = new PCPIN_Message($this);
         $message->addMessage(1100, 'n', 0, '', 0, 0, '-', date('Y-m-d H:i:s'), 0, '');
     }
     // Delete old logs
     if (!empty($this->_conf_all['logging_period'])) {
         _pcpin_loadClass('message_log');
         $message_log = new PCPIN_Message_Log($this);
         $message_log->cleanUp();
     }
     // Restore current state
     $this->_db_setObject($this_vars);
 }
 /**
  * Set user avatar from Avatar Gallery
  * @param   int   $user_id      User ID
  * @param   int   $avatar_id    Avatar ID
  * @return  boolean TRUE on success or FALSE on error
  */
 function setAvatarFromGallery($user_id = 0, $avatar_id = 0)
 {
     $result = false;
     if (!empty($user_id) && !empty($avatar_id) && $this->_db_getList('binaryfile_id', 'id = ' . $avatar_id, 'user_id = 0', 1)) {
         // Avatar exists
         $binaryfile_id = $this->_db_list[0]['binaryfile_id'];
         _pcpin_loadClass('user');
         $user = new PCPIN_User($this);
         if ($user->_db_getList('id', 'id = ' . $user_id, 1)) {
             // User exists
             $user->_db_freeList();
             // Does user has primary avatar
             if ($this->_db_getList('id', 'user_id = ' . $user_id, 'primary = y', 1)) {
                 // There is already one primary avatar
                 $this->primary = 'n';
                 $this->_db_freeList();
             } else {
                 // This avatar will be primary
                 $this->primary = 'y';
             }
             // Insert avatar
             $this->id = 0;
             $this->user_id = $user_id;
             $this->binaryfile_id = $binaryfile_id;
             $result = $this->_db_insertObj();
         }
     }
     return $result;
 }
 /**
  * Get default nickname. If user has no nicknames, his username will be returned.
  * @param   int   $user_id    User ID
  * @return  string
  */
 function getDefaultNickname($user_id)
 {
     $nickname = '';
     if (!empty($user_id)) {
         if (!$this->_db_getList('nickname', 'user_id = ' . $user_id, 'default = y', 1)) {
             $this->_db_getList('nickname', 'user_id = ' . $user_id, 1);
         }
         if (!empty($this->_db_list)) {
             $nickname = $this->_db_list[0]['nickname'];
             $this->_db_freeList();
         }
         if ($nickname == '') {
             // User has no nicknames, get username
             $usr = new PCPIN_User($this);
             if ($usr->_db_getList('login', 'id =# ' . $user_id, 1)) {
                 $nickname = $usr->_db_list[0]['login'];
                 $usr->_db_freeList();
             }
         }
     }
     return $nickname;
 }