@bigtyphoon/melo 1.7.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (296) hide show
  1. package/LICENSE +22 -0
  2. package/README.md +55 -0
  3. package/bin/commadtest.ts +10 -0
  4. package/bin/commands/add.ts +43 -0
  5. package/bin/commands/init.ts +292 -0
  6. package/bin/commands/kill.ts +21 -0
  7. package/bin/commands/list.ts +60 -0
  8. package/bin/commands/masterha.ts +40 -0
  9. package/bin/commands/restart.ts +48 -0
  10. package/bin/commands/start.ts +65 -0
  11. package/bin/commands/stop.ts +26 -0
  12. package/bin/melo.ts +30 -0
  13. package/bin/utils/constants.ts +27 -0
  14. package/bin/utils/utils.ts +130 -0
  15. package/dist/bin/commadtest.js +9 -0
  16. package/dist/bin/commands/add.js +40 -0
  17. package/dist/bin/commands/init.js +279 -0
  18. package/dist/bin/commands/kill.js +21 -0
  19. package/dist/bin/commands/list.js +65 -0
  20. package/dist/bin/commands/masterha.js +36 -0
  21. package/dist/bin/commands/restart.js +45 -0
  22. package/dist/bin/commands/start.js +58 -0
  23. package/dist/bin/commands/stop.js +20 -0
  24. package/dist/bin/melo.js +26 -0
  25. package/dist/bin/utils/constants.js +28 -0
  26. package/dist/bin/utils/utils.js +134 -0
  27. package/dist/lib/application.js +888 -0
  28. package/dist/lib/common/manager/appManager.js +112 -0
  29. package/dist/lib/common/manager/taskManager.js +39 -0
  30. package/dist/lib/common/remote/backend/msgRemote.js +63 -0
  31. package/dist/lib/common/remote/frontend/channelRemote.js +78 -0
  32. package/dist/lib/common/remote/frontend/sessionRemote.js +76 -0
  33. package/dist/lib/common/service/backendSessionService.js +337 -0
  34. package/dist/lib/common/service/channelService.js +514 -0
  35. package/dist/lib/common/service/connectionService.js +95 -0
  36. package/dist/lib/common/service/filterService.js +112 -0
  37. package/dist/lib/common/service/handlerService.js +187 -0
  38. package/dist/lib/common/service/sessionService.js +610 -0
  39. package/dist/lib/components/backendSession.js +14 -0
  40. package/dist/lib/components/channel.js +13 -0
  41. package/dist/lib/components/connection.js +12 -0
  42. package/dist/lib/components/connector.js +437 -0
  43. package/dist/lib/components/dictionary.js +93 -0
  44. package/dist/lib/components/master.js +39 -0
  45. package/dist/lib/components/monitor.js +25 -0
  46. package/dist/lib/components/protobuf.js +156 -0
  47. package/dist/lib/components/proxy.js +236 -0
  48. package/dist/lib/components/pushScheduler.js +62 -0
  49. package/dist/lib/components/remote.js +127 -0
  50. package/dist/lib/components/server.js +63 -0
  51. package/dist/lib/components/session.js +20 -0
  52. package/dist/lib/connectors/commands/handshake.js +119 -0
  53. package/dist/lib/connectors/commands/heartbeat.js +67 -0
  54. package/dist/lib/connectors/commands/kick.js +15 -0
  55. package/dist/lib/connectors/common/coder.js +90 -0
  56. package/dist/lib/connectors/common/handler.js +57 -0
  57. package/dist/lib/connectors/hybrid/IHybridSocket.js +3 -0
  58. package/dist/lib/connectors/hybrid/switcher.js +100 -0
  59. package/dist/lib/connectors/hybrid/tcpprocessor.js +40 -0
  60. package/dist/lib/connectors/hybrid/tcpsocket.js +171 -0
  61. package/dist/lib/connectors/hybrid/wsprocessor.js +49 -0
  62. package/dist/lib/connectors/hybridconnector.js +89 -0
  63. package/dist/lib/connectors/hybridsocket.js +139 -0
  64. package/dist/lib/connectors/mqtt/generate.js +113 -0
  65. package/dist/lib/connectors/mqtt/mqttadaptor.js +81 -0
  66. package/dist/lib/connectors/mqtt/protocol.js +48 -0
  67. package/dist/lib/connectors/mqttconnector.js +107 -0
  68. package/dist/lib/connectors/mqttsocket.js +59 -0
  69. package/dist/lib/connectors/sioconnector.js +135 -0
  70. package/dist/lib/connectors/siosocket.js +69 -0
  71. package/dist/lib/connectors/udpconnector.js +76 -0
  72. package/dist/lib/connectors/udpsocket.js +93 -0
  73. package/dist/lib/filters/handler/serial.js +44 -0
  74. package/dist/lib/filters/handler/time.js +32 -0
  75. package/dist/lib/filters/handler/timeout.js +45 -0
  76. package/dist/lib/filters/handler/toobusy.js +36 -0
  77. package/dist/lib/filters/rpc/rpcLog.js +43 -0
  78. package/dist/lib/filters/rpc/toobusy.js +41 -0
  79. package/dist/lib/index.js +81 -0
  80. package/dist/lib/interfaces/IComponent.js +3 -0
  81. package/dist/lib/interfaces/IConnector.js +3 -0
  82. package/dist/lib/interfaces/IHandlerFilter.js +3 -0
  83. package/dist/lib/interfaces/ILifeCycle.js +3 -0
  84. package/dist/lib/interfaces/IPlugin.js +3 -0
  85. package/dist/lib/interfaces/IPushScheduler.js +3 -0
  86. package/dist/lib/interfaces/ISocket.js +3 -0
  87. package/dist/lib/interfaces/IStore.js +3 -0
  88. package/dist/lib/interfaces/define.js +3 -0
  89. package/dist/lib/master/master.js +129 -0
  90. package/dist/lib/master/starter.js +236 -0
  91. package/dist/lib/master/watchdog.js +120 -0
  92. package/dist/lib/melo.js +125 -0
  93. package/dist/lib/modules/console.js +436 -0
  94. package/dist/lib/modules/masterwatcher.js +98 -0
  95. package/dist/lib/modules/monitorwatcher.js +124 -0
  96. package/dist/lib/modules/onlineUser.js +69 -0
  97. package/dist/lib/modules/restartNotifyModule.js +107 -0
  98. package/dist/lib/modules/watchServer.js +737 -0
  99. package/dist/lib/monitor/monitor.js +80 -0
  100. package/dist/lib/pushSchedulers/buffer.js +96 -0
  101. package/dist/lib/pushSchedulers/direct.js +58 -0
  102. package/dist/lib/pushSchedulers/multi.js +80 -0
  103. package/dist/lib/server/server.js +500 -0
  104. package/dist/lib/util/appUtil.js +306 -0
  105. package/dist/lib/util/constants.js +117 -0
  106. package/dist/lib/util/countDownLatch.js +51 -0
  107. package/dist/lib/util/events.js +20 -0
  108. package/dist/lib/util/handlerHelper.js +8 -0
  109. package/dist/lib/util/log.js +14 -0
  110. package/dist/lib/util/moduleUtil.js +101 -0
  111. package/dist/lib/util/pathUtil.js +134 -0
  112. package/dist/lib/util/remoterHelper.js +8 -0
  113. package/dist/lib/util/utils.js +358 -0
  114. package/dist/test/application.js +522 -0
  115. package/dist/test/config/log4js.json +28 -0
  116. package/dist/test/config/master.json +9 -0
  117. package/dist/test/config/servers.json +6 -0
  118. package/dist/test/filters/handler/serial.js +41 -0
  119. package/dist/test/filters/handler/time.js +41 -0
  120. package/dist/test/filters/handler/timeout.js +41 -0
  121. package/dist/test/filters/handler/toobusy.js +57 -0
  122. package/dist/test/filters/rpc/rpcLog.js +22 -0
  123. package/dist/test/filters/rpc/toobusy.js +39 -0
  124. package/dist/test/manager/mockChannelManager.js +77 -0
  125. package/dist/test/manager/taskManager.js +68 -0
  126. package/dist/test/mock-base/app/servers/other-file +0 -0
  127. package/dist/test/mock-plugin/components/mockPlugin.js +10 -0
  128. package/dist/test/mock-plugin/events/mockEvent.js +12 -0
  129. package/dist/test/modules/console.js +242 -0
  130. package/dist/test/pomelo.js +19 -0
  131. package/dist/test/remote/channelRemote.js +159 -0
  132. package/dist/test/service/channel.js +134 -0
  133. package/dist/test/service/channelService.js +216 -0
  134. package/dist/test/service/connectionService.js +114 -0
  135. package/dist/test/service/filterService.js +144 -0
  136. package/dist/test/service/handlerService.js +65 -0
  137. package/dist/test/service/sessionService.js +387 -0
  138. package/dist/test/util/countDownLatch.js +70 -0
  139. package/dist/test/util/pathUtil.js +108 -0
  140. package/dist/test/util/utils.js +140 -0
  141. package/lib/application.ts +1240 -0
  142. package/lib/common/manager/appManager.ts +118 -0
  143. package/lib/common/manager/taskManager.ts +50 -0
  144. package/lib/common/remote/backend/msgRemote.ts +134 -0
  145. package/lib/common/remote/frontend/channelRemote.ts +91 -0
  146. package/lib/common/remote/frontend/sessionRemote.ts +91 -0
  147. package/lib/common/service/backendSessionService.ts +388 -0
  148. package/lib/common/service/channelService.ts +609 -0
  149. package/lib/common/service/connectionService.ts +112 -0
  150. package/lib/common/service/filterService.ts +118 -0
  151. package/lib/common/service/handlerService.ts +224 -0
  152. package/lib/common/service/sessionService.ts +731 -0
  153. package/lib/components/backendSession.ts +14 -0
  154. package/lib/components/channel.ts +11 -0
  155. package/lib/components/connection.ts +13 -0
  156. package/lib/components/connector.ts +533 -0
  157. package/lib/components/dictionary.ts +121 -0
  158. package/lib/components/master.ts +41 -0
  159. package/lib/components/monitor.ts +30 -0
  160. package/lib/components/protobuf.ts +208 -0
  161. package/lib/components/proxy.ts +282 -0
  162. package/lib/components/pushScheduler.ts +70 -0
  163. package/lib/components/remote.ts +166 -0
  164. package/lib/components/server.ts +71 -0
  165. package/lib/components/session.ts +22 -0
  166. package/lib/connectors/commands/handshake.ts +155 -0
  167. package/lib/connectors/commands/heartbeat.ts +83 -0
  168. package/lib/connectors/commands/kick.ts +11 -0
  169. package/lib/connectors/common/coder.ts +93 -0
  170. package/lib/connectors/common/handler.ts +62 -0
  171. package/lib/connectors/hybrid/IHybridSocket.ts +9 -0
  172. package/lib/connectors/hybrid/switcher.ts +142 -0
  173. package/lib/connectors/hybrid/tcpprocessor.ts +43 -0
  174. package/lib/connectors/hybrid/tcpsocket.ts +223 -0
  175. package/lib/connectors/hybrid/wsprocessor.ts +57 -0
  176. package/lib/connectors/hybridconnector.ts +134 -0
  177. package/lib/connectors/hybridsocket.ts +168 -0
  178. package/lib/connectors/mqtt/generate.ts +103 -0
  179. package/lib/connectors/mqtt/mqttadaptor.ts +114 -0
  180. package/lib/connectors/mqtt/protocol.ts +49 -0
  181. package/lib/connectors/mqttconnector.ts +134 -0
  182. package/lib/connectors/mqttsocket.ts +79 -0
  183. package/lib/connectors/sioconnector.ts +161 -0
  184. package/lib/connectors/siosocket.ts +85 -0
  185. package/lib/connectors/udpconnector.ts +113 -0
  186. package/lib/connectors/udpsocket.ts +110 -0
  187. package/lib/filters/handler/serial.ts +46 -0
  188. package/lib/filters/handler/time.ts +35 -0
  189. package/lib/filters/handler/timeout.ts +50 -0
  190. package/lib/filters/handler/toobusy.ts +37 -0
  191. package/lib/filters/rpc/rpcLog.ts +42 -0
  192. package/lib/filters/rpc/toobusy.ts +41 -0
  193. package/lib/index.ts +74 -0
  194. package/lib/interfaces/IComponent.ts +47 -0
  195. package/lib/interfaces/IConnector.ts +20 -0
  196. package/lib/interfaces/IHandlerFilter.ts +15 -0
  197. package/lib/interfaces/ILifeCycle.ts +16 -0
  198. package/lib/interfaces/IPlugin.ts +65 -0
  199. package/lib/interfaces/IPushScheduler.ts +52 -0
  200. package/lib/interfaces/ISocket.ts +26 -0
  201. package/lib/interfaces/IStore.ts +10 -0
  202. package/lib/interfaces/define.ts +15 -0
  203. package/lib/master/master.ts +148 -0
  204. package/lib/master/starter.ts +234 -0
  205. package/lib/master/watchdog.ts +135 -0
  206. package/lib/melo.ts +152 -0
  207. package/lib/modules/console.ts +465 -0
  208. package/lib/modules/masterwatcher.ts +120 -0
  209. package/lib/modules/monitorwatcher.ts +151 -0
  210. package/lib/modules/onlineUser.ts +78 -0
  211. package/lib/modules/restartNotifyModule.ts +128 -0
  212. package/lib/modules/watchServer.ts +766 -0
  213. package/lib/monitor/monitor.ts +99 -0
  214. package/lib/pushSchedulers/buffer.ts +117 -0
  215. package/lib/pushSchedulers/direct.ts +65 -0
  216. package/lib/pushSchedulers/multi.ts +94 -0
  217. package/lib/server/server.ts +554 -0
  218. package/lib/util/appUtil.ts +313 -0
  219. package/lib/util/constants.ts +154 -0
  220. package/lib/util/countDownLatch.ts +72 -0
  221. package/lib/util/events.ts +15 -0
  222. package/lib/util/handlerHelper.ts +5 -0
  223. package/lib/util/log.ts +11 -0
  224. package/lib/util/moduleUtil.ts +110 -0
  225. package/lib/util/pathUtil.ts +132 -0
  226. package/lib/util/remoterHelper.ts +68 -0
  227. package/lib/util/utils.ts +365 -0
  228. package/package.json +93 -0
  229. package/template/game-server/.vscode/launch.json +27 -0
  230. package/template/game-server/app/servers/connector/handler/entryHandler.ts +50 -0
  231. package/template/game-server/app/servers/connector/remote/authRemoter.ts +36 -0
  232. package/template/game-server/app.ts +30 -0
  233. package/template/game-server/app.ts.mqtt +32 -0
  234. package/template/game-server/app.ts.sio +36 -0
  235. package/template/game-server/app.ts.sio.wss +34 -0
  236. package/template/game-server/app.ts.udp +31 -0
  237. package/template/game-server/app.ts.wss +40 -0
  238. package/template/game-server/config/adminServer.json +5 -0
  239. package/template/game-server/config/adminUser.json +22 -0
  240. package/template/game-server/config/clientProtos.json +1 -0
  241. package/template/game-server/config/dictionary.json +1 -0
  242. package/template/game-server/config/log4js.json +150 -0
  243. package/template/game-server/config/master.json +8 -0
  244. package/template/game-server/config/serverProtos.json +1 -0
  245. package/template/game-server/config/servers.json +12 -0
  246. package/template/game-server/copy.js +5 -0
  247. package/template/game-server/package.json +28 -0
  248. package/template/game-server/preload.ts +40 -0
  249. package/template/game-server/tsconfig.json +36 -0
  250. package/template/npm-install.bat +4 -0
  251. package/template/npm-install.sh +5 -0
  252. package/template/readme.md +31 -0
  253. package/template/shared/server.crt +15 -0
  254. package/template/shared/server.key +15 -0
  255. package/template/web-server/app.js +25 -0
  256. package/template/web-server/app.js.https +36 -0
  257. package/template/web-server/bin/component.bat +1 -0
  258. package/template/web-server/bin/component.sh +1 -0
  259. package/template/web-server/package.json +10 -0
  260. package/template/web-server/public/css/base.css +76 -0
  261. package/template/web-server/public/image/logo.png +0 -0
  262. package/template/web-server/public/image/sp.png +0 -0
  263. package/template/web-server/public/index.html +57 -0
  264. package/template/web-server/public/index.html.sio +58 -0
  265. package/template/web-server/public/js/lib/build/build.js +1730 -0
  266. package/template/web-server/public/js/lib/build/build.js.wss +1721 -0
  267. package/template/web-server/public/js/lib/component.json +6 -0
  268. package/template/web-server/public/js/lib/local/boot/component.json +11 -0
  269. package/template/web-server/public/js/lib/local/boot/index.js +11 -0
  270. package/template/web-server/public/js/lib/meloclient.js +456 -0
  271. package/template/web-server/public/js/lib/meloclient.js.wss +456 -0
  272. package/template/web-server/public/js/lib/socket.io.js +3 -0
  273. package/test/application.ts +607 -0
  274. package/test/filters/handler/serial.ts +47 -0
  275. package/test/filters/handler/time.ts +47 -0
  276. package/test/filters/handler/timeout.ts +46 -0
  277. package/test/filters/handler/toobusy.ts +59 -0
  278. package/test/filters/rpc/rpcLog.ts +20 -0
  279. package/test/filters/rpc/toobusy.ts +40 -0
  280. package/test/manager/mockChannelManager.ts +92 -0
  281. package/test/manager/taskManager.ts +78 -0
  282. package/test/mock-base/app/servers/other-file +0 -0
  283. package/test/mock-plugin/components/mockPlugin.ts +8 -0
  284. package/test/mock-plugin/events/mockEvent.ts +12 -0
  285. package/test/modules/console.ts +264 -0
  286. package/test/pomelo.ts +18 -0
  287. package/test/remote/channelRemote.ts +176 -0
  288. package/test/service/channel.ts +161 -0
  289. package/test/service/channelService.ts +243 -0
  290. package/test/service/connectionService.ts +142 -0
  291. package/test/service/filterService.ts +165 -0
  292. package/test/service/handlerService.ts +77 -0
  293. package/test/service/sessionService.ts +464 -0
  294. package/test/util/countDownLatch.ts +81 -0
  295. package/test/util/pathUtil.ts +122 -0
  296. package/test/util/utils.ts +165 -0
