mirror of
https://gitee.com/apiadmin/ApiAdmin.git
synced 2025-04-06 03:58:00 +08:00
239 lines
7.9 KiB
PHP
239 lines
7.9 KiB
PHP
<?php
|
|
/**
|
|
*
|
|
* @since 2018-02-06
|
|
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
|
*/
|
|
|
|
namespace app\admin\controller;
|
|
|
|
|
|
use app\model\ApiAuthGroupAccess;
|
|
use app\model\ApiUser;
|
|
use app\model\ApiUserData;
|
|
use app\util\ReturnCode;
|
|
use app\util\Tools;
|
|
|
|
class User extends Base {
|
|
|
|
/**
|
|
* 获取用户列表
|
|
* @return array
|
|
* @throws \think\db\exception\DataNotFoundException
|
|
* @throws \think\db\exception\ModelNotFoundException
|
|
* @throws \think\exception\DbException
|
|
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
|
*/
|
|
public function index() {
|
|
|
|
$limit = $this->request->get('size', config('apiAdmin.ADMIN_LIST_DEFAULT'));
|
|
$start = $limit * ($this->request->get('page', 1) - 1);
|
|
$type = $this->request->get('type', '');
|
|
$keywords = $this->request->get('keywords', '');
|
|
$status = $this->request->get('status', '');
|
|
|
|
$where = [];
|
|
if ($status === '1' || $status === '0') {
|
|
$where['status'] = $status;
|
|
}
|
|
if ($type) {
|
|
switch ($type) {
|
|
case 1:
|
|
$where['username'] = ['like', "%{$keywords}%"];
|
|
break;
|
|
case 2:
|
|
$where['nickname'] = ['like', "%{$keywords}%"];
|
|
break;
|
|
}
|
|
}
|
|
|
|
$listInfo = (new ApiUser())->where($where)->order('regTime', 'DESC')->limit($start, $limit)->select();
|
|
$count = (new ApiUser())->where($where)->count();
|
|
$listInfo = $this->buildArrFromObj($listInfo);
|
|
$idArr = array_column($listInfo, 'id');
|
|
|
|
$userData = ApiUserData::all(function($query) use ($idArr) {
|
|
$query->whereIn('uid', $idArr);
|
|
});
|
|
$userData = $this->buildArrFromObj($userData);
|
|
$userData = $this->buildArrByNewKey($userData, 'uid');
|
|
|
|
$userGroup = ApiAuthGroupAccess::all(function($query) use ($idArr) {
|
|
$query->whereIn('uid', $idArr);
|
|
});
|
|
$userGroup = $this->buildArrFromObj($userGroup);
|
|
$userGroup = $this->buildArrByNewKey($userGroup, 'uid');
|
|
|
|
foreach ($listInfo as $key => $value) {
|
|
if (isset($userData[$value['id']])) {
|
|
$listInfo[$key]['lastLoginIp'] = long2ip($userData[$value['id']]['lastLoginIp']);
|
|
$listInfo[$key]['loginTimes'] = $userData[$value['id']]['loginTimes'];
|
|
$listInfo[$key]['lastLoginTime'] = date('Y-m-d H:i:s', $userData[$value['id']]['lastLoginTime']);
|
|
}
|
|
$listInfo[$key]['regIp'] = long2ip($listInfo[$key]['regIp']);
|
|
if (isset($userGroup[$value['id']])) {
|
|
$listInfo[$key]['groupId'] = explode(',', $userGroup[$value['id']]['groupId']);
|
|
} else {
|
|
$listInfo[$key]['groupId'] = [];
|
|
}
|
|
}
|
|
|
|
return $this->buildSuccess([
|
|
'list' => $listInfo,
|
|
'count' => $count
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* 新增用户
|
|
* @return array
|
|
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
|
*/
|
|
public function add() {
|
|
$groups = '';
|
|
$postData = $this->request->post();
|
|
$postData['regIp'] = request()->ip(1);
|
|
$postData['regTime'] = time();
|
|
$postData['password'] = Tools::userMd5($postData['password']);
|
|
if ($postData['groupId']) {
|
|
$groups = implode(',', $postData['groupId']);
|
|
}
|
|
unset($postData['groupId']);
|
|
$res = ApiUser::create($postData);
|
|
if ($res === false) {
|
|
return $this->buildFailed(ReturnCode::DB_SAVE_ERROR, '操作失败');
|
|
} else {
|
|
ApiAuthGroupAccess::create([
|
|
'uid' => $res->id,
|
|
'groupId' => $groups
|
|
]);
|
|
|
|
return $this->buildSuccess([]);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 获取当前组的全部用户
|
|
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
|
* @return array
|
|
* @throws \think\db\exception\DataNotFoundException
|
|
* @throws \think\db\exception\ModelNotFoundException
|
|
* @throws \think\exception\DbException
|
|
*/
|
|
public function getUsers() {
|
|
$limit = $this->request->get('size', config('apiAdmin.ADMIN_LIST_DEFAULT'));
|
|
$start = $limit * ($this->request->get('page', 1) - 1);
|
|
$gid = $this->request->get('gid', 0);
|
|
if (!$gid) {
|
|
return $this->buildFailed(ReturnCode::PARAM_INVALID, '非法操作');
|
|
}
|
|
|
|
$listInfo = (new ApiAuthGroupAccess())->where(['groupId' => ['like', "%{$gid}%"]])->select();
|
|
$listInfo = $this->buildArrFromObj($listInfo);
|
|
$uidArr = array_column($listInfo, 'uid');
|
|
|
|
$userInfo = (new ApiUser())->whereIn('id', $uidArr)->order('regTime', 'DESC')->limit($start, $limit)->select();
|
|
$count = (new ApiUser())->whereIn('id', $uidArr)->count();
|
|
$userInfo = $this->buildArrFromObj($userInfo);
|
|
|
|
$userData = ApiUserData::all(function($query) use ($uidArr) {
|
|
$query->whereIn('uid', $uidArr);
|
|
});
|
|
$userData = $this->buildArrFromObj($userData);
|
|
$userData = $this->buildArrByNewKey($userData, 'uid');
|
|
|
|
foreach ($userInfo as $key => $value) {
|
|
if (isset($userData[$value['id']])) {
|
|
$userInfo[$key]['lastLoginIp'] = long2ip($userData[$value['id']]['lastLoginIp']);
|
|
$userInfo[$key]['loginTimes'] = $userData[$value['id']]['loginTimes'];
|
|
$userInfo[$key]['lastLoginTime'] = date('Y-m-d H:i:s', $userData[$value['id']]['lastLoginTime']);
|
|
}
|
|
$userInfo[$key]['regIp'] = long2ip($userInfo[$key]['regIp']);
|
|
}
|
|
|
|
return $this->buildSuccess([
|
|
'list' => $userInfo,
|
|
'count' => $count
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* 用户状态编辑
|
|
* @return array
|
|
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
|
*/
|
|
public function changeStatus() {
|
|
$id = $this->request->get('id');
|
|
$status = $this->request->get('status');
|
|
$res = ApiUser::update([
|
|
'id' => $id,
|
|
'status' => $status
|
|
]);
|
|
if ($res === false) {
|
|
return $this->buildFailed(ReturnCode::DB_SAVE_ERROR, '操作失败');
|
|
} else {
|
|
return $this->buildSuccess([]);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 编辑用户
|
|
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
|
* @return array
|
|
* @throws \think\exception\DbException
|
|
*/
|
|
public function edit() {
|
|
$groups = '';
|
|
$postData = $this->request->post();
|
|
$postData['regIp'] = request()->ip(1);
|
|
$postData['regTime'] = time();
|
|
if ($postData['password'] === 'ApiAdmin') {
|
|
unset($postData['password']);
|
|
} else {
|
|
$postData['password'] = Tools::userMd5($postData['password']);
|
|
}
|
|
if ($postData['groupId']) {
|
|
$groups = implode(',', $postData['groupId']);
|
|
}
|
|
unset($postData['groupId']);
|
|
$res = ApiUser::update($postData);
|
|
if ($res === false) {
|
|
return $this->buildFailed(ReturnCode::DB_SAVE_ERROR, '操作失败');
|
|
} else {
|
|
$has = ApiAuthGroupAccess::get(['uid' => $postData['id']]);
|
|
if($has){
|
|
ApiAuthGroupAccess::update([
|
|
'groupId' => $groups
|
|
], [
|
|
'uid' => $postData['id'],
|
|
]);
|
|
}else{
|
|
ApiAuthGroupAccess::create([
|
|
'uid' => $postData['id'],
|
|
'groupId' => $groups
|
|
]);
|
|
}
|
|
|
|
return $this->buildSuccess([]);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 删除用户
|
|
* @return array
|
|
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
|
*/
|
|
public function del() {
|
|
$id = $this->request->get('id');
|
|
if (!$id) {
|
|
return $this->buildFailed(ReturnCode::EMPTY_PARAMS, '缺少必要参数');
|
|
}
|
|
ApiUser::destroy($id);
|
|
ApiAuthGroupAccess::destroy(['uid' => $id]);
|
|
|
|
return $this->buildSuccess([]);
|
|
|
|
}
|
|
|
|
}
|