CreateRole.lua 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384
  1. ----------------------
  2. -- 创角相关逻辑
  3. ----------------------
  4. local Config = require("Config")
  5. local PlayerNamesExcel = require("excel.playerNames")
  6. local CommonDB = require("common.CommonDB")
  7. local Lang = require("common.Lang")
  8. local FilterUtil = require("common.FilterUtil")
  9. local Log = require("common.Log")
  10. local LogDefine = require("common.LogDefine")
  11. local CommonDefine = require("common.CommonDefine")
  12. local Msg = require("core.Msg")
  13. local ObjHuman = require("core.ObjHuman")
  14. local RoleDBLogic = require("role.RoleDBLogic")
  15. local RoleHeadLogic = require("role.RoleHeadLogic")
  16. local Broadcast = require("broadcast.Broadcast")
  17. local RoleExcel = require("excel.role")
  18. local ReportManager = require("platform.ReportManager")
  19. local HeroLogic = require("hero.HeroLogic")
  20. local RelationGiftLogic = require("present.RelationGiftLogic")
  21. local CombatDefine = require("combat.CombatDefine")
  22. local CombatPosLogic = require("combat.CombatPosLogic")
  23. local SysParameter = require("common.SysParameter")
  24. local ChatPaoMaLogic = require("chat.ChatPaoMaLogic")
  25. local MailExcel = require("excel.mail")
  26. local MailManager = require("mail.MailManager")
  27. local TriggerLogic = require("trigger.TriggerLogic")
  28. local TriggerDefine = require("trigger.TriggerDefine")
  29. local RoleStorageBox = require("roleSystem.RoleStorageBox")
  30. local DataCache = require("core.DataCache")
  31. local ROLE_NAME_LEN_MAX = 21
  32. local ROLE_NAME_LEN_MIN = 5
  33. local OP_RET_SUCC = 1
  34. local OP_RET_FAIL = 0
  35. local GodsAreaNS
  36. local AnotherWorldBattleNS
  37. -- 特定渠道用户创角时发送的邮件ID
  38. local NEW_ROLE_MAIL_ID = 7023
  39. -- 特定渠道列表
  40. local TARGET_CHANNEL_ARRAY = {1, 9}
  41. -- 用于公会渠道创角时发送奖励邮件的邮件Id
  42. local CHANNEL_GUILD_MAIL_ID = 7037
  43. -- 公会渠道创角奖励
  44. local channel_guild_createRole_rewards = {{102,8888}, {124,20}, {1208,2}, {111,1000000}, {112,1000}, {101,2000000}, {510,4}}
  45. local function sendMail(human, mailId, items)
  46. local mailCfg = MailExcel.mail[mailId]
  47. if not mailCfg then
  48. return
  49. end
  50. MailManager.add(MailManager.SYSTEM, human.db._id, mailCfg.title, mailCfg.content, items, mailCfg.senderName or "GM")
  51. end
  52. -- 生成一个11位的全局不重复的数字组成的id
  53. -- 规则 前6位服务器index 后五位自增id
  54. function genIdentity()
  55. local firstStr= Config.SVR_INDEX
  56. local nowMax = CommonDB.getIdentityMax()
  57. nowMax = nowMax + 1
  58. CommonDB.setIdentityMax(nowMax)
  59. return firstStr .. "" .. nowMax
  60. end
  61. function getFakeIdentityMax()
  62. local firstStr= Config.SVR_INDEX
  63. local id = CommonDB.getFakeIdentityMax()
  64. return firstStr .. string.format("%05d", id)
  65. end
  66. local function checkRoleName(roleName, default)
  67. --如果roleName是nil 游戏名不能为空
  68. if not roleName then
  69. return false, Lang.CREATE_ROLE_FAIL_NAME_NIL
  70. end
  71. local nameLen = string.len(roleName)
  72. --如果游戏名长度小于游戏名最小长度 角色名过短
  73. if nameLen < ROLE_NAME_LEN_MIN then
  74. return false, Lang.CREATE_ROLE_FAIL_NAME_LEN1
  75. end
  76. --如果游戏名长度大于游戏名最小长度 角色名过长
  77. if nameLen > ROLE_NAME_LEN_MAX then
  78. return false, Lang.CREATE_ROLE_FAIL_NAME_LEN2
  79. end
  80. if default == nil then
  81. --如果游戏名中包含非法字符 角色名中有非法字符
  82. if roleName ~= FilterUtil.filterName(roleName) then
  83. return false, Lang.CREATE_ROLE_FAIL_NAME_SHIELD
  84. end
  85. end
  86. --角色名已经存在
  87. if RoleDBLogic.isNameExistInDB(roleName) then
  88. return false, Lang.CREATE_ROLE_FAIL_NAME_DUPLICATE
  89. end
  90. return true
  91. end
  92. function creatFakeDb(account, serverTag)
  93. local db = RoleDBLogic.createDefaultRole(account, serverTag)
  94. local identity = genIdentity()
  95. db.identity = identity
  96. db.name = account
  97. return db
  98. end
  99. -- 创角时针对渠道的额外处理
  100. local function channelHandle(human)
  101. -- 特定渠道用户创角时发送的邮件
  102. if table.find(TARGET_CHANNEL_ARRAY, human.phpChanelID) then
  103. sendMail(human, NEW_ROLE_MAIL_ID)
  104. end
  105. -- 公会渠道创角时发送奖励邮件
  106. if human.phpChanelID == CommonDefine.CHANNEL_TAG_GUILD1 or human.phpChanelID == CommonDefine.CHANNEL_TAG_GUILD2 then
  107. sendMail(human, CHANNEL_GUILD_MAIL_ID, channel_guild_createRole_rewards)
  108. end
  109. end
  110. function createNewRole(human)
  111. if _G.is_middle == true then
  112. return
  113. end
  114. -- if human.db or RoleDBLogic.isAccountExistInDB(human.account, human.serverTag) then
  115. -- assert(nil)
  116. -- return
  117. -- end
  118. if human.db or RoleDBLogic.isNewUniqueTagExistInDB(human.phpChanelID, human.account, human.serverTag) then
  119. assert(nil)
  120. return
  121. end
  122. human.db = RoleDBLogic.createDefaultRole(human.phpChanelID, human.account, human.serverTag)
  123. -- 保存数据
  124. human.db.name = human.account
  125. local identity = genIdentity()
  126. human.db.identity = identity
  127. -- 测试 临时增加,用于防沉迷测试
  128. human.db.age = 20
  129. ----------
  130. -- 给角色的月光包盒中添加一定数量的道具
  131. RoleStorageBox.FillStorageBox(human)
  132. RelationGiftLogic.relationCreate(human)
  133. ObjHuman.initHuman(human)
  134. ObjHuman.save(human)
  135. ObjHuman.onLogin(human, true)
  136. createRoleSettingUp(human)
  137. DataCache.Insert_PlayerUuidList(human.db._id, human.db.lv)
  138. channelHandle(human)
  139. ReportManager.register(human)
  140. end
  141. -- 改名操作结果
  142. CHANGE_NAME_RET_FAIL = 0 -- 失败
  143. CHANGE_NAME_RET_OK = 1 -- 成功,首次改名
  144. CHANGE_NAME_RET_OK2 = 2 -- 成功,非首次改名
  145. CHANGE_NAME_COST = 200
  146. function changeName(human, roleName)
  147. local msgRet = Msg.gc.GC_ROLE_CHANGE_NAME
  148. msgRet.ret = CHANGE_NAME_RET_FAIL
  149. local isOk, tip = checkRoleName(roleName)
  150. if not isOk then
  151. msgRet.tip = tip
  152. Msg.send(msgRet, human.fd)
  153. return
  154. end
  155. if not human.db.changeNameCnt then
  156. human.db.changeNameCnt = 1
  157. else
  158. if human.db.zuanshi < CHANGE_NAME_COST then
  159. msgRet.tip = Lang.COMMON_NO_ZUANSHI
  160. Msg.send(msgRet, human.fd)
  161. return
  162. end
  163. human.db.changeNameCnt = human.db.changeNameCnt + 1
  164. ObjHuman.decZuanshi(human, -CHANGE_NAME_COST, "change_name")
  165. end
  166. ObjHuman.onlineHuman[human.db.name] = nil
  167. ObjHuman.onlineHuman[roleName] = human
  168. human.db.name = roleName
  169. ObjHuman.save(human)
  170. msgRet.ret = CHANGE_NAME_RET_OK
  171. if human.db.changeNameCnt > 1 then
  172. msgRet.ret = CHANGE_NAME_RET_OK2
  173. end
  174. msgRet.tip = "ok"
  175. Msg.send(msgRet, human.fd)
  176. TriggerLogic.PublishEvent(TriggerDefine.CHANGE_NAME, human.db._id, 1)
  177. GodsAreaNS = GodsAreaNS or require("godsArea.GodsAreaNS")
  178. GodsAreaNS.UpdateShowData(human, 1)
  179. AnotherWorldBattleNS = AnotherWorldBattleNS or require("anotherWorldBattle.AnotherWorldBattleNS")
  180. AnotherWorldBattleNS.PlayerChangeName(human)
  181. if human.db.changeNameCnt == 1 then
  182. -- Log.write(Log.LOGID_OSS_REGISTER, human.db._id, human.db.account, human.db.name, human.ip,human.pf or "",human.appid, human.db.changeNameCnt)
  183. -- Log.write(Log.LOGID_OSS_CREATELOSS,human.db.account, human.db.name, LogDefine.HUMAN_LOST.CREATE_NAME_FINISH, human.db.ip,human.pf or "",human.appid, human.phpChanelID)
  184. -- ReportManager.create(human)
  185. -- Log.write(Log.LOGID_OSS_LOGIN, human.db._id, human.db.account, human.db.name, human.db.lv, human.db.ip)
  186. Log.write(Log.LOGID_OSS_REGISTER, human.db._id, human.db.newUniqueTag, human.db.name, human.ip,human.pf or "",human.appid, human.db.changeNameCnt)
  187. Log.write(Log.LOGID_OSS_CREATELOSS,human.db.newUniqueTag, human.db.name, LogDefine.HUMAN_LOST.CREATE_NAME_FINISH, human.db.ip,human.pf or "",human.appid, human.phpChanelID)
  188. ReportManager.create(human)
  189. Log.write(Log.LOGID_OSS_LOGIN, human.db._id, human.db.newUniqueTag, human.db.name, human.db.lv, human.db.ip)
  190. end
  191. end
  192. -- 改名查询
  193. function changeNameQuery(human)
  194. local msgRet = Msg.gc.GC_ROLE_CHANGE_NAME_QUERY
  195. if human.db.changeNameCnt == nil then
  196. msgRet.price = 0
  197. --Log.write(Log.LOGID_OSS_CREATELOSS,human.db.account, human.db.name, LogDefine.HUMAN_LOST.SHOW_NAME_PANEL, human.db.ip,human.pf or "",human.appid, human.phpChanelID)
  198. Log.write(Log.LOGID_OSS_CREATELOSS,human.db.newUniqueTag, human.db.name, LogDefine.HUMAN_LOST.SHOW_NAME_PANEL, human.db.ip,human.pf or "",human.appid, human.phpChanelID)
  199. else
  200. msgRet.price = CHANGE_NAME_COST
  201. end
  202. Msg.send(msgRet,human.fd)
  203. end
  204. function randomName(human, sex)
  205. local msgRet = Msg.gc.GC_ROLE_RANDOM_NAME
  206. msgRet.sex = sex
  207. msgRet.name = getRandomName(sex)
  208. Msg.send(msgRet, human.fd)
  209. end
  210. function getRandomName(sex)
  211. if not sex then
  212. sex = math.random(1, 2)
  213. end
  214. local random1 = math.random(1, #PlayerNamesExcel.xing)
  215. if sex == 1 then
  216. local random2 = math.random(1, #PlayerNamesExcel.name)
  217. return PlayerNamesExcel.xing[random1].xing..PlayerNamesExcel.name[random2].name
  218. else
  219. local random2 = math.random(1, #PlayerNamesExcel.name2)
  220. return PlayerNamesExcel.xing[random1].xing..PlayerNamesExcel.name2[random2].name
  221. end
  222. end
  223. -- 创角时修改角色信息
  224. function createRoleChangeInfo(human,name,sex,firendCode)
  225. local msgRet = Msg.gc.GC_ROLE_CREATE_ROLE_CHANGE_MSG
  226. local isOk = checkRoleName(name)
  227. if isOk == false then
  228. msgRet.ret = 1
  229. Msg.send(msgRet,human.fd)
  230. return
  231. end
  232. -- 创角
  233. if not human.db.changeNameCnt then
  234. human.db.changeNameCnt = 0
  235. else
  236. if human.db.zuanshi < CHANGE_NAME_COST then
  237. msgRet.ret = 1
  238. Msg.send(msgRet, human.fd)
  239. return
  240. end
  241. human.db.changeNameCnt = human.db.changeNameCnt + 1
  242. ObjHuman.decZuanshi(human, -CHANGE_NAME_COST, "change_name")
  243. end
  244. ObjHuman.onlineHuman[human.db.name] = nil
  245. ObjHuman.onlineHuman[name] = human
  246. human.db.name = name
  247. human.db.sex = sex
  248. RoleHeadLogic.setHead(human, sex, RoleHeadLogic.HEAD_TYPE_1)
  249. ObjHuman.save(human)
  250. ChatPaoMaLogic.loginTips(human)
  251. -- 好友推荐 todo
  252. RelationGiftLogic.relationBind(human, firendCode)
  253. msgRet.ret = 0
  254. Msg.send(msgRet,human.fd)
  255. -- 记录流失日志
  256. if human.db.changeNameCnt == 0 then
  257. -- Log.write(Log.LOGID_OSS_REGISTER, human.db._id, human.db.account, human.db.name, human.ip,human.pf or "",human.appid, human.db.changeNameCnt)
  258. -- Log.write(Log.LOGID_OSS_CREATELOSS,human.db.account, human.db.name, LogDefine.HUMAN_LOST.CREATE_NAME_FINISH, human.db.ip,human.pf or "",human.appid, human.phpChanelID)
  259. -- ReportManager.create(human)
  260. -- Log.write(Log.LOGID_OSS_LOGIN, human.db._id, human.db.account, human.db.name, human.db.lv, human.db.ip)
  261. Log.write(Log.LOGID_OSS_REGISTER, human.db._id, human.db.newUniqueTag, human.db.name, human.ip,human.pf or "",human.appid, human.db.changeNameCnt)
  262. Log.write(Log.LOGID_OSS_CREATELOSS,human.db.newUniqueTag, human.db.name, LogDefine.HUMAN_LOST.CREATE_NAME_FINISH, human.db.ip,human.pf or "",human.appid, human.phpChanelID)
  263. ReportManager.create(human)
  264. Log.write(Log.LOGID_OSS_LOGIN, human.db._id, human.db.newUniqueTag, human.db.name, human.db.lv, human.db.ip)
  265. end
  266. end
  267. function createRoleSettingUp(human)
  268. -- 赠送新英雄 上阵
  269. local heroId = SysParameter.getSysParameter(SysParameter.PARAMETER_8)
  270. if heroId and heroId ~= 0 then
  271. local bagIndex, uuid = HeroLogic.addHero(human, heroId,nil, 1, "create_role")
  272. if bagIndex and uuid and type(uuid) == "string" then
  273. local msg = {}
  274. msg.type = CombatDefine.COMBAT_TYPE1
  275. msg.formation = 1
  276. msg.heroList = "0,"..uuid
  277. msg.helpList = ""
  278. msg.jibanList = ""
  279. CombatPosLogic.updatePos(human, msg)
  280. end
  281. end
  282. end
  283. RANDOM_HEAD_ID_TABLE = nil
  284. function getRandomHead()
  285. if RANDOM_HEAD_ID_TABLE == nil then
  286. RANDOM_HEAD_ID_TABLE = {}
  287. for k, v in pairs(RoleExcel.head) do
  288. RANDOM_HEAD_ID_TABLE[#RANDOM_HEAD_ID_TABLE + 1] = k
  289. end
  290. end
  291. local index = math.random(1, #RANDOM_HEAD_ID_TABLE)
  292. return RANDOM_HEAD_ID_TABLE[index]
  293. end
  294. RANDOM_HEADFRAME_ID_TABLE = nil
  295. function getRandomHeadFrame()
  296. if RANDOM_HEADFRAME_ID_TABLE == nil then
  297. RANDOM_HEADFRAME_ID_TABLE = {}
  298. for k, v in pairs(RoleExcel.headFrame) do
  299. RANDOM_HEADFRAME_ID_TABLE[#RANDOM_HEADFRAME_ID_TABLE + 1] = k
  300. end
  301. end
  302. local index = math.random(1, #RANDOM_HEADFRAME_ID_TABLE)
  303. return RANDOM_HEADFRAME_ID_TABLE[index]
  304. end
  305. RANDOM_BODY_ID_TABLE = nil
  306. function getRandomBody()
  307. if RANDOM_BODY_ID_TABLE == nil then
  308. RANDOM_BODY_ID_TABLE = {}
  309. for k, v in pairs(RoleExcel.body) do
  310. RANDOM_BODY_ID_TABLE[#RANDOM_BODY_ID_TABLE + 1] = k
  311. end
  312. end
  313. local index = math.random(1, #RANDOM_BODY_ID_TABLE)
  314. return RANDOM_BODY_ID_TABLE[index]
  315. end