From 2820a1281b0aa8e23e04ba3e0c052860dcc9576a Mon Sep 17 00:00:00 2001 From: database64128 Date: Fri, 24 Mar 2023 00:11:11 +0800 Subject: [PATCH] =?UTF-8?q?=F0=9F=92=88=20api:=20sort=20user=20list=20and?= =?UTF-8?q?=20stats=20by=20username?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- cred/manager.go | 7 +++++++ stats/collector.go | 9 +++++++++ 2 files changed, 16 insertions(+) diff --git a/cred/manager.go b/cred/manager.go index 2a39b7b..90ac4ea 100644 --- a/cred/manager.go +++ b/cred/manager.go @@ -13,6 +13,7 @@ import ( "github.com/database64128/shadowsocks-go/maps" "github.com/database64128/shadowsocks-go/mmap" + "github.com/database64128/shadowsocks-go/slices" "github.com/database64128/shadowsocks-go/ss2022" "go.uber.org/zap" ) @@ -44,6 +45,11 @@ type UserCredential struct { UPSK []byte `json:"uPSK"` } +// Less is useful for sorting user credentials by username. +func (uc UserCredential) Less(other UserCredential) bool { + return uc.Name < other.Name +} + type cachedUserCredential struct { uPSK []byte uPSKHash [ss2022.IdentityHeaderLength]byte @@ -60,6 +66,7 @@ func (s *ManagedServer) Credentials() []UserCredential { }) } s.mu.RUnlock() + slices.SortFunc(ucs, UserCredential.Less) return ucs } diff --git a/stats/collector.go b/stats/collector.go index d8ae453..13b6982 100644 --- a/stats/collector.go +++ b/stats/collector.go @@ -3,6 +3,8 @@ package stats import ( "sync" "sync/atomic" + + "github.com/database64128/shadowsocks-go/slices" ) type trafficCollector struct { @@ -82,6 +84,11 @@ type User struct { Traffic } +// Less is useful for sorting users by name. +func (u User) Less(other User) bool { + return u.Name < other.Name +} + func (uc *userCollector) snapshot(username string) User { return User{ Name: username, @@ -164,6 +171,7 @@ func (sc *serverCollector) Snapshot() (s Server) { s.Users = append(s.Users, u) } sc.mu.RUnlock() + slices.SortFunc(s.Users, User.Less) return } @@ -178,6 +186,7 @@ func (sc *serverCollector) SnapshotAndReset() (s Server) { s.Users = append(s.Users, u) } sc.mu.RUnlock() + slices.SortFunc(s.Users, User.Less) return }