@akanjs/server 0.0.4

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/README.md ADDED
@@ -0,0 +1,11 @@
1
+ # akan
2
+
3
+ This library was generated with [Nx](https://nx.dev).
4
+
5
+ ## Building
6
+
7
+ Run `nx build akan` to build the library.
8
+
9
+ ## Running unit tests
10
+
11
+ Run `nx test akan` to execute the unit tests via [Jest](https://jestjs.io).
package/index.d.ts ADDED
@@ -0,0 +1 @@
1
+ export * from "./src";
package/index.js ADDED
@@ -0,0 +1,21 @@
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/package.json ADDED
@@ -0,0 +1,68 @@
1
+ {
2
+ "name": "@akanjs/server",
3
+ "version": "0.0.4",
4
+ "type": "commonjs",
5
+ "publishConfig": {
6
+ "access": "public"
7
+ },
8
+ "repository": {
9
+ "type": "git",
10
+ "url": "https://github.com/akan-team/akanjs.git",
11
+ "directory": "pkgs/@akanjs/server"
12
+ },
13
+ "dependencies": {
14
+ "@apollo/server": "4.11.2",
15
+ "@inquirer/prompts": "7.2.1",
16
+ "@nestjs/apollo": "12.2.2",
17
+ "@nestjs/bull": "10.2.3",
18
+ "@nestjs/common": "10.4.15",
19
+ "@nestjs/core": "10.4.15",
20
+ "@nestjs/graphql": "12.2.2",
21
+ "@nestjs/mongoose": "10.1.0",
22
+ "@nestjs/passport": "10.0.3",
23
+ "@nestjs/platform-express": "10.4.15",
24
+ "@nestjs/platform-socket.io": "10.4.15",
25
+ "@nestjs/schedule": "4.1.2",
26
+ "@nestjs/websockets": "10.4.15",
27
+ "@socket.io/redis-adapter": "8.3.0",
28
+ "@urql/core": "5.1.0",
29
+ "apple-signin": "1.0.9",
30
+ "body-parser": "1.20.3",
31
+ "bull": "4.16.5",
32
+ "class-transformer": "0.5.1",
33
+ "class-validator": "0.14.1",
34
+ "cookie-parser": "1.4.7",
35
+ "dataloader": "2.2.3",
36
+ "dayjs": "1.11.13",
37
+ "express": "4.21.2",
38
+ "graphql": "16.10.0",
39
+ "graphql-type-json": "0.3.2",
40
+ "graphql-upload": "12.0.0",
41
+ "iap": "1.1.1",
42
+ "immer": "10.1.1",
43
+ "jsonwebtoken": "9.0.2",
44
+ "lodash": "4.17.21",
45
+ "meilisearch": "0.47.0",
46
+ "mongoose": "8.9.3",
47
+ "next": "15.1.3",
48
+ "passport": "0.7.0",
49
+ "passport-apple": "2.0.2",
50
+ "passport-facebook": "3.0.0",
51
+ "passport-github": "1.1.0",
52
+ "passport-google-oauth20": "2.0.0",
53
+ "passport-kakao": "1.0.1",
54
+ "passport-naver": "1.0.6",
55
+ "picocolors": "1.1.1",
56
+ "pluralize": "8.0.0",
57
+ "react": "18.2.0",
58
+ "react-dom": "18.2.0",
59
+ "redis": "4.7.0",
60
+ "reflect-metadata": "0.2.2",
61
+ "rxjs": "7.8.1",
62
+ "socket.io": "4.8.1",
63
+ "socket.io-client": "4.8.1",
64
+ "tunnel-ssh": "5.2.0",
65
+ "ua-parser-js": "1.0.40"
66
+ },
67
+ "main": "./index.js"
68
+ }
package/src/boot.d.ts ADDED
@@ -0,0 +1,18 @@
1
+ import { BackendEnv } from "@akanjs/base";
2
+ import { DynamicModule, INestApplication } from "@nestjs/common";
3
+ interface AppCreateForm {
4
+ registerModules: (options: any) => DynamicModule[];
5
+ registerBatches?: (options: any) => DynamicModule[];
6
+ serverMode?: "federation" | "batch" | "all" | "none";
7
+ env: BackendEnv;
8
+ log?: boolean;
9
+ }
10
+ export interface BackendApp {
11
+ nestApp: INestApplication;
12
+ close: () => Promise<void>;
13
+ }
14
+ export declare const createNestApp: ({ registerModules, registerBatches, serverMode, env, log, }: AppCreateForm) => Promise<{
15
+ nestApp: INestApplication<any>;
16
+ close: () => Promise<void>;
17
+ }>;
18
+ export {};
package/src/boot.js ADDED
@@ -0,0 +1,200 @@
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_apollo = require("@nestjs/apollo");
46
+ var import_bull = require("@nestjs/bull");
47
+ var import_common2 = require("@nestjs/common");
48
+ var import_core = require("@nestjs/core");
49
+ var import_graphql = require("@nestjs/graphql");
50
+ var import_mongoose = require("@nestjs/mongoose");
51
+ var import_schedule = require("@nestjs/schedule");
52
+ var import_body_parser = require("body-parser");
53
+ var import_cookie_parser = __toESM(require("cookie-parser"));
54
+ var import_events = __toESM(require("events"));
55
+ var import_graphql_upload = require("graphql-upload");
56
+ var import_meilisearch = require("meilisearch");
57
+ var import_path = require("path");
58
+ var import_redis = require("redis");
59
+ var import_gql = require("./gql");
60
+ var import_searchDaemon = require("./searchDaemon");
61
+ const createNestApp = async ({
62
+ registerModules,
63
+ registerBatches,
64
+ serverMode = "federation",
65
+ env,
66
+ log = true
67
+ }) => {
68
+ const backendLogger = new import_common.Logger("Backend");
69
+ if (log)
70
+ backendLogger.rawLog(import_base.logo);
71
+ const jwtSecret = (0, import_nest.generateJwtSecret)(env.appName, env.environment);
72
+ const [redisUri, mongoUri, meiliUri] = await Promise.all([
73
+ env.redisUri ?? (0, import_nest.generateRedisUri)({ ...env, ...env.redis?.sshOptions ? { sshOptions: env.redis.sshOptions } : {} }),
74
+ env.mongoUri ?? (0, import_nest.generateMongoUri)({
75
+ ...env,
76
+ ...env.mongo.username ? { username: env.mongo.username } : {},
77
+ password: env.mongo.password,
78
+ ...env.mongo.sshOptions ? { sshOptions: env.mongo.sshOptions } : {}
79
+ }),
80
+ env.meiliUri ?? (0, import_nest.generateMeiliUri)(env)
81
+ ]);
82
+ if (env.operationMode === "local") {
83
+ backendLogger.verbose(`connect to redis: ${redisUri}`);
84
+ backendLogger.verbose(`connect to mongo: ${mongoUri}`);
85
+ backendLogger.verbose(`connect to meili: ${meiliUri}`);
86
+ }
87
+ (0, import_nest.initMongoDB)({ logging: import_base.baseEnv.environment !== "main", sendReport: false });
88
+ import_events.default.EventEmitter.defaultMaxListeners = 1e3;
89
+ let AuthMiddleWare = class {
90
+ use(req, res, next) {
91
+ const requestHeader = req;
92
+ requestHeader.account = (0, import_nest.verifyToken)(
93
+ jwtSecret,
94
+ requestHeader.headers.authorization ?? (requestHeader.cookies?.jwt ? `Bearer ${requestHeader.cookies.jwt}` : void 0)
95
+ );
96
+ requestHeader.userAgent = requestHeader["user-agent"];
97
+ next();
98
+ }
99
+ };
100
+ AuthMiddleWare = __decorateClass([
101
+ (0, import_common2.Injectable)()
102
+ ], AuthMiddleWare);
103
+ const redisClient = (0, import_redis.createClient)({ url: redisUri });
104
+ let SubDatabaseModule = class {
105
+ };
106
+ SubDatabaseModule = __decorateClass([
107
+ (0, import_common2.Global)(),
108
+ (0, import_common2.Module)({
109
+ providers: [
110
+ { provide: "REDIS_CLIENT", useFactory: async () => await redisClient.connect() },
111
+ {
112
+ provide: "MEILI_CLIENT",
113
+ useFactory: () => new import_meilisearch.MeiliSearch({ host: meiliUri, apiKey: (0, import_nest.generateMeiliKey)(env) })
114
+ },
115
+ { provide: import_core.APP_INTERCEPTOR, useClass: import_nest.CacheInterceptor }
116
+ ],
117
+ exports: ["REDIS_CLIENT", "MEILI_CLIENT"]
118
+ })
119
+ ], SubDatabaseModule);
120
+ let AppModule = class {
121
+ configure(consumer) {
122
+ consumer.apply(AuthMiddleWare).forRoutes({ path: "*", method: import_common2.RequestMethod.ALL });
123
+ }
124
+ };
125
+ AppModule = __decorateClass([
126
+ (0, import_common2.Module)({
127
+ imports: [
128
+ import_bull.BullModule.forRoot({ redis: redisUri }),
129
+ import_schedule.ScheduleModule.forRoot(),
130
+ import_graphql.GraphQLModule.forRootAsync({
131
+ imports: [],
132
+ useFactory: () => ({
133
+ useGlobalPrefix: true,
134
+ autoSchemaFile: (0, import_path.join)(process.cwd(), "src/schema.gql"),
135
+ sortSchema: true,
136
+ playground: import_base.baseEnv.environment !== "main",
137
+ introspection: import_base.baseEnv.environment !== "main",
138
+ uploads: false,
139
+ debug: false
140
+ }),
141
+ driver: import_apollo.ApolloDriver
142
+ }),
143
+ import_mongoose.MongooseModule.forRootAsync({
144
+ useFactory: () => ({ uri: mongoUri, autoIndex: import_base.baseEnv.environment !== "main" })
145
+ }),
146
+ SubDatabaseModule,
147
+ ...["batch", "all"].includes(serverMode) && import_base.baseEnv.operationMode !== "edge" ? [import_searchDaemon.SearchDaemonModule] : [],
148
+ ...registerModules(env),
149
+ ...serverMode === "federation" || !registerBatches ? [] : registerBatches(env)
150
+ ],
151
+ providers: [import_gql.DateScalar]
152
+ })
153
+ ], AppModule);
154
+ const app = await import_core.NestFactory.create(AppModule, { logger: backendLogger });
155
+ const redisIoAdapter = new import_nest.RedisIoAdapter(app, { jwtSecret });
156
+ await redisIoAdapter.connectToRedis(redisUri);
157
+ app.enableShutdownHooks();
158
+ if (["federation", "all"].includes(serverMode)) {
159
+ app.setGlobalPrefix(process.env.GLOBAL_PREFIX ?? "/backend");
160
+ app.enableCors({
161
+ origin: "*",
162
+ methods: "GET,HEAD,PUT,PATCH,POST,DELETE",
163
+ preflightContinue: false,
164
+ optionsSuccessStatus: 204,
165
+ allowedHeaders: "DNT,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range,Authorization,apollo-require-preflight"
166
+ });
167
+ if (env.operationMode !== "local" && process.env.USE_REDIS_IO_ADAPTER !== "false")
168
+ app.useWebSocketAdapter(redisIoAdapter);
169
+ app.use((0, import_body_parser.json)({ limit: "100mb" }));
170
+ app.use((0, import_body_parser.urlencoded)({ limit: "100mb", extended: true }));
171
+ app.use("/backend/graphql", (0, import_graphql_upload.graphqlUploadExpress)());
172
+ app.use((0, import_cookie_parser.default)());
173
+ app.useGlobalInterceptors(new import_nest.LoggingInterceptor());
174
+ app.useGlobalInterceptors(new import_nest.TimeoutInterceptor());
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
+ });
@@ -0,0 +1,6 @@
1
+ import { Type } from "@akanjs/base";
2
+ export declare const controllerOf: (sigRef: Type, allSrvs: {
3
+ [key: string]: Type;
4
+ }) => {
5
+ new (): {};
6
+ };
@@ -0,0 +1,99 @@
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_signal = require("@akanjs/signal");
27
+ var import_common2 = require("@nestjs/common");
28
+ var import_passport = require("@nestjs/passport");
29
+ var import_platform_express = require("@nestjs/platform-express");
30
+ const internalArgMap = {
31
+ // Parent: Nest.Parent,
32
+ Account: import_nest.Account,
33
+ UserIp: import_nest.UserIp,
34
+ Access: import_nest.Access,
35
+ Self: import_nest.Self,
36
+ Me: import_nest.Me,
37
+ Req: import_nest.Req,
38
+ Res: import_nest.Res
39
+ };
40
+ const controllerOf = (sigRef, allSrvs) => {
41
+ const sigMeta = (0, import_signal.getSigMeta)(sigRef);
42
+ const gqlMetas = (0, import_signal.getGqlMetas)(sigRef);
43
+ const prefix = (0, import_signal.getControllerPrefix)(sigMeta);
44
+ const Ctrl = (0, import_signal.copySignal)(sigRef);
45
+ Object.keys(allSrvs).forEach((srv) => {
46
+ (0, import_common2.Inject)(allSrvs[srv])(Ctrl.prototype, (0, import_common.lowerlize)(srv));
47
+ });
48
+ for (const gqlMeta of gqlMetas) {
49
+ if (gqlMeta.guards.some((guard) => guard === "None") || gqlMeta.signalOption.onlyFor === "graphql" || !["Query", "Mutation"].includes(gqlMeta.type))
50
+ continue;
51
+ const [argMetas, internalArgMetas] = (0, import_signal.getArgMetas)(Ctrl, gqlMeta.key);
52
+ internalArgMetas.forEach((internalArgMeta) => {
53
+ const internalDecorator = internalArgMap[internalArgMeta.type];
54
+ internalDecorator(internalArgMeta.option ?? {})(Ctrl.prototype, gqlMeta.key, internalArgMeta.idx);
55
+ });
56
+ const uploadArgMeta = argMetas.find((argMeta) => argMeta.type === "Upload");
57
+ if (uploadArgMeta && gqlMeta.signalOption.onlyFor === "restapi") {
58
+ const [modelRef, arrDepth] = (0, import_base.getNonArrayModel)(uploadArgMeta.returns());
59
+ if (modelRef.prototype !== import_base.Upload.prototype)
60
+ throw new Error("Upload must be Upload");
61
+ else if (!arrDepth)
62
+ throw new Error(`Only Array of Upload is allowed - ${sigMeta.refName}/${gqlMeta.key}`);
63
+ (0, import_common2.UseInterceptors)((0, import_platform_express.FilesInterceptor)(uploadArgMeta.name))(Ctrl.prototype, gqlMeta.key, gqlMeta.descriptor);
64
+ (0, import_common2.UploadedFiles)(import_nest.MulterToUploadPipe)(Ctrl.prototype, gqlMeta.key, uploadArgMeta.idx);
65
+ }
66
+ const queryArgMetas = argMetas.filter((argMeta) => argMeta.type === "Query");
67
+ queryArgMetas.forEach((argMeta) => {
68
+ const [modelRef, arrDepth] = (0, import_base.getNonArrayModel)(argMeta.returns());
69
+ (0, import_common2.Query)(argMeta.name, ...(0, import_nest.getQueryPipes)(modelRef, arrDepth))(Ctrl.prototype, gqlMeta.key, argMeta.idx);
70
+ });
71
+ const paramArgMetas = argMetas.filter((argMeta) => argMeta.type === "Param");
72
+ paramArgMetas.forEach((argMeta) => {
73
+ (0, import_common2.Param)(argMeta.name)(Ctrl.prototype, gqlMeta.key, argMeta.idx);
74
+ });
75
+ const path = (0, import_signal.getControllerPath)(gqlMeta, paramArgMetas);
76
+ const bodyArgMetas = argMetas.filter((argMeta) => argMeta.type === "Body");
77
+ if (bodyArgMetas.length)
78
+ bodyArgMetas.forEach((argMeta) => {
79
+ (0, import_common2.Body)(argMeta.name, ...(0, import_nest.getBodyPipes)(argMeta))(Ctrl.prototype, gqlMeta.key, argMeta.idx);
80
+ });
81
+ (0, import_common2.UseGuards)(
82
+ ...gqlMeta.guards.map((guard) => import_nest.guards[guard]),
83
+ ...gqlMeta.signalOption.sso ? [(0, import_passport.AuthGuard)(gqlMeta.signalOption.sso)] : []
84
+ )(Ctrl.prototype, gqlMeta.key, gqlMeta.descriptor);
85
+ if (gqlMeta.type === "Query")
86
+ (0, import_common2.Get)(path)(Ctrl.prototype, gqlMeta.key, gqlMeta.descriptor);
87
+ else if (gqlMeta.type === "Mutation")
88
+ (0, import_common2.Post)(path)(Ctrl.prototype, gqlMeta.key, gqlMeta.descriptor);
89
+ }
90
+ if (prefix)
91
+ (0, import_common2.Controller)(prefix)(Ctrl);
92
+ else
93
+ (0, import_common2.Controller)()(Ctrl);
94
+ return Ctrl;
95
+ };
96
+ // Annotate the CommonJS export names for ESM import in node:
97
+ 0 && (module.exports = {
98
+ controllerOf
99
+ });
@@ -0,0 +1,26 @@
1
+ import type { Type } from "@akanjs/base";
2
+ import DataLoader from "dataloader";
3
+ import type { FilterQuery, Model } from "mongoose";
4
+ import { Schema, Types } from "mongoose";
5
+ export declare const Id: typeof Types.ObjectId;
6
+ export declare const ObjectId: typeof Schema.Types.ObjectId;
7
+ export declare const Mixed: typeof Schema.Types.Mixed;
8
+ export { DataLoader };
9
+ export declare const createLoader: <Key, Value>(model: Model<any>, fieldName?: string, defaultQuery?: FilterQuery<unknown>) => DataLoader<Key, Value, Key>;
10
+ export declare const createArrayLoader: <K, V>(model: Model<unknown, unknown, unknown, unknown>, fieldName?: string, defaultQuery?: FilterQuery<unknown>) => DataLoader<K, V, K>;
11
+ export declare const createArrayElementLoader: <K, V>(model: Model<unknown>, fieldName?: string, defaultQuery?: FilterQuery<unknown>) => DataLoader<K, V, K>;
12
+ export declare const createQueryLoader: <Key, Value>(model: Model<any>, queryKeys: string[], defaultQuery?: FilterQuery<unknown>) => DataLoader<Key, Value, Key>;
13
+ export interface LoaderMeta {
14
+ key: string;
15
+ type: "Field" | "ArrayField" | "Query";
16
+ fieldName?: string;
17
+ queryKeys?: string[];
18
+ defaultQuery: FilterQuery<unknown>;
19
+ }
20
+ export declare const getLoaderMetas: (target: Type) => LoaderMeta[];
21
+ export type Loader<Field, Value> = DataLoader<Field, Value | null>;
22
+ export declare const Loader: {
23
+ ByField: (fieldName: string, defaultQuery?: FilterQuery<unknown>) => (target: object, key: string) => void;
24
+ ByArrayField: (fieldName: string, defaultQuery?: FilterQuery<unknown>) => (target: object, key: string) => void;
25
+ ByQuery: (queryKeys: string[], defaultQuery?: FilterQuery<unknown>) => (target: object, key: string) => void;
26
+ };
@@ -0,0 +1,152 @@
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 dataLoader_exports = {};
29
+ __export(dataLoader_exports, {
30
+ DataLoader: () => import_dataloader.default,
31
+ Id: () => Id,
32
+ Loader: () => Loader,
33
+ Mixed: () => Mixed,
34
+ ObjectId: () => ObjectId,
35
+ createArrayElementLoader: () => createArrayElementLoader,
36
+ createArrayLoader: () => createArrayLoader,
37
+ createLoader: () => createLoader,
38
+ createQueryLoader: () => createQueryLoader,
39
+ getLoaderMetas: () => getLoaderMetas
40
+ });
41
+ module.exports = __toCommonJS(dataLoader_exports);
42
+ var import_dataloader = __toESM(require("dataloader"));
43
+ var import_lodash = require("lodash");
44
+ var import_mongoose = require("mongoose");
45
+ const Id = import_mongoose.Types.ObjectId;
46
+ const ObjectId = import_mongoose.Schema.Types.ObjectId;
47
+ const Mixed = import_mongoose.Schema.Types.Mixed;
48
+ const createLoader = (model, fieldName = "_id", defaultQuery = {}) => {
49
+ return new import_dataloader.default(
50
+ (fields) => {
51
+ const query = { ...defaultQuery };
52
+ query[fieldName] = { $in: fields };
53
+ const data = model.find(query).then((list) => {
54
+ const listByKey = (0, import_lodash.keyBy)(list, fieldName);
55
+ return fields.map((id) => (0, import_lodash.get)(listByKey, id, null));
56
+ });
57
+ return data;
58
+ },
59
+ { name: "dataloader", cache: false }
60
+ );
61
+ };
62
+ const createArrayLoader = (model, fieldName = "_id", defaultQuery = {}) => {
63
+ return new import_dataloader.default((fields) => {
64
+ const query = { ...defaultQuery };
65
+ query[fieldName] = { $in: fields };
66
+ const data = model.find(query).then((list) => {
67
+ return fields.map((field) => list.filter((item) => field === item[fieldName]));
68
+ });
69
+ return data;
70
+ });
71
+ };
72
+ const createArrayElementLoader = (model, fieldName = "_id", defaultQuery = {}) => {
73
+ return new import_dataloader.default(
74
+ (fields) => {
75
+ const query = { ...defaultQuery };
76
+ query[fieldName] = { $in: fields };
77
+ const data = model.find(query).then((list) => {
78
+ const flat = (0, import_lodash.flatMap)(
79
+ list,
80
+ (dat) => dat[fieldName].map((datField) => ({
81
+ ...dat.toObject(),
82
+ key: datField
83
+ }))
84
+ );
85
+ const listByKey = (0, import_lodash.groupBy)(flat, (dat) => dat.key);
86
+ return fields.map((id) => (0, import_lodash.get)(listByKey, id, null));
87
+ });
88
+ return data;
89
+ },
90
+ { name: "dataloader", cache: false }
91
+ );
92
+ };
93
+ const createQueryLoader = (model, queryKeys, defaultQuery = {}) => {
94
+ return new import_dataloader.default(
95
+ (queries) => {
96
+ const query = {
97
+ $and: [{ $or: queries }, defaultQuery]
98
+ };
99
+ const getQueryKey = (query2) => queryKeys.map((key) => query2[key].toString()).join("");
100
+ const data = model.find(query).then((list) => {
101
+ const listByKey = (0, import_lodash.keyBy)(list, getQueryKey);
102
+ return queries.map((query2) => (0, import_lodash.get)(listByKey, getQueryKey(query2), null));
103
+ });
104
+ return data;
105
+ },
106
+ { name: "dataloader", cache: false }
107
+ );
108
+ };
109
+ const getLoaderMetaMapByPrototype = (prototype) => {
110
+ const loaderMetaMap = Reflect.getOwnMetadata("loaders", prototype) ?? /* @__PURE__ */ new Map();
111
+ return loaderMetaMap;
112
+ };
113
+ const getLoaderMetas = (target) => {
114
+ const metas = [...getLoaderMetaMapByPrototype(target.prototype).values()];
115
+ return metas;
116
+ };
117
+ const Loader = {
118
+ ByField: (fieldName, defaultQuery = {}) => {
119
+ return function(target, key) {
120
+ const loaderMetaMap = getLoaderMetaMapByPrototype(target);
121
+ loaderMetaMap.set(key, { key, type: "Field", fieldName, defaultQuery });
122
+ Reflect.defineMetadata("loaders", loaderMetaMap, target);
123
+ };
124
+ },
125
+ ByArrayField: (fieldName, defaultQuery = {}) => {
126
+ return function(target, key) {
127
+ const loaderMetaMap = getLoaderMetaMapByPrototype(target);
128
+ loaderMetaMap.set(key, { key, type: "ArrayField", fieldName, defaultQuery });
129
+ Reflect.defineMetadata("loaders", loaderMetaMap, target);
130
+ };
131
+ },
132
+ ByQuery: (queryKeys, defaultQuery = {}) => {
133
+ return function(target, key) {
134
+ const loaderMetaMap = getLoaderMetaMapByPrototype(target);
135
+ loaderMetaMap.set(key, { key, type: "Query", queryKeys, defaultQuery });
136
+ Reflect.defineMetadata("loaders", loaderMetaMap, target);
137
+ };
138
+ }
139
+ };
140
+ // Annotate the CommonJS export names for ESM import in node:
141
+ 0 && (module.exports = {
142
+ DataLoader,
143
+ Id,
144
+ Loader,
145
+ Mixed,
146
+ ObjectId,
147
+ createArrayElementLoader,
148
+ createArrayLoader,
149
+ createLoader,
150
+ createQueryLoader,
151
+ getLoaderMetas
152
+ });