81 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			PHP
		
	
	
		
		
			
		
	
	
			81 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			PHP
		
	
	
| 
								 | 
							
								<?php
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								namespace app\model;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								use think\facade\Db;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								class Member extends Base
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    public const STATUS_NORMAL  = 1;//正常
							 | 
						||
| 
								 | 
							
								    public const STATUS_DISABLE = 0;//禁用
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    public const ANENT_role_id = 2;//角色id 2 为代理商
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    public static function getList($limit = 40)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        return self::alias('m')
							 | 
						||
| 
								 | 
							
								            ->leftjoin('auth_group g', 'g.id=m.group_id')
							 | 
						||
| 
								 | 
							
								            ->field('m.id,m.username,m.login_time,m.group_id,g.title')
							 | 
						||
| 
								 | 
							
								            ->order('m.id', 'asc')
							 | 
						||
| 
								 | 
							
								            ->paginate($limit);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * 获取所有代理商
							 | 
						||
| 
								 | 
							
								     * */
							 | 
						||
| 
								 | 
							
								    public static  function getAgentAll(){
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        $subQuery = Db::name('member')
							 | 
						||
| 
								 | 
							
								            ->field('id,business_code,nickname')
							 | 
						||
| 
								 | 
							
								            ->whereRaw('(find_in_set("'.Member::ANENT_role_id.'", roles))')
							 | 
						||
| 
								 | 
							
								            ->buildSql();
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								       return Db::table($subQuery . ' a')
							 | 
						||
| 
								 | 
							
								            ->join("business b" ,"a.business_code = b.code")
							 | 
						||
| 
								 | 
							
								           ->field("a.*")
							 | 
						||
| 
								 | 
							
								            ->order('a.id', 'desc')
							 | 
						||
| 
								 | 
							
								            ->select();
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * 根据角色分组返回用户
							 | 
						||
| 
								 | 
							
								     * @param  int  $groupId  角色分组ID
							 | 
						||
| 
								 | 
							
								     * @param  int  $limit  每页数量
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public static function getListByGroup($groupId, $limit = 40)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        return self::alias('m')
							 | 
						||
| 
								 | 
							
								            ->leftjoin('auth_group g', 'g.id=m.group_id')
							 | 
						||
| 
								 | 
							
								            ->field('m.id,m.username,m.login_time,m.group_id,g.title')
							 | 
						||
| 
								 | 
							
								            ->where('m.group_id', '=', $groupId)
							 | 
						||
| 
								 | 
							
								            ->order('m.id', 'asc')
							 | 
						||
| 
								 | 
							
								            ->paginate($limit);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    //根据用户名获取管理账号
							 | 
						||
| 
								 | 
							
								    public static function getByUserName($username)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        return self::where('username', trim($username))
							 | 
						||
| 
								 | 
							
								            ->findOrEmpty()
							 | 
						||
| 
								 | 
							
								            ->toArray();
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    //根据ID获取管理账户和相关权限
							 | 
						||
| 
								 | 
							
								    public static function getMemberAndRulesByID($memberId)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        return self::alias('m')
							 | 
						||
| 
								 | 
							
								            ->join('auth_group g', 'm.group_id = g.id', 'LEFT')
							 | 
						||
| 
								 | 
							
								            ->field('m.group_id,g.rules')
							 | 
						||
| 
								 | 
							
								            ->where('m.id', $memberId)
							 | 
						||
| 
								 | 
							
								            ->findOrEmpty()
							 | 
						||
| 
								 | 
							
								            ->toArray();
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    public static function updateCates($id, $cates)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $cates = implode(',', $cates);
							 | 
						||
| 
								 | 
							
								        $data  = ['cates' => $cates];
							 | 
						||
| 
								 | 
							
								        self::updateById($id, $data);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 |