mirror of
https://github.com/FreshRSS/FreshRSS.git
synced 2025-12-24 05:57:45 -05:00
* Housekeeping lib_rss.php `lib_rss.php` had become much too large, especially after https://github.com/FreshRSS/FreshRSS/pull/7924 Moved most functions to other places. Mostly no change of code otherwise (see comments). * Extension: composer run-script phpstan-third-party
101 lines
3.2 KiB
PHP
101 lines
3.2 KiB
PHP
<?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);
|
|
}
|
|
}
|