X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=plugins%2FRequireValidatedEmail%2FRequireValidatedEmailPlugin.php;h=b3ae574f16e752fcae9d4bc1409529eff16e3997;hb=d6b28c64830f632bb2f4b6f3c9369b9e56ad217a;hp=0deba68579dd4f0e349ca248fdc1563a6a64b9f1;hpb=e47d9ad50d16bbb23088da41c8448ab32ee97d97;p=quix0rs-gnu-social.git diff --git a/plugins/RequireValidatedEmail/RequireValidatedEmailPlugin.php b/plugins/RequireValidatedEmail/RequireValidatedEmailPlugin.php index 0deba68579..b3ae574f16 100644 --- a/plugins/RequireValidatedEmail/RequireValidatedEmailPlugin.php +++ b/plugins/RequireValidatedEmail/RequireValidatedEmailPlugin.php @@ -80,21 +80,7 @@ class RequireValidatedEmailPlugin extends Plugin */ public $disallowLogin = false; - function onAutoload($cls) - { - $dir = dirname(__FILE__); - - switch ($cls) - { - case 'ConfirmfirstemailAction': - include_once $dir . '/' . strtolower(mb_substr($cls, 0, -6)) . '.php'; - return false; - default: - return true; - } - } - - function onRouterInitialized($m) + public function onRouterInitialized(URLMapper $m) { $m->connect('main/confirmfirst/:code', array('action' => 'confirmfirstemail')); @@ -109,15 +95,18 @@ class RequireValidatedEmailPlugin extends Plugin * * @return bool hook result code */ - function onStartNoticeSave($notice) + public function onStartNoticeSave(Notice $notice) { - $user = User::staticGet('id', $notice->profile_id); - if (!empty($user)) { // it's a remote notice - if (!$this->validated($user)) { - // TRANS: Client exception thrown when trying to post notices before validating an e-mail address. - $msg = _m('You must validate your email address before posting.'); - throw new ClientException($msg); - } + $author = $notice->getProfile(); + if (!$author->isLocal()) { + // remote notice + return true; + } + $user = $author->getUser(); + if (!$this->validated($user)) { + // TRANS: Client exception thrown when trying to post notices before validating an e-mail address. + $msg = _m('You must validate your email address before posting.'); + throw new ClientException($msg); } return true; } @@ -130,7 +119,7 @@ class RequireValidatedEmailPlugin extends Plugin * * @return bool hook result code */ - function onStartRegisterUser(&$user, &$profile) + function onStartRegisterUser(User &$user, Profile &$profile) { $email = $user->email; @@ -150,7 +139,7 @@ class RequireValidatedEmailPlugin extends Plugin * * @return bool */ - protected function validated($user) + protected function validated(User $user) { // The email field is only stored after validation... // Until then you'll find them in confirm_address. @@ -176,7 +165,7 @@ class RequireValidatedEmailPlugin extends Plugin * * @return bool true if user is grandfathered */ - protected function grandfathered($user) + protected function grandfathered(User $user) { if ($this->grandfatherCutoff) { $created = strtotime($user->created . " GMT"); @@ -197,7 +186,7 @@ class RequireValidatedEmailPlugin extends Plugin * * @return bool true if user has a trusted OpenID. */ - function hasTrustedOpenID($user) + function hasTrustedOpenID(User $user) { if ($this->trustedOpenIDs && class_exists('User_openid')) { foreach ($this->trustedOpenIDs as $regex) { @@ -223,11 +212,11 @@ class RequireValidatedEmailPlugin extends Plugin * * @return boolean hook value */ - function onPluginVersion(&$versions) + function onPluginVersion(array &$versions) { $versions[] = array('name' => 'Require Validated Email', - 'version' => STATUSNET_VERSION, + 'version' => GNUSOCIAL_VERSION, 'author' => 'Craig Andrews, '. 'Evan Prodromou, '. 'Brion Vibber', @@ -272,7 +261,7 @@ class RequireValidatedEmailPlugin extends Plugin { if ($right == Right::CREATEGROUP || ($this->disallowLogin && ($right == Right::WEBLOGIN || $right == Right::API))) { - $user = User::staticGet('id', $profile->id); + $user = User::getKV('id', $profile->id); if ($user && !$this->validated($user)) { $result = false; return false;