Blame view

src/actions/HeroAction.lua 12.9 KB
0a07bdd9   zhouahaihai   角色升级 。gm
1
2
3
4
5
6
7
8
9
10
11
12
13
14
  local ipairs = ipairs
  local table = table
  local math = math
  local next = next
  local string = string
  local redisproxy = redisproxy
  local MsgPack = MsgPack
  local getRandomName = getRandomName
  local mcast_util = mcast_util
  local string_format = string.format
  local tonumber = tonumber
  local require = require
  local table_insert = table.insert
  local tconcat = table.concat
be9c9ca6   zhouahaihai   角色评论
15
  local table_unpack = table.unpack
0a07bdd9   zhouahaihai   角色升级 。gm
16
17
18
19
20
21
22
23
24
  
  local _M = {}
  function _M.levelUpRpc( agent, data )
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  	local hero = role.heros[msg.id]
  	if not hero then return end
  
  	if hero:getProperty("level") >= hero:getMaxLevel() then return end
8c74292c   zhouahaihai   增加item 以及 角色突破
25
  	local curData = csvdb["unit_expCsv"][hero:getProperty("level")]
997cbdfe   zhouahaihai   技能养成
26
  	local cost = {[ItemId.Exp] = curData.exp, [ItemId.Gold] = curData.gold}
8c74292c   zhouahaihai   增加item 以及 角色突破
27
  	if not role:checkItemEnough(cost) then return end
36204e3c   zhengshouren   贩卖逻辑
28
  	role:costItems(cost)
0a07bdd9   zhouahaihai   角色升级 。gm
29
30
31
32
33
34
  	hero:updateProperty({field = "level", delta = 1})
  	
  	SendPacket(actionCodes.Hero_levelUpRpc, '')
  	return true
  end
  
8c74292c   zhouahaihai   增加item 以及 角色突破
35
36
37
38
39
40
41
42
43
  function _M.breakRpc( agent, data )
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  	local hero = role.heros[msg.id]
  	if not hero then return end
  
  	if hero:getProperty("level") < hero:getMaxLevel() then return end
  	if hero:getProperty("breakL") >= #csvdb["unit_breakCsv"] then return end
  	local curData = csvdb["unit_breakCsv"][hero:getProperty("breakL")]
997cbdfe   zhouahaihai   技能养成
44
  	local cost = {[ItemId.BreakCost] = curData.cost, [ItemId.Gold] = curData.gold}
8c74292c   zhouahaihai   增加item 以及 角色突破
45
  	if not role:checkItemEnough(cost) then return end
36204e3c   zhengshouren   贩卖逻辑
46
  	role:costItems(cost)
8c74292c   zhouahaihai   增加item 以及 角色突破
47
48
49
50
51
  	hero:updateProperty({field = "breakL", delta = 1})
  	
  	SendPacket(actionCodes.Hero_breakRpc, '')
  	return true
  end
0a07bdd9   zhouahaihai   角色升级 。gm
52
  
997cbdfe   zhouahaihai   技能养成
53
54
55
56
57
58
59
60
61
62
63
64
  function _M.wakeRpc(agent, data)
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  	local hero = role.heros[msg.id]
  	if not hero then return end
  	if hero:getProperty("wakeL") >= #csvdb["unit_wakeCsv"] then return end
  	local cost = {[hero:getProperty("type")] = csvdb["unit_wakeCsv"][hero:getProperty("wakeL")].cost}
  	local isEnough, less = role:checkItemEnough(cost)
  	if not isEnough then
  		cost[ItemId.HeroFC[csvdb["unitCsv"][hero:getProperty("type")].rare]] = less[hero:getProperty("type")]
  		if not role:checkItemEnough(cost) then return end
  	end
36204e3c   zhengshouren   贩卖逻辑
65
  	role:costItems(cost)
997cbdfe   zhouahaihai   技能养成
66
67
68
69
70
71
72
73
74
75
76
77
78
  	hero:updateProperty({field = "wakeL", delta = 1})
  
  	SendPacket(actionCodes.Hero_wakeRpc, '')
  	return true
  end
  
  function _M.skillUpRpc(agent, data)
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  	local index = msg.skillIdx -- 第几个技能 -- 1  2  3  
  	local hero = role.heros[msg.id]
  	if not hero then return end
  	local curLevel = hero:getSkillLevel(index)
a22cbe63   zhouahaihai   bug
79
  	if hero:getLSPoint() <= 0 or curLevel >= #hero:getSkillData(index) then return end
