@akanjs/document 0.0.38 → 0.0.40

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.
@@ -0,0 +1,252 @@
1
+ import { Dayjs } from 'dayjs';
2
+ import { T as Type } from './types-H2HI4YUe.js';
3
+ import { ProjectionType, FilterQuery, HydratedDocument, Model, PipelineStage, Schema } from 'mongoose';
4
+ import DataLoader from 'dataloader';
5
+ import { MeiliSearch, Filter as Filter$1 } from 'meilisearch';
6
+ import { RedisClientType } from 'redis';
7
+ import { DataInputOf } from './src/types.js';
8
+
9
+ declare class BaseObject {
10
+ id: string;
11
+ createdAt: Dayjs;
12
+ updatedAt: Dayjs;
13
+ removedAt: Dayjs | null;
14
+ }
15
+
16
+ type Optional<T, K extends keyof T> = Pick<Partial<T>, K> & Omit<T, K>;
17
+ type OptionalKeys<T> = T extends {
18
+ [key: string]: any;
19
+ } ? {
20
+ [K in keyof T]-?: null extends T[K] ? K : never;
21
+ }[keyof T] : never;
22
+ type ObjectToId<O, D = Dayjs> = O extends BaseObject ? string : O extends BaseObject[] ? string[] : O extends Dayjs ? D : O extends {
23
+ [key: string]: any;
24
+ } ? DocumentModel<O> : O;
25
+ type SortOf<Filter> = keyof GetStateObject<Filter>;
26
+ type FilterType = Record<string, any>;
27
+ interface ListQueryOption<Sort, Obj> {
28
+ skip?: number | null;
29
+ limit?: number | null;
30
+ sort?: Sort | null;
31
+ sample?: number;
32
+ select?: ProjectionType<Obj>;
33
+ }
34
+ interface FindQueryOption<Sort, Obj> {
35
+ skip?: number | null;
36
+ sort?: Sort | null;
37
+ sample?: boolean;
38
+ select?: ProjectionType<Obj>;
39
+ }
40
+ type DocumentModel<T, D = Dayjs> = T extends (infer S)[] ? DocumentModel<S>[] : T extends string ? T : T extends number ? T : T extends boolean ? T : T extends Dayjs ? T : T extends Map<infer K, infer V> ? Map<K, DocumentModel<V, D>> : Optional<{
41
+ [K in keyof GetStateObject<T>]: T[K] extends infer S ? S extends null ? undefined : ObjectToId<T[K], D> : never;
42
+ }, OptionalKeys<GetStateObject<T>>>;
43
+ type GetStateObject<T> = Omit<{
44
+ [K in keyof T as T[K] extends (...args: any) => any ? never : K]: T[K];
45
+ }, "prototype">;
46
+ type GetActionObject<T> = Omit<{
47
+ [K in keyof T as T[K] extends (...args: any) => any ? K : never]: T[K];
48
+ }, "prototype">;
49
+
50
+ interface ConstantModel<T extends string, Input, Full, Light, Insight, Filter extends FilterType, Summary = any> {
51
+ refName: T;
52
+ Input: Type<Input>;
53
+ Full: Type<Full>;
54
+ Light: Type<Light>;
55
+ Insight: Type<Insight>;
56
+ Filter: Type<Filter>;
57
+ Summary?: Type<Summary>;
58
+ }
59
+
60
+ declare const logLevels: readonly ["trace", "verbose", "debug", "log", "info", "warn", "error"];
61
+ type LogLevel = (typeof logLevels)[number];
62
+ declare class Logger {
63
+ #private;
64
+ static level: LogLevel;
65
+ static setLevel(level: LogLevel): void;
66
+ name?: string;
67
+ constructor(name?: string);
68
+ trace(msg: string, context?: string): void;
69
+ verbose(msg: string, context?: string): void;
70
+ debug(msg: string, context?: string): void;
71
+ log(msg: string, context?: string): void;
72
+ info(msg: string, context?: string): void;
73
+ warn(msg: string, context?: string): void;
74
+ error(msg: string, context?: string): void;
75
+ raw(msg: string, method?: "console" | "process"): void;
76
+ rawLog(msg: string, method?: "console" | "process"): void;
77
+ static trace(msg: string, context?: string): void;
78
+ static verbose(msg: string, context?: string): void;
79
+ static debug(msg: string, context?: string): void;
80
+ static log(msg: string, context?: string): void;
81
+ static info(msg: string, context?: string): void;
82
+ static warn(msg: string, context?: string): void;
83
+ static error(msg: string, context?: string): void;
84
+ static rawLog(msg: string, method?: "console" | "process"): void;
85
+ static raw(msg: string, method?: "console" | "process"): void;
86
+ }
87
+
88
+ interface RedisSetOptions {
89
+ expireAt?: Dayjs;
90
+ }
91
+ declare class CacheDatabase<T = any> {
92
+ private readonly refName;
93
+ private readonly redis;
94
+ private logger;
95
+ constructor(refName: string, redis: RedisClientType);
96
+ set(topic: string, key: string, value: string | number | Buffer, option?: RedisSetOptions): Promise<void>;
97
+ get<T extends string | number | Buffer>(topic: string, key: string): Promise<T | undefined>;
98
+ delete(topic: string, key: string): Promise<void>;
99
+ }
100
+ declare class SearchDatabase<T = any> {
101
+ readonly refName: string;
102
+ readonly meili: MeiliSearch;
103
+ private logger;
104
+ private index;
105
+ constructor(refName: string, meili: MeiliSearch);
106
+ searchIds(searchText: string | undefined | null, option?: {
107
+ filter?: Filter$1;
108
+ skip?: number | null;
109
+ limit?: number | null;
110
+ sort?: string[] | null;
111
+ }): Promise<{
112
+ ids: string[];
113
+ total: number;
114
+ }>;
115
+ count(searchText: string | undefined | null, option?: {
116
+ filter?: Filter$1;
117
+ skip?: number | null;
118
+ limit?: number | null;
119
+ sort?: string | null;
120
+ }): Promise<number>;
121
+ }
122
+ type DatabaseModel<T extends string, Input, Doc, Obj, Insight, Filter, Summary = any> = DatabaseModelWithQuerySort<T, Input, Doc, Obj, Insight, GetActionObject<Filter>, SortOf<Filter>, Summary>;
123
+ type DatabaseModelWithQuerySort<T extends string, Input, Doc, Obj, Insight, Query, Sort, Summary = any> = {
124
+ logger: Logger;
125
+ __model: Mdl<Doc, Obj>;
126
+ __cache: CacheDatabase<T>;
127
+ __search: SearchDatabase<T>;
128
+ __loader: DataLoader<string, Doc, string>;
129
+ __list(query?: FilterQuery<Doc>, queryOption?: ListQueryOption<Sort, Obj>): Promise<Doc[]>;
130
+ __listIds(query?: FilterQuery<Doc>, queryOption?: ListQueryOption<Sort, Obj>): Promise<string[]>;
131
+ __find(query?: FilterQuery<Doc>, queryOption?: FindQueryOption<Sort, Obj>): Promise<Doc | null>;
132
+ __findId(query?: FilterQuery<Doc>, queryOption?: FindQueryOption<Sort, Obj>): Promise<string | null>;
133
+ __pick(query?: FilterQuery<Doc>, queryOption?: FindQueryOption<Sort, Obj>): Promise<Doc>;
134
+ __pickId(query?: FilterQuery<Doc>, queryOption?: FindQueryOption<Sort, Obj>): Promise<string>;
135
+ __exists(query?: FilterQuery<Doc>): Promise<string | null>;
136
+ __count(query?: FilterQuery<Doc>): Promise<number>;
137
+ __insight(query?: FilterQuery<Doc>): Promise<Insight>;
138
+ getDefaultSummary(addQuery?: FilterQuery<Doc>): Promise<Summary>;
139
+ } & {
140
+ [key in Capitalize<T>]: Mdl<Doc, Obj>;
141
+ } & {
142
+ [key in `${T}Loader`]: DataLoader<string, Doc, string>;
143
+ } & {
144
+ [key in `${T}Cache`]: CacheDatabase<T>;
145
+ } & {
146
+ [key in `${T}Search`]: SearchDatabase<T>;
147
+ } & {
148
+ [K in `get${Capitalize<T>}`]: (id: string) => Promise<Doc>;
149
+ } & {
150
+ [K in `load${Capitalize<T>}`]: (id?: string) => Promise<Doc | null>;
151
+ } & {
152
+ [K in `load${Capitalize<T>}Many`]: (ids: string) => Promise<Doc[]>;
153
+ } & {
154
+ [K in `create${Capitalize<T>}`]: (data: DataInputOf<Input, DocumentModel<Obj>>) => Promise<Doc>;
155
+ } & {
156
+ [K in `update${Capitalize<T>}`]: (id: string, data: DataInputOf<Input, DocumentModel<Obj>>) => Promise<Doc>;
157
+ } & {
158
+ [K in `remove${Capitalize<T>}`]: (id: string) => Promise<Doc>;
159
+ } & {
160
+ [K in `search${Capitalize<T>}`]: (searchText: string, queryOption?: ListQueryOption<Sort, Obj>) => Promise<{
161
+ docs: Doc[];
162
+ count: number;
163
+ }>;
164
+ } & {
165
+ [K in `searchDocs${Capitalize<T>}`]: (searchText: string, queryOption?: ListQueryOption<Sort, Obj>) => Promise<Doc[]>;
166
+ } & {
167
+ [K in `searchCount${Capitalize<T>}`]: (searchText: string) => Promise<number>;
168
+ } & {
169
+ [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;
170
+ } & {
171
+ [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;
172
+ } & {
173
+ [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;
174
+ } & {
175
+ [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;
176
+ } & {
177
+ [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;
178
+ } & {
179
+ [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;
180
+ } & {
181
+ [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;
182
+ } & {
183
+ [K in keyof Query as K extends string ? `count${Capitalize<K>}` : never]: Query[K] extends (...args: infer Args) => any ? (...args: [...Args]) => Promise<number> : never;
184
+ } & {
185
+ [K in keyof Query as K extends string ? `insight${Capitalize<K>}` : never]: Query[K] extends (...args: infer Args) => any ? (...args: [...Args]) => Promise<Insight> : never;
186
+ };
187
+ declare const databaseModelOf: <T extends string, Input, Doc extends HydratedDocument<any>, Model extends Mdl<any, any>, Middleware extends BaseMiddleware, Insight, Obj, Filter extends FilterType, Summary>(database: Database<T, Input, Doc, Model, Middleware, Insight, Obj, Filter, Summary>, model: Mdl<any, any>, redis: RedisClientType, meili: MeiliSearch) => DatabaseModel<T, Input, Doc, Model, Insight, Filter, Summary>;
188
+
189
+ interface DefaultDocMtds<TDocument> {
190
+ refresh(): Promise<this>;
191
+ set(data: Partial<TDocument>): this;
192
+ save(): Promise<this>;
193
+ }
194
+ type HydratedDocumentWithId<TDocument> = Omit<HydratedDocument<TDocument, DefaultDocMtds<TDocument>>, "id" | "set" | "save"> & {
195
+ id: string;
196
+ } & DefaultDocMtds<TDocument>;
197
+ type Doc<M> = HydratedDocumentWithId<DocumentModel<M>>;
198
+ interface DefaultMdlStats<TDocument, TSchema> {
199
+ pickOneAndWrite: (query: FilterQuery<TSchema>, rawData: Partial<TSchema>) => Promise<TDocument>;
200
+ pickAndWrite: (docId: string, rawData: Partial<TSchema>) => Promise<TDocument>;
201
+ pickOne: (query: FilterQuery<TSchema>, projection?: ProjectionType<TSchema>) => Promise<TDocument>;
202
+ pickById: (docId: string | undefined, projection?: ProjectionType<TSchema>) => Promise<TDocument>;
203
+ addSummary: (prefix?: string | string[], num?: number) => Promise<void>;
204
+ moveSummary: (prev: string, next: string, num?: number) => Promise<void>;
205
+ subSummary: (prefix?: string | string[], num?: number) => Promise<void>;
206
+ sample: (query: FilterQuery<TSchema>, size?: number, aggregations?: PipelineStage[]) => Promise<TDocument[]>;
207
+ sampleOne: (query: FilterQuery<TSchema>, aggregations?: PipelineStage[]) => Promise<TDocument | null>;
208
+ }
209
+ type Mdl<Doc extends HydratedDocument<any>, Raw> = Model<Raw, unknown, unknown, unknown, Doc> & DefaultMdlStats<Doc, DocumentModel<Raw>>;
210
+ type SchemaOf<Mdl, Doc> = Schema<null, Mdl, Doc, undefined, null, Mdl>;
211
+ interface BaseMiddleware {
212
+ onSchema: (schema: SchemaOf<any, any>) => void;
213
+ }
214
+ declare const dbOf: <T extends string, Input, Doc extends HydratedDocument<any>, Model extends DatabaseModel<T, Input, any, Obj, Insight, Filter>, Middleware extends BaseMiddleware, Obj, Insight, Filter extends FilterType, Summary>(refName: T, Input: Type<Input>, Doc: Type<Doc>, Model: Type<Model>, Middleware: Type<Middleware>, Obj: Type<Obj>, Insight: Type<Insight>, Filter: Type<Filter>, Summary?: Type<Summary>) => Database<T, Input, Doc, Model, Middleware, Obj, Insight, Filter, Summary>;
215
+ declare class InputDatabaseStorage {
216
+ }
217
+ declare class DocumentDatabaseStorage {
218
+ }
219
+ declare class ModelDatabaseStorage {
220
+ }
221
+ declare class MiddlewareDatabaseStorage {
222
+ }
223
+ declare const getAllDatabaseModelNames: () => string[];
224
+ interface Database<T extends string, Input, Doc extends HydratedDocument<any>, Model, Middleware extends BaseMiddleware, Obj, Insight, Filter extends FilterType, Summary> {
225
+ refName: T;
226
+ Input: Type<Input>;
227
+ Doc: Type<Doc>;
228
+ Model: Type<Model>;
229
+ Middleware: Type<Middleware>;
230
+ Obj: Type<Obj>;
231
+ Insight: Type<Insight>;
232
+ Filter: Type<Filter>;
233
+ Summary?: Type<Summary>;
234
+ }
235
+ declare const Database: {
236
+ Input: (returns: () => Type) => (target: any) => void;
237
+ Document: (returns: () => Type) => (target: any) => void;
238
+ Model: (returns: () => Type) => (target: any) => void;
239
+ Middleware: (returns: () => Type) => (target: any) => void;
240
+ };
241
+ declare const into: <Doc, T extends string, Input, Full, Light, Insight, Summary, Filter extends FilterType>(docRef: Type<Doc>, cnst: ConstantModel<T, Input, Full, Light, Insight, Filter, Summary>) => Type<DatabaseModel<T, DocumentModel<Input>, Doc, Full, Insight, Filter, Summary>>;
242
+ declare const inside: <Doc, T extends string, Input, Full, Light, Insight, Filter extends FilterType, Summary>(modelRef: Type, cnst: ConstantModel<T, Input, Full, Light, Insight, Filter, Summary>) => Type<DatabaseModel<T, DocumentModel<Input>, Doc, Full, Insight, Filter, Summary>>;
243
+ declare const by: <Model, AddModel>(modelRef: Type<Model>, addRef?: Type<AddModel>) => AddModel extends {
244
+ [key: string]: any;
245
+ } ? Type<Model & (AddModel extends BaseObject ? Doc<AddModel> : DocumentModel<AddModel>)> : Type<Model extends BaseObject ? Doc<Model> : DocumentModel<Model>>;
246
+ declare const beyond: <DbModel, Doc>(model: Type<DbModel>, doc: Type<Doc>) => {
247
+ new (): {
248
+ onSchema(schema: SchemaOf<DbModel, Doc>): void;
249
+ };
250
+ };
251
+
252
+ export { type BaseMiddleware as B, type Doc as D, InputDatabaseStorage as I, type Mdl as M, type SchemaOf as S, Database as a, DocumentDatabaseStorage as b, ModelDatabaseStorage as c, dbOf as d, MiddlewareDatabaseStorage as e, inside as f, getAllDatabaseModelNames as g, by as h, into as i, beyond as j, type DatabaseModel as k, databaseModelOf as l };
package/index.d.ts ADDED
@@ -0,0 +1,10 @@
1
+ export { B as BaseMiddleware, a as Database, k as DatabaseModel, D as Doc, b as DocumentDatabaseStorage, I as InputDatabaseStorage, M as Mdl, e as MiddlewareDatabaseStorage, c as ModelDatabaseStorage, S as SchemaOf, j as beyond, h as by, l as databaseModelOf, d as dbOf, g as getAllDatabaseModelNames, f as inside, i as into } from './dbDecorators-B-tzSGvi.js';
2
+ export { convertAggregateMatch, getDefaultSchemaOptions } from './src/schema.js';
3
+ export { DataInputOf } from './src/types.js';
4
+ export { Id, Loader, LoaderMeta, Mixed, ObjectId, createArrayElementLoader, createArrayLoader, createLoader, createQueryLoader, getLoaderMetas } from './src/dataLoader.js';
5
+ export { FilterQuery as QueryOf } from 'mongoose';
6
+ export { default as DataLoader } from 'dataloader';
7
+ import 'dayjs';
8
+ import './types-H2HI4YUe.js';
9
+ import 'meilisearch';
10
+ import 'redis';