MasterClient replicates all vid locations

This commit is contained in:
Chris Lu
2018-07-28 14:22:46 -07:00
parent 01bcc89803
commit 1d779389cb
4 changed files with 83 additions and 12 deletions

59
weed/wdclient/vid_map.go Normal file
View File

@@ -0,0 +1,59 @@
package wdclient
import (
"sync"
)
type Location struct {
Url string `json:"url,omitempty"`
PublicUrl string `json:"publicUrl,omitempty"`
}
type VidMap struct {
sync.RWMutex
vid2Locations map[uint32][]Location
}
func (vc *VidMap) GetLocations(vid uint32) (locations []Location) {
vc.RLock()
defer vc.RUnlock()
return vc.vid2Locations[vid]
}
func (vc *VidMap) AddLocation(vid uint32, location Location) {
vc.Lock()
defer vc.Unlock()
locations, found := vc.vid2Locations[vid]
if !found {
vc.vid2Locations[vid] = []Location{location}
return
}
for _, loc := range locations {
if loc.Url == location.Url {
return
}
}
vc.vid2Locations[vid] = append(locations, location)
}
func (vc *VidMap) DeleteLocation(vid uint32, location Location) {
vc.Lock()
defer vc.Unlock()
locations, found := vc.vid2Locations[vid]
if !found {
return
}
for i, loc := range locations {
if loc.Url == location.Url {
vc.vid2Locations[vid] = append(locations[0:i], locations[i+1:]...)
}
}
}