FestivalSevenDayCardLogic.lua 11 KB

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