997cbdfe   zhouahaihai   技能养成
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
  	hero:updateProperty({field = "skillL", value = hero:getProperty("skillL"):setv(index, curLevel + 1)})
  
  	SendPacket(actionCodes.Hero_skillUpRpc, '')
  	return true
  end
  
  function _M.talentRpc(agent, data)
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  	local hero = role.heros[msg.id]
  	if not hero then return end
  
  	local index = msg.index -- 第几个天赋
  	local need = {[1] = 1, [2] = 1, [3] = 1, [4] = 1}
  	if not need[index] then return end
  
  	local talent = hero:getProperty("talent")
  	local curStage = talent:getv(0, 1)
  	if curStage > csvdb["unit_breakCsv"][hero:getProperty("breakL")].talent then return end
  	
  	local curData = csvdb["unit_talentCsv"][curStage] 
  	if not curData then return end
  
  	local level = talent:getv(index, 0)
  	if level >= #curData then return end
  
  	local talentData = curData[level]
  	if not talentData then return end
4b7c7c96   zhouahaihai   增加 清空 挂机 冒险gm 角色经验
108
109
110
111
112
113
114
  	local cost = {}
  	local needCost = talentData.cost:toTableArray(true)
  	cost[needCost[1][1]] = needCost[1][2]
  	if needCost[2] then
  		cost[globalCsv.unit_talent_cost[csvdb["unitCsv"][hero:getProperty("type")].camp][needCost[2][1]]] = needCost[2][2]
  	end
  
997cbdfe   zhouahaihai   技能养成
115
  	if not role:checkItemEnough(cost) then return end
36204e3c   zhengshouren   贩卖逻辑
116
  	role:costItems(cost)
997cbdfe   zhouahaihai   技能养成
117
118
119
120
121
122
123
124
125
126
127
  	talent = talent:incrv(index, 1)
  
  	--是否进阶
  	local max = true
  	for i = 1, 4 do
  		if talent:getv(i, 0) < #curData then
  			max = false
  			break
  		end
  	end
  	if max then
b9bd5cb6   zhouahaihai   天赋阶段 bug
128
  		talent = talent:setv(0, curStage + 1)
997cbdfe   zhouahaihai   技能养成
129
130
131
132
133
134
135
136
137
  		for i = 1, 4 do
  			talent = talent:setv(i, 0)
  		end
  	end
  	hero:updateProperty({field = "talent", value = talent})
  	SendPacket(actionCodes.Hero_talentRpc, '')
  	return true
  end
  
