feat: 添加操作日志列表接口

This commit is contained in:
2025-03-10 17:01:32 +08:00
parent 6b641d381c
commit 26fde9a362
3 changed files with 76 additions and 0 deletions

View 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);
}
}

View File

@@ -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);
}
}
}
} }

View File

@@ -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() {