forked from linxGnu/goseaweedfs
-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathlookup.go
36 lines (28 loc) · 1002 Bytes
/
lookup.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
package goseaweedfs
import "math/rand"
// VolumeLocation location of volume responsed from master API. According to https://github.com/chrislusf/seaweedfs/wiki/Master-Server-API
type VolumeLocation struct {
URL string `json:"url,omitempty"`
PublicURL string `json:"publicUrl,omitempty"`
}
// VolumeLocations returned VolumeLocations (volumes)
type VolumeLocations []*VolumeLocation
// Head get first location in list
func (c VolumeLocations) Head() *VolumeLocation {
if len(c) == 0 {
return nil
}
return c[0]
}
// RandomPickForRead random pick a location for further read request
func (c VolumeLocations) RandomPickForRead() *VolumeLocation {
if len(c) == 0 {
return nil
}
return c[rand.Intn(len(c))]
}
// LookupResult the result of looking up volume. According to https://github.com/chrislusf/seaweedfs/wiki/Master-Server-API
type LookupResult struct {
VolumeLocations VolumeLocations `json:"locations,omitempty"`
Error string `json:"error,omitempty"`
}