Example #1
0
 public function run(User $user, $args)
 {
     $args = explode(' ', $args, 2);
     $userName = $args[0];
     if (!isset($args[1])) {
         RespondError::make($user, ['msg' => 'Вы не ввели сообщения']);
         return;
     }
     $text = $args[1];
     $properties = PropertiesDAO::create()->getByUserName($userName);
     if (!$properties->getId()) {
         RespondError::make($user, ['msg' => "{$userName} не зарегистрирован или имя введено не верно"]);
         return;
     }
     $address = UserDAO::create()->getById($properties->getUserId());
     $permissions = new UserActions($user->getUserDAO());
     $actions = $permissions->getAllowed($address);
     if (!in_array(UserActions::MAIL, $actions)) {
         RespondError::make($user, ['msg' => $user->getLang()->getPhrase('NoPermission')]);
         return;
     }
     //@TODO сделать отправку по крону
     //также надо ограничить частоту отправки
     $config = DI::get()->getConfig();
     $mailerName = 'СоциоЧат';
     $headers = "MIME-Version: 1.0 \n" . "From: " . mb_encode_mimeheader($mailerName) . "<" . $config->adminEmail . "> \n" . "Reply-To: " . mb_encode_mimeheader($mailerName) . "<" . $config->adminEmail . "> \n" . "Content-Type: text/html;charset=UTF-8\n";
     $topic = 'Для вас есть сообщение';
     $msg = "<h2>Вам пришло сообщение от пользователя {$user->getProperties()->getName()}</h2>";
     $msg .= '<p>' . htmlentities(strip_tags($text)) . '</p>';
     $msg .= '<hr>';
     $msg .= 'Вернуться в <a href="' . $config->domain->protocol . $config->domain->web . '">СоциоЧат</a>';
     mb_send_mail($address->getEmail(), $topic, $msg, $headers);
     RespondError::make($user, ['msg' => 'Сообщение отправлено!']);
     return ['Сообщение отправлено!', true];
 }
 public function run()
 {
     $config = DI::get()->getConfig();
     $timeOut = $config->onlineMonitoringTimeout;
     // Let it be simple for a while
     $channelId = 1;
     /** @var PropertiesDAO $props */
     foreach (PropertiesDAO::create()->getRegisteredList() as $props) {
         if (!($limit = $props->getOnlineNotificationLimit())) {
             continue;
         }
         $online = OnlineDAO::create();
         if ($online->isUserOnline($channelId, $props->getUserId())) {
             continue;
         }
         $onlineCount = $online->getOnlineCount($channelId);
         if (time() - $timeOut < strtotime($props->getOnlineNotificationLast())) {
             continue;
         }
         if ($onlineCount >= $limit) {
             $user = UserDAO::create()->getById($props->getUserId());
             $list = '';
             foreach ($online->getOnlineList($channelId) as $userId => $userName) {
                 $list .= "<li>{$userName}</li>";
             }
             $msg = "<h2>Достижение заданного онлайна в SocioChat.Me</h2>\n<p>Вы получили данное письмо, потому что пожелали уведомить вас, когда в чате будет более {$limit} человек.</p>\n<p>Сейчас на основном канале общается {$onlineCount} человек</p>\n<ul>{$list}</ul>\n<p><a href=\"" . $config->domain->protocol . $config->domain->web . "\">Присоединяйтесь</a>!</p>";
             $message = MailQueueDAO::create();
             $message->setEmail($user->getEmail())->setTopic('SocioChat.Me - Заходите к нам!')->setMessage($msg);
             $message->save();
             $props->setOnlineNotificationLast(DbQueryHelper::timestamp2date());
             $props->save(false);
         }
     }
 }
 public function updateSessionId(User $user, $oldUserId)
 {
     SessionDAO::create()->dropByUserId($oldUserId);
     $session = SessionDAO::create()->getByUserId($user->getId());
     $session->setSessionId($user->getWSRequest()->getCookie('token'))->setAccessTime(date(self::TIMESTAMP))->setUserId($user->getId());
     $session->save();
     PropertiesDAO::create()->dropByUserId($oldUserId);
     UserBlacklistDAO::create()->dropByUserId($oldUserId);
     NameChangeDAO::create()->dropByUserId($oldUserId);
     UserDAO::create()->dropById($oldUserId);
 }