@@ -0,0 +1,156 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ProtobufComponent = void 0;
4
+ const fs = require("fs");
5
+ const path = require("path");
6
+ const melo_protobuf_1 = require("@bigtyphoon/melo-protobuf");
7
+ const Constants = require("../util/constants");
8
+ const crypto = require("crypto");
9
+ const melo_logger_1 = require("@bigtyphoon/melo-logger");
10
+ const events_1 = require("../util/events");
11
+ let logger = (0, melo_logger_1.getLogger)('melo', path.basename(__filename));
12
+ class ProtobufComponent {
13
+ _canRequire(path) {
14
+ try {
15
+ require.resolve(path);
16
+ }
17
+ catch (err) {
18
+ return false;
19
+ }
20
+ return true;
21
+ }
22
+ constructor(app, opts) {
23
+ this.watchers = {};
24
+ this.serverProtos = {};
25
+ this.clientProtos = {};
26
+ this.version = '';
27
+ this.name = '__protobuf__';
28
+ this.app = app;
29
+ opts = opts || {};
30
+ logger.debug('ProtobufComponent options:', opts);
31
+ let env = app.get(Constants.RESERVED.ENV);
32
+ let originServerPath = path.join(app.getBase(), Constants.FILEPATH.SERVER_PROTOS);
33
+ let presentServerPath = path.join(Constants.FILEPATH.CONFIG_DIR, env, path.basename(Constants.FILEPATH.SERVER_PROTOS));
34
+ let originClientPath = path.join(app.getBase(), Constants.FILEPATH.CLIENT_PROTOS);
35
+ let presentClientPath = path.join(Constants.FILEPATH.CONFIG_DIR, env, path.basename(Constants.FILEPATH.CLIENT_PROTOS));
36
+ this.serverProtosPath = opts.serverProtos || (this._canRequire(originServerPath) ? Constants.FILEPATH.SERVER_PROTOS : presentServerPath);
37
+ this.clientProtosPath = opts.clientProtos || (this._canRequire(originClientPath) ? Constants.FILEPATH.CLIENT_PROTOS : presentClientPath);
38
+ this.setProtos(Constants.RESERVED.SERVER, path.join(app.getBase(), this.serverProtosPath));
39
+ this.setProtos(Constants.RESERVED.CLIENT, path.join(app.getBase(), this.clientProtosPath));
40
+ this.protobuf = new melo_protobuf_1.Protobuf({
41
+ encoderProtos: this.serverProtos,
42
+ decoderProtos: this.clientProtos,
43
+ encoderCacheSize: opts.encoderCacheSize,
44
+ decodeCheckMsg: opts.decodeCheckMsg,
45
+ });
46
+ }
47
+ encode(key, msg) {
48
+ return this.protobuf.encode(key, msg);
49
+ }
50
+ encode2Bytes(key, msg) {
51
+ return this.protobuf.encode2Bytes(key, msg);
52
+ }
53
+ decode(key, msg) {
54
+ return this.protobuf.decode(key, msg);
55
+ }
56
+ getProtos() {
57
+ return {
58
+ server: this.serverProtos,
59
+ client: this.clientProtos,
60
+ version: this.version
61
+ };
62
+ }
63
+ getVersion() {
64
+ return this.version;
65
+ }
66
+ // 手动重新加载协议文件。
67
+ manualReloadProtos() {
68
+ let truePath = path.join(this.app.getBase(), this.serverProtosPath);
69
+ truePath = require.resolve(truePath);
70
+ this.onUpdate(Constants.RESERVED.SERVER, truePath, 'change');
71
+ truePath = path.join(this.app.getBase(), this.clientProtosPath);
72
+ truePath = require.resolve(truePath);
73
+ this.onUpdate(Constants.RESERVED.CLIENT, truePath, 'change');
74
+ }
75
+ setProtos(type, path) {
76
+ if (!this._canRequire(path)) {
77
+ return;
78
+ }
79
+ if (type === Constants.RESERVED.SERVER) {
80
+ this.serverProtos = melo_protobuf_1.Protobuf.parse(require(path));
81
+ }
82
+ if (type === Constants.RESERVED.CLIENT) {
83
+ this.clientProtos = melo_protobuf_1.Protobuf.parse(require(path));
84
+ }
85
+ let protoStr = JSON.stringify(this.clientProtos) + JSON.stringify(this.serverProtos);
86
+ this.version = crypto.createHash('md5').update(protoStr).digest('base64');
87
+ // Watch file
88
+ const truePath = require.resolve(path);
89
+ let watcher = fs.watch(truePath, this.onUpdate.bind(this, type, truePath));
90
+ if (this.watchers[type]) {
91
+ this.watchers[type].close();
92
+ }
93
+ this.watchers[type] = watcher;
94
+ }
95
+ clearRequireCache(path) {
96
+ const moduleObj = require.cache[path];
97
+ if (!moduleObj) {
98
+ logger.warn('can not find module of truepath', path);
99
+ return;
100
+ }
101
+ if (moduleObj.parent) {
102
+ // console.log('has parent ',moduleObj.parent);
103
+ moduleObj.parent.children.splice(moduleObj.parent.children.indexOf(moduleObj), 1);
104
+ }
105
+ delete require.cache[path];
106
+ }
107
+ onUpdate(type, path, event, filename, errTry) {
108
+ if (event !== 'change') {
109
+ return;
110
+ }
111
+ let self = this;
112
+ this.clearRequireCache(path);
113
+ try {
114
+ let protos = melo_protobuf_1.Protobuf.parse(require(path));
115
+ // 预防 git checkout这样的操作导致获得的数据为空的情况
116
+ if (!protos || !Object.keys(protos).length) {
117
+ // retry.
118
+ throw new Error('protos error');
119
+ }
120
+ if (type === Constants.RESERVED.SERVER) {
121
+ this.protobuf.setEncoderProtos(protos);
122
+ self.serverProtos = protos;
123
+ }
124
+ else {
125
+ this.protobuf.setDecoderProtos(protos);
126
+ self.clientProtos = protos;
127
+ }
128
+ let protoStr = JSON.stringify(self.clientProtos) + JSON.stringify(self.serverProtos);
129
+ self.version = crypto.createHash('md5').update(protoStr).digest('base64');
130
+ logger.info('change proto file , type : %j, path : %j, version : %j', type, path, self.version);
131
+ // 抛出 proto 变化事件。
132
+ self.app.event.emit(events_1.default.PROTO_CHANGED, type);
133
+ }
134
+ catch (e) {
135
+ logger.error('change proto file error! path : %j', path, filename, errTry, e);
136
+ if (!errTry) {
137
+ logger.warn('setTimeout,try update proto');
138
+ setTimeout(() => {
139
+ logger.warn('try update proto again');
140
+ this.onUpdate(type, path, event, filename, true);
141
+ }, 3000);
142
+ }
143
+ }
144
+ this.watchers[type].close();
145
+ this.watchers[type] = fs.watch(path, this.onUpdate.bind(this, type, path));
146
+ }
147
+ stop(force, cb) {
148
+ for (let type in this.watchers) {
149
+ this.watchers[type].close();
150
+ }
151
+ this.watchers = {};
152
+ process.nextTick(cb);
153
+ }
154
+ }
155
+ exports.ProtobufComponent = ProtobufComponent;
156
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"protobuf.js","sourceRoot":"","sources":["../../../lib/components/protobuf.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,236 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.manualReloadProxies = exports.ProxyComponent = void 0;
4
+ /**
5
+ * Component for proxy.
6
+ * Generate proxies for rpc client.
7
+ */
8
+ const crc = require("crc");
9
+ const utils = require("../util/utils");
10
+ const events_1 = require("../util/events");
11
+ const melo_rpc_1 = require("@bigtyphoon/melo-rpc");
12
+ const Constants = require("../util/constants");
13
+ const melo_logger_1 = require("@bigtyphoon/melo-logger");
14
+ const path = require("path");
15
+ let logger = (0, melo_logger_1.getLogger)('melo', path.basename(__filename));
16
+ /**
17
+ * Proxy component class
18
+ *
19
+ * @param {Object} app current application context
20
+ * @param {Object} opts construct parameters
21
+ */
22
+ class ProxyComponent {
23
+ constructor(app, opts) {
24
+ var _a, _b;
25
+ this.name = '__proxy__';
26
+ opts = opts || {};
27
+ // proxy default config
28
+ // cacheMsg is deprecated, just for compatibility here.
29
+ opts.bufferMsg = opts.bufferMsg || opts.cacheMsg || false;
30
+ opts.interval = opts.interval || 30;
31
+ opts.router = genRouteFun();
32
+ opts.context = (_a = opts.context) !== null && _a !== void 0 ? _a : app;
33
+ opts.routeContext = (_b = opts.routeContext) !== null && _b !== void 0 ? _b : app;
34
+ if (app.enabled('rpcDebugLog')) {
35
+ opts.rpcDebugLog = true;
36
+ opts.rpcLogger = (0, melo_logger_1.getLogger)('rpc-debug', path.basename(__filename));
37
+ }
38
+ this.app = app;
39
+ this.opts = opts;
40
+ this.client = genRpcClient(this.app, opts);
41
+ this.app.event.on(events_1.default.ADD_SERVERS, this.addServers.bind(this));
42
+ this.app.event.on(events_1.default.REMOVE_SERVERS, this.removeServers.bind(this));
43
+ this.app.event.on(events_1.default.REPLACE_SERVERS, this.replaceServers.bind(this));
44
+ }
45
+ /**
46
+ * Proxy component lifecycle function
47
+ *
48
+ * @param {Function} cb
49
+ * @return {Void}
50
+ */
51
+ start(cb) {
52
+ if (this.opts.enableRpcLog) {
53
+ logger.warn('enableRpcLog is deprecated in 0.8.0, please use app.rpcFilter(melo.rpcFilters.rpcLog())');
54
+ }
55
+ let rpcBefores = this.app.get(Constants.KEYWORDS.RPC_BEFORE_FILTER);
56
+ let rpcAfters = this.app.get(Constants.KEYWORDS.RPC_AFTER_FILTER);
57
+ let rpcErrorHandler = this.app.get(Constants.RESERVED.RPC_ERROR_HANDLER);
58
+ if (!!rpcBefores) {
59
+ this.client.before(rpcBefores);
60
+ }
61
+ if (!!rpcAfters) {
62
+ this.client.after(rpcAfters);
63
+ }
64
+ if (!!rpcErrorHandler) {
65
+ this.client.setErrorHandler(rpcErrorHandler);
66
+ }
67
+ process.nextTick(cb);
68
+ }
69
+ /**
70
+ * Component lifecycle callback
71
+ *
72
+ * @param {Function} cb
73
+ * @return {Void}
74
+ */
75
+ afterStart(cb) {
76
+ let self = this;
77
+ Object.defineProperty(this.app, 'rpc', {
78
+ get: function () {
79
+ return self.client.proxies.user;
80
+ }
81
+ });
82
+ Object.defineProperty(this.app, 'sysrpc', {
83
+ get: function () {
84
+ return self.client.proxies.sys;
85
+ }
86
+ });
87
+ this.app.rpcInvoke = this.client.rpcInvoke.bind(this.client);
88
+ this.client.start(cb);
89
+ }
90
+ /**
91
+ * Add remote server to the rpc client.
92
+ *
93
+ * @param {Array} servers server info list, {id, serverType, host, port}
94
+ */
95
+ addServers(servers) {
96
+ if (!servers || !servers.length) {
97
+ return;
98
+ }
99
+ genProxies(this.client, this.app, servers);
100
+ this.client.addServers(servers);
101
+ }
102
+ manualReloadProxies() {
103
+ let servers = [];
104
+ for (let k in this.client._station.servers) {
105
+ servers.push(this.client._station.servers[k]);
106
+ }
107
+ logger.warn('manualReloadProxies servers:', servers);
108
+ genProxies(this.client, this.app, servers);
109
+ }
110
+ /**
111
+ * Remove remote server from the rpc client.
112
+ *
113
+ * @param {Array} ids server id list
114
+ */
115
+ removeServers(ids) {
116
+ this.client.removeServers(ids);
117
+ }
118
+ /**
119
+ * Replace remote servers from the rpc client.
120
+ *
121
+ * @param {Array} ids server id list
122
+ */
123
+ replaceServers(servers) {
124
+ if (!servers || !servers.length) {
125
+ return;
126
+ }
127
+ // update proxies
128
+ this.client.proxies = {};
129
+ genProxies(this.client, this.app, servers);
130
+ this.client.replaceServers(servers);
131
+ }
132
+ /**
133
+ * Proxy for rpc client rpcInvoke.
134
+ *
135
+ * @param {String} serverId remote server id
136
+ * @param {Object} msg rpc message: {serverType: serverType, service: serviceName, method: methodName, args: arguments}
137
+ * @param {Function} cb callback function
138
+ */
139
+ rpcInvoke(serverId, msg, cb) {
140
+ this.client.rpcInvoke(serverId, msg, cb);
141
+ }
142
+ }
143
+ exports.ProxyComponent = ProxyComponent;
144
+ function manualReloadProxies(app) {
145
+ if (!app.components.__proxy__) {
146
+ return;
147
+ }
148
+ if (app.components.__proxy__.manualReloadProxies) {
149
+ app.components.__proxy__.manualReloadProxies();
150
+ }
151
+ else {
152
+ logger.warn('manualReloadProxies not method');
153
+ }
154
+ }
155
+ exports.manualReloadProxies = manualReloadProxies;
156
+ /**
157
+ * Generate rpc client
158
+ *
159
+ * @param {Object} app current application context
160
+ * @param {Object} opts contructor parameters for rpc client
161
+ * @return {Object} rpc client
162
+ */
163
+ let genRpcClient = function (app, opts) {
164
+ var _a, _b;
165
+ opts.context = (_a = opts.context) !== null && _a !== void 0 ? _a : app;
166
+ opts.routeContext = (_b = opts.routeContext) !== null && _b !== void 0 ? _b : app;
167
+ if (!!opts.rpcClient) {
168
+ return opts.rpcClient.create(opts);
169
+ }
170
+ else {
171
+ return (0, melo_rpc_1.createClient)(opts);
172
+ }
173
+ };
174
+ /**
175
+ * Generate proxy for the server infos.
176
+ *
177
+ * @param {Object} client rpc client instance
178
+ * @param {Object} app application context
179
+ * @param {Array} sinfos server info list
180
+ */
181
+ let genProxies = function (client, app, sinfos) {
182
+ let item;
183
+ for (let i = 0, l = sinfos.length; i < l; i++) {
184
+ item = sinfos[i];
185
+ client.addProxies(getProxyRecords(app, item));
186
+ }
187
+ };
188
+ /**
189
+ * Check a server whether has generated proxy before
190
+ *
191
+ * @param {Object} client rpc client instance
192
+ * @param {Object} sinfo server info
193
+ * @return {Boolean} true or false
194
+ */
195
+ let hasProxy = function (client, sinfo) {
196
+ let proxy = client.proxies;
197
+ return !!proxy.sys && !!proxy.sys[sinfo.serverType];
198
+ };
199
+ /**
200
+ * Get proxy path for rpc client.
201
+ * Iterate all the remote service path and create remote path record.
202
+ *
203
+ * @param {Object} app current application context
204
+ * @param {Object} sinfo server info, format: {id, serverType, host, port}
205
+ * @return {Array} remote path record array
206
+ */
207
+ let getProxyRecords = function (app, sinfo) {
208
+ return sinfo.remoterPaths;
209
+ };
210
+ let genRouteFun = function () {
211
+ return function (session, msg, app, cb) {
212
+ let routes = app.get(Constants.KEYWORDS.ROUTE);
213
+ if (!routes) {
214
+ defaultRoute(session, msg, app, cb);
215
+ return;
216
+ }
217
+ let type = msg.serverType, route = routes[type] || routes['default'];
218
+ if (route) {
219
+ route(session, msg, app, cb);
220
+ }
221
+ else {
222
+ defaultRoute(session, msg, app, cb);
223
+ }
224
+ };
225
+ };
226
+ let defaultRoute = function (session, msg, app, cb) {
227
+ let list = app.getServersByType(msg.serverType);
228
+ if (!list || !list.length) {
229
+ cb(new Error('can not find server info for type:' + msg.serverType));
230
+ return;
231
+ }
232
+ let uid = session ? (session.uid || '') : '';
233
+ let index = Math.abs(crc.crc32(uid.toString())) % list.length;
234
+ utils.invokeCallback(cb, null, list[index].id);
235
+ };
236
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"proxy.js","sourceRoot":"","sources":["../../../lib/components/proxy.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,62 @@
1
+ "use strict";
2
+ /**
3
+ * Scheduler component to schedule message sending.
4
+ */
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.PushSchedulerComponent = void 0;
7
+ const direct_1 = require("../pushSchedulers/direct");
8
+ const melo_logger_1 = require("@bigtyphoon/melo-logger");
9
+ const multi_1 = require("../pushSchedulers/multi");
10
+ const path = require("path");
11
+ let logger = (0, melo_logger_1.getLogger)('melo', path.basename(__filename));
12
+ class PushSchedulerComponent {
13
+ constructor(app, opts) {
14
+ this.app = app;
15
+ this.name = '__pushScheduler__';
16
+ opts = opts || {};
17
+ this.scheduler = getScheduler(this, app, opts);
18
+ }
19
+ /**
20
+ * Component lifecycle callback
21
+ *
22
+ * @param {Function} cb
23
+ * @return {Void}
24
+ */
25
+ afterStart(cb) {
26
+ this.scheduler.start().then(cb);
27
+ }
28
+ /**
29
+ * Component lifecycle callback
30
+ *
31
+ * @param {Function} cb
32
+ * @return {Void}
33
+ */
34
+ stop(force, cb) {
35
+ this.scheduler.stop().then(cb);
36
+ }
37
+ /**
38
+ * Schedule how the message to send.
39
+ *
40
+ * @param {Number} reqId request id
41
+ * @param {String} route route string of the message
42
+ * @param {Object} msg message content after encoded
43
+ * @param {Array} recvs array of receiver's session id
44
+ * @param {Object} opts options
45
+ * @param {Function} cb
46
+ */
47
+ schedule(reqId, route, msg, recvs, opts, cb) {
48
+ this.scheduler.schedule(reqId, route, msg, recvs, opts, cb);
49
+ }
50
+ }
51
+ exports.PushSchedulerComponent = PushSchedulerComponent;
52
+ let getScheduler = function (pushSchedulerComp, app, opts) {
53
+ let scheduler = opts.scheduler || direct_1.DirectPushScheduler;
54
+ if (typeof scheduler === 'function') {
55
+ return new scheduler(app, opts);
56
+ }
57
+ if (Array.isArray(scheduler)) {
58
+ return new multi_1.MultiPushScheduler(app, opts);
59
+ }
60
+ return scheduler;
61
+ };
62
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVzaFNjaGVkdWxlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9jb21wb25lbnRzL3B1c2hTY2hlZHVsZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOztHQUVHOzs7QUFFSCxxREFBaUY7QUFDakYseURBQW9EO0FBSXBELG1EQUE2RDtBQUU3RCw2QkFBNkI7QUFDN0IsSUFBSSxNQUFNLEdBQUcsSUFBQSx1QkFBUyxFQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsUUFBUSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7QUFHMUQsTUFBYSxzQkFBc0I7SUFFL0IsWUFBb0IsR0FBZ0IsRUFBRSxJQUE2QjtRQUEvQyxRQUFHLEdBQUgsR0FBRyxDQUFhO1FBS3BDLFNBQUksR0FBRyxtQkFBbUIsQ0FBQztRQUp2QixJQUFJLEdBQUcsSUFBSSxJQUFJLEVBQUUsQ0FBQztRQUNsQixJQUFJLENBQUMsU0FBUyxHQUFHLFlBQVksQ0FBQyxJQUFJLEVBQUUsR0FBRyxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQ25ELENBQUM7SUFJRDs7Ozs7T0FLRztJQUNILFVBQVUsQ0FBQyxFQUFjO1FBQ3JCLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ3BDLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNILElBQUksQ0FBQyxLQUFjLEVBQUUsRUFBYztRQUMvQixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUNuQyxDQUFDO0lBRUQ7Ozs7Ozs7OztPQVNHO0lBQ0gsUUFBUSxDQUFDLEtBQWEsRUFBRSxLQUFhLEVBQUUsR0FBUSxFQUFFLEtBQVksRUFBRSxJQUFxQixFQUFFLEVBQXlCO1FBQzNHLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxLQUFLLEVBQUUsR0FBRyxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDaEUsQ0FBQztDQUNKO0FBMUNELHdEQTBDQztBQUNELElBQUksWUFBWSxHQUFHLFVBQVUsaUJBQXlDLEVBQUUsR0FBZ0IsRUFBRSxJQUEyQjtJQUNqSCxJQUFJLFNBQVMsR0FBRyxJQUFJLENBQUMsU0FBUyxJQUFJLDRCQUFnQixDQUFDO0lBQ25ELElBQUksT0FBTyxTQUFTLEtBQUssVUFBVSxFQUFFO1FBQ2pDLE9BQU8sSUFBSSxTQUFTLENBQUMsR0FBRyxFQUFFLElBQUksQ0FBQyxDQUFDO0tBQ25DO0lBRUQsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxFQUFFO1FBQzFCLE9BQU8sSUFBSSwwQkFBa0IsQ0FBQyxHQUFHLEVBQUcsSUFBaUMsQ0FBQyxDQUFDO0tBQzFFO0lBRUQsT0FBTyxTQUEyQixDQUFDO0FBQ3ZDLENBQUMsQ0FBQyJ9
@@ -0,0 +1,127 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.manualReloadRemoters = exports.RemoteComponent = void 0;
4
+ const pathUtil = require("../util/pathUtil");
5
+ const melo_rpc_1 = require("@bigtyphoon/melo-rpc");
6
+ const melo_logger_1 = require("@bigtyphoon/melo-logger");
7
+ const path = require("path");
8
+ /**
9
+ * Remote component class
10
+ *
11
+ * @param {Object} app current application context
12
+ * @param {Object} opts construct parameters
13
+ */
14
+ class RemoteComponent {
15
+ constructor(app, opts) {
16
+ this.app = app;
17
+ this.name = '__remote__';
18
+ opts = opts || {};
19
+ this.opts = opts;
20
+ // cacheMsg is deprecated, just for compatibility here.
21
+ opts.bufferMsg = opts.bufferMsg || opts.cacheMsg || false;
22
+ opts.interval = opts.interval || 30;
23
+ if (app.enabled('rpcDebugLog')) {
24
+ opts.rpcDebugLog = true;
25
+ opts.rpcLogger = (0, melo_logger_1.getLogger)('rpc-debug', path.basename(__filename));
26
+ }
27
+ opts.relativePath = opts.relativePath || false;
28
+ opts.paths = this.getRemotePaths(opts.relativePath);
29
+ opts.context = this.app;
30
+ let remoters = {};
31
+ opts.services = {};
32
+ opts.services['user'] = remoters;
33
+ let info = this.app.getCurrentServer();
34
+ // 添加插件中的remoter到ServerInfo中
35
+ for (let plugin of this.app.usedPlugins) {
36
+ if (plugin.remoterPath) {
37
+ opts.paths.push({
38
+ namespace: 'user',
39
+ serverType: info.serverType,
40
+ path: plugin.remoterPath
41
+ });
42
+ }
43
+ }
44
+ // 添加路径到ServerInfo中
45
+ info.remoterPaths = opts.paths;
46
+ }
47
+ /**
48
+ * Remote component lifecycle function
49
+ *
50
+ * @param {Function} cb
51
+ * @return {Void}
52
+ */
53
+ start(cb) {
54
+ this.opts.port = this.app.getCurServer().port;
55
+ this.remote = this.genRemote(this.opts);
56
+ this.remote.start();
57
+ process.nextTick(cb);
58
+ }
59
+ /**
60
+ * Remote component lifecycle function
61
+ *
62
+ * @param {Boolean} force whether stop the component immediately
63
+ * @param {Function} cb
64
+ * @return {Void}
65
+ */
66
+ stop(force, cb) {
67
+ this.remote.stop(force);
68
+ process.nextTick(cb);
69
+ }
70
+ /**
71
+ * Get remote paths from application
72
+ *
73
+ * @param {Boolean} relativePath convert path to relative path
74
+ * @return {Array} paths
75
+ *
76
+ */
77
+ getRemotePaths(relativePath) {
78
+ let paths = [];
79
+ let role;
80
+ // master server should not come here
81
+ if (this.app.isFrontend()) {
82
+ role = 'frontend';
83
+ }
84
+ else {
85
+ role = 'backend';
86
+ }
87
+ let sysPath = pathUtil.getSysRemotePath(role), serverType = this.app.getServerType();
88
+ if (sysPath !== null) {
89
+ paths.push(pathUtil.remotePathRecord('sys', serverType, sysPath, relativePath));
90
+ }
91
+ let userPath = pathUtil.getUserRemotePath(this.app.getBase(), serverType);
92
+ if (userPath !== null) {
93
+ paths.push(pathUtil.remotePathRecord('user', serverType, userPath, relativePath));
94
+ }
95
+ return paths;
96
+ }
97
+ /**
98
+ * Generate remote server instance
99
+ *
100
+ * @param {Object} app current application context
101
+ * @param {Object} opts contructor parameters for rpc Server
102
+ * @return {Object} remote server instance
103
+ */
104
+ genRemote(opts) {
105
+ if (!!opts.rpcServer) {
106
+ return opts.rpcServer.create(opts);
107
+ }
108
+ else {
109
+ return (0, melo_rpc_1.createServer)(opts);
110
+ }
111
+ }
112
+ }
113
+ exports.RemoteComponent = RemoteComponent;
114
+ function manualReloadRemoters(app) {
115
+ if (!app.components.__remote__) {
116
+ return;
117
+ }
118
+ const remote = app.components.__remote__.remote;
119
+ if (remote['manualReloadRemoters']) {
120
+ remote['manualReloadRemoters']();
121
+ }
122
+ else {
123
+ console.warn('manualReloadRemoters no method');
124
+ }
125
+ }
126
+ exports.manualReloadRemoters = manualReloadRemoters;
127
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVtb3RlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vbGliL2NvbXBvbmVudHMvcmVtb3RlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUtBLDZDQUE2QztBQUM3QyxtREFBaUg7QUFHakgseURBQTREO0FBRTVELDZCQUE2QjtBQXFCN0I7Ozs7O0dBS0c7QUFDSCxNQUFhLGVBQWU7SUFHeEIsWUFBb0IsR0FBZ0IsRUFBRSxJQUE2QjtRQUEvQyxRQUFHLEdBQUgsR0FBRyxDQUFhO1FBdUNwQyxTQUFJLEdBQUcsWUFBWSxDQUFDO1FBdENoQixJQUFJLEdBQUcsSUFBSSxJQUFJLEVBQUUsQ0FBQztRQUNsQixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztRQUVqQix1REFBdUQ7UUFDdkQsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsU0FBUyxJQUFJLElBQUksQ0FBQyxRQUFRLElBQUksS0FBSyxDQUFDO1FBQzFELElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLFFBQVEsSUFBSSxFQUFFLENBQUM7UUFDcEMsSUFBSSxHQUFHLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxFQUFFO1lBQzVCLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDO1lBQ3hCLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBQSx1QkFBUyxFQUFDLFdBQVcsRUFBRSxJQUFJLENBQUMsUUFBUSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7U0FDdEU7UUFFRCxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxZQUFZLElBQUksS0FBSyxDQUFDO1FBQy9DLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDcEQsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDO1FBRXhCLElBQUksUUFBUSxHQUFhLEVBQUUsQ0FBQztRQUM1QixJQUFJLENB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