be9c9ca6   zhouahaihai   角色评论
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
  -- 暂时没有这个功能
  function _M.likeHeroRpc(agent, data)
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  	local heroType = msg.type
  	local result = {status = 0}
  	local isLike = false
  	local hadLike = role:getProperty("likeHero"):toArray(true, "=")
  	for _, v in pairs(hadLike) do
  		if v == heroType then
  			isLike = true
  			break
  		end
  	end
  	if isLike then
  		result.status = 1
  	else
  		redisproxy:hincrby("hero:like", "hero:"..heroType, 1)
  		table.insert(hadLike, heroType)
  		role:setProperty("likeHero", table.concat(hadLike, "="))
  	end
  
  	SendPacket(actionCodes.Hero_likeHeroRpc, MsgPack.pack(result))
  	return true
  end
  local RankLikeNum = 5 --热度显示几个
  local TimeLikeNum = 95 -- 时间显示几个
  local function getCommentKey(heroType)
  	return {
  		commentListKey = string.format("list:%d:herocomments", heroType),
  		commentRankKey = string.format("rank:%d:herocomments", heroType),
  		commentKey = string.format("hero:%d:comments", heroType),
  	}
  end
  
  local function trimComment(heroType, commentId) -- 剪裁 CommentList
  	local commentKey = getCommentKey(heroType)
  	local redret = redisproxy:pipelining(function (red)
  		red:lpush(commentKey.commentListKey, commentId)
  		red:lrange(commentKey.commentListKey, TimeLikeNum,-1)
  		red:ltrim(commentKey.commentListKey, 0, TimeLikeNum - 1)
  		red:zrevrange(commentKey.commentRankKey, 0, RankLikeNum - 1)
  	end)
  	local hots = {}
  	for _, hot in pairs(redret[4]) do
  		hots[hot] = 1
  	end
  	redisproxy:pipelining(function (red)
  		local needDel = {}
  		for _, tempId in pairs(redret[2]) do
  			if not hots[tempId] then
  				table.insert(needDel, tempId)
  			end
  		end
  		if #needDel > 0 then
  			red:zrem(commentKey.commentRankKey, table_unpack(needDel))
  			red:hdel(commentKey.commentKey, table_unpack(needDel))
  		end
  	end)
  end
  
  
  function _M.commentHeroRpc(agent, data)
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  	local heroType = msg.type
  	local content = msg.content
  
  	local result = {status = 0}  -- status 0 成功  1 已经评论过了
  	local curStutus = role.dailyData:getProperty("commentHero")
  	if curStutus:getv(heroType, 0) ~= 0 then
  		result.status = 1
  	else
  		local commentKey = getCommentKey(heroType)
  		local SERV = string.format("NAMED%d", math.random(1, 5))
  		local legal, mod = skynet.call(SERV, "lua", "check", content)
  		if not legal then
  			content = mod or ""
  		end
  		local commentId = tostring(redisproxy:hincrby("hero:comment:autoincr", "hero:" .. heroType, 1))
  		local comment = {
  			commentId = commentId, 
  			content = content,
  			roleId = role:getProperty("id"),
  			name = role:getProperty("name"),
  			-- time = skynet.timex()
  		}
  		redisproxy:hset(commentKey.commentKey, commentId, json.encode(comment))
  		trimComment(heroType, commentId)
  
  		comment.like = 0
  		result.comment = comment
  		role.dailyData:setProperty("commentHero", curStutus:setv(heroType, 1))
  	end
  	SendPacket(actionCodes.Hero_commentHeroRpc, MsgPack.pack(result))
  	return true
  end
  
  function _M.getCommentsRpc(agent, data)
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  	local heroType = msg.type
  	local list = {}  -- 评论列表
  	local commentKey = getCommentKey(heroType)
  	local commentRoleKey = string.format("comment:%d:like", role:getProperty("id"))
  	local redret = redisproxy:pipelining(function (red)
  		red:lrange(commentKey.commentListKey, 0,TimeLikeNum - 1)
  		red:zrevrange(commentKey.commentRankKey, 0, -1, "WITHSCORES") --热门
  		red:hget("hero:like", "hero:"..heroType)
  		red:lrange(commentRoleKey, 0, 999)
  	end)
  
  	local likeMap = {}
  	local idList = {}
  	local liked = {}
  	for i = 1, #redret[2], 2 do
  		likeMap[redret[2][i]] = redret[2][i + 1]
  		if i < RankLikeNum * 2 then
  			table.insert(idList, redret[2][i])
  		end
  	end
  	for i = 1, #redret[1] do
  		table.insert(idList, redret[1][i])
  	end
  	for i = 1, #redret[4] do
  		liked[redret[4][i]] = 1
  	end
  
  	local commentData = redisproxy:pipelining(function (red)
  		for _, commentId in ipairs(idList) do
  			red:hget(commentKey.commentKey, commentId)
  		end
  	end)
  	for _, commentS in ipairs(commentData or {}) do
  		local comment = json.decode(commentS)
  		comment.like = likeMap[tostring(comment.commentId)] or 0
  		comment.liked = liked[heroType .. ":" .. comment.commentId] or 0
  		table.insert(list, comment)
  	end
  	SendPacket(actionCodes.Hero_getCommentsRpc, MsgPack.pack({list = list, like = tonumber(redret[3] or 0)}))
  	return true
  end
  
  function _M.likeCommentRpc(agent, data)
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  	local actType = msg.actType  -- 1 顶 2 踩
  	local heroType = msg.type
  	local commentId = msg.commentId  --评论id
  	local commentKey = getCommentKey(heroType)
  	local add = 0
  	if actType == 1 then
  		add = 1
  	elseif actType == 2 then
  		add = -1
  	else
  		return 
  	end
  
  	local result = {status = 0} 
  	local commentIndex = heroType .. ":" .. commentId 
  	local commentRoleKey = string.format("comment:%d:like", role:getProperty("id"))
  	local redret = redisproxy:pipelining(function (red)
  		red:hexists(commentKey.commentKey, commentId) 
  		red:lrem(commentRoleKey, 1, commentIndex)
  		red:lpush(commentRoleKey, commentIndex)
  		red:ltrim(commentRoleKey, 0, 999)
  	end)
  	if (tonumber(redret[2]) or 0) > 0 then
  		result.status = 1
  	else
  		if redret[1] == 1 then-- 查不到也返回ture
  			local redret2 = redisproxy:pipelining(function (red)
  				red:zrevrange(commentKey.commentRankKey, 0, RankLikeNum - 1) --热门
  				red:zincrby(commentKey.commentRankKey, add, commentId)
  				red:zrevrange(commentKey.commentRankKey, 0, RankLikeNum - 1) --热门
  			end)
  			local out = {}
  			for _, v in pairs(redret2[1]) do
  				out[v] = 1
  			end
  			local new = {}
  			for _, v in pairs(redret2[3]) do
  				if out[v] then
  					out[v] = nil
  				else
  					new[v] = 1
  				end
  			end
  			for tempId, _ in pairs(out) do
  				trimComment(heroType, tempId)
  			end
  			redisproxy:pipelining(function (red)
  				for tempId, _ in pairs(new) do
  					red:lrem(commentKey.commentListKey, 0, tempId)
  				end
  			end)
  		end
  	end
  
  	SendPacket(actionCodes.Hero_likeCommentRpc, MsgPack.pack(result))
  	return true
  end
  
