2019-12-08 23:18:29 +08:00
|
|
|
package model
|
|
|
|
|
2019-12-10 17:57:57 +08:00
|
|
|
import (
|
2024-10-17 21:03:03 +08:00
|
|
|
"log"
|
2024-08-12 10:06:55 +08:00
|
|
|
"sync"
|
2020-10-24 21:29:05 +08:00
|
|
|
"time"
|
|
|
|
|
2024-10-20 00:32:55 +08:00
|
|
|
"gorm.io/gorm"
|
|
|
|
|
2022-03-18 23:13:22 +08:00
|
|
|
"github.com/naiba/nezha/pkg/utils"
|
2020-11-11 10:07:45 +08:00
|
|
|
pb "github.com/naiba/nezha/proto"
|
2019-12-10 17:57:57 +08:00
|
|
|
)
|
|
|
|
|
2019-12-08 23:18:29 +08:00
|
|
|
type Server struct {
|
|
|
|
Common
|
2024-10-17 21:03:03 +08:00
|
|
|
|
2024-11-16 20:57:03 +08:00
|
|
|
Name string `json:"name"`
|
2024-10-20 23:23:04 +08:00
|
|
|
UUID string `json:"uuid,omitempty" gorm:"unique"`
|
|
|
|
Note string `json:"note,omitempty"` // 管理员可见备注
|
|
|
|
PublicNote string `json:"public_note,omitempty"` // 公开备注
|
2024-11-16 20:57:03 +08:00
|
|
|
DisplayIndex int `json:"display_index"` // 展示排序,越大越靠前
|
2024-10-20 23:23:04 +08:00
|
|
|
HideForGuest bool `json:"hide_for_guest,omitempty"` // 对游客隐藏
|
|
|
|
EnableDDNS bool `json:"enable_ddns,omitempty"` // 启用DDNS
|
2024-10-17 21:03:03 +08:00
|
|
|
DDNSProfilesRaw string `gorm:"default:'[]';column:ddns_profiles_raw" json:"-"`
|
2021-01-17 22:05:59 +08:00
|
|
|
|
2024-11-16 20:57:03 +08:00
|
|
|
DDNSProfiles []uint64 `gorm:"-" json:"ddns_profiles"` // DDNS配置
|
2024-10-20 23:23:04 +08:00
|
|
|
|
|
|
|
Host *Host `gorm:"-" json:"host,omitempty"`
|
|
|
|
State *HostState `gorm:"-" json:"state,omitempty"`
|
2024-11-22 22:40:43 +08:00
|
|
|
GeoIP *GeoIP `gorm:"-" json:"geoip,omitempty"`
|
2024-10-20 23:23:04 +08:00
|
|
|
LastActive time.Time `gorm:"-" json:"last_active,omitempty"`
|
2019-12-10 17:57:57 +08:00
|
|
|
|
2024-08-12 10:06:55 +08:00
|
|
|
TaskClose chan error `gorm:"-" json:"-"`
|
|
|
|
TaskCloseLock *sync.Mutex `gorm:"-" json:"-"`
|
|
|
|
TaskStream pb.NezhaService_RequestTaskServer `gorm:"-" json:"-"`
|
2021-07-14 23:53:37 +08:00
|
|
|
|
2024-08-11 10:35:19 +08:00
|
|
|
PrevTransferInSnapshot int64 `gorm:"-" json:"-"` // 上次数据点时的入站使用量
|
|
|
|
PrevTransferOutSnapshot int64 `gorm:"-" json:"-"` // 上次数据点时的出站使用量
|
2019-12-08 23:18:29 +08:00
|
|
|
}
|
2020-12-09 10:27:00 +08:00
|
|
|
|
2021-07-25 23:50:08 +08:00
|
|
|
func (s *Server) CopyFromRunningServer(old *Server) {
|
|
|
|
s.Host = old.Host
|
|
|
|
s.State = old.State
|
2024-11-22 22:40:43 +08:00
|
|
|
s.GeoIP = old.GeoIP
|
2021-07-25 23:50:08 +08:00
|
|
|
s.LastActive = old.LastActive
|
|
|
|
s.TaskClose = old.TaskClose
|
2024-08-12 10:06:55 +08:00
|
|
|
s.TaskCloseLock = old.TaskCloseLock
|
2021-07-25 23:50:08 +08:00
|
|
|
s.TaskStream = old.TaskStream
|
2024-08-11 10:35:19 +08:00
|
|
|
s.PrevTransferInSnapshot = old.PrevTransferInSnapshot
|
|
|
|
s.PrevTransferOutSnapshot = old.PrevTransferOutSnapshot
|
2021-07-25 23:50:08 +08:00
|
|
|
}
|
|
|
|
|
2024-10-17 21:03:03 +08:00
|
|
|
func (s *Server) AfterFind(tx *gorm.DB) error {
|
|
|
|
if s.DDNSProfilesRaw != "" {
|
|
|
|
if err := utils.Json.Unmarshal([]byte(s.DDNSProfilesRaw), &s.DDNSProfiles); err != nil {
|
|
|
|
log.Println("NEZHA>> Server.AfterFind:", err)
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|