@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 +11 -0
- package/index.d.ts +1 -0
- package/index.js +21 -0
- package/package.json +68 -0
- package/src/boot.d.ts +18 -0
- package/src/boot.js +200 -0
- package/src/controller.d.ts +6 -0
- package/src/controller.js +99 -0
- package/src/dataLoader.d.ts +26 -0
- package/src/dataLoader.js +152 -0
- package/src/database.d.ts +114 -0
- package/src/database.js +312 -0
- package/src/dbDecorators.d.ts +68 -0
- package/src/dbDecorators.js +130 -0
- package/src/gql.d.ts +14 -0
- package/src/gql.js +152 -0
- package/src/index.d.ts +14 -0
- package/src/index.js +47 -0
- package/src/module.d.ts +72 -0
- package/src/module.js +217 -0
- package/src/processor.d.ts +8 -0
- package/src/processor.js +89 -0
- package/src/resolver.d.ts +6 -0
- package/src/resolver.js +142 -0
- package/src/schema.d.ts +33 -0
- package/src/schema.js +343 -0
- package/src/searchDaemon.d.ts +7 -0
- package/src/searchDaemon.js +228 -0
- package/src/serviceDecorators.d.ts +178 -0
- package/src/serviceDecorators.js +491 -0
- package/src/types.d.ts +14 -0
- package/src/types.js +15 -0
- package/src/websocket.d.ts +17 -0
- package/src/websocket.js +143 -0
|
@@ -0,0 +1,228 @@
|
|
|
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 __decorateClass = (decorators, target, key, kind) => {
|
|
19
|
+
var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
|
|
20
|
+
for (var i = decorators.length - 1, decorator; i >= 0; i--)
|
|
21
|
+
if (decorator = decorators[i])
|
|
22
|
+
result = (kind ? decorator(target, key, result) : decorator(result)) || result;
|
|
23
|
+
if (kind && result)
|
|
24
|
+
__defProp(target, key, result);
|
|
25
|
+
return result;
|
|
26
|
+
};
|
|
27
|
+
var __decorateParam = (index, decorator) => (target, key) => decorator(target, key, index);
|
|
28
|
+
var searchDaemon_exports = {};
|
|
29
|
+
__export(searchDaemon_exports, {
|
|
30
|
+
SearchDaemonModule: () => SearchDaemonModule,
|
|
31
|
+
makeTextFilter: () => makeTextFilter
|
|
32
|
+
});
|
|
33
|
+
module.exports = __toCommonJS(searchDaemon_exports);
|
|
34
|
+
var import_common = require("@akanjs/common");
|
|
35
|
+
var import_constant = require("@akanjs/constant");
|
|
36
|
+
var import_common2 = require("@nestjs/common");
|
|
37
|
+
var import_mongoose = require("@nestjs/mongoose");
|
|
38
|
+
var import_dbDecorators = require("./dbDecorators");
|
|
39
|
+
const hasTextField = (modelRef) => {
|
|
40
|
+
const fieldMetas = (0, import_constant.getFieldMetas)(modelRef);
|
|
41
|
+
return fieldMetas.some(
|
|
42
|
+
(fieldMeta) => !!fieldMeta.text || fieldMeta.isScalar && fieldMeta.isClass && fieldMeta.select && hasTextField(fieldMeta.modelRef)
|
|
43
|
+
);
|
|
44
|
+
};
|
|
45
|
+
const getTextFieldKeys = (modelRef) => {
|
|
46
|
+
const allSearchFields = [];
|
|
47
|
+
const allFilterFields = [];
|
|
48
|
+
const fieldMetaMap = (0, import_constant.getFieldMetaMap)(modelRef);
|
|
49
|
+
const fieldMetas = [...fieldMetaMap.values()];
|
|
50
|
+
const stringTextFields = fieldMetas.filter((fieldMeta) => !!fieldMeta.text).map((fieldMeta) => {
|
|
51
|
+
if (fieldMeta.text === "filter")
|
|
52
|
+
allFilterFields.push(fieldMeta.key);
|
|
53
|
+
else if (fieldMeta.text === "search")
|
|
54
|
+
allSearchFields.push(fieldMeta.key);
|
|
55
|
+
return fieldMeta.key;
|
|
56
|
+
});
|
|
57
|
+
const scalarTextFields = fieldMetas.filter(
|
|
58
|
+
(fieldMeta) => fieldMeta.isScalar && fieldMeta.isClass && fieldMeta.select && hasTextField(fieldMeta.modelRef)
|
|
59
|
+
).map((fieldMeta) => fieldMeta.key);
|
|
60
|
+
const deepFields = scalarTextFields.map((key) => {
|
|
61
|
+
const fieldMeta = fieldMetaMap.get(key);
|
|
62
|
+
if (!fieldMeta)
|
|
63
|
+
throw new Error(`No fieldMeta for ${key}`);
|
|
64
|
+
const { stringTextFields: stringTextFields2, allTextFields, allSearchFields: allSearchFields2, allFilterFields: allFilterFields2 } = getTextFieldKeys(
|
|
65
|
+
fieldMeta.modelRef
|
|
66
|
+
);
|
|
67
|
+
allFilterFields2.push(...allSearchFields2.map((field) => `${key}.${field}`));
|
|
68
|
+
allSearchFields2.push(...stringTextFields2.map((field) => `${key}.${field}`));
|
|
69
|
+
return [
|
|
70
|
+
...stringTextFields2.map((field) => `${key}.${field}`),
|
|
71
|
+
...allTextFields.map((field) => `${key}.${field}`)
|
|
72
|
+
];
|
|
73
|
+
}).flat();
|
|
74
|
+
return {
|
|
75
|
+
stringTextFields,
|
|
76
|
+
scalarTextFields,
|
|
77
|
+
allTextFields: [...stringTextFields, ...deepFields],
|
|
78
|
+
allSearchFields,
|
|
79
|
+
allFilterFields
|
|
80
|
+
};
|
|
81
|
+
};
|
|
82
|
+
const makeTextFilter = (modelRef) => {
|
|
83
|
+
const fieldMetaMap = (0, import_constant.getFieldMetaMap)(modelRef);
|
|
84
|
+
const { stringTextFields, scalarTextFields } = getTextFieldKeys(modelRef);
|
|
85
|
+
const filterData = (data, assignObj = {}) => {
|
|
86
|
+
if (Array.isArray(data))
|
|
87
|
+
return data.map((d) => filterData(d));
|
|
88
|
+
return Object.assign(
|
|
89
|
+
Object.fromEntries([
|
|
90
|
+
...stringTextFields.map((key) => [key, data[key]]),
|
|
91
|
+
...scalarTextFields.map((key) => {
|
|
92
|
+
const fieldMeta = fieldMetaMap.get(key);
|
|
93
|
+
if (!fieldMeta)
|
|
94
|
+
throw new Error(`No fieldMeta for ${key}`);
|
|
95
|
+
const filterFunc = makeTextFilter(fieldMeta.modelRef);
|
|
96
|
+
return [key, filterFunc(data[key])];
|
|
97
|
+
})
|
|
98
|
+
]),
|
|
99
|
+
assignObj
|
|
100
|
+
);
|
|
101
|
+
};
|
|
102
|
+
return filterData;
|
|
103
|
+
};
|
|
104
|
+
const getSortableAttributes = (refName) => {
|
|
105
|
+
const cnst = (0, import_constant.getCnstMeta)(refName);
|
|
106
|
+
const sortMap = (0, import_constant.getFilterSortMap)(cnst.Filter);
|
|
107
|
+
const sortFields = Object.values(sortMap).filter((val) => typeof val === "object").map((sort) => Object.keys(sort)).flat();
|
|
108
|
+
return [...new Set(sortFields)];
|
|
109
|
+
};
|
|
110
|
+
let SearchDaemon = class {
|
|
111
|
+
constructor(connection, meili) {
|
|
112
|
+
this.connection = connection;
|
|
113
|
+
this.meili = meili;
|
|
114
|
+
}
|
|
115
|
+
logger = new import_common.Logger("SearchDaemon");
|
|
116
|
+
async onModuleInit() {
|
|
117
|
+
const databaseModelNames = (0, import_dbDecorators.getAllDatabaseModelNames)();
|
|
118
|
+
const indexes = (await this.meili.getIndexes({ limit: 1e3 })).results;
|
|
119
|
+
const indexMap = new Map(indexes.map((index) => [index.uid, index]));
|
|
120
|
+
const indexCreationNames = [];
|
|
121
|
+
const indexUpdateNames = [];
|
|
122
|
+
for (const modelName of databaseModelNames) {
|
|
123
|
+
const indexName = (0, import_common.lowerlize)(modelName);
|
|
124
|
+
const modelRef = (0, import_constant.getFullModelRef)(modelName);
|
|
125
|
+
if (!hasTextField(modelRef))
|
|
126
|
+
continue;
|
|
127
|
+
const index = indexMap.get(indexName);
|
|
128
|
+
if (!index)
|
|
129
|
+
indexCreationNames.push(indexName);
|
|
130
|
+
else if (index.primaryKey !== "id")
|
|
131
|
+
indexUpdateNames.push(indexName);
|
|
132
|
+
}
|
|
133
|
+
for (const indexName of indexCreationNames)
|
|
134
|
+
await this.meili.createIndex(indexName, { primaryKey: "id" });
|
|
135
|
+
for (const indexName of indexUpdateNames)
|
|
136
|
+
await this.meili.updateIndex(indexName, { primaryKey: "id" });
|
|
137
|
+
for (const modelName of databaseModelNames) {
|
|
138
|
+
const indexName = (0, import_common.lowerlize)(modelName);
|
|
139
|
+
const model = this.connection.models[modelName];
|
|
140
|
+
const modelRef = (0, import_constant.getFullModelRef)(modelName);
|
|
141
|
+
if (!hasTextField(modelRef))
|
|
142
|
+
continue;
|
|
143
|
+
const searchIndex = this.meili.index(indexName);
|
|
144
|
+
const { stringTextFields, scalarTextFields, allSearchFields, allFilterFields } = getTextFieldKeys(modelRef);
|
|
145
|
+
const settings = await searchIndex.getSettings();
|
|
146
|
+
const allSearchFieldSet = new Set(allSearchFields);
|
|
147
|
+
const allFilterFieldSet = new Set(allFilterFields);
|
|
148
|
+
const searchFieldSet = new Set(settings.searchableAttributes);
|
|
149
|
+
const filterFieldSet = new Set(settings.filterableAttributes);
|
|
150
|
+
const needUpdateSetting = !allSearchFields.every((field) => searchFieldSet.has(field)) || !allFilterFields.every((field) => filterFieldSet.has(field)) || !settings.searchableAttributes?.every((field) => allSearchFieldSet.has(field)) || !settings.filterableAttributes?.every((field) => allFilterFieldSet.has(field));
|
|
151
|
+
if (needUpdateSetting) {
|
|
152
|
+
this.logger.info(`update index settings (${modelName})`);
|
|
153
|
+
await searchIndex.updateSettings({
|
|
154
|
+
searchableAttributes: allSearchFields,
|
|
155
|
+
filterableAttributes: allFilterFields,
|
|
156
|
+
sortableAttributes: getSortableAttributes(indexName)
|
|
157
|
+
});
|
|
158
|
+
}
|
|
159
|
+
const stringTextFieldSet = new Set(stringTextFields);
|
|
160
|
+
const scalarTextFieldSet = new Set(scalarTextFields);
|
|
161
|
+
const filterText = makeTextFilter(modelRef);
|
|
162
|
+
model.watch().on("change", async (data) => {
|
|
163
|
+
try {
|
|
164
|
+
const id = data.documentKey._id.toString();
|
|
165
|
+
if (data.operationType === "delete") {
|
|
166
|
+
this.logger.trace(`delete text doc (${modelName}): ${id}`);
|
|
167
|
+
return await searchIndex.deleteDocument(id);
|
|
168
|
+
} else if (data.operationType === "insert") {
|
|
169
|
+
this.logger.trace(`insert text doc (${modelName}): ${data.documentKey._id}`);
|
|
170
|
+
if (!data.fullDocument)
|
|
171
|
+
throw new Error("No fullDocument");
|
|
172
|
+
const textFilteredData = filterText(data.fullDocument);
|
|
173
|
+
return await searchIndex.addDocuments([textFilteredData]);
|
|
174
|
+
} else if (data.operationType === "update") {
|
|
175
|
+
const updatedFields = data.updateDescription?.updatedFields ?? {};
|
|
176
|
+
const isRemoved = !!updatedFields.removedAt;
|
|
177
|
+
if (isRemoved) {
|
|
178
|
+
this.logger.trace(`remove text doc (${modelName}): ${id}`);
|
|
179
|
+
return await searchIndex.deleteDocument(id);
|
|
180
|
+
}
|
|
181
|
+
this.logger.trace(`update text doc (${modelName}): ${data.documentKey._id}`);
|
|
182
|
+
const updatedFieldKeys = Object.keys(updatedFields);
|
|
183
|
+
const removedFieldKeys = data.updateDescription?.removedFields ?? [];
|
|
184
|
+
const isScalarTextFieldUpdated = [...updatedFieldKeys, ...removedFieldKeys].map((key) => key.split(".")[0]).some((key) => scalarTextFieldSet.has(key));
|
|
185
|
+
if (isScalarTextFieldUpdated) {
|
|
186
|
+
const doc = await model.findById(data.documentKey._id);
|
|
187
|
+
if (!doc)
|
|
188
|
+
this.logger.error(`No doc for ${data.documentKey._id}`);
|
|
189
|
+
const textFilteredData = filterText(doc, { id });
|
|
190
|
+
return await searchIndex.updateDocuments([textFilteredData]);
|
|
191
|
+
} else {
|
|
192
|
+
const updateKeys = updatedFieldKeys.filter((key) => stringTextFieldSet.has(key));
|
|
193
|
+
const removeKeys = removedFieldKeys.filter((key) => stringTextFieldSet.has(key));
|
|
194
|
+
if (!updateKeys.length && !removeKeys.length)
|
|
195
|
+
return;
|
|
196
|
+
const textFilteredData = Object.fromEntries([
|
|
197
|
+
["id", id],
|
|
198
|
+
...updateKeys.map((key) => [key, updatedFields[key]]),
|
|
199
|
+
...removeKeys.map((key) => [key, null])
|
|
200
|
+
]);
|
|
201
|
+
return await searchIndex.updateDocuments([textFilteredData]);
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
} catch (e) {
|
|
205
|
+
this.logger.error(e);
|
|
206
|
+
}
|
|
207
|
+
});
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
};
|
|
211
|
+
SearchDaemon = __decorateClass([
|
|
212
|
+
(0, import_common2.Injectable)(),
|
|
213
|
+
__decorateParam(0, (0, import_mongoose.InjectConnection)()),
|
|
214
|
+
__decorateParam(1, (0, import_common2.Inject)("MEILI_CLIENT"))
|
|
215
|
+
], SearchDaemon);
|
|
216
|
+
let SearchDaemonModule = class {
|
|
217
|
+
};
|
|
218
|
+
SearchDaemonModule = __decorateClass([
|
|
219
|
+
(0, import_common2.Global)(),
|
|
220
|
+
(0, import_common2.Module)({
|
|
221
|
+
providers: [SearchDaemon]
|
|
222
|
+
})
|
|
223
|
+
], SearchDaemonModule);
|
|
224
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
225
|
+
0 && (module.exports = {
|
|
226
|
+
SearchDaemonModule,
|
|
227
|
+
makeTextFilter
|
|
228
|
+
});
|
|
@@ -0,0 +1,178 @@
|
|
|
1
|
+
import "reflect-metadata";
|
|
2
|
+
import { BaseObject, Dayjs, Type } from "@akanjs/base";
|
|
3
|
+
import { Logger } from "@akanjs/common";
|
|
4
|
+
import { type DocumentModel, type FilterType, FindQueryOption, type GetActionObject, ListQueryOption, QueryOf, type SortOf } from "@akanjs/constant";
|
|
5
|
+
import { FilterOutInternalArgs } from "@akanjs/signal";
|
|
6
|
+
import { CronExpression } from "@nestjs/schedule";
|
|
7
|
+
import type { Job, Queue as BullQueue } from "bull";
|
|
8
|
+
import type { HydratedDocument } from "mongoose";
|
|
9
|
+
import type { Server } from "socket.io";
|
|
10
|
+
import { type BaseMiddleware, type Database, type DatabaseModel, type DataInputOf } from ".";
|
|
11
|
+
export type GetServices<AllSrvs extends {
|
|
12
|
+
[key: string]: Type | undefined;
|
|
13
|
+
}> = {
|
|
14
|
+
[key in keyof AllSrvs]: AllSrvs[key] extends Type<infer Srv> | undefined ? Srv : AllSrvs[key] extends Type<infer Srv> ? Srv : never;
|
|
15
|
+
};
|
|
16
|
+
export declare class ServiceStorage {
|
|
17
|
+
}
|
|
18
|
+
export interface ServiceInjectMeta {
|
|
19
|
+
type: "Db" | "Srv" | "Use" | "Queue" | "Websocket";
|
|
20
|
+
name: string;
|
|
21
|
+
key: string;
|
|
22
|
+
}
|
|
23
|
+
export declare function Service(name: string): (target: Type) => Type;
|
|
24
|
+
export declare function Srv(name?: string): PropertyDecorator;
|
|
25
|
+
export declare function Use(name?: string): PropertyDecorator;
|
|
26
|
+
export declare function Queue(name?: string): PropertyDecorator;
|
|
27
|
+
export type Queue<Signal> = {
|
|
28
|
+
[K in keyof Signal as K extends string ? Signal[K] extends (...args: any) => Promise<{
|
|
29
|
+
__Returns__: "Done";
|
|
30
|
+
}> ? K : never : never]: Signal[K] extends (...args: infer Args) => Promise<infer R> ? (...args: FilterOutInternalArgs<Args>) => Promise<Job> : never;
|
|
31
|
+
} & BullQueue;
|
|
32
|
+
export declare function Websocket(name?: string): PropertyDecorator;
|
|
33
|
+
export type Websocket<Signal> = {
|
|
34
|
+
[K in keyof Signal as K extends string ? Signal[K] extends (...args: any) => Promise<{
|
|
35
|
+
__Returns__: "Subscribe";
|
|
36
|
+
}> ? K : Signal[K] extends (...args: any) => {
|
|
37
|
+
__Returns__: "Subscribe";
|
|
38
|
+
} ? K : never : never]: Signal[K] extends (...args: infer Args) => Promise<{
|
|
39
|
+
__Returns__: "Subscribe";
|
|
40
|
+
} & infer R> ? (...args: [...FilterOutInternalArgs<Args>, data: DocumentModel<R>]) => Promise<void> : Signal[K] extends (...args: infer Args) => {
|
|
41
|
+
__Returns__: "Subscribe";
|
|
42
|
+
} & infer R ? (...args: [...FilterOutInternalArgs<Args>, data: DocumentModel<R>]) => void : never;
|
|
43
|
+
} & {
|
|
44
|
+
server: Server;
|
|
45
|
+
};
|
|
46
|
+
export declare function Db(name: string): PropertyDecorator;
|
|
47
|
+
export declare const serviceOf: (srvRef: Type) => Type;
|
|
48
|
+
export declare function MixSrvs<T1 = unknown, T2 = unknown, T3 = unknown, T4 = unknown, T5 = unknown, T6 = unknown, T7 = unknown, T8 = unknown, T9 = unknown, T10 = unknown, T11 = unknown, T12 = unknown, T13 = unknown, T14 = unknown, T15 = unknown, T16 = unknown, T17 = unknown, T18 = unknown, T19 = unknown, T20 = unknown>(t1: Type<T1>, t2?: Type<T2>, t3?: Type<T3>, t4?: Type<T4>, t5?: Type<T5>, t6?: Type<T6>, t7?: Type<T7>, t8?: Type<T8>, t9?: Type<T9>, t10?: Type<T10>, t11?: Type<T11>, t12?: Type<T12>, t13?: Type<T13>, t14?: Type<T14>, t15?: Type<T15>, t16?: Type<T16>, t17?: Type<T17>, t18?: Type<T18>, t19?: Type<T19>, t20?: Type<T20>): Type<T1 & T2 & T3 & T4 & T5 & T6 & T7 & T8 & T9 & T10 & T11 & T12 & T13 & T14 & T15 & T16 & T17 & T18 & T19 & T20>;
|
|
49
|
+
export declare const LogService: <T extends string>(name: T) => {
|
|
50
|
+
new (): {
|
|
51
|
+
logger: Logger;
|
|
52
|
+
};
|
|
53
|
+
};
|
|
54
|
+
type QueueService<Signal> = {
|
|
55
|
+
[K in keyof Signal as K extends string ? Signal[K] extends (...args: any) => Promise<{
|
|
56
|
+
__Returns__: "Done";
|
|
57
|
+
}> ? K : never : never]: Signal[K] extends (...args: infer Args) => Promise<infer R> ? (...args: FilterOutInternalArgs<Args>) => Promise<Job> : never;
|
|
58
|
+
};
|
|
59
|
+
type DatabaseService<T extends string, Input, Doc, Obj, Model, Insight, Filter, Summary> = DatabaseServiceWithQuerySort<T, Input, Doc, Obj, Model, Insight, GetActionObject<Filter>, SortOf<Filter>>;
|
|
60
|
+
type DatabaseServiceWithQuerySort<T extends string, Input, Doc, Obj, Model, Insight, Query, Sort> = {
|
|
61
|
+
logger: Logger;
|
|
62
|
+
__databaseModel: Model;
|
|
63
|
+
__list(query?: QueryOf<Doc>, queryOption?: ListQueryOption<Sort, Obj>): Promise<Doc[]>;
|
|
64
|
+
__listIds(query?: QueryOf<Doc>, queryOption?: ListQueryOption<Sort, Obj>): Promise<string[]>;
|
|
65
|
+
__find(query?: QueryOf<Doc>, queryOption?: FindQueryOption<Sort, Obj>): Promise<Doc | null>;
|
|
66
|
+
__findId(query?: QueryOf<Doc>, queryOption?: FindQueryOption<Sort, Obj>): Promise<string | null>;
|
|
67
|
+
__pick(query?: QueryOf<Doc>, queryOption?: FindQueryOption<Sort, Obj>): Promise<Doc>;
|
|
68
|
+
__pickId(query?: QueryOf<Doc>, queryOption?: FindQueryOption<Sort, Obj>): Promise<string>;
|
|
69
|
+
__exists(query?: QueryOf<Doc>): Promise<string | null>;
|
|
70
|
+
__count(query?: QueryOf<Doc>): Promise<number>;
|
|
71
|
+
__insight(query?: QueryOf<Doc>): Promise<Insight>;
|
|
72
|
+
__search(query: QueryOf<Doc>, queryOption?: ListQueryOption<Sort, Obj>): Promise<{
|
|
73
|
+
docs: Doc[];
|
|
74
|
+
count: number;
|
|
75
|
+
}>;
|
|
76
|
+
__searchDocs(query: QueryOf<Doc>, queryOption?: ListQueryOption<Sort, Obj>): Promise<Doc[]>;
|
|
77
|
+
__searchCount(query: QueryOf<Doc>): Promise<number>;
|
|
78
|
+
_preCreate(data: DataInputOf<Input, Doc>): Promise<DataInputOf<Input, Doc>> | DataInputOf<Input, Doc>;
|
|
79
|
+
_postCreate(doc: Doc): Promise<Doc> | Doc;
|
|
80
|
+
_preUpdate(id: string, data: Partial<Doc>): Promise<Partial<Doc>> | Partial<Doc>;
|
|
81
|
+
_postUpdate(doc: Doc): Promise<Doc> | Doc;
|
|
82
|
+
_preRemove(id: string): Promise<void> | void;
|
|
83
|
+
_postRemove(doc: Doc): Promise<Doc> | Doc;
|
|
84
|
+
} & {
|
|
85
|
+
[key in `${T}Model`]: Model;
|
|
86
|
+
} & {
|
|
87
|
+
[K in `get${Capitalize<T>}`]: (id: string) => Promise<Doc>;
|
|
88
|
+
} & {
|
|
89
|
+
[K in `load${Capitalize<T>}`]: (id?: string) => Promise<Doc | null>;
|
|
90
|
+
} & {
|
|
91
|
+
[K in `load${Capitalize<T>}Many`]: (ids: string[]) => Promise<Doc[]>;
|
|
92
|
+
} & {
|
|
93
|
+
[K in `create${Capitalize<T>}`]: (data: DataInputOf<Input, Doc>) => Promise<Doc>;
|
|
94
|
+
} & {
|
|
95
|
+
[K in `update${Capitalize<T>}`]: (id: string, data: Partial<Doc>) => Promise<Doc>;
|
|
96
|
+
} & {
|
|
97
|
+
[K in `remove${Capitalize<T>}`]: (id: string) => Promise<Doc>;
|
|
98
|
+
} & {
|
|
99
|
+
[K in `search${Capitalize<T>}`]: (searchText: string, queryOption?: ListQueryOption<Sort, Obj>) => Promise<{
|
|
100
|
+
docs: Doc[];
|
|
101
|
+
count: number;
|
|
102
|
+
}>;
|
|
103
|
+
} & {
|
|
104
|
+
[K in `searchDocs${Capitalize<T>}`]: (searchText: string, queryOption?: ListQueryOption<Sort, Obj>) => Promise<Doc[]>;
|
|
105
|
+
} & {
|
|
106
|
+
[K in `searchCount${Capitalize<T>}`]: (searchText: string) => Promise<number>;
|
|
107
|
+
} & {
|
|
108
|
+
[K in keyof Query as K extends string ? `list${Capitalize<K>}` : never]: Query[K] extends (...args: infer Args) => any ? (...args: [...Args, queryOption?: ListQueryOption<Sort, Obj>]) => Promise<Doc[]> : never;
|
|
109
|
+
} & {
|
|
110
|
+
[K in keyof Query as K extends string ? `listIds${Capitalize<K>}` : never]: Query[K] extends (...args: infer Args) => any ? (...args: [...Args, queryOption?: ListQueryOption<Sort, Obj>]) => Promise<string[]> : never;
|
|
111
|
+
} & {
|
|
112
|
+
[K in keyof Query as K extends string ? `find${Capitalize<K>}` : never]: Query[K] extends (...args: infer Args) => any ? (...args: [...Args, queryOption?: FindQueryOption<Sort, Obj>]) => Promise<Doc | null> : never;
|
|
113
|
+
} & {
|
|
114
|
+
[K in keyof Query as K extends string ? `findId${Capitalize<K>}` : never]: Query[K] extends (...args: infer Args) => any ? (...args: [...Args, queryOption?: FindQueryOption<Sort, Obj>]) => Promise<string | null> : never;
|
|
115
|
+
} & {
|
|
116
|
+
[K in keyof Query as K extends string ? `pick${Capitalize<K>}` : never]: Query[K] extends (...args: infer Args) => any ? (...args: [...Args, queryOption?: FindQueryOption<Sort, Obj>]) => Promise<Doc> : never;
|
|
117
|
+
} & {
|
|
118
|
+
[K in keyof Query as K extends string ? `pickId${Capitalize<K>}` : never]: Query[K] extends (...args: infer Args) => any ? (...args: [...Args, queryOption?: FindQueryOption<Sort, Obj>]) => Promise<string> : never;
|
|
119
|
+
} & {
|
|
120
|
+
[K in keyof Query as K extends string ? `exists${Capitalize<K>}` : never]: Query[K] extends (...args: infer Args) => any ? (...args: [...Args]) => Promise<string | null> : never;
|
|
121
|
+
} & {
|
|
122
|
+
[K in keyof Query as K extends string ? `count${Capitalize<K>}` : never]: Query[K] extends (...args: infer Args) => any ? (...args: [...Args]) => Promise<number> : never;
|
|
123
|
+
} & {
|
|
124
|
+
[K in keyof Query as K extends string ? `insight${Capitalize<K>}` : never]: Query[K] extends (...args: infer Args) => any ? (...args: [...Args]) => Promise<Insight> : never;
|
|
125
|
+
};
|
|
126
|
+
export declare const DbService: <T extends string, Input, Doc extends unknown, Model extends DatabaseModel<T, Input, Doc, Obj, Insight, Filter, Summary>, Middleware extends BaseMiddleware, Obj, Insight, Filter extends FilterType, Summary, Signal = unknown>(database: Database<T, Input, Doc, Model, Middleware, Obj, Insight, Filter, Summary>, sigRef?: Type<Signal>) => Type<DatabaseService<T, Input, Doc, Obj, Model, Insight, Filter, Summary>>;
|
|
127
|
+
export declare const ExtendedUserService: <T extends string, Input, Doc extends unknown, Model extends DatabaseModel<T, Input, Doc, Obj, Insight, Filter, Summary>, Middleware extends BaseMiddleware, Obj, Insight, Filter extends FilterType, Summary, Srv, Signal = unknown>(database: Database<T, Input, Doc, Model, Middleware, Obj, Insight, Filter, Summary>, srvRef: Type<Srv>, sigRef?: Type<Signal>) => Type<DatabaseService<T, Input, Doc, BaseObject & {
|
|
128
|
+
nickname: string;
|
|
129
|
+
}, Model, Insight, Filter, Summary> & {
|
|
130
|
+
queue: QueueService<Signal>;
|
|
131
|
+
} & { [K in keyof Srv]: Srv[K] extends (...args: infer Args) => Promise<BaseObject & {
|
|
132
|
+
nickname: string;
|
|
133
|
+
}> ? (...args: Args) => Promise<Doc> : Srv[K] extends (...args: infer Args) => Promise<(BaseObject & {
|
|
134
|
+
nickname: string;
|
|
135
|
+
})[]> ? (...args: Args) => Promise<Doc[]> : Srv[K] extends BaseObject & {
|
|
136
|
+
nickname: string;
|
|
137
|
+
} ? Doc : Srv[K] extends (BaseObject & {
|
|
138
|
+
nickname: string;
|
|
139
|
+
})[] ? Doc[] : Srv[K]; }>;
|
|
140
|
+
export declare const ExtendedSummaryService: <T extends string, Input, Doc extends unknown, Model, Middleware extends BaseMiddleware, Obj, Insight, Filter extends FilterType, Summary, Srv, Signal = unknown>(database: Database<T, Input, Doc, Model, Middleware, Obj, Insight, Filter, Summary>, srvRef: Type<Srv>, sigRef?: Type<Signal>) => Type<Omit<DatabaseService<T, Input, Doc, Obj, Model, Insight, Filter, Summary> & {
|
|
141
|
+
queue: QueueService<Signal>;
|
|
142
|
+
} & { [K in keyof Srv]: Srv[K] extends (...args: infer Args) => Promise<BaseObject & {
|
|
143
|
+
type: string;
|
|
144
|
+
at: Dayjs;
|
|
145
|
+
}> ? (...args: Args) => Promise<Doc> : Srv[K] extends (...args: infer Args) => Promise<(BaseObject & {
|
|
146
|
+
type: string;
|
|
147
|
+
at: Dayjs;
|
|
148
|
+
})[]> ? (...args: Args) => Promise<Doc[]> : Srv[K] extends BaseObject & {
|
|
149
|
+
type: string;
|
|
150
|
+
at: Dayjs;
|
|
151
|
+
} ? Doc : Srv[K] extends (BaseObject & {
|
|
152
|
+
type: string;
|
|
153
|
+
at: Dayjs;
|
|
154
|
+
})[] ? Doc[] : Srv[K]; }, "userService">>;
|
|
155
|
+
export declare const ExtendedSettingService: <T extends string, Input, Doc extends unknown, Model extends DatabaseModel<T, Input, Doc, Obj, Insight, Filter, Summary>, Middleware extends BaseMiddleware, Obj, Insight, Filter extends FilterType, Summary, Srv, Signal = unknown>(database: Database<T, Input, Doc, Model, Middleware, Obj, Insight, Filter, Summary>, srvRef: Type<Srv>, sigRef?: Type<Signal>) => Type<DatabaseService<T, Input, Doc, BaseObject & {
|
|
156
|
+
resignupDays: number;
|
|
157
|
+
}, Model, Insight, Filter, Summary> & {
|
|
158
|
+
queue: QueueService<Signal>;
|
|
159
|
+
} & { [K in keyof Srv]: Srv[K] extends (...args: infer Args) => Promise<BaseObject & {
|
|
160
|
+
resignupDays: number;
|
|
161
|
+
}> ? (...args: Args) => Promise<Doc> : Srv[K] extends (...args: infer Args) => Promise<(BaseObject & {
|
|
162
|
+
resignupDays: number;
|
|
163
|
+
})[]> ? (...args: Args) => Promise<Doc[]> : Srv[K] extends BaseObject & {
|
|
164
|
+
resignupDays: number;
|
|
165
|
+
} ? Doc : Srv[K] extends (BaseObject & {
|
|
166
|
+
resignupDays: number;
|
|
167
|
+
})[] ? Doc[] : Srv[K]; }>;
|
|
168
|
+
export declare const Try: () => (target: any, key: string, descriptor: PropertyDescriptor) => void;
|
|
169
|
+
interface TimerOptions {
|
|
170
|
+
lock?: boolean;
|
|
171
|
+
serverMode?: "federation" | "batch";
|
|
172
|
+
enabled?: boolean;
|
|
173
|
+
}
|
|
174
|
+
export declare const Cron: (cronTime: CronExpression | string, { lock, serverMode, enabled }?: TimerOptions) => (target: any, key: string, descriptor: PropertyDescriptor) => void;
|
|
175
|
+
export declare const Interval: (ms: number, { lock, serverMode, enabled }?: TimerOptions) => (target: any, key: string, descriptor: PropertyDescriptor) => PropertyDescriptor | undefined;
|
|
176
|
+
export declare const Transaction: () => (target: any, key: string, descriptor: PropertyDescriptor) => PropertyDescriptor;
|
|
177
|
+
export declare const Cache: (timeout?: number, getCacheKey?: (...args: any) => string) => MethodDecorator;
|
|
178
|
+
export {};
|