Blame view

src/services/globald.lua 8.44 KB
314bc5df   zhengshouren   提交服务器初始代码
1
2
3
4
5
6
7
8
9
  local skynet = require "skynet"
  local harbor = require "skynet.harbor"
  local json = require("shared.json")
  local redisproxy = require("shared.redisproxy")
  
  require "shared.init"
  require "utils.init"
  require "RedisKeys"
  require "skynet.manager"
66fe093a   liuzujun   元旦关卡活动
10
  require "GlobalVar"
314bc5df   zhengshouren   提交服务器初始代码
11
  
875e5071   zhouhaihai   服务名称修改
12
  
314bc5df   zhengshouren   提交服务器初始代码
13
14
15
16
17
  local ipairs = ipairs
  local table_insert = table.insert
  local tarr2tab = table.array2Table
  local string_format = string.format
  
314bc5df   zhengshouren   提交服务器初始代码
18
  
875e5071   zhouhaihai   服务名称修改
19
  local CHECK_MAIL_STATUS_INTERVAL 	= 100 * 60
66fe093a   liuzujun   元旦关卡活动
20
  local CHECK_BATTLE_ACT_CLOSE_INTERVAL = 100 * 1
314bc5df   zhengshouren   提交服务器初始代码
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
  local function mailQuene()
  	local delayEmail = tonum(redisproxy:hget("autoincrement_set", "delay_email"))
  	if delayEmail == 0 then
  		return
  	end
  	local begin = math.max(delayEmail - 100, 1)
  	local mails = redisproxy:pipelining(function (red)
  		for id = begin, delayEmail do
  			red:hgetall(string.format("delayEmail:%s", id))
  		end
  	end)
  	if not mails then
  		return
  	end
  	local now = skynet.timex()
  	local mailList = {}
  	for index, data in ipairs(mails) do
  		if next(data) then
  			local email = tarr2tab(data)
  			if tonum(email.startTime) <= now then
  				table_insert(mailList, email)
  
  				if #mailList > 100 then
  					break
  				end
  			end
  		end
  	end
  	if #mailList == 0 then
  		return
  	end
  	redisproxy:pipelining(function (red)
  		for _, email in ipairs(mailList) do
  			red:del(string_format("delayEmail:%s", email.id))
  		end
  	end)
  	table.sort(mailList, function(a, b)
  		return tonum(a.id) < tonum(b.id)
  	end)
  	for _, email in ipairs(mailList) do
  		local gid = redisproxy:hincrby("autoincrement_set", "email", 1)
  		if email.mid then
  			redisproxy:hmset(string_format("globalEmail:%s", gid), 
  				"id", gid,
ca128b32   zhouhaihai   邮件时间bug
65
  				"createtime", email.startTime,
314bc5df   zhengshouren   提交服务器初始代码
66
  				"title", email.title,
eb4b0152   zhouhaihai   邮件增加 stitle
67
  				"stitle", email.stitle,
314bc5df   zhengshouren   提交服务器初始代码
68
69
70
71
  				"content", email.content,
  				"attachments", email.attachments,
  				"endtime", email.endTime,
  				"mid", email.mid,
017184f4   zhouhaihai   global
72
73
  				"timestamp", now,
  				"delayType", email.delayType
314bc5df   zhengshouren   提交服务器初始代码
74
75
76
77
  			)
  		else
  			redisproxy:hmset(string_format("globalEmail:%s", gid), 
  				"id", gid,
ca128b32   zhouhaihai   邮件时间bug
78
  				"createtime", email.startTime,
d9cb65a9   zhouhaihai   bug
79
  				"title", email.title,
eb4b0152   zhouhaihai   邮件增加 stitle
80
  				"stitle", email.stitle,
314bc5df   zhengshouren   提交服务器初始代码
81
82
83
  				"content", email.content,
  				"attachments", email.attachments,
  				"endtime", email.endTime,
017184f4   zhouhaihai   global
84
85
  				"timestamp", now,
  				"delayType", email.delayType
314bc5df   zhengshouren   提交服务器初始代码
86
87
88
89
90
91
92
93
94
95
96
97
  			)
  		end
  	end
  	redisproxy:hset("autoincrement_set", "emailTimestamp", now)
  end
  
  -- @desc: 定时邮件队列检测
  local function check_mail_queue()
  	pcall(mailQuene)
  	skynet.timeout(CHECK_MAIL_STATUS_INTERVAL, check_mail_queue)
  end
  
