@decaf-ts/db-decorators 0.5.1 → 0.6.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/README.md +7 -1
- package/dist/db-decorators.cjs +182 -278
- package/dist/db-decorators.esm.cjs +173 -271
- package/lib/esm/identity/decorators.js +2 -4
- package/lib/esm/identity/utils.d.ts +4 -4
- package/lib/esm/identity/utils.js +4 -4
- package/lib/esm/interfaces/Contextual.d.ts +3 -3
- package/lib/esm/interfaces/Contextual.js +1 -1
- package/lib/esm/interfaces/IRepository.d.ts +6 -4
- package/lib/esm/interfaces/IRepository.js +1 -1
- package/lib/esm/model/constants.d.ts +1 -0
- package/lib/esm/model/constants.js +2 -1
- package/lib/esm/model/decorators.d.ts +5 -3
- package/lib/esm/model/decorators.js +12 -6
- package/lib/esm/model/index.d.ts +1 -0
- package/lib/esm/model/index.js +2 -1
- package/lib/esm/model/model.d.ts +38 -5
- package/lib/esm/model/model.js +1 -1
- package/lib/esm/model/utils.d.ts +6 -0
- package/lib/esm/model/utils.js +32 -0
- package/lib/esm/model/validation.d.ts +1 -1
- package/lib/esm/model/validation.js +1 -1
- package/lib/esm/operations/Operations.d.ts +5 -2
- package/lib/esm/operations/Operations.js +1 -1
- package/lib/esm/operations/OperationsRegistry.d.ts +4 -2
- package/lib/esm/operations/OperationsRegistry.js +1 -1
- package/lib/esm/operations/constants.d.ts +7 -0
- package/lib/esm/operations/constants.js +8 -1
- package/lib/esm/operations/decorators.d.ts +15 -15
- package/lib/esm/operations/decorators.js +1 -1
- package/lib/esm/operations/types.d.ts +5 -20
- package/lib/esm/operations/types.js +1 -1
- package/lib/esm/repository/BaseRepository.d.ts +13 -10
- package/lib/esm/repository/BaseRepository.js +14 -5
- package/lib/esm/repository/Context.d.ts +13 -11
- package/lib/esm/repository/Context.js +43 -29
- package/lib/esm/repository/Repository.d.ts +3 -1
- package/lib/esm/repository/Repository.js +3 -3
- package/lib/esm/repository/constants.d.ts +2 -0
- package/lib/esm/repository/constants.js +12 -0
- package/lib/esm/repository/errors.d.ts +2 -1
- package/lib/esm/repository/errors.js +8 -7
- package/lib/esm/repository/index.d.ts +2 -1
- package/lib/esm/repository/index.js +3 -2
- package/lib/esm/repository/types.d.ts +17 -0
- package/lib/esm/repository/types.js +2 -0
- package/lib/esm/repository/utils.d.ts +4 -3
- package/lib/esm/repository/utils.js +13 -5
- package/lib/esm/repository/wrappers.js +17 -23
- package/lib/esm/validation/decorators.d.ts +7 -5
- package/lib/esm/validation/decorators.js +17 -126
- package/lib/identity/decorators.cjs +4 -6
- package/lib/identity/index.cjs +1 -1
- package/lib/identity/utils.cjs +7 -7
- package/lib/identity/utils.d.ts +4 -4
- package/lib/index.cjs +1 -1
- package/lib/interfaces/Contextual.cjs +1 -1
- package/lib/interfaces/Contextual.d.ts +3 -3
- package/lib/interfaces/IRepository.cjs +1 -1
- package/lib/interfaces/IRepository.d.ts +6 -4
- package/lib/interfaces/index.cjs +1 -1
- package/lib/model/constants.cjs +2 -1
- package/lib/model/constants.d.ts +1 -0
- package/lib/model/decorators.cjs +16 -9
- package/lib/model/decorators.d.ts +5 -3
- package/lib/model/index.cjs +2 -1
- package/lib/model/index.d.ts +1 -0
- package/lib/model/model.cjs +1 -1
- package/lib/model/model.d.ts +38 -5
- package/lib/model/utils.cjs +36 -0
- package/lib/model/utils.d.ts +6 -0
- package/lib/model/validation.cjs +3 -3
- package/lib/model/validation.d.ts +1 -1
- package/lib/operations/Operations.cjs +1 -1
- package/lib/operations/Operations.d.ts +5 -2
- package/lib/operations/OperationsRegistry.cjs +1 -1
- package/lib/operations/OperationsRegistry.d.ts +4 -2
- package/lib/operations/constants.cjs +9 -2
- package/lib/operations/constants.d.ts +7 -0
- package/lib/operations/decorators.cjs +1 -1
- package/lib/operations/decorators.d.ts +15 -15
- package/lib/operations/index.cjs +1 -1
- package/lib/operations/types.cjs +1 -1
- package/lib/operations/types.d.ts +5 -20
- package/lib/repository/BaseRepository.cjs +16 -7
- package/lib/repository/BaseRepository.d.ts +13 -10
- package/lib/repository/Context.cjs +45 -30
- package/lib/repository/Context.d.ts +13 -11
- package/lib/repository/Repository.cjs +5 -5
- package/lib/repository/Repository.d.ts +3 -1
- package/lib/repository/constants.cjs +15 -0
- package/lib/repository/constants.d.ts +2 -0
- package/lib/repository/errors.cjs +8 -7
- package/lib/repository/errors.d.ts +2 -1
- package/lib/repository/index.cjs +3 -2
- package/lib/repository/index.d.ts +2 -1
- package/lib/repository/types.cjs +3 -0
- package/lib/repository/types.d.ts +17 -0
- package/lib/repository/utils.cjs +14 -6
- package/lib/repository/utils.d.ts +4 -3
- package/lib/repository/wrappers.cjs +17 -23
- package/lib/validation/constants.cjs +2 -2
- package/lib/validation/decorators.cjs +21 -130
- package/lib/validation/decorators.d.ts +7 -5
- package/lib/validation/index.cjs +1 -1
- package/lib/validation/validation.cjs +1 -1
- package/lib/validation/validators/ReadOnlyValidator.cjs +2 -2
- package/lib/validation/validators/TimestampValidator.cjs +2 -2
- package/lib/validation/validators/index.cjs +1 -1
- package/package.json +4 -3
- package/lib/esm/repository/DataCache.d.ts +0 -9
- package/lib/esm/repository/DataCache.js +0 -38
- package/lib/repository/DataCache.cjs +0 -42
- package/lib/repository/DataCache.d.ts +0 -9
|
@@ -66,29 +66,23 @@ export function suffixMethod(obj, before, suffix, beforeName) {
|
|
|
66
66
|
* @memberOf module:db-decorators.Repository
|
|
67
67
|
*/
|
|
68
68
|
export function wrapMethodWithContext(obj, before, method, after, methodName) {
|
|
69
|
-
async function wrapper(...args) {
|
|
70
|
-
let transformedArgs = before.call(obj, ...args);
|
|
71
|
-
if (transformedArgs instanceof Promise)
|
|
72
|
-
transformedArgs = await transformedArgs;
|
|
73
|
-
const context = transformedArgs[transformedArgs.length - 1];
|
|
74
|
-
if (!(context instanceof Context))
|
|
75
|
-
throw new InternalError("Missing a context");
|
|
76
|
-
let results = await method.call(obj, ...transformedArgs);
|
|
77
|
-
if (results instanceof Promise)
|
|
78
|
-
results = await results;
|
|
79
|
-
results = after.call(this, results, context);
|
|
80
|
-
if (results instanceof Promise)
|
|
81
|
-
results = await results;
|
|
82
|
-
return results;
|
|
83
|
-
}
|
|
84
|
-
const wrapped = wrapper.bind(obj);
|
|
85
69
|
const name = methodName ? methodName : method.name;
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
70
|
+
obj[name] = new Proxy(obj[name], {
|
|
71
|
+
apply: async (target, thisArg, argArray) => {
|
|
72
|
+
let transformedArgs = before.call(thisArg, ...argArray);
|
|
73
|
+
if (transformedArgs instanceof Promise)
|
|
74
|
+
transformedArgs = await transformedArgs;
|
|
75
|
+
const context = transformedArgs[transformedArgs.length - 1];
|
|
76
|
+
if (!(context instanceof Context))
|
|
77
|
+
throw new InternalError("Missing a context");
|
|
78
|
+
let results = await target.call(thisArg, ...transformedArgs);
|
|
79
|
+
if (results instanceof Promise)
|
|
80
|
+
results = await results;
|
|
81
|
+
results = after.call(thisArg, results, context);
|
|
82
|
+
if (results instanceof Promise)
|
|
83
|
+
results = await results;
|
|
84
|
+
return results;
|
|
85
|
+
},
|
|
91
86
|
});
|
|
92
|
-
obj[name] = wrapped;
|
|
93
87
|
}
|
|
94
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
88
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wrappers.js","sourceRoot":"","sources":["../../../src/repository/wrappers.ts"],"names":[],"mappings":"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","sourcesContent":["import { Context } from \"./Context\";\nimport { InternalError } from \"./errors\";\n\n/**\n * @summary Util method to change a method of an object prefixing it with another\n * @param {any} obj The Base Object\n * @param {Function} after The original method\n * @param {Function} prefix The Prefix method. The output will be used as arguments in the original method\n * @param {string} [afterName] When the after function anme cannot be extracted, pass it here\n *\n * @function prefixMethod\n *\n * @memberOf module:db-decorators.Repository\n */\nexport function prefixMethod(\n  obj: any,\n  after: (...args: any[]) => any,\n  prefix: (...args: any[]) => any,\n  afterName?: string\n) {\n  async function wrapper(this: any, ...args: any[]) {\n    const results = await Promise.resolve(prefix.call(this, ...args));\n    return Promise.resolve(after.apply(this, results));\n  }\n  const wrapped = wrapper.bind(obj);\n  const name = afterName ? afterName : after.name;\n  Object.defineProperty(wrapped, \"name\", {\n    enumerable: true,\n    configurable: true,\n    writable: false,\n    value: name,\n  });\n  obj[name] = wrapped;\n}\n\n/**\n * @summary Util method to change a method of an object suffixing it with another\n * @param {any} obj The Base Object\n * @param {Function} before The original method\n * @param {Function} suffix The Prefix method. The output will be used as arguments in the original method\n * @param {string} [beforeName] When the after function anme cannot be extracted, pass it here\n *\n * @function suffixMethod\n *\n * @memberOf module:db-decorators.Repository\n */\nexport function suffixMethod(\n  obj: any,\n  before: (...args: any[]) => any,\n  suffix: (...args: any[]) => any,\n  beforeName?: string\n) {\n  async function wrapper(this: any, ...args: any[]) {\n    const results = await Promise.resolve(before.call(this, ...args));\n    return suffix.call(this, ...results);\n  }\n  const wrapped = wrapper.bind(obj);\n  const name = beforeName ? beforeName : before.name;\n  Object.defineProperty(wrapped, \"name\", {\n    enumerable: true,\n    configurable: true,\n    writable: false,\n    value: name,\n  });\n  obj[name] = wrapped;\n}\n\n/**\n * @summary Util method to wrap a method of an object with additional logic\n *\n * @param {any} obj The Base Object\n * @param {Function} before the method to be prefixed\n * @param {Function} method the method to be wrapped\n * @param {Function} after The method to be suffixed\n * @param {string} [methodName] When the after function anme cannot be extracted, pass it here\n *\n * @function wrapMethodWithContext\n *\n * @memberOf module:db-decorators.Repository\n */\nexport function wrapMethodWithContext(\n  obj: any,\n  before: (...args: any[]) => any,\n  method: (...args: any[]) => any,\n  after: (...args: any[]) => any,\n  methodName?: string\n) {\n  const name = methodName ? methodName : method.name;\n  obj[name] = new Proxy(obj[name], {\n    apply: async (target, thisArg, argArray) => {\n      let transformedArgs = before.call(thisArg, ...argArray);\n      if (transformedArgs instanceof Promise)\n        transformedArgs = await transformedArgs;\n      const context = transformedArgs[transformedArgs.length - 1] as any;\n      if (!(context instanceof Context))\n        throw new InternalError(\"Missing a context\");\n      let results = await target.call(thisArg, ...transformedArgs);\n      if (results instanceof Promise) results = await results;\n      results = after.call(thisArg, results, context);\n      if (results instanceof Promise) results = await results;\n      return results;\n    },\n  });\n}\n"]}
|
|
@@ -1,7 +1,9 @@
|
|
|
1
|
+
import "./validation";
|
|
1
2
|
import { Model } from "@decaf-ts/decorator-validation";
|
|
2
3
|
import { OperationKeys } from "../operations/constants";
|
|
3
4
|
import { IRepository } from "../interfaces/IRepository";
|
|
4
5
|
import { Context } from "../repository/Context";
|
|
6
|
+
import { RepositoryFlags } from "../repository/types";
|
|
5
7
|
/**
|
|
6
8
|
* Marks the property as readonly.
|
|
7
9
|
*
|
|
@@ -11,8 +13,8 @@ import { Context } from "../repository/Context";
|
|
|
11
13
|
*
|
|
12
14
|
* @category Decorators
|
|
13
15
|
*/
|
|
14
|
-
export declare function readonly(message?: string): (target:
|
|
15
|
-
export declare function timestampHandler<M extends Model,
|
|
16
|
+
export declare function readonly(message?: string): (target: any, propertyKey?: any, descriptor?: TypedPropertyDescriptor<any>) => any;
|
|
17
|
+
export declare function timestampHandler<M extends Model, R extends IRepository<M, F, C>, V, F extends RepositoryFlags = RepositoryFlags, C extends Context<F> = Context<F>>(this: R, context: C, data: V, key: keyof M, model: M): Promise<void>;
|
|
16
18
|
/**
|
|
17
19
|
* Marks the property as timestamp.
|
|
18
20
|
* Makes it {@link required}
|
|
@@ -44,9 +46,9 @@ export declare function timestampHandler<M extends Model, V extends IRepository<
|
|
|
44
46
|
*
|
|
45
47
|
* @category Decorators
|
|
46
48
|
*/
|
|
47
|
-
export declare function timestamp(operation?: OperationKeys[], format?: string): (target:
|
|
48
|
-
export declare function serializeOnCreateUpdate<
|
|
49
|
-
export declare function serializeAfterAll<
|
|
49
|
+
export declare function timestamp(operation?: OperationKeys[], format?: string): (target: any, propertyKey?: any, descriptor?: TypedPropertyDescriptor<any>) => any;
|
|
50
|
+
export declare function serializeOnCreateUpdate<M extends Model, R extends IRepository<M, F, C>, V, F extends RepositoryFlags = RepositoryFlags, C extends Context<F> = Context<F>>(this: R, context: C, data: V, key: keyof M, model: M): Promise<void>;
|
|
51
|
+
export declare function serializeAfterAll<M extends Model, R extends IRepository<M, F, C>, V, F extends RepositoryFlags = RepositoryFlags, C extends Context<F> = Context<F>>(this: R, context: C, data: V, key: keyof M, model: M): Promise<void>;
|
|
50
52
|
/**
|
|
51
53
|
* @summary Serialize Decorator
|
|
52
54
|
* @description properties decorated will the serialized before stored in the db
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import
|
|
1
|
+
import "./validation";
|
|
2
|
+
import { date, Decoration, propMetadata, required, type, Validation, } from "@decaf-ts/decorator-validation";
|
|
2
3
|
import { DBKeys, DEFAULT_TIMESTAMP_FORMAT } from "../model/constants";
|
|
3
4
|
import { DEFAULT_ERROR_MESSAGES } from "./constants";
|
|
4
5
|
import { DBOperations, OperationKeys } from "../operations/constants";
|
|
@@ -16,9 +17,12 @@ import { Repository } from "../repository";
|
|
|
16
17
|
* @category Decorators
|
|
17
18
|
*/
|
|
18
19
|
export function readonly(message = DEFAULT_ERROR_MESSAGES.READONLY.INVALID) {
|
|
19
|
-
|
|
20
|
+
const key = Validation.updateKey(DBKeys.READONLY);
|
|
21
|
+
return Decoration.for(key)
|
|
22
|
+
.define(propMetadata(key, {
|
|
20
23
|
message: message,
|
|
21
|
-
})
|
|
24
|
+
}))
|
|
25
|
+
.apply();
|
|
22
26
|
}
|
|
23
27
|
export async function timestampHandler(context, data, key, model) {
|
|
24
28
|
model[key] = context.timestamp;
|
|
@@ -55,6 +59,7 @@ export async function timestampHandler(context, data, key, model) {
|
|
|
55
59
|
* @category Decorators
|
|
56
60
|
*/
|
|
57
61
|
export function timestamp(operation = DBOperations.CREATE_UPDATE, format = DEFAULT_TIMESTAMP_FORMAT) {
|
|
62
|
+
const key = Validation.updateKey(DBKeys.TIMESTAMP);
|
|
58
63
|
const decorators = [
|
|
59
64
|
date(format, DEFAULT_ERROR_MESSAGES.TIMESTAMP.DATE),
|
|
60
65
|
required(DEFAULT_ERROR_MESSAGES.TIMESTAMP.REQUIRED),
|
|
@@ -64,19 +69,22 @@ export function timestamp(operation = DBOperations.CREATE_UPDATE, format = DEFAU
|
|
|
64
69
|
decorators.push(propMetadata(Validation.updateKey(DBKeys.TIMESTAMP), {
|
|
65
70
|
message: DEFAULT_ERROR_MESSAGES.TIMESTAMP.INVALID,
|
|
66
71
|
}));
|
|
67
|
-
return
|
|
72
|
+
return Decoration.for(key)
|
|
73
|
+
.define(...decorators)
|
|
74
|
+
.apply();
|
|
68
75
|
}
|
|
69
|
-
export async function serializeOnCreateUpdate(data, key, model
|
|
76
|
+
export async function serializeOnCreateUpdate(context, data, key, model) {
|
|
70
77
|
if (!model[key])
|
|
71
78
|
return;
|
|
72
79
|
try {
|
|
73
80
|
model[key] = JSON.stringify(model[key]);
|
|
81
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
74
82
|
}
|
|
75
83
|
catch (e) {
|
|
76
|
-
throw new SerializationError(
|
|
84
|
+
throw new SerializationError(`Failed to serialize ${key.toString()} property of model ${model.constructor.name}: e`);
|
|
77
85
|
}
|
|
78
86
|
}
|
|
79
|
-
export async function serializeAfterAll(data, key, model) {
|
|
87
|
+
export async function serializeAfterAll(context, data, key, model) {
|
|
80
88
|
if (!model[key])
|
|
81
89
|
return;
|
|
82
90
|
if (typeof model[key] !== "string")
|
|
@@ -85,7 +93,7 @@ export async function serializeAfterAll(data, key, model) {
|
|
|
85
93
|
model[key] = JSON.parse(model[key]);
|
|
86
94
|
}
|
|
87
95
|
catch (e) {
|
|
88
|
-
throw new SerializationError(
|
|
96
|
+
throw new SerializationError(`Failed to deserialize ${key.toString()} property of model ${model.constructor.name}: ${e}`);
|
|
89
97
|
}
|
|
90
98
|
}
|
|
91
99
|
/**
|
|
@@ -99,121 +107,4 @@ export async function serializeAfterAll(data, key, model) {
|
|
|
99
107
|
export function serialize() {
|
|
100
108
|
return apply(onCreateUpdate(serializeOnCreateUpdate), after(DBOperations.ALL, serializeAfterAll), type([String.name, Object.name]), metadata(Repository.key(DBKeys.SERIALIZE), {}));
|
|
101
109
|
}
|
|
102
|
-
//
|
|
103
|
-
// /**
|
|
104
|
-
// * @summary One To One relation Decorators
|
|
105
|
-
// *
|
|
106
|
-
// * @param {Constructor<any>} clazz the {@link Sequence} to use. Defaults to {@link NoneSequence}
|
|
107
|
-
// * @param {CascadeMetadata} [cascadeOptions]
|
|
108
|
-
// * @param {boolean} _populate If true, replaces the specified key in the document with the corresponding record from the database
|
|
109
|
-
// *
|
|
110
|
-
// * @function onToOne
|
|
111
|
-
// *
|
|
112
|
-
// * @memberOf module:wallet-db.Decorators
|
|
113
|
-
// *
|
|
114
|
-
// * @see oneToMany
|
|
115
|
-
// * @see manyToOne
|
|
116
|
-
// */
|
|
117
|
-
// export function oneToOne(
|
|
118
|
-
// clazz: Constructor<any>,
|
|
119
|
-
// cascadeOptions: CascadeMetadata = DefaultCascade,
|
|
120
|
-
// _populate: boolean = true,
|
|
121
|
-
// ) {
|
|
122
|
-
// Model.register(clazz);
|
|
123
|
-
// return (target: any, propertyKey: string) => {
|
|
124
|
-
// type([clazz.name, String.name])(target, propertyKey);
|
|
125
|
-
// onCreate(oneToOneOnCreate)(target, propertyKey);
|
|
126
|
-
// onUpdate(oneToOneOnUpdate, cascadeOptions as any)(target, propertyKey);
|
|
127
|
-
// onDelete(oneToOneOnDelete, cascadeOptions)(target, propertyKey);
|
|
128
|
-
//
|
|
129
|
-
// afterCreate(populate, _populate)(target, propertyKey);
|
|
130
|
-
// afterUpdate(populate, _populate)(target, propertyKey);
|
|
131
|
-
// afterRead(populate, _populate)(target, propertyKey);
|
|
132
|
-
// afterDelete(populate, _populate)(target, propertyKey);
|
|
133
|
-
//
|
|
134
|
-
// Reflect.defineMetadata(
|
|
135
|
-
// getDBKey(WalletDbKeys.ONE_TO_ONE),
|
|
136
|
-
// {
|
|
137
|
-
// constructor: clazz.name,
|
|
138
|
-
// cascade: cascadeOptions,
|
|
139
|
-
// populate: _populate,
|
|
140
|
-
// },
|
|
141
|
-
// target,
|
|
142
|
-
// propertyKey,
|
|
143
|
-
// );
|
|
144
|
-
// };
|
|
145
|
-
// }
|
|
146
|
-
//
|
|
147
|
-
// /**
|
|
148
|
-
// * @summary One To Many relation Decorators
|
|
149
|
-
// *
|
|
150
|
-
// * @param {Constructor<any>} clazz the {@link Sequence} to use. Defaults to {@link NoneSequence}
|
|
151
|
-
// * @param {CascadeMetadata} [cascadeOptions]
|
|
152
|
-
// *
|
|
153
|
-
// * @function onToMany
|
|
154
|
-
// *
|
|
155
|
-
// * @memberOf module:wallet-db.Decorators
|
|
156
|
-
// *
|
|
157
|
-
// * @see oneToOne
|
|
158
|
-
// * @see manyToOne
|
|
159
|
-
// */
|
|
160
|
-
// export function oneToMany(
|
|
161
|
-
// clazz: Constructor<any>,
|
|
162
|
-
// cascadeOptions: CascadeMetadata = DefaultCascade,
|
|
163
|
-
// _populate: boolean = true,
|
|
164
|
-
// ) {
|
|
165
|
-
// Model.register(clazz);
|
|
166
|
-
// return (target: any, propertyKey: string) => {
|
|
167
|
-
// list([clazz, String])(target, propertyKey);
|
|
168
|
-
// onCreate(oneToManyOnCreate)(target, propertyKey);
|
|
169
|
-
// onUpdate(oneToManyOnUpdate, cascadeOptions)(target, propertyKey);
|
|
170
|
-
// onDelete(oneToManyOnDelete, cascadeOptions)(target, propertyKey);
|
|
171
|
-
//
|
|
172
|
-
// afterCreate(populate, _populate)(target, propertyKey);
|
|
173
|
-
// afterUpdate(populate, _populate)(target, propertyKey);
|
|
174
|
-
// afterRead(populate, _populate)(target, propertyKey);
|
|
175
|
-
// afterDelete(populate, _populate)(target, propertyKey);
|
|
176
|
-
//
|
|
177
|
-
// Reflect.defineMetadata(
|
|
178
|
-
// getDBKey(WalletDbKeys.ONE_TO_MANY),
|
|
179
|
-
// {
|
|
180
|
-
// constructor: clazz.name,
|
|
181
|
-
// cascade: cascadeOptions,
|
|
182
|
-
// },
|
|
183
|
-
// target,
|
|
184
|
-
// propertyKey,
|
|
185
|
-
// );
|
|
186
|
-
// };
|
|
187
|
-
// }
|
|
188
|
-
//
|
|
189
|
-
// /**
|
|
190
|
-
// * @summary Many To One relation Decorators
|
|
191
|
-
// *
|
|
192
|
-
// * @param {Constructor<any>} clazz the {@link Sequence} to use. Defaults to {@link NoneSequence}
|
|
193
|
-
// * @param {CascadeMetadata} [cascadeOptions]
|
|
194
|
-
// *
|
|
195
|
-
// * @function manyToOne
|
|
196
|
-
// *
|
|
197
|
-
// * @memberOf module:wallet-db.Decorators
|
|
198
|
-
// *
|
|
199
|
-
// * @see oneToMany
|
|
200
|
-
// * @see oneToOne
|
|
201
|
-
// */
|
|
202
|
-
// export function manyToOne(
|
|
203
|
-
// clazz: Constructor<any>,
|
|
204
|
-
// cascadeOptions: CascadeMetadata = DefaultCascade,
|
|
205
|
-
// ) {
|
|
206
|
-
// Model.register(clazz);
|
|
207
|
-
// return (target: any, propertyKey: string) => {
|
|
208
|
-
// Reflect.defineMetadata(
|
|
209
|
-
// getDBKey(WalletDbKeys.MANY_TO_ONE),
|
|
210
|
-
// {
|
|
211
|
-
// constructor: clazz.name,
|
|
212
|
-
// cascade: cascadeOptions,
|
|
213
|
-
// },
|
|
214
|
-
// target,
|
|
215
|
-
// propertyKey,
|
|
216
|
-
// );
|
|
217
|
-
// };
|
|
218
|
-
// }
|
|
219
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../../src/validation/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  date,\n  Model,\n  propMetadata,\n  required,\n  sf,\n  type,\n  Validation,\n} from \"@decaf-ts/decorator-validation\";\nimport { DBKeys, DEFAULT_TIMESTAMP_FORMAT } from \"../model/constants\";\nimport { DEFAULT_ERROR_MESSAGES } from \"./constants\";\nimport { DBOperations, OperationKeys } from \"../operations/constants\";\nimport { after, on, onCreateUpdate } from \"../operations/decorators\";\nimport { IRepository } from \"../interfaces/IRepository\";\nimport { SerializationError } from \"../repository/errors\";\nimport { apply, metadata } from \"@decaf-ts/reflection\";\nimport { Repository } from \"../repository\";\nimport { Context } from \"../repository/Context\";\n\n/**\n * Marks the property as readonly.\n *\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES.READONLY.INVALID}\n *\n * @decorator readonly\n *\n * @category Decorators\n */\nexport function readonly(\n  message: string = DEFAULT_ERROR_MESSAGES.READONLY.INVALID\n) {\n  return propMetadata(Validation.updateKey(DBKeys.READONLY), {\n    message: message,\n  });\n}\n\nexport async function timestampHandler<\n  M extends Model,\n  V extends IRepository<M>,\n  Y = any,\n>(this: V, context: Context<M>, data: Y, key: string, model: M): Promise<void> {\n  (model as any)[key] = context.timestamp;\n}\n\n/**\n * Marks the property as timestamp.\n * Makes it {@link required}\n * Makes it a {@link date}\n *\n * Date Format:\n *\n * <pre>\n *      Using similar formatting as Moment.js, Class DateTimeFormatter (Java), and Class SimpleDateFormat (Java),\n *      I implemented a comprehensive solution formatDate(date, patternStr) where the code is easy to read and modify.\n *      You can display date, time, AM/PM, etc.\n *\n *      Date and Time Patterns\n *      yy = 2-digit year; yyyy = full year\n *      M = digit month; MM = 2-digit month; MMM = short month name; MMMM = full month name\n *      EEEE = full weekday name; EEE = short weekday name\n *      d = digit day; dd = 2-digit day\n *      h = hours am/pm; hh = 2-digit hours am/pm; H = hours; HH = 2-digit hours\n *      m = minutes; mm = 2-digit minutes; aaa = AM/PM\n *      s = seconds; ss = 2-digit seconds\n *      S = miliseconds\n * </pre>\n *\n * @param {string[]} operation The {@link DBOperations} to act on. Defaults to {@link DBOperations.CREATE_UPDATE}\n * @param {string} [format] The TimeStamp format. defaults to {@link DEFAULT_TIMESTAMP_FORMAT}\n * @param {{new: UpdateValidator}} [validator] defaults to {@link TimestampValidator}\n *\n * @decorator timestamp\n *\n * @category Decorators\n */\nexport function timestamp(\n  operation: OperationKeys[] = DBOperations.CREATE_UPDATE as unknown as OperationKeys[],\n  format: string = DEFAULT_TIMESTAMP_FORMAT\n) {\n  const decorators: any[] = [\n    date(format, DEFAULT_ERROR_MESSAGES.TIMESTAMP.DATE),\n    required(DEFAULT_ERROR_MESSAGES.TIMESTAMP.REQUIRED),\n    on(operation, timestampHandler),\n  ];\n\n  if (operation.indexOf(OperationKeys.UPDATE) !== -1)\n    decorators.push(\n      propMetadata(Validation.updateKey(DBKeys.TIMESTAMP), {\n        message: DEFAULT_ERROR_MESSAGES.TIMESTAMP.INVALID,\n      })\n    );\n\n  return apply(...decorators);\n}\n\nexport async function serializeOnCreateUpdate<\n  T extends Model,\n  V extends IRepository<T>,\n  Y = any,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n>(this: V, data: Y, key: string, model: T, oldModel: T): Promise<void> {\n  if (!(model as any)[key]) return;\n  try {\n    (model as any)[key] = JSON.stringify((model as any)[key]);\n  } catch (e: any) {\n    throw new SerializationError(\n      sf(\n        \"Failed to serialize {0} property on {1} model: {2}\",\n        key,\n        model.constructor.name,\n        e.message\n      )\n    );\n  }\n}\n\nexport async function serializeAfterAll<\n  T extends Model,\n  V extends IRepository<T>,\n  Y = any,\n>(this: V, data: Y, key: string, model: T): Promise<void> {\n  if (!(model as any)[key]) return;\n  if (typeof (model as any)[key] !== \"string\") return;\n\n  try {\n    (model as any)[key] = JSON.parse((model as any)[key]);\n  } catch (e: any) {\n    throw new SerializationError(\n      sf(\n        \"Failed to deserialize {0} property on {1} model: {2}\",\n        key,\n        model.constructor.name,\n        e.message\n      )\n    );\n  }\n}\n\n/**\n * @summary Serialize Decorator\n * @description properties decorated will the serialized before stored in the db\n *\n * @function serialize\n *\n * @memberOf module:wallet-db.Decorators\n */\nexport function serialize() {\n  return apply(\n    onCreateUpdate(serializeOnCreateUpdate),\n    after(DBOperations.ALL, serializeAfterAll),\n    type([String.name, Object.name]),\n    metadata(Repository.key(DBKeys.SERIALIZE), {})\n  );\n}\n\n//\n// /**\n//  * @summary One To One relation Decorators\n//  *\n//  * @param {Constructor<any>} clazz the {@link Sequence} to use. Defaults to {@link NoneSequence}\n//  * @param {CascadeMetadata} [cascadeOptions]\n//  * @param {boolean} _populate If true, replaces the specified key in the document with the corresponding record from the database\n//  *\n//  * @function onToOne\n//  *\n//  * @memberOf module:wallet-db.Decorators\n//  *\n//  * @see oneToMany\n//  * @see manyToOne\n//  */\n// export function oneToOne(\n//   clazz: Constructor<any>,\n//   cascadeOptions: CascadeMetadata = DefaultCascade,\n//   _populate: boolean = true,\n// ) {\n//   Model.register(clazz);\n//   return (target: any, propertyKey: string) => {\n//     type([clazz.name, String.name])(target, propertyKey);\n//     onCreate(oneToOneOnCreate)(target, propertyKey);\n//     onUpdate(oneToOneOnUpdate, cascadeOptions as any)(target, propertyKey);\n//     onDelete(oneToOneOnDelete, cascadeOptions)(target, propertyKey);\n//\n//     afterCreate(populate, _populate)(target, propertyKey);\n//     afterUpdate(populate, _populate)(target, propertyKey);\n//     afterRead(populate, _populate)(target, propertyKey);\n//     afterDelete(populate, _populate)(target, propertyKey);\n//\n//     Reflect.defineMetadata(\n//       getDBKey(WalletDbKeys.ONE_TO_ONE),\n//       {\n//         constructor: clazz.name,\n//         cascade: cascadeOptions,\n//         populate: _populate,\n//       },\n//       target,\n//       propertyKey,\n//     );\n//   };\n// }\n//\n// /**\n//  * @summary One To Many relation Decorators\n//  *\n//  * @param {Constructor<any>} clazz the {@link Sequence} to use. Defaults to {@link NoneSequence}\n//  * @param {CascadeMetadata} [cascadeOptions]\n//  *\n//  * @function onToMany\n//  *\n//  * @memberOf module:wallet-db.Decorators\n//  *\n//  * @see oneToOne\n//  * @see manyToOne\n//  */\n// export function oneToMany(\n//   clazz: Constructor<any>,\n//   cascadeOptions: CascadeMetadata = DefaultCascade,\n//   _populate: boolean = true,\n// ) {\n//   Model.register(clazz);\n//   return (target: any, propertyKey: string) => {\n//     list([clazz, String])(target, propertyKey);\n//     onCreate(oneToManyOnCreate)(target, propertyKey);\n//     onUpdate(oneToManyOnUpdate, cascadeOptions)(target, propertyKey);\n//     onDelete(oneToManyOnDelete, cascadeOptions)(target, propertyKey);\n//\n//     afterCreate(populate, _populate)(target, propertyKey);\n//     afterUpdate(populate, _populate)(target, propertyKey);\n//     afterRead(populate, _populate)(target, propertyKey);\n//     afterDelete(populate, _populate)(target, propertyKey);\n//\n//     Reflect.defineMetadata(\n//       getDBKey(WalletDbKeys.ONE_TO_MANY),\n//       {\n//         constructor: clazz.name,\n//         cascade: cascadeOptions,\n//       },\n//       target,\n//       propertyKey,\n//     );\n//   };\n// }\n//\n// /**\n//  * @summary Many To One relation Decorators\n//  *\n//  * @param {Constructor<any>} clazz the {@link Sequence} to use. Defaults to {@link NoneSequence}\n//  * @param {CascadeMetadata} [cascadeOptions]\n//  *\n//  * @function manyToOne\n//  *\n//  * @memberOf module:wallet-db.Decorators\n//  *\n//  * @see oneToMany\n//  * @see oneToOne\n//  */\n// export function manyToOne(\n//   clazz: Constructor<any>,\n//   cascadeOptions: CascadeMetadata = DefaultCascade,\n// ) {\n//   Model.register(clazz);\n//   return (target: any, propertyKey: string) => {\n//     Reflect.defineMetadata(\n//       getDBKey(WalletDbKeys.MANY_TO_ONE),\n//       {\n//         constructor: clazz.name,\n//         cascade: cascadeOptions,\n//       },\n//       target,\n//       propertyKey,\n//     );\n//   };\n// }\n"]}
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../../src/validation/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import \"./validation\";\nimport {\n  date,\n  Decoration,\n  Model,\n  propMetadata,\n  required,\n  type,\n  Validation,\n} from \"@decaf-ts/decorator-validation\";\nimport { DBKeys, DEFAULT_TIMESTAMP_FORMAT } from \"../model/constants\";\nimport { DEFAULT_ERROR_MESSAGES } from \"./constants\";\nimport { DBOperations, OperationKeys } from \"../operations/constants\";\nimport { after, on, onCreateUpdate } from \"../operations/decorators\";\nimport { IRepository } from \"../interfaces/IRepository\";\nimport { SerializationError } from \"../repository/errors\";\nimport { apply, metadata } from \"@decaf-ts/reflection\";\nimport { Repository } from \"../repository\";\nimport { Context } from \"../repository/Context\";\nimport { RepositoryFlags } from \"../repository/types\";\n\n/**\n * Marks the property as readonly.\n *\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES.READONLY.INVALID}\n *\n * @decorator readonly\n *\n * @category Decorators\n */\nexport function readonly(\n  message: string = DEFAULT_ERROR_MESSAGES.READONLY.INVALID\n) {\n  const key = Validation.updateKey(DBKeys.READONLY);\n  return Decoration.for(key)\n    .define(\n      propMetadata(key, {\n        message: message,\n      })\n    )\n    .apply();\n}\n\nexport async function timestampHandler<\n  M extends Model,\n  R extends IRepository<M, F, C>,\n  V,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n>(this: R, context: C, data: V, key: keyof M, model: M): Promise<void> {\n  (model as any)[key] = context.timestamp;\n}\n\n/**\n * Marks the property as timestamp.\n * Makes it {@link required}\n * Makes it a {@link date}\n *\n * Date Format:\n *\n * <pre>\n *      Using similar formatting as Moment.js, Class DateTimeFormatter (Java), and Class SimpleDateFormat (Java),\n *      I implemented a comprehensive solution formatDate(date, patternStr) where the code is easy to read and modify.\n *      You can display date, time, AM/PM, etc.\n *\n *      Date and Time Patterns\n *      yy = 2-digit year; yyyy = full year\n *      M = digit month; MM = 2-digit month; MMM = short month name; MMMM = full month name\n *      EEEE = full weekday name; EEE = short weekday name\n *      d = digit day; dd = 2-digit day\n *      h = hours am/pm; hh = 2-digit hours am/pm; H = hours; HH = 2-digit hours\n *      m = minutes; mm = 2-digit minutes; aaa = AM/PM\n *      s = seconds; ss = 2-digit seconds\n *      S = miliseconds\n * </pre>\n *\n * @param {string[]} operation The {@link DBOperations} to act on. Defaults to {@link DBOperations.CREATE_UPDATE}\n * @param {string} [format] The TimeStamp format. defaults to {@link DEFAULT_TIMESTAMP_FORMAT}\n * @param {{new: UpdateValidator}} [validator] defaults to {@link TimestampValidator}\n *\n * @decorator timestamp\n *\n * @category Decorators\n */\nexport function timestamp(\n  operation: OperationKeys[] = DBOperations.CREATE_UPDATE as unknown as OperationKeys[],\n  format: string = DEFAULT_TIMESTAMP_FORMAT\n) {\n  const key = Validation.updateKey(DBKeys.TIMESTAMP);\n\n  const decorators: any[] = [\n    date(format, DEFAULT_ERROR_MESSAGES.TIMESTAMP.DATE),\n    required(DEFAULT_ERROR_MESSAGES.TIMESTAMP.REQUIRED),\n    on(operation, timestampHandler),\n  ];\n\n  if (operation.indexOf(OperationKeys.UPDATE) !== -1)\n    decorators.push(\n      propMetadata(Validation.updateKey(DBKeys.TIMESTAMP), {\n        message: DEFAULT_ERROR_MESSAGES.TIMESTAMP.INVALID,\n      })\n    );\n  return Decoration.for(key)\n    .define(...decorators)\n    .apply();\n}\n\nexport async function serializeOnCreateUpdate<\n  M extends Model,\n  R extends IRepository<M, F, C>,\n  V,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n>(this: R, context: C, data: V, key: keyof M, model: M): Promise<void> {\n  if (!model[key]) return;\n  try {\n    model[key] = JSON.stringify(model[key]) as M[keyof M];\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  } catch (e: unknown) {\n    throw new SerializationError(\n      `Failed to serialize ${key.toString()} property of model ${model.constructor.name}: e`\n    );\n  }\n}\n\nexport async function serializeAfterAll<\n  M extends Model,\n  R extends IRepository<M, F, C>,\n  V,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n>(this: R, context: C, data: V, key: keyof M, model: M): Promise<void> {\n  if (!model[key]) return;\n  if (typeof model[key] !== \"string\") return;\n\n  try {\n    model[key] = JSON.parse(model[key]);\n  } catch (e: unknown) {\n    throw new SerializationError(\n      `Failed to deserialize ${key.toString()} property of model ${model.constructor.name}: ${e}`\n    );\n  }\n}\n\n/**\n * @summary Serialize Decorator\n * @description properties decorated will the serialized before stored in the db\n *\n * @function serialize\n *\n * @memberOf module:wallet-db.Decorators\n */\nexport function serialize() {\n  return apply(\n    onCreateUpdate(serializeOnCreateUpdate),\n    after(DBOperations.ALL, serializeAfterAll),\n    type([String.name, Object.name]),\n    metadata(Repository.key(DBKeys.SERIALIZE), {})\n  );\n}\n"]}
|
|
@@ -2,13 +2,11 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.id = id;
|
|
4
4
|
const decorator_validation_1 = require("@decaf-ts/decorator-validation");
|
|
5
|
+
const validation_1 = require("./../validation/index.cjs");
|
|
6
|
+
const constants_1 = require("./../model/constants.cjs");
|
|
7
|
+
const repository_1 = require("./../repository/index.cjs");
|
|
5
8
|
const reflection_1 = require("@decaf-ts/reflection");
|
|
6
|
-
const validation_1 = require("../validation/index.cjs");
|
|
7
|
-
const constants_1 = require("../model/constants.cjs");
|
|
8
|
-
const repository_1 = require("../repository/index.cjs");
|
|
9
|
-
// // eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
10
|
-
// import * as Validation from "../validation/validation";
|
|
11
9
|
function id() {
|
|
12
10
|
return (0, reflection_1.apply)((0, decorator_validation_1.required)(), (0, validation_1.readonly)(), (0, decorator_validation_1.propMetadata)(repository_1.Repository.key(constants_1.DBKeys.ID), {}));
|
|
13
11
|
}
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVjb3JhdG9ycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9pZGVudGl0eS9kZWNvcmF0b3JzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBTUEsZ0JBTUM7QUFaRCx5RUFBd0U7QUFDeEUsMERBQXlDO0FBQ3pDLHdEQUE0QztBQUM1QywwREFBMkM7QUFDM0MscURBQTZDO0FBRTdDLFNBQWdCLEVBQUU7SUFDaEIsT0FBTyxJQUFBLGtCQUFLLEVBQ1YsSUFBQSwrQkFBUSxHQUFFLEVBQ1YsSUFBQSxxQkFBUSxHQUFFLEVBQ1YsSUFBQSxtQ0FBWSxFQUFDLHVCQUFVLENBQUMsR0FBRyxDQUFDLGtCQUFNLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQzVDLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgcHJvcE1ldGFkYXRhLCByZXF1aXJlZCB9IGZyb20gXCJAZGVjYWYtdHMvZGVjb3JhdG9yLXZhbGlkYXRpb25cIjtcbmltcG9ydCB7IHJlYWRvbmx5IH0gZnJvbSBcIi4uL3ZhbGlkYXRpb25cIjtcbmltcG9ydCB7IERCS2V5cyB9IGZyb20gXCIuLi9tb2RlbC9jb25zdGFudHNcIjtcbmltcG9ydCB7IFJlcG9zaXRvcnkgfSBmcm9tIFwiLi4vcmVwb3NpdG9yeVwiO1xuaW1wb3J0IHsgYXBwbHkgfSBmcm9tIFwiQGRlY2FmLXRzL3JlZmxlY3Rpb25cIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGlkKCkge1xuICByZXR1cm4gYXBwbHkoXG4gICAgcmVxdWlyZWQoKSxcbiAgICByZWFkb25seSgpLFxuICAgIHByb3BNZXRhZGF0YShSZXBvc2l0b3J5LmtleShEQktleXMuSUQpLCB7fSlcbiAgKTtcbn1cbiJdfQ==
|
package/lib/identity/index.cjs
CHANGED
|
@@ -16,4 +16,4 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./decorators.cjs"), exports);
|
|
18
18
|
__exportStar(require("./utils.cjs"), exports);
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaWRlbnRpdHkvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLG1EQUE2QjtBQUM3Qiw4Q0FBd0IiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9kZWNvcmF0b3JzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi91dGlsc1wiO1xuIl19
|
package/lib/identity/utils.cjs
CHANGED
|
@@ -2,10 +2,10 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.findPrimaryKey = findPrimaryKey;
|
|
4
4
|
exports.findModelId = findModelId;
|
|
5
|
-
const constants_1 = require("
|
|
6
|
-
const utils_1 = require("
|
|
5
|
+
const constants_1 = require("./../model/constants.cjs");
|
|
6
|
+
const utils_1 = require("./../repository/utils.cjs");
|
|
7
7
|
const decorator_validation_1 = require("@decaf-ts/decorator-validation");
|
|
8
|
-
const errors_1 = require("
|
|
8
|
+
const errors_1 = require("./../repository/errors.cjs");
|
|
9
9
|
/**
|
|
10
10
|
* @summary Returns the primary key attribute for a {@link Model}
|
|
11
11
|
* @description searches in all the properties in the object for an {@link id} decorated property
|
|
@@ -47,7 +47,7 @@ function findPrimaryKey(model) {
|
|
|
47
47
|
*
|
|
48
48
|
* @param {Model} model
|
|
49
49
|
* @param {boolean} [returnEmpty]
|
|
50
|
-
* @return {string} primary key
|
|
50
|
+
* @return {string | number | bigint} primary key
|
|
51
51
|
*
|
|
52
52
|
* @throws {InternalError} if no property or more than one properties are {@link pk} decorated
|
|
53
53
|
* @throws {NotFoundError} returnEmpty is false and no value is set on the {@link pk} decorated property
|
|
@@ -59,8 +59,8 @@ function findPrimaryKey(model) {
|
|
|
59
59
|
function findModelId(model, returnEmpty = false) {
|
|
60
60
|
const idProp = findPrimaryKey(model).id;
|
|
61
61
|
const modelId = model[idProp];
|
|
62
|
-
if (
|
|
63
|
-
throw new errors_1.InternalError(
|
|
62
|
+
if (typeof modelId === "undefined" && !returnEmpty)
|
|
63
|
+
throw new errors_1.InternalError(`No value for the Id is defined under the property ${idProp}`);
|
|
64
64
|
return modelId;
|
|
65
65
|
}
|
|
66
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaWRlbnRpdHkvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFrQkEsd0NBOEJDO0FBaUJELGtDQVdDO0FBNUVELHdEQUE0QztBQUM1QyxxREFBd0U7QUFDeEUseUVBQXNFO0FBQ3RFLHVEQUFxRDtBQUVyRDs7Ozs7Ozs7Ozs7O0dBWUc7QUFDSCxTQUFnQixjQUFjLENBQWtCLEtBQVE7SUFDdEQsTUFBTSxVQUFVLEdBQUcsSUFBQSx5Q0FBaUMsRUFDbEQsS0FBSyxFQUNMLFNBQVMsRUFDVCxrQkFBTSxDQUFDLE9BQU8sR0FBRyxrQkFBTSxDQUFDLEVBQUUsQ0FDM0IsQ0FBQztJQUNGLE1BQU0sWUFBWSxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsVUFBb0IsQ0FBQyxDQUFDLE1BQU0sQ0FDOUQsQ0FBQyxLQUFtQyxFQUFFLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxFQUFFLEVBQUU7UUFDcEQsTUFBTSxRQUFRLEdBQUksSUFBMEIsQ0FBQyxNQUFNLENBQ2pELENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsR0FBRyxLQUFLLGdDQUFTLENBQUMsSUFBSSxDQUNoQyxDQUFDO1FBQ0YsSUFBSSxRQUFRLElBQUksUUFBUSxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQ2hDLEtBQUssQ0FBQyxJQUFJLENBQUMsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1lBQ2hDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxRQUFRLENBQUMsQ0FBQztRQUNoQyxDQUFDO1FBQ0QsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDLEVBQ0QsRUFBRSxDQUNILENBQUM7SUFFRixJQUFJLENBQUMsWUFBWSxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQyxNQUFNO1FBQ3BELE1BQU0sSUFBSSxzQkFBYSxDQUFDLHNDQUFzQyxDQUFDLENBQUM7SUFDbEUsSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLE1BQU0sR0FBRyxDQUFDO1FBQ3RDLE1BQU0sSUFBSSxzQkFBYSxDQUFDLElBQUEseUJBQUUsRUFBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDcEUsTUFBTSxNQUFNLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUM1QyxJQUFJLENBQUMsTUFBTTtRQUFFLE1BQU0sSUFBSSxzQkFBYSxDQUFDLHNDQUFzQyxDQUFDLENBQUM7SUFDN0UsT0FBTztRQUNMLEVBQUUsRUFBRSxNQUFpQjtRQUNyQixLQUFLLEVBQUUsWUFBWSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUs7S0FDckMsQ0FBQztBQUNKLENBQUM7QUFFRDs7Ozs7Ozs7Ozs7Ozs7R0FjRztBQUNILFNBQWdCLFdBQVcsQ0FDekIsS0FBUSxFQUNSLFdBQVcsR0FBRyxLQUFLO0lBRW5CLE1BQU0sTUFBTSxHQUFHLGNBQWMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLENBQUM7SUFDeEMsTUFBTSxPQUFPLEdBQUcsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzlCLElBQUksT0FBTyxPQUFPLEtBQUssV0FBVyxJQUFJLENBQUMsV0FBVztRQUNoRCxNQUFNLElBQUksc0JBQWEsQ0FDckIscURBQXFELE1BQWdCLEVBQUUsQ0FDeEUsQ0FBQztJQUNKLE9BQU8sT0FBbUMsQ0FBQztBQUM3QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgREJLZXlzIH0gZnJvbSBcIi4uL21vZGVsL2NvbnN0YW50c1wiO1xuaW1wb3J0IHsgZ2V0QWxsUHJvcGVydHlEZWNvcmF0b3JzUmVjdXJzaXZlIH0gZnJvbSBcIi4uL3JlcG9zaXRvcnkvdXRpbHNcIjtcbmltcG9ydCB7IE1vZGVsLCBNb2RlbEtleXMsIHNmIH0gZnJvbSBcIkBkZWNhZi10cy9kZWNvcmF0b3ItdmFsaWRhdGlvblwiO1xuaW1wb3J0IHsgSW50ZXJuYWxFcnJvciB9IGZyb20gXCIuLi9yZXBvc2l0b3J5L2Vycm9yc1wiO1xuXG4vKipcbiAqIEBzdW1tYXJ5IFJldHVybnMgdGhlIHByaW1hcnkga2V5IGF0dHJpYnV0ZSBmb3IgYSB7QGxpbmsgTW9kZWx9XG4gKiBAZGVzY3JpcHRpb24gc2VhcmNoZXMgaW4gYWxsIHRoZSBwcm9wZXJ0aWVzIGluIHRoZSBvYmplY3QgZm9yIGFuIHtAbGluayBpZH0gZGVjb3JhdGVkIHByb3BlcnR5XG4gKlxuICogQHBhcmFtIHtNb2RlbH0gbW9kZWxcbiAqXG4gKiBAdGhyb3dzIHtJbnRlcm5hbEVycm9yfSBpZiBubyBwcm9wZXJ0eSBvciBtb3JlIHRoYW4gb25lIHByb3BlcnRpZXMgYXJlIHtAbGluayBpZH0gZGVjb3JhdGVkXG4gKiBvciBubyB2YWx1ZSBpcyBzZXQgaW4gdGhhdCBwcm9wZXJ0eVxuICpcbiAqIEBmdW5jdGlvbiBmaW5kUHJpbWFyeUtleVxuICpcbiAqIEBjYXRlZ29yeSBtYW5hZ2Vyc1xuICovXG5leHBvcnQgZnVuY3Rpb24gZmluZFByaW1hcnlLZXk8TSBleHRlbmRzIE1vZGVsPihtb2RlbDogTSkge1xuICBjb25zdCBkZWNvcmF0b3JzID0gZ2V0QWxsUHJvcGVydHlEZWNvcmF0b3JzUmVjdXJzaXZlKFxuICAgIG1vZGVsLFxuICAgIHVuZGVmaW5lZCxcbiAgICBEQktleXMuUkVGTEVDVCArIERCS2V5cy5JRFxuICApO1xuICBjb25zdCBpZERlY29yYXRvcnMgPSBPYmplY3QuZW50cmllcyhkZWNvcmF0b3JzIGFzIG9iamVjdCkucmVkdWNlKFxuICAgIChhY2N1bTogeyBbaW5kZXhlcjogc3RyaW5nXTogYW55W10gfSwgW3Byb3AsIGRlY3NdKSA9PiB7XG4gICAgICBjb25zdCBmaWx0ZXJlZCA9IChkZWNzIGFzIHsga2V5OiBzdHJpbmcgfVtdKS5maWx0ZXIoXG4gICAgICAgIChkKSA9PiBkLmtleSAhPT0gTW9kZWxLZXlzLlRZUEVcbiAgICAgICk7XG4gICAgICBpZiAoZmlsdGVyZWQgJiYgZmlsdGVyZWQubGVuZ3RoKSB7XG4gICAgICAgIGFjY3VtW3Byb3BdID0gYWNjdW1bcHJvcF0gfHwgW107XG4gICAgICAgIGFjY3VtW3Byb3BdLnB1c2goLi4uZmlsdGVyZWQpO1xuICAgICAgfVxuICAgICAgcmV0dXJuIGFjY3VtO1xuICAgIH0sXG4gICAge31cbiAgKTtcblxuICBpZiAoIWlkRGVjb3JhdG9ycyB8fCAhT2JqZWN0LmtleXMoaWREZWNvcmF0b3JzKS5sZW5ndGgpXG4gICAgdGhyb3cgbmV3IEludGVybmFsRXJyb3IoXCJDb3VsZCBub3QgZmluZCBJRCBkZWNvcmF0ZWQgUHJvcGVydHlcIik7XG4gIGlmIChPYmplY3Qua2V5cyhpZERlY29yYXRvcnMpLmxlbmd0aCA+IDEpXG4gICAgdGhyb3cgbmV3IEludGVybmFsRXJyb3Ioc2YoT2JqZWN0LmtleXMoaWREZWNvcmF0b3JzKS5qb2luKFwiLCBcIikpKTtcbiAgY29uc3QgaWRQcm9wID0gT2JqZWN0LmtleXMoaWREZWNvcmF0b3JzKVswXTtcbiAgaWYgKCFpZFByb3ApIHRocm93IG5ldyBJbnRlcm5hbEVycm9yKFwiQ291bGQgbm90IGZpbmQgSUQgZGVjb3JhdGVkIFByb3BlcnR5XCIpO1xuICByZXR1cm4ge1xuICAgIGlkOiBpZFByb3AgYXMga2V5b2YgTSxcbiAgICBwcm9wczogaWREZWNvcmF0b3JzW2lkUHJvcF1bMF0ucHJvcHMsXG4gIH07XG59XG5cbi8qKlxuICogQHN1bW1hcnkgUmV0dXJucyB0aGUgcHJpbWFyeSBrZXkgdmFsdWUgZm9yIGEge0BsaW5rIE1vZGVsfVxuICogQGRlc2NyaXB0aW9uIHNlYXJjaGVzIGluIGFsbCB0aGUgcHJvcGVydGllcyBpbiB0aGUgb2JqZWN0IGZvciBhbiB7QGxpbmsgcGt9IGRlY29yYXRlZCBwcm9wZXJ0eVxuICpcbiAqIEBwYXJhbSB7TW9kZWx9IG1vZGVsXG4gKiBAcGFyYW0ge2Jvb2xlYW59IFtyZXR1cm5FbXB0eV1cbiAqIEByZXR1cm4ge3N0cmluZyB8IG51bWJlciB8IGJpZ2ludH0gcHJpbWFyeSBrZXlcbiAqXG4gKiBAdGhyb3dzIHtJbnRlcm5hbEVycm9yfSBpZiBubyBwcm9wZXJ0eSBvciBtb3JlIHRoYW4gb25lIHByb3BlcnRpZXMgYXJlIHtAbGluayBwa30gZGVjb3JhdGVkXG4gKiBAdGhyb3dzIHtOb3RGb3VuZEVycm9yfSByZXR1cm5FbXB0eSBpcyBmYWxzZSBhbmQgbm8gdmFsdWUgaXMgc2V0IG9uIHRoZSB7QGxpbmsgcGt9IGRlY29yYXRlZCBwcm9wZXJ0eVxuICpcbiAqIEBmdW5jdGlvbiBmaW5kTW9kZWxJRFxuICpcbiAqIEBjYXRlZ29yeSBtYW5hZ2Vyc1xuICovXG5leHBvcnQgZnVuY3Rpb24gZmluZE1vZGVsSWQ8TSBleHRlbmRzIE1vZGVsPihcbiAgbW9kZWw6IE0sXG4gIHJldHVybkVtcHR5ID0gZmFsc2Vcbik6IHN0cmluZyB8IG51bWJlciB8IGJpZ2ludCB7XG4gIGNvbnN0IGlkUHJvcCA9IGZpbmRQcmltYXJ5S2V5KG1vZGVsKS5pZDtcbiAgY29uc3QgbW9kZWxJZCA9IG1vZGVsW2lkUHJvcF07XG4gIGlmICh0eXBlb2YgbW9kZWxJZCA9PT0gXCJ1bmRlZmluZWRcIiAmJiAhcmV0dXJuRW1wdHkpXG4gICAgdGhyb3cgbmV3IEludGVybmFsRXJyb3IoXG4gICAgICBgTm8gdmFsdWUgZm9yIHRoZSBJZCBpcyBkZWZpbmVkIHVuZGVyIHRoZSBwcm9wZXJ0eSAke2lkUHJvcCBhcyBzdHJpbmd9YFxuICAgICk7XG4gIHJldHVybiBtb2RlbElkIGFzIHN0cmluZyB8IG51bWJlciB8IGJpZ2ludDtcbn1cbiJdfQ==
|
package/lib/identity/utils.d.ts
CHANGED
|
@@ -12,8 +12,8 @@ import { Model } from "@decaf-ts/decorator-validation";
|
|
|
12
12
|
*
|
|
13
13
|
* @category managers
|
|
14
14
|
*/
|
|
15
|
-
export declare function findPrimaryKey<
|
|
16
|
-
id:
|
|
15
|
+
export declare function findPrimaryKey<M extends Model>(model: M): {
|
|
16
|
+
id: keyof M;
|
|
17
17
|
props: any;
|
|
18
18
|
};
|
|
19
19
|
/**
|
|
@@ -22,7 +22,7 @@ export declare function findPrimaryKey<T extends Model>(model: T): {
|
|
|
22
22
|
*
|
|
23
23
|
* @param {Model} model
|
|
24
24
|
* @param {boolean} [returnEmpty]
|
|
25
|
-
* @return {string} primary key
|
|
25
|
+
* @return {string | number | bigint} primary key
|
|
26
26
|
*
|
|
27
27
|
* @throws {InternalError} if no property or more than one properties are {@link pk} decorated
|
|
28
28
|
* @throws {NotFoundError} returnEmpty is false and no value is set on the {@link pk} decorated property
|
|
@@ -31,4 +31,4 @@ export declare function findPrimaryKey<T extends Model>(model: T): {
|
|
|
31
31
|
*
|
|
32
32
|
* @category managers
|
|
33
33
|
*/
|
|
34
|
-
export declare function findModelId(model:
|
|
34
|
+
export declare function findModelId<M extends Model>(model: M, returnEmpty?: boolean): string | number | bigint;
|
package/lib/index.cjs
CHANGED
|
@@ -47,4 +47,4 @@ __exportStar(require("./model/index.cjs"), exports);
|
|
|
47
47
|
__exportStar(require("./operations/index.cjs"), exports);
|
|
48
48
|
__exportStar(require("./repository/index.cjs"), exports);
|
|
49
49
|
__exportStar(require("./validation/index.cjs"), exports);
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOztHQUVHOzs7Ozs7Ozs7Ozs7Ozs7O0FBRUg7OztHQUdHO0FBRUg7OztHQUdHO0FBRUg7OztHQUdHO0FBRUg7OztHQUdHO0FBRUg7OztHQUdHO0FBRUg7OztHQUdHO0FBQ0gsdURBQTJCO0FBQzNCLHlEQUE2QjtBQUM3QixvREFBd0I7QUFDeEIseURBQTZCO0FBQzdCLHlEQUE2QjtBQUM3Qix5REFBNkIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBtb2R1bGUgZGItZGVjb3JhdG9yc1xuICovXG5cbi8qKlxuICogQG5hbWVzcGFjZSBNb2RlbFxuICogQG1lbWJlck9mIG1vZHVsZTpkYi1kZWNvcmF0b3JzXG4gKi9cblxuLyoqXG4gKiBAbmFtZXNwYWNlIE9wZXJhdGlvbnNcbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGItZGVjb3JhdG9yc1xuICovXG5cbi8qKlxuICogQG5hbWVzcGFjZSBSZXBvc2l0b3J5XG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRiLWRlY29yYXRvcnNcbiAqL1xuXG4vKipcbiAqIEBuYW1lc3BhY2UgVmFsaWRhdGlvblxuICogQG1lbWJlck9mIG1vZHVsZTpkYi1kZWNvcmF0b3JzXG4gKi9cblxuLyoqXG4gKiBAbmFtZXNwYWNlIFZhbGlkYXRvcnNcbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGItZGVjb3JhdG9ycy5WYWxpZGF0aW9uXG4gKi9cblxuLyoqXG4gKiBAbmFtZXNwYWNlIFV0aWxzXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRiLWRlY29yYXRvcnNcbiAqL1xuZXhwb3J0ICogZnJvbSBcIi4vaWRlbnRpdHlcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2ludGVyZmFjZXNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL21vZGVsXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9vcGVyYXRpb25zXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9yZXBvc2l0b3J5XCI7XG5leHBvcnQgKiBmcm9tIFwiLi92YWxpZGF0aW9uXCI7XG4iXX0=
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ29udGV4dHVhbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9pbnRlcmZhY2VzL0NvbnRleHR1YWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9wZXJhdGlvbktleXMgfSBmcm9tIFwiLi4vb3BlcmF0aW9uc1wiO1xuaW1wb3J0IHsgQ29udGV4dCB9IGZyb20gXCIuLi9yZXBvc2l0b3J5XCI7XG5pbXBvcnQgeyBSZXBvc2l0b3J5RmxhZ3MgfSBmcm9tIFwiLi4vcmVwb3NpdG9yeS90eXBlc1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIENvbnRleHR1YWw8XG4gIEYgZXh0ZW5kcyBSZXBvc2l0b3J5RmxhZ3MgPSBSZXBvc2l0b3J5RmxhZ3MsXG4gIEMgZXh0ZW5kcyBDb250ZXh0PEY+ID0gQ29udGV4dDxGPixcbj4ge1xuICBjb250ZXh0KFxuICAgIG9wZXJhdGlvbjpcbiAgICAgIHwgT3BlcmF0aW9uS2V5cy5DUkVBVEVcbiAgICAgIHwgT3BlcmF0aW9uS2V5cy5SRUFEXG4gICAgICB8IE9wZXJhdGlvbktleXMuVVBEQVRFXG4gICAgICB8IE9wZXJhdGlvbktleXMuREVMRVRFLFxuICAgIG92ZXJyaWRlczogUGFydGlhbDxGPixcbiAgICAuLi5hcmdzOiBhbnlbXVxuICApOiBQcm9taXNlPEM+O1xufVxuIl19
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { OperationKeys } from "../operations";
|
|
2
|
-
import { Model } from "@decaf-ts/decorator-validation";
|
|
3
2
|
import { Context } from "../repository";
|
|
4
|
-
|
|
5
|
-
|
|
3
|
+
import { RepositoryFlags } from "../repository/types";
|
|
4
|
+
export interface Contextual<F extends RepositoryFlags = RepositoryFlags, C extends Context<F> = Context<F>> {
|
|
5
|
+
context(operation: OperationKeys.CREATE | OperationKeys.READ | OperationKeys.UPDATE | OperationKeys.DELETE, overrides: Partial<F>, ...args: any[]): Promise<C>;
|
|
6
6
|
}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSVJlcG9zaXRvcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW50ZXJmYWNlcy9JUmVwb3NpdG9yeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTW9kZWwsIE1vZGVsQ29uc3RydWN0b3IgfSBmcm9tIFwiQGRlY2FmLXRzL2RlY29yYXRvci12YWxpZGF0aW9uXCI7XG5pbXBvcnQgeyBCdWxrQ3J1ZE9wZXJhdG9yIH0gZnJvbSBcIi4vQnVsa0NydWRPcGVyYXRvclwiO1xuaW1wb3J0IHsgUmVwb3NpdG9yeUZsYWdzIH0gZnJvbSBcIi4uL3JlcG9zaXRvcnkvdHlwZXNcIjtcbmltcG9ydCB7IENvbnRleHQgfSBmcm9tIFwiLi4vcmVwb3NpdG9yeVwiO1xuXG4vKipcbiAqIEBzdW1tYXJ5IEludGVyZmFjZSBob2xkaW5nIGJhc2ljIENSVUQgQVBJc1xuICogQHR5cGVkZWYgVCBleHRlbmRzIHtAbGluayBNb2RlbH1cbiAqIEBpbnRlcmZhY2UgSVJlcG9zaXRvcnlcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBJUmVwb3NpdG9yeTxcbiAgTSBleHRlbmRzIE1vZGVsLFxuICBGIGV4dGVuZHMgUmVwb3NpdG9yeUZsYWdzID0gUmVwb3NpdG9yeUZsYWdzLFxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLXVudXNlZC12YXJzXG4gIEMgZXh0ZW5kcyBDb250ZXh0PEY+ID0gQ29udGV4dDxGPixcbj4gZXh0ZW5kcyBCdWxrQ3J1ZE9wZXJhdG9yPE0+IHtcbiAgcmVhZG9ubHkgY2xhc3M6IE1vZGVsQ29uc3RydWN0b3I8TT47XG4gIHJlYWRvbmx5IHBrOiBrZXlvZiBNO1xufVxuIl19
|
|
@@ -1,11 +1,13 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { Model, ModelConstructor } from "@decaf-ts/decorator-validation";
|
|
2
2
|
import { BulkCrudOperator } from "./BulkCrudOperator";
|
|
3
|
+
import { RepositoryFlags } from "../repository/types";
|
|
4
|
+
import { Context } from "../repository";
|
|
3
5
|
/**
|
|
4
6
|
* @summary Interface holding basic CRUD APIs
|
|
5
7
|
* @typedef T extends {@link Model}
|
|
6
8
|
* @interface IRepository
|
|
7
9
|
*/
|
|
8
|
-
export interface IRepository<M extends Model> extends BulkCrudOperator<M> {
|
|
9
|
-
readonly class:
|
|
10
|
-
readonly pk:
|
|
10
|
+
export interface IRepository<M extends Model, F extends RepositoryFlags = RepositoryFlags, C extends Context<F> = Context<F>> extends BulkCrudOperator<M> {
|
|
11
|
+
readonly class: ModelConstructor<M>;
|
|
12
|
+
readonly pk: keyof M;
|
|
11
13
|
}
|
package/lib/interfaces/index.cjs
CHANGED
|
@@ -18,4 +18,4 @@ __exportStar(require("./BulkCrudOperator.cjs"), exports);
|
|
|
18
18
|
__exportStar(require("./Contextual.cjs"), exports);
|
|
19
19
|
__exportStar(require("./CrudOperator.cjs"), exports);
|
|
20
20
|
__exportStar(require("./IRepository.cjs"), exports);
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW50ZXJmYWNlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEseURBQW1DO0FBQ25DLG1EQUE2QjtBQUM3QixxREFBK0I7QUFDL0Isb0RBQThCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vQnVsa0NydWRPcGVyYXRvclwiO1xuZXhwb3J0ICogZnJvbSBcIi4vQ29udGV4dHVhbFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vQ3J1ZE9wZXJhdG9yXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9JUmVwb3NpdG9yeVwiO1xuIl19
|
package/lib/model/constants.cjs
CHANGED
|
@@ -18,6 +18,7 @@ exports.DBKeys = {
|
|
|
18
18
|
SERIALIZE: "serialize",
|
|
19
19
|
READONLY: "readonly",
|
|
20
20
|
TIMESTAMP: "timestamp",
|
|
21
|
+
TRANSIENT: "transient",
|
|
21
22
|
HASH: "hash",
|
|
22
23
|
COMPOSED: "composed",
|
|
23
24
|
VERSION: "version",
|
|
@@ -39,4 +40,4 @@ exports.DefaultSeparator = "_";
|
|
|
39
40
|
* @memberOf module:db-decorators.Model
|
|
40
41
|
*/
|
|
41
42
|
exports.DEFAULT_TIMESTAMP_FORMAT = "dd/MM/yyyy HH:mm:ss:S";
|
|
42
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL21vZGVsL2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSx5RUFBMkQ7QUFFM0Q7Ozs7O0dBS0c7QUFDVSxRQUFBLE1BQU0sR0FBRztJQUNwQixPQUFPLEVBQUUsR0FBRyxnQ0FBUyxDQUFDLE9BQU8sY0FBYztJQUMzQyxVQUFVLEVBQUUsWUFBWTtJQUN4QixLQUFLLEVBQUUsUUFBUTtJQUNmLEVBQUUsRUFBRSxJQUFJO0lBQ1IsS0FBSyxFQUFFLE9BQU87SUFDZCxNQUFNLEVBQUUsUUFBUTtJQUNoQixTQUFTLEVBQUUsV0FBVztJQUN0QixRQUFRLEVBQUUsVUFBVTtJQUNwQixTQUFTLEVBQUUsV0FBVztJQUN0QixTQUFTLEVBQUUsV0FBVztJQUN0QixJQUFJLEVBQUUsTUFBTTtJQUNaLFFBQVEsRUFBRSxVQUFVO0lBQ3BCLE9BQU8sRUFBRSxTQUFTO0lBQ2xCLFFBQVEsRUFBRSxlQUFlO0NBQzFCLENBQUM7QUFFRjs7Ozs7OztHQU9HO0FBQ1UsUUFBQSxnQkFBZ0IsR0FBRyxHQUFHLENBQUM7QUFFcEM7Ozs7O0dBS0c7QUFDVSxRQUFBLHdCQUF3QixHQUFHLHVCQUF1QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTW9kZWxLZXlzIH0gZnJvbSBcIkBkZWNhZi10cy9kZWNvcmF0b3ItdmFsaWRhdGlvblwiO1xuXG4vKipcbiAqIEBzdW1tYXJ5IEhvbGRzIHRoZSBNb2RlbCByZWZsZWN0aW9uIGtleXNcbiAqIEBjb25zdCBEQktleXNcbiAqXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRiLWRlY29yYXRvcnMuTW9kZWxcbiAqL1xuZXhwb3J0IGNvbnN0IERCS2V5cyA9IHtcbiAgUkVGTEVDVDogYCR7TW9kZWxLZXlzLlJFRkxFQ1R9cGVyc2lzdGVuY2UuYCxcbiAgUkVQT1NJVE9SWTogXCJyZXBvc2l0b3J5XCIsXG4gIENMQVNTOiBcIl9jbGFzc1wiLFxuICBJRDogXCJpZFwiLFxuICBJTkRFWDogXCJpbmRleFwiLFxuICBVTklRVUU6IFwidW5pcXVlXCIsXG4gIFNFUklBTElaRTogXCJzZXJpYWxpemVcIixcbiAgUkVBRE9OTFk6IFwicmVhZG9ubHlcIixcbiAgVElNRVNUQU1QOiBcInRpbWVzdGFtcFwiLFxuICBUUkFOU0lFTlQ6IFwidHJhbnNpZW50XCIsXG4gIEhBU0g6IFwiaGFzaFwiLFxuICBDT01QT1NFRDogXCJjb21wb3NlZFwiLFxuICBWRVJTSU9OOiBcInZlcnNpb25cIixcbiAgT1JJR0lOQUw6IFwiX19vcmlnaW5hbE9ialwiLFxufTtcblxuLyoqXG4gKiBAc3VtbWFyeSBUaGUgZGVmYXVsdCBzZXBhcmF0b3Igd2hlbiBjb25jYXRlbmF0aW5nIGluZGV4ZXNcbiAqXG4gKiBAY29uc3QgRGVmYXVsdEluZGV4U2VwYXJhdG9yXG4gKlxuICogQGNhdGVnb3J5IE1hbmFnZXJzXG4gKiBAc3ViY2F0ZWdvcnkgQ29uc3RhbnRzXG4gKi9cbmV4cG9ydCBjb25zdCBEZWZhdWx0U2VwYXJhdG9yID0gXCJfXCI7XG5cbi8qKlxuICogQHN1bW1hcnkgSG9sZHMgdGhlIGRlZmF1bHQgdGltZXN0YW1wIGRhdGUgZm9ybWF0XG4gKiBAY29uc3RhbnQgREVGQVVMVF9USU1FU1RBTVBfRk9STUFUXG4gKlxuICogQG1lbWJlck9mIG1vZHVsZTpkYi1kZWNvcmF0b3JzLk1vZGVsXG4gKi9cbmV4cG9ydCBjb25zdCBERUZBVUxUX1RJTUVTVEFNUF9GT1JNQVQgPSBcImRkL01NL3l5eXkgSEg6bW06c3M6U1wiO1xuIl19
|