You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
146 lines
3.8 KiB
146 lines
3.8 KiB
<?php
|
|
|
|
namespace app\admin\controller\auth;
|
|
|
|
use app\admin\model\AuthGroup;
|
|
use app\common\controller\Backend;
|
|
|
|
/**
|
|
* 管理员日志
|
|
*
|
|
* @icon fa fa-users
|
|
* @remark 管理员可以查看自己所拥有的权限的管理员日志
|
|
*/
|
|
class Adminlog extends Backend
|
|
{
|
|
|
|
/**
|
|
* @var \app\admin\model\AdminLog
|
|
*/
|
|
protected $model = null;
|
|
protected $childrenGroupIds = [];
|
|
protected $childrenAdminIds = [];
|
|
|
|
public function _initialize()
|
|
{
|
|
parent::_initialize();
|
|
$this->model = model('AdminLog');
|
|
|
|
$this->childrenAdminIds = $this->auth->getChildrenAdminIds(true);
|
|
$this->childrenGroupIds = $this->auth->getChildrenGroupIds(true);
|
|
|
|
$groupName = AuthGroup::where('id', 'in', $this->childrenGroupIds)
|
|
->column('id,name');
|
|
|
|
$this->view->assign('groupdata', $groupName);
|
|
}
|
|
|
|
/**
|
|
* 查看
|
|
*/
|
|
public function index()
|
|
{
|
|
//设置过滤方法
|
|
$this->request->filter(['strip_tags', 'trim']);
|
|
if ($this->request->isAjax()) {
|
|
list($where, $sort, $order, $offset, $limit) = $this->buildparams();
|
|
$isSuperAdmin = $this->auth->isSuperAdmin();
|
|
$childrenAdminIds = $this->childrenAdminIds;
|
|
$list = $this->model
|
|
->where($where)
|
|
->where(function ($query) use ($isSuperAdmin, $childrenAdminIds) {
|
|
if (!$isSuperAdmin) {
|
|
$query->where('admin_id', 'in', $childrenAdminIds);
|
|
}
|
|
})
|
|
->field('content,useragent', true)
|
|
->order($sort, $order)
|
|
->paginate($limit);
|
|
|
|
$result = array("total" => $list->total(), "rows" => $list->items());
|
|
|
|
return json($result);
|
|
}
|
|
return $this->view->fetch();
|
|
}
|
|
|
|
/**
|
|
* 详情
|
|
*/
|
|
public function detail($ids)
|
|
{
|
|
$row = $this->model->get(['id' => $ids]);
|
|
if (!$row) {
|
|
$this->error(__('No Results were found'));
|
|
}
|
|
if (!$this->auth->isSuperAdmin()) {
|
|
if (!$row['admin_id'] || !in_array($row['admin_id'], $this->childrenAdminIds)) {
|
|
$this->error(__('You have no permission'));
|
|
}
|
|
}
|
|
$this->view->assign("row", $row->toArray());
|
|
return $this->view->fetch();
|
|
}
|
|
|
|
/**
|
|
* 添加
|
|
* @internal
|
|
*/
|
|
public function add()
|
|
{
|
|
$this->error();
|
|
}
|
|
|
|
/**
|
|
* 编辑
|
|
* @internal
|
|
*/
|
|
public function edit($ids = null)
|
|
{
|
|
$this->error();
|
|
}
|
|
|
|
/**
|
|
* 删除
|
|
*/
|
|
public function del($ids = "")
|
|
{
|
|
if (!$this->request->isPost()) {
|
|
$this->error(__("Invalid parameters"));
|
|
}
|
|
$ids = $ids ? $ids : $this->request->post("ids");
|
|
if ($ids) {
|
|
$isSuperAdmin = $this->auth->isSuperAdmin();
|
|
$childrenAdminIds = $this->childrenAdminIds;
|
|
$adminList = $this->model->where('id', 'in', $ids)
|
|
->where(function ($query) use ($isSuperAdmin, $childrenAdminIds) {
|
|
if (!$isSuperAdmin) {
|
|
$query->where('admin_id', 'in', $childrenAdminIds);
|
|
}
|
|
})
|
|
->select();
|
|
if ($adminList) {
|
|
$deleteIds = [];
|
|
foreach ($adminList as $k => $v) {
|
|
$deleteIds[] = $v->id;
|
|
}
|
|
if ($deleteIds) {
|
|
$this->model->destroy($deleteIds);
|
|
$this->success();
|
|
}
|
|
}
|
|
}
|
|
$this->error();
|
|
}
|
|
|
|
/**
|
|
* 批量更新
|
|
* @internal
|
|
*/
|
|
public function multi($ids = "")
|
|
{
|
|
// 管理员禁止批量操作
|
|
$this->error();
|
|
}
|
|
|
|
}
|
|
|