rads-db 3.0.30 → 3.0.31
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/index.cjs +5 -0
- package/dist/index.d.ts +3 -1
- package/dist/index.mjs +5 -1
- package/features/eventSourcing.cjs +10 -0
- package/features/eventSourcing.mjs +10 -0
- package/integrations/lib.cjs +2 -0
- package/integrations/lib.mjs +3 -0
- package/package.json +1 -1
package/dist/index.cjs
CHANGED
|
@@ -1137,6 +1137,10 @@ function computed(meta) {
|
|
|
1137
1137
|
return function(a, b) {
|
|
1138
1138
|
};
|
|
1139
1139
|
}
|
|
1140
|
+
function keepHistory() {
|
|
1141
|
+
return function(a, b) {
|
|
1142
|
+
};
|
|
1143
|
+
}
|
|
1140
1144
|
|
|
1141
1145
|
function createRadsDb(args) {
|
|
1142
1146
|
args = { ...args };
|
|
@@ -1166,6 +1170,7 @@ exports.entity = entity;
|
|
|
1166
1170
|
exports.field = field;
|
|
1167
1171
|
exports.getDriverInstance = getDriverInstance;
|
|
1168
1172
|
exports.handlePrecomputed = handlePrecomputed;
|
|
1173
|
+
exports.keepHistory = keepHistory;
|
|
1169
1174
|
exports.merge = merge;
|
|
1170
1175
|
exports.precomputed = precomputed;
|
|
1171
1176
|
exports.ui = ui;
|
package/dist/index.d.ts
CHANGED
|
@@ -209,6 +209,7 @@ interface TypeDefinition {
|
|
|
209
209
|
handle?: string;
|
|
210
210
|
handlePlural?: string;
|
|
211
211
|
isExtending?: string;
|
|
212
|
+
keepHistoryFields: string[];
|
|
212
213
|
}
|
|
213
214
|
interface FileUploadResult {
|
|
214
215
|
url: string;
|
|
@@ -388,6 +389,7 @@ declare function validate<T, C, F>(args: T extends new () => any ? ValidateEntit
|
|
|
388
389
|
declare function field(meta?: FieldDecoratorArgs): (a: any, b?: ClassFieldDecoratorContext) => void;
|
|
389
390
|
declare function precomputed(meta?: ComputedDecoratorArgs): (a: any, b?: ClassFieldDecoratorContext | ClassDecoratorContext) => void;
|
|
390
391
|
declare function computed(meta?: ComputedDecoratorArgs): (a: any, b?: ClassFieldDecoratorContext | ClassDecoratorContext) => void;
|
|
392
|
+
declare function keepHistory(): (a: any, b?: ClassFieldDecoratorContext) => void;
|
|
391
393
|
|
|
392
394
|
declare function getDriverInstance(schema: Schema, key: string, driverConstructor: DriverConstructor, driverInstances: Record<string, Driver>): Driver;
|
|
393
395
|
|
|
@@ -412,4 +414,4 @@ declare function createRadsDb(args?: CreateRadsDbArgs): RadsDb;
|
|
|
412
414
|
*/
|
|
413
415
|
declare function createRadsDbClient(args?: CreateRadsDbClientArgs): RadsDb;
|
|
414
416
|
|
|
415
|
-
export { Change, ComputedContext, ComputedContextGlobal, ComputedDecoratorArgs, CreateRadsArgsDrivers, CreateRadsDbArgs, CreateRadsDbArgsNormalized, CreateRadsDbClientArgs, DeepPartial, Driver, DriverConstructor, EntityDecoratorArgs, EntityMethods, EnumDefinition, FieldDecoratorArgs, FieldDefinition, FileSystemNode, FileUploadArgs, FileUploadDriver, FileUploadResult, GenerateClientNormalizedOptions, GenerateClientOptions, GetAggArgs, GetAggArgsAgg, GetAggArgsAny, GetAggResponse, GetArgs, GetArgsAny, GetArgsInclude, GetManyArgs, GetManyArgsAny, GetManyResponse, GetResponse, GetResponseInclude, GetResponseIncludeSelect, GetResponseNoInclude, GetRestRoutesArgs, GetRestRoutesOptions, GetRestRoutesResponse, MinimalDriver, PutArgs, PutEffect, RadsFeature, RadsRequestContext, RadsUiSlotDefinition, RadsUiSlotName, RadsVitePluginOptions, Relation, RequiredFields, RestDriverOptions, RestFileUploadDriverOptions, Schema, SchemaValidators, TypeDefinition, UiDecoratorArgs, UiFieldDecoratorArgs, ValidateEntityDecoratorArgs, ValidateFieldDecoratorArgs, ValidateStringDecoratorArgs, VerifyManyArgs, VerifyManyArgsAny, VerifyManyResponse, cleanUndefinedAndNull, computed, createRadsDb, createRadsDbClient, diff, entity, field, getDriverInstance, handlePrecomputed, merge, precomputed, ui, validate };
|
|
417
|
+
export { Change, ComputedContext, ComputedContextGlobal, ComputedDecoratorArgs, CreateRadsArgsDrivers, CreateRadsDbArgs, CreateRadsDbArgsNormalized, CreateRadsDbClientArgs, DeepPartial, Driver, DriverConstructor, EntityDecoratorArgs, EntityMethods, EnumDefinition, FieldDecoratorArgs, FieldDefinition, FileSystemNode, FileUploadArgs, FileUploadDriver, FileUploadResult, GenerateClientNormalizedOptions, GenerateClientOptions, GetAggArgs, GetAggArgsAgg, GetAggArgsAny, GetAggResponse, GetArgs, GetArgsAny, GetArgsInclude, GetManyArgs, GetManyArgsAny, GetManyResponse, GetResponse, GetResponseInclude, GetResponseIncludeSelect, GetResponseNoInclude, GetRestRoutesArgs, GetRestRoutesOptions, GetRestRoutesResponse, MinimalDriver, PutArgs, PutEffect, RadsFeature, RadsRequestContext, RadsUiSlotDefinition, RadsUiSlotName, RadsVitePluginOptions, Relation, RequiredFields, RestDriverOptions, RestFileUploadDriverOptions, Schema, SchemaValidators, TypeDefinition, UiDecoratorArgs, UiFieldDecoratorArgs, ValidateEntityDecoratorArgs, ValidateFieldDecoratorArgs, ValidateStringDecoratorArgs, VerifyManyArgs, VerifyManyArgsAny, VerifyManyResponse, cleanUndefinedAndNull, computed, createRadsDb, createRadsDbClient, diff, entity, field, getDriverInstance, handlePrecomputed, keepHistory, merge, precomputed, ui, validate };
|
package/dist/index.mjs
CHANGED
|
@@ -1129,6 +1129,10 @@ function computed(meta) {
|
|
|
1129
1129
|
return function(a, b) {
|
|
1130
1130
|
};
|
|
1131
1131
|
}
|
|
1132
|
+
function keepHistory() {
|
|
1133
|
+
return function(a, b) {
|
|
1134
|
+
};
|
|
1135
|
+
}
|
|
1132
1136
|
|
|
1133
1137
|
function createRadsDb(args) {
|
|
1134
1138
|
args = { ...args };
|
|
@@ -1149,4 +1153,4 @@ function createRadsDbClient(args) {
|
|
|
1149
1153
|
return generateMethods(s, validators, radsDbArgs);
|
|
1150
1154
|
}
|
|
1151
1155
|
|
|
1152
|
-
export { cleanUndefinedAndNull, computed, createRadsDb, createRadsDbClient, diff, entity, field, getDriverInstance, handlePrecomputed, merge, precomputed, ui, validate };
|
|
1156
|
+
export { cleanUndefinedAndNull, computed, createRadsDb, createRadsDbClient, diff, entity, field, getDriverInstance, handlePrecomputed, keepHistory, merge, precomputed, ui, validate };
|
|
@@ -69,6 +69,7 @@ function verifyEventSourcingSetup(schema, effects) {
|
|
|
69
69
|
}, ev.change));
|
|
70
70
|
ev.beforeChange = aggDoc;
|
|
71
71
|
ev.change = (0, _radsDb.diff)(newAggDoc, aggDoc);
|
|
72
|
+
keepHistory(schema[entityName].keepHistoryFields, newAggDoc, ev);
|
|
72
73
|
aggDoc = newAggDoc;
|
|
73
74
|
if (!context.options.keepNulls) (0, _radsDb.cleanUndefinedAndNull)(aggDoc);
|
|
74
75
|
}
|
|
@@ -96,6 +97,15 @@ function verifyEventSourcingSetup(schema, effects) {
|
|
|
96
97
|
});
|
|
97
98
|
}
|
|
98
99
|
}
|
|
100
|
+
function keepHistory(keepHistoryFields, newAggDoc, eventChange) {
|
|
101
|
+
if (keepHistoryFields && newAggDoc) {
|
|
102
|
+
keepHistoryFields.forEach(prop => {
|
|
103
|
+
if (!eventChange.change[prop]) {
|
|
104
|
+
eventChange.change[prop] = newAggDoc[prop];
|
|
105
|
+
}
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
}
|
|
99
109
|
function validateEventSourcingSetup(schema, entityName, eventEntityName, aggregateRelationField) {
|
|
100
110
|
const eventEntity = schema[eventEntityName];
|
|
101
111
|
if (!eventEntity) throw new Error(`You must create entity with name "${eventEntityName}" to use eventSourcing feature with "${entityName}"`);
|
|
@@ -63,6 +63,7 @@ function verifyEventSourcingSetup(schema, effects) {
|
|
|
63
63
|
const newAggDoc = context.validators[entityName](merge(aggDoc || { id: aggId }, ev.change));
|
|
64
64
|
ev.beforeChange = aggDoc;
|
|
65
65
|
ev.change = diff(newAggDoc, aggDoc);
|
|
66
|
+
keepHistory(schema[entityName].keepHistoryFields, newAggDoc, ev);
|
|
66
67
|
aggDoc = newAggDoc;
|
|
67
68
|
if (!context.options.keepNulls)
|
|
68
69
|
cleanUndefinedAndNull(aggDoc);
|
|
@@ -84,6 +85,15 @@ function verifyEventSourcingSetup(schema, effects) {
|
|
|
84
85
|
});
|
|
85
86
|
}
|
|
86
87
|
}
|
|
88
|
+
function keepHistory(keepHistoryFields, newAggDoc, eventChange) {
|
|
89
|
+
if (keepHistoryFields && newAggDoc) {
|
|
90
|
+
keepHistoryFields.forEach((prop) => {
|
|
91
|
+
if (!eventChange.change[prop]) {
|
|
92
|
+
eventChange.change[prop] = newAggDoc[prop];
|
|
93
|
+
}
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
}
|
|
87
97
|
function validateEventSourcingSetup(schema, entityName, eventEntityName, aggregateRelationField) {
|
|
88
98
|
const eventEntity = schema[eventEntityName];
|
|
89
99
|
if (!eventEntity)
|
package/integrations/lib.cjs
CHANGED
|
@@ -138,9 +138,11 @@ function fillComputedDefinitionsForType(result) {
|
|
|
138
138
|
const precomputedFields = _lodash.default.values(fields).filter(f => !!f.decorators?.precomputed).sort((f1, f2) => getOrder(f1) - getOrder(f2)).map(f => f.name);
|
|
139
139
|
const computedFields = _lodash.default.values(fields).filter(f => !!f.decorators?.computed).sort((f1, f2) => getOrder(f1) - getOrder(f2)).map(f => f.name);
|
|
140
140
|
const nestedTypeFields = _lodash.default.values(fields).filter(f => result[f.type] && result[f.type].fields && !result[f.type].decorators.entity).map(f => f.name);
|
|
141
|
+
const keepHistoryFields = _lodash.default.values(fields).filter(f => !!f.decorators?.keepHistory).sort((f1, f2) => getOrder(f1) - getOrder(f2)).map(f => f.name);
|
|
141
142
|
if (precomputedFields.length) type.precomputedFields = precomputedFields;
|
|
142
143
|
if (computedFields.length) type.computedFields = computedFields;
|
|
143
144
|
if (nestedTypeFields.length) type.nestedTypeFields = nestedTypeFields;
|
|
145
|
+
if (keepHistoryFields.length) type.keepHistoryFields = keepHistoryFields;
|
|
144
146
|
}
|
|
145
147
|
}
|
|
146
148
|
function getOrder(f) {
|
package/integrations/lib.mjs
CHANGED
|
@@ -112,12 +112,15 @@ function fillComputedDefinitionsForType(result) {
|
|
|
112
112
|
const precomputedFields = _.values(fields).filter((f) => !!f.decorators?.precomputed).sort((f1, f2) => getOrder(f1) - getOrder(f2)).map((f) => f.name);
|
|
113
113
|
const computedFields = _.values(fields).filter((f) => !!f.decorators?.computed).sort((f1, f2) => getOrder(f1) - getOrder(f2)).map((f) => f.name);
|
|
114
114
|
const nestedTypeFields = _.values(fields).filter((f) => result[f.type] && result[f.type].fields && !result[f.type].decorators.entity).map((f) => f.name);
|
|
115
|
+
const keepHistoryFields = _.values(fields).filter((f) => !!f.decorators?.keepHistory).sort((f1, f2) => getOrder(f1) - getOrder(f2)).map((f) => f.name);
|
|
115
116
|
if (precomputedFields.length)
|
|
116
117
|
type.precomputedFields = precomputedFields;
|
|
117
118
|
if (computedFields.length)
|
|
118
119
|
type.computedFields = computedFields;
|
|
119
120
|
if (nestedTypeFields.length)
|
|
120
121
|
type.nestedTypeFields = nestedTypeFields;
|
|
122
|
+
if (keepHistoryFields.length)
|
|
123
|
+
type.keepHistoryFields = keepHistoryFields;
|
|
121
124
|
}
|
|
122
125
|
}
|
|
123
126
|
function getOrder(f) {
|