gamelet-cli 0.7.12 → 0.8.0
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.
- package/assets/package.json.twig +3 -3
- package/assets/tsconfig.json.twig +1 -1
- package/build/package.json +68 -67
- package/build/src/gamelet/download.js +773 -737
- package/build/src/gamelet/merges.js +181 -179
- package/build/src/gamelet/prepare.js +276 -277
- package/build/src/gamelet/upload.js +280 -279
- package/build/src/index.js +86 -86
- package/build/src/server/Constant.js +9 -9
- package/build/src/server/entities/Client.js +78 -78
- package/build/src/server/entities/ClientOwner.js +67 -67
- package/build/src/server/entities/ClientProject.js +84 -84
- package/build/src/server/entities/Gameroom.js +89 -89
- package/build/src/server/entities/GameroomBase.js +276 -276
- package/build/src/server/entities/Gamezone.js +73 -73
- package/build/src/server/entities/ListFilter.js +193 -193
- package/build/src/server/entities/Monitor.js +94 -94
- package/build/src/server/entities/Player.js +140 -140
- package/build/src/server/managers/ApiManager.js +75 -75
- package/build/src/server/managers/ClientManager.js +64 -64
- package/build/src/server/managers/Database.js +625 -627
- package/build/src/server/managers/GameroomManager.js +392 -392
- package/build/src/server/managers/ManagerBase.js +17 -17
- package/build/src/server/managers/MonitorManager.js +73 -73
- package/build/src/server/managers/PlayerManager.js +108 -108
- package/build/src/server/managers/SocketManager.js +60 -60
- package/build/src/server/managers/UserManager.js +118 -58
- package/build/src/server/messages/Message.js +143 -143
- package/build/src/server/server.js +117 -113
- package/build/src/server/services/ServiceBase.js +25 -25
- package/build/src/server/services/clientService.js +23 -23
- package/build/src/server/services/gameroomService.js +121 -121
- package/build/src/server/services/gltserver.service.js +23 -23
- package/build/src/server/services/playerService.js +32 -32
- package/build/src/server/startServer.js +32 -33
- package/build/src/server/types/BadgeStatus.js +25 -25
- package/build/src/server/types/OrderType.js +38 -38
- package/build/src/server/types/SubmitType.js +24 -24
- package/build/src/server/types/TimeRange.js +26 -26
- package/build/src/server/utils/ArrayUtil.js +126 -126
- package/build/src/server/utils/IntUtil.js +9 -9
- package/build/src/server/utils/ObjectUtil.js +191 -191
- package/build/src/server/utils/StringUtil.js +37 -37
- package/build/src/utils/cli.js +53 -53
- package/build/src/utils/file.js +350 -337
- package/build/src/utils/init.js +57 -42
- package/build/src/utils/log.js +18 -17
- package/build/src/utils/net.js +65 -39
- package/package.json +3 -2
package/build/src/index.js
CHANGED
|
@@ -1,86 +1,86 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
"use strict";
|
|
3
|
-
/**
|
|
4
|
-
* gamelet
|
|
5
|
-
* Download project from code.gamelet.com, edit/test in vscode and sync back to server.
|
|
6
|
-
*
|
|
7
|
-
* @author Haska Su <https://haskasu.com>
|
|
8
|
-
*/
|
|
9
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
-
const cli_1 = require("./utils/cli");
|
|
11
|
-
const init_1 = require("./utils/init");
|
|
12
|
-
const log_1 = require("./utils/log");
|
|
13
|
-
const download_1 = require("./gamelet/download");
|
|
14
|
-
const prepare_1 = require("./gamelet/prepare");
|
|
15
|
-
const upload_1 = require("./gamelet/upload");
|
|
16
|
-
const startServer_1 = require("./server/startServer");
|
|
17
|
-
const Constant_1 = require("./server/Constant");
|
|
18
|
-
const input = cli_1.cli.input;
|
|
19
|
-
const flags = cli_1.cli.flags;
|
|
20
|
-
const debug = !!flags.debug;
|
|
21
|
-
(async () => {
|
|
22
|
-
init_1.init({ clear: Boolean(flags.clear) });
|
|
23
|
-
async function runDownload(prepareResult) {
|
|
24
|
-
try {
|
|
25
|
-
await download_1.download({
|
|
26
|
-
token: prepareResult.token,
|
|
27
|
-
projectCode: prepareResult.projectCode,
|
|
28
|
-
folder: prepareResult.folder,
|
|
29
|
-
sourceHandler: prepareResult.sourceHandler,
|
|
30
|
-
targetItems: prepareResult.items,
|
|
31
|
-
force: prepareResult.force,
|
|
32
|
-
debug: debug
|
|
33
|
-
});
|
|
34
|
-
}
|
|
35
|
-
catch (err) {
|
|
36
|
-
console.error(err);
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
if (input.indexOf('download') == 0) {
|
|
40
|
-
let result = await prepare_1.prepare({ command: input[0], tokenFile: input[1], folder: flags.dir, sourceHandler: flags.source, debug: debug });
|
|
41
|
-
if (result && result.token && result.projectCode && result.folder) {
|
|
42
|
-
if (flags.item) {
|
|
43
|
-
result.items = flags.item.split(',');
|
|
44
|
-
}
|
|
45
|
-
if (flags.force) {
|
|
46
|
-
result.force = true;
|
|
47
|
-
}
|
|
48
|
-
await runDownload(result);
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
else if (input.indexOf('merge') == 0) {
|
|
52
|
-
let result = await prepare_1.prepare({ command: input[0], tokenFile: null, folder: flags.dir, sourceHandler: 'merge', debug: debug });
|
|
53
|
-
if (result && result.token && result.projectCode && result.folder) {
|
|
54
|
-
if (flags.item) {
|
|
55
|
-
result.items = flags.item.split(',');
|
|
56
|
-
}
|
|
57
|
-
if (flags.force) {
|
|
58
|
-
result.force = true;
|
|
59
|
-
}
|
|
60
|
-
await runDownload(result);
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
else if (input.indexOf('upload') == 0) {
|
|
64
|
-
let result = await prepare_1.prepare({ command: input[0], tokenFile: null, folder: flags.dir, sourceHandler: 'merge', debug: debug });
|
|
65
|
-
if (result && result.token && result.projectCode && result.folder) {
|
|
66
|
-
await upload_1.upload({
|
|
67
|
-
token: result.token,
|
|
68
|
-
projectCode: result.projectCode,
|
|
69
|
-
folder: result.folder,
|
|
70
|
-
debug: debug
|
|
71
|
-
});
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
else if (input.indexOf('help') == 0) {
|
|
75
|
-
cli_1.cli.showHelp(0);
|
|
76
|
-
}
|
|
77
|
-
else if (input.indexOf('server') == 0) {
|
|
78
|
-
let result = await prepare_1.prepare({ command: input[0], tokenFile: flags.token, folder: flags.dir, sourceHandler: 'skip', debug: debug });
|
|
79
|
-
if (result && result.token && result.projectCode) {
|
|
80
|
-
await startServer_1.startServer(result.projectCode, result.folder, Constant_1.Constant.ServerPort);
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
debug && log_1.log(flags);
|
|
84
|
-
process.exit();
|
|
85
|
-
})();
|
|
86
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
"use strict";
|
|
3
|
+
/**
|
|
4
|
+
* gamelet
|
|
5
|
+
* Download project from code.gamelet.com, edit/test in vscode and sync back to server.
|
|
6
|
+
*
|
|
7
|
+
* @author Haska Su <https://haskasu.com>
|
|
8
|
+
*/
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
const cli_1 = require("./utils/cli");
|
|
11
|
+
const init_1 = require("./utils/init");
|
|
12
|
+
const log_1 = require("./utils/log");
|
|
13
|
+
const download_1 = require("./gamelet/download");
|
|
14
|
+
const prepare_1 = require("./gamelet/prepare");
|
|
15
|
+
const upload_1 = require("./gamelet/upload");
|
|
16
|
+
const startServer_1 = require("./server/startServer");
|
|
17
|
+
const Constant_1 = require("./server/Constant");
|
|
18
|
+
const input = cli_1.cli.input;
|
|
19
|
+
const flags = cli_1.cli.flags;
|
|
20
|
+
const debug = !!flags.debug;
|
|
21
|
+
(async () => {
|
|
22
|
+
(0, init_1.init)({ clear: Boolean(flags.clear) });
|
|
23
|
+
async function runDownload(prepareResult) {
|
|
24
|
+
try {
|
|
25
|
+
await (0, download_1.download)({
|
|
26
|
+
token: prepareResult.token,
|
|
27
|
+
projectCode: prepareResult.projectCode,
|
|
28
|
+
folder: prepareResult.folder,
|
|
29
|
+
sourceHandler: prepareResult.sourceHandler,
|
|
30
|
+
targetItems: prepareResult.items,
|
|
31
|
+
force: prepareResult.force,
|
|
32
|
+
debug: debug
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
catch (err) {
|
|
36
|
+
console.error(err);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
if (input.indexOf('download') == 0) {
|
|
40
|
+
let result = await (0, prepare_1.prepare)({ command: input[0], tokenFile: input[1], folder: flags.dir, sourceHandler: flags.source, debug: debug });
|
|
41
|
+
if (result && result.token && result.projectCode && result.folder) {
|
|
42
|
+
if (flags.item) {
|
|
43
|
+
result.items = flags.item.split(',');
|
|
44
|
+
}
|
|
45
|
+
if (flags.force) {
|
|
46
|
+
result.force = true;
|
|
47
|
+
}
|
|
48
|
+
await runDownload(result);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
else if (input.indexOf('merge') == 0) {
|
|
52
|
+
let result = await (0, prepare_1.prepare)({ command: input[0], tokenFile: null, folder: flags.dir, sourceHandler: 'merge', debug: debug });
|
|
53
|
+
if (result && result.token && result.projectCode && result.folder) {
|
|
54
|
+
if (flags.item) {
|
|
55
|
+
result.items = flags.item.split(',');
|
|
56
|
+
}
|
|
57
|
+
if (flags.force) {
|
|
58
|
+
result.force = true;
|
|
59
|
+
}
|
|
60
|
+
await runDownload(result);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
else if (input.indexOf('upload') == 0) {
|
|
64
|
+
let result = await (0, prepare_1.prepare)({ command: input[0], tokenFile: null, folder: flags.dir, sourceHandler: 'merge', debug: debug });
|
|
65
|
+
if (result && result.token && result.projectCode && result.folder) {
|
|
66
|
+
await (0, upload_1.upload)({
|
|
67
|
+
token: result.token,
|
|
68
|
+
projectCode: result.projectCode,
|
|
69
|
+
folder: result.folder,
|
|
70
|
+
debug: debug
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
else if (input.indexOf('help') == 0) {
|
|
75
|
+
cli_1.cli.showHelp(0);
|
|
76
|
+
}
|
|
77
|
+
else if (input.indexOf('server') == 0) {
|
|
78
|
+
let result = await (0, prepare_1.prepare)({ command: input[0], tokenFile: flags.token, folder: flags.dir, sourceHandler: 'skip', debug: debug });
|
|
79
|
+
if (result && result.token && result.projectCode) {
|
|
80
|
+
await (0, startServer_1.startServer)(result.projectCode, result.folder, Constant_1.Constant.ServerPort);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
debug && (0, log_1.log)(flags);
|
|
84
|
+
process.exit();
|
|
85
|
+
})();
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFFQTs7Ozs7R0FLRzs7QUFFSCxxQ0FBa0M7QUFDbEMsdUNBQW9DO0FBQ3BDLHFDQUFrQztBQUNsQyxpREFBOEM7QUFDOUMsK0NBQTRDO0FBQzVDLDZDQUEwQztBQUMxQyxzREFBbUQ7QUFDbkQsZ0RBQTZDO0FBRTdDLE1BQU0sS0FBSyxHQUFHLFNBQUcsQ0FBQyxLQUFLLENBQUM7QUFDeEIsTUFBTSxLQUFLLEdBQUcsU0FBRyxDQUFDLEtBQUssQ0FBQztBQUN4QixNQUFNLEtBQUssR0FBRyxDQUFDLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQztBQUU1QixDQUFDLEtBQUssSUFBSSxFQUFFO0lBQ1IsSUFBQSxXQUFJLEVBQUMsRUFBRSxLQUFLLEVBQUUsT0FBTyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLENBQUM7SUFFdEMsS0FBSyxVQUFVLFdBQVcsQ0FBQyxhQUFhO1FBQ3BDLElBQUksQ0FBQztZQUNELE1BQU0sSUFBQSxtQkFBUSxFQUFDO2dCQUNYLEtBQUssRUFBRSxhQUFhLENBQUMsS0FBSztnQkFDMUIsV0FBVyxFQUFFLGFBQWEsQ0FBQyxXQUFXO2dCQUN0QyxNQUFNLEVBQUUsYUFBYSxDQUFDLE1BQU07Z0JBQzVCLGFBQWEsRUFBRSxhQUFhLENBQUMsYUFBYTtnQkFDMUMsV0FBVyxFQUFFLGFBQWEsQ0FBQyxLQUFLO2dCQUNoQyxLQUFLLEVBQUUsYUFBYSxDQUFDLEtBQUs7Z0JBQzFCLEtBQUssRUFBRSxLQUFLO2FBQ2YsQ0FBQyxDQUFDO1FBQ1AsQ0FBQztRQUFDLE9BQU8sR0FBRyxFQUFFLENBQUM7WUFDWCxPQUFPLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ3ZCLENBQUM7SUFDTCxDQUFDO0lBRUQsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLFVBQVUsQ0FBQyxJ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
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Constant = void 0;
|
|
4
|
-
exports.Constant = {
|
|
5
|
-
ServerPort: 61701,
|
|
6
|
-
ONE_MINUTE: 60000,
|
|
7
|
-
ONE_HOUR: 60000 * 60,
|
|
8
|
-
ONE_DAY: 60000 * 60 * 24,
|
|
9
|
-
};
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Constant = void 0;
|
|
4
|
+
exports.Constant = {
|
|
5
|
+
ServerPort: 61701,
|
|
6
|
+
ONE_MINUTE: 60000,
|
|
7
|
+
ONE_HOUR: 60000 * 60,
|
|
8
|
+
ONE_DAY: 60000 * 60 * 24,
|
|
9
|
+
};
|
|
10
10
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ29uc3RhbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvc2VydmVyL0NvbnN0YW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFhLFFBQUEsUUFBUSxHQUFHO0lBRXBCLFVBQVUsRUFBRSxLQUFLO0lBSWpCLFVBQVUsRUFBRSxLQUFLO0lBQ2pCLFFBQVEsRUFBRSxLQUFLLEdBQUcsRUFBRTtJQUNwQixPQUFPLEVBQUUsS0FBSyxHQUFHLEVBQUUsR0FBRyxFQUFFO0NBQzNCLENBQUEifQ==
|
|
@@ -1,78 +1,78 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Client = void 0;
|
|
4
|
-
const Constant_1 = require("./../Constant");
|
|
5
|
-
const PlayerManager_1 = require("./../managers/PlayerManager");
|
|
6
|
-
const ArrayUtil_1 = require("./../utils/ArrayUtil");
|
|
7
|
-
class Client {
|
|
8
|
-
constructor(project, msgVersion) {
|
|
9
|
-
this.project = project;
|
|
10
|
-
this.msgVersion = msgVersion;
|
|
11
|
-
this.players = [];
|
|
12
|
-
if (typeof msgVersion === 'number') {
|
|
13
|
-
msgVersion = '' + msgVersion;
|
|
14
|
-
}
|
|
15
|
-
else if (!msgVersion) {
|
|
16
|
-
msgVersion = '';
|
|
17
|
-
}
|
|
18
|
-
this._key = project.code.replace(/\|/g, '/') + '|' + msgVersion.replace(/\|/g, '/');
|
|
19
|
-
}
|
|
20
|
-
get key() {
|
|
21
|
-
return this._key;
|
|
22
|
-
}
|
|
23
|
-
addPlayer(player) {
|
|
24
|
-
ArrayUtil_1.ArrayUtil.addUniqueElement(this.players, player);
|
|
25
|
-
}
|
|
26
|
-
removePlayer(player) {
|
|
27
|
-
ArrayUtil_1.ArrayUtil.removeElement(this.players, player);
|
|
28
|
-
}
|
|
29
|
-
removePlayerByCode(playerCode) {
|
|
30
|
-
let index = this.players.findIndex(p => p.code == playerCode);
|
|
31
|
-
if (index == -1) {
|
|
32
|
-
return null;
|
|
33
|
-
}
|
|
34
|
-
let player = this.players[index];
|
|
35
|
-
this.players.splice(index, 1);
|
|
36
|
-
return player;
|
|
37
|
-
}
|
|
38
|
-
get playersCount() {
|
|
39
|
-
return this.players.length;
|
|
40
|
-
}
|
|
41
|
-
get playerList() {
|
|
42
|
-
return this.players;
|
|
43
|
-
}
|
|
44
|
-
cleanDisconnectedPlayers() {
|
|
45
|
-
this.players = this.players.filter(p => PlayerManager_1.playerManager.getPlayerByCode(p.code));
|
|
46
|
-
}
|
|
47
|
-
disconnectInactivePlayers() {
|
|
48
|
-
let inactiveTime = Date.now() - Constant_1.Constant.ONE_HOUR * 3;
|
|
49
|
-
this.players.slice().forEach(p => {
|
|
50
|
-
if (p.lastMsgTime < inactiveTime) {
|
|
51
|
-
p.disconnect();
|
|
52
|
-
}
|
|
53
|
-
});
|
|
54
|
-
}
|
|
55
|
-
getPlayersCount(options) {
|
|
56
|
-
if (options) {
|
|
57
|
-
let total = 0;
|
|
58
|
-
const inGameroom = options.inGameroom;
|
|
59
|
-
for (let player of this.players) {
|
|
60
|
-
if (inGameroom) {
|
|
61
|
-
if (!player.getGameroom() ||
|
|
62
|
-
(inGameroom.zone && player.getGameroom().gamezone.code != inGameroom.zone) ||
|
|
63
|
-
(inGameroom.code && player.getGameroom().code != inGameroom.code) ||
|
|
64
|
-
(inGameroom.states && !inGameroom.states.includes(player.getGameroom().state))) {
|
|
65
|
-
continue;
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
++total;
|
|
69
|
-
}
|
|
70
|
-
return total;
|
|
71
|
-
}
|
|
72
|
-
else {
|
|
73
|
-
return this.playersCount;
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
exports.Client = Client;
|
|
78
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Client = void 0;
|
|
4
|
+
const Constant_1 = require("./../Constant");
|
|
5
|
+
const PlayerManager_1 = require("./../managers/PlayerManager");
|
|
6
|
+
const ArrayUtil_1 = require("./../utils/ArrayUtil");
|
|
7
|
+
class Client {
|
|
8
|
+
constructor(project, msgVersion) {
|
|
9
|
+
this.project = project;
|
|
10
|
+
this.msgVersion = msgVersion;
|
|
11
|
+
this.players = [];
|
|
12
|
+
if (typeof msgVersion === 'number') {
|
|
13
|
+
msgVersion = '' + msgVersion;
|
|
14
|
+
}
|
|
15
|
+
else if (!msgVersion) {
|
|
16
|
+
msgVersion = '';
|
|
17
|
+
}
|
|
18
|
+
this._key = project.code.replace(/\|/g, '/') + '|' + msgVersion.replace(/\|/g, '/');
|
|
19
|
+
}
|
|
20
|
+
get key() {
|
|
21
|
+
return this._key;
|
|
22
|
+
}
|
|
23
|
+
addPlayer(player) {
|
|
24
|
+
ArrayUtil_1.ArrayUtil.addUniqueElement(this.players, player);
|
|
25
|
+
}
|
|
26
|
+
removePlayer(player) {
|
|
27
|
+
ArrayUtil_1.ArrayUtil.removeElement(this.players, player);
|
|
28
|
+
}
|
|
29
|
+
removePlayerByCode(playerCode) {
|
|
30
|
+
let index = this.players.findIndex(p => p.code == playerCode);
|
|
31
|
+
if (index == -1) {
|
|
32
|
+
return null;
|
|
33
|
+
}
|
|
34
|
+
let player = this.players[index];
|
|
35
|
+
this.players.splice(index, 1);
|
|
36
|
+
return player;
|
|
37
|
+
}
|
|
38
|
+
get playersCount() {
|
|
39
|
+
return this.players.length;
|
|
40
|
+
}
|
|
41
|
+
get playerList() {
|
|
42
|
+
return this.players;
|
|
43
|
+
}
|
|
44
|
+
cleanDisconnectedPlayers() {
|
|
45
|
+
this.players = this.players.filter(p => PlayerManager_1.playerManager.getPlayerByCode(p.code));
|
|
46
|
+
}
|
|
47
|
+
disconnectInactivePlayers() {
|
|
48
|
+
let inactiveTime = Date.now() - Constant_1.Constant.ONE_HOUR * 3;
|
|
49
|
+
this.players.slice().forEach(p => {
|
|
50
|
+
if (p.lastMsgTime < inactiveTime) {
|
|
51
|
+
p.disconnect();
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
getPlayersCount(options) {
|
|
56
|
+
if (options) {
|
|
57
|
+
let total = 0;
|
|
58
|
+
const inGameroom = options.inGameroom;
|
|
59
|
+
for (let player of this.players) {
|
|
60
|
+
if (inGameroom) {
|
|
61
|
+
if (!player.getGameroom() ||
|
|
62
|
+
(inGameroom.zone && player.getGameroom().gamezone.code != inGameroom.zone) ||
|
|
63
|
+
(inGameroom.code && player.getGameroom().code != inGameroom.code) ||
|
|
64
|
+
(inGameroom.states && !inGameroom.states.includes(player.getGameroom().state))) {
|
|
65
|
+
continue;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
++total;
|
|
69
|
+
}
|
|
70
|
+
return total;
|
|
71
|
+
}
|
|
72
|
+
else {
|
|
73
|
+
return this.playersCount;
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
exports.Client = Client;
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ2xpZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3NlcnZlci9lbnRpdGllcy9DbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsNENBQXlDO0FBQ3pDLCtEQUE0RDtBQUM1RCxvREFBaUQ7QUFHakQsTUFBYSxNQUFNO0lBTWYsWUFBbUIsT0FBc0IsRUFBUyxVQUFrQjtRQUFqRCxZQUFPLEdBQVAsT0FBTyxDQUFlO1FBQVMsZUFBVSxHQUFWLFVBQVUsQ0FBUTtRQUY1RCxZQUFPLEdBQWEsRUFBRSxDQUFDO1FBRzNCLElBQUksT0FBTyxVQUFVLEtBQUssUUFBUSxFQUFFLENBQUM7WUFDakMsVUFBVSxHQUFHLEVBQUUsR0FBRyxVQUFVLENBQUM7UUFDakMsQ0FBQzthQUFNLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztZQUNyQixVQUFVLEdBQUcsRUFBRSxDQUFBO1FBQ25CLENBQUM7UUFDRCxJQUFJLENBQUMsSUFBSSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssRUFBRSxHQUFHLENBQUMsR0FBRyxHQUFHLEdBQUcsVUFBVSxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDeEYsQ0FBQztJQUVELElBQUksR0FBRztRQUNILE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQztJQUNyQixDQUFDO0lBRUQsU0FBUyxDQUFDLE1BQWM7UUFDcEIscUJBQVMsQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ3JELENBQUM7SUFFRCxZQUFZLENBQUMsTUFBYztRQUN2QixxQkFBUyxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ2xELENBQUM7SUFFRCxrQkFBa0IsQ0FBQyxVQUFrQjtRQUNqQyxJQUFJLEtBQUssR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLFNB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
|
|
@@ -1,67 +1,67 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.ClientOwner = void 0;
|
|
4
|
-
const ClientProject_1 = require("./ClientProject");
|
|
5
|
-
const Constant_1 = require("./../Constant");
|
|
6
|
-
const gltserver_service_1 = require("../services/gltserver.service");
|
|
7
|
-
class ClientOwner {
|
|
8
|
-
constructor(ownername) {
|
|
9
|
-
this.ownername = ownername;
|
|
10
|
-
this.projects = {};
|
|
11
|
-
this.maxPlayers = 5;
|
|
12
|
-
this.timeToUpdateMaxPlayers = 0;
|
|
13
|
-
}
|
|
14
|
-
addProject(project) {
|
|
15
|
-
this.projects[project.code] = project;
|
|
16
|
-
}
|
|
17
|
-
getProject(projectCode) {
|
|
18
|
-
let project = this.projects[projectCode];
|
|
19
|
-
if (!project) {
|
|
20
|
-
project = new ClientProject_1.ClientProject(projectCode, this);
|
|
21
|
-
this.projects[projectCode] = project;
|
|
22
|
-
}
|
|
23
|
-
return project;
|
|
24
|
-
}
|
|
25
|
-
getMaxPlayers() {
|
|
26
|
-
if (Date.now() < this.timeToUpdateMaxPlayers) {
|
|
27
|
-
return Promise.resolve(this.maxPlayers);
|
|
28
|
-
}
|
|
29
|
-
return gltserver_service_1.serverService.getMaxPlayers(this.ownername)
|
|
30
|
-
.then(max => {
|
|
31
|
-
this.maxPlayers = max;
|
|
32
|
-
this.timeToUpdateMaxPlayers = Date.now() + Constant_1.Constant.ONE_MINUTE;
|
|
33
|
-
return this.maxPlayers;
|
|
34
|
-
});
|
|
35
|
-
}
|
|
36
|
-
get playerList() {
|
|
37
|
-
let list = [];
|
|
38
|
-
for (let key in this.projects) {
|
|
39
|
-
list = list.concat(this.projects[key].playerList);
|
|
40
|
-
}
|
|
41
|
-
return list;
|
|
42
|
-
}
|
|
43
|
-
get playersCount() {
|
|
44
|
-
let count = 0;
|
|
45
|
-
for (let key in this.projects) {
|
|
46
|
-
count += this.projects[key].playersCount;
|
|
47
|
-
}
|
|
48
|
-
return count;
|
|
49
|
-
}
|
|
50
|
-
getPlayersCountByProject(project) {
|
|
51
|
-
let ownerCount = 0;
|
|
52
|
-
let projectCount = 0;
|
|
53
|
-
for (let key in this.projects) {
|
|
54
|
-
let count = this.projects[key].playersCount;
|
|
55
|
-
ownerCount += count;
|
|
56
|
-
if (key == project.code) {
|
|
57
|
-
projectCount = count;
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
return {
|
|
61
|
-
ownerCount: ownerCount,
|
|
62
|
-
projectCount: projectCount
|
|
63
|
-
};
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
exports.ClientOwner = ClientOwner;
|
|
67
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ClientOwner = void 0;
|
|
4
|
+
const ClientProject_1 = require("./ClientProject");
|
|
5
|
+
const Constant_1 = require("./../Constant");
|
|
6
|
+
const gltserver_service_1 = require("../services/gltserver.service");
|
|
7
|
+
class ClientOwner {
|
|
8
|
+
constructor(ownername) {
|
|
9
|
+
this.ownername = ownername;
|
|
10
|
+
this.projects = {};
|
|
11
|
+
this.maxPlayers = 5;
|
|
12
|
+
this.timeToUpdateMaxPlayers = 0;
|
|
13
|
+
}
|
|
14
|
+
addProject(project) {
|
|
15
|
+
this.projects[project.code] = project;
|
|
16
|
+
}
|
|
17
|
+
getProject(projectCode) {
|
|
18
|
+
let project = this.projects[projectCode];
|
|
19
|
+
if (!project) {
|
|
20
|
+
project = new ClientProject_1.ClientProject(projectCode, this);
|
|
21
|
+
this.projects[projectCode] = project;
|
|
22
|
+
}
|
|
23
|
+
return project;
|
|
24
|
+
}
|
|
25
|
+
getMaxPlayers() {
|
|
26
|
+
if (Date.now() < this.timeToUpdateMaxPlayers) {
|
|
27
|
+
return Promise.resolve(this.maxPlayers);
|
|
28
|
+
}
|
|
29
|
+
return gltserver_service_1.serverService.getMaxPlayers(this.ownername)
|
|
30
|
+
.then(max => {
|
|
31
|
+
this.maxPlayers = max;
|
|
32
|
+
this.timeToUpdateMaxPlayers = Date.now() + Constant_1.Constant.ONE_MINUTE;
|
|
33
|
+
return this.maxPlayers;
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
get playerList() {
|
|
37
|
+
let list = [];
|
|
38
|
+
for (let key in this.projects) {
|
|
39
|
+
list = list.concat(this.projects[key].playerList);
|
|
40
|
+
}
|
|
41
|
+
return list;
|
|
42
|
+
}
|
|
43
|
+
get playersCount() {
|
|
44
|
+
let count = 0;
|
|
45
|
+
for (let key in this.projects) {
|
|
46
|
+
count += this.projects[key].playersCount;
|
|
47
|
+
}
|
|
48
|
+
return count;
|
|
49
|
+
}
|
|
50
|
+
getPlayersCountByProject(project) {
|
|
51
|
+
let ownerCount = 0;
|
|
52
|
+
let projectCount = 0;
|
|
53
|
+
for (let key in this.projects) {
|
|
54
|
+
let count = this.projects[key].playersCount;
|
|
55
|
+
ownerCount += count;
|
|
56
|
+
if (key == project.code) {
|
|
57
|
+
projectCount = count;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
return {
|
|
61
|
+
ownerCount: ownerCount,
|
|
62
|
+
projectCount: projectCount
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
exports.ClientOwner = ClientOwner;
|
|
67
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ2xpZW50T3duZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvc2VydmVyL2VudGl0aWVzL0NsaWVudE93bmVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLG1EQUFnRDtBQUNoRCw0Q0FBeUM7QUFDekMscUVBQThEO0FBRzlELE1BQWEsV0FBVztJQVFwQixZQUFtQixTQUFpQjtRQUFqQixjQUFTLEdBQVQsU0FBUyxDQUFRO1FBTjVCLGFBQVEsR0FBcUMsRUFBRSxDQUFDO1FBRWhELGVBQVUsR0FBVyxDQUFDLENBQUM7UUFFdkIsMkJBQXNCLEdBQVcsQ0FBQyxDQUFDO0lBSTNDLENBQUM7SUFFRCxVQUFVLENBQUMsT0FBc0I7UUFDN0IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsT0FBTyxDQUFDO0lBQzFDLENBQUM7SUFFRCxVQUFVLENBQUMsV0FBbUI7UUFDMUIsSUFBSSxPQUFPLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUN6QyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDWCxPQUFPLEdBQUcsSUFBSSw2QkFBYSxDQUFDLFdBQVcsRUFBRSxJQUFJLENBQUMsQ0FBQztZQUMvQyxJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxHQUFHLE9BQU8sQ0FBQztRQUN6QyxDQUFDO1FBQ0QsT0FBTyxPQUFPLENBQUM7SUFDbkIsQ0FBQztJQUVELGFBQWE7UUFDVCxJQUFJLElBQUksQ0FBQyxHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsc0JBQXNCLEVBQUUsQ0FBQztZQUMzQyxPQUFPLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQzVDLENBQUM7UUFFRCxPQUFPLGlDQUFhLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUM7YUFDN0MsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFO1lBQ1IsSUFBSSxDQUFDLFVBQVUsR0FBRyxHQUFHLENBQUM7WUFDdEIsSUFBSSxDQUFDLHNCQUFzQixHQUFHLElBQUksQ0FBQyxHQUFHLEVBQUUsR0FBRyxtQkFBUSxDQUFDLFVBQVUsQ0FBQztZQUMvRCxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUM7UUFDM0IsQ0FBQyxDQUFDLENBQUE7SUFDVixDQUFDO0lBRUQsSUFBSSxVQUFVO1FBQ1YsSUFBSSxJQUFJLEdBQWEsRUFBRSxDQUFDO1FBQ3hCLEtBQUssSUFBSSxHQUFHLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQzVCLElBQUksR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDdEQsQ0FBQztRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2hCLENBQUM7SUFFRCxJQUFJLFlBQVk7UUFDWixJQUFJLEtBQUssR0FBRyxDQUFDLENBQUM7UUFDZCxLQUFLLElBQUksR0FBRyxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUM1QixLQUFLLElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsQ0FBQyxZQUFZLENBQUM7UUFDN0MsQ0FBQztRQUNELE9BQU8sS0FBSyxDQUFDO0lBQ2pCLENBQUM7SUFFRCx3QkFBd0IsQ0FBQyxPQUFzQjtRQUMzQyxJQUFJLFVBQVUsR0FBVyxDQUFDLENBQUM7UUFDM0IsSUFBSSxZQUFZLEdBQVcsQ0FBQyxDQUFDO1FBQzdCLEtBQUssSUFBSSxHQUFHLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQzVCLElBQUksS0FBSyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLENBQUMsWUFBWSxDQUFDO1lBQzVDLFVBQVUsSUFBSSxLQUFLLENBQUE7WUFDbkIsSUFBSSxHQUFHLElBQUksT0FBTyxDQUFDLElBQUksRUFBRSxDQUFDO2dCQUN0QixZQUFZLEdBQUcsS0FBSyxDQUFBO1lBQ3hCLENBQUM7UUFDTCxDQUFDO1FBQ0QsT0FBTztZQUNILFVBQVUsRUFBRSxVQUFVO1lBQ3RCLFlBQVksRUFBRSxZQUFZO1NBQzdCLENBQUM7SUFDTixDQUFDO0NBRUo7QUF0RUQsa0NBc0VDIn0=
|