feat: 添加操作日志列表接口
This commit is contained in:
39
app/admin/controller/v1/OperateLog.php
Normal file
39
app/admin/controller/v1/OperateLog.php
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
<?php
|
||||||
|
declare (strict_types = 1);
|
||||||
|
|
||||||
|
namespace app\admin\controller\v1;
|
||||||
|
|
||||||
|
use app\admin\model\v1\SysOperateLog;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 操作日志控制器
|
||||||
|
*/
|
||||||
|
class OperateLog
|
||||||
|
{
|
||||||
|
// 分页
|
||||||
|
public function index()
|
||||||
|
{
|
||||||
|
$param = request()->param([
|
||||||
|
'title',
|
||||||
|
'created_at',
|
||||||
|
'page/d',
|
||||||
|
'size/d'
|
||||||
|
]);
|
||||||
|
|
||||||
|
$logs = SysOperateLog::with(['user' => function($query) {
|
||||||
|
$query->field(['id', 'username']);
|
||||||
|
}])
|
||||||
|
->withSearch(['title', 'created_at'], [
|
||||||
|
'title' => $param['title'] ?? null,
|
||||||
|
'created_at' => $param['created_at'] ?? null
|
||||||
|
])
|
||||||
|
->paginate([
|
||||||
|
'list_rows' => $param['size'] ?? 10,
|
||||||
|
'page' => $param['page'] ?? 1,
|
||||||
|
])
|
||||||
|
->bindAttr('user', ['username'])
|
||||||
|
->hidden(['user_id', 'user']);
|
||||||
|
|
||||||
|
return success('获取成功', $logs);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -32,4 +32,35 @@ class SysOperateLog extends Model
|
|||||||
'message' => 'string',
|
'message' => 'string',
|
||||||
'created_at' => 'datetime'
|
'created_at' => 'datetime'
|
||||||
];
|
];
|
||||||
|
|
||||||
|
// 关联操作人
|
||||||
|
public function user()
|
||||||
|
{
|
||||||
|
return $this->belongsTo(SysUserModel::class, 'user_id', 'id');
|
||||||
|
}
|
||||||
|
|
||||||
|
// 按标题搜索
|
||||||
|
public function searchTitleAttr($query, $value, $data)
|
||||||
|
{
|
||||||
|
if (empty($value)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
$query->where('title', 'like', "%$value%");
|
||||||
|
}
|
||||||
|
|
||||||
|
// 按操作时间搜索
|
||||||
|
public function searchCreatedAtAttr($query, $value, $data)
|
||||||
|
{
|
||||||
|
if (empty($value)) return;
|
||||||
|
if (is_string($value)) {
|
||||||
|
$value = explode(',', $value);
|
||||||
|
}
|
||||||
|
if (is_array($value)) {
|
||||||
|
if (count($value) == 2) {
|
||||||
|
$query->whereBetweenTime('created_at', $value[0], $value[1]);
|
||||||
|
} else {
|
||||||
|
$query->whereTime('created_at', '>=', $value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -488,6 +488,12 @@ Route::group('v1', function () {
|
|||||||
Route::put('update', 'SiteConfig/update');
|
Route::put('update', 'SiteConfig/update');
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// 日志管理
|
||||||
|
Route::group('logs', function() {
|
||||||
|
// 操作日志列表
|
||||||
|
Route::get('operate/index', 'OperateLog/index');
|
||||||
|
});
|
||||||
})->prefix('v1.');
|
})->prefix('v1.');
|
||||||
|
|
||||||
Route::miss(function() {
|
Route::miss(function() {
|
||||||
|
|||||||
Reference in New Issue
Block a user