@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
package/lib/model/decorators.cjs
CHANGED
@@ -20,22 +20,37 @@ const Adapter_1 = require("./../persistence/Adapter.cjs");
|
|
20
20
|
const Repository_1 = require("./../repository/Repository.cjs");
|
21
21
|
const Condition_1 = require("./../query/Condition.cjs");
|
22
22
|
const construction_1 = require("./construction.cjs");
|
23
|
-
const
|
23
|
+
const utils_1 = require("./../utils/index.cjs");
|
24
|
+
/**
|
25
|
+
* @description Specifies the database table name for a model
|
26
|
+
* @summary Decorator that sets the table name for a model class in the database
|
27
|
+
* @param {string} tableName - The name of the table in the database
|
28
|
+
* @return {Function} A decorator function that can be applied to a class
|
29
|
+
* @function table
|
30
|
+
* @category Class Decorators
|
31
|
+
*/
|
24
32
|
function table(tableName) {
|
25
33
|
return (0, reflection_1.metadata)(Adapter_1.Adapter.key(constants_1.PersistenceKeys.TABLE), tableName);
|
26
34
|
}
|
35
|
+
/**
|
36
|
+
* @description Specifies the database column name for a model property
|
37
|
+
* @summary Decorator that maps a model property to a specific column name in the database
|
38
|
+
* @param {string} columnName - The name of the column in the database
|
39
|
+
* @return {Function} A decorator function that can be applied to a class property
|
40
|
+
* @function column
|
41
|
+
* @category Property Decorators
|
42
|
+
*/
|
27
43
|
function column(columnName) {
|
28
44
|
return (0, decorator_validation_1.propMetadata)(Adapter_1.Adapter.key(constants_1.PersistenceKeys.COLUMN), columnName);
|
29
45
|
}
|
30
46
|
/**
|
31
|
-
* @
|
32
|
-
* @
|
33
|
-
*
|
34
|
-
*
|
35
|
-
* @
|
36
|
-
* @param {string[]} [compositions]
|
37
|
-
*
|
47
|
+
* @description Creates an index on a model property for improved query performance
|
48
|
+
* @summary Decorator that marks a property to be indexed in the database, optionally with specific directions and compositions
|
49
|
+
* @param {OrderDirection[]} [directions] - Optional array of sort directions for the index
|
50
|
+
* @param {string[]} [compositions] - Optional array of property names to create a composite index
|
51
|
+
* @return {Function} A decorator function that can be applied to a class property
|
38
52
|
* @function index
|
53
|
+
* @category Property Decorators
|
39
54
|
*/
|
40
55
|
function index(directions, compositions) {
|
41
56
|
return (0, decorator_validation_1.propMetadata)(Repository_1.Repository.key(`${constants_1.PersistenceKeys.INDEX}${compositions && compositions.length ? `.${compositions.join(".")}` : ""}`), {
|
@@ -43,6 +58,23 @@ function index(directions, compositions) {
|
|
43
58
|
compositions: compositions,
|
44
59
|
});
|
45
60
|
}
|
61
|
+
/**
|
62
|
+
* @description Enforces uniqueness constraint during model creation and update
|
63
|
+
* @summary Internal function used by the unique decorator to check if a property value already exists in the database
|
64
|
+
* @template M - The model type extending Model
|
65
|
+
* @template R - The repository type extending Repo<M, F, C>
|
66
|
+
* @template V - The metadata type
|
67
|
+
* @template F - The repository flags type
|
68
|
+
* @template C - The context type extending Context<F>
|
69
|
+
* @param {R} this - The repository instance
|
70
|
+
* @param {Context<F>} context - The context for the operation
|
71
|
+
* @param {V} data - The metadata for the property
|
72
|
+
* @param key - The property key to check for uniqueness
|
73
|
+
* @param {M} model - The model instance being created or updated
|
74
|
+
* @return {Promise<void>} A promise that resolves when the check is complete or rejects with a ConflictError
|
75
|
+
* @function uniqueOnCreateUpdate
|
76
|
+
* @memberOf module:core
|
77
|
+
*/
|
46
78
|
async function uniqueOnCreateUpdate(context, data, key, model) {
|
47
79
|
if (!model[key])
|
48
80
|
return;
|
@@ -53,17 +85,40 @@ async function uniqueOnCreateUpdate(context, data, key, model) {
|
|
53
85
|
throw new db_decorators_1.ConflictError(`model already exists with property ${key} equal to ${JSON.stringify(model[key], undefined, 2)}`);
|
54
86
|
}
|
55
87
|
/**
|
56
|
-
* @
|
57
|
-
* @
|
58
|
-
*
|
59
|
-
*
|
88
|
+
* @description Tags a property as unique
|
89
|
+
* @summary Decorator that ensures a property value is unique across all instances of a model in the database
|
90
|
+
* @return {Function} A decorator function that can be applied to a class property
|
60
91
|
* @function unique
|
61
|
-
*
|
62
|
-
* @
|
92
|
+
* @category Property Decorators
|
93
|
+
* @example
|
94
|
+
* ```typescript
|
95
|
+
* class User extends BaseModel {
|
96
|
+
* @unique()
|
97
|
+
* @required()
|
98
|
+
* username!: string;
|
99
|
+
* }
|
100
|
+
* ```
|
63
101
|
*/
|
64
102
|
function unique() {
|
65
103
|
return (0, reflection_1.apply)((0, db_decorators_1.onCreateUpdate)(uniqueOnCreateUpdate), (0, decorator_validation_1.propMetadata)(Repository_1.Repository.key(constants_1.PersistenceKeys.UNIQUE), {}));
|
66
104
|
}
|
105
|
+
/**
|
106
|
+
* @description Handles user identification for ownership tracking
|
107
|
+
* @summary Internal function used by the createdBy and updatedBy decorators to set ownership information
|
108
|
+
* @template M - The model type extending Model
|
109
|
+
* @template R - The repository type extending Repo<M, F, C>
|
110
|
+
* @template V - The relations metadata type extending RelationsMetadata
|
111
|
+
* @template F - The repository flags type
|
112
|
+
* @template C - The context type extending Context<F>
|
113
|
+
* @param {R} this - The repository instance
|
114
|
+
* @param {Context<F>} context - The context for the operation
|
115
|
+
* @param {V} data - The metadata for the property
|
116
|
+
* @param key - The property key to store the user identifier
|
117
|
+
* @param {M} model - The model instance being created or updated
|
118
|
+
* @return {Promise<void>} A promise that rejects with an AuthorizationError if user identification is not supported
|
119
|
+
* @function createdByOnCreateUpdate
|
120
|
+
* @memberOf module:core
|
121
|
+
*/
|
67
122
|
async function createdByOnCreateUpdate(
|
68
123
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
69
124
|
context,
|
@@ -73,14 +128,42 @@ data,
|
|
73
128
|
key,
|
74
129
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
75
130
|
model) {
|
76
|
-
throw new
|
131
|
+
throw new utils_1.AuthorizationError("This adapter does not support user identification");
|
77
132
|
}
|
133
|
+
/**
|
134
|
+
* @description Tracks the creator of a model instance
|
135
|
+
* @summary Decorator that marks a property to store the identifier of the user who created the model instance
|
136
|
+
* @return {Function} A decorator function that can be applied to a class property
|
137
|
+
* @function createdBy
|
138
|
+
* @category Property Decorators
|
139
|
+
* @example
|
140
|
+
* ```typescript
|
141
|
+
* class Document extends BaseModel {
|
142
|
+
* @createdBy()
|
143
|
+
* creator!: string;
|
144
|
+
* }
|
145
|
+
* ```
|
146
|
+
*/
|
78
147
|
function createdBy() {
|
79
148
|
const key = Repository_1.Repository.key(constants_1.PersistenceKeys.CREATED_BY);
|
80
149
|
return decorator_validation_1.Decoration.for(key)
|
81
150
|
.define((0, db_decorators_1.onCreate)(createdByOnCreateUpdate), (0, decorator_validation_1.propMetadata)(key, {}))
|
82
151
|
.apply();
|
83
152
|
}
|
153
|
+
/**
|
154
|
+
* @description Tracks the last updater of a model instance
|
155
|
+
* @summary Decorator that marks a property to store the identifier of the user who last updated the model instance
|
156
|
+
* @return {Function} A decorator function that can be applied to a class property
|
157
|
+
* @function updatedBy
|
158
|
+
* @category Property Decorators
|
159
|
+
* @example
|
160
|
+
* ```typescript
|
161
|
+
* class Document extends BaseModel {
|
162
|
+
* @updatedBy()
|
163
|
+
* lastEditor!: string;
|
164
|
+
* }
|
165
|
+
* ```
|
166
|
+
*/
|
84
167
|
function updatedBy() {
|
85
168
|
const key = Repository_1.Repository.key(constants_1.PersistenceKeys.UPDATED_BY);
|
86
169
|
return decorator_validation_1.Decoration.for(key)
|
@@ -88,16 +171,27 @@ function updatedBy() {
|
|
88
171
|
.apply();
|
89
172
|
}
|
90
173
|
/**
|
91
|
-
* @
|
92
|
-
*
|
93
|
-
* @
|
94
|
-
* @param {
|
95
|
-
* @param {
|
96
|
-
*
|
97
|
-
* @function
|
98
|
-
*
|
99
|
-
* @
|
174
|
+
* @description Defines a one-to-one relationship between models
|
175
|
+
* @summary Decorator that establishes a one-to-one relationship between the current model and another model
|
176
|
+
* @template M - The related model type extending Model
|
177
|
+
* @param {Constructor<M>} clazz - The constructor of the related model class
|
178
|
+
* @param {CascadeMetadata} [cascadeOptions=DefaultCascade] - Options for cascading operations (create, update, delete)
|
179
|
+
* @param {boolean} [populate=true] - If true, automatically populates the relationship when the model is retrieved
|
180
|
+
* @return {Function} A decorator function that can be applied to a class property
|
181
|
+
* @function oneToOne
|
182
|
+
* @category Property Decorators
|
183
|
+
* @example
|
184
|
+
* ```typescript
|
185
|
+
* class User extends BaseModel {
|
186
|
+
* @oneToOne(Profile)
|
187
|
+
* profile!: string | Profile;
|
188
|
+
* }
|
100
189
|
*
|
190
|
+
* class Profile extends BaseModel {
|
191
|
+
* @required()
|
192
|
+
* bio!: string;
|
193
|
+
* }
|
194
|
+
* ```
|
101
195
|
* @see oneToMany
|
102
196
|
* @see manyToOne
|
103
197
|
*/
|
@@ -114,15 +208,30 @@ function oneToOne(clazz, cascadeOptions = constants_2.DefaultCascade, populate =
|
|
114
208
|
.apply();
|
115
209
|
}
|
116
210
|
/**
|
117
|
-
* @
|
118
|
-
*
|
119
|
-
* @
|
120
|
-
* @param {
|
121
|
-
*
|
211
|
+
* @description Defines a one-to-many relationship between models
|
212
|
+
* @summary Decorator that establishes a one-to-many relationship between the current model and multiple instances of another model
|
213
|
+
* @template M - The related model type extending Model
|
214
|
+
* @param {Constructor<M>} clazz - The constructor of the related model class
|
215
|
+
* @param {CascadeMetadata} [cascadeOptions=DefaultCascade] - Options for cascading operations (create, update, delete)
|
216
|
+
* @param {boolean} [populate=true] - If true, automatically populates the relationship when the model is retrieved
|
217
|
+
* @return {Function} A decorator function that can be applied to a class property
|
122
218
|
* @function oneToMany
|
219
|
+
* @category Property Decorators
|
220
|
+
* @example
|
221
|
+
* ```typescript
|
222
|
+
* class Author extends BaseModel {
|
223
|
+
* @required()
|
224
|
+
* name!: string;
|
123
225
|
*
|
124
|
-
*
|
226
|
+
* @oneToMany(Book)
|
227
|
+
* books!: string[] | Book[];
|
228
|
+
* }
|
125
229
|
*
|
230
|
+
* class Book extends BaseModel {
|
231
|
+
* @required()
|
232
|
+
* title!: string;
|
233
|
+
* }
|
234
|
+
* ```
|
126
235
|
* @see oneToOne
|
127
236
|
* @see manyToOne
|
128
237
|
*/
|
@@ -141,15 +250,30 @@ function oneToMany(clazz, cascadeOptions = constants_2.DefaultCascade, populate
|
|
141
250
|
.apply();
|
142
251
|
}
|
143
252
|
/**
|
144
|
-
* @
|
145
|
-
*
|
146
|
-
* @
|
147
|
-
* @param {
|
148
|
-
*
|
253
|
+
* @description Defines a many-to-one relationship between models
|
254
|
+
* @summary Decorator that establishes a many-to-one relationship between multiple instances of the current model and another model
|
255
|
+
* @template M - The related model type extending Model
|
256
|
+
* @param {Constructor<M>} clazz - The constructor of the related model class
|
257
|
+
* @param {CascadeMetadata} [cascadeOptions=DefaultCascade] - Options for cascading operations (create, update, delete)
|
258
|
+
* @param {boolean} [populate=true] - If true, automatically populates the relationship when the model is retrieved
|
259
|
+
* @return {Function} A decorator function that can be applied to a class property
|
149
260
|
* @function manyToOne
|
261
|
+
* @category Property Decorators
|
262
|
+
* @example
|
263
|
+
* ```typescript
|
264
|
+
* class Book extends BaseModel {
|
265
|
+
* @required()
|
266
|
+
* title!: string;
|
150
267
|
*
|
151
|
-
*
|
268
|
+
* @manyToOne(Author)
|
269
|
+
* author!: string | Author;
|
270
|
+
* }
|
152
271
|
*
|
272
|
+
* class Author extends BaseModel {
|
273
|
+
* @required()
|
274
|
+
* name!: string;
|
275
|
+
* }
|
276
|
+
* ```
|
153
277
|
* @see oneToMany
|
154
278
|
* @see oneToOne
|
155
279
|
*/
|
@@ -170,4 +294,4 @@ function manyToOne(clazz, cascadeOptions = constants_2.DefaultCascade, populate
|
|
170
294
|
(0, decorator_validation_1.propMetadata)(key, metadata))
|
171
295
|
.apply();
|
172
296
|
}
|
173
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/model/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ConflictError,\n  onCreate,\n  onCreateUpdate,\n  onDelete,\n  onUpdate,\n  afterAny,\n  RepositoryFlags,\n  Context,\n} from \"@decaf-ts/db-decorators\";\nimport { apply, metadata } from \"@decaf-ts/reflection\";\nimport { PersistenceKeys } from \"../persistence/constants\";\nimport { CascadeMetadata, IndexMetadata } from \"../repository/types\";\nimport { DefaultCascade, OrderDirection } from \"../repository/constants\";\nimport {\n  Constructor,\n  Decoration,\n  list,\n  Model,\n  prop,\n  propMetadata,\n  type,\n} from \"@decaf-ts/decorator-validation\";\nimport { Adapter } from \"../persistence/Adapter\";\nimport { Repo, Repository } from \"../repository/Repository\";\nimport { Condition } from \"../query/Condition\";\nimport { RelationsMetadata } from \"./types\";\nimport {\n  oneToManyOnCreate,\n  oneToManyOnDelete,\n  oneToManyOnUpdate,\n  oneToOneOnCreate,\n  oneToOneOnDelete,\n  oneToOneOnUpdate,\n  populate as pop,\n} from \"./construction\";\nimport { UnsupportedError } from \"../persistence/errors\";\n\nexport function table(tableName: string) {\n  return metadata(Adapter.key(PersistenceKeys.TABLE), tableName);\n}\n\nexport function column(columnName: string) {\n  return propMetadata(Adapter.key(PersistenceKeys.COLUMN), columnName);\n}\n\n/**\n * @summary Index Decorator\n * @description properties decorated will the index in the\n * DB for performance in queries\n *\n * @param {OrderDirection[]} [directions]\n * @param {string[]} [compositions]\n *\n * @function index\n */\nexport function index(directions?: OrderDirection[], compositions?: string[]) {\n  return propMetadata(\n    Repository.key(\n      `${PersistenceKeys.INDEX}${compositions && compositions.length ? `.${compositions.join(\".\")}` : \"\"}`\n    ),\n    {\n      directions: directions,\n      compositions: compositions,\n    } as IndexMetadata\n  );\n}\n\nexport async function uniqueOnCreateUpdate<\n  M extends Model,\n  R extends Repo<M, C, F>,\n  V extends object,\n  F extends RepositoryFlags,\n  C extends Context<F>,\n>(\n  this: R,\n  context: Context<F>,\n  data: V,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  if (!(model as any)[key]) return;\n  const existing = await this.select()\n    .where(Condition.attribute(key as string).eq((model as any)[key]))\n    .execute<M[]>();\n  if (existing.length)\n    throw new ConflictError(\n      `model already exists with property ${key as string} equal to ${JSON.stringify((model as any)[key], undefined, 2)}`\n    );\n}\n\n/**\n * @summary Unique Decorator\n * @description Tags a property as unique.\n *  No other elements in that table can have the same property value\n *\n * @function unique\n *\n * @memberOf module:wallet-db.Decorators\n */\nexport function unique() {\n  return apply(\n    onCreateUpdate(uniqueOnCreateUpdate),\n    propMetadata(Repository.key(PersistenceKeys.UNIQUE), {})\n  );\n}\n\nexport async function createdByOnCreateUpdate<\n  M extends Model,\n  R extends Repo<M, C, F>,\n  V extends RelationsMetadata,\n  F extends RepositoryFlags,\n  C extends Context<F>,\n>(\n  this: R,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  context: Context<F>,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  data: V,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  key: keyof M,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  model: M\n): Promise<void> {\n  throw new UnsupportedError(\n    \"This adapter does not support user identification\"\n  );\n}\n\nexport function createdBy() {\n  const key = Repository.key(PersistenceKeys.CREATED_BY);\n  return Decoration.for(key)\n    .define(onCreate(createdByOnCreateUpdate), propMetadata(key, {}))\n    .apply();\n}\n\nexport function updatedBy() {\n  const key = Repository.key(PersistenceKeys.UPDATED_BY);\n  return Decoration.for(key)\n    .define(onCreateUpdate(createdByOnCreateUpdate), propMetadata(key, {}))\n    .apply();\n}\n\n/**\n * @summary One To One relation Decorators\n *\n * @param {Constructor<any>} clazz the {@link Sequence} to use. Defaults to {@link NoneSequence}\n * @param {CascadeMetadata} [cascadeOptions]\n * @param {boolean} populate If true, replaces the specified key in the document with the corresponding record from the database\n *\n * @function onToOne\n *\n * @memberOf module:wallet-db.Decorators\n *\n * @see oneToMany\n * @see manyToOne\n */\nexport function oneToOne<M extends Model>(\n  clazz: Constructor<M>,\n  cascadeOptions: CascadeMetadata = DefaultCascade,\n  populate: boolean = true\n) {\n  Model.register(clazz);\n  const metadata: RelationsMetadata = {\n    class: clazz.name,\n    cascade: cascadeOptions,\n    populate: populate,\n  };\n  const key = Repository.key(PersistenceKeys.ONE_TO_ONE);\n  return Decoration.for(key)\n    .define(\n      prop(PersistenceKeys.RELATIONS),\n      type([clazz.name, String.name, Number.name, BigInt.name]),\n      onCreate(oneToOneOnCreate, metadata),\n      onUpdate(oneToOneOnUpdate, metadata),\n      onDelete(oneToOneOnDelete, metadata),\n      afterAny(pop, metadata),\n      propMetadata(key, metadata)\n    )\n    .apply();\n}\n\n/**\n * @summary One To Many relation Decorators\n *\n * @param {Constructor<any>} clazz the {@link Sequence} to use. Defaults to {@link NoneSequence}\n * @param {CascadeMetadata} [cascadeOptions]\n *\n * @function oneToMany\n *\n * @memberOf module:wallet-db.Decorators\n *\n * @see oneToOne\n * @see manyToOne\n */\nexport function oneToMany<M extends Model>(\n  clazz: Constructor<M>,\n  cascadeOptions: CascadeMetadata = DefaultCascade,\n  populate: boolean = true\n) {\n  Model.register(clazz);\n  const metadata: RelationsMetadata = {\n    class: clazz.name,\n    cascade: cascadeOptions,\n    populate: populate,\n  };\n  const key = Repository.key(PersistenceKeys.ONE_TO_MANY);\n  return Decoration.for(key)\n    .define(\n      prop(PersistenceKeys.RELATIONS),\n      // @ts-expect-error purposeful override\n      list([clazz, String, Number, BigInt]),\n      onCreate(oneToManyOnCreate, metadata),\n      onUpdate(oneToManyOnUpdate, metadata),\n      onDelete(oneToManyOnDelete, metadata),\n      afterAny(pop, metadata),\n      propMetadata(key, metadata)\n    )\n    .apply();\n}\n\n/**\n * @summary Many To One relation Decorators\n *\n * @param {Constructor<any>} clazz the {@link Sequence} to use. Defaults to {@link NoneSequence}\n * @param {CascadeMetadata} [cascadeOptions]\n *\n * @function manyToOne\n *\n * @memberOf module:wallet-db.Decorators\n *\n * @see oneToMany\n * @see oneToOne\n */\nexport function manyToOne(\n  clazz: Constructor<any>,\n  cascadeOptions: CascadeMetadata = DefaultCascade,\n  populate = true\n) {\n  Model.register(clazz);\n  const metadata: RelationsMetadata = {\n    class: clazz.name,\n    cascade: cascadeOptions,\n    populate: populate,\n  };\n  const key = Repository.key(PersistenceKeys.MANY_TO_ONE);\n  return Decoration.for(key)\n    .define(\n      prop(PersistenceKeys.RELATIONS),\n      type([clazz.name, String.name, Number.name, BigInt.name]),\n      // onCreate(oneToManyOnCreate, metadata),\n      // onUpdate(oneToManyOnUpdate, metadata),\n      // onDelete(oneToManyOnDelete, metadata),\n      // afterAll(populate, metadata),\n      propMetadata(key, metadata)\n    )\n    .apply();\n}\n"]}
|
297
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/model/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ConflictError,\n  onCreate,\n  onCreateUpdate,\n  onDelete,\n  onUpdate,\n  afterAny,\n  RepositoryFlags,\n  Context,\n} from \"@decaf-ts/db-decorators\";\nimport { apply, metadata } from \"@decaf-ts/reflection\";\nimport { PersistenceKeys } from \"../persistence/constants\";\nimport { CascadeMetadata, IndexMetadata } from \"../repository/types\";\nimport { DefaultCascade, OrderDirection } from \"../repository/constants\";\nimport {\n  Constructor,\n  Decoration,\n  list,\n  Model,\n  prop,\n  propMetadata,\n  type,\n} from \"@decaf-ts/decorator-validation\";\nimport { Adapter } from \"../persistence/Adapter\";\nimport { Repo, Repository } from \"../repository/Repository\";\nimport { Condition } from \"../query/Condition\";\nimport { RelationsMetadata } from \"./types\";\nimport {\n  oneToManyOnCreate,\n  oneToManyOnDelete,\n  oneToManyOnUpdate,\n  oneToOneOnCreate,\n  oneToOneOnDelete,\n  oneToOneOnUpdate,\n  populate as pop,\n} from \"./construction\";\nimport { AuthorizationError } from \"../utils\";\n\n/**\n * @description Specifies the database table name for a model\n * @summary Decorator that sets the table name for a model class in the database\n * @param {string} tableName - The name of the table in the database\n * @return {Function} A decorator function that can be applied to a class\n * @function table\n * @category Class Decorators\n */\nexport function table(tableName: string) {\n  return metadata(Adapter.key(PersistenceKeys.TABLE), tableName);\n}\n\n/**\n * @description Specifies the database column name for a model property\n * @summary Decorator that maps a model property to a specific column name in the database\n * @param {string} columnName - The name of the column in the database\n * @return {Function} A decorator function that can be applied to a class property\n * @function column\n * @category Property Decorators\n */\nexport function column(columnName: string) {\n  return propMetadata(Adapter.key(PersistenceKeys.COLUMN), columnName);\n}\n\n/**\n * @description Creates an index on a model property for improved query performance\n * @summary Decorator that marks a property to be indexed in the database, optionally with specific directions and compositions\n * @param {OrderDirection[]} [directions] - Optional array of sort directions for the index\n * @param {string[]} [compositions] - Optional array of property names to create a composite index\n * @return {Function} A decorator function that can be applied to a class property\n * @function index\n * @category Property Decorators\n */\nexport function index(directions?: OrderDirection[], compositions?: string[]) {\n  return propMetadata(\n    Repository.key(\n      `${PersistenceKeys.INDEX}${compositions && compositions.length ? `.${compositions.join(\".\")}` : \"\"}`\n    ),\n    {\n      directions: directions,\n      compositions: compositions,\n    } as IndexMetadata\n  );\n}\n\n/**\n * @description Enforces uniqueness constraint during model creation and update\n * @summary Internal function used by the unique decorator to check if a property value already exists in the database\n * @template M - The model type extending Model\n * @template R - The repository type extending Repo<M, F, C>\n * @template V - The metadata type\n * @template F - The repository flags type\n * @template C - The context type extending Context<F>\n * @param {R} this - The repository instance\n * @param {Context<F>} context - The context for the operation\n * @param {V} data - The metadata for the property\n * @param key - The property key to check for uniqueness\n * @param {M} model - The model instance being created or updated\n * @return {Promise<void>} A promise that resolves when the check is complete or rejects with a ConflictError\n * @function uniqueOnCreateUpdate\n * @memberOf module:core\n */\nexport async function uniqueOnCreateUpdate<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends object,\n  F extends RepositoryFlags,\n  C extends Context<F>,\n>(\n  this: R,\n  context: Context<F>,\n  data: V,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  if (!(model as any)[key]) return;\n  const existing = await this.select()\n    .where(Condition.attribute(key).eq(model[key]))\n    .execute();\n  if (existing.length)\n    throw new ConflictError(\n      `model already exists with property ${key as string} equal to ${JSON.stringify((model as any)[key], undefined, 2)}`\n    );\n}\n\n/**\n * @description Tags a property as unique\n * @summary Decorator that ensures a property value is unique across all instances of a model in the database\n * @return {Function} A decorator function that can be applied to a class property\n * @function unique\n * @category Property Decorators\n * @example\n * ```typescript\n * class User extends BaseModel {\n *   @unique()\n *   @required()\n *   username!: string;\n * }\n * ```\n */\nexport function unique() {\n  return apply(\n    onCreateUpdate(uniqueOnCreateUpdate),\n    propMetadata(Repository.key(PersistenceKeys.UNIQUE), {})\n  );\n}\n\n/**\n * @description Handles user identification for ownership tracking\n * @summary Internal function used by the createdBy and updatedBy decorators to set ownership information\n * @template M - The model type extending Model\n * @template R - The repository type extending Repo<M, F, C>\n * @template V - The relations metadata type extending RelationsMetadata\n * @template F - The repository flags type\n * @template C - The context type extending Context<F>\n * @param {R} this - The repository instance\n * @param {Context<F>} context - The context for the operation\n * @param {V} data - The metadata for the property\n * @param key - The property key to store the user identifier\n * @param {M} model - The model instance being created or updated\n * @return {Promise<void>} A promise that rejects with an AuthorizationError if user identification is not supported\n * @function createdByOnCreateUpdate\n * @memberOf module:core\n */\nexport async function createdByOnCreateUpdate<\n  M extends Model,\n  R extends Repo<M, F, C>,\n  V extends RelationsMetadata,\n  F extends RepositoryFlags,\n  C extends Context<F>,\n>(\n  this: R,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  context: Context<F>,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  data: V,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  key: keyof M,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  model: M\n): Promise<void> {\n  throw new AuthorizationError(\n    \"This adapter does not support user identification\"\n  );\n}\n\n/**\n * @description Tracks the creator of a model instance\n * @summary Decorator that marks a property to store the identifier of the user who created the model instance\n * @return {Function} A decorator function that can be applied to a class property\n * @function createdBy\n * @category Property Decorators\n * @example\n * ```typescript\n * class Document extends BaseModel {\n *   @createdBy()\n *   creator!: string;\n * }\n * ```\n */\nexport function createdBy() {\n  const key = Repository.key(PersistenceKeys.CREATED_BY);\n  return Decoration.for(key)\n    .define(onCreate(createdByOnCreateUpdate), propMetadata(key, {}))\n    .apply();\n}\n\n/**\n * @description Tracks the last updater of a model instance\n * @summary Decorator that marks a property to store the identifier of the user who last updated the model instance\n * @return {Function} A decorator function that can be applied to a class property\n * @function updatedBy\n * @category Property Decorators\n * @example\n * ```typescript\n * class Document extends BaseModel {\n *   @updatedBy()\n *   lastEditor!: string;\n * }\n * ```\n */\nexport function updatedBy() {\n  const key = Repository.key(PersistenceKeys.UPDATED_BY);\n  return Decoration.for(key)\n    .define(onCreateUpdate(createdByOnCreateUpdate), propMetadata(key, {}))\n    .apply();\n}\n\n/**\n * @description Defines a one-to-one relationship between models\n * @summary Decorator that establishes a one-to-one relationship between the current model and another model\n * @template M - The related model type extending Model\n * @param {Constructor<M>} clazz - The constructor of the related model class\n * @param {CascadeMetadata} [cascadeOptions=DefaultCascade] - Options for cascading operations (create, update, delete)\n * @param {boolean} [populate=true] - If true, automatically populates the relationship when the model is retrieved\n * @return {Function} A decorator function that can be applied to a class property\n * @function oneToOne\n * @category Property Decorators\n * @example\n * ```typescript\n * class User extends BaseModel {\n *   @oneToOne(Profile)\n *   profile!: string | Profile;\n * }\n *\n * class Profile extends BaseModel {\n *   @required()\n *   bio!: string;\n * }\n * ```\n * @see oneToMany\n * @see manyToOne\n */\nexport function oneToOne<M extends Model>(\n  clazz: Constructor<M>,\n  cascadeOptions: CascadeMetadata = DefaultCascade,\n  populate: boolean = true\n) {\n  Model.register(clazz);\n  const metadata: RelationsMetadata = {\n    class: clazz.name,\n    cascade: cascadeOptions,\n    populate: populate,\n  };\n  const key = Repository.key(PersistenceKeys.ONE_TO_ONE);\n  return Decoration.for(key)\n    .define(\n      prop(PersistenceKeys.RELATIONS),\n      type([clazz.name, String.name, Number.name, BigInt.name]),\n      onCreate(oneToOneOnCreate, metadata),\n      onUpdate(oneToOneOnUpdate, metadata),\n      onDelete(oneToOneOnDelete, metadata),\n      afterAny(pop, metadata),\n      propMetadata(key, metadata)\n    )\n    .apply();\n}\n\n/**\n * @description Defines a one-to-many relationship between models\n * @summary Decorator that establishes a one-to-many relationship between the current model and multiple instances of another model\n * @template M - The related model type extending Model\n * @param {Constructor<M>} clazz - The constructor of the related model class\n * @param {CascadeMetadata} [cascadeOptions=DefaultCascade] - Options for cascading operations (create, update, delete)\n * @param {boolean} [populate=true] - If true, automatically populates the relationship when the model is retrieved\n * @return {Function} A decorator function that can be applied to a class property\n * @function oneToMany\n * @category Property Decorators\n * @example\n * ```typescript\n * class Author extends BaseModel {\n *   @required()\n *   name!: string;\n *\n *   @oneToMany(Book)\n *   books!: string[] | Book[];\n * }\n *\n * class Book extends BaseModel {\n *   @required()\n *   title!: string;\n * }\n * ```\n * @see oneToOne\n * @see manyToOne\n */\nexport function oneToMany<M extends Model>(\n  clazz: Constructor<M>,\n  cascadeOptions: CascadeMetadata = DefaultCascade,\n  populate: boolean = true\n) {\n  Model.register(clazz);\n  const metadata: RelationsMetadata = {\n    class: clazz.name,\n    cascade: cascadeOptions,\n    populate: populate,\n  };\n  const key = Repository.key(PersistenceKeys.ONE_TO_MANY);\n  return Decoration.for(key)\n    .define(\n      prop(PersistenceKeys.RELATIONS),\n      // @ts-expect-error purposeful override\n      list([clazz, String, Number, BigInt]),\n      onCreate(oneToManyOnCreate, metadata),\n      onUpdate(oneToManyOnUpdate, metadata),\n      onDelete(oneToManyOnDelete, metadata),\n      afterAny(pop, metadata),\n      propMetadata(key, metadata)\n    )\n    .apply();\n}\n\n/**\n * @description Defines a many-to-one relationship between models\n * @summary Decorator that establishes a many-to-one relationship between multiple instances of the current model and another model\n * @template M - The related model type extending Model\n * @param {Constructor<M>} clazz - The constructor of the related model class\n * @param {CascadeMetadata} [cascadeOptions=DefaultCascade] - Options for cascading operations (create, update, delete)\n * @param {boolean} [populate=true] - If true, automatically populates the relationship when the model is retrieved\n * @return {Function} A decorator function that can be applied to a class property\n * @function manyToOne\n * @category Property Decorators\n * @example\n * ```typescript\n * class Book extends BaseModel {\n *   @required()\n *   title!: string;\n *\n *   @manyToOne(Author)\n *   author!: string | Author;\n * }\n *\n * class Author extends BaseModel {\n *   @required()\n *   name!: string;\n * }\n * ```\n * @see oneToMany\n * @see oneToOne\n */\nexport function manyToOne<M extends Model>(\n  clazz: Constructor<M>,\n  cascadeOptions: CascadeMetadata = DefaultCascade,\n  populate = true\n) {\n  Model.register(clazz);\n  const metadata: RelationsMetadata = {\n    class: clazz.name,\n    cascade: cascadeOptions,\n    populate: populate,\n  };\n  const key = Repository.key(PersistenceKeys.MANY_TO_ONE);\n  return Decoration.for(key)\n    .define(\n      prop(PersistenceKeys.RELATIONS),\n      type([clazz.name, String.name, Number.name, BigInt.name]),\n      // onCreate(oneToManyOnCreate, metadata),\n      // onUpdate(oneToManyOnUpdate, metadata),\n      // onDelete(oneToManyOnDelete, metadata),\n      // afterAll(populate, metadata),\n      propMetadata(key, metadata)\n    )\n    .apply();\n}\n"]}
|
@@ -4,73 +4,197 @@ import { OrderDirection } from "../repository/constants";
|
|
4
4
|
import { Constructor, Model } from "@decaf-ts/decorator-validation";
|
5
5
|
import { Repo } from "../repository/Repository";
|
6
6
|
import { RelationsMetadata } from "./types";
|
7
|
+
/**
|
8
|
+
* @description Specifies the database table name for a model
|
9
|
+
* @summary Decorator that sets the table name for a model class in the database
|
10
|
+
* @param {string} tableName - The name of the table in the database
|
11
|
+
* @return {Function} A decorator function that can be applied to a class
|
12
|
+
* @function table
|
13
|
+
* @category Class Decorators
|
14
|
+
*/
|
7
15
|
export declare function table(tableName: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
16
|
+
/**
|
17
|
+
* @description Specifies the database column name for a model property
|
18
|
+
* @summary Decorator that maps a model property to a specific column name in the database
|
19
|
+
* @param {string} columnName - The name of the column in the database
|
20
|
+
* @return {Function} A decorator function that can be applied to a class property
|
21
|
+
* @function column
|
22
|
+
* @category Property Decorators
|
23
|
+
*/
|
8
24
|
export declare function column(columnName: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
9
25
|
/**
|
10
|
-
* @
|
11
|
-
* @
|
12
|
-
*
|
13
|
-
*
|
14
|
-
* @
|
15
|
-
* @param {string[]} [compositions]
|
16
|
-
*
|
26
|
+
* @description Creates an index on a model property for improved query performance
|
27
|
+
* @summary Decorator that marks a property to be indexed in the database, optionally with specific directions and compositions
|
28
|
+
* @param {OrderDirection[]} [directions] - Optional array of sort directions for the index
|
29
|
+
* @param {string[]} [compositions] - Optional array of property names to create a composite index
|
30
|
+
* @return {Function} A decorator function that can be applied to a class property
|
17
31
|
* @function index
|
32
|
+
* @category Property Decorators
|
18
33
|
*/
|
19
34
|
export declare function index(directions?: OrderDirection[], compositions?: string[]): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
20
|
-
export declare function uniqueOnCreateUpdate<M extends Model, R extends Repo<M, C, F>, V extends object, F extends RepositoryFlags, C extends Context<F>>(this: R, context: Context<F>, data: V, key: keyof M, model: M): Promise<void>;
|
21
35
|
/**
|
22
|
-
* @
|
23
|
-
* @
|
24
|
-
*
|
25
|
-
*
|
36
|
+
* @description Enforces uniqueness constraint during model creation and update
|
37
|
+
* @summary Internal function used by the unique decorator to check if a property value already exists in the database
|
38
|
+
* @template M - The model type extending Model
|
39
|
+
* @template R - The repository type extending Repo<M, F, C>
|
40
|
+
* @template V - The metadata type
|
41
|
+
* @template F - The repository flags type
|
42
|
+
* @template C - The context type extending Context<F>
|
43
|
+
* @param {R} this - The repository instance
|
44
|
+
* @param {Context<F>} context - The context for the operation
|
45
|
+
* @param {V} data - The metadata for the property
|
46
|
+
* @param key - The property key to check for uniqueness
|
47
|
+
* @param {M} model - The model instance being created or updated
|
48
|
+
* @return {Promise<void>} A promise that resolves when the check is complete or rejects with a ConflictError
|
49
|
+
* @function uniqueOnCreateUpdate
|
50
|
+
* @memberOf module:core
|
51
|
+
*/
|
52
|
+
export declare function uniqueOnCreateUpdate<M extends Model, R extends Repo<M, F, C>, V extends object, F extends RepositoryFlags, C extends Context<F>>(this: R, context: Context<F>, data: V, key: keyof M, model: M): Promise<void>;
|
53
|
+
/**
|
54
|
+
* @description Tags a property as unique
|
55
|
+
* @summary Decorator that ensures a property value is unique across all instances of a model in the database
|
56
|
+
* @return {Function} A decorator function that can be applied to a class property
|
26
57
|
* @function unique
|
27
|
-
*
|
28
|
-
* @
|
58
|
+
* @category Property Decorators
|
59
|
+
* @example
|
60
|
+
* ```typescript
|
61
|
+
* class User extends BaseModel {
|
62
|
+
* @unique()
|
63
|
+
* @required()
|
64
|
+
* username!: string;
|
65
|
+
* }
|
66
|
+
* ```
|
29
67
|
*/
|
30
68
|
export declare function unique(): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
31
|
-
|
69
|
+
/**
|
70
|
+
* @description Handles user identification for ownership tracking
|
71
|
+
* @summary Internal function used by the createdBy and updatedBy decorators to set ownership information
|
72
|
+
* @template M - The model type extending Model
|
73
|
+
* @template R - The repository type extending Repo<M, F, C>
|
74
|
+
* @template V - The relations metadata type extending RelationsMetadata
|
75
|
+
* @template F - The repository flags type
|
76
|
+
* @template C - The context type extending Context<F>
|
77
|
+
* @param {R} this - The repository instance
|
78
|
+
* @param {Context<F>} context - The context for the operation
|
79
|
+
* @param {V} data - The metadata for the property
|
80
|
+
* @param key - The property key to store the user identifier
|
81
|
+
* @param {M} model - The model instance being created or updated
|
82
|
+
* @return {Promise<void>} A promise that rejects with an AuthorizationError if user identification is not supported
|
83
|
+
* @function createdByOnCreateUpdate
|
84
|
+
* @memberOf module:core
|
85
|
+
*/
|
86
|
+
export declare function createdByOnCreateUpdate<M extends Model, R extends Repo<M, F, C>, V extends RelationsMetadata, F extends RepositoryFlags, C extends Context<F>>(this: R, context: Context<F>, data: V, key: keyof M, model: M): Promise<void>;
|
87
|
+
/**
|
88
|
+
* @description Tracks the creator of a model instance
|
89
|
+
* @summary Decorator that marks a property to store the identifier of the user who created the model instance
|
90
|
+
* @return {Function} A decorator function that can be applied to a class property
|
91
|
+
* @function createdBy
|
92
|
+
* @category Property Decorators
|
93
|
+
* @example
|
94
|
+
* ```typescript
|
95
|
+
* class Document extends BaseModel {
|
96
|
+
* @createdBy()
|
97
|
+
* creator!: string;
|
98
|
+
* }
|
99
|
+
* ```
|
100
|
+
*/
|
32
101
|
export declare function createdBy(): (target: any, propertyKey?: any, descriptor?: TypedPropertyDescriptor<any>) => any;
|
102
|
+
/**
|
103
|
+
* @description Tracks the last updater of a model instance
|
104
|
+
* @summary Decorator that marks a property to store the identifier of the user who last updated the model instance
|
105
|
+
* @return {Function} A decorator function that can be applied to a class property
|
106
|
+
* @function updatedBy
|
107
|
+
* @category Property Decorators
|
108
|
+
* @example
|
109
|
+
* ```typescript
|
110
|
+
* class Document extends BaseModel {
|
111
|
+
* @updatedBy()
|
112
|
+
* lastEditor!: string;
|
113
|
+
* }
|
114
|
+
* ```
|
115
|
+
*/
|
33
116
|
export declare function updatedBy(): (target: any, propertyKey?: any, descriptor?: TypedPropertyDescriptor<any>) => any;
|
34
117
|
/**
|
35
|
-
* @
|
36
|
-
*
|
37
|
-
* @
|
38
|
-
* @param {
|
39
|
-
* @param {
|
40
|
-
*
|
41
|
-
* @function
|
42
|
-
*
|
43
|
-
* @
|
44
|
-
*
|
118
|
+
* @description Defines a one-to-one relationship between models
|
119
|
+
* @summary Decorator that establishes a one-to-one relationship between the current model and another model
|
120
|
+
* @template M - The related model type extending Model
|
121
|
+
* @param {Constructor<M>} clazz - The constructor of the related model class
|
122
|
+
* @param {CascadeMetadata} [cascadeOptions=DefaultCascade] - Options for cascading operations (create, update, delete)
|
123
|
+
* @param {boolean} [populate=true] - If true, automatically populates the relationship when the model is retrieved
|
124
|
+
* @return {Function} A decorator function that can be applied to a class property
|
125
|
+
* @function oneToOne
|
126
|
+
* @category Property Decorators
|
127
|
+
* @example
|
128
|
+
* ```typescript
|
129
|
+
* class User extends BaseModel {
|
130
|
+
* @oneToOne(Profile)
|
131
|
+
* profile!: string | Profile;
|
132
|
+
* }
|
133
|
+
*
|
134
|
+
* class Profile extends BaseModel {
|
135
|
+
* @required()
|
136
|
+
* bio!: string;
|
137
|
+
* }
|
138
|
+
* ```
|
45
139
|
* @see oneToMany
|
46
140
|
* @see manyToOne
|
47
141
|
*/
|
48
142
|
export declare function oneToOne<M extends Model>(clazz: Constructor<M>, cascadeOptions?: CascadeMetadata, populate?: boolean): (target: any, propertyKey?: any, descriptor?: TypedPropertyDescriptor<any>) => any;
|
49
143
|
/**
|
50
|
-
* @
|
51
|
-
*
|
52
|
-
* @
|
53
|
-
* @param {
|
54
|
-
*
|
144
|
+
* @description Defines a one-to-many relationship between models
|
145
|
+
* @summary Decorator that establishes a one-to-many relationship between the current model and multiple instances of another model
|
146
|
+
* @template M - The related model type extending Model
|
147
|
+
* @param {Constructor<M>} clazz - The constructor of the related model class
|
148
|
+
* @param {CascadeMetadata} [cascadeOptions=DefaultCascade] - Options for cascading operations (create, update, delete)
|
149
|
+
* @param {boolean} [populate=true] - If true, automatically populates the relationship when the model is retrieved
|
150
|
+
* @return {Function} A decorator function that can be applied to a class property
|
55
151
|
* @function oneToMany
|
56
|
-
*
|
57
|
-
* @
|
58
|
-
*
|
152
|
+
* @category Property Decorators
|
153
|
+
* @example
|
154
|
+
* ```typescript
|
155
|
+
* class Author extends BaseModel {
|
156
|
+
* @required()
|
157
|
+
* name!: string;
|
158
|
+
*
|
159
|
+
* @oneToMany(Book)
|
160
|
+
* books!: string[] | Book[];
|
161
|
+
* }
|
162
|
+
*
|
163
|
+
* class Book extends BaseModel {
|
164
|
+
* @required()
|
165
|
+
* title!: string;
|
166
|
+
* }
|
167
|
+
* ```
|
59
168
|
* @see oneToOne
|
60
169
|
* @see manyToOne
|
61
170
|
*/
|
62
171
|
export declare function oneToMany<M extends Model>(clazz: Constructor<M>, cascadeOptions?: CascadeMetadata, populate?: boolean): (target: any, propertyKey?: any, descriptor?: TypedPropertyDescriptor<any>) => any;
|
63
172
|
/**
|
64
|
-
* @
|
65
|
-
*
|
66
|
-
* @
|
67
|
-
* @param {
|
68
|
-
*
|
173
|
+
* @description Defines a many-to-one relationship between models
|
174
|
+
* @summary Decorator that establishes a many-to-one relationship between multiple instances of the current model and another model
|
175
|
+
* @template M - The related model type extending Model
|
176
|
+
* @param {Constructor<M>} clazz - The constructor of the related model class
|
177
|
+
* @param {CascadeMetadata} [cascadeOptions=DefaultCascade] - Options for cascading operations (create, update, delete)
|
178
|
+
* @param {boolean} [populate=true] - If true, automatically populates the relationship when the model is retrieved
|
179
|
+
* @return {Function} A decorator function that can be applied to a class property
|
69
180
|
* @function manyToOne
|
70
|
-
*
|
71
|
-
* @
|
72
|
-
*
|
181
|
+
* @category Property Decorators
|
182
|
+
* @example
|
183
|
+
* ```typescript
|
184
|
+
* class Book extends BaseModel {
|
185
|
+
* @required()
|
186
|
+
* title!: string;
|
187
|
+
*
|
188
|
+
* @manyToOne(Author)
|
189
|
+
* author!: string | Author;
|
190
|
+
* }
|
191
|
+
*
|
192
|
+
* class Author extends BaseModel {
|
193
|
+
* @required()
|
194
|
+
* name!: string;
|
195
|
+
* }
|
196
|
+
* ```
|
73
197
|
* @see oneToMany
|
74
198
|
* @see oneToOne
|
75
199
|
*/
|
76
|
-
export declare function manyToOne(clazz: Constructor<
|
200
|
+
export declare function manyToOne<M extends Model>(clazz: Constructor<M>, cascadeOptions?: CascadeMetadata, populate?: boolean): (target: any, propertyKey?: any, descriptor?: TypedPropertyDescriptor<any>) => any;
|
package/lib/model/index.cjs
CHANGED
@@ -17,6 +17,5 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./BaseModel.cjs"), exports);
|
18
18
|
__exportStar(require("./construction.cjs"), exports);
|
19
19
|
__exportStar(require("./decorators.cjs"), exports);
|
20
|
-
// export * from "./IdentifiedBaseModel";
|
21
20
|
__exportStar(require("./types.cjs"), exports);
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbW9kZWwvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLGtEQUE0QjtBQUM1QixxREFBK0I7QUFDL0IsbURBQTZCO0FBQzdCLDhDQUF3QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL0Jhc2VNb2RlbFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vY29uc3RydWN0aW9uXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9kZWNvcmF0b3JzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi90eXBlc1wiO1xuIl19
|
package/lib/model/types.cjs
CHANGED
@@ -1,3 +1,3 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbW9kZWwvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENhc2NhZGVNZXRhZGF0YSB9IGZyb20gXCIuLi9yZXBvc2l0b3J5XCI7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIE1ldGFkYXRhIGZvciBtb2RlbCByZWxhdGlvbnNoaXBzXG4gKiBAc3VtbWFyeSBUeXBlIGRlZmluaXRpb24gZm9yIHN0b3JpbmcgbWV0YWRhdGEgYWJvdXQgcmVsYXRpb25zaGlwcyBiZXR3ZWVuIG1vZGVsc1xuICogQHByb3BlcnR5IHtzdHJpbmd9IGNsYXNzIC0gVGhlIG5hbWUgb2YgdGhlIHJlbGF0ZWQgbW9kZWwgY2xhc3NcbiAqIEBwcm9wZXJ0eSB7Q2FzY2FkZU1ldGFkYXRhfSBjYXNjYWRlIC0gQ29uZmlndXJhdGlvbiBmb3IgY2FzY2FkZSBvcGVyYXRpb25zIChjcmVhdGUsIHVwZGF0ZSwgZGVsZXRlKVxuICogQHByb3BlcnR5IHtib29sZWFufSBwb3B1bGF0ZSAtIFdoZXRoZXIgdG8gYXV0b21hdGljYWxseSBwb3B1bGF0ZSB0aGUgcmVsYXRpb25zaGlwIHdoZW4gcmV0cmlldmluZyB0aGUgbW9kZWxcbiAqIEB0eXBlZGVmIHtPYmplY3R9IFJlbGF0aW9uc01ldGFkYXRhXG4gKiBAbWVtYmVyT2YgbW9kdWxlOm1vZGVsXG4gKi9cbmV4cG9ydCB0eXBlIFJlbGF0aW9uc01ldGFkYXRhID0ge1xuICBjbGFzczogc3RyaW5nO1xuICBjYXNjYWRlOiBDYXNjYWRlTWV0YWRhdGE7XG4gIHBvcHVsYXRlOiBib29sZWFuO1xufTtcbiJdfQ==
|
package/lib/model/types.d.ts
CHANGED
@@ -1,4 +1,13 @@
|
|
1
1
|
import { CascadeMetadata } from "../repository";
|
2
|
+
/**
|
3
|
+
* @description Metadata for model relationships
|
4
|
+
* @summary Type definition for storing metadata about relationships between models
|
5
|
+
* @property {string} class - The name of the related model class
|
6
|
+
* @property {CascadeMetadata} cascade - Configuration for cascade operations (create, update, delete)
|
7
|
+
* @property {boolean} populate - Whether to automatically populate the relationship when retrieving the model
|
8
|
+
* @typedef {Object} RelationsMetadata
|
9
|
+
* @memberOf module:model
|
10
|
+
*/
|
2
11
|
export type RelationsMetadata = {
|
3
12
|
class: string;
|
4
13
|
cascade: CascadeMetadata;
|