Example #4
0
 public function run(User $user, $args)
 {
     $request = explode(' ', $args, 1);
     $name = $request[0];
     if (!($targetUser = PropertiesDAO::create()->getByUserName($name))) {
         RespondError::make($user, ['name' => "{$name} не найден"]);
         return;
     }
     $list = NameChangeDAO::create()->getHistoryByUserId($targetUser->getUserId());
     $html = '<table class="table table-striped">';
     /** @var $row NameChangeDAO */
     foreach ($list as $row) {
         $html .= '<tr>';
         $html .= '<td>' . $row->getDateRaw() . '</td>';
         $html .= '<td>' . $row->getName() . '</td>';
         $html .= '</tr>';
     }
     $html .= '</table>';
     return [$html, true];
 }
 public function run()
 {
     $dir = ROOT . DIRECTORY_SEPARATOR . DI::get()->getConfig()->uploads->avatars->dir . DIRECTORY_SEPARATOR;
     $fileList = glob("{$dir}*.{jpg,png}", GLOB_BRACE);
     $fileList = array_flip($fileList);
     echo "Found images: " . count($fileList) . "\n";
     print_r($fileList);
     /** @var PropertiesDAO $userProp */
     foreach (PropertiesDAO::create()->getListWithAvatars() as $userProp) {
         if (file_exists($dir . $userProp->getAvatarImg())) {
             unset($fileList[$dir . $userProp->getAvatarImg()]);
         } else {
             $userProp->setAvatarImg(null);
         }
         if (file_exists($dir . $userProp->getAvatarThumb())) {
             unset($fileList[$dir . $userProp->getAvatarThumb()]);
         } else {
             $userProp->setAvatarImg(null);
         }
         if (file_exists($dir . $userProp->getAvatarThumb2X())) {
             unset($fileList[$dir . $userProp->getAvatarThumb2X()]);
         } else {
             $userProp->setAvatarImg(null);
         }
         if (file_exists($dir . $userProp->getAvatarImg2X())) {
             unset($fileList[$dir . $userProp->getAvatarImg2X()]);
         } else {
             $userProp->setAvatarImg(null);
         }
         if ($userProp->getAvatarImg() === null) {
             $userProp->save();
             echo "Fixed avatar link to null for " . $userProp->getName() . "\n";
         }
     }
     $fileList = array_keys($fileList);
     echo "Images to delete: " . count($fileList) . "\n";
     foreach ($fileList as $file) {
         unlink($file);
     }
 }
Example #6
0
 /**
  * @throws BaseException
  * @return PropertiesDAO
  */
 public function getPropeties()
 {
     if (!$this[self::PROPERTIES] && $this->getId()) {
         $this[self::PROPERTIES] = PropertiesDAO::create()->getByUserId($this->getId());
     }
     if (!$this->getId()) {
         throw new BaseException('Incorrect DAO request, id is null' . debug_backtrace());
     }
     return $this[self::PROPERTIES];
 }
 /**
  * @param Lang $lang
  * @param Logger $logger
  * @param User $newUserWrapper
  * @param Request $socketRequest
  * @return UserDAO
  */
 private function createNewUser(Lang $lang, Logger $logger, User $newUserWrapper, Request $socketRequest)
 {
     $user = UserDAO::create()->setChatId(1)->setDateRegister(DbQueryHelper::timestamp2date())->setRole(UserRoleEnum::USER)->setBanned(false)->setImprint(null);
     try {
         $user->save();
     } catch (\PDOException $e) {
         $logger->error("PDO Exception: " . $e->getMessage() . ': ' . $e->getTraceAsString(), [__METHOD__]);
     }
     $id = $user->getId();
     $guestName = $lang->getPhrase('Guest') . $id;
     if (PropertiesDAO::create()->getByUserName($guestName)->getName()) {
         $guestName = $lang->getPhrase('Guest') . ' ' . $id;
     }
     $properties = $user->getPropeties();
     $properties->setUserId($user->getId())->setName($guestName)->setSex(SexEnum::create(SexEnum::ANONYM))->setTim(TimEnum::create(TimEnum::ANY))->setBirthday(Rules::LOWEST_YEAR)->setOptions([PropertiesDAO::CENSOR => true])->setOnlineCount(0)->setMusicCount(0)->setWordsCount(0)->setRudeCount(0)->setKarma(0)->setMessagesCount(0)->setSubscription(true);
     try {
         $properties->save();
     } catch (\PDOException $e) {
         $logger->error("PDO Exception: " . $e->getTraceAsString(), [__CLASS__]);
     }
     if ($refUserId = $socketRequest->getCookie('refUserId')) {
         $ref = ReferralDAO::create()->getByUserId($user->getId(), $refUserId);
         if (!$ref) {
             $ref = ReferralDAO::create()->setUserId($user->getId())->setRefUserId($refUserId)->setDateRegister(DbQueryHelper::timestamp2date());
             $ref->save();
             $logger->info('Found referral userId ' . $refUserId . ' for guest userId ' . $user->getId());
         }
     }
     $logger->info("Created new user with id = {$id} for connectionId = {$newUserWrapper->getConnectionId()}", [__CLASS__]);
     return $user;
 }
