Commit c35b011f authored by 黄智's avatar 黄智

调整字典

parent e332acf7
......@@ -20,7 +20,7 @@ type AddDictReq struct {
Class int `json:"class" form:"class" binding:"required,oneof=1 2 3 4 5 6 7 8 9 10 11 12 13 14"` //组件分类(1开发语言与版本 2中间件类型与中间件 3云组件类型 4模块类型 5所属区域 6操作系统 7对象类型 8SQL类型 9调研评估结果 10任务阶段 11测试文档类型 12验收问题类型 13Q&A问题类型 14文档类型)
ParentId string `json:"parent_id" form:"parent_id"` //父级ID
Name string `json:"name" form:"name" binding:"required"` //字典标签
Status int `json:"status" form:"status" binding:"oneof=0 1"` //是否启用(1:启用 2:禁用)
Status int `json:"status" form:"status" binding:"oneof=0 1 2"` //是否启用(1:启用 2:禁用)
Description string `json:"description" form:"description" binding:"lte=200"` //描述
MinVal string `json:"min_val" form:"min_val"` //最大值
MaxVal string `json:"max_val" form:"max_val"` //最小值
......@@ -31,7 +31,7 @@ type UpdateDictReq struct {
Id string `json:"id" form:"id" binding:"required"` //组件ID
ParentId string `json:"parent_id" form:"parent_id"` //父级ID
Name string `json:"name" form:"name" binding:"required"` //字典标签
Status int `json:"status" form:"status" binding:"oneof=0 1"` //是否启用(1:启用 2:禁用)
Status int `json:"status" form:"status" binding:"oneof=0 1 2"` //是否启用(1:启用 2:禁用)
Description string `json:"description" form:"description" binding:"lte=200"` //描述
MinVal string `json:"min_val" form:"min_val"` //最大值
MaxVal string `json:"max_val" form:"max_val"` //最小值
......@@ -44,7 +44,7 @@ type DictManageListReq struct {
Id string `json:"id" form:"id" binding:"required"` //组件ID
ParentId string `json:"parent_id" form:"parent_id"` //父级ID
Name string `json:"name" form:"name" binding:"required"` //字典标签
Status int `json:"status" form:"status" binding:"oneof=0 1"` //是否启用(1:启用 2:禁用)
Status int `json:"status" form:"status" binding:"oneof=0 1 2"` //是否启用(1:启用 2:禁用)
Description string `json:"description" form:"description" binding:"lte=200"` //描述
MinVal string `json:"min_val" form:"min_val"` //最大值
MaxVal string `json:"max_val" form:"max_val"` //最小值
......
package request
type LogManagementListReq struct {
Pagination //分页参数
Search string `json:"search" form:"search"` // 搜素
//IsAdmin int `json:"is_admin" form:"is_admin"` // 用户类型 (1.业务系统账号 2.组织管理员账号 3.平台用户账号 4.超级管理员)
StartAt string `json:"start_at" form:"start_at"` // 开始时间
EndAt string `json:"end_at" form:"end_at"` // 结束时间
Active int `json:"active" form:"active"` // 活跃度 1: 低 2:中 3: 高
PwdLevel int `json:"pwd_level" form:"pwd_level"` // 密码强度 1低2中3高
}
type LogUserBehaviorListReq struct {
Pagination //分页参数
Search string `json:"search" form:"search"` // 搜素
//IsAdmin int `json:"is_admin" form:"is_admin"` // 用户类型 (1.业务系统账号 2.组织管理员账号 3.平台用户账号 4.超级管理员)
StartAt string `json:"start_at" form:"start_at"` // 开始时间
EndAt string `json:"end_at" form:"end_at"` // 结束时间
OperateType string `json:"operate_type" form:"operate_type"` // 操作类型
ReqMethod int `json:"req_method" form:"req_method"` // 请求方式
OperateStatus int `json:"operate_status" form:"operate_status"` // 操作状态
}
type SystemLogListReq struct {
Pagination //分页参数
Search string `json:"search" form:"search"` // 搜素
Index string `json:"index" form:"index"` //索引名称
Level string `json:"level" form:"level"` //级别
}
......@@ -19,3 +19,13 @@ func (p Pagination) GetPageSize() int {
}
return p.PageSize
}
func (p Pagination) GetOffset() int {
if p.Page == 0 {
p.Page = 1
}
if p.PageSize == 0 {
p.PageSize = 15
}
return (p.Page - 1) * p.PageSize
}
package response
import (
"gitlab.wodcloud.com/smart-operation/so-operation-api/src/pkg/beagle/jsontime"
)
type LogManagementRep struct {
Id int32 `json:"id" xorm:"pk autoincr" ` // id
OrganizationId string `json:"organization_id" xorm:"organization_id"` // 所属组织
Name string `json:"name"` // 所属组织名称
SystemAccount string `json:"system_account" xorm:"system_account"` // 系统账号
ContactPhone string `json:"contact_phone" xorm:"contact_phone"` // 联系人电话
//IsAdmin string `json:"is_admin" xorm:"is_admin"` // 用户类型 (1.业务系统账号 2.组织管理员账号 3.平台用户账号 4.超级管理员)
LastAccessTimes jsontime.Time `json:"-" xorm:"last_access_time"` // 用户最后访问时间
LastAccessTime jsontime.Time `json:"last_access_time" xorm:"-"` // 用户最后访问时间
Active string `json:"active"` // 活跃度 高:小于等于7天,中:大于7天小于一个月,低:大于等于一个月 1: 低 2:中 3: 高
PwdLevel string `json:"pwd_level"` // 密码强度 1低2中3高
PwdIsUsed int `json:"pwd_is_used"` // 密码使用时长
CreatedTime jsontime.Time `json:"created_time" xorm:"created_time" ` // 创建时间
}
type SystemUserBehaviorList struct {
Xh int64 `json:"xh" xorm:"id"`
Id string `json:"id" xorm:"-"` // 主键id
UserId int `json:"user_id"` // 系统用户id
OrganizationId string `json:"organization_id"` // 组织uuid
SystemModule string `json:"system_module"` // 系统模块
OperateType string `json:"operate_type"` // 操作类型
ReqMethod int `json:"req_method"` // 请求方式
OperateStatus int `json:"operate_status"` // 操作状态
OperateIp string `json:"operate_ip"` // 操作ip信息
OperateAddr string `json:"operate_addr"` // 操作地点
CreatedTime jsontime.Time `json:"created_time" xorm:"created"` // 操作时间
IsDeleted int `json:"is_deleted"` // 是否删除
OperateMethod string `json:"operate_method"` // 操作方法函数名
ResFields string `json:"res_fields"` // 返回参数
ReqParam string `json:"req_param"` // 请求参数
ReqUrl string `json:"req_url"` // 请求地址
AppId string `json:"app_id"` // appId
SystemAccount string `json:"system_account"` // 系统账号
Phone string `json:"-" xorm:"phone"` // 手机号
//IsAdmin int `json:"is_admin"` // 用户类型
OrgName string `json:"org_name"` // 组织
}
type LogUserBehaviorDetailRep struct {
Id int `json:"id" xorm:"pk autoincr"` // 主键id
UserId int `json:"user_id"` // 系统用户id
OrganizationId string `json:"organization_id"` // 组织uuid
SystemModule string `json:"system_module"` // 系统模块
OperateType string `json:"operate_type"` // 操作类型
ReqMethod int `json:"req_method"` // 请求方式
ReqMethodStr string `json:"req_method_str" xorm:"-"`
OperateStatus int `json:"operate_status"` // 操作状态
OperateStatusStr string `json:"operate_status_str" xorm:"-"`
OperateIp string `json:"operate_ip"` // 操作ip信息
OperateAddr string `json:"operate_addr"` // 操作地点
CreatedTime jsontime.Time `json:"created_time" xorm:"created"` // 操作时间
OperateMethod string `json:"operate_method"` // 操作方法函数名
ResFields string `json:"res_fields"` // 返回参数
ReqParam string `json:"req_param"` // 请求参数
ReqUrl string `json:"req_url"` // 请求地址
AppId string `json:"app_id"` // appId
SystemAccount string `json:"system_account"` // 系统账号
Phone string `json:"phone"` // 手机号
//IsAdmin int `json:"-"` // 用户类型
//UserType string `json:"user_type" xorm:"-"`
OrgName string `json:"org_name"` // 组织
}
type SystemUserBehaviorInfo struct {
Total map[string]interface{} `json:"total"`
Hits []BehaviorSourceData `json:"hits"`
}
type BehaviorSourceData struct {
Id string `json:"_id"`
Source SystemUserBehaviorEs `json:"_source"`
}
type SystemUserBehaviorEs struct {
Id string `json:"id"`
Xh int64 `json:"xh"`
UserId int `json:"user_id"` // 系统用户id
OrganizationId string `json:"organization_id"` // 组织uuid
SystemModule string `json:"system_module"` // 系统模块
OperateType string `json:"operate_type"` // 操作类型
ReqMethod int `json:"req_method"` // 请求方式
OperateStatus int `json:"operate_status"` // 操作状态
OperateIp string `json:"operate_ip"` // 操作ip信息
OperateAddr string `json:"operate_addr"` // 操作地点
CreatedTime string `json:"created_time" xorm:"created"` // 操作时间
CreatedTimeUnix int64 `json:"created_time_unix"` // 操作时间戳(用于排序统计)
IsDeleted int `json:"is_deleted"` // 是否删除
OperateMethod string `json:"operate_method"` // 操作方法函数名
ResFields string `json:"res_fields"` // 返回参数
ReqParam string `json:"req_param"` // 请求参数
ReqUrl string `json:"req_url"` // 请求地址
AppId string `json:"app_id"` // appId
SystemAccount string `json:"system_account"` // 系统账号
Phone string `json:"phone" xorm:"phone"` // 手机号
IsAdmin int `json:"is_admin"` // 用户类型
OrgName string `json:"org_name"` // 组织
}
type SystemUserBehaviorToEs struct {
UserId int `json:"user_id"` // 系统用户id
OrganizationId string `json:"organization_id"` // 组织uuid
SystemModule string `json:"system_module"` // 系统模块
OperateType string `json:"operate_type"` // 操作类型
ReqMethod int `json:"req_method"` // 请求方式
OperateStatus int `json:"operate_status"` // 操作状态
OperateIp string `json:"operate_ip"` // 操作ip信息
OperateAddr string `json:"operate_addr"` // 操作地点
CreatedTime string `json:"created_time" xorm:"created"` // 操作时间
CreatedTimeUnix int64 `json:"created_time_unix"` // 操作时间戳(用于排序统计)
IsDeleted int `json:"is_deleted"` // 是否删除
OperateMethod string `json:"operate_method"` // 操作方法函数名
ResFields string `json:"res_fields"` // 返回参数
ReqParam string `json:"req_param"` // 请求参数
ReqUrl string `json:"req_url"` // 请求地址
AppId string `json:"app_id"` // appId
SystemAccount string `json:"system_account"` // 系统账号
Phone string `json:"phone" xorm:"phone"` // 手机号
//IsAdmin int `json:"is_admin"` // 用户类型
OrgName string `json:"org_name"` // 组织
}
type SystemUserInfoEs struct {
SystemAccount string `json:"system_account"` // 系统账号
Phone string `json:"-" xorm:"phone"` // 手机号
//IsAdmin int `json:"is_admin"` // 用户类型
OrgName string `json:"org_name"` // 组织
}
type BehaviorEsListInfo struct {
Total map[string]interface{} `json:"total"`
Hits []SourceData `json:"hits"`
}
type SourceData struct {
Id string `json:"_id"`
Source SystemUserBehaviorList `json:"_source"`
}
type SystemLogTree struct {
Id int `json:"id"`
Name string `json:"name"`
Value string `json:"value"`
}
type SystemLogEsListInfo struct {
Hits []SystemLogSourceData `json:"hits"`
}
type SystemLogSourceData struct {
Id string `json:"_id"`
Source SystemLogEsList `json:"_source"`
}
type SystemLogEsList struct {
Level string `json:"level"`
Timestamp string `json:"timestamp"`
Msg string `json:"msg"`
Status int `json:"status"`
Method string `json:"method"`
Path string `json:"path"`
Query string `json:"query"`
Ip string `json:"ip"`
UserAgent string `json:"user-agent"`
Errors string `json:"errors"`
Cost int `json:"cost"`
TimeUnit int64 `json:"time_unit"`
}
/**
* @Author: Y
* @Description:
* @File: xlsxSheet
* @Version: 1.0.0
* @Date: 2023/2/23 15:34
*/
package tools
import (
"errors"
"github.com/tealeg/xlsx"
)
type XlsxRow struct {
Row *xlsx.Row
Data []string
}
func NewRow(row *xlsx.Row, data []string) *XlsxRow {
return &XlsxRow{
Row: row,
Data: data,
}
}
func (row *XlsxRow) SetRowTitle() error {
return generateRow(row.Row, row.Data)
}
func (row *XlsxRow) GenerateRow() error {
return generateRow(row.Row, row.Data)
}
func generateRow(row *xlsx.Row, rowStr []string) error {
if rowStr == nil {
return errors.New("no data to generate xlsx!")
}
for _, v := range rowStr {
cell := row.AddCell()
cell.SetString(v)
}
return nil
}
package controller
import (
"fmt"
"github.com/gin-gonic/gin"
"gitlab.wodcloud.com/smart-operation/so-operation-api/src/bean/vo/request"
"gitlab.wodcloud.com/smart-operation/so-operation-api/src/pkg/beagle/resp"
"gitlab.wodcloud.com/smart-operation/so-operation-api/src/router/middleware/header"
"gitlab.wodcloud.com/smart-operation/so-operation-api/src/service"
"strings"
)
// 系统日志树
func GetSystemLoggerTree(c *gin.Context) {
func GetSystemLoggerList(c *gin.Context) {
search := c.Query("logTime")
svc := service.LogManagement{User: header.GetUser(c)}
if dir, err := svc.GetSysLogDir(search); err != nil {
......@@ -20,7 +23,7 @@ func GetSystemLoggerTree(c *gin.Context) {
// 系统日志
func GetSystemLog(c *gin.Context) {
name := c.Param("name")
name := c.Query("name")
search := c.Query("search")
logLevel := c.Query("logLevel")
svc := service.LogManagement{User: header.GetUser(c)}
......@@ -31,7 +34,84 @@ func GetSystemLog(c *gin.Context) {
}
}
// 用户账户审计列表
// 用户行为审计列表
func LogUserBehaviorList(c *gin.Context) {
params := request.LogUserBehaviorListReq{}
// 绑定分页数据
if err := c.ShouldBindQuery(&params); err != nil {
SendJsonResponse(c, resp.InvalidParam.WithError(err), nil)
return
}
svc := service.LogManagement{User: header.GetUser(c)}
var (
list interface{}
count int64
err error
)
list, count, err = svc.LogUserBehaviorList(&params)
if err != nil {
SendJsonResponse(c, err, nil)
return
}
SendJsonPageResponse(c, nil, list, count)
}
// 用户行为审计列表导出
func LogUserBehaviorListExport(c *gin.Context) {
params := request.LogUserBehaviorListReq{}
// 绑定分页数据
if err := c.ShouldBindQuery(&params); err != nil {
SendJsonResponse(c, resp.InvalidParam.WithError(err), nil)
return
}
// 分页数据初始化 limit page Offset
svc := service.LogManagement{User: header.GetUser(c)}
file, fileName, err := svc.LogUserBehaviorListExport(&params)
if err != nil {
SendJsonResponse(c, err, nil)
return
}
c.Writer.Header().Add("Content-Disposition", fmt.Sprintf("attachment; filename=%s", fileName)) //fmt.Sprintf("attachment; filename=%s", filename)对下载的文件重命名
c.Writer.Header().Add("Content-Type", "application/octet-stream")
c.Writer.Header().Add("Content-Transfer-Encoding", "binary")
_ = file.Write(c.Writer)
}
func LogUserBehaviorDetail(c *gin.Context) {
id := c.Param("id")
if id == "" {
SendJsonResponse(c, resp.InvalidParam.WithData("id必填"), nil)
return
}
svc := service.LogManagement{User: header.GetUser(c)}
data, err := svc.LogUserBehaviorDetail(id)
if err != nil {
SendJsonResponse(c, err, nil)
return
}
SendJsonResponse(c, nil, data)
}
func LogUserBehaviorDelete(c *gin.Context) {
ids := strings.Split(c.Query("ids"), ",")
if len(ids) == 0 {
SendJsonResponse(c, resp.InvalidParam.WithData("id必填"), nil)
return
}
svc := service.LogManagement{User: header.GetUser(c)}
err := svc.LogUserBehaviorDelete(ids)
if err != nil {
SendJsonResponse(c, err, nil)
return
}
SendJsonResponse(c, nil, "删除成功")
}
//用户账户审计列表
//func LogUserAccountAuditList(c *gin.Context) {
// params := request.LogManagementListReq{}
// // 绑定分页数据
......@@ -72,88 +152,3 @@ func GetSystemLog(c *gin.Context) {
// _ = file.Write(c.Writer)
//
//}
//
//// 用户行为审计列表
//func LogUserBehaviorList(c *gin.Context) {
// params := request.LogUserBehaviorListReq{}
// // 绑定分页数据
// if err := c.ShouldBindQuery(&params); err != nil {
// SendJsonResponse(c, res.ParamsParserError.ErrorDetail(err), nil)
// return
// }
// // 分页数据初始化 limit page Offset
// params.PageInfo = params.PageInfo.InitPage()
// svc := service.LogManagement{User: util.GetContextUser(c)}
// var (
// list interface{}
// count int64
// err error
// )
// //是否ES查询用户行为审计信息
// if conf.Options.IsBehaviorToES {
// list, count, err = svc.LogUserBehaviorListEs(&params)
// if err != nil {
// SendJsonResponse(c, err, nil)
// return
// }
// } else {
// list, count, err = svc.LogUserBehaviorList(&params)
// if err != nil {
// SendJsonResponse(c, err, nil)
// return
// }
// }
// SendJsonPageResponse(c, nil, list, count)
//}
//
//// 用户行为审计列表导出
//func LogUserBehaviorListExport(c *gin.Context) {
// params := request.LogUserBehaviorListReq{}
// // 绑定分页数据
// if err := c.ShouldBindQuery(&params); err != nil {
// SendJsonResponse(c, res.ParamsParserError.ErrorDetail(err), nil)
// return
// }
// // 分页数据初始化 limit page Offset
// params.PageInfo = params.PageInfo.InitPage()
// svc := service.LogManagement{User: util.GetContextUser(c)}
// file, fileName, err := svc.LogUserBehaviorListExport(&params)
// if err != nil {
// SendJsonResponse(c, err, nil)
// return
// }
// c.Writer.Header().Add("Content-Disposition", fmt.Sprintf("attachment; filename=%s", fileName)) //fmt.Sprintf("attachment; filename=%s", filename)对下载的文件重命名
// c.Writer.Header().Add("Content-Type", "application/octet-stream")
// c.Writer.Header().Add("Content-Transfer-Encoding", "binary")
// _ = file.Write(c.Writer)
//}
//
//func LogUserBehaviorDetail(c *gin.Context) {
// id := c.Param("id")
// if id == "" {
// SendJsonResponse(c, res.ParamsMissError.ErrorDetail(errors.New("id必填")), nil)
// return
// }
// svc := service.LogManagement{User: util.GetContextUser(c)}
// data, err := svc.LogUserBehaviorDetail(id)
// if err != nil {
// SendJsonResponse(c, err, nil)
// return
// }
// SendJsonResponse(c, nil, data)
//}
//
//func LogUserBehaviorDelete(c *gin.Context) {
// ids := strings.Split(c.Query("ids"), ",")
// if len(ids) == 0 {
// SendJsonResponse(c, res.ParamsMissError.ErrorDetail(errors.New("ids必填")), nil)
// return
// }
// svc := service.LogManagement{User: util.GetContextUser(c)}
// err := svc.LogUserBehaviorDelete(ids)
// if err != nil {
// SendJsonResponse(c, err, nil)
// return
// }
// SendJsonResponse(c, nil, "删除成功")
//}
......@@ -12,6 +12,19 @@ import (
var CSTZone = time.FixedZone("CST", 8*3600) // 固定东八区(CST: China Standard Time)
const (
LocalDateTimeFormat string = "2006-01-02 15:04:05"
LocalDateTimeFormat1 string = "2006/01/02 15:04:05"
LocalDateTimeFormatUTC string = "2006-01-02T15:04:05"
LocalDateTimeFormatUTCZ string = "2006-01-02T15:04:05Z"
LocalDateFormat string = "2006-01-02"
LocalDateFormatEs string = "20060102150405"
LocalDateFormat1 string = `20060102`
LocalMonthFormat string = "2006-01"
LocalMonthFormat1 string = "2006.01"
LocalTimeFormat string = "15:04:05"
)
// Time 自定义时间
// 设置当前时间: jsonDate := Time(time.Now())
type Time time.Time
......
......@@ -5,33 +5,37 @@ import (
"github.com/gin-gonic/gin"
"gitlab.wodcloud.com/smart-operation/so-operation-api/src/common/conf"
"gitlab.wodcloud.com/smart-operation/so-operation-api/src/controller"
"gitlab.wodcloud.com/smart-operation/so-operation-api/src/pkg/beagle/constant"
"gitlab.wodcloud.com/smart-operation/so-operation-api/src/router/middleware/header"
)
// 初始化日志管理路由
func InitLogManagementRouter(e *gin.Engine) {
logger := e.Group(fmt.Sprintf("%s/log", conf.Options.Prefix), header.SetContext)
logger := e.Group(fmt.Sprintf("%s/log", conf.Options.Prefix))
{
systemLog := logger.Group("/system", header.SetContext)
{
systemLog.GET("tree", controller.GetSystemLoggerTree) //系统日志树
systemLog.GET("list", controller.GetSystemLoggerList) //系统日志树
systemLog.GET("log", controller.GetSystemLog) //系统日志
}
//userAccountAudit := logger.Group("/userAccountAudit", header.SetUserToContext)
userBehavior := logger.Group("userBehavior", header.SetContext)
{
//用户行为审计:
userBehavior.GET("list", controller.LogUserBehaviorList, header.AddLogMiddleware("用户行为审计", "/list", constant.OpTypeIntMap[constant.Find])) //用户行为审计列表
userBehavior.GET("list/export", controller.LogUserBehaviorListExport, header.AddLogMiddleware("用户行为审计", "/export", constant.OpTypeIntMap[constant.Export])) //用户行为审计列表导出
userBehavior.GET("detail/:id", controller.LogUserBehaviorDetail) //用户行为审计详情
userBehavior.DELETE("delete", controller.LogUserBehaviorDelete) //用户行为审计删除
}
//userAccountAudit := logger.Group("/userAccountAudit", header.SetContext)
//{
// //用户账户审计:
// userAccountAudit.GET("list", controller.LogUserAccountAuditList, log.AddLogMiddleware("用户账户审计", "/list", constant.OpTypeIntMap[constant.Find])) //用户账户审计列表
// userAccountAudit.GET("list/export", controller.LogUserAccountAuditExport, log.AddLogMiddleware("用户账户审计", "/export", constant.OpTypeIntMap[constant.Export])) //用户账户审计列表导出
// userAccountAudit.GET("list", controller.LogUserAccountAuditList, header.AddLogMiddleware("用户账户审计", "/list", constant.OpTypeIntMap[constant.Find])) //用户账户审计列表
// userAccountAudit.GET("list/export", controller.LogUserAccountAuditExport, header.AddLogMiddleware("用户账户审计", "/export", constant.OpTypeIntMap[constant.Export])) //用户账户审计列表导出
//
//}
//userBehavior := logger.Group("userBehavior", header.SetUserToContext)
//{
// //用户行为审计:
// userBehavior.GET("list", controller.LogUserBehaviorList, log.AddLogMiddleware("用户行为审计", "/list", constant.OpTypeIntMap[constant.Find])) //用户行为审计列表
// userBehavior.GET("list/export", controller.LogUserBehaviorListExport, log.AddLogMiddleware("用户行为审计", "/export", constant.OpTypeIntMap[constant.Export])) //用户行为审计列表导出
// userBehavior.GET("detail/:id", controller.LogUserBehaviorDetail) //用户行为审计详情
// userBehavior.DELETE("delete", controller.LogUserBehaviorDelete) //用户行为审计删除
//}
}
}
This diff is collapsed.
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment