Blame view

src/actions/CarAction.lua 5.66 KB
9c525cf9   gaofengduan   add car smithy
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
  local ipairs = ipairs
  local table = table
  local math = math
  local redisproxy = redisproxy
  local MsgPack = MsgPack
  
  local _M = {}
  
  function _M.makePotionRpc( agent, data )
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  	local potionId = msg.id
  	local count = msg.count
  	if count < 1 then return 0 end
  	local potionBag = role:getProperty("potionBag")
  	local potionLv = role.dinerData:getProperty("dishTree"):getv(potionId, 0)
  	if potionLv < 1 then return 1 end
  
  	local potionSet = csvdb["adv_potionCsv"][potionId]
  	if not potionSet then return 2 end
  
  	local potionData = potionSet[potionLv]
  	if not potionData then return 3 end
  
  	local own = potionBag[potionId] or 0
  	if own+count > potionData.limit then
  		return 4
  	end
  
  	local cost = potionData.material:toNumMap()
e668f4d0   gaofengduan   fix cost
31
32
  	for k, n in pairs(cost) do
  		cost[k] = n * count
9c525cf9   gaofengduan   add car smithy
33
34
35
36
37
  	end
  	if not role:checkItemEnough(cost) then
  		return 5
  	end
  
3133cb76   zhouhaihai   日志
38
  	role:costItems(cost, {log = {desc = "makePotion", int1 = potionId, int2 = count}})
9c525cf9   gaofengduan   add car smithy
39
40
  	potionBag[potionId] = own + count
  	role:updateProperty({field = "potionBag", value = potionBag})
53e8037e   zhouhaihai   任务
41
  	role:checkTaskEnter("PotionMake", {count = count, id = potionId})
3133cb76   zhouhaihai   日志
42
43
  
  	role:log("role_action", {desc = "makePotion", int1 = potionId, int2 = count})
9c525cf9   gaofengduan   add car smithy
44
45
46
47
48
49
50
51
52
  	SendPacket(actionCodes.Car_makePotionRpc, MsgPack.pack({potionBag = potionBag}))
  	return true
  end
  
  function _M.equipUpRpc( agent, data )
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  	local id = msg.id
  	local count = msg.count
056c01a0   zhouhaihai   简化装备
53
  
9c525cf9   gaofengduan   add car smithy
54
55
56
57
58
59
60
61
  	local typ = math.floor((id-7000)/100)
  	local lv = (id-7000)%100
  
  	local dataSet = csvdb["equipCsv"][typ]
  	if not dataSet then return 1 end
  	local equipData = dataSet[lv]
  	if not equipData then return 21 end
  	if equipData.merge < 1 then return 22 end
056c01a0   zhouhaihai   简化装备
62
  
9c525cf9   gaofengduan   add car smithy
63
64
65
66
67
68
69
70
  	local maxLv = 3
  	local nextLv = lv+1
  	if nextLv%10 > maxLv then
  		nextLv = nextLv+10-maxLv
  	end
  	local nextEquip = dataSet[nextLv]
  	if not nextEquip then return 23 end
  
912f7d2c   zhouhaihai   bug
71
  	local limit = csvdb["itemCsv"][nextEquip.id].limit ~= 0 and csvdb["itemCsv"][nextEquip.id].limit or math.huge
056c01a0   zhouhaihai   简化装备
72
73
  
  	if math.illegalNum(count, 1, limit)  then return 0 end
43cc5f51   gaofengduan   调整 equip 数据结构
74
75
  
  	local own = role:getEquipCount(typ,lv)
056c01a0   zhouhaihai   简化装备
76
  	local costCount = equipData.merge * count
43cc5f51   gaofengduan   调整 equip 数据结构
77
  	if own < costCount then
9c525cf9   gaofengduan   add car smithy
78
79
80
81
  		return 3
  	end
  
  	local cost = equipData.cost:toNumMap()
e668f4d0   gaofengduan   fix cost
82
83
  	for k, n in pairs(cost) do
  		cost[k] = n * count
9c525cf9   gaofengduan   add car smithy
84
85
86
87
88
  	end
  	if not role:checkItemEnough(cost) then
  		return 4
  	end
  
3133cb76   zhouhaihai   日志
89
90
91
  	role:costItems(cost, {log = {desc = "equipUp", int1 = id, int2 = count}})
  	role:addEquip(typ, lv, -costCount, {log = {desc = "equipUp"}})
  	role:addEquip(typ, nextLv ,count, {log = {desc = "equipUp"}})
f60b89b1   zhouhaihai   奖励副本
92
  	role:checkTaskEnter("EquipUp", {count = count})
3133cb76   zhouhaihai   日志
93
94
95
  
  	role:log("role_action", {desc = "equipUp", int1 = id, int2 = count})
  
9c525cf9   gaofengduan   add car smithy
96
97
98
99
  	SendPacket(actionCodes.Car_equipUpRpc, '')
  	return true
  end
  
fb321075   gaofengduan   add rune up
100
101
102
103
104
105
  function _M.runeUpRpc( agent, data )
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  	local uid = msg.uid
  	local ownRune = role.runeBag[uid]
  	if not ownRune then return 1 end
f52efe51   zhouhaihai   符文升级
106
  
fb321075   gaofengduan   add rune up
107
108
109
110
111
112
113
114
115
116
  
  	local typ = ownRune:getProperty("type")
  	local id = ownRune:getProperty("id")
  	local level = ownRune:getProperty("level")
  
  	local runeSet = csvdb["runeCsv"][typ]
  	if not runeSet then return 4 end
  	local runeData = runeSet[id]
  	if not runeData then return 5 end
  
