@ekhein/sekiro-node-client 1.0.3 → 1.0.5
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/dist/chunk-3KTEWZC4.js +13 -0
- package/dist/chunk-4IXLXWNL.js +29 -0
- package/dist/chunk-ADS4GRIL.js +14 -0
- package/dist/chunk-JB43IB4T.js +13 -0
- package/dist/{SekiroClient.js → chunk-MDQJHW6K.js} +20 -33
- package/dist/decorators/action.decorator.cjs +36 -0
- package/dist/decorators/action.decorator.d.cts +3 -0
- package/dist/decorators/action.decorator.d.ts +3 -0
- package/dist/decorators/action.decorator.js +13 -0
- package/dist/decorators/bootstrap.decorator.cjs +37 -0
- package/dist/decorators/bootstrap.decorator.d.cts +3 -0
- package/dist/decorators/bootstrap.decorator.d.ts +3 -0
- package/dist/decorators/bootstrap.decorator.js +7 -0
- package/dist/{SekiroClient.cjs → main.cjs} +42 -25
- package/dist/{SekiroClient.d.cts → main.d.cts} +6 -2
- package/dist/{SekiroClient.d.ts → main.d.ts} +6 -2
- package/dist/main.js +9 -0
- package/dist/test.cjs +119 -0
- package/dist/test.d.cts +2 -0
- package/dist/test.d.ts +2 -0
- package/dist/test.js +18 -0
- package/dist/utils/logger.util.cjs +53 -0
- package/dist/utils/logger.util.d.cts +12 -0
- package/dist/utils/logger.util.d.ts +12 -0
- package/dist/utils/logger.util.js +7 -0
- package/dist/utils/result.util.cjs +37 -0
- package/dist/utils/result.util.d.cts +6 -0
- package/dist/utils/result.util.d.ts +6 -0
- package/dist/utils/result.util.js +7 -0
- package/package.json +5 -5
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
// src/decorators/bootstrap.decorator.ts
|
|
2
|
+
function Fork(count = 1, host, prot, clientId) {
|
|
3
|
+
return function(Client) {
|
|
4
|
+
for (let i = 1; i <= count; i++) {
|
|
5
|
+
const group = Array(Client.name, i).join("::");
|
|
6
|
+
new Client(group, host, prot, clientId);
|
|
7
|
+
}
|
|
8
|
+
};
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export {
|
|
12
|
+
Fork
|
|
13
|
+
};
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
// src/utils/logger.util.ts
|
|
2
|
+
import { format } from "util";
|
|
3
|
+
var Logger = class {
|
|
4
|
+
constructor(context) {
|
|
5
|
+
this.context = context;
|
|
6
|
+
}
|
|
7
|
+
log(level, message) {
|
|
8
|
+
const time = (/* @__PURE__ */ new Date()).toLocaleString();
|
|
9
|
+
const base = format("[%s] [%s] [%s] [%s]", level, time, this.context.scope, this.context.clientId);
|
|
10
|
+
switch (level) {
|
|
11
|
+
case "INFO":
|
|
12
|
+
console.info(base, ...message);
|
|
13
|
+
break;
|
|
14
|
+
case "WARN":
|
|
15
|
+
console.warn(base, ...message);
|
|
16
|
+
break;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
info(...message) {
|
|
20
|
+
this.log("INFO", message);
|
|
21
|
+
}
|
|
22
|
+
warn(...message) {
|
|
23
|
+
this.log("WARN", message);
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
export {
|
|
28
|
+
Logger
|
|
29
|
+
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __decorateClass = (decorators, target, key, kind) => {
|
|
4
|
+
var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
|
|
5
|
+
for (var i = decorators.length - 1, decorator; i >= 0; i--)
|
|
6
|
+
if (decorator = decorators[i])
|
|
7
|
+
result = (kind ? decorator(target, key, result) : decorator(result)) || result;
|
|
8
|
+
if (kind && result) __defProp(target, key, result);
|
|
9
|
+
return result;
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
export {
|
|
13
|
+
__decorateClass
|
|
14
|
+
};
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
// src/utils/result.util.ts
|
|
2
|
+
var Result = class {
|
|
3
|
+
static success({ __sekiro_seq__ }, data) {
|
|
4
|
+
return JSON.stringify({ __sekiro_seq__, data, status: 0 });
|
|
5
|
+
}
|
|
6
|
+
static unknown({ __sekiro_seq__ }, message) {
|
|
7
|
+
return JSON.stringify({ __sekiro_seq__, message, status: -1 });
|
|
8
|
+
}
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
export {
|
|
12
|
+
Result
|
|
13
|
+
};
|
|
@@ -1,32 +1,16 @@
|
|
|
1
|
-
|
|
1
|
+
import {
|
|
2
|
+
Logger
|
|
3
|
+
} from "./chunk-4IXLXWNL.js";
|
|
4
|
+
import {
|
|
5
|
+
Result
|
|
6
|
+
} from "./chunk-JB43IB4T.js";
|
|
7
|
+
|
|
8
|
+
// src/main.ts
|
|
2
9
|
import { format } from "util";
|
|
3
10
|
import { randomUUID } from "crypto";
|
|
4
11
|
import { WebSocket } from "partysocket";
|
|
5
12
|
import { WebSocket as Client } from "ws";
|
|
6
|
-
|
|
7
|
-
// src/SekiroResult.ts
|
|
8
|
-
var SekiroResult = class {
|
|
9
|
-
static success({ __sekiro_seq__ }, data) {
|
|
10
|
-
return JSON.stringify({ __sekiro_seq__, data, status: 0 });
|
|
11
|
-
}
|
|
12
|
-
static unknown({ __sekiro_seq__ }, message) {
|
|
13
|
-
return JSON.stringify({ __sekiro_seq__, message, status: -1 });
|
|
14
|
-
}
|
|
15
|
-
};
|
|
16
|
-
|
|
17
|
-
// src/SekiroLogger.ts
|
|
18
|
-
var SekiroLogger = class {
|
|
19
|
-
static info(...args) {
|
|
20
|
-
console.info("[I] [" + (/* @__PURE__ */ new Date()).toLocaleString() + "]", ...args);
|
|
21
|
-
}
|
|
22
|
-
static warn(...args) {
|
|
23
|
-
console.warn("[W] [" + (/* @__PURE__ */ new Date()).toLocaleString() + "]", ...args);
|
|
24
|
-
}
|
|
25
|
-
};
|
|
26
|
-
|
|
27
|
-
// src/SekiroClient.ts
|
|
28
13
|
var SekiroClient = class extends WebSocket {
|
|
29
|
-
handlers = /* @__PURE__ */ new Map([]);
|
|
30
14
|
constructor(scope, host = "192.168.2.102", prot = 5612, clientId = randomUUID().replace(/-/g, "")) {
|
|
31
15
|
super("wss://", [], {
|
|
32
16
|
debug: false,
|
|
@@ -41,36 +25,39 @@ var SekiroClient = class extends WebSocket {
|
|
|
41
25
|
}
|
|
42
26
|
}
|
|
43
27
|
});
|
|
28
|
+
this.scope = scope;
|
|
29
|
+
this.host = host;
|
|
30
|
+
this.prot = prot;
|
|
31
|
+
this.clientId = clientId;
|
|
44
32
|
super.addEventListener("open", this.onOpen.bind(this));
|
|
45
33
|
super.addEventListener("message", this.onData.bind(this));
|
|
46
34
|
super.addEventListener("close", this.onClose.bind(this));
|
|
47
35
|
super.addEventListener("error", this.onError.bind(this));
|
|
48
36
|
}
|
|
37
|
+
logger = new Logger(this);
|
|
49
38
|
async onOpen(event) {
|
|
50
|
-
|
|
39
|
+
this.logger.info("Connection established");
|
|
51
40
|
}
|
|
52
41
|
async onClose(event) {
|
|
53
|
-
|
|
42
|
+
this.logger.warn("Connection closed");
|
|
54
43
|
}
|
|
55
44
|
async onError(event) {
|
|
56
|
-
|
|
45
|
+
this.logger.warn("WebSocket error:", event.message);
|
|
57
46
|
}
|
|
58
47
|
async onData(event) {
|
|
59
|
-
|
|
48
|
+
this.logger.info("Received request", event.data);
|
|
60
49
|
const request = JSON.parse(event.data);
|
|
61
50
|
try {
|
|
62
51
|
const data = await this.handlers.get(request.action)?.apply(this, [request]);
|
|
63
|
-
const pack =
|
|
52
|
+
const pack = Result.success(request, data);
|
|
64
53
|
this.send(pack);
|
|
65
54
|
} catch (error) {
|
|
66
|
-
const pack =
|
|
55
|
+
const pack = Result.unknown(request, error.message);
|
|
67
56
|
this.send(pack);
|
|
68
57
|
}
|
|
69
58
|
}
|
|
70
|
-
async registerAction(action, handler) {
|
|
71
|
-
this.handlers.set(action, handler);
|
|
72
|
-
}
|
|
73
59
|
};
|
|
60
|
+
|
|
74
61
|
export {
|
|
75
62
|
SekiroClient
|
|
76
63
|
};
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// src/decorators/action.decorator.ts
|
|
21
|
+
var action_decorator_exports = {};
|
|
22
|
+
__export(action_decorator_exports, {
|
|
23
|
+
Action: () => Action
|
|
24
|
+
});
|
|
25
|
+
module.exports = __toCommonJS(action_decorator_exports);
|
|
26
|
+
function Action() {
|
|
27
|
+
return function(target, method, descriptor) {
|
|
28
|
+
if (!target.handlers)
|
|
29
|
+
target.handlers = /* @__PURE__ */ new Map();
|
|
30
|
+
target.handlers.set(method, descriptor.value);
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
34
|
+
0 && (module.exports = {
|
|
35
|
+
Action
|
|
36
|
+
});
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import "../chunk-ADS4GRIL.js";
|
|
2
|
+
|
|
3
|
+
// src/decorators/action.decorator.ts
|
|
4
|
+
function Action() {
|
|
5
|
+
return function(target, method, descriptor) {
|
|
6
|
+
if (!target.handlers)
|
|
7
|
+
target.handlers = /* @__PURE__ */ new Map();
|
|
8
|
+
target.handlers.set(method, descriptor.value);
|
|
9
|
+
};
|
|
10
|
+
}
|
|
11
|
+
export {
|
|
12
|
+
Action
|
|
13
|
+
};
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// src/decorators/bootstrap.decorator.ts
|
|
21
|
+
var bootstrap_decorator_exports = {};
|
|
22
|
+
__export(bootstrap_decorator_exports, {
|
|
23
|
+
Fork: () => Fork
|
|
24
|
+
});
|
|
25
|
+
module.exports = __toCommonJS(bootstrap_decorator_exports);
|
|
26
|
+
function Fork(count = 1, host, prot, clientId) {
|
|
27
|
+
return function(Client) {
|
|
28
|
+
for (let i = 1; i <= count; i++) {
|
|
29
|
+
const group = Array(Client.name, i).join("::");
|
|
30
|
+
new Client(group, host, prot, clientId);
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
35
|
+
0 && (module.exports = {
|
|
36
|
+
Fork
|
|
37
|
+
});
|
|
@@ -17,19 +17,19 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
17
17
|
};
|
|
18
18
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
19
|
|
|
20
|
-
// src/
|
|
21
|
-
var
|
|
22
|
-
__export(
|
|
20
|
+
// src/main.ts
|
|
21
|
+
var main_exports = {};
|
|
22
|
+
__export(main_exports, {
|
|
23
23
|
SekiroClient: () => SekiroClient
|
|
24
24
|
});
|
|
25
|
-
module.exports = __toCommonJS(
|
|
26
|
-
var
|
|
25
|
+
module.exports = __toCommonJS(main_exports);
|
|
26
|
+
var import_util2 = require("util");
|
|
27
27
|
var import_crypto = require("crypto");
|
|
28
28
|
var import_partysocket = require("partysocket");
|
|
29
29
|
var import_ws = require("ws");
|
|
30
30
|
|
|
31
|
-
// src/
|
|
32
|
-
var
|
|
31
|
+
// src/utils/result.util.ts
|
|
32
|
+
var Result = class {
|
|
33
33
|
static success({ __sekiro_seq__ }, data) {
|
|
34
34
|
return JSON.stringify({ __sekiro_seq__, data, status: 0 });
|
|
35
35
|
}
|
|
@@ -38,26 +38,41 @@ var SekiroResult = class {
|
|
|
38
38
|
}
|
|
39
39
|
};
|
|
40
40
|
|
|
41
|
-
// src/
|
|
42
|
-
var
|
|
43
|
-
|
|
44
|
-
|
|
41
|
+
// src/utils/logger.util.ts
|
|
42
|
+
var import_util = require("util");
|
|
43
|
+
var Logger = class {
|
|
44
|
+
constructor(context) {
|
|
45
|
+
this.context = context;
|
|
46
|
+
}
|
|
47
|
+
log(level, message) {
|
|
48
|
+
const time = (/* @__PURE__ */ new Date()).toLocaleString();
|
|
49
|
+
const base = (0, import_util.format)("[%s] [%s] [%s] [%s]", level, time, this.context.scope, this.context.clientId);
|
|
50
|
+
switch (level) {
|
|
51
|
+
case "INFO":
|
|
52
|
+
console.info(base, ...message);
|
|
53
|
+
break;
|
|
54
|
+
case "WARN":
|
|
55
|
+
console.warn(base, ...message);
|
|
56
|
+
break;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
info(...message) {
|
|
60
|
+
this.log("INFO", message);
|
|
45
61
|
}
|
|
46
|
-
|
|
47
|
-
|
|
62
|
+
warn(...message) {
|
|
63
|
+
this.log("WARN", message);
|
|
48
64
|
}
|
|
49
65
|
};
|
|
50
66
|
|
|
51
|
-
// src/
|
|
67
|
+
// src/main.ts
|
|
52
68
|
var SekiroClient = class extends import_partysocket.WebSocket {
|
|
53
|
-
handlers = /* @__PURE__ */ new Map([]);
|
|
54
69
|
constructor(scope, host = "192.168.2.102", prot = 5612, clientId = (0, import_crypto.randomUUID)().replace(/-/g, "")) {
|
|
55
70
|
super("wss://", [], {
|
|
56
71
|
debug: false,
|
|
57
72
|
maxEnqueuedMessages: -1,
|
|
58
73
|
WebSocket: class extends import_ws.WebSocket {
|
|
59
74
|
constructor() {
|
|
60
|
-
const site = (0,
|
|
75
|
+
const site = (0, import_util2.format)("ws://%s:%s", host, prot);
|
|
61
76
|
const wsURL = new URL("/business-demo/register", site);
|
|
62
77
|
wsURL.searchParams.append("group", scope);
|
|
63
78
|
wsURL.searchParams.append("clientId", clientId);
|
|
@@ -65,35 +80,37 @@ var SekiroClient = class extends import_partysocket.WebSocket {
|
|
|
65
80
|
}
|
|
66
81
|
}
|
|
67
82
|
});
|
|
83
|
+
this.scope = scope;
|
|
84
|
+
this.host = host;
|
|
85
|
+
this.prot = prot;
|
|
86
|
+
this.clientId = clientId;
|
|
68
87
|
super.addEventListener("open", this.onOpen.bind(this));
|
|
69
88
|
super.addEventListener("message", this.onData.bind(this));
|
|
70
89
|
super.addEventListener("close", this.onClose.bind(this));
|
|
71
90
|
super.addEventListener("error", this.onError.bind(this));
|
|
72
91
|
}
|
|
92
|
+
logger = new Logger(this);
|
|
73
93
|
async onOpen(event) {
|
|
74
|
-
|
|
94
|
+
this.logger.info("Connection established");
|
|
75
95
|
}
|
|
76
96
|
async onClose(event) {
|
|
77
|
-
|
|
97
|
+
this.logger.warn("Connection closed");
|
|
78
98
|
}
|
|
79
99
|
async onError(event) {
|
|
80
|
-
|
|
100
|
+
this.logger.warn("WebSocket error:", event.message);
|
|
81
101
|
}
|
|
82
102
|
async onData(event) {
|
|
83
|
-
|
|
103
|
+
this.logger.info("Received request", event.data);
|
|
84
104
|
const request = JSON.parse(event.data);
|
|
85
105
|
try {
|
|
86
106
|
const data = await this.handlers.get(request.action)?.apply(this, [request]);
|
|
87
|
-
const pack =
|
|
107
|
+
const pack = Result.success(request, data);
|
|
88
108
|
this.send(pack);
|
|
89
109
|
} catch (error) {
|
|
90
|
-
const pack =
|
|
110
|
+
const pack = Result.unknown(request, error.message);
|
|
91
111
|
this.send(pack);
|
|
92
112
|
}
|
|
93
113
|
}
|
|
94
|
-
async registerAction(action, handler) {
|
|
95
|
-
this.handlers.set(action, handler);
|
|
96
|
-
}
|
|
97
114
|
};
|
|
98
115
|
// Annotate the CommonJS export names for ESM import in node:
|
|
99
116
|
0 && (module.exports = {
|
|
@@ -1,13 +1,17 @@
|
|
|
1
1
|
import { WebSocket } from 'partysocket';
|
|
2
2
|
|
|
3
3
|
declare class SekiroClient extends WebSocket {
|
|
4
|
-
|
|
4
|
+
readonly scope: string;
|
|
5
|
+
readonly host: string;
|
|
6
|
+
readonly prot: number;
|
|
7
|
+
readonly clientId: string;
|
|
8
|
+
readonly handlers: Map<string, Function>;
|
|
9
|
+
private readonly logger;
|
|
5
10
|
constructor(scope: string, host?: string, prot?: number, clientId?: string);
|
|
6
11
|
private onOpen;
|
|
7
12
|
private onClose;
|
|
8
13
|
private onError;
|
|
9
14
|
private onData;
|
|
10
|
-
registerAction(action: string, handler: ISekiroHandler): Promise<void>;
|
|
11
15
|
}
|
|
12
16
|
|
|
13
17
|
export { SekiroClient };
|
|
@@ -1,13 +1,17 @@
|
|
|
1
1
|
import { WebSocket } from 'partysocket';
|
|
2
2
|
|
|
3
3
|
declare class SekiroClient extends WebSocket {
|
|
4
|
-
|
|
4
|
+
readonly scope: string;
|
|
5
|
+
readonly host: string;
|
|
6
|
+
readonly prot: number;
|
|
7
|
+
readonly clientId: string;
|
|
8
|
+
readonly handlers: Map<string, Function>;
|
|
9
|
+
private readonly logger;
|
|
5
10
|
constructor(scope: string, host?: string, prot?: number, clientId?: string);
|
|
6
11
|
private onOpen;
|
|
7
12
|
private onClose;
|
|
8
13
|
private onError;
|
|
9
14
|
private onData;
|
|
10
|
-
registerAction(action: string, handler: ISekiroHandler): Promise<void>;
|
|
11
15
|
}
|
|
12
16
|
|
|
13
17
|
export { SekiroClient };
|
package/dist/main.js
ADDED
package/dist/test.cjs
ADDED
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __decorateClass = (decorators, target, key, kind) => {
|
|
5
|
+
var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
|
|
6
|
+
for (var i = decorators.length - 1, decorator; i >= 0; i--)
|
|
7
|
+
if (decorator = decorators[i])
|
|
8
|
+
result = (kind ? decorator(target, key, result) : decorator(result)) || result;
|
|
9
|
+
if (kind && result) __defProp(target, key, result);
|
|
10
|
+
return result;
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
// src/decorators/bootstrap.decorator.ts
|
|
14
|
+
function Fork(count = 1, host, prot, clientId) {
|
|
15
|
+
return function(Client2) {
|
|
16
|
+
for (let i = 1; i <= count; i++) {
|
|
17
|
+
const group = Array(Client2.name, i).join("::");
|
|
18
|
+
new Client2(group, host, prot, clientId);
|
|
19
|
+
}
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
// src/main.ts
|
|
24
|
+
var import_util2 = require("util");
|
|
25
|
+
var import_crypto = require("crypto");
|
|
26
|
+
var import_partysocket = require("partysocket");
|
|
27
|
+
var import_ws = require("ws");
|
|
28
|
+
|
|
29
|
+
// src/utils/result.util.ts
|
|
30
|
+
var Result = class {
|
|
31
|
+
static success({ __sekiro_seq__ }, data) {
|
|
32
|
+
return JSON.stringify({ __sekiro_seq__, data, status: 0 });
|
|
33
|
+
}
|
|
34
|
+
static unknown({ __sekiro_seq__ }, message) {
|
|
35
|
+
return JSON.stringify({ __sekiro_seq__, message, status: -1 });
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
|
|
39
|
+
// src/utils/logger.util.ts
|
|
40
|
+
var import_util = require("util");
|
|
41
|
+
var Logger = class {
|
|
42
|
+
constructor(context) {
|
|
43
|
+
this.context = context;
|
|
44
|
+
}
|
|
45
|
+
log(level, message) {
|
|
46
|
+
const time = (/* @__PURE__ */ new Date()).toLocaleString();
|
|
47
|
+
const base = (0, import_util.format)("[%s] [%s] [%s] [%s]", level, time, this.context.scope, this.context.clientId);
|
|
48
|
+
switch (level) {
|
|
49
|
+
case "INFO":
|
|
50
|
+
console.info(base, ...message);
|
|
51
|
+
break;
|
|
52
|
+
case "WARN":
|
|
53
|
+
console.warn(base, ...message);
|
|
54
|
+
break;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
info(...message) {
|
|
58
|
+
this.log("INFO", message);
|
|
59
|
+
}
|
|
60
|
+
warn(...message) {
|
|
61
|
+
this.log("WARN", message);
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
|
|
65
|
+
// src/main.ts
|
|
66
|
+
var SekiroClient = class extends import_partysocket.WebSocket {
|
|
67
|
+
constructor(scope, host = "192.168.2.102", prot = 5612, clientId = (0, import_crypto.randomUUID)().replace(/-/g, "")) {
|
|
68
|
+
super("wss://", [], {
|
|
69
|
+
debug: false,
|
|
70
|
+
maxEnqueuedMessages: -1,
|
|
71
|
+
WebSocket: class extends import_ws.WebSocket {
|
|
72
|
+
constructor() {
|
|
73
|
+
const site = (0, import_util2.format)("ws://%s:%s", host, prot);
|
|
74
|
+
const wsURL = new URL("/business-demo/register", site);
|
|
75
|
+
wsURL.searchParams.append("group", scope);
|
|
76
|
+
wsURL.searchParams.append("clientId", clientId);
|
|
77
|
+
super(wsURL);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
});
|
|
81
|
+
this.scope = scope;
|
|
82
|
+
this.host = host;
|
|
83
|
+
this.prot = prot;
|
|
84
|
+
this.clientId = clientId;
|
|
85
|
+
super.addEventListener("open", this.onOpen.bind(this));
|
|
86
|
+
super.addEventListener("message", this.onData.bind(this));
|
|
87
|
+
super.addEventListener("close", this.onClose.bind(this));
|
|
88
|
+
super.addEventListener("error", this.onError.bind(this));
|
|
89
|
+
}
|
|
90
|
+
logger = new Logger(this);
|
|
91
|
+
async onOpen(event) {
|
|
92
|
+
this.logger.info("Connection established");
|
|
93
|
+
}
|
|
94
|
+
async onClose(event) {
|
|
95
|
+
this.logger.warn("Connection closed");
|
|
96
|
+
}
|
|
97
|
+
async onError(event) {
|
|
98
|
+
this.logger.warn("WebSocket error:", event.message);
|
|
99
|
+
}
|
|
100
|
+
async onData(event) {
|
|
101
|
+
this.logger.info("Received request", event.data);
|
|
102
|
+
const request = JSON.parse(event.data);
|
|
103
|
+
try {
|
|
104
|
+
const data = await this.handlers.get(request.action)?.apply(this, [request]);
|
|
105
|
+
const pack = Result.success(request, data);
|
|
106
|
+
this.send(pack);
|
|
107
|
+
} catch (error) {
|
|
108
|
+
const pack = Result.unknown(request, error.message);
|
|
109
|
+
this.send(pack);
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
};
|
|
113
|
+
|
|
114
|
+
// src/test.ts
|
|
115
|
+
var Test = class extends SekiroClient {
|
|
116
|
+
};
|
|
117
|
+
Test = __decorateClass([
|
|
118
|
+
Fork(2)
|
|
119
|
+
], Test);
|
package/dist/test.d.cts
ADDED
package/dist/test.d.ts
ADDED
package/dist/test.js
ADDED
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import {
|
|
2
|
+
SekiroClient
|
|
3
|
+
} from "./chunk-MDQJHW6K.js";
|
|
4
|
+
import {
|
|
5
|
+
Fork
|
|
6
|
+
} from "./chunk-3KTEWZC4.js";
|
|
7
|
+
import "./chunk-4IXLXWNL.js";
|
|
8
|
+
import "./chunk-JB43IB4T.js";
|
|
9
|
+
import {
|
|
10
|
+
__decorateClass
|
|
11
|
+
} from "./chunk-ADS4GRIL.js";
|
|
12
|
+
|
|
13
|
+
// src/test.ts
|
|
14
|
+
var Test = class extends SekiroClient {
|
|
15
|
+
};
|
|
16
|
+
Test = __decorateClass([
|
|
17
|
+
Fork(2)
|
|
18
|
+
], Test);
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// src/utils/logger.util.ts
|
|
21
|
+
var logger_util_exports = {};
|
|
22
|
+
__export(logger_util_exports, {
|
|
23
|
+
Logger: () => Logger
|
|
24
|
+
});
|
|
25
|
+
module.exports = __toCommonJS(logger_util_exports);
|
|
26
|
+
var import_util = require("util");
|
|
27
|
+
var Logger = class {
|
|
28
|
+
constructor(context) {
|
|
29
|
+
this.context = context;
|
|
30
|
+
}
|
|
31
|
+
log(level, message) {
|
|
32
|
+
const time = (/* @__PURE__ */ new Date()).toLocaleString();
|
|
33
|
+
const base = (0, import_util.format)("[%s] [%s] [%s] [%s]", level, time, this.context.scope, this.context.clientId);
|
|
34
|
+
switch (level) {
|
|
35
|
+
case "INFO":
|
|
36
|
+
console.info(base, ...message);
|
|
37
|
+
break;
|
|
38
|
+
case "WARN":
|
|
39
|
+
console.warn(base, ...message);
|
|
40
|
+
break;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
info(...message) {
|
|
44
|
+
this.log("INFO", message);
|
|
45
|
+
}
|
|
46
|
+
warn(...message) {
|
|
47
|
+
this.log("WARN", message);
|
|
48
|
+
}
|
|
49
|
+
};
|
|
50
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
51
|
+
0 && (module.exports = {
|
|
52
|
+
Logger
|
|
53
|
+
});
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// src/utils/result.util.ts
|
|
21
|
+
var result_util_exports = {};
|
|
22
|
+
__export(result_util_exports, {
|
|
23
|
+
Result: () => Result
|
|
24
|
+
});
|
|
25
|
+
module.exports = __toCommonJS(result_util_exports);
|
|
26
|
+
var Result = class {
|
|
27
|
+
static success({ __sekiro_seq__ }, data) {
|
|
28
|
+
return JSON.stringify({ __sekiro_seq__, data, status: 0 });
|
|
29
|
+
}
|
|
30
|
+
static unknown({ __sekiro_seq__ }, message) {
|
|
31
|
+
return JSON.stringify({ __sekiro_seq__, message, status: -1 });
|
|
32
|
+
}
|
|
33
|
+
};
|
|
34
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
35
|
+
0 && (module.exports = {
|
|
36
|
+
Result
|
|
37
|
+
});
|
package/package.json
CHANGED
|
@@ -1,16 +1,16 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ekhein/sekiro-node-client",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.5",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"license": "MIT",
|
|
6
|
-
"main": "./dist/
|
|
7
|
-
"module": "./dist/
|
|
8
|
-
"types": "./dist/
|
|
6
|
+
"main": "./dist/main.cjs",
|
|
7
|
+
"module": "./dist/main.js",
|
|
8
|
+
"types": "./dist/main.d.ts",
|
|
9
9
|
"files": [
|
|
10
10
|
"dist/**/*"
|
|
11
11
|
],
|
|
12
12
|
"scripts": {
|
|
13
|
-
"build": "tsup src
|
|
13
|
+
"build": "tsup 'src/**/*.ts' --format cjs,esm --dts --clean",
|
|
14
14
|
"watch": "pnpm build --watch src",
|
|
15
15
|
"dev": "tsx example/index.ts"
|
|
16
16
|
},
|