MiddleCommonRank.lua 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774
  1. --------------------------------
  2. -- 文件名 : MiddleCommonRank.lua
  3. -- 文件说明 : 跨服相关-跨服排行榜
  4. -- 创建时间 : 2025/04/02
  5. -- 创建人 : FC
  6. --------------------------------
  7. local Msg = require("core.Msg")
  8. local Timer = require("core.Timer")
  9. local DB = require("common.DB")
  10. local CommonDB = require("common.CommonDB")
  11. local CommonDefine = require("common.CommonDefine")
  12. local Log = require("common.Log")
  13. local LuaMongo = _G.lua_mongo
  14. local Util = require("common.Util")
  15. local Grid = require("bag.Grid")
  16. local MiddleConnect = require("middle.MiddleConnect")
  17. local InnerMsg = require("core.InnerMsg")
  18. local MiddleManager = require("middle.MiddleManager")
  19. local ServerCommerceRankConf = require("excel.ServerCommerce").CommerceRank
  20. -- 缓存的排行榜数据
  21. local MIDDLE_COMMON_RANK = {
  22. --[[
  23. [nRankType] =
  24. {
  25. [nRankSubType] =
  26. {
  27. [nServerKey] = {
  28. nRankType = xx,
  29. nRankSubType = xx,
  30. nServerKey = xx,
  31. -- 根据UUID获取名次
  32. uuid2rank = {
  33. [uuid] = rank, -- 玩家uuid = 排行名次
  34. },
  35. -- 根据UUID获取发送名次
  36. sendUuid2rank = {
  37. [uuid] = rank, -- 玩家uuid = 真实发送的排行名次
  38. },
  39. -- 根据名次获取DATA (DB存储的数据相同)
  40. rank2data = {
  41. [nRank] = {
  42. uuid, -- 玩家UID
  43. name, -- 玩家name
  44. head, -- 玩家头像
  45. headFrame, -- 玩家头像框
  46. nSrcServerID, -- 玩家所属服务器
  47. nValue, -- 玩家排行值
  48. nTime, -- 更新时间
  49. }
  50. }
  51. }
  52. }
  53. }
  54. ]]
  55. }
  56. -- 缓存已经要处理的战区个人邮件
  57. local MIDDLE_SENDSERVER_MAIL =
  58. {
  59. }
  60. -- 上榜的最小条件
  61. local MIDDLE_COMMON_MIN_RANK = nil
  62. -- 对应排名需要上榜条件
  63. local MIDDLE_RANK_NEED_VALUES = nil
  64. -- 通过 排行榜类型,排行榜子类型,所属战区服务器key(WarZone中的nMinServerID),uuid查找DB数据
  65. MiddleRankQueryForData = {nRankType = 1, nRankSubType = 1, nServerKey = 1 ,uuid = 1}
  66. -- 通过排行榜类型,排行榜子类型,所属战区服务器key(WarZone中的nMinServerID),DB的uuid更新DB数据
  67. MiddleRankQueryByUuid = {nRankType = 1, nRankSubType = 1, nServerKey = 1, _id = 1}
  68. -- 通过排行榜类型,排行榜子类型,所属战区服务器key(WarZone中的nMinServerID)
  69. MiddleRankQueryByRankType = {nRankType = 1, nRankSubType = 1, nServerKey = 1}
  70. -- 获取配置
  71. local function MiddleCommonRank_GetConfByType(nRankType)
  72. if CommonDefine.COMMONRANK_TYPE_SERVERCOMMERCE == nRankType then
  73. return ServerCommerceRankConf
  74. end
  75. return nil
  76. end
  77. local function MiddleCommonRank_GetMinValue(nRankType, nRankSubType)
  78. local tRankConf = MiddleCommonRank_GetConfByType(nRankType)
  79. if not tRankConf then
  80. print("[MiddleCommonRank_GetMinValue] 获取不到配置 nRankType = "..nRankType.." nRankSubType = "..nRankSubType)
  81. return nil
  82. end
  83. print("[MiddleCommonRank_GetMinValue] nRankType = "..nRankType.." nRankSubType = "..nRankSubType)
  84. local nMinRankValue
  85. if CommonDefine.COMMONRANK_TYPE_SERVERCOMMERCE == nRankType then
  86. for _, v in pairs(tRankConf) do
  87. if v.nRankType == nRankSubType then
  88. if not nMinRankValue then
  89. nMinRankValue = v.nPoint
  90. else
  91. nMinRankValue = math.min(v.nPoint, nMinRankValue)
  92. end
  93. print("[MiddleCommonRank_GetMinValue] v.nPoint = "..v.nPoint.." nMinRankValue = "..nMinRankValue)
  94. end
  95. end
  96. end
  97. if nMinRankValue then
  98. print("[MiddleCommonRank_GetMinValue] nMinRankValue = "..nMinRankValue)
  99. end
  100. return nMinRankValue
  101. end
  102. -- 获取最小上榜条件
  103. local function MiddleCommonRank_GetMinRankValue(nRankType, nRankSubType)
  104. if MIDDLE_COMMON_MIN_RANK and MIDDLE_COMMON_MIN_RANK[nRankType] and MIDDLE_COMMON_MIN_RANK[nRankType][nRankSubType] then
  105. print("[MiddleCommonRank_GetMinRankValue] 存在缓存直接返回")
  106. return MIDDLE_COMMON_MIN_RANK[nRankType][nRankSubType]
  107. end
  108. local nMinValue = MiddleCommonRank_GetMinValue(nRankType, nRankSubType)
  109. if nil == nMinValue then
  110. print("[MiddleCommonRank_GetMinRankValue] 根据配置获取不到最小上榜条件值")
  111. return nil
  112. end
  113. print("[MiddleCommonRank_GetMinRankValue] 获取到的 nMinValue = "..nMinValue)
  114. if not MIDDLE_COMMON_MIN_RANK then
  115. MIDDLE_COMMON_MIN_RANK = {}
  116. end
  117. if not MIDDLE_COMMON_MIN_RANK[nRankType] then
  118. MIDDLE_COMMON_MIN_RANK[nRankType] = {}
  119. end
  120. MIDDLE_COMMON_MIN_RANK[nRankType][nRankSubType] = nMinValue
  121. return nMinValue
  122. end
  123. -- 获取最大排行榜长度
  124. local function MiddleCommonRank_GetMaxRankLen()
  125. return CommonDefine.COMMONRANK_SAVE_DB_LEN
  126. end
  127. -- 获取对应名次上榜所需要求值
  128. local function MiddleCommonRank_GetRankNeedValue(nRankType, nRankSubType, nRank)
  129. MIDDLE_RANK_NEED_VALUES = MIDDLE_RANK_NEED_VALUES or {}
  130. local minRankValue = MiddleCommonRank_GetMinRankValue(nRankType, nRankSubType)
  131. if nil == minRankValue then
  132. print("[MiddleCommonRank_GetRankNeedValue] 获取最小上排行榜值失败 nRankType = "..nRankType.." nRankSubType = "..nRankSubType)
  133. return
  134. end
  135. print("[MiddleCommonRank_GetRankNeedValue] 获取到的最小上榜值 minRankValue = "..minRankValue.." nRank = "..nRank)
  136. if MIDDLE_RANK_NEED_VALUES[nRankType] and MIDDLE_RANK_NEED_VALUES[nRankType][nRankSubType] then
  137. local nValue = nil
  138. for _, tData in ipairs(MIDDLE_RANK_NEED_VALUES[nRankType][nRankSubType]) do
  139. if tData.nMinRank <= nRank and tData.nMaxRank >= nRank then
  140. nValue = tData.nValue
  141. break
  142. end
  143. end
  144. if nValue then
  145. print("[MiddleCommonRank_GetRankNeedValue] 获取到的最小上榜值 minRankValue = "..minRankValue.." nValue = "..nValue)
  146. end
  147. return nValue or minRankValue
  148. end
  149. local tRankConfig = MiddleCommonRank_GetConfByType(nRankType)
  150. if not tRankConfig then
  151. print("[MiddleCommonRank_GetRankNeedValue] 获取不到对应的配置")
  152. return minRankValue
  153. end
  154. if not MIDDLE_RANK_NEED_VALUES[nRankType] then
  155. MIDDLE_RANK_NEED_VALUES[nRankType] = {}
  156. end
  157. if not MIDDLE_RANK_NEED_VALUES[nRankType][nRankSubType] then
  158. MIDDLE_RANK_NEED_VALUES[nRankType][nRankSubType] = {}
  159. end
  160. local nValue = nil
  161. for _, v in pairs(tRankConfig) do
  162. if v.nRankType == nRankSubType then
  163. local nMinRank = v.nOrder[1]
  164. local nMaxRank = v.nOrder[2]
  165. table.insert(MIDDLE_RANK_NEED_VALUES[nRankType][nRankSubType], {nMinRank = nMinRank, nMaxRank = nMaxRank, nValue = v.nPoint})
  166. if not nValue then
  167. nValue = v.nPoint
  168. else
  169. if nMinRank <= nRank and nMaxRank >= nRank then
  170. nValue = v.nPoint
  171. end
  172. end
  173. end
  174. end
  175. if nValue then
  176. print("[MiddleCommonRank_GetRankNeedValue] 获取到的最小上榜值 minRankValue = "..minRankValue.." nValue = "..nValue)
  177. else
  178. print("[MiddleCommonRank_GetRankNeedValue] 获取不到对应排名所需的值 nRank = "..nRank)
  179. end
  180. return nValue or minRankValue
  181. end
  182. -- 获取指定排名类型缓存数据
  183. local function MiddleCommonRank_GetRankDataByType(nRankType, nRankSubType, nServerKey)
  184. if not MIDDLE_COMMON_RANK or not MIDDLE_COMMON_RANK[nRankType] or
  185. not MIDDLE_COMMON_RANK[nRankType][nRankSubType] or not MIDDLE_COMMON_RANK[nRankType][nRankSubType][nServerKey] then
  186. return nil
  187. end
  188. return MIDDLE_COMMON_RANK[nRankType][nRankSubType][nServerKey]
  189. end
  190. -- -- 获取指定排名类型、指定用户的排名
  191. local function MiddleCommonRank_GetRankDataByUid(nRankType, nRankSubType, nServerKey, uuid)
  192. local tRankCacheData = MiddleCommonRank_GetRankDataByType(nRankType, nRankSubType, nServerKey)
  193. if not tRankCacheData then
  194. return
  195. end
  196. return tRankCacheData.uuid2rank[uuid]
  197. end
  198. -- 获取指定排名类型、指定用户的发送排名
  199. local function MiddleCommonRank_GetSendRank(nRankType, nRankSubType, nServerKey, uuid)
  200. local tRankCacheData = MiddleCommonRank_GetRankDataByType(nRankType, nRankSubType, nServerKey)
  201. if not tRankCacheData then
  202. return
  203. end
  204. return tRankCacheData.sendUuid2rank[uuid]
  205. end
  206. -- 排序
  207. local function MiddleCommonRank_CmpRank(data1, data2)
  208. if data1.nValue ~= data2.nValue then
  209. return data1.nValue > data2.nValue
  210. end
  211. return data1.nTime < data2.nTime
  212. end
  213. -- 更新排名
  214. local function MiddleCommonRank_UpdateRank(tRankData)
  215. if not tRankData then
  216. return
  217. end
  218. -- 清空普通排名和发送排名玩家数据
  219. for uuid in pairs(tRankData.uuid2rank) do
  220. tRankData.uuid2rank[uuid] = nil
  221. tRankData.sendUuid2rank[uuid] = nil
  222. end
  223. -- 设置普通排名
  224. for rank, data in ipairs(tRankData.rank2data) do
  225. tRankData.uuid2rank[data.uuid] = rank
  226. end
  227. -- 清空发送排名
  228. for rank in ipairs(tRankData.sendRank2data) do
  229. tRankData.sendRank2data[rank] = nil
  230. end
  231. local minRankValue = MiddleCommonRank_GetMinRankValue(tRankData.nRankType, tRankData.nRankSubType) -- 排名最小需要的排名值
  232. local aleadyRankCnt = 0 -- 已经排好的玩家数
  233. local maxRank = MiddleCommonRank_GetMaxRankLen() -- 最多排名玩家数量
  234. for rank = 1, maxRank do
  235. -- 取当前排名需要的排名值
  236. local rankNeedValue = MiddleCommonRank_GetRankNeedValue(tRankData.nRankType, tRankData.nRankSubType, rank)
  237. if rankNeedValue then
  238. print("[MiddleCommonRank_UpdateRank] rankNeedValue = "..rankNeedValue)
  239. end
  240. local rank2data = tRankData.rank2data[aleadyRankCnt + 1] -- 当前排的玩家
  241. if rank2data then -- 还有玩家需要排
  242. print("[MiddleCommonRank_UpdateRank] 存在 rank2data")
  243. table.print_lua_table(rank2data)
  244. if rank2data.nValue >= rankNeedValue then -- 达到排名值,可以排名
  245. tRankData.sendUuid2rank[rank2data.uuid] = rank -- 设置玩家发送排名
  246. tRankData.sendRank2data[rank] = rank2data -- 设置发送排名数据
  247. aleadyRankCnt = aleadyRankCnt + 1 -- 排名玩家数量+1
  248. elseif rankNeedValue <= minRankValue then -- 未达到排名值 且 当前排名值 小于等于 最小需要的排名值了,则后面的玩家都不需要排了
  249. break
  250. else -- 未到达最低排名值,当前名次未有玩家达到
  251. tRankData.sendRank2data[rank] = -1
  252. end
  253. else -- 没玩家排了直接停止
  254. break
  255. end
  256. end
  257. end
  258. -- 更新数据
  259. local function MiddleCommonRank_UpdateData(nRankType, nRankSubType, nServerKey, data)
  260. local tRankData = MiddleCommonRank_GetRankDataByType(nRankType, nRankSubType, nServerKey)
  261. if not tRankData then
  262. return
  263. end
  264. local uuid = data.uuid
  265. local oldRank = MiddleCommonRank_GetRankDataByUid(nRankType, nRankSubType, nServerKey, uuid) or (#tRankData.rank2data + 1)
  266. tRankData.rank2data[oldRank] = data
  267. -- 向后比较(data.value 减少时),往排名低方向->
  268. for i = oldRank + 1, #tRankData.rank2data do
  269. local data1 = tRankData.rank2data[i - 1]
  270. local data2 = tRankData.rank2data[i]
  271. if MiddleCommonRank_CmpRank(data1, data2) then
  272. break
  273. end
  274. tRankData.rank2data[i - 1] = data2
  275. tRankData.rank2data[i] = data1
  276. end
  277. -- 向前比较(data.value 增加时),往排名高方向<-
  278. for i = oldRank - 1, 1, -1 do
  279. local data1 = tRankData.rank2data[i]
  280. local data2 = tRankData.rank2data[i + 1]
  281. if MiddleCommonRank_CmpRank(data1, data2) then
  282. break
  283. end
  284. tRankData.rank2data[i] = data2
  285. tRankData.rank2data[i + 1] = data1
  286. end
  287. local maxRank = MiddleCommonRank_GetMaxRankLen()
  288. tRankData.rank2data[maxRank + 1] = nil
  289. return true
  290. end
  291. -- 起服将数据插入排行榜
  292. local function MiddleCommonRank_InsertCacheData(data)
  293. local tRankData = MiddleCommonRank_GetRankDataByType(data.nRankType, data.nRankSubType, data.nServerKey)
  294. if not tRankData then
  295. print("[MiddleCommonRank_InsertCacheData] 不存在对应的排行榜数据")
  296. return
  297. end
  298. table.insert(tRankData.rank2data, data)
  299. end
  300. -- 对整个排行榜进行排序
  301. local function MiddleCommonRank_SortAllRank(nRankType, nRankSubType, nServerKey)
  302. local tRankData = MiddleCommonRank_GetRankDataByType(nRankType, nRankSubType, nServerKey)
  303. if not tRankData then
  304. print("[MiddleCommonRank_SortAllRank] 不存在对应的排行榜数据")
  305. return false
  306. end
  307. table.sort(tRankData.rank2data, MiddleCommonRank_CmpRank)
  308. local maxRank = MiddleCommonRank_GetMaxRankLen()
  309. local nNowLen = #tRankData.rank2data
  310. -- 大于了排行榜最大缓存数据
  311. if maxRank < nNowLen then
  312. for i = maxRank + 1, nNowLen, 1 do
  313. tRankData.rank2data[i] = nil
  314. end
  315. end
  316. return true
  317. end
  318. -- 重置排行数据
  319. local function MiddleCommonRank_ResertCacheData(nRankType, nRankSubType, nServerKey)
  320. if not MIDDLE_COMMON_RANK[nRankType] then
  321. MIDDLE_COMMON_RANK[nRankType] = {}
  322. end
  323. if not MIDDLE_COMMON_RANK[nRankType][nRankSubType] then
  324. MIDDLE_COMMON_RANK[nRankType][nRankSubType] = {}
  325. end
  326. if not MIDDLE_COMMON_RANK[nRankType][nRankSubType][nServerKey] then
  327. MIDDLE_COMMON_RANK[nRankType][nRankSubType][nServerKey] = {}
  328. end
  329. MIDDLE_COMMON_RANK[nRankType][nRankSubType][nServerKey].nRankType = nRankType
  330. MIDDLE_COMMON_RANK[nRankType][nRankSubType][nServerKey].nRankSubType = nRankSubType
  331. MIDDLE_COMMON_RANK[nRankType][nRankSubType][nServerKey].nServerKey = nServerKey
  332. MIDDLE_COMMON_RANK[nRankType][nRankSubType][nServerKey].uuid2rank = {} -- 根据UUID获取名次
  333. MIDDLE_COMMON_RANK[nRankType][nRankSubType][nServerKey].sendUuid2rank = {} -- 根据UUID获取发送名次
  334. MIDDLE_COMMON_RANK[nRankType][nRankSubType][nServerKey].rank2data = {} -- 根据名次获取DATA
  335. MIDDLE_COMMON_RANK[nRankType][nRankSubType][nServerKey].sendRank2data = {} -- 根据名次获取发送DATA
  336. end
  337. -- 初始排行榜
  338. local function MiddleCommonRank_InitCacheData(nRankType, nRankSubType)
  339. if not MIDDLE_COMMON_RANK[nRankType] then
  340. MIDDLE_COMMON_RANK[nRankType] = {}
  341. end
  342. if not MIDDLE_COMMON_RANK[nRankType][nRankSubType] then
  343. MIDDLE_COMMON_RANK[nRankType][nRankSubType] = {}
  344. end
  345. end
  346. -- 加载排行榜
  347. local function MiddleCommonRank_LoadDBData()
  348. local cnt = 0
  349. LuaMongo.find(DB.db_middle_rank, nil)
  350. local tNeedSortRank = {}
  351. while true do
  352. local data = {}
  353. if not LuaMongo.next(data) then
  354. break
  355. end
  356. cnt = cnt + 1
  357. if cnt % 1000 == 0 then
  358. _G.collectgarbage("step", 100000)
  359. end
  360. if not tNeedSortRank[data.nRankType] then
  361. tNeedSortRank[data.nRankType] = {}
  362. end
  363. if not tNeedSortRank[data.nRankType][data.nRankSubType] then
  364. tNeedSortRank[data.nRankType][data.nRankSubType] = {}
  365. end
  366. if not tNeedSortRank[data.nRankType][data.nRankSubType][data.nServerKey] then
  367. tNeedSortRank[data.nRankType][data.nRankSubType][data.nServerKey] = 1
  368. MiddleCommonRank_ResertCacheData(data.nRankType, data.nRankSubType, data.nServerKey)
  369. end
  370. print("[MiddleCommonRank_LoadDBData] 获取到数据")
  371. table.print_lua_table(data)
  372. -- 先插入数据, 后排序
  373. MiddleCommonRank_InsertCacheData(data)
  374. end
  375. for nRankType, v1 in pairs(tNeedSortRank) do
  376. for nRankSubType, v2 in pairs(v1) do
  377. for nServerKey, _ in pairs(v2) do
  378. local bRet = MiddleCommonRank_SortAllRank(nRankType, nRankSubType, nServerKey)
  379. if true == bRet then
  380. print("[MiddleCommonRank_LoadDBData] 排序成功 nRankType = "..nRankType.." nRankSubType = "..nRankSubType.." nServerKey = "..nServerKey)
  381. else
  382. print("[MiddleCommonRank_LoadDBData] 排序失败 nRankType = "..nRankType.." nRankSubType = "..nRankSubType.." nServerKey = "..nServerKey)
  383. end
  384. end
  385. end
  386. end
  387. for nRankType, v1 in pairs(MIDDLE_COMMON_RANK) do
  388. for nRankSubType, v2 in pairs(v1) do
  389. for nServerKey, tData in pairs(v2) do
  390. MiddleCommonRank_UpdateRank(tData)
  391. end
  392. end
  393. end
  394. end
  395. -- 根据类型+uuid从db中取data
  396. local function MiddleCommonRank_GetDBDataByUid(nRankType, nRankSubType, nServerKey, uuid)
  397. -- MiddleRankQueryForData = {nRankType = 1, nRankSubType = 1, nServerKey = 1 ,uuid = 1}
  398. MiddleRankQueryForData.nRankType = nRankType
  399. MiddleRankQueryForData.nRankSubType = nRankSubType
  400. MiddleRankQueryForData.nServerKey = nServerKey
  401. MiddleRankQueryForData.uuid = uuid
  402. local data = {}
  403. LuaMongo.find(DB.db_middle_rank, MiddleRankQueryForData)
  404. return LuaMongo.next(data) and data
  405. end
  406. -- 更新DB数据
  407. local function MiddleCommonRank_UpdateDBData(data)
  408. local oldData = MiddleCommonRank_GetDBDataByUid(data.nRankType, data.nRankSubType, data.nServerKey, data.uuid)
  409. if oldData then
  410. MiddleRankQueryForData.nRankType = data.nRankType
  411. MiddleRankQueryForData.nRankSubType = data.nRankSubType
  412. MiddleRankQueryForData.nServerKey = data.nServerKey
  413. MiddleRankQueryForData.uuid = data.uuid
  414. LuaMongo.update(DB.db_middle_rank, MiddleRankQueryForData, data)
  415. print("[MiddleCommonRank_UpdateDBData] 存在久数据进行更新")
  416. else
  417. LuaMongo.insert(DB.db_middle_rank, data)
  418. print("[MiddleCommonRank_UpdateDBData] 不存在久数据直接进行插入")
  419. end
  420. end
  421. -- 设置排名数据
  422. local function MiddleCommonRank_SetRankInfo(data)
  423. local tRankData = MiddleCommonRank_GetRankDataByType(data.nRankType, data.nRankSubType, data.nServerKey)
  424. if not tRankData then
  425. print("[MiddleCommonRank_SetRankInfo] 获取不到缓存的排行数据")
  426. return
  427. end
  428. MiddleCommonRank_UpdateData(data.nRankType, data.nRankSubType, data.nServerKey, data)
  429. MiddleCommonRank_UpdateRank(tRankData)
  430. MiddleCommonRank_UpdateDBData(data)
  431. end
  432. -- 检查缓存
  433. local function MiddleCommonRank_CheckHaveCache(nRankType, nRankSubType, nServerKey)
  434. if not MIDDLE_COMMON_RANK[nRankType] then
  435. MiddleCommonRank_ResertCacheData(nRankType, nRankSubType, nServerKey)
  436. print("[MiddleCommonRank_CheckHaveCache] 检查缓存 不存在对应 nRankType 缓存,重新创建 nRankType = "
  437. ..nRankType.." nRankSubType = "..nRankSubType.." nServerKey = "..nServerKey)
  438. return
  439. end
  440. if not MIDDLE_COMMON_RANK[nRankType][nRankSubType] then
  441. MiddleCommonRank_ResertCacheData(nRankType, nRankSubType, nServerKey)
  442. print("[MiddleCommonRank_CheckHaveCache] 检查缓存 不存在对应 nRankSubType 缓存,重新创建 nRankType = "
  443. ..nRankType.." nRankSubType = "..nRankSubType.." nServerKey = "..nServerKey)
  444. return
  445. end
  446. if not MIDDLE_COMMON_RANK[nRankType][nRankSubType][nServerKey] then
  447. MiddleCommonRank_ResertCacheData(nRankType, nRankSubType, nServerKey)
  448. print("[MiddleCommonRank_CheckHaveCache] 检查缓存 不存在对应 nServerKey 缓存,重新创建 nRankType = "
  449. ..nRankType.." nRankSubType = "..nRankSubType.." nServerKey = "..nServerKey)
  450. return
  451. end
  452. end
  453. -------------------------------------------------- 外部调用 -----------------------------------------
  454. -- 启动就初始化
  455. function MiddleCommonRank_InitAfterStart()
  456. -- 不是中心服不用处理
  457. if _G.is_middle ~= true then
  458. return
  459. end
  460. -- 先初始化一下
  461. MiddleCommonRank_InitCacheData(CommonDefine.COMMONRANK_TYPE_SERVERCOMMERCE, CommonDefine.COMMONRANK_SUB_TYPE_SERVERCOMMERCE_SERVER)
  462. MiddleCommonRank_InitCacheData(CommonDefine.COMMONRANK_TYPE_SERVERCOMMERCE, CommonDefine.COMMONRANK_SUB_TYPE_SERVERCOMMERCE_HUMAN)
  463. -- 加载DB数据
  464. print("[MiddleCommonRank_InitAfterStart] 开始加载DB数据")
  465. MiddleCommonRank_LoadDBData()
  466. end
  467. -- 获取到跨服数据
  468. function MiddleCommonRank_ReceiveRankData(tMsgData)
  469. if _G.is_middle ~= true then
  470. return
  471. end
  472. local nConfServerID = MiddleConnect.MiddleConnect_TrueServerID2ConfServerID(tMsgData.nSrcServerID)
  473. local nServerKey = MiddleConnect.MiddleConnect_GetWarZoneServer(nConfServerID)
  474. local tDBData = MiddleCommonRank_GetDBDataByUid(tMsgData.nRankType, tMsgData.nRankSubType, nServerKey, tMsgData.uuid)
  475. if not tDBData then
  476. tDBData = {}
  477. end
  478. -- 检查缓存, 主要是 nConfServerID 这个对应的排行数据可能需要建立
  479. MiddleCommonRank_CheckHaveCache(tMsgData.nRankType, tMsgData.nRankSubType, nServerKey)
  480. tDBData.uuid = tMsgData.uuid
  481. tDBData.name = tMsgData.name
  482. tDBData.head = tMsgData.head
  483. tDBData.headFrame = tMsgData.headFrame
  484. tDBData.nSrcServerID = tMsgData.nSrcServerID
  485. tDBData.nRankType = tMsgData.nRankType
  486. tDBData.nRankSubType = tMsgData.nRankSubType
  487. tDBData.nServerKey = nServerKey
  488. tDBData.servername = tMsgData.servername
  489. -- 已经存在数据的用之前上榜的时间
  490. tDBData.nTime = tDBData.nTime or os.time()
  491. -- 排行的value值需要判断
  492. tDBData.nValue = tDBData.nValue or 0
  493. print("[MiddleCommonRank_ReceiveRankData] 获取到数据 name = "..tDBData.name.." nDBValue = "..tDBData.nValue.." nValue = "..tMsgData.nValue)
  494. local nMinValue = MiddleCommonRank_GetMinValue(tMsgData.nRankType, tMsgData.nRankSubType)
  495. if not nMinValue then
  496. print("[MiddleCommonRank_ReceiveRankData] 获取不到对应的最小上榜条件")
  497. return
  498. end
  499. local bUpRank = false
  500. if CommonDefine.COMMONRANK_VALUE_REPLACE == tMsgData.nOperate then
  501. -- 直接替换,对应nValue在普通服有存储,发上来都是最终的值,不满足条件可以不存
  502. tDBData.nValue = tMsgData.nValue
  503. if tDBData.nValue >= nMinValue then
  504. bUpRank = true
  505. end
  506. elseif CommonDefine.COMMONRANK_VALUE_ADD == tMsgData.nOperate then
  507. -- 直接增加的操作需要存库
  508. tDBData.nValue = tDBData.nValue + tMsgData.nValue
  509. bUpRank = true
  510. end
  511. if true == bUpRank then
  512. MiddleCommonRank_SetRankInfo(tDBData)
  513. print("[MiddleCommonRank_ReceiveRankData] 玩家上榜进行成功")
  514. end
  515. end
  516. function MiddleCommonRank_QueryRankInfo(tMsgData)
  517. if _G.is_middle ~= true then
  518. return
  519. end
  520. local nRankType = tMsgData.nRankType
  521. local nRankSubType = tMsgData.nRankSubType
  522. local nServerKey = MiddleConnect.MiddleConnect_TrueServerID2ConfServerID(tMsgData.nSrcServerID)
  523. nServerKey = MiddleConnect.MiddleConnect_GetWarZoneServer(nServerKey)
  524. local nSrcFD = MiddleManager.getFDBySvrIndex(tMsgData.nSrcServerID)
  525. if not nSrcFD then
  526. print("[MiddleCommonRank_QueryRankInfo] 获取不到对应的 服务器的 fd nSrcServerID = "..tMsgData.nSrcServerID)
  527. return
  528. end
  529. -- 检查缓存, 主要是 nServerKey 这个对应的排行数据可能需要建立
  530. MiddleCommonRank_CheckHaveCache(tMsgData.nRankType, tMsgData.nRankSubType, nServerKey)
  531. local tSendMsgData = InnerMsg.wl.WL_COMMERCE_QUERY_RANK_INFO
  532. tSendMsgData.nRankType = nRankType
  533. tSendMsgData.nRankSubType = nRankSubType
  534. tSendMsgData.nServerKey = nServerKey
  535. tSendMsgData.nBegin = 1
  536. tSendMsgData.nEnd = 0
  537. tSendMsgData.tRankData = {}
  538. tSendMsgData.tRankData[0] = 0
  539. local tRankCacheData = MiddleCommonRank_GetRankDataByType(nRankType, nRankSubType, nServerKey)
  540. if not tRankCacheData or nil == _G.next(tRankCacheData) then
  541. tSendMsgData.nEnd = 1
  542. else
  543. for nRank, v in pairs(tRankCacheData.sendRank2data) do
  544. tSendMsgData.tRankData[0] = tSendMsgData.tRankData[0] + 1
  545. tSendMsgData.tRankData[tSendMsgData.tRankData[0]] = {
  546. nRank = nRank,
  547. tRankData = v,
  548. }
  549. if tSendMsgData.tRankData[0] >= CommonDefine.COMMONRANK_ONE_SEND_LEN then
  550. InnerMsg.sendMsg(nSrcFD, tSendMsgData)
  551. tSendMsgData.tRankData[0] = 0
  552. tSendMsgData.nBegin = 0
  553. end
  554. end
  555. tSendMsgData.nEnd = 1
  556. end
  557. InnerMsg.sendMsg(nSrcFD, tSendMsgData)
  558. print("[MiddleCommonRank_QueryRankInfo] 向普通服发送排行榜数据完成")
  559. end
  560. -- 请求服务器排行榜对应服务器排名
  561. function MiddleCommonRank_QueryServerRank(msg)
  562. local nSrcFD = MiddleManager.getFDBySvrIndex(msg.nSrcServerID)
  563. if not nSrcFD then
  564. print("[MiddleCommonRank_QueryServerRank] 获取不到对应的 服务器的 fd nSrcServerID = "..msg.nSrcServerID)
  565. return
  566. end
  567. print("[MiddleCommonRank_QueryServerRank] 请求服务器排行榜对应服务器排名 nOperate = "..msg.nOperate.." nServerUuid = "..msg.nServerUuid)
  568. local tMsgData = InnerMsg.wl.WL_COMMERCE_GET_SERVERRANK_PRIZE
  569. tMsgData.nOperate = msg.nOperate
  570. local nServerKey = MiddleConnect.MiddleConnect_TrueServerID2ConfServerID(msg.nSrcServerID)
  571. nServerKey = MiddleConnect.MiddleConnect_GetWarZoneServer(nServerKey)
  572. print("[MiddleCommonRank_QueryServerRank] 请求服务器排行榜对应服务器排名 nServerKey = "..nServerKey)
  573. local tRankCacheData = MiddleCommonRank_GetRankDataByType(CommonDefine.COMMONRANK_TYPE_SERVERCOMMERCE,
  574. CommonDefine.COMMONRANK_SUB_TYPE_SERVERCOMMERCE_SERVER, nServerKey)
  575. local nNowRank = -1
  576. if not tRankCacheData then
  577. print("[MiddleCommonRank_QueryServerRank] 不存在缓存数据")
  578. nNowRank = MiddleCommonRank_GetMaxRankLen() + 1
  579. else
  580. print("[MiddleCommonRank_QueryServerRank] 存在缓存数据")
  581. for nRank, v in pairs(tRankCacheData.rank2data) do
  582. print("[MiddleCommonRank_QueryServerRank] nRank = "..nRank)
  583. if "table"== type(v) then
  584. print("[MiddleCommonRank_QueryServerRank] nRank = "..nRank.." uuid = "..v.uuid.." type1 = "..type(v.uuid).." type2 = "..type(msg.nServerUuid))
  585. end
  586. if "table"== type(v) and v.uuid == msg.nServerUuid then
  587. print("[MiddleCommonRank_QueryServerRank] nRank = "..nRank.." uuid = "..v.uuid.." nServerUuid = "..msg.nServerUuid)
  588. nNowRank = nRank
  589. break
  590. end
  591. end
  592. end
  593. if -1 >= nNowRank then
  594. nNowRank = MiddleCommonRank_GetMaxRankLen() + 1
  595. end
  596. tMsgData.nRank = nNowRank
  597. print("[MiddleCommonRank_QueryServerRank] 获取到rank = "..nNowRank.." nSrcServerID = "..msg.nSrcServerID.." nServerKey = "..nServerKey)
  598. InnerMsg.sendMsg(nSrcFD, tMsgData)
  599. end
  600. -- 延迟发送个人奖励
  601. function MiddleCommonRank_SendHumanRankPrize(nRankType, nRankSubType, nServerKey)
  602. print("[MiddleCommonRank_SendHumanRankPrize] 开始处理对应的个人排行榜奖励 nRankType = "..nRankType.." nRankSubType = "..nRankSubType.." nServerKey = "..nServerKey)
  603. local tRankData = MiddleCommonRank_GetRankDataByType(nRankType, nRankSubType, nServerKey)
  604. if tRankData then
  605. local tMsgData = InnerMsg.wl.WL_COMMERCE_SEND_HUMAN_PRIZE
  606. for nRank, v in ipairs(tRankData.rank2data) do
  607. if type(v) == "table" then
  608. tMsgData.nRank = nRank
  609. tMsgData.uuid = v.uuid
  610. local nSrcFD = MiddleManager.getFDBySvrIndex(v.nSrcServerID)
  611. if nSrcFD then
  612. print("[MiddleCommonRank_SendHumanRankPrize] nRank = "..nRank.." uuid = "..v.uuid.." nSrcServerID = "..v.nSrcServerID)
  613. InnerMsg.sendMsg(nSrcFD, tMsgData)
  614. else
  615. print("[MiddleCommonRank_SendHumanRankPrize] 获取不到对应服务器的FD nSrcServerID = "..v.nSrcServerID)
  616. end
  617. end
  618. end
  619. else
  620. print("[MiddleCommonRank_SendHumanRankPrize] 不存在对应的个人排行榜数据 nRankType = "..nRankType.." nRankSubType = "..nRankSubType.." nServerKey = "..nServerKey)
  621. end
  622. print("[MiddleCommonRank_SendHumanRankPrize] 开始处理对应的个人排行榜奖励完成")
  623. end
  624. -- 服务器发送全服邮件结束
  625. function MiddleCommonRank_ServerMailOk(msg)
  626. -- 先获取对应配置ID,再获取最小的ID
  627. local nConfServerID = MiddleConnect.MiddleConnect_TrueServerID2ConfServerID(msg.nSrcServerID)
  628. local nServerKey, nMaxServerID = MiddleConnect.MiddleConnect_GetWarZoneServer(nConfServerID)
  629. if not MIDDLE_SENDSERVER_MAIL[nServerKey] then
  630. MIDDLE_SENDSERVER_MAIL[nServerKey] = 1
  631. print("[MiddleCommonRank_ServerMailOk] 延迟处理个人邮件奖励 nServerKey = "..nServerKey)
  632. -- 延迟处理对应个人排行榜奖励
  633. Timer.addLater(10, MiddleCommonRank_SendHumanRankPrize, CommonDefine.COMMONRANK_TYPE_SERVERCOMMERCE, CommonDefine.COMMONRANK_SUB_TYPE_SERVERCOMMERCE_HUMAN, nServerKey)
  634. end
  635. end
  636. function MiddleCommonRank_ClearRank(msg)
  637. local nConfServerID = MiddleConnect.MiddleConnect_TrueServerID2ConfServerID(msg.nSrcServerID)
  638. local nServerKey = MiddleConnect.MiddleConnect_GetWarZoneServer(nConfServerID)
  639. MiddleCommonRank_ResertCacheData(msg.nRankType, msg.nRankSubType, nServerKey)
  640. print("[MiddleCommonRank_ClearRank] 清理排行榜开始 nRankType = "..msg.nRankType.." nRankSubType = "..msg.nRankSubType.." nServerKey = "..nServerKey)
  641. MiddleRankQueryByRankType.nRankType = msg.nRankType
  642. MiddleRankQueryByRankType.nRankSubType = msg.nRankSubType
  643. MiddleRankQueryByRankType.nServerKey = nServerKey
  644. LuaMongo.find(DB.db_middle_rank, MiddleRankQueryByRankType)
  645. local tData = {}
  646. if not LuaMongo.next(tData) then
  647. print("[MiddleCommonRank_ClearRank] 不存在对应的数据")
  648. return
  649. end
  650. LuaMongo.remove(DB.db_middle_rank, MiddleRankQueryByRankType)
  651. print("[MiddleCommonRank_ClearRank] 清理排行榜数据完成")
  652. end