Blame view

src/services/capsuled.lua 7.29 KB
555f745e   zhangqijia   feat: 一番赏
1
2
3
4
5
  require "ProtocolCode"
  require "shared.init"
  require "GlobalVar"
  require "RedisKeys"
  require "skynet.manager"
d10a9a36   zhangqijia   fix: 一番赏增加通知信息的数据...
6
  skynet = require "skynet"
555f745e   zhangqijia   feat: 一番赏
7
8
9
10
11
12
13
14
15
16
17
18
  csvdb = require "shared.csvdata"
  redisproxy = require "shared.redisproxy"
  datacenter = require "skynet.datacenter"
  
  local capsules = {}
  local CMD = {}
  
  NotifyChangeType = {
      JOIN = 1,
      EXIT = 2,
      DRAW = 3,
      SPECIAL = 4,
0eb317fb   zhangqijia   fix: 一番赏奖励抽奖的bug与...
19
20
21
22
23
24
25
  }
  
  skynet.register_protocol {
      name = "role",
      id = 101,
      pack = skynet.pack,
      unpack = skynet.unpack,
555f745e   zhangqijia   feat: 一番赏
26
27
  }
  
cd2a7a67   zhangqijia   fix: 一番赏奖励中加入得奖者的...
28
  local function rpcRole(roleId, funcName, ...)
555f745e   zhangqijia   feat: 一番赏
29
30
      local fields = ...
      local agent = datacenter.get("agent", roleId)
0eb317fb   zhangqijia   fix: 一番赏奖励抽奖的bug与...
31
32
33
34
35
36
      if agent and agent.serv then
          if funcName == "getProperties" then
              return true, skynet.call(agent.serv, "role", funcName, fields)
          else
              return true, skynet.call(agent.serv, "role", funcName, ...)
          end
555f745e   zhangqijia   feat: 一番赏
37
      else
0eb317fb   zhangqijia   fix: 一番赏奖励抽奖的bug与...
38
39
40
41
42
43
          local roleCross = require("models.RoleCross")
          if funcName == "getProperties" then
              return false, roleCross.handle(funcName, roleId, fields)
          else
              return false, roleCross.handle(funcName, roleId, ...)
          end
555f745e   zhangqijia   feat: 一番赏
44
45
46
      end
  end
  
cd2a7a67   zhangqijia   fix: 一番赏奖励中加入得奖者的...
47
  function getNameByRoleId(roleId)
0eb317fb   zhangqijia   fix: 一番赏奖励抽奖的bug与...
48
49
      local status, name = rpcRole(roleId, "getProperty", "name")
      return name
cd2a7a67   zhangqijia   fix: 一番赏奖励中加入得奖者的...
50
51
52
  
  end
  
555f745e   zhangqijia   feat: 一番赏
53
  function broadCastCapsule(roleId, capsuleId, broadInfo)
7f21f75b   zhangqijia   fix: 一番赏 增加rank,刷...
54
55
56
      local capsule = capsules[capsuleId]
      if not capsule then print("not capsule :" .. capsuleId) return end
  
555f745e   zhangqijia   feat: 一番赏
57
58
59
60
61
62
63
64
65
66
      local register = capsule:getProperty("register") or {}
      if next(capsule) then
          for id, _ in pairs(register) do
              if id ~= roleId then
                  rpcRole(id, "SendPacket", actionCodes.Capsule_notifyChange, MsgPack.pack(broadInfo)) 	-- 通知对方
              end
          end
      end
  end
  
0eb317fb   zhangqijia   fix: 一番赏奖励抽奖的bug与...
67
  function broadCastSpecial(roleId, capsuleId, broadInfo)
7f21f75b   zhangqijia   fix: 一番赏 增加rank,刷...
68
69
70
      local capsule = capsules[capsuleId]
      if not capsule then skynet.error("not capsule: " .. capsuleId) return end
  
0eb317fb   zhangqijia   fix: 一番赏奖励抽奖的bug与...
71
      local register = capsule:getProperty("register") or {}
7f21f75b   zhangqijia   fix: 一番赏 增加rank,刷...
72
73
74
75
      for id, _ in pairs(register) do
          if id ~= roleId then
              if broadInfo[id] then
                  rpcRole(id, "paySpecialReward", id, broadInfo[id])
0eb317fb   zhangqijia   fix: 一番赏奖励抽奖的bug与...
76
77
78
              end
          end
      end
555f745e   zhangqijia   feat: 一番赏
79
80
  end
  
555f745e   zhangqijia   feat: 一番赏
81
  local function add(roleId, capsuleId)
