@ditojs/server 0.271.0 → 0.274.0

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.
Files changed (86) hide show
  1. package/lib/app/Application.js +68 -25
  2. package/lib/app/SessionStore.js +3 -1
  3. package/lib/app/Validator.js +16 -2
  4. package/lib/app/index.js +7 -1
  5. package/lib/cli/console.js +14 -4
  6. package/lib/cli/db/createMigration.js +16 -4
  7. package/lib/cli/db/index.js +7 -1
  8. package/lib/cli/db/listAssetConfig.js +4 -2
  9. package/lib/cli/db/migrate.js +3 -3
  10. package/lib/cli/db/reset.js +3 -3
  11. package/lib/cli/db/rollback.js +3 -3
  12. package/lib/cli/db/seed.js +14 -6
  13. package/lib/cli/db/unlock.js +3 -3
  14. package/lib/cli/index.js +9 -5
  15. package/lib/controllers/AdminController.js +18 -6
  16. package/lib/controllers/CollectionController.js +15 -1
  17. package/lib/controllers/Controller.js +28 -4
  18. package/lib/controllers/ControllerAction.js +18 -6
  19. package/lib/controllers/RelationController.js +9 -3
  20. package/lib/controllers/UserController.js +15 -1
  21. package/lib/controllers/index.js +7 -1
  22. package/lib/decorators/index.js +7 -1
  23. package/lib/decorators/parameters.js +4 -2
  24. package/lib/decorators/returns.js +4 -2
  25. package/lib/errors/DatabaseError.js +5 -19
  26. package/lib/errors/ResponseError.js +4 -14
  27. package/lib/errors/index.js +7 -1
  28. package/lib/graph/DitoGraphProcessor.js +5 -1
  29. package/lib/graph/expression.js +5 -1
  30. package/lib/graph/graph.js +18 -2
  31. package/lib/graph/index.js +7 -1
  32. package/lib/index.js +7 -1
  33. package/lib/lib/index.js +7 -1
  34. package/lib/middleware/findRoute.js +7 -1
  35. package/lib/middleware/index.js +7 -1
  36. package/lib/middleware/logRequests.js +4 -4
  37. package/lib/mixins/AssetMixin.js +4 -4
  38. package/lib/mixins/SessionMixin.js +4 -4
  39. package/lib/mixins/TimeStampedMixin.js +4 -4
  40. package/lib/mixins/UserMixin.js +10 -4
  41. package/lib/mixins/index.js +7 -1
  42. package/lib/models/Model.js +41 -22
  43. package/lib/models/definitions/filters.js +9 -1
  44. package/lib/models/definitions/properties.js +7 -1
  45. package/lib/models/definitions/scopes.js +9 -1
  46. package/lib/models/index.js +7 -1
  47. package/lib/query/QueryBuilder.js +11 -1
  48. package/lib/query/QueryFilters.js +11 -1
  49. package/lib/query/index.js +7 -1
  50. package/lib/schema/formats/index.js +7 -1
  51. package/lib/schema/index.js +10 -2
  52. package/lib/schema/keywords/index.js +7 -1
  53. package/lib/schema/properties.js +11 -1
  54. package/lib/schema/relations.js +18 -4
  55. package/lib/services/index.js +7 -1
  56. package/lib/storage/DiskStorage.js +7 -1
  57. package/lib/storage/Storage.js +5 -1
  58. package/lib/storage/index.js +7 -1
  59. package/lib/utils/emitter.js +5 -1
  60. package/lib/utils/index.js +15 -1
  61. package/lib/utils/json.js +9 -0
  62. package/lib/utils/object.js +9 -3
  63. package/package.json +31 -31
  64. package/src/app/Application.js +40 -11
  65. package/src/app/Validator.js +2 -1
  66. package/src/cli/console.js +3 -3
  67. package/src/cli/db/createMigration.js +3 -3
  68. package/src/cli/db/listAssetConfig.js +3 -1
  69. package/src/cli/db/migrate.js +4 -4
  70. package/src/cli/db/reset.js +4 -4
  71. package/src/cli/db/rollback.js +4 -4
  72. package/src/cli/db/seed.js +6 -6
  73. package/src/cli/db/unlock.js +2 -2
  74. package/src/cli/index.js +3 -3
  75. package/src/controllers/AdminController.js +3 -2
  76. package/src/controllers/Controller.js +8 -8
  77. package/src/controllers/ControllerAction.js +7 -5
  78. package/src/controllers/RelationController.js +2 -2
  79. package/src/decorators/parameters.js +2 -2
  80. package/src/decorators/returns.js +2 -2
  81. package/src/errors/DatabaseError.js +2 -23
  82. package/src/errors/ResponseError.js +1 -8
  83. package/src/middleware/logRequests.js +9 -9
  84. package/src/models/Model.js +13 -8
  85. package/src/utils/index.js +1 -0
  86. package/src/utils/json.js +3 -0
@@ -3,8 +3,24 @@
3
3
  exports.__esModule = true;
4
4
  exports.Model = void 0;
5
5
 
6
+ require("core-js/modules/esnext.async-iterator.for-each.js");
7
+
8
+ require("core-js/modules/esnext.iterator.constructor.js");
9
+
10
+ require("core-js/modules/esnext.iterator.for-each.js");
11
+
12
+ require("core-js/modules/esnext.async-iterator.reduce.js");
13
+
14
+ require("core-js/modules/esnext.iterator.reduce.js");
15
+
16
+ require("core-js/modules/esnext.async-iterator.filter.js");
17
+
18
+ require("core-js/modules/esnext.iterator.filter.js");
19
+
6
20
  require("core-js/modules/esnext.weak-map.delete-all.js");
7
21
 
22
+ require("core-js/modules/esnext.weak-map.emplace.js");
23
+
8
24
  var _objection = _interopRequireDefault(require("objection"));
9
25
 
10
26
  var _query = require("../query");
@@ -15,9 +31,11 @@ var _schema = require("../schema");
15
31
 
16
32
  var _graph = require("../graph");
17
33
 
34
+ var _utils = require("../utils");
35
+
18
36
  var _errors = require("../errors");
19
37
 
20
- var _utils = require("@ditojs/utils");
38
+ var _utils2 = require("@ditojs/utils");
21
39
 
22
40
  var _RelationAccessor = _interopRequireDefault(require("./RelationAccessor"));
23
41
 
@@ -170,7 +188,7 @@ class Model extends _objection.default.Model {
170
188
  return shallow ? inputJson.$set(result) : result;
171
189
  };
172
190
 
173
- return (0, _utils.isPromise)(result) ? result.then(handleResult) : handleResult(result);
191
+ return (0, _utils2.isPromise)(result) ? result.then(handleResult) : handleResult(result);
174
192
  }
175
193
 
176
194
  async $validateGraph(options = {}) {
@@ -194,7 +212,7 @@ class Model extends _objection.default.Model {
194
212
 
195
213
  static query(trx) {
196
214
  return super.query(trx).onError(err => {
197
- err = err instanceof _errors.ResponseError ? err : err instanceof _objection.default.DBError ? new _errors.DatabaseError(err) : new _errors.WrappedError(err);
215
+ err = err instanceof _errors.ResponseError ? err : err instanceof _objection.default.DBError ? this.app.createDatabaseError(err) : new _errors.WrappedError(err);
198
216
  return Promise.reject(err);
199
217
  });
200
218
  }
@@ -232,7 +250,7 @@ class Model extends _objection.default.Model {
232
250
  const ref = new this();
233
251
  const idProperties = this.getIdPropertyArray();
234
252
 
235
- if ((0, _utils.isObject)(modelOrId)) {
253
+ if ((0, _utils2.isObject)(modelOrId)) {
236
254
  const addProperty = key => {
237
255
  const value = modelOrId[key];
238
256
 
@@ -245,10 +263,10 @@ class Model extends _objection.default.Model {
245
263
  idProperties.forEach(addProperty);
246
264
  includeProperties == null ? void 0 : includeProperties.forEach(addProperty);
247
265
  } else {
248
- const ids = (0, _utils.asArray)(modelOrId);
266
+ const ids = (0, _utils2.asArray)(modelOrId);
249
267
 
250
268
  if (ids.length !== idProperties.length) {
251
- throw new _errors.ModelError(this, `Invalid amount of id values provided for reference: Unable to map ${JSON.stringify(modelOrId)} to ${JSON.stringify(idProperties)}.`);
269
+ throw new _errors.ModelError(this, `Invalid amount of id values provided for reference: Unable to map ${(0, _utils.formatJson)(modelOrId, false)} to ${(0, _utils.formatJson)(idProperties, false)}.`);
252
270
  }
253
271
 
254
272
  idProperties.forEach((key, index) => {
@@ -310,7 +328,7 @@ class Model extends _objection.default.Model {
310
328
  return this._getCached('jsonSchema', () => {
311
329
  const schema = (0, _schema.convertSchema)(this.definition.properties);
312
330
  (0, _schema.addRelationSchemas)(this, schema.properties);
313
- (0, _utils.merge)(schema, this.definition.schema);
331
+ (0, _utils2.merge)(schema, this.definition.schema);
314
332
  return {
315
333
  $id: this.name,
316
334
  $schema: 'http://json-schema.org/draft-07/schema',
@@ -486,7 +504,7 @@ class Model extends _objection.default.Model {
486
504
  const date = json[key];
487
505
 
488
506
  if (date !== undefined) {
489
- json[key] = (0, _utils.isString)(date) ? new Date(date) : date;
507
+ json[key] = (0, _utils2.isString)(date) ? new Date(date) : date;
490
508
  }
491
509
  }
492
510
 
@@ -497,12 +515,12 @@ class Model extends _objection.default.Model {
497
515
  if (assets) {
498
516
  for (const dataPath in assets) {
499
517
  const storage = constructor.app.getStorage(assets[dataPath].storage);
500
- const data = (0, _utils.getValueAtDataPath)(json, dataPath, () => null);
518
+ const data = (0, _utils2.getValueAtDataPath)(json, dataPath, () => null);
501
519
 
502
520
  if (data) {
503
521
  const convertToAssetFiles = data => {
504
522
  if (data) {
505
- if ((0, _utils.isArray)(data)) {
523
+ if ((0, _utils2.isArray)(data)) {
506
524
  data.forEach(convertToAssetFiles);
507
525
  } else {
508
526
  storage.convertAssetFile(data);
@@ -557,15 +575,15 @@ class Model extends _objection.default.Model {
557
575
  }
558
576
 
559
577
  static getPropertyOrRelationAtDataPath(dataPath) {
560
- const parsedDataPath = (0, _utils.parseDataPath)(dataPath);
578
+ const parsedDataPath = (0, _utils2.parseDataPath)(dataPath);
561
579
  let index = 0;
562
580
 
563
581
  const getResult = (property = null, relation = null) => {
564
582
  const found = property || relation;
565
583
  const name = parsedDataPath[index];
566
584
  const next = index + 1;
567
- const dataPath = found ? (0, _utils.normalizeDataPath)(parsedDataPath.slice(0, next)) : null;
568
- const nestedDataPath = found ? (0, _utils.normalizeDataPath)(parsedDataPath.slice(next)) : null;
585
+ const dataPath = found ? (0, _utils2.normalizeDataPath)(parsedDataPath.slice(0, next)) : null;
586
+ const nestedDataPath = found ? (0, _utils2.normalizeDataPath)(parsedDataPath.slice(next)) : null;
569
587
  const expression = found ? parsedDataPath.slice(0, relation ? next : index).join('.') + (property ? `(#${name})` : '') : null;
570
588
  return {
571
589
  property,
@@ -628,7 +646,7 @@ class Model extends _objection.default.Model {
628
646
  }
629
647
 
630
648
  static modifierNotFound(query, modifier) {
631
- if ((0, _utils.isString)(modifier)) {
649
+ if ((0, _utils2.isString)(modifier)) {
632
650
  if (query.modelClass().hasScope(modifier)) {
633
651
  return query.applyScope(modifier);
634
652
  }
@@ -667,9 +685,10 @@ class Model extends _objection.default.Model {
667
685
  case 'ModelValidation':
668
686
  return this.app.createValidationError({
669
687
  type,
670
- message: message || `The provided data for the ${this.name} model is not valid: ${JSON.stringify(json)}`,
688
+ message: message || `The provided data for the ${this.name} model is not valid`,
671
689
  errors,
672
- options
690
+ options,
691
+ json
673
692
  });
674
693
 
675
694
  case 'RelationExpression':
@@ -900,7 +919,7 @@ function getMeta(modelClass, key, value) {
900
919
  }
901
920
 
902
921
  if (!(key in meta)) {
903
- meta[key] = (0, _utils.isFunction)(value) ? value() : value;
922
+ meta[key] = (0, _utils2.isFunction)(value) ? value() : value;
904
923
  }
905
924
 
906
925
  return meta[key];
@@ -911,14 +930,14 @@ function loadAssetDataPaths(query, dataPaths) {
911
930
  }
912
931
 
913
932
  function getValueAtAssetDataPath(item, path) {
914
- return (0, _utils.getValueAtDataPath)(item, path, () => undefined);
933
+ return (0, _utils2.getValueAtDataPath)(item, path, () => undefined);
915
934
  }
916
935
 
917
936
  function getFilesPerAssetDataPath(items, dataPaths) {
918
937
  return dataPaths.reduce((allFiles, dataPath) => {
919
- allFiles[dataPath] = (0, _utils.asArray)(items).reduce((files, item) => {
920
- const data = (0, _utils.asArray)(getValueAtAssetDataPath(item, dataPath));
921
- files.push(...(0, _utils.flatten)(data).filter(file => !!file));
938
+ allFiles[dataPath] = (0, _utils2.asArray)(items).reduce((files, item) => {
939
+ const data = (0, _utils2.asArray)(getValueAtAssetDataPath(item, dataPath));
940
+ files.push(...(0, _utils2.flatten)(data).filter(file => !!file));
922
941
  return files;
923
942
  }, []);
924
943
  return allFiles;
@@ -931,4 +950,4 @@ function mapFilesByKey(files) {
931
950
  return map;
932
951
  }, {});
933
952
  }
934
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/models/Model.js"],"names":["Model","objection","constructor","json","$setJson","setup","knex","relation","Object","values","getRelations","setupRelation","error","RelationError","referenceValidator","relatedModelClass","getRelatedRelations","push","accessor","name","prototype","defineAccessor","target","isClass","defineProperty","get","value","RelationAccessor","configurable","enumerable","initialize","hooks","assets","definition","_setupEmitter","_setupAssetsEvents","$initialize","$app","app","$is","model","id","$has","properties","property","$update","trx","$query","update","runAfter","result","query","has","$set","$patch","patch","$transaction","handler","transaction","$validate","options","skipValidation","graph","async","inputJson","shallow","$isObjectionModel","clone","mutable","validator","getValidator","args","ctx","create","beforeValidate","validate","handleResult","afterValidate","then","$validateGraph","fromJson","onError","err","ResponseError","DBError","DatabaseError","WrappedError","Promise","reject","count","first","tableName","match","idColumn","ids","entries","primary","length","getReference","modelOrId","includeProperties","ref","idProperties","getIdPropertyArray","addProperty","key","undefined","uidRefProp","forEach","ModelError","JSON","stringify","index","isReference","obj","compileValidator","oneOf","type","reduce","idProperty","additionalProperties","throw","getScope","scopes","hasScope","getModifiers","modifiers","relationMappings","_getCached","relations","models","jsonSchema","schema","$id","$schema","virtualAttributes","computedAttributes","jsonAttributes","getAttributes","specificType","computed","booleanAttributes","dateAttributes","includes","hiddenAttributes","hidden","filter","attributes","identifier","calculate","empty","cache","getMeta","entry","part","split","propertyNameToColumnName","propertyName","columnNameToPropertyName","columnName","callInitialize","$formatDatabaseJson","date","toISOString","isSQLite","bool","$parseDatabaseJson","$parseJson","Date","dataPath","storage","getStorage","data","convertToAssetFiles","convertAssetFile","$formatJson","$filterGraph","modelGraph","expr","$populateGraph","filterGraph","populateGraph","getPropertyOrRelationAtDataPath","parsedDataPath","getResult","found","next","slice","nestedDataPath","expression","join","firstToken","otherTokens","token","isOneToOne","relatedQuery","relationName","alias","modifierNotFound","modifier","modelClass","applyScope","ignoreScope","select","createNotFoundError","NotFoundError","byId","createValidator","createValidationError","message","errors","GraphError","setDefinition","getDefinition","desc","getOwnPropertyDescriptor","call","getPrototypeOf","merged","definitions","$emit","event","emit","beforeFind","_emitStaticHook","afterFind","beforeInsert","afterInsert","beforeUpdate","afterUpdate","beforeDelete","afterDelete","originalArgs","listeners","listener","res","assetDataPaths","keys","on","inputItems","asFindQuery","afterItems","dataPaths","path","getValueAtAssetDataPath","beforeItems","loadAssetDataPaths","beforeFilesPerDataPath","getFilesPerAssetDataPath","afterFilesPerDataPath","importedFiles","modifiedFiles","rollback","setMaxListeners","console","info","map","file","all","removeFile","beforeFiles","afterFiles","beforeByKey","mapFilesByKey","afterByKey","removedFiles","addedFiles","handleAdddedAndRemovedAssets","handleModifiedAssets","QueryBuilder","cloneObjectAttributes","pickJsonSchemaProperties","useLimitInFirst","EventEmitter","mixin","KnexHelper","metaMap","WeakMap","meta","set","loadDataPath","item","items","allFiles","files"],"mappings":"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","sourcesContent":["import objection from 'objection'\nimport { QueryBuilder } from '@/query'\nimport { EventEmitter, KnexHelper } from '@/lib'\nimport { convertSchema, addRelationSchemas, convertRelations } from '@/schema'\nimport { populateGraph, filterGraph } from '@/graph'\nimport {\n  ResponseError, DatabaseError, GraphError, ModelError, NotFoundError,\n  RelationError, WrappedError\n} from '@/errors'\nimport {\n  isString, isObject, isArray, isFunction, isPromise, asArray, merge, flatten,\n  parseDataPath, normalizeDataPath, getValueAtDataPath\n} from '@ditojs/utils'\nimport RelationAccessor from './RelationAccessor'\nimport definitions from './definitions'\n\nexport class Model extends objection.Model {\n  // Define a default constructor to allow new Model(json) as a short-cut to\n  // `Model.fromJson(json, { skipValidation: true })`\n  constructor(json) {\n    super()\n    if (json) {\n      this.$setJson(json)\n    }\n  }\n\n  static setup(knex) {\n    this.knex(knex)\n    try {\n      for (const relation of Object.values(this.getRelations())) {\n        this.setupRelation(relation)\n      }\n    } catch (error) {\n      throw error instanceof RelationError ? error : new RelationError(error)\n    }\n    this.referenceValidator = null\n  }\n\n  static setupRelation(relation) {\n    // Add this relation to the related model's relatedRelations, so it can\n    // register all required foreign keys in its properties.\n    relation.relatedModelClass.getRelatedRelations().push(relation)\n    // TODO: Check `through` settings to make sure they're correct?\n\n    // Expose RelationAccessor instances for each relation under short-cut $name\n    // for access to relations and implicit calls to $relatedQuery(name).\n    const accessor = `$${relation.name}`\n    if (accessor in this.prototype) {\n      throw new RelationError(\n        `Model '${this.name}' already defines a property with name ` +\n        `'${accessor}' that clashes with the relation accessor.`)\n    }\n\n    // Define an accessor on the class as well as on the prototype that when\n    // first called creates a RelationAccessor instance and then overrides the\n    // accessor with one that then just returns the same value afterwards.\n    const defineAccessor = (target, isClass) => {\n      Object.defineProperty(target, accessor, {\n        get() {\n          const value = new RelationAccessor(\n            relation,\n            isClass ? this : null, // modelClass\n            isClass ? null : this // model\n          )\n          // Override accessor with value on first call for caching.\n          Object.defineProperty(this, accessor, {\n            value,\n            configurable: true,\n            enumerable: false\n          })\n          return value\n        },\n        configurable: true,\n        enumerable: false\n      })\n    }\n\n    defineAccessor(this, true)\n    defineAccessor(this.prototype, false)\n  }\n\n  // @overridable\n  static initialize() {\n    const { hooks, assets } = this.definition\n    this._setupEmitter(hooks)\n    if (assets) {\n      this._setupAssetsEvents(assets)\n    }\n  }\n\n  // @overridable\n  $initialize() {\n  }\n\n  get $app() {\n    return this.constructor.app\n  }\n\n  $is(model) {\n    return model?.constructor === this.constructor && model?.id === this.id\n  }\n\n  $has(...properties) {\n    for (const property of properties) {\n      if (!(property in this)) return false\n    }\n    return true\n  }\n\n  $update(properties, trx) {\n    return this.$query(trx)\n      .update(properties)\n      .runAfter((result, query) =>\n        // Only perform `$set()` and return `this` if the query wasn't modified\n        // in a way that would remove the `update()` command, e.g. toFindQuery()\n        query.has('update') ? this.$set(result) : result\n      )\n  }\n\n  $patch(properties, trx) {\n    return this.$query(trx)\n      .patch(properties)\n      .runAfter((result, query) =>\n        // Only perform `$set()` and return `this` if the query wasn't modified\n        // in a way that would remove the `patch()` command, e.g. toFindQuery()\n        query.has('patch') ? this.$set(result) : result\n      )\n  }\n\n  // @override\n  $transaction(trx, handler) {\n    return this.constructor.transaction(trx, handler)\n  }\n\n  // @override\n  static transaction(trx, handler) {\n    // Support both `transaction(trx, handler)` & `transaction(handler)`\n    if (!handler) {\n      handler = trx\n      trx = null\n    }\n    if (handler) {\n      // Use existing transaction, or create new one, to execute handler with:\n      return trx\n        ? handler(trx)\n        : this.knex().transaction(handler)\n    } else {\n      // No arguments, simply delegate to objection's transaction()\n      return super.transaction()\n    }\n  }\n\n  // @override\n  $validate(json, options = {}) {\n    if (options.skipValidation) {\n      return json\n    }\n    if (!options.graph && !options.async) {\n      // Fall back to Objection's $validate() if we don't need any of our\n      // extensions (async and graph for now):\n      return super.$validate(json, options)\n    }\n    json = json || this\n    const inputJson = json\n    const shallow = json.$isObjectionModel && !options.graph\n    if (shallow) {\n      // Strip away relations and other internal stuff.\n      json = json.clone({ shallow: true })\n      // We can mutate `json` now that we took a copy of it.\n      options = { ...options, mutable: true }\n    }\n\n    const validator = this.constructor.getValidator()\n    const args = {\n      options,\n      model: this,\n      json,\n      ctx: Object.create(null)\n    }\n\n    validator.beforeValidate(args)\n    const result = validator.validate(args)\n    const handleResult = result => {\n      validator.afterValidate(args)\n      // If `json` was shallow-cloned, copy over the possible default values.\n      return shallow ? inputJson.$set(result) : result\n    }\n    // Handle both async and sync validation here:\n    return isPromise(result)\n      ? result.then(handleResult)\n      : handleResult(result)\n  }\n\n  async $validateGraph(options = {}) {\n    await this.$validate(null, {\n      ...options,\n      graph: true,\n      // Always use `async: true` option here for simplicity:\n      async: true\n    })\n    return this\n  }\n\n  // @override\n  static fromJson(json, options = {}) {\n    if (options.async && !options.skipValidation) {\n      // Handle async validation, as supported by Dito:\n      const model = new this()\n      return model.$validate(json, options).then(\n        json => model.$setJson(json, {\n          ...options,\n          skipValidation: true\n        })\n      )\n    }\n    // Fall back to Objection's fromJson() if we don't need async handling:\n    return super.fromJson(json, options)\n  }\n\n  // @override\n  static query(trx) {\n    return super.query(trx).onError(err => {\n      // TODO: Shouldn't this wrapping happen on the Controller level?\n      err = err instanceof ResponseError ? err\n        : err instanceof objection.DBError ? new DatabaseError(err)\n        : new WrappedError(err)\n      return Promise.reject(err)\n    })\n  }\n\n  static async count(...args) {\n    const { count } = await this.query().count(...args).first() || {}\n    return +count || 0\n  }\n\n  // @override\n  static get tableName() {\n    // If the class name ends in 'Model', remove that from the table name.\n    return this.name.match(/^(.*?)(?:Model|)$/)[1]\n  }\n\n  // @override\n  static get idColumn() {\n    // Try extracting the id column name from the raw properties definitions,\n    // not the resolved `definition.properties` which aren't ready at this point\n    // with fall-back onto default Objection.js behavior.\n    const { properties } = this\n    const ids = []\n    for (const [name, property] of Object.entries(properties || {})) {\n      if (property?.primary) {\n        ids.push(name)\n      }\n    }\n    const { length } = ids\n    return length > 1 ? ids : length > 0 ? ids[0] : super.idColumn\n  }\n\n  static getReference(modelOrId, includeProperties) {\n    // Creates a reference model that takes over the id / #ref properties from\n    // the passed model or id value/array, omitting any other properties in it,\n    // except for anything mentioned in the optional `includeProperties` arg.\n    const ref = new this()\n    const idProperties = this.getIdPropertyArray()\n    if (isObject(modelOrId)) {\n      const addProperty = key => {\n        const value = modelOrId[key]\n        if (value !== undefined) {\n          ref[key] = value\n        }\n      }\n      // Also support Objection's #ref type references next to id properties.\n      addProperty(this.uidRefProp)\n      idProperties.forEach(addProperty)\n      includeProperties?.forEach(addProperty)\n    } else {\n      // An id value/array: Map it to the properties in `getIdPropertyArray()`:\n      const ids = asArray(modelOrId)\n      if (ids.length !== idProperties.length) {\n        throw new ModelError(\n          this,\n          `Invalid amount of id values provided for reference: Unable to map ${\n            JSON.stringify(modelOrId)\n          } to ${\n            JSON.stringify(idProperties)\n          }.`\n        )\n      }\n      idProperties.forEach((key, index) => {\n        ref[key] = ids[index]\n      })\n    }\n    return ref\n  }\n\n  static isReference(obj) {\n    let validator = this.referenceValidator\n    if (!validator) {\n      // For `data` to be considered a reference, it needs to hold only one\n      // value that is either the target's id, or an Objection.js #ref value:\n      validator = this.referenceValidator = this.app.compileValidator(\n        {\n          oneOf: [\n            {\n              type: 'object',\n              // Support composite keys and add a property for each key:\n              properties: this.getIdPropertyArray().reduce(\n                (idProperties, idProperty) => {\n                  idProperties[idProperty] = {\n                    type: this.definition.properties[idProperty].type\n                  }\n                  return idProperties\n                },\n                {}\n              ),\n              additionalProperties: false\n            },\n            {\n              type: 'object',\n              properties: {\n                [this.uidRefProp]: {\n                  type: 'string'\n                }\n              },\n              additionalProperties: false\n            }\n          ]\n        },\n        // Receive `false` instead of thrown exceptions when validation fails:\n        { throw: false }\n      )\n    }\n    return validator(obj)\n  }\n\n  static getScope(name) {\n    return this.definition.scopes[name]\n  }\n\n  static hasScope(name) {\n    return !!this.getScope(name)\n  }\n\n  static getModifiers() {\n    return this.definition.modifiers\n  }\n\n  static get relationMappings() {\n    return this._getCached('relationMappings', () => (\n      convertRelations(this, this.definition.relations, this.app.models)\n    ), {})\n  }\n\n  static get jsonSchema() {\n    return this._getCached('jsonSchema', () => {\n      const schema = convertSchema(this.definition.properties)\n      addRelationSchemas(this, schema.properties)\n      // Merge in root-level schema additions\n      merge(schema, this.definition.schema)\n      return {\n        $id: this.name,\n        $schema: 'http://json-schema.org/draft-07/schema',\n        ...schema\n      }\n    }, {})\n  }\n\n  static get virtualAttributes() {\n    // Leverage Objection's own mechanism called `virtualAttributes` to handle\n    // `computedAttributes` when setting JSON data.\n    return this.computedAttributes\n  }\n\n  static get jsonAttributes() {\n    return this._getCached('jsonSchema:jsonAttributes', () => (\n      this.getAttributes(({ type, specificType, computed }) =>\n        !computed && !specificType && (type === 'object' || type === 'array'))\n    ), [])\n  }\n\n  static get booleanAttributes() {\n    return this._getCached('jsonSchema:booleanAttributes', () => (\n      this.getAttributes(({ type, computed }) =>\n        !computed && type === 'boolean')\n    ), [])\n  }\n\n  static get dateAttributes() {\n    return this._getCached('jsonSchema:dateAttributes', () => (\n      this.getAttributes(({ type, computed }) =>\n        !computed && ['date', 'datetime', 'timestamp'].includes(type))\n    ), [])\n  }\n\n  static get computedAttributes() {\n    return this._getCached('jsonSchema:computedAttributes', () => (\n      this.getAttributes(({ computed }) => computed)\n    ), [])\n  }\n\n  static get hiddenAttributes() {\n    return this._getCached('jsonSchema:hiddenAttributes', () => (\n      this.getAttributes(({ hidden }) => hidden)\n    ), [])\n  }\n\n  static getAttributes(filter) {\n    const attributes = []\n    const { properties } = this.definition\n    for (const [name, property] of Object.entries(properties)) {\n      if (filter(property)) {\n        attributes.push(name)\n      }\n    }\n    return attributes\n  }\n\n  static _getCached(identifier, calculate, empty = {}) {\n    let cache = getMeta(this, 'cache', {})\n    // Use a simple dependency tracking mechanism with cache identifiers that\n    // can be children of other cached values, e.g.:\n    // 'jsonSchema:jsonAttributes' as a child of 'jsonSchema', so that whenever\n    // 'jsonSchema' changes, all cached child values  are invalidated.\n    let entry\n    for (const part of identifier.split(':')) {\n      entry = cache[part] = cache[part] || {\n        cache: {},\n        value: undefined\n      }\n      cache = entry.cache\n    }\n    if (entry?.value === undefined) {\n      // Temporarily set cache to an empty object to prevent endless\n      // recursion with interdependent jsonSchema related calls...\n      entry.value = empty\n      entry.value = calculate()\n      // Clear child dependencies once parent value has changed:\n      entry.cache = {}\n    }\n    return entry?.value\n  }\n\n  static getRelatedRelations() {\n    return getMeta(this, 'relatedRelations', [])\n  }\n\n  // Override propertyNameToColumnName() / columnNameToPropertyName() to not\n  // rely on $formatDatabaseJson() /  $parseDatabaseJson() do detect naming\n  // conventions but assume simply that they're always the same.\n  // This is fine since we can now change naming at Knex level.\n  // See knexSnakeCaseMappers()\n\n  // @override\n  static propertyNameToColumnName(propertyName) {\n    return propertyName\n  }\n\n  // @override\n  static columnNameToPropertyName(columnName) {\n    return columnName\n  }\n\n  // @override\n  $setJson(json, options) {\n    options = options || {}\n    const callInitialize = (\n      // Only call initialize when:\n      // 1. we're not partially patching:\n      !options.patch &&\n      // 2. $initialize() is actually doing something:\n      this.$initialize !== Model.prototype.$initialize &&\n      // 3. the data is not just a reference:\n      !this.constructor.isReference(json)\n    )\n    if (!callInitialize || options.skipValidation) {\n      super.$setJson(json, options)\n      if (callInitialize) {\n        this.$initialize()\n      }\n    } else {\n      // If validation isn't skipped or the model provides its own $initialize()\n      // method, call $setJson() with patch validation first to not complain\n      // about missing fields, then perform a full validation after calling\n      // $initialize(), to give the model a chance to configure itself.\n      super.$setJson(json, { ...options, patch: true })\n      this.$initialize()\n      this.$validate(this, options)\n    }\n    return this\n  }\n\n  // @override\n  $formatDatabaseJson(json) {\n    const { constructor } = this\n    for (const key of constructor.dateAttributes) {\n      const date = json[key]\n      if (date?.toISOString) {\n        json[key] = date.toISOString()\n      }\n    }\n    if (constructor.isSQLite()) {\n      // SQLite does not support boolean natively and needs conversion...\n      for (const key of constructor.booleanAttributes) {\n        const bool = json[key]\n        if (bool !== undefined) {\n          json[key] = bool ? 1 : 0\n        }\n      }\n    }\n    // Remove the computed properties so they don't attempt to get set.\n    for (const key of constructor.computedAttributes) {\n      delete json[key]\n    }\n    // NOTE: No need to normalize the identifiers in the JSON in case of\n    // normalizeDbNames, as this already happens through\n    // knex.config.wrapIdentifier(), see Application.js\n    return super.$formatDatabaseJson(json)\n  }\n\n  // @override\n  $parseDatabaseJson(json) {\n    const { constructor } = this\n    json = super.$parseDatabaseJson(json)\n    if (constructor.isSQLite()) {\n      // SQLite does not support boolean natively and needs conversion...\n      for (const key of constructor.booleanAttributes) {\n        const bool = json[key]\n        if (bool !== undefined) {\n          json[key] = !!bool\n        }\n      }\n    }\n    // Also run through normal $parseJson(), for handling of `Date` and\n    // `AssetFile`.\n    return this.$parseJson(json)\n  }\n\n  // @override\n  $parseJson(json) {\n    const { constructor } = this\n    for (const key of constructor.dateAttributes) {\n      const date = json[key]\n      if (date !== undefined) {\n        json[key] = isString(date) ? new Date(date) : date\n      }\n    }\n    // Convert plain asset files objects to AssetFile instances with references\n    // to the linked storage.\n    const { assets } = constructor.definition\n    if (assets) {\n      for (const dataPath in assets) {\n        const storage = constructor.app.getStorage(assets[dataPath].storage)\n        const data = getValueAtDataPath(json, dataPath, () => null)\n        if (data) {\n          const convertToAssetFiles = data => {\n            if (data) {\n              if (isArray(data)) {\n                data.forEach(convertToAssetFiles)\n              } else {\n                storage.convertAssetFile(data)\n              }\n            }\n          }\n          convertToAssetFiles(data)\n        }\n      }\n    }\n    return json\n  }\n\n  // @override\n  $formatJson(json) {\n    const { constructor } = this\n    // Calculate and set the computed properties.\n    for (const key of constructor.computedAttributes) {\n      // Perhaps the computed property is produced in the SQL statement,\n      // in which case we don't have to do anything anymore here.\n      if (!(key in json)) {\n        const value = this[key]\n        if (value !== undefined) {\n          json[key] = value\n        }\n      }\n    }\n    // Remove hidden attributes.\n    for (const key of constructor.hiddenAttributes) {\n      delete json[key]\n    }\n    return json\n  }\n\n  // Graph handling\n\n  $filterGraph(modelGraph, expr) {\n    return filterGraph(this.constructor, modelGraph, expr)\n  }\n\n  async $populateGraph(modelGraph, expr, trx) {\n    return populateGraph(this.constructor, modelGraph, expr, trx)\n  }\n\n  static filterGraph(modelGraph, expr) {\n    return filterGraph(this, modelGraph, expr)\n  }\n\n  static async populateGraph(modelGraph, expr, trx) {\n    return populateGraph(this, modelGraph, expr, trx)\n  }\n\n  static getPropertyOrRelationAtDataPath(dataPath) {\n    // Finds the property or relation at the given the dataPath of the model by\n    // parsing the dataPath and matching it to its relations and properties.\n    const parsedDataPath = parseDataPath(dataPath)\n    let index = 0\n\n    const getResult = (property = null, relation = null) => {\n      const found = property || relation\n      const name = parsedDataPath[index]\n      const next = index + 1\n      const dataPath = found\n        ? normalizeDataPath(parsedDataPath.slice(0, next))\n        : null\n      const nestedDataPath = found\n        ? normalizeDataPath(parsedDataPath.slice(next))\n        : null\n      const expression = found\n        ? parsedDataPath.slice(0, relation ? next : index).join('.') +\n          (property ? `(#${name})` : '')\n        : null\n      return {\n        property,\n        relation,\n        dataPath,\n        nestedDataPath,\n        name,\n        expression,\n        index\n      }\n    }\n\n    const [firstToken, ...otherTokens] = parsedDataPath\n    const property = this.definition.properties[firstToken]\n    if (property) {\n      return getResult(property)\n    } else {\n      let relation = this.getRelations()[firstToken]\n      if (relation) {\n        let { relatedModelClass } = relation\n        for (const token of otherTokens) {\n          index++\n          const property = relatedModelClass.definition.properties[token]\n          if (property) {\n            return getResult(property)\n          } else if (token === '*') {\n            if (relation.isOneToOne()) {\n              // Do not support wildcards on one-to-one relations:\n              return getResult()\n            } else {\n              continue\n            }\n          } else {\n            // Found a relation? Keep iterating.\n            relation = relatedModelClass.getRelations()[token]\n            if (relation) {\n              relatedModelClass = relation.relatedModelClass\n            } else {\n              return getResult()\n            }\n          }\n        }\n        if (relation) {\n          // Still here? Found a relation at the end of the data-path.\n          return getResult(null, relation)\n        }\n      }\n    }\n    return getResult()\n  }\n\n  // @override\n  static relatedQuery(relationName, trx) {\n    // https://github.com/Vincit/objection.js/issues/1720\n    return super.relatedQuery(relationName, trx).alias(relationName)\n  }\n\n  // @override\n  static modifierNotFound(query, modifier) {\n    if (isString(modifier)) {\n      if (query.modelClass().hasScope(modifier)) {\n        return query.applyScope(modifier)\n      }\n      // Now check possible scope prefixes and handle them:\n      switch (modifier[0]) {\n      case '^': // Eager-applied scope:\n        // Always apply eager-scopes, even if the model itself doesn't know it.\n        // The scope may still be known in eager-loaded relations.\n        // Note: `applyScope()` will handle the '^' sign.\n        return query.applyScope(modifier)\n      case '-': // Ignore scope:\n        return query.ignoreScope(modifier.slice(1))\n      case '#': // Select column:\n        return query.select(modifier.slice(1))\n      }\n    }\n    super.modifierNotFound(query, modifier)\n  }\n\n  // @override\n  static createNotFoundError(ctx, error) {\n    return new NotFoundError(\n      error || (\n        ctx.byId\n          ? `'${this.name}' model with id ${ctx.byId} not found`\n          : `'${this.name}' model not found`\n      )\n    )\n  }\n\n  // @override\n  static createValidator() {\n    // Use a shared validator per app, so model schema can reference each other.\n    // NOTE: The Dito Validator class creates and manages this shared Objection\n    // Validator instance for us, we just need to return it here:\n    return this.app.validator\n  }\n\n  // @override\n  static createValidationError({ type, message, errors, options, json }) {\n    switch (type) {\n    case 'ModelValidation':\n      return this.app.createValidationError({\n        type,\n        message: message ||\n          `The provided data for the ${this.name} model is not valid: ${JSON.stringify(json)}`,\n        errors,\n        options\n      })\n    case 'RelationExpression':\n    case 'UnallowedRelation':\n      return new RelationError({ type, message, errors })\n    case 'InvalidGraph':\n      return new GraphError({ type, message, errors })\n    default:\n      return new ResponseError({ type, message, errors })\n    }\n  }\n\n  // @override\n  static QueryBuilder = QueryBuilder\n\n  // https://vincit.github.io/objection.js/api/model/static-properties.html#static-cloneobjectattributes\n  static cloneObjectAttributes = false\n\n  // Only pick properties for database JSON that is mentioned in the schema.\n  static pickJsonSchemaProperties = true\n\n  // See https://gitter.im/Vincit/objection.js?at=5a81f859ce68c3bc7479d65a\n  static useLimitInFirst = true\n\n  static get definition() {\n    // Check if we already have a definition object for this class and return it\n    return getMeta(this, 'definition', () => {\n      const definition = {}\n\n      const setDefinition = (name, property) => {\n        Object.defineProperty(definition, name, {\n          ...property,\n          enumerable: true\n        })\n      }\n\n      const getDefinition = name => {\n        let modelClass = this\n        // Collect ancestor values for proper inheritance.\n        // NOTE: values are collected in sequence of inheritance, from sub-class\n        // to super-class. To go from super-class to sub-class when merging,\n        // `mergeReversed()` is used to prevent wrong overrides.\n        // `mergeAsReversedArrays()` can be used to keep arrays of inherited\n        // values per key, see `definitions.hooks`.\n        const values = []\n        while (modelClass !== objection.Model) {\n          // Only consider model classes that actually define `name` property.\n          if (name in modelClass) {\n            // Use reflection through getOwnPropertyDescriptor() to be able to\n            // call the getter on `this` rather than on `modelClass`. This can\n            // be used to provide abstract base-classes and have them create\n            // their relations for `this` inside `get relations()` accessors.\n            const desc = Object.getOwnPropertyDescriptor(modelClass, name)\n            if (desc) {\n              const value = desc.get?.call(this) || desc.value\n              if (value) {\n                values.push(value)\n              }\n            }\n          }\n          modelClass = Object.getPrototypeOf(modelClass)\n        }\n        // To prevent endless recursion with interdependent calls related to\n        // properties, override definition before calling handler():\n        setDefinition(name, {\n          configurable: true,\n          value: {}\n        })\n        try {\n          const merged = definitions[name].call(this, values)\n          // Once calculated, override getter with final merged value.\n          setDefinition(name, {\n            configurable: false,\n            value: merged\n          })\n          return merged\n        } catch (error) {\n          throw new ModelError(this, error.message)\n        }\n      }\n\n      // If no definition object was defined yet, create one with accessors for\n      // each entry in `definitions`. Each of these getters when called merge\n      // definitions up the inheritance chain and store the merged result in\n      // `modelClass.definition[name]` for further caching.\n      for (const name in definitions) {\n        setDefinition(name, {\n          configurable: true,\n          get: () => getDefinition(name)\n        })\n      }\n      return definition\n    })\n  }\n\n  // Hooks\n\n  $emit(event, ...args) {\n    return this.constructor.emit(event, this, ...args)\n  }\n\n  static beforeFind(args) {\n    return this._emitStaticHook('before:find', args)\n  }\n\n  static afterFind(args) {\n    return this._emitStaticHook('after:find', args)\n  }\n\n  static beforeInsert(args) {\n    return this._emitStaticHook('before:insert', args)\n  }\n\n  static afterInsert(args) {\n    return this._emitStaticHook('after:insert', args)\n  }\n\n  static beforeUpdate(args) {\n    return this._emitStaticHook('before:update', args)\n  }\n\n  static afterUpdate(args) {\n    return this._emitStaticHook('after:update', args)\n  }\n\n  static beforeDelete(args) {\n    return this._emitStaticHook('before:delete', args)\n  }\n\n  static afterDelete(args) {\n    return this._emitStaticHook('after:delete', args)\n  }\n\n  static async _emitStaticHook(event, originalArgs) {\n    const listeners = this.listeners(event)\n    if (listeners.length > 0) {\n      // Static hooks are emitted in sequence (but each event can be async), and\n      // results are passed through and returned in the end.\n      let { result } = originalArgs\n      // The result of any event handler will override `args.result` in the call\n      // of the next handler in sequence. As `StaticHookArguments` in Objection\n      // is private, use a JS inheritance trick here to override `args.result`:\n      const args = Object.create(originalArgs, {\n        type: {\n          value: event\n        },\n        result: {\n          get() {\n            return result\n          }\n        }\n      })\n      for (const listener of listeners) {\n        const res = await listener.call(this, args)\n        if (res !== undefined) {\n          result = res\n        }\n      }\n      // Unfortunately `result` is always an array, even when the actual result\n      // is a model object. Avoid returning it when it's not actually changed.\n      // See: https://github.com/Vincit/objection.js/issues/1842\n      if (result !== originalArgs.result) {\n        return result\n      }\n    }\n  }\n\n  // Assets handling\n\n  static _setupAssetsEvents(assets) {\n    const assetDataPaths = Object.keys(assets)\n\n    this.on([\n      'before:insert',\n      'before:update',\n      'before:delete'\n    ], async ({ type, transaction, inputItems, asFindQuery }) => {\n      const afterItems = type === 'before:delete'\n        ? []\n        : inputItems\n      // Figure out which asset data paths where actually present in the\n      // submitted data, and only compare these. But when deleting, use all.\n      const dataPaths = afterItems.length > 0\n        ? assetDataPaths.filter(\n          path => getValueAtAssetDataPath(afterItems[0], path) !== undefined\n        )\n        : assetDataPaths\n\n      // `dataPaths` will be empty in the case of an update/insert that do not\n      // affect the assets.\n      if (dataPaths.length === 0) {\n        return\n      }\n\n      // Load the model's asset files in their current state before the query is\n      // executed.\n      const beforeItems = type === 'before:insert'\n        ? []\n        : await loadAssetDataPaths(asFindQuery(), dataPaths)\n      const beforeFilesPerDataPath = getFilesPerAssetDataPath(\n        beforeItems,\n        dataPaths\n      )\n      const afterFilesPerDataPath = getFilesPerAssetDataPath(\n        afterItems,\n        dataPaths\n      )\n\n      const importedFiles = []\n      const modifiedFiles = []\n\n      if (transaction.rollback) {\n        // Prevent wrong memory leak error messages when installing more than 10\n        // 'rollback' handlers, which can happen with more complex queries.\n        transaction.setMaxListeners(0)\n        transaction.on('rollback', async error => {\n          if (importedFiles.length > 0) {\n            console.info(\n              `Received '${error}', removing imported files again: ${\n                importedFiles.map(file => `'${file.name}'`)\n              }`\n            )\n            await Promise.all(\n              importedFiles.map(\n                file => file.storage.removeFile(file)\n              )\n            )\n          }\n          if (modifiedFiles.length > 0) {\n            // TODO: `modifiedFiles` should be restored as well, but that's far\n            // from trivial since no backup is kept in `handleModifiedAssets`\n            console.info(\n              `Unable to restore these already modified files: ${\n                modifiedFiles.map(file => `'${file.name}'`)\n              }`\n            )\n          }\n        })\n      }\n\n      for (const dataPath of dataPaths) {\n        const storage = this.app.getStorage(assets[dataPath].storage)\n        const beforeFiles = beforeFilesPerDataPath[dataPath] || []\n        const afterFiles = afterFilesPerDataPath[dataPath] || []\n        const beforeByKey = mapFilesByKey(beforeFiles)\n        const afterByKey = mapFilesByKey(afterFiles)\n        const removedFiles = beforeFiles.filter(file => !afterByKey[file.key])\n        const addedFiles = afterFiles.filter(file => !beforeByKey[file.key])\n        // Also handle modified files, which are files where the data property\n        // is changed before update / patch, meanting the file is changed.\n        // NOTE: This will change the content for all the references to it,\n        // and thus should only really be used when there's only one reference.\n        const modifiedFiles = afterFiles.filter(\n          file => file.data && beforeByKey[file.key]\n        )\n        importedFiles.push(\n          ...await this.app.handleAdddedAndRemovedAssets(\n            storage,\n            addedFiles,\n            removedFiles,\n            transaction\n          )\n        )\n        modifiedFiles.push(\n          ...await this.app.handleModifiedAssets(\n            storage,\n            modifiedFiles,\n            transaction\n          )\n        )\n      }\n    })\n  }\n}\n\nEventEmitter.mixin(Model)\nKnexHelper.mixin(Model)\n// Expose a selection of QueryBuilder methods as static methods on model classes\nQueryBuilder.mixin(Model)\n\nconst metaMap = new WeakMap()\n\nfunction getMeta(modelClass, key, value) {\n  let meta = metaMap.get(modelClass)\n  if (!meta) {\n    metaMap.set(modelClass, meta = {})\n  }\n  if (!(key in meta)) {\n    meta[key] = isFunction(value) ? value() : value\n  }\n  return meta[key]\n}\n\nfunction loadAssetDataPaths(query, dataPaths) {\n  return dataPaths.reduce(\n    (query, dataPath) => query.loadDataPath(dataPath),\n    query\n  )\n}\n\nfunction getValueAtAssetDataPath(item, path) {\n  return getValueAtDataPath(item, path, () => undefined)\n}\n\nfunction getFilesPerAssetDataPath(items, dataPaths) {\n  return dataPaths.reduce(\n    (allFiles, dataPath) => {\n      allFiles[dataPath] = asArray(items).reduce(\n        (files, item) => {\n          const data = asArray(getValueAtAssetDataPath(item, dataPath))\n          // Use flatten() as dataPath may contain wildcards, resulting in\n          // nested files arrays.\n          files.push(...flatten(data).filter(file => !!file))\n          return files\n        },\n        []\n      )\n      return allFiles\n    },\n    {}\n  )\n}\n\nfunction mapFilesByKey(files) {\n  return files.reduce(\n    (map, file) => {\n      map[file.key] = file\n      return map\n    },\n    {}\n  )\n}\n"]}
953
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/models/Model.js"],"names":["Model","objection","constructor","json","$setJson","setup","knex","relation","Object","values","getRelations","setupRelation","error","RelationError","referenceValidator","relatedModelClass","getRelatedRelations","push","accessor","name","prototype","defineAccessor","target","isClass","defineProperty","get","value","RelationAccessor","configurable","enumerable","initialize","hooks","assets","definition","_setupEmitter","_setupAssetsEvents","$initialize","$app","app","$is","model","id","$has","properties","property","$update","trx","$query","update","runAfter","result","query","has","$set","$patch","patch","$transaction","handler","transaction","$validate","options","skipValidation","graph","async","inputJson","shallow","$isObjectionModel","clone","mutable","validator","getValidator","args","ctx","create","beforeValidate","validate","handleResult","afterValidate","then","$validateGraph","fromJson","onError","err","ResponseError","DBError","createDatabaseError","WrappedError","Promise","reject","count","first","tableName","match","idColumn","ids","entries","primary","length","getReference","modelOrId","includeProperties","ref","idProperties","getIdPropertyArray","addProperty","key","undefined","uidRefProp","forEach","ModelError","index","isReference","obj","compileValidator","oneOf","type","reduce","idProperty","additionalProperties","throw","getScope","scopes","hasScope","getModifiers","modifiers","relationMappings","_getCached","relations","models","jsonSchema","schema","$id","$schema","virtualAttributes","computedAttributes","jsonAttributes","getAttributes","specificType","computed","booleanAttributes","dateAttributes","includes","hiddenAttributes","hidden","filter","attributes","identifier","calculate","empty","cache","getMeta","entry","part","split","propertyNameToColumnName","propertyName","columnNameToPropertyName","columnName","callInitialize","$formatDatabaseJson","date","toISOString","isSQLite","bool","$parseDatabaseJson","$parseJson","Date","dataPath","storage","getStorage","data","convertToAssetFiles","convertAssetFile","$formatJson","$filterGraph","modelGraph","expr","$populateGraph","filterGraph","populateGraph","getPropertyOrRelationAtDataPath","parsedDataPath","getResult","found","next","slice","nestedDataPath","expression","join","firstToken","otherTokens","token","isOneToOne","relatedQuery","relationName","alias","modifierNotFound","modifier","modelClass","applyScope","ignoreScope","select","createNotFoundError","NotFoundError","byId","createValidator","createValidationError","message","errors","GraphError","setDefinition","getDefinition","desc","getOwnPropertyDescriptor","call","getPrototypeOf","merged","definitions","$emit","event","emit","beforeFind","_emitStaticHook","afterFind","beforeInsert","afterInsert","beforeUpdate","afterUpdate","beforeDelete","afterDelete","originalArgs","listeners","listener","res","assetDataPaths","keys","on","inputItems","asFindQuery","afterItems","dataPaths","path","getValueAtAssetDataPath","beforeItems","loadAssetDataPaths","beforeFilesPerDataPath","getFilesPerAssetDataPath","afterFilesPerDataPath","importedFiles","modifiedFiles","rollback","setMaxListeners","console","info","map","file","all","removeFile","beforeFiles","afterFiles","beforeByKey","mapFilesByKey","afterByKey","removedFiles","addedFiles","handleAdddedAndRemovedAssets","handleModifiedAssets","QueryBuilder","cloneObjectAttributes","pickJsonSchemaProperties","useLimitInFirst","EventEmitter","mixin","KnexHelper","metaMap","WeakMap","meta","set","loadDataPath","item","items","allFiles","files"],"mappings":"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","sourcesContent":["import objection from 'objection'\nimport { QueryBuilder } from '@/query'\nimport { EventEmitter, KnexHelper } from '@/lib'\nimport { convertSchema, addRelationSchemas, convertRelations } from '@/schema'\nimport { populateGraph, filterGraph } from '@/graph'\nimport { formatJson } from '@/utils'\nimport {\n  ResponseError,\n  GraphError, ModelError,\n  NotFoundError,\n  RelationError,\n  WrappedError\n} from '@/errors'\nimport {\n  isString, isObject, isArray, isFunction, isPromise, asArray, merge, flatten,\n  parseDataPath, normalizeDataPath, getValueAtDataPath\n} from '@ditojs/utils'\nimport RelationAccessor from './RelationAccessor'\nimport definitions from './definitions'\n\nexport class Model extends objection.Model {\n  // Define a default constructor to allow new Model(json) as a short-cut to\n  // `Model.fromJson(json, { skipValidation: true })`\n  constructor(json) {\n    super()\n    if (json) {\n      this.$setJson(json)\n    }\n  }\n\n  static setup(knex) {\n    this.knex(knex)\n    try {\n      for (const relation of Object.values(this.getRelations())) {\n        this.setupRelation(relation)\n      }\n    } catch (error) {\n      throw error instanceof RelationError ? error : new RelationError(error)\n    }\n    this.referenceValidator = null\n  }\n\n  static setupRelation(relation) {\n    // Add this relation to the related model's relatedRelations, so it can\n    // register all required foreign keys in its properties.\n    relation.relatedModelClass.getRelatedRelations().push(relation)\n    // TODO: Check `through` settings to make sure they're correct?\n\n    // Expose RelationAccessor instances for each relation under short-cut $name\n    // for access to relations and implicit calls to $relatedQuery(name).\n    const accessor = `$${relation.name}`\n    if (accessor in this.prototype) {\n      throw new RelationError(\n        `Model '${this.name}' already defines a property with name ` +\n        `'${accessor}' that clashes with the relation accessor.`)\n    }\n\n    // Define an accessor on the class as well as on the prototype that when\n    // first called creates a RelationAccessor instance and then overrides the\n    // accessor with one that then just returns the same value afterwards.\n    const defineAccessor = (target, isClass) => {\n      Object.defineProperty(target, accessor, {\n        get() {\n          const value = new RelationAccessor(\n            relation,\n            isClass ? this : null, // modelClass\n            isClass ? null : this // model\n          )\n          // Override accessor with value on first call for caching.\n          Object.defineProperty(this, accessor, {\n            value,\n            configurable: true,\n            enumerable: false\n          })\n          return value\n        },\n        configurable: true,\n        enumerable: false\n      })\n    }\n\n    defineAccessor(this, true)\n    defineAccessor(this.prototype, false)\n  }\n\n  // @overridable\n  static initialize() {\n    const { hooks, assets } = this.definition\n    this._setupEmitter(hooks)\n    if (assets) {\n      this._setupAssetsEvents(assets)\n    }\n  }\n\n  // @overridable\n  $initialize() {\n  }\n\n  get $app() {\n    return this.constructor.app\n  }\n\n  $is(model) {\n    return model?.constructor === this.constructor && model?.id === this.id\n  }\n\n  $has(...properties) {\n    for (const property of properties) {\n      if (!(property in this)) return false\n    }\n    return true\n  }\n\n  $update(properties, trx) {\n    return this.$query(trx)\n      .update(properties)\n      .runAfter((result, query) =>\n        // Only perform `$set()` and return `this` if the query wasn't modified\n        // in a way that would remove the `update()` command, e.g. toFindQuery()\n        query.has('update') ? this.$set(result) : result\n      )\n  }\n\n  $patch(properties, trx) {\n    return this.$query(trx)\n      .patch(properties)\n      .runAfter((result, query) =>\n        // Only perform `$set()` and return `this` if the query wasn't modified\n        // in a way that would remove the `patch()` command, e.g. toFindQuery()\n        query.has('patch') ? this.$set(result) : result\n      )\n  }\n\n  // @override\n  $transaction(trx, handler) {\n    return this.constructor.transaction(trx, handler)\n  }\n\n  // @override\n  static transaction(trx, handler) {\n    // Support both `transaction(trx, handler)` & `transaction(handler)`\n    if (!handler) {\n      handler = trx\n      trx = null\n    }\n    if (handler) {\n      // Use existing transaction, or create new one, to execute handler with:\n      return trx\n        ? handler(trx)\n        : this.knex().transaction(handler)\n    } else {\n      // No arguments, simply delegate to objection's transaction()\n      return super.transaction()\n    }\n  }\n\n  // @override\n  $validate(json, options = {}) {\n    if (options.skipValidation) {\n      return json\n    }\n    if (!options.graph && !options.async) {\n      // Fall back to Objection's $validate() if we don't need any of our\n      // extensions (async and graph for now):\n      return super.$validate(json, options)\n    }\n    json = json || this\n    const inputJson = json\n    const shallow = json.$isObjectionModel && !options.graph\n    if (shallow) {\n      // Strip away relations and other internal stuff.\n      json = json.clone({ shallow: true })\n      // We can mutate `json` now that we took a copy of it.\n      options = { ...options, mutable: true }\n    }\n\n    const validator = this.constructor.getValidator()\n    const args = {\n      options,\n      model: this,\n      json,\n      ctx: Object.create(null)\n    }\n\n    validator.beforeValidate(args)\n    const result = validator.validate(args)\n    const handleResult = result => {\n      validator.afterValidate(args)\n      // If `json` was shallow-cloned, copy over the possible default values.\n      return shallow ? inputJson.$set(result) : result\n    }\n    // Handle both async and sync validation here:\n    return isPromise(result)\n      ? result.then(handleResult)\n      : handleResult(result)\n  }\n\n  async $validateGraph(options = {}) {\n    await this.$validate(null, {\n      ...options,\n      graph: true,\n      // Always use `async: true` option here for simplicity:\n      async: true\n    })\n    return this\n  }\n\n  // @override\n  static fromJson(json, options = {}) {\n    if (options.async && !options.skipValidation) {\n      // Handle async validation, as supported by Dito:\n      const model = new this()\n      return model.$validate(json, options).then(\n        json => model.$setJson(json, {\n          ...options,\n          skipValidation: true\n        })\n      )\n    }\n    // Fall back to Objection's fromJson() if we don't need async handling:\n    return super.fromJson(json, options)\n  }\n\n  // @override\n  static query(trx) {\n    return super.query(trx).onError(err => {\n      // TODO: Shouldn't this wrapping happen on the Controller level?\n      err = err instanceof ResponseError ? err\n        : err instanceof objection.DBError ? this.app.createDatabaseError(err)\n        : new WrappedError(err)\n      return Promise.reject(err)\n    })\n  }\n\n  static async count(...args) {\n    const { count } = await this.query().count(...args).first() || {}\n    return +count || 0\n  }\n\n  // @override\n  static get tableName() {\n    // If the class name ends in 'Model', remove that from the table name.\n    return this.name.match(/^(.*?)(?:Model|)$/)[1]\n  }\n\n  // @override\n  static get idColumn() {\n    // Try extracting the id column name from the raw properties definitions,\n    // not the resolved `definition.properties` which aren't ready at this point\n    // with fall-back onto default Objection.js behavior.\n    const { properties } = this\n    const ids = []\n    for (const [name, property] of Object.entries(properties || {})) {\n      if (property?.primary) {\n        ids.push(name)\n      }\n    }\n    const { length } = ids\n    return length > 1 ? ids : length > 0 ? ids[0] : super.idColumn\n  }\n\n  static getReference(modelOrId, includeProperties) {\n    // Creates a reference model that takes over the id / #ref properties from\n    // the passed model or id value/array, omitting any other properties in it,\n    // except for anything mentioned in the optional `includeProperties` arg.\n    const ref = new this()\n    const idProperties = this.getIdPropertyArray()\n    if (isObject(modelOrId)) {\n      const addProperty = key => {\n        const value = modelOrId[key]\n        if (value !== undefined) {\n          ref[key] = value\n        }\n      }\n      // Also support Objection's #ref type references next to id properties.\n      addProperty(this.uidRefProp)\n      idProperties.forEach(addProperty)\n      includeProperties?.forEach(addProperty)\n    } else {\n      // An id value/array: Map it to the properties in `getIdPropertyArray()`:\n      const ids = asArray(modelOrId)\n      if (ids.length !== idProperties.length) {\n        throw new ModelError(\n          this,\n          `Invalid amount of id values provided for reference: Unable to map ${\n            formatJson(modelOrId, false)\n          } to ${\n            formatJson(idProperties, false)\n          }.`\n        )\n      }\n      idProperties.forEach((key, index) => {\n        ref[key] = ids[index]\n      })\n    }\n    return ref\n  }\n\n  static isReference(obj) {\n    let validator = this.referenceValidator\n    if (!validator) {\n      // For `data` to be considered a reference, it needs to hold only one\n      // value that is either the target's id, or an Objection.js #ref value:\n      validator = this.referenceValidator = this.app.compileValidator(\n        {\n          oneOf: [\n            {\n              type: 'object',\n              // Support composite keys and add a property for each key:\n              properties: this.getIdPropertyArray().reduce(\n                (idProperties, idProperty) => {\n                  idProperties[idProperty] = {\n                    type: this.definition.properties[idProperty].type\n                  }\n                  return idProperties\n                },\n                {}\n              ),\n              additionalProperties: false\n            },\n            {\n              type: 'object',\n              properties: {\n                [this.uidRefProp]: {\n                  type: 'string'\n                }\n              },\n              additionalProperties: false\n            }\n          ]\n        },\n        // Receive `false` instead of thrown exceptions when validation fails:\n        { throw: false }\n      )\n    }\n    return validator(obj)\n  }\n\n  static getScope(name) {\n    return this.definition.scopes[name]\n  }\n\n  static hasScope(name) {\n    return !!this.getScope(name)\n  }\n\n  static getModifiers() {\n    return this.definition.modifiers\n  }\n\n  static get relationMappings() {\n    return this._getCached('relationMappings', () => (\n      convertRelations(this, this.definition.relations, this.app.models)\n    ), {})\n  }\n\n  static get jsonSchema() {\n    return this._getCached('jsonSchema', () => {\n      const schema = convertSchema(this.definition.properties)\n      addRelationSchemas(this, schema.properties)\n      // Merge in root-level schema additions\n      merge(schema, this.definition.schema)\n      return {\n        $id: this.name,\n        $schema: 'http://json-schema.org/draft-07/schema',\n        ...schema\n      }\n    }, {})\n  }\n\n  static get virtualAttributes() {\n    // Leverage Objection's own mechanism called `virtualAttributes` to handle\n    // `computedAttributes` when setting JSON data.\n    return this.computedAttributes\n  }\n\n  static get jsonAttributes() {\n    return this._getCached('jsonSchema:jsonAttributes', () => (\n      this.getAttributes(({ type, specificType, computed }) =>\n        !computed && !specificType && (type === 'object' || type === 'array'))\n    ), [])\n  }\n\n  static get booleanAttributes() {\n    return this._getCached('jsonSchema:booleanAttributes', () => (\n      this.getAttributes(({ type, computed }) =>\n        !computed && type === 'boolean')\n    ), [])\n  }\n\n  static get dateAttributes() {\n    return this._getCached('jsonSchema:dateAttributes', () => (\n      this.getAttributes(({ type, computed }) =>\n        !computed && ['date', 'datetime', 'timestamp'].includes(type))\n    ), [])\n  }\n\n  static get computedAttributes() {\n    return this._getCached('jsonSchema:computedAttributes', () => (\n      this.getAttributes(({ computed }) => computed)\n    ), [])\n  }\n\n  static get hiddenAttributes() {\n    return this._getCached('jsonSchema:hiddenAttributes', () => (\n      this.getAttributes(({ hidden }) => hidden)\n    ), [])\n  }\n\n  static getAttributes(filter) {\n    const attributes = []\n    const { properties } = this.definition\n    for (const [name, property] of Object.entries(properties)) {\n      if (filter(property)) {\n        attributes.push(name)\n      }\n    }\n    return attributes\n  }\n\n  static _getCached(identifier, calculate, empty = {}) {\n    let cache = getMeta(this, 'cache', {})\n    // Use a simple dependency tracking mechanism with cache identifiers that\n    // can be children of other cached values, e.g.:\n    // 'jsonSchema:jsonAttributes' as a child of 'jsonSchema', so that whenever\n    // 'jsonSchema' changes, all cached child values  are invalidated.\n    let entry\n    for (const part of identifier.split(':')) {\n      entry = cache[part] = cache[part] || {\n        cache: {},\n        value: undefined\n      }\n      cache = entry.cache\n    }\n    if (entry?.value === undefined) {\n      // Temporarily set cache to an empty object to prevent endless\n      // recursion with interdependent jsonSchema related calls...\n      entry.value = empty\n      entry.value = calculate()\n      // Clear child dependencies once parent value has changed:\n      entry.cache = {}\n    }\n    return entry?.value\n  }\n\n  static getRelatedRelations() {\n    return getMeta(this, 'relatedRelations', [])\n  }\n\n  // Override propertyNameToColumnName() / columnNameToPropertyName() to not\n  // rely on $formatDatabaseJson() /  $parseDatabaseJson() do detect naming\n  // conventions but assume simply that they're always the same.\n  // This is fine since we can now change naming at Knex level.\n  // See knexSnakeCaseMappers()\n\n  // @override\n  static propertyNameToColumnName(propertyName) {\n    return propertyName\n  }\n\n  // @override\n  static columnNameToPropertyName(columnName) {\n    return columnName\n  }\n\n  // @override\n  $setJson(json, options) {\n    options = options || {}\n    const callInitialize = (\n      // Only call initialize when:\n      // 1. we're not partially patching:\n      !options.patch &&\n      // 2. $initialize() is actually doing something:\n      this.$initialize !== Model.prototype.$initialize &&\n      // 3. the data is not just a reference:\n      !this.constructor.isReference(json)\n    )\n    if (!callInitialize || options.skipValidation) {\n      super.$setJson(json, options)\n      if (callInitialize) {\n        this.$initialize()\n      }\n    } else {\n      // If validation isn't skipped or the model provides its own $initialize()\n      // method, call $setJson() with patch validation first to not complain\n      // about missing fields, then perform a full validation after calling\n      // $initialize(), to give the model a chance to configure itself.\n      super.$setJson(json, { ...options, patch: true })\n      this.$initialize()\n      this.$validate(this, options)\n    }\n    return this\n  }\n\n  // @override\n  $formatDatabaseJson(json) {\n    const { constructor } = this\n    for (const key of constructor.dateAttributes) {\n      const date = json[key]\n      if (date?.toISOString) {\n        json[key] = date.toISOString()\n      }\n    }\n    if (constructor.isSQLite()) {\n      // SQLite does not support boolean natively and needs conversion...\n      for (const key of constructor.booleanAttributes) {\n        const bool = json[key]\n        if (bool !== undefined) {\n          json[key] = bool ? 1 : 0\n        }\n      }\n    }\n    // Remove the computed properties so they don't attempt to get set.\n    for (const key of constructor.computedAttributes) {\n      delete json[key]\n    }\n    // NOTE: No need to normalize the identifiers in the JSON in case of\n    // normalizeDbNames, as this already happens through\n    // knex.config.wrapIdentifier(), see Application.js\n    return super.$formatDatabaseJson(json)\n  }\n\n  // @override\n  $parseDatabaseJson(json) {\n    const { constructor } = this\n    json = super.$parseDatabaseJson(json)\n    if (constructor.isSQLite()) {\n      // SQLite does not support boolean natively and needs conversion...\n      for (const key of constructor.booleanAttributes) {\n        const bool = json[key]\n        if (bool !== undefined) {\n          json[key] = !!bool\n        }\n      }\n    }\n    // Also run through normal $parseJson(), for handling of `Date` and\n    // `AssetFile`.\n    return this.$parseJson(json)\n  }\n\n  // @override\n  $parseJson(json) {\n    const { constructor } = this\n    for (const key of constructor.dateAttributes) {\n      const date = json[key]\n      if (date !== undefined) {\n        json[key] = isString(date) ? new Date(date) : date\n      }\n    }\n    // Convert plain asset files objects to AssetFile instances with references\n    // to the linked storage.\n    const { assets } = constructor.definition\n    if (assets) {\n      for (const dataPath in assets) {\n        const storage = constructor.app.getStorage(assets[dataPath].storage)\n        const data = getValueAtDataPath(json, dataPath, () => null)\n        if (data) {\n          const convertToAssetFiles = data => {\n            if (data) {\n              if (isArray(data)) {\n                data.forEach(convertToAssetFiles)\n              } else {\n                storage.convertAssetFile(data)\n              }\n            }\n          }\n          convertToAssetFiles(data)\n        }\n      }\n    }\n    return json\n  }\n\n  // @override\n  $formatJson(json) {\n    const { constructor } = this\n    // Calculate and set the computed properties.\n    for (const key of constructor.computedAttributes) {\n      // Perhaps the computed property is produced in the SQL statement,\n      // in which case we don't have to do anything anymore here.\n      if (!(key in json)) {\n        const value = this[key]\n        if (value !== undefined) {\n          json[key] = value\n        }\n      }\n    }\n    // Remove hidden attributes.\n    for (const key of constructor.hiddenAttributes) {\n      delete json[key]\n    }\n    return json\n  }\n\n  // Graph handling\n\n  $filterGraph(modelGraph, expr) {\n    return filterGraph(this.constructor, modelGraph, expr)\n  }\n\n  async $populateGraph(modelGraph, expr, trx) {\n    return populateGraph(this.constructor, modelGraph, expr, trx)\n  }\n\n  static filterGraph(modelGraph, expr) {\n    return filterGraph(this, modelGraph, expr)\n  }\n\n  static async populateGraph(modelGraph, expr, trx) {\n    return populateGraph(this, modelGraph, expr, trx)\n  }\n\n  static getPropertyOrRelationAtDataPath(dataPath) {\n    // Finds the property or relation at the given the dataPath of the model by\n    // parsing the dataPath and matching it to its relations and properties.\n    const parsedDataPath = parseDataPath(dataPath)\n    let index = 0\n\n    const getResult = (property = null, relation = null) => {\n      const found = property || relation\n      const name = parsedDataPath[index]\n      const next = index + 1\n      const dataPath = found\n        ? normalizeDataPath(parsedDataPath.slice(0, next))\n        : null\n      const nestedDataPath = found\n        ? normalizeDataPath(parsedDataPath.slice(next))\n        : null\n      const expression = found\n        ? parsedDataPath.slice(0, relation ? next : index).join('.') +\n          (property ? `(#${name})` : '')\n        : null\n      return {\n        property,\n        relation,\n        dataPath,\n        nestedDataPath,\n        name,\n        expression,\n        index\n      }\n    }\n\n    const [firstToken, ...otherTokens] = parsedDataPath\n    const property = this.definition.properties[firstToken]\n    if (property) {\n      return getResult(property)\n    } else {\n      let relation = this.getRelations()[firstToken]\n      if (relation) {\n        let { relatedModelClass } = relation\n        for (const token of otherTokens) {\n          index++\n          const property = relatedModelClass.definition.properties[token]\n          if (property) {\n            return getResult(property)\n          } else if (token === '*') {\n            if (relation.isOneToOne()) {\n              // Do not support wildcards on one-to-one relations:\n              return getResult()\n            } else {\n              continue\n            }\n          } else {\n            // Found a relation? Keep iterating.\n            relation = relatedModelClass.getRelations()[token]\n            if (relation) {\n              relatedModelClass = relation.relatedModelClass\n            } else {\n              return getResult()\n            }\n          }\n        }\n        if (relation) {\n          // Still here? Found a relation at the end of the data-path.\n          return getResult(null, relation)\n        }\n      }\n    }\n    return getResult()\n  }\n\n  // @override\n  static relatedQuery(relationName, trx) {\n    // https://github.com/Vincit/objection.js/issues/1720\n    return super.relatedQuery(relationName, trx).alias(relationName)\n  }\n\n  // @override\n  static modifierNotFound(query, modifier) {\n    if (isString(modifier)) {\n      if (query.modelClass().hasScope(modifier)) {\n        return query.applyScope(modifier)\n      }\n      // Now check possible scope prefixes and handle them:\n      switch (modifier[0]) {\n      case '^': // Eager-applied scope:\n        // Always apply eager-scopes, even if the model itself doesn't know it.\n        // The scope may still be known in eager-loaded relations.\n        // Note: `applyScope()` will handle the '^' sign.\n        return query.applyScope(modifier)\n      case '-': // Ignore scope:\n        return query.ignoreScope(modifier.slice(1))\n      case '#': // Select column:\n        return query.select(modifier.slice(1))\n      }\n    }\n    super.modifierNotFound(query, modifier)\n  }\n\n  // @override\n  static createNotFoundError(ctx, error) {\n    return new NotFoundError(\n      error || (\n        ctx.byId\n          ? `'${this.name}' model with id ${ctx.byId} not found`\n          : `'${this.name}' model not found`\n      )\n    )\n  }\n\n  // @override\n  static createValidator() {\n    // Use a shared validator per app, so model schema can reference each other.\n    // NOTE: The Dito Validator class creates and manages this shared Objection\n    // Validator instance for us, we just need to return it here:\n    return this.app.validator\n  }\n\n  // @override\n  static createValidationError({ type, message, errors, options, json }) {\n    switch (type) {\n    case 'ModelValidation':\n      return this.app.createValidationError({\n        type,\n        message:\n          message || `The provided data for the ${this.name} model is not valid`,\n        errors,\n        options,\n        json\n      })\n    case 'RelationExpression':\n    case 'UnallowedRelation':\n      return new RelationError({ type, message, errors })\n    case 'InvalidGraph':\n      return new GraphError({ type, message, errors })\n    default:\n      return new ResponseError({ type, message, errors })\n    }\n  }\n\n  // @override\n  static QueryBuilder = QueryBuilder\n\n  // https://vincit.github.io/objection.js/api/model/static-properties.html#static-cloneobjectattributes\n  static cloneObjectAttributes = false\n\n  // Only pick properties for database JSON that is mentioned in the schema.\n  static pickJsonSchemaProperties = true\n\n  // See https://gitter.im/Vincit/objection.js?at=5a81f859ce68c3bc7479d65a\n  static useLimitInFirst = true\n\n  static get definition() {\n    // Check if we already have a definition object for this class and return it\n    return getMeta(this, 'definition', () => {\n      const definition = {}\n\n      const setDefinition = (name, property) => {\n        Object.defineProperty(definition, name, {\n          ...property,\n          enumerable: true\n        })\n      }\n\n      const getDefinition = name => {\n        let modelClass = this\n        // Collect ancestor values for proper inheritance.\n        // NOTE: values are collected in sequence of inheritance, from sub-class\n        // to super-class. To go from super-class to sub-class when merging,\n        // `mergeReversed()` is used to prevent wrong overrides.\n        // `mergeAsReversedArrays()` can be used to keep arrays of inherited\n        // values per key, see `definitions.hooks`.\n        const values = []\n        while (modelClass !== objection.Model) {\n          // Only consider model classes that actually define `name` property.\n          if (name in modelClass) {\n            // Use reflection through getOwnPropertyDescriptor() to be able to\n            // call the getter on `this` rather than on `modelClass`. This can\n            // be used to provide abstract base-classes and have them create\n            // their relations for `this` inside `get relations()` accessors.\n            const desc = Object.getOwnPropertyDescriptor(modelClass, name)\n            if (desc) {\n              const value = desc.get?.call(this) || desc.value\n              if (value) {\n                values.push(value)\n              }\n            }\n          }\n          modelClass = Object.getPrototypeOf(modelClass)\n        }\n        // To prevent endless recursion with interdependent calls related to\n        // properties, override definition before calling handler():\n        setDefinition(name, {\n          configurable: true,\n          value: {}\n        })\n        try {\n          const merged = definitions[name].call(this, values)\n          // Once calculated, override getter with final merged value.\n          setDefinition(name, {\n            configurable: false,\n            value: merged\n          })\n          return merged\n        } catch (error) {\n          throw new ModelError(this, error.message)\n        }\n      }\n\n      // If no definition object was defined yet, create one with accessors for\n      // each entry in `definitions`. Each of these getters when called merge\n      // definitions up the inheritance chain and store the merged result in\n      // `modelClass.definition[name]` for further caching.\n      for (const name in definitions) {\n        setDefinition(name, {\n          configurable: true,\n          get: () => getDefinition(name)\n        })\n      }\n      return definition\n    })\n  }\n\n  // Hooks\n\n  $emit(event, ...args) {\n    return this.constructor.emit(event, this, ...args)\n  }\n\n  static beforeFind(args) {\n    return this._emitStaticHook('before:find', args)\n  }\n\n  static afterFind(args) {\n    return this._emitStaticHook('after:find', args)\n  }\n\n  static beforeInsert(args) {\n    return this._emitStaticHook('before:insert', args)\n  }\n\n  static afterInsert(args) {\n    return this._emitStaticHook('after:insert', args)\n  }\n\n  static beforeUpdate(args) {\n    return this._emitStaticHook('before:update', args)\n  }\n\n  static afterUpdate(args) {\n    return this._emitStaticHook('after:update', args)\n  }\n\n  static beforeDelete(args) {\n    return this._emitStaticHook('before:delete', args)\n  }\n\n  static afterDelete(args) {\n    return this._emitStaticHook('after:delete', args)\n  }\n\n  static async _emitStaticHook(event, originalArgs) {\n    const listeners = this.listeners(event)\n    if (listeners.length > 0) {\n      // Static hooks are emitted in sequence (but each event can be async), and\n      // results are passed through and returned in the end.\n      let { result } = originalArgs\n      // The result of any event handler will override `args.result` in the call\n      // of the next handler in sequence. As `StaticHookArguments` in Objection\n      // is private, use a JS inheritance trick here to override `args.result`:\n      const args = Object.create(originalArgs, {\n        type: {\n          value: event\n        },\n        result: {\n          get() {\n            return result\n          }\n        }\n      })\n      for (const listener of listeners) {\n        const res = await listener.call(this, args)\n        if (res !== undefined) {\n          result = res\n        }\n      }\n      // Unfortunately `result` is always an array, even when the actual result\n      // is a model object. Avoid returning it when it's not actually changed.\n      // See: https://github.com/Vincit/objection.js/issues/1842\n      if (result !== originalArgs.result) {\n        return result\n      }\n    }\n  }\n\n  // Assets handling\n\n  static _setupAssetsEvents(assets) {\n    const assetDataPaths = Object.keys(assets)\n\n    this.on([\n      'before:insert',\n      'before:update',\n      'before:delete'\n    ], async ({ type, transaction, inputItems, asFindQuery }) => {\n      const afterItems = type === 'before:delete'\n        ? []\n        : inputItems\n      // Figure out which asset data paths where actually present in the\n      // submitted data, and only compare these. But when deleting, use all.\n      const dataPaths = afterItems.length > 0\n        ? assetDataPaths.filter(\n          path => getValueAtAssetDataPath(afterItems[0], path) !== undefined\n        )\n        : assetDataPaths\n\n      // `dataPaths` will be empty in the case of an update/insert that do not\n      // affect the assets.\n      if (dataPaths.length === 0) {\n        return\n      }\n\n      // Load the model's asset files in their current state before the query is\n      // executed.\n      const beforeItems = type === 'before:insert'\n        ? []\n        : await loadAssetDataPaths(asFindQuery(), dataPaths)\n      const beforeFilesPerDataPath = getFilesPerAssetDataPath(\n        beforeItems,\n        dataPaths\n      )\n      const afterFilesPerDataPath = getFilesPerAssetDataPath(\n        afterItems,\n        dataPaths\n      )\n\n      const importedFiles = []\n      const modifiedFiles = []\n\n      if (transaction.rollback) {\n        // Prevent wrong memory leak error messages when installing more than 10\n        // 'rollback' handlers, which can happen with more complex queries.\n        transaction.setMaxListeners(0)\n        transaction.on('rollback', async error => {\n          if (importedFiles.length > 0) {\n            console.info(\n              `Received '${error}', removing imported files again: ${\n                importedFiles.map(file => `'${file.name}'`)\n              }`\n            )\n            await Promise.all(\n              importedFiles.map(\n                file => file.storage.removeFile(file)\n              )\n            )\n          }\n          if (modifiedFiles.length > 0) {\n            // TODO: `modifiedFiles` should be restored as well, but that's far\n            // from trivial since no backup is kept in `handleModifiedAssets`\n            console.info(\n              `Unable to restore these already modified files: ${\n                modifiedFiles.map(file => `'${file.name}'`)\n              }`\n            )\n          }\n        })\n      }\n\n      for (const dataPath of dataPaths) {\n        const storage = this.app.getStorage(assets[dataPath].storage)\n        const beforeFiles = beforeFilesPerDataPath[dataPath] || []\n        const afterFiles = afterFilesPerDataPath[dataPath] || []\n        const beforeByKey = mapFilesByKey(beforeFiles)\n        const afterByKey = mapFilesByKey(afterFiles)\n        const removedFiles = beforeFiles.filter(file => !afterByKey[file.key])\n        const addedFiles = afterFiles.filter(file => !beforeByKey[file.key])\n        // Also handle modified files, which are files where the data property\n        // is changed before update / patch, meanting the file is changed.\n        // NOTE: This will change the content for all the references to it,\n        // and thus should only really be used when there's only one reference.\n        const modifiedFiles = afterFiles.filter(\n          file => file.data && beforeByKey[file.key]\n        )\n        importedFiles.push(\n          ...await this.app.handleAdddedAndRemovedAssets(\n            storage,\n            addedFiles,\n            removedFiles,\n            transaction\n          )\n        )\n        modifiedFiles.push(\n          ...await this.app.handleModifiedAssets(\n            storage,\n            modifiedFiles,\n            transaction\n          )\n        )\n      }\n    })\n  }\n}\n\nEventEmitter.mixin(Model)\nKnexHelper.mixin(Model)\n// Expose a selection of QueryBuilder methods as static methods on model classes\nQueryBuilder.mixin(Model)\n\nconst metaMap = new WeakMap()\n\nfunction getMeta(modelClass, key, value) {\n  let meta = metaMap.get(modelClass)\n  if (!meta) {\n    metaMap.set(modelClass, meta = {})\n  }\n  if (!(key in meta)) {\n    meta[key] = isFunction(value) ? value() : value\n  }\n  return meta[key]\n}\n\nfunction loadAssetDataPaths(query, dataPaths) {\n  return dataPaths.reduce(\n    (query, dataPath) => query.loadDataPath(dataPath),\n    query\n  )\n}\n\nfunction getValueAtAssetDataPath(item, path) {\n  return getValueAtDataPath(item, path, () => undefined)\n}\n\nfunction getFilesPerAssetDataPath(items, dataPaths) {\n  return dataPaths.reduce(\n    (allFiles, dataPath) => {\n      allFiles[dataPath] = asArray(items).reduce(\n        (files, item) => {\n          const data = asArray(getValueAtAssetDataPath(item, dataPath))\n          // Use flatten() as dataPath may contain wildcards, resulting in\n          // nested files arrays.\n          files.push(...flatten(data).filter(file => !!file))\n          return files\n        },\n        []\n      )\n      return allFiles\n    },\n    {}\n  )\n}\n\nfunction mapFilesByKey(files) {\n  return files.reduce(\n    (map, file) => {\n      map[file.key] = file\n      return map\n    },\n    {}\n  )\n}\n"]}
@@ -3,6 +3,14 @@
3
3
  exports.__esModule = true;
4
4
  exports.default = filters;
5
5
 
6
+ require("core-js/modules/es.error.cause.js");
7
+
8
+ require("core-js/modules/esnext.async-iterator.filter.js");
9
+
10
+ require("core-js/modules/esnext.iterator.constructor.js");
11
+
12
+ require("core-js/modules/esnext.iterator.filter.js");
13
+
6
14
  var _utils = require("@ditojs/utils");
7
15
 
8
16
  var _query = require("../../query");
@@ -90,4 +98,4 @@ function wrapWithValidation(filter, name, app) {
90
98
 
91
99
  return filter;
92
100
  }
93
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9tb2RlbHMvZGVmaW5pdGlvbnMvZmlsdGVycy5qcyJdLCJuYW1lcyI6WyJmaWx0ZXJzIiwidmFsdWVzIiwibmFtZSIsImRlZmluaXRpb24iLCJPYmplY3QiLCJlbnRyaWVzIiwiZmlsdGVyIiwiY29udmVydE9iamVjdEZpbHRlciIsIkVycm9yIiwid3JhcFdpdGhWYWxpZGF0aW9uIiwiYXBwIiwicHJvcGVydGllcyIsImFkZEZ1bmN0aW9uU2V0dGluZ3MiLCJxdWVyeUZpbHRlciIsIlF1ZXJ5RmlsdGVycyIsImdldCIsImZ1bmMiLCJxdWVyeSIsImFyZ3MiLCJwcm9wZXJ0eSIsIm9yV2hlcmUiLCJwYXJhbWV0ZXJzIiwidmFsaWRhdGUiLCJkYXRhTmFtZSIsInZhbGlkYXRvciIsImNvbXBpbGVQYXJhbWV0ZXJzVmFsaWRhdG9yIiwib2JqZWN0IiwiaW5kZXgiLCJsaXN0IiwiZXJyb3IiLCJjcmVhdGVWYWxpZGF0aW9uRXJyb3IiLCJ0eXBlIiwibWVzc2FnZSIsImVycm9ycyIsInByZWZpeERhdGFQYXRocyJdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7QUFFZSxTQUFTQSxPQUFULENBQWlCQyxNQUFqQixFQUF5QjtBQUN0QyxRQUFNRCxPQUFPLEdBQUcsRUFBaEI7O0FBQ0EsT0FBSyxNQUFNLENBQUNFLElBQUQsRUFBT0MsVUFBUCxDQUFYLElBQWlDQyxNQUFNLENBQUNDLE9BQVAsQ0FBZSwyQkFBY0osTUFBZCxDQUFmLENBQWpDLEVBQXdFO0FBQ3RFLFVBQU1LLE1BQU0sR0FBRyx1QkFBV0gsVUFBWCxJQUNYQSxVQURXLEdBRVgscUJBQVNBLFVBQVQsSUFDRUksbUJBQW1CLENBQUNKLFVBQUQsRUFBYUQsSUFBYixDQURyQixHQUVFLElBSk47O0FBS0EsUUFBSSxDQUFDSSxNQUFMLEVBQWE7QUFDWCxZQUFNLElBQUlFLEtBQUosQ0FDSCxtQkFBa0JOLElBQUssK0JBQThCQyxVQUFXLEdBRDdELENBQU47QUFHRDs7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QUNjLFNBQUosQ0FBY1UsZUFBZCxDQUNOTCxLQUFLLENBQUNJLE1BREEsRUFFTCxJQUFHL0IsSUFBSyxFQUZIO0FBSnNCLFNBQTFCLENBQU47QUFTRDs7QUFDRCxhQUFPSSxNQUFNLENBQUNXLEtBQUQsRUFBUSxHQUFHQyxJQUFYLENBQWI7QUFDRCxLQXZCRDtBQXdCRDs7QUFFRCxTQUFPWixNQUFQO0FBQ0QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpc09iamVjdCwgaXNGdW5jdGlvbiB9IGZyb20gJ0BkaXRvanMvdXRpbHMnXG5pbXBvcnQgeyBRdWVyeUZpbHRlcnMgfSBmcm9tICdAL3F1ZXJ5J1xuaW1wb3J0IHsgbWVyZ2VSZXZlcnNlZCB9IGZyb20gJ0AvdXRpbHMnXG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGZpbHRlcnModmFsdWVzKSB7XG4gIGNvbnN0IGZpbHRlcnMgPSB7fVxuICBmb3IgKGNvbnN0IFtuYW1lLCBkZWZpbml0aW9uXSBvZiBPYmplY3QuZW50cmllcyhtZXJnZVJldmVyc2VkKHZhbHVlcykpKSB7XG4gICAgY29uc3QgZmlsdGVyID0gaXNGdW5jdGlvbihkZWZpbml0aW9uKVxuICAgICAgPyBkZWZpbml0aW9uXG4gICAgICA6IGlzT2JqZWN0KGRlZmluaXRpb24pXG4gICAgICAgID8gY29udmVydE9iamVjdEZpbHRlcihkZWZpbml0aW9uLCBuYW1lKVxuICAgICAgICA6IG51bGxcbiAgICBpZiAoIWZpbHRlcikge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgICBgSW52YWxpZCBmaWx0ZXIgJyR7bmFtZX0nOiBVbnJlY29nbml6ZWQgZGVmaW5pdGlvbjogJHtkZWZpbml0aW9ufS5gXG4gICAgICApXG4gICAgfVxuICAgIGZpbHRlcnNbbmFtZV0gPSB3cmFwV2l0aFZhbGlkYXRpb24oZmlsdGVyLCBuYW1lLCB0aGlzLmFwcClcbiAgfVxuICByZXR1cm4gZmlsdGVyc1xufVxuXG5mdW5jdGlvbiBjb252ZXJ0T2JqZWN0RmlsdGVyKGRlZmluaXRpb24sIG5hbWUpIHtcbiAgY29uc3QgeyBmaWx0ZXIsIHByb3BlcnRpZXMgfSA9IGRlZmluaXRpb25cbiAgaWYgKGlzRnVuY3Rpb24oZmlsdGVyKSkge1xuICAgIHJldHVybiBhZGRGdW5jdGlvblNldHRpbmdzKGZpbHRlciwgZGVmaW5pdGlvbilcbiAgfSBlbHNlIHtcbiAgICAvLyBDb252ZXJ0IFF1ZXJ5RmlsdGVycyB0byBub3JtYWwgZmlsdGVyIGZ1bmN0aW9uc1xuICAgIGNvbnN0IHF1ZXJ5RmlsdGVyID0gUXVlcnlGaWx0ZXJzLmdldChmaWx0ZXIpXG4gICAgaWYgKCFxdWVyeUZpbHRlcikge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgICBgSW52YWxpZCBmaWx0ZXIgJyR7bmFtZX0nOiBVbmtub3duIGZpbHRlciB0eXBlICcke2ZpbHRlcn0nLmBcbiAgICAgIClcbiAgICB9XG4gICAgY29uc3QgZnVuYyA9IHByb3BlcnRpZXNcbiAgICAgID8gKHF1ZXJ5LCAuLi5hcmdzKSA9PiB7XG4gICAgICAgIC8vIFdoZW4gdGhlIGZpbHRlciBwcm92aWRlcyBtdWx0aXBsZSBwcm9wZXJ0aWVzLCBtYXRjaCB0aGVtXG4gICAgICAgIC8vIGFsbCwgYnV0IGNvbWJpbmUgdGhlIGV4cHJlc3Npb25zIHdpdGggT1IuXG4gICAgICAgIGZvciAoY29uc3QgcHJvcGVydHkgb2YgcHJvcGVydGllcykge1xuICAgICAgICAgIHF1ZXJ5Lm9yV2hlcmUocXVlcnkgPT4gcXVlcnlGaWx0ZXIocXVlcnksIHByb3BlcnR5LCAuLi5hcmdzKSlcbiAgICAgICAgfVxuICAgICAgfVxuICAgICAgOiAocXVlcnksIC4uLmFyZ3MpID0+IHtcbiAgICAgICAgcXVlcnlGaWx0ZXIocXVlcnksIG5hbWUsIC4uLmFyZ3MpXG4gICAgICB9XG4gICAgcmV0dXJuIGFkZEZ1bmN0aW9uU2V0dGluZ3MoZnVuYywgcXVlcnlGaWx0ZXIpXG4gIH1cbn1cblxuZnVuY3Rpb24gYWRkRnVuY3Rpb25TZXR0aW5ncyhmaWx0ZXIsIGRlZmluaXRpb24pIHtcbiAgLy8gQ29weSBvdmVyIEBwYXJhbWV0ZXJzKCkgYW5kIEB2YWxpZGF0ZSgpIHNldHRpbmdzXG4gIGZpbHRlci5wYXJhbWV0ZXJzID0gZGVmaW5pdGlvbi5wYXJhbWV0ZXJzXG4gIGZpbHRlci52YWxpZGF0ZSA9IGRlZmluaXRpb24udmFsaWRhdGVcbiAgcmV0dXJuIGZpbHRlclxufVxuXG5mdW5jdGlvbiB3cmFwV2l0aFZhbGlkYXRpb24oZmlsdGVyLCBuYW1lLCBhcHApIHtcbiAgLy8gSWYgcGFyYW1ldGVycyBhcmUgZGVmaW5lZCwgd3JhcCB0aGUgZnVuY3Rpb24gaW4gYSBjbG9zdXJlIHRoYXRcbiAgLy8gcGVyZm9ybXMgcGFyYW1ldGVyIHZhbGlkYXRpb24uLi5cbiAgY29uc3QgZGF0YU5hbWUgPSAncXVlcnknXG4gIGNvbnN0IHZhbGlkYXRvciA9IGZpbHRlciAmJiBhcHAuY29tcGlsZVBhcmFtZXRlcnNWYWxpZGF0b3IoXG4gICAgZmlsdGVyLnBhcmFtZXRlcnMsXG4gICAgeyAuLi5maWx0ZXIudmFsaWRhdGUsIGRhdGFOYW1lIH1cbiAgKVxuICBpZiAodmFsaWRhdG9yPy52YWxpZGF0ZSkge1xuICAgIHJldHVybiAocXVlcnksIC4uLmFyZ3MpID0+IHtcbiAgICAgIC8vIENvbnZlcnQgYXJncyB0byBvYmplY3QgZm9yIHZhbGlkYXRpb246XG4gICAgICBjb25zdCBvYmplY3QgPSB7fVxuICAgICAgbGV0IGluZGV4ID0gMFxuICAgICAgZm9yIChjb25zdCB7IG5hbWUgfSBvZiB2YWxpZGF0b3IubGlzdCkge1xuICAgICAgICAvLyBVc2UgZGF0YU5hbWUgaWYgbm8gbmFtZSBpcyBnaXZlbiwgc2VlOlxuICAgICAgICAvLyBBcHBsaWNhdGlvbi5jb21waWxlUGFyYW1ldGVyc1ZhbGlkYXRvcigpXG4gICAgICAgIG9iamVjdFtuYW1lIHx8IGRhdGFOYW1lXSA9IGFyZ3NbaW5kZXgrK11cbiAgICAgIH1cbiAgICAgIHRyeSB7XG4gICAgICAgIHZhbGlkYXRvci52YWxpZGF0ZShvYmplY3QpXG4gICAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgICB0aHJvdyBhcHAuY3JlYXRlVmFsaWRhdGlvbkVycm9yKHtcbiAgICAgICAgICB0eXBlOiAnRmlsdGVyVmFsaWRhdGlvbicsXG4gICAgICAgICAgbWVzc2FnZTpcbiAgICAgICAgICAgIGBUaGUgcHJvdmlkZWQgZGF0YSBmb3IgcXVlcnkgZmlsdGVyICcke25hbWV9JyBpcyBub3QgdmFsaWRgLFxuICAgICAgICAgIGVycm9yczogYXBwLnZhbGlkYXRvci5wcmVmaXhEYXRhUGF0aHMoXG4gICAgICAgICAgICBlcnJvci5lcnJvcnMsXG4gICAgICAgICAgICBgLiR7bmFtZX1gXG4gICAgICAgICAgKVxuICAgICAgICB9KVxuICAgICAgfVxuICAgICAgcmV0dXJuIGZpbHRlcihxdWVyeSwgLi4uYXJncylcbiAgICB9XG4gIH1cbiAgLy8gLi4ub3RoZXJ3aXNlIHVzZSB0aGUgZGVmaW5lZCBmaWx0ZXIgZnVuY3Rpb24gdW5tb2RpZmllZC5cbiAgcmV0dXJuIGZpbHRlclxufVxuIl19
101
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9tb2RlbHMvZGVmaW5pdGlvbnMvZmlsdGVycy5qcyJdLCJuYW1lcyI6WyJmaWx0ZXJzIiwidmFsdWVzIiwibmFtZSIsImRlZmluaXRpb24iLCJPYmplY3QiLCJlbnRyaWVzIiwiZmlsdGVyIiwiY29udmVydE9iamVjdEZpbHRlciIsIkVycm9yIiwid3JhcFdpdGhWYWxpZGF0aW9uIiwiYXBwIiwicHJvcGVydGllcyIsImFkZEZ1bmN0aW9uU2V0dGluZ3MiLCJxdWVyeUZpbHRlciIsIlF1ZXJ5RmlsdGVycyIsImdldCIsImZ1bmMiLCJxdWVyeSIsImFyZ3MiLCJwcm9wZXJ0eSIsIm9yV2hlcmUiLCJwYXJhbWV0ZXJzIiwidmFsaWRhdGUiLCJkYXRhTmFtZSIsInZhbGlkYXRvciIsImNvbXBpbGVQYXJhbWV0ZXJzVmFsaWRhdG9yIiwib2JqZWN0IiwiaW5kZXgiLCJsaXN0IiwiZXJyb3IiLCJjcmVhdGVWYWxpZGF0aW9uRXJyb3IiLCJ0eXBlIiwibWVzc2FnZSIsImVycm9ycyIsInByZWZpeERhdGFQYXRocyJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUVlLFNBQVNBLE9BQVQsQ0FBaUJDLE1BQWpCLEVBQXlCO0FBQ3RDLFFBQU1ELE9BQU8sR0FBRyxFQUFoQjs7QUFDQSxPQUFLLE1BQU0sQ0FBQ0UsSUFBRCxFQUFPQyxVQUFQLENBQVgsSUFBaUNDLE1BQU0sQ0FBQ0MsT0FBUCxDQUFlLDJCQUFjSixNQUFkLENBQWYsQ0FBakMsRUFBd0U7QUFDdEUsVUFBTUssTUFBTSxHQUFHLHVCQUFXSCxVQUFYLElBQ1hBLFVBRFcsR0FFWCxxQkFBU0EsVUFBVCxJQUNFSSxtQkFBbUIsQ0FBQ0osVUFBRCxFQUFhRCxJQUFiLENBRHJCLEdBRUUsSUFKTjs7QUFLQSxRQUFJLENBQUNJLE1BQUwsRUFBYTtBQUNYLFlBQU0sSUFBSUUsS0FBSixDQUNILG1CQUFrQk4sSUFBSywrQkFBOEJDLFVBQVcsR0FEN0QsQ0FB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LEdBQUcsQ0FBQ2MsU0FBSixDQUFjVSxlQUFkLENBQ05MLEtBQUssQ0FBQ0ksTUFEQSxFQUVMLElBQUcvQixJQUFLLEVBRkg7QUFKc0IsU0FBMUIsQ0FBTjtBQVNEOztBQUNELGFBQU9JLE1BQU0sQ0FBQ1csS0FBRCxFQUFRLEdBQUdDLElBQVgsQ0FBYjtBQUNELEtBdkJEO0FBd0JEOztBQUVELFNBQU9aLE1BQVA7QUFDRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGlzT2JqZWN0LCBpc0Z1bmN0aW9uIH0gZnJvbSAnQGRpdG9qcy91dGlscydcbmltcG9ydCB7IFF1ZXJ5RmlsdGVycyB9IGZyb20gJ0AvcXVlcnknXG5pbXBvcnQgeyBtZXJnZVJldmVyc2VkIH0gZnJvbSAnQC91dGlscydcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gZmlsdGVycyh2YWx1ZXMpIHtcbiAgY29uc3QgZmlsdGVycyA9IHt9XG4gIGZvciAoY29uc3QgW25hbWUsIGRlZmluaXRpb25dIG9mIE9iamVjdC5lbnRyaWVzKG1lcmdlUmV2ZXJzZWQodmFsdWVzKSkpIHtcbiAgICBjb25zdCBmaWx0ZXIgPSBpc0Z1bmN0aW9uKGRlZmluaXRpb24pXG4gICAgICA/IGRlZmluaXRpb25cbiAgICAgIDogaXNPYmplY3QoZGVmaW5pdGlvbilcbiAgICAgICAgPyBjb252ZXJ0T2JqZWN0RmlsdGVyKGRlZmluaXRpb24sIG5hbWUpXG4gICAgICAgIDogbnVsbFxuICAgIGlmICghZmlsdGVyKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICAgIGBJbnZhbGlkIGZpbHRlciAnJHtuYW1lfSc6IFVucmVjb2duaXplZCBkZWZpbml0aW9uOiAke2RlZmluaXRpb259LmBcbiAgICAgIClcbiAgICB9XG4gICAgZmlsdGVyc1tuYW1lXSA9IHdyYXBXaXRoVmFsaWRhdGlvbihmaWx0ZXIsIG5hbWUsIHRoaXMuYXBwKVxuICB9XG4gIHJldHVybiBmaWx0ZXJzXG59XG5cbmZ1bmN0aW9uIGNvbnZlcnRPYmplY3RGaWx0ZXIoZGVmaW5pdGlvbiwgbmFtZSkge1xuICBjb25zdCB7IGZpbHRlciwgcHJvcGVydGllcyB9ID0gZGVmaW5pdGlvblxuICBpZiAoaXNGdW5jdGlvbihmaWx0ZXIpKSB7XG4gICAgcmV0dXJuIGFkZEZ1bmN0aW9uU2V0dGluZ3MoZmlsdGVyLCBkZWZpbml0aW9uKVxuICB9IGVsc2Uge1xuICAgIC8vIENvbnZlcnQgUXVlcnlGaWx0ZXJzIHRvIG5vcm1hbCBmaWx0ZXIgZnVuY3Rpb25zXG4gICAgY29uc3QgcXVlcnlGaWx0ZXIgPSBRdWVyeUZpbHRlcnMuZ2V0KGZpbHRlcilcbiAgICBpZiAoIXF1ZXJ5RmlsdGVyKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICAgIGBJbnZhbGlkIGZpbHRlciAnJHtuYW1lfSc6IFVua25vd24gZmlsdGVyIHR5cGUgJyR7ZmlsdGVyfScuYFxuICAgICAgKVxuICAgIH1cbiAgICBjb25zdCBmdW5jID0gcHJvcGVydGllc1xuICAgICAgPyAocXVlcnksIC4uLmFyZ3MpID0+IHtcbiAgICAgICAgLy8gV2hlbiB0aGUgZmlsdGVyIHByb3ZpZGVzIG11bHRpcGxlIHByb3BlcnRpZXMsIG1hdGNoIHRoZW1cbiAgICAgICAgLy8gYWxsLCBidXQgY29tYmluZSB0aGUgZXhwcmVzc2lvbnMgd2l0aCBPUi5cbiAgICAgICAgZm9yIChjb25zdCBwcm9wZXJ0eSBvZiBwcm9wZXJ0aWVzKSB7XG4gICAgICAgICAgcXVlcnkub3JXaGVyZShxdWVyeSA9PiBxdWVyeUZpbHRlcihxdWVyeSwgcHJvcGVydHksIC4uLmFyZ3MpKVxuICAgICAgICB9XG4gICAgICB9XG4gICAgICA6IChxdWVyeSwgLi4uYXJncykgPT4ge1xuICAgICAgICBxdWVyeUZpbHRlcihxdWVyeSwgbmFtZSwgLi4uYXJncylcbiAgICAgIH1cbiAgICByZXR1cm4gYWRkRnVuY3Rpb25TZXR0aW5ncyhmdW5jLCBxdWVyeUZpbHRlcilcbiAgfVxufVxuXG5mdW5jdGlvbiBhZGRGdW5jdGlvblNldHRpbmdzKGZpbHRlciwgZGVmaW5pdGlvbikge1xuICAvLyBDb3B5IG92ZXIgQHBhcmFtZXRlcnMoKSBhbmQgQHZhbGlkYXRlKCkgc2V0dGluZ3NcbiAgZmlsdGVyLnBhcmFtZXRlcnMgPSBkZWZpbml0aW9uLnBhcmFtZXRlcnNcbiAgZmlsdGVyLnZhbGlkYXRlID0gZGVmaW5pdGlvbi52YWxpZGF0ZVxuICByZXR1cm4gZmlsdGVyXG59XG5cbmZ1bmN0aW9uIHdyYXBXaXRoVmFsaWRhdGlvbihmaWx0ZXIsIG5hbWUsIGFwcCkge1xuICAvLyBJZiBwYXJhbWV0ZXJzIGFyZSBkZWZpbmVkLCB3cmFwIHRoZSBmdW5jdGlvbiBpbiBhIGNsb3N1cmUgdGhhdFxuICAvLyBwZXJmb3JtcyBwYXJhbWV0ZXIgdmFsaWRhdGlvbi4uLlxuICBjb25zdCBkYXRhTmFtZSA9ICdxdWVyeSdcbiAgY29uc3QgdmFsaWRhdG9yID0gZmlsdGVyICYmIGFwcC5jb21waWxlUGFyYW1ldGVyc1ZhbGlkYXRvcihcbiAgICBmaWx0ZXIucGFyYW1ldGVycyxcbiAgICB7IC4uLmZpbHRlci52YWxpZGF0ZSwgZGF0YU5hbWUgfVxuICApXG4gIGlmICh2YWxpZGF0b3I/LnZhbGlkYXRlKSB7XG4gICAgcmV0dXJuIChxdWVyeSwgLi4uYXJncykgPT4ge1xuICAgICAgLy8gQ29udmVydCBhcmdzIHRvIG9iamVjdCBmb3IgdmFsaWRhdGlvbjpcbiAgICAgIGNvbnN0IG9iamVjdCA9IHt9XG4gICAgICBsZXQgaW5kZXggPSAwXG4gICAgICBmb3IgKGNvbnN0IHsgbmFtZSB9IG9mIHZhbGlkYXRvci5saXN0KSB7XG4gICAgICAgIC8vIFVzZSBkYXRhTmFtZSBpZiBubyBuYW1lIGlzIGdpdmVuLCBzZWU6XG4gICAgICAgIC8vIEFwcGxpY2F0aW9uLmNvbXBpbGVQYXJhbWV0ZXJzVmFsaWRhdG9yKClcbiAgICAgICAgb2JqZWN0W25hbWUgfHwgZGF0YU5hbWVdID0gYXJnc1tpbmRleCsrXVxuICAgICAgfVxuICAgICAgdHJ5IHtcbiAgICAgICAgdmFsaWRhdG9yLnZhbGlkYXRlKG9iamVjdClcbiAgICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICAgIHRocm93IGFwcC5jcmVhdGVWYWxpZGF0aW9uRXJyb3Ioe1xuICAgICAgICAgIHR5cGU6ICdGaWx0ZXJWYWxpZGF0aW9uJyxcbiAgICAgICAgICBtZXNzYWdlOlxuICAgICAgICAgICAgYFRoZSBwcm92aWRlZCBkYXRhIGZvciBxdWVyeSBmaWx0ZXIgJyR7bmFtZX0nIGlzIG5vdCB2YWxpZGAsXG4gICAgICAgICAgZXJyb3JzOiBhcHAudmFsaWRhdG9yLnByZWZpeERhdGFQYXRocyhcbiAgICAgICAgICAgIGVycm9yLmVycm9ycyxcbiAgICAgICAgICAgIGAuJHtuYW1lfWBcbiAgICAgICAgICApXG4gICAgICAgIH0pXG4gICAgICB9XG4gICAgICByZXR1cm4gZmlsdGVyKHF1ZXJ5LCAuLi5hcmdzKVxuICAgIH1cbiAgfVxuICAvLyAuLi5vdGhlcndpc2UgdXNlIHRoZSBkZWZpbmVkIGZpbHRlciBmdW5jdGlvbiB1bm1vZGlmaWVkLlxuICByZXR1cm4gZmlsdGVyXG59XG4iXX0=