kefu/models/ipblacks.go

65 lines
1.4 KiB
Go
Raw Permalink Normal View History

2024-12-10 02:50:12 +00:00
package models
import (
"kefu/types"
"time"
)
type Ipblack struct {
ID uint `gorm:"primary_key" json:"id"`
IP string `json:"ip"`
Name string `json:"name"`
KefuId string `json:"kefu_id"`
EntId string `json:"ent_id"`
CreateAt types.Time `json:"create_at"`
}
func CreateIpblack(ip string, kefuId, name, entId string) uint {
black := &Ipblack{
IP: ip,
KefuId: kefuId,
Name: name,
EntId: entId,
CreateAt: types.Time{time.Now()},
}
DB.Create(black)
return black.ID
}
func DeleteIpblackByIp(ip string) {
DB.Where("ip = ?", ip).Delete(&Ipblack{})
}
func FindIp(ip string) Ipblack {
var ipblack Ipblack
DB.Where("ip = ?", ip).First(&ipblack)
return ipblack
}
func FindIpsByKefuId(id string) []Ipblack {
var ipblack []Ipblack
DB.Where("kefu_id = ?", id).Find(&ipblack)
return ipblack
}
func FindIps(query interface{}, args []interface{}, page uint, pagesize uint) []Ipblack {
offset := (page - 1) * pagesize
if offset < 0 {
offset = 0
}
var ipblacks []Ipblack
if query != nil {
DB.Where(query, args...).Offset(offset).Limit(pagesize).Find(&ipblacks)
} else {
DB.Offset(offset).Limit(pagesize).Find(&ipblacks)
}
return ipblacks
}
//查询条数
func CountIps(query interface{}, args []interface{}) uint {
var count uint
if query != nil {
DB.Model(&Ipblack{}).Where(query, args...).Count(&count)
} else {
DB.Model(&Ipblack{}).Count(&count)
}
return count
}