@ditojs/server 0.272.0 → 0.275.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 (78) hide show
  1. package/lib/app/Application.js +48 -8
  2. package/lib/app/SessionStore.js +3 -1
  3. package/lib/app/Validator.js +13 -1
  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/migrate.js +3 -3
  9. package/lib/cli/db/reset.js +3 -3
  10. package/lib/cli/db/rollback.js +3 -3
  11. package/lib/cli/db/seed.js +14 -6
  12. package/lib/cli/db/unlock.js +3 -3
  13. package/lib/cli/index.js +9 -5
  14. package/lib/controllers/AdminController.js +12 -2
  15. package/lib/controllers/CollectionController.js +15 -1
  16. package/lib/controllers/Controller.js +28 -4
  17. package/lib/controllers/ControllerAction.js +23 -14
  18. package/lib/controllers/RelationController.js +9 -3
  19. package/lib/controllers/UserController.js +15 -1
  20. package/lib/controllers/index.js +7 -1
  21. package/lib/decorators/index.js +7 -1
  22. package/lib/decorators/parameters.js +3 -1
  23. package/lib/decorators/returns.js +3 -1
  24. package/lib/errors/DatabaseError.js +5 -19
  25. package/lib/errors/ResponseError.js +4 -16
  26. package/lib/errors/index.js +7 -1
  27. package/lib/graph/DitoGraphProcessor.js +5 -1
  28. package/lib/graph/expression.js +5 -1
  29. package/lib/graph/graph.js +18 -2
  30. package/lib/graph/index.js +7 -1
  31. package/lib/index.js +7 -1
  32. package/lib/lib/index.js +7 -1
  33. package/lib/middleware/findRoute.js +7 -1
  34. package/lib/middleware/index.js +7 -1
  35. package/lib/middleware/logRequests.js +4 -4
  36. package/lib/mixins/AssetMixin.js +4 -4
  37. package/lib/mixins/SessionMixin.js +4 -4
  38. package/lib/mixins/TimeStampedMixin.js +4 -4
  39. package/lib/mixins/UserMixin.js +10 -4
  40. package/lib/mixins/index.js +7 -1
  41. package/lib/models/Model.js +21 -4
  42. package/lib/models/definitions/filters.js +9 -1
  43. package/lib/models/definitions/properties.js +7 -1
  44. package/lib/models/definitions/scopes.js +9 -1
  45. package/lib/models/index.js +7 -1
  46. package/lib/query/QueryBuilder.js +11 -1
  47. package/lib/query/QueryFilters.js +11 -1
  48. package/lib/query/index.js +7 -1
  49. package/lib/schema/formats/index.js +7 -1
  50. package/lib/schema/index.js +10 -2
  51. package/lib/schema/keywords/index.js +7 -1
  52. package/lib/schema/properties.js +11 -1
  53. package/lib/schema/relations.js +18 -4
  54. package/lib/services/index.js +7 -1
  55. package/lib/storage/DiskStorage.js +7 -1
  56. package/lib/storage/Storage.js +5 -1
  57. package/lib/storage/index.js +7 -1
  58. package/lib/utils/emitter.js +5 -1
  59. package/lib/utils/index.js +7 -1
  60. package/lib/utils/object.js +9 -3
  61. package/package.json +31 -31
  62. package/src/app/Application.js +39 -9
  63. package/src/cli/console.js +3 -3
  64. package/src/cli/db/createMigration.js +3 -3
  65. package/src/cli/db/migrate.js +4 -4
  66. package/src/cli/db/reset.js +4 -4
  67. package/src/cli/db/rollback.js +4 -4
  68. package/src/cli/db/seed.js +6 -6
  69. package/src/cli/db/unlock.js +2 -2
  70. package/src/cli/index.js +3 -3
  71. package/src/controllers/AdminController.js +1 -1
  72. package/src/controllers/Controller.js +8 -8
  73. package/src/controllers/ControllerAction.js +7 -13
  74. package/src/controllers/RelationController.js +2 -2
  75. package/src/errors/DatabaseError.js +2 -23
  76. package/src/errors/ResponseError.js +1 -9
  77. package/src/middleware/logRequests.js +9 -9
  78. package/src/models/Model.js +10 -8
@@ -3,6 +3,26 @@
3
3
  exports.__esModule = true;
4
4
  exports.Application = void 0;
5
5
 
6
+ require("core-js/modules/esnext.async-iterator.filter.js");
7
+
8
+ require("core-js/modules/esnext.iterator.constructor.js");
9
+
10
+ require("core-js/modules/esnext.iterator.filter.js");
11
+
12
+ require("core-js/modules/es.error.cause.js");
13
+
14
+ require("core-js/modules/esnext.async-iterator.reduce.js");
15
+
16
+ require("core-js/modules/esnext.iterator.reduce.js");
17
+
18
+ require("core-js/modules/esnext.async-iterator.find.js");
19
+
20
+ require("core-js/modules/esnext.iterator.find.js");
21
+
22
+ require("core-js/modules/esnext.async-iterator.map.js");
23
+
24
+ require("core-js/modules/esnext.iterator.map.js");
25
+
6
26
  var _koa = _interopRequireDefault(require("koa"));
7
27
 
8
28
  var _knex2 = _interopRequireDefault(require("knex"));
@@ -11,7 +31,7 @@ var _util = _interopRequireDefault(require("util"));
11
31
 
12
32
  var _axios = _interopRequireDefault(require("axios"));
13
33
 
14
- var _chalk = _interopRequireDefault(require("chalk"));
34
+ var _picocolors = _interopRequireDefault(require("picocolors"));
15
35
 
16
36
  var _zlib = _interopRequireDefault(require("zlib"));
17
37
 
@@ -181,7 +201,7 @@ class Application extends _koa.default {
181
201
  }
182
202
 
183
203
  if (Object.keys(data).length > 0) {
184
- console.info(_chalk.default.yellow.bold(`\n${modelClass.name}:\n`), _util.default.inspect(data, {
204
+ console.info(_picocolors.default.yellow.bold(`\n${modelClass.name}:\n`), _util.default.inspect(data, {
185
205
  colors: true,
186
206
  depth: null,
187
207
  maxArrayLength: null
@@ -487,12 +507,26 @@ class Application extends _koa.default {
487
507
  type,
488
508
  message,
489
509
  errors,
490
- options
510
+ options,
511
+ json
491
512
  }) {
513
+ var _this$config$log$erro;
514
+
492
515
  return new _errors.ValidationError({
493
516
  type,
494
517
  message,
495
- errors: this.validator.parseErrors(errors, options)
518
+ errors: this.validator.parseErrors(errors, options),
519
+ json: (_this$config$log$erro = this.config.log.errors) != null && _this$config$log$erro.json ? json : undefined
520
+ });
521
+ }
522
+
523
+ createDatabaseError(error) {
524
+ var _this$config$log$erro2;
525
+
526
+ const [, sql, message] = error.message.match(/^([\s\S]*) - ([\s\S]*?)$/) || [null, null, error.message];
527
+ return new _errors.DatabaseError(error, {
528
+ message,
529
+ sql: (_this$config$log$erro2 = this.config.log.errors) != null && _this$config$log$erro2.sql ? sql : undefined
496
530
  });
497
531
  }
498
532
 
@@ -625,6 +659,12 @@ class Application extends _koa.default {
625
659
 
626
660
  this.knex = (0, _knex2.default)(knex);
627
661
 
662
+ if (knex.client === 'postgresql' && knex.typeParsers && this.knex.client.driver) {
663
+ for (const [type, parser] of Object.entries(knex.typeParsers)) {
664
+ this.knex.client.driver.types.setTypeParser(type, parser);
665
+ }
666
+ }
667
+
628
668
  if (log.sql) {
629
669
  this.setupKnexLogging();
630
670
  }
@@ -687,11 +727,11 @@ class Application extends _koa.default {
687
727
  }
688
728
 
689
729
  formatError(err) {
690
- var _this$config$log$erro;
730
+ var _this$config$log$erro3;
691
731
 
692
732
  const message = err.toJSON ? (0, _utils.formatJson)(err.toJSON()) : err.message || err;
693
733
  const str = `${err.name}: ${message}`;
694
- return err.stack && ((_this$config$log$erro = this.config.log.errors) == null ? void 0 : _this$config$log$erro.stack) !== false ? `${str}\n${err.stack.split(/\n|\r\n|\r/).slice(1).join(_os.default.EOL)}` : str;
734
+ return err.stack && ((_this$config$log$erro3 = this.config.log.errors) == null ? void 0 : _this$config$log$erro3.stack) !== false ? `${str}\n${err.stack.split(/\n|\r\n|\r/).slice(1).join(_os.default.EOL)}` : str;
695
735
  }
696
736
 
697
737
  logError(err, ctx) {
@@ -833,7 +873,7 @@ class Application extends _koa.default {
833
873
  } = file;
834
874
 
835
875
  if (!data) {
836
- console.info(`${_chalk.default.red('INFO:')} Asset ${_chalk.default.green(`'${file.name}'`)} is from a foreign source, fetching from ${_chalk.default.green(`'${file.url}'`)} and adding to storage ${_chalk.default.green(`'${storage.name}'`)}...`);
876
+ console.info(`${_picocolors.default.red('INFO:')} Asset ${_picocolors.default.green(`'${file.name}'`)} is from a foreign source, fetching from ${_picocolors.default.green(`'${file.url}'`)} and adding to storage ${_picocolors.default.green(`'${storage.name}'`)}...`);
837
877
  const response = await _axios.default.request({
838
878
  method: 'get',
839
879
  url: file.url,
@@ -918,4 +958,4 @@ _lib.EventEmitter.mixin(Application.prototype);
918
958
  function getOptions(options) {
919
959
  return (0, _utils2.isObject)(options) ? options : {};
920
960
  }
921
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/app/Application.js"],"names":["Application","Koa","constructor","config","validator","router","events","middleware","models","services","controllers","_setupEmitter","app","keys","log","rest","silent","process","env","DITO_SILENT","proxy","Validator","Router","storages","Object","create","hasControllerMiddleware","setupLogger","setupKnex","setupGlobalMiddleware","use","addStorages","addModels","addServices","addControllers","addRoute","verb","path","transacted","handlers","controller","action","handler","length","route","modelClass","values","addModel","sortModels","sortedModels","filter","name","setup","knex","initialize","addSchema","getJsonSchema","schema","relations","shouldLog","option","includes","data","relationMappings","value","Model","isPrototypeOf","console","info","chalk","yellow","bold","util","inspect","colors","depth","maxArrayLength","Error","sortByRelations","list","collected","excluded","relation","getRelations","BelongsToOneRelation","relatedModelClass","joinTableModelClass","related","reverse","reduce","getModel","endsWith","findModel","callback","find","service","entries","addService","Service","undefined","getService","findService","forEachService","Promise","all","map","namespace","key","addController","setupControllerMiddleware","Controller","url","compose","getController","findController","getAdminController","AdminController","getAdminVueConfig","getVueConfig","getAssetConfig","normalizeDbNames","assetConfig","modelName","assets","definition","normalizedModelName","normalizeIdentifier","convertedAssets","assetDataPath","property","nestedDataPath","index","getPropertyOrRelationAtDataPath","normalizedName","dataPath","assetConfigs","addStorage","storage","storageClass","Storage","get","type","getStorage","compileValidator","jsonSchema","options","compile","compileParametersValidator","parameters","dataName","properties","addParameter","push","member","asObject","validate","coerceTypes","ctx","call","createValidationError","message","errors","ValidationError","parseErrors","logger","responseTime","getOptions","requests","helmet","cors","compress","br","params","zlib","constants","BROTLI_PARAM_QUALITY","etag","bodyParser","session","ContextStore","passport","err","req","res","pino","stdSerializers","user","id","serializers","level","prettyPrint","ignore","translateTime","redact","base","child","client","snakeCaseOptions","sql","setupKnexLogging","startTimes","end","query","response","error","__knexQueryUid","diff","hrtime","duration","bindings","fromEntries","startsWith","on","identifier","wrapIdentifier","replace","denormalizeIdentifier","obj","postProcessResponse","normalizePath","normalizePaths","formatError","toJSON","str","stack","split","slice","join","os","EOL","logError","expose","text","ResponseError","status","e","start","emit","server","host","port","resolve","reject","listen","address","stop","close","setImmediate","off","startOrExit","exit","createAssets","files","count","trx","AssetModel","file","insert","handleAdddedAndRemovedAssets","addedFiles","removedFiles","cleanupTimeThreshold","timeThreshold","importedFiles","addForeignAssets","changeCount","increment","whereIn","setTimeout","releaseUnusedAssets","asset","findOne","red","green","axios","request","method","responseType","importedFile","addFile","assign","AssetError","handleModifiedAssets","modifiedFiles","changedFile","transaction","date","Date","setMilliseconds","getMilliseconds","orphanedAssets","where","andWhere","orphanedKeys","removeFile","delete","EventEmitter","mixin","prototype"],"mappings":"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","sourcesContent":["import Koa from 'koa'\nimport Knex from 'knex'\nimport util from 'util'\nimport axios from 'axios'\nimport chalk from 'chalk'\nimport zlib from 'zlib'\nimport pino from 'pino'\nimport os from 'os'\nimport parseDuration from 'parse-duration'\nimport bodyParser from 'koa-bodyparser'\nimport cors from '@koa/cors'\nimport compose from 'koa-compose'\nimport compress from 'koa-compress'\nimport conditional from 'koa-conditional-get'\nimport passport from 'koa-passport'\nimport session from 'koa-session'\nimport etag from 'koa-etag'\nimport helmet from 'koa-helmet'\nimport responseTime from 'koa-response-time'\nimport Router from '@ditojs/router'\nimport { EventEmitter } from '@/lib'\nimport { Controller, AdminController } from '@/controllers'\nimport { Service } from '@/services'\nimport { Storage } from '@/storage'\nimport { convertSchema } from '@/schema'\nimport { formatJson } from '@/utils'\nimport { ResponseError, ValidationError, AssetError } from '@/errors'\nimport SessionStore from './SessionStore'\nimport { Validator } from './Validator'\nimport {\n  attachLogger,\n  createTransaction,\n  findRoute,\n  handleError,\n  handleRoute,\n  handleUser,\n  logRequests\n} from '@/middleware'\nimport {\n  isArray, isObject, isString, asArray, isPlainObject, hyphenate, clone, merge,\n  parseDataPath, normalizeDataPath\n} from '@ditojs/utils'\nimport {\n  Model,\n  BelongsToOneRelation,\n  knexSnakeCaseMappers,\n  ref\n} from 'objection'\n\nexport class Application extends Koa {\n  constructor({\n    config = {},\n    validator,\n    router,\n    events,\n    middleware,\n    models,\n    services,\n    controllers\n  } = {}) {\n    super()\n    this._setupEmitter(events)\n    const {\n      // Pluck keys out of `config.app` to keep them secret\n      app: { keys, ...app } = {},\n      log = {},\n      ...rest\n    } = config\n    this.config = {\n      app,\n      log: log.silent || process.env.DITO_SILENT ? {} : log,\n      ...rest\n    }\n    this.keys = keys\n    this.proxy = !!app.proxy\n    this.validator = validator || new Validator()\n    this.router = router || new Router()\n    this.validator.app = this\n    this.storages = Object.create(null)\n    this.models = Object.create(null)\n    this.services = Object.create(null)\n    this.controllers = Object.create(null)\n    this.hasControllerMiddleware = false\n    this.setupLogger()\n    this.setupKnex()\n    this.setupGlobalMiddleware()\n    if (middleware) {\n      this.use(middleware)\n    }\n    if (config.storages) {\n      this.addStorages(config.storages)\n    }\n    if (models) {\n      this.addModels(models)\n    }\n    if (services) {\n      this.addServices(services)\n    }\n    if (controllers) {\n      this.addControllers(controllers)\n    }\n  }\n\n  addRoute(verb, path, transacted, handlers, controller = null, action = null) {\n    handlers = asArray(handlers)\n    const handler = handlers.length > 1 ? compose(handlers) : handlers[0]\n    // Instead of directly passing `handler`, pass a `route` object that also\n    // will be exposed through `ctx.route`, see `routerHandler()`:\n    const route = {\n      verb,\n      path,\n      transacted,\n      handler,\n      controller,\n      action\n    }\n    this.router[verb](path, route)\n  }\n\n  addModels(models) {\n    // First add all models then call initialize() for each in a second loop,\n    // since they may be referencing each other in relations.\n    for (const modelClass of Object.values(models)) {\n      this.addModel(modelClass)\n    }\n    // Now (re-)sort all models based on their relations.\n    this.models = this.sortModels(this.models)\n    // Filter through all sorted models, keeping only the newly added ones.\n    const sortedModels = Object.values(this.models).filter(\n      modelClass => models[modelClass.name] === modelClass\n    )\n    // Initialize the added models in correct sorted sequence, so that for every\n    // model, getRelatedRelations() returns the full list of relating relations.\n    for (const modelClass of sortedModels) {\n      if (models[modelClass.name] === modelClass) {\n        modelClass.setup(this.knex)\n        // Now that the modelClass is set up, call `initialize()`, which can be\n        // overridden by sub-classes,without having to call `super.initialize()`\n        modelClass.initialize()\n        this.validator.addSchema(modelClass.getJsonSchema())\n      }\n    }\n    const { log } = this.config\n    if (log.schema || log.relations) {\n      for (const modelClass of sortedModels) {\n        const shouldLog = option => (\n          option === true ||\n          asArray(option).includes(modelClass.name)\n        )\n        const data = {}\n        if (shouldLog(log.schema)) {\n          data.schema = modelClass.getJsonSchema()\n        }\n        if (shouldLog(log.relations)) {\n          data.relations = clone(modelClass.relationMappings, value =>\n            Model.isPrototypeOf(value) ? `[Model: ${value.name}]` : value\n          )\n        }\n        if (Object.keys(data).length > 0) {\n          console.info(\n            chalk.yellow.bold(`\\n${modelClass.name}:\\n`),\n            util.inspect(data, {\n              colors: true,\n              depth: null,\n              maxArrayLength: null\n            })\n          )\n        }\n      }\n    }\n  }\n\n  addModel(modelClass) {\n    if (Model.isPrototypeOf(modelClass)) {\n      modelClass.app = this\n      this.models[modelClass.name] = modelClass\n    } else {\n      throw new Error(`Invalid model class: ${modelClass}`)\n    }\n  }\n\n  sortModels(models) {\n    const sortByRelations = (list, collected = {}, excluded = {}) => {\n      for (const modelClass of list) {\n        const { name } = modelClass\n        if (!collected[name] && !excluded[name]) {\n          for (const relation of Object.values(modelClass.getRelations())) {\n            if (!(relation instanceof BelongsToOneRelation)) {\n              const { relatedModelClass, joinTableModelClass } = relation\n              for (const related of [joinTableModelClass, relatedModelClass]) {\n                // Exclude self-references and generated join models:\n                if (related && related !== modelClass && models[related.name]) {\n                  sortByRelations([related], collected, {\n                    // Exclude modelClass to prevent endless recursions:\n                    [name]: modelClass,\n                    ...excluded\n                  })\n                }\n              }\n            }\n          }\n          collected[name] = modelClass\n        }\n      }\n      return Object.values(collected)\n    }\n    // Return a new object with the sorted models as its key/value pairs.\n    // NOTE: We need to reverse for the above algorithm to sort properly,\n    // and then reverse the result back.\n    return sortByRelations(Object.values(models).reverse()).reverse().reduce(\n      (models, modelClass) => {\n        models[modelClass.name] = modelClass\n        return models\n      },\n      Object.create(null)\n    )\n  }\n\n  getModel(name) {\n    return (\n      this.models[name] ||\n      !name.endsWith('Model') && this.models[`${name}Model`] ||\n      null\n    )\n  }\n\n  findModel(callback) {\n    return Object.values(this.models).find(callback)\n  }\n\n  addServices(services) {\n    for (const [name, service] of Object.entries(services)) {\n      // Handle ES6 module weirdness that can happen, apparently:\n      if (name === 'default' && isPlainObject(service)) {\n        this.addServices(service)\n      } else {\n        this.addService(service, name)\n      }\n    }\n  }\n\n  addService(service, name) {\n    // Auto-instantiate controller classes:\n    if (Service.isPrototypeOf(service)) {\n      // eslint-disable-next-line new-cap\n      service = new service(this, name)\n    }\n    if (!(service instanceof Service)) {\n      throw new Error(`Invalid service: ${service}`)\n    }\n    // Only after the constructor is called, `service.name` is guaranteed to be\n    // set to the correct value, e.g. with an after-constructor class property.\n    ({ name } = service)\n    const config = this.config.services[name]\n    if (config === undefined) {\n      throw new Error(`Configuration missing for service '${name}'`)\n    }\n    // As a convention, the configuration of a service can be set to `false`\n    // in order to entirely deactivate the service.\n    if (config !== false) {\n      service.setup(config)\n      this.services[name] = service\n      // Now that the service is set up, call `initialize()` which can be\n      // overridden by services.\n      service.initialize()\n    }\n  }\n\n  getService(name) {\n    return this.services[name] || null\n  }\n\n  findService(callback) {\n    return Object.values(this.services).find(callback)\n  }\n\n  forEachService(callback) {\n    return Promise.all(Object.values(this.services).map(callback))\n  }\n\n  addControllers(controllers, namespace) {\n    for (const [key, value] of Object.entries(controllers)) {\n      if (isPlainObject(value)) {\n        this.addControllers(value, namespace ? `${namespace}/${key}` : key)\n      } else {\n        this.addController(value, namespace)\n      }\n    }\n  }\n\n  addController(controller, namespace) {\n    // Controllers require additional middleware to be installed once.\n    this.setupControllerMiddleware()\n    // Auto-instantiate controller classes:\n    if (Controller.isPrototypeOf(controller)) {\n      // eslint-disable-next-line new-cap\n      controller = new controller(this, namespace)\n    }\n    if (!(controller instanceof Controller)) {\n      throw new Error(`Invalid controller: ${controller}`)\n    }\n    // Inheritance of action methods cannot happen in the constructor itself,\n    // so call separate `setup()` method after in order to take care of it.\n    controller.setup()\n    this.controllers[controller.url] = controller\n    // Now that the controller is set up, call `initialize()` which can be\n    // overridden by controllers.\n    controller.initialize()\n    // Each controller can also provide further middleware, e.g.\n    // `AdminController`:\n    const middleware = controller.compose()\n    if (middleware) {\n      this.use(middleware)\n    }\n  }\n\n  getController(url) {\n    return this.controllers[url] || null\n  }\n\n  findController(callback) {\n    return Object.values(this.controllers).find(callback)\n  }\n\n  getAdminController() {\n    return this.findController(\n      controller => controller instanceof AdminController\n    )\n  }\n\n  getAdminVueConfig() {\n    return this.getAdminController()?.getVueConfig() || null\n  }\n\n  getAssetConfig({\n    models = Object.keys(this.models),\n    normalizeDbNames = this.config.knex.normalizeDbNames\n  } = {}) {\n    const assetConfig = {}\n    for (const modelName of models) {\n      const modelClass = this.models[modelName]\n      const { assets } = modelClass.definition\n      if (assets) {\n        const normalizedModelName = normalizeDbNames\n          ? this.normalizeIdentifier(modelName)\n          : modelName\n        const convertedAssets = {}\n        for (const [assetDataPath, config] of Object.entries(assets)) {\n          const {\n            property,\n            nestedDataPath,\n            name,\n            index\n          } = modelClass.getPropertyOrRelationAtDataPath(assetDataPath)\n          if (property && index === 0) {\n            const normalizedName = normalizeDbNames\n              ? this.normalizeIdentifier(name)\n              : name\n            const dataPath = normalizeDataPath([\n              normalizedName,\n              ...parseDataPath(nestedDataPath)\n            ])\n            const assetConfigs = convertedAssets[normalizedName] ||= {}\n            assetConfigs[dataPath] = config\n          } else {\n            throw new Error('Nested graph properties are not supported yet')\n          }\n        }\n        assetConfig[normalizedModelName] = convertedAssets\n      }\n    }\n    return assetConfig\n  }\n\n  addStorages(storages) {\n    for (const [name, config] of Object.entries(storages)) {\n      this.addStorage(config, name)\n    }\n  }\n\n  addStorage(config, name) {\n    let storage = null\n    if (isPlainObject(config)) {\n      const storageClass = Storage.get(config.type)\n      if (!storageClass) {\n        throw new Error(`Unsupported storage: ${config}`)\n      }\n      // eslint-disable-next-line new-cap\n      storage = new storageClass(this, config)\n    } else if (config instanceof Storage) {\n      storage = config\n    }\n    if (storage) {\n      if (name) {\n        storage.name = name\n      }\n      this.storages[storage.name] = storage\n    }\n    return storage\n  }\n\n  getStorage(name) {\n    return this.storages[name] || null\n  }\n\n  compileValidator(jsonSchema, options) {\n    return jsonSchema\n      ? this.validator.compile(jsonSchema, options)\n      : null\n  }\n\n  compileParametersValidator(parameters, options = {}) {\n    const list = []\n    const { dataName = 'data' } = options\n\n    let properties = null\n    const addParameter = (name, schema) => {\n      list.push({\n        name: name ?? null,\n        ...schema\n      })\n      if (!schema.member) {\n        properties ||= {}\n        properties[name || dataName] = schema\n      }\n    }\n\n    // Support two formats of parameters definitions:\n    // - An array of parameter schemas, named by their `name` key.\n    // - An object of parameter schemas, named by the key under which each\n    //   schema is stored in the root object.\n    // If an array is passed, then the controller actions receives the\n    // parameters as separate arguments. If an object is passed, then the\n    // actions receives one parameter object where under the same keys the\n    // specified parameter values are stored.\n    let asObject = false\n    if (isArray(parameters)) {\n      for (const { name, ...schema } of parameters) {\n        addParameter(name, schema)\n      }\n    } else if (isObject(parameters)) {\n      asObject = true\n      for (const [name, schema] of Object.entries(parameters)) {\n        if (schema) {\n          addParameter(name, schema)\n        }\n      }\n    } else if (parameters) {\n      throw new Error(`Invalid parameters definition: ${parameters}`)\n    }\n    // NOTE: If properties is null, schema and validate will become null too.\n    // NOTE: If it is not null, it will get expanded to an object schema.\n    const schema = convertSchema(properties, options)\n    const validate = this.compileValidator(schema, {\n      // For parameters, always coerce types, including arrays.\n      coerceTypes: 'array',\n      ...options\n    })\n    const ctx = {\n      app: this,\n      validator: this.validator,\n      options\n    }\n    return {\n      list,\n      schema,\n      asObject,\n      dataName,\n      validate: validate\n        // Use `call()` to pass ctx as context to Ajv, see passContext:\n        ? data => validate.call(ctx, data)\n        : null\n    }\n  }\n\n  createValidationError({ type, message, errors, options }) {\n    return new ValidationError({\n      type,\n      message,\n      errors: this.validator.parseErrors(errors, options)\n    })\n  }\n\n  setupGlobalMiddleware() {\n    const { app, log } = this.config\n\n    this.use(attachLogger(this.logger))\n\n    if (app.responseTime !== false) {\n      this.use(responseTime(getOptions(app.responseTime)))\n    }\n    if (log.requests) {\n      this.use(logRequests())\n    }\n    // Needs to be positioned after the request logger to log the correct\n    // response status.\n    this.use(handleError())\n    if (app.helmet !== false) {\n      this.use(helmet(getOptions(app.helmet)))\n    }\n    if (app.cors !== false) {\n      this.use(cors(getOptions(app.cors)))\n    }\n    if (app.compress !== false) {\n      this.use(compress(merge(\n        {\n          // Use a reasonable default for Brotli compression.\n          // See https://github.com/koajs/compress/issues/126\n          br: {\n            params: {\n              [zlib.constants.BROTLI_PARAM_QUALITY]: 4\n            }\n          }\n        },\n        getOptions(app.compress)\n      )))\n    }\n    if (app.etag !== false) {\n      this.use(conditional())\n      this.use(etag())\n    }\n  }\n\n  setupControllerMiddleware() {\n    // NOTE: This is not part of the automatic `setupGlobalMiddleware()` so that\n    // apps can set up the static serving of assets before installing the\n    // session and passport middleware. It is called from `addController()`.\n    // Use a flag to only install the middleware once:\n    if (!this.hasControllerMiddleware) {\n      const { app } = this.config\n      // Sequence is important:\n      // 1. body parser\n      this.use(bodyParser(getOptions(app.bodyParser)))\n      // 2. find route from routes installed by controllers.\n      this.use(findRoute(this.router))\n      // 3. respect transacted settings, create and handle transactions.\n      this.use(createTransaction())\n      // 4. session\n      if (app.session) {\n        const {\n          modelClass,\n          ...options\n        } = getOptions(app.session)\n        if (modelClass) {\n          // Create a ContextStore that resolved the specified model class,\n          // uses it to persist and retrieve the session, and automatically\n          // binds all db operations to `ctx.transaction`, if it is set.\n          // eslint-disable-next-line new-cap\n          options.ContextStore = SessionStore(modelClass)\n        }\n        this.use(session(options, this))\n      }\n      // 5. passport\n      if (app.passport) {\n        this.use(passport.initialize())\n        if (app.session) {\n          this.use(passport.session())\n        }\n        this.use(handleUser())\n      }\n\n      // 6. finally handle the found route, or set status / allow accordingly.\n      this.use(handleRoute())\n      this.hasControllerMiddleware = true\n    }\n  }\n\n  setupLogger() {\n    const { err, req, res } = pino.stdSerializers\n    // Only include `id` from the user, to not inadvertently log PII.\n    const user = user => ({ id: user.id })\n    const serializers = { err, req, res, user }\n\n    const logger = pino(merge(\n      {\n        level: 'info',\n        serializers,\n        prettyPrint: {\n          // List of keys to ignore in pretty mode.\n          ignore: 'req,res,durationMs,user,requestId',\n          // SYS to use system time and not UTC.\n          translateTime: 'SYS:HH:MM:ss.l'\n        },\n        // Redact common sensitive headers.\n        redact: [\n          '*.headers[\"cookie\"]',\n          '*.headers[\"set-cookie\"]',\n          '*.headers[\"authorization\"]'\n        ],\n        base: null // no pid,hostname,name\n      },\n      getOptions(this.config.logger)\n    ))\n\n    this.logger = logger.child({ name: 'app' })\n  }\n\n  setupKnex() {\n    let { knex, log } = this.config\n    if (knex?.client) {\n      const snakeCaseOptions = knex.normalizeDbNames === true\n        ? {}\n        : knex.normalizeDbNames\n      if (snakeCaseOptions) {\n        knex = {\n          ...knex,\n          ...knexSnakeCaseMappers(snakeCaseOptions)\n        }\n      }\n      this.knex = Knex(knex)\n      if (log.sql) {\n        this.setupKnexLogging()\n      }\n    }\n  }\n\n  setupKnexLogging() {\n    const startTimes = {}\n    const logger = this.logger.child({ name: 'sql' })\n    function end(query, { response, error }) {\n      const id = query.__knexQueryUid\n      const diff = process.hrtime(startTimes[id])\n      const duration = diff[0] * 1e3 + diff[1] / 1e6\n      delete startTimes[id]\n      const { sql, bindings } = query\n      response = Object.fromEntries(\n        Object.entries(response).filter(\n          ([key]) => !key.startsWith('_')\n        )\n      )\n      logger.info({ duration, bindings, response, error }, sql)\n    }\n\n    this.knex\n      .on('query', query => {\n        startTimes[query.__knexQueryUid] = process.hrtime()\n      })\n      .on('query-response', (response, query) => {\n        end(query, { response })\n      })\n      .on('query-error', (error, query) => {\n        end(query, { error })\n      })\n  }\n\n  normalizeIdentifier(identifier) {\n    return this.knex.client.wrapIdentifier(identifier).replace(/['`\"]/g, '')\n  }\n\n  denormalizeIdentifier(identifier) {\n    const obj = this.knex.client.postProcessResponse({ [identifier]: 1 })\n    return Object.keys(obj)[0]\n  }\n\n  normalizePath(path) {\n    return this.config.app.normalizePaths ? hyphenate(path) : path\n  }\n\n  formatError(err) {\n    const message = err.toJSON\n      ? formatJson(err.toJSON())\n      : err.message || err\n    const str = `${err.name}: ${message}`\n    return err.stack && this.config.log.errors?.stack !== false\n      ? `${str}\\n${err.stack.split(/\\n|\\r\\n|\\r/).slice(1).join(os.EOL)}`\n      : str\n  }\n\n  logError(err, ctx) {\n    if (!err.expose && !this.silent) {\n      try {\n        const text = this.formatError(err)\n        const level =\n          err instanceof ResponseError && err.status < 500 ? 'info' : 'error'\n        const logger = ctx?.logger || this.logger\n        logger[level](text)\n      } catch (e) {\n        console.error('Could not log error', e)\n      }\n    }\n  }\n\n  async start() {\n    if (this.config.log.errors !== false) {\n      this.on('error', this.logError)\n    }\n    await this.emit('before:start')\n    await this.forEachService(service => service.start())\n    const {\n      server: { host, port },\n      env\n    } = this.config\n    this.server = await new Promise((resolve, reject) => {\n      const server = this.listen(port, host, () => {\n        const { port } = server.address()\n        console.info(\n          `${env} server started at http://${host}:${port}`\n        )\n        resolve(server)\n      })\n      if (!server) {\n        reject(new Error(`Unable to start server at http://${host}:${port}`))\n      }\n    })\n    await this.emit('after:start')\n  }\n\n  async stop() {\n    await this.emit('before:stop')\n    this.server = await new Promise((resolve, reject) => {\n      const { server } = this\n      if (server) {\n        server.close(err => {\n          if (err) {\n            reject(err)\n          } else {\n            resolve(null)\n          }\n        })\n        // Hack to make sure that we close the server,\n        //  even if sockets are still open.\n        //  Taken from https://stackoverflow.com/a/36830072.\n        //  A proper solution would be to use a library, ex: https://github.com/godaddy/terminus\n        setImmediate(() => server.emit('close'))\n      } else {\n        reject(new Error('Server is not running'))\n      }\n    })\n    await this.forEachService(service => service.stop())\n    await this.emit('after:stop')\n    if (this.config.log.errors !== false) {\n      this.off('error', this.logError)\n    }\n  }\n\n  async startOrExit() {\n    try {\n      await this.start()\n    } catch (err) {\n      this.logError(err)\n      process.exit(-1)\n    }\n  }\n\n  // Assets handling\n\n  async createAssets(storage, files, count = 0, trx = null) {\n    const AssetModel = this.getModel('Asset')\n    if (AssetModel) {\n      const assets = files.map(file => ({\n        key: file.key,\n        file,\n        storage: storage.name,\n        count\n      }))\n      return AssetModel\n        .query(trx)\n        .insert(assets)\n    }\n    return null\n  }\n\n  async handleAdddedAndRemovedAssets(\n    storage,\n    addedFiles,\n    removedFiles,\n    trx = null\n  ) {\n    const {\n      assets: {\n        cleanupTimeThreshold = 0\n      } = {}\n    } = this.config\n    // Only remove unused assets that haven't seen changes for given timeframe.\n    const timeThreshold = isString(cleanupTimeThreshold)\n      ? parseDuration(cleanupTimeThreshold)\n      : cleanupTimeThreshold\n\n    const importedFiles = []\n    const AssetModel = this.getModel('Asset')\n    if (AssetModel) {\n      importedFiles.push(\n        ...await this.addForeignAssets(storage, addedFiles, trx)\n      )\n      if (\n        addedFiles.length > 0 ||\n        removedFiles.length > 0\n      ) {\n        const changeCount = (files, increment) => (\n          files.length > 0 &&\n          AssetModel.query(trx)\n            .whereIn('key', files.map(file => file.key))\n            .increment('count', increment)\n        )\n        await Promise.all([\n          changeCount(addedFiles, 1),\n          changeCount(removedFiles, -1)\n        ])\n        if (timeThreshold > 0) {\n          setTimeout(\n            // Don't pass `trx` here, as we want this delayed execution to\n            // create its own transaction.\n            () => this.releaseUnusedAssets(timeThreshold),\n            timeThreshold\n          )\n        }\n      }\n      // Also execute releaseUnusedAssets() immediately in the same\n      // transaction, to potentially clean up other pending assets.\n      await this.releaseUnusedAssets(timeThreshold, trx)\n      return importedFiles\n    }\n  }\n\n  async addForeignAssets(storage, files, trx = null) {\n    const importedFiles = []\n    const AssetModel = this.getModel('Asset')\n    if (AssetModel) {\n      // Find missing assets (copied from another system), and add them.\n      await Promise.all(\n        files.map(async file => {\n          const asset = await AssetModel.query(trx).findOne('key', file.key)\n          if (!asset) {\n            if (file.data || file.url) {\n              let { data } = file\n              if (!data) {\n                console.info(\n                  `${\n                    chalk.red('INFO:')\n                  } Asset ${\n                    chalk.green(`'${file.name}'`)\n                  } is from a foreign source, fetching from ${\n                    chalk.green(`'${file.url}'`)\n                  } and adding to storage ${\n                    chalk.green(`'${storage.name}'`)\n                  }...`\n                )\n                const response = await axios.request({\n                  method: 'get',\n                  url: file.url,\n                  responseType: 'arraybuffer'\n                })\n                data = response.data\n              }\n              const importedFile = await storage.addFile(file, data)\n              await this.createAssets(storage, [importedFile], 0, trx)\n              // Merge back the changed file properties into the actual files\n              // object, so that the data from the static model hook can be used\n              // directly for the actual running query.\n              Object.assign(file, importedFile)\n              importedFiles.push(importedFile)\n            } else {\n              throw new AssetError(\n                `Unable to import asset from foreign source: '${\n                  file.name\n                }' ('${\n                  file.key\n                }')`\n              )\n            }\n          } else {\n            // Asset is from a foreign source, but was already imported and can\n            // be reused. See above for an explanation of this merge.\n            Object.assign(file, asset.file)\n            // NOTE: No need to add `file` to `importedFiles`, since it's\n            // already been imported to the storage before.\n          }\n        })\n      )\n    }\n    return importedFiles\n  }\n\n  async handleModifiedAssets(storage, files, trx = null) {\n    const modifiedFiles = []\n    const AssetModel = this.getModel('Asset')\n    if (AssetModel) {\n      await Promise.all(\n        files.map(async file => {\n          if (file.data) {\n            const asset = await AssetModel.query(trx).findOne('key', file.key)\n            if (asset) {\n              const changedFile = await storage.addFile(file, file.data)\n              // Merge back the changed file properties into the actual files\n              // object, so that the data from the static model hook can be used\n              // directly for the actual running query.\n              Object.assign(file, changedFile)\n              modifiedFiles.push(changedFile)\n            } else {\n              throw new AssetError(\n                `Unable to update modified asset from memory source: '${\n                  file.name\n                }' ('${\n                  file.key\n                }')`\n              )\n            }\n          }\n        })\n      )\n    }\n    return modifiedFiles\n  }\n\n  async releaseUnusedAssets(timeThreshold = 0, trx = null) {\n    const AssetModel = this.getModel('Asset')\n    if (AssetModel) {\n      return AssetModel.transaction(trx, async trx => {\n        // Determine the time threshold in JS instead of SQL, as there is no\n        // easy cross-SQL way to do `now() - interval X hours`:\n        const date = new Date()\n        date.setMilliseconds(date.getMilliseconds() - timeThreshold)\n        const orphanedAssets = await AssetModel\n          .query(trx)\n          .where('count', 0)\n          .andWhere('updatedAt', '<=', date)\n          // Protect freshly created assets from being deleted again right away,\n          // .e.g. when `config.assets.cleanupTimeThreshold = 0`\n          .andWhere('updatedAt', '>', ref('createdAt'))\n        if (orphanedAssets.length > 0) {\n          const orphanedKeys = await Promise.all(\n            orphanedAssets.map(async asset => {\n              try {\n                await this.getStorage(asset.storage).removeFile(asset.file)\n              } catch (error) {\n                this.emit('error', error)\n                asset.error = error\n              }\n              return asset.key\n            })\n          )\n          await AssetModel\n            .query(trx)\n            .delete()\n            .whereIn('key', orphanedKeys)\n        }\n        return orphanedAssets\n      })\n    }\n  }\n}\n\n// Override Koa's events with our own EventEmitter that adds support for\n// asynchronous events.\nEventEmitter.mixin(Application.prototype)\n\nfunction getOptions(options) {\n  return isObject(options) ? options : {}\n}\n"]}
961
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/app/Application.js"],"names":["Application","Koa","constructor","config","validator","router","events","middleware","models","services","controllers","_setupEmitter","app","keys","log","rest","silent","process","env","DITO_SILENT","proxy","Validator","Router","storages","Object","create","hasControllerMiddleware","setupLogger","setupKnex","setupGlobalMiddleware","use","addStorages","addModels","addServices","addControllers","addRoute","verb","path","transacted","handlers","controller","action","handler","length","route","modelClass","values","addModel","sortModels","sortedModels","filter","name","setup","knex","initialize","addSchema","getJsonSchema","schema","relations","shouldLog","option","includes","data","relationMappings","value","Model","isPrototypeOf","console","info","pico","yellow","bold","util","inspect","colors","depth","maxArrayLength","Error","sortByRelations","list","collected","excluded","relation","getRelations","BelongsToOneRelation","relatedModelClass","joinTableModelClass","related","reverse","reduce","getModel","endsWith","findModel","callback","find","service","entries","addService","Service","undefined","getService","findService","forEachService","Promise","all","map","namespace","key","addController","setupControllerMiddleware","Controller","url","compose","getController","findController","getAdminController","AdminController","getAdminVueConfig","getVueConfig","getAssetConfig","normalizeDbNames","assetConfig","modelName","assets","definition","normalizedModelName","normalizeIdentifier","convertedAssets","assetDataPath","property","nestedDataPath","index","getPropertyOrRelationAtDataPath","normalizedName","dataPath","assetConfigs","addStorage","storage","storageClass","Storage","get","type","getStorage","compileValidator","jsonSchema","options","compile","compileParametersValidator","parameters","dataName","properties","addParameter","push","member","asObject","validate","coerceTypes","ctx","call","createValidationError","message","errors","json","ValidationError","parseErrors","createDatabaseError","error","sql","match","DatabaseError","logger","responseTime","getOptions","requests","helmet","cors","compress","br","params","zlib","constants","BROTLI_PARAM_QUALITY","etag","bodyParser","session","ContextStore","passport","err","req","res","pino","stdSerializers","user","id","serializers","level","prettyPrint","ignore","translateTime","redact","base","child","client","snakeCaseOptions","typeParsers","driver","parser","types","setTypeParser","setupKnexLogging","startTimes","end","query","response","__knexQueryUid","diff","hrtime","duration","bindings","fromEntries","startsWith","on","identifier","wrapIdentifier","replace","denormalizeIdentifier","obj","postProcessResponse","normalizePath","normalizePaths","formatError","toJSON","str","stack","split","slice","join","os","EOL","logError","expose","text","ResponseError","status","e","start","emit","server","host","port","resolve","reject","listen","address","stop","close","setImmediate","off","startOrExit","exit","createAssets","files","count","trx","AssetModel","file","insert","handleAdddedAndRemovedAssets","addedFiles","removedFiles","cleanupTimeThreshold","timeThreshold","importedFiles","addForeignAssets","changeCount","increment","whereIn","setTimeout","releaseUnusedAssets","asset","findOne","red","green","axios","request","method","responseType","importedFile","addFile","assign","AssetError","handleModifiedAssets","modifiedFiles","changedFile","transaction","date","Date","setMilliseconds","getMilliseconds","orphanedAssets","where","andWhere","orphanedKeys","removeFile","delete","EventEmitter","mixin","prototype"],"mappings":"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","sourcesContent":["import Koa from 'koa'\nimport Knex from 'knex'\nimport util from 'util'\nimport axios from 'axios'\nimport pico from 'picocolors'\nimport zlib from 'zlib'\nimport pino from 'pino'\nimport os from 'os'\nimport parseDuration from 'parse-duration'\nimport bodyParser from 'koa-bodyparser'\nimport cors from '@koa/cors'\nimport compose from 'koa-compose'\nimport compress from 'koa-compress'\nimport conditional from 'koa-conditional-get'\nimport passport from 'koa-passport'\nimport session from 'koa-session'\nimport etag from 'koa-etag'\nimport helmet from 'koa-helmet'\nimport responseTime from 'koa-response-time'\nimport Router from '@ditojs/router'\nimport { EventEmitter } from '@/lib'\nimport { Controller, AdminController } from '@/controllers'\nimport { Service } from '@/services'\nimport { Storage } from '@/storage'\nimport { convertSchema } from '@/schema'\nimport { formatJson } from '@/utils'\nimport {\n  ResponseError,\n  ValidationError,\n  DatabaseError,\n  AssetError\n} from '@/errors'\nimport SessionStore from './SessionStore'\nimport { Validator } from './Validator'\nimport {\n  attachLogger,\n  createTransaction,\n  findRoute,\n  handleError,\n  handleRoute,\n  handleUser,\n  logRequests\n} from '@/middleware'\nimport {\n  isArray, isObject, isString, asArray, isPlainObject, hyphenate, clone, merge,\n  parseDataPath, normalizeDataPath\n} from '@ditojs/utils'\nimport {\n  Model,\n  BelongsToOneRelation,\n  knexSnakeCaseMappers,\n  ref\n} from 'objection'\n\nexport class Application extends Koa {\n  constructor({\n    config = {},\n    validator,\n    router,\n    events,\n    middleware,\n    models,\n    services,\n    controllers\n  } = {}) {\n    super()\n    this._setupEmitter(events)\n    const {\n      // Pluck keys out of `config.app` to keep them secret\n      app: { keys, ...app } = {},\n      log = {},\n      ...rest\n    } = config\n    this.config = {\n      app,\n      log: log.silent || process.env.DITO_SILENT ? {} : log,\n      ...rest\n    }\n    this.keys = keys\n    this.proxy = !!app.proxy\n    this.validator = validator || new Validator()\n    this.router = router || new Router()\n    this.validator.app = this\n    this.storages = Object.create(null)\n    this.models = Object.create(null)\n    this.services = Object.create(null)\n    this.controllers = Object.create(null)\n    this.hasControllerMiddleware = false\n    this.setupLogger()\n    this.setupKnex()\n    this.setupGlobalMiddleware()\n    if (middleware) {\n      this.use(middleware)\n    }\n    if (config.storages) {\n      this.addStorages(config.storages)\n    }\n    if (models) {\n      this.addModels(models)\n    }\n    if (services) {\n      this.addServices(services)\n    }\n    if (controllers) {\n      this.addControllers(controllers)\n    }\n  }\n\n  addRoute(verb, path, transacted, handlers, controller = null, action = null) {\n    handlers = asArray(handlers)\n    const handler = handlers.length > 1 ? compose(handlers) : handlers[0]\n    // Instead of directly passing `handler`, pass a `route` object that also\n    // will be exposed through `ctx.route`, see `routerHandler()`:\n    const route = {\n      verb,\n      path,\n      transacted,\n      handler,\n      controller,\n      action\n    }\n    this.router[verb](path, route)\n  }\n\n  addModels(models) {\n    // First add all models then call initialize() for each in a second loop,\n    // since they may be referencing each other in relations.\n    for (const modelClass of Object.values(models)) {\n      this.addModel(modelClass)\n    }\n    // Now (re-)sort all models based on their relations.\n    this.models = this.sortModels(this.models)\n    // Filter through all sorted models, keeping only the newly added ones.\n    const sortedModels = Object.values(this.models).filter(\n      modelClass => models[modelClass.name] === modelClass\n    )\n    // Initialize the added models in correct sorted sequence, so that for every\n    // model, getRelatedRelations() returns the full list of relating relations.\n    for (const modelClass of sortedModels) {\n      if (models[modelClass.name] === modelClass) {\n        modelClass.setup(this.knex)\n        // Now that the modelClass is set up, call `initialize()`, which can be\n        // overridden by sub-classes,without having to call `super.initialize()`\n        modelClass.initialize()\n        this.validator.addSchema(modelClass.getJsonSchema())\n      }\n    }\n    const { log } = this.config\n    if (log.schema || log.relations) {\n      for (const modelClass of sortedModels) {\n        const shouldLog = option => (\n          option === true ||\n          asArray(option).includes(modelClass.name)\n        )\n        const data = {}\n        if (shouldLog(log.schema)) {\n          data.schema = modelClass.getJsonSchema()\n        }\n        if (shouldLog(log.relations)) {\n          data.relations = clone(modelClass.relationMappings, value =>\n            Model.isPrototypeOf(value) ? `[Model: ${value.name}]` : value\n          )\n        }\n        if (Object.keys(data).length > 0) {\n          console.info(\n            pico.yellow.bold(`\\n${modelClass.name}:\\n`),\n            util.inspect(data, {\n              colors: true,\n              depth: null,\n              maxArrayLength: null\n            })\n          )\n        }\n      }\n    }\n  }\n\n  addModel(modelClass) {\n    if (Model.isPrototypeOf(modelClass)) {\n      modelClass.app = this\n      this.models[modelClass.name] = modelClass\n    } else {\n      throw new Error(`Invalid model class: ${modelClass}`)\n    }\n  }\n\n  sortModels(models) {\n    const sortByRelations = (list, collected = {}, excluded = {}) => {\n      for (const modelClass of list) {\n        const { name } = modelClass\n        if (!collected[name] && !excluded[name]) {\n          for (const relation of Object.values(modelClass.getRelations())) {\n            if (!(relation instanceof BelongsToOneRelation)) {\n              const { relatedModelClass, joinTableModelClass } = relation\n              for (const related of [joinTableModelClass, relatedModelClass]) {\n                // Exclude self-references and generated join models:\n                if (related && related !== modelClass && models[related.name]) {\n                  sortByRelations([related], collected, {\n                    // Exclude modelClass to prevent endless recursions:\n                    [name]: modelClass,\n                    ...excluded\n                  })\n                }\n              }\n            }\n          }\n          collected[name] = modelClass\n        }\n      }\n      return Object.values(collected)\n    }\n    // Return a new object with the sorted models as its key/value pairs.\n    // NOTE: We need to reverse for the above algorithm to sort properly,\n    // and then reverse the result back.\n    return sortByRelations(Object.values(models).reverse()).reverse().reduce(\n      (models, modelClass) => {\n        models[modelClass.name] = modelClass\n        return models\n      },\n      Object.create(null)\n    )\n  }\n\n  getModel(name) {\n    return (\n      this.models[name] ||\n      !name.endsWith('Model') && this.models[`${name}Model`] ||\n      null\n    )\n  }\n\n  findModel(callback) {\n    return Object.values(this.models).find(callback)\n  }\n\n  addServices(services) {\n    for (const [name, service] of Object.entries(services)) {\n      // Handle ES6 module weirdness that can happen, apparently:\n      if (name === 'default' && isPlainObject(service)) {\n        this.addServices(service)\n      } else {\n        this.addService(service, name)\n      }\n    }\n  }\n\n  addService(service, name) {\n    // Auto-instantiate controller classes:\n    if (Service.isPrototypeOf(service)) {\n      // eslint-disable-next-line new-cap\n      service = new service(this, name)\n    }\n    if (!(service instanceof Service)) {\n      throw new Error(`Invalid service: ${service}`)\n    }\n    // Only after the constructor is called, `service.name` is guaranteed to be\n    // set to the correct value, e.g. with an after-constructor class property.\n    ({ name } = service)\n    const config = this.config.services[name]\n    if (config === undefined) {\n      throw new Error(`Configuration missing for service '${name}'`)\n    }\n    // As a convention, the configuration of a service can be set to `false`\n    // in order to entirely deactivate the service.\n    if (config !== false) {\n      service.setup(config)\n      this.services[name] = service\n      // Now that the service is set up, call `initialize()` which can be\n      // overridden by services.\n      service.initialize()\n    }\n  }\n\n  getService(name) {\n    return this.services[name] || null\n  }\n\n  findService(callback) {\n    return Object.values(this.services).find(callback)\n  }\n\n  forEachService(callback) {\n    return Promise.all(Object.values(this.services).map(callback))\n  }\n\n  addControllers(controllers, namespace) {\n    for (const [key, value] of Object.entries(controllers)) {\n      if (isPlainObject(value)) {\n        this.addControllers(value, namespace ? `${namespace}/${key}` : key)\n      } else {\n        this.addController(value, namespace)\n      }\n    }\n  }\n\n  addController(controller, namespace) {\n    // Controllers require additional middleware to be installed once.\n    this.setupControllerMiddleware()\n    // Auto-instantiate controller classes:\n    if (Controller.isPrototypeOf(controller)) {\n      // eslint-disable-next-line new-cap\n      controller = new controller(this, namespace)\n    }\n    if (!(controller instanceof Controller)) {\n      throw new Error(`Invalid controller: ${controller}`)\n    }\n    // Inheritance of action methods cannot happen in the constructor itself,\n    // so call separate `setup()` method after in order to take care of it.\n    controller.setup()\n    this.controllers[controller.url] = controller\n    // Now that the controller is set up, call `initialize()` which can be\n    // overridden by controllers.\n    controller.initialize()\n    // Each controller can also provide further middleware, e.g.\n    // `AdminController`:\n    const middleware = controller.compose()\n    if (middleware) {\n      this.use(middleware)\n    }\n  }\n\n  getController(url) {\n    return this.controllers[url] || null\n  }\n\n  findController(callback) {\n    return Object.values(this.controllers).find(callback)\n  }\n\n  getAdminController() {\n    return this.findController(\n      controller => controller instanceof AdminController\n    )\n  }\n\n  getAdminVueConfig() {\n    return this.getAdminController()?.getVueConfig() || null\n  }\n\n  getAssetConfig({\n    models = Object.keys(this.models),\n    normalizeDbNames = this.config.knex.normalizeDbNames\n  } = {}) {\n    const assetConfig = {}\n    for (const modelName of models) {\n      const modelClass = this.models[modelName]\n      const { assets } = modelClass.definition\n      if (assets) {\n        const normalizedModelName = normalizeDbNames\n          ? this.normalizeIdentifier(modelName)\n          : modelName\n        const convertedAssets = {}\n        for (const [assetDataPath, config] of Object.entries(assets)) {\n          const {\n            property,\n            nestedDataPath,\n            name,\n            index\n          } = modelClass.getPropertyOrRelationAtDataPath(assetDataPath)\n          if (property && index === 0) {\n            const normalizedName = normalizeDbNames\n              ? this.normalizeIdentifier(name)\n              : name\n            const dataPath = normalizeDataPath([\n              normalizedName,\n              ...parseDataPath(nestedDataPath)\n            ])\n            const assetConfigs = convertedAssets[normalizedName] ||= {}\n            assetConfigs[dataPath] = config\n          } else {\n            throw new Error('Nested graph properties are not supported yet')\n          }\n        }\n        assetConfig[normalizedModelName] = convertedAssets\n      }\n    }\n    return assetConfig\n  }\n\n  addStorages(storages) {\n    for (const [name, config] of Object.entries(storages)) {\n      this.addStorage(config, name)\n    }\n  }\n\n  addStorage(config, name) {\n    let storage = null\n    if (isPlainObject(config)) {\n      const storageClass = Storage.get(config.type)\n      if (!storageClass) {\n        throw new Error(`Unsupported storage: ${config}`)\n      }\n      // eslint-disable-next-line new-cap\n      storage = new storageClass(this, config)\n    } else if (config instanceof Storage) {\n      storage = config\n    }\n    if (storage) {\n      if (name) {\n        storage.name = name\n      }\n      this.storages[storage.name] = storage\n    }\n    return storage\n  }\n\n  getStorage(name) {\n    return this.storages[name] || null\n  }\n\n  compileValidator(jsonSchema, options) {\n    return jsonSchema\n      ? this.validator.compile(jsonSchema, options)\n      : null\n  }\n\n  compileParametersValidator(parameters, options = {}) {\n    const list = []\n    const { dataName = 'data' } = options\n\n    let properties = null\n    const addParameter = (name, schema) => {\n      list.push({\n        name: name ?? null,\n        ...schema\n      })\n      if (!schema.member) {\n        properties ||= {}\n        properties[name || dataName] = schema\n      }\n    }\n\n    // Support two formats of parameters definitions:\n    // - An array of parameter schemas, named by their `name` key.\n    // - An object of parameter schemas, named by the key under which each\n    //   schema is stored in the root object.\n    // If an array is passed, then the controller actions receives the\n    // parameters as separate arguments. If an object is passed, then the\n    // actions receives one parameter object where under the same keys the\n    // specified parameter values are stored.\n    let asObject = false\n    if (isArray(parameters)) {\n      for (const { name, ...schema } of parameters) {\n        addParameter(name, schema)\n      }\n    } else if (isObject(parameters)) {\n      asObject = true\n      for (const [name, schema] of Object.entries(parameters)) {\n        if (schema) {\n          addParameter(name, schema)\n        }\n      }\n    } else if (parameters) {\n      throw new Error(`Invalid parameters definition: ${parameters}`)\n    }\n    // NOTE: If properties is null, schema and validate will become null too.\n    // NOTE: If it is not null, it will get expanded to an object schema.\n    const schema = convertSchema(properties, options)\n    const validate = this.compileValidator(schema, {\n      // For parameters, always coerce types, including arrays.\n      coerceTypes: 'array',\n      ...options\n    })\n    const ctx = {\n      app: this,\n      validator: this.validator,\n      options\n    }\n    return {\n      list,\n      schema,\n      asObject,\n      dataName,\n      validate: validate\n        // Use `call()` to pass ctx as context to Ajv, see passContext:\n        ? data => validate.call(ctx, data)\n        : null\n    }\n  }\n\n  createValidationError({ type, message, errors, options, json }) {\n    return new ValidationError({\n      type,\n      message,\n      errors: this.validator.parseErrors(errors, options),\n      // Only include the JSON data in the error if `log.errors.json`is set.\n      json: this.config.log.errors?.json ? json : undefined\n    })\n  }\n\n  createDatabaseError(error) {\n    // Remove knex SQL query and move to separate `sql` property.\n    // TODO: Fix this properly in Knex / Objection instead, see:\n    // https://gitter.im/Vincit/objection.js?at=5a68728f5a9ebe4f75ca40b0\n    const [, sql, message] = error.message.match(/^([\\s\\S]*) - ([\\s\\S]*?)$/) ||\n      [null, null, error.message]\n    return new DatabaseError(error, {\n      message,\n      // Only include the SQL query in the error if `log.errors.sql`is set.\n      sql: this.config.log.errors?.sql ? sql : undefined\n    })\n  }\n\n  setupGlobalMiddleware() {\n    const { app, log } = this.config\n\n    this.use(attachLogger(this.logger))\n\n    if (app.responseTime !== false) {\n      this.use(responseTime(getOptions(app.responseTime)))\n    }\n    if (log.requests) {\n      this.use(logRequests())\n    }\n    // Needs to be positioned after the request logger to log the correct\n    // response status.\n    this.use(handleError())\n    if (app.helmet !== false) {\n      this.use(helmet(getOptions(app.helmet)))\n    }\n    if (app.cors !== false) {\n      this.use(cors(getOptions(app.cors)))\n    }\n    if (app.compress !== false) {\n      this.use(compress(merge(\n        {\n          // Use a reasonable default for Brotli compression.\n          // See https://github.com/koajs/compress/issues/126\n          br: {\n            params: {\n              [zlib.constants.BROTLI_PARAM_QUALITY]: 4\n            }\n          }\n        },\n        getOptions(app.compress)\n      )))\n    }\n    if (app.etag !== false) {\n      this.use(conditional())\n      this.use(etag())\n    }\n  }\n\n  setupControllerMiddleware() {\n    // NOTE: This is not part of the automatic `setupGlobalMiddleware()` so that\n    // apps can set up the static serving of assets before installing the\n    // session and passport middleware. It is called from `addController()`.\n    // Use a flag to only install the middleware once:\n    if (!this.hasControllerMiddleware) {\n      const { app } = this.config\n      // Sequence is important:\n      // 1. body parser\n      this.use(bodyParser(getOptions(app.bodyParser)))\n      // 2. find route from routes installed by controllers.\n      this.use(findRoute(this.router))\n      // 3. respect transacted settings, create and handle transactions.\n      this.use(createTransaction())\n      // 4. session\n      if (app.session) {\n        const {\n          modelClass,\n          ...options\n        } = getOptions(app.session)\n        if (modelClass) {\n          // Create a ContextStore that resolved the specified model class,\n          // uses it to persist and retrieve the session, and automatically\n          // binds all db operations to `ctx.transaction`, if it is set.\n          // eslint-disable-next-line new-cap\n          options.ContextStore = SessionStore(modelClass)\n        }\n        this.use(session(options, this))\n      }\n      // 5. passport\n      if (app.passport) {\n        this.use(passport.initialize())\n        if (app.session) {\n          this.use(passport.session())\n        }\n        this.use(handleUser())\n      }\n\n      // 6. finally handle the found route, or set status / allow accordingly.\n      this.use(handleRoute())\n      this.hasControllerMiddleware = true\n    }\n  }\n\n  setupLogger() {\n    const { err, req, res } = pino.stdSerializers\n    // Only include `id` from the user, to not inadvertently log PII.\n    const user = user => ({ id: user.id })\n    const serializers = { err, req, res, user }\n\n    const logger = pino(merge(\n      {\n        level: 'info',\n        serializers,\n        prettyPrint: {\n          // List of keys to ignore in pretty mode.\n          ignore: 'req,res,durationMs,user,requestId',\n          // SYS to use system time and not UTC.\n          translateTime: 'SYS:HH:MM:ss.l'\n        },\n        // Redact common sensitive headers.\n        redact: [\n          '*.headers[\"cookie\"]',\n          '*.headers[\"set-cookie\"]',\n          '*.headers[\"authorization\"]'\n        ],\n        base: null // no pid,hostname,name\n      },\n      getOptions(this.config.logger)\n    ))\n\n    this.logger = logger.child({ name: 'app' })\n  }\n\n  setupKnex() {\n    let { knex, log } = this.config\n    if (knex?.client) {\n      const snakeCaseOptions = knex.normalizeDbNames === true\n        ? {}\n        : knex.normalizeDbNames\n      if (snakeCaseOptions) {\n        knex = {\n          ...knex,\n          ...knexSnakeCaseMappers(snakeCaseOptions)\n        }\n      }\n      this.knex = Knex(knex)\n      // Support PostgreSQL type parser mappings in the config.\n      if (\n        knex.client === 'postgresql' &&\n        knex.typeParsers &&\n        this.knex.client.driver\n      ) {\n        for (const [type, parser] of Object.entries(knex.typeParsers)) {\n          this.knex.client.driver.types.setTypeParser(type, parser)\n        }\n      }\n      if (log.sql) {\n        this.setupKnexLogging()\n      }\n    }\n  }\n\n  setupKnexLogging() {\n    const startTimes = {}\n    const logger = this.logger.child({ name: 'sql' })\n    function end(query, { response, error }) {\n      const id = query.__knexQueryUid\n      const diff = process.hrtime(startTimes[id])\n      const duration = diff[0] * 1e3 + diff[1] / 1e6\n      delete startTimes[id]\n      const { sql, bindings } = query\n      response = Object.fromEntries(\n        Object.entries(response).filter(\n          ([key]) => !key.startsWith('_')\n        )\n      )\n      logger.info({ duration, bindings, response, error }, sql)\n    }\n\n    this.knex\n      .on('query', query => {\n        startTimes[query.__knexQueryUid] = process.hrtime()\n      })\n      .on('query-response', (response, query) => {\n        end(query, { response })\n      })\n      .on('query-error', (error, query) => {\n        end(query, { error })\n      })\n  }\n\n  normalizeIdentifier(identifier) {\n    return this.knex.client.wrapIdentifier(identifier).replace(/['`\"]/g, '')\n  }\n\n  denormalizeIdentifier(identifier) {\n    const obj = this.knex.client.postProcessResponse({ [identifier]: 1 })\n    return Object.keys(obj)[0]\n  }\n\n  normalizePath(path) {\n    return this.config.app.normalizePaths ? hyphenate(path) : path\n  }\n\n  formatError(err) {\n    const message = err.toJSON\n      ? formatJson(err.toJSON())\n      : err.message || err\n    const str = `${err.name}: ${message}`\n    return err.stack && this.config.log.errors?.stack !== false\n      ? `${str}\\n${err.stack.split(/\\n|\\r\\n|\\r/).slice(1).join(os.EOL)}`\n      : str\n  }\n\n  logError(err, ctx) {\n    if (!err.expose && !this.silent) {\n      try {\n        const text = this.formatError(err)\n        const level =\n          err instanceof ResponseError && err.status < 500 ? 'info' : 'error'\n        const logger = ctx?.logger || this.logger\n        logger[level](text)\n      } catch (e) {\n        console.error('Could not log error', e)\n      }\n    }\n  }\n\n  async start() {\n    if (this.config.log.errors !== false) {\n      this.on('error', this.logError)\n    }\n    await this.emit('before:start')\n    await this.forEachService(service => service.start())\n    const {\n      server: { host, port },\n      env\n    } = this.config\n    this.server = await new Promise((resolve, reject) => {\n      const server = this.listen(port, host, () => {\n        const { port } = server.address()\n        console.info(\n          `${env} server started at http://${host}:${port}`\n        )\n        resolve(server)\n      })\n      if (!server) {\n        reject(new Error(`Unable to start server at http://${host}:${port}`))\n      }\n    })\n    await this.emit('after:start')\n  }\n\n  async stop() {\n    await this.emit('before:stop')\n    this.server = await new Promise((resolve, reject) => {\n      const { server } = this\n      if (server) {\n        server.close(err => {\n          if (err) {\n            reject(err)\n          } else {\n            resolve(null)\n          }\n        })\n        // Hack to make sure that we close the server,\n        //  even if sockets are still open.\n        //  Taken from https://stackoverflow.com/a/36830072.\n        //  A proper solution would be to use a library, ex: https://github.com/godaddy/terminus\n        setImmediate(() => server.emit('close'))\n      } else {\n        reject(new Error('Server is not running'))\n      }\n    })\n    await this.forEachService(service => service.stop())\n    await this.emit('after:stop')\n    if (this.config.log.errors !== false) {\n      this.off('error', this.logError)\n    }\n  }\n\n  async startOrExit() {\n    try {\n      await this.start()\n    } catch (err) {\n      this.logError(err)\n      process.exit(-1)\n    }\n  }\n\n  // Assets handling\n\n  async createAssets(storage, files, count = 0, trx = null) {\n    const AssetModel = this.getModel('Asset')\n    if (AssetModel) {\n      const assets = files.map(file => ({\n        key: file.key,\n        file,\n        storage: storage.name,\n        count\n      }))\n      return AssetModel\n        .query(trx)\n        .insert(assets)\n    }\n    return null\n  }\n\n  async handleAdddedAndRemovedAssets(\n    storage,\n    addedFiles,\n    removedFiles,\n    trx = null\n  ) {\n    const {\n      assets: {\n        cleanupTimeThreshold = 0\n      } = {}\n    } = this.config\n    // Only remove unused assets that haven't seen changes for given timeframe.\n    const timeThreshold = isString(cleanupTimeThreshold)\n      ? parseDuration(cleanupTimeThreshold)\n      : cleanupTimeThreshold\n\n    const importedFiles = []\n    const AssetModel = this.getModel('Asset')\n    if (AssetModel) {\n      importedFiles.push(\n        ...await this.addForeignAssets(storage, addedFiles, trx)\n      )\n      if (\n        addedFiles.length > 0 ||\n        removedFiles.length > 0\n      ) {\n        const changeCount = (files, increment) => (\n          files.length > 0 &&\n          AssetModel.query(trx)\n            .whereIn('key', files.map(file => file.key))\n            .increment('count', increment)\n        )\n        await Promise.all([\n          changeCount(addedFiles, 1),\n          changeCount(removedFiles, -1)\n        ])\n        if (timeThreshold > 0) {\n          setTimeout(\n            // Don't pass `trx` here, as we want this delayed execution to\n            // create its own transaction.\n            () => this.releaseUnusedAssets(timeThreshold),\n            timeThreshold\n          )\n        }\n      }\n      // Also execute releaseUnusedAssets() immediately in the same\n      // transaction, to potentially clean up other pending assets.\n      await this.releaseUnusedAssets(timeThreshold, trx)\n      return importedFiles\n    }\n  }\n\n  async addForeignAssets(storage, files, trx = null) {\n    const importedFiles = []\n    const AssetModel = this.getModel('Asset')\n    if (AssetModel) {\n      // Find missing assets (copied from another system), and add them.\n      await Promise.all(\n        files.map(async file => {\n          const asset = await AssetModel.query(trx).findOne('key', file.key)\n          if (!asset) {\n            if (file.data || file.url) {\n              let { data } = file\n              if (!data) {\n                console.info(\n                  `${\n                    pico.red('INFO:')\n                  } Asset ${\n                    pico.green(`'${file.name}'`)\n                  } is from a foreign source, fetching from ${\n                    pico.green(`'${file.url}'`)\n                  } and adding to storage ${\n                    pico.green(`'${storage.name}'`)\n                  }...`\n                )\n                const response = await axios.request({\n                  method: 'get',\n                  url: file.url,\n                  responseType: 'arraybuffer'\n                })\n                data = response.data\n              }\n              const importedFile = await storage.addFile(file, data)\n              await this.createAssets(storage, [importedFile], 0, trx)\n              // Merge back the changed file properties into the actual files\n              // object, so that the data from the static model hook can be used\n              // directly for the actual running query.\n              Object.assign(file, importedFile)\n              importedFiles.push(importedFile)\n            } else {\n              throw new AssetError(\n                `Unable to import asset from foreign source: '${\n                  file.name\n                }' ('${\n                  file.key\n                }')`\n              )\n            }\n          } else {\n            // Asset is from a foreign source, but was already imported and can\n            // be reused. See above for an explanation of this merge.\n            Object.assign(file, asset.file)\n            // NOTE: No need to add `file` to `importedFiles`, since it's\n            // already been imported to the storage before.\n          }\n        })\n      )\n    }\n    return importedFiles\n  }\n\n  async handleModifiedAssets(storage, files, trx = null) {\n    const modifiedFiles = []\n    const AssetModel = this.getModel('Asset')\n    if (AssetModel) {\n      await Promise.all(\n        files.map(async file => {\n          if (file.data) {\n            const asset = await AssetModel.query(trx).findOne('key', file.key)\n            if (asset) {\n              const changedFile = await storage.addFile(file, file.data)\n              // Merge back the changed file properties into the actual files\n              // object, so that the data from the static model hook can be used\n              // directly for the actual running query.\n              Object.assign(file, changedFile)\n              modifiedFiles.push(changedFile)\n            } else {\n              throw new AssetError(\n                `Unable to update modified asset from memory source: '${\n                  file.name\n                }' ('${\n                  file.key\n                }')`\n              )\n            }\n          }\n        })\n      )\n    }\n    return modifiedFiles\n  }\n\n  async releaseUnusedAssets(timeThreshold = 0, trx = null) {\n    const AssetModel = this.getModel('Asset')\n    if (AssetModel) {\n      return AssetModel.transaction(trx, async trx => {\n        // Determine the time threshold in JS instead of SQL, as there is no\n        // easy cross-SQL way to do `now() - interval X hours`:\n        const date = new Date()\n        date.setMilliseconds(date.getMilliseconds() - timeThreshold)\n        const orphanedAssets = await AssetModel\n          .query(trx)\n          .where('count', 0)\n          .andWhere('updatedAt', '<=', date)\n          // Protect freshly created assets from being deleted again right away,\n          // .e.g. when `config.assets.cleanupTimeThreshold = 0`\n          .andWhere('updatedAt', '>', ref('createdAt'))\n        if (orphanedAssets.length > 0) {\n          const orphanedKeys = await Promise.all(\n            orphanedAssets.map(async asset => {\n              try {\n                await this.getStorage(asset.storage).removeFile(asset.file)\n              } catch (error) {\n                this.emit('error', error)\n                asset.error = error\n              }\n              return asset.key\n            })\n          )\n          await AssetModel\n            .query(trx)\n            .delete()\n            .whereIn('key', orphanedKeys)\n        }\n        return orphanedAssets\n      })\n    }\n  }\n}\n\n// Override Koa's events with our own EventEmitter that adds support for\n// asynchronous events.\nEventEmitter.mixin(Application.prototype)\n\nfunction getOptions(options) {\n  return isObject(options) ? options : {}\n}\n"]}
@@ -3,6 +3,8 @@
3
3
  exports.__esModule = true;
4
4
  exports.default = void 0;
5
5
 
6
+ require("core-js/modules/es.error.cause.js");
7
+
6
8
  var _default = modelName => class SessionStore {
7
9
  constructor(ctx) {
8
10
  this.ctx = ctx;
@@ -35,4 +37,4 @@ var _default = modelName => class SessionStore {
35
37
  };
36
38
 
37
39
  exports.default = _default;
38
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9hcHAvU2Vzc2lvblN0b3JlLmpzIl0sIm5hbWVzIjpbIm1vZGVsTmFtZSIsIlNlc3Npb25TdG9yZSIsImNvbnN0cnVjdG9yIiwiY3R4IiwibW9kZWxDbGFzcyIsImFwcCIsIm1vZGVscyIsIkVycm9yIiwicXVlcnkiLCJ0cmFuc2FjdGlvbiIsImdldCIsImlkIiwic2Vzc2lvbiIsImZpbmRCeUlkIiwidmFsdWUiLCJzZXQiLCJ1cHNlcnQiLCJnZXRSZWZlcmVuY2UiLCJkZXN0cm95Iiwia2V5IiwiZGVsZXRlQnlJZCJdLCJtYXBwaW5ncyI6Ijs7Ozs7ZUFBZUEsU0FBUyxJQUFJLE1BQU1DLFlBQU4sQ0FBbUI7QUFDN0NDLEVBQUFBLFdBQVcsQ0FBQ0MsR0FBRCxFQUFNO0FBQ2YsU0FBS0EsR0FBTCxHQUFXQSxHQUFYO0FBQ0EsU0FBS0MsVUFBTCxHQUFrQkQsR0FBRyxDQUFDRSxHQUFKLENBQVFDLE1BQVIsQ0FBZU4sU0FBZixDQUFsQjs7QUFDQSxRQUFJLENBQUMsS0FBS0ksVUFBVixFQUFzQjtBQUNwQixZQUFNLElBQUlHLEtBQUosQ0FBVyxnQ0FBK0JQLFNBQVUsR0FBcEQsQ0FBTjtBQUNEO0FBQ0Y7O0FBRURRLEVBQUFBLEtBQUssR0FBRztBQUNOLFdBQU8sS0FBS0osVUFBTCxDQUFnQkksS0FBaEIsQ0FBc0IsS0FBS0wsR0FBTCxDQUFTTSxXQUEvQixDQUFQO0FBQ0Q7O0FBRVEsUUFBSEMsR0FBRyxDQUFDQyxFQUFELEVBQUs7QUFDWixVQUFNQyxPQUFPLEdBQUcsTUFBTSxLQUFLSixLQUFMLEdBQWFLLFFBQWIsQ0FBc0JGLEVBQXRCLENBQXRCO0FBQ0EsV0FBTyxDQUFBQyxPQUFPLFFBQVAsWUFBQUEsT0FBTyxDQUFFRSxLQUFULEtBQWtCLEVBQXpCO0FBQ0Q7O0FBRVEsUUFBSEMsR0FBRyxDQUFDSixFQUFELEVBQUtHLEtBQUwsRUFBWTtBQUNuQixVQUFNLEtBQUtOLEtBQUwsR0FDSEssUUFERyxDQUNNRixFQUROLEVBRUhLLE1BRkcsQ0FFSSxFQUNOLEdBQUcsS0FBS1osVUFBTCxDQUFnQmEsWUFBaEIsQ0FBNkJOLEVBQTdCLENBREc7QUFFTkcsTUFBQUE7QUFGTSxLQUZKLENBQU47QUFNRDs7QUFFWSxRQUFQSSxPQUFPLENBQUNDLEdBQUQsRUFBTTtBQUNqQixXQUFPLEtBQUtYLEtBQUwsR0FBYVksVUFBYixDQUF3QkQsR0FBeEIsQ0FBUDtBQUNEOztBQTdCNEMsQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBkZWZhdWx0IG1vZGVsTmFtZSA9PiBjbGFzcyBTZXNzaW9uU3RvcmUge1xuICBjb25zdHJ1Y3RvcihjdHgpIHtcbiAgICB0aGlzLmN0eCA9IGN0eFxuICAgIHRoaXMubW9kZWxDbGFzcyA9IGN0eC5hcHAubW9kZWxzW21vZGVsTmFtZV1cbiAgICBpZiAoIXRoaXMubW9kZWxDbGFzcykge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBVbmFibGUgdG8gZmluZCBtb2RlbCBjbGFzczogJyR7bW9kZWxOYW1lfSdgKVxuICAgIH1cbiAgfVxuXG4gIHF1ZXJ5KCkge1xuICAgIHJldHVybiB0aGlzLm1vZGVsQ2xhc3MucXVlcnkodGhpcy5jdHgudHJhbnNhY3Rpb24pXG4gIH1cblxuICBhc3luYyBnZXQoaWQpIHtcbiAgICBjb25zdCBzZXNzaW9uID0gYXdhaXQgdGhpcy5xdWVyeSgpLmZpbmRCeUlkKGlkKVxuICAgIHJldHVybiBzZXNzaW9uPy52YWx1ZSB8fCB7fVxuICB9XG5cbiAgYXN5bmMgc2V0KGlkLCB2YWx1ZSkge1xuICAgIGF3YWl0IHRoaXMucXVlcnkoKVxuICAgICAgLmZpbmRCeUlkKGlkKVxuICAgICAgLnVwc2VydCh7XG4gICAgICAgIC4uLnRoaXMubW9kZWxDbGFzcy5nZXRSZWZlcmVuY2UoaWQpLFxuICAgICAgICB2YWx1ZVxuICAgICAgfSlcbiAgfVxuXG4gIGFzeW5jIGRlc3Ryb3koa2V5KSB7XG4gICAgcmV0dXJuIHRoaXMucXVlcnkoKS5kZWxldGVCeUlkKGtleSlcbiAgfVxufVxuIl19
40
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9hcHAvU2Vzc2lvblN0b3JlLmpzIl0sIm5hbWVzIjpbIm1vZGVsTmFtZSIsIlNlc3Npb25TdG9yZSIsImNvbnN0cnVjdG9yIiwiY3R4IiwibW9kZWxDbGFzcyIsImFwcCIsIm1vZGVscyIsIkVycm9yIiwicXVlcnkiLCJ0cmFuc2FjdGlvbiIsImdldCIsImlkIiwic2Vzc2lvbiIsImZpbmRCeUlkIiwidmFsdWUiLCJzZXQiLCJ1cHNlcnQiLCJnZXRSZWZlcmVuY2UiLCJkZXN0cm95Iiwia2V5IiwiZGVsZXRlQnlJZCJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztlQUFlQSxTQUFTLElBQUksTUFBTUMsWUFBTixDQUFtQjtBQUM3Q0MsRUFBQUEsV0FBVyxDQUFDQyxHQUFELEVBQU07QUFDZixTQUFLQSxHQUFMLEdBQVdBLEdBQVg7QUFDQSxTQUFLQyxVQUFMLEdBQWtCRCxHQUFHLENBQUNFLEdBQUosQ0FBUUMsTUFBUixDQUFlTixTQUFmLENBQWxCOztBQUNBLFFBQUksQ0FBQyxLQUFLSSxVQUFWLEVBQXNCO0FBQ3BCLFlBQU0sSUFBSUcsS0FBSixDQUFXLGdDQUErQlAsU0FBVSxHQUFwRCxDQUFOO0FBQ0Q7QUFDRjs7QUFFRFEsRUFBQUEsS0FBSyxHQUFHO0FBQ04sV0FBTyxLQUFLSixVQUFMLENBQWdCSSxLQUFoQixDQUFzQixLQUFLTCxHQUFMLENBQVNNLFdBQS9CLENBQVA7QUFDRDs7QUFFUSxRQUFIQyxHQUFHLENBQUNDLEVBQUQsRUFBSztBQUNaLFVBQU1DLE9BQU8sR0FBRyxNQUFNLEtBQUtKLEtBQUwsR0FBYUssUUFBYixDQUFzQkYsRUFBdEIsQ0FBdEI7QUFDQSxXQUFPLENBQUFDLE9BQU8sUUFBUCxZQUFBQSxPQUFPLENBQUVFLEtBQVQsS0FBa0IsRUFBekI7QUFDRDs7QUFFUSxRQUFIQyxHQUFHLENBQUNKLEVBQUQsRUFBS0csS0FBTCxFQUFZO0FBQ25CLFVBQU0sS0FBS04sS0FBTCxHQUNISyxRQURHLENBQ01GLEVBRE4sRUFFSEssTUFGRyxDQUVJLEVBQ04sR0FBRyxLQUFLWixVQUFMLENBQWdCYSxZQUFoQixDQUE2Qk4sRUFBN0IsQ0FERztBQUVORyxNQUFBQTtBQUZNLEtBRkosQ0FBTjtBQU1EOztBQUVZLFFBQVBJLE9BQU8sQ0FBQ0MsR0FBRCxFQUFNO0FBQ2pCLFdBQU8sS0FBS1gsS0FBTCxHQUFhWSxVQUFiLENBQXdCRCxHQUF4QixDQUFQO0FBQ0Q7O0FBN0I0QyxDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGRlZmF1bHQgbW9kZWxOYW1lID0+IGNsYXNzIFNlc3Npb25TdG9yZSB7XG4gIGNvbnN0cnVjdG9yKGN0eCkge1xuICAgIHRoaXMuY3R4ID0gY3R4XG4gICAgdGhpcy5tb2RlbENsYXNzID0gY3R4LmFwcC5tb2RlbHNbbW9kZWxOYW1lXVxuICAgIGlmICghdGhpcy5tb2RlbENsYXNzKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYFVuYWJsZSB0byBmaW5kIG1vZGVsIGNsYXNzOiAnJHttb2RlbE5hbWV9J2ApXG4gICAgfVxuICB9XG5cbiAgcXVlcnkoKSB7XG4gICAgcmV0dXJuIHRoaXMubW9kZWxDbGFzcy5xdWVyeSh0aGlzLmN0eC50cmFuc2FjdGlvbilcbiAgfVxuXG4gIGFzeW5jIGdldChpZCkge1xuICAgIGNvbnN0IHNlc3Npb24gPSBhd2FpdCB0aGlzLnF1ZXJ5KCkuZmluZEJ5SWQoaWQpXG4gICAgcmV0dXJuIHNlc3Npb24/LnZhbHVlIHx8IHt9XG4gIH1cblxuICBhc3luYyBzZXQoaWQsIHZhbHVlKSB7XG4gICAgYXdhaXQgdGhpcy5xdWVyeSgpXG4gICAgICAuZmluZEJ5SWQoaWQpXG4gICAgICAudXBzZXJ0KHtcbiAgICAgICAgLi4udGhpcy5tb2RlbENsYXNzLmdldFJlZmVyZW5jZShpZCksXG4gICAgICAgIHZhbHVlXG4gICAgICB9KVxuICB9XG5cbiAgYXN5bmMgZGVzdHJveShrZXkpIHtcbiAgICByZXR1cm4gdGhpcy5xdWVyeSgpLmRlbGV0ZUJ5SWQoa2V5KVxuICB9XG59XG4iXX0=