package singleton import ( "cmp" "slices" "sync" "github.com/nezhahq/nezha/model" "github.com/nezhahq/nezha/pkg/utils" ) var ( NATCache = make(map[string]*model.NAT) NATCacheRwLock sync.RWMutex NATIDToDomain = make(map[uint64]string) NATList []*model.NAT NATListLock sync.RWMutex ) func initNAT() { DB.Find(&NATList) NATCache = make(map[string]*model.NAT) for i := 0; i < len(NATList); i++ { NATCache[NATList[i].Domain] = NATList[i] NATIDToDomain[NATList[i].ID] = NATList[i].Domain } } func OnNATUpdate(n *model.NAT) { NATCacheRwLock.Lock() defer NATCacheRwLock.Unlock() if oldDomain, ok := NATIDToDomain[n.ID]; ok && oldDomain != n.Domain { delete(NATCache, oldDomain) } NATCache[n.Domain] = n NATIDToDomain[n.ID] = n.Domain } func OnNATDelete(id []uint64) { NATCacheRwLock.Lock() defer NATCacheRwLock.Unlock() for _, i := range id { if domain, ok := NATIDToDomain[i]; ok { delete(NATCache, domain) delete(NATIDToDomain, i) } } } func UpdateNATList() { NATCacheRwLock.RLock() defer NATCacheRwLock.RUnlock() NATListLock.Lock() defer NATListLock.Unlock() NATList = utils.MapValuesToSlice(NATCache) slices.SortFunc(NATList, func(a, b *model.NAT) int { return cmp.Compare(a.ID, b.ID) }) } func GetNATConfigByDomain(domain string) *model.NAT { NATCacheRwLock.RLock() defer NATCacheRwLock.RUnlock() return NATCache[domain] }