Blame view

src/actions/RoleAction.lua 5.41 KB
314bc5df   zhengshouren   提交服务器初始代码
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
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
  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
  local httpc = require("http.httpc")
  
  local WAVE_HERO_NUMS = 150
  local WAVE_EQUIP_NUMS = 150
  
  local function validName(name)
  	name = string.upper(name)
  	local exist = redisproxy:exists(string_format("user:%s", name))
  	if exist then return "existed" end
  
  	local SERV = string_format("NAMED%d", math.random(1, 5))
  	local legal = skynet.call(SERV, "lua", "check", name)
  	return legal and "ok" or "illegal"
  end
  
  -- 随机玩家名
  local function randomRoleName()
  	-- 过滤已经存在的名字
  	local name
  	repeat
  		name = getRandomName()
  	until validName(name) == "ok"
  	return name
  end
  
  local function setRoleName(uid, roleId)
  	local result
  	local name
  	local dbName
  	repeat
  		name = randomRoleName()
  		dbName = string.upper(name)
  		result = redisproxy:setnx(string_format("user:%s", dbName), roleId)
  	until result == 1
  	redisproxy:set(string_format("uid:%s", uid), dbName)
  	return name
  end
  
  local _M = {}
  function _M.loginRpc( agent, data )
  	local msg = MsgPack.unpack(data)
  	local response = {}
  
be83d162   zhouahaihai   登陆成功。 增加数据结构修正功能
58
59
60
61
62
  	-- if msg.version ~= globalCsv.version then
  	-- 	response.result = "UPDATE_TIP"
  	-- 	SendPacket(actionCodes.Role_loginRpc, MsgPack.pack(response))
  	-- 	return true
  	-- end
314bc5df   zhengshouren   提交服务器初始代码
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
  
  	-- 1.
  	local roleId = redisproxy:get(string_format("user:%s", string.upper(msg.name)))
  	if not roleId then
  		response.result = "NOT_EXIST"
  		SendPacket(actionCodes.Role_loginRpc, MsgPack.pack(response))
  		return true
  	end
  
  	roleId = tonumber(roleId)
  
  	--维护不能登录
  	local maintain = tonumber(redisproxy:hget("autoincrement_set", "maintain"))
  	if maintain and maintain > 0 then
  		if tonumber(redisproxy:hget(string_format("role:%d", roleId), "ignoreMaintain")) ~= 1 then
  			response.result = "MAINTAIN_TIP"
  			SendPacket(actionCodes.Role_loginRpc, MsgPack.pack(response))
  			return true
  		end
  	end
  
  	local now = skynet.timex()
  	local role = agent.role
  	-- 2
  	if not role then
  		local roleKey = string_format("role:%d", roleId)
  		if not redisproxy:exists(roleKey) then
  			response.result = "DB_ERROR"
  			SendPacket(actionCodes.Role_loginRpc, MsgPack.pack(response))
  			return true
  		end
  		-- 2a
  		role = require("models.Role").new({key = roleKey})
  		role:load()
  		role:loadAll()
  	else
  		role:reloadWhenLogin()
  	end
  	
be83d162   zhouahaihai   登陆成功。 增加数据结构修正功能
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
  	-- if not msg.isGMlogin then
  	-- 	local banTime = role:getProperty("banTime")
  	-- 	if banTime > now then
  	-- 		response.result = "BAN_TIP"
  	-- 		response.banTime = banTime
  	-- 		response.banType = role:getProperty("banType")
  	-- 		response.roleId = roleId
  	-- 		SendPacket(actionCodes.Role_loginRpc, MsgPack.pack(response))
  	-- 		return true
  	-- 	end
  	-- 	if banTime ~= 0 then
  	-- 		-- 清除封号状态
  	-- 		role:setBan(0)
  	-- 	end
  	-- end
314bc5df   zhengshouren   提交服务器初始代码
117
118
119
  	SERV_OPEN = redisproxy:hget("autoincrement_set", "server_start")
  	local lastLoginTime = role:getProperty("lastLoginTime")
  
be83d162   zhouahaihai   登陆成功。 增加数据结构修正功能
120
  	role:changeStructVersion() -- 数据结构 版本更新
314bc5df   zhengshouren   提交服务器初始代码
121
  
be83d162   zhouahaihai   登陆成功。 增加数据结构修正功能
122
123
  	-- 跨天登陆事件
  	-- role:onCrossDay(now)
314bc5df   zhengshouren   提交服务器初始代码
124
125
  
  	role:setProperty("lastLoginTime", now)
be83d162   zhouahaihai   登陆成功。 增加数据结构修正功能
126
127
128
  	-- if msg.device and type(msg.device) == "string" then
  	-- 	role:setProperty("device", msg.device)
  	-- end
314bc5df   zhengshouren   提交服务器初始代码
129
130
131
132
133
  
  	response.role = role:data()
  	response.result = "SUCCESS"
  	response.serverTime = now
  
be83d162   zhouahaihai   登陆成功。 增加数据结构修正功能
134
  	response.wave = 1
314bc5df   zhengshouren   提交服务器初始代码
135
136
137
  
  	SendPacket(actionCodes.Role_loginRpc, MsgPack.pack(response))
  
314bc5df   zhengshouren   提交服务器初始代码
138
139
140
141
142
143
144
145
146
  
  	-- role:log("login", { ip = agent.ip, diamond = role:getProperty("diamond"), reDiamond = role:getProperty("reDiamond")})
  
  	datacenter.set("agent", roleId, {
  		serv = skynet.self(),
  		fd = agent.client_fd,
  		gate_serv = agent.gate_serv,
  	})
  	agent.role = role
314bc5df   zhengshouren   提交服务器初始代码
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
  	
  	start_agent_timer()
  	-- 注册全服广播
  	local channel = math.randomInt(1, 1)
  	local w_channel = datacenter.get( ("MC_W_CHANNEL" .. channel) )
  	if w_channel then
  		mcast_util.sub_world(w_channel)
  	end
  	return true
  end
  
  function _M.createRpc(agent, data)
  	local msg = MsgPack.unpack(data)
  	local response = {}
  
  	-- 再次检查uid
  	local uid = tostring(msg.uid)
  	local user = redisproxy:get(string_format("uid:%s", uid))
  	if user then
  		response.result = "SUCCESS"
  		response.roleName = user
  		SendPacket(actionCodes.Role_createRpc, MsgPack.pack(response))
  		return true
  	end
  
  	local roleId = getNextRoleId()
  	if not roleId then
  		response.result = "DB_FULL"
  		SendPacket(actionCodes.Role_createRpc, MsgPack.pack(response))
  		return true
  	end
  	local roleName = setRoleName(msg.uid, roleId)
314bc5df   zhengshouren   提交服务器初始代码
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
  	local newRole = require("models.Role").new({
  		key = string_format("role:%d", roleId),
  		id = roleId,
  		uid = tostring(msg.uid),
  		subId = msg.subId or 0,
  		name = roleName,
  		uname = msg.uname or "",
  		device = tostring(msg.device)
  	})
  
  	if newRole:create() then
  		--更新USER表
  		response.result = "SUCCESS"
  		response.roleId = roleId
  		response.roleName = string.upper(roleName)
  	else
  		response.result = "DB_ERROR"
  		SendPacket(actionCodes.Role_createRpc, MsgPack.pack(response))
  		return true
  	end
  
314bc5df   zhengshouren   提交服务器初始代码
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
  	-- 欢迎邮件
  	-- redisproxy:insertEmail({roleId = roleId, emailId = 1})
  	-- redisproxy:insertEmail({roleId = roleId, emailId = 2})
  
  	newRole:log("create", { ip = agent.ip, ucode = ucode})
  
  	SendPacket(actionCodes.Role_createRpc, MsgPack.pack(response))
  	return true
  end
  
  function _M.syncTimeRpc(agent, data)
  	SendPacket(actionCodes.Role_syncTimeRpc, MsgPack.pack({nowTime = skynet.timex()}))
  	return true
  end
  
  return _M