103 lines
3.7 KiB
PHP
103 lines
3.7 KiB
PHP
|
<?php
|
|||
|
// +----------------------------------------------------------------------
|
|||
|
// | Niucloud-admin 企业快速开发的saas管理平台
|
|||
|
// +----------------------------------------------------------------------
|
|||
|
// | 官方网址:https://www.niucloud-admin.com
|
|||
|
// +----------------------------------------------------------------------
|
|||
|
// | niucloud团队 版权所有 开源版本可自由商用
|
|||
|
// +----------------------------------------------------------------------
|
|||
|
// | Author: Niucloud Team
|
|||
|
// +----------------------------------------------------------------------
|
|||
|
|
|||
|
namespace app\service\api\login;
|
|||
|
|
|||
|
use app\dict\site\SiteDict;
|
|||
|
use app\model\member\Member;
|
|||
|
use app\Request;
|
|||
|
use app\service\api\member\MemberService;
|
|||
|
use app\service\core\site\CoreSiteService;
|
|||
|
use app\service\core\weapp\CoreWeappAuthService;
|
|||
|
use core\base\BaseApiService;
|
|||
|
use core\exception\ApiException;
|
|||
|
use core\exception\AuthException;
|
|||
|
|
|||
|
/**
|
|||
|
* 登录服务层
|
|||
|
* Class BaseService
|
|||
|
* @package app\service
|
|||
|
*/
|
|||
|
class AuthService extends BaseApiService
|
|||
|
{
|
|||
|
|
|||
|
public function __construct()
|
|||
|
{
|
|||
|
parent::__construct();
|
|||
|
$this->model = new Member();
|
|||
|
}
|
|||
|
|
|||
|
public function checkSiteAuth(Request $request){
|
|||
|
//如果登录信息非法就报错
|
|||
|
if($this->member_id > 0){
|
|||
|
$member_service = new MemberService();
|
|||
|
$member_info = $member_service->findMemberInfo(['member_id' => $this->member_id, 'site_id' => $this->site_id]);
|
|||
|
if($member_info->isEmpty())
|
|||
|
throw new AuthException('MEMBER_NOT_EXIST');
|
|||
|
}
|
|||
|
return true;
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* 检测站点的合法性
|
|||
|
* @param Request $request
|
|||
|
* @return true
|
|||
|
*/
|
|||
|
public function checkSite(Request $request){
|
|||
|
$site_id = $request->apiSiteId();//todo 可以是依赖传值,也可以通过domain域名来获取site_id
|
|||
|
$site_info = (new CoreSiteService())->getSiteCache($site_id);
|
|||
|
if(empty($site_info)) throw new AuthException('SITE_NOT_EXIST');
|
|||
|
$rule = strtolower(trim($request->rule()->getRule()));
|
|||
|
if($rule != 'site'){
|
|||
|
if ($site_info['status'] == SiteDict::CLOSE || $site_info['expire_time'] < time()) throw new AuthException('SITE_CLOSE_NOT_ALLOW');
|
|||
|
}
|
|||
|
$request->siteId($site_id);
|
|||
|
return true;
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* 绑定手机号
|
|||
|
* @param string $mobile
|
|||
|
* @param string $mobile_code
|
|||
|
* @return true
|
|||
|
*/
|
|||
|
public function bindMobile(string $mobile, string $mobile_code){
|
|||
|
|
|||
|
if(empty($mobile)){
|
|||
|
$result = (new CoreWeappAuthService())->getUserPhoneNumber($this->site_id, $mobile_code);
|
|||
|
if(empty($result)) throw new ApiException('WECHAT_EMPOWER_NOT_EXIST');
|
|||
|
$phone_info = $result['phone_info'];
|
|||
|
$mobile = $phone_info['purePhoneNumber'];
|
|||
|
if(empty($mobile)) throw new ApiException('WECHAT_EMPOWER_NOT_EXIST');
|
|||
|
}else{
|
|||
|
//todo 校验手机号验证码
|
|||
|
(new LoginService())->checkMobileCode($mobile);
|
|||
|
}
|
|||
|
$member_service = new MemberService();
|
|||
|
$member = $member_service->findMemberInfo(['member_id' => $this->member_id, 'site_id' => $this->site_id]);
|
|||
|
if($member->isEmpty()) throw new AuthException('MEMBER_NOT_EXIST');
|
|||
|
|
|||
|
$o_mobile = $member['mobile'];//原始手机号
|
|||
|
if(!empty($o_mobile)) throw new AuthException('MOBILE_IS_BIND_MEMBER');
|
|||
|
|
|||
|
$mobile_member = $member_service->findMemberInfo(['mobile' => $mobile, 'site_id' => $this->site_id]);
|
|||
|
if(!$mobile_member->isEmpty()) throw new AuthException('MOBILE_IS_EXIST');
|
|||
|
|
|||
|
// if(empty($mobile)) throw new AuthException('MOBILE_NEEDED');//必须填写
|
|||
|
$member->save([
|
|||
|
'mobile' => $mobile
|
|||
|
]);
|
|||
|
return true;
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
}
|