106 lines
2.3 KiB
Go
106 lines
2.3 KiB
Go
|
package importfunc
|
||
|
|
||
|
import (
|
||
|
"context"
|
||
|
"fmt"
|
||
|
|
||
|
mycrypto "github.com/Leufolium/test/crypto"
|
||
|
"github.com/Leufolium/test/dbstruct"
|
||
|
"github.com/Leufolium/test/mongo"
|
||
|
"github.com/Leufolium/test/mysql"
|
||
|
"github.com/Leufolium/test/util"
|
||
|
)
|
||
|
|
||
|
func ImportZoneMemberInfo() {
|
||
|
fmt.Println("Start importing...")
|
||
|
|
||
|
mcli, err := mongo.NewMongo()
|
||
|
if err != nil {
|
||
|
fmt.Printf("mongo client init fail : %v", err)
|
||
|
return
|
||
|
}
|
||
|
|
||
|
mysqlcli, err := mysql.NewMysql()
|
||
|
if err != nil {
|
||
|
fmt.Printf("mysql client init fail : %v", err)
|
||
|
return
|
||
|
}
|
||
|
|
||
|
ctx := context.Background()
|
||
|
|
||
|
limit := 1000
|
||
|
offset := 0
|
||
|
|
||
|
streamers, err := mcli.GetStreamerList(ctx, offset, limit)
|
||
|
if err != nil {
|
||
|
fmt.Printf("GetStreamerListfail : %v", err)
|
||
|
return
|
||
|
}
|
||
|
mids := make([]int64, 0)
|
||
|
for _, streamer := range streamers {
|
||
|
mids = append(mids, streamer.GetMid())
|
||
|
}
|
||
|
accounts, _ := mcli.GetAccountListByMids(ctx, mids)
|
||
|
acctMp := make(map[int64]*dbstruct.Account)
|
||
|
for _, acct := range accounts {
|
||
|
acctMp[acct.GetMid()] = acct
|
||
|
}
|
||
|
zones, _ := mcli.GetZoneListByMids(ctx, mids)
|
||
|
zoneMp := make(map[int64]*dbstruct.Zone)
|
||
|
for _, zone := range zones {
|
||
|
zoneMp[zone.GetMid()] = zone
|
||
|
}
|
||
|
|
||
|
zids := make([]int64, 0)
|
||
|
fmt.Printf("zid: [")
|
||
|
for _, zone := range zones {
|
||
|
zids = append(zids, zone.GetId())
|
||
|
fmt.Printf("%v ", zone.GetId())
|
||
|
}
|
||
|
fmt.Printf("]")
|
||
|
|
||
|
zmlist, err := mysqlcli.GetZoneMemberCountGroupByZid(ctx, nil, zids)
|
||
|
if err != nil {
|
||
|
fmt.Printf("GetZoneMemberCountGroupByZid : %v", err)
|
||
|
return
|
||
|
}
|
||
|
zmMp := make(map[int64]*dbstruct.ZoneMemberCount)
|
||
|
for _, zm := range zmlist {
|
||
|
zmMp[zm.GetZid()] = zm
|
||
|
}
|
||
|
|
||
|
fmt.Printf("user_id\t昵称\t手机号\t空间动态数\t空间人数")
|
||
|
|
||
|
for _, streamer := range streamers {
|
||
|
|
||
|
acct, ok := acctMp[streamer.GetMid()]
|
||
|
if !ok {
|
||
|
continue
|
||
|
}
|
||
|
|
||
|
userId := acct.GetUserId()
|
||
|
name := acct.GetName()
|
||
|
mobilephonestr := util.DerefString(acct.MobilePhone)
|
||
|
dcrb, err := mycrypto.CryptoServiceInstance().DecryptByAES([]byte(mobilephonestr))
|
||
|
if err != nil {
|
||
|
fmt.Printf("DecryptByAES : %v", err)
|
||
|
return
|
||
|
}
|
||
|
mobilephone := string(dcrb)
|
||
|
zmmtcount := int64(0)
|
||
|
zmbcount := int64(0)
|
||
|
zone, ok := zoneMp[streamer.GetMid()]
|
||
|
if ok {
|
||
|
zmmtcount = zone.GetZoneMomentCount()
|
||
|
zmb, ok := zmMp[zone.GetId()]
|
||
|
if ok {
|
||
|
zmbcount = zmb.GetNum()
|
||
|
}
|
||
|
}
|
||
|
|
||
|
fmt.Printf("%d\t%s\t%s\t%d\t%d", userId, name, mobilephone, zmmtcount, zmbcount)
|
||
|
}
|
||
|
|
||
|
fmt.Println("End importing...")
|
||
|
}
|