
* refactor(server): 重构服务器启动和重载逻辑 将服务器启动和重载逻辑进行重构,提取初始化系统为单独函数,优化代码结构。删除冗余的服务器初始化文件,统一使用新的 `server_run.go` 实现优雅关闭和重载功能。同时,将“重启服务”改为“重载服务”以更准确地描述功能。 * refactor: 重构系统事件处理、JWT和Casbin相关逻辑 - 将系统重载逻辑提取到独立的`system_events.go`文件中,并引入全局事件管理器 - 将JWT相关操作从`service`层移动到`utils`层,减少服务层依赖 - 将Casbin实例管理逻辑提取到`utils`层,统一管理Casbin实例的初始化和获取 - 删除冗余的`CreateSysOperationRecord`方法,优化操作记录中间件逻辑 * refactor(server): 重构服务初始化和关闭逻辑 将 `RunServer` 函数重命名为 `initServer`,并调整其调用方式以简化代码。同时,在系统初始化时添加 `SetupHandlers` 函数以注册全局处理函数,提升代码可维护性。 * fix: 修复自动化代码enum查询条件的bug * fix: 修复组合模式下,顶部菜单重复bug * refactor: 修改名称 RunWindowsServer ==> RunServer * 新增mcp * feat: 支持mcp服务 * feat:调整mcp结构,增加客户端和测试用例 * feat:更换mcp基础包和结构 * feat:提交客户端工具测试用例 * feat: 增加自动创建 mcp Tool模板 功能 * fix: 增加默认值属性 * feat: 调整初始化menu的逻辑 * feat: 调整初始config.yaml * feat: 增加全局GVA_MCP_SERVER属性,方便灵活化开发。 * feat: 优化自动化mcp逻辑和成功展示 * feat: 优化mcp tool nickname工具 * feat: 发布2.8.2 Beta版本 --------- Co-authored-by: piexlMax(奇淼 <qimiaojiangjizhao@gmail.com> Co-authored-by: Gor-c <creup@outlook.com> Co-authored-by: QIN xiansheng <sjjlnaps@163.com>
84 lines
3.0 KiB
Go
84 lines
3.0 KiB
Go
package system
|
|
|
|
import (
|
|
"github.com/flipped-aurora/gin-vue-admin/server/global"
|
|
"github.com/flipped-aurora/gin-vue-admin/server/model/common/request"
|
|
"github.com/flipped-aurora/gin-vue-admin/server/model/system"
|
|
systemReq "github.com/flipped-aurora/gin-vue-admin/server/model/system/request"
|
|
)
|
|
|
|
//@author: [granty1](https://github.com/granty1)
|
|
//@function: CreateSysOperationRecord
|
|
//@description: 创建记录
|
|
//@param: sysOperationRecord model.SysOperationRecord
|
|
//@return: err error
|
|
|
|
type OperationRecordService struct{}
|
|
|
|
var OperationRecordServiceApp = new(OperationRecordService)
|
|
|
|
//@author: [granty1](https://github.com/granty1)
|
|
//@author: [piexlmax](https://github.com/piexlmax)
|
|
//@function: DeleteSysOperationRecordByIds
|
|
//@description: 批量删除记录
|
|
//@param: ids request.IdsReq
|
|
//@return: err error
|
|
|
|
func (operationRecordService *OperationRecordService) DeleteSysOperationRecordByIds(ids request.IdsReq) (err error) {
|
|
err = global.GVA_DB.Delete(&[]system.SysOperationRecord{}, "id in (?)", ids.Ids).Error
|
|
return err
|
|
}
|
|
|
|
//@author: [granty1](https://github.com/granty1)
|
|
//@function: DeleteSysOperationRecord
|
|
//@description: 删除操作记录
|
|
//@param: sysOperationRecord model.SysOperationRecord
|
|
//@return: err error
|
|
|
|
func (operationRecordService *OperationRecordService) DeleteSysOperationRecord(sysOperationRecord system.SysOperationRecord) (err error) {
|
|
err = global.GVA_DB.Delete(&sysOperationRecord).Error
|
|
return err
|
|
}
|
|
|
|
//@author: [granty1](https://github.com/granty1)
|
|
//@function: GetSysOperationRecord
|
|
//@description: 根据id获取单条操作记录
|
|
//@param: id uint
|
|
//@return: sysOperationRecord system.SysOperationRecord, err error
|
|
|
|
func (operationRecordService *OperationRecordService) GetSysOperationRecord(id uint) (sysOperationRecord system.SysOperationRecord, err error) {
|
|
err = global.GVA_DB.Where("id = ?", id).First(&sysOperationRecord).Error
|
|
return
|
|
}
|
|
|
|
//@author: [granty1](https://github.com/granty1)
|
|
//@author: [piexlmax](https://github.com/piexlmax)
|
|
//@function: GetSysOperationRecordInfoList
|
|
//@description: 分页获取操作记录列表
|
|
//@param: info systemReq.SysOperationRecordSearch
|
|
//@return: list interface{}, total int64, err error
|
|
|
|
func (operationRecordService *OperationRecordService) GetSysOperationRecordInfoList(info systemReq.SysOperationRecordSearch) (list interface{}, total int64, err error) {
|
|
limit := info.PageSize
|
|
offset := info.PageSize * (info.Page - 1)
|
|
// 创建db
|
|
db := global.GVA_DB.Model(&system.SysOperationRecord{})
|
|
var sysOperationRecords []system.SysOperationRecord
|
|
// 如果有条件搜索 下方会自动创建搜索语句
|
|
if info.Method != "" {
|
|
db = db.Where("method = ?", info.Method)
|
|
}
|
|
if info.Path != "" {
|
|
db = db.Where("path LIKE ?", "%"+info.Path+"%")
|
|
}
|
|
if info.Status != 0 {
|
|
db = db.Where("status = ?", info.Status)
|
|
}
|
|
err = db.Count(&total).Error
|
|
if err != nil {
|
|
return
|
|
}
|
|
err = db.Order("id desc").Limit(limit).Offset(offset).Preload("User").Find(&sysOperationRecords).Error
|
|
return sysOperationRecords, total, err
|
|
}
|