Example #8
0
$activation = $result[0];
/* @var $activation ActivationsDAO */
if (!$activation->getId() || $activation->getIsUsed()) {
    $heading = 'Ошибка!';
    $message = 'Извините, но код невалиден.';
    require_once "pages/common_page.php";
    exit;
}
if ($activation->getCode() != $code) {
    $heading = 'Ошибка!';
    $message = 'Извините, но код невалиден.';
    require_once "pages/common_page.php";
    exit;
}
if (strtotime($activation->getTimestamp()) + $config->activationTTL < time()) {
    $activation->setIsUsed(true);
    $activation->save();
    $heading = 'Ошибка!';
    $message = 'Извините, но валидационный код просрочен.';
    require_once "pages/common_page.php";
    exit;
}
$user = UserDAO::create()->getByEmail($email);
$props = \SocioChat\DAO\PropertiesDAO::create()->getByUserId($user->getId());
$props->setSubscription(false);
$props->save(false);
$activation->setIsUsed(true);
$activation->save(false);
$heading = 'Готово!';
$message = 'Ваша учётная запись удалена из рассылки!';
require_once "pages/common_page.php";
 private function handleNameChange(User $user, $request)
 {
     $name = $request[PropertiesDAO::NAME];
     $guestName = $user->getLang()->getPhrase('Guest');
     $nameChangeFreq = DI::get()->getConfig()->nameChangeFreq;
     $isNewbie = mb_strpos($name, $guestName) !== false;
     $changeLog = NameChangeDAO::create()->getLastByUser($user);
     $hasNameChanged = $name != $user->getProperties()->getName();
     if ($isNewbie) {
         $newname = str_replace($guestName, TimEnum::create($request[PropertiesDAO::TIM])->getShortName(), $name);
         $duplUser = PropertiesDAO::create()->getByUserName($newname);
         if (!($duplUser->getId() && $duplUser->getUserId() != $user->getId())) {
             $name = $newname;
         }
     } elseif ($changeLog && $hasNameChanged && !$this->isExpired($changeLog, $nameChangeFreq)) {
         RespondError::make($user, $user->getLang()->getPhrase('NameChangePolicy', date('Y-m-d H:i', $changeLog->getDate() + $nameChangeFreq)));
         return;
     }
     if ($changeLog = NameChangeDAO::create()->getLastByName($name)) {
         if ($changeLog->getUserId() != $user->getId()) {
             if (!$this->isExpired($changeLog, $nameChangeFreq)) {
                 RespondError::make($user, $user->getLang()->getPhrase('NameTakePolicy', date('Y-m-d H:i', $changeLog->getDate() + $nameChangeFreq)));
                 return;
             }
         }
     }
     if ($hasNameChanged && !$isNewbie) {
         NameChangeDAO::create()->setUser($user)->save();
     }
 }