7f21f75b   zhangqijia   fix: 一番赏 增加rank,刷...
82
83
      local capsule = capsules[capsuleId]
      if not capsule then skynet.error("not capsule: " .. capsuleId) return end
555f745e   zhangqijia   feat: 一番赏
84
85
      if next(capsule) then
          capsule:join(roleId)
0eb317fb   zhangqijia   fix: 一番赏奖励抽奖的bug与...
86
          broadCastCapsule(roleId, capsuleId, {notifyType= NotifyChangeType.JOIN, roleId = roleId})
f382b4f2   zhangqijia   fix: 一番赏的抽奖bug
87
          return capsule:data(roleId)
555f745e   zhangqijia   feat: 一番赏
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
      end
      print("id 不存在: ".. capsuleId)
      return nil
  end
  
  local function capsuleRefreshing()
      for _, v in pairs(capsules) do
          if v:refreshing() then
              v:init()
              v:create()
          end
      end
  end
  
  --扭蛋机刷新
  local function check_capsules()
      pcall(capsuleRefreshing)
      skynet.timeout(60, check_capsules)
  end
  
6304b5ad   zhangqijia   feat: 一番赏 增加重置扭蛋机指令
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
  function CMD.reset()
      local now = skynet.timex()
      local res = redisproxy:smembers(CAPSULE_INFO) or {}
      for _, key in pairs(res) do
          redisproxy:del(CAPSULE_PUBLIC:format(key))
          redisproxy:srem(CAPSULE_INFO, key)
      end
  
      for _, data in pairs(csvdb["ichibankuji_mainCsv"]) do
          for _, val in ipairs(data) do
              if val.type == 1 then
                  local key = val.id..val.room
                  if not capsules[key] then
                      local capsule = require("models.Capsule").new({ key = CAPSULE_PUBLIC:format(key), id= val.id, room = val.room, typ = 1, name=val.name})
                      capsule:init()
                      capsule:create()
                      capsules[key] = capsule
                      redisproxy:sadd(CAPSULE_INFO, key)
                  end
              end
          end
      end
  end
  
555f745e   zhangqijia   feat: 一番赏
132
133
134
135
  function CMD.start()
      local now = skynet.timex()
      local res = redisproxy:smembers(CAPSULE_INFO) or {}
      for _, key in pairs(res) do
d10a9a36   zhangqijia   fix: 一番赏增加通知信息的数据...
136
          local capsule = require("models.Capsule").new({ key = CAPSULE_PUBLIC:format(key)})
555f745e   zhangqijia   feat: 一番赏
137
138
139
140
141
142
143
144
          capsule:load()
          if capsule:isShow() then
              if capsule:refreshing(now) then
                  capsule:init()
                  capsule:create()
              end
              capsules[key] = capsule
          else
d10a9a36   zhangqijia   fix: 一番赏增加通知信息的数据...
145
              redisproxy:del(CAPSULE_PUBLIC:format(key))
f382b4f2   zhangqijia   fix: 一番赏的抽奖bug
146
              redisproxy:srem(CAPSULE_INFO, key)
555f745e   zhangqijia   feat: 一番赏
147
148
149
150
151
152
          end
      end
  
      for _, data in pairs(csvdb["ichibankuji_mainCsv"]) do
          for _, val in ipairs(data) do
              if val.type == 1 then
d10a9a36   zhangqijia   fix: 一番赏增加通知信息的数据...
153
                  local key = val.id..val.room
555f745e   zhangqijia   feat: 一番赏
154
                  if not capsules[key] then
d10a9a36   zhangqijia   fix: 一番赏增加通知信息的数据...
155
                      local capsule = require("models.Capsule").new({ key = CAPSULE_PUBLIC:format(key), id= val.id, room = val.room, typ = 1, name=val.name})
555f745e   zhangqijia   feat: 一番赏
156
157
158
                      capsule:init()
                      capsule:create()
                      capsules[key] = capsule
f382b4f2   zhangqijia   fix: 一番赏的抽奖bug
159
                      redisproxy:sadd(CAPSULE_INFO, key)
555f745e   zhangqijia   feat: 一番赏
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
                  end
              end
          end
      end
  
      check_capsules()
  end
  
  function CMD.list(coin)
      local tmpCapsules = {}
      for k, v in pairs(capsules) do
          if v:getProperty("coin") == coin then
              local onlineCount= v:getOnlineCount()
              tmpCapsules[k] = {id=v:getProperty("id"), room=v:getProperty("room"), typ=v:getProperty("typ"), people=onlineCount[2], coin= v:getProperty("coin")}
          end
      end
      return tmpCapsules
  end
  
  function CMD.join(roleId, capsuleId)
      if capsuleId then
          return add(roleId, capsuleId)
      end
      return nil
  end
  
  
  function CMD.exit(roleId, capsuleId)