6947e382   zhouahaihai   好感度, 皮肤
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
  function _M.loveItemRpc(agent, data)
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  	local hero = role.heros[msg.id]
  	if not hero then return end
  	local result = {}
  	local curL = hero:getProperty("loveL")
  	local curExp = hero:getProperty("loveExp")
  	local curPlus = csvdb["unit_love_plusCsv"][hero:getProperty("type")]
  	if not curPlus or curL >= curPlus.limit then return end
  
  	local curEffect = csvdb["unit_love_effectCsv"][curL]
  	if not curEffect or curExp >= curEffect.loveValue then return end
  	local delta = 100  -- todo
  	local newExp = curExp + delta
  	hero:updateProperty({field = "loveExp", value = newExp})
  	if newExp >= curEffect.loveValue then
  		-- todo  发任务
  	end
  	SendPacket(actionCodes.Hero_loveItemRpc, MsgPack.pack({delta = delta}))
  	return true
  end
  
  function _M.loveTaskRpc(agent, data)
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  	local hero = role.heros[msg.id]
  	if not hero then return end
  
  	local curL = hero:getProperty("loveL")
  	local curExp = hero:getProperty("loveExp")
  	local curType = hero:getProperty("type")
  	local curPlus = csvdb["unit_love_plusCsv"][curType]
  	if not curPlus or curL >= curPlus.limit then return end
   	
   	local curEffect = csvdb["unit_love_effectCsv"][curL]
  	if not curEffect or curExp < curEffect.loveValue then return end
  
  	local lastEffect = csvdb["unit_love_effectCsv"][curL + 1]
  	local newExp = curExp - curEffect.loveValue
  	if lastEffect and curL + 1 < curPlus.limit then
  		if newExp >= lastEffect.loveValue then
  			-- todo  发任务
  		end
  	else
  		newExp = 0
  	end
  	hero:updateProperty({field = "loveExp", value = newExp})
  	hero:updateProperty({field = "loveL", value = curL + 1})
  	
  	if role:getProperty("loveStatus"):getv(curType, 0) < curL + 1 then
  		role:changeUpdates({{type = "loveStatus", field = curType, value = curL + 1}}) -- 总的
  	end
  
  	SendPacket(actionCodes.Hero_loveTaskRpc, "")
  	return true
  end
  
  function _M.changeSkinRpc(agent, data)
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  	local hero = role.heros[msg.id]
  	if not hero then return end
  	local skin = msg.skin
  	local skinData = csvdb["unit_skinCsv"][hero:getSkinId(skin)]
  	if not skinData or (skinData.itemId ~= 0 and not role:checkItemEnough({[skinData.itemId] = 1})) then return end
  	hero:updateProperty({field = "skin", value = skin})
  	SendPacket(actionCodes.Hero_changeSkinRpc, "")
  	return true
  end
  
312b9db5   zhouahaihai   背包
413
414
415
416
417
418
419
420
421
422
423
424
425
426
  function _M.createHeroRpc(agent, data)
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  	local heroType = msg.heroType
  	local unitData = csvdb["unitCsv"][heroType]
  	if not unitData then return end
  	local cost = globalCsv.unit_fragment_cost[unitData["rare"]]
  	if not cost then return end
  	if role:getItemCount(heroType) < cost then return end
  
  	for _, hero in pairs(role.heros) do
  		if hero:getProperty("type") == heroType then return end
  	end
  
36204e3c   zhengshouren   贩卖逻辑
427
  	role:costItems({[heroType] = cost})
8c199cec   zhengshouren   简化物品奖励接口,设置默认参数
428
  	role:award({[heroType + ItemStartId.Hero] = 1})
312b9db5   zhouahaihai   背包
429
430
431
432
433
  
  	SendPacket(actionCodes.Hero_createHeroRpc, "")
  	return true
  end
  
0a07bdd9   zhouahaihai   角色升级 。gm
434
  return _M