package dbdata import ( "encoding/json" "time" ) type Group struct { Id int `json:"id" xorm:"pk autoincr not null"` Name string `json:"name" xorm:"varchar(60) not null unique"` Note string `json:"note" xorm:"varchar(255)"` AllowLan bool `json:"allow_lan" xorm:"Bool"` ClientDns []ValData `json:"client_dns" xorm:"Text"` RouteInclude []ValData `json:"route_include" xorm:"Text"` RouteExclude []ValData `json:"route_exclude" xorm:"Text"` LinkAcl []GroupLinkAcl `json:"link_acl" xorm:"Text"` Bandwidth int `json:"bandwidth" xorm:"Int"` // 带宽限制 Status int8 `json:"status" xorm:"Int"` // 1正常 CreatedAt time.Time `json:"created_at" xorm:"DateTime created"` UpdatedAt time.Time `json:"updated_at" xorm:"DateTime updated"` } type User struct { Id int `json:"id" xorm:"pk autoincr not null"` Username string `json:"username" xorm:"varchar(60) not null unique"` Nickname string `json:"nickname" xorm:"varchar(255)"` Email string `json:"email" xorm:"varchar(255)"` // Password string `json:"password"` PinCode string `json:"pin_code" xorm:"varchar(32)"` OtpSecret string `json:"otp_secret" xorm:"varchar(255)"` DisableOtp bool `json:"disable_otp" xorm:"Bool"` // 禁用otp Groups []string `json:"groups" xorm:"Text"` Status int8 `json:"status" xorm:"Int"` // 1正常 SendEmail bool `json:"send_email" xorm:"Bool"` CreatedAt time.Time `json:"created_at" xorm:"DateTime created"` UpdatedAt time.Time `json:"updated_at" xorm:"DateTime updated"` } type IpMap struct { Id int `json:"id" xorm:"pk autoincr not null"` IpAddr string `json:"ip_addr" xorm:"varchar(32) not null unique"` MacAddr string `json:"mac_addr" xorm:"varchar(32) not null unique"` Username string `json:"username" xorm:"varchar(60)"` Keep bool `json:"keep" xorm:"Bool"` // 保留 ip-mac 绑定 KeepTime time.Time `json:"keep_time" xorm:"DateTime"` Note string `json:"note" xorm:"varchar(255)"` // 备注 LastLogin time.Time `json:"last_login" xorm:"DateTime updated"` UpdatedAt time.Time `json:"updated_at" xorm:"DateTime updated"` } type Setting struct { Id int `json:"id" xorm:"pk autoincr not null"` Name string `json:"name" xorm:"varchar(60) not null unique"` Data json.RawMessage `json:"data" xorm:"Text"` UpdatedAt time.Time `json:"updated_at" xorm:"DateTime updated"` } type AccessAudit struct { Id int `json:"id" xorm:"pk autoincr not null"` Username string `json:"username" xorm:"varchar(60) not null"` Protocol uint8 `json:"protocol" xorm:"not null"` Src string `json:"src" xorm:"varchar(60) not null"` SrcPort uint16 `json:"src_port" xorm:"not null"` Dst string `json:"dst" xorm:"varchar(60) not null"` DstPort uint16 `json:"dst_port" xorm:"not null"` CreatedAt time.Time `json:"created_at" xorm:"DateTime"` }