@stemy/backend 3.2.6 → 3.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -6,22 +6,22 @@ import { createParamDecorator, BadRequestError, HttpError, getMetadataArgsStorag
6
6
  import { OnMessage, ConnectedSocket, MessageBody, SocketController, Middleware as Middleware$1, useContainer as useContainer$1, useSocketServer } from 'socket-controllers';
7
7
  import { routingControllersToSpec } from 'routing-controllers-openapi';
8
8
  import { defaultMetadataStorage } from 'class-transformer/storage';
9
- import { ValidatorConstraint, ValidationTypes } from 'class-validator';
9
+ import { ValidatorConstraint, ValidationTypes, Min, Max, IsOptional, IsBoolean } from 'class-validator';
10
10
  import { validationMetadatasToSchemas } from 'class-validator-jsonschema';
11
11
  import { exec } from 'child_process';
12
12
  import { createHash } from 'crypto';
13
13
  import { Subscription, Observable, Subject, from } from 'rxjs';
14
14
  import { canReportError } from 'rxjs/internal/util/canReportError';
15
15
  import { mkdir, unlink, readFile as readFile$1, writeFile as writeFile$1, lstat, readdir, access, constants, lstatSync, readFileSync, existsSync } from 'fs';
16
+ import { ObjectId, GridFSBucket } from 'mongodb';
16
17
  import { Types, model, connect } from 'mongoose';
17
18
  import { getValue as getValue$1, setValue } from 'mongoose/lib/utils';
18
19
  import { Readable, PassThrough } from 'stream';
19
- import { ObjectId } from 'bson';
20
20
  import sharp_ from 'sharp';
21
+ import { ObjectId as ObjectId$1 } from 'bson';
21
22
  import fontKit_ from 'fontkit';
22
23
  import { fromBuffer } from 'file-type';
23
24
  import axios from 'axios';
24
- import { GridFSBucket } from 'mongodb';
25
25
  import dotenv from 'dotenv';
26
26
  import { validate, schedule } from 'node-cron';
27
27
  import { socket } from 'zeromq';
@@ -594,21 +594,23 @@ function ResolveEntity(model, extraCheck) {
594
594
  const query = !token
595
595
  ? model.findById(id)
596
596
  : model.findOne({ token });
597
- const doc = yield query;
598
- if (!doc) {
599
- throw new HttpError(404, !token
600
- ? `${modelName} could not be found with id: ${id}`
601
- : `${modelName} could not be found with token: ${token}`);
602
- }
597
+ let doc = null;
603
598
  if (isFunction(extraCheck)) {
604
599
  try {
605
- action.request[paramName] = (yield valueToPromise(extraCheck(query, action))) || doc;
606
- return action.request[paramName];
600
+ doc = yield valueToPromise(extraCheck(query, action));
607
601
  }
608
602
  catch (e) {
609
603
  throw new BadRequestError(`${modelName} check error: ${e.message || e}`);
610
604
  }
611
605
  }
606
+ else {
607
+ doc = yield query;
608
+ }
609
+ if (!doc) {
610
+ throw new HttpError(404, !token
611
+ ? `${modelName} could not be found with id: ${id}`
612
+ : `${modelName} could not be found with token: ${token}`);
613
+ }
612
614
  action.request[paramName] = doc;
613
615
  return doc;
614
616
  })
@@ -626,7 +628,9 @@ function idToString(value) {
626
628
  if (Array.isArray(value)) {
627
629
  return value.map(idToString);
628
630
  }
629
- return value instanceof ObjectId ? value.toHexString() : null;
631
+ return value instanceof ObjectId || value instanceof Types.ObjectId
632
+ ? value.toHexString()
633
+ : (isString(value) ? value : value || null);
630
634
  }
