123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300 |
- package controller
- import (
- "fmt"
- "ktogame/dbUtil"
- "ktogame/models"
- "strings"
- "github.com/astaxie/beego/logs"
- "github.com/go-xorm/xorm"
- )
- func UpdateSuperiorsPerformance(engine *xorm.Engine, superiorsStr string, amount float64) error {
- logs.Info("into UpdateSuperiorsPerformance:", superiorsStr, amount)
- ids := strings.Split(superiorsStr, ",")
- if len(ids) <= 0 {
- return nil
- }
- var supers []models.UserInfo
- for _, sid := range ids {
- var tmpUser models.UserInfo
- ok, err := engine.Where("id = ?", sid).Get(&tmpUser)
- if err != nil {
- return err
- }
- if !ok {
- continue
- }
- supers = append(supers, tmpUser)
- }
- if len(supers) == 0 {
- return nil
- }
- var rp models.RewardsPool
- _, err := engine.Id(1).Get(&rp)
- if err != nil {
- return err
- }
- for _, super := range supers {
- var per models.Performance
- ok, err := engine.Id(super.Addr).Get(&per)
- if err != nil {
- fmt.Println(err)
- continue
- }
- if !ok {
- logs.Info("%v not exist!", super.Addr)
- continue
- }
- per.TotalPerformance += amount
- if per.TotalPerformance >= CommunityMarket {
- if per.Recorded == 0 {
- var super models.Performance
- ok, err := engine.Id(per.Addr).Get(&super)
- if err != nil {
- fmt.Println(err)
- continue
- }
- if !ok {
- logs.Info("%v not exist!", per.Addr)
- continue
- }
- super.MarketNum += 1
- _, err = engine.ID(super.Addr).Cols("markit_num").Update(&super)
- if err != nil {
- fmt.Println(err)
- continue
- }
- per.Recorded = 1
- }
- }
- var level int = 0
- for i := 1; i < len(PerformanceLevel); i++ {
- if PerformanceLevel[i-1] <= per.TotalPerformance && per.TotalPerformance < PerformanceLevel[i] {
- level = i
- break
- }
- }
- if level > 0 {
- if level > per.PerformanceLevel {
- ratio := PerformanceRatio[level] - PerformanceRatio[per.PerformanceLevel]
- rewards := amount * ratio
- if rp.TeamPerformance >= rewards {
- rp.TeamPerformance -= rewards //pool sub rewards
- per.PerformanceRewards += rewards //user add rewards to PerformanceRewards
- per.PerformanceLevel = level
- //update available
- err := UpdateAvailableRewards(rewards, super.Addr, false, false)
- if err != nil {
- return err
- }
- _, err = engine.ID(super.Addr).Cols("total_performance,performance_rewards,performance_level").Update(&per)
- if err != nil {
- return err
- }
- }
- }
- }
- }
- _, err = engine.ID(1).Cols("team_performance").Update(&rp)
- if err != nil {
- return err
- }
- logs.Info("into UpdateSuperiorsPerformance end:", rp)
- return nil
- }
- func UpdateRewardsPool(engine *xorm.Engine, amount float64) error {
- logs.Info("into UpdateRewardsPool:", amount)
- var rp models.RewardsPool
- rp.TeamPerformance = amount * 0.15
- rp.TeamCultivate = amount * 0.10
- rp.TotalPool += amount
- _, err := engine.ID(1).Update(&rp)
- if err != nil {
- return err
- }
- logs.Info("UpdateRewardsPool end:", rp)
- return nil
- }
- func UpdateAvailableRewards(rewards float64, uaddr string, join, isdirect bool) error {
- logs.Info("into UpdateAvailableRewards:", rewards, uaddr, join, isdirect)
- a_rewards := rewards * 60 / 100
- a_reinput := rewards * 40 / 100
- var user models.UserInfo
- ok, err := dbUtil.Engine.Id(uaddr).Get(&user)
- if err != nil {
- return err
- }
- if !ok {
- logs.Info("%v not exist!", uaddr)
- return nil
- }
- user.AvailableClaim = a_rewards
- user.AvailableReinput = a_reinput
- if join {
- if isdirect {
- user.DirectNumber += 1
- user.DirectRewards += rewards
- logs.Info("check direct info=====:", rewards, a_rewards, a_reinput, user.AvailableClaim, user.AvailableReinput, user.DirectNumber, user.DirectRewards)
- _, err := dbUtil.Engine.ID(user.Addr).Cols("available_claim,available_reinput,direct_number,direct_rewards").Update(&user)
- if err != nil {
- return err
- }
- } else {
- user.IndirectNumber += 1
- user.IndirectRewards += rewards
- logs.Info("check indirect info=====:", rewards, a_rewards, a_reinput, user.AvailableClaim, user.AvailableReinput, user.DirectNumber, user.DirectRewards)
- _, err := dbUtil.Engine.ID(user.Addr).Cols("available_claim,available_reinput,indirect_number,indirect_rewards").Update(&user)
- if err != nil {
- return err
- }
- }
- } else {
- logs.Info("check else info=====:", user.AvailableClaim, user.AvailableReinput)
- _, err := dbUtil.Engine.ID(user.Addr).Cols("available_claim,available_reinput").Update(&user)
- if err != nil {
- return err
- }
- }
- logs.Info("into UpdateAvailableRewards end:", user)
- return nil
- }
- func UpdateCommunityGift(engine *xorm.Engine, amount float64, uaddr string) error {
- logs.Info("into UpdateCommunityGift:", amount, uaddr)
- var user, tmpUser models.UserInfo
- ok, err := engine.Id(uaddr).Get(&user)
- if err != nil {
- return err
- }
- if !ok {
- return nil
- }
- ok, err = engine.Desc("id").Get(&tmpUser)
- if err != nil {
- return err
- }
- if !ok {
- logs.Info("%v not exist!", uaddr)
- return nil
- }
- var leftNum, rightNum int64
- if user.Id >= 26 {
- leftNum = 25
- } else {
- leftNum = user.Id - 1
- }
- if tmpUser.Id-user.Id >= 25 {
- rightNum = 25
- } else {
- rightNum = tmpUser.Id - user.Id
- }
- rewards := amount * (float64(leftNum+rightNum) / 100)
- err = UpdateAvailableRewards(rewards, user.Addr, false, false)
- if err != nil {
- return err
- }
- var per models.Performance
- ok, err = engine.Id(uaddr).Get(&per)
- if err != nil {
- return err
- }
- if !ok {
- return nil
- }
- per.CommunityGift += rewards
- _, err = engine.ID(uaddr).Cols("community_gift").Update(&per)
- if err != nil {
- return err
- }
- logs.Info("into UpdateCommunityGift end:", amount, uaddr)
- return nil
- }
- func UpdateCommunityNodes(engine *xorm.Engine, amount float64) error {
- logs.Info("into UpdateCommunityNodes:", amount)
- var nodes []models.UserInfo
- err := engine.Where("state = ?", CommunityUsers).Find(&nodes)
- if err != nil {
- return err
- }
- if len(nodes) == 0 {
- return nil
- }
- rewards := (amount * 5 / 100) / float64(len(nodes))
- for _, node := range nodes {
- err = UpdateAvailableRewards(rewards, node.Addr, false, false)
- if err != nil {
- fmt.Println(err)
- continue
- }
- }
- logs.Info("into UpdateCommunityNodes end:", amount)
- return nil
- }
- func UpdateMarket(engine *xorm.Engine, amount float64) error {
- logs.Info("into UpdateMarket:", amount)
- var pers []models.Performance
- err := engine.Where("market_num >= ?", 2).Find(&pers)
- if err != nil {
- return err
- }
- var rp models.RewardsPool
- ok, err := engine.Id(1).Get(&rp)
- if err != nil {
- return err
- }
- if !ok {
- return nil
- }
- for _, per := range pers {
- var level int = 0
- for i := 1; i < len(MarketLevel); i++ {
- if MarketLevel[i-1] <= per.MarketNum && per.MarketNum < MarketLevel[i] {
- level = i
- break
- }
- }
- if level > 0 {
- if level > per.MarketLevel {
- ratio := MarketRatio[level] - MarketRatio[per.MarketLevel]
- rewards := amount * ratio
- if rp.TeamCultivate >= rewards {
- rp.TeamCultivate -= rewards //pool sub rewards
- per.MarketRewards += rewards //user add rewards to PerformanceRewards
- per.MarketLevel = level
- //update available
- err := UpdateAvailableRewards(rewards, per.Addr, false, false)
- if err != nil {
- return err
- }
- _, err = engine.ID(per.Addr).Cols("market_level,market_rewards").Update(&per)
- if err != nil {
- return err
- }
- }
- }
- }
- }
- _, err = engine.ID(1).Cols("team_performance").Update(&rp)
- if err != nil {
- return err
- }
- logs.Info("into UpdateMarket end:", amount)
- return nil
- }
|