query()->insertGetId($data); // 如果操作失败 if( !$id ) return $id; // 更新缓存 $this->getList(true); // 返回结果 return $id; } /** * 添加数据 * */ public function edit($id,$data) { // 更新时间 $data['update_time'] = time(); // 写入数据表 $result = $this->query()->where(['uid'=>$id])->update($data); // 如果操作失败 if( !$result ) return $result; // 更新缓存 $this->getList(true); // 返回结果 return $result; } /** * 获取列表 * @param Bool $force 是否强制更新 * */ public function getList($force = false) { // 结果数据 $list = $force ? [] : cache('admin:user:list'); // 不存在数据 if ( !$list ) { // 从数据库获取数据 $data = $this->query()->where(['status'=>0])->get(['uid','username','phone','status','password','insert_time','update_time']); // 是否有数据 $data = $data ? $data->toArray() : []; // 循环处理数据 $list = []; // 进行更新 foreach ($data as $value) { // 重组数据 $list[$value['uid']] = $value; } // 存起来 cache(['admin:user:list'=>$list]); } // 返回结果 return $list; } /** * 获取配置平台对应的应用数据 * * @param int 用户ID * @param string 指定字段 * */ public function getOne($id,$field='') { // 获取列表数据 $list = $this->getList(); // 获取数据 $one = isset($list[$id]) ? $list[$id] : []; // 返回值 return empty($field) ? $one : ( isset($one[$field]) ? $one[$field] : null); } /** * 获取配置平台对应的应用数据 * * @param string 用户ID * @param string 指定字段 * */ public function getByName($name,$field='') { // 获取列表数据 $list = $this->getList(); // 获取单个 $one = []; // 循环管理员 foreach ($list as $value) { // 符合条件 if( $name == $value['username'] ) { // 获取数据 $one = $value; // 结束循环 break; } } // 返回值 return empty($field) ? $one : ( isset($one[$field]) ? $one[$field] : null); } /** * 小组成员 * * @param Array 用户组ID * */ public function getUserByGroups($groupIds){ // 获取小组成员 $userList = $this->query()->join('auth_group_access','admin.uid','=','auth_group_access.user_uid')->where([['admin.status','=','0']])->whereIn('auth_group_access.group_id',$groupIds)->groupBy('auth_group_access.user_uid')->get(['admin.uid','admin.username','admin.phone','admin.nickname','admin.email','admin.password','admin.project_uid','admin.saler_uid'])->toArray(); // 返回结果 return $userList; } }