文件输出

This commit is contained in:
TsMask
2023-08-24 20:37:19 +08:00
parent 7377143dd5
commit bfeb98bb9b
2 changed files with 101 additions and 16 deletions

View File

@@ -45,7 +45,7 @@ func (s *ReqSyncAlarmFile) Handle(request ziface.IRequest) {
fmt.Println(endTime)
}
alarmSeq, alarmSeqOk := body.Data["alarmSeq"]
if !alarmSeqOk {
if !alarmSeqOk || alarmSeq == "" {
fmt.Println(alarmSeq)
alarmSeq = "0"
}
@@ -76,11 +76,15 @@ func (s *ReqSyncAlarmFile) Handle(request ziface.IRequest) {
seq = 0
}
//check alarmSeq 是否存在
// check alarmSeq 是否存在
neBind, _ := parse.ConvertBindFlag(m.BindFlag)
alarmSeqCount := service.AlarmSeqCount(neBind.NeType, neBind.NeId, int64(seq))
if alarmSeqCount > 0 {
alarm, err := service.ListForSaveFile(neBind.NeType, neBind.NeId, int64(seq), startTime, endTime, syncSource)
if err != nil {
zlog.Ins().ErrorF("no permissions ")
request.GetConnection().SendMsg(ReqSyncAlarmFileType, core.ResultError(ReqSyncAlarmFileName, "no permissions", reqId))
return
}
if len(alarm) > 0 {
request.GetConnection().SendMsg(ReqSyncAlarmFileResultType, core.Result(ReqSyncAlarmFileResultName, map[string]string{
"reqId": reqId,
"result": "succ",

View File

@@ -1,9 +1,11 @@
package service
import (
"errors"
"omc/core/db"
"omc/core/emun"
"omc/handle/model"
"time"
"github.com/aceld/zinx/zlog"
)
@@ -11,11 +13,11 @@ import (
// AlarmSeqCount alarm_seq大于等于的记录数
func AlarmSeqCount(neType, neId string, alarmSeq int64) int64 {
var num int64
tx := db.Client.Model(&model.Alarm{}).Where("ne_type = ? and ne_id = ?", neType, neId)
query := db.Client.Model(&model.Alarm{}).Where("ne_type = ? and ne_id = ?", neType, neId)
if alarmSeq > 0 {
tx = tx.Where("alarm_seq >= ?", alarmSeq)
query = query.Where("alarm_seq >= ?", alarmSeq)
}
if err := tx.Order("alarm_seq desc").Count(&num).Error; err != nil {
if err := query.Order("alarm_seq desc").Count(&num).Error; err != nil {
zlog.Ins().ErrorF("HasAlarmSeq db error %s", err)
return num
}
@@ -85,26 +87,105 @@ func LastAlarmSeq(neType, neId string) int64 {
// List 获取告警信息为文件保存
func ListForSaveFile(neType, neId string, alarmSeq int64, startTime, endTime, syncSource string) ([]model.Alarm, error) {
// 基于OMC数据库的存量活动告警数据文件
if syncSource == "0" {
// 取告警发生的时间即告警本身的event_time
return alarmByEventTime(neType, neId, startTime, endTime)
} else {
}
// 基于告警消息日志的告警消息流水数据文件
if syncSource == "1" {
if alarmSeq > 0 {
return GetAlarmOfAlarmSeq(neType, neId, alarmSeq)
// 只适用于syncSource=1的情况 同步告警的起始告警消息序号
return alarmByAlarmSeq(neType, neId, alarmSeq)
} else {
return GetAlarmOfLog(neType, neId, startTime, endTime)
// 取北向接口记录日志流水的时间
return alarmByLog(neType, neId, startTime, endTime)
}
}
return []model.Alarm{}, nil
}
// 从数据库读取告警记录
// 取告警发生的时间即告警本身的event_time
func alarmByEventTime(neType, neId, startTime, endTime string) ([]model.Alarm, error) {
var alarms []model.Alarm
if err := db.Client.Model(&model.Alarm{}).Where("ne_type = ? and ne_id = ? and alarm_seq >= ?", neType, neId, alarmSeq).Order("alarm_seq asc").Find(&alarms).Error; err != nil {
zlog.Ins().ErrorF("AlarmList db error %s", err)
if startTime == "" && endTime == "" {
return alarms, nil
}
query := db.Client.Model(&model.Alarm{}).Where("ne_type = ? and ne_id = ?", neType, neId)
// 从当前告警中最早的开始
if startTime != "" {
startT, err := time.Parse("2006-01-02 15:04:05", startTime)
if err != nil {
return nil, errors.New("startTime invalid")
}
query = query.Where("event_time >= ?", startT)
}
// 取到当前最新的告警截止
if endTime != "" {
endT, err := time.Parse("2006-01-02 15:04:05", endTime)
if err != nil {
return nil, errors.New("endTime invalid")
}
query = query.Where("event_time <= ?", endT)
}
// 查询
if err := query.Order("alarm_seq asc").Find(&alarms).Error; err != nil {
return nil, err
}
return alarms, nil
}
func alarmByEventTime(startTime, endTime string) {
// 同步告警的起始告警消息序号
func alarmByAlarmSeq(neType, neId string, alarmSeq int64) ([]model.Alarm, error) {
var alarms []model.Alarm
// 查询
query := db.Client.Model(&model.Alarm{}).Where("ne_type = ? and ne_id = ? and alarm_seq >= ?", neType, neId, alarmSeq)
if err := query.Order("alarm_seq asc").Find(&alarms).Error; err != nil {
return nil, err
}
return alarms, nil
}
}
// 取北向接口记录日志流水的时间
func alarmByLog(neType, neId, startTime, endTime string) ([]model.Alarm, error) {
var alarms []model.Alarm
if startTime == "" && endTime == "" {
return alarms, nil
}
var aIDs []int64
query := db.Client.Model(&model.NbiAlarmLog{}).Select("distinct a_id").Where("ne_type = ? and ne_id = ?", neType, neId)
// 从当前告警中最早的开始
if startTime != "" {
startT, err := time.Parse("2006-01-02 15:04:05", startTime)
if err != nil {
return nil, errors.New("startTime invalid")
}
query = query.Where("log_time >= ?", startT)
}
// 取到当前最新的告警截止
if endTime != "" {
endT, err := time.Parse("2006-01-02 15:04:05", endTime)
if err != nil {
return nil, errors.New("endTime invalid")
}
query = query.Where("log_time <= ?", endT)
}
// 查询记录日志流水的id组
if err := query.Order("alarm_seq asc").Find(&aIDs).Error; err != nil {
return nil, err
}
// 查询告警本身的记录
if err := db.Client.Model(&model.Alarm{}).Where("id in (?)", aIDs).Find(&alarms).Error; err != nil {
return nil, err
}
return alarms, nil
}