aboutsummaryrefslogtreecommitdiff
path: root/app/FreshRSS.php
diff options
context:
space:
mode:
authorGravatar Marien Fressinaud <dev@marienfressinaud.fr> 2019-08-29 12:02:05 +0200
committerGravatar Alexandre Alapetite <alexandre@alapetite.fr> 2019-08-29 12:02:05 +0200
commit75632e70f0d49048f4ce72a0fa8bbcbcd7b2d312 (patch)
tree09c2f637ceedb76a30ad833555f02c2d50ee4863 /app/FreshRSS.php
parentad44ff81694ff4cbcccc514a17351476a38aadd8 (diff)
Provide email address verification feature (#2481)
* Add an email field to the profile page I reuse the `mail_login` from the configuration. I'm not sure if it's useful today (I would say it was used when Persona login was available). A good improvement would be to rename `mail_login` into `email` so it would be more intuitive to use. * Add boolean to the conf to force email validation This commit only adds a configuration item. * Add email during registration if email must be validated * Set email token to validate when email changes * Block access to FreshRSS if email is not validated * Send email when address is changed * Allow to resend the validation email * Allow the user to change its email while blocked * Document the email validation feature * fixup! Allow the user to change its email while blocked * tec: Autoload PHPMailer lib * Validate email address format * Add feedback on validation email resend action * Allow to logout when user is blocked * fix: Change default email "from" * Reorganize i18n keys * Complete all the locales with default english * Hide sidebar (profile page) if email is not validated * Check email requirements on registration * Allow admin to specify email when creating users * Don't check email format if value is empty * Remove trailing comma in userController Co-Authored-By: Alexandre Alapetite <alexandre@alapetite.fr> * Set PHPMailer validator to html5 before sending email * fixup! Remove trailing comma in userController
Diffstat (limited to 'app/FreshRSS.php')
-rw-r--r--app/FreshRSS.php18
1 files changed, 18 insertions, 0 deletions
diff --git a/app/FreshRSS.php b/app/FreshRSS.php
index d578beac4..c48ad2093 100644
--- a/app/FreshRSS.php
+++ b/app/FreshRSS.php
@@ -54,6 +54,8 @@ class FreshRSS extends Minz_FrontController {
Minz_ExtensionManager::enableByList($ext_list);
}
+ self::checkEmailValidated();
+
Minz_ExtensionManager::callHook('freshrss_init');
}
@@ -144,4 +146,20 @@ class FreshRSS extends Minz_FrontController {
FreshRSS_Share::load(join_path(APP_PATH, 'shares.php'));
self::loadStylesAndScripts();
}
+
+ private static function checkEmailValidated() {
+ $email_not_verified = FreshRSS_Auth::hasAccess() && FreshRSS_Context::$user_conf->email_validation_token !== '';
+ $action_is_allowed = (
+ Minz_Request::is('user', 'validateEmail') ||
+ Minz_Request::is('user', 'sendValidationEmail') ||
+ Minz_Request::is('user', 'profile') ||
+ Minz_Request::is('auth', 'logout')
+ );
+ if ($email_not_verified && !$action_is_allowed) {
+ Minz_Request::forward(array(
+ 'c' => 'user',
+ 'a' => 'validateEmail',
+ ), true);
+ }
+ }
}