d10a9a36   zhangqijia   fix: 一番赏增加通知信息的数据...
188
      if capsuleId then
7f21f75b   zhangqijia   fix: 一番赏 增加rank,刷...
189
190
191
192
193
          local capsule = capsules[capsuleId]
          if not capsule then skynet.error("not capsule: " .. capsuleId) return end
  
          capsule:exit(roleId)
          broadCastCapsule(roleId, capsuleId, {notifyType = NotifyChangeType.EXIT, roleId = roleId})
d10a9a36   zhangqijia   fix: 一番赏增加通知信息的数据...
194
195
196
197
      else
          for _, capsule in pairs(capsules) do
              if next(capsule) then
                  capsule:exit(roleId)
0eb317fb   zhangqijia   fix: 一番赏奖励抽奖的bug与...
198
                  broadCastCapsule(roleId, capsuleId, {notifyType = NotifyChangeType.EXIT, roleId = roleId})
d10a9a36   zhangqijia   fix: 一番赏增加通知信息的数据...
199
200
              end
          end
555f745e   zhangqijia   feat: 一番赏
201
202
203
      end
  end
  
0eb317fb   zhangqijia   fix: 一番赏奖励抽奖的bug与...
204
  function CMD.draw_capsule(roleId, capsuleId, full, drawsNum, cares)
7f21f75b   zhangqijia   fix: 一番赏 增加rank,刷...
205
206
207
208
209
210
211
      local capsule = capsules[capsuleId]
      if not capsule then skynet.error("not capsule: " .. capsuleId) return 2 end
  
      local ret, reward, rewardByGoods, notify = capsule:draw(roleId, full, drawsNum, cares)
      if ret > 5 then
          --broadCastCapsule(roleId, capsuleId, {notifyType = NotifyChangeType.DRAW, notify = notify})
          broadCastSpecial(roleId, capsuleId, notify)
555f745e   zhangqijia   feat: 一番赏
212
      end
7f21f75b   zhangqijia   fix: 一番赏 增加rank,刷...
213
      return ret, reward, rewardByGoods, capsule:data(roleId)
555f745e   zhangqijia   feat: 一番赏
214
215
  end
  
f382b4f2   zhangqijia   fix: 一番赏的抽奖bug
216
  function CMD.register(roleId, capsuleId)
7f21f75b   zhangqijia   fix: 一番赏 增加rank,刷...
217
218
219
      local capsule = capsules[capsuleId]
      if not capsule then skynet.error("not capsule: " .. capsuleId) return nil end
  
0eb317fb   zhangqijia   fix: 一番赏奖励抽奖的bug与...
220
221
222
223
      return capsule:register(roleId)
  end
  
  function CMD.goods_stock(capsuleId)
7f21f75b   zhangqijia   fix: 一番赏 增加rank,刷...
224
225
226
      local capsule = capsules[capsuleId]
      if not capsule then skynet.error("not capsule: " .. capsuleId) return 0 end
  
0eb317fb   zhangqijia   fix: 一番赏奖励抽奖的bug与...
227
228
229
      return capsule:getGoodsAmount(), capsule:getProperty("token")
  end
  
0a421d34   zhangqijia   fix: 一番赏奖励 刷新协议缺少...
230
  function CMD.capsule_data(roleId, capsuleId)
7f21f75b   zhangqijia   fix: 一番赏 增加rank,刷...
231
232
233
      local capsule = capsules[capsuleId]
      if not capsule then skynet.error("not capsule: " .. capsuleId) return nil end
  
0a421d34   zhangqijia   fix: 一番赏奖励 刷新协议缺少...
234
      return capsule:data(roleId)
f382b4f2   zhangqijia   fix: 一番赏的抽奖bug
235
236
  end
  
555f745e   zhangqijia   feat: 一番赏
237
238
239
240
241
242
243
  skynet.start(function()
      skynet.dispatch("lua", function(session, address, cmd, ...)
          local f = CMD[string.lower(cmd)]
          skynet.ret(skynet.pack(f(...)))
      end)
  
      skynet.register("capsuled")
cd2a7a67   zhangqijia   fix: 一番赏奖励中加入得奖者的...
244
      globalCsv = csvdb["GlobalDefineCsv"]
555f745e   zhangqijia   feat: 一番赏
245
  end)