@stemy/backend 3.6.0 → 4.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (145) hide show
  1. package/commands/fixtures-command.d.ts +9 -0
  2. package/commands/index.d.ts +2 -0
  3. package/common-types.d.ts +11 -6
  4. package/esm2020/commands/clear-command.mjs +17 -0
  5. package/esm2020/commands/fixtures-command.mjs +23 -0
  6. package/esm2020/commands/index.mjs +7 -0
  7. package/esm2020/common-types.mjs +21 -0
  8. package/esm2020/public_api.mjs +379 -0
  9. package/esm2020/requests/asset-image-params.mjs +53 -0
  10. package/esm2020/rest-controllers/assets.controller.mjs +126 -0
  11. package/esm2020/rest-controllers/auth.controller.mjs +46 -0
  12. package/esm2020/rest-controllers/gallery.controller.mjs +21 -0
  13. package/esm2020/rest-controllers/progresses.controller.mjs +29 -0
  14. package/esm2020/rest-controllers/terminal-styles.mjs +67 -0
  15. package/esm2020/rest-controllers/terminal.controller.mjs +125 -0
  16. package/esm2020/rest-middlewares/container.middleware.mjs +20 -0
  17. package/esm2020/rest-middlewares/error-handler.middleware.mjs +74 -0
  18. package/esm2020/rest-middlewares/language.middleware.mjs +18 -0
  19. package/esm2020/rest-middlewares/request-ended.middleware.mjs +23 -0
  20. package/esm2020/rest-middlewares/request-started.middleware.mjs +22 -0
  21. package/esm2020/services/asset-processor.mjs +90 -0
  22. package/esm2020/services/asset-resolver.mjs +31 -0
  23. package/esm2020/services/assets.mjs +140 -0
  24. package/esm2020/services/backend-provider.mjs +22 -0
  25. package/esm2020/services/cache-processor.mjs +16 -0
  26. package/esm2020/services/cache.mjs +62 -0
  27. package/{esm2015/services/configuration.js → esm2020/services/configuration.mjs} +3 -15
  28. package/esm2020/services/endpoint-provider.mjs +13 -0
  29. package/esm2020/services/entities/asset.mjs +43 -0
  30. package/esm2020/services/entities/base-entity.mjs +26 -0
  31. package/esm2020/services/entities/lazy-asset.mjs +73 -0
  32. package/esm2020/services/entities/progress.mjs +176 -0
  33. package/esm2020/services/entities/temp-asset.mjs +45 -0
  34. package/esm2020/services/fixtures.mjs +26 -0
  35. package/esm2020/services/gallery-cache.mjs +27 -0
  36. package/esm2020/services/gallery-image.mjs +37 -0
  37. package/esm2020/services/gallery.mjs +116 -0
  38. package/esm2020/services/id-generator.mjs +42 -0
  39. package/esm2020/services/job-manager.mjs +187 -0
  40. package/esm2020/services/lazy-assets.mjs +48 -0
  41. package/esm2020/services/logger.mjs +21 -0
  42. package/esm2020/services/mail-sender.mjs +36 -0
  43. package/esm2020/services/memory-cache.mjs +57 -0
  44. package/esm2020/services/mongo-connector.mjs +37 -0
  45. package/esm2020/services/open-api.mjs +114 -0
  46. package/esm2020/services/progresses.mjs +86 -0
  47. package/esm2020/services/template-renderer.mjs +64 -0
  48. package/esm2020/services/terminal-manager.mjs +77 -0
  49. package/esm2020/services/token-generator.mjs +35 -0
  50. package/esm2020/services/translation-provider.mjs +34 -0
  51. package/esm2020/services/translator.mjs +63 -0
  52. package/esm2020/services/user-manager.mjs +27 -0
  53. package/esm2020/socket-controllers/progress.controller.mjs +52 -0
  54. package/esm2020/socket-controllers/terminal.controller.mjs +48 -0
  55. package/esm2020/socket-controllers/terminal.mjs +85 -0
  56. package/esm2020/socket-middlewares/compression.middleware.mjs +14 -0
  57. package/esm2020/static.mjs +23 -0
  58. package/esm2020/utilities/decorators.mjs +52 -0
  59. package/esm2020/utilities/di-container.mjs +83 -0
  60. package/esm2020/utilities/empty-job.mjs +13 -0
  61. package/esm2020/utilities/lazy-asset-generator.mjs +35 -0
  62. package/esm2020/utilities/mongoose.mjs +216 -0
  63. package/esm2020/utils.mjs +693 -0
  64. package/esm2020/validators.mjs +46 -0
  65. package/fesm2015/{stemy-backend.js → stemy-backend.mjs} +1638 -2403
  66. package/fesm2015/stemy-backend.mjs.map +1 -0
  67. package/fesm2020/stemy-backend.mjs +4202 -0
  68. package/fesm2020/stemy-backend.mjs.map +1 -0
  69. package/{stemy-backend.d.ts → index.d.ts} +1 -0
  70. package/package.json +35 -23
  71. package/public_api.d.ts +2 -2
  72. package/rest-controllers/terminal-styles.d.ts +2 -0
  73. package/rest-controllers/terminal.controller.d.ts +2 -0
  74. package/services/assets.d.ts +1 -0
  75. package/services/entities/asset.d.ts +1 -0
  76. package/services/entities/temp-asset.d.ts +1 -0
  77. package/services/fixtures.d.ts +2 -2
  78. package/utils.d.ts +3 -0
  79. package/bundles/stemy-backend.umd.js +0 -7553
  80. package/bundles/stemy-backend.umd.js.map +0 -1
  81. package/esm2015/common-types.js +0 -20
  82. package/esm2015/public_api.js +0 -380
  83. package/esm2015/requests/asset-image-params.js +0 -70
  84. package/esm2015/rest-controllers/assets.controller.js +0 -180
  85. package/esm2015/rest-controllers/auth.controller.js +0 -76
  86. package/esm2015/rest-controllers/gallery.controller.js +0 -37
  87. package/esm2015/rest-controllers/progresses.controller.js +0 -57
  88. package/esm2015/rest-controllers/terminal.controller.js +0 -151
  89. package/esm2015/rest-middlewares/container.middleware.js +0 -32
  90. package/esm2015/rest-middlewares/error-handler.middleware.js +0 -99
  91. package/esm2015/rest-middlewares/language.middleware.js +0 -28
  92. package/esm2015/rest-middlewares/request-ended.middleware.js +0 -33
  93. package/esm2015/rest-middlewares/request-started.middleware.js +0 -32
  94. package/esm2015/rest-openapi.js +0 -44
  95. package/esm2015/services/asset-processor.js +0 -108
  96. package/esm2015/services/asset-resolver.js +0 -53
  97. package/esm2015/services/assets.js +0 -181
  98. package/esm2015/services/backend-provider.js +0 -32
  99. package/esm2015/services/cache-processor.js +0 -34
  100. package/esm2015/services/cache.js +0 -93
  101. package/esm2015/services/endpoint-provider.js +0 -29
  102. package/esm2015/services/entities/asset.js +0 -60
  103. package/esm2015/services/entities/base-entity.js +0 -37
  104. package/esm2015/services/entities/lazy-asset.js +0 -90
  105. package/esm2015/services/entities/progress.js +0 -213
  106. package/esm2015/services/entities/temp-asset.js +0 -64
  107. package/esm2015/services/fixtures.js +0 -45
  108. package/esm2015/services/gallery-cache.js +0 -36
  109. package/esm2015/services/gallery-image.js +0 -48
  110. package/esm2015/services/gallery.js +0 -138
  111. package/esm2015/services/id-generator.js +0 -63
  112. package/esm2015/services/job-manager.js +0 -221
  113. package/esm2015/services/lazy-assets.js +0 -83
  114. package/esm2015/services/logger.js +0 -31
  115. package/esm2015/services/mail-sender.js +0 -58
  116. package/esm2015/services/memory-cache.js +0 -84
  117. package/esm2015/services/mongo-connector.js +0 -58
  118. package/esm2015/services/open-api.js +0 -140
  119. package/esm2015/services/progresses.js +0 -118
  120. package/esm2015/services/template-renderer.js +0 -88
  121. package/esm2015/services/terminal-manager.js +0 -94
  122. package/esm2015/services/token-generator.js +0 -55
  123. package/esm2015/services/translation-provider.js +0 -54
  124. package/esm2015/services/translator.js +0 -84
  125. package/esm2015/services/user-manager.js +0 -47
  126. package/esm2015/socket-controllers/progress.controller.js +0 -82
  127. package/esm2015/socket-controllers/terminal.controller.js +0 -83
  128. package/esm2015/socket-controllers/terminal.js +0 -98
  129. package/esm2015/socket-middlewares/compression.middleware.js +0 -19
  130. package/esm2015/static.js +0 -33
  131. package/esm2015/utilities/clear-command.js +0 -33
  132. package/esm2015/utilities/decorators.js +0 -54
  133. package/esm2015/utilities/di-container.js +0 -84
  134. package/esm2015/utilities/empty-job.js +0 -29
  135. package/esm2015/utilities/lazy-asset-generator.js +0 -46
  136. package/esm2015/utilities/mongoose.js +0 -225
  137. package/esm2015/utils.js +0 -699
  138. package/esm2015/validators.js +0 -51
  139. package/fesm2015/stemy-backend.js.map +0 -1
  140. package/rest-openapi.d.ts +0 -3
  141. package/stemy-backend.metadata.json +0 -1
  142. /package/{utilities → commands}/clear-command.d.ts +0 -0
  143. /package/{esm2015/stemy-backend.js → esm2020/stemy-backend.mjs} +0 -0
  144. /package/{esm2015/utilities/base-doc.js → esm2020/utilities/base-doc.mjs} +0 -0
  145. /package/{esm2015/utilities/tree.js → esm2020/utilities/tree.mjs} +0 -0
