123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081 |
- package schema
- import (
- "context"
- "time"
- "github.com/gravitl/netmaker/db"
- "github.com/gravitl/netmaker/models"
- "gorm.io/datatypes"
- )
- type Event struct {
- ID string `gorm:"primaryKey" json:"id"`
- Action models.Action `gorm:"action" json:"action"`
- Source datatypes.JSON `gorm:"source" json:"source"`
- Origin models.Origin `gorm:"origin" json:"origin"`
- Target datatypes.JSON `gorm:"target" json:"target"`
- NetworkID models.NetworkID `gorm:"network_id" json:"network_id"`
- TriggeredBy string `gorm:"triggered_by" json:"triggered_by"`
- Diff datatypes.JSON `gorm:"diff" json:"diff"`
- TimeStamp time.Time `gorm:"time_stamp" json:"time_stamp"`
- }
- func (a *Event) Get(ctx context.Context) error {
- return db.FromContext(ctx).Model(&Event{}).First(&a).Where("id = ?", a.ID).Error
- }
- func (a *Event) Update(ctx context.Context) error {
- return db.FromContext(ctx).Model(&Event{}).Where("id = ?", a.ID).Updates(&a).Error
- }
- func (a *Event) Create(ctx context.Context) error {
- return db.FromContext(ctx).Model(&Event{}).Create(&a).Error
- }
- func (a *Event) ListByNetwork(ctx context.Context, from, to time.Time) (ats []Event, err error) {
- if !from.IsZero() && !to.IsZero() {
- // "created_at BETWEEN ? AND ?
- err = db.FromContext(ctx).Model(&Event{}).Where("network_id = ? AND time_stamp BETWEEN ? AND ?",
- a.NetworkID, from, to).Order("time_stamp DESC").Find(&ats).Error
- return
- }
- err = db.FromContext(ctx).Model(&Event{}).Where("network_id = ?", a.NetworkID).Order("time_stamp DESC").Find(&ats).Error
- return
- }
- func (a *Event) ListByUser(ctx context.Context, from, to time.Time) (ats []Event, err error) {
- if !from.IsZero() && !to.IsZero() {
- err = db.FromContext(ctx).Model(&Event{}).Where("triggered_by = ? AND time_stamp BETWEEN ? AND ?",
- a.TriggeredBy, from, to).Order("time_stamp DESC").Find(&ats).Error
- return
- }
- err = db.FromContext(ctx).Model(&Event{}).Where("triggered_by = ?", a.TriggeredBy).Order("time_stamp DESC").Find(&ats).Error
- return
- }
- func (a *Event) ListByUserAndNetwork(ctx context.Context, from, to time.Time) (ats []Event, err error) {
- if !from.IsZero() && !to.IsZero() {
- err = db.FromContext(ctx).Model(&Event{}).Where("network_id = ? AND triggered_by = ? AND time_stamp BETWEEN ? AND ?",
- a.NetworkID, a.TriggeredBy, from, to).Order("time_stamp DESC").Find(&ats).Error
- return
- }
- err = db.FromContext(ctx).Model(&Event{}).Where("network_id = ? AND triggered_by = ?",
- a.NetworkID, a.TriggeredBy).Order("time_stamp DESC").Find(&ats).Error
- return
- }
- func (a *Event) List(ctx context.Context, from, to time.Time) (ats []Event, err error) {
- if !from.IsZero() && !to.IsZero() {
- err = db.FromContext(ctx).Model(&Event{}).Where("time_stamp BETWEEN ? AND ?", from, to).Order("time_stamp DESC").Find(&ats).Error
- return
- }
- err = db.FromContext(ctx).Model(&Event{}).Order("time_stamp DESC").Find(&ats).Error
- return
- }
- func (a *Event) DeleteOldEvents(ctx context.Context, retentionDays int) error {
- cutoff := time.Now().AddDate(0, 0, -retentionDays)
- return db.FromContext(ctx).Model(&Event{}).Where("created_at < ?", cutoff).Delete(&Event{}).Error
- }
|