代码拉取完成,页面将自动刷新
package model
import (
"errors"
"time"
"gitee.com/linqwen/momo/app/conf/dao"
"gitee.com/linqwen/momo/base"
"gitee.com/linqwen/momo/cache"
"gorm.io/gorm"
)
func init() {
dao.ConfDb.AutoMigrate(&ClientEntity{})
initClientCache()
}
type ClientEntity struct {
base.SnowflakeIDModel
Status int `gorm:"column:status;type:int" json:"Status"`
Access int `gorm:"column:access;default:1" json:"Access" form:"Access" comment:"Access"`
Task int `gorm:"column:task;type:int" json:"Task"`
Cpu string `gorm:"column:cpu;size:255" json:"Cpu"`
Mem string `gorm:"column:mem;size:255" json:"Mem"`
Account string `gorm:"column:account;size:255" json:"Account"`
Name string `gorm:"column:name;size:255" json:"Name"`
Ip string `gorm:"column:ip;size:39;unique" json:"Ip"` // 对于MySQL和PostgreSQL使用varchar长度控制,SQLite仍不支持inet类型
}
func (ClientEntity) TableName() string { return "conf_client" }
func (s *ClientEntity) AfterSave(tx *gorm.DB) (err error) {
go initClientCache()
return nil
}
func (s *ClientEntity) AfterDelete(tx *gorm.DB) (err error) {
go initClientCache()
return nil
}
func initClientCache() {
time.Sleep(100 * time.Millisecond)
var objs []ClientEntity
var objmap = make(map[string]int)
if err := dao.ConfDb.Where("status = ?", 1).Find(&objs).Error; err != nil {
if errors.Is(err, gorm.ErrRecordNotFound) {
return
}
return
}
if len(objs) > 0 {
for _, a := range objs {
objmap[a.Ip] = a.Access
}
cache.SetCache("clientMap", objmap, time.Now().Add(365*24*time.Hour))
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。