3f50410e   zhouhaihai   判断错误
117
118
  	local maxLv = #csvdb["rune_buildCsv"]
  	if level >= maxLv then return 6 end
04c7448f   gaofengduan   fix rune up
119
  	local lvData = csvdb["rune_buildCsv"][level]
fb321075   gaofengduan   add rune up
120
121
122
123
124
  	local cost = lvData.cost:toNumMap()
  	if not role:checkItemEnough(cost) then
  		return 7
  	end
  
3133cb76   zhouhaihai   日志
125
  	role:costItems(cost, {log = {desc = "runeUp", int1 = uid, int2 = level}})
fb321075   gaofengduan   add rune up
126
  	ownRune:updateProperty({field = "level",value = level+1})
53e8037e   zhouhaihai   任务
127
  	role:checkTaskEnter("RuneUp")
3133cb76   zhouhaihai   日志
128
  
f52efe51   zhouhaihai   符文升级
129
130
131
132
133
134
  	if ownRune:getProperty("refer") ~= 0 then
  		local hero = role.heros[ownRune:getProperty("refer")]
  		if hero then
  			hero:updateProperty({field = "battleV", value = hero:getBattleValue()})
  		end
  	end
3133cb76   zhouhaihai   日志
135
136
  	ownRune:log({desc = "runeUp", int1 = level + 1})
  
fb321075   gaofengduan   add rune up
137
138
139
140
  	SendPacket(actionCodes.Car_runeUpRpc, '')
  	return true
  end
  
912f7d2c   zhouhaihai   bug
141
  function _M.saleEquipRpc(agent, data )
056c01a0   zhouhaihai   简化装备
142
143
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
9dd0add2   zhouhaihai   批量分解装备
144
145
146
  	local backs = msg.backs
  	if not backs then return end
  	for id, count in pairs(backs) do
2445248d   zhouhaihai   去掉热门料理
147
  		if not csvdb["itemCsv"][id] then return end
9dd0add2   zhouhaihai   批量分解装备
148
149
150
151
152
153
  		local typ = math.floor((id-7000)/100)
  		local lv = (id-7000)%100
  		local own = role:getEquipCount(typ,lv)
  		if math.illegalNum(count, 1, own)  then return end
  	end
  	local reward = {}
03a6166a   zhouhaihai   餐厅优化
154
  	local allCount = 0
9dd0add2   zhouhaihai   批量分解装备
155
  	for id, count in pairs(backs) do
03a6166a   zhouhaihai   餐厅优化
156
  		allCount = allCount + count
2445248d   zhouhaihai   去掉热门料理
157
  		local itemData = csvdb["itemCsv"][id]
9dd0add2   zhouhaihai   批量分解装备
158
159
  		local typ = math.floor((id-7000)/100)
  		local lv = (id-7000)%100
3133cb76   zhouhaihai   日志
160
  		role:addEquip(typ, lv, -count, {log = {desc = "saleEquip"}}) -- 删掉装备
9dd0add2   zhouhaihai   批量分解装备
161
162
163
164
165
  		-- 发奖励
  		local one = itemData.sell_effect:toNumMap()
  		for k ,v in pairs(one) do
  			reward[k] = (reward[k] or 0) + v * count 
  		end
056c01a0   zhouhaihai   简化装备
166
  	end
03a6166a   zhouhaihai   餐厅优化
167
  	role:checkTaskEnter("SaleEquip", {count = allCount})
3133cb76   zhouhaihai   日志
168
169
170
171
  	reward = role:award(reward, {log = {desc = "saleEquip"}})
  
  	role:log("role_action", {desc = "saleEquip", int1 = allCount})
  
056c01a0   zhouhaihai   简化装备
172
173
174
175
  	SendPacket(actionCodes.Car_saleEquipRpc, MsgPack.pack({reward = reward}))
  	return true
  end
  
497f9a67   zhouhaihai   卖零件
176
177
178
179
180
181
182
  function _M.saleRuneRpc(agent, data )
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  	local backs = msg.backs
  	if not backs then return end
  
  	local reward = {}
03a6166a   zhouhaihai   餐厅优化
183
  	local count = 0
2445248d   zhouhaihai   去掉热门料理
184
  	for _, uid in pairs(backs) do
03a6166a   zhouhaihai   餐厅优化
185
  		count = count + 1
497f9a67   zhouhaihai   卖零件
186
187
188
  		local rune = role.runeBag[uid]
  		if not rune then return end
  		if rune:getProperty("refer") ~= 0 then return end
2445248d   zhouhaihai   去掉热门料理
189
  		local itemData = csvdb["itemCsv"][rune:getProperty("id")]
497f9a67   zhouhaihai   卖零件
190
191
192
193
194
195
196
  		if not itemData then return end
  		local one = itemData.sell_effect:toNumMap()
  		for k ,v in pairs(one) do
  			reward[k] = (reward[k] or 0) + v
  		end
  	end
  
3133cb76   zhouhaihai   日志
197
  	role:delRunes(backs, {log = {desc = "saleRune"}})
03a6166a   zhouhaihai   餐厅优化
198
  	role:checkTaskEnter("DecoRune", {count = count})
3133cb76   zhouhaihai   日志
199
200
  	reward = role:award(reward, {log = {desc = "saleRune"}})
  	
497f9a67   zhouhaihai   卖零件
201
202
203
204
  	SendPacket(actionCodes.Car_saleRuneRpc, MsgPack.pack({reward = reward}))
  	return true
  end
  
9c525cf9   gaofengduan   add car smithy
205
  return _M