mirror of
https://github.com/FreshRSS/FreshRSS.git
synced 2025-12-26 23:17:47 -05:00
* Fix most PHPDocs errors Contributes to https://github.com/FreshRSS/FreshRSS/issues/4103 https://phpstan.org/writing-php-code/phpdoc-types * Avoid func_get_args Use variadic syntax instead https://php.net/manual/functions.arguments#functions.variable-arg-list And avoid dynamic functions names when possible to more easily identify calls and unused functions. Contributes to https://github.com/FreshRSS/FreshRSS/issues/4103 * PHPStan level 3 * PHPStand level 4 * Update default to PHPStan level 4 * Towards level 5 * Fix level 4 regression * Towards level 5 * Pass PHPStan level 5 * Towards level 6 * Remove erronenous regression from changelog https://github.com/FreshRSS/FreshRSS/pull/4116
58 lines
2.1 KiB
PHP
Executable File
58 lines
2.1 KiB
PHP
Executable File
<?php
|
|
|
|
class FreshRSS_javascript_Controller extends FreshRSS_ActionController {
|
|
public function firstAction() {
|
|
$this->view->_layout(false);
|
|
}
|
|
|
|
public function actualizeAction() {
|
|
header('Content-Type: application/json; charset=UTF-8');
|
|
Minz_Session::_param('actualize_feeds', false);
|
|
$feedDAO = FreshRSS_Factory::createFeedDao();
|
|
$this->view->feeds = $feedDAO->listFeedsOrderUpdate(FreshRSS_Context::$user_conf->ttl_default);
|
|
}
|
|
|
|
public function nbUnreadsPerFeedAction() {
|
|
header('Content-Type: application/json; charset=UTF-8');
|
|
$catDAO = FreshRSS_Factory::createCategoryDao();
|
|
$this->view->categories = $catDAO->listCategories(true, false);
|
|
$tagDAO = FreshRSS_Factory::createTagDao();
|
|
$this->view->tags = $tagDAO->listTags(true);
|
|
}
|
|
|
|
//For Web-form login
|
|
public function nonceAction() {
|
|
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 = isset($_GET['user']) ? $_GET['user'] : '';
|
|
if (FreshRSS_Context::initUser($user)) {
|
|
try {
|
|
$salt = FreshRSS_Context::$system_conf->salt;
|
|
$s = FreshRSS_Context::$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 = sha1($salt . uniqid('' . mt_rand(), true));
|
|
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!');
|
|
}
|
|
//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[mt_rand(0, 63)];
|
|
}
|
|
$this->view->nonce = sha1('' . mt_rand());
|
|
}
|
|
}
|