631
635
  function createTransformer(transform) {
632
636
  return (doc, ret, options) => {
@@ -868,7 +872,7 @@ function replaceSpecialChars(str, to = "-") {
868
872
  return `${str}`.replace(/[&\/\\#, +()$~%.@'":*?<>{}]/g, to);
869
873
  }
870
874
 
871
- var __decorate$x = (this && this.__decorate) || function (decorators, target, key, desc) {
875
+ var __decorate$y = (this && this.__decorate) || function (decorators, target, key, desc) {
872
876
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
873
877
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
874
878
  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;
@@ -878,8 +882,8 @@ function checkValue(multi, value) {
878
882
  if (multi) {
879
883
  return Array.isArray(value) && value.every(v => {
880
884
  try {
881
- const id = new ObjectId(v);
882
- return id instanceof ObjectId;
885
+ const id = new ObjectId$1(v);
886
+ return id instanceof ObjectId$1;
883
887
  }
884
888
  catch (e) {
885
889
  return false;
@@ -889,8 +893,8 @@ function checkValue(multi, value) {
889
893
  if (null === value)
890
894
  return true;
891
895
  try {
892
- const id = new ObjectId(value);
893
- return id instanceof ObjectId;
896
+ const id = new ObjectId$1(value);
897
+ return id instanceof ObjectId$1;
894
898
  }
895
899
  catch (e) {
896
900
  return false;
@@ -902,7 +906,7 @@ let IsFile = class IsFile {
902
906
  return checkValue(multi, value);
903
907
  }
904
908
  };
905
- IsFile = __decorate$x([
909
+ IsFile = __decorate$y([
906
910
  ValidatorConstraint()
907
911
  ], IsFile);
908
912
  let IsObjectId = class IsObjectId {
@@ -911,7 +915,7 @@ let IsObjectId = class IsObjectId {
911
915
  return checkValue(multi, value);
912
916
  }
913
917
  };
914
- IsObjectId = __decorate$x([
918
+ IsObjectId = __decorate$y([
915
919
  ValidatorConstraint()
916
920
  ], IsObjectId);
917
921
 
@@ -970,7 +974,7 @@ class Parameter {
970
974
  }
971
975
  }
972
976
 
973
- var __decorate$w = (this && this.__decorate) || function (decorators, target, key, desc) {
977
+ var __decorate$x = (this && this.__decorate) || function (decorators, target, key, desc) {
974
978
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
975
979
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
976
980
  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;
@@ -1089,18 +1093,18 @@ let AssetProcessor = AssetProcessor_1 = class AssetProcessor {
1089
1093
  });
1090
1094
  }
1091
1095
  };
1092
- AssetProcessor = AssetProcessor_1 = __decorate$w([
1096
+ AssetProcessor = AssetProcessor_1 = __decorate$x([
1093
1097
  injectable(),
1094
1098
  scoped(Lifecycle.ContainerScoped)
1095
1099
  ], AssetProcessor);
1096
1100
 
1097
- var __decorate$v = (this && this.__decorate) || function (decorators, target, key, desc) {
1101
+ var __decorate$w = (this && this.__decorate) || function (decorators, target, key, desc) {
1098
1102
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
1099
1103
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
1100
1104
  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;
1101
1105
  return c > 3 && r && Object.defineProperty(target, key, r), r;
1102
1106
  };
1103
- var __metadata$p = (this && this.__metadata) || function (k, v) {
1107
+ var __metadata$q = (this && this.__metadata) || function (k, v) {
1104
1108
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
1105
1109
  };
1106
1110
  var __param$8 = (this && this.__param) || function (paramIndex, decorator) {
@@ -1139,20 +1143,20 @@ let Configuration = class Configuration {
1139
1143
  return param.defaultValue;
1140
1144
  }
1141
1145
  };
1142
- Configuration = __decorate$v([
1146
+ Configuration = __decorate$w([
1143
1147
  injectable(),
1144
1148
  scoped(Lifecycle.ContainerScoped),
1145
1149
  __param$8(0, injectAll(PARAMETER)),
1146
- __metadata$p("design:paramtypes", [Array])
1150
+ __metadata$q("design:paramtypes", [Array])
1147
1151
  ], Configuration);
1148
1152
 
1149
- var __decorate$u = (this && this.__decorate) || function (decorators, target, key, desc) {
1153
+ var __decorate$v = (this && this.__decorate) || function (decorators, target, key, desc) {
1150
1154
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
1151
1155
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
1152
1156
  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;
1153
1157
  return c > 3 && r && Object.defineProperty(target, key, r), r;
1154
1158
  };
1155
- var __metadata$o = (this && this.__metadata) || function (k, v) {
1159
+ var __metadata$p = (this && this.__metadata) || function (k, v) {
1156
1160
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
1157
1161
  };
1158
1162
  var __awaiter$u = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
@@ -1194,10 +1198,10 @@ let MongoConnector = class MongoConnector {
1194
1198
  });
1195
1199
  }
1196
1200
  };
1197
- MongoConnector = __decorate$u([
1201
+ MongoConnector = __decorate$v([
1198
1202
  injectable(),
1199
1203
  singleton(),
1200
- __metadata$o("design:paramtypes", [Configuration])
1204
+ __metadata$p("design:paramtypes", [Configuration])
1201
1205
  ], MongoConnector);
1202
1206
 
1203
1207
  var __awaiter$t = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
@@ -1310,7 +1314,7 @@ class TempAsset {
1310
1314
  this.filename = filename;
1311
1315
  this.contentType = contentType;
1312
1316
  this.metadata = metadata;
1313
- this.id = new ObjectId().toHexString();
1317
+ this.id = new ObjectId$1().toHexString();
1314
1318
  }
1315
1319
  get stream() {
1316
1320
  return bufferToStream(this.buffer);
@@ -1357,13 +1361,13 @@ class TempAsset {
1357
1361
  }
1358
1362
  }
1359
1363
 
1360
- var __decorate$t = (this && this.__decorate) || function (decorators, target, key, desc) {
1364
+ var __decorate$u = (this && this.__decorate) || function (decorators, target, key, desc) {
1361
1365
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
1362
1366
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
1363
1367
  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;
1364
1368
  return c > 3 && r && Object.defineProperty(target, key, r), r;
1365
1369
  };
1366
- var __metadata$n = (this && this.__metadata) || function (k, v) {
1370
+ var __metadata$o = (this && this.__metadata) || function (k, v) {
1367
1371
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
1368
1372
  };
1369
1373
  var __awaiter$q = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
@@ -1447,7 +1451,7 @@ let Assets = class Assets {
1447
1451
  }
1448
1452
  read(id) {
1449
1453
  return __awaiter$q(this, void 0, void 0, function* () {
1450
- return !id ? null : this.find({ _id: new ObjectId(id) });
1454
+ return !id ? null : this.find({ _id: new ObjectId$1(id) });
1451
1455
  });
1452
1456
  }
1453
1457
  find(where) {
@@ -1491,7 +1495,7 @@ let Assets = class Assets {
1491
1495
  firstDownload: null,
1492
1496
  lastDownload: null
1493
1497
  }, metadata || {});
1494
- metadata.filename = metadata.filename || new ObjectId().toHexString();
1498
+ metadata.filename = metadata.filename || new ObjectId$1().toHexString();
1495
1499
  metadata.extension = (fileType.ext || "").trim();
1496
1500
  return new Promise(((resolve, reject) => {
1497
1501
  const uploaderStream = this.bucket.openUploadStream(metadata.filename);
@@ -1515,10 +1519,10 @@ let Assets = class Assets {
1515
1519
  });
1516
1520
  }
1517
1521
  };
1518
- Assets = __decorate$t([
1522
+ Assets = __decorate$u([
1519
1523
  injectable(),
1520
1524
  scoped(Lifecycle.ContainerScoped),
1521
- __metadata$n("design:paramtypes", [MongoConnector, AssetProcessor])
1525
+ __metadata$o("design:paramtypes", [MongoConnector, AssetProcessor])
1522
1526
  ], Assets);
1523
1527
 
1524
1528
  var __awaiter$p = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
@@ -1557,7 +1561,7 @@ class LazyAsset extends BaseEntity {
1557
1561
  if (!this.progressId) {
1558
1562
  yield this.collection.deleteOne({ _id: this.mId });
1559
1563
  }
1560
- return deleteFromBucket(this.assets.bucket, new ObjectId(this.assetId));
1564
+ return deleteFromBucket(this.assets.bucket, new ObjectId$1(this.assetId));
1561
1565
  });
1562
1566
  }
1563
1567
  startWorking() {
@@ -1607,13 +1611,13 @@ class LazyAsset extends BaseEntity {
1607
1611
  }
1608
1612
  }
1609
1613
 
1610
- var __decorate$s = (this && this.__decorate) || function (decorators, target, key, desc) {
1614
+ var __decorate$t = (this && this.__decorate) || function (decorators, target, key, desc) {
1611
1615
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
1612
1616
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
1613
1617
  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;
1614
1618
  return c > 3 && r && Object.defineProperty(target, key, r), r;
1615
1619
  };
1616
- var __metadata$m = (this && this.__metadata) || function (k, v) {
1620
+ var __metadata$n = (this && this.__metadata) || function (k, v) {
1617
1621
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
1618
1622
  };
1619
1623
  var __param$7 = (this && this.__param) || function (paramIndex, decorator) {
@@ -1801,17 +1805,17 @@ let JobManager = class JobManager {
1801
1805
  sendToWorkers(jobName, params) {
1802
1806
  return __awaiter$o(this, void 0, void 0, function* () {
1803
1807
  const publisher = yield this.apiPush;
1804
- const uniqueId = new ObjectId().toHexString();
1808
+ const uniqueId = new ObjectId$1().toHexString();
1805
1809
  yield publisher.send([jobName, JSON.stringify(params), uniqueId]);
1806
1810
  return uniqueId;
1807
1811
  });
1808
1812
  }
1809
1813
  };
1810
- JobManager = __decorate$s([
1814
+ JobManager = __decorate$t([
1811
1815
  injectable(),
1812
1816
  scoped(Lifecycle.ContainerScoped),
1813
1817
  __param$7(1, inject(DI_CONTAINER)), __param$7(2, injectAll(JOB)),
1814
- __metadata$m("design:paramtypes", [Configuration, Object, Array])
1818
+ __metadata$n("design:paramtypes", [Configuration, Object, Array])
1815
1819
  ], JobManager);
1816
1820
 
1817
1821
  var __awaiter$n = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
@@ -2024,13 +2028,13 @@ class SubProgress {
2024
2028
  }
2025
2029
  }
2026
2030
 
2027
- var __decorate$r = (this && this.__decorate) || function (decorators, target, key, desc) {
2031
+ var __decorate$s = (this && this.__decorate) || function (decorators, target, key, desc) {
2028
2032
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
2029
2033
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
2030
2034
  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;
2031
2035
  return c > 3 && r && Object.defineProperty(target, key, r), r;
2032
2036
  };
2033
- var __metadata$l = (this && this.__metadata) || function (k, v) {
2037
+ var __metadata$m = (this && this.__metadata) || function (k, v) {
2034
2038
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
2035
2039
  };
2036
2040
  var __awaiter$m = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
@@ -2050,7 +2054,7 @@ let Progresses = class Progresses {
2050
2054
  this.progresses = {};
2051
2055
  this.jobMan.on("progress-changed", progress => {
2052
2056
  const id = progress.id;
2053
- this.progresses[id] = new Progress(new ObjectId(id), progress, this.collection);
2057
+ this.progresses[id] = new Progress(new ObjectId$1(id), progress, this.collection);
2054
2058
  });
2055
2059
  }
2056
2060
  waitToFinish(id) {
@@ -2074,7 +2078,7 @@ let Progresses = class Progresses {
2074
2078
  }
2075
2079
  get(id) {
2076
2080
  return __awaiter$m(this, void 0, void 0, function* () {
2077
- return !id ? null : this.find({ _id: new ObjectId(id) });
2081
+ return !id ? null : this.find({ _id: new ObjectId$1(id) });
2078
2082
  });
2079
2083
  }
2080
2084
  find(where) {
@@ -2101,7 +2105,7 @@ let Progresses = class Progresses {
2101
2105
  }
2102
2106
  remove(id) {
2103
2107
  return __awaiter$m(this, void 0, void 0, function* () {
2104
- yield this.collection.deleteOne({ _id: new ObjectId(id) });
2108
+ yield this.collection.deleteOne({ _id: new ObjectId$1(id) });
2105
2109
  return id;
2106
2110
  });
2107
2111
  }
@@ -2130,19 +2134,19 @@ let Progresses = class Progresses {
2130
2134
  });
2131
2135
  }
2132
2136
  };
2133
- Progresses = __decorate$r([
2137
+ Progresses = __decorate$s([
2134
2138
  injectable(),
2135
2139
  singleton(),
2136
- __metadata$l("design:paramtypes", [MongoConnector, JobManager])
2140
+ __metadata$m("design:paramtypes", [MongoConnector, JobManager])
2137
2141
  ], Progresses);
2138
2142
 
2139
- var __decorate$q = (this && this.__decorate) || function (decorators, target, key, desc) {
2143
+ var __decorate$r = (this && this.__decorate) || function (decorators, target, key, desc) {
2140
2144
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
2141
2145
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
2142
2146
  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;
2143
2147
  return c > 3 && r && Object.defineProperty(target, key, r), r;
2144
2148
  };
2145
- var __metadata$k = (this && this.__metadata) || function (k, v) {
2149
+ var __metadata$l = (this && this.__metadata) || function (k, v) {
2146
2150
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
2147
2151
  };
2148
2152
  var __awaiter$l = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
@@ -2179,7 +2183,7 @@ let LazyAssets = class LazyAssets {
2179
2183
  }
2180
2184
  read(id) {
2181
2185
  return __awaiter$l(this, void 0, void 0, function* () {
2182
- return !id ? null : this.find({ _id: new ObjectId(id) });
2186
+ return !id ? null : this.find({ _id: new ObjectId$1(id) });
2183
2187
  });
2184
2188
  }
2185
2189
  find(where) {
@@ -2199,22 +2203,22 @@ let LazyAssets = class LazyAssets {
2199
2203
  });
2200
2204
  }
2201
2205
  };
2202
- LazyAssets = __decorate$q([
2206
+ LazyAssets = __decorate$r([
2203
2207
  injectable(),
2204
2208
  scoped(Lifecycle.ContainerScoped),
2205
- __metadata$k("design:paramtypes", [MongoConnector,
2209
+ __metadata$l("design:paramtypes", [MongoConnector,
2206
2210
  Assets,
2207
2211
  Progresses,
2208
2212
  JobManager])
2209
2213
  ], LazyAssets);
2210
2214
 
2211
- var __decorate$p = (this && this.__decorate) || function (decorators, target, key, desc) {
2215
+ var __decorate$q = (this && this.__decorate) || function (decorators, target, key, desc) {
2212
2216
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
2213
2217
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
2214
2218
  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;
2215
2219
  return c > 3 && r && Object.defineProperty(target, key, r), r;
2216
2220
  };
2217
- var __metadata$j = (this && this.__metadata) || function (k, v) {
2221
+ var __metadata$k = (this && this.__metadata) || function (k, v) {
2218
2222
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
2219
2223
  };
2220
2224
  var __awaiter$k = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
@@ -2251,19 +2255,19 @@ let AssetResolver = class AssetResolver {
2251
2255
  });
2252
2256
  }
2253
2257
  };
2254
- AssetResolver = __decorate$p([
2258
+ AssetResolver = __decorate$q([
2255
2259
  injectable(),
2256
2260
  scoped(Lifecycle.ContainerScoped),
2257
- __metadata$j("design:paramtypes", [Assets, LazyAssets])
2261
+ __metadata$k("design:paramtypes", [Assets, LazyAssets])
2258
2262
  ], AssetResolver);
2259
2263
 
2260
- var __decorate$o = (this && this.__decorate) || function (decorators, target, key, desc) {
2264
+ var __decorate$p = (this && this.__decorate) || function (decorators, target, key, desc) {
2261
2265
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
2262
2266
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
2263
2267
  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;
2264
2268
  return c > 3 && r && Object.defineProperty(target, key, r), r;
2265
2269
  };
2266
- var __metadata$i = (this && this.__metadata) || function (k, v) {
2270
+ var __metadata$j = (this && this.__metadata) || function (k, v) {
2267
2271
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
2268
2272
  };
2269
2273
  const express = express_;
@@ -2278,13 +2282,13 @@ let BackendProvider = class BackendProvider {
2278
2282
  return this.ioServer;
2279
2283
  }
2280
2284
  };
2281
- BackendProvider = __decorate$o([
2285
+ BackendProvider = __decorate$p([
2282
2286
  injectable(),
2283
2287
  singleton(),
2284
- __metadata$i("design:paramtypes", [])
2288
+ __metadata$j("design:paramtypes", [])
2285
2289
  ], BackendProvider);
2286
2290
 
2287
- var __decorate$n = (this && this.__decorate) || function (decorators, target, key, desc) {
2291
+ var __decorate$o = (this && this.__decorate) || function (decorators, target, key, desc) {
2288
2292
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
2289
2293
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
2290
2294
  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;
@@ -2311,18 +2315,18 @@ let CacheProcessor = class CacheProcessor {
2311
2315
  });
2312
2316
  }
2313
2317
  };
2314
- CacheProcessor = __decorate$n([
2318
+ CacheProcessor = __decorate$o([
2315
2319
  injectable(),
2316
2320
  scoped(Lifecycle.ContainerScoped)
2317
2321
  ], CacheProcessor);
2318
2322
 
2319
- var __decorate$m = (this && this.__decorate) || function (decorators, target, key, desc) {
2323
+ var __decorate$n = (this && this.__decorate) || function (decorators, target, key, desc) {
2320
2324
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
2321
2325
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
2322
2326
  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;
2323
2327
  return c > 3 && r && Object.defineProperty(target, key, r), r;
2324
2328
  };
2325
- var __metadata$h = (this && this.__metadata) || function (k, v) {
2329
+ var __metadata$i = (this && this.__metadata) || function (k, v) {
2326
2330
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
2327
2331
  };
2328
2332
  var __awaiter$i = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
@@ -2399,13 +2403,13 @@ let Cache = class Cache {
2399
2403
  });
2400
2404
  }
2401
2405
  };
2402
- Cache = __decorate$m([
2406
+ Cache = __decorate$n([
2403
2407
  injectable(),
2404
2408
  scoped(Lifecycle.ContainerScoped),
2405
- __metadata$h("design:paramtypes", [MongoConnector, Configuration, CacheProcessor])
2409
+ __metadata$i("design:paramtypes", [MongoConnector, Configuration, CacheProcessor])
2406
2410
  ], Cache);
2407
2411
 
2408
- var __decorate$l = (this && this.__decorate) || function (decorators, target, key, desc) {
2412
+ var __decorate$m = (this && this.__decorate) || function (decorators, target, key, desc) {
2409
2413
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
2410
2414
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
2411
2415
  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;
@@ -2427,18 +2431,18 @@ let EndpointProvider = class EndpointProvider {
2427
2431
  });
2428
2432
  }
2429
2433
  };
2430
- EndpointProvider = __decorate$l([
2434
+ EndpointProvider = __decorate$m([
2431
2435
  injectable(),
2432
2436
  scoped(Lifecycle.ContainerScoped)
2433
2437
  ], EndpointProvider);
2434
2438
 
2435
- var __decorate$k = (this && this.__decorate) || function (decorators, target, key, desc) {
2439
+ var __decorate$l = (this && this.__decorate) || function (decorators, target, key, desc) {
2436
2440
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
2437
2441
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
2438
2442
  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;
2439
2443
  return c > 3 && r && Object.defineProperty(target, key, r), r;
2440
2444
  };
2441
- var __metadata$g = (this && this.__metadata) || function (k, v) {
2445
+ var __metadata$h = (this && this.__metadata) || function (k, v) {
2442
2446
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
2443
2447
  };
2444
2448
  var __param$6 = (this && this.__param) || function (paramIndex, decorator) {
@@ -2467,11 +2471,11 @@ let Fixtures = class Fixtures {
2467
2471
  });
2468
2472
  }
2469
2473
  };
2470
- Fixtures = __decorate$k([
2474
+ Fixtures = __decorate$l([
2471
2475
  injectable(),
2472
2476
  scoped(Lifecycle.ContainerScoped),
2473
2477
  __param$6(0, injectAll(FIXTURE)),
2474
- __metadata$g("design:paramtypes", [Array])
2478
+ __metadata$h("design:paramtypes", [Array])
2475
2479
  ], Fixtures);
2476
2480
 
2477
2481
  var __awaiter$f = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
@@ -2520,13 +2524,13 @@ class GalleryImage {
2520
2524
  }
2521
2525
  }
2522
2526
 
2523
- var __decorate$j = (this && this.__decorate) || function (decorators, target, key, desc) {
2527
+ var __decorate$k = (this && this.__decorate) || function (decorators, target, key, desc) {
2524
2528
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
2525
2529
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
2526
2530
  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;
2527
2531
  return c > 3 && r && Object.defineProperty(target, key, r), r;
2528
2532
  };
2529
- var __metadata$f = (this && this.__metadata) || function (k, v) {
2533
+ var __metadata$g = (this && this.__metadata) || function (k, v) {
2530
2534
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
2531
2535
  };
2532
2536
  let GalleryCache = class GalleryCache {
@@ -2547,19 +2551,19 @@ let GalleryCache = class GalleryCache {
2547
2551
  return image;
2548
2552
  }
2549
2553
  };
2550
- GalleryCache = __decorate$j([
2554
+ GalleryCache = __decorate$k([
2551
2555
  injectable(),
2552
2556
  scoped(Lifecycle.ContainerScoped),
2553
- __metadata$f("design:paramtypes", [])
2557
+ __metadata$g("design:paramtypes", [])
2554
2558
  ], GalleryCache);
2555
2559
 
2556
- var __decorate$i = (this && this.__decorate) || function (decorators, target, key, desc) {
2560
+ var __decorate$j = (this && this.__decorate) || function (decorators, target, key, desc) {
2557
2561
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
2558
2562
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
2559
2563
  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;
2560
2564
  return c > 3 && r && Object.defineProperty(target, key, r), r;
2561
2565
  };
2562
- var __metadata$e = (this && this.__metadata) || function (k, v) {
2566
+ var __metadata$f = (this && this.__metadata) || function (k, v) {
2563
2567
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
2564
2568
  };
2565
2569
  var __awaiter$e = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
@@ -2677,19 +2681,19 @@ let Gallery = class Gallery {
2677
2681
  });
2678
2682
  }
2679
2683
  };
2680
- Gallery = __decorate$i([
2684
+ Gallery = __decorate$j([
2681
2685
  injectable(),
2682
2686
  scoped(Lifecycle.ContainerScoped),
2683
- __metadata$e("design:paramtypes", [Configuration, GalleryCache])
2687
+ __metadata$f("design:paramtypes", [Configuration, GalleryCache])
2684
2688
  ], Gallery);
2685
2689
 
2686
- var __decorate$h = (this && this.__decorate) || function (decorators, target, key, desc) {
2690
+ var __decorate$i = (this && this.__decorate) || function (decorators, target, key, desc) {
2687
2691
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
2688
2692
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
2689
2693
  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;
2690
2694
  return c > 3 && r && Object.defineProperty(target, key, r), r;
2691
2695
  };
2692
- var __metadata$d = (this && this.__metadata) || function (k, v) {
2696
+ var __metadata$e = (this && this.__metadata) || function (k, v) {
2693
2697
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
2694
2698
  };
2695
2699
  var __awaiter$d = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
@@ -2736,19 +2740,19 @@ let IdGenerator = class IdGenerator {
2736
2740
  }).join(this.separator);
2737
2741
  }
2738
2742
  };
2739
- IdGenerator = __decorate$h([
2743
+ IdGenerator = __decorate$i([
2740
2744
  injectable(),
2741
2745
  scoped(Lifecycle.ContainerScoped),
2742
- __metadata$d("design:paramtypes", [Configuration])
2746
+ __metadata$e("design:paramtypes", [Configuration])
2743
2747
  ], IdGenerator);
2744
2748
 
2745
- var __decorate$g = (this && this.__decorate) || function (decorators, target, key, desc) {
2749
+ var __decorate$h = (this && this.__decorate) || function (decorators, target, key, desc) {
2746
2750
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
2747
2751
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
2748
2752
  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;
2749
2753
  return c > 3 && r && Object.defineProperty(target, key, r), r;
2750
2754
  };
2751
- var __metadata$c = (this && this.__metadata) || function (k, v) {
2755
+ var __metadata$d = (this && this.__metadata) || function (k, v) {
2752
2756
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
2753
2757
  };
2754
2758
  let TranslationProvider = class TranslationProvider {
@@ -2763,19 +2767,19 @@ let TranslationProvider = class TranslationProvider {
2763
2767
  return this.cache[language];
2764
2768
  }
2765
2769
  };
2766
- TranslationProvider = __decorate$g([
2770
+ TranslationProvider = __decorate$h([
2767
2771
  injectable(),
2768
2772
  singleton(),
2769
- __metadata$c("design:paramtypes", [Configuration])
2773
+ __metadata$d("design:paramtypes", [Configuration])
2770
2774
  ], TranslationProvider);
2771
2775
 
2772
- var __decorate$f = (this && this.__decorate) || function (decorators, target, key, desc) {
2776
+ var __decorate$g = (this && this.__decorate) || function (decorators, target, key, desc) {
2773
2777
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
2774
2778
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
2775
2779
  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;
2776
2780
  return c > 3 && r && Object.defineProperty(target, key, r), r;
2777
2781
  };
2778
- var __metadata$b = (this && this.__metadata) || function (k, v) {
2782
+ var __metadata$c = (this && this.__metadata) || function (k, v) {
2779
2783
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
2780
2784
  };
2781
2785
  var __awaiter$c = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
@@ -2844,19 +2848,19 @@ let Translator = class Translator {
2844
2848
  });
2845
2849
  }
2846
2850
  };
2847
- Translator = __decorate$f([
2851
+ Translator = __decorate$g([
2848
2852
  injectable(),
2849
2853
  singleton(),
2850
- __metadata$b("design:paramtypes", [TranslationProvider])
2854
+ __metadata$c("design:paramtypes", [TranslationProvider])
2851
2855
  ], Translator);
2852
2856
 
2853
- var __decorate$e = (this && this.__decorate) || function (decorators, target, key, desc) {
2857
+ var __decorate$f = (this && this.__decorate) || function (decorators, target, key, desc) {
2854
2858
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
2855
2859
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
2856
2860
  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;
2857
2861
  return c > 3 && r && Object.defineProperty(target, key, r), r;
2858
2862
  };
2859
- var __metadata$a = (this && this.__metadata) || function (k, v) {
2863
+ var __metadata$b = (this && this.__metadata) || function (k, v) {
2860
2864
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
2861
2865
  };
2862
2866
  var __awaiter$b = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
@@ -2926,19 +2930,19 @@ let TemplateRenderer = class TemplateRenderer {
2926
2930
  });
2927
2931
  }
2928
2932
  };
2929
- TemplateRenderer = __decorate$e([
2933
+ TemplateRenderer = __decorate$f([
2930
2934
  injectable(),
2931
2935
  singleton(),
2932
- __metadata$a("design:paramtypes", [Translator, Configuration])
2936
+ __metadata$b("design:paramtypes", [Translator, Configuration])
2933
2937
  ], TemplateRenderer);
2934
2938
 
2935
- var __decorate$d = (this && this.__decorate) || function (decorators, target, key, desc) {
2939
+ var __decorate$e = (this && this.__decorate) || function (decorators, target, key, desc) {
2936
2940
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
2937
2941
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
2938
2942
  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;
2939
2943
  return c > 3 && r && Object.defineProperty(target, key, r), r;
2940
2944
  };
2941
- var __metadata$9 = (this && this.__metadata) || function (k, v) {
2945
+ var __metadata$a = (this && this.__metadata) || function (k, v) {
2942
2946
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
2943
2947
  };
2944
2948
  var __awaiter$a = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
@@ -2980,19 +2984,19 @@ let MailSender = class MailSender {
2980
2984
  });
2981
2985
  }
2982
2986
  };
2983
- MailSender = __decorate$d([
2987
+ MailSender = __decorate$e([
2984
2988
  injectable(),
2985
2989
  singleton(),
2986
- __metadata$9("design:paramtypes", [Configuration, TemplateRenderer])
2990
+ __metadata$a("design:paramtypes", [Configuration, TemplateRenderer])
2987
2991
  ], MailSender);
2988
2992
 
2989
- var __decorate$c = (this && this.__decorate) || function (decorators, target, key, desc) {
2993
+ var __decorate$d = (this && this.__decorate) || function (decorators, target, key, desc) {
2990
2994
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
2991
2995
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
2992
2996
  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;
2993
2997
  return c > 3 && r && Object.defineProperty(target, key, r), r;
2994
2998
  };
2995
- var __metadata$8 = (this && this.__metadata) || function (k, v) {
2999
+ var __metadata$9 = (this && this.__metadata) || function (k, v) {
2996
3000
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
2997
3001
  };
2998
3002
  var __awaiter$9 = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
@@ -3061,13 +3065,13 @@ let MemoryCache = class MemoryCache {
3061
3065
  });
3062
3066
  }
3063
3067
  };
3064
- MemoryCache = __decorate$c([
3068
+ MemoryCache = __decorate$d([
3065
3069
  injectable(),
3066
3070
  scoped(Lifecycle.ContainerScoped),
3067
- __metadata$8("design:paramtypes", [Cache])
3071
+ __metadata$9("design:paramtypes", [Cache])
3068
3072
  ], MemoryCache);
3069
3073
 
3070
- var __decorate$b = (this && this.__decorate) || function (decorators, target, key, desc) {
3074
+ var __decorate$c = (this && this.__decorate) || function (decorators, target, key, desc) {
3071
3075
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3072
3076
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
3073
3077
  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;
@@ -3107,11 +3111,80 @@ let UserManager = class UserManager {
3107
3111
  });
3108
3112
  }
3109
3113
  };
3110
- UserManager = __decorate$b([
3114
+ UserManager = __decorate$c([
3111
3115
  injectable(),
3112
3116
  scoped(Lifecycle.ContainerScoped)
3113
3117
  ], UserManager);
3114
3118
 
3119
+ var __decorate$b = (this && this.__decorate) || function (decorators, target, key, desc) {
3120
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3121
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
3122
+ 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;
3123
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
3124
+ };
3125
+ var __metadata$8 = (this && this.__metadata) || function (k, v) {
3126
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
3127
+ };
3128
+ class AssetImageParams {
3129
+ constructor() {
3130
+ this.rotation = 0;
3131
+ this.canvasScaleX = 1;
3132
+ this.canvasScaleY = 1;
3133
+ this.scaleX = 1;
3134
+ this.scaleY = 1;
3135
+ this.lazy = false;
3136
+ this.crop = false;
3137
+ this.cropBefore = false;
3138
+ this.cropAfter = false;
3139
+ }
3140
+ }
3141
+ __decorate$b([
3142
+ Min(-360),
3143
+ Max(360),
3144
+ IsOptional(),
3145
+ __metadata$8("design:type", Number)
3146
+ ], AssetImageParams.prototype, "rotation", void 0);
3147
+ __decorate$b([
3148
+ Min(0.0001),
3149
+ IsOptional(),
3150
+ __metadata$8("design:type", Number)
3151
+ ], AssetImageParams.prototype, "canvasScaleX", void 0);
3152
+ __decorate$b([
3153
+ Min(0.0001),
3154
+ IsOptional(),
3155
+ __metadata$8("design:type", Number)
3156
+ ], AssetImageParams.prototype, "canvasScaleY", void 0);
3157
+ __decorate$b([
3158
+ Min(0.0001),
3159
+ IsOptional(),
3160
+ __metadata$8("design:type", Number)
3161
+ ], AssetImageParams.prototype, "scaleX", void 0);
3162
+ __decorate$b([
3163
+ Min(0.0001),
3164
+ IsOptional(),
3165
+ __metadata$8("design:type", Number)
3166
+ ], AssetImageParams.prototype, "scaleY", void 0);
3167
+ __decorate$b([
3168
+ IsBoolean(),
3169
+ IsOptional(),
3170
+ __metadata$8("design:type", Boolean)
3171
+ ], AssetImageParams.prototype, "lazy", void 0);
3172
+ __decorate$b([
3173
+ IsBoolean(),
3174
+ IsOptional(),
3175
+ __metadata$8("design:type", Boolean)
3176
+ ], AssetImageParams.prototype, "crop", void 0);
3177
+ __decorate$b([
3178
+ IsBoolean(),
3179
+ IsOptional(),
3180
+ __metadata$8("design:type", Boolean)
3181
+ ], AssetImageParams.prototype, "cropBefore", void 0);
3182
+ __decorate$b([
3183
+ IsBoolean(),
3184
+ IsOptional(),
3185
+ __metadata$8("design:type", Boolean)
3186
+ ], AssetImageParams.prototype, "cropAfter", void 0);
3187
+
3115
3188
  var __decorate$a = (this && this.__decorate) || function (decorators, target, key, desc) {
3116
3189
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3117
3190
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
@@ -3256,14 +3329,14 @@ __decorate$a([
3256
3329
  Get("/image/:id/:rotation"),
3257
3330
  __param$5(0, Param("id")), __param$5(1, QueryParams()), __param$5(2, Res()), __param$5(3, Param("rotation")),
3258
3331
  __metadata$7("design:type", Function),
3259
- __metadata$7("design:paramtypes", [String, Object, Object, Number]),
3332
+ __metadata$7("design:paramtypes", [String, AssetImageParams, Object, Number]),
3260
3333
  __metadata$7("design:returntype", Promise)
3261
3334
  ], AssetsController.prototype, "getImageRotation", null);
3262
3335
  __decorate$a([
3263
3336
  Get("/image/:id"),
3264
3337
  __param$5(0, Param("id")), __param$5(1, QueryParams()), __param$5(2, Res()),
3265
3338
  __metadata$7("design:type", Function),
3266
- __metadata$7("design:paramtypes", [String, Object, Object]),
3339
+ __metadata$7("design:paramtypes", [String, AssetImageParams, Object]),
3267
3340
  __metadata$7("design:returntype", Promise)
3268
3341
  ], AssetsController.prototype, "getImage", null);
3269
3342
  __decorate$a([
@@ -3277,7 +3350,7 @@ __decorate$a([
3277
3350
  Get("/by-name/image/:name"),
3278
3351
  __param$5(0, Param("name")), __param$5(1, QueryParams()), __param$5(2, Res()),
3279
3352
  __metadata$7("design:type", Function),
3280
- __metadata$7("design:paramtypes", [String, Object, Object]),
3353
+ __metadata$7("design:paramtypes", [String, AssetImageParams, Object]),
3281
3354
  __metadata$7("design:returntype", Promise)
3282
3355
  ], AssetsController.prototype, "getImageByName", null);
3283
3356
  AssetsController = __decorate$a([
@@ -3598,7 +3671,7 @@ var __decorate$2 = (this && this.__decorate) || function (decorators, target, ke
3598
3671
  };
3599
3672
  let RequestStartedMiddleware = class RequestStartedMiddleware {
3600
3673
  use(request, response, next) {
3601
- request.id = new ObjectId().toHexString();
3674
+ request.id = new ObjectId$1().toHexString();
3602
3675
  request.started = moment();
3603
3676
  console.log(`Request '${request.id}' started at: ${request.started.format("YYYY-MM-DD HH:mm:ss")} [${request.method}] ${request.url}`);
3604
3677
  next(null);
@@ -4231,5 +4304,5 @@ function setupBackend(config, providers, parent) {
4231
4304
  * Generated bundle index. Do not edit.
4232
4305
  */
4233
4306
 
4234
- export { AssetProcessor, AssetResolver, Assets, AuthController, BackendProvider, Cache, CacheProcessor, Configuration, ConsoleColor, DI_CONTAINER, EXPRESS, EndpointProvider, ErrorHandlerMiddleware, FIXTURE, Fixtures, Gallery, GalleryCache, GalleryController, HTTP_SERVER, IdGenerator, IsFile, IsObjectId, JOB, JobManager, LanguageMiddleware, LazyAssetGenerator, LazyAssets, MailSender, MemoryCache, MongoConnector, PARAMETER, Parameter, Progresses, ResolveEntity, SOCKET_SERVER, TemplateRenderer, TranslationProvider, Translator, Type, UserManager, assign, broadcast, bufferToStream, colorize, convertValue, copy, copyStream, createServices, createTransformer, deleteFile, deleteFromBucket, filter, firstItem, getConstructorName, getExtension, getFileName, getFunctionParams, getType, getValue, groupBy, hydratePopulated, idToString, injectServices, isArray, isBoolean, isConstructor, isDate, isDefined, isFunction, isInterface, isNullOrUndefined, isObject, isObjectId, isPrimitive, isString, isType, jsonHighlight, lastItem, lcFirst, letsLookupStage, lookupStages, matchField, matchFieldStages, matchStage, md5, mkdirRecursive, multiSubscription, observableFromFunction, padLeft, padRight, paginate, paginateAggregations, projectStage, promiseTimeout, proxyFunction, proxyFunctions, rand, random, readAndDeleteFile, readFile, regroup, replaceSpecialChars, runCommand, setupBackend, streamToBuffer, toImage, ucFirst, uniqueItems, unwindStage, valueToPromise, writeFile };
4307
+ export { AssetImageParams, AssetProcessor, AssetResolver, Assets, AuthController, BackendProvider, Cache, CacheProcessor, Configuration, ConsoleColor, DI_CONTAINER, EXPRESS, EndpointProvider, ErrorHandlerMiddleware, FIXTURE, Fixtures, Gallery, GalleryCache, GalleryController, HTTP_SERVER, IdGenerator, IsFile, IsObjectId, JOB, JobManager, LanguageMiddleware, LazyAssetGenerator, LazyAssets, MailSender, MemoryCache, MongoConnector, PARAMETER, Parameter, Progresses, ResolveEntity, SOCKET_SERVER, TemplateRenderer, TranslationProvider, Translator, Type, UserManager, assign, broadcast, bufferToStream, colorize, convertValue, copy, copyStream, createServices, createTransformer, deleteFile, deleteFromBucket, filter, firstItem, getConstructorName, getExtension, getFileName, getFunctionParams, getType, getValue, groupBy, hydratePopulated, idToString, injectServices, isArray, isBoolean, isConstructor, isDate, isDefined, isFunction, isInterface, isNullOrUndefined, isObject, isObjectId, isPrimitive, isString, isType, jsonHighlight, lastItem, lcFirst, letsLookupStage, lookupStages, matchField, matchFieldStages, matchStage, md5, mkdirRecursive, multiSubscription, observableFromFunction, padLeft, padRight, paginate, paginateAggregations, projectStage, promiseTimeout, proxyFunction, proxyFunctions, rand, random, readAndDeleteFile, readFile, regroup, replaceSpecialChars, runCommand, setupBackend, streamToBuffer, toImage, ucFirst, uniqueItems, unwindStage, valueToPromise, writeFile };
4235
4308
  //# sourceMappingURL=stemy-backend.js.map