@@ -0,0 +1,379 @@
1
+ import { join } from "path";
2
+ import bodyParser from "body-parser";
3
+ import webToken from "jsonwebtoken";
4
+ import { container } from "tsyringe";
5
+ import { HttpError, useContainer as useRoutingContainer, useExpressServer } from "routing-controllers";
6
+ import { SocketControllers } from "socket-controllers";
7
+ import { DI_CONTAINER, EXPRESS, FIXTURE, HTTP_SERVER, JOB, OPENAPI_VALIDATION, Parameter, PARAMETER, SOCKET_SERVER, SOCKET_CONTROLLERS, TERMINAL_COMMAND } from "./common-types";
8
+ import { AssetProcessor } from "./services/asset-processor";
9
+ import { AssetResolver } from "./services/asset-resolver";
10
+ import { Assets } from "./services/assets";
11
+ import { BackendProvider } from "./services/backend-provider";
12
+ import { Cache } from "./services/cache";
13
+ import { CacheProcessor } from "./services/cache-processor";
14
+ import { Configuration } from "./services/configuration";
15
+ import { EndpointProvider } from "./services/endpoint-provider";
16
+ import { Fixtures } from "./services/fixtures";
17
+ import { Gallery } from "./services/gallery";
18
+ import { GalleryCache } from "./services/gallery-cache";
19
+ import { IdGenerator } from "./services/id-generator";
20
+ import { JobManager } from "./services/job-manager";
21
+ import { LazyAssets } from "./services/lazy-assets";
22
+ import { Logger } from "./services/logger";
23
+ import { MailSender } from "./services/mail-sender";
24
+ import { MemoryCache } from "./services/memory-cache";
25
+ import { MongoConnector } from "./services/mongo-connector";
26
+ import { OpenApi } from "./services/open-api";
27
+ import { Progresses } from "./services/progresses";
28
+ import { TemplateRenderer } from "./services/template-renderer";
29
+ import { TerminalManager } from "./services/terminal-manager";
30
+ import { TokenGenerator } from "./services/token-generator";
31
+ import { TranslationProvider } from "./services/translation-provider";
32
+ import { Translator } from "./services/translator";
33
+ import { UserManager } from "./services/user-manager";
34
+ import { AssetsController } from "./rest-controllers/assets.controller";
35
+ import { AuthController } from "./rest-controllers/auth.controller";
36
+ import { GalleryController } from "./rest-controllers/gallery.controller";
37
+ import { ProgressesController } from "./rest-controllers/progresses.controller";
38
+ import { TerminalController as TerminalRestController } from "./rest-controllers/terminal.controller";
39
+ import { ErrorHandlerMiddleware } from "./rest-middlewares/error-handler.middleware";
40
+ import { ContainerMiddleware } from "./rest-middlewares/container.middleware";
41
+ import { LanguageMiddleware } from "./rest-middlewares/language.middleware";
42
+ import { RequestEndedMiddleware } from "./rest-middlewares/request-ended.middleware";
43
+ import { RequestStartedMiddleware } from "./rest-middlewares/request-started.middleware";
44
+ import { ProgressController } from "./socket-controllers/progress.controller";
45
+ import { TerminalController } from "./socket-controllers/terminal.controller";
46
+ import { CompressionMiddleware } from "./socket-middlewares/compression.middleware";
47
+ import { DiContainer } from "./utilities/di-container";
48
+ import { EmptyJob } from "./utilities/empty-job";
49
+ import { diContainers, isFunction, isString, isType, prepareUrlEmpty, valueToPromise, getDirName } from "./utils";
50
+ import { setupStatic } from "./static";
51
+ import { commands } from "./commands";
52
+ export { isNullOrUndefined, isDefined, getType, isObject, isArray, isBuffer, isBoolean, isDate, isPrimitive, isString, isFunction, isConstructor, isType, isInterface, ucFirst, lcFirst, isObjectId, firstItem, lastItem, regroup, uniqueItems, getValue, groupBy, convertValue, toImage, bufferToStream, streamToBuffer, copyStream, mkdirRecursive, deleteFile, readFile, readAndDeleteFile, writeFile, valueToPromise, promiseTimeout, getConstructorName, getFunctionParams, getFileName, getExtension, createIdString, idToString, createTransformer, broadcast, rand, random, multiSubscription, observableFromFunction, padLeft, padRight, camelCaseToDash, deleteFromBucket, filter, copy, assign, md5, runCommand, ConsoleColor, colorize, jsonHighlight, replaceSpecialChars, regexEscape, flatten, wrapError, getDirName, prepareUrl, prepareUrlSlash, prepareUrlEmpty, fileTypeFromBuffer } from "./utils";
53
+ export { IsFile, IsObjectId } from "./validators";
54
+ export { FIXTURE, JOB, TERMINAL_COMMAND, EXPRESS, HTTP_SERVER, SOCKET_SERVER, SOCKET_CONTROLLERS, PARAMETER, DI_CONTAINER, OPENAPI_VALIDATION, Type, Parameter } from "./common-types";
55
+ export { AssetProcessor } from "./services/asset-processor";
56
+ export { AssetResolver } from "./services/asset-resolver";
57
+ export { Assets } from "./services/assets";
58
+ export { BackendProvider } from "./services/backend-provider";
59
+ export { Cache } from "./services/cache";
60
+ export { CacheProcessor } from "./services/cache-processor";
61
+ export { Configuration } from "./services/configuration";
62
+ export { EndpointProvider } from "./services/endpoint-provider";
63
+ export { Fixtures } from "./services/fixtures";
64
+ export { Gallery } from "./services/gallery";
65
+ export { GalleryCache } from "./services/gallery-cache";
66
+ export { IdGenerator } from "./services/id-generator";
67
+ export { JobManager } from "./services/job-manager";
68
+ export { LazyAssets } from "./services/lazy-assets";
69
+ export { Logger } from "./services/logger";
70
+ export { MailSender } from "./services/mail-sender";
71
+ export { MemoryCache } from "./services/memory-cache";
72
+ export { MongoConnector } from "./services/mongo-connector";
73
+ export { OpenApi } from "./services/open-api";
74
+ export { Progresses } from "./services/progresses";
75
+ export { TemplateRenderer } from "./services/template-renderer";
76
+ export { TerminalManager } from "./services/terminal-manager";
77
+ export { TokenGenerator } from "./services/token-generator";
78
+ export { TranslationProvider } from "./services/translation-provider";
79
+ export { Translator } from "./services/translator";
80
+ export { UserManager } from "./services/user-manager";
81
+ export { AssetImageParams } from "./requests/asset-image-params";
82
+ export { AuthController } from "./rest-controllers/auth.controller";
83
+ export { GalleryController } from "./rest-controllers/gallery.controller";
84
+ export { ErrorHandlerMiddleware } from "./rest-middlewares/error-handler.middleware";
85
+ export { LanguageMiddleware } from "./rest-middlewares/language.middleware";
86
+ export { BaseDoc, DocumentArray, PrimitiveArray } from "./utilities/base-doc";
87
+ export { IsDocumented, JsonResponse, ResponseType } from "./utilities/decorators";
88
+ export { LazyAssetGenerator } from "./utilities/lazy-asset-generator";
89
+ export { ResolveEntity, paginateAggregations, hydratePopulated, unwindStage, projectStage, matchFieldStages, matchField, matchStage, letsLookupStage, lookupStages, paginate, injectServices, service } from "./utilities/mongoose";
90
+ export async function resolveUser(req) {
91
+ if (req.user)
92
+ return req.user;
93
+ const container = req.container;
94
+ const auth = req.header("Authorization") || "";
95
+ let payload = null;
96
+ try {
97
+ const config = container.resolve(Configuration);
98
+ payload = webToken.verify(auth.split(" ")[1], config.resolve("jwtSecret"));
99
+ }
100
+ catch (e) {
101
+ throw new HttpError(401, `Authentication failed. (${e.message})`);
102
+ }
103
+ if (!payload) {
104
+ throw new HttpError(401, `Authentication failed. (Maybe invalid token)`);
105
+ }
106
+ req.user = await container.resolve(UserManager).getById(payload.id);
107
+ return req.user;
108
+ }
109
+ export function createServices() {
110
+ // List of parameters
111
+ const dirName = getDirName();
112
+ const params = [
113
+ new Parameter("serviceName", "Backend"),
114
+ new Parameter("servicePassword", Math.random().toString(36).substring(7)),
115
+ new Parameter("serviceUrl", "http://localhost:3000", (value, helper) => {
116
+ // Replace port number to empty string
117
+ const url = prepareUrlEmpty(`${value}`.replace(/:[0-9]+$/, ""), helper);
118
+ const port = helper("appPort");
119
+ return (!port || port === 80 || port === 443) ? url : `${url}:${port}`;
120
+ }),
121
+ new Parameter("templatesDir", join(dirName, "templates")),
122
+ new Parameter("galleryDir", join(dirName, "gallery")),
123
+ new Parameter("cacheDir", join(dirName, "cache")),
124
+ new Parameter("defaultLanguage", "en"),
125
+ new Parameter("smtpHost", "smtp.sendgrid.net"),
126
+ new Parameter("smtpPort", 587),
127
+ new Parameter("smtpUser", "apikey"),
128
+ new Parameter("smtpPassword", ""),
129
+ new Parameter("mailSenderAddress", "info@stemy.hu"),
130
+ new Parameter("translationsTemplate", "https://translation.service/[lang]"),
131
+ new Parameter("jwtSecret", "eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9"),
132
+ new Parameter("mongoUri", ""),
133
+ new Parameter("mongoDb", "node-backend"),
134
+ new Parameter("mongoUser", null),
135
+ new Parameter("mongoPassword", null),
136
+ new Parameter("nodeEnv", "production"),
137
+ new Parameter("appPort", 80),
138
+ new Parameter("zmqPort", 3000),
139
+ new Parameter("zmqBackPort", 3100),
140
+ new Parameter("zmqRemoteHost", "tcp://127.0.0.1"),
141
+ new Parameter("isWorker", false),
142
+ new Parameter("mainEndpoint", ""),
143
+ new Parameter("idChars", "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"),
144
+ new Parameter("idSeparator", "-"),
145
+ new Parameter("idPrefix", "ID-"),
146
+ new Parameter("idParts", [4, 4]),
147
+ new Parameter("jsonLimit", "250mb"),
148
+ new Parameter("jobTimeout", 5 * 60 * 1000),
149
+ new Parameter("cacheCollection", "cache"),
150
+ new Parameter("logTags", []),
151
+ new Parameter("ignoredLogTags", []),
152
+ ];
153
+ // Convert parameters to providers
154
+ const paramProviders = params.map(p => {
155
+ return {
156
+ provide: PARAMETER,
157
+ useValue: p
158
+ };
159
+ });
160
+ // List of services
161
+ const services = [
162
+ AssetProcessor,
163
+ AssetResolver,
164
+ Assets,
165
+ BackendProvider,
166
+ Cache,
167
+ CacheProcessor,
168
+ Configuration,
169
+ EndpointProvider,
170
+ Fixtures,
171
+ Gallery,
172
+ GalleryCache,
173
+ IdGenerator,
174
+ JobManager,
175
+ LazyAssets,
176
+ Logger,
177
+ MailSender,
178
+ MemoryCache,
179
+ MongoConnector,
180
+ OpenApi,
181
+ Progresses,
182
+ TemplateRenderer,
183
+ TerminalManager,
184
+ TokenGenerator,
185
+ TranslationProvider,
186
+ Translator,
187
+ UserManager
188
+ ];
189
+ // Create container
190
+ const diContainer = new DiContainer(container.createChildContainer());
191
+ paramProviders.forEach(provider => {
192
+ diContainer.register(provider.provide, provider);
193
+ });
194
+ services.forEach(service => {
195
+ if (!container.isRegistered(service))
196
+ diContainer.register(service, service);
197
+ });
198
+ return diContainer;
199
+ }
200
+ export async function setupBackend(config, providers, parent) {
201
+ providers = Array.isArray(providers) ? providers : [];
202
+ parent = parent || createServices();
203
+ // Create fixtures
204
+ const fixtureTypes = (config.fixtures || []);
205
+ const fixtureProviders = fixtureTypes.map(fixture => {
206
+ return {
207
+ provide: FIXTURE,
208
+ useClass: fixture
209
+ };
210
+ });
211
+ // Create params
212
+ const paramProviders = (config.params || []).map(p => {
213
+ return {
214
+ provide: PARAMETER,
215
+ useValue: p
216
+ };
217
+ });
218
+ // Create jobs
219
+ const jobProviders = [EmptyJob].concat(config.jobs || []).map(jobType => {
220
+ return {
221
+ provide: JOB,
222
+ useValue: jobType
223
+ };
224
+ });
225
+ // Create commands
226
+ const commandProviders = commands.concat(config.commands || []).map(commandType => {
227
+ return {
228
+ provide: TERMINAL_COMMAND,
229
+ useClass: commandType
230
+ };
231
+ });
232
+ // Create DI container
233
+ const diContainer = parent.createChildContainer();
234
+ // Setup rest API
235
+ const restOptions = {
236
+ routePrefix: config.routePrefix || "/api",
237
+ defaultErrorHandler: false,
238
+ ...(config.restOptions || {})
239
+ };
240
+ restOptions.cors = Object.assign({
241
+ credentials: true,
242
+ exposedHeaders: ["content-disposition"],
243
+ origin: (origin, callback) => {
244
+ callback(null, true);
245
+ }
246
+ }, restOptions.cors || {});
247
+ restOptions.routePrefix = restOptions.routePrefix == "/" ? "" : restOptions.routePrefix;
248
+ restOptions.middlewares = [ErrorHandlerMiddleware, ContainerMiddleware, LanguageMiddleware, RequestStartedMiddleware, RequestEndedMiddleware]
249
+ .concat(restOptions.middlewares || []);
250
+ restOptions.controllers = [AssetsController, AuthController, GalleryController, ProgressesController, TerminalRestController]
251
+ .concat(restOptions.controllers || []);
252
+ // Setup socket API
253
+ const socketOptions = {
254
+ container: {
255
+ get(someClass) {
256
+ return diContainer.get(someClass);
257
+ }
258
+ },
259
+ ...(config.socketOptions || {})
260
+ };
261
+ socketOptions.middlewares = [CompressionMiddleware].concat(socketOptions.middlewares || []);
262
+ socketOptions.controllers = [ProgressController, TerminalController].concat(socketOptions.controllers || []);
263
+ // Create providers
264
+ const allProviders = [];
265
+ // Add multi tokens to sub container
266
+ [PARAMETER].forEach(provide => {
267
+ const values = parent.resolveAll(provide);
268
+ values.forEach(useValue => {
269
+ allProviders.push({ provide, useValue });
270
+ });
271
+ });
272
+ // Add other providers
273
+ allProviders.push(...fixtureTypes, ...fixtureProviders, ...paramProviders, ...jobProviders, ...commandProviders, ...restOptions.middlewares, ...restOptions.controllers, ...socketOptions.middlewares, ...socketOptions.controllers, ...providers, {
274
+ provide: EXPRESS,
275
+ useFactory: (container) => {
276
+ return container.resolve(BackendProvider).express;
277
+ }
278
+ }, {
279
+ provide: HTTP_SERVER,
280
+ useFactory: (container) => {
281
+ return container.resolve(BackendProvider).server;
282
+ }
283
+ }, {
284
+ provide: SOCKET_SERVER,
285
+ useFactory: (container) => {
286
+ return container.resolve(BackendProvider).io;
287
+ }
288
+ });
289
+ allProviders.forEach(provider => {
290
+ if (isType(provider)) {
291
+ if (container.isRegistered(provider))
292
+ return;
293
+ diContainer.register(provider, provider);
294
+ return;
295
+ }
296
+ diContainer.register(provider.provide, provider);
297
+ });
298
+ diContainer.register(DI_CONTAINER, {
299
+ useValue: diContainer
300
+ });
301
+ diContainer.register(OPENAPI_VALIDATION, {
302
+ useValue: config.customValidation || (() => null)
303
+ });
304
+ diContainers.appContainer = diContainers.appContainer || diContainer;
305
+ // Authentication
306
+ restOptions.authorizationChecker = async (action, roles) => {
307
+ const user = await resolveUser(action.request);
308
+ if (!user) {
309
+ throw new HttpError(401, "Authentication failed. (User can't be found.)");
310
+ }
311
+ const userRoles = Array.isArray(user.roles) ? user.roles : [];
312
+ if (Array.isArray(roles) && roles.length > 0) {
313
+ let lastError = null;
314
+ for (let role of roles) {
315
+ if (isFunction(role)) {
316
+ try {
317
+ if (await valueToPromise(role(user, action))) {
318
+ return true;
319
+ }
320
+ }
321
+ catch (e) {
322
+ lastError = e;
323
+ }
324
+ }
325
+ if (userRoles.indexOf(role) >= 0)
326
+ return true;
327
+ }
328
+ const error = !lastError || (!lastError.message && !isString(lastError))
329
+ ? "User doesn't have access to this resource"
330
+ : lastError.message || lastError;
331
+ throw new HttpError(401, `Authentication failed. (${error})`);
332
+ }
333
+ return true;
334
+ };
335
+ restOptions.currentUserChecker = async (action) => {
336
+ try {
337
+ return await resolveUser(action.request);
338
+ }
339
+ catch (e) {
340
+ return null;
341
+ }
342
+ };
343
+ // Final setup
344
+ const configuration = diContainer.resolve(Configuration);
345
+ const bp = diContainer.resolve(BackendProvider);
346
+ if (config.restOptions) {
347
+ bp.express.use(bodyParser.json({
348
+ limit: configuration.hasParam("jsonLimit")
349
+ ? configuration.resolve("jsonLimit")
350
+ : "250mb"
351
+ }));
352
+ useRoutingContainer(diContainer);
353
+ useExpressServer(bp.express, restOptions);
354
+ // Setup rest ai docs
355
+ let openApi = null;
356
+ bp.express.get("/api-docs", (req, res) => {
357
+ openApi = openApi || diContainer.get(OpenApi);
358
+ res.header("Content-Type", "application/json")
359
+ .status(200)
360
+ .end(openApi.apiDocsStr);
361
+ });
362
+ }
363
+ diContainer.register(SOCKET_CONTROLLERS, {
364
+ useValue: new SocketControllers({
365
+ io: bp.io,
366
+ ...socketOptions,
367
+ })
368
+ });
369
+ // Connect to mongo if necessary
370
+ if (configuration.hasParam("mongoUri") && configuration.resolve("mongoUri")) {
371
+ console.log("Connecting to MongoDB...");
372
+ const connector = diContainer.resolve(MongoConnector);
373
+ await connector.connect();
374
+ console.log("Successfully connected to MongoDB.");
375
+ }
376
+ await setupStatic(config.rootFolder, diContainer);
377
+ return diContainer;
378
+ }
379
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9wdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxJQUFJLEVBQUMsTUFBTSxNQUFNLENBQUM7QUFDMUIsT0FBTyxVQUFVLE1BQU0sYUFBYSxDQUFDO0FBQ3JDLE9BQU8sUUFBUSxNQUFNLGNBQWMsQ0FBQztBQUNwQyxPQUFPLEVBQUMsU0FBUyxFQUFzQixNQUFNLFVBQVUsQ0FBQztBQUN4RCxPQUFPLEVBRUgsU0FBUyxFQUVULFlBQVksSUFBSSxtQkFBbUIsRUFDbkMsZ0JBQWdCLEVBQ25CLE1BQU0scUJBQXFCLENBQUM7QUFDN0IsT0FBTyxFQUEyQixpQkFBaUIsRUFBQyxNQUFNLG9CQUFvQixDQUFDO0FBRS9FLE9BQU8sRUFDSCxZQUFZLEVBQ1osT0FBTyxFQUNQLE9BQU8sRUFDUCxXQUFXLEVBUVgsR0FBRyxFQUNILGtCQUFrQixFQUNsQixTQUFTLEVBQ1QsU0FBUyxFQUVULGFBQWEsRUFDYixrQkFBa0IsRUFDbEIsZ0JBQWdCLEVBRW5CLE1BQU0sZ0JBQWdCLENBQUM7QUFFeEIsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLDRCQUE0QixDQUFDO0FBQzFELE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSwyQkFBMkIsQ0FBQztBQUN4RCxPQUFPLEVBQUMsTUFBTSxFQUFDLE1BQU0sbUJBQW1CLENBQUM7QUFDekMsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLDZCQUE2QixDQUFDO0FBQzVELE9BQU8sRUFBQyxLQUFLLEVBQUMsTUFBTSxrQkFBa0IsQ0FBQztBQUN2QyxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0sNEJBQTRCLENBQUM7QUFDMUQsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBQ3ZELE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLDhCQUE4QixDQUFDO0FBQzlELE9BQU8sRUFBQyxRQUFR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Q0FBQztpQkFDekMsTUFBTSxDQUFDLEdBQUcsQ0FBQztpQkFDWCxHQUFHLENBQUMsT0FBTyxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQ2pDLENBQUMsQ0FBQyxDQUFDO0tBQ047SUFFRCxXQUFXLENBQUMsUUFBUSxDQUFDLGtCQUFrQixFQUFFO1FBQ3JDLFFBQVEsRUFBRSxJQUFJLGlCQUFpQixDQUFDO1lBQzVCLEVBQUUsRUFBRSxFQUFFLENBQUMsRUFBRTtZQUNULEdBQUcsYUFBYTtTQUNuQixDQUFDO0tBQ0wsQ0FBQyxDQUFDO0lBRUgsZ0NBQWdDO0lBQ2hDLElBQUksYUFBYSxDQUFDLFFBQVEsQ0FBQyxVQUFVLENBQUMsSUFBSSxhQUFhLENBQUMsT0FBTyxDQUFDLFVBQVUsQ0FBQyxFQUFFO1FBQ3pFLE9BQU8sQ0FBQyxHQUFHLENBQUMsMEJBQTBCLENBQUMsQ0FBQztRQUN4QyxNQUFNLFNBQVMsR0FBRyxXQUFXLENBQUMsT0FBTyxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBQ3RELE1BQU0sU0FBUyxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQzFCLE9BQU8sQ0FBQyxHQUFHLENBQUMsb0NBQW9DLENBQUMsQ0FBQztLQUNyRDtJQUVELE1BQU0sV0FBVyxDQUFDLE1BQU0sQ0FBQyxVQUFVLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFFbEQsT0FBTyxXQUFXLENBQUM7QUFDdkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7am9pbn0gZnJvbSBcInBhdGhcIjtcclxuaW1wb3J0IGJvZHlQYXJzZXIgZnJvbSBcImJvZHktcGFyc2VyXCI7XHJcbmltcG9ydCB3ZWJUb2tlbiBmcm9tIFwianNvbndlYnRva2VuXCI7XHJcbmltcG9ydCB7Y29udGFpbmVyLCBEZXBlbmRlbmN5Q29udGFpbmVyfSBmcm9tIFwidHN5cmluZ2VcIjtcclxuaW1wb3J0IHtcclxuICAgIEFjdGlvbixcclxuICAgIEh0dHBFcnJvcixcclxuICAgIFJvdXRpbmdDb250cm9sbGVyc09wdGlvbnMsXHJcbiAgICB1c2VDb250YWluZXIgYXMgdXNlUm91dGluZ0NvbnRhaW5lcixcclxuICAgIHVzZUV4cHJlc3NTZXJ2ZXJcclxufSBmcm9tIFwicm91dGluZy1jb250cm9sbGVyc1wiO1xyXG5pbXBvcnQge1NvY2tldENvbnRyb2xsZXJzT3B0aW9ucywgU29ja2V0Q29udHJvbGxlcnN9IGZyb20gXCJzb2NrZXQtY29udHJvbGxlcnNcIjtcclxuXHJcbmltcG9ydCB7XHJcbiAgICBESV9DT05UQUlORVIsXHJcbiAgICBFWFBSRVNTLFxyXG4gICAgRklYVFVSRSxcclxuICAgIEhUVFBfU0VSVkVSLFxyXG4gICAgSUJhY2tlbmRDb25maWcsXHJcbiAgICBJRGVwZW5kZW5jeUNvbnRhaW5lcixcclxuICAgIElKb2IsXHJcbiAgICBJUGFnaW5hdGlvblBhcmFtcyxcclxuICAgIElSZXF1ZXN0LFxyXG4gICAgSVRlcm1pbmFsQ29tbWFuZCxcclxuICAgIElVc2VyLFxyXG4gICAgSk9CLFxyXG4gICAgT1BFTkFQSV9WQUxJREFUSU9OLFxyXG4gICAgUGFyYW1ldGVyLFxyXG4gICAgUEFSQU1FVEVSLFxyXG4gICAgUHJvdmlkZXIsXHJcbiAgICBTT0NLRVRfU0VSVkVSLFxyXG4gICAgU09DS0VUX0NPTlRST0xMRVJTLFxyXG4gICAgVEVSTUlOQUxfQ09NTUFORCxcclxuICAgIFR5cGVcclxufSBmcm9tIFwiLi9jb21tb24tdHlwZXNcIjtcclxuXHJcbmltcG9ydCB7QXNzZXRQcm9jZXNzb3J9IGZyb20gXCIuL3NlcnZpY2VzL2Fzc2V0LXByb2Nlc3NvclwiO1xyXG5pbXBvcnQge0Fzc2V0UmVzb2x2ZXJ9IGZyb20gXCIuL3NlcnZpY2VzL2Fzc2V0LXJlc29sdmVyXCI7XHJcbmltcG9ydCB7QXNzZXRzfSBmcm9tIFwiLi9zZXJ2aWNlcy9hc3NldHNcIjtcclxuaW1wb3J0IHtCYWNrZW5kUHJvdmlkZXJ9IGZyb20gXCIuL3NlcnZpY2VzL2JhY2tlbmQtcHJvdmlkZXJcIjtcclxuaW1wb3J0IHtDYWNoZX0gZnJvbSBcIi4vc2VydmljZXMvY2FjaGVcIjtcclxuaW1wb3J0IHtDYWNoZVByb2Nlc3Nvcn0gZnJvbSBcIi4vc2VydmljZXMvY2FjaGUtcHJvY2Vzc29yXCI7XHJcbmltcG9ydCB7Q29uZmlndXJhdGlvbn0gZnJvbSBcIi4vc2VydmljZXMvY29uZmlndXJhdGlvblwiO1xyXG5pbXBvcnQge0VuZHBvaW50UHJvdmlkZXJ9IGZyb20gXCIuL3NlcnZpY2VzL2VuZHBvaW50LXByb3ZpZGVyXCI7XHJcbmltcG9ydCB7Rml4dHVyZXN9IGZyb20gXCIuL3NlcnZpY2VzL2ZpeHR1cmVzXCI7XHJcbmltcG9ydCB7R2FsbGVyeX0gZnJvbSBcIi4vc2VydmljZXMvZ2FsbGVyeVwiO1xyXG5pbXBvcnQge0dhbGxlcnlDYWNoZX0gZnJvbSBcIi4vc2VydmljZXMvZ2FsbGVyeS1jYWNoZVwiO1xyXG5pbXBvcnQge0lkR2VuZXJhdG9yfSBmcm9tIFwiLi9zZXJ2aWNlcy9pZC1nZW5lcmF0b3JcIjtcclxuaW1wb3J0IHtKb2JNYW5hZ2VyfSBmcm9tIFwiLi9zZXJ2aWNlcy9qb2ItbWFuYWdlclwiO1xyXG5pbXBvcnQge0xhenlBc3NldHN9IGZyb20gXCIuL3NlcnZpY2VzL2xhenktYXNzZXRzXCI7XHJcbmltcG9ydCB7TG9nZ2VyfSBmcm9tIFwiLi9zZXJ2aWNlcy9sb2dnZXJcIjtcclxuaW1wb3J0IHtNYWlsU2VuZGVyfSBmcm9tIFwiLi9zZXJ2aWNlcy9tYWlsLXNlbmRlclwiO1xyXG5pbXBvcnQge01lbW9yeUNhY2hlfSBmcm9tIFwiLi9zZXJ2aWNlcy9tZW1vcnktY2FjaGVcIjtcclxuaW1wb3J0IHtNb25nb0Nvbm5lY3Rvcn0gZnJvbSBcIi4vc2VydmljZXMvbW9uZ28tY29ubmVjdG9yXCI7XHJcbmltcG9ydCB7T3BlbkFwaX0gZnJvbSBcIi4vc2VydmljZXMvb3Blbi1hcGlcIjtcclxuaW1wb3J0IHtQcm9ncmVzc2VzfSBmcm9tIFwiLi9zZXJ2aWNlcy9wcm9ncmVzc2VzXCI7XHJcbmltcG9ydCB7VGVtcGxhdGVSZW5kZXJlcn0gZnJvbSBcIi4vc2VydmljZXMvdGVtcGxhdGUtcmVuZGVyZXJcIjtcclxuaW1wb3J0IHtUZXJtaW5hbE1hbmFnZXJ9IGZyb20gXCIuL3NlcnZpY2VzL3Rlcm1pbmFsLW1hbmFnZXJcIjtcclxuaW1wb3J0IHtUb2tlbkdlbmVyYXRvcn0gZnJvbSBcIi4vc2VydmljZXMvdG9rZW4tZ2VuZXJhdG9yXCI7XHJcbmltcG9ydCB7VHJhbnNsYXRpb25Qcm92aWRlcn0gZnJvbSBcIi4vc2VydmljZXMvdHJhbnNsYXRpb24tcHJvdmlkZXJcIjtcclxuaW1wb3J0IHtUcmFuc2xhdG9yfSBmcm9tIFwiLi9zZXJ2aWNlcy90cmFuc2xhdG9yXCI7XHJcbmltcG9ydCB7VXNlck1hbmFnZXJ9IGZyb20gXCIuL3NlcnZpY2VzL3VzZXItbWFuYWdlclwiO1xyXG5cclxuaW1wb3J0IHtBc3NldHNDb250cm9sbGVyfSBmcm9tIFwiLi9yZXN0LWNvbnRyb2xsZXJzL2Fzc2V0cy5jb250cm9sbGVyXCI7XHJcbmltcG9ydCB7QXV0aENvbnRyb2xsZXJ9IGZyb20gXCIuL3Jlc3QtY29udHJvbGxlcnMvYXV0aC5jb250cm9sbGVyXCI7XHJcbmltcG9ydCB7R2FsbGVyeUNvbnRyb2xsZXJ9IGZyb20gXCIuL3Jlc3QtY29udHJvbGxlcnMvZ2FsbGVyeS5jb250cm9sbGVyXCI7XHJcbmltcG9ydCB7UHJvZ3Jlc3Nlc0NvbnRyb2xsZXJ9IGZyb20gXCIuL3Jlc3QtY29udHJvbGxlcnMvcHJvZ3Jlc3Nlcy5jb250cm9sbGVyXCI7XHJcbmltcG9ydCB7VGVybWluYWxDb250cm9sbGVyIGFzIFRlcm1pbmFsUmVzdENvbnRyb2xsZXJ9IGZyb20gXCIuL3Jlc3QtY29udHJvbGxlcnMvdGVybWluYWwuY29udHJvbGxlclwiO1xyXG5cclxuaW1wb3J0IHtFcnJvckhhbmRsZXJNaWRkbGV3YXJlfSBmcm9tIFwiLi9yZXN0LW1pZGRsZXdhcmVzL2Vycm9yLWhhbmRsZXIubWlkZGxld2FyZVwiO1xyXG5pbXBvcnQge0NvbnRhaW5lck1pZGRsZXdhcmV9IGZyb20gXCIuL3Jlc3QtbWlkZGxld2FyZXMvY29udGFpbmVyLm1pZGRsZXdhcmVcIjtcclxuaW1wb3J0IHtMYW5ndWFnZU1pZGRsZXdhcmV9IGZyb20gXCIuL3Jlc3QtbWlkZGxld2FyZXMvbGFuZ3VhZ2UubWlkZGxld2FyZVwiO1xyXG5pbXBvcnQge1JlcXVlc3RFbmRlZE1pZGRsZXdhcmV9IGZyb20gXCIuL3Jlc3QtbWlkZGxld2FyZXMvcmVxdWVzdC1lbmRlZC5taWRkbGV3YXJlXCI7XHJcbmltcG9ydCB7UmVxdWVzdFN0YXJ0ZWRNaWRkbGV3YXJlfSBmcm9tIFwiLi9yZXN0LW1pZGRsZXdhcmVzL3JlcXVlc3Qtc3RhcnRlZC5taWRkbGV3YXJlXCI7XHJcblxyXG5pbXBvcnQge1Byb2dyZXNzQ29udHJvbGxlcn0gZnJvbSBcIi4vc29ja2V0LWNvbnRyb2xsZXJzL3Byb2dyZXNzLmNvbnRyb2xsZXJcIjtcclxuaW1wb3J0IHtUZXJtaW5hbENvbnRyb2xsZXJ9IGZyb20gXCIuL3NvY2tldC1jb250cm9sbGVycy90ZXJtaW5hbC5jb250cm9sbGVyXCI7XHJcblxyXG5pbXBvcnQge0NvbXByZXNzaW9uTWlkZGxld2FyZX0gZnJvbSBcIi4vc29ja2V0LW1pZGRsZXdhcmVzL2NvbXByZXNzaW9uLm1pZGRsZXdhcmVcIjtcclxuXHJcbmltcG9ydCB7RGlDb250YWluZXJ9IGZyb20gXCIuL3V0aWxpdGllcy9kaS1jb250YWluZXJcIjtcclxuaW1wb3J0IHtFbXB0eUpvYn0gZnJvbSBcIi4vdXRpbGl0aWVzL2VtcHR5LWpvYlwiO1xyXG5pbXBvcnQge2RpQ29udGFpbmVycywgaXNGdW5jdGlvbiwgaXNTdHJpbmcsIGlzVHlwZSwgcHJlcGFyZVVybEVtcHR5LCB2YWx1ZVRvUHJvbWlzZSwgZ2V0RGlyTmFtZX0gZnJvbSBcIi4vdXRpbHNcIjtcclxuaW1wb3J0IHtzZXR1cFN0YXRpY30gZnJvbSBcIi4vc3RhdGljXCI7XHJcbmltcG9ydCB7Y29tbWFuZHN9IGZyb20gXCIuL2NvbW1hbmRzXCI7XHJcblxyXG5leHBvcnQge1xyXG4gICAgRmlsdGVyUHJlZGljYXRlLFxyXG4gICAgaXNOdWxsT3JVbmRlZmluZWQsXHJcbiAgICBpc0RlZmluZWQsXHJcbiAgICBnZXRUeXBlLFxyXG4gICAgaXNPYmplY3QsXHJcbiAgICBpc0FycmF5LFxyXG4gICAgaXNCdWZmZXIsXHJcbiAgICBpc0Jvb2xlYW4sXHJcbiAgICBpc0RhdGUsXHJcbiAgICBpc1ByaW1pdGl2ZSxcclxuICAgIGlzU3RyaW5nLFxyXG4gICAgaXNGdW5jdGlvbixcclxuICAgIGlzQ29uc3RydWN0b3IsXHJcbiAgICBpc1R5cGUsXHJcbiAgICBpc0ludGVyZmFjZSxcclxuICAgIHVjRmlyc3QsXHJcbiAgICBsY0ZpcnN0LFxyXG4gICAgaXNPYmplY3RJZCxcclxuICAgIGZpcnN0SXRlbSxcclxuICAgIGxhc3RJdGVtLFxyXG4gICAgcmVncm91cCxcclxuICAgIHVuaXF1ZUl0ZW1zLFxyXG4gICAgZ2V0VmFsdWUsXHJcbiAgICBncm91cEJ5LFxyXG4gICAgY29udmVydFZhbHVlLFxyXG4gICAgdG9JbWFnZSxcclxuICAgIGJ1ZmZlclRvU3RyZWFtLFxyXG4gICAgc3RyZWFtVG9CdWZmZXIsXHJcbiAgICBjb3B5U3RyZWFtLFxyXG4gICAgbWtkaXJSZWN1cnNpdmUsXHJcbiAgICBkZWxldGVGaWxlLFxyXG4gICAgcmVhZEZpbGUsXHJcbiAgICByZWFkQW5kRGVsZXRlRmlsZSxcclxuICAgIHdyaXRlRmlsZSxcclxuICAgIHZhbHVlVG9Qcm9taXNlLFxyXG4gICAgcHJvbWlzZVRpbWVvdXQsXHJcbiAgICBnZXRDb25zdHJ1Y3Rvck5hbWUsXHJcbiAgICBnZXRGdW5jdGlvblBhcmFtcyxcclxuICAgIGdldEZpbGVOYW1lLFxyXG4gICAgZ2V0RXh0ZW5zaW9uLFxyXG4gICAgY3JlYXRlSWRTdHJpbmcsXHJcbiAgICBpZFRvU3RyaW5nLFxyXG4gICAgY3JlYXRlVHJhbnNmb3JtZXIsXHJcbiAgICBicm9hZGNhc3QsXHJcbiAgICByYW5kLFxyXG4gICAgcmFuZG9tLFxyXG4gICAgbXVsdGlTdWJzY3JpcHRpb24sXHJcbiAgICBvYnNlcnZhYmxlRnJvbUZ1bmN0aW9uLFxyXG4gICAgcGFkTGVmdCxcclxuICAgIHBhZFJpZ2h0LFxyXG4gICAgY2FtZWxDYXNlVG9EYXNoLFxyXG4gICAgZGVsZXRlRnJvbUJ1Y2tldCxcclxuICAgIGZpbHRlcixcclxuICAgIGNvcHksXHJcbiAgICBhc3NpZ24sXHJcbiAgICBtZDUsXHJcbiAgICBydW5Db21tYW5kLFxyXG4gICAgQ29uc29sZUNvbG9yLFxyXG4gICAgSUpzb25Db2xvcnMsXHJcbiAgICBjb2xvcml6ZSxcclxuICAgIGpzb25IaWdobGlnaHQsXHJcbiAgICByZXBsYWNlU3BlY2lhbENoYXJzLFxyXG4gICAgcmVnZXhFc2NhcGUsXHJcbiAgICBmbGF0dGVuLFxyXG4gICAgd3JhcEVycm9yLFxyXG4gICAgZ2V0RGlyTmFtZSxcclxuICAgIHByZXBhcmVVcmwsXHJcbiAgICBwcmVwYXJlVXJsU2xhc2gsXHJcbiAgICBwcmVwYXJlVXJsRW1wdHksXHJcbiAgICBmaWxlVHlwZUZyb21CdWZmZXJcclxufSBmcm9tIFwiLi91dGlsc1wiO1xyXG5cclxuZXhwb3J0IHtJc0ZpbGUsIElzT2JqZWN0SWR9IGZyb20gXCIuL3ZhbGlkYXRvcnNcIjtcclxuXHJcbmV4cG9ydCB7XHJcbiAgICBGSVhUVVJFLFxyXG4gICAgSk9CLFxyXG4gICAgVEVSTUlOQUxfQ09NTUFORCxcclxuICAgIEVYUFJFU1MsXHJcbiAgICBIVFRQX1NFUlZFUixcclxuICAgIFNPQ0tFVF9TRVJWRVIsXHJcbiAgICBTT0NLRVRfQ09OVFJPTExFUlMsXHJcbiAgICBQQVJBTUVURVIsXHJcbiAgICBESV9DT05UQUlORVIsXHJcbiAgICBPUEVOQVBJX1ZBTElEQVRJT04sXHJcbiAgICBUeXBlLFxyXG4gICAgRmFjdG9yeVByb3ZpZGVyLFxyXG4gICAgSURlcGVuZGVuY3lDb250YWluZXIsXHJcbiAgICBDbGFzc0Jhc2VkUHJvdmlkZXIsXHJcbiAgICBWYWx1ZUJhc2VkUHJvdmlkZXIsXHJcbiAgICBGYWN0b3J5QmFzZWRQcm92aWRlcixcclxuICAgIFRva2VuQmFzZWRQcm92aWRlcixcclxuICAgIFN5cmluZ2VQcm92aWRlcixcclxuICAgIFByb3ZpZGVyLFxyXG4gICAgQ29uc3RydWN0b3IsXHJcbiAgICBJbmZlckdlbmVyaWMsXHJcbiAgICBQaWNrTWF0Y2hpbmcsXHJcbiAgICBPbWl0Rmlyc3RBcmcsXHJcbiAgICBJTWF0Y2hGaWVsZCxcclxuICAgIElQcm9qZWN0T3B0aW9ucyxcclxuICAgIElVbndpbmRPcHRpb25zLFxyXG4gICAgSUZpeHR1cmUsXHJcbiAgICBJRml4dHVyZU91dHB1dCxcclxuICAgIFNjaGVtYUNvbnZlcnRlcixcclxuICAgIE9wZW5BcGlWYWxpZGF0aW9uLFxyXG4gICAgUGFyYW1SZXNvbHZlcixcclxuICAgIFBhcmFtZXRlcixcclxuICAgIFNvY2tldFBhcmFtLFxyXG4gICAgU29ja2V0UGFyYW1zLFxyXG4gICAgSVNvY2tldE1lc3NhZ2UsXHJcbiAgICBJTWVzc2FnZUJyaWRnZSxcclxuICAgIElKb2IsXHJcbiAgICBJSm9iVGFzayxcclxuICAgIEpvYlBhcmFtcyxcclxuICAgIEpvYlNjaGVkdWxlUmFuZ2UsXHJcbiAgICBKb2JTY2hlZHVsZVRpbWUsXHJcbiAgICBJVGVybWluYWxGaWxlLFxyXG4gICAgSVRlcm1pbmFsLFxyXG4gICAgSVRlcm1pbmFsQ29tbWFuZCxcclxuICAgIElQcm9ncmVzcyxcclxuICAgIElBc3NldENyb3BJbmZvLFxyXG4gICAgSUFzc2V0TWV0YSxcclxuICAgIElBc3NldEltYWdlUGFyYW1zLFxyXG4gICAgSUFzc2V0LFxyXG4gICAgSUxhenlBc3NldCxcclxuICAgIElVc2VyLFxyXG4gICAgSUNsaWVudFNvY2tldCxcclxuICAgIElSZXF1ZXN0QmFzZSxcclxuICAgIElSZXF1ZXN0LFxyXG4gICAgSUdhbGxlcnlJbWFnZSxcclxuICAgIElHYWxsZXJ5U2l6ZSxcclxuICAgIElHYWxsZXJ5SW1hZ2VIYW5kbGVyLFxyXG4gICAgSVRyYW5zbGF0aW9ucyxcclxuICAgIElQYWdpbmF0aW9uTWV0YSxcclxuICAgIElQYWdpbmF0aW9uQmFzZSxcclxuICAgIElQYWdpbmF0aW9uLFxyXG4gICAgSVBhZ2luYXRpb25QYXJhbXMsXHJcbiAgICBGb250Rm9ybWF0LFxyXG4gICAgSUZpbGVUeXBlLFxyXG4gICAgSUJhY2tlbmRDb25maWdcclxufSBmcm9tIFwiLi9jb21tb24tdHlwZXNcIjtcclxuXHJcbmV4cG9ydCB7QXNzZXRQcm9jZXNzb3J9IGZyb20gXCIuL3NlcnZpY2VzL2Fzc2V0LXByb2Nlc3NvclwiO1xyXG5leHBvcnQge0Fzc2V0UmVzb2x2ZXJ9IGZyb20gXCIuL3NlcnZpY2VzL2Fzc2V0LXJlc29sdmVyXCI7XHJcbmV4cG9ydCB7QXNzZXRzfSBmcm9tIFwiLi9zZXJ2aWNlcy9hc3NldHNcIjtcclxuZXhwb3J0IHtCYWNrZW5kUHJvdmlkZXJ9IGZyb20gXCIuL3NlcnZpY2VzL2JhY2tlbmQtcHJvdmlkZXJcIjtcclxuZXhwb3J0IHtDYWNoZX0gZnJvbSBcIi4vc2VydmljZXMvY2FjaGVcIjtcclxuZXhwb3J0IHtDYWNoZVByb2Nlc3Nvcn0gZnJvbSBcIi4vc2VydmljZXMvY2FjaGUtcHJvY2Vzc29yXCI7XHJcbmV4cG9ydCB7Q29uZmlndXJhdGlvbn0gZnJvbSBcIi4vc2VydmljZXMvY29uZmlndXJhdGlvblwiO1xyXG5leHBvcnQge0VuZHBvaW50UHJvdmlkZXJ9IGZyb20gXCIuL3NlcnZpY2VzL2VuZHBvaW50LXByb3ZpZGVyXCI7XHJcbmV4cG9ydCB7Rml4dHVyZXN9IGZyb20gXCIuL3NlcnZpY2VzL2ZpeHR1cmVzXCI7XHJcbmV4cG9ydCB7R2FsbGVyeX0gZnJvbSBcIi4vc2VydmljZXMvZ2FsbGVyeVwiO1xyXG5leHBvcnQge0dhbGxlcnlDYWNoZX0gZnJvbSBcIi4vc2VydmljZXMvZ2FsbGVyeS1jYWNoZVwiO1xyXG5leHBvcnQge0lkR2VuZXJhdG9yfSBmcm9tIFwiLi9zZXJ2aWNlcy9pZC1nZW5lcmF0b3JcIjtcclxuZXhwb3J0IHtKb2JNYW5hZ2VyfSBmcm9tIFwiLi9zZXJ2aWNlcy9qb2ItbWFuYWdlclwiO1xyXG5leHBvcnQge0xhenlBc3NldHN9IGZyb20gXCIuL3NlcnZpY2VzL2xhenktYXNzZXRzXCI7XHJcbmV4cG9ydCB7TG9nZ2VyfSBmcm9tIFwiLi9zZXJ2aWNlcy9sb2dnZXJcIjtcclxuZXhwb3J0IHtNYWlsU2VuZGVyfSBmcm9tIFwiLi9zZXJ2aWNlcy9tYWlsLXNlbmRlclwiO1xyXG5leHBvcnQge01lbW9yeUNhY2hlfSBmcm9tIFwiLi9zZXJ2aWNlcy9tZW1vcnktY2FjaGVcIjtcclxuZXhwb3J0IHtNb25nb0Nvbm5lY3Rvcn0gZnJvbSBcIi4vc2VydmljZXMvbW9uZ28tY29ubmVjdG9yXCI7XHJcbmV4cG9ydCB7T3BlbkFwaX0gZnJvbSBcIi4vc2VydmljZXMvb3Blbi1hcGlcIjtcclxuZXhwb3J0IHtQcm9ncmVzc2VzfSBmcm9tIFwiLi9zZXJ2aWNlcy9wcm9ncmVzc2VzXCI7XHJcbmV4cG9ydCB7VGVtcGxhdGVSZW5kZXJlcn0gZnJvbSBcIi4vc2VydmljZXMvdGVtcGxhdGUtcmVuZGVyZXJcIjtcclxuZXhwb3J0IHtUZXJtaW5hbE1hbmFnZXJ9IGZyb20gXCIuL3NlcnZpY2VzL3Rlcm1pbmFsLW1hbmFnZXJcIjtcclxuZXhwb3J0IHtUb2tlbkdlbmVyYXRvcn0gZnJvbSBcIi4vc2VydmljZXMvdG9rZW4tZ2VuZXJhdG9yXCI7XHJcbmV4cG9ydCB7VHJhbnNsYXRpb25Qcm92aWRlcn0gZnJvbSBcIi4vc2VydmljZXMvdHJhbnNsYXRpb24tcHJvdmlkZXJcIjtcclxuZXhwb3J0IHtUcmFuc2xhdG9yfSBmcm9tIFwiLi9zZXJ2aWNlcy90cmFuc2xhdG9yXCI7XHJcbmV4cG9ydCB7VXNlck1hbmFnZXJ9IGZyb20gXCIuL3NlcnZpY2VzL3VzZXItbWFuYWdlclwiO1xyXG5cclxuZXhwb3J0IHtBc3NldEltYWdlUGFyYW1zfSBmcm9tIFwiLi9yZXF1ZXN0cy9hc3NldC1pbWFnZS1wYXJhbXNcIjtcclxuXHJcbmV4cG9ydCB7QXV0aENvbnRyb2xsZXJ9IGZyb20gXCIuL3Jlc3QtY29udHJvbGxlcnMvYXV0aC5jb250cm9sbGVyXCI7XHJcbmV4cG9ydCB7R2FsbGVyeUNvbnRyb2xsZXJ9IGZyb20gXCIuL3Jlc3QtY29udHJvbGxlcnMvZ2FsbGVyeS5jb250cm9sbGVyXCI7XHJcblxyXG5leHBvcnQge0Vycm9ySGFuZGxlck1pZGRsZXdhcmV9IGZyb20gXCIuL3Jlc3QtbWlkZGxld2FyZXMvZXJyb3ItaGFuZGxlci5taWRkbGV3YXJlXCI7XHJcbmV4cG9ydCB7TGFuZ3VhZ2VNaWRkbGV3YXJlfSBmcm9tIFwiLi9yZXN0LW1pZGRsZXdhcmVzL2xhbmd1YWdlLm1pZGRsZXdhcmVcIjtcclxuXHJcbmV4cG9ydCB7QmFzZURvYywgRG9jdW1lbnRBcnJheSwgUHJpbWl0aXZlQXJyYXl9IGZyb20gXCIuL3V0aWxpdGllcy9iYXNlLWRvY1wiO1xyXG5leHBvcnQge0lzRG9jdW1lbnRlZCwgSnNvblJlc3BvbnNlLCBSZXNwb25zZVR5cGV9IGZyb20gXCIuL3V0aWxpdGllcy9kZWNvcmF0b3JzXCI7XHJcbmV4cG9ydCB7TGF6eUFzc2V0R2VuZXJhdG9yfSBmcm9tIFwiLi91dGlsaXRpZXMvbGF6eS1hc3NldC1nZW5lcmF0b3JcIjtcclxuZXhwb3J0IHtcclxuICAgIFJlc29sdmVFbnRpdHksXHJcbiAgICBwYWdpbmF0ZUFnZ3JlZ2F0aW9ucyxcclxuICAgIGh5ZHJhdGVQb3B1bGF0ZWQsXHJcbiAgICB1bndpbmRTdGFnZSxcclxuICAgIHByb2plY3RTdGFnZSxcclxuICAgIG1hdGNoRmllbGRTdGFnZXMsXHJcbiAgICBtYXRjaEZpZWxkLFxyXG4gICAgbWF0Y2hTdGFnZSxcclxuICAgIGxldHNMb29rdXBTdGFnZSxcclxuICAgIGxvb2t1cFN0YWdlcyxcclxuICAgIHBhZ2luYXRlLFxyXG4gICAgaW5qZWN0U2VydmljZXMsXHJcbiAgICBzZXJ2aWNlXHJcbn0gZnJvbSBcIi4vdXRpbGl0aWVzL21vbmdvb3NlXCI7XHJcblxyXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gcmVzb2x2ZVVzZXIocmVxOiBJUmVxdWVzdCk6IFByb21pc2U8SVVzZXI+IHtcclxuICAgIGlmIChyZXEudXNlcikgcmV0dXJuIHJlcS51c2VyO1xyXG4gICAgY29uc3QgY29udGFpbmVyID0gcmVxLmNvbnRhaW5lcjtcclxuICAgIGNvbnN0IGF1dGggPSByZXEuaGVhZGVyKFwiQXV0aG9yaXphdGlvblwiKSB8fCBcIlwiO1xyXG4gICAgbGV0IHBheWxvYWQgPSBudWxsO1xyXG4gICAgdHJ5IHtcclxuICAgICAgICBjb25zdCBjb25maWcgPSBjb250YWluZXIucmVzb2x2ZShDb25maWd1cmF0aW9uKTtcclxuICAgICAgICBwYXlsb2FkID0gd2ViVG9rZW4udmVyaWZ5KGF1dGguc3BsaXQoXCIgXCIpWzFdLCBjb25maWcucmVzb2x2ZShcImp3dFNlY3JldFwiKSkgYXMgYW55O1xyXG4gICAgfSBjYXRjaCAoZSkge1xyXG4gICAgICAgIHRocm93IG5ldyBIdHRwRXJyb3IoNDAxLCBgQXV0aGVudGljYXRpb24gZmFpbGVkLiAoJHtlLm1lc3NhZ2V9KWApO1xyXG4gICAgfVxyXG4gICAgaWYgKCFwYXlsb2FkKSB7XHJcbiAgICAgICAgdGhyb3cgbmV3IEh0dHBFcnJvcig0MDEsIGBBdXRoZW50aWNhdGlvbiBmYWlsZWQuIChNYXliZSBpbnZhbGlkIHRva2VuKWApO1xyXG4gICAgfVxyXG4gICAgcmVxLnVzZXIgPSBhd2FpdCBjb250YWluZXIucmVzb2x2ZShVc2VyTWFuYWdlcikuZ2V0QnlJZChwYXlsb2FkLmlkKTtcclxuICAgIHJldHVybiByZXEudXNlcjtcclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVNlcnZpY2VzKCk6IElEZXBlbmRlbmN5Q29udGFpbmVyIHtcclxuICAgIC8vIExpc3Qgb2YgcGFyYW1ldGVyc1xyXG4gICAgY29uc3QgZGlyTmFtZSA9IGdldERpck5hbWUoKTtcclxuICAgIGNvbnN0IHBhcmFtcyA9IFtcclxuICAgICAgICBuZXcgUGFyYW1ldGVyKFwic2VydmljZU5hbWVcIiwgXCJCYWNrZW5kXCIpLFxyXG4gICAgICAgIG5ldyBQYXJhbWV0ZXIoXCJzZXJ2aWNlUGFzc3dvcmRcIiwgTWF0aC5yYW5kb20oKS50b1N0cmluZygzNikuc3Vic3RyaW5nKDcpKSxcclxuICAgICAgICBuZXcgUGFyYW1ldGVyKFwic2VydmljZVVybFwiLCBcImh0dHA6Ly9sb2NhbGhvc3Q6MzAwMFwiLCAodmFsdWUsIGhlbHBlcikgPT4ge1xyXG4gICAgICAgICAgICAvLyBSZXBsYWNlIHBvcnQgbnVtYmVyIHRvIGVtcHR5IHN0cmluZ1xyXG4gICAgICAgICAgICBjb25zdCB1cmwgPSBwcmVwYXJlVXJsRW1wdHkoYCR7dmFsdWV9YC5yZXBsYWNlKC86WzAtOV0rJC8sIFwiXCIpLCBoZWxwZXIpIGFzIHN0cmluZztcclxuICAgICAgICAgICAgY29uc3QgcG9ydCA9IGhlbHBlcihcImFwcFBvcnRcIik7XHJcbiAgICAgICAgICAgIHJldHVybiAoIXBvcnQgfHwgcG9ydCA9PT0gODAgfHwgcG9ydCA9PT0gNDQzKSA/IHVybCA6IGAke3VybH06JHtwb3J0fWA7XHJcbiAgICAgICAgfSksXHJcbiAgICAgICAgbmV3IFBhcmFtZXRlcihcInRlbXBsYXRlc0RpclwiLCBqb2luKGRpck5hbWUsIFwidGVtcGxhdGVzXCIpKSxcclxuICAgICAgICBuZXcgUGFyYW1ldGVyKFwiZ2FsbGVyeURpclwiLCBqb2luKGRpck5hbWUsIFwiZ2FsbGVyeVwiKSksXHJcbiAgICAgICAgbmV3IFBhcmFtZXRlcihcImNhY2hlRGlyXCIsIGpvaW4oZGlyTmFtZSwgXCJjYWNoZVwiKSksXHJcbiAgICAgICAgbmV3IFBhcmFtZXRlcihcImRlZmF1bHRMYW5ndWFnZVwiLCBcImVuXCIpLFxyXG4gICAgICAgIG5ldyBQYXJhbWV0ZXIoXCJzbXRwSG9zdFwiLCBcInNtdHAuc2VuZGdyaWQubmV0XCIpLFxyXG4gICAgICAgIG5ldyBQYXJhbWV0ZXIoXCJzbXRwUG9ydFwiLCA1ODcpLFxyXG4gICAgICAgIG5ldyBQYXJhbWV0ZXIoXCJzbXRwVXNlclwiLCBcImFwaWtleVwiKSxcclxuICAgICAgICBuZXcgUGFyYW1ldGVyKFwic210cFBhc3N3b3JkXCIsIFwiXCIpLFxyXG4gICAgICAgIG5ldyBQYXJhbWV0ZXIoXCJtYWlsU2VuZGVyQWRkcmVzc1wiLCBcImluZm9Ac3RlbXkuaHVcIiksXHJcbiAgICAgICAgbmV3IFBhcmFtZXRlcihcInRyYW5zbGF0aW9uc1RlbXBsYXRlXCIsIFwiaHR0cHM6Ly90cmFuc2xhdGlvbi5zZXJ2aWNlL1tsYW5nXVwiKSxcclxuICAgICAgICBuZXcgUGFyYW1ldGVyKFwiand0U2VjcmV0XCIsIFwiZXlKMGVYQWlPaUpLVjFRaUxDSmhiR2NpT2lKU1V6STFOaUo5XCIpLFxyXG4gICAgICAgIG5ldyBQYXJhbWV0ZXIoXCJtb25nb1VyaVwiLCBcIlwiKSxcclxuICAgICAgICBuZXcgUGFyYW1ldGVyKFwibW9uZ29EYlwiLCBcIm5vZGUtYmFja2VuZFwiKSxcclxuICAgICAgICBuZXcgUGFyYW1ldGVyKFwibW9uZ29Vc2VyXCIsIG51bGwpLFxyXG4gICAgICAgIG5ldyBQYXJhbWV0ZXIoXCJtb25nb1Bhc3N3b3JkXCIsIG51bGwpLFxyXG4gICAgICAgIG5ldyBQYXJhbWV0ZXIoXCJub2RlRW52XCIsIFwicHJvZHVjdGlvblwiKSxcclxuICAgICAgICBuZXcgUGFyYW1ldGVyKFwiYXBwUG9ydFwiLCA4MCksXHJcbiAgICAgICAgbmV3IFBhcmFtZXRlcihcInptcVBvcnRcIiwgMzAwMCksXHJcbiAgICAgICAgbmV3IFBhcmFtZXRlcihcInptcUJhY2tQb3J0XCIsIDMxMDApLFxyXG4gICAgICAgIG5ldyBQYXJhbWV0ZXIoXCJ6bXFSZW1vdGVIb3N0XCIsIFwidGNwOi8vMTI3LjAuMC4xXCIpLFxyXG4gICAgICAgIG5ldyBQYXJhbWV0ZXIoXCJpc1dvcmtlclwiLCBmYWxzZSksXHJcbiAgICAgICAgbmV3IFBhcmFtZXRlcihcIm1haW5FbmRwb2ludFwiLCBcIlwiKSxcclxuICAgICAgICBuZXcgUGFyYW1ldGVyKFwiaWRDaGFyc1wiLCBcIjAxMjM0NTY3ODlBQkNERUZHSElKS0xNTk9QUVJTVFVWV1hZWlwiKSxcclxuICAgICAgICBuZXcgUGFyYW1ldGVyKFwiaWRTZXBhcmF0b3JcIiwgXCItXCIpLFxyXG4gICAgICAgIG5ldyBQYXJhbWV0ZXIoXCJpZFByZWZpeFwiLCBcIklELVwiKSxcclxuICAgICAgICBuZXcgUGFyYW1ldGVyKFwiaWRQYXJ0c1wiLCBbNCwgNF0pLFxyXG4gICAgICAgIG5ldyBQYXJhbWV0ZXIoXCJqc29uTGltaXRcIiwgXCIyNTBtYlwiKSxcclxuICAgICAgICBuZXcgUGFyYW1ldGVyKFwiam9iVGltZW91dFwiLCA1ICogNjAgKiAxMDAwKSxcclxuICAgICAgICBuZXcgUGFyYW1ldGVyKFwiY2FjaGVDb2xsZWN0aW9uXCIsIFwiY2FjaGVcIiksXHJcbiAgICAgICAgbmV3IFBhcmFtZXRlcihcImxvZ1RhZ3NcIiwgW10pLFxyXG4gICAgICAgIG5ldyBQYXJhbWV0ZXIoXCJpZ25vcmVkTG9nVGFnc1wiLCBbXSksXHJcbiAgICBdO1xyXG5cclxuICAgIC8vIENvbnZlcnQgcGFyYW1ldGVycyB0byBwcm92aWRlcnNcclxuICAgIGNvbnN0IHBhcmFtUHJvdmlkZXJzID0gcGFyYW1zLm1hcChwID0+IHtcclxuICAgICAgICByZXR1cm4ge1xyXG4gICAgICAgICAgICBwcm92aWRlOiBQQVJBTUVURVIsXHJcbiAgICAgICAgICAgIHVzZVZhbHVlOiBwXHJcbiAgICAgICAgfVxyXG4gICAgfSk7XHJcblxyXG4gICAgLy8gTGlzdCBvZiBzZXJ2aWNlc1xyXG4gICAgY29uc3Qgc2VydmljZXMgPSBbXHJcbiAgICAgICAgQXNzZXRQcm9jZXNzb3IsXHJcbiAgICAgICAgQXNzZXRSZXNvbHZlcixcclxuICAgICAgICBBc3NldHMsXHJcbiAgICAgICAgQmFja2VuZFByb3ZpZGVyLFxyXG4gICAgICAgIENhY2hlLFxyXG4gICAgICAgIENhY2hlUHJvY2Vzc29yLFxyXG4gICAgICAgIENvbmZpZ3VyYXRpb24sXHJcbiAgICAgICAgRW5kcG9pbnRQcm92aWRlcixcclxuICAgICAgICBGaXh0dXJlcyxcclxuICAgICAgICBHYWxsZXJ5LFxyXG4gICAgICAgIEdhbGxlcnlDYWNoZSxcclxuICAgICAgICBJZEdlbmVyYXRvcixcclxuICAgICAgICBKb2JNYW5hZ2VyLFxyXG4gICAgICAgIExhenlBc3NldHMsXHJcbiAgICAgICAgTG9nZ2VyLFxyXG4gICAgICAgIE1haWxTZW5kZXIsXHJcbiAgICAgICAgTWVtb3J5Q2FjaGUsXHJcbiAgICAgICAgTW9uZ29Db25uZWN0b3IsXHJcbiAgICAgICAgT3BlbkFwaSxcclxuICAgICAgICBQcm9ncmVzc2VzLFxyXG4gICAgICAgIFRlbXBsYXRlUmVuZGVyZXIsXHJcbiAgICAgICAgVGVybWluYWxNYW5hZ2VyLFxyXG4gICAgICAgIFRva2VuR2VuZXJhdG9yLFxyXG4gICAgICAgIFRyYW5zbGF0aW9uUHJvdmlkZXIsXHJcbiAgICAgICAgVHJhbnNsYXRvcixcclxuICAgICAgICBVc2VyTWFuYWdlclxyXG4gICAgXSBhcyBUeXBlPGFueT5bXTtcclxuXHJcbiAgICAvLyBDcmVhdGUgY29udGFpbmVyXHJcbiAgICBjb25zdCBkaUNvbnRhaW5lciA9IG5ldyBEaUNvbnRhaW5lcihjb250YWluZXIuY3JlYXRlQ2hpbGRDb250YWluZXIoKSk7XHJcbiAgICBwYXJhbVByb3ZpZGVycy5mb3JFYWNoKHByb3ZpZGVyID0+IHtcclxuICAgICAgICBkaUNvbnRhaW5lci5yZWdpc3Rlcihwcm92aWRlci5wcm92aWRlLCBwcm92aWRlcik7XHJcbiAgICB9KTtcclxuICAgIHNlcnZpY2VzLmZvckVhY2goc2VydmljZSA9PiB7XHJcbiAgICAgICAgaWYgKCFjb250YWluZXIuaXNSZWdpc3RlcmVkKHNlcnZpY2UpKVxyXG4gICAgICAgICAgICBkaUNvbnRhaW5lci5yZWdpc3RlcihzZXJ2aWNlLCBzZXJ2aWNlKTtcclxuICAgIH0pO1xyXG4gICAgcmV0dXJuIGRpQ29udGFpbmVyO1xyXG59XHJcblxyXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gc2V0dXBCYWNrZW5kKGNvbmZpZzogSUJhY2tlbmRDb25maWcsIHByb3ZpZGVycz86IFByb3ZpZGVyPGFueT5bXSwgcGFyZW50PzogSURlcGVuZGVuY3lDb250YWluZXIpOiBQcm9taXNlPElEZXBlbmRlbmN5Q29udGFpbmVyPiB7XHJcblxyXG4gICAgcHJvdmlkZXJzID0gQXJyYXkuaXNBcnJheShwcm92aWRlcnMpID8gcHJvdmlkZXJzIDogW107XHJcbiAgICBwYXJlbnQgPSBwYXJlbnQgfHwgY3JlYXRlU2VydmljZXMoKTtcclxuXHJcbiAgICAvLyBDcmVhdGUgZml4dHVyZXNcclxuICAgIGNvbnN0IGZpeHR1cmVUeXBlcyA9IChjb25maWcuZml4dHVyZXMgfHwgW10pO1xyXG4gICAgY29uc3QgZml4dHVyZVByb3ZpZGVycyA9IGZpeHR1cmVUeXBlcy5tYXAoZml4dHVyZSA9PiB7XHJcbiAgICAgICAgcmV0dXJuIHtcclxuICAgICAgICAgICAgcHJvdmlkZTogRklYVFVSRSxcclxuICAgICAgICAgICAgdXNlQ2xhc3M6IGZpeHR1cmVcclxuICAgICAgICB9O1xyXG4gICAgfSk7XHJcblxyXG4gICAgLy8gQ3JlYXRlIHBhcmFtc1xyXG4gICAgY29uc3QgcGFyYW1Qcm92aWRlcnMgPSAoY29uZmlnLnBhcmFtcyB8fCBbXSkubWFwKHAgPT4ge1xyXG4gICAgICAgIHJldHVybiB7XHJcbiAgICAgICAgICAgIHByb3ZpZGU6IFBBUkFNRVRFUixcclxuICAgICAgICAgICAgdXNlVmFsdWU6IHBcclxuICAgICAgICB9XHJcbiAgICB9KTtcclxuXHJcbiAgICAvLyBDcmVhdGUgam9ic1xyXG4gICAgY29uc3Qgam9iUHJvdmlkZXJzID0gW0VtcHR5Sm9iIGFzIFR5cGU8SUpvYj5dLmNvbmNhdChjb25maWcuam9icyB8fCBbXSkubWFwKGpvYlR5cGUgPT4ge1xyXG4gICAgICAgIHJldHVybiB7XHJcbiAgICAgICAgICAgIHByb3ZpZGU6IEpPQixcclxuICAgICAgICAgICAgdXNlVmFsdWU6IGpvYlR5cGVcclxuICAgICAgICB9O1xyXG4gICAgfSk7XHJcblxyXG4gICAgLy8gQ3JlYXRlIGNvbW1hbmRzXHJcbiAgICBjb25zdCBjb21tYW5kUHJvdmlkZXJzID0gY29tbWFuZHMuY29uY2F0KGNvbmZpZy5jb21tYW5kcyB8fCBbXSkubWFwKGNvbW1hbmRUeXBlID0+IHtcclxuICAgICAgICByZXR1cm4ge1xyXG4gICAgICAgICAgICBwcm92aWRlOiBURVJNSU5BTF9DT01NQU5ELFxyXG4gICAgICAgICAgICB1c2VDbGFzczogY29tbWFuZFR5cGVcclxuICAgICAgICB9O1xyXG4gICAgfSk7XHJcblxyXG4gICAgLy8gQ3JlYXRlIERJIGNvbnRhaW5lclxyXG4gICAgY29uc3QgZGlDb250YWluZXIgPSBwYXJlbnQuY3JlYXRlQ2hpbGRDb250YWluZXIoKTtcclxuXHJcbiAgICAvLyBTZXR1cCByZXN0IEFQSVxyXG4gICAgY29uc3QgcmVzdE9wdGlvbnM6IFJvdXRpbmdDb250cm9sbGVyc09wdGlvbnMgPSB7XHJcbiAgICAgICAgcm91dGVQcmVmaXg6IGNvbmZpZy5yb3V0ZVByZWZpeCB8fCBcIi9hcGlcIixcclxuICAgICAgICBkZWZhdWx0RXJyb3JIYW5kbGVyOiBmYWxzZSxcclxuICAgICAgICAuLi4oY29uZmlnLnJlc3RPcHRpb25zIHx8IHt9KVxyXG4gICAgfTtcclxuICAgIHJlc3RPcHRpb25zLmNvcnMgPSBPYmplY3QuYXNzaWduKHtcclxuICAgICAgICBjcmVkZW50aWFsczogdHJ1ZSxcclxuICAgICAgICBleHBvc2VkSGVhZGVyczogW1wiY29udGVudC1kaXNwb3NpdGlvblwiXSxcclxuICAgICAgICBvcmlnaW46IChvcmlnaW4sIGNhbGxiYWNrKSA9PiB7XHJcbiAgICAgICAgICAgIGNhbGxiYWNrKG51bGwsIHRydWUpO1xyXG4gICAgICAgIH1cclxuICAgIH0sIHJlc3RPcHRpb25zLmNvcnMgfHwge30pO1xyXG4gICAgcmVzdE9wdGlvbnMucm91dGVQcmVmaXggPSByZXN0T3B0aW9ucy5yb3V0ZVByZWZpeCA9PSBcIi9cIiA/IFwiXCIgOiByZXN0T3B0aW9ucy5yb3V0ZVByZWZpeDtcclxuICAgIHJlc3RPcHRpb25zLm1pZGRsZXdhcmVzID0gW0Vycm9ySGFuZGxlck1pZGRsZXdhcmUsIENvbnRhaW5lck1pZGRsZXdhcmUsIExhbmd1YWdlTWlkZGxld2FyZSwgUmVxdWVzdFN0YXJ0ZWRNaWRkbGV3YXJlLCBSZXF1ZXN0RW5kZWRNaWRkbGV3YXJlXVxyXG4gICAgICAgIC5jb25jYXQocmVzdE9wdGlvbnMubWlkZGxld2FyZXMgYXMgYW55IHx8IFtdKTtcclxuICAgIHJlc3RPcHRpb25zLmNvbnRyb2xsZXJzID0gW0Fzc2V0c0NvbnRyb2xsZXIsIEF1dGhDb250cm9sbGVyLCBHYWxsZXJ5Q29udHJvbGxlciwgUHJvZ3Jlc3Nlc0NvbnRyb2xsZXIsIFRlcm1pbmFsUmVzdENvbnRyb2xsZXJdXHJcbiAgICAgICAgLmNvbmNhdChyZXN0T3B0aW9ucy5jb250cm9sbGVycyBhcyBhbnkgfHwgW10pO1xyXG5cclxuICAgIC8vIFNldHVwIHNvY2tldCBBUElcclxuICAgIGNvbnN0IHNvY2tldE9wdGlvbnM6IFNvY2tldENvbnRyb2xsZXJzT3B0aW9ucyA9IHtcclxuICAgICAgICBjb250YWluZXI6IHtcclxuICAgICAgICAgICAgZ2V0PFQ+KHNvbWVDbGFzczogVHlwZTxhbnk+KTogVCB7XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gZGlDb250YWluZXIuZ2V0PFQ+KHNvbWVDbGFzcyk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9LFxyXG4gICAgICAgIC4uLihjb25maWcuc29ja2V0T3B0aW9ucyB8fCB7fSlcclxuICAgIH07XHJcbiAgICBzb2NrZXRPcHRpb25zLm1pZGRsZXdhcmVzID0gW0NvbXByZXNzaW9uTWlkZGxld2FyZV0uY29uY2F0KHNvY2tldE9wdGlvbnMubWlkZGxld2FyZXMgYXMgYW55IHx8IFtdKTtcclxuICAgIHNvY2tldE9wdGlvbnMuY29udHJvbGxlcnMgPSBbUHJvZ3Jlc3NDb250cm9sbGVyLCBUZXJtaW5hbENvbnRyb2xsZXJdLmNvbmNhdChzb2NrZXRPcHRpb25zLmNvbnRyb2xsZXJzIGFzIGFueSB8fCBbXSk7XHJcblxyXG4gICAgLy8gQ3JlYXRlIHByb3ZpZGVyc1xyXG5cclxuICAgIGNvbnN0IGFsbFByb3ZpZGVyczogUHJvdmlkZXI8YW55PltdID0gW107XHJcblxyXG4gICAgLy8gQWRkIG11bHRpIHRva2VucyB0byBzdWIgY29udGFpbmVyXHJcbiAgICBbUEFSQU1FVEVSXS5mb3JFYWNoKHByb3ZpZGUgPT4ge1xyXG4gICAgICAgIGNvbnN0IHZhbHVlcyA9IHBhcmVudC5yZXNvbHZlQWxsKHByb3ZpZGUpO1xyXG4gICAgICAgIHZhbHVlcy5mb3JFYWNoKHVzZVZhbHVlID0+IHtcclxuICAgICAgICAgICAgYWxsUHJvdmlkZXJzLnB1c2goe3Byb3ZpZGUsIHVzZVZhbHVlfSk7XHJcbiAgICAgICAgfSk7XHJcbiAgICB9KTtcclxuXHJcbiAgICAvLyBBZGQgb3RoZXIgcHJvdmlkZXJzXHJcbiAgICBhbGxQcm92aWRlcnMucHVzaChcclxuICAgICAgICAuLi5maXh0dXJlVHlwZXMsXHJcbiAgICAgICAgLi4uZml4dHVyZVByb3ZpZGVycyxcclxuICAgICAgICAuLi5wYXJhbVByb3ZpZGVycyxcclxuICAgICAgICAuLi5qb2JQcm92aWRlcnMsXHJcbiAgICAgICAgLi4uY29tbWFuZFByb3ZpZGVycyxcclxuICAgICAgICAuLi5yZXN0T3B0aW9ucy5taWRkbGV3YXJlcyBhcyBUeXBlPGFueT5bXSxcclxuICAgICAgICAuLi5yZXN0T3B0aW9ucy5jb250cm9sbGVycyBhcyBUeXBlPGFueT5bXSxcclxuICAgICAgICAuLi5zb2NrZXRPcHRpb25zLm1pZGRsZXdhcmVzIGFzIFR5cGU8YW55PltdLFxyXG4gICAgICAgIC4uLnNvY2tldE9wdGlvbnMuY29udHJvbGxlcnMgYXMgVHlwZTxhbnk+W10sXHJcbiAgICAgICAgLi4ucHJvdmlkZXJzLFxyXG4gICAgICAgIHtcclxuICAgICAgICAgICAgcHJvdmlkZTogRVhQUkVTUyxcclxuICAgICAgICAgICAgdXNlRmFjdG9yeTogKGNvbnRhaW5lcjogRGVwZW5kZW5jeUNvbnRhaW5lcikgPT4ge1xyXG4gICAgICAgICAgICAgICAgcmV0dXJuIGNvbnRhaW5lci5yZXNvbHZlKEJhY2tlbmRQcm92aWRlcikuZXhwcmVzcztcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIH0sXHJcbiAgICAgICAge1xyXG4gICAgICAgICAgICBwcm92aWRlOiBIVFRQX1NFUlZFUixcclxuICAgICAgICAgICAgdXNlRmFjdG9yeTogKGNvbnRhaW5lcjogRGVwZW5kZW5jeUNvbnRhaW5lcikgPT4ge1xyXG4gICAgICAgICAgICAgICAgcmV0dXJuIGNvbnRhaW5lci5yZXNvbHZlKEJhY2tlbmRQcm92aWRlcikuc2VydmVyO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfSxcclxuICAgICAgICB7XHJcbiAgICAgICAgICAgIHByb3ZpZGU6IFNPQ0tFVF9TRVJWRVIsXHJcbiAgICAgICAgICAgIHVzZUZhY3Rvcnk6IChjb250YWluZXI6IERlcGVuZGVuY3lDb250YWluZXIpID0+IHtcclxuICAgICAgICAgICAgICAgIHJldHVybiBjb250YWluZXIucmVzb2x2ZShCYWNrZW5kUHJvdmlkZXIpLmlvO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG4gICAgKVxyXG5cclxuICAgIGFsbFByb3ZpZGVycy5mb3JFYWNoKHByb3ZpZGVyID0+IHtcclxuICAgICAgICBpZiAoaXNUeXBlKHByb3ZpZGVyKSkge1xyXG4gICAgICAgICAgICBpZiAoY29udGFpbmVyLmlzUmVnaXN0ZXJlZChwcm92aWRlcikpIHJldHVybjtcclxuICAgICAgICAgICAgZGlDb250YWluZXIucmVnaXN0ZXIocHJvdmlkZXIsIHByb3ZpZGVyKTtcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIH1cclxuICAgICAgICBkaUNvbnRhaW5lci5yZWdpc3Rlcihwcm92aWRlci5wcm92aWRlLCBwcm92aWRlciBhcyBhbnkpO1xyXG4gICAgfSk7XHJcblxyXG4gICAgZGlDb250YWluZXIucmVnaXN0ZXIoRElfQ09OVEFJTkVSLCB7XHJcbiAgICAgICAgdXNlVmFsdWU6IGRpQ29udGFpbmVyXHJcbiAgICB9KTtcclxuXHJcbiAgICBkaUNvbnRhaW5lci5yZWdpc3RlcihPUEVOQVBJX1ZBTElEQVRJT04sIHtcclxuICAgICAgICB1c2VWYWx1ZTogY29uZmlnLmN1c3RvbVZhbGlkYXRpb24gfHwgKCgpID0+IG51bGwpXHJcbiAgICB9KTtcclxuXHJcbiAgICBkaUNvbnRhaW5lcnMuYXBwQ29udGFpbmVyID0gZGlDb250YWluZXJzLmFwcENvbnRhaW5lciB8fCBkaUNvbnRhaW5lcjtcclxuXHJcbiAgICAvLyBBdXRoZW50aWNhdGlvblxyXG4gICAgcmVzdE9wdGlvbnMuYXV0aG9yaXphdGlvbkNoZWNrZXIgPSBhc3luYyAoYWN0aW9uOiBBY3Rpb24sIHJvbGVzOiBhbnlbXSkgPT4ge1xyXG4gICAgICAgIGNvbnN0IHVzZXIgPSBhd2FpdCByZXNvbHZlVXNlcihhY3Rpb24ucmVxdWVzdCk7XHJcbiAgICAgICAgaWYgKCF1c2VyKSB7XHJcbiAgICAgICAgICAgIHRocm93IG5ldyBIdHRwRXJyb3IoNDAxLCBcIkF1dGhlbnRpY2F0aW9uIGZhaWxlZC4gKFVzZXIgY2FuJ3QgYmUgZm91bmQuKVwiKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgY29uc3QgdXNlclJvbGVzID0gQXJyYXkuaXNBcnJheSh1c2VyLnJvbGVzKSA/IHVzZXIucm9sZXMgOiBbXTtcclxuICAgICAgICBpZiAoQXJyYXkuaXNBcnJheShyb2xlcykgJiYgcm9sZXMubGVuZ3RoID4gMCkge1xyXG4gICAgICAgICAgICBsZXQgbGFzdEVycm9yID0gbnVsbDtcclxuICAgICAgICAgICAgZm9yIChsZXQgcm9sZSBvZiByb2xlcykge1xyXG4gICAgICAgICAgICAgICAgaWYgKGlzRnVuY3Rpb24ocm9sZSkpIHtcclxuICAgICAgICAgICAgICAgICAgICB0cnkge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBpZiAoYXdhaXQgdmFsdWVUb1Byb21pc2Uocm9sZSh1c2VyLCBhY3Rpb24pKSkge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuIHRydWU7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICAgICAgICB9IGNhdGNoIChlKSB7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGxhc3RFcnJvciA9IGU7XHJcbiAgICAgICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgaWYgKHVzZXJSb2xlcy5pbmRleE9mKHJvbGUpID49IDApIHJldHVybiB0cnVlO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIGNvbnN0IGVycm9yID0gIWxhc3RFcnJvciB8fCAoIWxhc3RFcnJvci5tZXNzYWdlICYmICFpc1N0cmluZyhsYXN0RXJyb3IpKVxyXG4gICAgICAgICAgICAgICAgPyBcIlVzZXIgZG9lc24ndCBoYXZlIGFjY2VzcyB0byB0aGlzIHJlc291cmNlXCJcclxuICAgICAgICAgICAgICAgIDogbGFzdEVycm9yLm1lc3NhZ2UgfHwgbGFzdEVycm9yO1xyXG4gICAgICAgICAgICB0aHJvdyBuZXcgSHR0cEVycm9yKDQwMSwgYEF1dGhlbnRpY2F0aW9uIGZhaWxlZC4gKCR7ZXJyb3J9KWApO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gdHJ1ZTtcclxuICAgIH07XHJcbiAgICByZXN0T3B0aW9ucy5jdXJyZW50VXNlckNoZWNrZXIgPSBhc3luYyAoYWN0aW9uOiBBY3Rpb24pID0+IHtcclxuICAgICAgICB0cnkge1xyXG4gICAgICAgICAgICByZXR1cm4gYXdhaXQgcmVzb2x2ZVVzZXIoYWN0aW9uLnJlcXVlc3QpO1xyXG4gICAgICAgIH0gY2F0Y2ggKGUpIHtcclxuICAgICAgICAgICAgcmV0dXJuIG51bGw7XHJcbiAgICAgICAgfVxyXG4gICAgfTtcclxuXHJcbiAgICAvLyBGaW5hbCBzZXR1cFxyXG4gICAgY29uc3QgY29uZmlndXJhdGlvbiA9IGRpQ29udGFpbmVyLnJlc29sdmUoQ29uZmlndXJhdGlvbik7XHJcbiAgICBjb25zdCBicCA9IGRpQ29udGFpbmVyLnJlc29sdmUoQmFja2VuZFByb3ZpZGVyKTtcclxuXHJcbiAgICBpZiAoY29uZmlnLnJlc3RPcHRpb25zKSB7XHJcbiAgICAgICAgYnAuZXhwcmVzcy51c2UoYm9keVBhcnNlci5qc29uKHtcclxuICAgICAgICAgICAgbGltaXQ6IGNvbmZpZ3VyYXRpb24uaGFzUGFyYW0oXCJqc29uTGltaXRcIilcclxuICAgICAgICAgICAgICAgID8gY29uZmlndXJhdGlvbi5yZXNvbHZlKFwianNvbkxpbWl0XCIpXHJcbiAgICAgICAgICAgICAgICA6IFwiMjUwbWJcIlxyXG4gICAgICAgIH0pKTtcclxuICAgICAgICB1c2VSb3V0aW5nQ29udGFpbmVyKGRpQ29udGFpbmVyKTtcclxuICAgICAgICB1c2VFeHByZXNzU2VydmVyKGJwLmV4cHJlc3MsIHJlc3RPcHRpb25zKTtcclxuICAgICAgICAvLyBTZXR1cCByZXN0IGFpIGRvY3NcclxuICAgICAgICBsZXQgb3BlbkFwaTogT3BlbkFwaSA9IG51bGxcclxuICAgICAgICBicC5leHByZXNzLmdldChcIi9hcGktZG9jc1wiLCAocmVxLCByZXMpID0+IHtcclxuICAgICAgICAgICAgb3BlbkFwaSA9IG9wZW5BcGkgfHwgZGlDb250YWluZXIuZ2V0KE9wZW5BcGkpO1xyXG4gICAgICAgICAgICByZXMuaGVhZGVyKFwiQ29udGVudC1UeXBlXCIsIFwiYXBwbGljYXRpb24vanNvblwiKVxyXG4gICAgICAgICAgICAgICAgLnN0YXR1cygyMDApXHJcbiAgICAgICAgICAgICAgICAuZW5kKG9wZW5BcGkuYXBpRG9jc1N0cik7XHJcbiAgICAgICAgfSk7XHJcbiAgICB9XHJcblxyXG4gICAgZGlDb250YWluZXIucmVnaXN0ZXIoU09DS0VUX0NPTlRST0xMRVJTLCB7XHJcbiAgICAgICAgdXNlVmFsdWU6IG5ldyBTb2NrZXRDb250cm9sbGVycyh7XHJcbiAgICAgICAgICAgIGlvOiBicC5pbyxcclxuICAgICAgICAgICAgLi4uc29ja2V0T3B0aW9ucyxcclxuICAgICAgICB9KVxyXG4gICAgfSk7XHJcblxyXG4gICAgLy8gQ29ubmVjdCB0byBtb25nbyBpZiBuZWNlc3NhcnlcclxuICAgIGlmIChjb25maWd1cmF0aW9uLmhhc1BhcmFtKFwibW9uZ29VcmlcIikgJiYgY29uZmlndXJhdGlvbi5yZXNvbHZlKFwibW9uZ29VcmlcIikpIHtcclxuICAgICAgICBjb25zb2xlLmxvZyhcIkNvbm5lY3RpbmcgdG8gTW9uZ29EQi4uLlwiKTtcclxuICAgICAgICBjb25zdCBjb25uZWN0b3IgPSBkaUNvbnRhaW5lci5yZXNvbHZlKE1vbmdvQ29ubmVjdG9yKTtcclxuICAgICAgICBhd2FpdCBjb25uZWN0b3IuY29ubmVjdCgpO1xyXG4gICAgICAgIGNvbnNvbGUubG9nKFwiU3VjY2Vzc2Z1bGx5IGNvbm5lY3RlZCB0byBNb25nb0RCLlwiKTtcclxuICAgIH1cclxuXHJcbiAgICBhd2FpdCBzZXR1cFN0YXRpYyhjb25maWcucm9vdEZvbGRlciwgZGlDb250YWluZXIpO1xyXG5cclxuICAgIHJldHVybiBkaUNvbnRhaW5lcjtcclxufVxyXG4iXX0=
@@ -0,0 +1,53 @@
1
+ import { __decorate } from "tslib";
2
+ import { IsBoolean, IsOptional, Max, Min } from "class-validator";
3
+ export class AssetImageParams {
4
+ constructor() {
5
+ this.rotation = 0;
6
+ this.canvasScaleX = 1;
7
+ this.canvasScaleY = 1;
8
+ this.scaleX = 1;
9
+ this.scaleY = 1;
10
+ this.lazy = false;
11
+ this.crop = false;
12
+ this.cropBefore = false;
13
+ this.cropAfter = false;
14
+ }
15
+ }
16
+ __decorate([
17
+ Min(-360),
18
+ Max(360),
19
+ IsOptional()
20
+ ], AssetImageParams.prototype, "rotation", void 0);
21
+ __decorate([
22
+ Min(0.0001),
23
+ IsOptional()
24
+ ], AssetImageParams.prototype, "canvasScaleX", void 0);
25
+ __decorate([
26
+ Min(0.0001),
27
+ IsOptional()
28
+ ], AssetImageParams.prototype, "canvasScaleY", void 0);
29
+ __decorate([
30
+ Min(0.0001),
31
+ IsOptional()
32
+ ], AssetImageParams.prototype, "scaleX", void 0);
33
+ __decorate([
34
+ Min(0.0001),
35
+ IsOptional()
36
+ ], AssetImageParams.prototype, "scaleY", void 0);
37
+ __decorate([
38
+ IsBoolean(),
39
+ IsOptional()
40
+ ], AssetImageParams.prototype, "lazy", void 0);
41
+ __decorate([
42
+ IsBoolean(),
43
+ IsOptional()
44
+ ], AssetImageParams.prototype, "crop", void 0);
45
+ __decorate([
46
+ IsBoolean(),
47
+ IsOptional()
48
+ ], AssetImageParams.prototype, "cropBefore", void 0);
49
+ __decorate([
50
+ IsBoolean(),
51
+ IsOptional()
52
+ ], AssetImageParams.prototype, "cropAfter", void 0);
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXQtaW1hZ2UtcGFyYW1zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3JlcXVlc3RzL2Fzc2V0LWltYWdlLXBhcmFtcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQ0EsT0FBTyxFQUFDLFNBQVMsRUFBRSxVQUFVLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBRWhFLE1BQU0sT0FBTyxnQkFBZ0I7SUFBN0I7UUFLSSxhQUFRLEdBQVksQ0FBQyxDQUFDO1FBSXRCLGlCQUFZLEdBQVksQ0FBQyxDQUFDO1FBSTFCLGlCQUFZLEdBQVksQ0FBQyxDQUFDO1FBSTFCLFdBQU0sR0FBWSxDQUFDLENBQUM7UUFJcEIsV0FBTSxHQUFZLENBQUMsQ0FBQztRQUlwQixTQUFJLEdBQWEsS0FBSyxDQUFDO1FBSXZCLFNBQUksR0FBYSxLQUFLLENBQUM7UUFJdkIsZUFBVSxHQUFhLEtBQUssQ0FBQztRQUk3QixjQUFTLEdBQWEsS0FBSyxDQUFDO0lBQ2hDLENBQUM7Q0FBQTtBQWpDRztJQUhDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQztJQUNULEdBQUcsQ0FBQyxHQUFHLENBQUM7SUFDUixVQUFVLEVBQUU7a0RBQ1M7QUFJdEI7SUFGQyxHQUFHLENBQUMsTUFBTSxDQUFDO0lBQ1gsVUFBVSxFQUFFO3NEQUNhO0FBSTFCO0lBRkMsR0FBRyxDQUFDLE1BQU0sQ0FBQztJQUNYLFVBQVUsRUFBRTtzREFDYTtBQUkxQjtJQUZDLEdBQUcsQ0FBQyxNQUFNLENBQUM7SUFDWCxVQUFVLEVBQUU7Z0RBQ087QUFJcEI7SUFGQyxHQUFHLENBQUMsTUFBTSxDQUFDO0lBQ1gsVUFBVSxFQUFFO2dEQUNPO0FBSXBCO0lBRkMsU0FBUyxFQUFFO0lBQ1gsVUFBVSxFQUFFOzhDQUNVO0FBSXZCO0lBRkMsU0FBUyxFQUFFO0lBQ1gsVUFBVSxFQUFFOzhDQUNVO0FBSXZCO0lBRkMsU0FBUyxFQUFFO0lBQ1gsVUFBVSxFQUFFO29EQUNnQjtBQUk3QjtJQUZDLFNBQVMsRUFBRTtJQUNYLFVBQVUsRUFBRTttREFDZSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SUFzc2V0SW1hZ2VQYXJhbXN9IGZyb20gXCIuLi9jb21tb24tdHlwZXNcIjtcclxuaW1wb3J0IHtJc0Jvb2xlYW4sIElzT3B0aW9uYWwsIE1heCwgTWlufSBmcm9tIFwiY2xhc3MtdmFsaWRhdG9yXCI7XHJcblxyXG5leHBvcnQgY2xhc3MgQXNzZXRJbWFnZVBhcmFtcyBpbXBsZW1lbnRzIElBc3NldEltYWdlUGFyYW1zIHtcclxuXHJcbiAgICBATWluKC0zNjApXHJcbiAgICBATWF4KDM2MClcclxuICAgIEBJc09wdGlvbmFsKClcclxuICAgIHJvdGF0aW9uPzogbnVtYmVyID0gMDtcclxuXHJcbiAgICBATWluKDAuMDAwMSlcclxuICAgIEBJc09wdGlvbmFsKClcclxuICAgIGNhbnZhc1NjYWxlWD86IG51bWJlciA9IDE7XHJcblxyXG4gICAgQE1pbigwLjAwMDEpXHJcbiAgICBASXNPcHRpb25hbCgpXHJcbiAgICBjYW52YXNTY2FsZVk/OiBudW1iZXIgPSAxO1xyXG5cclxuICAgIEBNaW4oMC4wMDAxKVxyXG4gICAgQElzT3B0aW9uYWwoKVxyXG4gICAgc2NhbGVYPzogbnVtYmVyID0gMTtcclxuXHJcbiAgICBATWluKDAuMDAwMSlcclxuICAgIEBJc09wdGlvbmFsKClcclxuICAgIHNjYWxlWT86IG51bWJlciA9IDE7XHJcblxyXG4gICAgQElzQm9vbGVhbigpXHJcbiAgICBASXNPcHRpb25hbCgpXHJcbiAgICBsYXp5PzogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICAgIEBJc0Jvb2xlYW4oKVxyXG4gICAgQElzT3B0aW9uYWwoKVxyXG4gICAgY3JvcD86IGJvb2xlYW4gPSBmYWxzZTtcclxuXHJcbiAgICBASXNCb29sZWFuKClcclxuICAgIEBJc09wdGlvbmFsKClcclxuICAgIGNyb3BCZWZvcmU/OiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gICAgQElzQm9vbGVhbigpXHJcbiAgICBASXNPcHRpb25hbCgpXHJcbiAgICBjcm9wQWZ0ZXI/OiBib29sZWFuID0gZmFsc2U7XHJcbn1cclxuIl19