| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100 |
- <?php
- declare(strict_types=1);
- class FreshRSS_javascript_Controller extends FreshRSS_ActionController {
- /**
- * @var FreshRSS_ViewJavascript
- * @phpstan-ignore property.phpDocType
- */
- protected $view;
- public function __construct() {
- parent::__construct(FreshRSS_ViewJavascript::class);
- }
- #[\Override]
- public function firstAction(): void {
- $this->view->_layout(null);
- }
- public function actualizeAction(): void {
- if (!FreshRSS_Auth::hasAccess() && !(
- FreshRSS_Context::systemConf()->allow_anonymous
- && FreshRSS_Context::systemConf()->allow_anonymous_refresh
- )) {
- Minz_Error::error(403);
- return;
- }
- header('Content-Type: application/json; charset=UTF-8');
- Minz_Session::_param('actualize_feeds', false);
- $databaseDAO = FreshRSS_Factory::createDatabaseDAO();
- $databaseDAO->minorDbMaintenance();
- Minz_ExtensionManager::callHookVoid(Minz_HookType::FreshrssUserMaintenance);
- $catDAO = FreshRSS_Factory::createCategoryDao();
- $this->view->categories = $catDAO->listCategoriesOrderUpdate(FreshRSS_Context::userConf()->dynamic_opml_ttl_default);
- $feedDAO = FreshRSS_Factory::createFeedDao();
- $this->view->feeds = $feedDAO->listFeedsOrderUpdate(FreshRSS_Context::userConf()->ttl_default);
- }
- public function nbUnreadsPerFeedAction(): void {
- if (!FreshRSS_Auth::hasAccess() && !FreshRSS_Context::systemConf()->allow_anonymous) {
- Minz_Error::error(403);
- return;
- }
- header('Content-Type: application/json; charset=UTF-8');
- $catDAO = FreshRSS_Factory::createCategoryDao();
- $this->view->categories = $catDAO->listCategories(prePopulateFeeds: true, details: false);
- $tagDAO = FreshRSS_Factory::createTagDao();
- $this->view->tags = $tagDAO->listTags(precounts: true);
- }
- //For Web-form login
- /**
- * @throws Exception
- */
- public function nonceAction(): void {
- header('Content-Type: application/json; charset=UTF-8');
- header('Last-Modified: ' . gmdate('D, d M Y H:i:s \G\M\T'));
- header('Expires: 0');
- header('Cache-Control: private, no-cache, no-store, must-revalidate');
- header('Pragma: no-cache');
- $user = Minz_Request::paramString('user');
- if ($user === '') {
- Minz_Error::error(400);
- return;
- }
- $user_conf = FreshRSS_UserConfiguration::getForUser($user);
- if ($user_conf !== null) {
- try {
- $s = $user_conf->passwordHash;
- if (strlen($s) >= 60) {
- //CRYPT_BLOWFISH Salt: "$2a$", a two digit cost parameter, "$", and 22 characters from the alphabet "./0-9A-Za-z".
- $this->view->salt1 = substr($s, 0, 29);
- $this->view->nonce = hash('sha256', FreshRSS_Context::systemConf()->salt . $user . random_bytes(32));
- Minz_Session::_param('nonce', $this->view->nonce);
- return; //Success
- }
- } catch (Minz_Exception $me) {
- Minz_Log::warning('Nonce failure: ' . $me->getMessage());
- }
- } else {
- Minz_Log::notice('Nonce failure due to invalid username! ' . $user);
- }
- //Failure: Return random data.
- $this->view->salt1 = sprintf('$2a$%02d$', FreshRSS_password_Util::BCRYPT_COST);
- $alphabet = './ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
- for ($i = 22; $i > 0; $i--) {
- $this->view->salt1 .= $alphabet[random_int(0, 63)];
- }
- $this->view->nonce = hash('sha256', 'failure' . rand());
- Minz_Session::_param('nonce', $this->view->nonce);
- }
- }
|