Socket
Socket
Sign inDemoInstall

nukak

Package Overview
Dependencies
2
Maintainers
1
Versions
61
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 0.3.0 to 0.3.1

7

CHANGELOG.md

@@ -7,2 +7,9 @@ # Changelog

## [0.3.1] - 2023-10-19
1. Remove `$group` and `$having` as they detriment type safety as currently implemented (support may be redesigned later if required).
2. Improve type safety of `$project` operator.
3. Improve type safety of `$filter` operator.
4. Remove projection operators (`$count`, `$min`, `$max`, `$min`, and `$sum`) as they detriment type safety as currently implemented. This can be done via Virtual fields instead as currently supported for better type safety.
## [0.3.0] - 2023-10-18

@@ -9,0 +16,0 @@

14

dialect/abstractSqlDialect.d.ts

@@ -1,2 +0,2 @@

import { QueryFilter, Scalar, QueryFilterFieldOperatorMap, QuerySort, QueryPager, FieldKey, QueryProject, Type, QueryOptions, QueryDialect, QueryFilterOptions, QueryComparisonOptions, QueryFilterMap, QueryProjectOptions, QueryRaw, QueryProjectOperation, QuerySearch, QueryCriteria } from '../type/index.js';
import { QueryFilter, Scalar, QueryFilterFieldOperatorMap, QuerySort, QueryPager, FieldKey, QueryProject, Type, QueryOptions, QueryDialect, QueryFilterOptions, QueryComparisonOptions, QueryFilterMap, QueryProjectOptions, QuerySearch, QueryCriteria } from '../type/index.js';
export declare abstract class AbstractSqlDialect implements QueryDialect {

@@ -7,5 +7,4 @@ readonly escapeIdChar: '`' | '"';

constructor(escapeIdChar?: '`' | '"', beginTransactionCommand?: string);
criteria<E, P extends QueryProject<E>>(entity: Type<E>, qm: QueryCriteria<E>, project: P, opts?: QueryOptions): string;
projectFields<E, P extends QueryProject<E>>(entity: Type<E>, project: P, opts?: QueryProjectOptions): string;
projectOperation<E>(operation: QueryProjectOperation<E>, alias: string): QueryRaw;
criteria<E>(entity: Type<E>, qm: QueryCriteria<E>, project: QueryProject<E>, opts?: QueryOptions): string;
projectFields<E>(entity: Type<E>, project: QueryProject<E>, opts: QueryProjectOptions): string;
projectRelations<E>(entity: Type<E>, project?: QueryProject<E>, { prefix }?: {

@@ -18,11 +17,10 @@ prefix?: string;

select<E>(entity: Type<E>, project: QueryProject<E>, opts?: QueryOptions): string;
where<E>(entity: Type<E>, filter?: QueryFilter<E>, opts?: QueryFilterOptions): string;
where<E>(entity: Type<E>, filter: QueryFilter<E>, opts: QueryFilterOptions): string;
compare<E, K extends keyof QueryFilterMap<E>>(entity: Type<E>, key: K, val: QueryFilterMap<E>[K], opts?: QueryComparisonOptions): string;
compareFieldOperator<E, K extends keyof QueryFilterFieldOperatorMap<E>>(entity: Type<E>, key: FieldKey<E>, op: K, val: QueryFilterFieldOperatorMap<E>[K], opts?: QueryOptions): string;
getComparisonKey<E>(entity: Type<E>, key: FieldKey<E>, { prefix }?: QueryOptions): Scalar;
group<E>(entity: Type<E>, fields: readonly FieldKey<E>[]): string;
sort<E>(entity: Type<E>, sort: QuerySort<E>, { prefix }?: QueryOptions): string;
sort<E>(entity: Type<E>, sort: QuerySort<E>, { prefix }: QueryOptions): string;
pager(opts: QueryPager): string;
count<E>(entity: Type<E>, qm?: QuerySearch<E>, opts?: QueryOptions): string;
find<E, P extends QueryProject<E>>(entity: Type<E>, qm: QueryCriteria<E>, project?: P, opts?: QueryOptions): string;
find<E>(entity: Type<E>, qm: QueryCriteria<E>, project?: QueryProject<E>, opts?: QueryOptions): string;
insert<E>(entity: Type<E>, payload: E | E[]): string;

@@ -29,0 +27,0 @@ update<E>(entity: Type<E>, qm: QuerySearch<E>, payload: E, opts?: QueryOptions): string;

@@ -6,3 +6,3 @@ {

"license": "MIT",
"version": "0.3.0",
"version": "0.3.1",
"type": "module",

@@ -9,0 +9,0 @@ "main": "./index.js",

@@ -1,7 +0,7 @@

import type { IdValue, Merge, Querier, QueryCriteria, QueryOneCriteria, QueryOptions, QueryProject, QuerySearch, RelationKey, Repository, Type } from '../type/index.js';
import type { IdValue, Querier, QueryCriteria, QueryOneCriteria, QueryOptions, QueryProject, QuerySearch, RelationKey, Repository, Type } from '../type/index.js';
export declare abstract class AbstractQuerier implements Querier {
findOneById<E, P extends QueryProject<E>>(entity: Type<E>, id: IdValue<E>, project?: P): Promise<Merge<E, P>>;
findOne<E, P extends QueryProject<E>>(entity: Type<E>, qm: QueryOneCriteria<E>, project?: P): Promise<Merge<E, P>>;
abstract findMany<E, P extends QueryProject<E>>(entity: Type<E>, qm: QueryCriteria<E>, project?: P): Promise<Merge<E, P>[]>;
findManyAndCount<E, P extends QueryProject<E>>(entity: Type<E>, qm: QueryCriteria<E>, project?: P): Promise<[Merge<E, P>[], number]>;
findOneById<E>(entity: Type<E>, id: IdValue<E>, project?: QueryProject<E>): Promise<E>;
findOne<E>(entity: Type<E>, qm: QueryOneCriteria<E>, project?: QueryProject<E>): Promise<E>;
abstract findMany<E>(entity: Type<E>, qm: QueryCriteria<E>, project?: QueryProject<E>): Promise<E[]>;
findManyAndCount<E>(entity: Type<E>, qm: QueryCriteria<E>, project?: QueryProject<E>): Promise<[E[], number]>;
abstract count<E>(entity: Type<E>, qm?: QuerySearch<E>): Promise<number>;

@@ -8,0 +8,0 @@ insertOne<E>(entity: Type<E>, payload: E): Promise<IdValue<E>>;

@@ -224,2 +224,2 @@ import { getMeta } from '../entity/decorator/index.js';

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstractQuerier.js","sourceRoot":"","sources":["../../src/querier/abstractQuerier.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,OAAO,EAAE,MAAM,8BAA8B,CAAC;AACvD,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,sBAAsB,EAAE,uBAAuB,EAAE,MAAM,kBAAkB,CAAC;AACnG,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAE3D,MAAM,OAAgB,eAAe;IACnC,WAAW,CAA+B,MAAe,EAAE,EAAc,EAAE,OAAW;QACpF,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,EAAE,OAAO,CAAC,CAAC;IACxD,CAAC;IAED,KAAK,CAAC,OAAO,CAA+B,MAAe,EAAE,EAAuB,EAAE,OAAW;QAC/F,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,EAAE,GAAG,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC;QACxE,OAAO,IAAI,CAAC,CAAC,CAAC,CAAC;IACjB,CAAC;IAQD,gBAAgB,CAA+B,MAAe,EAAE,EAAoB,EAAE,OAAW;QAC/F,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,EAAE,EAAE,OAAO,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;IACnF,CAAC;IAID,KAAK,CAAC,SAAS,CAAI,MAAe,EAAE,OAAU;QAC5C,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;QACtD,OAAO,EAAE,CAAC;IACZ,CAAC;IAID,aAAa,CAAI,MAAe,EAAE,EAAc,EAAE,OAAU;QAC1D,OAAO,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,EAAE,OAAO,CAAC,CAAC;IAC3D,CAAC;IAID,aAAa,CAAI,MAAe,EAAE,EAAc,EAAE,IAAmB;QACnE,OAAO,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;IACxD,CAAC;IAID,KAAK,CAAC,OAAO,CAAI,MAAe,EAAE,OAAU;QAC1C,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;QACpD,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,KAAK,CAAC,QAAQ,CAAI,MAAe,EAAE,OAAY;QAC7C,MAAM,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;QAC7B,MAAM,GAAG,GAAiB,EAAE,CAAC;QAC7B,MAAM,OAAO,GAAQ,EAAE,CAAC;QACxB,MAAM,OAAO,GAAQ,EAAE,CAAC;QAExB,KAAK,MAAM,EAAE,IAAI,OAAO,EAAE;YACxB,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE;gBACf,IAAI,OAAO,CAAC,EAAE,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE;oBAC5B,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;iBACvB;qBAAM;oBACL,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;iBAClB;aACF;iBAAM;gBACL,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;aAClB;SACF;QAED,OAAO,OAAO,CAAC,GAAG,CAAC;YACjB,GAAG,GAAG;YACN,GAAG,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;YACjE,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,EAAE,EAAE,EAAE;gBAC1B,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,CAAC;gBACtC,MAAM,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,EAAE,EAAE,IAAS,CAAC,CAAC;gBAChD,OAAO,EAAE,CAAC;YACZ,CAAC,CAAC;SACH,CAAC,CAAC;IACL,CAAC;IAES,KAAK,CAAC,mBAAmB,CAAI,MAAe,EAAE,OAAY,EAAE,OAAwB;QAC5F,MAAM,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;QAC7B,MAAM,SAAS,GAAG,sBAAsB,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QAExD,KAAK,MAAM,MAAM,IAAI,SAAS,EAAE;YAC9B,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;YACvC,MAAM,SAAS,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;YACnC,MAAM,UAAU,GAAG,KAAK,CAAC,OAAO,CAAC,MAAgB,CAAC,CAAC,CAAC;YACpD,MAAM,QAAQ,GACZ,UAAU,KAAK,IAAI,IAAI,UAAU,KAAK,SAAS;gBAC7C,CAAC,CAAC,EAAE;gBACJ,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC;oBAC3B,CAAC,CAAC,EAAE,QAAQ,EAAE,UAAU,EAAE;oBAC1B,CAAC,CAAC,UAAU,CAAC;YACjB,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;YAE7C,IAAI,OAAO,CAAC,OAAO,EAAE;gBACnB,MAAM,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;gBAC/C,MAAM,aAAa,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;gBACxC,MAAM,WAAW,GAAG,OAAO,CAAC,aAAa,CAAC,CAAC;gBAC3C,MAAM,YAAY,GAAG,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CACnE,WAAW,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,KAAK,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CACjG,CAAC;gBACF,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,QAAQ,CACvC,aAAa,EACb;oBACE,OAAO,EAAE;wBACP,CAAC,UAAU,CAAC,EAAE,GAAG;qBAClB;iBACF,EACD;oBACE,CAAC,UAAU,CAAC,EAAE,IAAI;oBAClB,CAAC,YAAY,CAAC,EAAE;wBACd,GAAG,QAAQ;wBACX,SAAS,EAAE,IAAI;qBAChB;iBACF,CACF,CAAC;gBACF,MAAM,MAAM,GAAG,aAAa,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,CAAC;gBAClG,IAAI,CAAC,oBAAoB,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,EAAE,UAAU,EAAE,MAAM,CAAC,CAAC;aACzE;iBAAM,IAAI,OAAO,CAAC,WAAW,KAAK,IAAI,EAAE;gBACvC,MAAM,YAAY,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;gBACnD,IAAI,QAAQ,CAAC,QAAQ,EAAE;oBACrB,IAAI,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE;wBACpC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE;4BAC7C,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;yBACtC;qBACF;yBAAM,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE;wBAC3C,QAAQ,CAAC,QAAQ,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC;qBACxC;iBACF;gBACD,QAAQ,CAAC,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,EAAE,GAAG,EAAE,CAAC;gBAC3C,MAAM,EAAE,QAAQ,EAAE,UAAU,EAAE,GAAG,KAAK,EAAE,GAAG,QAAQ,CAAC;gBACpD,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,KAAK,EAAE,UAAU,CAAC,CAAC;gBACjE,IAAI,CAAC,oBAAoB,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,EAAE,YAAY,EAAE,MAAM,CAAC,CAAC;aAC3E;SACF;IACH,CAAC;IAES,oBAAoB,CAC5B,OAAY,EACZ,QAAa,EACb,WAAmB,EACnB,YAAoB,EACpB,MAAc;QAEd,MAAM,mBAAmB,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE;YACzD,MAAM,OAAO,GAAG,KAAK,CAAC,YAAY,CAAC,CAAC;YACpC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE;gBACjB,GAAG,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC;aACnB;YACD,GAAG,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACzB,OAAO,GAAG,CAAC;QACb,CAAC,EAAE,EAAE,CAAC,CAAC;QAEP,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE;YAC5B,MAAM,QAAQ,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;YACrC,MAAM,CAAC,MAAM,CAAC,GAAG,mBAAmB,CAAC,QAAQ,CAAC,CAAC;SAChD;IACH,CAAC;IAES,KAAK,CAAC,eAAe,CAAI,MAAe,EAAE,OAAY;QAC9D,MAAM,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;QAC7B,MAAM,OAAO,CAAC,GAAG,CACf,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE;YACjB,MAAM,OAAO,GAAG,uBAAuB,CAAC,IAAI,EAAE,EAAE,EAAE,SAAS,CAAC,CAAC;YAC7D,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;gBACnB,OAAO;aACR;YACD,OAAO,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,EAAE,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;QACrF,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAES,KAAK,CAAC,eAAe,CAAI,MAAe,EAAE,QAAwB,EAAE,OAAU;QACtF,MAAM,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;QAC7B,MAAM,OAAO,GAAG,uBAAuB,CAAC,IAAI,EAAE,OAAO,EAAE,SAAS,CAAC,CAAC;QAElE,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;YACnB,OAAO;SACR;QAED,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,QAAQ,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;QAEhE,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;QAElD,MAAM,OAAO,CAAC,GAAG,CACf,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CACb,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,EAAE,GAAG,OAAO,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,CAAC,CAAC,CAC7G,CACF,CAAC;IACJ,CAAC;IAES,KAAK,CAAC,eAAe,CAAI,MAAe,EAAE,GAAiB,EAAE,IAAmB;QACxF,MAAM,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;QAC7B,MAAM,OAAO,GAAG,uBAAuB,CAAC,IAAI,EAAE,IAAI,CAAC,SAAc,EAAE,QAAQ,CAAC,CAAC;QAE7E,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE;YAC5B,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;YACvC,MAAM,SAAS,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;YACnC,MAAM,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;YAC/C,IAAI,OAAO,CAAC,OAAO,EAAE;gBACnB,MAAM,aAAa,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;gBACxC,MAAM,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,EAAE,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;gBAC/E,OAAO;aACR;YACD,MAAM,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,EAAE,CAAC,UAAU,CAAC,EAAE,GAAG,EAAE,EAAE,IAAI,CAAC,CAAC;SAC/D;IACH,CAAC;IAES,KAAK,CAAC,YAAY,CAAI,MAAe,EAAE,OAAU,EAAE,MAAsB,EAAE,QAAkB;QACrG,MAAM,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;QAC7B,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAC5B,MAAM,EAAE,MAAM,EAAE,YAAY,EAAE,WAAW,EAAE,UAAU,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAC1F,MAAM,SAAS,GAAG,YAAY,EAAE,CAAC;QACjC,MAAM,UAAU,GAAG,OAAO,CAAC,MAAM,CAAkC,CAAC;QAEpE,IAAI,WAAW,KAAK,IAAI,IAAI,WAAW,KAAK,IAAI,EAAE;YAChD,IAAI,OAAO,EAAE;gBACX,MAAM,UAAU,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;gBAEvC,MAAM,aAAa,GAAG,OAAO,EAAE,CAAC;gBAChC,IAAI,QAAQ,EAAE;oBACZ,MAAM,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,EAAE,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;iBACzE;gBACD,IAAI,UAAU,EAAE;oBACd,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC;oBAC5D,MAAM,aAAa,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;wBAC7C,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE;wBACzB,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,KAAK;qBAC7B,CAAC,CAAC,CAAC;oBACJ,MAAM,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,aAAa,CAAC,CAAC;iBACrD;gBACD,OAAO;aACR;YACD,MAAM,YAAY,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;YAC3C,IAAI,QAAQ,EAAE;gBACZ,MAAM,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,EAAE,OAAO,EAAE,EAAE,CAAC,YAAY,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;aACvE;YACD,IAAI,UAAU,EAAE;gBACd,KAAK,MAAM,EAAE,IAAI,UAAU,EAAE;oBAC3B,EAAE,CAAC,YAAY,CAAC,GAAG,EAAE,CAAC;iBACvB;gBACD,MAAM,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC;aAC5C;YACD,OAAO;SACR;QAED,IAAI,WAAW,KAAK,IAAI,EAAE;YACxB,MAAM,YAAY,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;YAC3C,IAAI,UAAU,KAAK,IAAI,EAAE;gBACvB,MAAM,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,EAAE,OAAO,EAAE,EAAE,CAAC,YAAY,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;gBACtE,OAAO;aACR;YACD,MAAM,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,GAAG,UAAU,EAAE,CAAC,YAAY,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;YACrE,OAAO;SACR;QAED,IAAI,WAAW,KAAK,IAAI,IAAI,UAAU,EAAE;YACtC,MAAM,UAAU,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;YACvC,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC;YAChE,MAAM,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,EAAE,EAAE,EAAE,CAAC,UAAU,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC;YACpE,OAAO;SACR;IACH,CAAC;IAED,aAAa,CAAI,MAAe;QAC9B,OAAO,IAAI,iBAAiB,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;IAC7C,CAAC;IAID,KAAK,CAAC,WAAW,CAAI,QAA0B;QAC7C,IAAI;YACF,MAAM,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC9B,MAAM,GAAG,GAAG,MAAM,QAAQ,EAAE,CAAC;YAC7B,MAAM,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC/B,OAAO,GAAG,CAAC;SACZ;QAAC,OAAO,GAAG,EAAE;YACZ,MAAM,IAAI,CAAC,mBAAmB,EAAE,CAAC;YACjC,MAAM,GAAG,CAAC;SACX;IACH,CAAC;CASF","sourcesContent":["import type {\n  IdValue,\n  Merge,\n  Querier,\n  Query,\n  QueryCriteria,\n  QueryOneCriteria,\n  QueryOptions,\n  QueryProject,\n  QuerySearch,\n  RelationKey,\n  RelationValue,\n  Repository,\n  Type,\n} from '../type/index.js';\nimport { getMeta } from '../entity/decorator/index.js';\nimport { clone, getKeys, getProjectRelationKeys, getPersistableRelations } from '../util/index.js';\nimport { GenericRepository } from '../repository/index.js';\n\nexport abstract class AbstractQuerier implements Querier {\n  findOneById<E, P extends QueryProject<E>>(entity: Type<E>, id: IdValue<E>, project?: P) {\n    return this.findOne(entity, { $filter: id }, project);\n  }\n\n  async findOne<E, P extends QueryProject<E>>(entity: Type<E>, qm: QueryOneCriteria<E>, project?: P) {\n    const rows = await this.findMany(entity, { ...qm, $limit: 1 }, project);\n    return rows[0];\n  }\n\n  abstract findMany<E, P extends QueryProject<E>>(\n    entity: Type<E>,\n    qm: QueryCriteria<E>,\n    project?: P,\n  ): Promise<Merge<E, P>[]>;\n\n  findManyAndCount<E, P extends QueryProject<E>>(entity: Type<E>, qm: QueryCriteria<E>, project?: P) {\n    return Promise.all([this.findMany(entity, qm, project), this.count(entity, qm)]);\n  }\n\n  abstract count<E>(entity: Type<E>, qm?: QuerySearch<E>): Promise<number>;\n\n  async insertOne<E>(entity: Type<E>, payload: E) {\n    const [id] = await this.insertMany(entity, [payload]);\n    return id;\n  }\n\n  abstract insertMany<E>(entity: Type<E>, payload: E[]): Promise<IdValue<E>[]>;\n\n  updateOneById<E>(entity: Type<E>, id: IdValue<E>, payload: E) {\n    return this.updateMany(entity, { $filter: id }, payload);\n  }\n\n  abstract updateMany<E>(entity: Type<E>, qm: QuerySearch<E>, payload: E): Promise<number>;\n\n  deleteOneById<E>(entity: Type<E>, id: IdValue<E>, opts?: QueryOptions) {\n    return this.deleteMany(entity, { $filter: id }, opts);\n  }\n\n  abstract deleteMany<E>(entity: Type<E>, qm: QuerySearch<E>, opts?: QueryOptions): Promise<number>;\n\n  async saveOne<E>(entity: Type<E>, payload: E) {\n    const [id] = await this.saveMany(entity, [payload]);\n    return id;\n  }\n\n  async saveMany<E>(entity: Type<E>, payload: E[]) {\n    const meta = getMeta(entity);\n    const ids: IdValue<E>[] = [];\n    const updates: E[] = [];\n    const inserts: E[] = [];\n\n    for (const it of payload) {\n      if (it[meta.id]) {\n        if (getKeys(it).length === 1) {\n          ids.push(it[meta.id]);\n        } else {\n          updates.push(it);\n        }\n      } else {\n        inserts.push(it);\n      }\n    }\n\n    return Promise.all([\n      ...ids,\n      ...(inserts.length ? await this.insertMany(entity, inserts) : []),\n      ...updates.map(async (it) => {\n        const { [meta.id]: id, ...data } = it;\n        await this.updateOneById(entity, id, data as E);\n        return id;\n      }),\n    ]);\n  }\n\n  protected async findToManyRelations<E>(entity: Type<E>, payload: E[], project: QueryProject<E>) {\n    const meta = getMeta(entity);\n    const relations = getProjectRelationKeys(meta, project);\n\n    for (const relKey of relations) {\n      const relOpts = meta.relations[relKey];\n      const relEntity = relOpts.entity();\n      const relProject = clone(project[relKey as string]);\n      const relQuery: Query<unknown> =\n        relProject === true || relProject === undefined\n          ? {}\n          : Array.isArray(relProject)\n          ? { $project: relProject }\n          : relProject;\n      const ids = payload.map((it) => it[meta.id]);\n\n      if (relOpts.through) {\n        const localField = relOpts.references[0].local;\n        const throughEntity = relOpts.through();\n        const throughMeta = getMeta(throughEntity);\n        const targetRelKey = Object.keys(throughMeta.relations).find((key) =>\n          throughMeta.relations[key].references.some(({ local }) => local === relOpts.references[1].local),\n        );\n        const throughFounds = await this.findMany(\n          throughEntity,\n          {\n            $filter: {\n              [localField]: ids,\n            },\n          },\n          {\n            [localField]: true,\n            [targetRelKey]: {\n              ...relQuery,\n              $required: true,\n            },\n          },\n        );\n        const founds = throughFounds.map((it) => ({ ...it[targetRelKey], [localField]: it[localField] }));\n        this.putChildrenInParents(payload, founds, meta.id, localField, relKey);\n      } else if (relOpts.cardinality === '1m') {\n        const foreignField = relOpts.references[0].foreign;\n        if (relQuery.$project) {\n          if (Array.isArray(relQuery.$project)) {\n            if (!relQuery.$project.includes(foreignField)) {\n              relQuery.$project.push(foreignField);\n            }\n          } else if (!relQuery.$project[foreignField]) {\n            relQuery.$project[foreignField] = true;\n          }\n        }\n        relQuery.$filter = { [foreignField]: ids };\n        const { $project: relProject, ...relQm } = relQuery;\n        const founds = await this.findMany(relEntity, relQm, relProject);\n        this.putChildrenInParents(payload, founds, meta.id, foreignField, relKey);\n      }\n    }\n  }\n\n  protected putChildrenInParents<E>(\n    parents: E[],\n    children: E[],\n    parentIdKey: string,\n    referenceKey: string,\n    relKey: string,\n  ): void {\n    const childrenByParentMap = children.reduce((acc, child) => {\n      const parenId = child[referenceKey];\n      if (!acc[parenId]) {\n        acc[parenId] = [];\n      }\n      acc[parenId].push(child);\n      return acc;\n    }, {});\n\n    for (const parent of parents) {\n      const parentId = parent[parentIdKey];\n      parent[relKey] = childrenByParentMap[parentId];\n    }\n  }\n\n  protected async insertRelations<E>(entity: Type<E>, payload: E[]) {\n    const meta = getMeta(entity);\n    await Promise.all(\n      payload.map((it) => {\n        const relKeys = getPersistableRelations(meta, it, 'persist');\n        if (!relKeys.length) {\n          return;\n        }\n        return Promise.all(relKeys.map((relKey) => this.saveRelation(entity, it, relKey)));\n      }),\n    );\n  }\n\n  protected async updateRelations<E>(entity: Type<E>, criteria: QuerySearch<E>, payload: E) {\n    const meta = getMeta(entity);\n    const relKeys = getPersistableRelations(meta, payload, 'persist');\n\n    if (!relKeys.length) {\n      return;\n    }\n\n    const founds = await this.findMany(entity, criteria, [meta.id]);\n\n    const ids = founds.map((found) => found[meta.id]);\n\n    await Promise.all(\n      ids.map((id) =>\n        Promise.all(relKeys.map((relKey) => this.saveRelation(entity, { ...payload, [meta.id]: id }, relKey, true))),\n      ),\n    );\n  }\n\n  protected async deleteRelations<E>(entity: Type<E>, ids: IdValue<E>[], opts?: QueryOptions) {\n    const meta = getMeta(entity);\n    const relKeys = getPersistableRelations(meta, meta.relations as E, 'delete');\n\n    for (const relKey of relKeys) {\n      const relOpts = meta.relations[relKey];\n      const relEntity = relOpts.entity();\n      const localField = relOpts.references[0].local;\n      if (relOpts.through) {\n        const throughEntity = relOpts.through();\n        await this.deleteMany(throughEntity, { $filter: { [localField]: ids } }, opts);\n        return;\n      }\n      await this.deleteMany(relEntity, { [localField]: ids }, opts);\n    }\n  }\n\n  protected async saveRelation<E>(entity: Type<E>, payload: E, relKey: RelationKey<E>, isUpdate?: boolean) {\n    const meta = getMeta(entity);\n    const id = payload[meta.id];\n    const { entity: entityGetter, cardinality, references, through } = meta.relations[relKey];\n    const relEntity = entityGetter();\n    const relPayload = payload[relKey] as unknown as RelationValue<E>[];\n\n    if (cardinality === '1m' || cardinality === 'mm') {\n      if (through) {\n        const localField = references[0].local;\n\n        const throughEntity = through();\n        if (isUpdate) {\n          await this.deleteMany(throughEntity, { $filter: { [localField]: id } });\n        }\n        if (relPayload) {\n          const savedIds = await this.saveMany(relEntity, relPayload);\n          const throughBodies = savedIds.map((relId) => ({\n            [references[0].local]: id,\n            [references[1].local]: relId,\n          }));\n          await this.insertMany(throughEntity, throughBodies);\n        }\n        return;\n      }\n      const foreignField = references[0].foreign;\n      if (isUpdate) {\n        await this.deleteMany(relEntity, { $filter: { [foreignField]: id } });\n      }\n      if (relPayload) {\n        for (const it of relPayload) {\n          it[foreignField] = id;\n        }\n        await this.saveMany(relEntity, relPayload);\n      }\n      return;\n    }\n\n    if (cardinality === '11') {\n      const foreignField = references[0].foreign;\n      if (relPayload === null) {\n        await this.deleteMany(relEntity, { $filter: { [foreignField]: id } });\n        return;\n      }\n      await this.saveOne(relEntity, { ...relPayload, [foreignField]: id });\n      return;\n    }\n\n    if (cardinality === 'm1' && relPayload) {\n      const localField = references[0].local;\n      const referenceId = await this.insertOne(relEntity, relPayload);\n      await this.updateOneById(entity, id, { [localField]: referenceId });\n      return;\n    }\n  }\n\n  getRepository<E>(entity: Type<E>): Repository<E> {\n    return new GenericRepository(entity, this);\n  }\n\n  abstract readonly hasOpenTransaction: boolean;\n\n  async transaction<T>(callback: () => Promise<T>) {\n    try {\n      await this.beginTransaction();\n      const res = await callback();\n      await this.commitTransaction();\n      return res;\n    } catch (err) {\n      await this.rollbackTransaction();\n      throw err;\n    }\n  }\n\n  abstract beginTransaction(): Promise<void>;\n\n  abstract commitTransaction(): Promise<void>;\n\n  abstract rollbackTransaction(): Promise<void>;\n\n  abstract release(): Promise<void>;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstractQuerier.js","sourceRoot":"","sources":["../../src/querier/abstractQuerier.ts"],"names":[],"mappings":"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","sourcesContent":["import type {\n  IdValue,\n  Querier,\n  Query,\n  QueryCriteria,\n  QueryOneCriteria,\n  QueryOptions,\n  QueryProject,\n  QuerySearch,\n  RelationKey,\n  RelationValue,\n  Repository,\n  Type,\n} from '../type/index.js';\nimport { getMeta } from '../entity/decorator/index.js';\nimport { clone, getKeys, getProjectRelationKeys, getPersistableRelations } from '../util/index.js';\nimport { GenericRepository } from '../repository/index.js';\n\nexport abstract class AbstractQuerier implements Querier {\n  findOneById<E>(entity: Type<E>, id: IdValue<E>, project?: QueryProject<E>) {\n    return this.findOne(entity, { $filter: id }, project);\n  }\n\n  async findOne<E>(entity: Type<E>, qm: QueryOneCriteria<E>, project?: QueryProject<E>) {\n    const rows = await this.findMany(entity, { ...qm, $limit: 1 }, project);\n    return rows[0];\n  }\n\n  abstract findMany<E>(entity: Type<E>, qm: QueryCriteria<E>, project?: QueryProject<E>): Promise<E[]>;\n\n  findManyAndCount<E>(entity: Type<E>, qm: QueryCriteria<E>, project?: QueryProject<E>) {\n    return Promise.all([this.findMany(entity, qm, project), this.count(entity, qm)]);\n  }\n\n  abstract count<E>(entity: Type<E>, qm?: QuerySearch<E>): Promise<number>;\n\n  async insertOne<E>(entity: Type<E>, payload: E) {\n    const [id] = await this.insertMany(entity, [payload]);\n    return id;\n  }\n\n  abstract insertMany<E>(entity: Type<E>, payload: E[]): Promise<IdValue<E>[]>;\n\n  updateOneById<E>(entity: Type<E>, id: IdValue<E>, payload: E) {\n    return this.updateMany(entity, { $filter: id }, payload);\n  }\n\n  abstract updateMany<E>(entity: Type<E>, qm: QuerySearch<E>, payload: E): Promise<number>;\n\n  deleteOneById<E>(entity: Type<E>, id: IdValue<E>, opts?: QueryOptions) {\n    return this.deleteMany(entity, { $filter: id }, opts);\n  }\n\n  abstract deleteMany<E>(entity: Type<E>, qm: QuerySearch<E>, opts?: QueryOptions): Promise<number>;\n\n  async saveOne<E>(entity: Type<E>, payload: E) {\n    const [id] = await this.saveMany(entity, [payload]);\n    return id;\n  }\n\n  async saveMany<E>(entity: Type<E>, payload: E[]) {\n    const meta = getMeta(entity);\n    const ids: IdValue<E>[] = [];\n    const updates: E[] = [];\n    const inserts: E[] = [];\n\n    for (const it of payload) {\n      if (it[meta.id]) {\n        if (getKeys(it).length === 1) {\n          ids.push(it[meta.id]);\n        } else {\n          updates.push(it);\n        }\n      } else {\n        inserts.push(it);\n      }\n    }\n\n    return Promise.all([\n      ...ids,\n      ...(inserts.length ? await this.insertMany(entity, inserts) : []),\n      ...updates.map(async (it) => {\n        const { [meta.id]: id, ...data } = it;\n        await this.updateOneById(entity, id, data as E);\n        return id;\n      }),\n    ]);\n  }\n\n  protected async findToManyRelations<E>(entity: Type<E>, payload: E[], project: QueryProject<E>) {\n    const meta = getMeta(entity);\n    const relations = getProjectRelationKeys(meta, project);\n\n    for (const relKey of relations) {\n      const relOpts = meta.relations[relKey];\n      const relEntity = relOpts.entity();\n      const relProject = clone(project[relKey as string]);\n      const relQuery: Query<unknown> =\n        relProject === true || relProject === undefined\n          ? {}\n          : Array.isArray(relProject)\n          ? { $project: relProject }\n          : relProject;\n      const ids = payload.map((it) => it[meta.id]);\n\n      if (relOpts.through) {\n        const localField = relOpts.references[0].local;\n        const throughEntity = relOpts.through();\n        const throughMeta = getMeta(throughEntity);\n        const targetRelKey = Object.keys(throughMeta.relations).find((key) =>\n          throughMeta.relations[key].references.some(({ local }) => local === relOpts.references[1].local),\n        );\n        const throughFounds = await this.findMany(\n          throughEntity,\n          {\n            $filter: {\n              [localField]: ids,\n            },\n          },\n          {\n            [localField]: true,\n            [targetRelKey]: {\n              ...relQuery,\n              $required: true,\n            },\n          },\n        );\n        const founds = throughFounds.map((it) => ({ ...it[targetRelKey], [localField]: it[localField] }));\n        this.putChildrenInParents(payload, founds, meta.id, localField, relKey);\n      } else if (relOpts.cardinality === '1m') {\n        const foreignField = relOpts.references[0].foreign;\n        if (relQuery.$project) {\n          if (Array.isArray(relQuery.$project)) {\n            if (!relQuery.$project.includes(foreignField)) {\n              relQuery.$project.push(foreignField);\n            }\n          } else if (!relQuery.$project[foreignField]) {\n            relQuery.$project[foreignField] = true;\n          }\n        }\n        relQuery.$filter = { [foreignField]: ids };\n        const { $project: relProject, ...relQm } = relQuery;\n        const founds = await this.findMany(relEntity, relQm, relProject);\n        this.putChildrenInParents(payload, founds, meta.id, foreignField, relKey);\n      }\n    }\n  }\n\n  protected putChildrenInParents<E>(\n    parents: E[],\n    children: E[],\n    parentIdKey: string,\n    referenceKey: string,\n    relKey: string,\n  ): void {\n    const childrenByParentMap = children.reduce((acc, child) => {\n      const parenId = child[referenceKey];\n      if (!acc[parenId]) {\n        acc[parenId] = [];\n      }\n      acc[parenId].push(child);\n      return acc;\n    }, {});\n\n    for (const parent of parents) {\n      const parentId = parent[parentIdKey];\n      parent[relKey] = childrenByParentMap[parentId];\n    }\n  }\n\n  protected async insertRelations<E>(entity: Type<E>, payload: E[]) {\n    const meta = getMeta(entity);\n    await Promise.all(\n      payload.map((it) => {\n        const relKeys = getPersistableRelations(meta, it, 'persist');\n        if (!relKeys.length) {\n          return;\n        }\n        return Promise.all(relKeys.map((relKey) => this.saveRelation(entity, it, relKey)));\n      }),\n    );\n  }\n\n  protected async updateRelations<E>(entity: Type<E>, criteria: QuerySearch<E>, payload: E) {\n    const meta = getMeta(entity);\n    const relKeys = getPersistableRelations(meta, payload, 'persist');\n\n    if (!relKeys.length) {\n      return;\n    }\n\n    const founds = await this.findMany(entity, criteria, [meta.id]);\n\n    const ids = founds.map((found) => found[meta.id]);\n\n    await Promise.all(\n      ids.map((id) =>\n        Promise.all(relKeys.map((relKey) => this.saveRelation(entity, { ...payload, [meta.id]: id }, relKey, true))),\n      ),\n    );\n  }\n\n  protected async deleteRelations<E>(entity: Type<E>, ids: IdValue<E>[], opts?: QueryOptions) {\n    const meta = getMeta(entity);\n    const relKeys = getPersistableRelations(meta, meta.relations as E, 'delete');\n\n    for (const relKey of relKeys) {\n      const relOpts = meta.relations[relKey];\n      const relEntity = relOpts.entity();\n      const localField = relOpts.references[0].local;\n      if (relOpts.through) {\n        const throughEntity = relOpts.through();\n        await this.deleteMany(throughEntity, { $filter: { [localField]: ids } }, opts);\n        return;\n      }\n      await this.deleteMany(relEntity, { [localField]: ids }, opts);\n    }\n  }\n\n  protected async saveRelation<E>(entity: Type<E>, payload: E, relKey: RelationKey<E>, isUpdate?: boolean) {\n    const meta = getMeta(entity);\n    const id = payload[meta.id];\n    const { entity: entityGetter, cardinality, references, through } = meta.relations[relKey];\n    const relEntity = entityGetter();\n    const relPayload = payload[relKey] as unknown as RelationValue<E>[];\n\n    if (cardinality === '1m' || cardinality === 'mm') {\n      if (through) {\n        const localField = references[0].local;\n\n        const throughEntity = through();\n        if (isUpdate) {\n          await this.deleteMany(throughEntity, { $filter: { [localField]: id } });\n        }\n        if (relPayload) {\n          const savedIds = await this.saveMany(relEntity, relPayload);\n          const throughBodies = savedIds.map((relId) => ({\n            [references[0].local]: id,\n            [references[1].local]: relId,\n          }));\n          await this.insertMany(throughEntity, throughBodies);\n        }\n        return;\n      }\n      const foreignField = references[0].foreign;\n      if (isUpdate) {\n        await this.deleteMany(relEntity, { $filter: { [foreignField]: id } });\n      }\n      if (relPayload) {\n        for (const it of relPayload) {\n          it[foreignField] = id;\n        }\n        await this.saveMany(relEntity, relPayload);\n      }\n      return;\n    }\n\n    if (cardinality === '11') {\n      const foreignField = references[0].foreign;\n      if (relPayload === null) {\n        await this.deleteMany(relEntity, { $filter: { [foreignField]: id } });\n        return;\n      }\n      await this.saveOne(relEntity, { ...relPayload, [foreignField]: id });\n      return;\n    }\n\n    if (cardinality === 'm1' && relPayload) {\n      const localField = references[0].local;\n      const referenceId = await this.insertOne(relEntity, relPayload);\n      await this.updateOneById(entity, id, { [localField]: referenceId });\n      return;\n    }\n  }\n\n  getRepository<E>(entity: Type<E>): Repository<E> {\n    return new GenericRepository(entity, this);\n  }\n\n  abstract readonly hasOpenTransaction: boolean;\n\n  async transaction<T>(callback: () => Promise<T>) {\n    try {\n      await this.beginTransaction();\n      const res = await callback();\n      await this.commitTransaction();\n      return res;\n    } catch (err) {\n      await this.rollbackTransaction();\n      throw err;\n    }\n  }\n\n  abstract beginTransaction(): Promise<void>;\n\n  abstract commitTransaction(): Promise<void>;\n\n  abstract rollbackTransaction(): Promise<void>;\n\n  abstract release(): Promise<void>;\n}\n"]}

@@ -1,2 +0,2 @@

import { Type, QueryOptions, QueryUpdateResult, QueryProject, Merge, QuerySearch, QueryCriteria } from '../type/index.js';
import { Type, QueryOptions, QueryUpdateResult, QueryProject, QuerySearch, QueryCriteria } from '../type/index.js';
import { AbstractSqlDialect } from '../dialect/index.js';

@@ -18,3 +18,3 @@ import { AbstractQuerier } from './abstractQuerier.js';

abstract run(query: string): Promise<QueryUpdateResult>;
findMany<E, P extends QueryProject<E>>(entity: Type<E>, qm: QueryCriteria<E>, project?: P): Promise<Merge<E, P>[]>;
findMany<E>(entity: Type<E>, qm: QueryCriteria<E>, project?: QueryProject<E>): Promise<E[]>;
count<E>(entity: Type<E>, qm?: QuerySearch<E>): Promise<number>;

@@ -21,0 +21,0 @@ insertMany<E>(entity: Type<E>, payload: E[]): Promise<E[import("../type/entity.js").IdKey<E>][]>;

@@ -84,2 +84,2 @@ import { unflatObjects, clone } from '../util/index.js';

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstractSqlQuerier.js","sourceRoot":"","sources":["../../src/querier/abstractSqlQuerier.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Type,\n  QueryOptions,\n  QueryUpdateResult,\n  QueryProject,\n  Merge,\n  QuerySearch,\n  QueryCriteria,\n} from '../type/index.js';\nimport { unflatObjects, clone } from '../util/index.js';\nimport { AbstractSqlDialect } from '../dialect/index.js';\nimport { getMeta } from '../entity/index.js';\n\nimport { AbstractQuerier } from './abstractQuerier.js';\n\nexport abstract class AbstractSqlQuerier extends AbstractQuerier {\n  private hasPendingTransaction?: boolean;\n\n  constructor(readonly dialect: AbstractSqlDialect) {\n    super();\n  }\n\n  /**\n   * read query.\n   * @param query the query\n   */\n  abstract all<T>(query: string): Promise<T[]>;\n\n  /**\n   * insert/update/delete/ddl query.\n   * @param query the query\n   */\n  abstract run(query: string): Promise<QueryUpdateResult>;\n\n  override async findMany<E, P extends QueryProject<E>>(entity: Type<E>, qm: QueryCriteria<E>, project?: P) {\n    const query = this.dialect.find(entity, qm, project);\n    const res = await this.all<Merge<E, P>>(query);\n    const founds = unflatObjects(res);\n    await this.findToManyRelations(entity, founds, project);\n    return founds;\n  }\n\n  override async count<E>(entity: Type<E>, qm?: QuerySearch<E>) {\n    const query = await this.dialect.count(entity, qm);\n    const res = await this.all<{ count: number }>(query);\n    return Number(res[0].count);\n  }\n\n  override async insertMany<E>(entity: Type<E>, payload: E[]) {\n    payload = clone(payload);\n    const query = this.dialect.insert(entity, payload);\n    const { firstId } = await this.run(query);\n    const meta = getMeta(entity);\n    const ids = payload.map((it, index) => {\n      it[meta.id as string] ??= firstId + index;\n      return it[meta.id];\n    });\n    await this.insertRelations(entity, payload);\n    return ids;\n  }\n\n  override async updateMany<E>(entity: Type<E>, qm: QuerySearch<E>, payload: E) {\n    payload = clone(payload);\n    const query = this.dialect.update(entity, qm, payload);\n    const { changes } = await this.run(query);\n    await this.updateRelations(entity, qm, payload);\n    return changes;\n  }\n\n  override async deleteMany<E>(entity: Type<E>, qm: QuerySearch<E>, opts?: QueryOptions) {\n    const meta = getMeta(entity);\n    const findQuery = await this.dialect.find(entity, qm, [meta.id]);\n    const founds = await this.all<E>(findQuery);\n    if (!founds.length) {\n      return 0;\n    }\n    const ids = founds.map((it) => it[meta.id]);\n    const query = this.dialect.delete(entity, { $filter: ids }, opts);\n    const { changes } = await this.run(query);\n    await this.deleteRelations(entity, ids, opts);\n    return changes;\n  }\n\n  override get hasOpenTransaction() {\n    return this.hasPendingTransaction;\n  }\n\n  override async beginTransaction(/*isolationLevel?: IsolationLevel*/) {\n    if (this.hasPendingTransaction) {\n      throw TypeError('pending transaction');\n    }\n    // TODO\n    // if (isolationLevel) {\n    //   await this.run(`SET TRANSACTION ISOLATION LEVEL ${isolationLevel}`);\n    // }\n    await this.run(this.dialect.beginTransactionCommand);\n    this.hasPendingTransaction = true;\n  }\n\n  override async commitTransaction() {\n    if (!this.hasPendingTransaction) {\n      throw TypeError('not a pending transaction');\n    }\n    await this.run('COMMIT');\n    this.hasPendingTransaction = undefined;\n  }\n\n  override async rollbackTransaction() {\n    if (!this.hasPendingTransaction) {\n      throw TypeError('not a pending transaction');\n    }\n    await this.run('ROLLBACK');\n    this.hasPendingTransaction = undefined;\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstractSqlQuerier.js","sourceRoot":"","sources":["../../src/querier/abstractSqlQuerier.ts"],"names":[],"mappings":"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","sourcesContent":["import { Type, QueryOptions, QueryUpdateResult, QueryProject, QuerySearch, QueryCriteria } from '../type/index.js';\nimport { unflatObjects, clone } from '../util/index.js';\nimport { AbstractSqlDialect } from '../dialect/index.js';\nimport { getMeta } from '../entity/index.js';\n\nimport { AbstractQuerier } from './abstractQuerier.js';\n\nexport abstract class AbstractSqlQuerier extends AbstractQuerier {\n  private hasPendingTransaction?: boolean;\n\n  constructor(readonly dialect: AbstractSqlDialect) {\n    super();\n  }\n\n  /**\n   * read query.\n   * @param query the query\n   */\n  abstract all<T>(query: string): Promise<T[]>;\n\n  /**\n   * insert/update/delete/ddl query.\n   * @param query the query\n   */\n  abstract run(query: string): Promise<QueryUpdateResult>;\n\n  override async findMany<E>(entity: Type<E>, qm: QueryCriteria<E>, project?: QueryProject<E>) {\n    const query = this.dialect.find(entity, qm, project);\n    const res = await this.all<E>(query);\n    const founds = unflatObjects(res);\n    await this.findToManyRelations(entity, founds, project);\n    return founds;\n  }\n\n  override async count<E>(entity: Type<E>, qm?: QuerySearch<E>) {\n    const query = await this.dialect.count(entity, qm);\n    const res = await this.all<{ count: number }>(query);\n    return Number(res[0].count);\n  }\n\n  override async insertMany<E>(entity: Type<E>, payload: E[]) {\n    payload = clone(payload);\n    const query = this.dialect.insert(entity, payload);\n    const { firstId } = await this.run(query);\n    const meta = getMeta(entity);\n    const ids = payload.map((it, index) => {\n      it[meta.id as string] ??= firstId + index;\n      return it[meta.id];\n    });\n    await this.insertRelations(entity, payload);\n    return ids;\n  }\n\n  override async updateMany<E>(entity: Type<E>, qm: QuerySearch<E>, payload: E) {\n    payload = clone(payload);\n    const query = this.dialect.update(entity, qm, payload);\n    const { changes } = await this.run(query);\n    await this.updateRelations(entity, qm, payload);\n    return changes;\n  }\n\n  override async deleteMany<E>(entity: Type<E>, qm: QuerySearch<E>, opts?: QueryOptions) {\n    const meta = getMeta(entity);\n    const findQuery = await this.dialect.find(entity, qm, [meta.id]);\n    const founds = await this.all<E>(findQuery);\n    if (!founds.length) {\n      return 0;\n    }\n    const ids = founds.map((it) => it[meta.id]);\n    const query = this.dialect.delete(entity, { $filter: ids }, opts);\n    const { changes } = await this.run(query);\n    await this.deleteRelations(entity, ids, opts);\n    return changes;\n  }\n\n  override get hasOpenTransaction() {\n    return this.hasPendingTransaction;\n  }\n\n  override async beginTransaction(/*isolationLevel?: IsolationLevel*/) {\n    if (this.hasPendingTransaction) {\n      throw TypeError('pending transaction');\n    }\n    // TODO\n    // if (isolationLevel) {\n    //   await this.run(`SET TRANSACTION ISOLATION LEVEL ${isolationLevel}`);\n    // }\n    await this.run(this.dialect.beginTransactionCommand);\n    this.hasPendingTransaction = true;\n  }\n\n  override async commitTransaction() {\n    if (!this.hasPendingTransaction) {\n      throw TypeError('not a pending transaction');\n    }\n    await this.run('COMMIT');\n    this.hasPendingTransaction = undefined;\n  }\n\n  override async rollbackTransaction() {\n    if (!this.hasPendingTransaction) {\n      throw TypeError('not a pending transaction');\n    }\n    await this.run('ROLLBACK');\n    this.hasPendingTransaction = undefined;\n  }\n}\n"]}

@@ -6,6 +6,6 @@ import type { IdValue, Querier, QueryOptions, Repository, Type, QueryProject, QuerySearch, QueryCriteria, QueryOneCriteria } from '../type/index.js';

constructor(entity: Type<E>, querier: Querier);
findOneById<P extends QueryProject<E>>(id: IdValue<E>, project?: P): Promise<import("../type/query.js").Merge<E, P>>;
findOne<P extends QueryProject<E>>(qm: QueryOneCriteria<E>, project?: P): Promise<import("../type/query.js").Merge<E, P>>;
findMany<P extends QueryProject<E>>(qm: QueryCriteria<E>, project?: P): Promise<import("../type/query.js").Merge<E, P>[]>;
findManyAndCount<P extends QueryProject<E>>(qm: QueryCriteria<E>, project?: P): Promise<[import("../type/query.js").Merge<E, P>[], number]>;
findOneById(id: IdValue<E>, project?: QueryProject<E>): Promise<E>;
findOne(qm: QueryOneCriteria<E>, project?: QueryProject<E>): Promise<E>;
findMany(qm: QueryCriteria<E>, project?: QueryProject<E>): Promise<E[]>;
findManyAndCount(qm: QueryCriteria<E>, project?: QueryProject<E>): Promise<[E[], number]>;
count(qm?: QuerySearch<E>): Promise<number>;

@@ -12,0 +12,0 @@ insertOne(payload: E): Promise<IdValue<E>>;

@@ -48,2 +48,2 @@ export class GenericRepository {

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuZXJpY1JlcG9zaXRvcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcmVwb3NpdG9yeS9nZW5lcmljUmVwb3NpdG9yeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFZQSxNQUFNLE9BQU8saUJBQWlCO0lBRWpCO0lBQ0E7SUFGWCxZQUNXLE1BQWUsRUFDZixPQUFnQjtRQURoQixXQUFNLEdBQU4sTUFBTSxDQUFTO1FBQ2YsWUFBTyxHQUFQLE9BQU8sQ0FBUztJQUN4QixDQUFDO0lBRUosV0FBVyxDQUE0QixFQUFjLEVBQUUsT0FBVztRQUNoRSxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsRUFBRSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQzVELENBQUM7SUFFRCxPQUFPLENBQTRCLEVBQXVCLEVBQUUsT0FBVztRQUNyRSxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsRUFBRSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ3hELENBQUM7SUFFRCxRQUFRLENBQTRCLEVBQW9CLEVBQUUsT0FBVztRQUNuRSxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsRUFBRSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ3pELENBQUM7SUFFRCxnQkFBZ0IsQ0FBNEIsRUFBb0IsRUFBRSxPQUFXO1FBQzNFLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLEVBQUUsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUNqRSxDQUFDO0lBRUQsS0FBSyxDQUFDLEVBQW1CO1FBQ3ZCLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBRUQsU0FBUyxDQUFDLE9BQVU7UUFDbEIsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ3RELENBQUM7SUFFRCxVQUFVLENBQUMsT0FBWTtRQUNyQixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDdkQsQ0FBQztJQUVELGFBQWEsQ0FBQyxFQUFjLEVBQUUsT0FBVTtRQUN0QyxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsRUFBRSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQzlELENBQUM7SUFFRCxVQUFVLENBQUMsRUFBa0IsRUFBRSxPQUFVO1FBQ3ZDLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxFQUFFLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDM0QsQ0FBQztJQUVELE9BQU8sQ0FBQyxPQUFVO1FBQ2hCLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxPQUFPLENBQUMsQ0FBQztJQUNwRCxDQUFDO0lBRUQsUUFBUSxDQUFDLE9BQVk7UUFDbkIsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ3JELENBQUM7SUFFRCxhQUFhLENBQUMsRUFBYyxFQUFFLElBQW1CO1FBQy9DLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxFQUFFLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDM0QsQ0FBQztJQUVELFVBQVUsQ0FBQyxFQUFrQixFQUFFLElBQW1CO1FBQ2hELE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxFQUFFLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDeEQsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge1xuICBJZFZhbHVlLFxuICBRdWVyaWVyLFxuICBRdWVyeU9wdGlvbnMsXG4gIFJlcG9zaXRvcnksXG4gIFR5cGUsXG4gIFF1ZXJ5UHJvamVjdCxcbiAgUXVlcnlTZWFyY2gsXG4gIFF1ZXJ5Q3JpdGVyaWEsXG4gIFF1ZXJ5T25lQ3JpdGVyaWEsXG59IGZyb20gJy4uL3R5cGUvaW5kZXguanMnO1xuXG5leHBvcnQgY2xhc3MgR2VuZXJpY1JlcG9zaXRvcnk8RT4gaW1wbGVtZW50cyBSZXBvc2l0b3J5PEU+IHtcbiAgY29uc3RydWN0b3IoXG4gICAgcmVhZG9ubHkgZW50aXR5OiBUeXBlPEU+LFxuICAgIHJlYWRvbmx5IHF1ZXJpZXI6IFF1ZXJpZXIsXG4gICkge31cblxuICBmaW5kT25lQnlJZDxQIGV4dGVuZHMgUXVlcnlQcm9qZWN0PEU+PihpZDogSWRWYWx1ZTxFPiwgcHJvamVjdD86IFApIHtcbiAgICByZXR1cm4gdGhpcy5xdWVyaWVyLmZpbmRPbmVCeUlkKHRoaXMuZW50aXR5LCBpZCwgcHJvamVjdCk7XG4gIH1cblxuICBmaW5kT25lPFAgZXh0ZW5kcyBRdWVyeVByb2plY3Q8RT4+KHFtOiBRdWVyeU9uZUNyaXRlcmlhPEU+LCBwcm9qZWN0PzogUCkge1xuICAgIHJldHVybiB0aGlzLnF1ZXJpZXIuZmluZE9uZSh0aGlzLmVudGl0eSwgcW0sIHByb2plY3QpO1xuICB9XG5cbiAgZmluZE1hbnk8UCBleHRlbmRzIFF1ZXJ5UHJvamVjdDxFPj4ocW06IFF1ZXJ5Q3JpdGVyaWE8RT4sIHByb2plY3Q/OiBQKSB7XG4gICAgcmV0dXJuIHRoaXMucXVlcmllci5maW5kTWFueSh0aGlzLmVudGl0eSwgcW0sIHByb2plY3QpO1xuICB9XG5cbiAgZmluZE1hbnlBbmRDb3VudDxQIGV4dGVuZHMgUXVlcnlQcm9qZWN0PEU+PihxbTogUXVlcnlDcml0ZXJpYTxFPiwgcHJvamVjdD86IFApIHtcbiAgICByZXR1cm4gdGhpcy5xdWVyaWVyLmZpbmRNYW55QW5kQ291bnQodGhpcy5lbnRpdHksIHFtLCBwcm9qZWN0KTtcbiAgfVxuXG4gIGNvdW50KHFtPzogUXVlcnlTZWFyY2g8RT4pIHtcbiAgICByZXR1cm4gdGhpcy5xdWVyaWVyLmNvdW50KHRoaXMuZW50aXR5LCBxbSk7XG4gIH1cblxuICBpbnNlcnRPbmUocGF5bG9hZDogRSkge1xuICAgIHJldHVybiB0aGlzLnF1ZXJpZXIuaW5zZXJ0T25lKHRoaXMuZW50aXR5LCBwYXlsb2FkKTtcbiAgfVxuXG4gIGluc2VydE1hbnkocGF5bG9hZDogRVtdKSB7XG4gICAgcmV0dXJuIHRoaXMucXVlcmllci5pbnNlcnRNYW55KHRoaXMuZW50aXR5LCBwYXlsb2FkKTtcbiAgfVxuXG4gIHVwZGF0ZU9uZUJ5SWQoaWQ6IElkVmFsdWU8RT4sIHBheWxvYWQ6IEUpIHtcbiAgICByZXR1cm4gdGhpcy5xdWVyaWVyLnVwZGF0ZU9uZUJ5SWQodGhpcy5lbnRpdHksIGlkLCBwYXlsb2FkKTtcbiAgfVxuXG4gIHVwZGF0ZU1hbnkocW06IFF1ZXJ5U2VhcmNoPEU+LCBwYXlsb2FkOiBFKSB7XG4gICAgcmV0dXJuIHRoaXMucXVlcmllci51cGRhdGVNYW55KHRoaXMuZW50aXR5LCBxbSwgcGF5bG9hZCk7XG4gIH1cblxuICBzYXZlT25lKHBheWxvYWQ6IEUpIHtcbiAgICByZXR1cm4gdGhpcy5xdWVyaWVyLnNhdmVPbmUodGhpcy5lbnRpdHksIHBheWxvYWQpO1xuICB9XG5cbiAgc2F2ZU1hbnkocGF5bG9hZDogRVtdKSB7XG4gICAgcmV0dXJuIHRoaXMucXVlcmllci5zYXZlTWFueSh0aGlzLmVudGl0eSwgcGF5bG9hZCk7XG4gIH1cblxuICBkZWxldGVPbmVCeUlkKGlkOiBJZFZhbHVlPEU+LCBvcHRzPzogUXVlcnlPcHRpb25zKSB7XG4gICAgcmV0dXJuIHRoaXMucXVlcmllci5kZWxldGVPbmVCeUlkKHRoaXMuZW50aXR5LCBpZCwgb3B0cyk7XG4gIH1cblxuICBkZWxldGVNYW55KHFtOiBRdWVyeVNlYXJjaDxFPiwgb3B0cz86IFF1ZXJ5T3B0aW9ucykge1xuICAgIHJldHVybiB0aGlzLnF1ZXJpZXIuZGVsZXRlTWFueSh0aGlzLmVudGl0eSwgcW0sIG9wdHMpO1xuICB9XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuZXJpY1JlcG9zaXRvcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcmVwb3NpdG9yeS9nZW5lcmljUmVwb3NpdG9yeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFZQSxNQUFNLE9BQU8saUJBQWlCO0lBRWpCO0lBQ0E7SUFGWCxZQUNXLE1BQWUsRUFDZixPQUFnQjtRQURoQixXQUFNLEdBQU4sTUFBTSxDQUFTO1FBQ2YsWUFBTyxHQUFQLE9BQU8sQ0FBUztJQUN4QixDQUFDO0lBRUosV0FBVyxDQUFDLEVBQWMsRUFBRSxPQUF5QjtRQUNuRCxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsRUFBRSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQzVELENBQUM7SUFFRCxPQUFPLENBQUMsRUFBdUIsRUFBRSxPQUF5QjtRQUN4RCxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsRUFBRSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ3hELENBQUM7SUFFRCxRQUFRLENBQUMsRUFBb0IsRUFBRSxPQUF5QjtRQUN0RCxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsRUFBRSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ3pELENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxFQUFvQixFQUFFLE9BQXlCO1FBQzlELE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLEVBQUUsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUNqRSxDQUFDO0lBRUQsS0FBSyxDQUFDLEVBQW1CO1FBQ3ZCLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBRUQsU0FBUyxDQUFDLE9BQVU7UUFDbEIsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ3RELENBQUM7SUFFRCxVQUFVLENBQUMsT0FBWTtRQUNyQixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDdkQsQ0FBQztJQUVELGFBQWEsQ0FBQyxFQUFjLEVBQUUsT0FBVTtRQUN0QyxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsRUFBRSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQzlELENBQUM7SUFFRCxVQUFVLENBQUMsRUFBa0IsRUFBRSxPQUFVO1FBQ3ZDLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxFQUFFLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDM0QsQ0FBQztJQUVELE9BQU8sQ0FBQyxPQUFVO1FBQ2hCLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxPQUFPLENBQUMsQ0FBQztJQUNwRCxDQUFDO0lBRUQsUUFBUSxDQUFDLE9BQVk7UUFDbkIsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ3JELENBQUM7SUFFRCxhQUFhLENBQUMsRUFBYyxFQUFFLElBQW1CO1FBQy9DLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxFQUFFLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDM0QsQ0FBQztJQUVELFVBQVUsQ0FBQyxFQUFrQixFQUFFLElBQW1CO1FBQ2hELE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxFQUFFLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDeEQsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge1xuICBJZFZhbHVlLFxuICBRdWVyaWVyLFxuICBRdWVyeU9wdGlvbnMsXG4gIFJlcG9zaXRvcnksXG4gIFR5cGUsXG4gIFF1ZXJ5UHJvamVjdCxcbiAgUXVlcnlTZWFyY2gsXG4gIFF1ZXJ5Q3JpdGVyaWEsXG4gIFF1ZXJ5T25lQ3JpdGVyaWEsXG59IGZyb20gJy4uL3R5cGUvaW5kZXguanMnO1xuXG5leHBvcnQgY2xhc3MgR2VuZXJpY1JlcG9zaXRvcnk8RT4gaW1wbGVtZW50cyBSZXBvc2l0b3J5PEU+IHtcbiAgY29uc3RydWN0b3IoXG4gICAgcmVhZG9ubHkgZW50aXR5OiBUeXBlPEU+LFxuICAgIHJlYWRvbmx5IHF1ZXJpZXI6IFF1ZXJpZXIsXG4gICkge31cblxuICBmaW5kT25lQnlJZChpZDogSWRWYWx1ZTxFPiwgcHJvamVjdD86IFF1ZXJ5UHJvamVjdDxFPikge1xuICAgIHJldHVybiB0aGlzLnF1ZXJpZXIuZmluZE9uZUJ5SWQodGhpcy5lbnRpdHksIGlkLCBwcm9qZWN0KTtcbiAgfVxuXG4gIGZpbmRPbmUocW06IFF1ZXJ5T25lQ3JpdGVyaWE8RT4sIHByb2plY3Q/OiBRdWVyeVByb2plY3Q8RT4pIHtcbiAgICByZXR1cm4gdGhpcy5xdWVyaWVyLmZpbmRPbmUodGhpcy5lbnRpdHksIHFtLCBwcm9qZWN0KTtcbiAgfVxuXG4gIGZpbmRNYW55KHFtOiBRdWVyeUNyaXRlcmlhPEU+LCBwcm9qZWN0PzogUXVlcnlQcm9qZWN0PEU+KSB7XG4gICAgcmV0dXJuIHRoaXMucXVlcmllci5maW5kTWFueSh0aGlzLmVudGl0eSwgcW0sIHByb2plY3QpO1xuICB9XG5cbiAgZmluZE1hbnlBbmRDb3VudChxbTogUXVlcnlDcml0ZXJpYTxFPiwgcHJvamVjdD86IFF1ZXJ5UHJvamVjdDxFPikge1xuICAgIHJldHVybiB0aGlzLnF1ZXJpZXIuZmluZE1hbnlBbmRDb3VudCh0aGlzLmVudGl0eSwgcW0sIHByb2plY3QpO1xuICB9XG5cbiAgY291bnQocW0/OiBRdWVyeVNlYXJjaDxFPikge1xuICAgIHJldHVybiB0aGlzLnF1ZXJpZXIuY291bnQodGhpcy5lbnRpdHksIHFtKTtcbiAgfVxuXG4gIGluc2VydE9uZShwYXlsb2FkOiBFKSB7XG4gICAgcmV0dXJuIHRoaXMucXVlcmllci5pbnNlcnRPbmUodGhpcy5lbnRpdHksIHBheWxvYWQpO1xuICB9XG5cbiAgaW5zZXJ0TWFueShwYXlsb2FkOiBFW10pIHtcbiAgICByZXR1cm4gdGhpcy5xdWVyaWVyLmluc2VydE1hbnkodGhpcy5lbnRpdHksIHBheWxvYWQpO1xuICB9XG5cbiAgdXBkYXRlT25lQnlJZChpZDogSWRWYWx1ZTxFPiwgcGF5bG9hZDogRSkge1xuICAgIHJldHVybiB0aGlzLnF1ZXJpZXIudXBkYXRlT25lQnlJZCh0aGlzLmVudGl0eSwgaWQsIHBheWxvYWQpO1xuICB9XG5cbiAgdXBkYXRlTWFueShxbTogUXVlcnlTZWFyY2g8RT4sIHBheWxvYWQ6IEUpIHtcbiAgICByZXR1cm4gdGhpcy5xdWVyaWVyLnVwZGF0ZU1hbnkodGhpcy5lbnRpdHksIHFtLCBwYXlsb2FkKTtcbiAgfVxuXG4gIHNhdmVPbmUocGF5bG9hZDogRSkge1xuICAgIHJldHVybiB0aGlzLnF1ZXJpZXIuc2F2ZU9uZSh0aGlzLmVudGl0eSwgcGF5bG9hZCk7XG4gIH1cblxuICBzYXZlTWFueShwYXlsb2FkOiBFW10pIHtcbiAgICByZXR1cm4gdGhpcy5xdWVyaWVyLnNhdmVNYW55KHRoaXMuZW50aXR5LCBwYXlsb2FkKTtcbiAgfVxuXG4gIGRlbGV0ZU9uZUJ5SWQoaWQ6IElkVmFsdWU8RT4sIG9wdHM/OiBRdWVyeU9wdGlvbnMpIHtcbiAgICByZXR1cm4gdGhpcy5xdWVyaWVyLmRlbGV0ZU9uZUJ5SWQodGhpcy5lbnRpdHksIGlkLCBvcHRzKTtcbiAgfVxuXG4gIGRlbGV0ZU1hbnkocW06IFF1ZXJ5U2VhcmNoPEU+LCBvcHRzPzogUXVlcnlPcHRpb25zKSB7XG4gICAgcmV0dXJuIHRoaXMucXVlcmllci5kZWxldGVNYW55KHRoaXMuZW50aXR5LCBxbSwgb3B0cyk7XG4gIH1cbn1cbiJdfQ==
import type { Type } from './utility.js';
import type { QueryCriteria, QueryOptions, QueryProject, QuerySearch, Merge, QueryOneCriteria } from './query.js';
import type { QueryCriteria, QueryOptions, QueryProject, QuerySearch, QueryOneCriteria } from './query.js';
import type { Repository } from './repository.js';

@@ -11,6 +11,6 @@ import type { IdValue } from './entity.js';

export interface Querier extends UniversalQuerier {
findOneById<E, P extends QueryProject<E>>(entity: Type<E>, id: IdValue<E>, project?: P): Promise<Merge<E, P>>;
findOne<E, P extends QueryProject<E>>(entity: Type<E>, qm: QueryOneCriteria<E>, project?: P): Promise<Merge<E, P>>;
findMany<E, P extends QueryProject<E>>(entity: Type<E>, qm: QueryCriteria<E>, project?: P): Promise<Merge<E, P>[]>;
findManyAndCount<E, P extends QueryProject<E>>(entity: Type<E>, qm: QueryCriteria<E>, project?: P): Promise<[Merge<E, P>[], number]>;
findOneById<E>(entity: Type<E>, id: IdValue<E>, project?: QueryProject<E>): Promise<E>;
findOne<E>(entity: Type<E>, qm: QueryOneCriteria<E>, project?: QueryProject<E>): Promise<E>;
findMany<E>(entity: Type<E>, qm: QueryCriteria<E>, project?: QueryProject<E>): Promise<E[]>;
findManyAndCount<E>(entity: Type<E>, qm: QueryCriteria<E>, project?: QueryProject<E>): Promise<[E[], number]>;
count<E>(entity: Type<E>, qm?: QuerySearch<E>): Promise<number>;

@@ -17,0 +17,0 @@ insertOne<E>(entity: Type<E>, payload: E): Promise<IdValue<E>>;

export {};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVlcmllci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90eXBlL3F1ZXJpZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgVHlwZSB9IGZyb20gJy4vdXRpbGl0eS5qcyc7XG5pbXBvcnQgdHlwZSB7IFF1ZXJ5Q3JpdGVyaWEsIFF1ZXJ5T3B0aW9ucywgUXVlcnlQcm9qZWN0LCBRdWVyeVNlYXJjaCwgTWVyZ2UsIFF1ZXJ5T25lQ3JpdGVyaWEgfSBmcm9tICcuL3F1ZXJ5LmpzJztcbmltcG9ydCB0eXBlIHsgUmVwb3NpdG9yeSB9IGZyb20gJy4vcmVwb3NpdG9yeS5qcyc7XG5pbXBvcnQgdHlwZSB7IElkVmFsdWUgfSBmcm9tICcuL2VudGl0eS5qcyc7XG5pbXBvcnQgdHlwZSB7IFVuaXZlcnNhbFF1ZXJpZXIgfSBmcm9tICcuL3VuaXZlcnNhbFF1ZXJpZXIuanMnO1xuXG4vKipcbiAqIElzb2xhdGlvbiBsZXZlbHMgZm9yIHRyYW5zYWN0aW9ucy5cbiAqL1xuZXhwb3J0IHR5cGUgSXNvbGF0aW9uTGV2ZWwgPSAncmVhZCB1bmNvbW1pdHRlZCcgfCAncmVhZCBjb21taXR0ZWQnIHwgJ3JlcGV0ZWFibGUgcmVhZCcgfCAnc2VyaWFsaXphYmxlJztcblxuZXhwb3J0IGludGVyZmFjZSBRdWVyaWVyIGV4dGVuZHMgVW5pdmVyc2FsUXVlcmllciB7XG4gIGZpbmRPbmVCeUlkPEUsIFAgZXh0ZW5kcyBRdWVyeVByb2plY3Q8RT4+KGVudGl0eTogVHlwZTxFPiwgaWQ6IElkVmFsdWU8RT4sIHByb2plY3Q/OiBQKTogUHJvbWlzZTxNZXJnZTxFLCBQPj47XG5cbiAgZmluZE9uZTxFLCBQIGV4dGVuZHMgUXVlcnlQcm9qZWN0PEU+PihlbnRpdHk6IFR5cGU8RT4sIHFtOiBRdWVyeU9uZUNyaXRlcmlhPEU+LCBwcm9qZWN0PzogUCk6IFByb21pc2U8TWVyZ2U8RSwgUD4+O1xuXG4gIGZpbmRNYW55PEUsIFAgZXh0ZW5kcyBRdWVyeVByb2plY3Q8RT4+KGVudGl0eTogVHlwZTxFPiwgcW06IFF1ZXJ5Q3JpdGVyaWE8RT4sIHByb2plY3Q/OiBQKTogUHJvbWlzZTxNZXJnZTxFLCBQPltdPjtcblxuICBmaW5kTWFueUFuZENvdW50PEUsIFAgZXh0ZW5kcyBRdWVyeVByb2plY3Q8RT4+KFxuICAgIGVudGl0eTogVHlwZTxFPixcbiAgICBxbTogUXVlcnlDcml0ZXJpYTxFPixcbiAgICBwcm9qZWN0PzogUCxcbiAgKTogUHJvbWlzZTxbTWVyZ2U8RSwgUD5bXSwgbnVtYmVyXT47XG5cbiAgY291bnQ8RT4oZW50aXR5OiBUeXBlPEU+LCBxbT86IFF1ZXJ5U2VhcmNoPEU+KTogUHJvbWlzZTxudW1iZXI+O1xuXG4gIGluc2VydE9uZTxFPihlbnRpdHk6IFR5cGU8RT4sIHBheWxvYWQ6IEUpOiBQcm9taXNlPElkVmFsdWU8RT4+O1xuXG4gIGluc2VydE1hbnk8RT4oZW50aXR5OiBUeXBlPEU+LCBwYXlsb2FkOiBFW10pOiBQcm9taXNlPElkVmFsdWU8RT5bXT47XG5cbiAgdXBkYXRlT25lQnlJZDxFPihlbnRpdHk6IFR5cGU8RT4sIGlkOiBJZFZhbHVlPEU+LCBwYXlsb2FkOiBFKTogUHJvbWlzZTxudW1iZXI+O1xuXG4gIHVwZGF0ZU1hbnk8RT4oZW50aXR5OiBUeXBlPEU+LCBxbTogUXVlcnlTZWFyY2g8RT4sIHBheWxvYWQ6IEUpOiBQcm9taXNlPG51bWJlcj47XG5cbiAgc2F2ZU9uZTxFPihlbnRpdHk6IFR5cGU8RT4sIHBheWxvYWQ6IEUpOiBQcm9taXNlPElkVmFsdWU8RT4+O1xuXG4gIHNhdmVNYW55PEU+KGVudGl0eTogVHlwZTxFPiwgcGF5bG9hZDogRVtdKTogUHJvbWlzZTxJZFZhbHVlPEU+W10+O1xuXG4gIGRlbGV0ZU9uZUJ5SWQ8RT4oZW50aXR5OiBUeXBlPEU+LCBpZDogSWRWYWx1ZTxFPiwgb3B0cz86IFF1ZXJ5T3B0aW9ucyk6IFByb21pc2U8bnVtYmVyPjtcblxuICBkZWxldGVNYW55PEU+KGVudGl0eTogVHlwZTxFPiwgcW06IFF1ZXJ5U2VhcmNoPEU+LCBvcHRzPzogUXVlcnlPcHRpb25zKTogUHJvbWlzZTxudW1iZXI+O1xuXG4gIGdldFJlcG9zaXRvcnk8RT4oZW50aXR5OiBUeXBlPEU+KTogUmVwb3NpdG9yeTxFPjtcblxuICAvKipcbiAgICogd2hldGhlciB0aGlzIHF1ZXJpZXIgaXMgaW4gYSB0cmFuc2FjdGlvbiBvciBub3QuXG4gICAqL1xuICByZWFkb25seSBoYXNPcGVuVHJhbnNhY3Rpb246IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIHJ1biB0aGUgZ2l2ZW4gY2FsbGJhY2sgaW5zaWRlIGEgdHJhbnNhY3Rpb24gaW4gdGhpcyBxdWVyaWVyLlxuICAgKi9cbiAgdHJhbnNhY3Rpb248VD4oY2FsbGJhY2s6ICgpID0+IFByb21pc2U8VD4pOiBQcm9taXNlPFQ+O1xuXG4gIC8qKlxuICAgKiBzdGFydHMgYSBuZXcgdHJhbnNhY3Rpb24gaW4gdGhpcyBxdWVyaWVyLlxuICAgKi9cbiAgYmVnaW5UcmFuc2FjdGlvbigpOiBQcm9taXNlPHZvaWQ+O1xuXG4gIC8qKlxuICAgKiBjb21taXRzIHRoZSBjdXJyZW50bHkgYWN0aXZlIHRyYW5zYWN0aW9uIGluIHRoaXMgcXVlcmllci5cbiAgICovXG4gIGNvbW1pdFRyYW5zYWN0aW9uKCk6IFByb21pc2U8dm9pZD47XG5cbiAgLyoqXG4gICAqIGFib3J0cyB0aGUgY3VycmVudGx5IGFjdGl2ZSB0cmFuc2FjdGlvbiBpbiB0aGlzIHF1ZXJpZXIuXG4gICAqL1xuICByb2xsYmFja1RyYW5zYWN0aW9uKCk6IFByb21pc2U8dm9pZD47XG5cbiAgLyoqXG4gICAqIHJlbGVhc2UgdGhlIHF1ZXJpZXIgdG8gdGhlIHBvb2wuXG4gICAqL1xuICByZWxlYXNlKCk6IFByb21pc2U8dm9pZD47XG59XG5cbi8qKlxuICogbG9nZ2VyIGZ1bmN0aW9uIHRvIGRlYnVnIHF1ZXJpZXMuXG4gKi9cbmV4cG9ydCB0eXBlIExvZ2dlciA9IChtZXNzYWdlOiB1bmtub3duLCAuLi5hcmdzOiB1bmtub3duW10pID0+IHVua25vd247XG5cbmV4cG9ydCB0eXBlIEV4dHJhT3B0aW9ucyA9IHtcbiAgcmVhZG9ubHkgbG9nZ2VyPzogTG9nZ2VyO1xufTtcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVlcmllci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90eXBlL3F1ZXJpZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgVHlwZSB9IGZyb20gJy4vdXRpbGl0eS5qcyc7XG5pbXBvcnQgdHlwZSB7IFF1ZXJ5Q3JpdGVyaWEsIFF1ZXJ5T3B0aW9ucywgUXVlcnlQcm9qZWN0LCBRdWVyeVNlYXJjaCwgUXVlcnlPbmVDcml0ZXJpYSB9IGZyb20gJy4vcXVlcnkuanMnO1xuaW1wb3J0IHR5cGUgeyBSZXBvc2l0b3J5IH0gZnJvbSAnLi9yZXBvc2l0b3J5LmpzJztcbmltcG9ydCB0eXBlIHsgSWRWYWx1ZSB9IGZyb20gJy4vZW50aXR5LmpzJztcbmltcG9ydCB0eXBlIHsgVW5pdmVyc2FsUXVlcmllciB9IGZyb20gJy4vdW5pdmVyc2FsUXVlcmllci5qcyc7XG5cbi8qKlxuICogSXNvbGF0aW9uIGxldmVscyBmb3IgdHJhbnNhY3Rpb25zLlxuICovXG5leHBvcnQgdHlwZSBJc29sYXRpb25MZXZlbCA9ICdyZWFkIHVuY29tbWl0dGVkJyB8ICdyZWFkIGNvbW1pdHRlZCcgfCAncmVwZXRlYWJsZSByZWFkJyB8ICdzZXJpYWxpemFibGUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFF1ZXJpZXIgZXh0ZW5kcyBVbml2ZXJzYWxRdWVyaWVyIHtcbiAgZmluZE9uZUJ5SWQ8RT4oZW50aXR5OiBUeXBlPEU+LCBpZDogSWRWYWx1ZTxFPiwgcHJvamVjdD86IFF1ZXJ5UHJvamVjdDxFPik6IFByb21pc2U8RT47XG5cbiAgZmluZE9uZTxFPihlbnRpdHk6IFR5cGU8RT4sIHFtOiBRdWVyeU9uZUNyaXRlcmlhPEU+LCBwcm9qZWN0PzogUXVlcnlQcm9qZWN0PEU+KTogUHJvbWlzZTxFPjtcblxuICBmaW5kTWFueTxFPihlbnRpdHk6IFR5cGU8RT4sIHFtOiBRdWVyeUNyaXRlcmlhPEU+LCBwcm9qZWN0PzogUXVlcnlQcm9qZWN0PEU+KTogUHJvbWlzZTxFW10+O1xuXG4gIGZpbmRNYW55QW5kQ291bnQ8RT4oZW50aXR5OiBUeXBlPEU+LCBxbTogUXVlcnlDcml0ZXJpYTxFPiwgcHJvamVjdD86IFF1ZXJ5UHJvamVjdDxFPik6IFByb21pc2U8W0VbXSwgbnVtYmVyXT47XG5cbiAgY291bnQ8RT4oZW50aXR5OiBUeXBlPEU+LCBxbT86IFF1ZXJ5U2VhcmNoPEU+KTogUHJvbWlzZTxudW1iZXI+O1xuXG4gIGluc2VydE9uZTxFPihlbnRpdHk6IFR5cGU8RT4sIHBheWxvYWQ6IEUpOiBQcm9taXNlPElkVmFsdWU8RT4+O1xuXG4gIGluc2VydE1hbnk8RT4oZW50aXR5OiBUeXBlPEU+LCBwYXlsb2FkOiBFW10pOiBQcm9taXNlPElkVmFsdWU8RT5bXT47XG5cbiAgdXBkYXRlT25lQnlJZDxFPihlbnRpdHk6IFR5cGU8RT4sIGlkOiBJZFZhbHVlPEU+LCBwYXlsb2FkOiBFKTogUHJvbWlzZTxudW1iZXI+O1xuXG4gIHVwZGF0ZU1hbnk8RT4oZW50aXR5OiBUeXBlPEU+LCBxbTogUXVlcnlTZWFyY2g8RT4sIHBheWxvYWQ6IEUpOiBQcm9taXNlPG51bWJlcj47XG5cbiAgc2F2ZU9uZTxFPihlbnRpdHk6IFR5cGU8RT4sIHBheWxvYWQ6IEUpOiBQcm9taXNlPElkVmFsdWU8RT4+O1xuXG4gIHNhdmVNYW55PEU+KGVudGl0eTogVHlwZTxFPiwgcGF5bG9hZDogRVtdKTogUHJvbWlzZTxJZFZhbHVlPEU+W10+O1xuXG4gIGRlbGV0ZU9uZUJ5SWQ8RT4oZW50aXR5OiBUeXBlPEU+LCBpZDogSWRWYWx1ZTxFPiwgb3B0cz86IFF1ZXJ5T3B0aW9ucyk6IFByb21pc2U8bnVtYmVyPjtcblxuICBkZWxldGVNYW55PEU+KGVudGl0eTogVHlwZTxFPiwgcW06IFF1ZXJ5U2VhcmNoPEU+LCBvcHRzPzogUXVlcnlPcHRpb25zKTogUHJvbWlzZTxudW1iZXI+O1xuXG4gIGdldFJlcG9zaXRvcnk8RT4oZW50aXR5OiBUeXBlPEU+KTogUmVwb3NpdG9yeTxFPjtcblxuICAvKipcbiAgICogd2hldGhlciB0aGlzIHF1ZXJpZXIgaXMgaW4gYSB0cmFuc2FjdGlvbiBvciBub3QuXG4gICAqL1xuICByZWFkb25seSBoYXNPcGVuVHJhbnNhY3Rpb246IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIHJ1biB0aGUgZ2l2ZW4gY2FsbGJhY2sgaW5zaWRlIGEgdHJhbnNhY3Rpb24gaW4gdGhpcyBxdWVyaWVyLlxuICAgKi9cbiAgdHJhbnNhY3Rpb248VD4oY2FsbGJhY2s6ICgpID0+IFByb21pc2U8VD4pOiBQcm9taXNlPFQ+O1xuXG4gIC8qKlxuICAgKiBzdGFydHMgYSBuZXcgdHJhbnNhY3Rpb24gaW4gdGhpcyBxdWVyaWVyLlxuICAgKi9cbiAgYmVnaW5UcmFuc2FjdGlvbigpOiBQcm9taXNlPHZvaWQ+O1xuXG4gIC8qKlxuICAgKiBjb21taXRzIHRoZSBjdXJyZW50bHkgYWN0aXZlIHRyYW5zYWN0aW9uIGluIHRoaXMgcXVlcmllci5cbiAgICovXG4gIGNvbW1pdFRyYW5zYWN0aW9uKCk6IFByb21pc2U8dm9pZD47XG5cbiAgLyoqXG4gICAqIGFib3J0cyB0aGUgY3VycmVudGx5IGFjdGl2ZSB0cmFuc2FjdGlvbiBpbiB0aGlzIHF1ZXJpZXIuXG4gICAqL1xuICByb2xsYmFja1RyYW5zYWN0aW9uKCk6IFByb21pc2U8dm9pZD47XG5cbiAgLyoqXG4gICAqIHJlbGVhc2UgdGhlIHF1ZXJpZXIgdG8gdGhlIHBvb2wuXG4gICAqL1xuICByZWxlYXNlKCk6IFByb21pc2U8dm9pZD47XG59XG5cbi8qKlxuICogbG9nZ2VyIGZ1bmN0aW9uIHRvIGRlYnVnIHF1ZXJpZXMuXG4gKi9cbmV4cG9ydCB0eXBlIExvZ2dlciA9IChtZXNzYWdlOiB1bmtub3duLCAuLi5hcmdzOiB1bmtub3duW10pID0+IHVua25vd247XG5cbmV4cG9ydCB0eXBlIEV4dHJhT3B0aW9ucyA9IHtcbiAgcmVhZG9ubHkgbG9nZ2VyPzogTG9nZ2VyO1xufTtcbiJdfQ==

@@ -28,27 +28,2 @@ import { FieldKey, IdValue, Key, RelationKey } from './entity.js';

/**
* query projection of operations
*/
export type QueryProjectOperation<E> = {
/**
* Calculates the quantity of entries
*/
readonly $count?: FieldKey<E> | 1;
/**
* Gets the maximum value of a field in the entity
*/
readonly $max?: FieldKey<E>;
/**
* Gets the minimum value of a field in the entity
*/
readonly $min?: FieldKey<E>;
/**
* Gets the average value of a field in the entity
*/
readonly $avg?: FieldKey<E>;
/**
* Sums up the specified values of all entries in the entity
*/
readonly $sum?: FieldKey<E>;
};
/**
* query projection as an array.

@@ -69,5 +44,3 @@ */

export type QueryProjectFieldMap<E> = {
[K in FieldKey<E>]?: BooleanLike;
} | {
[K: string]: QueryProjectOperation<E> | QueryRaw;
readonly [K in FieldKey<E>]?: BooleanLike;
};

@@ -78,3 +51,3 @@ /**

export type QueryProjectRelationMap<E> = {
[K in RelationKey<E>]?: BooleanLike | readonly Key<Unpacked<E[K]>>[] | QueryProjectRelationOptions<E[K]>;
readonly [K in RelationKey<E>]?: BooleanLike | readonly Key<Unpacked<E[K]>>[] | QueryProjectRelationOptions<E[K]>;
};

@@ -101,6 +74,2 @@ /**

/**
* value for a logical filtering.
*/
export type QueryFilterLogical<E> = readonly QueryFilter<E>[];
/**
* comparison by fields.

@@ -110,4 +79,2 @@ */

readonly [K in FieldKey<E>]?: QueryFilterFieldValue<E[K]>;
} | {
readonly [K: string]: QueryFilterFieldValue<E[any]>;
};

@@ -122,15 +89,15 @@ /**

*/
readonly $and?: QueryFilterLogical<E>;
readonly $and?: QueryFilterArray<E>;
/**
* joins query clauses with a logical `OR`, returns records that match any of the clauses.
*/
readonly $or?: QueryFilterLogical<E>;
readonly $or?: QueryFilterArray<E>;
/**
* joins query clauses with a logical `AND`, returns records that do not match all the clauses.
*/
readonly $not?: QueryFilterLogical<E>;
readonly $not?: QueryFilterArray<E>;
/**
* joins query clauses with a logical `OR`, returns records that do not match any of the clauses.
*/
readonly $nor?: QueryFilterLogical<E>;
readonly $nor?: QueryFilterArray<E>;
/**

@@ -228,5 +195,13 @@ * whether the specified fields match against a full-text search of the given string.

/**
* query single filter.
*/
export type QueryFilterSingle<E> = IdValue<E> | readonly IdValue<E>[] | QueryFilterMap<E> | QueryRaw;
/**
* query filter array.
*/
export type QueryFilterArray<E> = readonly QueryFilterSingle<E>[];
/**
* query filter.
*/
export type QueryFilter<E> = IdValue<E> | readonly IdValue<E>[] | QueryRaw | QueryFilterMap<E>;
export type QueryFilter<E> = QueryFilterSingle<E> | QueryFilterArray<E>;
/**

@@ -251,5 +226,3 @@ * direction for the sort.

export type QuerySortFieldMap<E> = {
[K in FieldKey<E>]?: QuerySortDirection;
} | {
[K: string]: QuerySortDirection;
readonly [K in FieldKey<E>]?: QuerySortDirection;
};

@@ -260,3 +233,3 @@ /**

export type QuerySortRelationMap<E> = {
[K in RelationKey<E>]?: QuerySortMap<Unpacked<E[K]>>;
readonly [K in RelationKey<E>]?: QuerySortMap<Unpacked<E[K]>>;
};

@@ -292,10 +265,2 @@ /**

$filter?: QueryFilter<E>;
/**
* list of fields to group.
*/
$group?: readonly FieldKey<E>[];
/**
* having options.
*/
$having?: QueryFilter<E>;
} & QueryPager;

@@ -402,3 +367,3 @@ /**

*/
find<E, P extends QueryProject<E>>(entity: Type<E>, qm: QueryCriteria<E>, project?: P, opts?: QueryOptions): string;
find<E>(entity: Type<E>, qm: QueryCriteria<E>, project?: QueryProject<E>, opts?: QueryOptions): string;
/**

@@ -446,4 +411,1 @@ * counts the number of records matching the given search parameters.

}
export type Merge<E, P> = E & (P extends string[] ? {} : {
[K in Exclude<keyof P, keyof E>]: Scalar;
});

@@ -9,2 +9,2 @@ export class QueryRaw {

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query.js","sourceRoot":"","sources":["../../src/type/query.ts"],"names":[],"mappings":"AAgZA,MAAM,OAAO,QAAQ;IAER;IACA;IAFX,YACW,KAA0B,EAC1B,KAAc;QADd,UAAK,GAAL,KAAK,CAAqB;QAC1B,UAAK,GAAL,KAAK,CAAS;IACtB,CAAC;CACL","sourcesContent":["import { FieldKey, IdValue, Key, RelationKey } from './entity.js';\nimport { BooleanLike, ExpandScalar, Scalar, Type, Unpacked } from './utility.js';\n\nexport type QueryOptions = {\n  /**\n   * use or omit `softDelete` attribute.\n   */\n  readonly softDelete?: boolean;\n  /**\n   * prefix the query with this.\n   */\n  readonly prefix?: string;\n  /**\n   * automatically infer the prefix for the query.\n   */\n  readonly autoPrefix?: boolean;\n};\n\nexport type QueryProjectOptions = {\n  /**\n   * prefix the query with this.\n   */\n  readonly prefix?: string;\n  /**\n   * automatically add the prefix for the alias.\n   */\n  readonly autoPrefixAlias?: boolean;\n};\n\n/**\n * query projection of operations\n */\nexport type QueryProjectOperation<E> = {\n  /**\n   * Calculates the quantity of entries\n   */\n  readonly $count?: FieldKey<E> | 1;\n\n  /**\n   * Gets the maximum value of a field in the entity\n   */\n  readonly $max?: FieldKey<E>;\n\n  /**\n   * Gets the minimum value of a field in the entity\n   */\n  readonly $min?: FieldKey<E>;\n\n  /**\n   * Gets the average value of a field in the entity\n   */\n  readonly $avg?: FieldKey<E>;\n\n  /**\n   * Sums up the specified values of all entries in the entity\n   */\n  readonly $sum?: FieldKey<E>;\n};\n\n/**\n * query projection as an array.\n */\nexport type QueryProjectArray<E> = readonly (Key<E> | QueryRaw)[];\n\n/**\n * query projection as a map.\n */\nexport type QueryProjectMap<E> = QueryProjectFieldMap<E> | QueryProjectRelationMap<E>;\n\n/**\n * query projection.\n */\nexport type QueryProject<E> = QueryProjectArray<E> | QueryProjectMap<E>;\n\n/**\n * query projection of fields as a map.\n */\nexport type QueryProjectFieldMap<E> =\n  | {\n      // TODO add support to use alias for projected fields (string value)\n      [K in FieldKey<E>]?: BooleanLike;\n    }\n  | { [K: string]: QueryProjectOperation<E> | QueryRaw };\n\n/**\n * query projection of relations as a map.\n */\nexport type QueryProjectRelationMap<E> = {\n  [K in RelationKey<E>]?: BooleanLike | readonly Key<Unpacked<E[K]>>[] | QueryProjectRelationOptions<E[K]>;\n};\n\n/**\n * options to project a relation.\n */\nexport type QueryProjectRelationOptions<E> = (E extends unknown[] ? Query<Unpacked<E>> : QueryUnique<Unpacked<E>>) & {\n  readonly $required?: boolean;\n};\n\n/**\n * options for full-text-search operator.\n */\nexport type QueryTextSearchOptions<E> = {\n  /**\n   * text to search for.\n   */\n  readonly $value: string;\n  /**\n   * list of fields to search on.\n   */\n  readonly $fields?: readonly FieldKey<E>[];\n};\n\n/**\n * value for a logical filtering.\n */\nexport type QueryFilterLogical<E> = readonly QueryFilter<E>[];\n\n/**\n * comparison by fields.\n */\nexport type QueryFilterFieldMap<E> =\n  | { readonly [K in FieldKey<E>]?: QueryFilterFieldValue<E[K]> }\n  | { readonly [K: string]: QueryFilterFieldValue<E[any]> };\n\n/**\n * complex operators.\n */\nexport type QueryFilterMap<E> = QueryFilterFieldMap<E> & QueryFilterRootOperator<E>;\n\nexport type QueryFilterRootOperator<E> = {\n  /**\n   * joins query clauses with a logical `AND`, returns records that match all the clauses.\n   */\n  readonly $and?: QueryFilterLogical<E>;\n  /**\n   * joins query clauses with a logical `OR`, returns records that match any of the clauses.\n   */\n  readonly $or?: QueryFilterLogical<E>;\n  /**\n   * joins query clauses with a logical `AND`, returns records that do not match all the clauses.\n   */\n  readonly $not?: QueryFilterLogical<E>;\n  /**\n   * joins query clauses with a logical `OR`, returns records that do not match any of the clauses.\n   */\n  readonly $nor?: QueryFilterLogical<E>;\n  /**\n   * whether the specified fields match against a full-text search of the given string.\n   */\n  readonly $text?: QueryTextSearchOptions<E>;\n  /**\n   * whether the record exists in the given sub-query.\n   */\n  readonly $exists?: QueryRaw;\n  /**\n   * whether the record does not exists in the given sub-query.\n   */\n  readonly $nexists?: QueryRaw;\n};\n\nexport type QueryFilterFieldOperatorMap<T> = {\n  /**\n   * whether a value is equal to the given value.\n   */\n  readonly $eq?: ExpandScalar<T>;\n  /**\n   * whether a value is not equal to the given value.\n   */\n  readonly $ne?: ExpandScalar<T>;\n  /**\n   * negates the given comparison.\n   */\n  readonly $not?: QueryFilterFieldValue<T>;\n  /**\n   * whether a value is less than the given value.\n   */\n  readonly $lt?: ExpandScalar<T>;\n  /**\n   * whether a value is less than or equal to the given value.\n   */\n  readonly $lte?: ExpandScalar<T>;\n  /**\n   * whether a value is greater than the given value.\n   */\n  readonly $gt?: ExpandScalar<T>;\n  /**\n   * whether a value is greater than or equal to the given value.\n   */\n  readonly $gte?: ExpandScalar<T>;\n  /**\n   * whether a string begins with the given string (case sensitive).\n   */\n  readonly $startsWith?: string;\n  /**\n   * whether a string begins with the given string (case insensitive).\n   */\n  readonly $istartsWith?: string;\n  /**\n   * whether a string ends with the given string (case sensitive).\n   */\n  readonly $endsWith?: string;\n  /**\n   * whether a string ends with the given string (case insensitive).\n   */\n  readonly $iendsWith?: string;\n  /**\n   * whether a string is contained within the given string (case sensitive).\n   */\n  readonly $includes?: string;\n  /**\n   * whether a string is contained within the given string (case insensitive).\n   */\n  readonly $iincludes?: string;\n  /**\n   * whether a string fulfills the given pattern (case sensitive).\n   */\n  readonly $like?: string;\n  /**\n   * whether a string fulfills the given pattern (case insensitive).\n   */\n  readonly $ilike?: string;\n  /**\n   * whether a string matches the given regular expression.\n   */\n  readonly $regex?: string;\n  /**\n   * whether a value matches any of the given values.\n   */\n  readonly $in?: readonly ExpandScalar<T>[];\n  /**\n   * whether a value does not match any of the given values.\n   */\n  readonly $nin?: readonly ExpandScalar<T>[];\n};\n\n/**\n * Value for a field comparison.\n */\nexport type QueryFilterFieldValue<T> = T | readonly T[] | QueryFilterFieldOperatorMap<T> | QueryRaw;\n\n/**\n * query filter.\n */\nexport type QueryFilter<E> = IdValue<E> | readonly IdValue<E>[] | QueryRaw | QueryFilterMap<E>;\n\n/**\n * direction for the sort.\n */\nexport type QuerySortDirection = -1 | 1 | 'asc' | 'desc';\n\n/**\n * sort by tuples\n */\nexport type QuerySortTuples<E> = readonly [FieldKey<E>, QuerySortDirection][];\n\n/**\n * sort by objects.\n */\nexport type QuerySortObjects<E> = readonly { readonly field: FieldKey<E>; readonly sort: QuerySortDirection }[];\n\n/**\n * sort by fields.\n */\nexport type QuerySortFieldMap<E> =\n  | {\n      [K in FieldKey<E>]?: QuerySortDirection;\n    }\n  | { [K: string]: QuerySortDirection };\n\n/**\n * sort by relations fields.\n */\nexport type QuerySortRelationMap<E> = {\n  [K in RelationKey<E>]?: QuerySortMap<Unpacked<E[K]>>;\n};\n\n/**\n * sort by map.\n */\nexport type QuerySortMap<E> = QuerySortFieldMap<E> | QuerySortRelationMap<E>;\n\n/**\n * sort options.\n */\nexport type QuerySort<E> = QuerySortMap<E> | QuerySortTuples<E> | QuerySortObjects<E>;\n\n/**\n * pager options.\n */\nexport type QueryPager = {\n  /**\n   * Index from where start the search\n   */\n  $skip?: number;\n\n  /**\n   * Max number of records to retrieve\n   */\n  $limit?: number;\n};\n\n/**\n * search options.\n */\nexport type QuerySearch<E> = {\n  /**\n   * filtering options.\n   */\n  $filter?: QueryFilter<E>;\n\n  /**\n   * list of fields to group.\n   */\n  $group?: readonly FieldKey<E>[];\n\n  /**\n   * having options.\n   */\n  $having?: QueryFilter<E>;\n} & QueryPager;\n\n/**\n * criteria options.\n */\nexport type QueryCriteria<E> = QuerySearch<E> & {\n  /**\n   * sorting options.\n   */\n  $sort?: QuerySort<E>;\n};\n\n/**\n * criteria one options.\n */\nexport type QueryOneCriteria<E> = Omit<QueryCriteria<E>, '$limit'>;\n\n/**\n * query options.\n */\nexport type Query<E> = {\n  /**\n   * projection options.\n   */\n  $project?: QueryProject<E>;\n} & QueryCriteria<E>;\n\n/**\n * options to get a single record.\n */\nexport type QueryOne<E> = Omit<Query<E>, '$limit'>;\n\n/**\n * options to get an unique record.\n */\nexport type QueryUnique<E> = Pick<QueryOne<E>, '$project' | '$filter'>;\n\n/**\n * stringified query.\n */\nexport type QueryStringified = {\n  readonly [K in keyof Query<any>]?: string;\n};\n\n/**\n * result of an update operation.\n */\nexport type QueryUpdateResult = {\n  /**\n   * number of changes.\n   */\n  readonly changes?: number;\n  /**\n   * first inserted ID.\n   */\n  readonly firstId?: number;\n};\n\n/**\n * options for the `raw` function.\n */\nexport type QueryRawFnOptions = {\n  /**\n   * the current dialect.\n   */\n  readonly dialect: QueryDialect;\n  /**\n   * the prefix.\n   */\n  readonly prefix?: string;\n  /**\n   * the escaped prefix.\n   */\n  readonly escapedPrefix?: string;\n};\n\n/**\n * a `raw` function\n */\nexport type QueryRawFn = (opts?: QueryRawFnOptions) => string;\n\nexport class QueryRaw {\n  constructor(\n    readonly value: Scalar | QueryRawFn,\n    readonly alias?: string,\n  ) {}\n}\n\n/**\n * comparison options.\n */\nexport type QueryComparisonOptions = QueryOptions & {\n  /**\n   * use precedence for the comparison or not.\n   */\n  readonly usePrecedence?: boolean;\n};\n\n/**\n * query filter options.\n */\nexport type QueryFilterOptions = QueryComparisonOptions & {\n  /**\n   * clause to be used in the filter.\n   */\n  readonly clause?: 'WHERE' | 'HAVING' | false;\n};\n\nexport interface QueryDialect {\n  /**\n   * obtains the records matching the given search parameters.\n   * @param entity the target entity\n   * @param qm the criteria options\n   * @param opts the query options\n   */\n  find<E, P extends QueryProject<E>>(entity: Type<E>, qm: QueryCriteria<E>, project?: P, opts?: QueryOptions): string;\n\n  /**\n   * counts the number of records matching the given search parameters.\n   * @param entity the target entity\n   * @param qm the criteria options\n   * @param opts the query options\n   */\n  count<E>(entity: Type<E>, qm: QuerySearch<E>, opts?: QueryOptions): string;\n\n  /**\n   * inser records.\n   * @param entity the target entity\n   * @param qm the criteria options\n   * @param opts the query options\n   */\n  insert<E>(entity: Type<E>, payload: E | readonly E[], opts?: QueryOptions): string;\n\n  /**\n   * update records.\n   * @param entity the target entity\n   * @param qm the criteria options\n   * @param payload\n   * @param opts the query options\n   */\n  update<E>(entity: Type<E>, qm: QuerySearch<E>, payload: E, opts?: QueryOptions): string;\n\n  /**\n   * delete records.\n   * @param entity the target entity\n   * @param qm the criteria options\n   * @param opts the query options\n   */\n  delete<E>(entity: Type<E>, qm: QuerySearch<E>, opts?: QueryOptions): string;\n\n  /**\n   * escape an identifier.\n   * @param val the value to be escaped\n   * @param forbidQualified don't escape dots\n   * @param addDot use a dot as suffix\n   */\n  escapeId(val: string, forbidQualified?: boolean, addDot?: boolean): string;\n\n  /**\n   * escape a value.\n   * @param val the value to escape\n   */\n  escape(val: any): Scalar;\n}\n\nexport type Merge<E, P> = E & (P extends string[] ? {} : { [K in Exclude<keyof P, keyof E>]: Scalar });\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query.js","sourceRoot":"","sources":["../../src/type/query.ts"],"names":[],"mappings":"AAsWA,MAAM,OAAO,QAAQ;IAER;IACA;IAFX,YACW,KAA0B,EAC1B,KAAc;QADd,UAAK,GAAL,KAAK,CAAqB;QAC1B,UAAK,GAAL,KAAK,CAAS;IACtB,CAAC;CACL","sourcesContent":["import { FieldKey, IdValue, Key, RelationKey } from './entity.js';\nimport { BooleanLike, ExpandScalar, Scalar, Type, Unpacked } from './utility.js';\n\nexport type QueryOptions = {\n  /**\n   * use or omit `softDelete` attribute.\n   */\n  readonly softDelete?: boolean;\n  /**\n   * prefix the query with this.\n   */\n  readonly prefix?: string;\n  /**\n   * automatically infer the prefix for the query.\n   */\n  readonly autoPrefix?: boolean;\n};\n\nexport type QueryProjectOptions = {\n  /**\n   * prefix the query with this.\n   */\n  readonly prefix?: string;\n  /**\n   * automatically add the prefix for the alias.\n   */\n  readonly autoPrefixAlias?: boolean;\n};\n\n/**\n * query projection as an array.\n */\nexport type QueryProjectArray<E> = readonly (Key<E> | QueryRaw)[];\n\n/**\n * query projection as a map.\n */\nexport type QueryProjectMap<E> = QueryProjectFieldMap<E> | QueryProjectRelationMap<E>;\n\n/**\n * query projection.\n */\nexport type QueryProject<E> = QueryProjectArray<E> | QueryProjectMap<E>;\n\n/**\n * query projection of fields as a map.\n */\nexport type QueryProjectFieldMap<E> = {\n  readonly [K in FieldKey<E>]?: BooleanLike;\n};\n\n/**\n * query projection of relations as a map.\n */\nexport type QueryProjectRelationMap<E> = {\n  readonly [K in RelationKey<E>]?: BooleanLike | readonly Key<Unpacked<E[K]>>[] | QueryProjectRelationOptions<E[K]>;\n};\n\n/**\n * options to project a relation.\n */\nexport type QueryProjectRelationOptions<E> = (E extends unknown[] ? Query<Unpacked<E>> : QueryUnique<Unpacked<E>>) & {\n  readonly $required?: boolean;\n};\n\n/**\n * options for full-text-search operator.\n */\nexport type QueryTextSearchOptions<E> = {\n  /**\n   * text to search for.\n   */\n  readonly $value: string;\n  /**\n   * list of fields to search on.\n   */\n  readonly $fields?: readonly FieldKey<E>[];\n};\n\n/**\n * comparison by fields.\n */\nexport type QueryFilterFieldMap<E> = { readonly [K in FieldKey<E>]?: QueryFilterFieldValue<E[K]> };\n\n/**\n * complex operators.\n */\nexport type QueryFilterMap<E> = QueryFilterFieldMap<E> & QueryFilterRootOperator<E>;\n\nexport type QueryFilterRootOperator<E> = {\n  /**\n   * joins query clauses with a logical `AND`, returns records that match all the clauses.\n   */\n  readonly $and?: QueryFilterArray<E>;\n  /**\n   * joins query clauses with a logical `OR`, returns records that match any of the clauses.\n   */\n  readonly $or?: QueryFilterArray<E>;\n  /**\n   * joins query clauses with a logical `AND`, returns records that do not match all the clauses.\n   */\n  readonly $not?: QueryFilterArray<E>;\n  /**\n   * joins query clauses with a logical `OR`, returns records that do not match any of the clauses.\n   */\n  readonly $nor?: QueryFilterArray<E>;\n  /**\n   * whether the specified fields match against a full-text search of the given string.\n   */\n  readonly $text?: QueryTextSearchOptions<E>;\n  /**\n   * whether the record exists in the given sub-query.\n   */\n  readonly $exists?: QueryRaw;\n  /**\n   * whether the record does not exists in the given sub-query.\n   */\n  readonly $nexists?: QueryRaw;\n};\n\nexport type QueryFilterFieldOperatorMap<T> = {\n  /**\n   * whether a value is equal to the given value.\n   */\n  readonly $eq?: ExpandScalar<T>;\n  /**\n   * whether a value is not equal to the given value.\n   */\n  readonly $ne?: ExpandScalar<T>;\n  /**\n   * negates the given comparison.\n   */\n  readonly $not?: QueryFilterFieldValue<T>;\n  /**\n   * whether a value is less than the given value.\n   */\n  readonly $lt?: ExpandScalar<T>;\n  /**\n   * whether a value is less than or equal to the given value.\n   */\n  readonly $lte?: ExpandScalar<T>;\n  /**\n   * whether a value is greater than the given value.\n   */\n  readonly $gt?: ExpandScalar<T>;\n  /**\n   * whether a value is greater than or equal to the given value.\n   */\n  readonly $gte?: ExpandScalar<T>;\n  /**\n   * whether a string begins with the given string (case sensitive).\n   */\n  readonly $startsWith?: string;\n  /**\n   * whether a string begins with the given string (case insensitive).\n   */\n  readonly $istartsWith?: string;\n  /**\n   * whether a string ends with the given string (case sensitive).\n   */\n  readonly $endsWith?: string;\n  /**\n   * whether a string ends with the given string (case insensitive).\n   */\n  readonly $iendsWith?: string;\n  /**\n   * whether a string is contained within the given string (case sensitive).\n   */\n  readonly $includes?: string;\n  /**\n   * whether a string is contained within the given string (case insensitive).\n   */\n  readonly $iincludes?: string;\n  /**\n   * whether a string fulfills the given pattern (case sensitive).\n   */\n  readonly $like?: string;\n  /**\n   * whether a string fulfills the given pattern (case insensitive).\n   */\n  readonly $ilike?: string;\n  /**\n   * whether a string matches the given regular expression.\n   */\n  readonly $regex?: string;\n  /**\n   * whether a value matches any of the given values.\n   */\n  readonly $in?: readonly ExpandScalar<T>[];\n  /**\n   * whether a value does not match any of the given values.\n   */\n  readonly $nin?: readonly ExpandScalar<T>[];\n};\n\n/**\n * Value for a field comparison.\n */\nexport type QueryFilterFieldValue<T> = T | readonly T[] | QueryFilterFieldOperatorMap<T> | QueryRaw;\n\n/**\n * query single filter.\n */\nexport type QueryFilterSingle<E> = IdValue<E> | readonly IdValue<E>[] | QueryFilterMap<E> | QueryRaw;\n\n/**\n * query filter array.\n */\nexport type QueryFilterArray<E> = readonly QueryFilterSingle<E>[];\n\n/**\n * query filter.\n */\nexport type QueryFilter<E> = QueryFilterSingle<E> | QueryFilterArray<E>;\n\n/**\n * direction for the sort.\n */\nexport type QuerySortDirection = -1 | 1 | 'asc' | 'desc';\n\n/**\n * sort by tuples\n */\nexport type QuerySortTuples<E> = readonly [FieldKey<E>, QuerySortDirection][];\n\n/**\n * sort by objects.\n */\nexport type QuerySortObjects<E> = readonly { readonly field: FieldKey<E>; readonly sort: QuerySortDirection }[];\n\n/**\n * sort by fields.\n */\nexport type QuerySortFieldMap<E> = {\n  readonly [K in FieldKey<E>]?: QuerySortDirection;\n};\n\n/**\n * sort by relations fields.\n */\nexport type QuerySortRelationMap<E> = {\n  readonly [K in RelationKey<E>]?: QuerySortMap<Unpacked<E[K]>>;\n};\n\n/**\n * sort by map.\n */\nexport type QuerySortMap<E> = QuerySortFieldMap<E> | QuerySortRelationMap<E>;\n\n/**\n * sort options.\n */\nexport type QuerySort<E> = QuerySortMap<E> | QuerySortTuples<E> | QuerySortObjects<E>;\n\n/**\n * pager options.\n */\nexport type QueryPager = {\n  /**\n   * Index from where start the search\n   */\n  $skip?: number;\n\n  /**\n   * Max number of records to retrieve\n   */\n  $limit?: number;\n};\n\n/**\n * search options.\n */\nexport type QuerySearch<E> = {\n  /**\n   * filtering options.\n   */\n  $filter?: QueryFilter<E>;\n} & QueryPager;\n\n/**\n * criteria options.\n */\nexport type QueryCriteria<E> = QuerySearch<E> & {\n  /**\n   * sorting options.\n   */\n  $sort?: QuerySort<E>;\n};\n\n/**\n * criteria one options.\n */\nexport type QueryOneCriteria<E> = Omit<QueryCriteria<E>, '$limit'>;\n\n/**\n * query options.\n */\nexport type Query<E> = {\n  /**\n   * projection options.\n   */\n  $project?: QueryProject<E>;\n} & QueryCriteria<E>;\n\n/**\n * options to get a single record.\n */\nexport type QueryOne<E> = Omit<Query<E>, '$limit'>;\n\n/**\n * options to get an unique record.\n */\nexport type QueryUnique<E> = Pick<QueryOne<E>, '$project' | '$filter'>;\n\n/**\n * stringified query.\n */\nexport type QueryStringified = {\n  readonly [K in keyof Query<any>]?: string;\n};\n\n/**\n * result of an update operation.\n */\nexport type QueryUpdateResult = {\n  /**\n   * number of changes.\n   */\n  readonly changes?: number;\n  /**\n   * first inserted ID.\n   */\n  readonly firstId?: number;\n};\n\n/**\n * options for the `raw` function.\n */\nexport type QueryRawFnOptions = {\n  /**\n   * the current dialect.\n   */\n  readonly dialect: QueryDialect;\n  /**\n   * the prefix.\n   */\n  readonly prefix?: string;\n  /**\n   * the escaped prefix.\n   */\n  readonly escapedPrefix?: string;\n};\n\n/**\n * a `raw` function\n */\nexport type QueryRawFn = (opts?: QueryRawFnOptions) => string;\n\nexport class QueryRaw {\n  constructor(\n    readonly value: Scalar | QueryRawFn,\n    readonly alias?: string,\n  ) {}\n}\n\n/**\n * comparison options.\n */\nexport type QueryComparisonOptions = QueryOptions & {\n  /**\n   * use precedence for the comparison or not.\n   */\n  readonly usePrecedence?: boolean;\n};\n\n/**\n * query filter options.\n */\nexport type QueryFilterOptions = QueryComparisonOptions & {\n  /**\n   * clause to be used in the filter.\n   */\n  readonly clause?: 'WHERE' | 'HAVING' | false;\n};\n\nexport interface QueryDialect {\n  /**\n   * obtains the records matching the given search parameters.\n   * @param entity the target entity\n   * @param qm the criteria options\n   * @param opts the query options\n   */\n  find<E>(entity: Type<E>, qm: QueryCriteria<E>, project?: QueryProject<E>, opts?: QueryOptions): string;\n\n  /**\n   * counts the number of records matching the given search parameters.\n   * @param entity the target entity\n   * @param qm the criteria options\n   * @param opts the query options\n   */\n  count<E>(entity: Type<E>, qm: QuerySearch<E>, opts?: QueryOptions): string;\n\n  /**\n   * inser records.\n   * @param entity the target entity\n   * @param qm the criteria options\n   * @param opts the query options\n   */\n  insert<E>(entity: Type<E>, payload: E | readonly E[], opts?: QueryOptions): string;\n\n  /**\n   * update records.\n   * @param entity the target entity\n   * @param qm the criteria options\n   * @param payload\n   * @param opts the query options\n   */\n  update<E>(entity: Type<E>, qm: QuerySearch<E>, payload: E, opts?: QueryOptions): string;\n\n  /**\n   * delete records.\n   * @param entity the target entity\n   * @param qm the criteria options\n   * @param opts the query options\n   */\n  delete<E>(entity: Type<E>, qm: QuerySearch<E>, opts?: QueryOptions): string;\n\n  /**\n   * escape an identifier.\n   * @param val the value to be escaped\n   * @param forbidQualified don't escape dots\n   * @param addDot use a dot as suffix\n   */\n  escapeId(val: string, forbidQualified?: boolean, addDot?: boolean): string;\n\n  /**\n   * escape a value.\n   * @param val the value to escape\n   */\n  escape(val: any): Scalar;\n}\n"]}
import type { IdValue } from './entity.js';
import type { QueryCriteria, QueryOptions, QueryProject, QuerySearch, Merge, QueryOneCriteria } from './query.js';
import type { QueryCriteria, QueryOptions, QueryProject, QuerySearch, QueryOneCriteria } from './query.js';
import type { UniversalQuerier } from './universalQuerier.js';

@@ -22,3 +22,3 @@ import type { Type } from './utility.js';

*/
findOneById<P extends QueryProject<E>>(id: IdValue<E>, project?: P): Promise<any>;
findOneById(id: IdValue<E>, project?: QueryProject<E>): Promise<any>;
/**

@@ -28,3 +28,3 @@ * obtains the first record matching the given search parameters.

*/
findOne<P extends QueryProject<E>>(qm: QueryOneCriteria<E>, project?: P): Promise<any>;
findOne(qm: QueryOneCriteria<E>, project?: QueryProject<E>): Promise<any>;
/**

@@ -34,3 +34,3 @@ * obtains the records matching the given search parameters.

*/
findMany<P extends QueryProject<E>>(qm: QueryCriteria<E>, project?: P): Promise<any>;
findMany(qm: QueryCriteria<E>, project?: QueryProject<E>): Promise<any>;
/**

@@ -41,3 +41,3 @@ * obtains the records matching the given search parameters,

*/
findManyAndCount<P extends QueryProject<E>>(qm: QueryCriteria<E>, project?: P): Promise<any>;
findManyAndCount(qm: QueryCriteria<E>, project?: QueryProject<E>): Promise<any>;
/**

@@ -96,6 +96,6 @@ * counts the number of records matching the given search parameters.

export interface Repository<E> extends UniversalRepository<E> {
findOneById<P extends QueryProject<E>>(id: IdValue<E>, project?: P): Promise<Merge<E, P>>;
findOne<P extends QueryProject<E>>(qm: QueryOneCriteria<E>, project?: P): Promise<Merge<E, P>>;
findMany<P extends QueryProject<E>>(qm: QueryCriteria<E>, project?: P): Promise<Merge<E, P>[]>;
findManyAndCount<P extends QueryProject<E>>(qm: QueryCriteria<E>, project?: P): Promise<[Merge<E, P>[], number]>;
findOneById(id: IdValue<E>, project?: QueryProject<E>): Promise<E>;
findOne(qm: QueryOneCriteria<E>, project?: QueryProject<E>): Promise<E>;
findMany(qm: QueryCriteria<E>, project?: QueryProject<E>): Promise<E[]>;
findManyAndCount(qm: QueryCriteria<E>, project?: QueryProject<E>): Promise<[E[], number]>;
count(qm?: QuerySearch<E>): Promise<number>;

@@ -102,0 +102,0 @@ insertOne(payload: E): Promise<IdValue<E>>;

export {};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVwb3NpdG9yeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90eXBlL3JlcG9zaXRvcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgSWRWYWx1ZSB9IGZyb20gJy4vZW50aXR5LmpzJztcbmltcG9ydCB0eXBlIHsgUXVlcnlDcml0ZXJpYSwgUXVlcnlPcHRpb25zLCBRdWVyeVByb2plY3QsIFF1ZXJ5U2VhcmNoLCBNZXJnZSwgUXVlcnlPbmVDcml0ZXJpYSB9IGZyb20gJy4vcXVlcnkuanMnO1xuaW1wb3J0IHR5cGUgeyBVbml2ZXJzYWxRdWVyaWVyIH0gZnJvbSAnLi91bml2ZXJzYWxRdWVyaWVyLmpzJztcbmltcG9ydCB0eXBlIHsgVHlwZSB9IGZyb20gJy4vdXRpbGl0eS5qcyc7XG5cbi8qKlxuICogQSBgcmVwb3NpdG9yeWAgYWxsb3dzIHRvIGludGVyYWN0IHdpdGggdGhlIGRhdGFzb3VyY2UgdG8gcGVyZm9ybSBwZXJzaXN0ZW5jZSBvcGVyYXRpb25zIG9uIGEgc3BlY2lmaWMgZW50aXR5LlxuICovXG5leHBvcnQgdHlwZSBVbml2ZXJzYWxSZXBvc2l0b3J5PEU+ID0ge1xuICAvKipcbiAgICogdGhlIGBlbnRpdHlgIGNsYXNzIHRvIHdoaWNoIHRoaXMgYHJlcG9zaXRvcnlgIGlzIGxpbmtlZCB0by5cbiAgICovXG4gIHJlYWRvbmx5IGVudGl0eTogVHlwZTxFPjtcblxuICAvKipcbiAgICogdGhlIGBxdWVyaWVyYCBpbnN0YW5jZSB0byB3aGljaCB0aGlzIGByZXBvc2l0b3J5YCBpcyBsaW5rZWQgdG8uXG4gICAqL1xuICByZWFkb25seSBxdWVyaWVyOiBVbml2ZXJzYWxRdWVyaWVyO1xuXG4gIC8qKlxuICAgKiBvYnRhaW5zIHRoZSByZWNvcmQgd2l0aCB0aGUgZ2l2ZW4gcHJpbWFyeSBrZXkuXG4gICAqIEBwYXJhbSBpZCB0aGUgcHJpbWFyeSBrZXkgdmFsdWVcbiAgICogQHBhcmFtIHFtIHRoZSBjcml0ZXJpYSBvcHRpb25zXG4gICAqL1xuICBmaW5kT25lQnlJZDxQIGV4dGVuZHMgUXVlcnlQcm9qZWN0PEU+PihpZDogSWRWYWx1ZTxFPiwgcHJvamVjdD86IFApOiBQcm9taXNlPGFueT47XG5cbiAgLyoqXG4gICAqIG9idGFpbnMgdGhlIGZpcnN0IHJlY29yZCBtYXRjaGluZyB0aGUgZ2l2ZW4gc2VhcmNoIHBhcmFtZXRlcnMuXG4gICAqIEBwYXJhbSBxbSB0aGUgY3JpdGVyaWEgb3B0aW9uc1xuICAgKi9cbiAgZmluZE9uZTxQIGV4dGVuZHMgUXVlcnlQcm9qZWN0PEU+PihxbTogUXVlcnlPbmVDcml0ZXJpYTxFPiwgcHJvamVjdD86IFApOiBQcm9taXNlPGFueT47XG5cbiAgLyoqXG4gICAqIG9idGFpbnMgdGhlIHJlY29yZHMgbWF0Y2hpbmcgdGhlIGdpdmVuIHNlYXJjaCBwYXJhbWV0ZXJzLlxuICAgKiBAcGFyYW0gcW0gdGhlIGNyaXRlcmlhIG9wdGlvbnNcbiAgICovXG4gIGZpbmRNYW55PFAgZXh0ZW5kcyBRdWVyeVByb2plY3Q8RT4+KHFtOiBRdWVyeUNyaXRlcmlhPEU+LCBwcm9qZWN0PzogUCk6IFByb21pc2U8YW55PjtcblxuICAvKipcbiAgICogb2J0YWlucyB0aGUgcmVjb3JkcyBtYXRjaGluZyB0aGUgZ2l2ZW4gc2VhcmNoIHBhcmFtZXRlcnMsXG4gICAqIGFsc28gY291bnRzIHRoZSBudW1iZXIgb2YgbWF0Y2hlcyBpZ25vcmluZyBwYWdpbmF0aW9uLlxuICAgKiBAcGFyYW0gcW0gdGhlIGNyaXRlcmlhIG9wdGlvbnNcbiAgICovXG4gIGZpbmRNYW55QW5kQ291bnQ8UCBleHRlbmRzIFF1ZXJ5UHJvamVjdDxFPj4ocW06IFF1ZXJ5Q3JpdGVyaWE8RT4sIHByb2plY3Q/OiBQKTogUHJvbWlzZTxhbnk+O1xuXG4gIC8qKlxuICAgKiBjb3VudHMgdGhlIG51bWJlciBvZiByZWNvcmRzIG1hdGNoaW5nIHRoZSBnaXZlbiBzZWFyY2ggcGFyYW1ldGVycy5cbiAgICogQHBhcmFtIHFtIHRoZSBzZWFyY2ggb3B0aW9uc1xuICAgKi9cbiAgY291bnQocW0/OiBRdWVyeVNlYXJjaDxFPik6IFByb21pc2U8YW55PjtcblxuICAvKipcbiAgICogaW5zZXJ0cyBhIHJlY29yZC5cbiAgICogQHBhcmFtIHBheWxvYWQgdGhlIGRhdGEgdG8gYmUgcGVyc2lzdGVkXG4gICAqL1xuICBpbnNlcnRPbmUocGF5bG9hZDogRSk6IFByb21pc2U8YW55PjtcblxuICAvKipcbiAgICogSW5zZXJ0cyBtYW55IHJlY29yZHMuXG4gICAqIEBwYXJhbSBlbnRpdHkgdGhlIGVudGl0eSB0byBwZXJzaXN0IG9uXG4gICAqIEBwYXJhbSBwYXlsb2FkIHRoZSBkYXRhIHRvIGJlIHBlcnNpc3RlZFxuICAgKi9cbiAgaW5zZXJ0TWFueT8ocGF5bG9hZDogRVtdKTogUHJvbWlzZTxhbnk+O1xuXG4gIC8qKlxuICAgKiB1cGRhdGVzIGEgcmVjb3JkIHBhcnRpYWxseS5cbiAgICogQHBhcmFtIGlkIHRoZSBwcmltYXJ5IGtleSBvZiB0aGUgcmVjb3JkIHRvIGJlIHVwZGF0ZWRcbiAgICogQHBhcmFtIHBheWxvYWQgdGhlIGRhdGEgdG8gYmUgcGVyc2lzdGVkXG4gICAqL1xuICB1cGRhdGVPbmVCeUlkKGlkOiBJZFZhbHVlPEU+LCBwYXlsb2FkOiBFKTogUHJvbWlzZTxhbnk+O1xuXG4gIC8qKlxuICAgKiB1cGRhdGVzIG1hbnkgcmVjb3JkcyBwYXJ0aWFsbHkuXG4gICAqIEBwYXJhbSBxbSB0aGUgY3JpdGVyaWEgdG8gbG9vayBmb3IgdGhlIHJlY29yZHNcbiAgICogQHBhcmFtIHBheWxvYWQgdGhlIGRhdGEgdG8gYmUgcGVyc2lzdGVkXG4gICAqL1xuICB1cGRhdGVNYW55PyhxbTogUXVlcnlTZWFyY2g8RT4sIHBheWxvYWQ6IEUpOiBQcm9taXNlPGFueT47XG5cbiAgLyoqXG4gICAqIEluc2VydCBvciB1cGRhdGUgYSByZWNvcmQuXG4gICAqIEBwYXJhbSBwYXlsb2FkIHRoZSBkYXRhIHRvIGJlIHBlcnNpc3RlZFxuICAgKi9cbiAgc2F2ZU9uZShwYXlsb2FkOiBFKTogUHJvbWlzZTxhbnk+O1xuXG4gIC8qKlxuICAgKiBpbnNlcnQgb3IgdXBkYXRlIHJlY29yZHMuXG4gICAqIEBwYXJhbSBwYXlsb2FkIHRoZSBkYXRhIHRvIGJlIHBlcnNpc3RlZFxuICAgKi9cbiAgc2F2ZU1hbnk/KHBheWxvYWQ6IEVbXSk6IFByb21pc2U8YW55PjtcblxuICAvKipcbiAgICogZGVsZXRlIG9yIFNvZnREZWxldGUgYSByZWNvcmQuXG4gICAqIEBwYXJhbSBpZCB0aGUgcHJpbWFyeSBrZXkgb2YgdGhlIHJlY29yZFxuICAgKi9cbiAgZGVsZXRlT25lQnlJZChpZDogSWRWYWx1ZTxFPiwgb3B0cz86IFF1ZXJ5T3B0aW9ucyk6IFByb21pc2U8YW55PjtcblxuICAvKipcbiAgICogZGVsZXRlIG9yIFNvZnREZWxldGUgcmVjb3Jkcy5cbiAgICogQHBhcmFtIHFtIHRoZSBjcml0ZXJpYSB0byBsb29rIGZvciB0aGUgcmVjb3Jkc1xuICAgKi9cbiAgZGVsZXRlTWFueShxbTogUXVlcnlTZWFyY2g8RT4sIG9wdHM/OiBRdWVyeU9wdGlvbnMpOiBQcm9taXNlPGFueT47XG59O1xuXG4vKipcbiAqIGJhc2UgY29udHJhY3QgZm9yIHRoZSBiYWNrZW5kIHJlcG9zaXRvcmllcy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBSZXBvc2l0b3J5PEU+IGV4dGVuZHMgVW5pdmVyc2FsUmVwb3NpdG9yeTxFPiB7XG4gIGZpbmRPbmVCeUlkPFAgZXh0ZW5kcyBRdWVyeVByb2plY3Q8RT4+KGlkOiBJZFZhbHVlPEU+LCBwcm9qZWN0PzogUCk6IFByb21pc2U8TWVyZ2U8RSwgUD4+O1xuXG4gIGZpbmRPbmU8UCBleHRlbmRzIFF1ZXJ5UHJvamVjdDxFPj4ocW06IFF1ZXJ5T25lQ3JpdGVyaWE8RT4sIHByb2plY3Q/OiBQKTogUHJvbWlzZTxNZXJnZTxFLCBQPj47XG5cbiAgZmluZE1hbnk8UCBleHRlbmRzIFF1ZXJ5UHJvamVjdDxFPj4ocW06IFF1ZXJ5Q3JpdGVyaWE8RT4sIHByb2plY3Q/OiBQKTogUHJvbWlzZTxNZXJnZTxFLCBQPltdPjtcblxuICBmaW5kTWFueUFuZENvdW50PFAgZXh0ZW5kcyBRdWVyeVByb2plY3Q8RT4+KHFtOiBRdWVyeUNyaXRlcmlhPEU+LCBwcm9qZWN0PzogUCk6IFByb21pc2U8W01lcmdlPEUsIFA+W10sIG51bWJlcl0+O1xuXG4gIGNvdW50KHFtPzogUXVlcnlTZWFyY2g8RT4pOiBQcm9taXNlPG51bWJlcj47XG5cbiAgaW5zZXJ0T25lKHBheWxvYWQ6IEUpOiBQcm9taXNlPElkVmFsdWU8RT4+O1xuXG4gIGluc2VydE1hbnkocGF5bG9hZDogRVtdKTogUHJvbWlzZTxJZFZhbHVlPEU+W10+O1xuXG4gIHVwZGF0ZU9uZUJ5SWQoaWQ6IElkVmFsdWU8RT4sIHBheWxvYWQ6IEUpOiBQcm9taXNlPG51bWJlcj47XG5cbiAgdXBkYXRlTWFueShxbTogUXVlcnlTZWFyY2g8RT4sIHBheWxvYWQ6IEUpOiBQcm9taXNlPG51bWJlcj47XG5cbiAgc2F2ZU9uZShwYXlsb2FkOiBFKTogUHJvbWlzZTxJZFZhbHVlPEU+PjtcblxuICBzYXZlTWFueT8ocGF5bG9hZDogRVtdKTogUHJvbWlzZTxJZFZhbHVlPEU+W10+O1xuXG4gIGRlbGV0ZU9uZUJ5SWQoaWQ6IElkVmFsdWU8RT4sIG9wdHM/OiBRdWVyeU9wdGlvbnMpOiBQcm9taXNlPG51bWJlcj47XG5cbiAgZGVsZXRlTWFueShxbTogUXVlcnlTZWFyY2g8RT4sIG9wdHM/OiBRdWVyeU9wdGlvbnMpOiBQcm9taXNlPG51bWJlcj47XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVwb3NpdG9yeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90eXBlL3JlcG9zaXRvcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgSWRWYWx1ZSB9IGZyb20gJy4vZW50aXR5LmpzJztcbmltcG9ydCB0eXBlIHsgUXVlcnlDcml0ZXJpYSwgUXVlcnlPcHRpb25zLCBRdWVyeVByb2plY3QsIFF1ZXJ5U2VhcmNoLCBRdWVyeU9uZUNyaXRlcmlhIH0gZnJvbSAnLi9xdWVyeS5qcyc7XG5pbXBvcnQgdHlwZSB7IFVuaXZlcnNhbFF1ZXJpZXIgfSBmcm9tICcuL3VuaXZlcnNhbFF1ZXJpZXIuanMnO1xuaW1wb3J0IHR5cGUgeyBUeXBlIH0gZnJvbSAnLi91dGlsaXR5LmpzJztcblxuLyoqXG4gKiBBIGByZXBvc2l0b3J5YCBhbGxvd3MgdG8gaW50ZXJhY3Qgd2l0aCB0aGUgZGF0YXNvdXJjZSB0byBwZXJmb3JtIHBlcnNpc3RlbmNlIG9wZXJhdGlvbnMgb24gYSBzcGVjaWZpYyBlbnRpdHkuXG4gKi9cbmV4cG9ydCB0eXBlIFVuaXZlcnNhbFJlcG9zaXRvcnk8RT4gPSB7XG4gIC8qKlxuICAgKiB0aGUgYGVudGl0eWAgY2xhc3MgdG8gd2hpY2ggdGhpcyBgcmVwb3NpdG9yeWAgaXMgbGlua2VkIHRvLlxuICAgKi9cbiAgcmVhZG9ubHkgZW50aXR5OiBUeXBlPEU+O1xuXG4gIC8qKlxuICAgKiB0aGUgYHF1ZXJpZXJgIGluc3RhbmNlIHRvIHdoaWNoIHRoaXMgYHJlcG9zaXRvcnlgIGlzIGxpbmtlZCB0by5cbiAgICovXG4gIHJlYWRvbmx5IHF1ZXJpZXI6IFVuaXZlcnNhbFF1ZXJpZXI7XG5cbiAgLyoqXG4gICAqIG9idGFpbnMgdGhlIHJlY29yZCB3aXRoIHRoZSBnaXZlbiBwcmltYXJ5IGtleS5cbiAgICogQHBhcmFtIGlkIHRoZSBwcmltYXJ5IGtleSB2YWx1ZVxuICAgKiBAcGFyYW0gcW0gdGhlIGNyaXRlcmlhIG9wdGlvbnNcbiAgICovXG4gIGZpbmRPbmVCeUlkKGlkOiBJZFZhbHVlPEU+LCBwcm9qZWN0PzogUXVlcnlQcm9qZWN0PEU+KTogUHJvbWlzZTxhbnk+O1xuXG4gIC8qKlxuICAgKiBvYnRhaW5zIHRoZSBmaXJzdCByZWNvcmQgbWF0Y2hpbmcgdGhlIGdpdmVuIHNlYXJjaCBwYXJhbWV0ZXJzLlxuICAgKiBAcGFyYW0gcW0gdGhlIGNyaXRlcmlhIG9wdGlvbnNcbiAgICovXG4gIGZpbmRPbmUocW06IFF1ZXJ5T25lQ3JpdGVyaWE8RT4sIHByb2plY3Q/OiBRdWVyeVByb2plY3Q8RT4pOiBQcm9taXNlPGFueT47XG5cbiAgLyoqXG4gICAqIG9idGFpbnMgdGhlIHJlY29yZHMgbWF0Y2hpbmcgdGhlIGdpdmVuIHNlYXJjaCBwYXJhbWV0ZXJzLlxuICAgKiBAcGFyYW0gcW0gdGhlIGNyaXRlcmlhIG9wdGlvbnNcbiAgICovXG4gIGZpbmRNYW55KHFtOiBRdWVyeUNyaXRlcmlhPEU+LCBwcm9qZWN0PzogUXVlcnlQcm9qZWN0PEU+KTogUHJvbWlzZTxhbnk+O1xuXG4gIC8qKlxuICAgKiBvYnRhaW5zIHRoZSByZWNvcmRzIG1hdGNoaW5nIHRoZSBnaXZlbiBzZWFyY2ggcGFyYW1ldGVycyxcbiAgICogYWxzbyBjb3VudHMgdGhlIG51bWJlciBvZiBtYXRjaGVzIGlnbm9yaW5nIHBhZ2luYXRpb24uXG4gICAqIEBwYXJhbSBxbSB0aGUgY3JpdGVyaWEgb3B0aW9uc1xuICAgKi9cbiAgZmluZE1hbnlBbmRDb3VudChxbTogUXVlcnlDcml0ZXJpYTxFPiwgcHJvamVjdD86IFF1ZXJ5UHJvamVjdDxFPik6IFByb21pc2U8YW55PjtcblxuICAvKipcbiAgICogY291bnRzIHRoZSBudW1iZXIgb2YgcmVjb3JkcyBtYXRjaGluZyB0aGUgZ2l2ZW4gc2VhcmNoIHBhcmFtZXRlcnMuXG4gICAqIEBwYXJhbSBxbSB0aGUgc2VhcmNoIG9wdGlvbnNcbiAgICovXG4gIGNvdW50KHFtPzogUXVlcnlTZWFyY2g8RT4pOiBQcm9taXNlPGFueT47XG5cbiAgLyoqXG4gICAqIGluc2VydHMgYSByZWNvcmQuXG4gICAqIEBwYXJhbSBwYXlsb2FkIHRoZSBkYXRhIHRvIGJlIHBlcnNpc3RlZFxuICAgKi9cbiAgaW5zZXJ0T25lKHBheWxvYWQ6IEUpOiBQcm9taXNlPGFueT47XG5cbiAgLyoqXG4gICAqIEluc2VydHMgbWFueSByZWNvcmRzLlxuICAgKiBAcGFyYW0gZW50aXR5IHRoZSBlbnRpdHkgdG8gcGVyc2lzdCBvblxuICAgKiBAcGFyYW0gcGF5bG9hZCB0aGUgZGF0YSB0byBiZSBwZXJzaXN0ZWRcbiAgICovXG4gIGluc2VydE1hbnk/KHBheWxvYWQ6IEVbXSk6IFByb21pc2U8YW55PjtcblxuICAvKipcbiAgICogdXBkYXRlcyBhIHJlY29yZCBwYXJ0aWFsbHkuXG4gICAqIEBwYXJhbSBpZCB0aGUgcHJpbWFyeSBrZXkgb2YgdGhlIHJlY29yZCB0byBiZSB1cGRhdGVkXG4gICAqIEBwYXJhbSBwYXlsb2FkIHRoZSBkYXRhIHRvIGJlIHBlcnNpc3RlZFxuICAgKi9cbiAgdXBkYXRlT25lQnlJZChpZDogSWRWYWx1ZTxFPiwgcGF5bG9hZDogRSk6IFByb21pc2U8YW55PjtcblxuICAvKipcbiAgICogdXBkYXRlcyBtYW55IHJlY29yZHMgcGFydGlhbGx5LlxuICAgKiBAcGFyYW0gcW0gdGhlIGNyaXRlcmlhIHRvIGxvb2sgZm9yIHRoZSByZWNvcmRzXG4gICAqIEBwYXJhbSBwYXlsb2FkIHRoZSBkYXRhIHRvIGJlIHBlcnNpc3RlZFxuICAgKi9cbiAgdXBkYXRlTWFueT8ocW06IFF1ZXJ5U2VhcmNoPEU+LCBwYXlsb2FkOiBFKTogUHJvbWlzZTxhbnk+O1xuXG4gIC8qKlxuICAgKiBJbnNlcnQgb3IgdXBkYXRlIGEgcmVjb3JkLlxuICAgKiBAcGFyYW0gcGF5bG9hZCB0aGUgZGF0YSB0byBiZSBwZXJzaXN0ZWRcbiAgICovXG4gIHNhdmVPbmUocGF5bG9hZDogRSk6IFByb21pc2U8YW55PjtcblxuICAvKipcbiAgICogaW5zZXJ0IG9yIHVwZGF0ZSByZWNvcmRzLlxuICAgKiBAcGFyYW0gcGF5bG9hZCB0aGUgZGF0YSB0byBiZSBwZXJzaXN0ZWRcbiAgICovXG4gIHNhdmVNYW55PyhwYXlsb2FkOiBFW10pOiBQcm9taXNlPGFueT47XG5cbiAgLyoqXG4gICAqIGRlbGV0ZSBvciBTb2Z0RGVsZXRlIGEgcmVjb3JkLlxuICAgKiBAcGFyYW0gaWQgdGhlIHByaW1hcnkga2V5IG9mIHRoZSByZWNvcmRcbiAgICovXG4gIGRlbGV0ZU9uZUJ5SWQoaWQ6IElkVmFsdWU8RT4sIG9wdHM/OiBRdWVyeU9wdGlvbnMpOiBQcm9taXNlPGFueT47XG5cbiAgLyoqXG4gICAqIGRlbGV0ZSBvciBTb2Z0RGVsZXRlIHJlY29yZHMuXG4gICAqIEBwYXJhbSBxbSB0aGUgY3JpdGVyaWEgdG8gbG9vayBmb3IgdGhlIHJlY29yZHNcbiAgICovXG4gIGRlbGV0ZU1hbnkocW06IFF1ZXJ5U2VhcmNoPEU+LCBvcHRzPzogUXVlcnlPcHRpb25zKTogUHJvbWlzZTxhbnk+O1xufTtcblxuLyoqXG4gKiBiYXNlIGNvbnRyYWN0IGZvciB0aGUgYmFja2VuZCByZXBvc2l0b3JpZXMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUmVwb3NpdG9yeTxFPiBleHRlbmRzIFVuaXZlcnNhbFJlcG9zaXRvcnk8RT4ge1xuICBmaW5kT25lQnlJZChpZDogSWRWYWx1ZTxFPiwgcHJvamVjdD86IFF1ZXJ5UHJvamVjdDxFPik6IFByb21pc2U8RT47XG5cbiAgZmluZE9uZShxbTogUXVlcnlPbmVDcml0ZXJpYTxFPiwgcHJvamVjdD86IFF1ZXJ5UHJvamVjdDxFPik6IFByb21pc2U8RT47XG5cbiAgZmluZE1hbnkocW06IFF1ZXJ5Q3JpdGVyaWE8RT4sIHByb2plY3Q/OiBRdWVyeVByb2plY3Q8RT4pOiBQcm9taXNlPEVbXT47XG5cbiAgZmluZE1hbnlBbmRDb3VudChxbTogUXVlcnlDcml0ZXJpYTxFPiwgcHJvamVjdD86IFF1ZXJ5UHJvamVjdDxFPik6IFByb21pc2U8W0VbXSwgbnVtYmVyXT47XG5cbiAgY291bnQocW0/OiBRdWVyeVNlYXJjaDxFPik6IFByb21pc2U8bnVtYmVyPjtcblxuICBpbnNlcnRPbmUocGF5bG9hZDogRSk6IFByb21pc2U8SWRWYWx1ZTxFPj47XG5cbiAgaW5zZXJ0TWFueShwYXlsb2FkOiBFW10pOiBQcm9taXNlPElkVmFsdWU8RT5bXT47XG5cbiAgdXBkYXRlT25lQnlJZChpZDogSWRWYWx1ZTxFPiwgcGF5bG9hZDogRSk6IFByb21pc2U8bnVtYmVyPjtcblxuICB1cGRhdGVNYW55KHFtOiBRdWVyeVNlYXJjaDxFPiwgcGF5bG9hZDogRSk6IFByb21pc2U8bnVtYmVyPjtcblxuICBzYXZlT25lKHBheWxvYWQ6IEUpOiBQcm9taXNlPElkVmFsdWU8RT4+O1xuXG4gIHNhdmVNYW55PyhwYXlsb2FkOiBFW10pOiBQcm9taXNlPElkVmFsdWU8RT5bXT47XG5cbiAgZGVsZXRlT25lQnlJZChpZDogSWRWYWx1ZTxFPiwgb3B0cz86IFF1ZXJ5T3B0aW9ucyk6IFByb21pc2U8bnVtYmVyPjtcblxuICBkZWxldGVNYW55KHFtOiBRdWVyeVNlYXJjaDxFPiwgb3B0cz86IFF1ZXJ5T3B0aW9ucyk6IFByb21pc2U8bnVtYmVyPjtcbn1cbiJdfQ==

@@ -15,3 +15,3 @@ import type { Type } from './utility.js';

*/
findOneById<E, P extends QueryProject<E>>(entity: Type<E>, id: IdValue<E>, project?: P): Promise<any>;
findOneById<E>(entity: Type<E>, id: IdValue<E>, project?: QueryProject<E>): Promise<any>;
/**

@@ -23,3 +23,3 @@ * obtains the first record matching the given search parameters.

*/
findOne<E, P extends QueryProject<E>>(entity: Type<E>, qm: QueryOneCriteria<E>, project?: P): Promise<any>;
findOne<E>(entity: Type<E>, qm: QueryOneCriteria<E>, project?: QueryProject<E>): Promise<any>;
/**

@@ -31,3 +31,3 @@ * obtains the records matching the given search parameters.

*/
findMany<E, P extends QueryProject<E>>(entity: Type<E>, qm: QueryCriteria<E>, project?: P): Promise<any>;
findMany<E>(entity: Type<E>, qm: QueryCriteria<E>, project?: QueryProject<E>): Promise<any>;
/**

@@ -40,3 +40,3 @@ * obtains the records matching the given search parameters,

*/
findManyAndCount<E, P extends QueryProject<E>>(entity: Type<E>, qm: QueryCriteria<E>, project?: P): Promise<any>;
findManyAndCount<E>(entity: Type<E>, qm: QueryCriteria<E>, project?: QueryProject<E>): Promise<any>;
/**

@@ -43,0 +43,0 @@ * counts the number of records matching the given search parameters.

export {};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5pdmVyc2FsUXVlcmllci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90eXBlL3VuaXZlcnNhbFF1ZXJpZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgVHlwZSB9IGZyb20gJy4vdXRpbGl0eS5qcyc7XG5pbXBvcnQgdHlwZSB7IFF1ZXJ5Q3JpdGVyaWEsIFF1ZXJ5T25lQ3JpdGVyaWEsIFF1ZXJ5T3B0aW9ucywgUXVlcnlQcm9qZWN0LCBRdWVyeVNlYXJjaCB9IGZyb20gJy4vcXVlcnkuanMnO1xuaW1wb3J0IHR5cGUgeyBVbml2ZXJzYWxSZXBvc2l0b3J5IH0gZnJvbSAnLi9yZXBvc2l0b3J5LmpzJztcbmltcG9ydCB0eXBlIHsgSWRWYWx1ZSB9IGZyb20gJy4vZW50aXR5LmpzJztcblxuLyoqXG4gKiBBIGBxdWVyaWVyYCBhbGxvd3MgdG8gaW50ZXJhY3Qgd2l0aCB0aGUgZGF0YXNvdXJjZSB0byBwZXJmb3JtIHBlcnNpc3RlbmNlIG9wZXJhdGlvbnMgb24gYW55IGVudGl0eS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBVbml2ZXJzYWxRdWVyaWVyIHtcbiAgLyoqXG4gICAqIG9idGFpbnMgdGhlIHJlY29yZCB3aXRoIHRoZSBnaXZlbiBwcmltYXJ5IGtleS5cbiAgICogQHBhcmFtIGVudGl0eSB0aGUgdGFyZ2V0IGVudGl0eVxuICAgKiBAcGFyYW0gaWQgdGhlIHByaW1hcnkga2V5IHZhbHVlXG4gICAqIEByZXR1cm4gdGhlIHJlY29yZFxuICAgKi9cbiAgZmluZE9uZUJ5SWQ8RSwgUCBleHRlbmRzIFF1ZXJ5UHJvamVjdDxFPj4oZW50aXR5OiBUeXBlPEU+LCBpZDogSWRWYWx1ZTxFPiwgcHJvamVjdD86IFApOiBQcm9taXNlPGFueT47XG5cbiAgLyoqXG4gICAqIG9idGFpbnMgdGhlIGZpcnN0IHJlY29yZCBtYXRjaGluZyB0aGUgZ2l2ZW4gc2VhcmNoIHBhcmFtZXRlcnMuXG4gICAqIEBwYXJhbSBlbnRpdHkgdGhlIHRhcmdldCBlbnRpdHlcbiAgICogQHBhcmFtIHFtIHRoZSBjcml0ZXJpYSBvcHRpb25zXG4gICAqIEByZXR1cm4gdGhlIHJlY29yZFxuICAgKi9cbiAgZmluZE9uZTxFLCBQIGV4dGVuZHMgUXVlcnlQcm9qZWN0PEU+PihlbnRpdHk6IFR5cGU8RT4sIHFtOiBRdWVyeU9uZUNyaXRlcmlhPEU+LCBwcm9qZWN0PzogUCk6IFByb21pc2U8YW55PjtcblxuICAvKipcbiAgICogb2J0YWlucyB0aGUgcmVjb3JkcyBtYXRjaGluZyB0aGUgZ2l2ZW4gc2VhcmNoIHBhcmFtZXRlcnMuXG4gICAqIEBwYXJhbSBlbnRpdHkgdGhlIHRhcmdldCBlbnRpdHlcbiAgICogQHBhcmFtIHFtIHRoZSBjcml0ZXJpYSBvcHRpb25zXG4gICAqIEByZXR1cm4gdGhlIHJlY29yZHNcbiAgICovXG4gIGZpbmRNYW55PEUsIFAgZXh0ZW5kcyBRdWVyeVByb2plY3Q8RT4+KGVudGl0eTogVHlwZTxFPiwgcW06IFF1ZXJ5Q3JpdGVyaWE8RT4sIHByb2plY3Q/OiBQKTogUHJvbWlzZTxhbnk+O1xuXG4gIC8qKlxuICAgKiBvYnRhaW5zIHRoZSByZWNvcmRzIG1hdGNoaW5nIHRoZSBnaXZlbiBzZWFyY2ggcGFyYW1ldGVycyxcbiAgICogYWxzbyBjb3VudHMgdGhlIG51bWJlciBvZiBtYXRjaGVzIGlnbm9yaW5nIHBhZ2luYXRpb24uXG4gICAqIEBwYXJhbSBlbnRpdHkgdGhlIHRhcmdldCBlbnRpdHlcbiAgICogQHBhcmFtIHFtIHRoZSBjcml0ZXJpYSBvcHRpb25zXG4gICAqIEByZXR1cm4gdGhlIHJlY29yZHMgYW5kIHRoZSBjb3VudFxuICAgKi9cbiAgZmluZE1hbnlBbmRDb3VudDxFLCBQIGV4dGVuZHMgUXVlcnlQcm9qZWN0PEU+PihlbnRpdHk6IFR5cGU8RT4sIHFtOiBRdWVyeUNyaXRlcmlhPEU+LCBwcm9qZWN0PzogUCk6IFByb21pc2U8YW55PjtcblxuICAvKipcbiAgICogY291bnRzIHRoZSBudW1iZXIgb2YgcmVjb3JkcyBtYXRjaGluZyB0aGUgZ2l2ZW4gc2VhcmNoIHBhcmFtZXRlcnMuXG4gICAqIEBwYXJhbSBlbnRpdHkgdGhlIHRhcmdldCBlbnRpdHlcbiAgICogQHBhcmFtIHFtIHRoZSBzZWFyY2ggb3B0aW9uc1xuICAgKiBAcmV0dXJuIHRoZSBjb3VudFxuICAgKi9cbiAgY291bnQ8RT4oZW50aXR5OiBUeXBlPEU+LCBxbT86IFF1ZXJ5U2VhcmNoPEU+KTogUHJvbWlzZTxhbnk+O1xuXG4gIC8qKlxuICAgKiBpbnNlcnRzIGEgcmVjb3JkLlxuICAgKiBAcGFyYW0gZW50aXR5IHRoZSBlbnRpdHkgdG8gcGVyc2lzdCBvblxuICAgKiBAcGFyYW0gcGF5bG9hZCB0aGUgZGF0YSB0byBiZSBwZXJzaXN0ZWRcbiAgICogQHJldHVybiB0aGUgSURcbiAgICovXG4gIGluc2VydE9uZTxFPihlbnRpdHk6IFR5cGU8RT4sIHBheWxvYWQ6IEUpOiBQcm9taXNlPGFueT47XG5cbiAgLyoqXG4gICAqIEluc2VydHMgbWFueSByZWNvcmRzLlxuICAgKiBAcGFyYW0gZW50aXR5IHRoZSBlbnRpdHkgdG8gcGVyc2lzdCBvblxuICAgKiBAcGFyYW0gcGF5bG9hZCB0aGUgZGF0YSB0byBiZSBwZXJzaXN0ZWRcbiAgICogQHJldHVybiB0aGUgSURzXG4gICAqL1xuICBpbnNlcnRNYW55PzxFPihlbnRpdHk6IFR5cGU8RT4sIHBheWxvYWQ6IEVbXSk6IFByb21pc2U8YW55PjtcblxuICAvKipcbiAgICogdXBkYXRlcyBhIHJlY29yZCBwYXJ0aWFsbHkuXG4gICAqIEBwYXJhbSBlbnRpdHkgdGhlIGVudGl0eSB0byBwZXJzaXN0IG9uXG4gICAqIEBwYXJhbSBpZCB0aGUgcHJpbWFyeSBrZXkgb2YgdGhlIHJlY29yZCB0byBiZSB1cGRhdGVkXG4gICAqIEBwYXJhbSBwYXlsb2FkIHRoZSBkYXRhIHRvIGJlIHBlcnNpc3RlZFxuICAgKiBAcmV0dXJuIHRoZSBudW1iZXIgb2YgYWZmZWN0ZWQgcmVjb3Jkc1xuICAgKi9cbiAgdXBkYXRlT25lQnlJZDxFPihlbnRpdHk6IFR5cGU8RT4sIGlkOiBJZFZhbHVlPEU+LCBwYXlsb2FkOiBFKTogUHJvbWlzZTxhbnk+O1xuXG4gIC8qKlxuICAgKiB1cGRhdGVzIG1hbnkgcmVjb3JkcyBwYXJ0aWFsbHkuXG4gICAqIEBwYXJhbSBlbnRpdHkgdGhlIGVudGl0eSB0byBwZXJzaXN0IG9uXG4gICAqIEBwYXJhbSBxbSB0aGUgY3JpdGVyaWEgdG8gbG9vayBmb3IgdGhlIHJlY29yZHNcbiAgICogQHBhcmFtIHBheWxvYWQgdGhlIGRhdGEgdG8gYmUgcGVyc2lzdGVkXG4gICAqIEByZXR1cm4gdGhlIG51bWJlciBvZiBhZmZlY3RlZCByZWNvcmRzXG4gICAqL1xuICB1cGRhdGVNYW55PzxFPihlbnRpdHk6IFR5cGU8RT4sIHFtOiBRdWVyeVNlYXJjaDxFPiwgcGF5bG9hZDogRSk6IFByb21pc2U8YW55PjtcblxuICAvKipcbiAgICogaW5zZXJ0IG9yIHVwZGF0ZSBhIHJlY29yZC5cbiAgICogQHBhcmFtIGVudGl0eSB0aGUgZW50aXR5IHRvIHBlcnNpc3Qgb25cbiAgICogQHBhcmFtIHBheWxvYWQgdGhlIGRhdGEgdG8gYmUgcGVyc2lzdGVkXG4gICAqIEByZXR1cm4gdGhlIElEXG4gICAqL1xuICBzYXZlT25lPEU+KGVudGl0eTogVHlwZTxFPiwgcGF5bG9hZDogRSk6IFByb21pc2U8YW55PjtcblxuICAvKipcbiAgICogSW5zZXJ0IG9yIHVwZGF0ZSByZWNvcmRzLlxuICAgKiBAcGFyYW0gZW50aXR5IHRoZSBlbnRpdHkgdG8gcGVyc2lzdCBvblxuICAgKiBAcGFyYW0gcGF5bG9hZCB0aGUgZGF0YSB0byBiZSBwZXJzaXN0ZWRcbiAgICogQHJldHVybiB0aGUgSURzXG4gICAqL1xuICBzYXZlTWFueT88RT4oZW50aXR5OiBUeXBlPEU+LCBwYXlsb2FkOiBFW10pOiBQcm9taXNlPGFueT47XG5cbiAgLyoqXG4gICAqIGRlbGV0ZSBvciBTb2Z0RGVsZXRlIGEgcmVjb3JkLlxuICAgKiBAcGFyYW0gZW50aXR5IHRoZSBlbnRpdHkgdG8gcGVyc2lzdCBvblxuICAgKiBAcGFyYW0gaWQgdGhlIHByaW1hcnkga2V5IG9mIHRoZSByZWNvcmRcbiAgICogQHJldHVybiB0aGUgbnVtYmVyIG9mIGFmZmVjdGVkIHJlY29yZHNcbiAgICovXG4gIGRlbGV0ZU9uZUJ5SWQ8RT4oZW50aXR5OiBUeXBlPEU+LCBpZDogSWRWYWx1ZTxFPiwgb3B0cz86IFF1ZXJ5T3B0aW9ucyk6IFByb21pc2U8YW55PjtcblxuICAvKipcbiAgICogZGVsZXRlIG9yIFNvZnREZWxldGUgcmVjb3Jkcy5cbiAgICogQHBhcmFtIGVudGl0eSB0aGUgZW50aXR5IHRvIHBlcnNpc3Qgb25cbiAgICogQHBhcmFtIHFtIHRoZSBjcml0ZXJpYSB0byBsb29rIGZvciB0aGUgcmVjb3Jkc1xuICAgKiBAcmV0dXJuIHRoZSBudW1iZXIgb2YgYWZmZWN0ZWQgcmVjb3Jkc1xuICAgKi9cbiAgZGVsZXRlTWFueTxFPihlbnRpdHk6IFR5cGU8RT4sIHFtOiBRdWVyeVNlYXJjaDxFPiwgb3B0cz86IFF1ZXJ5T3B0aW9ucyk6IFByb21pc2U8YW55PjtcblxuICAvKipcbiAgICogZ2V0IGEgcmVwb3NpdG9yeSBmb3IgdGhlIGdpdmVuIGVudGl0eS5cbiAgICogQHBhcmFtIGVudGl0eSB0aGUgZW50aXR5IHRvIGdldCB0aGUgcmVwb3NpdG9yeSBmb3JcbiAgICogQHJldHVybiB0aGUgcmVwb3NpdG9yeVxuICAgKi9cbiAgZ2V0UmVwb3NpdG9yeTxFPihlbnRpdHk6IFR5cGU8RT4pOiBVbml2ZXJzYWxSZXBvc2l0b3J5PEU+O1xufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5pdmVyc2FsUXVlcmllci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90eXBlL3VuaXZlcnNhbFF1ZXJpZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgVHlwZSB9IGZyb20gJy4vdXRpbGl0eS5qcyc7XG5pbXBvcnQgdHlwZSB7IFF1ZXJ5Q3JpdGVyaWEsIFF1ZXJ5T25lQ3JpdGVyaWEsIFF1ZXJ5T3B0aW9ucywgUXVlcnlQcm9qZWN0LCBRdWVyeVNlYXJjaCB9IGZyb20gJy4vcXVlcnkuanMnO1xuaW1wb3J0IHR5cGUgeyBVbml2ZXJzYWxSZXBvc2l0b3J5IH0gZnJvbSAnLi9yZXBvc2l0b3J5LmpzJztcbmltcG9ydCB0eXBlIHsgSWRWYWx1ZSB9IGZyb20gJy4vZW50aXR5LmpzJztcblxuLyoqXG4gKiBBIGBxdWVyaWVyYCBhbGxvd3MgdG8gaW50ZXJhY3Qgd2l0aCB0aGUgZGF0YXNvdXJjZSB0byBwZXJmb3JtIHBlcnNpc3RlbmNlIG9wZXJhdGlvbnMgb24gYW55IGVudGl0eS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBVbml2ZXJzYWxRdWVyaWVyIHtcbiAgLyoqXG4gICAqIG9idGFpbnMgdGhlIHJlY29yZCB3aXRoIHRoZSBnaXZlbiBwcmltYXJ5IGtleS5cbiAgICogQHBhcmFtIGVudGl0eSB0aGUgdGFyZ2V0IGVudGl0eVxuICAgKiBAcGFyYW0gaWQgdGhlIHByaW1hcnkga2V5IHZhbHVlXG4gICAqIEByZXR1cm4gdGhlIHJlY29yZFxuICAgKi9cbiAgZmluZE9uZUJ5SWQ8RT4oZW50aXR5OiBUeXBlPEU+LCBpZDogSWRWYWx1ZTxFPiwgcHJvamVjdD86IFF1ZXJ5UHJvamVjdDxFPik6IFByb21pc2U8YW55PjtcblxuICAvKipcbiAgICogb2J0YWlucyB0aGUgZmlyc3QgcmVjb3JkIG1hdGNoaW5nIHRoZSBnaXZlbiBzZWFyY2ggcGFyYW1ldGVycy5cbiAgICogQHBhcmFtIGVudGl0eSB0aGUgdGFyZ2V0IGVudGl0eVxuICAgKiBAcGFyYW0gcW0gdGhlIGNyaXRlcmlhIG9wdGlvbnNcbiAgICogQHJldHVybiB0aGUgcmVjb3JkXG4gICAqL1xuICBmaW5kT25lPEU+KGVudGl0eTogVHlwZTxFPiwgcW06IFF1ZXJ5T25lQ3JpdGVyaWE8RT4sIHByb2plY3Q/OiBRdWVyeVByb2plY3Q8RT4pOiBQcm9taXNlPGFueT47XG5cbiAgLyoqXG4gICAqIG9idGFpbnMgdGhlIHJlY29yZHMgbWF0Y2hpbmcgdGhlIGdpdmVuIHNlYXJjaCBwYXJhbWV0ZXJzLlxuICAgKiBAcGFyYW0gZW50aXR5IHRoZSB0YXJnZXQgZW50aXR5XG4gICAqIEBwYXJhbSBxbSB0aGUgY3JpdGVyaWEgb3B0aW9uc1xuICAgKiBAcmV0dXJuIHRoZSByZWNvcmRzXG4gICAqL1xuICBmaW5kTWFueTxFPihlbnRpdHk6IFR5cGU8RT4sIHFtOiBRdWVyeUNyaXRlcmlhPEU+LCBwcm9qZWN0PzogUXVlcnlQcm9qZWN0PEU+KTogUHJvbWlzZTxhbnk+O1xuXG4gIC8qKlxuICAgKiBvYnRhaW5zIHRoZSByZWNvcmRzIG1hdGNoaW5nIHRoZSBnaXZlbiBzZWFyY2ggcGFyYW1ldGVycyxcbiAgICogYWxzbyBjb3VudHMgdGhlIG51bWJlciBvZiBtYXRjaGVzIGlnbm9yaW5nIHBhZ2luYXRpb24uXG4gICAqIEBwYXJhbSBlbnRpdHkgdGhlIHRhcmdldCBlbnRpdHlcbiAgICogQHBhcmFtIHFtIHRoZSBjcml0ZXJpYSBvcHRpb25zXG4gICAqIEByZXR1cm4gdGhlIHJlY29yZHMgYW5kIHRoZSBjb3VudFxuICAgKi9cbiAgZmluZE1hbnlBbmRDb3VudDxFPihlbnRpdHk6IFR5cGU8RT4sIHFtOiBRdWVyeUNyaXRlcmlhPEU+LCBwcm9qZWN0PzogUXVlcnlQcm9qZWN0PEU+KTogUHJvbWlzZTxhbnk+O1xuXG4gIC8qKlxuICAgKiBjb3VudHMgdGhlIG51bWJlciBvZiByZWNvcmRzIG1hdGNoaW5nIHRoZSBnaXZlbiBzZWFyY2ggcGFyYW1ldGVycy5cbiAgICogQHBhcmFtIGVudGl0eSB0aGUgdGFyZ2V0IGVudGl0eVxuICAgKiBAcGFyYW0gcW0gdGhlIHNlYXJjaCBvcHRpb25zXG4gICAqIEByZXR1cm4gdGhlIGNvdW50XG4gICAqL1xuICBjb3VudDxFPihlbnRpdHk6IFR5cGU8RT4sIHFtPzogUXVlcnlTZWFyY2g8RT4pOiBQcm9taXNlPGFueT47XG5cbiAgLyoqXG4gICAqIGluc2VydHMgYSByZWNvcmQuXG4gICAqIEBwYXJhbSBlbnRpdHkgdGhlIGVudGl0eSB0byBwZXJzaXN0IG9uXG4gICAqIEBwYXJhbSBwYXlsb2FkIHRoZSBkYXRhIHRvIGJlIHBlcnNpc3RlZFxuICAgKiBAcmV0dXJuIHRoZSBJRFxuICAgKi9cbiAgaW5zZXJ0T25lPEU+KGVudGl0eTogVHlwZTxFPiwgcGF5bG9hZDogRSk6IFByb21pc2U8YW55PjtcblxuICAvKipcbiAgICogSW5zZXJ0cyBtYW55IHJlY29yZHMuXG4gICAqIEBwYXJhbSBlbnRpdHkgdGhlIGVudGl0eSB0byBwZXJzaXN0IG9uXG4gICAqIEBwYXJhbSBwYXlsb2FkIHRoZSBkYXRhIHRvIGJlIHBlcnNpc3RlZFxuICAgKiBAcmV0dXJuIHRoZSBJRHNcbiAgICovXG4gIGluc2VydE1hbnk/PEU+KGVudGl0eTogVHlwZTxFPiwgcGF5bG9hZDogRVtdKTogUHJvbWlzZTxhbnk+O1xuXG4gIC8qKlxuICAgKiB1cGRhdGVzIGEgcmVjb3JkIHBhcnRpYWxseS5cbiAgICogQHBhcmFtIGVudGl0eSB0aGUgZW50aXR5IHRvIHBlcnNpc3Qgb25cbiAgICogQHBhcmFtIGlkIHRoZSBwcmltYXJ5IGtleSBvZiB0aGUgcmVjb3JkIHRvIGJlIHVwZGF0ZWRcbiAgICogQHBhcmFtIHBheWxvYWQgdGhlIGRhdGEgdG8gYmUgcGVyc2lzdGVkXG4gICAqIEByZXR1cm4gdGhlIG51bWJlciBvZiBhZmZlY3RlZCByZWNvcmRzXG4gICAqL1xuICB1cGRhdGVPbmVCeUlkPEU+KGVudGl0eTogVHlwZTxFPiwgaWQ6IElkVmFsdWU8RT4sIHBheWxvYWQ6IEUpOiBQcm9taXNlPGFueT47XG5cbiAgLyoqXG4gICAqIHVwZGF0ZXMgbWFueSByZWNvcmRzIHBhcnRpYWxseS5cbiAgICogQHBhcmFtIGVudGl0eSB0aGUgZW50aXR5IHRvIHBlcnNpc3Qgb25cbiAgICogQHBhcmFtIHFtIHRoZSBjcml0ZXJpYSB0byBsb29rIGZvciB0aGUgcmVjb3Jkc1xuICAgKiBAcGFyYW0gcGF5bG9hZCB0aGUgZGF0YSB0byBiZSBwZXJzaXN0ZWRcbiAgICogQHJldHVybiB0aGUgbnVtYmVyIG9mIGFmZmVjdGVkIHJlY29yZHNcbiAgICovXG4gIHVwZGF0ZU1hbnk/PEU+KGVudGl0eTogVHlwZTxFPiwgcW06IFF1ZXJ5U2VhcmNoPEU+LCBwYXlsb2FkOiBFKTogUHJvbWlzZTxhbnk+O1xuXG4gIC8qKlxuICAgKiBpbnNlcnQgb3IgdXBkYXRlIGEgcmVjb3JkLlxuICAgKiBAcGFyYW0gZW50aXR5IHRoZSBlbnRpdHkgdG8gcGVyc2lzdCBvblxuICAgKiBAcGFyYW0gcGF5bG9hZCB0aGUgZGF0YSB0byBiZSBwZXJzaXN0ZWRcbiAgICogQHJldHVybiB0aGUgSURcbiAgICovXG4gIHNhdmVPbmU8RT4oZW50aXR5OiBUeXBlPEU+LCBwYXlsb2FkOiBFKTogUHJvbWlzZTxhbnk+O1xuXG4gIC8qKlxuICAgKiBJbnNlcnQgb3IgdXBkYXRlIHJlY29yZHMuXG4gICAqIEBwYXJhbSBlbnRpdHkgdGhlIGVudGl0eSB0byBwZXJzaXN0IG9uXG4gICAqIEBwYXJhbSBwYXlsb2FkIHRoZSBkYXRhIHRvIGJlIHBlcnNpc3RlZFxuICAgKiBAcmV0dXJuIHRoZSBJRHNcbiAgICovXG4gIHNhdmVNYW55PzxFPihlbnRpdHk6IFR5cGU8RT4sIHBheWxvYWQ6IEVbXSk6IFByb21pc2U8YW55PjtcblxuICAvKipcbiAgICogZGVsZXRlIG9yIFNvZnREZWxldGUgYSByZWNvcmQuXG4gICAqIEBwYXJhbSBlbnRpdHkgdGhlIGVudGl0eSB0byBwZXJzaXN0IG9uXG4gICAqIEBwYXJhbSBpZCB0aGUgcHJpbWFyeSBrZXkgb2YgdGhlIHJlY29yZFxuICAgKiBAcmV0dXJuIHRoZSBudW1iZXIgb2YgYWZmZWN0ZWQgcmVjb3Jkc1xuICAgKi9cbiAgZGVsZXRlT25lQnlJZDxFPihlbnRpdHk6IFR5cGU8RT4sIGlkOiBJZFZhbHVlPEU+LCBvcHRzPzogUXVlcnlPcHRpb25zKTogUHJvbWlzZTxhbnk+O1xuXG4gIC8qKlxuICAgKiBkZWxldGUgb3IgU29mdERlbGV0ZSByZWNvcmRzLlxuICAgKiBAcGFyYW0gZW50aXR5IHRoZSBlbnRpdHkgdG8gcGVyc2lzdCBvblxuICAgKiBAcGFyYW0gcW0gdGhlIGNyaXRlcmlhIHRvIGxvb2sgZm9yIHRoZSByZWNvcmRzXG4gICAqIEByZXR1cm4gdGhlIG51bWJlciBvZiBhZmZlY3RlZCByZWNvcmRzXG4gICAqL1xuICBkZWxldGVNYW55PEU+KGVudGl0eTogVHlwZTxFPiwgcW06IFF1ZXJ5U2VhcmNoPEU+LCBvcHRzPzogUXVlcnlPcHRpb25zKTogUHJvbWlzZTxhbnk+O1xuXG4gIC8qKlxuICAgKiBnZXQgYSByZXBvc2l0b3J5IGZvciB0aGUgZ2l2ZW4gZW50aXR5LlxuICAgKiBAcGFyYW0gZW50aXR5IHRoZSBlbnRpdHkgdG8gZ2V0IHRoZSByZXBvc2l0b3J5IGZvclxuICAgKiBAcmV0dXJuIHRoZSByZXBvc2l0b3J5XG4gICAqL1xuICBnZXRSZXBvc2l0b3J5PEU+KGVudGl0eTogVHlwZTxFPik6IFVuaXZlcnNhbFJlcG9zaXRvcnk8RT47XG59XG4iXX0=

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc