@akanjs/document 0.0.39 → 0.0.41

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.d.ts ADDED
@@ -0,0 +1 @@
1
+ export * from "./src";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@akanjs/document",
3
- "version": "0.0.39",
3
+ "version": "0.0.41",
4
4
  "type": "commonjs",
5
5
  "publishConfig": {
6
6
  "access": "public"
@@ -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,110 @@
1
+ import { type Dayjs } from "@akanjs/base";
2
+ import { Logger } from "@akanjs/common";
3
+ import { type DocumentModel, type FilterType, type FindQueryOption, type GetActionObject, type ListQueryOption, type QueryOf, type SortOf } from "@akanjs/constant";
4
+ import type DataLoader from "dataloader";
5
+ import type { Filter, MeiliSearch } from "meilisearch";
6
+ import type { HydratedDocument } from "mongoose";
7
+ import type { RedisClientType } from "redis";
8
+ import type { BaseMiddleware, Database, Mdl } from "./dbDecorators";
9
+ import type { DataInputOf } from "./types";
10
+ interface RedisSetOptions {
11
+ expireAt?: Dayjs;
12
+ }
13
+ declare class CacheDatabase<T = any> {
14
+ private readonly refName;
15
+ private readonly redis;
16
+ private logger;
17
+ constructor(refName: string, redis: RedisClientType);
18
+ set(topic: string, key: string, value: string | number | Buffer, option?: RedisSetOptions): Promise<void>;
19
+ get<T extends string | number | Buffer>(topic: string, key: string): Promise<T | undefined>;
20
+ delete(topic: string, key: string): Promise<void>;
21
+ }
22
+ declare class SearchDatabase<T = any> {
23
+ readonly refName: string;
24
+ readonly meili: MeiliSearch;
25
+ private logger;
26
+ private index;
27
+ constructor(refName: string, meili: MeiliSearch);
28
+ searchIds(searchText: string | undefined | null, option?: {
29
+ filter?: Filter;
30
+ skip?: number | null;
31
+ limit?: number | null;
32
+ sort?: string[] | null;
33
+ }): Promise<{
34
+ ids: string[];
35
+ total: number;
36
+ }>;
37
+ count(searchText: string | undefined | null, option?: {
38
+ filter?: Filter;
39
+ skip?: number | null;
40
+ limit?: number | null;
41
+ sort?: string | null;
42
+ }): Promise<number>;
43
+ }
44
+ export type DatabaseModel<T extends string, Input, Doc, Obj, Insight, Filter, Summary = any> = DatabaseModelWithQuerySort<T, Input, Doc, Obj, Insight, GetActionObject<Filter>, SortOf<Filter>, Summary>;
45
+ type DatabaseModelWithQuerySort<T extends string, Input, Doc, Obj, Insight, Query, Sort, Summary = any> = {
46
+ logger: Logger;
47
+ __model: Mdl<Doc, Obj>;
48
+ __cache: CacheDatabase<T>;
49
+ __search: SearchDatabase<T>;
50
+ __loader: DataLoader<string, Doc, string>;
51
+ __list(query?: QueryOf<Doc>, queryOption?: ListQueryOption<Sort, Obj>): Promise<Doc[]>;
52
+ __listIds(query?: QueryOf<Doc>, queryOption?: ListQueryOption<Sort, Obj>): Promise<string[]>;
53
+ __find(query?: QueryOf<Doc>, queryOption?: FindQueryOption<Sort, Obj>): Promise<Doc | null>;
54
+ __findId(query?: QueryOf<Doc>, queryOption?: FindQueryOption<Sort, Obj>): Promise<string | null>;
55
+ __pick(query?: QueryOf<Doc>, queryOption?: FindQueryOption<Sort, Obj>): Promise<Doc>;
56
+ __pickId(query?: QueryOf<Doc>, queryOption?: FindQueryOption<Sort, Obj>): Promise<string>;
57
+ __exists(query?: QueryOf<Doc>): Promise<string | null>;
58
+ __count(query?: QueryOf<Doc>): Promise<number>;
59
+ __insight(query?: QueryOf<Doc>): Promise<Insight>;
60
+ getDefaultSummary(addQuery?: QueryOf<Doc>): Promise<Summary>;
61
+ } & {
62
+ [key in Capitalize<T>]: Mdl<Doc, Obj>;
63
+ } & {
64
+ [key in `${T}Loader`]: DataLoader<string, Doc, string>;
65
+ } & {
66
+ [key in `${T}Cache`]: CacheDatabase<T>;
67
+ } & {
68
+ [key in `${T}Search`]: SearchDatabase<T>;
69
+ } & {
70
+ [K in `get${Capitalize<T>}`]: (id: string) => Promise<Doc>;
71
+ } & {
72
+ [K in `load${Capitalize<T>}`]: (id?: string) => Promise<Doc | null>;
73
+ } & {
74
+ [K in `load${Capitalize<T>}Many`]: (ids: string) => Promise<Doc[]>;
75
+ } & {
76
+ [K in `create${Capitalize<T>}`]: (data: DataInputOf<Input, DocumentModel<Obj>>) => Promise<Doc>;
77
+ } & {
78
+ [K in `update${Capitalize<T>}`]: (id: string, data: DataInputOf<Input, DocumentModel<Obj>>) => Promise<Doc>;
79
+ } & {
80
+ [K in `remove${Capitalize<T>}`]: (id: string) => Promise<Doc>;
81
+ } & {
82
+ [K in `search${Capitalize<T>}`]: (searchText: string, queryOption?: ListQueryOption<Sort, Obj>) => Promise<{
83
+ docs: Doc[];
84
+ count: number;
85
+ }>;
86
+ } & {
87
+ [K in `searchDocs${Capitalize<T>}`]: (searchText: string, queryOption?: ListQueryOption<Sort, Obj>) => Promise<Doc[]>;
88
+ } & {
89
+ [K in `searchCount${Capitalize<T>}`]: (searchText: string) => Promise<number>;
90
+ } & {
91
+ [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;
92
+ } & {
93
+ [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;
94
+ } & {
95
+ [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;
96
+ } & {
97
+ [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;
98
+ } & {
99
+ [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;
100
+ } & {
101
+ [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;
102
+ } & {
103
+ [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;
104
+ } & {
105
+ [K in keyof Query as K extends string ? `count${Capitalize<K>}` : never]: Query[K] extends (...args: infer Args) => any ? (...args: [...Args]) => Promise<number> : never;
106
+ } & {
107
+ [K in keyof Query as K extends string ? `insight${Capitalize<K>}` : never]: Query[K] extends (...args: infer Args) => any ? (...args: [...Args]) => Promise<Insight> : never;
108
+ };
109
+ export 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>;
110
+ export {};
@@ -0,0 +1,67 @@
1
+ import { BaseObject, Type } from "@akanjs/base";
2
+ import { type ConstantModel, type DocumentModel, type FilterType } from "@akanjs/constant";
3
+ import type { FilterQuery, HydratedDocument, Model as MongooseModel, PipelineStage, ProjectionType, Schema } from "mongoose";
4
+ import type { DatabaseModel } from "./database";
5
+ export type { FilterQuery as QueryOf };
6
+ interface DefaultDocMtds<TDocument> {
7
+ refresh(): Promise<this>;
8
+ set(data: Partial<TDocument>): this;
9
+ save(): Promise<this>;
10
+ }
11
+ type HydratedDocumentWithId<TDocument> = Omit<HydratedDocument<TDocument, DefaultDocMtds<TDocument>>, "id" | "set" | "save"> & {
12
+ id: string;
13
+ } & DefaultDocMtds<TDocument>;
14
+ export type Doc<M> = HydratedDocumentWithId<DocumentModel<M>>;
15
+ interface DefaultMdlStats<TDocument, TSchema> {
16
+ pickOneAndWrite: (query: FilterQuery<TSchema>, rawData: Partial<TSchema>) => Promise<TDocument>;
17
+ pickAndWrite: (docId: string, rawData: Partial<TSchema>) => Promise<TDocument>;
18
+ pickOne: (query: FilterQuery<TSchema>, projection?: ProjectionType<TSchema>) => Promise<TDocument>;
19
+ pickById: (docId: string | undefined, projection?: ProjectionType<TSchema>) => Promise<TDocument>;
20
+ addSummary: (prefix?: string | string[], num?: number) => Promise<void>;
21
+ moveSummary: (prev: string, next: string, num?: number) => Promise<void>;
22
+ subSummary: (prefix?: string | string[], num?: number) => Promise<void>;
23
+ sample: (query: FilterQuery<TSchema>, size?: number, aggregations?: PipelineStage[]) => Promise<TDocument[]>;
24
+ sampleOne: (query: FilterQuery<TSchema>, aggregations?: PipelineStage[]) => Promise<TDocument | null>;
25
+ }
26
+ export type Mdl<Doc extends HydratedDocument<any>, Raw> = MongooseModel<Raw, unknown, unknown, unknown, Doc> & DefaultMdlStats<Doc, DocumentModel<Raw>>;
27
+ export type SchemaOf<Mdl, Doc> = Schema<null, Mdl, Doc, undefined, null, Mdl>;
28
+ export interface BaseMiddleware {
29
+ onSchema: (schema: SchemaOf<any, any>) => void;
30
+ }
31
+ export interface Database<T extends string, Input, Doc extends HydratedDocument<any>, Model, Middleware extends BaseMiddleware, Obj, Insight, Filter extends FilterType, Summary> {
32
+ refName: T;
33
+ Input: Type<Input>;
34
+ Doc: Type<Doc>;
35
+ Model: Type<Model>;
36
+ Middleware: Type<Middleware>;
37
+ Obj: Type<Obj>;
38
+ Insight: Type<Insight>;
39
+ Filter: Type<Filter>;
40
+ Summary?: Type<Summary>;
41
+ }
42
+ export 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>;
43
+ export declare class InputDatabaseStorage {
44
+ }
45
+ export declare class DocumentDatabaseStorage {
46
+ }
47
+ export declare class ModelDatabaseStorage {
48
+ }
49
+ export declare class MiddlewareDatabaseStorage {
50
+ }
51
+ export declare const getAllDatabaseModelNames: () => string[];
52
+ export declare const Database: {
53
+ Input: (returns: () => Type) => (target: any) => void;
54
+ Document: (returns: () => Type) => (target: any) => void;
55
+ Model: (returns: () => Type) => (target: any) => void;
56
+ Middleware: (returns: () => Type) => (target: any) => void;
57
+ };
58
+ export 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>>;
59
+ export 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>>;
60
+ export declare const by: <Model, AddModel>(modelRef: Type<Model>, addRef?: Type<AddModel>) => AddModel extends {
61
+ [key: string]: any;
62
+ } ? Type<Model & (AddModel extends BaseObject ? Doc<AddModel> : DocumentModel<AddModel>)> : Type<Model extends BaseObject ? Doc<Model> : DocumentModel<Model>>;
63
+ export declare const beyond: <DbModel, Doc>(model: Type<DbModel>, doc: Type<Doc>) => {
64
+ new (): {
65
+ onSchema(schema: SchemaOf<DbModel, Doc>): void;
66
+ };
67
+ };
package/src/index.d.ts ADDED
@@ -0,0 +1,5 @@
1
+ export * from "./dbDecorators";
2
+ export * from "./schema";
3
+ export * from "./types";
4
+ export * from "./database";
5
+ export * from "./dataLoader";
@@ -0,0 +1,29 @@
1
+ import { FilterQuery, PipelineStage, type ProjectionType } from "mongoose";
2
+ export declare const getDefaultSchemaOptions: <TSchema, TDocument>() => {
3
+ toJSON: {
4
+ getters: boolean;
5
+ virtuals: boolean;
6
+ };
7
+ toObject: {
8
+ getters: boolean;
9
+ virtuals: boolean;
10
+ };
11
+ _id: boolean;
12
+ id: boolean;
13
+ timestamps: boolean;
14
+ methods: {
15
+ refresh: () => Promise<any>;
16
+ };
17
+ statics: {
18
+ pickOne: (query: FilterQuery<TSchema>, projection?: ProjectionType<TSchema>) => Promise<TDocument>;
19
+ pickById: (docId: string | undefined, projection?: ProjectionType<TSchema>) => Promise<TDocument>;
20
+ sample: (query: FilterQuery<TSchema>, size?: number, aggregations?: PipelineStage[]) => Promise<TDocument[]>;
21
+ sampleOne: (query: FilterQuery<TSchema>, aggregations?: PipelineStage[]) => Promise<TDocument | null>;
22
+ addSummary: (prefix?: string, num?: number) => Promise<void>;
23
+ moveSummary: (prev: string, next: string, num?: number) => Promise<void>;
24
+ subSummary: (prefix?: string, num?: number) => Promise<void>;
25
+ };
26
+ };
27
+ export declare const convertAggregateMatch: (query: any) => {
28
+ [k: string]: any;
29
+ };
package/src/types.d.ts ADDED
@@ -0,0 +1,5 @@
1
+ export type DataInputOf<Input, Obj> = {
2
+ [K in keyof Input as Input[K] extends any[] ? never : K]: Input[K];
3
+ } & {
4
+ [K in keyof Input as Input[K] extends any[] ? K : never]?: Input[K];
5
+ } & Partial<Obj>;