66fe093a   liuzujun   元旦关卡活动
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
  -- @desc: 检测关卡活动结束 排行榜奖励发放
  local lastCheckBattleActTs = 0
  local function check_battle_act_close()
  	local csvdb = require "shared.csvdata"
  	local act = require "models.Activity"
  	local st = 0
  	local et = 0
  	local actId = 0
  	local timeNow = skynet.timex()
  	for k, v in pairs(csvdb["activity_ctrlCsv"]) do
  		if v.showType == act.ActivityType.ChallengeLevel then
  			local openTimes = v.time:toArray(false, "=")
  			if openTimes[1] ~= "0" then
  				st = toUnixtime(openTimes[1]..string_format("%02x", RESET_TIME))
  			end
  			if openTimes[2] ~= "0" then
  				et = toUnixtime(openTimes[2]..string_format("%02x", RESET_TIME))
  			end
  			actId = k
  			break
  		end
  	end
  	if st ~= 0 and et ~= 0 and actId ~= 0 then
  		-- close
  		if lastCheckBattleActTs < et and timeNow >= et then
  			-- check rank key exist
  			local rankKey = RANK_COMMON..RANK_TYPE.ActBattleBoss
  			local flag = redisproxy:exists(rankKey)
  			if flag then
  				local actData = csvdb["activity_groupCsv"][actId]
  				local lastRank = actData[#actData].rank
  
  				local ids = redisproxy:zrevrange(rankKey, 0 , lastRank - 1)
  				local rankIndex = 0
  				for roleId in pairs(ids) do
  					rankIndex = rankIndex + 1
  					for _, cfg in pairs(actData) do
  						if rankIndex <= cfg.rank then
  							redisproxy:insertEmail({
  								roleId = roleId,
  								emailId = cfg.email_1,
  								attachments = cfg.reward_1,
  								contentPms = {rankIndex},
  							})
  							break
  						end
  					end
  				end
  
  				redisproxy:del(rankKey..":bak")
  				redisproxy:rename(rankKey, rankKey..":bak")
  			end
  		end
  	end
  	lastCheckBattleActTs = skynet.timex()
  	skynet.timeout(CHECK_BATTLE_ACT_CLOSE_INTERVAL, check_battle_act_close)
  end
  
65b551a7   chenyueqi   海港贸易季初版
156
157
  -- @desc: 检查海港贸易开启、关闭
  local function check_trade_seaport_status()
e820b3f3   chenyueqi   海港贸易季bug修正
158
  	local nowTime = skynet.timex()
65b551a7   chenyueqi   海港贸易季初版
159
  	local nextTime = dayLater(nowTime)
e820b3f3   chenyueqi   海港贸易季bug修正
160
  	local interval = 100 * (nextTime - nowTime + 1)
65b551a7   chenyueqi   海港贸易季初版
161
162
  
  	local curTm = os.date("*t", nowTime)
e820b3f3   chenyueqi   海港贸易季bug修正
163
164
165
166
167
168
169
170
171
  	if curTm.wday == 7 and curTm.hour >= 4 then -- 周六
  		local oldTime = tonumber(redisproxy:hget("autoincrement_set", "seaportTime0")) or 0
  		local cur4Time = specTime({hour = 4},nowTime)
  		if cur4Time ~= oldTime then
  			redisproxy:hset("autoincrement_set", "seaportTime0", cur4Time)
  			redisproxy:hset("autoincrement_set", "seaportTime1", 1)
  			redisproxy:del(SEAPORT_TRADE_TASK_1)
  			redisproxy:del(SEAPORT_TRADE_TASK_2)
  		end
65b551a7   chenyueqi   海港贸易季初版
172
  	end
e820b3f3   chenyueqi   海港贸易季bug修正
173
174
175
176
  	if curTm.wday == 1 and curTm.hour >= 4 then -- 周日
  		if (tonumber(redisproxy:hget("autoincrement_set", "seaportTime1")) or 0) == 1 then
  			redisproxy:hset("autoincrement_set", "seaportTime2", 1)
  		end
65b551a7   chenyueqi   海港贸易季初版
177
  	end
e820b3f3   chenyueqi   海港贸易季bug修正
178
  	if curTm.wday == 2 and curTm.hour >= 4 then -- 周一
65b551a7   chenyueqi   海港贸易季初版
179
180
181
182
  		-- redisproxy:hset("autoincrement_set", "seaportTime0", 0)
  		redisproxy:hset("autoincrement_set", "seaportTime1", 0)
  		redisproxy:hset("autoincrement_set", "seaportTime2", 0)
  	end
c384626d   zhouhaihai   好友
183
  
65b551a7   chenyueqi   海港贸易季初版
184
185
  	skynet.timeout(interval, check_trade_seaport_status)
  end
c384626d   zhouhaihai   好友
186
  
d9d63fa0   chenyueqi   海港贸易季自动填充,活动结束后的奖...
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
  -- @desc: 海港贸易捐赠作弊
  local seaportTimes = {}
  local function check_trade_seaport_donate()
  	local time1 = tonumber(redisproxy:hget("autoincrement_set", "seaportTime1")) or 0
  	local time2 = tonumber(redisproxy:hget("autoincrement_set", "seaportTime2")) or 0
  	if time1 == 0 and time2 == 0 then
  		seaportTimes = {}
  		skynet.timeout(360000, check_trade_seaport_donate)
  		return
  	end
  
  	local csvdb = require "shared.csvdata"
  	local donateCsv = csvdb["seaport_purchaseCsv"]
  
  	local times = {time1, time2}
  	for phase, open in ipairs(times) do
  		if open == 1 and not seaportTimes[phase] then
  			seaportTimes[phase] = {}
  			for _, _ in ipairs(donateCsv[phase]) do
  				table.insert(seaportTimes[phase],math.randomInt(1800, 3600))
  			end
  		end
  	end
  
  	local interval = 3600
  	local phase, id = 0, 0
  
  	for key1, data in ipairs(seaportTimes) do
  		for key2, temp in pairs(data) do
  			if times[key1] == 1 and temp < interval then
  				interval = temp
  				phase = key1
  				id = key2
  			end
  		end
  	end
  
  	for _, data in ipairs(seaportTimes) do
  		for id, temp in pairs(data) do
  			data[id] = temp - interval
  			if data[id] == 0 then
  				data[id] = math.randomInt(1800, 3600)
  			end
  		end
  	end
  
  	if phase ~= 0 and id ~= 0 then
  		local redisKeys = {SEAPORT_TRADE_TASK_1,SEAPORT_TRADE_TASK_2}
  		local all = donateCsv[phase][id].need_num
  		local old = tonumber(redisproxy:hget(redisKeys[phase],id)) or 0
  		local add = math.min(math.randomInt(math.floor(all/20),math.floor(all/12)),all - old)
  		if add > 0 then
  			redisproxy:hincrby(redisKeys[phase],id,add)
  		else
  			seaportTimes[phase][id] = nil
  		end
  	end
  
  	skynet.timeout(interval * 100, check_trade_seaport_donate)
  end
  
4cd97819   zhouhaihai   工作日玩法增加机器人
248
249
250
251
252
253
254
255
256
257
258
259
260
261
  local function check_work_battle()
  	local csvdb = require "shared.csvdata"
  	local now = skynet.timex()
  	local day = weekday(now)
  	local workMainCsv = csvdb["work_mainCsv"][day]
  	if workMainCsv and isSpecTime(now - RESET_TIME * 3600, csvdb["time_resetCsv"][TimeReset["WorkBattle1"]].start / 3600, 24) then
  		local round = math.floor((now - START_RESET_TIME) / 604800)
  		local field = round * 10 + day
  		local count = tonum(redisproxy:hget(WORK_BATTLE_COUNT, field))
  		if count < workMainCsv.target_num then
  			local add = math.floor(workMainCsv.target_num * math.randomInt(3125, 5000) / 100000)
  			redisproxy:hincrby(WORK_BATTLE_COUNT, field, add)
  		end
  	end
28b0c285   zhouhaihai   时间随机精确到秒
262
  	skynet.timeout(math.randomInt(10 * 60, 15 * 60) * 100, check_work_battle)
4cd97819   zhouhaihai   工作日玩法增加机器人
263
264
  end
  
314bc5df   zhengshouren   提交服务器初始代码
265
  local CMD = {}
c384626d   zhouhaihai   好友
266
  
875e5071   zhouhaihai   服务名称修改
267
268
  
  -- 服务器缓存50条消息
c384626d   zhouhaihai   好友
269
270
271
272
273
274
275
276
277
278
  local cacheWorldMsg = {}
  local CACHE_WORLD_MSG_COUNT = 50
  function CMD.sendWorldMsg(channel, msg)
  	cacheWorldMsg[channel] = cacheWorldMsg[channel] or {}
  	table.insert(cacheWorldMsg[channel], msg)
  	for i = #cacheWorldMsg[channel] - CACHE_WORLD_MSG_COUNT, 1, -1 do
  		table.remove(cacheWorldMsg[channel], i)
  	end
  end
  
c384626d   zhouhaihai   好友
279
280
281
282
283
  function CMD.getWorldMsg(channel)
  	local msgs = cacheWorldMsg[channel] or {}
  	return msgs
  end
  
875e5071   zhouhaihai   服务名称修改
284
  
314bc5df   zhengshouren   提交服务器初始代码
285
  function CMD.start()
4cd97819   zhouhaihai   工作日玩法增加机器人
286
  	math.randomInit(skynet.timex())
314bc5df   zhengshouren   提交服务器初始代码
287
  	check_mail_queue()
14f57eed   liuzujun   去除globald中发放活动排行奖励
288
  	--check_battle_act_close()
65b551a7   chenyueqi   海港贸易季初版
289
  	check_trade_seaport_status()
d9d63fa0   chenyueqi   海港贸易季自动填充,活动结束后的奖...
290
  	check_trade_seaport_donate()
4cd97819   zhouhaihai   工作日玩法增加机器人
291
  	check_work_battle()
314bc5df   zhengshouren   提交服务器初始代码
292
293
294
295
  end
  
  local function __init__()
  	skynet.dispatch("lua", function(_, _, command, ...)
c384626d   zhouhaihai   好友
296
297
298
299
300
301
302
303
  		local f = CMD[command]
  		if f then
  			if command == "sendWorldMsg" then
  				skynet.ignoreret()
  				f(...)
  			else
  				skynet.ret(skynet.pack(f(...)))
  			end
314bc5df   zhengshouren   提交服务器初始代码
304
305
  		end
  	end)
a5486ede   zhouhaihai   csvdata 修改为 share...
306
  	skynet.register(".globald")
875e5071   zhouhaihai   服务名称修改
307
  
314bc5df   zhengshouren   提交服务器初始代码
308
309
310
  end
  
  skynet.start(__init__)