@decaf-ts/core 0.2.1 → 0.3.1
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/dist/core.bundle.min.js +1 -1
- package/dist/esm/core.bundle.min.esm.js +1 -1
- package/lib/esm/identity/decorators.d.ts +2 -1
- package/lib/esm/identity/decorators.js +4 -3
- package/lib/esm/identity/index.d.ts +1 -0
- package/lib/esm/identity/index.js +2 -1
- package/lib/esm/identity/utils.d.ts +3 -2
- package/lib/esm/identity/utils.js +15 -3
- package/lib/esm/index.d.ts +1 -1
- package/lib/esm/index.js +2 -2
- package/lib/esm/interfaces/Paginatable.d.ts +4 -0
- package/lib/esm/interfaces/Paginatable.js +3 -0
- package/lib/esm/interfaces/index.d.ts +0 -1
- package/lib/esm/interfaces/index.js +1 -2
- package/lib/esm/model/BaseModel.d.ts +4 -2
- package/lib/esm/model/BaseModel.js +10 -3
- package/lib/esm/model/User.d.ts +8 -0
- package/lib/esm/model/User.js +35 -0
- package/lib/esm/model/construction.d.ts +15 -0
- package/lib/esm/model/construction.js +205 -0
- package/lib/esm/model/decorators.d.ts +51 -3
- package/lib/esm/model/decorators.js +91 -5
- package/lib/esm/model/index.d.ts +2 -0
- package/lib/esm/model/index.js +3 -1
- package/lib/esm/model/types.d.ts +6 -0
- package/lib/esm/model/types.js +3 -0
- package/lib/esm/persistence/Adapter.d.ts +8 -4
- package/lib/esm/persistence/Adapter.js +13 -11
- package/lib/esm/persistence/Sequence.d.ts +22 -0
- package/lib/esm/persistence/Sequence.js +11 -0
- package/lib/esm/persistence/constants.d.ts +13 -1
- package/lib/esm/persistence/constants.js +16 -1
- package/lib/esm/persistence/index.d.ts +1 -0
- package/lib/esm/persistence/index.js +2 -1
- package/lib/esm/query/Clause.d.ts +8 -1
- package/lib/esm/query/Clause.js +8 -1
- package/lib/esm/query/Paginator.d.ts +22 -0
- package/lib/esm/query/Paginator.js +39 -0
- package/lib/esm/query/Query.d.ts +1 -1
- package/lib/esm/query/Query.js +1 -1
- package/lib/esm/query/Statement.d.ts +6 -0
- package/lib/esm/query/Statement.js +7 -2
- package/lib/esm/query/errors.d.ts +3 -0
- package/lib/esm/query/errors.js +6 -1
- package/lib/esm/query/index.d.ts +1 -0
- package/lib/esm/query/index.js +2 -1
- package/lib/esm/query/options.d.ts +4 -3
- package/lib/esm/query/options.js +1 -1
- package/lib/esm/repository/Repository.d.ts +10 -6
- package/lib/esm/repository/Repository.js +85 -62
- package/lib/esm/repository/decorators.js +2 -2
- package/lib/esm/repository/injectables.js +3 -1
- package/lib/identity/decorators.cjs +4 -3
- package/lib/identity/decorators.d.ts +2 -1
- package/lib/identity/index.cjs +2 -1
- package/lib/identity/index.d.ts +1 -0
- package/lib/identity/utils.cjs +16 -3
- package/lib/identity/utils.d.ts +3 -2
- package/lib/index.cjs +2 -2
- package/lib/index.d.ts +1 -1
- package/lib/interfaces/Paginatable.cjs +4 -0
- package/lib/interfaces/Paginatable.d.ts +4 -0
- package/lib/interfaces/index.cjs +1 -2
- package/lib/interfaces/index.d.ts +0 -1
- package/lib/model/BaseModel.cjs +10 -3
- package/lib/model/BaseModel.d.ts +4 -2
- package/lib/model/User.cjs +38 -0
- package/lib/model/User.d.ts +8 -0
- package/lib/model/construction.cjs +218 -0
- package/lib/model/construction.d.ts +15 -0
- package/lib/model/decorators.cjs +95 -3
- package/lib/model/decorators.d.ts +51 -3
- package/lib/model/index.cjs +3 -1
- package/lib/model/index.d.ts +2 -0
- package/lib/model/types.cjs +4 -0
- package/lib/model/types.d.ts +6 -0
- package/lib/persistence/Adapter.cjs +12 -10
- package/lib/persistence/Adapter.d.ts +8 -4
- package/lib/persistence/Sequence.cjs +15 -0
- package/lib/persistence/Sequence.d.ts +22 -0
- package/lib/persistence/constants.cjs +17 -2
- package/lib/persistence/constants.d.ts +13 -1
- package/lib/persistence/index.cjs +2 -1
- package/lib/persistence/index.d.ts +1 -0
- package/lib/query/Clause.cjs +8 -1
- package/lib/query/Clause.d.ts +8 -1
- package/lib/query/Paginator.cjs +43 -0
- package/lib/query/Paginator.d.ts +22 -0
- package/lib/query/Query.cjs +1 -1
- package/lib/query/Query.d.ts +1 -1
- package/lib/query/Statement.cjs +7 -2
- package/lib/query/Statement.d.ts +6 -0
- package/lib/query/errors.cjs +8 -2
- package/lib/query/errors.d.ts +3 -0
- package/lib/query/index.cjs +2 -1
- package/lib/query/index.d.ts +1 -0
- package/lib/query/options.cjs +1 -1
- package/lib/query/options.d.ts +4 -3
- package/lib/repository/Repository.cjs +85 -62
- package/lib/repository/Repository.d.ts +10 -6
- package/lib/repository/decorators.cjs +2 -2
- package/lib/repository/injectables.cjs +3 -1
- package/package.json +1 -1
- package/lib/esm/interfaces/Sequence.d.ts +0 -17
- package/lib/esm/interfaces/Sequence.js +0 -10
- package/lib/interfaces/Sequence.cjs +0 -11
- package/lib/interfaces/Sequence.d.ts +0 -17
@@ -1,6 +1,7 @@
|
|
1
1
|
import { Model } from "@decaf-ts/decorator-validation";
|
2
2
|
import { SequenceOptions } from "../interfaces/SequenceOptions";
|
3
3
|
import { Repository } from "../repository/Repository";
|
4
|
+
import { Context } from "@decaf-ts/db-decorators/lib/repository/Context";
|
4
5
|
/**
|
5
6
|
* @summary Primary Key Decorator
|
6
7
|
* @description Marks the property as the {@link Model}s primary key.
|
@@ -19,5 +20,5 @@ import { Repository } from "../repository/Repository";
|
|
19
20
|
* @param key
|
20
21
|
* @param model
|
21
22
|
*/
|
22
|
-
export declare function pkOnCreate<M extends Model, V extends Repository<M, any>>(this: V, data: SequenceOptions, key: string, model: M): Promise<void>;
|
23
|
+
export declare function pkOnCreate<M extends Model, V extends Repository<M, any>>(this: V, context: Context<M>, data: SequenceOptions, key: string, model: M): Promise<void>;
|
23
24
|
export declare function pk(opts?: Omit<SequenceOptions, "cycle" | "startWith" | "incrementBy">): (target: object, propertyKey?: any, descriptor?: any) => void;
|
@@ -5,6 +5,7 @@ import { apply } from "@decaf-ts/reflection";
|
|
5
5
|
import { Repository } from "../repository/Repository";
|
6
6
|
import { index } from "../model/decorators";
|
7
7
|
import { sequenceNameForModel } from "./utils";
|
8
|
+
import { OrderDirection } from "../repository";
|
8
9
|
/**
|
9
10
|
* @summary Primary Key Decorator
|
10
11
|
* @description Marks the property as the {@link Model}s primary key.
|
@@ -23,7 +24,7 @@ import { sequenceNameForModel } from "./utils";
|
|
23
24
|
* @param key
|
24
25
|
* @param model
|
25
26
|
*/
|
26
|
-
export async function pkOnCreate(data, key, model) {
|
27
|
+
export async function pkOnCreate(context, data, key, model) {
|
27
28
|
if (!data.type || model[key]) {
|
28
29
|
return;
|
29
30
|
}
|
@@ -49,9 +50,9 @@ export async function pkOnCreate(data, key, model) {
|
|
49
50
|
}
|
50
51
|
export function pk(opts = DefaultSequenceOptions) {
|
51
52
|
opts = Object.assign({}, DefaultSequenceOptions, opts);
|
52
|
-
return apply(index(), required(), readonly(),
|
53
|
+
return apply(index([OrderDirection.ASC, OrderDirection.DSC]), required(), readonly(),
|
53
54
|
// type([String.name, Number.name, BigInt.name]),
|
54
55
|
propMetadata(Repository.key(DBKeys.ID), opts), onCreate(pkOnCreate, opts));
|
55
56
|
}
|
56
57
|
|
57
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
58
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9pZGVudGl0eS9kZWNvcmF0b3JzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBUyxZQUFZLEVBQUUsUUFBUSxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDL0UsT0FBTyxFQUNMLHNCQUFzQixHQUV2QixNQUFNLCtCQUErQixDQUFDO0FBQ3ZDLE9BQU8sRUFDTCxNQUFNLEVBQ04sYUFBYSxFQUNiLFFBQVEsRUFDUixRQUFRLEdBQ1QsTUFBTSx5QkFBeUIsQ0FBQztBQUNqQyxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDN0MsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQ3RELE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUM1QyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFHL0MsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUvQzs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FpQkc7QUFDSCxNQUFNLENBQUMsS0FBSyxVQUFVLFVBQVUsQ0FFOUIsT0FBbUIsRUFDbkIsSUFBcUIsRUFDckIsR0FBVyxFQUNYLEtBQVE7SUFFUixJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksSUFBSyxLQUE2QixDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUM7UUFDdEQsT0FBTztJQUNULENBQUM7SUFFRCxNQUFNLGtCQUFrQixHQUFHLFVBQ3pCLE1BQVMsRUFDVCxXQUFtQixFQUNuQixLQUErQjtRQUUvQixNQUFNLENBQUMsY0FBYyxDQUFDLE1BQU0sRUFBRSxXQUFXLEVBQUU7WUFDekMsVUFBVSxFQUFFLElBQUk7WUFDaEIsUUFBUSxFQUFFLEtBQUs7WUFDZixZQUFZLEVBQUUsSUFBSTtZQUNsQixLQUFLLEVBQUUsS0FBSztTQUNiLENBQUMsQ0FBQztJQUNMLENBQUMsQ0FBQztJQUNGLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSTtRQUFFLElBQUksQ0FBQyxJQUFJLEdBQUcsb0JBQW9CLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQzlELElBQUksUUFBa0IsQ0FBQztJQUN2QixJQUFJLENBQUM7UUFDSCxRQUFRLEdBQUcsTUFBTSxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUMvQyxDQUFDO0lBQUMsT0FBTyxDQUFNLEVBQUUsQ0FBQztRQUNoQixNQUFNLElBQUksYUFBYSxDQUNyQixrQ0FBa0MsSUFBSSxDQUFDLElBQUksS0FBSyxDQUFDLEVBQUUsQ0FDcEQsQ0FBQztJQUNKLENBQUM7SUFFRCxNQUFNLElBQUksR0FBRyxNQUFNLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNuQyxrQkFBa0IsQ0FBQyxLQUFLLEVBQUUsR0FBRyxFQUFFLElBQUksQ0FBQyxDQUFDO0FBQ3ZDLENBQUM7QUFFRCxNQUFNLFVBQVUsRUFBRSxDQUNoQixPQUdJLHNCQUFzQjtJQUUxQixJQUFJLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxFQUFFLEVBQUUsc0JBQXNCLEVBQUUsSUFBSSxDQUFvQixDQUFDO0lBQzFFLE9BQU8sS0FBSyxDQUNWLEtBQUssQ0FBQyxDQUFDLGNBQWMsQ0FBQyxHQUFHLEVBQUUsY0FBYyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQy9DLFFBQVEsRUFBRSxFQUNWLFFBQVEsRUFBRTtJQUNWLGlEQUFpRDtJQUNqRCxZQUFZLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLEVBQUUsSUFBdUIsQ0FBQyxFQUNoRSxRQUFRLENBQUMsVUFBVSxFQUFFLElBQXVCLENBQUMsQ0FDOUMsQ0FBQztBQUNKLENBQUMiLCJmaWxlIjoiaWRlbnRpdHkvZGVjb3JhdG9ycy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1vZGVsLCBwcm9wTWV0YWRhdGEsIHJlcXVpcmVkIH0gZnJvbSBcIkBkZWNhZi10cy9kZWNvcmF0b3ItdmFsaWRhdGlvblwiO1xuaW1wb3J0IHtcbiAgRGVmYXVsdFNlcXVlbmNlT3B0aW9ucyxcbiAgU2VxdWVuY2VPcHRpb25zLFxufSBmcm9tIFwiLi4vaW50ZXJmYWNlcy9TZXF1ZW5jZU9wdGlvbnNcIjtcbmltcG9ydCB7XG4gIERCS2V5cyxcbiAgSW50ZXJuYWxFcnJvcixcbiAgb25DcmVhdGUsXG4gIHJlYWRvbmx5LFxufSBmcm9tIFwiQGRlY2FmLXRzL2RiLWRlY29yYXRvcnNcIjtcbmltcG9ydCB7IGFwcGx5IH0gZnJvbSBcIkBkZWNhZi10cy9yZWZsZWN0aW9uXCI7XG5pbXBvcnQgeyBSZXBvc2l0b3J5IH0gZnJvbSBcIi4uL3JlcG9zaXRvcnkvUmVwb3NpdG9yeVwiO1xuaW1wb3J0IHsgaW5kZXggfSBmcm9tIFwiLi4vbW9kZWwvZGVjb3JhdG9yc1wiO1xuaW1wb3J0IHsgc2VxdWVuY2VOYW1lRm9yTW9kZWwgfSBmcm9tIFwiLi91dGlsc1wiO1xuaW1wb3J0IHsgU2VxdWVuY2UgfSBmcm9tIFwiLi4vcGVyc2lzdGVuY2UvU2VxdWVuY2VcIjtcbmltcG9ydCB7IENvbnRleHQgfSBmcm9tIFwiQGRlY2FmLXRzL2RiLWRlY29yYXRvcnMvbGliL3JlcG9zaXRvcnkvQ29udGV4dFwiO1xuaW1wb3J0IHsgT3JkZXJEaXJlY3Rpb24gfSBmcm9tIFwiLi4vcmVwb3NpdG9yeVwiO1xuXG4vKipcbiAqIEBzdW1tYXJ5IFByaW1hcnkgS2V5IERlY29yYXRvclxuICogQGRlc2NyaXB0aW9uIE1hcmtzIHRoZSBwcm9wZXJ0eSBhcyB0aGUge0BsaW5rIE1vZGVsfXMgcHJpbWFyeSBrZXkuXG4gKiAgQWxzbyBtYXJrcyB0aGUgcHJvcGVydHkgYXMge0BsaW5rIHVuaXF1ZX0gYXMge0ByZXF1aXJlZH0gYW5kIGVuc3VyZXMgdGhlIGluZGV4IGlzIGNyZWF0ZWQgcHJvcGVybHkgYWNjb3JkaW5nIHRvIHRoZSBwcm92aWRlZCB7QGxpbmsgU2VxdWVuY2V9XG4gKlxuICpcbiAqXG4gKiBAZnVuY3Rpb24gcGtcbiAqXG4gKiBAbWVtYmVyT2YgbW9kdWxlOndhbGxldC1kYi5EZWNvcmF0b3JzXG4gKlxuICogQHNlZSB1bmlxdWVcbiAqIEBzZWUgcmVxdWlyZWRcbiAqIEBzZWUgb25cbiAqIEBwYXJhbSBkYXRhXG4gKiBAcGFyYW0ga2V5XG4gKiBAcGFyYW0gbW9kZWxcbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHBrT25DcmVhdGU8TSBleHRlbmRzIE1vZGVsLCBWIGV4dGVuZHMgUmVwb3NpdG9yeTxNLCBhbnk+PihcbiAgdGhpczogVixcbiAgY29udGV4dDogQ29udGV4dDxNPixcbiAgZGF0YTogU2VxdWVuY2VPcHRpb25zLFxuICBrZXk6IHN0cmluZyxcbiAgbW9kZWw6IE1cbik6IFByb21pc2U8dm9pZD4ge1xuICBpZiAoIWRhdGEudHlwZSB8fCAobW9kZWwgYXMgUmVjb3JkPHN0cmluZywgYW55Pilba2V5XSkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IHNldFByaW1hcnlLZXlWYWx1ZSA9IGZ1bmN0aW9uIDxNIGV4dGVuZHMgTW9kZWw+KFxuICAgIHRhcmdldDogTSxcbiAgICBwcm9wZXJ0eUtleTogc3RyaW5nLFxuICAgIHZhbHVlOiBzdHJpbmcgfCBudW1iZXIgfCBiaWdpbnRcbiAgKSB7XG4gICAgT2JqZWN0LmRlZmluZVByb3BlcnR5KHRhcmdldCwgcHJvcGVydHlLZXksIHtcbiAgICAgIGVudW1lcmFibGU6IHRydWUsXG4gICAgICB3cml0YWJsZTogZmFsc2UsXG4gICAgICBjb25maWd1cmFibGU6IHRydWUsXG4gICAgICB2YWx1ZTogdmFsdWUsXG4gICAgfSk7XG4gIH07XG4gIGlmICghZGF0YS5uYW1lKSBkYXRhLm5hbWUgPSBzZXF1ZW5jZU5hbWVGb3JNb2RlbChtb2RlbCwgXCJwa1wiKTtcbiAgbGV0IHNlcXVlbmNlOiBTZXF1ZW5jZTtcbiAgdHJ5IHtcbiAgICBzZXF1ZW5jZSA9IGF3YWl0IHRoaXMuYWRhcHRlci5TZXF1ZW5jZShkYXRhKTtcbiAgfSBjYXRjaCAoZTogYW55KSB7XG4gICAgdGhyb3cgbmV3IEludGVybmFsRXJyb3IoXG4gICAgICBgRmFpbGVkIHRvIGluc3RhbnRpYXRlIFNlcXVlbmNlICR7ZGF0YS5uYW1lfTogJHtlfWBcbiAgICApO1xuICB9XG5cbiAgY29uc3QgbmV4dCA9IGF3YWl0IHNlcXVlbmNlLm5leHQoKTtcbiAgc2V0UHJpbWFyeUtleVZhbHVlKG1vZGVsLCBrZXksIG5leHQpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcGsoXG4gIG9wdHM6IE9taXQ8XG4gICAgU2VxdWVuY2VPcHRpb25zLFxuICAgIFwiY3ljbGVcIiB8IFwic3RhcnRXaXRoXCIgfCBcImluY3JlbWVudEJ5XCJcbiAgPiA9IERlZmF1bHRTZXF1ZW5jZU9wdGlvbnNcbikge1xuICBvcHRzID0gT2JqZWN0LmFzc2lnbih7fSwgRGVmYXVsdFNlcXVlbmNlT3B0aW9ucywgb3B0cykgYXMgU2VxdWVuY2VPcHRpb25zO1xuICByZXR1cm4gYXBwbHkoXG4gICAgaW5kZXgoW09yZGVyRGlyZWN0aW9uLkFTQywgT3JkZXJEaXJlY3Rpb24uRFNDXSksXG4gICAgcmVxdWlyZWQoKSxcbiAgICByZWFkb25seSgpLFxuICAgIC8vIHR5cGUoW1N0cmluZy5uYW1lLCBOdW1iZXIubmFtZSwgQmlnSW50Lm5hbWVdKSxcbiAgICBwcm9wTWV0YWRhdGEoUmVwb3NpdG9yeS5rZXkoREJLZXlzLklEKSwgb3B0cyBhcyBTZXF1ZW5jZU9wdGlvbnMpLFxuICAgIG9uQ3JlYXRlKHBrT25DcmVhdGUsIG9wdHMgYXMgU2VxdWVuY2VPcHRpb25zKVxuICApO1xufVxuIl19
|
@@ -1,3 +1,4 @@
|
|
1
1
|
export * from "./decorators";
|
2
|
+
export * from "./utils";
|
2
3
|
|
3
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
4
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9pZGVudGl0eS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLFNBQVMsQ0FBQyIsImZpbGUiOiJpZGVudGl0eS9pbmRleC5qcyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL2RlY29yYXRvcnNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3V0aWxzXCI7XG4iXX0=
|
@@ -1,2 +1,3 @@
|
|
1
|
-
import { Model } from "@decaf-ts/decorator-validation";
|
2
|
-
export declare function
|
1
|
+
import { Constructor, Model } from "@decaf-ts/decorator-validation";
|
2
|
+
export declare function getTableName<M extends Model>(model: M | Constructor<M>): any;
|
3
|
+
export declare function sequenceNameForModel<M extends Model>(model: M | Constructor<M>, ...args: string[]): string;
|
@@ -1,6 +1,18 @@
|
|
1
|
-
import {
|
1
|
+
import { Model } from "@decaf-ts/decorator-validation";
|
2
|
+
import { Adapter } from "../persistence/Adapter";
|
3
|
+
import { PersistenceKeys } from "../persistence/constants";
|
4
|
+
export function getTableName(model) {
|
5
|
+
const metadata = Reflect.getMetadata(Adapter.key(PersistenceKeys.TABLE), model instanceof Model ? model.constructor : model);
|
6
|
+
if (metadata) {
|
7
|
+
return metadata;
|
8
|
+
}
|
9
|
+
if (model instanceof Model) {
|
10
|
+
return model.constructor.name;
|
11
|
+
}
|
12
|
+
return model.name;
|
13
|
+
}
|
2
14
|
export function sequenceNameForModel(model, ...args) {
|
3
|
-
return [
|
15
|
+
return [getTableName(model), ...args].join("_");
|
4
16
|
}
|
5
17
|
|
6
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
18
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9pZGVudGl0eS91dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWUsS0FBSyxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDcEUsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ2pELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUUzRCxNQUFNLFVBQVUsWUFBWSxDQUFrQixLQUF5QjtJQUNyRSxNQUFNLFFBQVEsR0FBRyxPQUFPLENBQUMsV0FBVyxDQUNsQyxPQUFPLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQyxLQUFLLENBQUMsRUFDbEMsS0FBSyxZQUFZLEtBQUssQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUNuRCxDQUFDO0lBQ0YsSUFBSSxRQUFRLEVBQUUsQ0FBQztRQUNiLE9BQU8sUUFBUSxDQUFDO0lBQ2xCLENBQUM7SUFDRCxJQUFJLEtBQUssWUFBWSxLQUFLLEVBQUUsQ0FBQztRQUMzQixPQUFPLEtBQUssQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDO0lBQ2hDLENBQUM7SUFDRCxPQUFPLEtBQUssQ0FBQyxJQUFJLENBQUM7QUFDcEIsQ0FBQztBQUVELE1BQU0sVUFBVSxvQkFBb0IsQ0FDbEMsS0FBeUIsRUFDekIsR0FBRyxJQUFjO0lBRWpCLE9BQU8sQ0FBQyxZQUFZLENBQUMsS0FBSyxDQUFDLEVBQUUsR0FBRyxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7QUFDbEQsQ0FBQyIsImZpbGUiOiJpZGVudGl0eS91dGlscy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbnN0cnVjdG9yLCBNb2RlbCB9IGZyb20gXCJAZGVjYWYtdHMvZGVjb3JhdG9yLXZhbGlkYXRpb25cIjtcbmltcG9ydCB7IEFkYXB0ZXIgfSBmcm9tIFwiLi4vcGVyc2lzdGVuY2UvQWRhcHRlclwiO1xuaW1wb3J0IHsgUGVyc2lzdGVuY2VLZXlzIH0gZnJvbSBcIi4uL3BlcnNpc3RlbmNlL2NvbnN0YW50c1wiO1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0VGFibGVOYW1lPE0gZXh0ZW5kcyBNb2RlbD4obW9kZWw6IE0gfCBDb25zdHJ1Y3RvcjxNPikge1xuICBjb25zdCBtZXRhZGF0YSA9IFJlZmxlY3QuZ2V0TWV0YWRhdGEoXG4gICAgQWRhcHRlci5rZXkoUGVyc2lzdGVuY2VLZXlzLlRBQkxFKSxcbiAgICBtb2RlbCBpbnN0YW5jZW9mIE1vZGVsID8gbW9kZWwuY29uc3RydWN0b3IgOiBtb2RlbFxuICApO1xuICBpZiAobWV0YWRhdGEpIHtcbiAgICByZXR1cm4gbWV0YWRhdGE7XG4gIH1cbiAgaWYgKG1vZGVsIGluc3RhbmNlb2YgTW9kZWwpIHtcbiAgICByZXR1cm4gbW9kZWwuY29uc3RydWN0b3IubmFtZTtcbiAgfVxuICByZXR1cm4gbW9kZWwubmFtZTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHNlcXVlbmNlTmFtZUZvck1vZGVsPE0gZXh0ZW5kcyBNb2RlbD4oXG4gIG1vZGVsOiBNIHwgQ29uc3RydWN0b3I8TT4sXG4gIC4uLmFyZ3M6IHN0cmluZ1tdXG4pIHtcbiAgcmV0dXJuIFtnZXRUYWJsZU5hbWUobW9kZWwpLCAuLi5hcmdzXS5qb2luKFwiX1wiKTtcbn1cbiJdfQ==
|
package/lib/esm/index.d.ts
CHANGED
package/lib/esm/index.js
CHANGED
@@ -25,6 +25,6 @@ Injectables.setRegistry(new InjectablesRegistry());
|
|
25
25
|
* @const VERSION
|
26
26
|
* @memberOf module:ts-workspace
|
27
27
|
*/
|
28
|
-
export const VERSION = "0.
|
28
|
+
export const VERSION = "0.3.0";
|
29
29
|
|
30
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
30
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDbkQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBRTlEOzs7O0dBSUc7QUFFSDs7Ozs7R0FLRztBQUVILGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsY0FBYyxDQUFDO0FBRTdCLFdBQVcsQ0FBQyxXQUFXLENBQUMsSUFBSSxtQkFBbUIsRUFBRSxDQUFDLENBQUM7QUFFbkQ7Ozs7O0dBS0c7QUFDSCxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsT0FBTyxDQUFDIiwiZmlsZSI6ImluZGV4LmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZXNSZWdpc3RyeSB9IGZyb20gXCIuL3JlcG9zaXRvcnlcIjtcbmltcG9ydCB7IEluamVjdGFibGVzIH0gZnJvbSBcIkBkZWNhZi10cy9pbmplY3RhYmxlLWRlY29yYXRvcnNcIjtcblxuLyoqXG4gKiBAc3VtbWFyeSBNb2R1bGUgc3VtbWFyeVxuICogQGRlc2NyaXB0aW9uIE1vZHVsZSBkZXNjcmlwdGlvblxuICogQG1vZHVsZSB0cy13b3Jrc3BhY2VcbiAqL1xuXG4vKipcbiAqIEBzdW1tYXJ5IE5hbWVzcGFjZSBzdW1tYXJ5XG4gKiBAZGVzY3JpcHRpb24gTmFtZXNwYWNlIGRlc2NyaXB0aW9uXG4gKiBAbmFtZXNwYWNlIE5hbWVzcGFjZVxuICogQG1lbWJlck9mIG1vZHVsZTp0cy13b3Jrc3BhY2VcbiAqL1xuXG5leHBvcnQgKiBmcm9tIFwiLi9pZGVudGl0eVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vaW50ZXJmYWNlc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vbW9kZWxcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3BlcnNpc3RlbmNlXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9xdWVyeVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vcmVwb3NpdG9yeVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdmFsaWRhdG9yc1wiO1xuXG5JbmplY3RhYmxlcy5zZXRSZWdpc3RyeShuZXcgSW5qZWN0YWJsZXNSZWdpc3RyeSgpKTtcblxuLyoqXG4gKiBAc3VtbWFyeSBzdG9yZXMgdGhlIGN1cnJlbnQgcGFja2FnZSB2ZXJzaW9uXG4gKiBAZGVzY3JpcHRpb24gdGhpcyBpcyBob3cgeW91IHNob3VsZCBkb2N1bWVudCBhIGNvbnN0YW50XG4gKiBAY29uc3QgVkVSU0lPTlxuICogQG1lbWJlck9mIG1vZHVsZTp0cy13b3Jrc3BhY2VcbiAqL1xuZXhwb3J0IGNvbnN0IFZFUlNJT04gPSBcIjAuMy4wXCI7XG4iXX0=
|
@@ -0,0 +1,3 @@
|
|
1
|
+
export {};
|
2
|
+
|
3
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9pbnRlcmZhY2VzL1BhZ2luYXRhYmxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJmaWxlIjoiaW50ZXJmYWNlcy9QYWdpbmF0YWJsZS5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBhZ2luYXRvciB9IGZyb20gXCIuLi9xdWVyeS9QYWdpbmF0b3JcIjtcblxuZXhwb3J0IGludGVyZmFjZSBQYWdpbmF0YWJsZSB7XG4gIHBhZ2luYXRlPFY+KC4uLmFyZ3M6IGFueVtdKTogUHJvbWlzZTxQYWdpbmF0b3I8ViwgYW55Pj47XG59XG4iXX0=
|
@@ -4,7 +4,6 @@ export * from "./Observable";
|
|
4
4
|
export * from "./Observer";
|
5
5
|
export * from "./Queriable";
|
6
6
|
export * from "./RawExecutor";
|
7
|
-
export * from "./Sequence";
|
8
7
|
export * from "./SequenceOptions";
|
9
8
|
|
10
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
9
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9pbnRlcmZhY2VzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsbUJBQW1CLENBQUMiLCJmaWxlIjoiaW50ZXJmYWNlcy9pbmRleC5qcyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL0J1aWxkZXJcIjtcbmV4cG9ydCAqIGZyb20gXCIuL0V4ZWN1dG9yXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9PYnNlcnZhYmxlXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9PYnNlcnZlclwiO1xuZXhwb3J0ICogZnJvbSBcIi4vUXVlcmlhYmxlXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9SYXdFeGVjdXRvclwiO1xuZXhwb3J0ICogZnJvbSBcIi4vU2VxdWVuY2VPcHRpb25zXCI7XG4iXX0=
|
@@ -1,6 +1,8 @@
|
|
1
1
|
import { ModelArg, Model } from "@decaf-ts/decorator-validation";
|
2
2
|
export declare abstract class BaseModel extends Model {
|
3
|
-
createdOn
|
4
|
-
updatedOn
|
3
|
+
createdOn: Date;
|
4
|
+
updatedOn: Date;
|
5
|
+
createdBy: string;
|
6
|
+
updatedBy: string;
|
5
7
|
protected constructor(arg?: ModelArg<BaseModel>);
|
6
8
|
}
|
@@ -9,11 +9,10 @@ var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
9
|
};
|
10
10
|
import { DBOperations, timestamp } from "@decaf-ts/db-decorators";
|
11
11
|
import { Model } from "@decaf-ts/decorator-validation";
|
12
|
+
import { createdBy, updatedBy } from "./decorators";
|
12
13
|
export class BaseModel extends Model {
|
13
14
|
constructor(arg) {
|
14
15
|
super(arg);
|
15
|
-
this.createdOn = undefined;
|
16
|
-
this.updatedOn = undefined;
|
17
16
|
}
|
18
17
|
}
|
19
18
|
__decorate([
|
@@ -24,5 +23,13 @@ __decorate([
|
|
24
23
|
timestamp(),
|
25
24
|
__metadata("design:type", Date)
|
26
25
|
], BaseModel.prototype, "updatedOn", void 0);
|
26
|
+
__decorate([
|
27
|
+
createdBy(),
|
28
|
+
__metadata("design:type", String)
|
29
|
+
], BaseModel.prototype, "createdBy", void 0);
|
30
|
+
__decorate([
|
31
|
+
updatedBy(),
|
32
|
+
__metadata("design:type", String)
|
33
|
+
], BaseModel.prototype, "updatedBy", void 0);
|
27
34
|
|
28
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
35
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9tb2RlbC9CYXNlTW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxTQUFTLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUNsRSxPQUFPLEVBQVksS0FBSyxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDakUsT0FBTyxFQUFFLFNBQVMsRUFBRSxTQUFTLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFFcEQsTUFBTSxPQUFnQixTQUFVLFNBQVEsS0FBSztJQVczQyxZQUFzQixHQUF5QjtRQUM3QyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDYixDQUFDO0NBQ0Y7QUFaQztJQURDLFNBQVMsQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDOzhCQUNuQixJQUFJOzRDQUFDO0FBRWpCO0lBREMsU0FBUyxFQUFFOzhCQUNBLElBQUk7NENBQUM7QUFHakI7SUFEQyxTQUFTLEVBQUU7OzRDQUNPO0FBRW5CO0lBREMsU0FBUyxFQUFFOzs0Q0FDTyIsImZpbGUiOiJtb2RlbC9CYXNlTW9kZWwuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEQk9wZXJhdGlvbnMsIHRpbWVzdGFtcCB9IGZyb20gXCJAZGVjYWYtdHMvZGItZGVjb3JhdG9yc1wiO1xuaW1wb3J0IHsgTW9kZWxBcmcsIE1vZGVsIH0gZnJvbSBcIkBkZWNhZi10cy9kZWNvcmF0b3ItdmFsaWRhdGlvblwiO1xuaW1wb3J0IHsgY3JlYXRlZEJ5LCB1cGRhdGVkQnkgfSBmcm9tIFwiLi9kZWNvcmF0b3JzXCI7XG5cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBCYXNlTW9kZWwgZXh0ZW5kcyBNb2RlbCB7XG4gIEB0aW1lc3RhbXAoREJPcGVyYXRpb25zLkNSRUFURSlcbiAgY3JlYXRlZE9uITogRGF0ZTtcbiAgQHRpbWVzdGFtcCgpXG4gIHVwZGF0ZWRPbiE6IERhdGU7XG5cbiAgQGNyZWF0ZWRCeSgpXG4gIGNyZWF0ZWRCeSE6IHN0cmluZztcbiAgQHVwZGF0ZWRCeSgpXG4gIHVwZGF0ZWRCeSE6IHN0cmluZztcblxuICBwcm90ZWN0ZWQgY29uc3RydWN0b3IoYXJnPzogTW9kZWxBcmc8QmFzZU1vZGVsPikge1xuICAgIHN1cGVyKGFyZyk7XG4gIH1cbn1cbiJdfQ==
|
@@ -0,0 +1,8 @@
|
|
1
|
+
import { Model, ModelArg } from "@decaf-ts/decorator-validation";
|
2
|
+
import { Roles } from "../persistence/constants";
|
3
|
+
export declare class User extends Model {
|
4
|
+
id: string;
|
5
|
+
roles?: (string | Roles)[];
|
6
|
+
affiliations?: string[];
|
7
|
+
constructor(arg?: ModelArg<User>);
|
8
|
+
}
|
@@ -0,0 +1,35 @@
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
6
|
+
};
|
7
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
8
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
9
|
+
};
|
10
|
+
import { list, model, Model } from "@decaf-ts/decorator-validation";
|
11
|
+
import { pk } from "../identity/decorators";
|
12
|
+
let User = class User extends Model {
|
13
|
+
constructor(arg) {
|
14
|
+
super(arg);
|
15
|
+
}
|
16
|
+
};
|
17
|
+
__decorate([
|
18
|
+
pk(),
|
19
|
+
__metadata("design:type", String)
|
20
|
+
], User.prototype, "id", void 0);
|
21
|
+
__decorate([
|
22
|
+
list([String]),
|
23
|
+
__metadata("design:type", Array)
|
24
|
+
], User.prototype, "roles", void 0);
|
25
|
+
__decorate([
|
26
|
+
list([String]),
|
27
|
+
__metadata("design:type", Array)
|
28
|
+
], User.prototype, "affiliations", void 0);
|
29
|
+
User = __decorate([
|
30
|
+
model(),
|
31
|
+
__metadata("design:paramtypes", [Object])
|
32
|
+
], User);
|
33
|
+
export { User };
|
34
|
+
|
35
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9tb2RlbC9Vc2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBWSxNQUFNLGdDQUFnQyxDQUFDO0FBRTlFLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUdyQyxJQUFNLElBQUksR0FBVixNQUFNLElBQUssU0FBUSxLQUFLO0lBVTdCLFlBQVksR0FBb0I7UUFDOUIsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ2IsQ0FBQztDQUNGLENBQUE7QUFYQztJQURDLEVBQUUsRUFBRTs7Z0NBQ087QUFHWjtJQURDLElBQUksQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDOzttQ0FDWTtBQUczQjtJQURDLElBQUksQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDOzswQ0FDUztBQVJiLElBQUk7SUFEaEIsS0FBSyxFQUFFOztHQUNLLElBQUksQ0FhaEIiLCJmaWxlIjoibW9kZWwvVXNlci5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGxpc3QsIG1vZGVsLCBNb2RlbCwgTW9kZWxBcmcgfSBmcm9tIFwiQGRlY2FmLXRzL2RlY29yYXRvci12YWxpZGF0aW9uXCI7XG5pbXBvcnQgeyBSb2xlcyB9IGZyb20gXCIuLi9wZXJzaXN0ZW5jZS9jb25zdGFudHNcIjtcbmltcG9ydCB7IHBrIH0gZnJvbSBcIi4uL2lkZW50aXR5L2RlY29yYXRvcnNcIjtcblxuQG1vZGVsKClcbmV4cG9ydCBjbGFzcyBVc2VyIGV4dGVuZHMgTW9kZWwge1xuICBAcGsoKVxuICBpZCE6IHN0cmluZztcblxuICBAbGlzdChbU3RyaW5nXSlcbiAgcm9sZXM/OiAoc3RyaW5nIHwgUm9sZXMpW107XG5cbiAgQGxpc3QoW1N0cmluZ10pXG4gIGFmZmlsaWF0aW9ucz86IHN0cmluZ1tdO1xuXG4gIGNvbnN0cnVjdG9yKGFyZz86IE1vZGVsQXJnPFVzZXI+KSB7XG4gICAgc3VwZXIoYXJnKTtcbiAgfVxufVxuIl19
|
@@ -0,0 +1,15 @@
|
|
1
|
+
import { Model } from "@decaf-ts/decorator-validation";
|
2
|
+
import { Repository } from "../repository/Repository";
|
3
|
+
import { RelationsMetadata } from "./types";
|
4
|
+
import { Context } from "@decaf-ts/db-decorators/lib/repository/Context";
|
5
|
+
export declare function createOrUpdate<M extends Model>(model: M, context: Context<M>, repository?: Repository<M>): Promise<M>;
|
6
|
+
export declare function oneToOneOnCreate<M extends Model, R extends Repository<M>, Y extends RelationsMetadata>(this: R, context: Context<M>, data: Y, key: string, model: M): Promise<void>;
|
7
|
+
export declare function oneToOneOnUpdate<M extends Model, R extends Repository<M>, Y extends RelationsMetadata>(this: R, context: Context<M>, data: Y, key: string, model: M): Promise<void>;
|
8
|
+
export declare function oneToOneOnDelete<M extends Model, R extends Repository<M>, Y extends RelationsMetadata>(this: R, context: Context<M>, data: Y, key: string, model: M): Promise<void>;
|
9
|
+
export declare function oneToManyOnCreate<M extends Model, R extends Repository<M>, Y extends RelationsMetadata>(this: R, context: Context<M>, data: Y, key: string, model: M): Promise<void>;
|
10
|
+
export declare function oneToManyOnUpdate<M extends Model, R extends Repository<M>, Y extends RelationsMetadata>(this: R, context: Context<M>, data: Y, key: string, model: M): Promise<void>;
|
11
|
+
export declare function oneToManyOnDelete<M extends Model, R extends Repository<M>, Y extends RelationsMetadata>(this: R, context: Context<M>, data: Y, key: string, model: M): Promise<void>;
|
12
|
+
export declare function getPopulateKey(tableName: string, fieldName: string, id: string | number): string;
|
13
|
+
export declare function cacheModelForPopulate<M extends Model>(context: Context<M>, parentModel: M, propertyKey: string, pkValue: string | number, cacheValue: any): Promise<void>;
|
14
|
+
export declare function populate<M extends Model, R extends Repository<M>, Y extends RelationsMetadata>(this: R, context: Context<M>, data: Y, key: string, model: M): Promise<void>;
|
15
|
+
export declare function repositoryFromTypeMetadata<M extends Model>(model: any, propertyKey: string): Repository<M>;
|
@@ -0,0 +1,205 @@
|
|
1
|
+
import { Model, Validation, ValidationKeys, } from "@decaf-ts/decorator-validation";
|
2
|
+
import { Repository } from "../repository/Repository";
|
3
|
+
import { findPrimaryKey, InternalError, NotFoundError, } from "@decaf-ts/db-decorators";
|
4
|
+
import { PersistenceKeys } from "../persistence/constants";
|
5
|
+
import { Cascade } from "../repository/constants";
|
6
|
+
export async function createOrUpdate(model, context, repository) {
|
7
|
+
if (!repository) {
|
8
|
+
const constructor = Model.get(model.constructor.name);
|
9
|
+
if (!constructor)
|
10
|
+
throw new InternalError(`Could not find model ${model.constructor.name}`);
|
11
|
+
repository = Repository.forModel(constructor);
|
12
|
+
}
|
13
|
+
if (typeof model[repository.pk] === "undefined")
|
14
|
+
return repository.create(model, context);
|
15
|
+
else {
|
16
|
+
try {
|
17
|
+
return repository.update(model, context);
|
18
|
+
}
|
19
|
+
catch (e) {
|
20
|
+
if (!(e instanceof NotFoundError))
|
21
|
+
throw e;
|
22
|
+
return repository.create(model, context);
|
23
|
+
}
|
24
|
+
}
|
25
|
+
}
|
26
|
+
export async function oneToOneOnCreate(context, data, key, model) {
|
27
|
+
const propertyValue = model[key];
|
28
|
+
if (!propertyValue)
|
29
|
+
return;
|
30
|
+
if (typeof propertyValue !== "object") {
|
31
|
+
const innerRepo = repositoryFromTypeMetadata(model, key);
|
32
|
+
const read = await innerRepo.read(propertyValue);
|
33
|
+
await cacheModelForPopulate(context, model, key, propertyValue, read);
|
34
|
+
model[key] = propertyValue;
|
35
|
+
return;
|
36
|
+
}
|
37
|
+
const constructor = Model.get(data.class);
|
38
|
+
if (!constructor)
|
39
|
+
throw new InternalError(`Could not find model ${data.class}`);
|
40
|
+
const repo = Repository.forModel(constructor);
|
41
|
+
const created = await repo.create(propertyValue);
|
42
|
+
const pk = findPrimaryKey(created).id;
|
43
|
+
await cacheModelForPopulate(context, model, key, created[pk], created);
|
44
|
+
model[key] = created[pk];
|
45
|
+
}
|
46
|
+
export async function oneToOneOnUpdate(context, data, key, model) {
|
47
|
+
const propertyValue = model[key];
|
48
|
+
if (!propertyValue)
|
49
|
+
return;
|
50
|
+
if (data.cascade.update !== Cascade.CASCADE)
|
51
|
+
return;
|
52
|
+
if (typeof propertyValue !== "object") {
|
53
|
+
const innerRepo = repositoryFromTypeMetadata(model, key);
|
54
|
+
const read = await innerRepo.read(propertyValue);
|
55
|
+
await cacheModelForPopulate(context, model, key, propertyValue, read);
|
56
|
+
model[key] = propertyValue;
|
57
|
+
return;
|
58
|
+
}
|
59
|
+
const updated = await createOrUpdate(model[key], context);
|
60
|
+
const pk = findPrimaryKey(updated).id;
|
61
|
+
await cacheModelForPopulate(context, model, key, updated[pk], updated);
|
62
|
+
model[key] = updated[pk];
|
63
|
+
}
|
64
|
+
export async function oneToOneOnDelete(context, data, key, model) {
|
65
|
+
const propertyValue = model[key];
|
66
|
+
if (!propertyValue)
|
67
|
+
return;
|
68
|
+
if (data.cascade.update !== Cascade.CASCADE)
|
69
|
+
return;
|
70
|
+
const innerRepo = repositoryFromTypeMetadata(model, key);
|
71
|
+
let deleted;
|
72
|
+
if (!(propertyValue instanceof Model))
|
73
|
+
deleted = await innerRepo.delete(model[key], context);
|
74
|
+
else
|
75
|
+
deleted = await innerRepo.delete(model[key][innerRepo.pk], context);
|
76
|
+
await cacheModelForPopulate(context, model, key, deleted[innerRepo.pk], deleted);
|
77
|
+
}
|
78
|
+
export async function oneToManyOnCreate(context, data, key, model) {
|
79
|
+
const propertyValues = model[key];
|
80
|
+
if (!propertyValues || !propertyValues.length)
|
81
|
+
return;
|
82
|
+
const arrayType = typeof propertyValues[0];
|
83
|
+
if (!propertyValues.every((item) => typeof item === arrayType))
|
84
|
+
throw new InternalError(`Invalid operation. All elements of property ${key} must match the same type.`);
|
85
|
+
const uniqueValues = new Set([...propertyValues]);
|
86
|
+
if (arrayType !== "object") {
|
87
|
+
const repo = repositoryFromTypeMetadata(model, key);
|
88
|
+
for (const id of uniqueValues) {
|
89
|
+
const read = await repo.read(id);
|
90
|
+
await cacheModelForPopulate(context, model, key, id, read);
|
91
|
+
}
|
92
|
+
model[key] = [...uniqueValues];
|
93
|
+
return;
|
94
|
+
}
|
95
|
+
const pkName = findPrimaryKey(propertyValues[0]).id;
|
96
|
+
const result = new Set();
|
97
|
+
for (const m of propertyValues) {
|
98
|
+
const record = await createOrUpdate(m, context);
|
99
|
+
await cacheModelForPopulate(context, model, key, record[pkName], record);
|
100
|
+
result.add(record[pkName]);
|
101
|
+
}
|
102
|
+
model[key] = [...result];
|
103
|
+
}
|
104
|
+
export async function oneToManyOnUpdate(context, data, key, model) {
|
105
|
+
const { cascade } = data;
|
106
|
+
if (cascade.update !== Cascade.CASCADE)
|
107
|
+
return;
|
108
|
+
return oneToManyOnCreate.call(this, context, data, key, model);
|
109
|
+
}
|
110
|
+
export async function oneToManyOnDelete(context, data, key, model) {
|
111
|
+
if (data.cascade.delete !== Cascade.CASCADE)
|
112
|
+
return;
|
113
|
+
const values = model[key];
|
114
|
+
if (!values || !values.length)
|
115
|
+
return;
|
116
|
+
const arrayType = typeof values[0];
|
117
|
+
const areAllSameType = values.every((item) => typeof item === arrayType);
|
118
|
+
if (!areAllSameType)
|
119
|
+
throw new InternalError(`Invalid operation. All elements of property ${key} must match the same type.`);
|
120
|
+
const isInstantiated = arrayType === "object";
|
121
|
+
const repo = isInstantiated
|
122
|
+
? Repository.forModel(values[0])
|
123
|
+
: repositoryFromTypeMetadata(model, key);
|
124
|
+
const uniqueValues = new Set([
|
125
|
+
...(isInstantiated
|
126
|
+
? values.map((v) => v[repo.pk])
|
127
|
+
: values),
|
128
|
+
]);
|
129
|
+
for (const id of uniqueValues.values()) {
|
130
|
+
const deleted = await repo.delete(id, context);
|
131
|
+
await cacheModelForPopulate(context, model, key, id, deleted);
|
132
|
+
}
|
133
|
+
model[key] = [...uniqueValues];
|
134
|
+
}
|
135
|
+
export function getPopulateKey(tableName, fieldName, id) {
|
136
|
+
return [PersistenceKeys.POPULATE, tableName, fieldName, id].join(".");
|
137
|
+
}
|
138
|
+
export async function cacheModelForPopulate(context, parentModel, propertyKey, pkValue, cacheValue) {
|
139
|
+
const cacheKey = getPopulateKey(parentModel.constructor.name, propertyKey, pkValue);
|
140
|
+
return context.put(cacheKey, cacheValue);
|
141
|
+
}
|
142
|
+
export async function populate(context, data, key, model) {
|
143
|
+
if (!data.populate)
|
144
|
+
return;
|
145
|
+
const nested = model[key];
|
146
|
+
const isArr = Array.isArray(nested);
|
147
|
+
if (typeof nested === "undefined" || (isArr && nested.length === 0))
|
148
|
+
return;
|
149
|
+
async function fetchPopulateValues(c, model, propName, propKeyValues) {
|
150
|
+
let cacheKey;
|
151
|
+
let val;
|
152
|
+
const results = [];
|
153
|
+
for (const proKeyValue of propKeyValues) {
|
154
|
+
cacheKey = getPopulateKey(model.constructor.name, propName, proKeyValue);
|
155
|
+
try {
|
156
|
+
val = await c.get(cacheKey);
|
157
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
158
|
+
}
|
159
|
+
catch (e) {
|
160
|
+
const repo = repositoryFromTypeMetadata(model, propName);
|
161
|
+
if (!repo)
|
162
|
+
throw new InternalError("Could not find repo");
|
163
|
+
val = await repo.read(proKeyValue);
|
164
|
+
}
|
165
|
+
results.push(val);
|
166
|
+
}
|
167
|
+
return results;
|
168
|
+
}
|
169
|
+
const res = await fetchPopulateValues(context, model, key, isArr ? nested : [nested]);
|
170
|
+
model[key] = isArr ? res : res[0];
|
171
|
+
}
|
172
|
+
const commomTypes = [
|
173
|
+
"array",
|
174
|
+
"string",
|
175
|
+
"number",
|
176
|
+
"boolean",
|
177
|
+
"symbol",
|
178
|
+
"function",
|
179
|
+
"object",
|
180
|
+
"undefined",
|
181
|
+
"null",
|
182
|
+
"bigint",
|
183
|
+
];
|
184
|
+
export function repositoryFromTypeMetadata(model, propertyKey) {
|
185
|
+
const types = Reflect.getMetadata(Validation.key(Array.isArray(model[propertyKey])
|
186
|
+
? ValidationKeys.LIST
|
187
|
+
: ValidationKeys.TYPE), model, propertyKey);
|
188
|
+
const customTypes = Array.isArray(model[propertyKey])
|
189
|
+
? types.class
|
190
|
+
: types.customTypes;
|
191
|
+
if (!types || !customTypes)
|
192
|
+
throw new InternalError(`Failed to find types decorators for property ${propertyKey}`);
|
193
|
+
const allowedTypes = Array.isArray(customTypes)
|
194
|
+
? [...customTypes]
|
195
|
+
: [customTypes];
|
196
|
+
const constructorName = allowedTypes.find((t) => !commomTypes.includes(`${t}`.toLowerCase()));
|
197
|
+
if (!constructorName)
|
198
|
+
throw new InternalError(`Property key ${propertyKey} does not have a valid constructor type`);
|
199
|
+
const constructor = Model.get(constructorName);
|
200
|
+
if (!constructor)
|
201
|
+
throw new InternalError(`No registered model found for ${constructorName}`);
|
202
|
+
return Repository.forModel(constructor);
|
203
|
+
}
|
204
|
+
|
205
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["src/model/construction.ts"],"names":[],"mappings":"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","file":"model/construction.js","sourcesContent":["import {\n  Constructor,\n  Model,\n  Validation,\n  ValidationKeys,\n} from \"@decaf-ts/decorator-validation\";\nimport { Repository } from \"../repository/Repository\";\nimport { RelationsMetadata } from \"./types\";\nimport {\n  findPrimaryKey,\n  InternalError,\n  NotFoundError,\n} from \"@decaf-ts/db-decorators\";\nimport { PersistenceKeys } from \"../persistence/constants\";\nimport { Cascade } from \"../repository/constants\";\nimport { Context } from \"@decaf-ts/db-decorators/lib/repository/Context\";\n\nexport async function createOrUpdate<M extends Model>(\n  model: M,\n  context: Context<M>,\n  repository?: Repository<M>\n): Promise<M> {\n  if (!repository) {\n    const constructor = Model.get(model.constructor.name);\n    if (!constructor)\n      throw new InternalError(`Could not find model ${model.constructor.name}`);\n    repository = Repository.forModel(constructor) as Repository<M>;\n  }\n  if (typeof (model as Record<string, any>)[repository.pk] === \"undefined\")\n    return repository.create(model, context);\n  else {\n    try {\n      return repository.update(model, context);\n    } catch (e: any) {\n      if (!(e instanceof NotFoundError)) throw e;\n      return repository.create(model, context);\n    }\n  }\n}\n\nexport async function oneToOneOnCreate<\n  M extends Model,\n  R extends Repository<M>,\n  Y extends RelationsMetadata,\n>(this: R, context: Context<M>, data: Y, key: string, model: M): Promise<void> {\n  const propertyValue: any = (model as Record<string, any>)[key];\n  if (!propertyValue) return;\n\n  if (typeof propertyValue !== \"object\") {\n    const innerRepo = repositoryFromTypeMetadata(model, key);\n    const read = await innerRepo.read(propertyValue);\n    await cacheModelForPopulate(context, model, key, propertyValue, read);\n    (model as Record<string, any>)[key] = propertyValue;\n    return;\n  }\n\n  const constructor = Model.get(data.class);\n  if (!constructor)\n    throw new InternalError(`Could not find model ${data.class}`);\n  const repo: Repository<any> = Repository.forModel(constructor);\n  const created = await repo.create(propertyValue);\n  const pk = findPrimaryKey(created).id;\n  await cacheModelForPopulate(context, model, key, created[pk], created);\n  (model as any)[key] = created[pk];\n}\n\nexport async function oneToOneOnUpdate<\n  M extends Model,\n  R extends Repository<M>,\n  Y extends RelationsMetadata,\n>(this: R, context: Context<M>, data: Y, key: string, model: M): Promise<void> {\n  const propertyValue: any = (model as Record<string, any>)[key];\n  if (!propertyValue) return;\n  if (data.cascade.update !== Cascade.CASCADE) return;\n\n  if (typeof propertyValue !== \"object\") {\n    const innerRepo = repositoryFromTypeMetadata(model, key);\n    const read = await innerRepo.read(propertyValue);\n    await cacheModelForPopulate(context, model, key, propertyValue, read);\n    (model as Record<string, any>)[key] = propertyValue;\n    return;\n  }\n\n  const updated = await createOrUpdate(\n    (model as Record<string, any>)[key],\n    context\n  );\n  const pk = findPrimaryKey(updated).id;\n  await cacheModelForPopulate(\n    context,\n    model,\n    key,\n    (updated as Record<string, any>)[pk],\n    updated\n  );\n  (model as any)[key] = (updated as Record<string, any>)[pk];\n}\n\nexport async function oneToOneOnDelete<\n  M extends Model,\n  R extends Repository<M>,\n  Y extends RelationsMetadata,\n>(this: R, context: Context<M>, data: Y, key: string, model: M): Promise<void> {\n  const propertyValue: any = (model as Record<string, any>)[key];\n  if (!propertyValue) return;\n  if (data.cascade.update !== Cascade.CASCADE) return;\n  const innerRepo: Repository<M> = repositoryFromTypeMetadata(model, key);\n  let deleted: M;\n  if (!(propertyValue instanceof Model))\n    deleted = await innerRepo.delete(\n      (model as Record<string, any>)[key],\n      context\n    );\n  else\n    deleted = await innerRepo.delete(\n      (model as Record<string, any>)[key][innerRepo.pk],\n      context\n    );\n  await cacheModelForPopulate(\n    context,\n    model,\n    key,\n    (deleted as Record<string, any>)[innerRepo.pk],\n    deleted\n  );\n}\n\nexport async function oneToManyOnCreate<\n  M extends Model,\n  R extends Repository<M>,\n  Y extends RelationsMetadata,\n>(this: R, context: Context<M>, data: Y, key: string, model: M): Promise<void> {\n  const propertyValues: any = (model as Record<string, any>)[key];\n  if (!propertyValues || !propertyValues.length) return;\n  const arrayType = typeof propertyValues[0];\n  if (!propertyValues.every((item: any) => typeof item === arrayType))\n    throw new InternalError(\n      `Invalid operation. All elements of property ${key} must match the same type.`\n    );\n  const uniqueValues = new Set([...propertyValues]);\n  if (arrayType !== \"object\") {\n    const repo = repositoryFromTypeMetadata(model, key);\n    for (const id of uniqueValues) {\n      const read = await repo.read(id);\n      await cacheModelForPopulate(context, model, key, id, read);\n    }\n    (model as any)[key] = [...uniqueValues];\n    return;\n  }\n\n  const pkName = findPrimaryKey(propertyValues[0]).id;\n\n  const result: Set<string> = new Set();\n\n  for (const m of propertyValues) {\n    const record = await createOrUpdate(m, context);\n    await cacheModelForPopulate(context, model, key, record[pkName], record);\n    result.add(record[pkName]);\n  }\n\n  (model as any)[key] = [...result];\n}\n\nexport async function oneToManyOnUpdate<\n  M extends Model,\n  R extends Repository<M>,\n  Y extends RelationsMetadata,\n>(this: R, context: Context<M>, data: Y, key: string, model: M): Promise<void> {\n  const { cascade } = data;\n  if (cascade.update !== Cascade.CASCADE) return;\n  return oneToManyOnCreate.call(this, context, data, key, model);\n}\n\nexport async function oneToManyOnDelete<\n  M extends Model,\n  R extends Repository<M>,\n  Y extends RelationsMetadata,\n>(this: R, context: Context<M>, data: Y, key: string, model: M): Promise<void> {\n  if (data.cascade.delete !== Cascade.CASCADE) return;\n  const values = (model as Record<string, any>)[key];\n  if (!values || !values.length) return;\n  const arrayType = typeof values[0];\n  const areAllSameType = values.every((item: any) => typeof item === arrayType);\n  if (!areAllSameType)\n    throw new InternalError(\n      `Invalid operation. All elements of property ${key} must match the same type.`\n    );\n  const isInstantiated = arrayType === \"object\";\n  const repo = isInstantiated\n    ? Repository.forModel(values[0])\n    : repositoryFromTypeMetadata(model, key);\n\n  const uniqueValues = new Set([\n    ...(isInstantiated\n      ? values.map((v: Record<string, any>) => v[repo.pk])\n      : values),\n  ]);\n\n  for (const id of uniqueValues.values()) {\n    const deleted = await repo.delete(id, context);\n    await cacheModelForPopulate(context, model, key, id, deleted);\n  }\n  (model as any)[key] = [...uniqueValues];\n}\n\nexport function getPopulateKey(\n  tableName: string,\n  fieldName: string,\n  id: string | number\n) {\n  return [PersistenceKeys.POPULATE, tableName, fieldName, id].join(\".\");\n}\n\nexport async function cacheModelForPopulate<M extends Model>(\n  context: Context<M>,\n  parentModel: M,\n  propertyKey: string,\n  pkValue: string | number,\n  cacheValue: any\n) {\n  const cacheKey = getPopulateKey(\n    parentModel.constructor.name,\n    propertyKey,\n    pkValue\n  );\n  return context.put(cacheKey, cacheValue);\n}\n\nexport async function populate<\n  M extends Model,\n  R extends Repository<M>,\n  Y extends RelationsMetadata,\n>(this: R, context: Context<M>, data: Y, key: string, model: M): Promise<void> {\n  if (!data.populate) return;\n  const nested: any = (model as Record<string, any>)[key];\n  const isArr = Array.isArray(nested);\n  if (typeof nested === \"undefined\" || (isArr && nested.length === 0)) return;\n\n  async function fetchPopulateValues(\n    c: Context<M>,\n    model: M,\n    propName: string,\n    propKeyValues: any[]\n  ) {\n    let cacheKey: string;\n    let val: any;\n    const results: M[] = [];\n    for (const proKeyValue of propKeyValues) {\n      cacheKey = getPopulateKey(model.constructor.name, propName, proKeyValue);\n      try {\n        val = await c.get(cacheKey);\n        // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      } catch (e: any) {\n        const repo = repositoryFromTypeMetadata(model, propName);\n        if (!repo) throw new InternalError(\"Could not find repo\");\n        val = await repo.read(proKeyValue);\n      }\n      results.push(val);\n    }\n    return results;\n  }\n  const res = await fetchPopulateValues(\n    context,\n    model,\n    key,\n    isArr ? nested : [nested]\n  );\n  (model as Record<string, any>)[key] = isArr ? res : res[0];\n}\n\nconst commomTypes = [\n  \"array\",\n  \"string\",\n  \"number\",\n  \"boolean\",\n  \"symbol\",\n  \"function\",\n  \"object\",\n  \"undefined\",\n  \"null\",\n  \"bigint\",\n];\n\nexport function repositoryFromTypeMetadata<M extends Model>(\n  model: any,\n  propertyKey: string\n): Repository<M> {\n  const types = Reflect.getMetadata(\n    Validation.key(\n      Array.isArray(model[propertyKey])\n        ? ValidationKeys.LIST\n        : ValidationKeys.TYPE\n    ),\n    model,\n    propertyKey\n  );\n  const customTypes: any = Array.isArray(model[propertyKey])\n    ? types.class\n    : types.customTypes;\n  if (!types || !customTypes)\n    throw new InternalError(\n      `Failed to find types decorators for property ${propertyKey}`\n    );\n\n  const allowedTypes: string[] = Array.isArray(customTypes)\n    ? [...customTypes]\n    : [customTypes];\n  const constructorName = allowedTypes.find(\n    (t) => !commomTypes.includes(`${t}`.toLowerCase())\n  );\n  if (!constructorName)\n    throw new InternalError(\n      `Property key ${propertyKey} does not have a valid constructor type`\n    );\n  const constructor: Constructor<M> | undefined = Model.get(constructorName);\n  if (!constructor)\n    throw new InternalError(`No registered model found for ${constructorName}`);\n\n  return Repository.forModel(constructor);\n}\n"]}
|
@@ -1,5 +1,7 @@
|
|
1
|
+
import { Context } from "@decaf-ts/db-decorators";
|
2
|
+
import { CascadeMetadata } from "../repository/types";
|
1
3
|
import { OrderDirection } from "../repository/constants";
|
2
|
-
import { Model } from "@decaf-ts/decorator-validation";
|
4
|
+
import { Constructor, Model } from "@decaf-ts/decorator-validation";
|
3
5
|
import { Repository } from "../repository/Repository";
|
4
6
|
export declare function table(tableName: string): import("@decaf-ts/reflection").CustomDecorator<V>;
|
5
7
|
export declare function column(columnName: string): PropertyDecorator;
|
@@ -13,8 +15,8 @@ export declare function column(columnName: string): PropertyDecorator;
|
|
13
15
|
*
|
14
16
|
* @function index
|
15
17
|
*/
|
16
|
-
export declare function index(
|
17
|
-
export declare function uniqueOnCreateUpdate<M extends Model, R extends Repository<M>, Y = any>(this: R, data: Y, key: string, model: M): Promise<void>;
|
18
|
+
export declare function index(directions?: OrderDirection[], compositions?: string[]): PropertyDecorator;
|
19
|
+
export declare function uniqueOnCreateUpdate<M extends Model, R extends Repository<M>, Y = any>(this: R, context: Context<M>, data: Y, key: string, model: M): Promise<void>;
|
18
20
|
/**
|
19
21
|
* @summary Unique Decorator
|
20
22
|
* @description Tags a property as unique.
|
@@ -25,3 +27,49 @@ export declare function uniqueOnCreateUpdate<M extends Model, R extends Reposito
|
|
25
27
|
* @memberOf module:wallet-db.Decorators
|
26
28
|
*/
|
27
29
|
export declare function unique(): (target: object, propertyKey?: any, descriptor?: any) => void;
|
30
|
+
export declare function createdByOnCreateUpdate<M extends Model, R extends Repository<M>, Y = any>(this: R, context: Context<M>, data: Y, key: string, model: M): Promise<void>;
|
31
|
+
export declare function createdBy(): (target: object, propertyKey?: any, descriptor?: any) => void;
|
32
|
+
export declare function updatedBy(): (target: object, propertyKey?: any, descriptor?: any) => void;
|
33
|
+
/**
|
34
|
+
* @summary One To One relation Decorators
|
35
|
+
*
|
36
|
+
* @param {Constructor<any>} clazz the {@link Sequence} to use. Defaults to {@link NoneSequence}
|
37
|
+
* @param {CascadeMetadata} [cascadeOptions]
|
38
|
+
* @param {boolean} populate If true, replaces the specified key in the document with the corresponding record from the database
|
39
|
+
*
|
40
|
+
* @function onToOne
|
41
|
+
*
|
42
|
+
* @memberOf module:wallet-db.Decorators
|
43
|
+
*
|
44
|
+
* @see oneToMany
|
45
|
+
* @see manyToOne
|
46
|
+
*/
|
47
|
+
export declare function oneToOne<M extends Model>(clazz: Constructor<M>, cascadeOptions?: CascadeMetadata, populate?: boolean): (target: object, propertyKey?: any, descriptor?: any) => void;
|
48
|
+
/**
|
49
|
+
* @summary One To Many relation Decorators
|
50
|
+
*
|
51
|
+
* @param {Constructor<any>} clazz the {@link Sequence} to use. Defaults to {@link NoneSequence}
|
52
|
+
* @param {CascadeMetadata} [cascadeOptions]
|
53
|
+
*
|
54
|
+
* @function oneToMany
|
55
|
+
*
|
56
|
+
* @memberOf module:wallet-db.Decorators
|
57
|
+
*
|
58
|
+
* @see oneToOne
|
59
|
+
* @see manyToOne
|
60
|
+
*/
|
61
|
+
export declare function oneToMany<M extends Model>(clazz: Constructor<M>, cascadeOptions?: CascadeMetadata, populate?: boolean): (target: object, propertyKey?: any, descriptor?: any) => void;
|
62
|
+
/**
|
63
|
+
* @summary Many To One relation Decorators
|
64
|
+
*
|
65
|
+
* @param {Constructor<any>} clazz the {@link Sequence} to use. Defaults to {@link NoneSequence}
|
66
|
+
* @param {CascadeMetadata} [cascadeOptions]
|
67
|
+
*
|
68
|
+
* @function manyToOne
|
69
|
+
*
|
70
|
+
* @memberOf module:wallet-db.Decorators
|
71
|
+
*
|
72
|
+
* @see oneToMany
|
73
|
+
* @see oneToOne
|
74
|
+
*/
|
75
|
+
export declare function manyToOne(clazz: Constructor<any>, cascadeOptions?: CascadeMetadata, populate?: boolean): (target: object, propertyKey?: any, descriptor?: any) => void;
|