@dcl/sdk 7.0.6-4197661608.commit-41efaad → 7.0.6-4197739270.commit-db87ed8

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.
@@ -28,25 +28,26 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
28
28
  Object.defineProperty(exports, "__esModule", { value: true });
29
29
  exports.getFilesFromFolder = exports.setupEcs6Endpoints = void 0;
30
30
  const path = __importStar(require("path"));
31
- const fs = __importStar(require("fs"));
32
31
  const glob_1 = require("glob");
33
32
  const sdk_1 = require("@dcl/schemas/dist/sdk");
34
33
  const schemas_1 = require("@dcl/schemas");
35
34
  const ignore_1 = __importDefault(require("ignore"));
36
35
  const node_fetch_1 = __importStar(require("node-fetch"));
37
36
  const catalyst_1 = require("./catalyst");
37
+ const fs_1 = require("fs");
38
+ const dcl_ignore_1 = require("../../utils/dcl-ignore");
38
39
  function getCatalystUrl() {
39
40
  return new URL('https://peer.decentraland.org');
40
41
  }
41
42
  function smartWearableNameToId(name) {
42
43
  return name.toLocaleLowerCase().replace(/ /g, '-');
43
44
  }
44
- function setupEcs6Endpoints(dir, router) {
45
+ function setupEcs6Endpoints(components, dir, router) {
45
46
  const baseFolders = [dir];
46
47
  router.get('/scene.json', async () => {
47
48
  return {
48
49
  headers: { 'content-type': 'application/json' },
49
- body: fs.createReadStream(path.join(dir, 'scene.json'))
50
+ body: components.fs.createReadStream(path.join(dir, 'scene.json'))
50
51
  };
51
52
  });
52
53
  router.get('/lambdas/explore/realms', async (ctx) => {
@@ -77,10 +78,10 @@ function setupEcs6Endpoints(dir, router) {
77
78
  router.get('/lambdas/profiles', async (ctx, next) => {
78
79
  const baseUrl = `${ctx.url.protocol}//${ctx.url.host}/content/contents`;
79
80
  try {
80
- const previewWearables = getAllPreviewWearables({
81
+ const previewWearables = await getAllPreviewWearables(components, {
81
82
  baseFolders,
82
83
  baseUrl
83
- }).map((wearable) => wearable.id);
84
+ });
84
85
  if (previewWearables.length === 1) {
85
86
  const catalystUrl = getCatalystUrl();
86
87
  const u = new URL(ctx.url.toString());
@@ -96,7 +97,7 @@ function setupEcs6Endpoints(dir, router) {
96
97
  });
97
98
  const deployedProfile = (await req.json());
98
99
  if ((deployedProfile === null || deployedProfile === void 0 ? void 0 : deployedProfile.length) === 1) {
99
- deployedProfile[0].avatars[0].avatar.wearables.push(...previewWearables);
100
+ deployedProfile[0].avatars[0].avatar.wearables.push(...previewWearables.map(($) => $.id));
100
101
  return {
101
102
  headers: {
102
103
  'content-type': req.headers.get('content-type') || 'application/binary'
@@ -142,11 +143,11 @@ function setupEcs6Endpoints(dir, router) {
142
143
  });
143
144
  return res;
144
145
  });
145
- serveStatic(dir, router);
146
- serveFolders(router, baseFolders);
146
+ serveStatic(components, dir, router);
147
+ serveFolders(components, router, baseFolders);
147
148
  }
148
149
  exports.setupEcs6Endpoints = setupEcs6Endpoints;
149
- function serveFolders(router, baseFolders) {
150
+ function serveFolders(components, router, baseFolders) {
150
151
  router.get('/content/contents/:hash', async (ctx, next) => {
151
152
  if (ctx.params.hash && ctx.params.hash.startsWith('b64-')) {
152
153
  const fullPath = path.resolve(Buffer.from(ctx.params.hash.replace(/^b64-/, ''), 'base64').toString('utf8'));
@@ -159,7 +160,7 @@ function serveFolders(router, baseFolders) {
159
160
  'x-sent': true,
160
161
  'cache-control': 'no-cache,private,max-age=1'
161
162
  },
162
- body: fs.createReadStream(fullPath)
163
+ body: components.fs.createReadStream(fullPath)
163
164
  };
164
165
  }
165
166
  return next();
@@ -169,7 +170,7 @@ function serveFolders(router, baseFolders) {
169
170
  return [];
170
171
  }
171
172
  const requestedPointers = new Set(pointers && typeof pointers === 'string' ? [pointers] : pointers);
172
- const resultEntities = getSceneJson({
173
+ const resultEntities = await getSceneJson(components, {
173
174
  baseFolders,
174
175
  pointers: Array.from(requestedPointers)
175
176
  });
@@ -191,7 +192,7 @@ function serveFolders(router, baseFolders) {
191
192
  });
192
193
  router.get('/preview-wearables/:id', async (ctx) => {
193
194
  const baseUrl = `${ctx.url.protocol}//${ctx.url.host}/content/contents`;
194
- const wearables = getAllPreviewWearables({
195
+ const wearables = await getAllPreviewWearables(components, {
195
196
  baseUrl,
196
197
  baseFolders
197
198
  });
@@ -208,24 +209,24 @@ function serveFolders(router, baseFolders) {
208
209
  return {
209
210
  body: {
210
211
  ok: true,
211
- data: getAllPreviewWearables({ baseUrl, baseFolders })
212
+ data: await getAllPreviewWearables(components, { baseUrl, baseFolders })
212
213
  }
213
214
  };
214
215
  });
215
216
  }
216
217
  const defaultHashMaker = (str) => 'b64-' + Buffer.from(str).toString('base64');
217
- function getAllPreviewWearables({ baseFolders, baseUrl }) {
218
+ async function getAllPreviewWearables(components, { baseFolders, baseUrl }) {
218
219
  const wearablePathArray = [];
219
220
  for (const wearableDir of baseFolders) {
220
221
  const wearableJsonPath = path.resolve(wearableDir, 'wearable.json');
221
- if (fs.existsSync(wearableJsonPath)) {
222
+ if (await components.fs.fileExists(wearableJsonPath)) {
222
223
  wearablePathArray.push(wearableJsonPath);
223
224
  }
224
225
  }
225
226
  const ret = [];
226
227
  for (const wearableJsonPath of wearablePathArray) {
227
228
  try {
228
- ret.push(serveWearable({ wearableJsonPath, baseUrl }));
229
+ ret.push(await serveWearable(components, { wearableJsonPath, baseUrl }));
229
230
  }
230
231
  catch (err) {
231
232
  console.error(`Couldn't mock the wearable ${wearableJsonPath}. Please verify the correct format and scheme.`, err);
@@ -233,24 +234,18 @@ function getAllPreviewWearables({ baseFolders, baseUrl }) {
233
234
  }
234
235
  return ret;
235
236
  }
236
- function serveWearable({ wearableJsonPath, baseUrl }) {
237
+ async function serveWearable(components, { wearableJsonPath, baseUrl }) {
237
238
  var _a;
238
239
  const wearableDir = path.dirname(wearableJsonPath);
239
- const wearableJson = JSON.parse(fs.readFileSync(wearableJsonPath).toString());
240
+ const wearableJson = JSON.parse((await components.fs.readFile(wearableJsonPath)).toString());
240
241
  if (!sdk_1.WearableJson.validate(wearableJson)) {
241
242
  const errors = (sdk_1.WearableJson.validate.errors || []).map((a) => `${a.data} ${a.message}`).join('');
242
243
  console.error(`Unable to validate wearable.json properly, please check it.`, errors);
243
244
  throw new Error(`Invalid wearable.json (${wearableJsonPath})`);
244
245
  }
245
- const dclIgnorePath = path.resolve(wearableDir, '.dclignore');
246
- let ignoreFileContent = '';
247
- if (fs.existsSync(dclIgnorePath)) {
248
- ignoreFileContent = fs.readFileSync(path.resolve(wearableDir, '.dclignore'), 'utf-8');
249
- }
250
- const hashedFiles = getFilesFromFolder({
246
+ const hashedFiles = await getFilesFromFolder(components, {
251
247
  folder: wearableDir,
252
- addOriginalPath: false,
253
- ignorePattern: ignoreFileContent
248
+ addOriginalPath: false
254
249
  });
255
250
  const thumbnailFiltered = hashedFiles.filter(($) => ($ === null || $ === void 0 ? void 0 : $.file) === 'thumbnail.png');
256
251
  const thumbnail = thumbnailFiltered.length > 0 && ((_a = thumbnailFiltered[0]) === null || _a === void 0 ? void 0 : _a.hash) && `${baseUrl}/${thumbnailFiltered[0].hash}`;
@@ -266,6 +261,8 @@ function serveWearable({ wearableJsonPath, baseUrl }) {
266
261
  i18n: [{ code: 'en', text: wearableJson.name }],
267
262
  description: wearableJson.description,
268
263
  thumbnail: thumbnail || '',
264
+ image: thumbnail || '',
265
+ collectionAddress: '0x0',
269
266
  baseUrl: `${baseUrl}/`,
270
267
  name: wearableJson.name || '',
271
268
  data: {
@@ -273,27 +270,20 @@ function serveWearable({ wearableJsonPath, baseUrl }) {
273
270
  replaces: [],
274
271
  hides: [],
275
272
  tags: [],
276
- scene: hashedFiles,
277
273
  representations: representations
278
274
  }
279
275
  };
280
276
  }
281
- function getSceneJson({ baseFolders, pointers, customHashMaker }) {
277
+ async function getSceneJson(components, { baseFolders, pointers, customHashMaker }) {
282
278
  const requestedPointers = new Set(pointers);
283
279
  const resultEntities = [];
284
- const allDeployments = baseFolders.map((folder) => {
285
- const dclIgnorePath = path.resolve(folder, '.dclignore');
286
- let ignoreFileContent = '';
287
- if (fs.existsSync(dclIgnorePath)) {
288
- ignoreFileContent = fs.readFileSync(path.resolve(folder, '.dclignore'), 'utf-8');
289
- }
290
- return entityV3FromFolder({
280
+ const allDeployments = await Promise.all(baseFolders.map(async (folder) => {
281
+ return entityV3FromFolder(components, {
291
282
  folder,
292
283
  addOriginalPath: false,
293
- ignorePattern: ignoreFileContent,
294
284
  customHashMaker
295
285
  });
296
- });
286
+ }));
297
287
  for (const pointer of Array.from(requestedPointers)) {
298
288
  const theDeployment = allDeployments.find(($) => $ && $.pointers.includes(pointer));
299
289
  if (theDeployment) {
@@ -303,7 +293,7 @@ function getSceneJson({ baseFolders, pointers, customHashMaker }) {
303
293
  }
304
294
  return resultEntities;
305
295
  }
306
- function serveStatic(dir, router) {
296
+ function serveStatic(components, dir, router) {
307
297
  const sdkPath = path.dirname(require.resolve('@dcl/sdk/package.json', {
308
298
  paths: [dir]
309
299
  }));
@@ -333,15 +323,15 @@ function serveStatic(dir, router) {
333
323
  router.get(route.route, async (_ctx) => {
334
324
  return {
335
325
  headers: { 'Content-Type': route.type },
336
- body: fs.createReadStream(route.path)
326
+ body: components.fs.createReadStream(route.path)
337
327
  };
338
328
  });
339
329
  }
340
- function createStaticRoutes(route, folder, transform = (str) => str) {
330
+ function createStaticRoutes(components, route, folder, transform = (str) => str) {
341
331
  router.get(route, async (ctx, next) => {
342
332
  const file = ctx.params.path;
343
333
  const fullPath = path.resolve(folder, transform(file));
344
- if (!fs.existsSync(fullPath)) {
334
+ if (!(await components.fs.fileExists(fullPath))) {
345
335
  return next();
346
336
  }
347
337
  const headers = {
@@ -354,13 +344,13 @@ function serveStatic(dir, router) {
354
344
  }
355
345
  return {
356
346
  headers,
357
- body: fs.createReadStream(fullPath)
347
+ body: components.fs.createReadStream(fullPath)
358
348
  };
359
349
  });
360
350
  }
361
- createStaticRoutes('/images/decentraland-connect/:path+', dclKernelImagesDecentralandConnect);
362
- createStaticRoutes('/default-profile/:path+', dclKernelDefaultProfilePath);
363
- createStaticRoutes('/@/explorer/:path+', dclExplorerJsonPath, (filePath) => filePath.replace(/.br+$/, ''));
351
+ createStaticRoutes(components, '/images/decentraland-connect/:path+', dclKernelImagesDecentralandConnect);
352
+ createStaticRoutes(components, '/default-profile/:path+', dclKernelDefaultProfilePath);
353
+ createStaticRoutes(components, '/@/explorer/:path+', dclExplorerJsonPath, (filePath) => filePath.replace(/.br+$/, ''));
364
354
  router.get('/feature-flags/:file', async (ctx) => {
365
355
  const res = await (0, node_fetch_1.default)(`https://feature-flags.decentraland.zone/${ctx.params.file}`, {
366
356
  headers: {
@@ -372,13 +362,13 @@ function serveStatic(dir, router) {
372
362
  };
373
363
  });
374
364
  }
375
- function entityV3FromFolder({ folder, addOriginalPath, ignorePattern, customHashMaker }) {
365
+ async function entityV3FromFolder(components, { folder, addOriginalPath, customHashMaker }) {
376
366
  const sceneJsonPath = path.resolve(folder, './scene.json');
377
367
  let isParcelScene = true;
378
368
  const wearableJsonPath = path.resolve(folder, './wearable.json');
379
- if (fs.existsSync(wearableJsonPath)) {
369
+ if (await components.fs.fileExists(wearableJsonPath)) {
380
370
  try {
381
- const wearableJson = JSON.parse(fs.readFileSync(wearableJsonPath).toString());
371
+ const wearableJson = JSON.parse(await components.fs.readFile(wearableJsonPath, 'utf-8'));
382
372
  if (!sdk_1.WearableJson.validate(wearableJson)) {
383
373
  const errors = (sdk_1.WearableJson.validate.errors || []).map((a) => `${a.data} ${a.message}`).join('');
384
374
  console.error(`Unable to validate wearable.json properly, please check it.`, errors);
@@ -393,16 +383,15 @@ function entityV3FromFolder({ folder, addOriginalPath, ignorePattern, customHash
393
383
  }
394
384
  }
395
385
  const hashMaker = customHashMaker ? customHashMaker : defaultHashMaker;
396
- if (fs.existsSync(sceneJsonPath) && isParcelScene) {
397
- const sceneJson = JSON.parse(fs.readFileSync(sceneJsonPath).toString());
386
+ if ((await components.fs.fileExists(sceneJsonPath)) && isParcelScene) {
387
+ const sceneJson = JSON.parse(await components.fs.readFile(sceneJsonPath, 'utf-8'));
398
388
  const { base, parcels } = sceneJson.scene;
399
389
  const pointers = new Set();
400
390
  pointers.add(base);
401
391
  parcels.forEach(($) => pointers.add($));
402
- const mappedFiles = getFilesFromFolder({
392
+ const mappedFiles = await getFilesFromFolder(components, {
403
393
  folder,
404
394
  addOriginalPath,
405
- ignorePattern,
406
395
  customHashMaker
407
396
  });
408
397
  return {
@@ -417,36 +406,18 @@ function entityV3FromFolder({ folder, addOriginalPath, ignorePattern, customHash
417
406
  }
418
407
  return null;
419
408
  }
420
- const defaultDclIgnore = () => [
421
- '.*',
422
- 'package.json',
423
- 'package-lock.json',
424
- 'yarn-lock.json',
425
- 'build.json',
426
- 'export',
427
- 'tsconfig.json',
428
- 'tslint.json',
429
- 'node_modules',
430
- '*.ts',
431
- '*.tsx',
432
- 'Dockerfile',
433
- 'dist',
434
- 'README.md',
435
- '*.blend',
436
- '*.fbx',
437
- '*.zip',
438
- '*.rar'
439
- ].join('\n');
440
- function getFilesFromFolder({ folder, addOriginalPath, ignorePattern, customHashMaker }) {
409
+ async function getFilesFromFolder(components, { folder, addOriginalPath, customHashMaker }) {
441
410
  const hashMaker = customHashMaker ? customHashMaker : defaultHashMaker;
411
+ const ignorePatterns = await (0, dcl_ignore_1.getDCLIgnorePatterns)(components, folder);
442
412
  const allFiles = (0, glob_1.sync)('**/*', {
413
+ ignore: ignorePatterns,
443
414
  cwd: folder,
444
415
  dot: false,
445
416
  absolute: true
446
417
  })
447
418
  .map((file) => {
448
419
  try {
449
- if (!fs.statSync(file).isFile())
420
+ if (!(0, fs_1.statSync)(file).isFile())
450
421
  return;
451
422
  }
452
423
  catch (err) {
@@ -457,18 +428,17 @@ function getFilesFromFolder({ folder, addOriginalPath, ignorePattern, customHash
457
428
  return key;
458
429
  })
459
430
  .filter(($) => !!$);
460
- const ensureIgnorePattern = ignorePattern && ignorePattern !== '' ? ignorePattern : defaultDclIgnore();
461
- const ig = (0, ignore_1.default)().add(ensureIgnorePattern);
431
+ const ig = (0, ignore_1.default)().add(ignorePatterns);
462
432
  const filteredFiles = ig.filter(allFiles);
463
433
  const ret = [];
464
434
  for (const file of filteredFiles) {
465
435
  const absolutePath = path.resolve(folder, file);
466
436
  try {
467
- if (!fs.statSync(absolutePath).isFile())
437
+ if (!(0, fs_1.statSync)(absolutePath).isFile())
468
438
  continue;
469
439
  }
470
440
  catch (err) {
471
- console.log(err);
441
+ console.error(err);
472
442
  continue;
473
443
  }
474
444
  const absoluteFolder = folder.replace(/\\/gi, '/');
@@ -482,4 +452,4 @@ function getFilesFromFolder({ folder, addOriginalPath, ignorePattern, customHash
482
452
  return ret;
483
453
  }
484
454
  exports.getFilesFromFolder = getFilesFromFolder;
485
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"endpoints.js","sourceRoot":"","sources":["endpoints.ts"],"names":[],"mappings":"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","sourcesContent":["import { Router } from '@well-known-components/http-server'\nimport { PreviewComponents } from './types'\nimport * as path from 'path'\nimport * as fs from 'fs'\nimport { sync as globSync } from 'glob'\nimport { WearableJson } from '@dcl/schemas/dist/sdk'\nimport { ContentMapping, Entity, EntityType } from '@dcl/schemas'\nimport ignore from 'ignore'\nimport fetch, { Headers } from 'node-fetch'\nimport { fetchEntityByPointer } from './catalyst'\n\nfunction getCatalystUrl(): URL {\n  return new URL('https://peer.decentraland.org')\n}\n\nfunction smartWearableNameToId(name: string) {\n  return name.toLocaleLowerCase().replace(/ /g, '-')\n}\n\nexport function setupEcs6Endpoints(dir: string, router: Router<PreviewComponents>) {\n  const baseFolders = [dir]\n  // handle old preview scene.json\n  router.get('/scene.json', async () => {\n    return {\n      headers: { 'content-type': 'application/json' },\n      body: fs.createReadStream(path.join(dir, 'scene.json'))\n    }\n  })\n\n  router.get('/lambdas/explore/realms', async (ctx) => {\n    return {\n      body: [\n        {\n          serverName: 'localhost',\n          url: `http://${ctx.url.host}`,\n          layer: 'stub',\n          usersCount: 0,\n          maxUsers: 100,\n          userParcels: []\n        }\n      ]\n    }\n  })\n\n  router.get('/lambdas/contracts/servers', async (ctx) => {\n    return {\n      body: [\n        {\n          address: `http://${ctx.url.host}`,\n          owner: '0x0000000000000000000000000000000000000000',\n          id: '0x0000000000000000000000000000000000000000000000000000000000000000'\n        }\n      ]\n    }\n  })\n\n  router.get('/lambdas/profiles', async (ctx, next) => {\n    const baseUrl = `${ctx.url.protocol}//${ctx.url.host}/content/contents`\n\n    try {\n      const previewWearables = getAllPreviewWearables({\n        baseFolders,\n        baseUrl\n      }).map((wearable) => wearable.id)\n\n      if (previewWearables.length === 1) {\n        const catalystUrl = getCatalystUrl()\n\n        const u = new URL(ctx.url.toString())\n        u.host = catalystUrl.host\n        u.protocol = catalystUrl.protocol\n        u.port = catalystUrl.port\n        const req = await fetch(u.toString(), {\n          headers: {\n            connection: 'close'\n          },\n          method: ctx.request.method,\n          body: ctx.request.method === 'get' ? undefined : ctx.request.body\n        })\n\n        const deployedProfile = (await req.json()) as any[]\n\n        if (deployedProfile?.length === 1) {\n          deployedProfile[0].avatars[0].avatar.wearables.push(...previewWearables)\n          return {\n            headers: {\n              'content-type': req.headers.get('content-type') || 'application/binary'\n            },\n            body: deployedProfile\n          }\n        }\n      }\n    } catch (err) {\n      console.warn(`Failed to catch profile and fill with preview wearables.`, err)\n    }\n\n    return next()\n  })\n\n  router.all('/lambdas/:path+', async (ctx) => {\n    const catalystUrl = getCatalystUrl()\n    const u = new URL(ctx.url.toString())\n    u.host = catalystUrl.host\n    u.protocol = catalystUrl.protocol\n    u.port = catalystUrl.port\n    const req = await fetch(u.toString(), {\n      headers: {\n        connection: 'close'\n      },\n      method: ctx.request.method,\n      body: ctx.request.method === 'get' ? undefined : ctx.request.body\n    })\n\n    return {\n      headers: {\n        'content-type': req.headers.get('content-type') || 'application/binary'\n      },\n      body: req.body\n    }\n  })\n\n  router.post('/content/entities', async (ctx) => {\n    const catalystUrl = getCatalystUrl()\n    const headers = new Headers()\n    console.log(ctx.request.headers)\n    const res = await fetch(`${catalystUrl.toString()}/content/entities`, {\n      method: 'post',\n      headers,\n      body: ctx.request.body\n    })\n\n    return res\n  })\n\n  serveStatic(dir, router)\n\n  // TODO: get workspace scenes & wearables...\n\n  serveFolders(router, baseFolders)\n}\n\nfunction serveFolders(router: Router<PreviewComponents>, baseFolders: string[]) {\n  router.get('/content/contents/:hash', async (ctx: any, next: any) => {\n    if (ctx.params.hash && ctx.params.hash.startsWith('b64-')) {\n      const fullPath = path.resolve(Buffer.from(ctx.params.hash.replace(/^b64-/, ''), 'base64').toString('utf8'))\n\n      // only return files IF the file is within a baseFolder\n      if (!baseFolders.find((folder: string) => fullPath.startsWith(folder))) {\n        return next()\n      }\n\n      return {\n        headers: {\n          'x-timestamp': Date.now(),\n          'x-sent': true,\n          'cache-control': 'no-cache,private,max-age=1'\n        },\n        body: fs.createReadStream(fullPath)\n      }\n    }\n\n    return next()\n  })\n\n  async function pointerRequestHandler(pointers: string[]) {\n    if (!pointers || pointers.length === 0) {\n      return []\n    }\n\n    const requestedPointers = new Set<string>(\n      pointers && typeof pointers === 'string' ? [pointers as string] : (pointers as string[])\n    )\n\n    const resultEntities = getSceneJson({\n      baseFolders,\n      pointers: Array.from(requestedPointers)\n    })\n    const catalystUrl = getCatalystUrl()\n    const remote = fetchEntityByPointer(\n      catalystUrl.toString(),\n      pointers.filter(($: string) => !$.match(/-?\\d+,-?\\d+/))\n    )\n\n    const serverEntities = Array.isArray(remote) ? remote : []\n\n    return [...resultEntities, ...serverEntities]\n  }\n\n  // REVIEW RESPONSE FORMAT\n  router.get('/content/entities/scene', async (ctx) => {\n    return {\n      body: await pointerRequestHandler(ctx.url.searchParams.getAll('pointer'))\n    }\n  })\n\n  // REVIEW RESPONSE FORMAT\n  router.post('/content/entities/active', async (ctx) => {\n    const body = await ctx.request.json()\n    return {\n      body: await pointerRequestHandler(body.pointers)\n    }\n  })\n\n  router.get('/preview-wearables/:id', async (ctx) => {\n    const baseUrl = `${ctx.url.protocol}//${ctx.url.host}/content/contents`\n    const wearables = getAllPreviewWearables({\n      baseUrl,\n      baseFolders\n    })\n    const wearableId = ctx.params.id\n    return {\n      body: {\n        ok: true,\n        data: wearables.filter((wearable) => smartWearableNameToId(wearable?.name) === wearableId)\n      }\n    }\n  })\n\n  router.get('/preview-wearables', async (ctx) => {\n    const baseUrl = `${ctx.url.protocol}//${ctx.url.host}/content/contents`\n    return {\n      body: {\n        ok: true,\n        data: getAllPreviewWearables({ baseUrl, baseFolders })\n      }\n    }\n  })\n}\n\nconst defaultHashMaker = (str: string) => 'b64-' + Buffer.from(str).toString('base64')\n\nfunction getAllPreviewWearables({ baseFolders, baseUrl }: { baseFolders: string[]; baseUrl: string }) {\n  const wearablePathArray: string[] = []\n  for (const wearableDir of baseFolders) {\n    const wearableJsonPath = path.resolve(wearableDir, 'wearable.json')\n    if (fs.existsSync(wearableJsonPath)) {\n      wearablePathArray.push(wearableJsonPath)\n    }\n  }\n\n  const ret: ReturnType<typeof serveWearable>[] = []\n  for (const wearableJsonPath of wearablePathArray) {\n    try {\n      ret.push(serveWearable({ wearableJsonPath, baseUrl }))\n    } catch (err) {\n      console.error(`Couldn't mock the wearable ${wearableJsonPath}. Please verify the correct format and scheme.`, err)\n    }\n  }\n  return ret\n}\n\nfunction serveWearable({ wearableJsonPath, baseUrl }: { wearableJsonPath: string; baseUrl: string }) {\n  const wearableDir = path.dirname(wearableJsonPath)\n  const wearableJson = JSON.parse(fs.readFileSync(wearableJsonPath).toString())\n\n  if (!WearableJson.validate(wearableJson)) {\n    const errors = (WearableJson.validate.errors || []).map((a) => `${a.data} ${a.message}`).join('')\n\n    console.error(`Unable to validate wearable.json properly, please check it.`, errors)\n    throw new Error(`Invalid wearable.json (${wearableJsonPath})`)\n  }\n\n  const dclIgnorePath = path.resolve(wearableDir, '.dclignore')\n  let ignoreFileContent = ''\n  if (fs.existsSync(dclIgnorePath)) {\n    ignoreFileContent = fs.readFileSync(path.resolve(wearableDir, '.dclignore'), 'utf-8')\n  }\n\n  const hashedFiles = getFilesFromFolder({\n    folder: wearableDir,\n    addOriginalPath: false,\n    ignorePattern: ignoreFileContent\n  })\n\n  const thumbnailFiltered = hashedFiles.filter(($) => $?.file === 'thumbnail.png')\n  const thumbnail =\n    thumbnailFiltered.length > 0 && thumbnailFiltered[0]?.hash && `${baseUrl}/${thumbnailFiltered[0].hash}`\n\n  const wearableId = 'urn:8dc2d7ad-97e3-44d0-ba89-e8305d795a6a'\n\n  const representations = wearableJson.data.representations.map((representation) => ({\n    ...representation,\n    mainFile: `male/${representation.mainFile}`,\n    contents: hashedFiles.map(($) => ({\n      key: `male/${$?.file}`,\n      url: `${baseUrl}/${$?.hash}`,\n      hash: $?.hash\n    }))\n  }))\n\n  return {\n    id: wearableId,\n    rarity: wearableJson.rarity,\n    i18n: [{ code: 'en', text: wearableJson.name }],\n    description: wearableJson.description,\n    thumbnail: thumbnail || '',\n    baseUrl: `${baseUrl}/`,\n    name: wearableJson.name || '',\n    data: {\n      category: wearableJson.data.category,\n      replaces: [],\n      hides: [],\n      tags: [],\n      scene: hashedFiles,\n      representations: representations as any\n    }\n  }\n}\n\nfunction getSceneJson({\n  baseFolders,\n  pointers,\n  customHashMaker\n}: {\n  baseFolders: string[]\n  pointers: string[]\n  customHashMaker?: (str: string) => string\n}): Entity[] {\n  const requestedPointers = new Set<string>(pointers)\n  const resultEntities: Entity[] = []\n\n  const allDeployments = baseFolders.map((folder) => {\n    const dclIgnorePath = path.resolve(folder, '.dclignore')\n    let ignoreFileContent = ''\n    if (fs.existsSync(dclIgnorePath)) {\n      ignoreFileContent = fs.readFileSync(path.resolve(folder, '.dclignore'), 'utf-8')\n    }\n\n    return entityV3FromFolder({\n      folder,\n      addOriginalPath: false,\n      ignorePattern: ignoreFileContent,\n      customHashMaker\n    })\n  })\n\n  for (const pointer of Array.from(requestedPointers)) {\n    // get deployment by pointer\n    const theDeployment = allDeployments.find(($) => $ && $.pointers.includes(pointer))\n    if (theDeployment) {\n      // remove all the required pointers from the requestedPointers set\n      // to prevent sending duplicated entities\n      theDeployment.pointers.forEach(($) => requestedPointers.delete($))\n\n      // add the deployment to the results\n      resultEntities.push(theDeployment)\n    }\n  }\n\n  return resultEntities\n}\n\nfunction serveStatic(dir: string, router: Router<PreviewComponents>) {\n  const sdkPath = path.dirname(\n    require.resolve('@dcl/sdk/package.json', {\n      paths: [dir]\n    })\n  )\n  const dclExplorerJsonPath = path.dirname(\n    require.resolve('@dcl/explorer/package.json', {\n      paths: [dir, sdkPath]\n    })\n  )\n\n  const dclKernelDefaultProfilePath = path.resolve(dclExplorerJsonPath, 'default-profile')\n  const dclKernelImagesDecentralandConnect = path.resolve(dclExplorerJsonPath, 'images', 'decentraland-connect')\n\n  const routes = [\n    {\n      route: '/',\n      path: path.resolve(dclExplorerJsonPath, 'preview.html'),\n      type: 'text/html'\n    },\n    {\n      route: '/favicon.ico',\n      path: path.resolve(dclExplorerJsonPath, 'favicon.ico'),\n      type: 'text/html'\n    },\n    {\n      route: '/@/explorer/index.js',\n      path: path.resolve(dclExplorerJsonPath, 'index.js'),\n      type: 'text/javascript'\n    }\n  ]\n\n  for (const route of routes) {\n    router.get(route.route, async (_ctx) => {\n      return {\n        headers: { 'Content-Type': route.type },\n        body: fs.createReadStream(route.path)\n      }\n    })\n  }\n\n  function createStaticRoutes(route: string, folder: string, transform = (str: string) => str) {\n    router.get(route, async (ctx, next) => {\n      const file = ctx.params.path\n      const fullPath = path.resolve(folder, transform(file))\n\n      // only return files IF the file is within a baseFolder\n      if (!fs.existsSync(fullPath)) {\n        return next()\n      }\n\n      const headers: Record<string, any> = {\n        'x-timestamp': Date.now(),\n        'x-sent': true,\n        'cache-control': 'no-cache,private,max-age=1'\n      }\n\n      if (fullPath.endsWith('.wasm')) {\n        headers['content-type'] = 'application/wasm'\n      }\n\n      return {\n        headers,\n        body: fs.createReadStream(fullPath)\n      }\n    })\n  }\n\n  createStaticRoutes('/images/decentraland-connect/:path+', dclKernelImagesDecentralandConnect)\n  createStaticRoutes('/default-profile/:path+', dclKernelDefaultProfilePath)\n  createStaticRoutes('/@/explorer/:path+', dclExplorerJsonPath, (filePath) => filePath.replace(/.br+$/, ''))\n\n  router.get('/feature-flags/:file', async (ctx) => {\n    const res = await fetch(`https://feature-flags.decentraland.zone/${ctx.params.file}`, {\n      headers: {\n        connection: 'close'\n      }\n    })\n    return {\n      body: await res.arrayBuffer()\n    }\n  })\n}\n\nfunction entityV3FromFolder({\n  folder,\n  addOriginalPath,\n  ignorePattern,\n  customHashMaker\n}: {\n  folder: string\n  addOriginalPath?: boolean\n  ignorePattern?: string\n  customHashMaker?: (str: string) => string\n}): Entity | null {\n  const sceneJsonPath = path.resolve(folder, './scene.json')\n  let isParcelScene = true\n\n  const wearableJsonPath = path.resolve(folder, './wearable.json')\n  if (fs.existsSync(wearableJsonPath)) {\n    try {\n      const wearableJson = JSON.parse(fs.readFileSync(wearableJsonPath).toString())\n      if (!WearableJson.validate(wearableJson)) {\n        const errors = (WearableJson.validate.errors || []).map((a) => `${a.data} ${a.message}`).join('')\n\n        console.error(`Unable to validate wearable.json properly, please check it.`, errors)\n        console.error(`Invalid wearable.json (${wearableJsonPath})`)\n      } else {\n        isParcelScene = false\n      }\n    } catch (err) {\n      console.error(`Unable to load wearable.json properly`, err)\n    }\n  }\n\n  const hashMaker = customHashMaker ? customHashMaker : defaultHashMaker\n\n  if (fs.existsSync(sceneJsonPath) && isParcelScene) {\n    const sceneJson = JSON.parse(fs.readFileSync(sceneJsonPath).toString())\n    const { base, parcels }: { base: string; parcels: string[] } = sceneJson.scene\n    const pointers = new Set<string>()\n    pointers.add(base)\n    parcels.forEach(($) => pointers.add($))\n\n    const mappedFiles = getFilesFromFolder({\n      folder,\n      addOriginalPath,\n      ignorePattern,\n      customHashMaker\n    })\n\n    return {\n      version: 'v3',\n      type: EntityType.SCENE,\n      id: hashMaker(folder),\n      pointers: Array.from(pointers),\n      timestamp: Date.now(),\n      metadata: sceneJson,\n      content: mappedFiles\n    }\n  }\n\n  return null\n}\n\nconst defaultDclIgnore = () =>\n  [\n    '.*',\n    'package.json',\n    'package-lock.json',\n    'yarn-lock.json',\n    'build.json',\n    'export',\n    'tsconfig.json',\n    'tslint.json',\n    'node_modules',\n    '*.ts',\n    '*.tsx',\n    'Dockerfile',\n    'dist',\n    'README.md',\n    '*.blend',\n    '*.fbx',\n    '*.zip',\n    '*.rar'\n  ].join('\\n')\n\nexport function getFilesFromFolder({\n  folder,\n  addOriginalPath,\n  ignorePattern,\n  customHashMaker\n}: {\n  folder: string\n  addOriginalPath?: boolean\n  ignorePattern?: string\n  customHashMaker?: (str: string) => string\n}): ContentMapping[] {\n  const hashMaker = customHashMaker ? customHashMaker : defaultHashMaker\n\n  const allFiles = globSync('**/*', {\n    cwd: folder,\n    dot: false,\n    absolute: true\n  })\n    .map((file) => {\n      try {\n        if (!fs.statSync(file).isFile()) return\n      } catch (err) {\n        return\n      }\n      const _folder = folder.replace(/\\\\/gi, '/')\n      const key = file.replace(_folder, '').replace(/^\\/+/, '')\n      return key\n    })\n    .filter(($) => !!$) as string[]\n\n  const ensureIgnorePattern = ignorePattern && ignorePattern !== '' ? ignorePattern : defaultDclIgnore()\n  const ig = ignore().add(ensureIgnorePattern)\n  const filteredFiles = ig.filter(allFiles)\n\n  const ret: (ContentMapping & { original_path: string | undefined })[] = []\n\n  for (const file of filteredFiles) {\n    const absolutePath = path.resolve(folder, file)\n    try {\n      if (!fs.statSync(absolutePath).isFile()) continue\n    } catch (err) {\n      console.log(err)\n      continue\n    }\n\n    const absoluteFolder = folder.replace(/\\\\/gi, '/')\n\n    const relativeFilePathToFolder = file.replace(absoluteFolder, '').replace(/^\\/+/, '')\n\n    ret.push({\n      file: relativeFilePathToFolder.toLowerCase(),\n      original_path: addOriginalPath ? absolutePath : undefined,\n      hash: hashMaker(absolutePath)\n    })\n  }\n\n  return ret\n}\n"]}
455
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"endpoints.js","sourceRoot":"","sources":["endpoints.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA,2CAA4B;AAC5B,+BAAuC;AACvC,+CAAoD;AACpD,0CAAmF;AACnF,oDAA2B;AAC3B,yDAA2C;AAC3C,yCAAiD;AAEjD,2BAA6B;AAC7B,uDAA6D;AAE7D,SAAS,cAAc;IACrB,OAAO,IAAI,GAAG,CAAC,+BAA+B,CAAC,CAAA;AACjD,CAAC;AAED,SAAS,qBAAqB,CAAC,IAAY;IACzC,OAAO,IAAI,CAAC,iBAAiB,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAAA;AACpD,CAAC;AAMD,SAAgB,kBAAkB,CAAC,UAAyB,EAAE,GAAW,EAAE,MAAiC;IAC1G,MAAM,WAAW,GAAG,CAAC,GAAG,CAAC,CAAA;IAEzB,MAAM,CAAC,GAAG,CAAC,aAAa,EAAE,KAAK,IAAI,EAAE;QACnC,OAAO;YACL,OAAO,EAAE,EAAE,cAAc,EAAE,kBAAkB,EAAE;YAC/C,IAAI,EAAE,UAAU,CAAC,EAAE,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,YAAY,CAAC,CAAC;SACnE,CAAA;IACH,CAAC,CAAC,CAAA;IAEF,MAAM,CAAC,GAAG,CAAC,yBAAyB,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE;QAClD,OAAO;YACL,IAAI,EAAE;gBACJ;oBACE,UAAU,EAAE,WAAW;oBACvB,GAAG,EAAE,UAAU,GAAG,CAAC,GAAG,CAAC,IAAI,EAAE;oBAC7B,KAAK,EAAE,MAAM;oBACb,UAAU,EAAE,CAAC;oBACb,QAAQ,EAAE,GAAG;oBACb,WAAW,EAAE,EAAE;iBAChB;aACF;SACF,CAAA;IACH,CAAC,CAAC,CAAA;IAEF,MAAM,CAAC,GAAG,CAAC,4BAA4B,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE;QACrD,OAAO;YACL,IAAI,EAAE;gBACJ;oBACE,OAAO,EAAE,UAAU,GAAG,CAAC,GAAG,CAAC,IAAI,EAAE;oBACjC,KAAK,EAAE,4CAA4C;oBACnD,EAAE,EAAE,oEAAoE;iBACzE;aACF;SACF,CAAA;IACH,CAAC,CAAC,CAAA;IAEF,MAAM,CAAC,GAAG,CAAC,mBAAmB,EAAE,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;QAClD,MAAM,OAAO,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,QAAQ,KAAK,GAAG,CAAC,GAAG,CAAC,IAAI,mBAAmB,CAAA;QAEvE,IAAI;YACF,MAAM,gBAAgB,GAAG,MAAM,sBAAsB,CAAC,UAAU,EAAE;gBAChE,WAAW;gBACX,OAAO;aACR,CAAC,CAAA;YAEF,IAAI,gBAAgB,CAAC,MAAM,KAAK,CAAC,EAAE;gBACjC,MAAM,WAAW,GAAG,cAAc,EAAE,CAAA;gBAEpC,MAAM,CAAC,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAA;gBACrC,CAAC,CAAC,IAAI,GAAG,WAAW,CAAC,IAAI,CAAA;gBACzB,CAAC,CAAC,QAAQ,GAAG,WAAW,CAAC,QAAQ,CAAA;gBACjC,CAAC,CAAC,IAAI,GAAG,WAAW,CAAC,IAAI,CAAA;gBACzB,MAAM,GAAG,GAAG,MAAM,IAAA,oBAAK,EAAC,CAAC,CAAC,QAAQ,EAAE,EAAE;oBACpC,OAAO,EAAE;wBACP,UAAU,EAAE,OAAO;qBACpB;oBACD,MAAM,EAAE,GAAG,CAAC,OAAO,CAAC,MAAM;oBAC1B,IAAI,EAAE,GAAG,CAAC,OAAO,CAAC,MAAM,KAAK,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI;iBAClE,CAAC,CAAA;gBAEF,MAAM,eAAe,GAAG,CAAC,MAAM,GAAG,CAAC,IAAI,EAAE,CAAU,CAAA;gBAEnD,IAAI,CAAA,eAAe,aAAf,eAAe,uBAAf,eAAe,CAAE,MAAM,MAAK,CAAC,EAAE;oBACjC,eAAe,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;oBACzF,OAAO;wBACL,OAAO,EAAE;4BACP,cAAc,EAAE,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,IAAI,oBAAoB;yBACxE;wBACD,IAAI,EAAE,eAAe;qBACtB,CAAA;iBACF;aACF;SACF;QAAC,OAAO,GAAG,EAAE;YACZ,OAAO,CAAC,IAAI,CAAC,0DAA0D,EAAE,GAAG,CAAC,CAAA;SAC9E;QAED,OAAO,IAAI,EAAE,CAAA;IACf,CAAC,CAAC,CAAA;IAEF,MAAM,CAAC,GAAG,CAAC,iBAAiB,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE;QAC1C,MAAM,WAAW,GAAG,cAAc,EAAE,CAAA;QACpC,MAAM,CAAC,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAA;QACrC,CAAC,CAAC,IAAI,GAAG,WAAW,CAAC,IAAI,CAAA;QACzB,CAAC,CAAC,QAAQ,GAAG,WAAW,CAAC,QAAQ,CAAA;QACjC,CAAC,CAAC,IAAI,GAAG,WAAW,CAAC,IAAI,CAAA;QACzB,MAAM,GAAG,GAAG,MAAM,IAAA,oBAAK,EAAC,CAAC,CAAC,QAAQ,EAAE,EAAE;YACpC,OAAO,EAAE;gBACP,UAAU,EAAE,OAAO;aACpB;YACD,MAAM,EAAE,GAAG,CAAC,OAAO,CAAC,MAAM;YAC1B,IAAI,EAAE,GAAG,CAAC,OAAO,CAAC,MAAM,KAAK,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI;SAClE,CAAC,CAAA;QAEF,OAAO;YACL,OAAO,EAAE;gBACP,cAAc,EAAE,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,IAAI,oBAAoB;aACxE;YACD,IAAI,EAAE,GAAG,CAAC,IAAI;SACf,CAAA;IACH,CAAC,CAAC,CAAA;IAEF,MAAM,CAAC,IAAI,CAAC,mBAAmB,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE;QAC7C,MAAM,WAAW,GAAG,cAAc,EAAE,CAAA;QACpC,MAAM,OAAO,GAAG,IAAI,oBAAO,EAAE,CAAA;QAC7B,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,OAAO,CAAC,OAAO,CAAC,CAAA;QAChC,MAAM,GAAG,GAAG,MAAM,IAAA,oBAAK,EAAC,GAAG,WAAW,CAAC,QAAQ,EAAE,mBAAmB,EAAE;YACpE,MAAM,EAAE,MAAM;YACd,OAAO;YACP,IAAI,EAAE,GAAG,CAAC,OAAO,CAAC,IAAI;SACvB,CAAC,CAAA;QAEF,OAAO,GAAG,CAAA;IACZ,CAAC,CAAC,CAAA;IAEF,WAAW,CAAC,UAAU,EAAE,GAAG,EAAE,MAAM,CAAC,CAAA;IAIpC,YAAY,CAAC,UAAU,EAAE,MAAM,EAAE,WAAW,CAAC,CAAA;AAC/C,CAAC;AAxHD,gDAwHC;AAED,SAAS,YAAY,CAAC,UAAqC,EAAE,MAAiC,EAAE,WAAqB;IACnH,MAAM,CAAC,GAAG,CAAC,yBAAyB,EAAE,KAAK,EAAE,GAAQ,EAAE,IAAS,EAAE,EAAE;QAClE,IAAI,GAAG,CAAC,MAAM,CAAC,IAAI,IAAI,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE;YACzD,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,EAAE,QAAQ,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAA;YAG3G,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,MAAc,EAAE,EAAE,CAAC,QAAQ,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,EAAE;gBACtE,OAAO,IAAI,EAAE,CAAA;aACd;YAED,OAAO;gBACL,OAAO,EAAE;oBACP,aAAa,EAAE,IAAI,CAAC,GAAG,EAAE;oBACzB,QAAQ,EAAE,IAAI;oBACd,eAAe,EAAE,4BAA4B;iBAC9C;gBACD,IAAI,EAAE,UAAU,CAAC,EAAE,CAAC,gBAAgB,CAAC,QAAQ,CAAC;aAC/C,CAAA;SACF;QAED,OAAO,IAAI,EAAE,CAAA;IACf,CAAC,CAAC,CAAA;IAEF,KAAK,UAAU,qBAAqB,CAAC,QAAkB;QACrD,IAAI,CAAC,QAAQ,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;YACtC,OAAO,EAAE,CAAA;SACV;QAED,MAAM,iBAAiB,GAAG,IAAI,GAAG,CAC/B,QAAQ,IAAI,OAAO,QAAQ,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAkB,CAAC,CAAC,CAAC,CAAE,QAAqB,CACzF,CAAA;QAED,MAAM,cAAc,GAAG,MAAM,YAAY,CAAC,UAAU,EAAE;YACpD,WAAW;YACX,QAAQ,EAAE,KAAK,CAAC,IAAI,CAAC,iBAAiB,CAAC;SACxC,CAAC,CAAA;QACF,MAAM,WAAW,GAAG,cAAc,EAAE,CAAA;QACpC,MAAM,MAAM,GAAG,IAAA,+BAAoB,EACjC,WAAW,CAAC,QAAQ,EAAE,EACtB,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC,CACxD,CAAA;QAED,MAAM,cAAc,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAA;QAE1D,OAAO,CAAC,GAAG,cAAc,EAAE,GAAG,cAAc,CAAC,CAAA;IAC/C,CAAC;IAGD,MAAM,CAAC,GAAG,CAAC,yBAAyB,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE;QAClD,OAAO;YACL,IAAI,EAAE,MAAM,qBAAqB,CAAC,GAAG,CAAC,GAAG,CAAC,YAAY,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;SAC1E,CAAA;IACH,CAAC,CAAC,CAAA;IAGF,MAAM,CAAC,IAAI,CAAC,0BAA0B,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE;QACpD,MAAM,IAAI,GAAG,MAAM,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,CAAA;QACrC,OAAO;YACL,IAAI,EAAE,MAAM,qBAAqB,CAAC,IAAI,CAAC,QAAQ,CAAC;SACjD,CAAA;IACH,CAAC,CAAC,CAAA;IAEF,MAAM,CAAC,GAAG,CAAC,wBAAwB,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE;QACjD,MAAM,OAAO,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,QAAQ,KAAK,GAAG,CAAC,GAAG,CAAC,IAAI,mBAAmB,CAAA;QACvE,MAAM,SAAS,GAAG,MAAM,sBAAsB,CAAC,UAAU,EAAE;YACzD,OAAO;YACP,WAAW;SACZ,CAAC,CAAA;QACF,MAAM,UAAU,GAAG,GAAG,CAAC,MAAM,CAAC,EAAE,CAAA;QAChC,OAAO;YACL,IAAI,EAAE;gBACJ,EAAE,EAAE,IAAI;gBACR,IAAI,EAAE,SAAS,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,qBAAqB,CAAC,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,IAAI,CAAC,KAAK,UAAU,CAAC;aAC3F;SACF,CAAA;IACH,CAAC,CAAC,CAAA;IAEF,MAAM,CAAC,GAAG,CAAC,oBAAoB,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE;QAC7C,MAAM,OAAO,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,QAAQ,KAAK,GAAG,CAAC,GAAG,CAAC,IAAI,mBAAmB,CAAA;QACvE,OAAO;YACL,IAAI,EAAE;gBACJ,EAAE,EAAE,IAAI;gBACR,IAAI,EAAE,MAAM,sBAAsB,CAAC,UAAU,EAAE,EAAE,OAAO,EAAE,WAAW,EAAE,CAAC;aACzE;SACF,CAAA;IACH,CAAC,CAAC,CAAA;AACJ,CAAC;AAED,MAAM,gBAAgB,GAAG,CAAC,GAAW,EAAE,EAAE,CAAC,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAA;AAEtF,KAAK,UAAU,sBAAsB,CACnC,UAAqC,EACrC,EAAE,WAAW,EAAE,OAAO,EAA8C;IAEpE,MAAM,iBAAiB,GAAa,EAAE,CAAA;IACtC,KAAK,MAAM,WAAW,IAAI,WAAW,EAAE;QACrC,MAAM,gBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,eAAe,CAAC,CAAA;QACnE,IAAI,MAAM,UAAU,CAAC,EAAE,CAAC,UAAU,CAAC,gBAAgB,CAAC,EAAE;YACpD,iBAAiB,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAA;SACzC;KACF;IAED,MAAM,GAAG,GAAsB,EAAE,CAAA;IACjC,KAAK,MAAM,gBAAgB,IAAI,iBAAiB,EAAE;QAChD,IAAI;YACF,GAAG,CAAC,IAAI,CAAC,MAAM,aAAa,CAAC,UAAU,EAAE,EAAE,gBAAgB,EAAE,OAAO,EAAE,CAAC,CAAC,CAAA;SACzE;QAAC,OAAO,GAAG,EAAE;YACZ,OAAO,CAAC,KAAK,CAAC,8BAA8B,gBAAgB,gDAAgD,EAAE,GAAG,CAAC,CAAA;SACnH;KACF;IACD,OAAO,GAAG,CAAA;AACZ,CAAC;AAED,KAAK,UAAU,aAAa,CAC1B,UAAqC,EACrC,EAAE,gBAAgB,EAAE,OAAO,EAAiD;;IAE5E,MAAM,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAA;IAClD,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,UAAU,CAAC,EAAE,CAAC,QAAQ,CAAC,gBAAgB,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAA;IAE5F,IAAI,CAAC,kBAAY,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE;QACxC,MAAM,MAAM,GAAG,CAAC,kBAAY,CAAC,QAAQ,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QAEjG,OAAO,CAAC,KAAK,CAAC,6DAA6D,EAAE,MAAM,CAAC,CAAA;QACpF,MAAM,IAAI,KAAK,CAAC,0BAA0B,gBAAgB,GAAG,CAAC,CAAA;KAC/D;IAED,MAAM,WAAW,GAAG,MAAM,kBAAkB,CAAC,UAAU,EAAE;QACvD,MAAM,EAAE,WAAW;QACnB,eAAe,EAAE,KAAK;KACvB,CAAC,CAAA;IAEF,MAAM,iBAAiB,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAA,CAAC,aAAD,CAAC,uBAAD,CAAC,CAAE,IAAI,MAAK,eAAe,CAAC,CAAA;IAChF,MAAM,SAAS,GACb,iBAAiB,CAAC,MAAM,GAAG,CAAC,KAAI,MAAA,iBAAiB,CAAC,CAAC,CAAC,0CAAE,IAAI,CAAA,IAAI,GAAG,OAAO,IAAI,iBAAiB,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAA;IAEzG,MAAM,UAAU,GAAG,0CAA0C,CAAA;IAE7D,MAAM,eAAe,GAAG,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,cAAc,EAAE,EAAE,CAAC,iCAC7E,cAAc,KACjB,QAAQ,EAAE,QAAQ,cAAc,CAAC,QAAQ,EAAE,EAC3C,QAAQ,EAAE,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YAChC,GAAG,EAAE,QAAQ,CAAC,aAAD,CAAC,uBAAD,CAAC,CAAE,IAAI,EAAE;YACtB,GAAG,EAAE,GAAG,OAAO,IAAI,CAAC,aAAD,CAAC,uBAAD,CAAC,CAAE,IAAI,EAAE;YAC5B,IAAI,EAAE,CAAC,aAAD,CAAC,uBAAD,CAAC,CAAE,IAAI;SACd,CAAC,CAAC,IACH,CAAC,CAAA;IAEH,OAAO;QACL,EAAE,EAAE,UAAU;QACd,MAAM,EAAE,YAAY,CAAC,MAAM;QAC3B,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,IAAc,EAAE,IAAI,EAAE,YAAY,CAAC,IAAI,EAAE,CAAC;QACzD,WAAW,EAAE,YAAY,CAAC,WAAW;QACrC,SAAS,EAAE,SAAS,IAAI,EAAE;QAC1B,KAAK,EAAE,SAAS,IAAI,EAAE;QACtB,iBAAiB,EAAE,KAAK;QACxB,OAAO,EAAE,GAAG,OAAO,GAAG;QACtB,IAAI,EAAE,YAAY,CAAC,IAAI,IAAI,EAAE;QAC7B,IAAI,EAAE;YACJ,QAAQ,EAAE,YAAY,CAAC,IAAI,CAAC,QAAQ;YACpC,QAAQ,EAAE,EAAE;YACZ,KAAK,EAAE,EAAE;YACT,IAAI,EAAE,EAAE;YACR,eAAe,EAAE,eAAsB;SAExC;KACF,CAAA;AACH,CAAC;AAED,KAAK,UAAU,YAAY,CACzB,UAAqC,EACrC,EACE,WAAW,EACX,QAAQ,EACR,eAAe,EAKhB;IAED,MAAM,iBAAiB,GAAG,IAAI,GAAG,CAAS,QAAQ,CAAC,CAAA;IACnD,MAAM,cAAc,GAAa,EAAE,CAAA;IAEnC,MAAM,cAAc,GAAG,MAAM,OAAO,CAAC,GAAG,CACtC,WAAW,CAAC,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE;QAC/B,OAAO,kBAAkB,CAAC,UAAU,EAAE;YACpC,MAAM;YACN,eAAe,EAAE,KAAK;YACtB,eAAe;SAChB,CAAC,CAAA;IACJ,CAAC,CAAC,CACH,CAAA;IAED,KAAK,MAAM,OAAO,IAAI,KAAK,CAAC,IAAI,CAAC,iBAAiB,CAAC,EAAE;QAEnD,MAAM,aAAa,GAAG,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAA;QACnF,IAAI,aAAa,EAAE;YAGjB,aAAa,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAA;YAGlE,cAAc,CAAC,IAAI,CAAC,aAAa,CAAC,CAAA;SACnC;KACF;IAED,OAAO,cAAc,CAAA;AACvB,CAAC;AAED,SAAS,WAAW,CAAC,UAAqC,EAAE,GAAW,EAAE,MAAiC;IACxG,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAC1B,OAAO,CAAC,OAAO,CAAC,uBAAuB,EAAE;QACvC,KAAK,EAAE,CAAC,GAAG,CAAC;KACb,CAAC,CACH,CAAA;IACD,MAAM,mBAAmB,GAAG,IAAI,CAAC,OAAO,CACtC,OAAO,CAAC,OAAO,CAAC,4BAA4B,EAAE;QAC5C,KAAK,EAAE,CAAC,GAAG,EAAE,OAAO,CAAC;KACtB,CAAC,CACH,CAAA;IAED,MAAM,2BAA2B,GAAG,IAAI,CAAC,OAAO,CAAC,mBAAmB,EAAE,iBAAiB,CAAC,CAAA;IACxF,MAAM,kCAAkC,GAAG,IAAI,CAAC,OAAO,CAAC,mBAAmB,EAAE,QAAQ,EAAE,sBAAsB,CAAC,CAAA;IAE9G,MAAM,MAAM,GAAG;QACb;YACE,KAAK,EAAE,GAAG;YACV,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,mBAAmB,EAAE,cAAc,CAAC;YACvD,IAAI,EAAE,WAAW;SAClB;QACD;YACE,KAAK,EAAE,cAAc;YACrB,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,mBAAmB,EAAE,aAAa,CAAC;YACtD,IAAI,EAAE,WAAW;SAClB;QACD;YACE,KAAK,EAAE,sBAAsB;YAC7B,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,mBAAmB,EAAE,UAAU,CAAC;YACnD,IAAI,EAAE,iBAAiB;SACxB;KACF,CAAA;IAED,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE;QAC1B,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;YACrC,OAAO;gBACL,OAAO,EAAE,EAAE,cAAc,EAAE,KAAK,CAAC,IAAI,EAAE;gBACvC,IAAI,EAAE,UAAU,CAAC,EAAE,CAAC,gBAAgB,CAAC,KAAK,CAAC,IAAI,CAAC;aACjD,CAAA;QACH,CAAC,CAAC,CAAA;KACH;IAED,SAAS,kBAAkB,CACzB,UAAqC,EACrC,KAAa,EACb,MAAc,EACd,YAAY,CAAC,GAAW,EAAE,EAAE,CAAC,GAAG;QAEhC,MAAM,CAAC,GAAG,CAAC,KAAK,EAAE,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;YACpC,MAAM,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC,IAAI,CAAA;YAC5B,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,SAAS,CAAC,IAAI,CAAC,CAAC,CAAA;YAGtD,IAAI,CAAC,CAAC,MAAM,UAAU,CAAC,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,EAAE;gBAC/C,OAAO,IAAI,EAAE,CAAA;aACd;YAED,MAAM,OAAO,GAAwB;gBACnC,aAAa,EAAE,IAAI,CAAC,GAAG,EAAE;gBACzB,QAAQ,EAAE,IAAI;gBACd,eAAe,EAAE,4BAA4B;aAC9C,CAAA;YAED,IAAI,QAAQ,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;gBAC9B,OAAO,CAAC,cAAc,CAAC,GAAG,kBAAkB,CAAA;aAC7C;YAED,OAAO;gBACL,OAAO;gBACP,IAAI,EAAE,UAAU,CAAC,EAAE,CAAC,gBAAgB,CAAC,QAAQ,CAAC;aAC/C,CAAA;QACH,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,kBAAkB,CAAC,UAAU,EAAE,qCAAqC,EAAE,kCAAkC,CAAC,CAAA;IACzG,kBAAkB,CAAC,UAAU,EAAE,yBAAyB,EAAE,2BAA2B,CAAC,CAAA;IACtF,kBAAkB,CAAC,UAAU,EAAE,oBAAoB,EAAE,mBAAmB,EAAE,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAA;IAEtH,MAAM,CAAC,GAAG,CAAC,sBAAsB,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE;QAC/C,MAAM,GAAG,GAAG,MAAM,IAAA,oBAAK,EAAC,2CAA2C,GAAG,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE;YACpF,OAAO,EAAE;gBACP,UAAU,EAAE,OAAO;aACpB;SACF,CAAC,CAAA;QACF,OAAO;YACL,IAAI,EAAE,MAAM,GAAG,CAAC,WAAW,EAAE;SAC9B,CAAA;IACH,CAAC,CAAC,CAAA;AACJ,CAAC;AAED,KAAK,UAAU,kBAAkB,CAC/B,UAAqC,EACrC,EACE,MAAM,EACN,eAAe,EACf,eAAe,EAKhB;IAED,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,cAAc,CAAC,CAAA;IAC1D,IAAI,aAAa,GAAG,IAAI,CAAA;IAExB,MAAM,gBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,iBAAiB,CAAC,CAAA;IAChE,IAAI,MAAM,UAAU,CAAC,EAAE,CAAC,UAAU,CAAC,gBAAgB,CAAC,EAAE;QACpD,IAAI;YACF,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,UAAU,CAAC,EAAE,CAAC,QAAQ,CAAC,gBAAgB,EAAE,OAAO,CAAC,CAAC,CAAA;YACxF,IAAI,CAAC,kBAAY,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE;gBACxC,MAAM,MAAM,GAAG,CAAC,kBAAY,CAAC,QAAQ,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;gBAEjG,OAAO,CAAC,KAAK,CAAC,6DAA6D,EAAE,MAAM,CAAC,CAAA;gBACpF,OAAO,CAAC,KAAK,CAAC,0BAA0B,gBAAgB,GAAG,CAAC,CAAA;aAC7D;iBAAM;gBACL,aAAa,GAAG,KAAK,CAAA;aACtB;SACF;QAAC,OAAO,GAAG,EAAE;YACZ,OAAO,CAAC,KAAK,CAAC,uCAAuC,EAAE,GAAG,CAAC,CAAA;SAC5D;KACF;IAED,MAAM,SAAS,GAAG,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,gBAAgB,CAAA;IAEtE,IAAI,CAAC,MAAM,UAAU,CAAC,EAAE,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,IAAI,aAAa,EAAE;QACpE,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,UAAU,CAAC,EAAE,CAAC,QAAQ,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC,CAAA;QAClF,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,GAAwC,SAAS,CAAC,KAAK,CAAA;QAC9E,MAAM,QAAQ,GAAG,IAAI,GAAG,EAAU,CAAA;QAClC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;QAClB,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAA;QAEvC,MAAM,WAAW,GAAG,MAAM,kBAAkB,CAAC,UAAU,EAAE;YACvD,MAAM;YACN,eAAe;YACf,eAAe;SAChB,CAAC,CAAA;QAEF,OAAO;YACL,OAAO,EAAE,IAAI;YACb,IAAI,EAAE,oBAAU,CAAC,KAAK;YACtB,EAAE,EAAE,SAAS,CAAC,MAAM,CAAC;YACrB,QAAQ,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC;YAC9B,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;YACrB,QAAQ,EAAE,SAAS;YACnB,OAAO,EAAE,WAAW;SACrB,CAAA;KACF;IAED,OAAO,IAAI,CAAA;AACb,CAAC;AAEM,KAAK,UAAU,kBAAkB,CACtC,UAAqC,EACrC,EACE,MAAM,EACN,eAAe,EACf,eAAe,EAKhB;IAED,MAAM,SAAS,GAAG,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,gBAAgB,CAAA;IACtE,MAAM,cAAc,GAAG,MAAM,IAAA,iCAAoB,EAAC,UAAU,EAAE,MAAM,CAAC,CAAA;IAErE,MAAM,QAAQ,GAAG,IAAA,WAAQ,EAAC,MAAM,EAAE;QAChC,MAAM,EAAE,cAAc;QACtB,GAAG,EAAE,MAAM;QACX,GAAG,EAAE,KAAK;QACV,QAAQ,EAAE,IAAI;KACf,CAAC;SACC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;QACZ,IAAI;YACF,IAAI,CAAC,IAAA,aAAQ,EAAC,IAAI,CAAC,CAAC,MAAM,EAAE;gBAAE,OAAM;SACrC;QAAC,OAAO,GAAG,EAAE;YACZ,OAAM;SACP;QACD,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;QAC3C,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAA;QACzD,OAAO,GAAG,CAAA;IACZ,CAAC,CAAC;SACD,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAa,CAAA;IAEjC,MAAM,EAAE,GAAG,IAAA,gBAAM,GAAE,CAAC,GAAG,CAAC,cAAc,CAAC,CAAA;IACvC,MAAM,aAAa,GAAG,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAA;IAEzC,MAAM,GAAG,GAA+D,EAAE,CAAA;IAE1E,KAAK,MAAM,IAAI,IAAI,aAAa,EAAE;QAChC,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,CAAA;QAC/C,IAAI;YACF,IAAI,CAAC,IAAA,aAAQ,EAAC,YAAY,CAAC,CAAC,MAAM,EAAE;gBAAE,SAAQ;SAC/C;QAAC,OAAO,GAAG,EAAE;YACZ,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;YAClB,SAAQ;SACT;QAED,MAAM,cAAc,GAAG,MAAM,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;QAElD,MAAM,wBAAwB,GAAG,IAAI,CAAC,OAAO,CAAC,cAAc,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAA;QAErF,GAAG,CAAC,IAAI,CAAC;YACP,IAAI,EAAE,wBAAwB,CAAC,WAAW,EAAE;YAC5C,aAAa,EAAE,eAAe,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS;YACzD,IAAI,EAAE,SAAS,CAAC,YAAY,CAAC;SAC9B,CAAC,CAAA;KACH;IAED,OAAO,GAAG,CAAA;AACZ,CAAC;AA3DD,gDA2DC","sourcesContent":["import { Router } from '@well-known-components/http-server'\nimport { PreviewComponents } from './types'\nimport * as path from 'path'\nimport { sync as globSync } from 'glob'\nimport { WearableJson } from '@dcl/schemas/dist/sdk'\nimport { ContentMapping, Entity, EntityType, Locale, Wearable } from '@dcl/schemas'\nimport ignore from 'ignore'\nimport fetch, { Headers } from 'node-fetch'\nimport { fetchEntityByPointer } from './catalyst'\nimport { CliComponents } from '../../components'\nimport { statSync } from 'fs'\nimport { getDCLIgnorePatterns } from '../../utils/dcl-ignore'\n\nfunction getCatalystUrl(): URL {\n  return new URL('https://peer.decentraland.org')\n}\n\nfunction smartWearableNameToId(name: string) {\n  return name.toLocaleLowerCase().replace(/ /g, '-')\n}\n\ntype LambdasWearable = Wearable & {\n  baseUrl: string\n}\n\nexport function setupEcs6Endpoints(components: CliComponents, dir: string, router: Router<PreviewComponents>) {\n  const baseFolders = [dir]\n  // handle old preview scene.json\n  router.get('/scene.json', async () => {\n    return {\n      headers: { 'content-type': 'application/json' },\n      body: components.fs.createReadStream(path.join(dir, 'scene.json'))\n    }\n  })\n\n  router.get('/lambdas/explore/realms', async (ctx) => {\n    return {\n      body: [\n        {\n          serverName: 'localhost',\n          url: `http://${ctx.url.host}`,\n          layer: 'stub',\n          usersCount: 0,\n          maxUsers: 100,\n          userParcels: []\n        }\n      ]\n    }\n  })\n\n  router.get('/lambdas/contracts/servers', async (ctx) => {\n    return {\n      body: [\n        {\n          address: `http://${ctx.url.host}`,\n          owner: '0x0000000000000000000000000000000000000000',\n          id: '0x0000000000000000000000000000000000000000000000000000000000000000'\n        }\n      ]\n    }\n  })\n\n  router.get('/lambdas/profiles', async (ctx, next) => {\n    const baseUrl = `${ctx.url.protocol}//${ctx.url.host}/content/contents`\n\n    try {\n      const previewWearables = await getAllPreviewWearables(components, {\n        baseFolders,\n        baseUrl\n      })\n\n      if (previewWearables.length === 1) {\n        const catalystUrl = getCatalystUrl()\n\n        const u = new URL(ctx.url.toString())\n        u.host = catalystUrl.host\n        u.protocol = catalystUrl.protocol\n        u.port = catalystUrl.port\n        const req = await fetch(u.toString(), {\n          headers: {\n            connection: 'close'\n          },\n          method: ctx.request.method,\n          body: ctx.request.method === 'get' ? undefined : ctx.request.body\n        })\n\n        const deployedProfile = (await req.json()) as any[]\n\n        if (deployedProfile?.length === 1) {\n          deployedProfile[0].avatars[0].avatar.wearables.push(...previewWearables.map(($) => $.id))\n          return {\n            headers: {\n              'content-type': req.headers.get('content-type') || 'application/binary'\n            },\n            body: deployedProfile\n          }\n        }\n      }\n    } catch (err) {\n      console.warn(`Failed to catch profile and fill with preview wearables.`, err)\n    }\n\n    return next()\n  })\n\n  router.all('/lambdas/:path+', async (ctx) => {\n    const catalystUrl = getCatalystUrl()\n    const u = new URL(ctx.url.toString())\n    u.host = catalystUrl.host\n    u.protocol = catalystUrl.protocol\n    u.port = catalystUrl.port\n    const req = await fetch(u.toString(), {\n      headers: {\n        connection: 'close'\n      },\n      method: ctx.request.method,\n      body: ctx.request.method === 'get' ? undefined : ctx.request.body\n    })\n\n    return {\n      headers: {\n        'content-type': req.headers.get('content-type') || 'application/binary'\n      },\n      body: req.body\n    }\n  })\n\n  router.post('/content/entities', async (ctx) => {\n    const catalystUrl = getCatalystUrl()\n    const headers = new Headers()\n    console.log(ctx.request.headers)\n    const res = await fetch(`${catalystUrl.toString()}/content/entities`, {\n      method: 'post',\n      headers,\n      body: ctx.request.body\n    })\n\n    return res\n  })\n\n  serveStatic(components, dir, router)\n\n  // TODO: get workspace scenes & wearables...\n\n  serveFolders(components, router, baseFolders)\n}\n\nfunction serveFolders(components: Pick<CliComponents, 'fs'>, router: Router<PreviewComponents>, baseFolders: string[]) {\n  router.get('/content/contents/:hash', async (ctx: any, next: any) => {\n    if (ctx.params.hash && ctx.params.hash.startsWith('b64-')) {\n      const fullPath = path.resolve(Buffer.from(ctx.params.hash.replace(/^b64-/, ''), 'base64').toString('utf8'))\n\n      // only return files IF the file is within a baseFolder\n      if (!baseFolders.find((folder: string) => fullPath.startsWith(folder))) {\n        return next()\n      }\n\n      return {\n        headers: {\n          'x-timestamp': Date.now(),\n          'x-sent': true,\n          'cache-control': 'no-cache,private,max-age=1'\n        },\n        body: components.fs.createReadStream(fullPath)\n      }\n    }\n\n    return next()\n  })\n\n  async function pointerRequestHandler(pointers: string[]) {\n    if (!pointers || pointers.length === 0) {\n      return []\n    }\n\n    const requestedPointers = new Set<string>(\n      pointers && typeof pointers === 'string' ? [pointers as string] : (pointers as string[])\n    )\n\n    const resultEntities = await getSceneJson(components, {\n      baseFolders,\n      pointers: Array.from(requestedPointers)\n    })\n    const catalystUrl = getCatalystUrl()\n    const remote = fetchEntityByPointer(\n      catalystUrl.toString(),\n      pointers.filter(($: string) => !$.match(/-?\\d+,-?\\d+/))\n    )\n\n    const serverEntities = Array.isArray(remote) ? remote : []\n\n    return [...resultEntities, ...serverEntities]\n  }\n\n  // REVIEW RESPONSE FORMAT\n  router.get('/content/entities/scene', async (ctx) => {\n    return {\n      body: await pointerRequestHandler(ctx.url.searchParams.getAll('pointer'))\n    }\n  })\n\n  // REVIEW RESPONSE FORMAT\n  router.post('/content/entities/active', async (ctx) => {\n    const body = await ctx.request.json()\n    return {\n      body: await pointerRequestHandler(body.pointers)\n    }\n  })\n\n  router.get('/preview-wearables/:id', async (ctx) => {\n    const baseUrl = `${ctx.url.protocol}//${ctx.url.host}/content/contents`\n    const wearables = await getAllPreviewWearables(components, {\n      baseUrl,\n      baseFolders\n    })\n    const wearableId = ctx.params.id\n    return {\n      body: {\n        ok: true,\n        data: wearables.filter((wearable) => smartWearableNameToId(wearable?.name) === wearableId)\n      }\n    }\n  })\n\n  router.get('/preview-wearables', async (ctx) => {\n    const baseUrl = `${ctx.url.protocol}//${ctx.url.host}/content/contents`\n    return {\n      body: {\n        ok: true,\n        data: await getAllPreviewWearables(components, { baseUrl, baseFolders })\n      }\n    }\n  })\n}\n\nconst defaultHashMaker = (str: string) => 'b64-' + Buffer.from(str).toString('base64')\n\nasync function getAllPreviewWearables(\n  components: Pick<CliComponents, 'fs'>,\n  { baseFolders, baseUrl }: { baseFolders: string[]; baseUrl: string }\n) {\n  const wearablePathArray: string[] = []\n  for (const wearableDir of baseFolders) {\n    const wearableJsonPath = path.resolve(wearableDir, 'wearable.json')\n    if (await components.fs.fileExists(wearableJsonPath)) {\n      wearablePathArray.push(wearableJsonPath)\n    }\n  }\n\n  const ret: LambdasWearable[] = []\n  for (const wearableJsonPath of wearablePathArray) {\n    try {\n      ret.push(await serveWearable(components, { wearableJsonPath, baseUrl }))\n    } catch (err) {\n      console.error(`Couldn't mock the wearable ${wearableJsonPath}. Please verify the correct format and scheme.`, err)\n    }\n  }\n  return ret\n}\n\nasync function serveWearable(\n  components: Pick<CliComponents, 'fs'>,\n  { wearableJsonPath, baseUrl }: { wearableJsonPath: string; baseUrl: string }\n): Promise<LambdasWearable> {\n  const wearableDir = path.dirname(wearableJsonPath)\n  const wearableJson = JSON.parse((await components.fs.readFile(wearableJsonPath)).toString())\n\n  if (!WearableJson.validate(wearableJson)) {\n    const errors = (WearableJson.validate.errors || []).map((a) => `${a.data} ${a.message}`).join('')\n\n    console.error(`Unable to validate wearable.json properly, please check it.`, errors)\n    throw new Error(`Invalid wearable.json (${wearableJsonPath})`)\n  }\n\n  const hashedFiles = await getFilesFromFolder(components, {\n    folder: wearableDir,\n    addOriginalPath: false\n  })\n\n  const thumbnailFiltered = hashedFiles.filter(($) => $?.file === 'thumbnail.png')\n  const thumbnail =\n    thumbnailFiltered.length > 0 && thumbnailFiltered[0]?.hash && `${baseUrl}/${thumbnailFiltered[0].hash}`\n\n  const wearableId = 'urn:8dc2d7ad-97e3-44d0-ba89-e8305d795a6a'\n\n  const representations = wearableJson.data.representations.map((representation) => ({\n    ...representation,\n    mainFile: `male/${representation.mainFile}`,\n    contents: hashedFiles.map(($) => ({\n      key: `male/${$?.file}`,\n      url: `${baseUrl}/${$?.hash}`,\n      hash: $?.hash\n    }))\n  }))\n\n  return {\n    id: wearableId,\n    rarity: wearableJson.rarity,\n    i18n: [{ code: 'en' as Locale, text: wearableJson.name }],\n    description: wearableJson.description,\n    thumbnail: thumbnail || '',\n    image: thumbnail || '',\n    collectionAddress: '0x0',\n    baseUrl: `${baseUrl}/`,\n    name: wearableJson.name || '',\n    data: {\n      category: wearableJson.data.category,\n      replaces: [],\n      hides: [],\n      tags: [],\n      representations: representations as any\n      // scene: hashedFiles as any,\n    }\n  }\n}\n\nasync function getSceneJson(\n  components: Pick<CliComponents, 'fs'>,\n  {\n    baseFolders,\n    pointers,\n    customHashMaker\n  }: {\n    baseFolders: string[]\n    pointers: string[]\n    customHashMaker?: (str: string) => string\n  }\n): Promise<Entity[]> {\n  const requestedPointers = new Set<string>(pointers)\n  const resultEntities: Entity[] = []\n\n  const allDeployments = await Promise.all(\n    baseFolders.map(async (folder) => {\n      return entityV3FromFolder(components, {\n        folder,\n        addOriginalPath: false,\n        customHashMaker\n      })\n    })\n  )\n\n  for (const pointer of Array.from(requestedPointers)) {\n    // get deployment by pointer\n    const theDeployment = allDeployments.find(($) => $ && $.pointers.includes(pointer))\n    if (theDeployment) {\n      // remove all the required pointers from the requestedPointers set\n      // to prevent sending duplicated entities\n      theDeployment.pointers.forEach(($) => requestedPointers.delete($))\n\n      // add the deployment to the results\n      resultEntities.push(theDeployment)\n    }\n  }\n\n  return resultEntities\n}\n\nfunction serveStatic(components: Pick<CliComponents, 'fs'>, dir: string, router: Router<PreviewComponents>) {\n  const sdkPath = path.dirname(\n    require.resolve('@dcl/sdk/package.json', {\n      paths: [dir]\n    })\n  )\n  const dclExplorerJsonPath = path.dirname(\n    require.resolve('@dcl/explorer/package.json', {\n      paths: [dir, sdkPath]\n    })\n  )\n\n  const dclKernelDefaultProfilePath = path.resolve(dclExplorerJsonPath, 'default-profile')\n  const dclKernelImagesDecentralandConnect = path.resolve(dclExplorerJsonPath, 'images', 'decentraland-connect')\n\n  const routes = [\n    {\n      route: '/',\n      path: path.resolve(dclExplorerJsonPath, 'preview.html'),\n      type: 'text/html'\n    },\n    {\n      route: '/favicon.ico',\n      path: path.resolve(dclExplorerJsonPath, 'favicon.ico'),\n      type: 'text/html'\n    },\n    {\n      route: '/@/explorer/index.js',\n      path: path.resolve(dclExplorerJsonPath, 'index.js'),\n      type: 'text/javascript'\n    }\n  ]\n\n  for (const route of routes) {\n    router.get(route.route, async (_ctx) => {\n      return {\n        headers: { 'Content-Type': route.type },\n        body: components.fs.createReadStream(route.path)\n      }\n    })\n  }\n\n  function createStaticRoutes(\n    components: Pick<CliComponents, 'fs'>,\n    route: string,\n    folder: string,\n    transform = (str: string) => str\n  ) {\n    router.get(route, async (ctx, next) => {\n      const file = ctx.params.path\n      const fullPath = path.resolve(folder, transform(file))\n\n      // only return files IF the file is within a baseFolder\n      if (!(await components.fs.fileExists(fullPath))) {\n        return next()\n      }\n\n      const headers: Record<string, any> = {\n        'x-timestamp': Date.now(),\n        'x-sent': true,\n        'cache-control': 'no-cache,private,max-age=1'\n      }\n\n      if (fullPath.endsWith('.wasm')) {\n        headers['content-type'] = 'application/wasm'\n      }\n\n      return {\n        headers,\n        body: components.fs.createReadStream(fullPath)\n      }\n    })\n  }\n\n  createStaticRoutes(components, '/images/decentraland-connect/:path+', dclKernelImagesDecentralandConnect)\n  createStaticRoutes(components, '/default-profile/:path+', dclKernelDefaultProfilePath)\n  createStaticRoutes(components, '/@/explorer/:path+', dclExplorerJsonPath, (filePath) => filePath.replace(/.br+$/, ''))\n\n  router.get('/feature-flags/:file', async (ctx) => {\n    const res = await fetch(`https://feature-flags.decentraland.zone/${ctx.params.file}`, {\n      headers: {\n        connection: 'close'\n      }\n    })\n    return {\n      body: await res.arrayBuffer()\n    }\n  })\n}\n\nasync function entityV3FromFolder(\n  components: Pick<CliComponents, 'fs'>,\n  {\n    folder,\n    addOriginalPath,\n    customHashMaker\n  }: {\n    folder: string\n    addOriginalPath?: boolean\n    customHashMaker?: (str: string) => string\n  }\n): Promise<Entity | null> {\n  const sceneJsonPath = path.resolve(folder, './scene.json')\n  let isParcelScene = true\n\n  const wearableJsonPath = path.resolve(folder, './wearable.json')\n  if (await components.fs.fileExists(wearableJsonPath)) {\n    try {\n      const wearableJson = JSON.parse(await components.fs.readFile(wearableJsonPath, 'utf-8'))\n      if (!WearableJson.validate(wearableJson)) {\n        const errors = (WearableJson.validate.errors || []).map((a) => `${a.data} ${a.message}`).join('')\n\n        console.error(`Unable to validate wearable.json properly, please check it.`, errors)\n        console.error(`Invalid wearable.json (${wearableJsonPath})`)\n      } else {\n        isParcelScene = false\n      }\n    } catch (err) {\n      console.error(`Unable to load wearable.json properly`, err)\n    }\n  }\n\n  const hashMaker = customHashMaker ? customHashMaker : defaultHashMaker\n\n  if ((await components.fs.fileExists(sceneJsonPath)) && isParcelScene) {\n    const sceneJson = JSON.parse(await components.fs.readFile(sceneJsonPath, 'utf-8'))\n    const { base, parcels }: { base: string; parcels: string[] } = sceneJson.scene\n    const pointers = new Set<string>()\n    pointers.add(base)\n    parcels.forEach(($) => pointers.add($))\n\n    const mappedFiles = await getFilesFromFolder(components, {\n      folder,\n      addOriginalPath,\n      customHashMaker\n    })\n\n    return {\n      version: 'v3',\n      type: EntityType.SCENE,\n      id: hashMaker(folder),\n      pointers: Array.from(pointers),\n      timestamp: Date.now(),\n      metadata: sceneJson,\n      content: mappedFiles\n    }\n  }\n\n  return null\n}\n\nexport async function getFilesFromFolder(\n  components: Pick<CliComponents, 'fs'>,\n  {\n    folder,\n    addOriginalPath,\n    customHashMaker\n  }: {\n    folder: string\n    addOriginalPath?: boolean\n    customHashMaker?: (str: string) => string\n  }\n): Promise<ContentMapping[]> {\n  const hashMaker = customHashMaker ? customHashMaker : defaultHashMaker\n  const ignorePatterns = await getDCLIgnorePatterns(components, folder)\n\n  const allFiles = globSync('**/*', {\n    ignore: ignorePatterns,\n    cwd: folder,\n    dot: false,\n    absolute: true\n  })\n    .map((file) => {\n      try {\n        if (!statSync(file).isFile()) return\n      } catch (err) {\n        return\n      }\n      const _folder = folder.replace(/\\\\/gi, '/')\n      const key = file.replace(_folder, '').replace(/^\\/+/, '')\n      return key\n    })\n    .filter(($) => !!$) as string[]\n\n  const ig = ignore().add(ignorePatterns)\n  const filteredFiles = ig.filter(allFiles)\n\n  const ret: (ContentMapping & { original_path: string | undefined })[] = []\n\n  for (const file of filteredFiles) {\n    const absolutePath = path.resolve(folder, file)\n    try {\n      if (!statSync(absolutePath).isFile()) continue\n    } catch (err) {\n      console.error(err)\n      continue\n    }\n\n    const absoluteFolder = folder.replace(/\\\\/gi, '/')\n\n    const relativeFilePathToFolder = file.replace(absoluteFolder, '').replace(/^\\/+/, '')\n\n    ret.push({\n      file: relativeFilePathToFolder.toLowerCase(),\n      original_path: addOriginalPath ? absolutePath : undefined,\n      hash: hashMaker(absolutePath)\n    })\n  }\n\n  return ret\n}\n"]}