mirror of
https://github.com/TeaOSLab/EdgeAPI.git
synced 2025-11-09 12:00:25 +08:00
增加操作日志查看界面
This commit is contained in:
@@ -72,7 +72,7 @@ func (this *AdminDAO) ExistEnabledAdmin(adminId int64) (bool, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// 获取管理员名称
|
// 获取管理员名称
|
||||||
func (this *AdminDAO) FindAdminFullname(adminId int) (string, error) {
|
func (this *AdminDAO) FindAdminFullname(adminId int64) (string, error) {
|
||||||
return this.Query().
|
return this.Query().
|
||||||
Pk(adminId).
|
Pk(adminId).
|
||||||
Result("fullname").
|
Result("fullname").
|
||||||
|
|||||||
@@ -28,10 +28,28 @@ func init() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// 创建管理员日志
|
// 创建管理员日志
|
||||||
func (this *LogDAO) CreateAdminLog(adminId int64, level string, description string, action string, ip string) error {
|
func (this *LogDAO) CreateLog(adminType string, adminId int64, level string, description string, action string, ip string) error {
|
||||||
op := NewLogOperator()
|
op := NewLogOperator()
|
||||||
|
op.Type = adminType
|
||||||
op.AdminId, op.Level, op.Description, op.Action, op.Ip = adminId, level, description, action, ip
|
op.AdminId, op.Level, op.Description, op.Action, op.Ip = adminId, level, description, action, ip
|
||||||
op.Type = LogTypeAdmin
|
op.Type = LogTypeAdmin
|
||||||
_, err := this.Save(op)
|
_, err := this.Save(op)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 计算所有日志数量
|
||||||
|
func (this *LogDAO) CountAllLogs() (int64, error) {
|
||||||
|
return this.Query().
|
||||||
|
Count()
|
||||||
|
}
|
||||||
|
|
||||||
|
// 列出单页日志
|
||||||
|
func (this *LogDAO) ListLogs(offset int64, size int64) (result []*Log, err error) {
|
||||||
|
_, err = this.Query().
|
||||||
|
Offset(offset).
|
||||||
|
Limit(size).
|
||||||
|
Slice(&result).
|
||||||
|
DescPk().
|
||||||
|
FindAll()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|||||||
@@ -33,7 +33,7 @@ func init() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// 启用条目
|
// 启用条目
|
||||||
func (this *ProviderDAO) EnableProvider(id uint32) (rowsAffected int64, err error) {
|
func (this *ProviderDAO) EnableProvider(id int64) (rowsAffected int64, err error) {
|
||||||
return this.Query().
|
return this.Query().
|
||||||
Pk(id).
|
Pk(id).
|
||||||
Set("state", ProviderStateEnabled).
|
Set("state", ProviderStateEnabled).
|
||||||
@@ -41,7 +41,7 @@ func (this *ProviderDAO) EnableProvider(id uint32) (rowsAffected int64, err erro
|
|||||||
}
|
}
|
||||||
|
|
||||||
// 禁用条目
|
// 禁用条目
|
||||||
func (this *ProviderDAO) DisableProvider(id uint32) (rowsAffected int64, err error) {
|
func (this *ProviderDAO) DisableProvider(id int64) (rowsAffected int64, err error) {
|
||||||
return this.Query().
|
return this.Query().
|
||||||
Pk(id).
|
Pk(id).
|
||||||
Set("state", ProviderStateDisabled).
|
Set("state", ProviderStateDisabled).
|
||||||
@@ -49,7 +49,7 @@ func (this *ProviderDAO) DisableProvider(id uint32) (rowsAffected int64, err err
|
|||||||
}
|
}
|
||||||
|
|
||||||
// 查找启用中的条目
|
// 查找启用中的条目
|
||||||
func (this *ProviderDAO) FindEnabledProvider(id uint32) (*Provider, error) {
|
func (this *ProviderDAO) FindEnabledProvider(id int64) (*Provider, error) {
|
||||||
result, err := this.Query().
|
result, err := this.Query().
|
||||||
Pk(id).
|
Pk(id).
|
||||||
Attr("state", ProviderStateEnabled).
|
Attr("state", ProviderStateEnabled).
|
||||||
@@ -59,3 +59,11 @@ func (this *ProviderDAO) FindEnabledProvider(id uint32) (*Provider, error) {
|
|||||||
}
|
}
|
||||||
return result.(*Provider), err
|
return result.(*Provider), err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 查找供应商名称
|
||||||
|
func (this *ProviderDAO) FindProviderName(providerId int64) (string, error) {
|
||||||
|
return this.Query().
|
||||||
|
Pk(providerId).
|
||||||
|
Result("name").
|
||||||
|
FindStringCol("")
|
||||||
|
}
|
||||||
|
|||||||
@@ -59,3 +59,11 @@ func (this *UserDAO) FindEnabledUser(id uint32) (*User, error) {
|
|||||||
}
|
}
|
||||||
return result.(*User), err
|
return result.(*User), err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 获取管理员名称
|
||||||
|
func (this *UserDAO) FindUserFullname(userId int64) (string, error) {
|
||||||
|
return this.Query().
|
||||||
|
Pk(userId).
|
||||||
|
Result("fullname").
|
||||||
|
FindStringCol("")
|
||||||
|
}
|
||||||
|
|||||||
@@ -180,6 +180,7 @@ func (this *APINode) listenRPC(listener net.Listener, tlsConfig *tls.Config) err
|
|||||||
pb.RegisterRegionProvinceServiceServer(rpcServer, &services.RegionProvinceService{})
|
pb.RegisterRegionProvinceServiceServer(rpcServer, &services.RegionProvinceService{})
|
||||||
pb.RegisterIPListServiceServer(rpcServer, &services.IPListService{})
|
pb.RegisterIPListServiceServer(rpcServer, &services.IPListService{})
|
||||||
pb.RegisterIPItemServiceServer(rpcServer, &services.IPItemService{})
|
pb.RegisterIPItemServiceServer(rpcServer, &services.IPItemService{})
|
||||||
|
pb.RegisterLogServiceServer(rpcServer, &services.LogService{})
|
||||||
err := rpcServer.Serve(listener)
|
err := rpcServer.Serve(listener)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return errors.New("[API]start rpc failed: " + err.Error())
|
return errors.New("[API]start rpc failed: " + err.Error())
|
||||||
|
|||||||
@@ -48,19 +48,6 @@ func (this *AdminService) LoginAdmin(ctx context.Context, req *pb.LoginAdminRequ
|
|||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// 创建操作日志
|
|
||||||
func (this *AdminService) CreateAdminLog(ctx context.Context, req *pb.CreateAdminLogRequest) (*pb.CreateAdminLogResponse, error) {
|
|
||||||
_, userId, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
err = models.SharedLogDAO.CreateAdminLog(userId, req.Level, req.Description, req.Action, req.Ip)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return &pb.CreateAdminLogResponse{}, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// 检查管理员是否存在
|
// 检查管理员是否存在
|
||||||
func (this *AdminService) CheckAdminExists(ctx context.Context, req *pb.CheckAdminExistsRequest) (*pb.CheckAdminExistsResponse, error) {
|
func (this *AdminService) CheckAdminExists(ctx context.Context, req *pb.CheckAdminExistsRequest) (*pb.CheckAdminExistsResponse, error) {
|
||||||
_, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin)
|
_, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin)
|
||||||
@@ -108,7 +95,7 @@ func (this *AdminService) FindAdminFullname(ctx context.Context, req *pb.FindAdm
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
fullname, err := models.SharedAdminDAO.FindAdminFullname(int(req.AdminId))
|
fullname, err := models.SharedAdminDAO.FindAdminFullname(req.AdminId)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
utils.PrintError(err)
|
utils.PrintError(err)
|
||||||
return nil, err
|
return nil, err
|
||||||
|
|||||||
88
internal/rpc/services/service_log.go
Normal file
88
internal/rpc/services/service_log.go
Normal file
@@ -0,0 +1,88 @@
|
|||||||
|
package services
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"github.com/TeaOSLab/EdgeAPI/internal/db/models"
|
||||||
|
rpcutils "github.com/TeaOSLab/EdgeAPI/internal/rpc/utils"
|
||||||
|
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
|
||||||
|
)
|
||||||
|
|
||||||
|
// 管理员、用户或者其他系统用户日志
|
||||||
|
type LogService struct {
|
||||||
|
}
|
||||||
|
|
||||||
|
// 创建日志
|
||||||
|
func (this *LogService) CreateLog(ctx context.Context, req *pb.CreateLogRequest) (*pb.CreateLogResponse, error) {
|
||||||
|
// 校验请求
|
||||||
|
userType, userId, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin, rpcutils.UserTypeUser, rpcutils.UserTypeProvider)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
err = models.SharedLogDAO.CreateLog(userType, userId, req.Level, req.Description, req.Action, req.Ip)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return &pb.CreateLogResponse{}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// 计算日志数量
|
||||||
|
func (this *LogService) CountLogs(ctx context.Context, req *pb.CountLogRequest) (*pb.CountLogResponse, error) {
|
||||||
|
// 校验请求
|
||||||
|
_, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
count, err := models.SharedLogDAO.CountAllLogs()
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return &pb.CountLogResponse{Count: count}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// 列出单页日志
|
||||||
|
func (this *LogService) ListLogs(ctx context.Context, req *pb.ListLogsRequest) (*pb.ListLogsResponse, error) {
|
||||||
|
// 校验请求
|
||||||
|
_, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
logs, err := models.SharedLogDAO.ListLogs(req.Offset, req.Size)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
result := []*pb.Log{}
|
||||||
|
for _, log := range logs {
|
||||||
|
userName := ""
|
||||||
|
if log.AdminId > 0 {
|
||||||
|
userName, err = models.SharedAdminDAO.FindAdminFullname(int64(log.AdminId))
|
||||||
|
} else if log.UserId > 0 {
|
||||||
|
userName, err = models.SharedUserDAO.FindUserFullname(int64(log.UserId))
|
||||||
|
} else if log.ProviderId > 0 {
|
||||||
|
userName, err = models.SharedProviderDAO.FindProviderName(int64(log.ProviderId))
|
||||||
|
}
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
result = append(result, &pb.Log{
|
||||||
|
Id: int64(log.Id),
|
||||||
|
Level: log.Level,
|
||||||
|
Action: log.Action,
|
||||||
|
AdminId: int64(log.AdminId),
|
||||||
|
UserId: int64(log.UserId),
|
||||||
|
ProviderId: int64(log.ProviderId),
|
||||||
|
CreatedAt: int64(log.CreatedAt),
|
||||||
|
Type: log.Type,
|
||||||
|
Ip: log.Ip,
|
||||||
|
UserName: userName,
|
||||||
|
Description: log.Description,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
return &pb.ListLogsResponse{Logs: result}, nil
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user