Files
cloudpods/pkg/notify/models/event.go
2023-09-06 19:41:05 +08:00

100 lines
2.5 KiB
Go

// Copyright 2019 Yunion
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package models
import (
"context"
"strconv"
"time"
"yunion.io/x/pkg/errors"
"yunion.io/x/onecloud/pkg/cloudcommon/consts"
"yunion.io/x/onecloud/pkg/cloudcommon/db"
)
type SEventManager struct {
db.SLogBaseManager
}
var EventManager *SEventManager
func InitEventLog() {
EventManager = &SEventManager{
SLogBaseManager: db.NewLogBaseManager(SEvent{}, "events2_tbl", "notifyevent", "notifyevents", "created_at", consts.OpsLogWithClickhouse),
}
EventManager.SetVirtualObject(EventManager)
}
type SEvent struct {
db.SLogBase
// 资源创建时间
CreatedAt time.Time `nullable:"false" created_at:"true" index:"true" get:"user" list:"user" json:"created_at"`
Message string
Event string `width:"64" nullable:"true"`
ResourceType string `width:"64" nullable:"true"`
Action string `width:"64" nullable:"true"`
AdvanceDays int
TopicId string `width:"128" nullable:"true" index:"true"`
}
func (e *SEventManager) CreateEvent(ctx context.Context, event, topicId, message, action, resourceType string, advanceDays int) (*SEvent, error) {
eve := &SEvent{
Message: message,
Event: event,
AdvanceDays: advanceDays,
TopicId: topicId,
Action: action,
ResourceType: resourceType,
}
err := e.TableSpec().Insert(ctx, eve)
if err != nil {
return nil, err
}
return eve, nil
}
func (e *SEventManager) GetEvent(id string) (*SEvent, error) {
if len(id) == 0 {
return nil, nil
}
if consts.OpsLogWithClickhouse {
eventModel, err := e.FetchById(id)
if err != nil {
return nil, errors.Wrap(err, "fetch event by id")
}
event := eventModel.(*SEvent)
return event, nil
}
event := &SEvent{}
event.SetModelManager(EventManager, event)
eventId, err := strconv.Atoi(id)
if err != nil {
return nil, errors.Wrapf(err, "Atoi(%s)", id)
}
event.Id = int64(eventId)
err = EventManager.GetSplitTable().Fetch(event)
if err != nil {
return nil, err
}
return event, nil
}
func (e *SEvent) GetRecordTime() time.Time {
return e.CreatedAt
}