up
This commit is contained in:
parent
6763fff733
commit
03a6aef4fc
59
plugin/chips/rank.go
Normal file
59
plugin/chips/rank.go
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
package chips
|
||||||
|
|
||||||
|
import (
|
||||||
|
"amor/proto"
|
||||||
|
redisrepo "amor/repository/redisRepo"
|
||||||
|
"encoding/json"
|
||||||
|
|
||||||
|
"github.com/redis/rueidis"
|
||||||
|
zero "github.com/wdvxdr1123/ZeroBot"
|
||||||
|
)
|
||||||
|
|
||||||
|
func Rank(ctx *zero.Ctx) {
|
||||||
|
groupID := ctx.Event.GroupID
|
||||||
|
groupMemberList := ctx.GetGroupMemberList(groupID)
|
||||||
|
var list proto.GroupMemberInfoList
|
||||||
|
err := json.Unmarshal([]byte(groupMemberList.Raw), &list)
|
||||||
|
if err != nil {
|
||||||
|
ctx.Send("获取群成员列表失败")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
type Rank struct {
|
||||||
|
UserID int64
|
||||||
|
Nickname string
|
||||||
|
Balance int64
|
||||||
|
}
|
||||||
|
var rankList []Rank
|
||||||
|
for _, member := range list {
|
||||||
|
balance, err := redisrepo.GetUserBalance(int64(member.UserID))
|
||||||
|
if err != nil {
|
||||||
|
if err == rueidis.Nil {
|
||||||
|
continue
|
||||||
|
} else {
|
||||||
|
ctx.Send("获取余额失败")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
rankList = append(rankList, Rank{
|
||||||
|
UserID: int64(member.UserID),
|
||||||
|
Nickname: member.Nickname,
|
||||||
|
Balance: balance,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
// sort rankList
|
||||||
|
for i := 0; i < len(rankList); i++ {
|
||||||
|
for j := i + 1; j < len(rankList); j++ {
|
||||||
|
if rankList[i].Balance < rankList[j].Balance {
|
||||||
|
rankList[i], rankList[j] = rankList[j], rankList[i]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var msg string
|
||||||
|
for i, rank := range rankList {
|
||||||
|
msg += "第" + string(i+1) + "名: " + rank.Nickname + " 余额: " + string(rank.Balance) + "\n"
|
||||||
|
}
|
||||||
|
ctx.Send(msg)
|
||||||
|
}
|
36
proto/group.go
Normal file
36
proto/group.go
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
package proto
|
||||||
|
|
||||||
|
type GroupMemberInfo struct {
|
||||||
|
GroupID int64 `json:"group_id"`
|
||||||
|
UserID int64 `json:"user_id"`
|
||||||
|
Nickname string `json:"nickname"`
|
||||||
|
Card string `json:"card"`
|
||||||
|
Sex string `json:"sex"`
|
||||||
|
Age int64 `json:"age"`
|
||||||
|
Area string `json:"area"`
|
||||||
|
JoinTime int32 `json:"join_time"`
|
||||||
|
LastSentTime int32 `json:"last_sent_time"`
|
||||||
|
Level string `json:"level"`
|
||||||
|
Role string `json:"role"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type GroupMemberInfoList []struct {
|
||||||
|
GroupID int `json:"group_id"`
|
||||||
|
UserID int `json:"user_id"`
|
||||||
|
Nickname string `json:"nickname"`
|
||||||
|
Card string `json:"card"`
|
||||||
|
Sex string `json:"sex"`
|
||||||
|
Age int `json:"age"`
|
||||||
|
Area string `json:"area"`
|
||||||
|
Level int `json:"level"`
|
||||||
|
QqLevel int `json:"qq_level"`
|
||||||
|
JoinTime int `json:"join_time"`
|
||||||
|
LastSentTime int `json:"last_sent_time"`
|
||||||
|
TitleExpireTime int `json:"title_expire_time"`
|
||||||
|
Unfriendly bool `json:"unfriendly"`
|
||||||
|
CardChangeable bool `json:"card_changeable"`
|
||||||
|
IsRobot bool `json:"is_robot"`
|
||||||
|
ShutUpTimestamp int `json:"shut_up_timestamp"`
|
||||||
|
Role string `json:"role"`
|
||||||
|
Title string `json:"title"`
|
||||||
|
}
|
@ -3,6 +3,7 @@ package router
|
|||||||
import (
|
import (
|
||||||
"amor/plugin"
|
"amor/plugin"
|
||||||
"amor/plugin/blackjack"
|
"amor/plugin/blackjack"
|
||||||
|
"amor/plugin/chips"
|
||||||
"amor/plugin/member"
|
"amor/plugin/member"
|
||||||
|
|
||||||
zero "github.com/wdvxdr1123/ZeroBot"
|
zero "github.com/wdvxdr1123/ZeroBot"
|
||||||
@ -11,6 +12,7 @@ import (
|
|||||||
func Router() {
|
func Router() {
|
||||||
zero.OnFullMatch("register").Handle(member.Register)
|
zero.OnFullMatch("register").Handle(member.Register)
|
||||||
zero.OnFullMatch("chips").Handle(member.GetBalance)
|
zero.OnFullMatch("chips").Handle(member.GetBalance)
|
||||||
|
zero.OnFullMatch("rank").Handle(chips.Rank)
|
||||||
zero.OnFullMatch("help").Handle(plugin.Help)
|
zero.OnFullMatch("help").Handle(plugin.Help)
|
||||||
|
|
||||||
// 21点游戏
|
// 21点游戏
|
||||||
|
Loading…
x
Reference in New Issue
Block a user