@akanjs/server 0.0.99 → 0.0.100
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/index.js +21 -1
- package/index.mjs +1 -0
- package/package.json +4 -4
- package/src/boot.js +94 -84
- package/src/boot.mjs +190 -0
- package/src/controller.js +63 -70
- package/src/controller.mjs +109 -0
- package/src/gql.js +64 -35
- package/src/gql.mjs +123 -0
- package/src/index.js +39 -10
- package/src/index.mjs +10 -0
- package/src/module.js +103 -77
- package/src/module.mjs +229 -0
- package/src/processor.js +41 -22
- package/src/processor.mjs +73 -0
- package/src/resolver.js +76 -49
- package/src/resolver.mjs +118 -0
- package/src/schema.js +78 -54
- package/src/{schema.cjs → schema.mjs} +54 -78
- package/src/searchDaemon.js +45 -29
- package/src/{searchDaemon.cjs → searchDaemon.mjs} +29 -45
- package/src/types.js +15 -0
- package/src/types.mjs +0 -0
- package/src/websocket.js +55 -33
- package/src/websocket.mjs +124 -0
- package/index.cjs +0 -21
- package/src/boot.cjs +0 -200
- package/src/controller.cjs +0 -102
- package/src/gql.cjs +0 -152
- package/src/index.cjs +0 -39
- package/src/module.cjs +0 -255
- package/src/processor.cjs +0 -92
- package/src/resolver.cjs +0 -145
- package/src/types.cjs +0 -15
- package/src/websocket.cjs +0 -146
package/src/websocket.js
CHANGED
|
@@ -1,5 +1,20 @@
|
|
|
1
1
|
var __defProp = Object.defineProperty;
|
|
2
2
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
+
var __export = (target, all) => {
|
|
6
|
+
for (var name in all)
|
|
7
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
8
|
+
};
|
|
9
|
+
var __copyProps = (to, from, except, desc) => {
|
|
10
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
11
|
+
for (let key of __getOwnPropNames(from))
|
|
12
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
13
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
14
|
+
}
|
|
15
|
+
return to;
|
|
16
|
+
};
|
|
17
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
3
18
|
var __decorateClass = (decorators, target, key, kind) => {
|
|
4
19
|
var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
|
|
5
20
|
for (var i = decorators.length - 1, decorator; i >= 0; i--)
|
|
@@ -9,22 +24,28 @@ var __decorateClass = (decorators, target, key, kind) => {
|
|
|
9
24
|
__defProp(target, key, result);
|
|
10
25
|
return result;
|
|
11
26
|
};
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
27
|
+
var websocket_exports = {};
|
|
28
|
+
__export(websocket_exports, {
|
|
29
|
+
websocketOf: () => websocketOf,
|
|
30
|
+
websocketServerOf: () => websocketServerOf
|
|
31
|
+
});
|
|
32
|
+
module.exports = __toCommonJS(websocket_exports);
|
|
33
|
+
var import_common = require("@akanjs/common");
|
|
34
|
+
var import_nest = require("@akanjs/nest");
|
|
35
|
+
var import_service = require("@akanjs/service");
|
|
36
|
+
var import_signal = require("@akanjs/signal");
|
|
37
|
+
var import_common2 = require("@nestjs/common");
|
|
38
|
+
var import_websockets = require("@nestjs/websockets");
|
|
39
|
+
var import_operators = require("rxjs/operators");
|
|
40
|
+
const internalArgMap = { Account: import_nest.Account, UserIp: import_nest.UserIp, Access: import_nest.Access, Self: import_nest.Self, Me: import_nest.Me, Ws: import_nest.Ws };
|
|
20
41
|
let TransformInterceptor = class {
|
|
21
42
|
intercept(context, next) {
|
|
22
43
|
const [, gqlKey] = [context.getArgByIndex(1), context.getArgByIndex(3)];
|
|
23
|
-
return next.handle().pipe(map((data) => ({ event: gqlKey, data })));
|
|
44
|
+
return next.handle().pipe((0, import_operators.map)((data) => ({ event: gqlKey, data })));
|
|
24
45
|
}
|
|
25
46
|
};
|
|
26
47
|
TransformInterceptor = __decorateClass([
|
|
27
|
-
Injectable()
|
|
48
|
+
(0, import_common2.Injectable)()
|
|
28
49
|
], TransformInterceptor);
|
|
29
50
|
const makeRoomId = (gqlKey, argValues) => `${gqlKey}-${argValues.join("-")}`;
|
|
30
51
|
const getPubsubInterceptor = (argMetas) => {
|
|
@@ -39,75 +60,75 @@ const getPubsubInterceptor = (argMetas) => {
|
|
|
39
60
|
await socket.join(roomId);
|
|
40
61
|
else
|
|
41
62
|
await socket.leave(roomId);
|
|
42
|
-
return next.handle().pipe(map(() => ({ event: gqlKey, data: { roomId, __subscribe__ } })));
|
|
63
|
+
return next.handle().pipe((0, import_operators.map)(() => ({ event: gqlKey, data: { roomId, __subscribe__ } })));
|
|
43
64
|
}
|
|
44
65
|
};
|
|
45
66
|
PubsubInterceptor = __decorateClass([
|
|
46
|
-
Injectable()
|
|
67
|
+
(0, import_common2.Injectable)()
|
|
47
68
|
], PubsubInterceptor);
|
|
48
69
|
return PubsubInterceptor;
|
|
49
70
|
};
|
|
50
71
|
const websocketOf = (sigRef, allSrvs) => {
|
|
51
|
-
const sigMeta = getSigMeta(sigRef);
|
|
72
|
+
const sigMeta = (0, import_signal.getSigMeta)(sigRef);
|
|
52
73
|
class WsGateway {
|
|
53
74
|
__sigRef__ = sigRef;
|
|
54
75
|
}
|
|
55
76
|
Object.keys(allSrvs).forEach((srv) => {
|
|
56
|
-
if (!isServiceEnabled(allSrvs[srv]))
|
|
77
|
+
if (!(0, import_service.isServiceEnabled)(allSrvs[srv]))
|
|
57
78
|
return;
|
|
58
|
-
Inject(allSrvs[srv])(WsGateway.prototype, lowerlize(srv));
|
|
79
|
+
(0, import_common2.Inject)(allSrvs[srv])(WsGateway.prototype, (0, import_common.lowerlize)(srv));
|
|
59
80
|
});
|
|
60
|
-
const messageGqlMetas = getGqlMetas(sigRef).filter((gqlMeta) => gqlMeta.type === "Message");
|
|
81
|
+
const messageGqlMetas = (0, import_signal.getGqlMetas)(sigRef).filter((gqlMeta) => gqlMeta.type === "Message");
|
|
61
82
|
for (const gqlMeta of messageGqlMetas) {
|
|
62
83
|
const descriptor = { ...Object.getOwnPropertyDescriptor(sigRef.prototype, gqlMeta.key) ?? {} };
|
|
63
84
|
Object.defineProperty(WsGateway.prototype, gqlMeta.key, descriptor);
|
|
64
|
-
const [argMetas, internalArgMetas] = getArgMetas(sigRef, gqlMeta.key);
|
|
85
|
+
const [argMetas, internalArgMetas] = (0, import_signal.getArgMetas)(sigRef, gqlMeta.key);
|
|
65
86
|
argMetas.forEach((argMeta) => {
|
|
66
87
|
if (argMeta.type !== "Msg")
|
|
67
88
|
throw new Error(`Argument of Message should be Msg ${sigMeta.refName}-${gqlMeta.key}-${argMeta.name}`);
|
|
68
|
-
MessageBody(argMeta.name, ...getBodyPipes(argMeta))(WsGateway.prototype, gqlMeta.key, argMeta.idx);
|
|
89
|
+
(0, import_websockets.MessageBody)(argMeta.name, ...(0, import_nest.getBodyPipes)(argMeta))(WsGateway.prototype, gqlMeta.key, argMeta.idx);
|
|
69
90
|
});
|
|
70
91
|
internalArgMetas.forEach((internalArgMeta) => {
|
|
71
92
|
const internalDecorator = internalArgMap[internalArgMeta.type];
|
|
72
93
|
internalDecorator(internalArgMeta.option ?? {})(WsGateway.prototype, gqlMeta.key, internalArgMeta.idx);
|
|
73
94
|
});
|
|
74
|
-
UseInterceptors(TransformInterceptor)(WsGateway.prototype, gqlMeta.key, gqlMeta.descriptor);
|
|
75
|
-
SubscribeMessage(gqlMeta.key)(WsGateway.prototype, gqlMeta.key, descriptor);
|
|
95
|
+
(0, import_common2.UseInterceptors)(TransformInterceptor)(WsGateway.prototype, gqlMeta.key, gqlMeta.descriptor);
|
|
96
|
+
(0, import_websockets.SubscribeMessage)(gqlMeta.key)(WsGateway.prototype, gqlMeta.key, descriptor);
|
|
76
97
|
}
|
|
77
|
-
const pubsubGqlMetas = getGqlMetas(sigRef).filter((gqlMeta) => gqlMeta.type === "Pubsub");
|
|
98
|
+
const pubsubGqlMetas = (0, import_signal.getGqlMetas)(sigRef).filter((gqlMeta) => gqlMeta.type === "Pubsub");
|
|
78
99
|
for (const gqlMeta of pubsubGqlMetas) {
|
|
79
100
|
const descriptor = { ...Object.getOwnPropertyDescriptor(sigRef.prototype, gqlMeta.key) ?? {} };
|
|
80
101
|
Object.defineProperty(WsGateway.prototype, gqlMeta.key, descriptor);
|
|
81
|
-
const [argMetas, internalArgMetas] = getArgMetas(sigRef, gqlMeta.key);
|
|
102
|
+
const [argMetas, internalArgMetas] = (0, import_signal.getArgMetas)(sigRef, gqlMeta.key);
|
|
82
103
|
argMetas.forEach((argMeta) => {
|
|
83
104
|
if (argMeta.type !== "Room")
|
|
84
105
|
throw new Error(`Argument of Message should be Room ${sigMeta.refName}-${gqlMeta.key}-${argMeta.name}`);
|
|
85
|
-
MessageBody(argMeta.name, ...getBodyPipes(argMeta))(WsGateway.prototype, gqlMeta.key, argMeta.idx);
|
|
106
|
+
(0, import_websockets.MessageBody)(argMeta.name, ...(0, import_nest.getBodyPipes)(argMeta))(WsGateway.prototype, gqlMeta.key, argMeta.idx);
|
|
86
107
|
});
|
|
87
108
|
internalArgMetas.forEach((internalArgMeta) => {
|
|
88
109
|
const internalDecorator = internalArgMap[internalArgMeta.type];
|
|
89
110
|
internalDecorator(internalArgMeta.option ?? {})(WsGateway.prototype, gqlMeta.key, internalArgMeta.idx);
|
|
90
111
|
});
|
|
91
|
-
UseInterceptors(getPubsubInterceptor(argMetas))(WsGateway.prototype, gqlMeta.key, gqlMeta.descriptor);
|
|
92
|
-
SubscribeMessage(gqlMeta.key)(WsGateway.prototype, gqlMeta.key, descriptor);
|
|
112
|
+
(0, import_common2.UseInterceptors)(getPubsubInterceptor(argMetas))(WsGateway.prototype, gqlMeta.key, gqlMeta.descriptor);
|
|
113
|
+
(0, import_websockets.SubscribeMessage)(gqlMeta.key)(WsGateway.prototype, gqlMeta.key, descriptor);
|
|
93
114
|
}
|
|
94
|
-
WebSocketGateway({ cors: { origin: "*" }, transports: ["websocket"] })(WsGateway);
|
|
115
|
+
(0, import_websockets.WebSocketGateway)({ cors: { origin: "*" }, transports: ["websocket"] })(WsGateway);
|
|
95
116
|
return WsGateway;
|
|
96
117
|
};
|
|
97
118
|
const websocketServerOf = (sigRef) => {
|
|
98
|
-
const pubsubGqlMetas = getGqlMetas(sigRef).filter((gqlMeta) => gqlMeta.type === "Pubsub");
|
|
119
|
+
const pubsubGqlMetas = (0, import_signal.getGqlMetas)(sigRef).filter((gqlMeta) => gqlMeta.type === "Pubsub");
|
|
99
120
|
let Websocket = class {
|
|
100
121
|
server;
|
|
101
122
|
};
|
|
102
123
|
__decorateClass([
|
|
103
|
-
WebSocketServer()
|
|
124
|
+
(0, import_websockets.WebSocketServer)()
|
|
104
125
|
], Websocket.prototype, "server", 2);
|
|
105
126
|
Websocket = __decorateClass([
|
|
106
|
-
Injectable(),
|
|
107
|
-
WebSocketGateway({ cors: { origin: "*" }, transports: ["websocket"] })
|
|
127
|
+
(0, import_common2.Injectable)(),
|
|
128
|
+
(0, import_websockets.WebSocketGateway)({ cors: { origin: "*" }, transports: ["websocket"] })
|
|
108
129
|
], Websocket);
|
|
109
130
|
for (const gqlMeta of pubsubGqlMetas) {
|
|
110
|
-
const [argMetas] = getArgMetas(sigRef, gqlMeta.key);
|
|
131
|
+
const [argMetas] = (0, import_signal.getArgMetas)(sigRef, gqlMeta.key);
|
|
111
132
|
Websocket.prototype[gqlMeta.key] = function(...args) {
|
|
112
133
|
const roomId = makeRoomId(
|
|
113
134
|
gqlMeta.key,
|
|
@@ -118,7 +139,8 @@ const websocketServerOf = (sigRef) => {
|
|
|
118
139
|
}
|
|
119
140
|
return Websocket;
|
|
120
141
|
};
|
|
121
|
-
export
|
|
142
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
143
|
+
0 && (module.exports = {
|
|
122
144
|
websocketOf,
|
|
123
145
|
websocketServerOf
|
|
124
|
-
};
|
|
146
|
+
});
|
|
@@ -0,0 +1,124 @@
|
|
|
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)
|
|
9
|
+
__defProp(target, key, result);
|
|
10
|
+
return result;
|
|
11
|
+
};
|
|
12
|
+
import { lowerlize } from "@akanjs/common";
|
|
13
|
+
import { Access, Account, getBodyPipes, Me, Self, UserIp, Ws } from "@akanjs/nest";
|
|
14
|
+
import { isServiceEnabled } from "@akanjs/service";
|
|
15
|
+
import { getArgMetas, getGqlMetas, getSigMeta } from "@akanjs/signal";
|
|
16
|
+
import { Inject, Injectable, UseInterceptors } from "@nestjs/common";
|
|
17
|
+
import { MessageBody, SubscribeMessage, WebSocketGateway, WebSocketServer } from "@nestjs/websockets";
|
|
18
|
+
import { map } from "rxjs/operators";
|
|
19
|
+
const internalArgMap = { Account, UserIp, Access, Self, Me, Ws };
|
|
20
|
+
let TransformInterceptor = class {
|
|
21
|
+
intercept(context, next) {
|
|
22
|
+
const [, gqlKey] = [context.getArgByIndex(1), context.getArgByIndex(3)];
|
|
23
|
+
return next.handle().pipe(map((data) => ({ event: gqlKey, data })));
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
TransformInterceptor = __decorateClass([
|
|
27
|
+
Injectable()
|
|
28
|
+
], TransformInterceptor);
|
|
29
|
+
const makeRoomId = (gqlKey, argValues) => `${gqlKey}-${argValues.join("-")}`;
|
|
30
|
+
const getPubsubInterceptor = (argMetas) => {
|
|
31
|
+
let PubsubInterceptor = class {
|
|
32
|
+
async intercept(context, next) {
|
|
33
|
+
const [socket, { __subscribe__, ...body }, gqlKey] = [context.getArgByIndex(0), context.getArgByIndex(1), context.getArgByIndex(3)];
|
|
34
|
+
const roomId = makeRoomId(
|
|
35
|
+
gqlKey,
|
|
36
|
+
argMetas.map((argMeta) => body[argMeta.name])
|
|
37
|
+
);
|
|
38
|
+
if (__subscribe__)
|
|
39
|
+
await socket.join(roomId);
|
|
40
|
+
else
|
|
41
|
+
await socket.leave(roomId);
|
|
42
|
+
return next.handle().pipe(map(() => ({ event: gqlKey, data: { roomId, __subscribe__ } })));
|
|
43
|
+
}
|
|
44
|
+
};
|
|
45
|
+
PubsubInterceptor = __decorateClass([
|
|
46
|
+
Injectable()
|
|
47
|
+
], PubsubInterceptor);
|
|
48
|
+
return PubsubInterceptor;
|
|
49
|
+
};
|
|
50
|
+
const websocketOf = (sigRef, allSrvs) => {
|
|
51
|
+
const sigMeta = getSigMeta(sigRef);
|
|
52
|
+
class WsGateway {
|
|
53
|
+
__sigRef__ = sigRef;
|
|
54
|
+
}
|
|
55
|
+
Object.keys(allSrvs).forEach((srv) => {
|
|
56
|
+
if (!isServiceEnabled(allSrvs[srv]))
|
|
57
|
+
return;
|
|
58
|
+
Inject(allSrvs[srv])(WsGateway.prototype, lowerlize(srv));
|
|
59
|
+
});
|
|
60
|
+
const messageGqlMetas = getGqlMetas(sigRef).filter((gqlMeta) => gqlMeta.type === "Message");
|
|
61
|
+
for (const gqlMeta of messageGqlMetas) {
|
|
62
|
+
const descriptor = { ...Object.getOwnPropertyDescriptor(sigRef.prototype, gqlMeta.key) ?? {} };
|
|
63
|
+
Object.defineProperty(WsGateway.prototype, gqlMeta.key, descriptor);
|
|
64
|
+
const [argMetas, internalArgMetas] = getArgMetas(sigRef, gqlMeta.key);
|
|
65
|
+
argMetas.forEach((argMeta) => {
|
|
66
|
+
if (argMeta.type !== "Msg")
|
|
67
|
+
throw new Error(`Argument of Message should be Msg ${sigMeta.refName}-${gqlMeta.key}-${argMeta.name}`);
|
|
68
|
+
MessageBody(argMeta.name, ...getBodyPipes(argMeta))(WsGateway.prototype, gqlMeta.key, argMeta.idx);
|
|
69
|
+
});
|
|
70
|
+
internalArgMetas.forEach((internalArgMeta) => {
|
|
71
|
+
const internalDecorator = internalArgMap[internalArgMeta.type];
|
|
72
|
+
internalDecorator(internalArgMeta.option ?? {})(WsGateway.prototype, gqlMeta.key, internalArgMeta.idx);
|
|
73
|
+
});
|
|
74
|
+
UseInterceptors(TransformInterceptor)(WsGateway.prototype, gqlMeta.key, gqlMeta.descriptor);
|
|
75
|
+
SubscribeMessage(gqlMeta.key)(WsGateway.prototype, gqlMeta.key, descriptor);
|
|
76
|
+
}
|
|
77
|
+
const pubsubGqlMetas = getGqlMetas(sigRef).filter((gqlMeta) => gqlMeta.type === "Pubsub");
|
|
78
|
+
for (const gqlMeta of pubsubGqlMetas) {
|
|
79
|
+
const descriptor = { ...Object.getOwnPropertyDescriptor(sigRef.prototype, gqlMeta.key) ?? {} };
|
|
80
|
+
Object.defineProperty(WsGateway.prototype, gqlMeta.key, descriptor);
|
|
81
|
+
const [argMetas, internalArgMetas] = getArgMetas(sigRef, gqlMeta.key);
|
|
82
|
+
argMetas.forEach((argMeta) => {
|
|
83
|
+
if (argMeta.type !== "Room")
|
|
84
|
+
throw new Error(`Argument of Message should be Room ${sigMeta.refName}-${gqlMeta.key}-${argMeta.name}`);
|
|
85
|
+
MessageBody(argMeta.name, ...getBodyPipes(argMeta))(WsGateway.prototype, gqlMeta.key, argMeta.idx);
|
|
86
|
+
});
|
|
87
|
+
internalArgMetas.forEach((internalArgMeta) => {
|
|
88
|
+
const internalDecorator = internalArgMap[internalArgMeta.type];
|
|
89
|
+
internalDecorator(internalArgMeta.option ?? {})(WsGateway.prototype, gqlMeta.key, internalArgMeta.idx);
|
|
90
|
+
});
|
|
91
|
+
UseInterceptors(getPubsubInterceptor(argMetas))(WsGateway.prototype, gqlMeta.key, gqlMeta.descriptor);
|
|
92
|
+
SubscribeMessage(gqlMeta.key)(WsGateway.prototype, gqlMeta.key, descriptor);
|
|
93
|
+
}
|
|
94
|
+
WebSocketGateway({ cors: { origin: "*" }, transports: ["websocket"] })(WsGateway);
|
|
95
|
+
return WsGateway;
|
|
96
|
+
};
|
|
97
|
+
const websocketServerOf = (sigRef) => {
|
|
98
|
+
const pubsubGqlMetas = getGqlMetas(sigRef).filter((gqlMeta) => gqlMeta.type === "Pubsub");
|
|
99
|
+
let Websocket = class {
|
|
100
|
+
server;
|
|
101
|
+
};
|
|
102
|
+
__decorateClass([
|
|
103
|
+
WebSocketServer()
|
|
104
|
+
], Websocket.prototype, "server", 2);
|
|
105
|
+
Websocket = __decorateClass([
|
|
106
|
+
Injectable(),
|
|
107
|
+
WebSocketGateway({ cors: { origin: "*" }, transports: ["websocket"] })
|
|
108
|
+
], Websocket);
|
|
109
|
+
for (const gqlMeta of pubsubGqlMetas) {
|
|
110
|
+
const [argMetas] = getArgMetas(sigRef, gqlMeta.key);
|
|
111
|
+
Websocket.prototype[gqlMeta.key] = function(...args) {
|
|
112
|
+
const roomId = makeRoomId(
|
|
113
|
+
gqlMeta.key,
|
|
114
|
+
argMetas.map((argMeta) => args[argMeta.idx])
|
|
115
|
+
);
|
|
116
|
+
this.server.to(roomId).emit(roomId, args.at(-1));
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
return Websocket;
|
|
120
|
+
};
|
|
121
|
+
export {
|
|
122
|
+
websocketOf,
|
|
123
|
+
websocketServerOf
|
|
124
|
+
};
|
package/index.cjs
DELETED
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
var __defProp = Object.defineProperty;
|
|
2
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
-
var __copyProps = (to, from, except, desc) => {
|
|
6
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
7
|
-
for (let key of __getOwnPropNames(from))
|
|
8
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
9
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
10
|
-
}
|
|
11
|
-
return to;
|
|
12
|
-
};
|
|
13
|
-
var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
|
|
14
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
15
|
-
var server_exports = {};
|
|
16
|
-
module.exports = __toCommonJS(server_exports);
|
|
17
|
-
__reExport(server_exports, require("./src"), module.exports);
|
|
18
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
19
|
-
0 && (module.exports = {
|
|
20
|
-
...require("./src")
|
|
21
|
-
});
|
package/src/boot.cjs
DELETED
|
@@ -1,200 +0,0 @@
|
|
|
1
|
-
var __create = Object.create;
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
6
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
-
var __export = (target, all) => {
|
|
8
|
-
for (var name in all)
|
|
9
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
-
};
|
|
11
|
-
var __copyProps = (to, from, except, desc) => {
|
|
12
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
-
for (let key of __getOwnPropNames(from))
|
|
14
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
16
|
-
}
|
|
17
|
-
return to;
|
|
18
|
-
};
|
|
19
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
20
|
-
// If the importer is in node compatibility mode or this is not an ESM
|
|
21
|
-
// file that has been converted to a CommonJS file using a Babel-
|
|
22
|
-
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
23
|
-
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
24
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
25
|
-
mod
|
|
26
|
-
));
|
|
27
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
28
|
-
var __decorateClass = (decorators, target, key, kind) => {
|
|
29
|
-
var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
|
|
30
|
-
for (var i = decorators.length - 1, decorator; i >= 0; i--)
|
|
31
|
-
if (decorator = decorators[i])
|
|
32
|
-
result = (kind ? decorator(target, key, result) : decorator(result)) || result;
|
|
33
|
-
if (kind && result)
|
|
34
|
-
__defProp(target, key, result);
|
|
35
|
-
return result;
|
|
36
|
-
};
|
|
37
|
-
var boot_exports = {};
|
|
38
|
-
__export(boot_exports, {
|
|
39
|
-
createNestApp: () => createNestApp
|
|
40
|
-
});
|
|
41
|
-
module.exports = __toCommonJS(boot_exports);
|
|
42
|
-
var import_base = require("@akanjs/base");
|
|
43
|
-
var import_common = require("@akanjs/common");
|
|
44
|
-
var import_nest = require("@akanjs/nest");
|
|
45
|
-
var import_signal = require("@akanjs/signal");
|
|
46
|
-
var import_apollo = require("@nestjs/apollo");
|
|
47
|
-
var import_bull = require("@nestjs/bull");
|
|
48
|
-
var import_common2 = require("@nestjs/common");
|
|
49
|
-
var import_core = require("@nestjs/core");
|
|
50
|
-
var import_graphql = require("@nestjs/graphql");
|
|
51
|
-
var import_mongoose = require("@nestjs/mongoose");
|
|
52
|
-
var import_schedule = require("@nestjs/schedule");
|
|
53
|
-
var import_body_parser = require("body-parser");
|
|
54
|
-
var import_cookie_parser = __toESM(require("cookie-parser"), 1);
|
|
55
|
-
var import_dgram = __toESM(require("dgram"), 1);
|
|
56
|
-
var import_events = __toESM(require("events"), 1);
|
|
57
|
-
var import_graphql_upload = require("graphql-upload");
|
|
58
|
-
var import_meilisearch = require("meilisearch");
|
|
59
|
-
var import_redis = require("redis");
|
|
60
|
-
var import_gql = require("./gql");
|
|
61
|
-
var import_module = require("./module");
|
|
62
|
-
var import_searchDaemon = require("./searchDaemon");
|
|
63
|
-
const createNestApp = async ({ registerModules, serverMode = "federation", env, log = true }) => {
|
|
64
|
-
const backendLogger = new import_common.Logger("Backend");
|
|
65
|
-
if (log)
|
|
66
|
-
backendLogger.rawLog(import_base.logo);
|
|
67
|
-
const jwtSecret = (0, import_nest.generateJwtSecret)(env.appName, env.environment);
|
|
68
|
-
const [redisUri, mongoUri, meiliUri] = await Promise.all([
|
|
69
|
-
env.redisUri ?? (0, import_nest.generateRedisUri)({ ...env, ...env.redis?.sshOptions ? { sshOptions: env.redis.sshOptions } : {} }),
|
|
70
|
-
env.mongoUri ?? (0, import_nest.generateMongoUri)({
|
|
71
|
-
...env,
|
|
72
|
-
...env.mongo.username ? { username: env.mongo.username } : {},
|
|
73
|
-
password: env.mongo.password,
|
|
74
|
-
...env.mongo.sshOptions ? { sshOptions: env.mongo.sshOptions } : {}
|
|
75
|
-
}),
|
|
76
|
-
env.meiliUri ?? (0, import_nest.generateMeiliUri)(env)
|
|
77
|
-
]);
|
|
78
|
-
if (env.operationMode === "local") {
|
|
79
|
-
backendLogger.verbose(`connect to redis: ${redisUri}`);
|
|
80
|
-
backendLogger.verbose(`connect to mongo: ${mongoUri}`);
|
|
81
|
-
backendLogger.verbose(`connect to meili: ${meiliUri}`);
|
|
82
|
-
}
|
|
83
|
-
(0, import_nest.initMongoDB)({ logging: import_base.baseEnv.environment !== "main", sendReport: false });
|
|
84
|
-
import_events.default.EventEmitter.defaultMaxListeners = 1e3;
|
|
85
|
-
let AuthMiddleWare = class {
|
|
86
|
-
use(req, res, next) {
|
|
87
|
-
const requestHeader = req;
|
|
88
|
-
requestHeader.account = (0, import_nest.verifyToken)(
|
|
89
|
-
jwtSecret,
|
|
90
|
-
requestHeader.headers.authorization ?? (requestHeader.cookies?.jwt ? `Bearer ${requestHeader.cookies.jwt}` : void 0)
|
|
91
|
-
);
|
|
92
|
-
requestHeader.userAgent = requestHeader["user-agent"];
|
|
93
|
-
next();
|
|
94
|
-
}
|
|
95
|
-
};
|
|
96
|
-
AuthMiddleWare = __decorateClass([
|
|
97
|
-
(0, import_common2.Injectable)()
|
|
98
|
-
], AuthMiddleWare);
|
|
99
|
-
const redisClient = await (0, import_redis.createClient)({ url: redisUri }).connect();
|
|
100
|
-
let SubDatabaseModule = class {
|
|
101
|
-
};
|
|
102
|
-
SubDatabaseModule = __decorateClass([
|
|
103
|
-
(0, import_common2.Global)(),
|
|
104
|
-
(0, import_common2.Module)({
|
|
105
|
-
providers: [
|
|
106
|
-
{ provide: "REDIS_CLIENT", useValue: redisClient },
|
|
107
|
-
{
|
|
108
|
-
provide: "MEILI_CLIENT",
|
|
109
|
-
useFactory: () => new import_meilisearch.MeiliSearch({ host: meiliUri, apiKey: (0, import_nest.generateMeiliKey)(env) })
|
|
110
|
-
}
|
|
111
|
-
],
|
|
112
|
-
exports: ["REDIS_CLIENT", "MEILI_CLIENT"]
|
|
113
|
-
})
|
|
114
|
-
], SubDatabaseModule);
|
|
115
|
-
let AppModule = class {
|
|
116
|
-
configure(consumer) {
|
|
117
|
-
consumer.apply(AuthMiddleWare).forRoutes({ path: "*", method: import_common2.RequestMethod.ALL });
|
|
118
|
-
}
|
|
119
|
-
};
|
|
120
|
-
AppModule = __decorateClass([
|
|
121
|
-
(0, import_common2.Module)({
|
|
122
|
-
imports: [
|
|
123
|
-
import_bull.BullModule.forRoot({ redis: redisUri }),
|
|
124
|
-
import_schedule.ScheduleModule.forRoot(),
|
|
125
|
-
import_graphql.GraphQLModule.forRootAsync({
|
|
126
|
-
imports: [],
|
|
127
|
-
useFactory: () => ({
|
|
128
|
-
useGlobalPrefix: true,
|
|
129
|
-
autoSchemaFile: true,
|
|
130
|
-
sortSchema: true,
|
|
131
|
-
playground: import_base.baseEnv.environment !== "main",
|
|
132
|
-
introspection: import_base.baseEnv.environment !== "main",
|
|
133
|
-
uploads: false,
|
|
134
|
-
debug: false
|
|
135
|
-
}),
|
|
136
|
-
driver: import_apollo.ApolloDriver
|
|
137
|
-
}),
|
|
138
|
-
import_mongoose.MongooseModule.forRootAsync({
|
|
139
|
-
useFactory: () => ({ uri: mongoUri, autoIndex: import_base.baseEnv.environment !== "main" })
|
|
140
|
-
}),
|
|
141
|
-
SubDatabaseModule,
|
|
142
|
-
(0, import_module.useGlobals)({
|
|
143
|
-
injects: { SearchClient: import_nest.SearchClient, DatabaseClient: import_nest.DatabaseClient, CacheClient: import_nest.CacheClient }
|
|
144
|
-
}),
|
|
145
|
-
...["batch", "all"].includes(serverMode) && import_base.baseEnv.operationMode !== "edge" ? [import_searchDaemon.SearchDaemonModule] : [],
|
|
146
|
-
...registerModules(env).filter((m) => !!m)
|
|
147
|
-
],
|
|
148
|
-
providers: [import_gql.DateScalar]
|
|
149
|
-
})
|
|
150
|
-
], AppModule);
|
|
151
|
-
const app = await import_core.NestFactory.create(AppModule, { logger: backendLogger });
|
|
152
|
-
const redisIoAdapter = new import_nest.RedisIoAdapter(app, { jwtSecret });
|
|
153
|
-
await redisIoAdapter.connectToRedis(redisUri);
|
|
154
|
-
app.enableShutdownHooks();
|
|
155
|
-
const udp = import_dgram.default.createSocket("udp4");
|
|
156
|
-
import_signal.client.setUdp(udp);
|
|
157
|
-
if (["federation", "all"].includes(serverMode)) {
|
|
158
|
-
app.setGlobalPrefix(process.env.GLOBAL_PREFIX ?? "/backend");
|
|
159
|
-
app.enableCors({
|
|
160
|
-
origin: "*",
|
|
161
|
-
methods: "GET,HEAD,PUT,PATCH,POST,DELETE",
|
|
162
|
-
preflightContinue: false,
|
|
163
|
-
optionsSuccessStatus: 204,
|
|
164
|
-
allowedHeaders: "DNT,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range,Authorization,apollo-require-preflight"
|
|
165
|
-
});
|
|
166
|
-
if (env.operationMode !== "local" && process.env.USE_REDIS_IO_ADAPTER !== "false")
|
|
167
|
-
app.useWebSocketAdapter(redisIoAdapter);
|
|
168
|
-
app.use((0, import_body_parser.json)({ limit: "100mb" }));
|
|
169
|
-
app.use((0, import_body_parser.urlencoded)({ limit: "100mb", extended: true }));
|
|
170
|
-
app.use("/backend/graphql", (0, import_graphql_upload.graphqlUploadExpress)());
|
|
171
|
-
app.use((0, import_cookie_parser.default)());
|
|
172
|
-
app.useGlobalInterceptors(new import_nest.LoggingInterceptor());
|
|
173
|
-
app.useGlobalInterceptors(new import_nest.TimeoutInterceptor());
|
|
174
|
-
app.useGlobalInterceptors(new import_nest.CacheInterceptor(redisClient));
|
|
175
|
-
app.useGlobalFilters(new import_nest.AllExceptionsFilter());
|
|
176
|
-
await app.listen(process.env.PORT ?? env.port ?? 8080);
|
|
177
|
-
backendLogger.log(`\u{1F680} Server is running on: ${await app.getUrl()}`);
|
|
178
|
-
} else {
|
|
179
|
-
await app.init();
|
|
180
|
-
backendLogger.log(`\u{1F680} Batch Server is running`);
|
|
181
|
-
}
|
|
182
|
-
if (module.hot) {
|
|
183
|
-
module.hot.accept();
|
|
184
|
-
module.hot.dispose(() => {
|
|
185
|
-
void app.close();
|
|
186
|
-
});
|
|
187
|
-
}
|
|
188
|
-
return {
|
|
189
|
-
nestApp: app,
|
|
190
|
-
close: async () => {
|
|
191
|
-
await app.close();
|
|
192
|
-
await redisIoAdapter.destroy();
|
|
193
|
-
await redisClient.quit();
|
|
194
|
-
}
|
|
195
|
-
};
|
|
196
|
-
};
|
|
197
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
198
|
-
0 && (module.exports = {
|
|
199
|
-
createNestApp
|
|
200
|
-
});
|
package/src/controller.cjs
DELETED
|
@@ -1,102 +0,0 @@
|
|
|
1
|
-
var __defProp = Object.defineProperty;
|
|
2
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
-
var __export = (target, all) => {
|
|
6
|
-
for (var name in all)
|
|
7
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
8
|
-
};
|
|
9
|
-
var __copyProps = (to, from, except, desc) => {
|
|
10
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
11
|
-
for (let key of __getOwnPropNames(from))
|
|
12
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
13
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
14
|
-
}
|
|
15
|
-
return to;
|
|
16
|
-
};
|
|
17
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
18
|
-
var controller_exports = {};
|
|
19
|
-
__export(controller_exports, {
|
|
20
|
-
controllerOf: () => controllerOf
|
|
21
|
-
});
|
|
22
|
-
module.exports = __toCommonJS(controller_exports);
|
|
23
|
-
var import_base = require("@akanjs/base");
|
|
24
|
-
var import_common = require("@akanjs/common");
|
|
25
|
-
var import_nest = require("@akanjs/nest");
|
|
26
|
-
var import_service = require("@akanjs/service");
|
|
27
|
-
var import_signal = require("@akanjs/signal");
|
|
28
|
-
var import_common2 = require("@nestjs/common");
|
|
29
|
-
var import_passport = require("@nestjs/passport");
|
|
30
|
-
var import_platform_express = require("@nestjs/platform-express");
|
|
31
|
-
const internalArgMap = {
|
|
32
|
-
// Parent: Nest.Parent,
|
|
33
|
-
Account: import_nest.Account,
|
|
34
|
-
UserIp: import_nest.UserIp,
|
|
35
|
-
Access: import_nest.Access,
|
|
36
|
-
Self: import_nest.Self,
|
|
37
|
-
Me: import_nest.Me,
|
|
38
|
-
Req: import_nest.Req,
|
|
39
|
-
Res: import_nest.Res
|
|
40
|
-
};
|
|
41
|
-
const controllerOf = (sigRef, allSrvs) => {
|
|
42
|
-
const sigMeta = (0, import_signal.getSigMeta)(sigRef);
|
|
43
|
-
const gqlMetas = (0, import_signal.getGqlMetas)(sigRef);
|
|
44
|
-
const prefix = (0, import_signal.getControllerPrefix)(sigMeta);
|
|
45
|
-
const Ctrl = (0, import_signal.copySignal)(sigRef);
|
|
46
|
-
Object.keys(allSrvs).forEach((srv) => {
|
|
47
|
-
if (!(0, import_service.isServiceEnabled)(allSrvs[srv]))
|
|
48
|
-
return;
|
|
49
|
-
(0, import_common2.Inject)(allSrvs[srv])(Ctrl.prototype, (0, import_common.lowerlize)(srv));
|
|
50
|
-
});
|
|
51
|
-
for (const gqlMeta of gqlMetas) {
|
|
52
|
-
if (gqlMeta.guards.some((guard) => guard === "None") || gqlMeta.signalOption.onlyFor === "graphql" || !["Query", "Mutation"].includes(gqlMeta.type))
|
|
53
|
-
continue;
|
|
54
|
-
const [argMetas, internalArgMetas] = (0, import_signal.getArgMetas)(Ctrl, gqlMeta.key);
|
|
55
|
-
internalArgMetas.forEach((internalArgMeta) => {
|
|
56
|
-
const internalDecorator = internalArgMap[internalArgMeta.type];
|
|
57
|
-
internalDecorator(internalArgMeta.option ?? {})(Ctrl.prototype, gqlMeta.key, internalArgMeta.idx);
|
|
58
|
-
});
|
|
59
|
-
const uploadArgMeta = argMetas.find((argMeta) => argMeta.type === "Upload");
|
|
60
|
-
if (uploadArgMeta && gqlMeta.signalOption.onlyFor === "restapi") {
|
|
61
|
-
const [modelRef, arrDepth] = (0, import_base.getNonArrayModel)(uploadArgMeta.returns());
|
|
62
|
-
if (modelRef.prototype !== import_base.Upload.prototype)
|
|
63
|
-
throw new Error("Upload must be Upload");
|
|
64
|
-
else if (!arrDepth)
|
|
65
|
-
throw new Error(`Only Array of Upload is allowed - ${sigMeta.refName}/${gqlMeta.key}`);
|
|
66
|
-
(0, import_common2.UseInterceptors)((0, import_platform_express.FilesInterceptor)(uploadArgMeta.name))(Ctrl.prototype, gqlMeta.key, gqlMeta.descriptor);
|
|
67
|
-
(0, import_common2.UploadedFiles)(import_nest.MulterToUploadPipe)(Ctrl.prototype, gqlMeta.key, uploadArgMeta.idx);
|
|
68
|
-
}
|
|
69
|
-
const queryArgMetas = argMetas.filter((argMeta) => argMeta.type === "Query");
|
|
70
|
-
queryArgMetas.forEach((argMeta) => {
|
|
71
|
-
const [modelRef, arrDepth] = (0, import_base.getNonArrayModel)(argMeta.returns());
|
|
72
|
-
(0, import_common2.Query)(argMeta.name, ...(0, import_nest.getQueryPipes)(modelRef, arrDepth))(Ctrl.prototype, gqlMeta.key, argMeta.idx);
|
|
73
|
-
});
|
|
74
|
-
const paramArgMetas = argMetas.filter((argMeta) => argMeta.type === "Param");
|
|
75
|
-
paramArgMetas.forEach((argMeta) => {
|
|
76
|
-
(0, import_common2.Param)(argMeta.name)(Ctrl.prototype, gqlMeta.key, argMeta.idx);
|
|
77
|
-
});
|
|
78
|
-
const path = (0, import_signal.getControllerPath)(gqlMeta, paramArgMetas);
|
|
79
|
-
const bodyArgMetas = argMetas.filter((argMeta) => argMeta.type === "Body");
|
|
80
|
-
if (bodyArgMetas.length)
|
|
81
|
-
bodyArgMetas.forEach((argMeta) => {
|
|
82
|
-
(0, import_common2.Body)(argMeta.name, ...(0, import_nest.getBodyPipes)(argMeta))(Ctrl.prototype, gqlMeta.key, argMeta.idx);
|
|
83
|
-
});
|
|
84
|
-
(0, import_common2.UseGuards)(
|
|
85
|
-
...gqlMeta.guards.map((guard) => import_nest.guards[guard]),
|
|
86
|
-
...gqlMeta.signalOption.sso ? [(0, import_passport.AuthGuard)(gqlMeta.signalOption.sso)] : []
|
|
87
|
-
)(Ctrl.prototype, gqlMeta.key, gqlMeta.descriptor);
|
|
88
|
-
if (gqlMeta.type === "Query")
|
|
89
|
-
(0, import_common2.Get)(path)(Ctrl.prototype, gqlMeta.key, gqlMeta.descriptor);
|
|
90
|
-
else if (gqlMeta.type === "Mutation")
|
|
91
|
-
(0, import_common2.Post)(path)(Ctrl.prototype, gqlMeta.key, gqlMeta.descriptor);
|
|
92
|
-
}
|
|
93
|
-
if (prefix)
|
|
94
|
-
(0, import_common2.Controller)(prefix)(Ctrl);
|
|
95
|
-
else
|
|
96
|
-
(0, import_common2.Controller)()(Ctrl);
|
|
97
|
-
return Ctrl;
|
|
98
|
-
};
|
|
99
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
100
|
-
0 && (module.exports = {
|
|
101
|
-
controllerOf
|
|
102
|
-
});
|