test_lgq/niucloud/app/service/api/login/AuthService.php

103 lines
3.7 KiB
PHP
Raw Normal View History

2024-01-24 17:36:08 +08:00
<?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;
}
}