1
0
mirror of https://gitee.com/koogua/course-tencent-cloud.git synced 2025-06-30 06:11:38 +08:00
winzer 62964bbd95 Merge branch 'winzer/I2EJH8' into demo
# Conflicts:
#	app/Console/Tasks/CleanLogTask.php
#	app/Console/Tasks/DeliverTask.php
#	app/Console/Tasks/NoticeTask.php
#	app/Http/Admin/Services/AuthNode.php
#	app/Http/Admin/Services/Setting.php
#	app/Http/Api/Services/Account.php
#	app/Library/Utils/Lock.php
#	app/Listeners/Trade.php
#	app/Listeners/User.php
#	app/Models/Course.php
#	app/Models/Online.php
#	app/Models/UserSession.php
#	app/Models/UserToken.php
#	app/Services/Auth/Api.php
#	app/Services/Auth/Home.php
2021-02-13 19:09:30 +08:00

126 lines
2.9 KiB
PHP

<?php
namespace App\Http\Home\Services;
use App\Models\User as UserModel;
use App\Repos\User as UserRepo;
use App\Services\Auth\Home as AuthService;
use App\Services\Logic\Account\Register as RegisterService;
use App\Services\Logic\Notice\AccountLogin as AccountLoginNoticeService;
use App\Validators\Account as AccountValidator;
use App\Validators\Captcha as CaptchaValidator;
use Phalcon\Di as Di;
use Phalcon\Events\Manager as EventsManager;
class Account extends Service
{
/**
* @var AuthService
*/
protected $auth;
public function __construct()
{
$this->auth = $this->getDI()->get('auth');
}
public function register()
{
$service = new RegisterService();
$account = $service->handle();
$userRepo = new UserRepo();
$user = $userRepo->findById($account->id);
$this->auth->saveAuthInfo($user);
$this->fireAfterRegisterEvent($user);
return $user;
}
public function loginByPassword()
{
$post = $this->request->getPost();
$validator = new AccountValidator();
$user = $validator->checkUserLogin($post['account'], $post['password']);
$validator = new CaptchaValidator();
$validator->checkCode($post['ticket'], $post['rand']);
$this->handleLoginNotice($user);
$this->auth->saveAuthInfo($user);
$this->fireAfterLoginEvent($user);
}
public function loginByVerify()
{
$post = $this->request->getPost();
$validator = new AccountValidator();
$user = $validator->checkVerifyLogin($post['account'], $post['verify_code']);
$this->handleLoginNotice($user);
$this->auth->saveAuthInfo($user);
$this->fireAfterLoginEvent($user);
}
public function logout()
{
$user = $this->getLoginUser();
$this->auth->clearAuthInfo();
$this->fireAfterLogoutEvent($user);
}
protected function fireAfterRegisterEvent(UserModel $user)
{
/**
* @var EventsManager $eventsManager
*/
$eventsManager = Di::getDefault()->getShared('eventsManager');
$eventsManager->fire('Account:afterRegister', $this, $user);
}
protected function fireAfterLoginEvent(UserModel $user)
{
/**
* @var EventsManager $eventsManager
*/
$eventsManager = Di::getDefault()->getShared('eventsManager');
$eventsManager->fire('Account:afterLogin', $this, $user);
}
protected function fireAfterLogoutEvent(UserModel $user)
{
/**
* @var EventsManager $eventsManager
*/
$eventsManager = Di::getDefault()->getShared('eventsManager');
$eventsManager->fire('Account:afterLogout', $this, $user);
}
protected function handleLoginNotice(UserModel $user)
{
$service = new AccountLoginNoticeService();
$service->createTask($user);
}
}