cluster: sort regions, for jpictl dump sake
#37
@@ -56,6 +56,7 @@ func (m *Cluster) initRegions(_ *ScanOptions) error {
|
|||||||
|
|
||||||
// first regions defined by zones
|
// first regions defined by zones
|
||||||
m.ForEachZone(func(z *Zone) bool {
|
m.ForEachZone(func(z *Zone) bool {
|
||||||
|
SortRegions(z.Regions)
|
||||||
for _, region := range z.Regions {
|
for _, region := range z.Regions {
|
||||||
regions[region] = append(regions[region], z)
|
regions[region] = append(regions[region], z)
|
||||||
}
|
}
|
||||||
@@ -74,6 +75,7 @@ func (m *Cluster) initRegions(_ *ScanOptions) error {
|
|||||||
m.finishRegion(r)
|
m.finishRegion(r)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
m.sortRegions()
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,41 @@
|
|||||||
|
package cluster
|
||||||
|
|
||||||
|
import "sort"
|
||||||
|
|
||||||
|
// SortRegions sorts regions. first by length those 3-character
|
||||||
|
// or shorter, and then by length. It's mostly aimed at
|
||||||
|
// supporting ISO-3166 order
|
||||||
|
func SortRegions(regions []string) []string {
|
||||||
|
sort.Slice(regions, func(i, j int) bool {
|
||||||
|
r1, r2 := regions[i], regions[j]
|
||||||
|
return regionLess(r1, r2)
|
||||||
|
})
|
||||||
|
|
||||||
|
return regions
|
||||||
|
}
|
||||||
|
|
||||||
|
func regionLess(r1, r2 string) bool {
|
||||||
|
switch {
|
||||||
|
case len(r1) < 4:
|
||||||
|
switch {
|
||||||
|
case len(r1) < len(r2):
|
||||||
|
return true
|
||||||
|
case len(r1) > len(r2):
|
||||||
|
return false
|
||||||
|
default:
|
||||||
|
return r1 < r2
|
||||||
|
}
|
||||||
|
case len(r2) < 4:
|
||||||
|
return false
|
||||||
|
default:
|
||||||
|
return r1 < r2
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *Cluster) sortRegions() {
|
||||||
|
sort.Slice(m.Regions, func(i, j int) bool {
|
||||||
|
r1 := m.Regions[i].Name
|
||||||
|
r2 := m.Regions[j].Name
|
||||||
|
return regionLess(r1, r2)
|
||||||
|
})
|
||||||
|
}
|
||||||
+3
-27
@@ -11,6 +11,8 @@ import (
|
|||||||
|
|
||||||
"darvaza.org/core"
|
"darvaza.org/core"
|
||||||
"github.com/libdns/libdns"
|
"github.com/libdns/libdns"
|
||||||
|
|
||||||
|
"git.jpi.io/amery/jpictl/pkg/cluster"
|
||||||
)
|
)
|
||||||
|
|
||||||
func (mgr *Manager) fqdn(name string) string {
|
func (mgr *Manager) fqdn(name string) string {
|
||||||
@@ -86,32 +88,6 @@ func lessRecord(a, b libdns.Record) bool {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// SortRegions sorts regions. first by length those 3-character
|
|
||||||
// or shorter, and then by length. It's mostly aimed at
|
|
||||||
// supporting ISO-3166 order
|
|
||||||
func SortRegions(regions []string) []string {
|
|
||||||
sort.Slice(regions, func(i, j int) bool {
|
|
||||||
r1, r2 := regions[i], regions[j]
|
|
||||||
|
|
||||||
switch {
|
|
||||||
case len(r1) < 4:
|
|
||||||
switch {
|
|
||||||
case len(r1) < len(r2):
|
|
||||||
return true
|
|
||||||
case len(r1) > len(r2):
|
|
||||||
return false
|
|
||||||
default:
|
|
||||||
return r1 < r2
|
|
||||||
}
|
|
||||||
case len(r2) < 4:
|
|
||||||
return false
|
|
||||||
default:
|
|
||||||
return r1 < r2
|
|
||||||
}
|
|
||||||
})
|
|
||||||
return regions
|
|
||||||
}
|
|
||||||
|
|
||||||
// AddrRecord represents an A or AAAA record
|
// AddrRecord represents an A or AAAA record
|
||||||
type AddrRecord struct {
|
type AddrRecord struct {
|
||||||
Name string
|
Name string
|
||||||
@@ -172,7 +148,7 @@ func (mgr *Manager) genRegionsSorted() []string {
|
|||||||
regions = append(regions, name)
|
regions = append(regions, name)
|
||||||
}
|
}
|
||||||
|
|
||||||
return SortRegions(regions)
|
return cluster.SortRegions(regions)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (mgr *Manager) genAllAddrRecords() []AddrRecord {
|
func (mgr *Manager) genAllAddrRecords() []AddrRecord {
|
||||||
|
|||||||
Reference in New Issue
Block a user