mirror of
https://gitcode.com/flipped-aurora/gin-vue-admin.git
synced 2025-12-30 11:52:26 +00:00
添加错误日志记录功能,包括API、路由、服务和前端接口 修复sysError相关变量名的拼写错误 更新依赖版本至go 1.24 使用自定义Recovery中间件记录panic信息 添加zap日志钩子将错误日志写入数据库
170 lines
5.2 KiB
Go
170 lines
5.2 KiB
Go
package system
|
|
|
|
import (
|
|
"github.com/flipped-aurora/gin-vue-admin/server/global"
|
|
"github.com/flipped-aurora/gin-vue-admin/server/model/common/response"
|
|
"github.com/flipped-aurora/gin-vue-admin/server/model/system"
|
|
systemReq "github.com/flipped-aurora/gin-vue-admin/server/model/system/request"
|
|
"github.com/gin-gonic/gin"
|
|
"go.uber.org/zap"
|
|
)
|
|
|
|
type SysErrorApi struct{}
|
|
|
|
// CreateSysError 创建错误日志
|
|
// @Tags SysError
|
|
// @Summary 创建错误日志
|
|
// @Security ApiKeyAuth
|
|
// @Accept application/json
|
|
// @Produce application/json
|
|
// @Param data body system.SysError true "创建错误日志"
|
|
// @Success 200 {object} response.Response{msg=string} "创建成功"
|
|
// @Router /sysError/createSysError [post]
|
|
func (sysErrorApi *SysErrorApi) CreateSysError(c *gin.Context) {
|
|
// 创建业务用Context
|
|
ctx := c.Request.Context()
|
|
|
|
var sysError system.SysError
|
|
err := c.ShouldBindJSON(&sysError)
|
|
if err != nil {
|
|
response.FailWithMessage(err.Error(), c)
|
|
return
|
|
}
|
|
err = sysErrorService.CreateSysError(ctx, &sysError)
|
|
if err != nil {
|
|
global.GVA_LOG.Error("创建失败!", zap.Error(err))
|
|
response.FailWithMessage("创建失败:"+err.Error(), c)
|
|
return
|
|
}
|
|
response.OkWithMessage("创建成功", c)
|
|
}
|
|
|
|
// DeleteSysError 删除错误日志
|
|
// @Tags SysError
|
|
// @Summary 删除错误日志
|
|
// @Security ApiKeyAuth
|
|
// @Accept application/json
|
|
// @Produce application/json
|
|
// @Param data body system.SysError true "删除错误日志"
|
|
// @Success 200 {object} response.Response{msg=string} "删除成功"
|
|
// @Router /sysError/deleteSysError [delete]
|
|
func (sysErrorApi *SysErrorApi) DeleteSysError(c *gin.Context) {
|
|
// 创建业务用Context
|
|
ctx := c.Request.Context()
|
|
|
|
ID := c.Query("ID")
|
|
err := sysErrorService.DeleteSysError(ctx, ID)
|
|
if err != nil {
|
|
global.GVA_LOG.Error("删除失败!", zap.Error(err))
|
|
response.FailWithMessage("删除失败:"+err.Error(), c)
|
|
return
|
|
}
|
|
response.OkWithMessage("删除成功", c)
|
|
}
|
|
|
|
// DeleteSysErrorByIds 批量删除错误日志
|
|
// @Tags SysError
|
|
// @Summary 批量删除错误日志
|
|
// @Security ApiKeyAuth
|
|
// @Accept application/json
|
|
// @Produce application/json
|
|
// @Success 200 {object} response.Response{msg=string} "批量删除成功"
|
|
// @Router /sysError/deleteSysErrorByIds [delete]
|
|
func (sysErrorApi *SysErrorApi) DeleteSysErrorByIds(c *gin.Context) {
|
|
// 创建业务用Context
|
|
ctx := c.Request.Context()
|
|
|
|
IDs := c.QueryArray("IDs[]")
|
|
err := sysErrorService.DeleteSysErrorByIds(ctx, IDs)
|
|
if err != nil {
|
|
global.GVA_LOG.Error("批量删除失败!", zap.Error(err))
|
|
response.FailWithMessage("批量删除失败:"+err.Error(), c)
|
|
return
|
|
}
|
|
response.OkWithMessage("批量删除成功", c)
|
|
}
|
|
|
|
// UpdateSysError 更新错误日志
|
|
// @Tags SysError
|
|
// @Summary 更新错误日志
|
|
// @Security ApiKeyAuth
|
|
// @Accept application/json
|
|
// @Produce application/json
|
|
// @Param data body system.SysError true "更新错误日志"
|
|
// @Success 200 {object} response.Response{msg=string} "更新成功"
|
|
// @Router /sysError/updateSysError [put]
|
|
func (sysErrorApi *SysErrorApi) UpdateSysError(c *gin.Context) {
|
|
// 从ctx获取标准context进行业务行为
|
|
ctx := c.Request.Context()
|
|
|
|
var sysError system.SysError
|
|
err := c.ShouldBindJSON(&sysError)
|
|
if err != nil {
|
|
response.FailWithMessage(err.Error(), c)
|
|
return
|
|
}
|
|
err = sysErrorService.UpdateSysError(ctx, sysError)
|
|
if err != nil {
|
|
global.GVA_LOG.Error("更新失败!", zap.Error(err))
|
|
response.FailWithMessage("更新失败:"+err.Error(), c)
|
|
return
|
|
}
|
|
response.OkWithMessage("更新成功", c)
|
|
}
|
|
|
|
// FindSysError 用id查询错误日志
|
|
// @Tags SysError
|
|
// @Summary 用id查询错误日志
|
|
// @Security ApiKeyAuth
|
|
// @Accept application/json
|
|
// @Produce application/json
|
|
// @Param ID query uint true "用id查询错误日志"
|
|
// @Success 200 {object} response.Response{data=system.SysError,msg=string} "查询成功"
|
|
// @Router /sysError/findSysError [get]
|
|
func (sysErrorApi *SysErrorApi) FindSysError(c *gin.Context) {
|
|
// 创建业务用Context
|
|
ctx := c.Request.Context()
|
|
|
|
ID := c.Query("ID")
|
|
resysError, err := sysErrorService.GetSysError(ctx, ID)
|
|
if err != nil {
|
|
global.GVA_LOG.Error("查询失败!", zap.Error(err))
|
|
response.FailWithMessage("查询失败:"+err.Error(), c)
|
|
return
|
|
}
|
|
response.OkWithData(resysError, c)
|
|
}
|
|
|
|
// GetSysErrorList 分页获取错误日志列表
|
|
// @Tags SysError
|
|
// @Summary 分页获取错误日志列表
|
|
// @Security ApiKeyAuth
|
|
// @Accept application/json
|
|
// @Produce application/json
|
|
// @Param data query systemReq.SysErrorSearch true "分页获取错误日志列表"
|
|
// @Success 200 {object} response.Response{data=response.PageResult,msg=string} "获取成功"
|
|
// @Router /sysError/getSysErrorList [get]
|
|
func (sysErrorApi *SysErrorApi) GetSysErrorList(c *gin.Context) {
|
|
// 创建业务用Context
|
|
ctx := c.Request.Context()
|
|
|
|
var pageInfo systemReq.SysErrorSearch
|
|
err := c.ShouldBindQuery(&pageInfo)
|
|
if err != nil {
|
|
response.FailWithMessage(err.Error(), c)
|
|
return
|
|
}
|
|
list, total, err := sysErrorService.GetSysErrorInfoList(ctx, pageInfo)
|
|
if err != nil {
|
|
global.GVA_LOG.Error("获取失败!", zap.Error(err))
|
|
response.FailWithMessage("获取失败:"+err.Error(), c)
|
|
return
|
|
}
|
|
response.OkWithDetailed(response.PageResult{
|
|
List: list,
|
|
Total: total,
|
|
Page: pageInfo.Page,
|
|
PageSize: pageInfo.PageSize,
|
|
}, "获取成功", c)
|
|
}
|