BuyLogic.lua 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385
  1. -----------------------------------------
  2. -- 直购
  3. -----------------------------------------
  4. local BuyExcel = require("excel.buy").buy
  5. local TopupExcel = require("excel.buy").topup
  6. local presentExcel = require("excel.present")
  7. local Log = require("common.Log")
  8. local Lang = require("common.Lang")
  9. local Msg = require("core.Msg")
  10. local ObjHuman = require("core.ObjHuman")
  11. local BagLogic = require("bag.BagLogic")
  12. local FcmLogic = require("fcm.FcmLogic")
  13. local PfLogic = require("platform.PfLogic")
  14. local FundLogic = require("present.FundLogic")
  15. local DailyLibaoLogic = require("present.DailyLibaoLogic")
  16. local RichangLibaoLogic = require("present.RichangLibaoLogic")
  17. local TequanShopLogic = require("present.TequanShopLogic")
  18. local TopupLogic = require("topup.TopupLogic")
  19. local VipLogic = require("vip.VipLogic")
  20. local SceneHandler = require("scene.Handler")
  21. local UnionRedBagLogic = require("union.UnionRedBagLogic")
  22. local LimitBuy = require("present.LimitBuy")
  23. local ActCustomizeLogic = require("present.ActCustomizeLogic")
  24. local OpenServerGiftLogic = require("present.OpenServerGiftLogic")
  25. local MonthCard = require("present.MonthCard")
  26. local GiftPackLogic = require("present.GiftPackLogic")
  27. local PremiumGiftLogic = require("absAct.PremiumGiftLogic")
  28. local LimitMangHeLogic = require("present.LimitMangHeLogic")
  29. local Broadcast = require("broadcast.Broadcast")
  30. local MangHeLogic = require("absAct.MangHeLogic")
  31. local HeroGrowUp = require("absAct.HeroGrowUp")
  32. local ItemDefine = require("bag.ItemDefine")
  33. local OverflowFundLogic = require("present.OverflowFundLogic")
  34. local AbsWeeklyCardLogic = require("absAct.AbsWeeklyCardLogic")
  35. local YunYingLogic = require("yunying.YunYingLogic")
  36. local DoubleChargeLogic = require("absAct.DoubleChargeLogic")
  37. local MoshouLogic = require("moshou.MoshouLogic")
  38. local OrderExcel = require("excel.warOrder")
  39. local WarOrderLogic = require("shop.WarOrder")
  40. local GiftExcel = require("excel.buy").gift
  41. local GiftLogic = require("topup.GiftLogic")
  42. BUY_CODE_NORMAL = 0 -- 正常调平台的充值接口
  43. BUY_CODE_WX_KEFU = 1 -- 微信小程序客服充值接口
  44. cmd = {}
  45. -- 是否首次购买
  46. function getIsFirst(human,id)
  47. if not human.db.buy or
  48. not human.db.buy[id] then
  49. return true
  50. end
  51. end
  52. -- 购买次数
  53. function getBuyCnt(human,id)
  54. if not human.db.buy or
  55. not human.db.buy[id] then
  56. return 0
  57. end
  58. local cnt = human.db.buy[id].cnt or 0
  59. return cnt
  60. end
  61. -- 双倍购买次数
  62. function getDoubleBuyCnt(human,id)
  63. if not human.db.buy or
  64. not human.db.buy[id] then
  65. return 0
  66. end
  67. local cnt = human.db.buy[id].doubleCnt or 0
  68. return cnt
  69. end
  70. -- 真实价格 某些商品首次购买比较便宜
  71. function getRealPrice(human, buyID, region)
  72. region = human.region or "CN"
  73. local buyConf = BuyExcel[buyID]
  74. if not buyConf then return 0 end
  75. return buyConf[region]
  76. end
  77. -- 封装BuyItem结构体
  78. function fontBuyItem(human, net, buyID)
  79. local conf = BuyExcel[buyID]
  80. net.buyID = buyID
  81. local region = human.region or "THA"
  82. net.region = region
  83. net.cost = getRealPrice(human, buyID, region)
  84. net.icon = conf.icon
  85. net.name = conf.name
  86. net.isFirst = getIsFirst(human, buyID) and 1 or 0
  87. local giveZuanshi = tonumber(conf.desc)
  88. if giveZuanshi then
  89. if net.isFirst == 1 then
  90. net.desc = tostring(giveZuanshi * 3)
  91. else
  92. net.desc = tostring(giveZuanshi)
  93. end
  94. else
  95. net.desc = conf.desc
  96. end
  97. net.doubleCnt = conf.doubleCnt
  98. local actDouble = YunYingLogic.onCallBack(human,"getDoubleCnt", buyID, true)
  99. net.actDoubleCnt = actDouble or 0
  100. net.useDoubleCnt = getDoubleBuyCnt(human, buyID)
  101. net.buyCnt = getBuyCnt(human, buyID)
  102. net.vipExp = conf.vipExp
  103. net.yuanjia = conf.THA
  104. net.zhekou = conf.zhekou
  105. end
  106. -------------------------------- cmd开始 ----------------------------------
  107. -- 充值-元宝
  108. function cmd.topup(human, buyConf, isFirst, buyCnt)
  109. local args = buyConf.args
  110. local id = args[1]
  111. local config = TopupExcel[id]
  112. local cnt = config.cnt * 2
  113. local doubleCnt = buyConf.doubleCnt
  114. local actDouble = YunYingLogic.onCallBack(human,"getDoubleCnt", config.buyID, true)
  115. if actDouble > 0 then
  116. YunYingLogic.onCallBack(human,"buyCall",config.buyID)
  117. cnt = cnt * 2
  118. else
  119. YunYingLogic.onCallBack(human,"touchSingleReach",config.buyID)
  120. --首冲双倍
  121. if buyCnt < doubleCnt then
  122. cnt = cnt * 2
  123. human.db.buy[config.buyID].doubleCnt = human.db.buy[config.buyID].doubleCnt + 1
  124. end
  125. end
  126. ObjHuman.addZuanshi(human, cnt, "buyTopup")
  127. BagLogic.sendItemGetList(human, {{ItemDefine.ITEM_ZUANSHI_ID, cnt}}, "buyTopup")
  128. TopupLogic.query(human)
  129. end
  130. -- 充值-每日礼包
  131. function cmd.dailyLibao(human, buyConf)
  132. local id = buyConf.args[1]
  133. DailyLibaoLogic.buyLibao(human, id)
  134. end
  135. -- 充值-每周礼包
  136. function cmd.weekLibao(human, buyConf)
  137. local id = buyConf.args[1]
  138. RichangLibaoLogic.buyLibao(human, RichangLibaoLogic.LIBAOTYPE_WEEK, id, RichangLibaoLogic.RMB_BUY)
  139. end
  140. -- 充值-每月礼包
  141. function cmd.monthLibao(human, buyConf)
  142. local id = buyConf.args[1]
  143. RichangLibaoLogic.buyLibao(human, RichangLibaoLogic.LIBAOTYPE_MONTH, id, RichangLibaoLogic.RMB_BUY)
  144. end
  145. -- 成长礼包
  146. function cmd.giftPack(human, buyConf)
  147. local id = buyConf.args[1]
  148. GiftPackLogic.buyLibao(human, id)
  149. end
  150. -- 充值-特权商店
  151. function cmd.tequanShop(human, buyConf)
  152. local id = buyConf.args[1]
  153. TequanShopLogic.buyLibao(human, id, TequanShopLogic.COST_RMB)
  154. end
  155. -- 发公会红包
  156. function cmd.unionRedbag(human,buyConf)
  157. UnionRedBagLogic.sendRedBagCallBack(human,buyConf.args[1])
  158. end
  159. -- 限时抢购
  160. function cmd.limitBuy(human, buyConf)
  161. LimitBuy.buy(human, buyConf.args[1])
  162. end
  163. function cmd.customize(human,buyConf)
  164. ActCustomizeLogic.onBuyCustomize(human,buyConf.args[1])
  165. end
  166. -- 开服好礼
  167. function cmd.openServer(human,buyConf)
  168. OpenServerGiftLogic.buyGift(human,buyConf.args[1])
  169. end
  170. -- 月卡
  171. function cmd.monthCard(human,buyConf)
  172. MonthCard.buyMonthCard(human,buyConf.args[1])
  173. end
  174. --
  175. function cmd.heroGrowUp(human, buyConf)
  176. HeroGrowUp.buyKing(human)
  177. end
  178. function cmd.limitMangHe(human, buyConf)
  179. LimitMangHeLogic.buy(human, buyConf.id)
  180. end
  181. function cmd.overflowFund(human,buyConf)
  182. OverflowFundLogic.onBuy(human,buyConf.args[1])
  183. end
  184. function cmd.xiLianGift(human, buyConf)
  185. MoshouLogic.xlianGiftBuy(human, buyConf.id)
  186. end
  187. function cmd.gift(human,buyConf)
  188. local buyId = buyConf.id
  189. for id,cfg in pairs(GiftExcel) do
  190. if cfg.buyID == buyId then
  191. GiftLogic.buy(human,id)
  192. break
  193. end
  194. end
  195. end
  196. function cmd.warOrder(human,buyConf)
  197. local buyId = buyConf.id
  198. for _,cfg in pairs(OrderExcel.desc) do
  199. if cfg.buyId == buyId then
  200. WarOrderLogic.warOrderUnlock(human,cfg.type)
  201. break
  202. end
  203. end
  204. end
  205. -------------------------------- cmd结束 ----------------------------------
  206. function checkBuy(human, ret)
  207. local buyID = ret.id
  208. local buyConf = BuyExcel[buyID]
  209. if buyConf then
  210. return true
  211. end
  212. ret.result = 8
  213. ret.err = buyID..":buy config not exist"
  214. end
  215. function isArgOK(human,buyID,region,money)
  216. local buyConf = BuyExcel[buyID]
  217. if not (buyConf and buyConf[region]) then
  218. return
  219. end
  220. --海外微端统计,会传转换后的美元值,增加多一层判断
  221. if PfLogic.isHaiwaiWeiduan(human) then
  222. if money == buyConf["US"] then
  223. return true
  224. end
  225. end
  226. local checkMoney = getRealPrice(human, buyID, region)
  227. if money ~= checkMoney then
  228. return
  229. end
  230. return true
  231. end
  232. --直购
  233. function buy(human, arg, nolog)
  234. local buyID
  235. if type(arg) == "table" then
  236. buyID = arg.buyID
  237. else
  238. buyID = arg
  239. end
  240. local buyConf = BuyExcel[buyID]
  241. local isFirst = getIsFirst(human, buyID)
  242. local cnt = getBuyCnt(human, buyID)
  243. local buyDB = human.db.buy
  244. buyDB[buyID] = buyDB[buyID] or {upTime = {}, cnt=0}
  245. buyDB[buyID].upTime[#buyDB[buyID].upTime + 1] = os.time()
  246. buyDB[buyID].cnt = buyDB[buyID].cnt or 0
  247. buyDB[buyID].cnt = buyDB[buyID].cnt + 1
  248. buyDB[buyID].doubleCnt = buyDB[buyID].doubleCnt or 0
  249. if cmd[buyConf.cmd] then
  250. cmd[buyConf.cmd](human, buyConf, isFirst, buyDB[buyID].doubleCnt)
  251. else
  252. YunYingLogic.onBuy(human, buyConf, isFirst, cnt)
  253. end
  254. -- 增加VIP经验
  255. if buyConf.vipExp > 0 then
  256. VipLogic.addExp(human, buyConf.vipExp)
  257. end
  258. if not nolog and type(arg) == "table" and arg.order ~= "transaction_id1"then
  259. Log.write(Log.LOGID_OSS_PAY, human.db._id, human.db.account, human.db.name, human.db.lv,arg.order or "" ,buyID or 0,arg.amt or arg.money or 0,arg.gold or 0,2,arg.region or "")
  260. end
  261. if type(arg) == "table" then
  262. afterCharge(human, arg, buyID, buyConf)
  263. end
  264. end
  265. function afterCharge(human,oJsonInput, buyID, buyConf)
  266. --local price = oJsonInput.topupMoney
  267. local buyConf = BuyExcel[buyID]
  268. local price = buyConf.CN
  269. if price and price > 0 then
  270. TopupLogic.clacTopupAcount(human, price, buyID)
  271. local msgRet = Msg.gc.GC_NOTICE_DADIAN
  272. msgRet.type = 1
  273. msgRet.param = oJsonInput.money * 100
  274. msgRet.param2 = tonumber(oJsonInput.buyID)
  275. Msg.send(msgRet,human.fd)
  276. end
  277. end
  278. --直充
  279. function charge(human,oJsonInput)
  280. --[[local gold = oJsonInput.gold
  281. local money = oJsonInput.money
  282. local region = oJsonInput.region
  283. local buyID = oJsonInput.buyID
  284. --local gold = oJsonInput.gold
  285. if buyID and BuyExcel[buyID] then
  286. oJsonInput.id = buyID
  287. buy(human,oJsonInput,true)
  288. --else
  289. --直充档次表没有对应配置的话直接给请求中要求的元宝
  290. ObjHuman.addZuanshi(human, gold, "buyTopup")
  291. end]]
  292. if oJsonInput.id and BuyExcel[oJsonInput.id] then
  293. buy(human,oJsonInput,true)
  294. if oJsonInput.order ~= 'transaction_id1' then
  295. Log.write(Log.LOGID_OSS_PAY, human.db._id, human.db.account, human.db.name, human.db.lv,oJsonInput.order,buyID or 0,oJsonInput.amt or oJsonInput.money,oJsonInput.gold,2,oJsonInput.region)
  296. end
  297. end
  298. end
  299. function onLogin(human)
  300. if not human.db.buyOrder then return end
  301. for k,v in ipairs(human.db.buyOrder) do
  302. if v.cmd == "charge" then
  303. buy(human,v)
  304. elseif v.cmd == "deliver" then
  305. charge(human,v)
  306. end
  307. end
  308. human.db.buyOrder = nil
  309. end
  310. -- 判断能不能直购
  311. function checkCanBuy(human, buyID)
  312. local buyConf = BuyExcel[buyID]
  313. if not buyConf then return end
  314. local price = getRealPrice(human, buyID, "CN")
  315. if price and not FcmLogic.checkCanBuy(human, price) then
  316. return
  317. end
  318. if SceneHandler.canCharge(human) ~= true then
  319. return Broadcast.sendErr(human, Lang.CHARGE_CLOSE_TIP)
  320. end
  321. local msgRet = Msg.gc.GC_BUY_CHECK
  322. msgRet.buyCode = BUY_CODE_NORMAL
  323. if PfLogic.isFKW(human) then
  324. -- 方块玩微信小程序的正式服 ios下走客服充值
  325. if human.isIOS == 1 then
  326. msgRet.buyCode = BUY_CODE_WX_KEFU
  327. end
  328. elseif PfLogic.isKunTang(human) then
  329. -- 坤堂微信小程序的正式服 ios和安卓都走客服充值
  330. msgRet.buyCode = BUY_CODE_WX_KEFU
  331. end
  332. fontBuyItem(human, msgRet.buyItem, buyID)
  333. Msg.send(msgRet, human.fd)
  334. end