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); }
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); } }
/** * @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; }
$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(); } }