@decaf-ts/core 0.5.0 → 0.5.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE.md +21 -157
- package/README.md +652 -15
- package/dist/core.cjs +2638 -1085
- package/dist/core.esm.cjs +2636 -1070
- package/lib/esm/identity/decorators.d.ts +52 -14
- package/lib/esm/identity/decorators.js +54 -16
- package/lib/esm/identity/utils.d.ts +20 -1
- package/lib/esm/identity/utils.js +22 -2
- package/lib/esm/index.d.ts +11 -15
- package/lib/esm/index.js +17 -19
- package/lib/esm/interfaces/ErrorParser.d.ts +12 -0
- package/lib/esm/interfaces/ErrorParser.js +1 -1
- package/lib/esm/interfaces/Executor.d.ts +10 -13
- package/lib/esm/interfaces/Executor.js +1 -1
- package/lib/esm/interfaces/Observable.d.ts +20 -18
- package/lib/esm/interfaces/Observable.js +1 -1
- package/lib/esm/interfaces/Observer.d.ts +7 -8
- package/lib/esm/interfaces/Observer.js +1 -1
- package/lib/esm/interfaces/Paginatable.d.ts +18 -2
- package/lib/esm/interfaces/Paginatable.js +1 -1
- package/lib/esm/interfaces/Queriable.d.ts +44 -3
- package/lib/esm/interfaces/Queriable.js +1 -1
- package/lib/esm/interfaces/RawExecutor.d.ts +10 -13
- package/lib/esm/interfaces/RawExecutor.js +1 -1
- package/lib/esm/interfaces/SequenceOptions.d.ts +50 -5
- package/lib/esm/interfaces/SequenceOptions.js +19 -1
- package/lib/esm/interfaces/index.d.ts +0 -1
- package/lib/esm/interfaces/index.js +1 -2
- package/lib/esm/model/BaseModel.d.ts +31 -0
- package/lib/esm/model/BaseModel.js +24 -1
- package/lib/esm/model/construction.d.ts +442 -9
- package/lib/esm/model/construction.js +441 -2
- package/lib/esm/model/decorators.d.ts +166 -42
- package/lib/esm/model/decorators.js +161 -37
- package/lib/esm/model/index.js +1 -2
- package/lib/esm/model/types.d.ts +9 -0
- package/lib/esm/model/types.js +1 -1
- package/lib/esm/persistence/Adapter.d.ts +384 -40
- package/lib/esm/persistence/Adapter.js +415 -59
- package/lib/esm/persistence/Dispatch.d.ts +131 -0
- package/lib/esm/persistence/Dispatch.js +187 -0
- package/lib/esm/persistence/ObserverHandler.d.ts +109 -0
- package/lib/esm/persistence/ObserverHandler.js +137 -0
- package/lib/esm/persistence/Sequence.d.ts +89 -8
- package/lib/esm/persistence/Sequence.js +91 -1
- package/lib/esm/persistence/constants.d.ts +22 -5
- package/lib/esm/persistence/constants.js +23 -7
- package/lib/esm/persistence/decorators.d.ts +10 -0
- package/lib/esm/persistence/decorators.js +11 -1
- package/lib/esm/persistence/errors.d.ts +23 -3
- package/lib/esm/persistence/errors.js +25 -7
- package/lib/esm/persistence/index.d.ts +3 -0
- package/lib/esm/persistence/index.js +4 -1
- package/lib/esm/persistence/types.d.ts +21 -0
- package/lib/esm/persistence/types.js +2 -0
- package/lib/esm/query/Condition.d.ts +88 -44
- package/lib/esm/query/Condition.js +144 -62
- package/lib/esm/query/Paginator.d.ts +67 -10
- package/lib/esm/query/Paginator.js +64 -10
- package/lib/esm/query/Statement.d.ts +82 -47
- package/lib/esm/query/Statement.js +175 -122
- package/lib/esm/query/constants.d.ts +25 -64
- package/lib/esm/query/constants.js +26 -68
- package/lib/esm/query/errors.d.ts +14 -0
- package/lib/esm/query/errors.js +15 -1
- package/lib/esm/query/index.d.ts +0 -5
- package/lib/esm/query/index.js +1 -6
- package/lib/esm/query/options.d.ts +69 -178
- package/lib/esm/query/options.js +1 -1
- package/lib/esm/query/selectors.d.ts +20 -24
- package/lib/esm/query/selectors.js +1 -1
- package/lib/esm/ram/RamAdapter.d.ts +322 -20
- package/lib/esm/ram/RamAdapter.js +360 -140
- package/lib/esm/ram/RamContext.d.ts +16 -1
- package/lib/esm/ram/RamContext.js +18 -3
- package/lib/esm/ram/RamPaginator.d.ts +51 -6
- package/lib/esm/ram/RamPaginator.js +58 -6
- package/lib/esm/ram/RamSequence.d.ts +49 -24
- package/lib/esm/ram/RamSequence.js +52 -40
- package/lib/esm/ram/RamStatement.d.ts +84 -6
- package/lib/esm/ram/RamStatement.js +175 -6
- package/lib/esm/ram/constants.d.ts +9 -0
- package/lib/esm/ram/constants.js +10 -0
- package/lib/esm/ram/handlers.d.ts +25 -0
- package/lib/esm/ram/handlers.js +27 -0
- package/lib/esm/ram/index.d.ts +4 -4
- package/lib/esm/ram/index.js +9 -5
- package/lib/esm/ram/model/RamSequence.d.ts +21 -9
- package/lib/esm/ram/model/RamSequence.js +19 -1
- package/lib/esm/ram/types.d.ts +47 -5
- package/lib/esm/ram/types.js +1 -1
- package/lib/esm/repository/Repository.d.ts +381 -22
- package/lib/esm/repository/Repository.js +446 -43
- package/lib/esm/repository/constants.d.ts +23 -13
- package/lib/esm/repository/constants.js +24 -14
- package/lib/esm/repository/decorators.d.ts +27 -0
- package/lib/esm/repository/decorators.js +28 -1
- package/lib/esm/repository/errors.d.ts +12 -11
- package/lib/esm/repository/errors.js +13 -16
- package/lib/esm/repository/injectables.d.ts +18 -0
- package/lib/esm/repository/injectables.js +19 -1
- package/lib/esm/repository/types.d.ts +13 -1
- package/lib/esm/repository/types.js +1 -1
- package/lib/esm/repository/utils.d.ts +11 -0
- package/lib/esm/repository/utils.js +12 -1
- package/lib/esm/utils/decorators.d.ts +9 -0
- package/lib/esm/utils/decorators.js +19 -0
- package/lib/esm/utils/errors.d.ts +56 -0
- package/lib/esm/utils/errors.js +63 -0
- package/lib/esm/utils/index.d.ts +2 -0
- package/lib/esm/utils/index.js +3 -0
- package/lib/identity/decorators.cjs +54 -16
- package/lib/identity/decorators.d.ts +52 -14
- package/lib/identity/utils.cjs +22 -2
- package/lib/identity/utils.d.ts +20 -1
- package/lib/index.cjs +17 -19
- package/lib/index.d.ts +11 -15
- package/lib/interfaces/ErrorParser.cjs +1 -1
- package/lib/interfaces/ErrorParser.d.ts +12 -0
- package/lib/interfaces/Executor.cjs +1 -1
- package/lib/interfaces/Executor.d.ts +10 -13
- package/lib/interfaces/Observable.cjs +1 -1
- package/lib/interfaces/Observable.d.ts +20 -18
- package/lib/interfaces/Observer.cjs +1 -1
- package/lib/interfaces/Observer.d.ts +7 -8
- package/lib/interfaces/Paginatable.cjs +1 -1
- package/lib/interfaces/Paginatable.d.ts +18 -2
- package/lib/interfaces/Queriable.cjs +1 -1
- package/lib/interfaces/Queriable.d.ts +44 -3
- package/lib/interfaces/RawExecutor.cjs +1 -1
- package/lib/interfaces/RawExecutor.d.ts +10 -13
- package/lib/interfaces/SequenceOptions.cjs +19 -1
- package/lib/interfaces/SequenceOptions.d.ts +50 -5
- package/lib/interfaces/index.cjs +1 -2
- package/lib/interfaces/index.d.ts +0 -1
- package/lib/model/BaseModel.cjs +24 -1
- package/lib/model/BaseModel.d.ts +31 -0
- package/lib/model/construction.cjs +441 -2
- package/lib/model/construction.d.ts +442 -9
- package/lib/model/decorators.cjs +161 -37
- package/lib/model/decorators.d.ts +166 -42
- package/lib/model/index.cjs +1 -2
- package/lib/model/types.cjs +1 -1
- package/lib/model/types.d.ts +9 -0
- package/lib/persistence/Adapter.cjs +414 -58
- package/lib/persistence/Adapter.d.ts +384 -40
- package/lib/persistence/Dispatch.cjs +191 -0
- package/lib/persistence/Dispatch.d.ts +131 -0
- package/lib/persistence/ObserverHandler.cjs +141 -0
- package/lib/persistence/ObserverHandler.d.ts +109 -0
- package/lib/persistence/Sequence.cjs +91 -1
- package/lib/persistence/Sequence.d.ts +89 -8
- package/lib/persistence/constants.cjs +24 -8
- package/lib/persistence/constants.d.ts +22 -5
- package/lib/persistence/decorators.cjs +11 -1
- package/lib/persistence/decorators.d.ts +10 -0
- package/lib/persistence/errors.cjs +26 -9
- package/lib/persistence/errors.d.ts +23 -3
- package/lib/persistence/index.cjs +4 -1
- package/lib/persistence/index.d.ts +3 -0
- package/lib/persistence/types.cjs +3 -0
- package/lib/persistence/types.d.ts +21 -0
- package/lib/query/Condition.cjs +143 -61
- package/lib/query/Condition.d.ts +88 -44
- package/lib/query/Paginator.cjs +64 -10
- package/lib/query/Paginator.d.ts +67 -10
- package/lib/query/Statement.cjs +174 -121
- package/lib/query/Statement.d.ts +82 -47
- package/lib/query/constants.cjs +27 -69
- package/lib/query/constants.d.ts +25 -64
- package/lib/query/errors.cjs +15 -1
- package/lib/query/errors.d.ts +14 -0
- package/lib/query/index.cjs +1 -6
- package/lib/query/index.d.ts +0 -5
- package/lib/query/options.cjs +1 -1
- package/lib/query/options.d.ts +69 -178
- package/lib/query/selectors.cjs +1 -1
- package/lib/query/selectors.d.ts +20 -24
- package/lib/ram/RamAdapter.cjs +358 -172
- package/lib/ram/RamAdapter.d.ts +322 -20
- package/lib/ram/RamContext.cjs +18 -3
- package/lib/ram/RamContext.d.ts +16 -1
- package/lib/ram/RamPaginator.cjs +58 -6
- package/lib/ram/RamPaginator.d.ts +51 -6
- package/lib/ram/RamSequence.cjs +52 -41
- package/lib/ram/RamSequence.d.ts +49 -24
- package/lib/ram/RamStatement.cjs +175 -6
- package/lib/ram/RamStatement.d.ts +84 -6
- package/lib/ram/constants.cjs +13 -0
- package/lib/ram/constants.d.ts +9 -0
- package/lib/ram/handlers.cjs +30 -0
- package/lib/ram/handlers.d.ts +25 -0
- package/lib/ram/index.cjs +9 -5
- package/lib/ram/index.d.ts +4 -4
- package/lib/ram/model/RamSequence.cjs +19 -1
- package/lib/ram/model/RamSequence.d.ts +21 -9
- package/lib/ram/types.cjs +1 -1
- package/lib/ram/types.d.ts +47 -5
- package/lib/repository/Repository.cjs +445 -42
- package/lib/repository/Repository.d.ts +381 -22
- package/lib/repository/constants.cjs +24 -14
- package/lib/repository/constants.d.ts +23 -13
- package/lib/repository/decorators.cjs +28 -1
- package/lib/repository/decorators.d.ts +27 -0
- package/lib/repository/errors.cjs +14 -19
- package/lib/repository/errors.d.ts +12 -11
- package/lib/repository/injectables.cjs +19 -1
- package/lib/repository/injectables.d.ts +18 -0
- package/lib/repository/types.cjs +1 -1
- package/lib/repository/types.d.ts +13 -1
- package/lib/repository/utils.cjs +12 -1
- package/lib/repository/utils.d.ts +11 -0
- package/lib/utils/decorators.cjs +22 -0
- package/lib/utils/decorators.d.ts +9 -0
- package/lib/utils/errors.cjs +69 -0
- package/lib/utils/errors.d.ts +56 -0
- package/lib/{validators → utils}/index.cjs +2 -2
- package/lib/utils/index.d.ts +2 -0
- package/package.json +5 -5
- package/lib/esm/interfaces/Builder.d.ts +0 -16
- package/lib/esm/interfaces/Builder.js +0 -2
- package/lib/esm/model/IdentifiedBaseModel.d.ts +0 -7
- package/lib/esm/model/IdentifiedBaseModel.js +0 -25
- package/lib/esm/query/Clause.d.ts +0 -50
- package/lib/esm/query/Clause.js +0 -82
- package/lib/esm/query/ClauseFactory.d.ts +0 -71
- package/lib/esm/query/ClauseFactory.js +0 -6
- package/lib/esm/query/Query.d.ts +0 -43
- package/lib/esm/query/Query.js +0 -54
- package/lib/esm/query/clauses/FromClause.d.ts +0 -45
- package/lib/esm/query/clauses/FromClause.js +0 -59
- package/lib/esm/query/clauses/GroupByClause.d.ts +0 -21
- package/lib/esm/query/clauses/GroupByClause.js +0 -19
- package/lib/esm/query/clauses/InsertClause.d.ts +0 -37
- package/lib/esm/query/clauses/InsertClause.js +0 -55
- package/lib/esm/query/clauses/LimitClause.d.ts +0 -29
- package/lib/esm/query/clauses/LimitClause.js +0 -27
- package/lib/esm/query/clauses/OffsetClause.d.ts +0 -21
- package/lib/esm/query/clauses/OffsetClause.js +0 -19
- package/lib/esm/query/clauses/OrderByClause.d.ts +0 -37
- package/lib/esm/query/clauses/OrderByClause.js +0 -39
- package/lib/esm/query/clauses/SelectClause.d.ts +0 -47
- package/lib/esm/query/clauses/SelectClause.js +0 -62
- package/lib/esm/query/clauses/SelectorBasedClause.d.ts +0 -25
- package/lib/esm/query/clauses/SelectorBasedClause.js +0 -44
- package/lib/esm/query/clauses/ValuesClause.d.ts +0 -21
- package/lib/esm/query/clauses/ValuesClause.js +0 -36
- package/lib/esm/query/clauses/WhereClause.d.ts +0 -46
- package/lib/esm/query/clauses/WhereClause.js +0 -71
- package/lib/esm/query/clauses/index.d.ts +0 -10
- package/lib/esm/query/clauses/index.js +0 -11
- package/lib/esm/query/types.d.ts +0 -2
- package/lib/esm/query/types.js +0 -2
- package/lib/esm/ram/RamClauseFactory.d.ts +0 -17
- package/lib/esm/ram/RamClauseFactory.js +0 -92
- package/lib/esm/ram/clauses/FromClause.d.ts +0 -7
- package/lib/esm/ram/clauses/FromClause.js +0 -11
- package/lib/esm/ram/clauses/InsertClause.d.ts +0 -7
- package/lib/esm/ram/clauses/InsertClause.js +0 -13
- package/lib/esm/ram/clauses/OrderByClause.d.ts +0 -7
- package/lib/esm/ram/clauses/OrderByClause.js +0 -39
- package/lib/esm/ram/clauses/SelectClause.d.ts +0 -7
- package/lib/esm/ram/clauses/SelectClause.js +0 -16
- package/lib/esm/ram/clauses/ValuesClause.d.ts +0 -7
- package/lib/esm/ram/clauses/ValuesClause.js +0 -12
- package/lib/esm/ram/clauses/WhereClause.d.ts +0 -7
- package/lib/esm/ram/clauses/WhereClause.js +0 -11
- package/lib/esm/ram/clauses/index.d.ts +0 -6
- package/lib/esm/ram/clauses/index.js +0 -7
- package/lib/esm/validators/ClauseSequenceValidator.d.ts +0 -28
- package/lib/esm/validators/ClauseSequenceValidator.js +0 -95
- package/lib/esm/validators/decorators.d.ts +0 -10
- package/lib/esm/validators/decorators.js +0 -24
- package/lib/esm/validators/index.d.ts +0 -2
- package/lib/esm/validators/index.js +0 -3
- package/lib/interfaces/Builder.cjs +0 -3
- package/lib/interfaces/Builder.d.ts +0 -16
- package/lib/model/IdentifiedBaseModel.cjs +0 -29
- package/lib/model/IdentifiedBaseModel.d.ts +0 -7
- package/lib/query/Clause.cjs +0 -86
- package/lib/query/Clause.d.ts +0 -50
- package/lib/query/ClauseFactory.cjs +0 -10
- package/lib/query/ClauseFactory.d.ts +0 -71
- package/lib/query/Query.cjs +0 -58
- package/lib/query/Query.d.ts +0 -43
- package/lib/query/clauses/FromClause.cjs +0 -63
- package/lib/query/clauses/FromClause.d.ts +0 -45
- package/lib/query/clauses/GroupByClause.cjs +0 -23
- package/lib/query/clauses/GroupByClause.d.ts +0 -21
- package/lib/query/clauses/InsertClause.cjs +0 -59
- package/lib/query/clauses/InsertClause.d.ts +0 -37
- package/lib/query/clauses/LimitClause.cjs +0 -31
- package/lib/query/clauses/LimitClause.d.ts +0 -29
- package/lib/query/clauses/OffsetClause.cjs +0 -23
- package/lib/query/clauses/OffsetClause.d.ts +0 -21
- package/lib/query/clauses/OrderByClause.cjs +0 -43
- package/lib/query/clauses/OrderByClause.d.ts +0 -37
- package/lib/query/clauses/SelectClause.cjs +0 -66
- package/lib/query/clauses/SelectClause.d.ts +0 -47
- package/lib/query/clauses/SelectorBasedClause.cjs +0 -48
- package/lib/query/clauses/SelectorBasedClause.d.ts +0 -25
- package/lib/query/clauses/ValuesClause.cjs +0 -40
- package/lib/query/clauses/ValuesClause.d.ts +0 -21
- package/lib/query/clauses/WhereClause.cjs +0 -75
- package/lib/query/clauses/WhereClause.d.ts +0 -46
- package/lib/query/clauses/index.cjs +0 -27
- package/lib/query/clauses/index.d.ts +0 -10
- package/lib/query/types.cjs +0 -3
- package/lib/query/types.d.ts +0 -2
- package/lib/ram/RamClauseFactory.cjs +0 -96
- package/lib/ram/RamClauseFactory.d.ts +0 -17
- package/lib/ram/clauses/FromClause.cjs +0 -15
- package/lib/ram/clauses/FromClause.d.ts +0 -7
- package/lib/ram/clauses/InsertClause.cjs +0 -17
- package/lib/ram/clauses/InsertClause.d.ts +0 -7
- package/lib/ram/clauses/OrderByClause.cjs +0 -43
- package/lib/ram/clauses/OrderByClause.d.ts +0 -7
- package/lib/ram/clauses/SelectClause.cjs +0 -20
- package/lib/ram/clauses/SelectClause.d.ts +0 -7
- package/lib/ram/clauses/ValuesClause.cjs +0 -16
- package/lib/ram/clauses/ValuesClause.d.ts +0 -7
- package/lib/ram/clauses/WhereClause.cjs +0 -15
- package/lib/ram/clauses/WhereClause.d.ts +0 -7
- package/lib/ram/clauses/index.cjs +0 -23
- package/lib/ram/clauses/index.d.ts +0 -6
- package/lib/validators/ClauseSequenceValidator.cjs +0 -98
- package/lib/validators/ClauseSequenceValidator.d.ts +0 -28
- package/lib/validators/decorators.cjs +0 -27
- package/lib/validators/decorators.d.ts +0 -10
- package/lib/validators/index.d.ts +0 -2
@@ -7,156 +7,209 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
7
7
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
8
8
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
9
9
|
};
|
10
|
-
|
11
|
-
import {
|
12
|
-
import {
|
13
|
-
import { clauseSequence } from "../validators";
|
14
|
-
import { Adapter } from "../persistence";
|
10
|
+
var _a, _b, _c, _d;
|
11
|
+
import { Model } from "@decaf-ts/decorator-validation";
|
12
|
+
import { Condition } from "./Condition";
|
15
13
|
import { findPrimaryKey, InternalError } from "@decaf-ts/db-decorators";
|
14
|
+
import { final } from "../utils/decorators";
|
15
|
+
import { QueryError } from "./errors";
|
16
16
|
/**
|
17
|
-
* @
|
18
|
-
* @
|
17
|
+
* @description Base class for database query statements
|
18
|
+
* @summary Provides a foundation for building and executing database queries
|
19
19
|
*
|
20
|
-
*
|
20
|
+
* This abstract class implements the query builder pattern for constructing
|
21
|
+
* database queries. It supports various query operations like select, from,
|
22
|
+
* where, orderBy, groupBy, limit, and offset. It also provides methods for
|
23
|
+
* executing queries and handling pagination.
|
21
24
|
*
|
25
|
+
* @template Q - The query type specific to the database adapter
|
26
|
+
* @template M - The model type this statement operates on
|
27
|
+
* @template R - The return type of the query
|
28
|
+
* @param {Adapter<any, Q, any, any>} adapter - The database adapter to use for executing queries
|
22
29
|
* @class Statement
|
23
|
-
* @
|
24
|
-
*
|
25
|
-
*
|
30
|
+
* @example
|
31
|
+
* // Create a statement to query users
|
32
|
+
* const statement = new SQLStatement(adapter);
|
33
|
+
* const users = await statement
|
34
|
+
* .select()
|
35
|
+
* .from(User)
|
36
|
+
* .where(Condition.attribute("status").eq("active"))
|
37
|
+
* .orderBy(["createdAt", "DESC"])
|
38
|
+
* .limit(10)
|
39
|
+
* .execute();
|
40
|
+
*
|
41
|
+
* // Use pagination
|
42
|
+
* const paginator = await statement
|
43
|
+
* .select()
|
44
|
+
* .from(User)
|
45
|
+
* .paginate(20); // 20 users per page
|
26
46
|
*
|
27
|
-
* @
|
47
|
+
* @mermaid
|
48
|
+
* sequenceDiagram
|
49
|
+
* participant Client
|
50
|
+
* participant Statement
|
51
|
+
* participant Adapter
|
52
|
+
* participant Database
|
53
|
+
*
|
54
|
+
* Client->>Statement: select()
|
55
|
+
* Client->>Statement: from(Model)
|
56
|
+
* Client->>Statement: where(condition)
|
57
|
+
* Client->>Statement: orderBy([field, direction])
|
58
|
+
* Client->>Statement: limit(value)
|
59
|
+
* Client->>Statement: execute()
|
60
|
+
* Statement->>Statement: build()
|
61
|
+
* Statement->>Adapter: raw(query)
|
62
|
+
* Adapter->>Database: execute query
|
63
|
+
* Database-->>Adapter: return results
|
64
|
+
* Adapter-->>Statement: return processed results
|
65
|
+
* Statement-->>Client: return final results
|
28
66
|
*/
|
29
|
-
export class Statement
|
30
|
-
constructor(
|
31
|
-
|
32
|
-
this.clauses = undefined;
|
33
|
-
this.target = undefined;
|
34
|
-
this.fullRecord = false;
|
35
|
-
this.type = undefined;
|
36
|
-
this.adapter = db;
|
67
|
+
export class Statement {
|
68
|
+
constructor(adapter) {
|
69
|
+
this.adapter = adapter;
|
37
70
|
}
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
return c1.getPriority() - c2.getPriority();
|
71
|
+
select(selector) {
|
72
|
+
Object.defineProperty(this, "selectSelector", {
|
73
|
+
value: selector,
|
74
|
+
writable: false,
|
43
75
|
});
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
76
|
+
return this;
|
77
|
+
}
|
78
|
+
distinct(selector) {
|
79
|
+
this.distinctSelector = selector;
|
80
|
+
return this;
|
81
|
+
}
|
82
|
+
max(selector) {
|
83
|
+
this.maxSelector = selector;
|
84
|
+
return this;
|
85
|
+
}
|
86
|
+
min(selector) {
|
87
|
+
this.minSelector = selector;
|
88
|
+
return this;
|
89
|
+
}
|
90
|
+
count(selector) {
|
91
|
+
this.countSelector = selector;
|
92
|
+
return this;
|
93
|
+
}
|
94
|
+
from(selector) {
|
95
|
+
this.fromSelector = (typeof selector === "string" ? Model.get(selector) : selector);
|
96
|
+
if (!this.fromSelector)
|
97
|
+
throw new QueryError(`Could not find selector model: ${selector}`);
|
98
|
+
return this;
|
99
|
+
}
|
100
|
+
where(condition) {
|
101
|
+
this.whereCondition = condition;
|
102
|
+
return this;
|
103
|
+
}
|
104
|
+
orderBy(selector) {
|
105
|
+
this.orderBySelector = selector;
|
106
|
+
return this;
|
107
|
+
}
|
108
|
+
groupBy(selector) {
|
109
|
+
this.groupBySelector = selector;
|
110
|
+
return this;
|
111
|
+
}
|
112
|
+
limit(value) {
|
113
|
+
this.limitSelector = value;
|
114
|
+
return this;
|
115
|
+
}
|
116
|
+
offset(value) {
|
117
|
+
this.offsetSelector = value;
|
118
|
+
return this;
|
62
119
|
}
|
63
|
-
/**
|
64
|
-
* @inheritDoc
|
65
|
-
*/
|
66
120
|
async execute() {
|
67
121
|
try {
|
68
122
|
const query = this.build();
|
69
|
-
return this.raw(query);
|
123
|
+
return (await this.raw(query));
|
70
124
|
}
|
71
125
|
catch (e) {
|
72
126
|
throw new InternalError(e);
|
73
127
|
}
|
74
128
|
}
|
75
|
-
async raw(rawInput
|
76
|
-
const results = await this.adapter.raw(rawInput
|
77
|
-
if (!this.
|
129
|
+
async raw(rawInput) {
|
130
|
+
const results = await this.adapter.raw(rawInput);
|
131
|
+
if (!this.selectSelector)
|
78
132
|
return results;
|
79
|
-
|
80
|
-
throw new InternalError("No target defined in statement. should never happen");
|
81
|
-
const pkAttr = findPrimaryKey(new this.target()).id;
|
133
|
+
const pkAttr = findPrimaryKey(new this.fromSelector()).id;
|
82
134
|
const processor = function recordProcessor(r) {
|
83
135
|
const id = r[pkAttr];
|
84
|
-
return this.adapter.revert(r, this.
|
136
|
+
return this.adapter.revert(r, this.fromSelector, pkAttr, id);
|
85
137
|
}.bind(this);
|
86
138
|
if (Array.isArray(results))
|
87
139
|
return results.map(processor);
|
88
140
|
return processor(results);
|
89
141
|
}
|
90
|
-
/**
|
91
|
-
* @inheritDoc
|
92
|
-
*/
|
93
|
-
hasErrors(...exceptions) {
|
94
|
-
const errors = super.hasErrors(...exceptions);
|
95
|
-
if (errors)
|
96
|
-
return errors;
|
97
|
-
for (const i in this.clauses) {
|
98
|
-
const err = this.clauses[i].hasErrors();
|
99
|
-
if (err)
|
100
|
-
return err;
|
101
|
-
}
|
102
|
-
}
|
103
|
-
/**
|
104
|
-
* @summary Adds a clause to the Statement
|
105
|
-
* @param {Clause} clause
|
106
|
-
*/
|
107
|
-
addClause(clause) {
|
108
|
-
if (!this.clauses)
|
109
|
-
this.clauses = [];
|
110
|
-
const priority = clause.getPriority();
|
111
|
-
const currentPriority = this.clauses
|
112
|
-
.map((c, i) => ({ index: i, clause: c }))
|
113
|
-
.find((c) => c.clause.getPriority() === priority);
|
114
|
-
if (currentPriority) {
|
115
|
-
this.clauses[currentPriority.index] = clause;
|
116
|
-
}
|
117
|
-
this.clauses.push(clause);
|
118
|
-
}
|
119
|
-
getAdapter() {
|
120
|
-
return this.adapter;
|
121
|
-
}
|
122
|
-
/**
|
123
|
-
* @summary Defines the output class (when existing)
|
124
|
-
* @param {Constructor} clazz
|
125
|
-
*/
|
126
|
-
setTarget(clazz) {
|
127
|
-
if (this.target)
|
128
|
-
throw new QueryError(sf("Output class already defined to {0}", this.target.name));
|
129
|
-
this.target = clazz;
|
130
|
-
}
|
131
|
-
getTarget() {
|
132
|
-
if (!this.target)
|
133
|
-
throw new InternalError("No target defined for statement");
|
134
|
-
return this.target;
|
135
|
-
}
|
136
|
-
setFullRecord() {
|
137
|
-
this.fullRecord = true;
|
138
|
-
}
|
139
|
-
setMode(type) {
|
140
|
-
this.type = type;
|
141
|
-
}
|
142
142
|
}
|
143
143
|
__decorate([
|
144
|
-
|
145
|
-
|
146
|
-
|
147
|
-
__metadata("design:
|
148
|
-
], Statement.prototype, "
|
144
|
+
final(),
|
145
|
+
__metadata("design:type", Function),
|
146
|
+
__metadata("design:paramtypes", [Array]),
|
147
|
+
__metadata("design:returntype", Object)
|
148
|
+
], Statement.prototype, "select", null);
|
149
|
+
__decorate([
|
150
|
+
final(),
|
151
|
+
__metadata("design:type", Function),
|
152
|
+
__metadata("design:paramtypes", [typeof (_a = typeof S !== "undefined" && S) === "function" ? _a : Object]),
|
153
|
+
__metadata("design:returntype", Object)
|
154
|
+
], Statement.prototype, "distinct", null);
|
155
|
+
__decorate([
|
156
|
+
final(),
|
157
|
+
__metadata("design:type", Function),
|
158
|
+
__metadata("design:paramtypes", [typeof (_b = typeof S !== "undefined" && S) === "function" ? _b : Object]),
|
159
|
+
__metadata("design:returntype", Object)
|
160
|
+
], Statement.prototype, "max", null);
|
161
|
+
__decorate([
|
162
|
+
final(),
|
163
|
+
__metadata("design:type", Function),
|
164
|
+
__metadata("design:paramtypes", [typeof (_c = typeof S !== "undefined" && S) === "function" ? _c : Object]),
|
165
|
+
__metadata("design:returntype", Object)
|
166
|
+
], Statement.prototype, "min", null);
|
167
|
+
__decorate([
|
168
|
+
final(),
|
169
|
+
__metadata("design:type", Function),
|
170
|
+
__metadata("design:paramtypes", [typeof (_d = typeof S !== "undefined" && S) === "function" ? _d : Object]),
|
171
|
+
__metadata("design:returntype", Object)
|
172
|
+
], Statement.prototype, "count", null);
|
173
|
+
__decorate([
|
174
|
+
final(),
|
175
|
+
__metadata("design:type", Function),
|
176
|
+
__metadata("design:paramtypes", [Object]),
|
177
|
+
__metadata("design:returntype", Object)
|
178
|
+
], Statement.prototype, "from", null);
|
179
|
+
__decorate([
|
180
|
+
final(),
|
181
|
+
__metadata("design:type", Function),
|
182
|
+
__metadata("design:paramtypes", [Condition]),
|
183
|
+
__metadata("design:returntype", Object)
|
184
|
+
], Statement.prototype, "where", null);
|
185
|
+
__decorate([
|
186
|
+
final(),
|
187
|
+
__metadata("design:type", Function),
|
188
|
+
__metadata("design:paramtypes", [Array]),
|
189
|
+
__metadata("design:returntype", Object)
|
190
|
+
], Statement.prototype, "orderBy", null);
|
191
|
+
__decorate([
|
192
|
+
final(),
|
193
|
+
__metadata("design:type", Function),
|
194
|
+
__metadata("design:paramtypes", [Object]),
|
195
|
+
__metadata("design:returntype", Object)
|
196
|
+
], Statement.prototype, "groupBy", null);
|
149
197
|
__decorate([
|
150
|
-
|
151
|
-
|
152
|
-
__metadata("design:
|
153
|
-
|
198
|
+
final(),
|
199
|
+
__metadata("design:type", Function),
|
200
|
+
__metadata("design:paramtypes", [Number]),
|
201
|
+
__metadata("design:returntype", Object)
|
202
|
+
], Statement.prototype, "limit", null);
|
154
203
|
__decorate([
|
155
|
-
|
156
|
-
__metadata("design:type",
|
157
|
-
|
204
|
+
final(),
|
205
|
+
__metadata("design:type", Function),
|
206
|
+
__metadata("design:paramtypes", [Number]),
|
207
|
+
__metadata("design:returntype", Object)
|
208
|
+
], Statement.prototype, "offset", null);
|
158
209
|
__decorate([
|
159
|
-
|
160
|
-
__metadata("design:type",
|
161
|
-
|
162
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Statement.js","sourceRoot":"","sources":["../../../src/query/Statement.ts"],"names":[],"mappings":";;;;;;;;;AACA,OAAO,EACL,SAAS,EACT,KAAK,EAEL,QAAQ,EACR,IAAI,EACJ,EAAE,GACH,MAAM,gCAAgC,CAAC;AAExC,OAAO,EAAE,mBAAmB,EAAiB,MAAM,aAAa,CAAC;AACjE,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAEtC,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC/C,OAAO,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAC;AACzC,OAAO,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAGxE;;;;;;;;;;;;GAYG;AACH,MAAM,OAAgB,SACpB,SAAQ,KAAK;IAkBb,YAAsB,EAA6B;QACjD,KAAK,EAAE,CAAC;QAbA,YAAO,GAAmB,SAAS,CAAC;QAKpC,WAAM,GAAsB,SAAS,CAAC;QAEtC,eAAU,GAAY,KAAK,CAAC;QAG5B,SAAI,GAAY,SAAS,CAAC;QAIlC,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;IACpB,CAAC;IAES,KAAK;QACb,IAAI,CAAC,IAAI,CAAC,OAAO;YACf,MAAM,IAAI,UAAU,CAAC,EAAE,CAAC,iCAAiC,EAAE,YAAY,CAAC,CAAC,CAAC;QAC5E,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE;YAC3B,OAAO,EAAE,CAAC,WAAW,EAAE,GAAG,EAAE,CAAC,WAAW,EAAE,CAAC;QAC7C,CAAC,CAAC,CAAC;QAEH,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;QAChC,IAAI,MAAM;YACR,MAAM,IAAI,UAAU,CAClB,EAAE,CAAC,6BAA6B,EAAE,MAAM,CAAC,QAAQ,EAAE,CAAC,CACrD,CAAC;QAEJ,IAAI,KAAQ,CAAC;QACb,IAAI,CAAC;YACH,MAAM,QAAQ,GAAG,UACf,OAAsB,EACtB,WAAgB,EAAE;gBAElB,MAAM,CAAC,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;gBAC1B,IAAI,CAAC,CAAC;oBAAE,OAAO,QAAa,CAAC;gBAC7B,MAAM,OAAO,GAAG,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;gBAClC,OAAO,QAAQ,CAAC,OAAO,EAAE,OAAc,CAAC,CAAC;YAC3C,CAAC,CAAC;YAEF,KAAK,GAAG,QAAQ,CAAC,IAAI,KAAK,CAAC,GAAI,IAAI,CAAC,OAAuB,CAAC,CAAM,CAAC;QACrE,CAAC;QAAC,OAAO,CAAM,EAAE,CAAC;YAChB,MAAM,IAAI,UAAU,CAAC,CAAC,CAAC,CAAC;QAC1B,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,OAAO;QACX,IAAI,CAAC;YACH,MAAM,KAAK,GAAM,IAAI,CAAC,KAAK,EAAE,CAAC;YAC9B,OAAO,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACzB,CAAC;QAAC,OAAO,CAAM,EAAE,CAAC;YAChB,MAAM,IAAI,aAAa,CAAC,CAAC,CAAC,CAAC;QAC7B,CAAC;IACH,CAAC;IAOD,KAAK,CAAC,GAAG,CAAI,QAAW,EAAE,GAAG,IAAW;QACtC,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,GAAG,CAAI,QAAQ,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,CAAC;QACnE,IAAI,CAAC,IAAI,CAAC,UAAU;YAAE,OAAO,OAAO,CAAC;QACrC,IAAI,CAAC,IAAI,CAAC,MAAM;YACd,MAAM,IAAI,aAAa,CACrB,qDAAqD,CACtD,CAAC;QAEJ,MAAM,MAAM,GAAG,cAAc,CAAC,IAAI,IAAI,CAAC,MAAM,EAAS,CAAC,CAAC,EAAE,CAAC;QAE3D,MAAM,SAAS,GAAG,SAAS,eAAe,CAAqB,CAAM;YACnE,MAAM,EAAE,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC;YACrB,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CACxB,CAAC,EACD,IAAI,CAAC,MAA0B,EAC/B,MAAM,EACN,EAAE,CACI,CAAC;QACX,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAEb,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC;YAAE,OAAO,OAAO,CAAC,GAAG,CAAC,SAAS,CAAM,CAAC;QAC/D,OAAO,SAAS,CAAC,OAAO,CAAM,CAAC;IACjC,CAAC;IAED;;OAEG;IACH,SAAS,CAAC,GAAG,UAAoB;QAC/B,MAAM,MAAM,GAAG,KAAK,CAAC,SAAS,CAAC,GAAG,UAAU,CAAC,CAAC;QAC9C,IAAI,MAAM;YAAE,OAAO,MAAM,CAAC;QAE1B,KAAK,MAAM,CAAC,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YAC7B,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,CAAQ,CAAC,CAAC,SAAS,EAAE,CAAC;YAC/C,IAAI,GAAG;gBAAE,OAAO,GAAG,CAAC;QACtB,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,SAAS,CAAC,MAAiB;QACzB,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;QAErC,MAAM,QAAQ,GAAG,MAAM,CAAC,WAAW,EAAE,CAAC;QACtC,MAAM,eAAe,GAAG,IAAI,CAAC,OAAO;aACjC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC,CAAC;aACxC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,WAAW,EAAE,KAAK,QAAQ,CAAC,CAAC;QACpD,IAAI,eAAe,EAAE,CAAC;YACpB,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,KAAK,CAAC,GAAG,MAAM,CAAC;QAC/C,CAAC;QACD,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC5B,CAAC;IAED,UAAU;QACR,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED;;;OAGG;IACH,SAAS,CAAC,KAAuB;QAC/B,IAAI,IAAI,CAAC,MAAM;YACb,MAAM,IAAI,UAAU,CAClB,EAAE,CAAC,qCAAqC,EAAE,IAAI,CAAC,MAAO,CAAC,IAAI,CAAC,CAC7D,CAAC;QACJ,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACtB,CAAC;IAED,SAAS;QACP,IAAI,CAAC,IAAI,CAAC,MAAM;YACd,MAAM,IAAI,aAAa,CAAC,iCAAiC,CAAC,CAAC;QAC7D,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED,aAAa;QACX,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;IACzB,CAAC;IAED,OAAO,CAAC,IAAmB;QACzB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,CAAC;CACF;AAtJW;IAHT,QAAQ,EAAE;IACV,SAAS,CAAC,mBAAmB,CAAC,MAAM,CAAC;IACrC,cAAc,EAAE;;0CAC6B;AAGpC;IAFT,QAAQ,EAAE;IACV,IAAI,CAAC,CAAC,QAAQ,CAAC,CAAC;8BACE,OAAO;0CAAmB;AAEnC;IADT,QAAQ,EAAE;;yCACqC;AAKtC;IADT,QAAQ,EAAE;;uCACyB","sourcesContent":["import type { Constructor } from \"@decaf-ts/decorator-validation\";\nimport {\n  minlength,\n  Model,\n  ModelErrorDefinition,\n  required,\n  type,\n  sf,\n} from \"@decaf-ts/decorator-validation\";\nimport { Executor, RawExecutor } from \"../interfaces\";\nimport { MandatoryPriorities, StatementType } from \"./constants\";\nimport { QueryError } from \"./errors\";\nimport { Clause } from \"./Clause\";\nimport { clauseSequence } from \"../validators\";\nimport { Adapter } from \"../persistence\";\nimport { findPrimaryKey, InternalError } from \"@decaf-ts/db-decorators\";\nimport { Paginator } from \"./Paginator\";\n\n/**\n * @summary Statement Class\n * @description holds all the clauses until they can be processed\n *\n * @param {ModelArg} [statement]\n *\n * @class Statement\n * @extends Model\n * @implements Executor\n * @implements RawExecutor\n *\n * @category Query\n */\nexport abstract class Statement<Q>\n  extends Model\n  implements Executor, RawExecutor<Q>\n{\n  @required()\n  @minlength(MandatoryPriorities.length)\n  @clauseSequence()\n  protected clauses?: Clause<any>[] = undefined;\n  @required()\n  @type([\"object\"])\n  protected adapter: Adapter<any, Q, any, any>;\n  @required()\n  protected target?: Constructor<any> = undefined;\n\n  protected fullRecord: boolean = false;\n\n  @required()\n  protected type?: string = undefined;\n\n  protected constructor(db: Adapter<any, Q, any, any>) {\n    super();\n    this.adapter = db;\n  }\n\n  protected build(): Q {\n    if (!this.clauses)\n      throw new QueryError(sf(\"Failed to build Statement:\\n{0}\", \"No Clauses\"));\n    this.clauses.sort((c1, c2) => {\n      return c1.getPriority() - c2.getPriority();\n    });\n\n    const errors = this.hasErrors();\n    if (errors)\n      throw new QueryError(\n        sf(\"Poorly built statement: {0}\", errors.toString())\n      );\n\n    let query: Q;\n    try {\n      const iterator = function (\n        clauses: Clause<any>[],\n        previous: any = {}\n      ): Q {\n        const c = clauses.shift();\n        if (!c) return previous as Q;\n        const results = c.build(previous);\n        return iterator(clauses, results as any);\n      };\n\n      query = iterator(new Array(...(this.clauses as Clause<Q>[]))) as Q;\n    } catch (e: any) {\n      throw new QueryError(e);\n    }\n\n    return query;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  async execute<Y>(): Promise<Y> {\n    try {\n      const query: Q = this.build();\n      return this.raw(query);\n    } catch (e: any) {\n      throw new InternalError(e);\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  abstract paginate<Y>(size: number): Promise<Paginator<Y, Q>>;\n\n  async raw<R>(rawInput: Q, ...args: any[]): Promise<R> {\n    const results = await this.adapter.raw<R>(rawInput, true, ...args);\n    if (!this.fullRecord) return results;\n    if (!this.target)\n      throw new InternalError(\n        \"No target defined in statement. should never happen\"\n      );\n\n    const pkAttr = findPrimaryKey(new this.target() as any).id;\n\n    const processor = function recordProcessor(this: Statement<Q>, r: any) {\n      const id = r[pkAttr];\n      return this.adapter.revert(\n        r,\n        this.target as Constructor<any>,\n        pkAttr,\n        id\n      ) as any;\n    }.bind(this);\n\n    if (Array.isArray(results)) return results.map(processor) as R;\n    return processor(results) as R;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  hasErrors(...exceptions: string[]): ModelErrorDefinition | undefined {\n    const errors = super.hasErrors(...exceptions);\n    if (errors) return errors;\n\n    for (const i in this.clauses) {\n      const err = this.clauses[i as any].hasErrors();\n      if (err) return err;\n    }\n  }\n\n  /**\n   * @summary Adds a clause to the Statement\n   * @param {Clause} clause\n   */\n  addClause(clause: Clause<Q>) {\n    if (!this.clauses) this.clauses = [];\n\n    const priority = clause.getPriority();\n    const currentPriority = this.clauses\n      .map((c, i) => ({ index: i, clause: c }))\n      .find((c) => c.clause.getPriority() === priority);\n    if (currentPriority) {\n      this.clauses[currentPriority.index] = clause;\n    }\n    this.clauses.push(clause);\n  }\n\n  getAdapter(): Adapter<any, Q, any, any> {\n    return this.adapter;\n  }\n\n  /**\n   * @summary Defines the output class (when existing)\n   * @param {Constructor} clazz\n   */\n  setTarget(clazz: Constructor<any>) {\n    if (this.target)\n      throw new QueryError(\n        sf(\"Output class already defined to {0}\", this.target!.name)\n      );\n    this.target = clazz;\n  }\n\n  getTarget() {\n    if (!this.target)\n      throw new InternalError(\"No target defined for statement\");\n    return this.target;\n  }\n\n  setFullRecord() {\n    this.fullRecord = true;\n  }\n\n  setMode(type: StatementType) {\n    this.type = type;\n  }\n}\n"]}
|
210
|
+
final(),
|
211
|
+
__metadata("design:type", Function),
|
212
|
+
__metadata("design:paramtypes", []),
|
213
|
+
__metadata("design:returntype", Promise)
|
214
|
+
], Statement.prototype, "execute", null);
|
215
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Statement.js","sourceRoot":"","sources":["../../../src/query/Statement.ts"],"names":[],"mappings":"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","sourcesContent":["import { type Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport type { Executor, RawExecutor } from \"../interfaces\";\nimport type {\n  FromSelector,\n  GroupBySelector,\n  OrderBySelector,\n  SelectSelector,\n} from \"./selectors\";\nimport { Condition } from \"./Condition\";\nimport { findPrimaryKey, InternalError } from \"@decaf-ts/db-decorators\";\nimport { final } from \"../utils/decorators\";\nimport type {\n  CountOption,\n  DistinctOption,\n  LimitOption,\n  MaxOption,\n  MinOption,\n  OffsetOption,\n  OrderAndGroupOption,\n  SelectOption,\n  WhereOption,\n} from \"./options\";\nimport { Paginatable } from \"../interfaces/Paginatable\";\nimport { Paginator } from \"./Paginator\";\nimport { Adapter } from \"../persistence\";\nimport { QueryError } from \"./errors\";\n\n/**\n * @description Base class for database query statements\n * @summary Provides a foundation for building and executing database queries\n * \n * This abstract class implements the query builder pattern for constructing\n * database queries. It supports various query operations like select, from,\n * where, orderBy, groupBy, limit, and offset. It also provides methods for\n * executing queries and handling pagination.\n * \n * @template Q - The query type specific to the database adapter\n * @template M - The model type this statement operates on\n * @template R - The return type of the query\n * @param {Adapter<any, Q, any, any>} adapter - The database adapter to use for executing queries\n * @class Statement\n * @example\n * // Create a statement to query users\n * const statement = new SQLStatement(adapter);\n * const users = await statement\n *   .select()\n *   .from(User)\n *   .where(Condition.attribute(\"status\").eq(\"active\"))\n *   .orderBy([\"createdAt\", \"DESC\"])\n *   .limit(10)\n *   .execute();\n * \n * // Use pagination\n * const paginator = await statement\n *   .select()\n *   .from(User)\n *   .paginate(20); // 20 users per page\n * \n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant Statement\n *   participant Adapter\n *   participant Database\n *   \n *   Client->>Statement: select()\n *   Client->>Statement: from(Model)\n *   Client->>Statement: where(condition)\n *   Client->>Statement: orderBy([field, direction])\n *   Client->>Statement: limit(value)\n *   Client->>Statement: execute()\n *   Statement->>Statement: build()\n *   Statement->>Adapter: raw(query)\n *   Adapter->>Database: execute query\n *   Database-->>Adapter: return results\n *   Adapter-->>Statement: return processed results\n *   Statement-->>Client: return final results\n */\nexport abstract class Statement<Q, M extends Model, R>\n  implements Executor<R>, RawExecutor<Q>, Paginatable<M, R, Q>\n{\n  protected readonly selectSelector?: SelectSelector<M>[];\n  protected distinctSelector?: SelectSelector<M>;\n  protected maxSelector?: SelectSelector<M>;\n  protected minSelector?: SelectSelector<M>;\n  protected countSelector?: SelectSelector<M>;\n  protected fromSelector!: Constructor<M>;\n  protected whereCondition?: Condition<M>;\n  protected orderBySelector?: OrderBySelector<M>;\n  protected groupBySelector?: GroupBySelector<M>;\n  protected limitSelector?: number;\n  protected offsetSelector?: number;\n\n  protected constructor(protected adapter: Adapter<any, Q, any, any>) {}\n\n  select<\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    S extends readonly SelectSelector<M>[],\n  >(): SelectOption<M, M[]>;\n  select<S extends readonly SelectSelector<M>[]>(\n    selector: readonly [...S]\n  ): SelectOption<M, Pick<M, S[number]>[]>;\n\n  @final()\n  select<S extends readonly SelectSelector<M>[]>(\n    selector?: readonly [...S]\n  ): SelectOption<M, M[]> | SelectOption<M, Pick<M, S[number]>[]> {\n    Object.defineProperty(this, \"selectSelector\", {\n      value: selector,\n      writable: false,\n    });\n    return this as SelectOption<M, M[]> | SelectOption<M, Pick<M, S[number]>[]>;\n  }\n\n  @final()\n  distinct<S extends SelectSelector<M>>(\n    selector: S\n  ): DistinctOption<M, M[S][]> {\n    this.distinctSelector = selector;\n    return this as DistinctOption<M, M[S][]>;\n  }\n\n  @final()\n  max<S extends SelectSelector<M>>(selector: S): MaxOption<M, M[S]> {\n    this.maxSelector = selector;\n    return this as MaxOption<M, M[S]>;\n  }\n\n  @final()\n  min<S extends SelectSelector<M>>(selector: S): MinOption<M, M[S]> {\n    this.minSelector = selector;\n    return this as MinOption<M, M[S]>;\n  }\n\n  @final()\n  count<S extends SelectSelector<M>>(selector?: S): CountOption<M, number> {\n    this.countSelector = selector;\n    return this as CountOption<M, number>;\n  }\n\n  @final()\n  public from(selector: FromSelector<M>): WhereOption<M, R> {\n    this.fromSelector = (\n      typeof selector === \"string\" ? Model.get(selector) : selector\n    ) as Constructor<M>;\n    if (!this.fromSelector)\n      throw new QueryError(`Could not find selector model: ${selector}`);\n    return this;\n  }\n\n  @final()\n  public where(condition: Condition<M>): OrderAndGroupOption<M, R> {\n    this.whereCondition = condition;\n    return this;\n  }\n\n  @final()\n  public orderBy(\n    selector: OrderBySelector<M>\n  ): LimitOption<M, R> & OffsetOption<R> {\n    this.orderBySelector = selector;\n    return this;\n  }\n\n  @final()\n  public groupBy(selector: GroupBySelector<M>): LimitOption<M, R> {\n    this.groupBySelector = selector;\n    return this;\n  }\n\n  @final()\n  public limit(value: number): OffsetOption<R> {\n    this.limitSelector = value;\n    return this;\n  }\n\n  @final()\n  public offset(value: number): Executor<R> {\n    this.offsetSelector = value;\n    return this;\n  }\n\n  @final()\n  async execute(): Promise<R> {\n    try {\n      const query: Q = this.build();\n      return (await this.raw(query)) as R;\n    } catch (e: unknown) {\n      throw new InternalError(e as Error);\n    }\n  }\n\n  async raw<R>(rawInput: Q): Promise<R> {\n    const results = await this.adapter.raw<R>(rawInput);\n    if (!this.selectSelector) return results;\n    const pkAttr = findPrimaryKey(\n      new (this.fromSelector as Constructor<M>)()\n    ).id;\n\n    const processor = function recordProcessor(\n      this: Statement<Q, M, R>,\n      r: any\n    ) {\n      const id = r[pkAttr];\n      return this.adapter.revert(\n        r,\n        this.fromSelector as Constructor<any>,\n        pkAttr,\n        id\n      ) as any;\n    }.bind(this as any);\n\n    if (Array.isArray(results)) return results.map(processor) as R;\n    return processor(results) as R;\n  }\n\n  protected abstract build(): Q;\n  protected abstract parseCondition(condition: Condition<M>): Q;\n  abstract paginate(size: number): Promise<Paginator<M, R, Q>>;\n}\n"]}
|
@@ -1,79 +1,40 @@
|
|
1
|
+
/**
|
2
|
+
* @description Comparison operators for query conditions
|
3
|
+
* @summary Enum defining the available operators for comparing values in database queries
|
4
|
+
* @enum {string}
|
5
|
+
* @readonly
|
6
|
+
* @memberOf module:core
|
7
|
+
*/
|
1
8
|
export declare enum Operator {
|
9
|
+
/** Equal comparison (=) */
|
2
10
|
EQUAL = "EQUAL",
|
11
|
+
/** Not equal comparison (!=) */
|
3
12
|
DIFFERENT = "DIFFERENT",
|
13
|
+
/** Greater than comparison (>) */
|
4
14
|
BIGGER = "BIGGER",
|
15
|
+
/** Greater than or equal comparison (>=) */
|
5
16
|
BIGGER_EQ = "BIGGER_EQ",
|
17
|
+
/** Less than comparison (<) */
|
6
18
|
SMALLER = "SMALLER",
|
19
|
+
/** Less than or equal comparison (<=) */
|
7
20
|
SMALLER_EQ = "SMALLER_EQ",
|
21
|
+
/** Negation operator (NOT) */
|
8
22
|
NOT = "NOT",
|
23
|
+
/** Inclusion operator (IN) */
|
9
24
|
IN = "IN",
|
25
|
+
/** Regular expression matching */
|
10
26
|
REGEXP = "REGEXP"
|
11
27
|
}
|
28
|
+
/**
|
29
|
+
* @description Logical operators for combining query conditions
|
30
|
+
* @summary Enum defining the available operators for grouping multiple conditions in database queries
|
31
|
+
* @enum {string}
|
32
|
+
* @readonly
|
33
|
+
* @memberOf module:core
|
34
|
+
*/
|
12
35
|
export declare enum GroupOperator {
|
36
|
+
/** Logical AND operator - all conditions must be true */
|
13
37
|
AND = "AND",
|
38
|
+
/** Logical OR operator - at least one condition must be true */
|
14
39
|
OR = "OR"
|
15
40
|
}
|
16
|
-
export declare enum Const {
|
17
|
-
NULL = "NULL",
|
18
|
-
FULL_RECORD = "*"
|
19
|
-
}
|
20
|
-
/**
|
21
|
-
* @summary Defines execution order of Clauses in statements as defined in SQL.
|
22
|
-
*
|
23
|
-
* @description sub priorities where defined to better organize clauses within statements, eg From and Join Clauses
|
24
|
-
*
|
25
|
-
* @const Priority
|
26
|
-
*
|
27
|
-
* @category Clauses
|
28
|
-
* @subcategory Constants
|
29
|
-
*/
|
30
|
-
export declare enum Priority {
|
31
|
-
/**
|
32
|
-
* @summary Defines the priority for the FROM Clause
|
33
|
-
* @description From Clause in SELECT Statements.
|
34
|
-
* Values Clause in INSERT Statements
|
35
|
-
*
|
36
|
-
* @prop FROM
|
37
|
-
*/
|
38
|
-
FROM = 1,
|
39
|
-
/**
|
40
|
-
* @summary Defines the priority for the JOIN Clause
|
41
|
-
*
|
42
|
-
* @property {number} JOIN
|
43
|
-
*/
|
44
|
-
JOIN = 1.1,
|
45
|
-
/**
|
46
|
-
* Where Clause
|
47
|
-
*/
|
48
|
-
WHERE = 2,
|
49
|
-
/**
|
50
|
-
* Group By Clause
|
51
|
-
*/
|
52
|
-
GROUP_BY = 3,
|
53
|
-
/**
|
54
|
-
* Having Clause
|
55
|
-
*/
|
56
|
-
HAVING = 4,
|
57
|
-
/**
|
58
|
-
* Select Clause in SELECT Statements
|
59
|
-
* Insert Clause in INSERT Statements
|
60
|
-
*/
|
61
|
-
SELECT = 5,
|
62
|
-
/**
|
63
|
-
* Order By Clause
|
64
|
-
*/
|
65
|
-
ORDER_BY = 6,
|
66
|
-
/**
|
67
|
-
* Limit Clause
|
68
|
-
*/
|
69
|
-
LIMIT = 7,
|
70
|
-
/**
|
71
|
-
* Offset Clause
|
72
|
-
*/
|
73
|
-
OFFSET = 7.1
|
74
|
-
}
|
75
|
-
export declare const MandatoryPriorities: Priority[];
|
76
|
-
export declare enum StatementType {
|
77
|
-
QUERY = "query",
|
78
|
-
TRANSACTION = "transaction"
|
79
|
-
}
|
@@ -1,87 +1,45 @@
|
|
1
|
+
/**
|
2
|
+
* @description Comparison operators for query conditions
|
3
|
+
* @summary Enum defining the available operators for comparing values in database queries
|
4
|
+
* @enum {string}
|
5
|
+
* @readonly
|
6
|
+
* @memberOf module:core
|
7
|
+
*/
|
1
8
|
export var Operator;
|
2
9
|
(function (Operator) {
|
10
|
+
/** Equal comparison (=) */
|
3
11
|
Operator["EQUAL"] = "EQUAL";
|
12
|
+
/** Not equal comparison (!=) */
|
4
13
|
Operator["DIFFERENT"] = "DIFFERENT";
|
14
|
+
/** Greater than comparison (>) */
|
5
15
|
Operator["BIGGER"] = "BIGGER";
|
16
|
+
/** Greater than or equal comparison (>=) */
|
6
17
|
Operator["BIGGER_EQ"] = "BIGGER_EQ";
|
18
|
+
/** Less than comparison (<) */
|
7
19
|
Operator["SMALLER"] = "SMALLER";
|
20
|
+
/** Less than or equal comparison (<=) */
|
8
21
|
Operator["SMALLER_EQ"] = "SMALLER_EQ";
|
9
22
|
// BETWEEN = "BETWEEN",
|
23
|
+
/** Negation operator (NOT) */
|
10
24
|
Operator["NOT"] = "NOT";
|
25
|
+
/** Inclusion operator (IN) */
|
11
26
|
Operator["IN"] = "IN";
|
12
27
|
// IS = "IS",
|
28
|
+
/** Regular expression matching */
|
13
29
|
Operator["REGEXP"] = "REGEXP";
|
14
30
|
})(Operator || (Operator = {}));
|
31
|
+
/**
|
32
|
+
* @description Logical operators for combining query conditions
|
33
|
+
* @summary Enum defining the available operators for grouping multiple conditions in database queries
|
34
|
+
* @enum {string}
|
35
|
+
* @readonly
|
36
|
+
* @memberOf module:core
|
37
|
+
*/
|
15
38
|
export var GroupOperator;
|
16
39
|
(function (GroupOperator) {
|
40
|
+
/** Logical AND operator - all conditions must be true */
|
17
41
|
GroupOperator["AND"] = "AND";
|
42
|
+
/** Logical OR operator - at least one condition must be true */
|
18
43
|
GroupOperator["OR"] = "OR";
|
19
44
|
})(GroupOperator || (GroupOperator = {}));
|
20
|
-
|
21
|
-
(function (Const) {
|
22
|
-
Const["NULL"] = "NULL";
|
23
|
-
Const["FULL_RECORD"] = "*";
|
24
|
-
})(Const || (Const = {}));
|
25
|
-
/**
|
26
|
-
* @summary Defines execution order of Clauses in statements as defined in SQL.
|
27
|
-
*
|
28
|
-
* @description sub priorities where defined to better organize clauses within statements, eg From and Join Clauses
|
29
|
-
*
|
30
|
-
* @const Priority
|
31
|
-
*
|
32
|
-
* @category Clauses
|
33
|
-
* @subcategory Constants
|
34
|
-
*/
|
35
|
-
export var Priority;
|
36
|
-
(function (Priority) {
|
37
|
-
/**
|
38
|
-
* @summary Defines the priority for the FROM Clause
|
39
|
-
* @description From Clause in SELECT Statements.
|
40
|
-
* Values Clause in INSERT Statements
|
41
|
-
*
|
42
|
-
* @prop FROM
|
43
|
-
*/
|
44
|
-
Priority[Priority["FROM"] = 1] = "FROM";
|
45
|
-
/**
|
46
|
-
* @summary Defines the priority for the JOIN Clause
|
47
|
-
*
|
48
|
-
* @property {number} JOIN
|
49
|
-
*/
|
50
|
-
Priority[Priority["JOIN"] = 1.1] = "JOIN";
|
51
|
-
/**
|
52
|
-
* Where Clause
|
53
|
-
*/
|
54
|
-
Priority[Priority["WHERE"] = 2] = "WHERE";
|
55
|
-
/**
|
56
|
-
* Group By Clause
|
57
|
-
*/
|
58
|
-
Priority[Priority["GROUP_BY"] = 3] = "GROUP_BY";
|
59
|
-
/**
|
60
|
-
* Having Clause
|
61
|
-
*/
|
62
|
-
Priority[Priority["HAVING"] = 4] = "HAVING";
|
63
|
-
/**
|
64
|
-
* Select Clause in SELECT Statements
|
65
|
-
* Insert Clause in INSERT Statements
|
66
|
-
*/
|
67
|
-
Priority[Priority["SELECT"] = 5] = "SELECT";
|
68
|
-
/**
|
69
|
-
* Order By Clause
|
70
|
-
*/
|
71
|
-
Priority[Priority["ORDER_BY"] = 6] = "ORDER_BY";
|
72
|
-
/**
|
73
|
-
* Limit Clause
|
74
|
-
*/
|
75
|
-
Priority[Priority["LIMIT"] = 7] = "LIMIT";
|
76
|
-
/**
|
77
|
-
* Offset Clause
|
78
|
-
*/
|
79
|
-
Priority[Priority["OFFSET"] = 7.1] = "OFFSET";
|
80
|
-
})(Priority || (Priority = {}));
|
81
|
-
export const MandatoryPriorities = [Priority.FROM, Priority.SELECT];
|
82
|
-
export var StatementType;
|
83
|
-
(function (StatementType) {
|
84
|
-
StatementType["QUERY"] = "query";
|
85
|
-
StatementType["TRANSACTION"] = "transaction";
|
86
|
-
})(StatementType || (StatementType = {}));
|
87
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3F1ZXJ5L2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQU4sSUFBWSxRQVlYO0FBWkQsV0FBWSxRQUFRO0lBQ2xCLDJCQUFlLENBQUE7SUFDZixtQ0FBdUIsQ0FBQTtJQUN2Qiw2QkFBaUIsQ0FBQTtJQUNqQixtQ0FBdUIsQ0FBQTtJQUN2QiwrQkFBbUIsQ0FBQTtJQUNuQixxQ0FBeUIsQ0FBQTtJQUN6Qix1QkFBdUI7SUFDdkIsdUJBQVcsQ0FBQTtJQUNYLHFCQUFTLENBQUE7SUFDVCxhQUFhO0lBQ2IsNkJBQWlCLENBQUE7QUFDbkIsQ0FBQyxFQVpXLFFBQVEsS0FBUixRQUFRLFFBWW5CO0FBRUQsTUFBTSxDQUFOLElBQVksYUFHWDtBQUhELFdBQVksYUFBYTtJQUN2Qiw0QkFBVyxDQUFBO0lBQ1gsMEJBQVMsQ0FBQTtBQUNYLENBQUMsRUFIVyxhQUFhLEtBQWIsYUFBYSxRQUd4QjtBQUVELE1BQU0sQ0FBTixJQUFZLEtBR1g7QUFIRCxXQUFZLEtBQUs7SUFDZixzQkFBYSxDQUFBO0lBQ2IsMEJBQWlCLENBQUE7QUFDbkIsQ0FBQyxFQUhXLEtBQUssS0FBTCxLQUFLLFFBR2hCO0FBRUQ7Ozs7Ozs7OztHQVNHO0FBQ0gsTUFBTSxDQUFOLElBQVksUUE0Q1g7QUE1Q0QsV0FBWSxRQUFRO0lBQ2xCOzs7Ozs7T0FNRztJQUNILHVDQUFRLENBQUE7SUFDUjs7OztPQUlHO0lBQ0gseUNBQVUsQ0FBQTtJQUNWOztPQUVHO0lBQ0gseUNBQVMsQ0FBQTtJQUNUOztPQUVHO0lBQ0gsK0NBQVksQ0FBQTtJQUNaOztPQUVHO0lBQ0gsMkNBQVUsQ0FBQTtJQUNWOzs7T0FHRztJQUNILDJDQUFVLENBQUE7SUFDVjs7T0FFRztJQUNILCtDQUFZLENBQUE7SUFDWjs7T0FFRztJQUNILHlDQUFTLENBQUE7SUFDVDs7T0FFRztJQUNILDZDQUFZLENBQUE7QUFDZCxDQUFDLEVBNUNXLFFBQVEsS0FBUixRQUFRLFFBNENuQjtBQUVELE1BQU0sQ0FBQyxNQUFNLG1CQUFtQixHQUFHLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxRQUFRLENBQUMsTUFBTSxDQUFDLENBQUM7QUFFcEUsTUFBTSxDQUFOLElBQVksYUFHWDtBQUhELFdBQVksYUFBYTtJQUN2QixnQ0FBZSxDQUFBO0lBQ2YsNENBQTJCLENBQUE7QUFDN0IsQ0FBQyxFQUhXLGFBQWEsS0FBYixhQUFhLFFBR3hCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gT3BlcmF0b3Ige1xuICBFUVVBTCA9IFwiRVFVQUxcIixcbiAgRElGRkVSRU5UID0gXCJESUZGRVJFTlRcIixcbiAgQklHR0VSID0gXCJCSUdHRVJcIixcbiAgQklHR0VSX0VRID0gXCJCSUdHRVJfRVFcIixcbiAgU01BTExFUiA9IFwiU01BTExFUlwiLFxuICBTTUFMTEVSX0VRID0gXCJTTUFMTEVSX0VRXCIsXG4gIC8vIEJFVFdFRU4gPSBcIkJFVFdFRU5cIixcbiAgTk9UID0gXCJOT1RcIixcbiAgSU4gPSBcIklOXCIsXG4gIC8vIElTID0gXCJJU1wiLFxuICBSRUdFWFAgPSBcIlJFR0VYUFwiLFxufVxuXG5leHBvcnQgZW51bSBHcm91cE9wZXJhdG9yIHtcbiAgQU5EID0gXCJBTkRcIixcbiAgT1IgPSBcIk9SXCIsXG59XG5cbmV4cG9ydCBlbnVtIENvbnN0IHtcbiAgTlVMTCA9IFwiTlVMTFwiLFxuICBGVUxMX1JFQ09SRCA9IFwiKlwiLFxufVxuXG4vKipcbiAqIEBzdW1tYXJ5IERlZmluZXMgZXhlY3V0aW9uIG9yZGVyIG9mIENsYXVzZXMgaW4gc3RhdGVtZW50cyBhcyBkZWZpbmVkIGluIFNRTC5cbiAqXG4gKiBAZGVzY3JpcHRpb24gc3ViIHByaW9yaXRpZXMgd2hlcmUgZGVmaW5lZCB0byBiZXR0ZXIgb3JnYW5pemUgY2xhdXNlcyB3aXRoaW4gc3RhdGVtZW50cywgZWcgRnJvbSBhbmQgSm9pbiBDbGF1c2VzXG4gKlxuICogQGNvbnN0IFByaW9yaXR5XG4gKlxuICogQGNhdGVnb3J5IENsYXVzZXNcbiAqIEBzdWJjYXRlZ29yeSBDb25zdGFudHNcbiAqL1xuZXhwb3J0IGVudW0gUHJpb3JpdHkge1xuICAvKipcbiAgICogQHN1bW1hcnkgRGVmaW5lcyB0aGUgcHJpb3JpdHkgZm9yIHRoZSBGUk9NIENsYXVzZVxuICAgKiBAZGVzY3JpcHRpb24gRnJvbSBDbGF1c2UgaW4gU0VMRUNUIFN0YXRlbWVudHMuXG4gICAqIFZhbHVlcyBDbGF1c2UgaW4gSU5TRVJUIFN0YXRlbWVudHNcbiAgICpcbiAgICogQHByb3AgRlJPTVxuICAgKi9cbiAgRlJPTSA9IDEsXG4gIC8qKlxuICAgKiBAc3VtbWFyeSBEZWZpbmVzIHRoZSBwcmlvcml0eSBmb3IgdGhlIEpPSU4gQ2xhdXNlXG4gICAqXG4gICAqIEBwcm9wZXJ0eSB7bnVtYmVyfSBKT0lOXG4gICAqL1xuICBKT0lOID0gMS4xLFxuICAvKipcbiAgICogV2hlcmUgQ2xhdXNlXG4gICAqL1xuICBXSEVSRSA9IDIsXG4gIC8qKlxuICAgKiBHcm91cCBCeSBDbGF1c2VcbiAgICovXG4gIEdST1VQX0JZID0gMyxcbiAgLyoqXG4gICAqIEhhdmluZyBDbGF1c2VcbiAgICovXG4gIEhBVklORyA9IDQsXG4gIC8qKlxuICAgKiBTZWxlY3QgQ2xhdXNlIGluIFNFTEVDVCBTdGF0ZW1lbnRzXG4gICAqIEluc2VydCBDbGF1c2UgaW4gSU5TRVJUIFN0YXRlbWVudHNcbiAgICovXG4gIFNFTEVDVCA9IDUsXG4gIC8qKlxuICAgKiBPcmRlciBCeSBDbGF1c2VcbiAgICovXG4gIE9SREVSX0JZID0gNixcbiAgLyoqXG4gICAqIExpbWl0IENsYXVzZVxuICAgKi9cbiAgTElNSVQgPSA3LFxuICAvKipcbiAgICogT2Zmc2V0IENsYXVzZVxuICAgKi9cbiAgT0ZGU0VUID0gNy4xLFxufVxuXG5leHBvcnQgY29uc3QgTWFuZGF0b3J5UHJpb3JpdGllcyA9IFtQcmlvcml0eS5GUk9NLCBQcmlvcml0eS5TRUxFQ1RdO1xuXG5leHBvcnQgZW51bSBTdGF0ZW1lbnRUeXBlIHtcbiAgUVVFUlkgPSBcInF1ZXJ5XCIsXG4gIFRSQU5TQUNUSU9OID0gXCJ0cmFuc2FjdGlvblwiLFxufVxuIl19
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3F1ZXJ5L2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFDSCxNQUFNLENBQU4sSUFBWSxRQXFCWDtBQXJCRCxXQUFZLFFBQVE7SUFDbEIsMkJBQTJCO0lBQzNCLDJCQUFlLENBQUE7SUFDZixnQ0FBZ0M7SUFDaEMsbUNBQXVCLENBQUE7SUFDdkIsa0NBQWtDO0lBQ2xDLDZCQUFpQixDQUFBO0lBQ2pCLDRDQUE0QztJQUM1QyxtQ0FBdUIsQ0FBQTtJQUN2QiwrQkFBK0I7SUFDL0IsK0JBQW1CLENBQUE7SUFDbkIseUNBQXlDO0lBQ3pDLHFDQUF5QixDQUFBO0lBQ3pCLHVCQUF1QjtJQUN2Qiw4QkFBOEI7SUFDOUIsdUJBQVcsQ0FBQTtJQUNYLDhCQUE4QjtJQUM5QixxQkFBUyxDQUFBO0lBQ1QsYUFBYTtJQUNiLGtDQUFrQztJQUNsQyw2QkFBaUIsQ0FBQTtBQUNuQixDQUFDLEVBckJXLFFBQVEsS0FBUixRQUFRLFFBcUJuQjtBQUVEOzs7Ozs7R0FNRztBQUNILE1BQU0sQ0FBTixJQUFZLGFBS1g7QUFMRCxXQUFZLGFBQWE7SUFDdkIseURBQXlEO0lBQ3pELDRCQUFXLENBQUE7SUFDWCxnRUFBZ0U7SUFDaEUsMEJBQVMsQ0FBQTtBQUNYLENBQUMsRUFMVyxhQUFhLEtBQWIsYUFBYSxRQUt4QiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGRlc2NyaXB0aW9uIENvbXBhcmlzb24gb3BlcmF0b3JzIGZvciBxdWVyeSBjb25kaXRpb25zXG4gKiBAc3VtbWFyeSBFbnVtIGRlZmluaW5nIHRoZSBhdmFpbGFibGUgb3BlcmF0b3JzIGZvciBjb21wYXJpbmcgdmFsdWVzIGluIGRhdGFiYXNlIHF1ZXJpZXNcbiAqIEBlbnVtIHtzdHJpbmd9XG4gKiBAcmVhZG9ubHlcbiAqIEBtZW1iZXJPZiBtb2R1bGU6Y29yZVxuICovXG5leHBvcnQgZW51bSBPcGVyYXRvciB7XG4gIC8qKiBFcXVhbCBjb21wYXJpc29uICg9KSAqL1xuICBFUVVBTCA9IFwiRVFVQUxcIixcbiAgLyoqIE5vdCBlcXVhbCBjb21wYXJpc29uICghPSkgKi9cbiAgRElGRkVSRU5UID0gXCJESUZGRVJFTlRcIixcbiAgLyoqIEdyZWF0ZXIgdGhhbiBjb21wYXJpc29uICg+KSAqL1xuICBCSUdHRVIgPSBcIkJJR0dFUlwiLFxuICAvKiogR3JlYXRlciB0aGFuIG9yIGVxdWFsIGNvbXBhcmlzb24gKD49KSAqL1xuICBCSUdHRVJfRVEgPSBcIkJJR0dFUl9FUVwiLFxuICAvKiogTGVzcyB0aGFuIGNvbXBhcmlzb24gKDwpICovXG4gIFNNQUxMRVIgPSBcIlNNQUxMRVJcIixcbiAgLyoqIExlc3MgdGhhbiBvciBlcXVhbCBjb21wYXJpc29uICg8PSkgKi9cbiAgU01BTExFUl9FUSA9IFwiU01BTExFUl9FUVwiLFxuICAvLyBCRVRXRUVOID0gXCJCRVRXRUVOXCIsXG4gIC8qKiBOZWdhdGlvbiBvcGVyYXRvciAoTk9UKSAqL1xuICBOT1QgPSBcIk5PVFwiLFxuICAvKiogSW5jbHVzaW9uIG9wZXJhdG9yIChJTikgKi9cbiAgSU4gPSBcIklOXCIsXG4gIC8vIElTID0gXCJJU1wiLFxuICAvKiogUmVndWxhciBleHByZXNzaW9uIG1hdGNoaW5nICovXG4gIFJFR0VYUCA9IFwiUkVHRVhQXCIsXG59XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIExvZ2ljYWwgb3BlcmF0b3JzIGZvciBjb21iaW5pbmcgcXVlcnkgY29uZGl0aW9uc1xuICogQHN1bW1hcnkgRW51bSBkZWZpbmluZyB0aGUgYXZhaWxhYmxlIG9wZXJhdG9ycyBmb3IgZ3JvdXBpbmcgbXVsdGlwbGUgY29uZGl0aW9ucyBpbiBkYXRhYmFzZSBxdWVyaWVzXG4gKiBAZW51bSB7c3RyaW5nfVxuICogQHJlYWRvbmx5XG4gKiBAbWVtYmVyT2YgbW9kdWxlOmNvcmVcbiAqL1xuZXhwb3J0IGVudW0gR3JvdXBPcGVyYXRvciB7XG4gIC8qKiBMb2dpY2FsIEFORCBvcGVyYXRvciAtIGFsbCBjb25kaXRpb25zIG11c3QgYmUgdHJ1ZSAqL1xuICBBTkQgPSBcIkFORFwiLFxuICAvKiogTG9naWNhbCBPUiBvcGVyYXRvciAtIGF0IGxlYXN0IG9uZSBjb25kaXRpb24gbXVzdCBiZSB0cnVlICovXG4gIE9SID0gXCJPUlwiLFxufVxuIl19
|
@@ -1,7 +1,21 @@
|
|
1
1
|
import { BaseError } from "@decaf-ts/db-decorators";
|
2
|
+
/**
|
3
|
+
* @description Error thrown during query operations
|
4
|
+
* @summary Represents errors that occur during query building or execution
|
5
|
+
* @param {string | Error} msg - The error message or Error object
|
6
|
+
* @class QueryError
|
7
|
+
* @category Errors
|
8
|
+
*/
|
2
9
|
export declare class QueryError extends BaseError {
|
3
10
|
constructor(msg: string | Error);
|
4
11
|
}
|
12
|
+
/**
|
13
|
+
* @description Error thrown during pagination operations
|
14
|
+
* @summary Represents errors that occur during pagination setup or execution
|
15
|
+
* @param {string | Error} msg - The error message or Error object
|
16
|
+
* @class PagingError
|
17
|
+
* @category Errors
|
18
|
+
*/
|
5
19
|
export declare class PagingError extends BaseError {
|
6
20
|
constructor(msg: string | Error);
|
7
21
|
}
|
package/lib/esm/query/errors.js
CHANGED
@@ -1,12 +1,26 @@
|
|
1
1
|
import { BaseError } from "@decaf-ts/db-decorators";
|
2
|
+
/**
|
3
|
+
* @description Error thrown during query operations
|
4
|
+
* @summary Represents errors that occur during query building or execution
|
5
|
+
* @param {string | Error} msg - The error message or Error object
|
6
|
+
* @class QueryError
|
7
|
+
* @category Errors
|
8
|
+
*/
|
2
9
|
export class QueryError extends BaseError {
|
3
10
|
constructor(msg) {
|
4
11
|
super(QueryError.name, msg, 500);
|
5
12
|
}
|
6
13
|
}
|
14
|
+
/**
|
15
|
+
* @description Error thrown during pagination operations
|
16
|
+
* @summary Represents errors that occur during pagination setup or execution
|
17
|
+
* @param {string | Error} msg - The error message or Error object
|
18
|
+
* @class PagingError
|
19
|
+
* @category Errors
|
20
|
+
*/
|
7
21
|
export class PagingError extends BaseError {
|
8
22
|
constructor(msg) {
|
9
23
|
super(PagingError.name, msg, 500);
|
10
24
|
}
|
11
25
|
}
|
12
|
-
//# sourceMappingURL=data:application/json;base64,
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3F1ZXJ5L2Vycm9ycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFFcEQ7Ozs7OztHQU1HO0FBQ0gsTUFBTSxPQUFPLFVBQVcsU0FBUSxTQUFTO0lBQ3ZDLFlBQVksR0FBbUI7UUFDN0IsS0FBSyxDQUFDLFVBQVUsQ0FBQyxJQUFJLEVBQUUsR0FBRyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQ25DLENBQUM7Q0FDRjtBQUVEOzs7Ozs7R0FNRztBQUNILE1BQU0sT0FBTyxXQUFZLFNBQVEsU0FBUztJQUN4QyxZQUFZLEdBQW1CO1FBQzdCLEtBQUssQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFFLEdBQUcsRUFBRSxHQUFHLENBQUMsQ0FBQztJQUNwQyxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCYXNlRXJyb3IgfSBmcm9tIFwiQGRlY2FmLXRzL2RiLWRlY29yYXRvcnNcIjtcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gRXJyb3IgdGhyb3duIGR1cmluZyBxdWVyeSBvcGVyYXRpb25zXG4gKiBAc3VtbWFyeSBSZXByZXNlbnRzIGVycm9ycyB0aGF0IG9jY3VyIGR1cmluZyBxdWVyeSBidWlsZGluZyBvciBleGVjdXRpb25cbiAqIEBwYXJhbSB7c3RyaW5nIHwgRXJyb3J9IG1zZyAtIFRoZSBlcnJvciBtZXNzYWdlIG9yIEVycm9yIG9iamVjdFxuICogQGNsYXNzIFF1ZXJ5RXJyb3JcbiAqIEBjYXRlZ29yeSBFcnJvcnNcbiAqL1xuZXhwb3J0IGNsYXNzIFF1ZXJ5RXJyb3IgZXh0ZW5kcyBCYXNlRXJyb3Ige1xuICBjb25zdHJ1Y3Rvcihtc2c6IHN0cmluZyB8IEVycm9yKSB7XG4gICAgc3VwZXIoUXVlcnlFcnJvci5uYW1lLCBtc2csIDUwMCk7XG4gIH1cbn1cblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gRXJyb3IgdGhyb3duIGR1cmluZyBwYWdpbmF0aW9uIG9wZXJhdGlvbnNcbiAqIEBzdW1tYXJ5IFJlcHJlc2VudHMgZXJyb3JzIHRoYXQgb2NjdXIgZHVyaW5nIHBhZ2luYXRpb24gc2V0dXAgb3IgZXhlY3V0aW9uXG4gKiBAcGFyYW0ge3N0cmluZyB8IEVycm9yfSBtc2cgLSBUaGUgZXJyb3IgbWVzc2FnZSBvciBFcnJvciBvYmplY3RcbiAqIEBjbGFzcyBQYWdpbmdFcnJvclxuICogQGNhdGVnb3J5IEVycm9yc1xuICovXG5leHBvcnQgY2xhc3MgUGFnaW5nRXJyb3IgZXh0ZW5kcyBCYXNlRXJyb3Ige1xuICBjb25zdHJ1Y3Rvcihtc2c6IHN0cmluZyB8IEVycm9yKSB7XG4gICAgc3VwZXIoUGFnaW5nRXJyb3IubmFtZSwgbXNnLCA1MDApO1xuICB9XG59XG4iXX0=
|