@stemy/backend 3.5.6 → 3.5.7

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.
@@ -61,7 +61,7 @@ var __decorate$C = (this && this.__decorate) || function (decorators, target, ke
61
61
  else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
62
62
  return c > 3 && r && Object.defineProperty(target, key, r), r;
63
63
  };
64
- var __awaiter$A = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
64
+ var __awaiter$B = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
65
65
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
66
66
  return new (P || (P = Promise))(function (resolve, reject) {
67
67
  function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
@@ -97,7 +97,7 @@ let AssetProcessor = AssetProcessor_1 = class AssetProcessor {
97
97
  }
98
98
  static fileTypeFromBuffer(buffer) {
99
99
  var _a;
100
- return __awaiter$A(this, void 0, void 0, function* () {
100
+ return __awaiter$B(this, void 0, void 0, function* () {
101
101
  const type = ((_a = yield fromBuffer(buffer)) !== null && _a !== void 0 ? _a : { ext: "txt", mime: "text/plain" });
102
102
  if (AssetProcessor_1.checkTextFileType(type)) {
103
103
  return AssetProcessor_1.fixTextFileType(type, buffer);
@@ -124,7 +124,7 @@ let AssetProcessor = AssetProcessor_1 = class AssetProcessor {
124
124
  return imageTypes.indexOf(contentType) >= 0;
125
125
  }
126
126
  static copyImageMeta(buffer, metadata, fileType) {
127
- return __awaiter$A(this, void 0, void 0, function* () {
127
+ return __awaiter$B(this, void 0, void 0, function* () {
128
128
  if (fileType.mime === "image/svg+xml") {
129
129
  const match = /<svg([^<>]+)>/gi.exec(buffer.toString("utf8"));
130
130
  if (match && match.length > 1) {
@@ -163,7 +163,7 @@ let AssetProcessor = AssetProcessor_1 = class AssetProcessor {
163
163
  });
164
164
  }
165
165
  process(buffer, metadata, fileType) {
166
- return __awaiter$A(this, void 0, void 0, function* () {
166
+ return __awaiter$B(this, void 0, void 0, function* () {
167
167
  if (AssetProcessor_1.isImage(fileType.mime)) {
168
168
  buffer = yield AssetProcessor_1.copyImageMeta(buffer, metadata, fileType);
169
169
  }
@@ -179,7 +179,7 @@ AssetProcessor = AssetProcessor_1 = __decorate$C([
179
179
  scoped(Lifecycle.ContainerScoped)
180
180
  ], AssetProcessor);
181
181
 
182
- var __awaiter$z = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
182
+ var __awaiter$A = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
183
183
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
184
184
  return new (P || (P = Promise))(function (resolve, reject) {
185
185
  function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
@@ -357,7 +357,7 @@ function toCropRegion(cropInfo) {
357
357
  };
358
358
  }
359
359
  function toImage(src, params, meta) {
360
- return __awaiter$z(this, void 0, void 0, function* () {
360
+ return __awaiter$A(this, void 0, void 0, function* () {
361
361
  // Default params and meta
362
362
  params = params || {};
363
363
  meta = meta || {};
@@ -495,7 +495,7 @@ function readFile(path) {
495
495
  });
496
496
  }
497
497
  function readAndDeleteFile(path, timeout = 5000) {
498
- return __awaiter$z(this, void 0, void 0, function* () {
498
+ return __awaiter$A(this, void 0, void 0, function* () {
499
499
  const data = yield readFile(path);
500
500
  setTimeout(() => {
501
501
  unlink(path, () => {
@@ -505,7 +505,7 @@ function readAndDeleteFile(path, timeout = 5000) {
505
505
  });
506
506
  }
507
507
  function writeFile(path, data) {
508
- return __awaiter$z(this, void 0, void 0, function* () {
508
+ return __awaiter$A(this, void 0, void 0, function* () {
509
509
  yield mkdirRecursive(dirname(path));
510
510
  return new Promise((res, rej) => {
511
511
  writeFile$1(path, data, err => {
@@ -891,7 +891,7 @@ var __decorate$A = (this && this.__decorate) || function (decorators, target, ke
891
891
  var __metadata$u = (this && this.__metadata) || function (k, v) {
892
892
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
893
893
  };
894
- var __awaiter$y = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
894
+ var __awaiter$z = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
895
895
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
896
896
  return new (P || (P = Promise))(function (resolve, reject) {
897
897
  function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
@@ -917,7 +917,7 @@ let MongoConnector = class MongoConnector {
917
917
  return this.fsBucket;
918
918
  }
919
919
  connect() {
920
- return __awaiter$y(this, void 0, void 0, function* () {
920
+ return __awaiter$z(this, void 0, void 0, function* () {
921
921
  if (this.db)
922
922
  return this.db;
923
923
  this.conn = (yield connect(this.configuration.resolve("mongoUri"), {
@@ -935,7 +935,7 @@ MongoConnector = __decorate$A([
935
935
  __metadata$u("design:paramtypes", [Configuration])
936
936
  ], MongoConnector);
937
937
 
938
- var __awaiter$x = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
938
+ var __awaiter$y = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
939
939
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
940
940
  return new (P || (P = Promise))(function (resolve, reject) {
941
941
  function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
@@ -957,7 +957,7 @@ class BaseEntity {
957
957
  return this.collection.updateOne({ _id: this.mId }, { $set: this.toJSON() });
958
958
  }
959
959
  load() {
960
- return __awaiter$x(this, void 0, void 0, function* () {
960
+ return __awaiter$y(this, void 0, void 0, function* () {
961
961
  const res = yield this.collection.findOne({ _id: this.mId });
962
962
  this.deleted = !res;
963
963
  this.data = res || {};
@@ -972,7 +972,7 @@ class BaseEntity {
972
972
  }
973
973
  }
974
974
 
975
- var __awaiter$w = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
975
+ var __awaiter$x = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
976
976
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
977
977
  return new (P || (P = Promise))(function (resolve, reject) {
978
978
  function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
@@ -999,7 +999,7 @@ class Asset extends BaseEntity {
999
999
  return this.bucket.openDownloadStream(this.mId);
1000
1000
  }
1001
1001
  unlink() {
1002
- return __awaiter$w(this, void 0, void 0, function* () {
1002
+ return __awaiter$x(this, void 0, void 0, function* () {
1003
1003
  return deleteFromBucket(this.bucket, this.mId);
1004
1004
  });
1005
1005
  }
@@ -1007,7 +1007,7 @@ class Asset extends BaseEntity {
1007
1007
  return streamToBuffer(this.stream);
1008
1008
  }
1009
1009
  download(metadata) {
1010
- return __awaiter$w(this, void 0, void 0, function* () {
1010
+ return __awaiter$x(this, void 0, void 0, function* () {
1011
1011
  metadata = Object.assign(this.metadata, metadata || {});
1012
1012
  metadata.downloadCount = isNaN(metadata.downloadCount) || !metadata.firstDownload
1013
1013
  ? 1
@@ -1019,18 +1019,18 @@ class Asset extends BaseEntity {
1019
1019
  });
1020
1020
  }
1021
1021
  getImage(params = null) {
1022
- return __awaiter$w(this, void 0, void 0, function* () {
1022
+ return __awaiter$x(this, void 0, void 0, function* () {
1023
1023
  return toImage(this.stream, params, this.metadata);
1024
1024
  });
1025
1025
  }
1026
1026
  downloadImage(params, metadata) {
1027
- return __awaiter$w(this, void 0, void 0, function* () {
1027
+ return __awaiter$x(this, void 0, void 0, function* () {
1028
1028
  return toImage(yield this.download(metadata), params, this.metadata);
1029
1029
  });
1030
1030
  }
1031
1031
  }
1032
1032
 
1033
- var __awaiter$v = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
1033
+ var __awaiter$w = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
1034
1034
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
1035
1035
  return new (P || (P = Promise))(function (resolve, reject) {
1036
1036
  function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
@@ -1051,17 +1051,17 @@ class TempAsset {
1051
1051
  return bufferToStream(this.buffer);
1052
1052
  }
1053
1053
  unlink() {
1054
- return __awaiter$v(this, void 0, void 0, function* () {
1054
+ return __awaiter$w(this, void 0, void 0, function* () {
1055
1055
  throw new Error(`Temp asset '${this.id}' can not be removed!`);
1056
1056
  });
1057
1057
  }
1058
1058
  getBuffer() {
1059
- return __awaiter$v(this, void 0, void 0, function* () {
1059
+ return __awaiter$w(this, void 0, void 0, function* () {
1060
1060
  return this.buffer;
1061
1061
  });
1062
1062
  }
1063
1063
  download(metadata) {
1064
- return __awaiter$v(this, void 0, void 0, function* () {
1064
+ return __awaiter$w(this, void 0, void 0, function* () {
1065
1065
  return this.stream;
1066
1066
  });
1067
1067
  }
@@ -1073,12 +1073,12 @@ class TempAsset {
1073
1073
  return this.downloadImage(params);
1074
1074
  }
1075
1075
  save() {
1076
- return __awaiter$v(this, void 0, void 0, function* () {
1076
+ return __awaiter$w(this, void 0, void 0, function* () {
1077
1077
  return this;
1078
1078
  });
1079
1079
  }
1080
1080
  load() {
1081
- return __awaiter$v(this, void 0, void 0, function* () {
1081
+ return __awaiter$w(this, void 0, void 0, function* () {
1082
1082
  return this;
1083
1083
  });
1084
1084
  }
@@ -1101,7 +1101,7 @@ var __decorate$z = (this && this.__decorate) || function (decorators, target, ke
1101
1101
  var __metadata$t = (this && this.__metadata) || function (k, v) {
1102
1102
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
1103
1103
  };
1104
- var __awaiter$u = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
1104
+ var __awaiter$v = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
1105
1105
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
1106
1106
  return new (P || (P = Promise))(function (resolve, reject) {
1107
1107
  function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
@@ -1119,7 +1119,7 @@ let Assets = class Assets {
1119
1119
  this.collection = (_a = connector.database) === null || _a === void 0 ? void 0 : _a.collection("assets.files");
1120
1120
  }
1121
1121
  write(stream, contentType = null, metadata = null) {
1122
- return __awaiter$u(this, void 0, void 0, function* () {
1122
+ return __awaiter$v(this, void 0, void 0, function* () {
1123
1123
  const uploadStream = copyStream(stream);
1124
1124
  const buffer = yield streamToBuffer(stream);
1125
1125
  let fileType = { ext: "", mime: contentType };
@@ -1137,7 +1137,7 @@ let Assets = class Assets {
1137
1137
  });
1138
1138
  }
1139
1139
  writeBuffer(buffer, metadata = null, contentType = null) {
1140
- return __awaiter$u(this, void 0, void 0, function* () {
1140
+ return __awaiter$v(this, void 0, void 0, function* () {
1141
1141
  let fileType = { ext: "", mime: contentType };
1142
1142
  try {
1143
1143
  fileType = yield AssetProcessor.fileTypeFromBuffer(buffer);
@@ -1154,7 +1154,7 @@ let Assets = class Assets {
1154
1154
  });
1155
1155
  }
1156
1156
  writeUrl(url, metadata = null) {
1157
- return __awaiter$u(this, void 0, void 0, function* () {
1157
+ return __awaiter$v(this, void 0, void 0, function* () {
1158
1158
  metadata = metadata || {};
1159
1159
  metadata.filename = metadata.filename || url;
1160
1160
  metadata.uploadTime = new Date().getTime();
@@ -1167,7 +1167,7 @@ let Assets = class Assets {
1167
1167
  });
1168
1168
  }
1169
1169
  download(url, contentType = null) {
1170
- return __awaiter$u(this, void 0, void 0, function* () {
1170
+ return __awaiter$v(this, void 0, void 0, function* () {
1171
1171
  let buffer = (yield axios({ url, responseType: "arraybuffer" })).data;
1172
1172
  let fileType = { ext: "", mime: contentType };
1173
1173
  try {
@@ -1188,18 +1188,18 @@ let Assets = class Assets {
1188
1188
  });
1189
1189
  }
1190
1190
  read(id) {
1191
- return __awaiter$u(this, void 0, void 0, function* () {
1191
+ return __awaiter$v(this, void 0, void 0, function* () {
1192
1192
  return !id ? null : this.find({ _id: new ObjectId$1(id) });
1193
1193
  });
1194
1194
  }
1195
1195
  find(where) {
1196
- return __awaiter$u(this, void 0, void 0, function* () {
1196
+ return __awaiter$v(this, void 0, void 0, function* () {
1197
1197
  const data = yield this.collection.findOne(where);
1198
1198
  return !data ? null : new Asset(data._id, data, this.collection, this.bucket);
1199
1199
  });
1200
1200
  }
1201
1201
  findMany(where) {
1202
- return __awaiter$u(this, void 0, void 0, function* () {
1202
+ return __awaiter$v(this, void 0, void 0, function* () {
1203
1203
  const cursor = this.collection.find(where);
1204
1204
  const items = (yield cursor.toArray()) || [];
1205
1205
  const result = [];
@@ -1212,13 +1212,13 @@ let Assets = class Assets {
1212
1212
  });
1213
1213
  }
1214
1214
  deleteMany(where) {
1215
- return __awaiter$u(this, void 0, void 0, function* () {
1215
+ return __awaiter$v(this, void 0, void 0, function* () {
1216
1216
  const assets = yield this.findMany(where);
1217
1217
  return Promise.all(assets.map(a => a.unlink()));
1218
1218
  });
1219
1219
  }
1220
1220
  unlink(id) {
1221
- return __awaiter$u(this, void 0, void 0, function* () {
1221
+ return __awaiter$v(this, void 0, void 0, function* () {
1222
1222
  const asset = yield this.read(id);
1223
1223
  if (!asset)
1224
1224
  return null;
@@ -1226,7 +1226,7 @@ let Assets = class Assets {
1226
1226
  });
1227
1227
  }
1228
1228
  upload(stream, fileType, metadata) {
1229
- return __awaiter$u(this, void 0, void 0, function* () {
1229
+ return __awaiter$v(this, void 0, void 0, function* () {
1230
1230
  const contentType = fileType.mime.trim();
1231
1231
  metadata = Object.assign({
1232
1232
  downloadCount: 0,
@@ -1263,7 +1263,7 @@ Assets = __decorate$z([
1263
1263
  __metadata$t("design:paramtypes", [MongoConnector, AssetProcessor])
1264
1264
  ], Assets);
1265
1265
 
1266
- var __awaiter$t = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
1266
+ var __awaiter$u = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
1267
1267
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
1268
1268
  return new (P || (P = Promise))(function (resolve, reject) {
1269
1269
  function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
@@ -1295,7 +1295,7 @@ class LazyAsset extends BaseEntity {
1295
1295
  return this.data.assetId;
1296
1296
  }
1297
1297
  unlink() {
1298
- return __awaiter$t(this, void 0, void 0, function* () {
1298
+ return __awaiter$u(this, void 0, void 0, function* () {
1299
1299
  yield this.load();
1300
1300
  if (!this.progressId) {
1301
1301
  yield this.collection.deleteOne({ _id: this.mId });
@@ -1318,7 +1318,7 @@ class LazyAsset extends BaseEntity {
1318
1318
  });
1319
1319
  }
1320
1320
  loadAsset() {
1321
- return __awaiter$t(this, void 0, void 0, function* () {
1321
+ return __awaiter$u(this, void 0, void 0, function* () {
1322
1322
  yield this.load();
1323
1323
  if (this.deleted)
1324
1324
  return null;
@@ -1334,14 +1334,14 @@ class LazyAsset extends BaseEntity {
1334
1334
  });
1335
1335
  }
1336
1336
  writeAsset(asset) {
1337
- return __awaiter$t(this, void 0, void 0, function* () {
1337
+ return __awaiter$u(this, void 0, void 0, function* () {
1338
1338
  this.data.assetId = asset.id;
1339
1339
  yield this.save();
1340
1340
  return asset;
1341
1341
  });
1342
1342
  }
1343
1343
  startWorkingOnAsset(fromLoad) {
1344
- return __awaiter$t(this, void 0, void 0, function* () {
1344
+ return __awaiter$u(this, void 0, void 0, function* () {
1345
1345
  this.data.progressId = (yield this.progresses.create()).id;
1346
1346
  this.data.assetId = null;
1347
1347
  yield this.save();
@@ -1388,7 +1388,7 @@ var __metadata$r = (this && this.__metadata) || function (k, v) {
1388
1388
  var __param$8 = (this && this.__param) || function (paramIndex, decorator) {
1389
1389
  return function (target, key) { decorator(target, key, paramIndex); }
1390
1390
  };
1391
- var __awaiter$s = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
1391
+ var __awaiter$t = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
1392
1392
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
1393
1393
  return new (P || (P = Promise))(function (resolve, reject) {
1394
1394
  function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
@@ -1428,7 +1428,7 @@ let JobManager = class JobManager {
1428
1428
  .pipe(map(t => t.params)).subscribe(cb);
1429
1429
  }
1430
1430
  process(jobType, params = {}) {
1431
- return __awaiter$s(this, void 0, void 0, function* () {
1431
+ return __awaiter$t(this, void 0, void 0, function* () {
1432
1432
  let instance = null;
1433
1433
  try {
1434
1434
  instance = this.resolveJobInstance(jobType, params);
@@ -1441,12 +1441,12 @@ let JobManager = class JobManager {
1441
1441
  });
1442
1442
  }
1443
1443
  enqueueWithName(name, params = {}) {
1444
- return __awaiter$s(this, void 0, void 0, function* () {
1444
+ return __awaiter$t(this, void 0, void 0, function* () {
1445
1445
  return this.sendToWorkers(this.tryResolveFromName(name, params), params);
1446
1446
  });
1447
1447
  }
1448
1448
  enqueue(jobType, params = {}) {
1449
- return __awaiter$s(this, void 0, void 0, function* () {
1449
+ return __awaiter$t(this, void 0, void 0, function* () {
1450
1450
  return this.sendToWorkers(this.tryResolveAndInit(jobType, params), params);
1451
1451
  });
1452
1452
  }
@@ -1473,7 +1473,7 @@ let JobManager = class JobManager {
1473
1473
  });
1474
1474
  }
1475
1475
  startProcessing() {
1476
- return __awaiter$s(this, void 0, void 0, function* () {
1476
+ return __awaiter$t(this, void 0, void 0, function* () {
1477
1477
  if (this.processing)
1478
1478
  return null;
1479
1479
  this.processing = true;
@@ -1490,7 +1490,7 @@ let JobManager = class JobManager {
1490
1490
  this.workerPull = socket("pull");
1491
1491
  yield this.workerPull.connect(pullHost);
1492
1492
  this.logger.log("job-manager", `Worker consumer connected to: ${pullHost}`);
1493
- this.workerPull.on("message", (name, args, uniqId) => __awaiter$s(this, void 0, void 0, function* () {
1493
+ this.workerPull.on("message", (name, args, uniqId) => __awaiter$t(this, void 0, void 0, function* () {
1494
1494
  try {
1495
1495
  const jobName = name.toString("utf8");
1496
1496
  const jobParams = JSON.parse(args.toString("utf8"));
@@ -1569,7 +1569,7 @@ let JobManager = class JobManager {
1569
1569
  return container.resolve(jobType);
1570
1570
  }
1571
1571
  sendToWorkers(jobName, params) {
1572
- return __awaiter$s(this, void 0, void 0, function* () {
1572
+ return __awaiter$t(this, void 0, void 0, function* () {
1573
1573
  const publisher = yield this.apiPush;
1574
1574
  const uniqueId = new ObjectId$1().toHexString();
1575
1575
  yield publisher.send([jobName, JSON.stringify(params), uniqueId]);
@@ -1586,7 +1586,7 @@ JobManager = __decorate$x([
1586
1586
  Logger, Object, Array])
1587
1587
  ], JobManager);
1588
1588
 
1589
- var __awaiter$r = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
1589
+ var __awaiter$s = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
1590
1590
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
1591
1591
  return new (P || (P = Promise))(function (resolve, reject) {
1592
1592
  function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
@@ -1625,7 +1625,7 @@ class Progress extends BaseEntity {
1625
1625
  return this;
1626
1626
  }
1627
1627
  createSubProgress(progressValue, max, message) {
1628
- return __awaiter$r(this, void 0, void 0, function* () {
1628
+ return __awaiter$s(this, void 0, void 0, function* () {
1629
1629
  if (max <= 0 && progressValue > 0) {
1630
1630
  yield this.advance(progressValue);
1631
1631
  }
@@ -1637,7 +1637,7 @@ class Progress extends BaseEntity {
1637
1637
  });
1638
1638
  }
1639
1639
  setMax(max) {
1640
- return __awaiter$r(this, void 0, void 0, function* () {
1640
+ return __awaiter$s(this, void 0, void 0, function* () {
1641
1641
  if (isNaN(max) || max <= 0) {
1642
1642
  throw "Max progress value must be bigger than zero";
1643
1643
  }
@@ -1646,19 +1646,19 @@ class Progress extends BaseEntity {
1646
1646
  });
1647
1647
  }
1648
1648
  setMessage(message) {
1649
- return __awaiter$r(this, void 0, void 0, function* () {
1649
+ return __awaiter$s(this, void 0, void 0, function* () {
1650
1650
  this.data.message = message;
1651
1651
  yield this.save();
1652
1652
  });
1653
1653
  }
1654
1654
  setError(error) {
1655
- return __awaiter$r(this, void 0, void 0, function* () {
1655
+ return __awaiter$s(this, void 0, void 0, function* () {
1656
1656
  this.data.error = error;
1657
1657
  yield this.save();
1658
1658
  });
1659
1659
  }
1660
1660
  advance(value = 1) {
1661
- return __awaiter$r(this, void 0, void 0, function* () {
1661
+ return __awaiter$s(this, void 0, void 0, function* () {
1662
1662
  if (isNaN(value) || value <= 0) {
1663
1663
  throw "Advance value must be bigger than zero";
1664
1664
  }
@@ -1670,7 +1670,7 @@ class Progress extends BaseEntity {
1670
1670
  });
1671
1671
  }
1672
1672
  cancel() {
1673
- return __awaiter$r(this, void 0, void 0, function* () {
1673
+ return __awaiter$s(this, void 0, void 0, function* () {
1674
1674
  this.data.canceled = true;
1675
1675
  yield this.save();
1676
1676
  });
@@ -1727,7 +1727,7 @@ class SubProgress {
1727
1727
  return this;
1728
1728
  }
1729
1729
  createSubProgress(progressValue, max, message) {
1730
- return __awaiter$r(this, void 0, void 0, function* () {
1730
+ return __awaiter$s(this, void 0, void 0, function* () {
1731
1731
  if (max <= 0 && progressValue > 0) {
1732
1732
  yield this.advance(progressValue);
1733
1733
  }
@@ -1738,7 +1738,7 @@ class SubProgress {
1738
1738
  });
1739
1739
  }
1740
1740
  setMax(max) {
1741
- return __awaiter$r(this, void 0, void 0, function* () {
1741
+ return __awaiter$s(this, void 0, void 0, function* () {
1742
1742
  if (isNaN(max) || max <= 0) {
1743
1743
  throw "Max progress value must be bigger than zero";
1744
1744
  }
@@ -1747,21 +1747,21 @@ class SubProgress {
1747
1747
  });
1748
1748
  }
1749
1749
  setMessage(message) {
1750
- return __awaiter$r(this, void 0, void 0, function* () {
1750
+ return __awaiter$s(this, void 0, void 0, function* () {
1751
1751
  if (!this.parent)
1752
1752
  return null;
1753
1753
  yield this.parent.setMessage(message);
1754
1754
  });
1755
1755
  }
1756
1756
  setError(error) {
1757
- return __awaiter$r(this, void 0, void 0, function* () {
1757
+ return __awaiter$s(this, void 0, void 0, function* () {
1758
1758
  if (!this.parent)
1759
1759
  return null;
1760
1760
  yield this.parent.setError(error);
1761
1761
  });
1762
1762
  }
1763
1763
  advance(value = 1) {
1764
- return __awaiter$r(this, void 0, void 0, function* () {
1764
+ return __awaiter$s(this, void 0, void 0, function* () {
1765
1765
  if (isNaN(value) || value <= 0) {
1766
1766
  throw "Advance value must be bigger than zero";
1767
1767
  }
@@ -1770,14 +1770,14 @@ class SubProgress {
1770
1770
  });
1771
1771
  }
1772
1772
  cancel() {
1773
- return __awaiter$r(this, void 0, void 0, function* () {
1773
+ return __awaiter$s(this, void 0, void 0, function* () {
1774
1774
  if (!this.parent)
1775
1775
  return null;
1776
1776
  yield this.parent.cancel();
1777
1777
  });
1778
1778
  }
1779
1779
  save() {
1780
- return __awaiter$r(this, void 0, void 0, function* () {
1780
+ return __awaiter$s(this, void 0, void 0, function* () {
1781
1781
  const ratio = this.max > 0 ? this.mCurrent / this.max : 0;
1782
1782
  const newProgress = this.progressFrom + Math.round(this.progressValue * ratio);
1783
1783
  const current = this.parent.current;
@@ -1787,7 +1787,7 @@ class SubProgress {
1787
1787
  });
1788
1788
  }
1789
1789
  load() {
1790
- return __awaiter$r(this, void 0, void 0, function* () {
1790
+ return __awaiter$s(this, void 0, void 0, function* () {
1791
1791
  return null;
1792
1792
  });
1793
1793
  }
@@ -1805,7 +1805,7 @@ var __decorate$w = (this && this.__decorate) || function (decorators, target, ke
1805
1805
  var __metadata$q = (this && this.__metadata) || function (k, v) {
1806
1806
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
1807
1807
  };
1808
- var __awaiter$q = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
1808
+ var __awaiter$r = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
1809
1809
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
1810
1810
  return new (P || (P = Promise))(function (resolve, reject) {
1811
1811
  function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
@@ -1826,9 +1826,9 @@ let Progresses = class Progresses {
1826
1826
  });
1827
1827
  }
1828
1828
  waitToFinish(id) {
1829
- return __awaiter$q(this, void 0, void 0, function* () {
1829
+ return __awaiter$r(this, void 0, void 0, function* () {
1830
1830
  return Promise.race([
1831
- this.waitForProgress(id, () => __awaiter$q(this, void 0, void 0, function* () {
1831
+ this.waitForProgress(id, () => __awaiter$r(this, void 0, void 0, function* () {
1832
1832
  let progress = this.progresses[id];
1833
1833
  if (!progress || progress.percent < 100) {
1834
1834
  progress = yield this.get(id);
@@ -1838,25 +1838,25 @@ let Progresses = class Progresses {
1838
1838
  }
1839
1839
  return progress;
1840
1840
  }), 500),
1841
- this.waitForProgress(id, () => __awaiter$q(this, void 0, void 0, function* () {
1841
+ this.waitForProgress(id, () => __awaiter$r(this, void 0, void 0, function* () {
1842
1842
  return this.progresses[id] || null;
1843
1843
  }), 25)
1844
1844
  ]);
1845
1845
  });
1846
1846
  }
1847
1847
  get(id) {
1848
- return __awaiter$q(this, void 0, void 0, function* () {
1848
+ return __awaiter$r(this, void 0, void 0, function* () {
1849
1849
  return !id ? null : this.find({ _id: new ObjectId$1(id) });
1850
1850
  });
1851
1851
  }
1852
1852
  find(where) {
1853
- return __awaiter$q(this, void 0, void 0, function* () {
1853
+ return __awaiter$r(this, void 0, void 0, function* () {
1854
1854
  const data = yield this.collection.findOne(where);
1855
1855
  return !data ? null : new Progress(data._id, data, this.collection);
1856
1856
  });
1857
1857
  }
1858
1858
  create(max = 100) {
1859
- return __awaiter$q(this, void 0, void 0, function* () {
1859
+ return __awaiter$r(this, void 0, void 0, function* () {
1860
1860
  if (isNaN(max) || max <= 0) {
1861
1861
  throw new Error(`Max progress value must be bigger than zero`);
1862
1862
  }
@@ -1872,13 +1872,13 @@ let Progresses = class Progresses {
1872
1872
  });
1873
1873
  }
1874
1874
  remove(id) {
1875
- return __awaiter$q(this, void 0, void 0, function* () {
1875
+ return __awaiter$r(this, void 0, void 0, function* () {
1876
1876
  yield this.collection.deleteOne({ _id: new ObjectId$1(id) });
1877
1877
  return id;
1878
1878
  });
1879
1879
  }
1880
1880
  waitForProgress(id, cb, delay) {
1881
- return __awaiter$q(this, void 0, void 0, function* () {
1881
+ return __awaiter$r(this, void 0, void 0, function* () {
1882
1882
  let isFinished = false;
1883
1883
  let progress = null;
1884
1884
  let waitTime = 0;
@@ -1916,7 +1916,7 @@ var __decorate$v = (this && this.__decorate) || function (decorators, target, ke
1916
1916
  var __metadata$p = (this && this.__metadata) || function (k, v) {
1917
1917
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
1918
1918
  };
1919
- var __awaiter$p = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
1919
+ var __awaiter$q = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
1920
1920
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
1921
1921
  return new (P || (P = Promise))(function (resolve, reject) {
1922
1922
  function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
@@ -1935,7 +1935,7 @@ let LazyAssets = class LazyAssets {
1935
1935
  this.collection = connector.database.collection("lazyassets");
1936
1936
  }
1937
1937
  create(jobType, jobParams = {}, jobQue = "main") {
1938
- return __awaiter$p(this, void 0, void 0, function* () {
1938
+ return __awaiter$q(this, void 0, void 0, function* () {
1939
1939
  const jobName = this.jobMan.tryResolve(jobType, Object.assign(Object.assign({}, jobParams), { lazyId: "" }));
1940
1940
  const data = {
1941
1941
  jobName,
@@ -1950,12 +1950,12 @@ let LazyAssets = class LazyAssets {
1950
1950
  });
1951
1951
  }
1952
1952
  read(id) {
1953
- return __awaiter$p(this, void 0, void 0, function* () {
1953
+ return __awaiter$q(this, void 0, void 0, function* () {
1954
1954
  return !id ? null : this.find({ _id: new ObjectId$1(id) });
1955
1955
  });
1956
1956
  }
1957
1957
  find(where) {
1958
- return __awaiter$p(this, void 0, void 0, function* () {
1958
+ return __awaiter$q(this, void 0, void 0, function* () {
1959
1959
  const data = yield this.collection.findOne(where);
1960
1960
  return !data
1961
1961
  ? null
@@ -1963,7 +1963,7 @@ let LazyAssets = class LazyAssets {
1963
1963
  });
1964
1964
  }
1965
1965
  unlink(id) {
1966
- return __awaiter$p(this, void 0, void 0, function* () {
1966
+ return __awaiter$q(this, void 0, void 0, function* () {
1967
1967
  const asset = yield this.read(id);
1968
1968
  if (!asset)
1969
1969
  return null;
@@ -1990,7 +1990,7 @@ var __decorate$u = (this && this.__decorate) || function (decorators, target, ke
1990
1990
  var __metadata$o = (this && this.__metadata) || function (k, v) {
1991
1991
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
1992
1992
  };
1993
- var __awaiter$o = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
1993
+ var __awaiter$p = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
1994
1994
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
1995
1995
  return new (P || (P = Promise))(function (resolve, reject) {
1996
1996
  function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
@@ -2005,7 +2005,7 @@ let AssetResolver = class AssetResolver {
2005
2005
  this.lazyAssets = lazyAssets;
2006
2006
  }
2007
2007
  resolve(id, lazy = false) {
2008
- return __awaiter$o(this, void 0, void 0, function* () {
2008
+ return __awaiter$p(this, void 0, void 0, function* () {
2009
2009
  let asset = null;
2010
2010
  if (lazy) {
2011
2011
  const lazyAsset = yield this.lazyAssets.read(id);
@@ -2063,7 +2063,7 @@ var __decorate$s = (this && this.__decorate) || function (decorators, target, ke
2063
2063
  else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
2064
2064
  return c > 3 && r && Object.defineProperty(target, key, r), r;
2065
2065
  };
2066
- var __awaiter$n = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2066
+ var __awaiter$o = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2067
2067
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
2068
2068
  return new (P || (P = Promise))(function (resolve, reject) {
2069
2069
  function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
@@ -2074,12 +2074,12 @@ var __awaiter$n = (this && this.__awaiter) || function (thisArg, _arguments, P,
2074
2074
  };
2075
2075
  let CacheProcessor = class CacheProcessor {
2076
2076
  serialize(data) {
2077
- return __awaiter$n(this, void 0, void 0, function* () {
2077
+ return __awaiter$o(this, void 0, void 0, function* () {
2078
2078
  return data;
2079
2079
  });
2080
2080
  }
2081
2081
  deserialize(data) {
2082
- return __awaiter$n(this, void 0, void 0, function* () {
2082
+ return __awaiter$o(this, void 0, void 0, function* () {
2083
2083
  return data;
2084
2084
  });
2085
2085
  }
@@ -2098,7 +2098,7 @@ var __decorate$r = (this && this.__decorate) || function (decorators, target, ke
2098
2098
  var __metadata$m = (this && this.__metadata) || function (k, v) {
2099
2099
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
2100
2100
  };
2101
- var __awaiter$m = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2101
+ var __awaiter$n = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2102
2102
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
2103
2103
  return new (P || (P = Promise))(function (resolve, reject) {
2104
2104
  function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
@@ -2114,7 +2114,7 @@ let Cache = class Cache {
2114
2114
  this.cacheProcessor = cacheProcessor;
2115
2115
  }
2116
2116
  prepare() {
2117
- return __awaiter$m(this, void 0, void 0, function* () {
2117
+ return __awaiter$n(this, void 0, void 0, function* () {
2118
2118
  if (this.collection)
2119
2119
  return;
2120
2120
  if (!this.connector.database) {
@@ -2125,7 +2125,7 @@ let Cache = class Cache {
2125
2125
  });
2126
2126
  }
2127
2127
  set(key, value, ttl, expirationTimestamp = null, tags = {}) {
2128
- return __awaiter$m(this, void 0, void 0, function* () {
2128
+ return __awaiter$n(this, void 0, void 0, function* () {
2129
2129
  yield this.prepare();
2130
2130
  const item = {
2131
2131
  _id: key,
@@ -2142,7 +2142,7 @@ let Cache = class Cache {
2142
2142
  });
2143
2143
  }
2144
2144
  get(key) {
2145
- return __awaiter$m(this, void 0, void 0, function* () {
2145
+ return __awaiter$n(this, void 0, void 0, function* () {
2146
2146
  yield this.prepare();
2147
2147
  let item = yield this.collection.findOne({ _id: key });
2148
2148
  const now = Math.round(new Date().getTime() / 1000);
@@ -2156,7 +2156,7 @@ let Cache = class Cache {
2156
2156
  });
2157
2157
  }
2158
2158
  getOrSet(key, valueCb, ttl, expirationTimestamp = null, tags = {}) {
2159
- return __awaiter$m(this, void 0, void 0, function* () {
2159
+ return __awaiter$n(this, void 0, void 0, function* () {
2160
2160
  try {
2161
2161
  return yield this.get(key);
2162
2162
  }
@@ -2166,15 +2166,14 @@ let Cache = class Cache {
2166
2166
  });
2167
2167
  }
2168
2168
  delete(key) {
2169
- return __awaiter$m(this, void 0, void 0, function* () {
2169
+ return __awaiter$n(this, void 0, void 0, function* () {
2170
2170
  yield this.prepare();
2171
2171
  yield this.collection.deleteOne({ _id: key });
2172
2172
  });
2173
2173
  }
2174
2174
  };
2175
2175
  Cache = __decorate$r([
2176
- injectable(),
2177
- scoped(Lifecycle.ContainerScoped),
2176
+ singleton(),
2178
2177
  __metadata$m("design:paramtypes", [MongoConnector, Configuration, CacheProcessor])
2179
2178
  ], Cache);
2180
2179
 
@@ -2184,7 +2183,7 @@ var __decorate$q = (this && this.__decorate) || function (decorators, target, ke
2184
2183
  else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
2185
2184
  return c > 3 && r && Object.defineProperty(target, key, r), r;
2186
2185
  };
2187
- var __awaiter$l = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2186
+ var __awaiter$m = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2188
2187
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
2189
2188
  return new (P || (P = Promise))(function (resolve, reject) {
2190
2189
  function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
@@ -2195,7 +2194,7 @@ var __awaiter$l = (this && this.__awaiter) || function (thisArg, _arguments, P,
2195
2194
  };
2196
2195
  let EndpointProvider = class EndpointProvider {
2197
2196
  configure(app) {
2198
- return __awaiter$l(this, void 0, void 0, function* () {
2197
+ return __awaiter$m(this, void 0, void 0, function* () {
2199
2198
  console.log(`Express app is mounted to: ${app.mountpath}`);
2200
2199
  });
2201
2200
  }
@@ -2217,7 +2216,7 @@ var __metadata$l = (this && this.__metadata) || function (k, v) {
2217
2216
  var __param$7 = (this && this.__param) || function (paramIndex, decorator) {
2218
2217
  return function (target, key) { decorator(target, key, paramIndex); }
2219
2218
  };
2220
- var __awaiter$k = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2219
+ var __awaiter$l = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2221
2220
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
2222
2221
  return new (P || (P = Promise))(function (resolve, reject) {
2223
2222
  function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
@@ -2231,7 +2230,7 @@ let Fixtures = class Fixtures {
2231
2230
  this.fixtures = fixtures;
2232
2231
  }
2233
2232
  load() {
2234
- return __awaiter$k(this, void 0, void 0, function* () {
2233
+ return __awaiter$l(this, void 0, void 0, function* () {
2235
2234
  if (!this.fixtures)
2236
2235
  return;
2237
2236
  for (let fixture of this.fixtures) {
@@ -2247,7 +2246,7 @@ Fixtures = __decorate$p([
2247
2246
  __metadata$l("design:paramtypes", [Array])
2248
2247
  ], Fixtures);
2249
2248
 
2250
- var __awaiter$j = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2249
+ var __awaiter$k = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2251
2250
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
2252
2251
  return new (P || (P = Promise))(function (resolve, reject) {
2253
2252
  function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
@@ -2268,7 +2267,7 @@ class GalleryImage {
2268
2267
  this.targetSize = !size ? { width: thumbSize, height: thumbSize } : size;
2269
2268
  }
2270
2269
  serve(id) {
2271
- return __awaiter$j(this, void 0, void 0, function* () {
2270
+ return __awaiter$k(this, void 0, void 0, function* () {
2272
2271
  const isThumb = id == this.thumb;
2273
2272
  if (yield this.handler.hasResult(isThumb)) {
2274
2273
  return this.handler.serveResult(isThumb);
@@ -2335,7 +2334,7 @@ var __decorate$n = (this && this.__decorate) || function (decorators, target, ke
2335
2334
  var __metadata$j = (this && this.__metadata) || function (k, v) {
2336
2335
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
2337
2336
  };
2338
- var __awaiter$i = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2337
+ var __awaiter$j = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2339
2338
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
2340
2339
  return new (P || (P = Promise))(function (resolve, reject) {
2341
2340
  function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
@@ -2354,7 +2353,7 @@ let Gallery = class Gallery {
2354
2353
  this.output = join(this.config.resolve("cacheDir"), "gallery");
2355
2354
  }
2356
2355
  getFolder(folder, size = null) {
2357
- return __awaiter$i(this, void 0, void 0, function* () {
2356
+ return __awaiter$j(this, void 0, void 0, function* () {
2358
2357
  this.cache[folder] = this.cache[folder] || new Promise(resolve => {
2359
2358
  lstat(join(this.dir, folder), (err, stats) => {
2360
2359
  if (err || !stats.isDirectory()) {
@@ -2375,7 +2374,7 @@ let Gallery = class Gallery {
2375
2374
  return;
2376
2375
  }
2377
2376
  const promises = files.map(file => {
2378
- return new Promise((resolve) => __awaiter$i(this, void 0, void 0, function* () {
2377
+ return new Promise((resolve) => __awaiter$j(this, void 0, void 0, function* () {
2379
2378
  const filePath = join(path, file);
2380
2379
  const absoluteFilePath = join(this.dir, filePath);
2381
2380
  lstat(absoluteFilePath, (err, stats) => {
@@ -2408,7 +2407,7 @@ let Gallery = class Gallery {
2408
2407
  });
2409
2408
  },
2410
2409
  writeResult: (isThumb, buffer) => {
2411
- return new Promise((res, rej) => __awaiter$i(this, void 0, void 0, function* () {
2410
+ return new Promise((res, rej) => __awaiter$j(this, void 0, void 0, function* () {
2412
2411
  const resultPath = getResultPath(isThumb);
2413
2412
  yield mkdirRecursive(dirname(resultPath));
2414
2413
  writeFile$1(resultPath, buffer, err => {
@@ -2465,7 +2464,7 @@ var __decorate$m = (this && this.__decorate) || function (decorators, target, ke
2465
2464
  var __metadata$i = (this && this.__metadata) || function (k, v) {
2466
2465
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
2467
2466
  };
2468
- var __awaiter$h = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2467
+ var __awaiter$i = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2469
2468
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
2470
2469
  return new (P || (P = Promise))(function (resolve, reject) {
2471
2470
  function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
@@ -2483,7 +2482,7 @@ let IdGenerator = class IdGenerator {
2483
2482
  this.parts = config.resolve("idParts");
2484
2483
  }
2485
2484
  generate(checkCb) {
2486
- return __awaiter$h(this, void 0, void 0, function* () {
2485
+ return __awaiter$i(this, void 0, void 0, function* () {
2487
2486
  let id = null;
2488
2487
  let tries = 0;
2489
2488
  let notGood = true;
@@ -2524,21 +2523,43 @@ var __decorate$l = (this && this.__decorate) || function (decorators, target, ke
2524
2523
  var __metadata$h = (this && this.__metadata) || function (k, v) {
2525
2524
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
2526
2525
  };
2526
+ var __awaiter$h = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2527
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
2528
+ return new (P || (P = Promise))(function (resolve, reject) {
2529
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
2530
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
2531
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
2532
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
2533
+ });
2534
+ };
2527
2535
  let TranslationProvider = class TranslationProvider {
2528
- constructor(config) {
2536
+ constructor(config, cache) {
2529
2537
  this.config = config;
2530
- this.cache = {};
2538
+ this.cache = cache;
2531
2539
  }
2532
2540
  getDictionary(language) {
2533
- this.cache[language] = this.cache[language] || axios.get(this.config.resolve("translationsTemplate").replace(`[lang]`, language)).then(r => r.data, reason => ({
2534
- message: reason
2535
- }));
2536
- return this.cache[language];
2541
+ return this.cache.getOrSet(`translations-${language}`, () => __awaiter$h(this, void 0, void 0, function* () {
2542
+ try {
2543
+ const url = this.config.resolve("translationsTemplate")
2544
+ .replace(`__lang__`, language)
2545
+ .replace(`[lang]`, language);
2546
+ const data = yield axios.get(url).then(t => t.data);
2547
+ if (isObject(data[language])) {
2548
+ return data[language];
2549
+ }
2550
+ return data;
2551
+ }
2552
+ catch (e) {
2553
+ return {
2554
+ message: `${e}`
2555
+ };
2556
+ }
2557
+ }), 5 * 60);
2537
2558
  }
2538
2559
  };
2539
2560
  TranslationProvider = __decorate$l([
2540
2561
  singleton(),
2541
- __metadata$h("design:paramtypes", [Configuration])
2562
+ __metadata$h("design:paramtypes", [Configuration, Cache])
2542
2563
  ], TranslationProvider);
2543
2564
 
2544
2565
  var __decorate$k = (this && this.__decorate) || function (decorators, target, key, desc) {