@decaf-ts/core 0.5.1 → 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 +2110 -132
- package/dist/core.esm.cjs +2111 -133
- package/lib/esm/identity/decorators.d.ts +52 -7
- package/lib/esm/identity/decorators.js +53 -8
- package/lib/esm/identity/utils.d.ts +19 -0
- package/lib/esm/identity/utils.js +20 -1
- package/lib/esm/index.d.ts +9 -2
- package/lib/esm/index.js +10 -3
- package/lib/esm/interfaces/ErrorParser.d.ts +12 -0
- package/lib/esm/interfaces/ErrorParser.js +1 -1
- package/lib/esm/interfaces/Executor.d.ts +13 -0
- package/lib/esm/interfaces/Executor.js +1 -1
- package/lib/esm/interfaces/Observable.d.ts +27 -0
- package/lib/esm/interfaces/Observable.js +1 -1
- package/lib/esm/interfaces/Observer.d.ts +12 -0
- package/lib/esm/interfaces/Observer.js +1 -1
- package/lib/esm/interfaces/Paginatable.d.ts +15 -0
- package/lib/esm/interfaces/Paginatable.js +1 -1
- package/lib/esm/interfaces/Queriable.d.ts +34 -9
- package/lib/esm/interfaces/Queriable.js +1 -1
- package/lib/esm/interfaces/RawExecutor.d.ts +14 -0
- package/lib/esm/interfaces/RawExecutor.js +1 -1
- package/lib/esm/interfaces/SequenceOptions.d.ts +52 -0
- package/lib/esm/interfaces/SequenceOptions.js +19 -1
- package/lib/esm/model/BaseModel.d.ts +31 -0
- package/lib/esm/model/BaseModel.js +24 -1
- package/lib/esm/model/construction.d.ts +433 -0
- package/lib/esm/model/construction.js +441 -2
- package/lib/esm/model/decorators.d.ts +159 -29
- package/lib/esm/model/decorators.js +160 -30
- package/lib/esm/model/types.d.ts +9 -0
- package/lib/esm/model/types.js +1 -1
- package/lib/esm/persistence/Adapter.d.ts +358 -17
- package/lib/esm/persistence/Adapter.js +287 -19
- package/lib/esm/persistence/Dispatch.d.ts +114 -1
- package/lib/esm/persistence/Dispatch.js +102 -4
- package/lib/esm/persistence/ObserverHandler.d.ts +95 -0
- package/lib/esm/persistence/ObserverHandler.js +96 -1
- package/lib/esm/persistence/Sequence.d.ts +89 -0
- package/lib/esm/persistence/Sequence.js +70 -1
- package/lib/esm/persistence/constants.d.ts +22 -0
- package/lib/esm/persistence/constants.js +23 -1
- 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 -0
- package/lib/esm/persistence/errors.js +24 -1
- package/lib/esm/persistence/types.d.ts +18 -0
- package/lib/esm/persistence/types.js +1 -1
- package/lib/esm/query/Condition.d.ts +78 -31
- package/lib/esm/query/Condition.js +132 -53
- package/lib/esm/query/Paginator.d.ts +56 -0
- package/lib/esm/query/Paginator.js +57 -1
- package/lib/esm/query/Statement.d.ts +51 -0
- package/lib/esm/query/Statement.js +52 -1
- package/lib/esm/query/constants.d.ts +25 -0
- package/lib/esm/query/constants.js +26 -1
- package/lib/esm/query/errors.d.ts +14 -0
- package/lib/esm/query/errors.js +15 -1
- package/lib/esm/query/options.d.ts +21 -3
- package/lib/esm/query/options.js +1 -1
- package/lib/esm/query/selectors.d.ts +26 -0
- package/lib/esm/query/selectors.js +1 -1
- package/lib/esm/ram/RamAdapter.d.ts +311 -0
- package/lib/esm/ram/RamAdapter.js +312 -1
- package/lib/esm/ram/RamContext.d.ts +16 -1
- package/lib/esm/ram/RamContext.js +18 -3
- package/lib/esm/ram/RamPaginator.d.ts +43 -0
- package/lib/esm/ram/RamPaginator.js +54 -2
- package/lib/esm/ram/RamSequence.d.ts +61 -0
- package/lib/esm/ram/RamSequence.js +63 -2
- package/lib/esm/ram/RamStatement.d.ts +74 -0
- package/lib/esm/ram/RamStatement.js +75 -1
- package/lib/esm/ram/constants.d.ts +8 -0
- package/lib/esm/ram/constants.js +9 -1
- package/lib/esm/ram/handlers.d.ts +19 -0
- package/lib/esm/ram/handlers.js +20 -1
- package/lib/esm/ram/model/RamSequence.d.ts +25 -0
- package/lib/esm/ram/model/RamSequence.js +19 -1
- package/lib/esm/ram/types.d.ts +42 -0
- package/lib/esm/ram/types.js +1 -1
- package/lib/esm/repository/Repository.d.ts +363 -8
- package/lib/esm/repository/Repository.js +361 -16
- package/lib/esm/repository/constants.d.ts +25 -0
- package/lib/esm/repository/constants.js +26 -1
- 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 -5
- package/lib/esm/repository/errors.js +13 -6
- package/lib/esm/repository/injectables.d.ts +18 -0
- package/lib/esm/repository/injectables.js +19 -1
- package/lib/esm/repository/types.d.ts +15 -0
- 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 +8 -0
- package/lib/esm/utils/decorators.js +9 -1
- package/lib/esm/utils/errors.d.ts +46 -0
- package/lib/esm/utils/errors.js +47 -1
- package/lib/identity/decorators.cjs +53 -8
- package/lib/identity/decorators.d.ts +52 -7
- package/lib/identity/utils.cjs +20 -1
- package/lib/identity/utils.d.ts +19 -0
- package/lib/index.cjs +10 -3
- package/lib/index.d.ts +9 -2
- 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 +13 -0
- package/lib/interfaces/Observable.cjs +1 -1
- package/lib/interfaces/Observable.d.ts +27 -0
- package/lib/interfaces/Observer.cjs +1 -1
- package/lib/interfaces/Observer.d.ts +12 -0
- package/lib/interfaces/Paginatable.cjs +1 -1
- package/lib/interfaces/Paginatable.d.ts +15 -0
- package/lib/interfaces/Queriable.cjs +1 -1
- package/lib/interfaces/Queriable.d.ts +34 -9
- package/lib/interfaces/RawExecutor.cjs +1 -1
- package/lib/interfaces/RawExecutor.d.ts +14 -0
- package/lib/interfaces/SequenceOptions.cjs +19 -1
- package/lib/interfaces/SequenceOptions.d.ts +52 -0
- 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 +433 -0
- package/lib/model/decorators.cjs +160 -30
- package/lib/model/decorators.d.ts +159 -29
- package/lib/model/types.cjs +1 -1
- package/lib/model/types.d.ts +9 -0
- package/lib/persistence/Adapter.cjs +287 -19
- package/lib/persistence/Adapter.d.ts +358 -17
- package/lib/persistence/Dispatch.cjs +102 -4
- package/lib/persistence/Dispatch.d.ts +114 -1
- package/lib/persistence/ObserverHandler.cjs +96 -1
- package/lib/persistence/ObserverHandler.d.ts +95 -0
- package/lib/persistence/Sequence.cjs +70 -1
- package/lib/persistence/Sequence.d.ts +89 -0
- package/lib/persistence/constants.cjs +23 -1
- package/lib/persistence/constants.d.ts +22 -0
- package/lib/persistence/decorators.cjs +11 -1
- package/lib/persistence/decorators.d.ts +10 -0
- package/lib/persistence/errors.cjs +24 -1
- package/lib/persistence/errors.d.ts +23 -0
- package/lib/persistence/types.cjs +1 -1
- package/lib/persistence/types.d.ts +18 -0
- package/lib/query/Condition.cjs +132 -53
- package/lib/query/Condition.d.ts +78 -31
- package/lib/query/Paginator.cjs +57 -1
- package/lib/query/Paginator.d.ts +56 -0
- package/lib/query/Statement.cjs +52 -1
- package/lib/query/Statement.d.ts +51 -0
- package/lib/query/constants.cjs +26 -1
- package/lib/query/constants.d.ts +25 -0
- package/lib/query/errors.cjs +15 -1
- package/lib/query/errors.d.ts +14 -0
- package/lib/query/options.cjs +1 -1
- package/lib/query/options.d.ts +21 -3
- package/lib/query/selectors.cjs +1 -1
- package/lib/query/selectors.d.ts +26 -0
- package/lib/ram/RamAdapter.cjs +312 -1
- package/lib/ram/RamAdapter.d.ts +311 -0
- package/lib/ram/RamContext.cjs +18 -3
- package/lib/ram/RamContext.d.ts +16 -1
- package/lib/ram/RamPaginator.cjs +54 -2
- package/lib/ram/RamPaginator.d.ts +43 -0
- package/lib/ram/RamSequence.cjs +63 -2
- package/lib/ram/RamSequence.d.ts +61 -0
- package/lib/ram/RamStatement.cjs +75 -1
- package/lib/ram/RamStatement.d.ts +74 -0
- package/lib/ram/constants.cjs +9 -1
- package/lib/ram/constants.d.ts +8 -0
- package/lib/ram/handlers.cjs +20 -1
- package/lib/ram/handlers.d.ts +19 -0
- package/lib/ram/model/RamSequence.cjs +19 -1
- package/lib/ram/model/RamSequence.d.ts +25 -0
- package/lib/ram/types.cjs +1 -1
- package/lib/ram/types.d.ts +42 -0
- package/lib/repository/Repository.cjs +360 -15
- package/lib/repository/Repository.d.ts +363 -8
- package/lib/repository/constants.cjs +26 -1
- package/lib/repository/constants.d.ts +25 -0
- package/lib/repository/decorators.cjs +28 -1
- package/lib/repository/decorators.d.ts +27 -0
- package/lib/repository/errors.cjs +13 -6
- package/lib/repository/errors.d.ts +12 -5
- 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 +15 -0
- package/lib/repository/utils.cjs +12 -1
- package/lib/repository/utils.d.ts +11 -0
- package/lib/utils/decorators.cjs +9 -1
- package/lib/utils/decorators.d.ts +8 -0
- package/lib/utils/errors.cjs +47 -1
- package/lib/utils/errors.d.ts +46 -0
- package/package.json +5 -5
@@ -4,66 +4,196 @@ 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;
|
35
|
+
/**
|
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
|
+
*/
|
20
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>;
|
21
53
|
/**
|
22
|
-
* @
|
23
|
-
* @
|
24
|
-
*
|
25
|
-
*
|
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
|
-
*
|
58
|
+
* @category Property Decorators
|
59
|
+
* @example
|
60
|
+
* ```typescript
|
61
|
+
* class User extends BaseModel {
|
62
|
+
* @unique()
|
63
|
+
* @required()
|
64
|
+
* username!: string;
|
65
|
+
* }
|
66
|
+
* ```
|
28
67
|
*/
|
29
68
|
export declare function unique(): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
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
|
+
*/
|
30
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
|
+
*/
|
31
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
|
+
*/
|
32
116
|
export declare function updatedBy(): (target: any, propertyKey?: any, descriptor?: TypedPropertyDescriptor<any>) => any;
|
33
117
|
/**
|
34
|
-
* @
|
35
|
-
*
|
36
|
-
* @
|
37
|
-
* @param {
|
38
|
-
* @param {
|
39
|
-
*
|
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
|
40
125
|
* @function oneToOne
|
126
|
+
* @category Property Decorators
|
127
|
+
* @example
|
128
|
+
* ```typescript
|
129
|
+
* class User extends BaseModel {
|
130
|
+
* @oneToOne(Profile)
|
131
|
+
* profile!: string | Profile;
|
132
|
+
* }
|
41
133
|
*
|
42
|
-
*
|
134
|
+
* class Profile extends BaseModel {
|
135
|
+
* @required()
|
136
|
+
* bio!: string;
|
137
|
+
* }
|
138
|
+
* ```
|
43
139
|
* @see oneToMany
|
44
140
|
* @see manyToOne
|
45
141
|
*/
|
46
142
|
export declare function oneToOne<M extends Model>(clazz: Constructor<M>, cascadeOptions?: CascadeMetadata, populate?: boolean): (target: any, propertyKey?: any, descriptor?: TypedPropertyDescriptor<any>) => any;
|
47
143
|
/**
|
48
|
-
* @
|
49
|
-
*
|
50
|
-
* @
|
51
|
-
* @param {
|
52
|
-
*
|
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
|
53
151
|
* @function oneToMany
|
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
|
+
* }
|
54
162
|
*
|
163
|
+
* class Book extends BaseModel {
|
164
|
+
* @required()
|
165
|
+
* title!: string;
|
166
|
+
* }
|
167
|
+
* ```
|
55
168
|
* @see oneToOne
|
56
169
|
* @see manyToOne
|
57
170
|
*/
|
58
171
|
export declare function oneToMany<M extends Model>(clazz: Constructor<M>, cascadeOptions?: CascadeMetadata, populate?: boolean): (target: any, propertyKey?: any, descriptor?: TypedPropertyDescriptor<any>) => any;
|
59
172
|
/**
|
60
|
-
* @
|
61
|
-
*
|
62
|
-
* @
|
63
|
-
* @param {
|
64
|
-
*
|
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
|
65
180
|
* @function manyToOne
|
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
|
+
* }
|
66
191
|
*
|
192
|
+
* class Author extends BaseModel {
|
193
|
+
* @required()
|
194
|
+
* name!: string;
|
195
|
+
* }
|
196
|
+
* ```
|
67
197
|
* @see oneToMany
|
68
198
|
* @see oneToOne
|
69
199
|
*/
|
@@ -8,21 +8,36 @@ import { Repository } from "../repository/Repository";
|
|
8
8
|
import { Condition } from "../query/Condition";
|
9
9
|
import { oneToManyOnCreate, oneToManyOnDelete, oneToManyOnUpdate, oneToOneOnCreate, oneToOneOnDelete, oneToOneOnUpdate, populate as pop, } from "./construction";
|
10
10
|
import { AuthorizationError } from "../utils";
|
11
|
+
/**
|
12
|
+
* @description Specifies the database table name for a model
|
13
|
+
* @summary Decorator that sets the table name for a model class in the database
|
14
|
+
* @param {string} tableName - The name of the table in the database
|
15
|
+
* @return {Function} A decorator function that can be applied to a class
|
16
|
+
* @function table
|
17
|
+
* @category Class Decorators
|
18
|
+
*/
|
11
19
|
export function table(tableName) {
|
12
20
|
return metadata(Adapter.key(PersistenceKeys.TABLE), tableName);
|
13
21
|
}
|
22
|
+
/**
|
23
|
+
* @description Specifies the database column name for a model property
|
24
|
+
* @summary Decorator that maps a model property to a specific column name in the database
|
25
|
+
* @param {string} columnName - The name of the column in the database
|
26
|
+
* @return {Function} A decorator function that can be applied to a class property
|
27
|
+
* @function column
|
28
|
+
* @category Property Decorators
|
29
|
+
*/
|
14
30
|
export function column(columnName) {
|
15
31
|
return propMetadata(Adapter.key(PersistenceKeys.COLUMN), columnName);
|
16
32
|
}
|
17
33
|
/**
|
18
|
-
* @
|
19
|
-
* @
|
20
|
-
*
|
21
|
-
*
|
22
|
-
* @
|
23
|
-
* @param {string[]} [compositions]
|
24
|
-
*
|
34
|
+
* @description Creates an index on a model property for improved query performance
|
35
|
+
* @summary Decorator that marks a property to be indexed in the database, optionally with specific directions and compositions
|
36
|
+
* @param {OrderDirection[]} [directions] - Optional array of sort directions for the index
|
37
|
+
* @param {string[]} [compositions] - Optional array of property names to create a composite index
|
38
|
+
* @return {Function} A decorator function that can be applied to a class property
|
25
39
|
* @function index
|
40
|
+
* @category Property Decorators
|
26
41
|
*/
|
27
42
|
export function index(directions, compositions) {
|
28
43
|
return propMetadata(Repository.key(`${PersistenceKeys.INDEX}${compositions && compositions.length ? `.${compositions.join(".")}` : ""}`), {
|
@@ -30,6 +45,23 @@ export function index(directions, compositions) {
|
|
30
45
|
compositions: compositions,
|
31
46
|
});
|
32
47
|
}
|
48
|
+
/**
|
49
|
+
* @description Enforces uniqueness constraint during model creation and update
|
50
|
+
* @summary Internal function used by the unique decorator to check if a property value already exists in the database
|
51
|
+
* @template M - The model type extending Model
|
52
|
+
* @template R - The repository type extending Repo<M, F, C>
|
53
|
+
* @template V - The metadata type
|
54
|
+
* @template F - The repository flags type
|
55
|
+
* @template C - The context type extending Context<F>
|
56
|
+
* @param {R} this - The repository instance
|
57
|
+
* @param {Context<F>} context - The context for the operation
|
58
|
+
* @param {V} data - The metadata for the property
|
59
|
+
* @param key - The property key to check for uniqueness
|
60
|
+
* @param {M} model - The model instance being created or updated
|
61
|
+
* @return {Promise<void>} A promise that resolves when the check is complete or rejects with a ConflictError
|
62
|
+
* @function uniqueOnCreateUpdate
|
63
|
+
* @memberOf module:core
|
64
|
+
*/
|
33
65
|
export async function uniqueOnCreateUpdate(context, data, key, model) {
|
34
66
|
if (!model[key])
|
35
67
|
return;
|
@@ -40,16 +72,40 @@ export async function uniqueOnCreateUpdate(context, data, key, model) {
|
|
40
72
|
throw new ConflictError(`model already exists with property ${key} equal to ${JSON.stringify(model[key], undefined, 2)}`);
|
41
73
|
}
|
42
74
|
/**
|
43
|
-
* @
|
44
|
-
* @
|
45
|
-
*
|
46
|
-
*
|
75
|
+
* @description Tags a property as unique
|
76
|
+
* @summary Decorator that ensures a property value is unique across all instances of a model in the database
|
77
|
+
* @return {Function} A decorator function that can be applied to a class property
|
47
78
|
* @function unique
|
48
|
-
*
|
79
|
+
* @category Property Decorators
|
80
|
+
* @example
|
81
|
+
* ```typescript
|
82
|
+
* class User extends BaseModel {
|
83
|
+
* @unique()
|
84
|
+
* @required()
|
85
|
+
* username!: string;
|
86
|
+
* }
|
87
|
+
* ```
|
49
88
|
*/
|
50
89
|
export function unique() {
|
51
90
|
return apply(onCreateUpdate(uniqueOnCreateUpdate), propMetadata(Repository.key(PersistenceKeys.UNIQUE), {}));
|
52
91
|
}
|
92
|
+
/**
|
93
|
+
* @description Handles user identification for ownership tracking
|
94
|
+
* @summary Internal function used by the createdBy and updatedBy decorators to set ownership information
|
95
|
+
* @template M - The model type extending Model
|
96
|
+
* @template R - The repository type extending Repo<M, F, C>
|
97
|
+
* @template V - The relations metadata type extending RelationsMetadata
|
98
|
+
* @template F - The repository flags type
|
99
|
+
* @template C - The context type extending Context<F>
|
100
|
+
* @param {R} this - The repository instance
|
101
|
+
* @param {Context<F>} context - The context for the operation
|
102
|
+
* @param {V} data - The metadata for the property
|
103
|
+
* @param key - The property key to store the user identifier
|
104
|
+
* @param {M} model - The model instance being created or updated
|
105
|
+
* @return {Promise<void>} A promise that rejects with an AuthorizationError if user identification is not supported
|
106
|
+
* @function createdByOnCreateUpdate
|
107
|
+
* @memberOf module:core
|
108
|
+
*/
|
53
109
|
export async function createdByOnCreateUpdate(
|
54
110
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
55
111
|
context,
|
@@ -61,12 +117,40 @@ key,
|
|
61
117
|
model) {
|
62
118
|
throw new AuthorizationError("This adapter does not support user identification");
|
63
119
|
}
|
120
|
+
/**
|
121
|
+
* @description Tracks the creator of a model instance
|
122
|
+
* @summary Decorator that marks a property to store the identifier of the user who created the model instance
|
123
|
+
* @return {Function} A decorator function that can be applied to a class property
|
124
|
+
* @function createdBy
|
125
|
+
* @category Property Decorators
|
126
|
+
* @example
|
127
|
+
* ```typescript
|
128
|
+
* class Document extends BaseModel {
|
129
|
+
* @createdBy()
|
130
|
+
* creator!: string;
|
131
|
+
* }
|
132
|
+
* ```
|
133
|
+
*/
|
64
134
|
export function createdBy() {
|
65
135
|
const key = Repository.key(PersistenceKeys.CREATED_BY);
|
66
136
|
return Decoration.for(key)
|
67
137
|
.define(onCreate(createdByOnCreateUpdate), propMetadata(key, {}))
|
68
138
|
.apply();
|
69
139
|
}
|
140
|
+
/**
|
141
|
+
* @description Tracks the last updater of a model instance
|
142
|
+
* @summary Decorator that marks a property to store the identifier of the user who last updated the model instance
|
143
|
+
* @return {Function} A decorator function that can be applied to a class property
|
144
|
+
* @function updatedBy
|
145
|
+
* @category Property Decorators
|
146
|
+
* @example
|
147
|
+
* ```typescript
|
148
|
+
* class Document extends BaseModel {
|
149
|
+
* @updatedBy()
|
150
|
+
* lastEditor!: string;
|
151
|
+
* }
|
152
|
+
* ```
|
153
|
+
*/
|
70
154
|
export function updatedBy() {
|
71
155
|
const key = Repository.key(PersistenceKeys.UPDATED_BY);
|
72
156
|
return Decoration.for(key)
|
@@ -74,15 +158,27 @@ export function updatedBy() {
|
|
74
158
|
.apply();
|
75
159
|
}
|
76
160
|
/**
|
77
|
-
* @
|
78
|
-
*
|
79
|
-
* @
|
80
|
-
* @param {
|
81
|
-
* @param {
|
82
|
-
*
|
161
|
+
* @description Defines a one-to-one relationship between models
|
162
|
+
* @summary Decorator that establishes a one-to-one relationship between the current model and another model
|
163
|
+
* @template M - The related model type extending Model
|
164
|
+
* @param {Constructor<M>} clazz - The constructor of the related model class
|
165
|
+
* @param {CascadeMetadata} [cascadeOptions=DefaultCascade] - Options for cascading operations (create, update, delete)
|
166
|
+
* @param {boolean} [populate=true] - If true, automatically populates the relationship when the model is retrieved
|
167
|
+
* @return {Function} A decorator function that can be applied to a class property
|
83
168
|
* @function oneToOne
|
169
|
+
* @category Property Decorators
|
170
|
+
* @example
|
171
|
+
* ```typescript
|
172
|
+
* class User extends BaseModel {
|
173
|
+
* @oneToOne(Profile)
|
174
|
+
* profile!: string | Profile;
|
175
|
+
* }
|
84
176
|
*
|
85
|
-
*
|
177
|
+
* class Profile extends BaseModel {
|
178
|
+
* @required()
|
179
|
+
* bio!: string;
|
180
|
+
* }
|
181
|
+
* ```
|
86
182
|
* @see oneToMany
|
87
183
|
* @see manyToOne
|
88
184
|
*/
|
@@ -99,13 +195,30 @@ export function oneToOne(clazz, cascadeOptions = DefaultCascade, populate = true
|
|
99
195
|
.apply();
|
100
196
|
}
|
101
197
|
/**
|
102
|
-
* @
|
103
|
-
*
|
104
|
-
* @
|
105
|
-
* @param {
|
106
|
-
*
|
198
|
+
* @description Defines a one-to-many relationship between models
|
199
|
+
* @summary Decorator that establishes a one-to-many relationship between the current model and multiple instances of another model
|
200
|
+
* @template M - The related model type extending Model
|
201
|
+
* @param {Constructor<M>} clazz - The constructor of the related model class
|
202
|
+
* @param {CascadeMetadata} [cascadeOptions=DefaultCascade] - Options for cascading operations (create, update, delete)
|
203
|
+
* @param {boolean} [populate=true] - If true, automatically populates the relationship when the model is retrieved
|
204
|
+
* @return {Function} A decorator function that can be applied to a class property
|
107
205
|
* @function oneToMany
|
206
|
+
* @category Property Decorators
|
207
|
+
* @example
|
208
|
+
* ```typescript
|
209
|
+
* class Author extends BaseModel {
|
210
|
+
* @required()
|
211
|
+
* name!: string;
|
212
|
+
*
|
213
|
+
* @oneToMany(Book)
|
214
|
+
* books!: string[] | Book[];
|
215
|
+
* }
|
108
216
|
*
|
217
|
+
* class Book extends BaseModel {
|
218
|
+
* @required()
|
219
|
+
* title!: string;
|
220
|
+
* }
|
221
|
+
* ```
|
109
222
|
* @see oneToOne
|
110
223
|
* @see manyToOne
|
111
224
|
*/
|
@@ -124,13 +237,30 @@ export function oneToMany(clazz, cascadeOptions = DefaultCascade, populate = tru
|
|
124
237
|
.apply();
|
125
238
|
}
|
126
239
|
/**
|
127
|
-
* @
|
128
|
-
*
|
129
|
-
* @
|
130
|
-
* @param {
|
131
|
-
*
|
240
|
+
* @description Defines a many-to-one relationship between models
|
241
|
+
* @summary Decorator that establishes a many-to-one relationship between multiple instances of the current model and another model
|
242
|
+
* @template M - The related model type extending Model
|
243
|
+
* @param {Constructor<M>} clazz - The constructor of the related model class
|
244
|
+
* @param {CascadeMetadata} [cascadeOptions=DefaultCascade] - Options for cascading operations (create, update, delete)
|
245
|
+
* @param {boolean} [populate=true] - If true, automatically populates the relationship when the model is retrieved
|
246
|
+
* @return {Function} A decorator function that can be applied to a class property
|
132
247
|
* @function manyToOne
|
248
|
+
* @category Property Decorators
|
249
|
+
* @example
|
250
|
+
* ```typescript
|
251
|
+
* class Book extends BaseModel {
|
252
|
+
* @required()
|
253
|
+
* title!: string;
|
254
|
+
*
|
255
|
+
* @manyToOne(Author)
|
256
|
+
* author!: string | Author;
|
257
|
+
* }
|
133
258
|
*
|
259
|
+
* class Author extends BaseModel {
|
260
|
+
* @required()
|
261
|
+
* name!: string;
|
262
|
+
* }
|
263
|
+
* ```
|
134
264
|
* @see oneToMany
|
135
265
|
* @see oneToOne
|
136
266
|
*/
|
@@ -151,4 +281,4 @@ export function manyToOne(clazz, cascadeOptions = DefaultCascade, populate = tru
|
|
151
281
|
propMetadata(key, metadata))
|
152
282
|
.apply();
|
153
283
|
}
|
154
|
-
//# 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\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, 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 * @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 */\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, 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\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}\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 oneToOne\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 * @summary One To Many relation Decorators\n *\n * @param {Constructor<any>} clazz the {@link Sequence} to use.\n * @param {CascadeMetadata} [cascadeOptions]\n *\n * @function oneToMany\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 * @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"]}
|
284
|
+
//# 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"]}
|
package/lib/esm/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;
|
package/lib/esm/model/types.js
CHANGED
@@ -1,2 +1,2 @@
|
|
1
1
|
export {};
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbW9kZWwvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENhc2NhZGVNZXRhZGF0YSB9IGZyb20gXCIuLi9yZXBvc2l0b3J5XCI7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIE1ldGFkYXRhIGZvciBtb2RlbCByZWxhdGlvbnNoaXBzXG4gKiBAc3VtbWFyeSBUeXBlIGRlZmluaXRpb24gZm9yIHN0b3JpbmcgbWV0YWRhdGEgYWJvdXQgcmVsYXRpb25zaGlwcyBiZXR3ZWVuIG1vZGVsc1xuICogQHByb3BlcnR5IHtzdHJpbmd9IGNsYXNzIC0gVGhlIG5hbWUgb2YgdGhlIHJlbGF0ZWQgbW9kZWwgY2xhc3NcbiAqIEBwcm9wZXJ0eSB7Q2FzY2FkZU1ldGFkYXRhfSBjYXNjYWRlIC0gQ29uZmlndXJhdGlvbiBmb3IgY2FzY2FkZSBvcGVyYXRpb25zIChjcmVhdGUsIHVwZGF0ZSwgZGVsZXRlKVxuICogQHByb3BlcnR5IHtib29sZWFufSBwb3B1bGF0ZSAtIFdoZXRoZXIgdG8gYXV0b21hdGljYWxseSBwb3B1bGF0ZSB0aGUgcmVsYXRpb25zaGlwIHdoZW4gcmV0cmlldmluZyB0aGUgbW9kZWxcbiAqIEB0eXBlZGVmIHtPYmplY3R9IFJlbGF0aW9uc01ldGFkYXRhXG4gKiBAbWVtYmVyT2YgbW9kdWxlOm1vZGVsXG4gKi9cbmV4cG9ydCB0eXBlIFJlbGF0aW9uc01ldGFkYXRhID0ge1xuICBjbGFzczogc3RyaW5nO1xuICBjYXNjYWRlOiBDYXNjYWRlTWV0YWRhdGE7XG4gIHBvcHVsYXRlOiBib29sZWFuO1xufTtcbiJdfQ==
|