FestivalSevenDayCardLogic.lua 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306
  1. --[[
  2. absAct ={
  3. [id] = {
  4. time = os.time()
  5. day = 1
  6. }
  7. }
  8. ]]
  9. local AbsActLogic = require("absAct.AbsActLogic")
  10. local AbsActExcel = require("excel.absAct")
  11. local BuyExcel = require("excel.buy")
  12. local Util = require("common.Util")
  13. local Msg = require("core.Msg")
  14. local Grid = require("bag.Grid")
  15. local BagLogic = require("bag.BagLogic")
  16. local BuyLogic = require("topup.BuyLogic")
  17. local ObjHuman = require("core.ObjHuman")
  18. local Lang = require("common.Lang")
  19. local Broadcast = require("broadcast.Broadcast")
  20. local MailManager = require("mail.MailManager")
  21. local MailExcel = require("excel.mail")
  22. local YunYingLogic = require("yunying.YunYingLogic")
  23. local Log = require("common.Log")
  24. local SEVENDAYCARD_STAUS_NOBUY = 0 -- 未购买
  25. local SEVENDAYCARD_STAUS_BUY = 1 -- 已购买
  26. local SEVENDAYCARD_STAUS_FINISH = 2 -- 已购买奖励发送完成
  27. local SEVENDAYCARD_TOTALDAY = 7 -- 持续时间
  28. local SEVENDAYCARD_GIFTGET = 1 -- 礼包已领取
  29. local SEVENDAYCARD_ID = 742 -- 活动ID
  30. local function SEVENDAYCARD_WRITELOG(human, szText)
  31. Log.write(Log.LOGID_OSS_COMMON, "[限时周卡]".." id = "..human.db._id.." name = "..human.db.name..szText)
  32. end
  33. function isOpen(human, YYInfo, funcConfig)
  34. local state, endTime, startTime = AbsActLogic.isStarted(human, funcConfig.funcID)
  35. if not state then return end
  36. local absAct = human.db.absAct[funcConfig.funcID]
  37. if absAct and absAct.dayCnt and absAct.dayCnt <= 0 and #absAct.item <= 0 then
  38. return false
  39. end
  40. return true, endTime, startTime
  41. end
  42. function isActive(human, YYInfo, funcConfig)
  43. return not isOpen(human, YYInfo, funcConfig)
  44. end
  45. function fontFestvialSevenDayCard(human,config,net,id,giftId)
  46. local len = #config.item
  47. for i = 1,len do
  48. local jLen = #config.item[i]
  49. for j = 1,jLen do
  50. Grid.makeItem(net.dayItem[i].item[j],config.item[i][j][1],config.item[i][j][2])
  51. end
  52. net.dayItem[i].item[0] = jLen
  53. end
  54. net.dayItem[0] = len
  55. BuyLogic.fontBuyItem(human, net.buyItem, config.buyID)
  56. net.state = human.db.absAct[id] and (human.db.absAct[id].nStatus == SEVENDAYCARD_STAUS_BUY and 1 or 0) or 0
  57. end
  58. -- 发放邮件奖励
  59. local function SevenDayCard_SendMail(human, cardConfig, dayIndex)
  60. local mailId = cardConfig.mailId
  61. local mailConfig = MailExcel.mail[mailId]
  62. local title = mailConfig.title
  63. local senderName = mailConfig.senderName
  64. local content = Util.format(mailConfig.content, 7, dayIndex)
  65. MailManager.add(MailManager.SYSTEM, human.db._id, title, content, cardConfig.item[dayIndex], senderName)
  66. print("[SevenDayCard_SendMail] 发送周卡邮件奖励 name = "..human.db.name.." dayIndex = "..dayIndex)
  67. end
  68. function getAndSendMsg(human,id)
  69. -- 判断活动是否开启
  70. local state, endTime, starTime = AbsActLogic.isStarted(human, id)
  71. print("getAndSendMsg ",state, endTime, starTime, id)
  72. if not state then return end
  73. local absConfig = AbsActExcel.absActivity[id]
  74. if not absConfig then return end
  75. local absAct = human.db.absAct[id]
  76. if not absAct then
  77. return
  78. end
  79. local msgRet = Msg.gc.GC_ABS_FESTVIAL_SEVENDAY_CARD_QUERY
  80. local config = AbsActExcel.festvialSevenDayCard
  81. local len = 0
  82. for infoId,info in pairs(config) do
  83. if info.actId == absConfig.actId then
  84. len = len + 1
  85. fontFestvialSevenDayCard(human,info,msgRet.netList[len],id,infoId)
  86. end
  87. end
  88. msgRet.netList[0] = len
  89. Msg.send(msgRet,human.fd)
  90. end
  91. function festvialCard(human,id,conf)
  92. local szLogText = " [festvialCard] "
  93. local giftId = conf.args[1]
  94. local state, endTime, starTime = AbsActLogic.isStarted(human, id)
  95. if not state then
  96. SEVENDAYCARD_WRITELOG(human,szLogText.."活动未开启")
  97. return
  98. end
  99. local absConfig = AbsActExcel.absActivity[id]
  100. if not absConfig then
  101. SEVENDAYCARD_WRITELOG(human,szLogText.."不存在对应配置 id = "..id)
  102. return
  103. end
  104. local absAct = human.db.absAct[id]
  105. if not absAct then
  106. return
  107. end
  108. -- 状态设置为已购买
  109. absAct.nStatus = SEVENDAYCARD_STAUS_BUY
  110. -- 记录购买时间
  111. absAct.nBuyTime = os.time()
  112. local nDay = 1
  113. absAct.giftId = giftId
  114. absAct.day = Util.setBit(0, nDay)
  115. -- absAct.card = absAct.card or {}
  116. -- if absAct.card and absAct.card[giftId] then
  117. -- SEVENDAYCARD_WRITELOG(human,szLogText.."存在旧的数据 id = "..id.." giftId = "..giftId)
  118. -- return
  119. -- end
  120. -- absAct.card[giftId] = {}
  121. -- absAct.card[giftId].day = Util.setBit(0, nDay)
  122. local cardConfig = AbsActExcel.festvialSevenDayCard[giftId]
  123. BagLogic.addItemList(human, cardConfig.zuanshi, "festival_seven_day_card")
  124. if cardConfig then
  125. -- 减去一天
  126. SevenDayCard_SendMail(human, cardConfig, nDay)
  127. end
  128. print("[festvialCard] id = "..id.." giftId = "..giftId.." day = "..absAct.day)
  129. SEVENDAYCARD_WRITELOG(human,szLogText.."玩家购买了限时周卡, 发送了第一天奖励 id = "..id.." giftId = "..giftId.." day = "..absAct.day)
  130. getAndSendMsg(human, id)
  131. YunYingLogic.sendBanner(human)
  132. YunYingLogic.updateIcon(YYInfo[id], human)
  133. YunYingLogic.sendGroupUpdate(YYInfo[id], human, absConfig.panelID)
  134. end
  135. function updateDaily(human,id)
  136. local szLogText = " [updateDaily] "
  137. local config = AbsActExcel.absActivity[id]
  138. if not config then
  139. SEVENDAYCARD_WRITELOG(human, szLogText.." 不存在对应配置 id = "..id)
  140. return
  141. end
  142. AbsActLogic.checkAbsActClean(human, id)
  143. -- 有无激活记录
  144. local absAct = human.db.absAct[id]
  145. if not absAct then
  146. SEVENDAYCARD_WRITELOG(human, szLogText.." 不存在对应数据 id = "..id)
  147. return
  148. end
  149. if not absAct.nStatus or SEVENDAYCARD_STAUS_BUY ~= absAct.nStatus then
  150. return
  151. end
  152. -- 发放奖励
  153. local bClear = false
  154. local nBuyTime = absAct.nBuyTime
  155. local giftId = absAct.giftId
  156. local nDiffDay = -1
  157. nDiffDay = Util.diffDay(nBuyTime)
  158. if nDiffDay ~= -1 then
  159. if nDiffDay >= SEVENDAYCARD_TOTALDAY then
  160. bClear = true
  161. end
  162. end
  163. table.print_lua_table(absAct)
  164. local bRet = true == bClear and 1 or 0
  165. print("[updateDaily] nDiffDay = "..nDiffDay.." bRet = \n"..bRet)
  166. if false == bClear then
  167. local nNowDay = nDiffDay + 1
  168. local nFlag = Util.getBit(absAct.day, nNowDay)
  169. print("[updateDaily] nDiffDay = "..nDiffDay.." nNowDay = "..nNowDay.." day = "..absAct.day.." nFlag = ".. nFlag)
  170. if nFlag == 0 then
  171. absAct.day = Util.setBit(absAct.day, nNowDay)
  172. local dayIndex = nNowDay
  173. local cardConfig = AbsActExcel.festvialSevenDayCard[giftId]
  174. if cardConfig then
  175. -- 减去一天
  176. SevenDayCard_SendMail(human, cardConfig, dayIndex)
  177. end
  178. SEVENDAYCARD_WRITELOG(human, szLogText.." 正常发放了限时周卡奖励 id = "..id.." nNowDay = "..nNowDay)
  179. if nNowDay == SEVENDAYCARD_TOTALDAY then
  180. absAct.nStatus = SEVENDAYCARD_STAUS_FINISH
  181. end
  182. else
  183. print("[updateDaily] 当天重复登录 = "..nDiffDay.." day = "..absAct.day.." nNowDay = "..nNowDay.." nFlag = "..nFlag)
  184. end
  185. else
  186. print("[updateDaily] 已过期 nDiffDay = "..nDiffDay.." absAct.day = "..absAct.day)
  187. -- 检测一遍,如果还有就直接发
  188. for i = 1, SEVENDAYCARD_TOTALDAY, 1 do
  189. local nFlag = Util.getBit(absAct.day, i)
  190. print("[updateDaily] 已过期 nDiffDay = "..nDiffDay.." absAct.day = "..absAct.day.." i = "..i .." nFlag = "..nFlag)
  191. if 0 == nFlag then
  192. absAct.day = Util.setBit(absAct.day, i)
  193. local dayIndex = i
  194. local cardConfig = AbsActExcel.festvialSevenDayCard[giftId]
  195. if cardConfig then
  196. -- 减去一天
  197. SevenDayCard_SendMail(human, cardConfig, dayIndex)
  198. else
  199. print("[updateDaily] 过期但是不存在对应的配置")
  200. end
  201. SEVENDAYCARD_WRITELOG(human, szLogText.." 判断玩家已经过了7天但是有奖励没有领取 发放了限时周卡奖励 id = "..id.." nNowDay = "..i)
  202. end
  203. end
  204. absAct.nStatus = SEVENDAYCARD_STAUS_FINISH
  205. end
  206. end
  207. function isRed(human, YYInfo, funcConfig)
  208. local state,endTime,starTime = AbsActLogic.isStarted(human, funcConfig.funcID)
  209. if not state then return end
  210. local absConfig = AbsActExcel.absActivity[funcConfig.funcID]
  211. local absAct = human.db.absAct[funcConfig.funcID]
  212. if not absAct then return end
  213. return false
  214. end
  215. function SEVENDAYCARD_GMCLEAR(human, id)
  216. human.db.absAct[id] = {}
  217. human.db.absAct[id].card = nil
  218. print("[SEVENDAYCARD_GMCLEAR] 重置成功 id = "..id)
  219. end
  220. function onLogin(human, funcID)
  221. print("[onLogin] 玩家登入限时周卡 111")
  222. local tAbsAct = human.db.absAct[SEVENDAYCARD_ID]
  223. if tAbsAct then
  224. table.print_lua_table(tAbsAct)
  225. if tAbsAct.nStatus then
  226. print("[onLogin] nStatus = \n", tAbsAct.nStatus)
  227. end
  228. else
  229. print("[onLogin] 不存在对应的数据了")
  230. end
  231. if tAbsAct and SEVENDAYCARD_STAUS_BUY == tAbsAct.nStatus then
  232. print("[onLogin] 玩家登入限时周卡 2222")
  233. local nDiffDay = Util.diffDay(tAbsAct.nBuyTime)
  234. local nCheckDay = nDiffDay + 1 >= SEVENDAYCARD_TOTALDAY and SEVENDAYCARD_TOTALDAY or nDiffDay + 1
  235. local giftId = tAbsAct.giftId
  236. print("[onLogin] 玩家登入限时周卡 nDiffDay = "..nDiffDay.." nCheckDay = "..nCheckDay)
  237. for i = 1, nCheckDay, 1 do
  238. local nFlag = Util.getBit(tAbsAct.day, i)
  239. print("[onLogin] 玩家登入限时周卡 day = "..tAbsAct.day.." nFlag = "..nFlag)
  240. if 0 == nFlag then
  241. tAbsAct.day = Util.setBit(tAbsAct.day, i)
  242. print("[onLogin] 玩家登入限时周卡 tAbsAct.day = "..tAbsAct.day)
  243. local dayIndex = i
  244. local cardConfig = AbsActExcel.festvialSevenDayCard[giftId]
  245. if cardConfig then
  246. -- 减去一天
  247. SevenDayCard_SendMail(human, cardConfig, dayIndex)
  248. end
  249. SEVENDAYCARD_WRITELOG(human, "[onLogin] 玩家登录检测 ".." 发放了限时周卡奖励 nNowDay = "..i)
  250. if SEVENDAYCARD_TOTALDAY == i then
  251. tAbsAct.nStatus = SEVENDAYCARD_STAUS_FINISH
  252. break
  253. end
  254. end
  255. end
  256. end
  257. end