Files
account/app/Services/System/LogService.php
2026-01-18 09:52:48 +08:00

114 lines
3.2 KiB
PHP

<?php
// +----------------------------------------------------------------------
// | SentCMS [ WE CAN DO IT JUST THINK IT ]
// +----------------------------------------------------------------------
// | Copyright (c) 2024 http://www.tensent.cn All rights reserved.
// +----------------------------------------------------------------------
// | Author: molong <molong@tensent.cn> <http://www.tensent.cn>
// +----------------------------------------------------------------------
namespace App\Services\System;
use App\Models\System\Log;
class LogService {
/**
* @title 获取日志列表
*
* @param [type] $request
* @return void
*/
public function getDataList($request) {
$map = [];
if ($request->filled('title')) {
$map[] = ['title', 'like', '%' . $request->input('title') . '%'];
}
if ($request->filled('name')) {
$map[] = ['name', 'like', '%' . $request->input('name') . '%'];
}
if ($request->filled('url')) {
$map[] = ['url', 'like', '%' . $request->input('url') . '%'];
}
if ($request->filled('method')) {
$map[] = ['method', 'like', '%' . $request->input('method') . '%'];
}
if ($request->filled('ip')) {
$map[] = ['ip', 'like', '%' . $request->input('ip') . '%'];
}
if ($request->filled('user_id')) {
$map[] = ['user_id', '=', $request->input('user_id')];
}
if ($request->filled('remark')) {
$map[] = ['remark', 'like', '%' . $request->input('remark') . '%'];
}
if ($request->filled('status')) {
$map[] = ['status', '=', $request->input('status')];
}
if ($request->filled('is_my')) {
$user = auth('admin')->user();
$map[] = ['user_id', '=', $user->uid];
}
$query = Log::with(['user:nickname,username,uid'])->where($map)->orderBy('id', 'desc');
if ($request->filled('date')) {
$query->whereBetween('created_at', $request->input('date'));
}
$data = [
'total' => $query->count(),
'page' => $request->input('page', 1),
'data' => $query->offset($request->input('offset', 0))->limit($request->input('limit', 10))->get(),
];
return $data;
}
public function createLog($request){
list($class, $method) = explode('@', $request->route()->getActionName());
$reflection = new \ReflectionMethod("\\" . $class, $method);
$docComment = $reflection->getDocComment();
$matches = [];
preg_match("/@title(.*)(\\r\\n|\\r|\\n)/U", $docComment, $matches);
$data = [
'user_id' => auth('admin')->user()->uid,
'title' => isset($matches[1]) ? trim($matches[1]) : '',
'name' => $request->route()->getName() ?? '',
'client_ip' => $request->ip(),
'url' => $request->path(),
'method' => $request->method(),
'data' => json_encode($request->all()),
'browser' => $request->userAgent(),
'remark' => $request->input('remark', ''),
'status' => 1,
];
$log = Log::create($data);
return $log;
}
/**
* @title 删除日志
* @param Request $request
* @return bool
*/
public function delete($request){
$map = [];
if($request->filled('id')){
$map[] = ['id', '=', $request->input('id')];
}
if($request->filled('ids')){
$map[] = ['id', 'IN', $request->input('ids')];
}
$query = Log::where($map);
if($request->filled('date')){
$query->whereBetween('created_at', $request->input('date'));
}
$query->delete();
return true;
}
}