@restforgejs/platform 5.2.11 → 5.2.12

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 (169) hide show
  1. package/build-info.json +2 -2
  2. package/cli/consumer-deploy.js +1 -1
  3. package/cli/consumer.js +1 -1
  4. package/generators/cli/fast-track.js +147 -27
  5. package/generators/lib/templates/dashboard-catalog.js +1 -1
  6. package/generators/lib/templates/db-connection-env.js +1 -1
  7. package/generators/lib/templates/dbschema-catalog.js +1 -1
  8. package/generators/lib/templates/field-validation-catalog.js +1 -1
  9. package/generators/lib/templates/mysql-template.js +1 -1
  10. package/generators/lib/templates/oracle-template.js +1 -1
  11. package/generators/lib/templates/postgres-template.js +1 -1
  12. package/generators/lib/templates/query-declarative-catalog.js +1 -1
  13. package/generators/lib/templates/sqlite-template.js +1 -1
  14. package/integrity-manifest.json +18 -18
  15. package/package.json +1 -1
  16. package/scripts/verify-integrity.js +1 -1
  17. package/server.js +1 -1
  18. package/src/components/handlers/adjust_handler.js +1 -1
  19. package/src/components/handlers/audit_handler.js +1 -1
  20. package/src/components/handlers/delete_handler.js +1 -1
  21. package/src/components/handlers/export_handler.js +1 -1
  22. package/src/components/handlers/import_handler.js +1 -1
  23. package/src/components/handlers/insert_handler.js +1 -1
  24. package/src/components/handlers/update_handler.js +1 -1
  25. package/src/components/handlers/upload_handler.js +1 -1
  26. package/src/components/handlers/workflow_handler.js +1 -1
  27. package/src/components/integrations/webhook.js +1 -1
  28. package/src/consumers/baseConsumer.js +1 -1
  29. package/src/consumers/declarativeMapper.js +1 -1
  30. package/src/consumers/handlers/apiHandler.js +1 -1
  31. package/src/consumers/handlers/consoleHandler.js +1 -1
  32. package/src/consumers/handlers/databaseHandler.js +1 -1
  33. package/src/consumers/handlers/index.js +1 -1
  34. package/src/consumers/handlers/kafkaHandler.js +1 -1
  35. package/src/consumers/index.js +1 -1
  36. package/src/consumers/messageTransformer.js +1 -1
  37. package/src/consumers/validator.js +1 -1
  38. package/src/core/db/dialect/base-dialect.js +1 -1
  39. package/src/core/db/dialect/index.js +1 -1
  40. package/src/core/db/dialect/mysql-dialect.js +1 -1
  41. package/src/core/db/dialect/oracle-dialect.js +1 -1
  42. package/src/core/db/dialect/postgres-dialect.js +1 -1
  43. package/src/core/db/dialect/sqlite-dialect.js +1 -1
  44. package/src/core/db/flatten-helper.js +1 -1
  45. package/src/core/db/query-builder-error.js +1 -1
  46. package/src/core/db/query-builder.js +1 -1
  47. package/src/core/db/relation-helper.js +1 -1
  48. package/src/core/handlers/delete_handler.js +1 -1
  49. package/src/core/handlers/insert_handler.js +1 -1
  50. package/src/core/handlers/update_handler.js +1 -1
  51. package/src/core/models/base-model.js +1 -1
  52. package/src/core/utils/cache-manager.js +1 -1
  53. package/src/core/utils/component-engine.js +1 -1
  54. package/src/core/utils/context-builder.js +1 -1
  55. package/src/core/utils/datetime-formatter.js +1 -1
  56. package/src/core/utils/datetime-parser.js +1 -1
  57. package/src/core/utils/db.js +1 -1
  58. package/src/core/utils/logger.js +1 -1
  59. package/src/core/utils/payload-loader.js +1 -1
  60. package/src/core/utils/security-checks.js +1 -1
  61. package/src/middleware/body-options.js +1 -1
  62. package/src/middleware/cors.js +1 -1
  63. package/src/middleware/idempotency.js +1 -1
  64. package/src/middleware/rate-limiter.js +1 -1
  65. package/src/middleware/request-logger.js +1 -1
  66. package/src/middleware/security-headers.js +1 -1
  67. package/src/models/base-model-mysql.js +1 -1
  68. package/src/models/base-model-oracle.js +1 -1
  69. package/src/models/base-model-sqlite.js +1 -1
  70. package/src/models/base-model.js +1 -1
  71. package/src/pro/caching/redis-client.js +1 -1
  72. package/src/pro/caching/redis-helper.js +1 -1
  73. package/src/pro/consumers/baseConsumer.js +1 -1
  74. package/src/pro/consumers/declarativeMapper.js +1 -1
  75. package/src/pro/consumers/handlers/apiHandler.js +1 -1
  76. package/src/pro/consumers/handlers/consoleHandler.js +1 -1
  77. package/src/pro/consumers/handlers/databaseHandler.js +1 -1
  78. package/src/pro/consumers/handlers/index.js +1 -1
  79. package/src/pro/consumers/handlers/kafkaHandler.js +1 -1
  80. package/src/pro/consumers/index.js +1 -1
  81. package/src/pro/consumers/messageTransformer.js +1 -1
  82. package/src/pro/consumers/validator.js +1 -1
  83. package/src/pro/database/base-model-mysql.js +1 -1
  84. package/src/pro/database/base-model-oracle.js +1 -1
  85. package/src/pro/database/base-model-sqlite.js +1 -1
  86. package/src/pro/database/db-mysql.js +1 -1
  87. package/src/pro/database/db-oracle.js +1 -1
  88. package/src/pro/database/db-sqlite.js +1 -1
  89. package/src/pro/excel/excel-generator.js +1 -1
  90. package/src/pro/excel/excel-parser.js +1 -1
  91. package/src/pro/excel/export-service.js +1 -1
  92. package/src/pro/excel/export_handler.js +1 -1
  93. package/src/pro/excel/import-service.js +1 -1
  94. package/src/pro/excel/import-validator.js +1 -1
  95. package/src/pro/excel/import_handler.js +1 -1
  96. package/src/pro/excel/upsert-builder.js +1 -1
  97. package/src/pro/idgen/idgen-routes.js +1 -1
  98. package/src/pro/integrations/lookup-resolver.js +1 -1
  99. package/src/pro/integrations/upload-handler-v2.js +1 -1
  100. package/src/pro/integrations/upload-handler.js +1 -1
  101. package/src/pro/integrations/webhook.js +1 -1
  102. package/src/pro/locking/lock-routes.js +1 -1
  103. package/src/pro/locking/resource-lock-manager.js +1 -1
  104. package/src/pro/messaging/kafkaConsumerService.js +1 -1
  105. package/src/pro/messaging/kafkaService.js +1 -1
  106. package/src/pro/messaging/messagehubService.js +1 -1
  107. package/src/pro/messaging/rabbitmqService.js +1 -1
  108. package/src/pro/scheduler/job-manager.js +1 -1
  109. package/src/pro/scheduler/job-routes.js +1 -1
  110. package/src/pro/scheduler/job-validator.js +1 -1
  111. package/src/pro/storage/base-storage-provider.js +1 -1
  112. package/src/pro/storage/file-metadata-helper.js +1 -1
  113. package/src/pro/storage/index.js +1 -1
  114. package/src/pro/storage/local-storage-provider.js +1 -1
  115. package/src/pro/storage/s3-storage-provider.js +1 -1
  116. package/src/pro/storage/upload-cleanup-job.js +1 -1
  117. package/src/pro/storage/upload-cleanup-scheduler.js +1 -1
  118. package/src/pro/storage/upload-pending-tracker.js +1 -1
  119. package/src/pro/websocket/broadcast-helper.js +1 -1
  120. package/src/pro/websocket/index.js +1 -1
  121. package/src/pro/websocket/livesync-server.js +1 -1
  122. package/src/pro/websocket/ws-broadcaster.js +1 -1
  123. package/src/services/export-service.js +1 -1
  124. package/src/services/import-service.js +1 -1
  125. package/src/services/kafkaConsumerService.js +1 -1
  126. package/src/services/kafkaService.js +1 -1
  127. package/src/services/messagehubService.js +1 -1
  128. package/src/services/rabbitmqService.js +1 -1
  129. package/src/utils/cache-invalidation-registry.js +1 -1
  130. package/src/utils/cache-manager.js +1 -1
  131. package/src/utils/component-engine.js +1 -1
  132. package/src/utils/config-extractor.js +1 -1
  133. package/src/utils/consumerLogger.js +1 -1
  134. package/src/utils/context-builder.js +1 -1
  135. package/src/utils/dashboard-helpers.js +1 -1
  136. package/src/utils/dateHelper.js +1 -1
  137. package/src/utils/datetime-formatter.js +1 -1
  138. package/src/utils/datetime-parser.js +1 -1
  139. package/src/utils/db-bootstrap.js +1 -1
  140. package/src/utils/db-mysql.js +1 -1
  141. package/src/utils/db-oracle.js +1 -1
  142. package/src/utils/db-sqlite.js +1 -1
  143. package/src/utils/db.js +1 -1
  144. package/src/utils/demo-generator.js +1 -1
  145. package/src/utils/excel-generator.js +1 -1
  146. package/src/utils/excel-parser.js +1 -1
  147. package/src/utils/file-watcher.js +1 -1
  148. package/src/utils/id-generator.js +1 -1
  149. package/src/utils/idempotency-manager.js +1 -1
  150. package/src/utils/import-validator.js +1 -1
  151. package/src/utils/license-client.js +1 -1
  152. package/src/utils/lock-manager.js +1 -1
  153. package/src/utils/logger.js +1 -1
  154. package/src/utils/lookup-resolver.js +1 -1
  155. package/src/utils/payload-loader.js +1 -1
  156. package/src/utils/processor-response.js +1 -1
  157. package/src/utils/rabbitmq.js +1 -1
  158. package/src/utils/redis-client.js +1 -1
  159. package/src/utils/redis-helper.js +1 -1
  160. package/src/utils/request-scope.js +1 -1
  161. package/src/utils/security-checks.js +1 -1
  162. package/src/utils/service-resolver.js +1 -1
  163. package/src/utils/shutdown-coordinator.js +1 -1
  164. package/src/utils/soft-delete-dashboard-guard.js +1 -1
  165. package/src/utils/sql-table-extractor.js +1 -1
  166. package/src/utils/trusted-keys.js +1 -1
  167. package/src/utils/upload-handler.js +1 -1
  168. package/src/utils/upsert-builder.js +1 -1
  169. package/src/utils/workflow-hook-executor.js +1 -1
@@ -257,8 +257,9 @@ function checkDesigner() {
257
257
  console.log('');
258
258
  console.log('[Preflight]');
259
259
 
260
- // Probe nyata: jalankan `restforge-designer --version`.
261
- const r = spawnSync('cmd', ['/S', '/C', 'restforge-designer --version'], { encoding: 'utf8' });
260
+ // Probe nyata: jalankan `restforge-designer --version`. shell:true memilih
261
+ // cmd.exe (Windows) atau /bin/sh (Linux/macOS) otomatis, termasuk resolusi PATH.
262
+ const r = spawnSync('restforge-designer --version', { shell: true, encoding: 'utf8' });
262
263
  const found = !r.error && r.status === 0;
263
264
  let version = '';
264
265
  if (found && r.stdout) version = r.stdout.trim().split(/\r?\n/)[0];
@@ -654,7 +655,7 @@ const ANSI_RE = /\x1b\[[0-9;]*m/g;
654
655
  * (list hanya membaca metadata plugin built-in).
655
656
  */
656
657
  function runDesignerPluginsList() {
657
- const r = spawnSync('cmd', ['/S', '/C', 'restforge-designer plugins list'], { encoding: 'utf8' });
658
+ const r = spawnSync('restforge-designer plugins list', { shell: true, encoding: 'utf8' });
658
659
  if (r.error || r.status !== 0) return null;
659
660
  return r.stdout || '';
660
661
  }
@@ -865,7 +866,7 @@ function phase(title) {
865
866
  /** Jalankan command CMD inline; hentikan pipeline bila gagal. */
866
867
  function run(cmd, cwd, { allowNonZero = false } = {}) {
867
868
  console.log(`\n#${cmd}`);
868
- const r = spawnSync('cmd', ['/S', '/C', cmd], { cwd, stdio: 'inherit' });
869
+ const r = spawnSync(cmd, { cwd, stdio: 'inherit', shell: true });
869
870
  if (allowNonZero) {
870
871
  if (r.error) console.log(`\n [WARN] ${cmd}\n ${r.error.message}`);
871
872
  return r.status;
@@ -1130,19 +1131,34 @@ function healthHost(serverAddress) {
1130
1131
  return (!serverAddress || serverAddress === '0.0.0.0') ? 'localhost' : serverAddress;
1131
1132
  }
1132
1133
 
1133
- /** Bila port dipakai, hentikan proses lama (Windows) sebelum serve. */
1134
+ /** Bila port dipakai, hentikan proses lama sebelum serve. */
1134
1135
  function freePort(port) {
1135
- const res = spawnSync('cmd', ['/S', '/C', `netstat -ano | findstr :${port}`], { encoding: 'utf8' });
1136
+ const isWin = process.platform === 'win32';
1136
1137
  const pids = new Set();
1137
- for (const line of (res.stdout || '').split(/\r?\n/)) {
1138
- const p = line.trim().split(/\s+/);
1139
- if (p.length >= 5 && /LISTENING/i.test(p[3]) && p[1].endsWith(`:${port}`)) {
1140
- if (/^\d+$/.test(p[4]) && p[4] !== '0') pids.add(p[4]);
1138
+
1139
+ if (isWin) {
1140
+ const res = spawnSync(`netstat -ano | findstr :${port}`, { shell: true, encoding: 'utf8' });
1141
+ for (const line of (res.stdout || '').split(/\r?\n/)) {
1142
+ const p = line.trim().split(/\s+/);
1143
+ if (p.length >= 5 && /LISTENING/i.test(p[3]) && p[1].endsWith(`:${port}`)) {
1144
+ if (/^\d+$/.test(p[4]) && p[4] !== '0') pids.add(p[4]);
1145
+ }
1146
+ }
1147
+ } else {
1148
+ // lsof tidak selalu terinstall (mis. minimal container) - tolerant, skip kalau gagal.
1149
+ const res = spawnSync(`lsof -ti tcp:${port}`, { shell: true, encoding: 'utf8' });
1150
+ for (const line of (res.stdout || '').split(/\r?\n/)) {
1151
+ const pid = line.trim();
1152
+ if (/^\d+$/.test(pid)) pids.add(pid);
1141
1153
  }
1142
1154
  }
1155
+
1143
1156
  if (pids.size === 0) return;
1144
1157
  console.log(` Port ${port} in use (PID ${[...pids].join(', ')}); stopping old process...`);
1145
- for (const pid of pids) spawnSync('cmd', ['/S', '/C', `taskkill /PID ${pid} /F`], { stdio: 'inherit' });
1158
+ for (const pid of pids) {
1159
+ const killCmd = isWin ? `taskkill /PID ${pid} /F` : `kill -9 ${pid}`;
1160
+ spawnSync(killCmd, { shell: true, stdio: 'inherit' });
1161
+ }
1146
1162
  }
1147
1163
 
1148
1164
  /** Pipeline REST API nyata: env -> validate -> migrate -> payload+endpoint. */
@@ -1230,7 +1246,12 @@ function runFrontendPipeline(ctx) {
1230
1246
 
1231
1247
  phase('[F3/3] Generate frontend application');
1232
1248
  // Hapus index.html lama agar landing page diregenerasi sesuai set page terbaru.
1233
- run(`if exist apps\\${ctx.project}\\index.html del /Q apps\\${ctx.project}\\index.html`, frontendDir, { allowNonZero: true });
1249
+ // Pakai fs langsung (bukan shell command) supaya portable Windows/Linux/macOS.
1250
+ try {
1251
+ fs.unlinkSync(path.join(frontendDir, 'apps', ctx.project, 'index.html'));
1252
+ } catch {
1253
+ // File belum ada (first run) - abaikan.
1254
+ }
1234
1255
  run(`restforge-designer generate --payload=payload/${appCode}.json --output=./apps/${ctx.project} ${pluginArg} --overwrite`, frontendDir);
1235
1256
  }
1236
1257
 
@@ -1271,6 +1292,66 @@ function writeServerStartScript(ctx) {
1271
1292
  return file;
1272
1293
  }
1273
1294
 
1295
+ /**
1296
+ * Tulis launcher start frontend mandiri di folder app (frontend/apps/<project>/).
1297
+ * Windows -> frontend-start.bat, Linux/macOS -> frontend-start.sh. Sama seperti
1298
+ * writeServerStartScript, dipakai juga sebagai target `pm2 start` di non-Windows.
1299
+ */
1300
+ function writeFrontendStartScript(ctx) {
1301
+ const serveCmd = `npx serve . -l ${ctx.cfg.WEB_SERVER_PORT}`;
1302
+ const isWin = process.platform === 'win32';
1303
+ const appDir = path.join(ctx.cwd, 'frontend', 'apps', ctx.project);
1304
+ const file = path.join(appDir, isWin ? 'frontend-start.bat' : 'frontend-start.sh');
1305
+ let content;
1306
+ if (isWin) {
1307
+ content = [
1308
+ '@echo off',
1309
+ 'REM Start RESTForge frontend app. Generated by fast-track.',
1310
+ 'cd /d "%~dp0"',
1311
+ `call ${serveCmd}`,
1312
+ ''
1313
+ ].join('\r\n');
1314
+ } else {
1315
+ content = [
1316
+ '#!/usr/bin/env bash',
1317
+ '# Start RESTForge frontend app. Generated by fast-track.',
1318
+ 'set -e',
1319
+ 'cd "$(dirname "$0")"',
1320
+ serveCmd,
1321
+ ''
1322
+ ].join('\n');
1323
+ }
1324
+ fs.writeFileSync(file, content);
1325
+ if (!isWin) {
1326
+ try { fs.chmodSync(file, 0o755); } catch { /* abaikan bila FS tak dukung chmod */ }
1327
+ }
1328
+ return file;
1329
+ }
1330
+
1331
+ /**
1332
+ * pm2 dipakai di Linux/macOS sebagai pengganti "open new window" (konsep
1333
+ * Windows-only) untuk mengelola proses server/frontend: pm2 list/logs/reload/
1334
+ * stop, bukan raw PID. Nama proses dibedakan per-project per-kind agar tidak
1335
+ * collision antar project yang dijalankan bersamaan.
1336
+ */
1337
+ function pm2Name(project, kind) {
1338
+ return `${project}-${kind}`;
1339
+ }
1340
+
1341
+ /**
1342
+ * Start (ulang) script launcher via pm2. Idempotent: hapus instance lama dulu
1343
+ * (silent, tolerant bila belum ada) supaya re-run fast-track tidak gagal
1344
+ * dengan "already launched". Return false bila pm2 tidak tersedia/gagal.
1345
+ */
1346
+ function pm2StartScript(name, scriptPath, cwd) {
1347
+ spawnSync(`pm2 delete ${name} --silent`, { shell: true, stdio: 'ignore' });
1348
+ const r = spawnSync(
1349
+ `pm2 start "${scriptPath}" --name ${name} --cwd "${cwd}" --interpreter bash`,
1350
+ { shell: true, stdio: 'inherit' }
1351
+ );
1352
+ return !r.error && r.status === 0;
1353
+ }
1354
+
1274
1355
  function printFinalSummary(ctx) {
1275
1356
  const parts = [];
1276
1357
  if (ctx.scope.backend) parts.push('REST API generated');
@@ -1287,6 +1368,9 @@ function printFinalSummary(ctx) {
1287
1368
  }
1288
1369
  if (ctx.scope.frontend) {
1289
1370
  console.log(` Frontend : frontend/apps/${ctx.project}/ (start: npx serve . -l ${ctx.cfg.WEB_SERVER_PORT})`);
1371
+ if (ctx.frontendStartFile) {
1372
+ console.log(` Start : ${path.basename(ctx.frontendStartFile)} (start frontend manually)`);
1373
+ }
1290
1374
  }
1291
1375
  console.log(rule('='));
1292
1376
  }
@@ -1304,20 +1388,35 @@ async function startServerNow(ctx) {
1304
1388
  const serveCmd = `npx restforge serve --project=${ctx.project} --config=${ctx.configFlag} --watch`;
1305
1389
  freePort(ctx.cfg.SERVER_PORT);
1306
1390
  const title = `RESTForge Server - ${ctx.project}`;
1307
- console.log(`\n Opening new window: "${title}"`);
1308
- console.log(`#${serveCmd}`);
1309
1391
  // server.js (dispatcher) memaksa NODE_ENV=production untuk proses cli command,
1310
1392
  // sehingga fast-track berjalan production dan secara default akan mewariskannya
1311
1393
  // ke serve -> logger memakai format JSON mentah (verbose). Set development agar
1312
1394
  // runtime server memakai pino-pretty (rapi), konsisten dengan playbook yang
1313
1395
  // menjalankan serve dari plain `node`.
1314
1396
  const serveEnv = { ...process.env, NODE_ENV: 'development' };
1315
- const r = spawnSync('cmd', ['/C', 'start', title, 'cmd', '/k', serveCmd], { cwd: ctx.cwd, stdio: 'inherit', env: serveEnv });
1316
- if (r.error) {
1317
- console.log(` Failed to open server window: ${r.error.message}`);
1318
- return false;
1397
+
1398
+ if (process.platform === 'win32') {
1399
+ console.log(`\n Opening new window: "${title}"`);
1400
+ console.log(`#${serveCmd}`);
1401
+ const r = spawnSync('cmd', ['/C', 'start', title, 'cmd', '/k', serveCmd], { cwd: ctx.cwd, stdio: 'inherit', env: serveEnv });
1402
+ if (r.error) {
1403
+ console.log(` Failed to open server window: ${r.error.message}`);
1404
+ return false;
1405
+ }
1406
+ console.log(' ✓ Server window opened. Keep it open. Stop with Ctrl+C.');
1407
+ } else {
1408
+ // Tidak ada konsep "window baru" di Linux/macOS (terutama session SSH headless) -
1409
+ // pakai pm2 supaya proses bisa dikelola normal (pm2 list/logs/reload/stop).
1410
+ console.log(`\n Starting via pm2: "${title}"`);
1411
+ const name = pm2Name(ctx.project, 'server');
1412
+ const ok = pm2StartScript(name, ctx.serverStartFile, ctx.cwd);
1413
+ if (!ok) {
1414
+ console.log(' Failed to start via pm2. Is pm2 installed? (npm install -g pm2)');
1415
+ return false;
1416
+ }
1417
+ console.log(` ✓ Server started via pm2 as "${name}".`);
1418
+ console.log(` pm2 logs ${name} | pm2 reload ${name} | pm2 stop ${name}`);
1319
1419
  }
1320
- console.log(' ✓ Server window opened. Keep it open. Stop with Ctrl+C.');
1321
1420
 
1322
1421
  // Health check: tunggu runtime benar-benar siap menerima request sebelum
1323
1422
  // lanjut (mis. ke frontend). URL = banner runtime: /api/<project>/health.
@@ -1365,14 +1464,27 @@ async function startFrontendNow(ctx) {
1365
1464
  }
1366
1465
  freePort(webPort);
1367
1466
  const title = `RESTForge Frontend - ${ctx.project}`;
1368
- console.log(`\n Opening new window: "${title}"`);
1369
- console.log(`#${serveCmd}`);
1370
- const r = spawnSync('cmd', ['/C', 'start', title, 'cmd', '/k', serveCmd], { cwd: appDir, stdio: 'inherit' });
1371
- if (r.error) {
1372
- console.log(` Failed to open frontend window: ${r.error.message}`);
1373
- return false;
1467
+
1468
+ if (process.platform === 'win32') {
1469
+ console.log(`\n Opening new window: "${title}"`);
1470
+ console.log(`#${serveCmd}`);
1471
+ const r = spawnSync('cmd', ['/C', 'start', title, 'cmd', '/k', serveCmd], { cwd: appDir, stdio: 'inherit' });
1472
+ if (r.error) {
1473
+ console.log(` Failed to open frontend window: ${r.error.message}`);
1474
+ return false;
1475
+ }
1476
+ console.log(` ✓ Frontend window opened (WEB_SERVER_PORT ${webPort}).`);
1477
+ } else {
1478
+ console.log(`\n Starting via pm2: "${title}"`);
1479
+ const name = pm2Name(ctx.project, 'frontend');
1480
+ const ok = pm2StartScript(name, ctx.frontendStartFile, appDir);
1481
+ if (!ok) {
1482
+ console.log(' Failed to start via pm2. Is pm2 installed? (npm install -g pm2)');
1483
+ return false;
1484
+ }
1485
+ console.log(` ✓ Frontend started via pm2 as "${name}" (WEB_SERVER_PORT ${webPort}).`);
1486
+ console.log(` pm2 logs ${name} | pm2 reload ${name} | pm2 stop ${name}`);
1374
1487
  }
1375
- console.log(` ✓ Frontend window opened (WEB_SERVER_PORT ${webPort}).`);
1376
1488
 
1377
1489
  const url = `http://localhost:${webPort}/index.html`;
1378
1490
  // Tunggu static server (`npx serve`) benar-benar siap sebelum buka browser,
@@ -1387,7 +1499,12 @@ async function startFrontendNow(ctx) {
1387
1499
  if (!ready.ok) {
1388
1500
  console.log(' ⚠ Frontend belum merespons - buka URL di atas manual bila browser tidak otomatis terbuka.');
1389
1501
  }
1390
- const openResult = spawnSync('cmd', ['/C', 'start', '""', url], { stdio: 'ignore' });
1502
+ const openCmd = process.platform === 'win32'
1503
+ ? ['cmd', ['/C', 'start', '""', url]]
1504
+ : process.platform === 'darwin'
1505
+ ? ['open', [url]]
1506
+ : ['xdg-open', [url]];
1507
+ const openResult = spawnSync(openCmd[0], openCmd[1], { stdio: 'ignore' });
1391
1508
  if (openResult.error) {
1392
1509
  console.log(` (Could not open browser automatically: ${openResult.error.message})`);
1393
1510
  }
@@ -1552,6 +1669,9 @@ module.exports = {
1552
1669
  }
1553
1670
  if (ctx.scope.frontend) {
1554
1671
  runFrontendPipeline(ctx);
1672
+ // Launcher start frontend mandiri (sesuai OS), dipakai juga sebagai
1673
+ // target `pm2 start` di non-Windows.
1674
+ ctx.frontendStartFile = writeFrontendStartScript(ctx);
1555
1675
  }
1556
1676
 
1557
1677
  printFinalSummary(ctx);
@@ -1 +1 @@
1
- function a0_0x4d0b(_0x15ca17,_0x2cce2a){_0x15ca17=_0x15ca17-0xaa;const _0x30b410=a0_0x30b4();let _0x4d0bad=_0x30b410[_0x15ca17];if(a0_0x4d0b['tafAzt']===undefined){var _0x4f1e31=function(_0x318eed){const _0x151004='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0xb3efe3='',_0x46fd12='';for(let _0x43f95d=0x0,_0x2121d3,_0x3aa25e,_0x539667=0x0;_0x3aa25e=_0x318eed['charAt'](_0x539667++);~_0x3aa25e&&(_0x2121d3=_0x43f95d%0x4?_0x2121d3*0x40+_0x3aa25e:_0x3aa25e,_0x43f95d++%0x4)?_0xb3efe3+=String['fromCharCode'](0xff&_0x2121d3>>(-0x2*_0x43f95d&0x6)):0x0){_0x3aa25e=_0x151004['indexOf'](_0x3aa25e);}for(let _0x19b81d=0x0,_0x3b66ff=_0xb3efe3['length'];_0x19b81d<_0x3b66ff;_0x19b81d++){_0x46fd12+='%'+('00'+_0xb3efe3['charCodeAt'](_0x19b81d)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x46fd12);};a0_0x4d0b['fiTAxp']=_0x4f1e31,a0_0x4d0b['bNqqil']={},a0_0x4d0b['tafAzt']=!![];}const _0x2f6fc6=_0x30b410[0x0],_0x2d3dc2=_0x15ca17+_0x2f6fc6,_0x4abd93=a0_0x4d0b['bNqqil'][_0x2d3dc2];return!_0x4abd93?(_0x4d0bad=a0_0x4d0b['fiTAxp'](_0x4d0bad),a0_0x4d0b['bNqqil'][_0x2d3dc2]=_0x4d0bad):_0x4d0bad=_0x4abd93,_0x4d0bad;}const a0_0x4756bb=a0_0x4d0b;(function(_0x40bce1,_0x4d7f13){const _0xfd4b57=a0_0x4d0b,_0x85f2a=_0x40bce1();while(!![]){try{const _0x4e0739=-parseInt(_0xfd4b57(0xe8))/0x1*(-parseInt(_0xfd4b57(0xc8))/0x2)+-parseInt(_0xfd4b57(0xc5))/0x3*(parseInt(_0xfd4b57(0xb1))/0x4)+parseInt(_0xfd4b57(0xb3))/0x5*(parseInt(_0xfd4b57(0xe0))/0x6)+parseInt(_0xfd4b57(0xf2))/0x7+-parseInt(_0xfd4b57(0xbb))/0x8+-parseInt(_0xfd4b57(0xb5))/0x9*(parseInt(_0xfd4b57(0xb7))/0xa)+parseInt(_0xfd4b57(0xe9))/0xb;if(_0x4e0739===_0x4d7f13)break;else _0x85f2a['push'](_0x85f2a['shift']());}catch(_0x295b1c){_0x85f2a['push'](_0x85f2a['shift']());}}}(a0_0x30b4,0xbbf75));function a0_0x30b4(){const _0x53a7c7=['EYbZDwnJzxnZoIbIB29SzwfUlcbKyxrHoIb7idX3AwrNzxrjzd46idXWzxjxAwrNzxrszxnWB25Zzt4Sic4UlIb9ih0','AxrLBxm','yxzNx2rHAwX5x3nHBgvZ','zgLYzwn0Aw9U','zMLSztPXDwvYEs88Cgf0Ad4VyNjLywTKB3DUlNnXBa','BM9UlwvTChr5lcb1BMLXDwuGywnYB3nZihDPzgDLDhmGAw4GDgHLihnHBwuGCgf5Bg9Hza','iJi4odqI','Bwv0CMLJx3nWyxjRBgLUzq','yxjYyxKGB2yGB2jQzwn0CW','rgv0zxjTAw5LzcbIEsbZy2fSyxjdB2XSyxbZzvj1BgvZlIbgywLSzwqGD2LKz2v0CYbWCM9KDwnLihSGzxjYB3i6icCUlI4Nih0GyMXVy2SGD2L0Acb0B3aTBgv2zwWGC3vJy2vZCYbZDgLSBcb0CNvLicHVBMuGD2LKz2v0igzHAwX1CMuGzg9LCYbot1qGzMfPBcb0AguGzgfZAgjVyxjKks4','sgvHzgXPBMuGBwv0CMLJihDPDgGGDhjLBMqGy2HPCcbHBMqGC3bHCMTSAw5Lig1PBMKTy2HHCNqGzM9YihnOB3j0ihDPBMrVD3mGkdCGzgf5CYWGmtiGBw9UDgHZlcbLDgmUks4Gu3vPDgfIBguGzM9YihDPzgDLDhmGBgLRzsaNqxzLCMfNzsbeywLSEsbtywXLCYCU','DhrS','C3vIDgL0Bgu','msbYB3CGW5CGmsbJB2WSig91Dhb1DcbJB2X1Bw4Gj3zHBhvLjW','u3bHCMTSAw5LigXPyNjHCMLLCYaOqxbLEenOyxj0CYWGq2HHCNrPC3qSigv0yY4Pihr5CgLJywXSEsbUzwvKigeGCgXHAw4GBNvTyMvYigfYCMf5lIbgCM9UDgvUzcbTyxbZihbVAw50CY5TyxaOCca9pIbWlNzHBhvLks4GvgHLicDWzxjPB2qNigzPzwXKihn0yxLZigzVCIb0B29SDgLWigfUzcbNyxaTCMvZAwXPzw5JzsbHz2fPBNn0ig1PC3nPBMCGzgf5CY4GvxnLigDLBMvYyxrLx3nLCMLLCYbPBIbtuuWGDg8Gzw5ZDxjLignVBNnPC3rLBNqGCM93ignVDw50igv2zw4GzM9YigrHExmGD2L0AcbUBYb0CMfUC2fJDgLVBNmU','sgvHzgXPBMuGBwv0CMLJihDPDgGGDhjLBMqGy2HPCcbHBMqGChjVz3jLC3mGyMfYigfNywLUC3qGysbWzxjPB2qGDgfYz2v0lIbtDwL0ywjSzsbMB3iGD2LKz2v0CYbSAwTLicDpCMrLCNmGvgHPCYbnB250AcCU','zgfZAc1ZywXLCW','v2LKz2v0igLKzw50AwzPzxi7ihvZzwqGyxmGDgHLihjLC3bVBNnLigTLEsbPBIb0AguGzgfZAgjVyxjKigvUDMvSB3bLlG','D2LKz2v0CW','iJe4mZyI','CxvLCNK','zMLSztPYzwXHDgL2zs9WyxrOl3rVl3f1zxj5lNnXBa','Cgn0','mZC2mdG0tLbJv2rg','vg9Nz2XLignHy2HLigzLyxr1CMuGzM9YihrOAxmGzgfZAgjVyxjKlG','mJuWvNL0y2fm','BwfW','mJi0nJrcENfoDwe','iJi0mJaI','nty5mgjLww9msa','D2LKz2v0lNf1zxj5icHZAw5NDwXHCIK','iNnOB3bWAw5Nx2nHDgvNB3jPzxmIoIb7icjPDgvTCYi6ifT7icjUyw1LiJOGiKXHBMrZiIb9lcb7icjUyw1LiJOGiKHVDxnLCYiGFv0GFq','yw55icGXihjVDYddLYaXignVBcWGtIbYB3DZimoxie0Gy29SCYWGzxrJlIK','mte5mdu3mdrOuLbQALK','BNvTyMvY','Dg9WlwXLDMvSicDWyxjHBxmNig9IAMvJDa','DMfSDwuGkg9Yign1CNjLBNqP','l2fWAs97ChjVAMvJDh0VE25HBwv9l2rHC2HIB2fYza','BgvUz3rO','qsbWyxLSB2fKihDPDgGGyM90AcaND2LKz2v0CYCGyw5KicD0ywjSzu5HBwuNigLZihjLAMvJDgvKigj5ierHC2HIB2fYzfzHBgLKyxrVCI4GugLJAYbVBMuGC2HHCguU','kd88itOPoIHBys16qs1Ax11Bys16qs1Amc05x10Qkq','vMLZDwfSihzHCMLHBNqGkgrVBNv0lcbIyxiSihbPzsWGyxjLysKGAxmGysbMCM9UDgvUzcbYzw5KzxjPBMCGy29Uy2vYBIaOC2vWyxjHDgLVBIbVzIbJB25JzxjUCYKU','B2jQzwn0','mtvJBLzTEKG','yxjYyxK8C3rYAw5NpG','qwX3yxLZihSGAxrLBxm6ifSUlI5Dih0GCMvNyxjKBgvZCYbVzIbtuuWGCMvZDwX0ihnOyxbLlG','mtaWnZKWBuTAENvj','Bgf5B3v0','B3jKzxjZx3rOAxnFBw9UDgG','rNjVBNrLBMqGy29TChv0zxmGDg9Fz29HBca9ihrHCMDLDcaTihzHBhvLigfUzcbWy3qGpsbYB3vUzcH2ywX1zsaVihrHCMDLDcaQideWmcKGzM9YihrOzsbWCM9NCMvZCYbIyxiUifzPC3vHBcb3Awr0AcbPCYbWCMvZzw50yxrPB25HBcbHBMqGBxvZDcbot1qGBgL2zsbPBIb0AguGyMfJA2vUzcbWyxLSB2fKlIbjzIbWCM9NCMvZCYbPBNzVBhzLCYbJB21WBgv4igj1C2LUzxnZihj1BgvZicHLlMCUigv4y2X1zguGD2vLA2vUzhmSihbYB3jHDgvKihDVCMTKyxLZksWGDxnLigeGC2LUz2XLig11BhrPlwnVBhvTBIbXDwvYEsbZBYaNCgn0jYbPCYbHihn0ywjSzsbIDxnPBMvZCYbMywn0ihjHDgHLCIb0AgfUihzPC3vHBcb3Awr0Ac4','zgfZAgjVyxjKlwnHDgfSB2C','EYaIzgLYzwn0Aw9UiJOGiNvWiIWGiNbJDci6iciYlJiIih0','qwXSihDPzgDLDcbtuuWG4OcuigjVDgGGj3f1zxj5jYaOC2LUz3vSyxiPigfUzcbLDMvYEsaNCxvLCMLLCY48A2v5pICU','zNjVBNrLBMqTy29Uy2vYBG','DgfIBgvoyw1L','EYaICgfYyw1ZiJOGEYaIEwvHCIi6ihSGiNr5CguIoIaIBNvTyMvYiIWGiNjLCxvPCMvKiJOGDhj1zsb9ih0GFq','yM9VBgvHBG','q29SBgfWC2uGDg8GB2jQzwn0ihDOB3nLigTLExmGyxjLifnrtcbJB2X1Bw4GBMfTzxmGkgXVD2vYy2fZzwqPlG','tgLZDcbVzIbduLveihrHyMXLig5HBwvZihrOyxqSihDOzw4GD3jPDhrLBIWGD2LSBcb0CMLNz2vYigLUDMfSAwrHDgLVBIbVzIb0AgLZigrHC2HIB2fYzcbJywnOzs4','DhjLBMq','phDPzgDLDf9Pzd4','D2LKz2v0lNf1zxjPzxmUpgTLEt4GD2L0AcbtuuWGCMv0DxjUAw5NideGCM93imoxideGy29SDw1U','Dg9Wtgv2zwXbBgXVD2vK','t3b0Aw9UywWGy2fJAguGy29UzMLNDxjHDgLVBI4Gu2vLignHy2HLu3bLyYbMB3iGzgv0ywLSCY4','A2v54OAszMLSztPYzwXHDgL2zs9WyxrOl3rVl3f1zxj5lNnXBa','zMLSztPXDwvYEs88Cgf0Ad4Vy3vYCMvUDc5ZCwW','DMfSDwu','tIbYB3DZimoxidiGy29SDw1UCW','q29SBgfWC2uGDg8GC2nHBgfYihbYAw1PDgL2zsaODgHLihzHBhvLig9MihrOzsbZAw5NBguGy29SDw1Uks4','vgfIBguGzgvJBgfYzwqGAw4GAw52ywXPzgf0zxmSigj1DcbUB3qGzgv0zwn0zwqGAw4Gyw55ihDPzgDLDcbtuuWGkhr5Cg8GB3iGzgvHzcbLBNrYEsK','ndi0mJbLu1PrEeW','D2LKz2v0vhLWzq','qsb3AwrNzxqGtvvtvcbKzwnSyxjLigv4ywn0BhKGB25Lig9MoIaNCxvLCNKNie9sicDXDwvYAwvZjY4GqM90AcbVCIbUzwL0AgvYigLZihjLAMvJDgvKlG','msbYB3CGW5CGmIbJB2X1Bw5Z','ue9tvcaVyxbPl21PBMKTAw52zw50B3j5l2rHC2GTAw5IB3vUzc9KyxnOyM9HCMq','vuKGBgfIzwWGAxmGysbMCM9UDgvUzcbYzw5KzxjPBMCGy29Uy2vYBI4','rxzLCNKGCgXHy2vOB2XKzxiGDxnLzcbPBIbtuuWGtvvtvcbIzsbKzwnSyxjLzcbPBIaNCgfYyw1ZjY4GvMfSAwrHDg9YihrOCM93CYbfCNjVCIb3AxrOig1LC3nHz2uGzM9YBwf0oIaIv2LKz2v0icC8Awq+jYbXDwvYEsaNpgXHyMvSpICGDxnLCYb1BMrLy2XHCMvKihbSywnLAg9SzgvYicC6phrVA2vUpICGkgrLy2XHCMuGAw4Gj3bHCMfTCYCPiI4','msbYB3CGW5CGmsbJB2X1Bw4','mtnQse1nyMK','mJe3odq4mdDgDhLNDwu','u1fmigzPBguGy29UDgvUDcbPCYbLBwjLzgrLzcbHCYbkyxzHu2nYAxb0ihrLBxbSyxrLigXPDgvYywWGAw5ZAwrLihrOzsbNzw5LCMf0zwqGBw9KDwXLigzPBguUifj1BNrPBwuGCgvYzM9YBxmGEMvYBYbKAxnRieKVtYbWzxiGCMvXDwvZDcdIGjqGywXSifnrtcbPCYbPBIbTzw1VCNKGywz0zxiGBw9KDwXLigXVywqU','zMLSztPXDwvYEs88Cgf0Ad4VCg9PBNrZlNnXBa','vxbKyxrPBMCGyw4Gu1fmigzPBguGCMvXDwLYzxmGCMvNzw5LCMf0Aw5NihrOzsbKyxnOyM9HCMqGBw9KDwXLicGNy29KzwDLBL9JCMvHDgvFzgfZAgjVyxjKjYKGzM9YignOyw5NzxmGDg8GDgfRzsbLzMzLy3qU','zxHWzwn0zwrFzwfYBMLUz3m','twv0CMLJicSGuhjVz3jLC3mGDg8Gr29HBa','iNzHBhvLiJOGiJy5nZaWiG','C2nHBgfYihbYAw1PDgL2zq','u2LUz2XLifnrtcbXDwvYEsbMB3iGDgHLihDPzgDLDc4','odeXnty1m3vxs3HHCW','yxjYyxK'];a0_0x30b4=function(){return _0x53a7c7;};return a0_0x30b4();}const FORBIDDEN_FRONTEND_FIELDS=[a0_0x4756bb(0xe1),a0_0x4756bb(0xc9),'title',a0_0x4756bb(0x100),'color'],ALLOWED_PARAM_TYPES=['string',a0_0x4756bb(0xbc),a0_0x4756bb(0xd2),'date'],FRONTEND_CONCERN_REASONS={'widgetType':a0_0x4756bb(0xc3),'layout':'Layout\x20is\x20a\x20frontend\x20rendering\x20concern.','title':'UI\x20label\x20is\x20a\x20frontend\x20rendering\x20concern.','subtitle':a0_0x4756bb(0xe5),'color':'Visual\x20color\x20is\x20a\x20frontend\x20rendering\x20concern.'},PAYLOAD_SHAPE={'discriminator':{'field':a0_0x4756bb(0xac),'presentMeans':'dashboard\x20payload','absentMeans':'Not\x20a\x20dashboard\x20payload\x20(likely\x20CRUD\x20with\x20tableName,\x20or\x20invalid)','conflictsWith':a0_0x4756bb(0xd0),'conflictRationale':a0_0x4756bb(0xc1)},'topLevelAllowed':[{'name':a0_0x4756bb(0xac),'type':a0_0x4756bb(0xf3),'required':!![],'minItems':0x1,'description':'List\x20of\x20widget\x20definitions.\x20Order\x20is\x20informational\x20only\x20(response\x20keys\x20are\x20by\x20widget\x20id,\x20not\x20array\x20index).'},{'name':'params','type':'object','required':![],'description':'Parameter\x20contract\x20for\x20the\x20dashboard.\x20Each\x20key\x20is\x20a\x20param\x20name;\x20values\x20describe\x20type/required/default.\x20Placeholders\x20inside\x20widget\x20SQL\x20must\x20reference\x20declared\x20param\x20names.'},{'name':'cache','type':'object','required':![],'description':a0_0x4756bb(0xd9)}],'topLevelForbidden':[{'name':a0_0x4756bb(0xd0),'category':'shape-conflict','reason':'Reserved\x20for\x20CRUD\x20payloads.\x20A\x20dashboard\x20payload\x20must\x20declare\x20\x27widgets\x27\x20instead.'},...FORBIDDEN_FRONTEND_FIELDS[a0_0x4756bb(0xb4)](_0xb3efe3=>({'name':_0xb3efe3,'category':a0_0x4756bb(0xcf),'reason':FRONTEND_CONCERN_REASONS[_0xb3efe3]}))]},WIDGET_SPEC={'requiredFields':[{'name':'id','type':'string','constraint':a0_0x4756bb(0xf9),'description':a0_0x4756bb(0xab)}],'exclusiveQueryFields':{'rule':a0_0x4756bb(0xe2),'options':[{'name':a0_0x4756bb(0xae),'type':'string','format':'file:relative/path/to/query.sql','description':a0_0x4756bb(0xf1),'responseShape':a0_0x4756bb(0xc7)},{'name':'queries','type':a0_0x4756bb(0xc4),'format':a0_0x4756bb(0xda),'minKeys':0x1,'description':'Multi-SQL\x20widget.\x20Each\x20key\x20becomes\x20a\x20key\x20in\x20the\x20response\x20object.','responseShape':'Per-key\x20based\x20on\x20scalarCollapseRules\x20below.'}]},'forbiddenFields':FORBIDDEN_FRONTEND_FIELDS},PARAM_SPEC={'container':a0_0x4756bb(0xbd),'keyConvention':'Param\x20name\x20must\x20match\x20the\x20placeholder\x20regex\x20`[a-zA-Z_][a-zA-Z0-9_]*`\x20(alphanumeric\x20+\x20underscore,\x20must\x20start\x20with\x20letter\x20or\x20underscore).','perEntryFields':[{'name':'type','required':!![],'allowedValues':ALLOWED_PARAM_TYPES,'description':'Param\x20data\x20type.\x20Validates\x20request\x20body\x20and\x20shapes\x20runtime\x20parameter\x20binding.'},{'name':'required','required':![],'type':a0_0x4756bb(0xd2),'default':![],'description':'When\x20true,\x20the\x20request\x20body\x20MUST\x20include\x20this\x20param\x20(otherwise\x20400).'},{'name':'default','required':![],'type':'any\x20(must\x20be\x20compatible\x20with\x20declared\x20\x27type\x27)','description':'Default\x20value\x20applied\x20when\x20the\x20request\x20omits\x20this\x20param.\x20Validator\x20does\x20NOT\x20strictly\x20type-check\x20default;\x20runtime\x20is\x20responsible\x20for\x20compatibility.'}]},SCALAR_COLLAPSE_RULES=[{'appliesTo':a0_0x4756bb(0xb8),'rule':'Always\x20wrap\x20as\x20{\x20items:\x20[...]\x20}\x20regardless\x20of\x20SQL\x20result\x20shape.','exampleSqlShape':a0_0x4756bb(0xba),'exampleResponse':a0_0x4756bb(0xb9)},{'appliesTo':a0_0x4756bb(0xd7),'rule':a0_0x4756bb(0xde),'exampleSqlShape':a0_0x4756bb(0x101),'exampleResponse':a0_0x4756bb(0xef)},{'appliesTo':'widget.queries.<key>\x20with\x20SQL\x20returning\x201\x20row\x20×\x20multiple\x20columns','rule':a0_0x4756bb(0xd3),'exampleSqlShape':'1\x20row\x20×\x202\x20cols,\x20output\x20columns\x20\x27direction\x27,\x20\x27pct\x27','exampleResponse':'\x22trend\x22:\x20{\x20\x22direction\x22:\x20\x22up\x22,\x20\x22pct\x22:\x20\x222.2\x22\x20}'},{'appliesTo':'widget.queries.<key>\x20with\x20SQL\x20returning\x20N\x20rows','rule':'Return\x20as\x20array\x20of\x20objects\x20(no\x20collapse).','exampleSqlShape':'N\x20rows\x20×\x20M\x20cols','exampleResponse':'\x22items\x22:\x20[{\x20\x22label\x22:\x20\x22Shoes\x22,\x20\x22value\x22:\x20\x227660\x22\x20},\x20...]'}],COMMON_WIDGET_PATTERNS=[{'id':'metric_donut_breakdown','name':'Metric\x20+\x20Donut\x20Breakdown','useCase':'Headline\x20metric\x20with\x20trend\x20chip\x20and\x20breakdown\x20across\x20categories.\x20Suitable\x20for\x20widgets\x20like\x20\x27Expected\x20Earnings\x27\x20that\x20show\x20total\x20value,\x20percentage\x20change,\x20and\x20per-category\x20contribution.','payloadShape':{'id':'<widget_id>','queries':{'value':'file:query/<path>/value.sql','trend':'file:query/<path>/trend.sql','items':a0_0x4756bb(0xf8)}},'sqlShapesPerKey':[{'key':'value','shape':a0_0x4756bb(0xe7),'outputColumns':[a0_0x4756bb(0xdc)],'collapseRule':a0_0x4756bb(0xf0)},{'key':a0_0x4756bb(0xd5),'shape':'1\x20row\x20×\x202\x20columns','outputColumns':['direction',a0_0x4756bb(0xb0)],'collapseRule':a0_0x4756bb(0xc4)},{'key':a0_0x4756bb(0xf5),'shape':a0_0x4756bb(0xdd),'outputColumns':['label',a0_0x4756bb(0xdc)],'collapseRule':'array\x20of\x20objects'}],'responseShape':{'value':'\x2269700\x22','trend':a0_0x4756bb(0xcd),'items':'[{\x20\x22label\x22:\x20\x22Shoes\x22,\x20\x22value\x22:\x20\x227660\x22\x20},\x20{\x20\x22label\x22:\x20\x22Gaming\x22,\x20\x22value\x22:\x20\x222820\x22\x20},\x20{\x20\x22label\x22:\x20\x22Others\x22,\x20\x22value\x22:\x20\x2245257\x22\x20}]'},'referenceWidgetId':a0_0x4756bb(0xed),'socNotes':'Frontend\x20determines\x20donut/pie\x20variant,\x20color\x20per\x20category,\x20and\x20label\x20order.\x20If\x20per-category\x20percentage\x20is\x20needed\x20for\x20the\x20donut\x20arc,\x20frontend\x20computes\x20it\x20from\x20items[i].value\x20/\x20sum(items[*].value).\x20No\x20need\x20to\x20send\x20\x27pct\x27\x20from\x20backend\x20unless\x20the\x20figure\x20is\x20a\x20stable\x20business\x20calculation\x20independent\x20of\x20visual\x20rendering.'},{'id':a0_0x4756bb(0xfb),'name':'Metric\x20+\x20Sparkline','useCase':a0_0x4756bb(0xfe),'payloadShape':{'id':a0_0x4756bb(0xd6),'queries':{'value':'file:query/<path>/value.sql','trend':'file:query/<path>/trend.sql','points':a0_0x4756bb(0xeb)}},'sqlShapesPerKey':[{'key':a0_0x4756bb(0xdc),'shape':'1\x20row\x20×\x201\x20column','outputColumns':[a0_0x4756bb(0xdc)],'collapseRule':'scalar\x20primitive'},{'key':'trend','shape':'1\x20row\x20×\x202\x20columns','outputColumns':[a0_0x4756bb(0xf7),a0_0x4756bb(0xb0)],'collapseRule':a0_0x4756bb(0xc4)},{'key':'points','shape':a0_0x4756bb(0xdd),'outputColumns':['period',a0_0x4756bb(0xdc)],'collapseRule':a0_0x4756bb(0xfc)}],'responseShape':{'value':a0_0x4756bb(0xb6),'trend':'{\x20\x22direction\x22:\x20\x22up\x22,\x20\x22pct\x22:\x20\x222.6\x22\x20}','points':'[{\x20\x22period\x22:\x20\x222026-04-24\x22,\x20\x22value\x22:\x20\x221850\x22\x20},\x20...\x20]'},'referenceWidgetId':a0_0x4756bb(0xf6),'socNotes':a0_0x4756bb(0x102)},{'id':'metric_progress_to_goal','name':a0_0x4756bb(0xee),'useCase':a0_0x4756bb(0x103),'payloadShape':{'id':a0_0x4756bb(0xd6),'queries':{'value':a0_0x4756bb(0xdb),'trend':'file:query/<path>/trend.sql','target':'file:query/<path>/target.sql'}},'sqlShapesPerKey':[{'key':'value','shape':a0_0x4756bb(0xe7),'outputColumns':[a0_0x4756bb(0xbe)],'collapseRule':'scalar\x20primitive'},{'key':'trend','shape':a0_0x4756bb(0xe3),'outputColumns':[a0_0x4756bb(0xf7),'pct'],'collapseRule':a0_0x4756bb(0xc4)},{'key':'target','shape':a0_0x4756bb(0xe7),'outputColumns':['target'],'collapseRule':'scalar\x20primitive'}],'responseShape':{'value':a0_0x4756bb(0xad),'trend':'{\x20\x22direction\x22:\x20\x22down\x22,\x20\x22pct\x22:\x20\x222.2\x22\x20}','target':a0_0x4756bb(0xfa)},'referenceWidgetId':a0_0x4756bb(0xca),'socNotes':a0_0x4756bb(0xcb)}],NAMING_CONVENTION={'dashboardName':{'constraint':'MUST\x20start\x20with\x20\x27dash-\x27\x20prefix','minLength':0x6,'maxLength':0x32,'regex':'^dash-[a-zA-Z0-9_-]+$','examples':[a0_0x4756bb(0xaa),'dash-inbound','dash-author-stats'],'rationale':'The\x20prefix\x20becomes\x20part\x20of\x20the\x20URL\x20segment.\x20The\x20reserved\x20scheme\x20keeps\x20dashboard\x20endpoints\x20visually\x20distinct\x20from\x20CRUD\x20endpoints\x20in\x20the\x20URL\x20space\x20and\x20allows\x20future\x20routing\x20differentiation.'}},URL_PATTERN={'method':'POST','path':a0_0x4756bb(0xbf),'exampleFull':a0_0x4756bb(0xe4),'requestBodyShape':{'params':'object\x20—\x20values\x20for\x20declared\x20params\x20(validated\x20against\x20params\x20contract;\x20missing\x20required\x20→\x20400,\x20type\x20mismatch\x20→\x20400)','widgets':'array<string>,\x20optional\x20—\x20subset\x20of\x20widget\x20IDs\x20to\x20execute.\x20Omit\x20to\x20execute\x20all\x20declared\x20widgets.'},'responseShape':{'envelope':a0_0x4756bb(0xf4),'perWidgetResponse':a0_0x4756bb(0xfd)}},FILE_REFERENCE_CONVENTION={'format':a0_0x4756bb(0xaf),'pathRelativeTo':'payload\x20JSON\x20file\x20location','fileExtensionPolicy':'free;\x20.sql\x20recommended\x20for\x20editor\x20highlight','resolvedAt':'generation\x20time\x20(NOT\x20runtime)','embedStrategy':a0_0x4756bb(0xea),'implication':a0_0x4756bb(0xec)},PLACEHOLDER_CONVENTION={'format':':paramName','regex':a0_0x4756bb(0xc2),'regexNotes':'Negative\x20lookbehind\x20prevents\x20matching\x20\x27::\x27\x20(Postgres\x20cast\x20syntax)\x20as\x20a\x20placeholder.','scanScope':a0_0x4756bb(0xce),'constraint':a0_0x4756bb(0xe6),'exampleSql':'SELECT\x20*\x20FROM\x20stock_inbound\x20WHERE\x20EXTRACT(YEAR\x20FROM\x20inbound_date)\x20=\x20:year','exampleParamDeclaration':a0_0x4756bb(0xd1)},CACHE_SPEC={'container':'top-level\x20\x27cache\x27\x20object','optional':!![],'rationale':'Dashboard\x20endpoint\x20may\x20opt-in\x20to\x20Redis-based\x20cache.\x20Pattern\x20follows\x20processor\x20cache\x20(see\x20feat-cache.md).\x20Cache\x20scope\x20is\x20the\x20full\x20response\x20envelope;\x20one\x20cache\x20entry\x20per\x20(params\x20+\x20widgets[]\x20subset)\x20combination.','fields':[{'name':'enabled','type':a0_0x4756bb(0xd2),'required':!![],'description':a0_0x4756bb(0xb2)},{'name':a0_0x4756bb(0xff),'type':'number','required':![],'constraint':'>=\x200\x20(seconds)','default':'inherits\x20CACHE_TTL\x20env','description':'Time-to-live\x20in\x20seconds.\x200\x20effectively\x20disables\x20cache\x20for\x20this\x20entry.'},{'name':'invalidates','type':a0_0x4756bb(0xc6),'required':![],'default':'[]','description':a0_0x4756bb(0xd4)}],'validation':{'sqlCrossReference':'When\x20cache.enabled\x20===\x20true\x20and\x20invalidates\x20is\x20non-empty:\x20validator\x20extracts\x20table\x20candidates\x20from\x20widget\x20SQL\x20(regex\x20FROM/JOIN),\x20cross-references\x20with\x20metadata/{project}.json\x20(endpoints[*].tableName\x20where\x20type\x20===\x20\x22module\x22),\x20and\x20asserts\x20equality\x20of\x20expected\x20vs\x20declared\x20sets.\x20Mismatches\x20are\x20reported\x20per\x20category\x20(missing,\x20extra,\x20unmatched).','errorOn':['Table\x20appears\x20in\x20SQL\x20AND\x20in\x20metadata\x20project,\x20but\x20missing\x20from\x20invalidates\x20(cache\x20stale\x20risk)',a0_0x4756bb(0xdf)],'warningOn':['Table\x20detected\x20in\x20SQL,\x20but\x20not\x20registered\x20as\x20CRUD\x20endpoint\x20in\x20metadata\x20project\x20(likely\x20a\x20view,\x20CTE\x20alias,\x20or\x20cross-project\x20table\x20—\x20cascade\x20will\x20not\x20fire)']}},DOCUMENTATION_URL='https://restforge.dev/docs/server/query-data/dashboard',DASHBOARD_CATALOG={'schemaVersion':'1.0','source':a0_0x4756bb(0xcc),'summary':{'totalAllowedTopLevelFields':PAYLOAD_SHAPE[a0_0x4756bb(0xd8)]['length'],'totalForbiddenFrontendFields':FORBIDDEN_FRONTEND_FIELDS['length'],'totalParamTypes':ALLOWED_PARAM_TYPES['length'],'totalScalarCollapseRules':SCALAR_COLLAPSE_RULES['length'],'totalCommonWidgetPatterns':COMMON_WIDGET_PATTERNS[a0_0x4756bb(0xc0)]},'payloadShape':PAYLOAD_SHAPE,'widgetSpec':WIDGET_SPEC,'paramSpec':PARAM_SPEC,'scalarCollapseRules':SCALAR_COLLAPSE_RULES,'commonWidgetPatterns':COMMON_WIDGET_PATTERNS,'namingConvention':NAMING_CONVENTION,'urlPattern':URL_PATTERN,'fileReferenceConvention':FILE_REFERENCE_CONVENTION,'placeholderConvention':PLACEHOLDER_CONVENTION,'cacheSpec':CACHE_SPEC,'documentationUrl':DOCUMENTATION_URL};module['exports']={'DASHBOARD_CATALOG':DASHBOARD_CATALOG};
1
+ const a0_0x2659ec=a0_0x3123;function a0_0x3123(_0x3453ca,_0x3ebf10){_0x3453ca=_0x3453ca-0x1ca;const _0xd56b41=a0_0xd56b();let _0x3123bd=_0xd56b41[_0x3453ca];if(a0_0x3123['LjhHqG']===undefined){var _0x160abd=function(_0x228b94){const _0x3b01bd='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x999290='',_0x554244='';for(let _0x3693f0=0x0,_0x3bf121,_0x4c17c9,_0x1bddf2=0x0;_0x4c17c9=_0x228b94['charAt'](_0x1bddf2++);~_0x4c17c9&&(_0x3bf121=_0x3693f0%0x4?_0x3bf121*0x40+_0x4c17c9:_0x4c17c9,_0x3693f0++%0x4)?_0x999290+=String['fromCharCode'](0xff&_0x3bf121>>(-0x2*_0x3693f0&0x6)):0x0){_0x4c17c9=_0x3b01bd['indexOf'](_0x4c17c9);}for(let _0x182fe0=0x0,_0x2910e6=_0x999290['length'];_0x182fe0<_0x2910e6;_0x182fe0++){_0x554244+='%'+('00'+_0x999290['charCodeAt'](_0x182fe0)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x554244);};a0_0x3123['JvXOmB']=_0x160abd,a0_0x3123['VFxKvD']={},a0_0x3123['LjhHqG']=!![];}const _0x4e576c=_0xd56b41[0x0],_0x1e9a8e=_0x3453ca+_0x4e576c,_0x1bdeca=a0_0x3123['VFxKvD'][_0x1e9a8e];return!_0x1bdeca?(_0x3123bd=a0_0x3123['JvXOmB'](_0x3123bd),a0_0x3123['VFxKvD'][_0x1e9a8e]=_0x3123bd):_0x3123bd=_0x1bdeca,_0x3123bd;}(function(_0x49959a,_0x13afe1){const _0x4b3d5b=a0_0x3123,_0x579a11=_0x49959a();while(!![]){try{const _0xaf9556=-parseInt(_0x4b3d5b(0x1d3))/0x1*(-parseInt(_0x4b3d5b(0x211))/0x2)+parseInt(_0x4b3d5b(0x1ef))/0x3+parseInt(_0x4b3d5b(0x21e))/0x4+-parseInt(_0x4b3d5b(0x226))/0x5+-parseInt(_0x4b3d5b(0x22d))/0x6+-parseInt(_0x4b3d5b(0x20f))/0x7*(parseInt(_0x4b3d5b(0x230))/0x8)+parseInt(_0x4b3d5b(0x20d))/0x9*(parseInt(_0x4b3d5b(0x22b))/0xa);if(_0xaf9556===_0x13afe1)break;else _0x579a11['push'](_0x579a11['shift']());}catch(_0x5773d1){_0x579a11['push'](_0x579a11['shift']());}}}(a0_0xd56b,0xdcd92));const FORBIDDEN_FRONTEND_FIELDS=['widgetType',a0_0x2659ec(0x1f6),a0_0x2659ec(0x213),'subtitle','color'],ALLOWED_PARAM_TYPES=[a0_0x2659ec(0x210),'number','boolean',a0_0x2659ec(0x1f5)],FRONTEND_CONCERN_REASONS={'widgetType':a0_0x2659ec(0x206),'layout':'Layout\x20is\x20a\x20frontend\x20rendering\x20concern.','title':'UI\x20label\x20is\x20a\x20frontend\x20rendering\x20concern.','subtitle':a0_0x2659ec(0x200),'color':a0_0x2659ec(0x222)},PAYLOAD_SHAPE={'discriminator':{'field':a0_0x2659ec(0x1fd),'presentMeans':'dashboard\x20payload','absentMeans':a0_0x2659ec(0x1e4),'conflictsWith':'tableName','conflictRationale':'A\x20payload\x20with\x20both\x20\x27widgets\x27\x20and\x20\x27tableName\x27\x20is\x20rejected\x20by\x20DashboardValidator.\x20Pick\x20one\x20shape.'},'topLevelAllowed':[{'name':a0_0x2659ec(0x1fd),'type':a0_0x2659ec(0x1f3),'required':!![],'minItems':0x1,'description':a0_0x2659ec(0x21a)},{'name':a0_0x2659ec(0x1f2),'type':a0_0x2659ec(0x1ec),'required':![],'description':a0_0x2659ec(0x212)},{'name':'cache','type':'object','required':![],'description':a0_0x2659ec(0x1e9)}],'topLevelForbidden':[{'name':a0_0x2659ec(0x1ff),'category':a0_0x2659ec(0x20e),'reason':a0_0x2659ec(0x1df)},...FORBIDDEN_FRONTEND_FIELDS[a0_0x2659ec(0x1ee)](_0x999290=>({'name':_0x999290,'category':a0_0x2659ec(0x1d1),'reason':FRONTEND_CONCERN_REASONS[_0x999290]}))]},WIDGET_SPEC={'requiredFields':[{'name':'id','type':'string','constraint':a0_0x2659ec(0x1f8),'description':a0_0x2659ec(0x221)}],'exclusiveQueryFields':{'rule':'A\x20widget\x20MUST\x20declare\x20exactly\x20one\x20of:\x20\x27query\x27\x20OR\x20\x27queries\x27.\x20Both\x20or\x20neither\x20is\x20rejected.','options':[{'name':'query','type':a0_0x2659ec(0x210),'format':'file:relative/path/to/query.sql','description':'Single\x20SQL\x20query\x20for\x20the\x20widget.','responseShape':a0_0x2659ec(0x1da)},{'name':'queries','type':'object','format':a0_0x2659ec(0x1ce),'minKeys':0x1,'description':a0_0x2659ec(0x1dc),'responseShape':'Per-key\x20based\x20on\x20scalarCollapseRules\x20below.'}]},'forbiddenFields':FORBIDDEN_FRONTEND_FIELDS},PARAM_SPEC={'container':'top-level\x20\x27params\x27\x20object','keyConvention':a0_0x2659ec(0x21d),'perEntryFields':[{'name':'type','required':!![],'allowedValues':ALLOWED_PARAM_TYPES,'description':a0_0x2659ec(0x1d0)},{'name':a0_0x2659ec(0x215),'required':![],'type':a0_0x2659ec(0x216),'default':![],'description':'When\x20true,\x20the\x20request\x20body\x20MUST\x20include\x20this\x20param\x20(otherwise\x20400).'},{'name':a0_0x2659ec(0x1fa),'required':![],'type':a0_0x2659ec(0x234),'description':'Default\x20value\x20applied\x20when\x20the\x20request\x20omits\x20this\x20param.\x20Validator\x20does\x20NOT\x20strictly\x20type-check\x20default;\x20runtime\x20is\x20responsible\x20for\x20compatibility.'}]},SCALAR_COLLAPSE_RULES=[{'appliesTo':'widget.query\x20(singular)','rule':a0_0x2659ec(0x1d4),'exampleSqlShape':a0_0x2659ec(0x1d8),'exampleResponse':a0_0x2659ec(0x21f)},{'appliesTo':'widget.queries.<key>\x20with\x20SQL\x20returning\x201\x20row\x20×\x201\x20column','rule':'Collapse\x20to\x20scalar\x20primitive\x20(the\x20value\x20of\x20the\x20single\x20column).','exampleSqlShape':'1\x20row\x20×\x201\x20col,\x20output\x20column\x20\x27value\x27','exampleResponse':a0_0x2659ec(0x208)},{'appliesTo':a0_0x2659ec(0x205),'rule':'Collapse\x20to\x20object\x20whose\x20keys\x20are\x20SQL\x20column\x20names\x20(lowercased).','exampleSqlShape':'1\x20row\x20×\x202\x20cols,\x20output\x20columns\x20\x27direction\x27,\x20\x27pct\x27','exampleResponse':a0_0x2659ec(0x1d9)},{'appliesTo':'widget.queries.<key>\x20with\x20SQL\x20returning\x20N\x20rows','rule':a0_0x2659ec(0x231),'exampleSqlShape':a0_0x2659ec(0x1eb),'exampleResponse':'\x22items\x22:\x20[{\x20\x22label\x22:\x20\x22Shoes\x22,\x20\x22value\x22:\x20\x227660\x22\x20},\x20...]'}],COMMON_WIDGET_PATTERNS=[{'id':a0_0x2659ec(0x214),'name':a0_0x2659ec(0x1e8),'useCase':'Headline\x20metric\x20with\x20trend\x20chip\x20and\x20breakdown\x20across\x20categories.\x20Suitable\x20for\x20widgets\x20like\x20\x27Expected\x20Earnings\x27\x20that\x20show\x20total\x20value,\x20percentage\x20change,\x20and\x20per-category\x20contribution.','payloadShape':{'id':a0_0x2659ec(0x1d5),'queries':{'value':a0_0x2659ec(0x235),'trend':'file:query/<path>/trend.sql','items':'file:query/<path>/breakdown.sql'}},'sqlShapesPerKey':[{'key':a0_0x2659ec(0x21c),'shape':a0_0x2659ec(0x1d7),'outputColumns':[a0_0x2659ec(0x21c)],'collapseRule':'scalar\x20primitive'},{'key':a0_0x2659ec(0x1d6),'shape':'1\x20row\x20×\x202\x20columns','outputColumns':['direction','pct'],'collapseRule':'object'},{'key':'items','shape':'N\x20rows\x20×\x202\x20columns','outputColumns':[a0_0x2659ec(0x20c),a0_0x2659ec(0x21c)],'collapseRule':'array\x20of\x20objects'}],'responseShape':{'value':a0_0x2659ec(0x22c),'trend':a0_0x2659ec(0x1db),'items':a0_0x2659ec(0x218)},'referenceWidgetId':a0_0x2659ec(0x228),'socNotes':'Frontend\x20determines\x20donut/pie\x20variant,\x20color\x20per\x20category,\x20and\x20label\x20order.\x20If\x20per-category\x20percentage\x20is\x20needed\x20for\x20the\x20donut\x20arc,\x20frontend\x20computes\x20it\x20from\x20items[i].value\x20/\x20sum(items[*].value).\x20No\x20need\x20to\x20send\x20\x27pct\x27\x20from\x20backend\x20unless\x20the\x20figure\x20is\x20a\x20stable\x20business\x20calculation\x20independent\x20of\x20visual\x20rendering.'},{'id':a0_0x2659ec(0x22f),'name':a0_0x2659ec(0x209),'useCase':a0_0x2659ec(0x22e),'payloadShape':{'id':'<widget_id>','queries':{'value':'file:query/<path>/value.sql','trend':a0_0x2659ec(0x1f9),'points':'file:query/<path>/points.sql'}},'sqlShapesPerKey':[{'key':'value','shape':'1\x20row\x20×\x201\x20column','outputColumns':[a0_0x2659ec(0x21c)],'collapseRule':a0_0x2659ec(0x229)},{'key':'trend','shape':'1\x20row\x20×\x202\x20columns','outputColumns':[a0_0x2659ec(0x1ed),a0_0x2659ec(0x207)],'collapseRule':a0_0x2659ec(0x1ec)},{'key':a0_0x2659ec(0x201),'shape':'N\x20rows\x20×\x202\x20columns','outputColumns':[a0_0x2659ec(0x1f4),a0_0x2659ec(0x21c)],'collapseRule':'array\x20of\x20objects'}],'responseShape':{'value':'\x222420\x22','trend':a0_0x2659ec(0x1cd),'points':a0_0x2659ec(0x233)},'referenceWidgetId':a0_0x2659ec(0x217),'socNotes':a0_0x2659ec(0x1cc)},{'id':'metric_progress_to_goal','name':'Metric\x20+\x20Progress\x20to\x20Goal','useCase':a0_0x2659ec(0x204),'payloadShape':{'id':a0_0x2659ec(0x1d5),'queries':{'value':a0_0x2659ec(0x22a),'trend':'file:query/<path>/trend.sql','target':'file:query/<path>/target.sql'}},'sqlShapesPerKey':[{'key':a0_0x2659ec(0x21c),'shape':a0_0x2659ec(0x1d7),'outputColumns':['value\x20(or\x20current)'],'collapseRule':a0_0x2659ec(0x229)},{'key':'trend','shape':a0_0x2659ec(0x1fc),'outputColumns':['direction','pct'],'collapseRule':'object'},{'key':'target','shape':'1\x20row\x20×\x201\x20column','outputColumns':[a0_0x2659ec(0x202)],'collapseRule':a0_0x2659ec(0x229)}],'responseShape':{'value':'\x221836\x22','trend':'{\x20\x22direction\x22:\x20\x22down\x22,\x20\x22pct\x22:\x20\x222.2\x22\x20}','target':'\x222884\x22'},'referenceWidgetId':a0_0x2659ec(0x1e0),'socNotes':a0_0x2659ec(0x1d2)}],NAMING_CONVENTION={'dashboardName':{'constraint':a0_0x2659ec(0x224),'minLength':0x6,'maxLength':0x32,'regex':'^dash-[a-zA-Z0-9_-]+$','examples':[a0_0x2659ec(0x1ca),'dash-inbound',a0_0x2659ec(0x1e2)],'rationale':a0_0x2659ec(0x1de)}},URL_PATTERN={'method':a0_0x2659ec(0x1cb),'path':'/api/{project}/{name}/dashboard','exampleFull':'POST\x20/api/mini-inventory/dash-inbound/dashboard','requestBodyShape':{'params':a0_0x2659ec(0x20b),'widgets':a0_0x2659ec(0x203)},'responseShape':{'envelope':a0_0x2659ec(0x21b),'perWidgetResponse':'Determined\x20by\x20scalarCollapseRules.\x20Failed\x20widgets\x20produce\x20{\x20error:\x20\x27...\x27\x20}\x20block\x20with\x20top-level\x20success\x20still\x20true\x20(one\x20widget\x20failure\x20does\x20NOT\x20fail\x20the\x20dashboard).'}},FILE_REFERENCE_CONVENTION={'format':a0_0x2659ec(0x1ea),'pathRelativeTo':'payload\x20JSON\x20file\x20location','fileExtensionPolicy':a0_0x2659ec(0x1e6),'resolvedAt':a0_0x2659ec(0x1e7),'embedStrategy':a0_0x2659ec(0x1f7),'implication':a0_0x2659ec(0x1e5)},PLACEHOLDER_CONVENTION={'format':a0_0x2659ec(0x223),'regex':a0_0x2659ec(0x1e1),'regexNotes':'Negative\x20lookbehind\x20prevents\x20matching\x20\x27::\x27\x20(Postgres\x20cast\x20syntax)\x20as\x20a\x20placeholder.','scanScope':a0_0x2659ec(0x20a),'constraint':'Every\x20placeholder\x20used\x20in\x20SQL\x20MUST\x20be\x20declared\x20in\x20\x27params\x27.\x20Validator\x20throws\x20Error\x20with\x20message\x20format:\x20\x22Widget\x20\x27<id>\x27\x20query\x20\x27<label>\x27\x20uses\x20undeclared\x20placeholder\x20\x27:<token>\x27\x20(declare\x20in\x20\x27params\x27)\x22.','exampleSql':a0_0x2659ec(0x1fb),'exampleParamDeclaration':a0_0x2659ec(0x1f1)},CACHE_SPEC={'container':a0_0x2659ec(0x1f0),'optional':!![],'rationale':'Dashboard\x20endpoint\x20may\x20opt-in\x20to\x20Redis-based\x20cache.\x20Pattern\x20follows\x20processor\x20cache\x20(see\x20feat-cache.md).\x20Cache\x20scope\x20is\x20the\x20full\x20response\x20envelope;\x20one\x20cache\x20entry\x20per\x20(params\x20+\x20widgets[]\x20subset)\x20combination.','fields':[{'name':'enabled','type':'boolean','required':!![],'description':a0_0x2659ec(0x227)},{'name':'ttl','type':'number','required':![],'constraint':a0_0x2659ec(0x220),'default':'inherits\x20CACHE_TTL\x20env','description':'Time-to-live\x20in\x20seconds.\x200\x20effectively\x20disables\x20cache\x20for\x20this\x20entry.'},{'name':a0_0x2659ec(0x1cf),'type':'array<string>','required':![],'default':'[]','description':a0_0x2659ec(0x232)}],'validation':{'sqlCrossReference':'When\x20cache.enabled\x20===\x20true\x20and\x20invalidates\x20is\x20non-empty:\x20validator\x20extracts\x20table\x20candidates\x20from\x20widget\x20SQL\x20(regex\x20FROM/JOIN),\x20cross-references\x20with\x20metadata/{project}.json\x20(endpoints[*].tableName\x20where\x20type\x20===\x20\x22module\x22),\x20and\x20asserts\x20equality\x20of\x20expected\x20vs\x20declared\x20sets.\x20Mismatches\x20are\x20reported\x20per\x20category\x20(missing,\x20extra,\x20unmatched).','errorOn':[a0_0x2659ec(0x1fe),'Table\x20declared\x20in\x20invalidates,\x20but\x20not\x20detected\x20in\x20any\x20widget\x20SQL\x20(typo\x20or\x20dead\x20entry)'],'warningOn':[a0_0x2659ec(0x225)]}},DOCUMENTATION_URL=a0_0x2659ec(0x1e3),DASHBOARD_CATALOG={'schemaVersion':a0_0x2659ec(0x219),'source':'dashboard-catalog','summary':{'totalAllowedTopLevelFields':PAYLOAD_SHAPE['topLevelAllowed']['length'],'totalForbiddenFrontendFields':FORBIDDEN_FRONTEND_FIELDS['length'],'totalParamTypes':ALLOWED_PARAM_TYPES[a0_0x2659ec(0x1dd)],'totalScalarCollapseRules':SCALAR_COLLAPSE_RULES[a0_0x2659ec(0x1dd)],'totalCommonWidgetPatterns':COMMON_WIDGET_PATTERNS[a0_0x2659ec(0x1dd)]},'payloadShape':PAYLOAD_SHAPE,'widgetSpec':WIDGET_SPEC,'paramSpec':PARAM_SPEC,'scalarCollapseRules':SCALAR_COLLAPSE_RULES,'commonWidgetPatterns':COMMON_WIDGET_PATTERNS,'namingConvention':NAMING_CONVENTION,'urlPattern':URL_PATTERN,'fileReferenceConvention':FILE_REFERENCE_CONVENTION,'placeholderConvention':PLACEHOLDER_CONVENTION,'cacheSpec':CACHE_SPEC,'documentationUrl':DOCUMENTATION_URL};function a0_0xd56b(){const _0x40fc8a=['tvvtvcbZDgfYDcb3AxrOicDKyxnOlsCGChjLzML4','vgfIBguGzgv0zwn0zwqGAw4Gu1fmlcbIDxqGBM90ihjLz2LZDgvYzwqGyxmGq1jvrcbLBMrWB2LUDcbPBIbTzxrHzgf0ysbWCM9Qzwn0icHSAwTLBhKGysb2Awv3lcbdveuGywXPyxmSig9YignYB3nZlxbYB2PLy3qGDgfIBguG4OcuignHC2nHzguGD2LSBcbUB3qGzMLYzsK','mZC2mdy2mgjyEMjSvW','vg9Nz2XLignHy2HLigzLyxr1CMuGzM9YihrOAxmGzgfZAgjVyxjKlG','zxHWzwn0zwrFzwfYBMLUz3m','C2nHBgfYihbYAw1PDgL2zq','zMLSztPXDwvYEs88Cgf0Ad4Vy3vYCMvUDc5ZCwW','otK1ntKZmgnxwerzqW','iJy5nZaWiG','ntm1mdyWogP3rNH6Aq','sgvHzgXPBMuGBwv0CMLJihDPDgGGDhjLBMqGy2HPCcbHBMqGC3bHCMTSAw5Lig1PBMKTy2HHCNqGzM9YihnOB3j0ihDPBMrVD3mGkdCGzgf5CYWGmtiGBw9UDgHZlcbLDgmUks4Gu3vPDgfIBguGzM9YihDPzgDLDhmGBgLRzsaNqxzLCMfNzsbeywLSEsbtywXLCYCU','Bwv0CMLJx3nWyxjRBgLUzq','ohrbs1nzzW','uMv0DxjUigfZigfYCMf5ig9Mig9IAMvJDhmGkg5VignVBgXHChnLks4','tgLZDcbVzIbduLveihrHyMXLig5HBwvZihrOyxqSihDOzw4GD3jPDhrLBIWGD2LSBcb0CMLNz2vYigLUDMfSAwrHDgLVBIbVzIb0AgLZigrHC2HIB2fYzcbJywnOzs4','w3SGiNbLCMLVzci6iciYmdi2lta0lti0iIWGiNzHBhvLiJOGiJe4ntaIih0Sic4UlIbD','yw55icHTDxn0igjLignVBxbHDgLIBguGD2L0AcbKzwnSyxjLzcaNDhLWzsCP','zMLSztPXDwvYEs88Cgf0Ad4VDMfSDwuUC3fS','zgfZAc1ZywXLCW','ue9tva','u3bHCMTSAw5LigXPyNjHCMLLCYaOqxbLEenOyxj0CYWGq2HHCNrPC3qSigv0yY4Pihr5CgLJywXSEsbUzwvKigeGCgXHAw4GBNvTyMvYigfYCMf5lIbgCM9UDgvUzcbTyxbZihbVAw50CY5TyxaOCca9pIbWlNzHBhvLks4GvgHLicDWzxjPB2qNigzPzwXKihn0yxLZigzVCIb0B29SDgLWigfUzcbNyxaTCMvZAwXPzw5JzsbHz2fPBNn0ig1PC3nPBMCGzgf5CY4GvxnLigDLBMvYyxrLx3nLCMLLCYbPBIbtuuWGDg8Gzw5ZDxjLignVBNnPC3rLBNqGCM93ignVDw50igv2zw4GzM9YigrHExmGD2L0AcbUBYb0CMfUC2fJDgLVBNmU','EYaIzgLYzwn0Aw9UiJOGiNvWiIWGiNbJDci6iciYlJyIih0','A2v54OAszMLSztPYzwXHDgL2zs9WyxrOl3rVl3f1zxj5lNnXBa','Aw52ywXPzgf0zxm','ugfYyw0Gzgf0ysb0ExbLlIbwywXPzgf0zxmGCMvXDwvZDcbIB2r5igfUzcbZAgfWzxmGCNvUDgLTzsbWyxjHBwv0zxiGyMLUzgLUzY4','zNjVBNrLBMqTy29Uy2vYBG','rNjVBNrLBMqGy29TChv0zxmGDg9Fz29HBca9ihrHCMDLDcaTihzHBhvLigfUzcbWy3qGpsbYB3vUzcH2ywX1zsaVihrHCMDLDcaQideWmcKGzM9YihrOzsbWCM9NCMvZCYbIyxiUifzPC3vHBcb3Awr0AcbPCYbWCMvZzw50yxrPB25HBcbHBMqGBxvZDcbot1qGBgL2zsbPBIb0AguGyMfJA2vUzcbWyxLSB2fKlIbjzIbWCM9NCMvZCYbPBNzVBhzLCYbJB21WBgv4igj1C2LUzxnZihj1BgvZicHLlMCUigv4y2X1zguGD2vLA2vUzhmSihbYB3jHDgvKihDVCMTKyxLZksWGDxnLigeGC2LUz2XLig11BhrPlwnVBhvTBIbXDwvYEsbZBYaNCgn0jYbPCYbHihn0ywjSzsbIDxnPBMvZCYbMywn0ihjHDgHLCIb0AgfUihzPC3vHBcb3Awr0Ac4','mtvVy1Drq3u','qwX3yxLZihDYyxaGyxmGEYbPDgvTCZOGwY4UlL0GFsbYzwDHCMrSzxnZig9MifnrtcbYzxn1BhqGC2HHCguU','phDPzgDLDf9Pzd4','DhjLBMq','msbYB3CGW5CGmsbJB2X1Bw4','yw55icGXihjVDYddLYaXignVBcWGtIbYB3DZimoxie0Gy29SCYWGzxrJlIK','iNrYzw5KiJOGEYaIzgLYzwn0Aw9UiJOGiNvWiIWGiNbJDci6iciYlJiIih0','qwX3yxLZihSGAxrLBxm6ifSUlI5Dih0GCMvNyxjKBgvZCYbVzIbtuuWGCMvZDwX0ihnOyxbLlG','EYaIzgLYzwn0Aw9UiJOGiNvWiIWGiNbJDci6iciYlJiIih0','txvSDgKTu1fmihDPzgDLDc4GrwfJAcbRzxKGyMvJB21LCYbHigTLEsbPBIb0AguGCMvZCg9UC2uGB2jQzwn0lG','BgvUz3rO','vgHLihbYzwzPEcbIzwnVBwvZihbHCNqGB2yGDgHLifvstcbZzwDTzw50lIbuAguGCMvZzxj2zwqGC2nOzw1LigTLzxbZigrHC2HIB2fYzcbLBMrWB2LUDhmGDMLZDwfSBhKGzgLZDgLUy3qGzNjVBsbduLveigvUzhbVAw50CYbPBIb0AguGvvjmihnWywnLigfUzcbHBgXVD3mGzNv0DxjLihjVDxrPBMCGzgLMzMvYzw50Awf0Aw9UlG','uMvZzxj2zwqGzM9YiensvuqGCgf5Bg9HzhmUieeGzgfZAgjVyxjKihbHEwXVywqGBxvZDcbKzwnSyxjLicD3AwrNzxrZjYbPBNn0zwfKlG','B3jKzxjZx3rOAxnFBw9UDgG','kd88itOPoIHBys16qs1Ax11Bys16qs1Amc05x10Qkq','zgfZAc1HDxrOB3iTC3rHDhm','Ahr0Chm6lY9Yzxn0zM9Yz2uUzgv2l2rVy3mVC2vYDMvYl3f1zxj5lwrHDgeVzgfZAgjVyxjK','tM90igeGzgfZAgjVyxjKihbHEwXVywqGkgXPA2vSEsbduLveihDPDgGGDgfIBgvoyw1LlcbVCIbPBNzHBgLKkq','vxbKyxrPBMCGyw4Gu1fmigzPBguGCMvXDwLYzxmGCMvNzw5LCMf0Aw5NihrOzsbKyxnOyM9HCMqGBw9KDwXLicGNy29KzwDLBL9JCMvHDgvFzgfZAgjVyxjKjYKGzM9YignOyw5NzxmGDg8GDgfRzsbLzMzLy3qU','zNjLztSGlNnXBcbYzwnVBw1LBMrLzcbMB3iGzwrPDg9YigHPz2HSAwDODa','z2vUzxjHDgLVBIb0Aw1LicHot1qGCNvUDgLTzsK','twv0CMLJicSGrg9UDxqGqNjLywTKB3DU','t3b0Aw9UywWGy2fJAguGy29UzMLNDxjHDgLVBI4Gu2vLignHy2HLu3bLyYbMB3iGzgv0ywLSCY4','zMLSztPYzwXHDgL2zs9WyxrOl3rVl3f1zxj5lNnXBa','tIbYB3DZimoxie0Gy29SCW','B2jQzwn0','zgLYzwn0Aw9U','BwfW','mtm5ndG3n0fWCvjbqW','Dg9WlwXLDMvSicDJywnOzsCGB2jQzwn0','EYaICgfYyw1ZiJOGEYaIEwvHCIi6ihSGiNr5CguIoIaIBNvTyMvYiIWGiNjLCxvPCMvKiJOGDhj1zsb9ih0GFq','CgfYyw1Z','yxjYyxK','CgvYAw9K','zgf0zq','Bgf5B3v0','u1fmigzPBguGy29UDgvUDcbPCYbLBwjLzgrLzcbHCYbkyxzHu2nYAxb0ihrLBxbSyxrLigXPDgvYywWGAw5ZAwrLihrOzsbNzw5LCMf0zwqGBw9KDwXLigzPBguUifj1BNrPBwuGCgvYzM9YBxmGEMvYBYbKAxnRieKVtYbWzxiGCMvXDwvZDcdIGjqGywXSifnrtcbPCYbPBIbTzw1VCNKGywz0zxiGBw9KDwXLigXVywqU','BM9UlwvTChr5lcb1BMLXDwuGywnYB3nZihDPzgDLDhmGAw4GDgHLihnHBwuGCgf5Bg9Hza','zMLSztPXDwvYEs88Cgf0Ad4VDhjLBMqUC3fS','zgvMyxvSDa','u0vmrunuicOGrLjptsbZDg9JA19PBMjVDw5KifDirvjfievyvfjbq1qOwuvbuIbguK9nigLUyM91BMrFzgf0zsKGpsa6EwvHCG','msbYB3CGW5CGmIbJB2X1Bw5Z','D2LKz2v0CW','vgfIBguGyxbWzwfYCYbPBIbtuuWGqu5eigLUig1LDgfKyxrHihbYB2PLy3qSigj1DcbTAxnZAw5NigzYB20GAw52ywXPzgf0zxmGkgnHy2HLihn0ywXLihjPC2SP','DgfIBgvoyw1L','vuKGBgfIzwWGAxmGysbMCM9UDgvUzcbYzw5KzxjPBMCGy29Uy2vYBI4','Cg9PBNrZ','DgfYz2v0','yxjYyxK8C3rYAw5NpIWGB3b0Aw9UywWG4Ocuihn1yNnLDcbVzIb3AwrNzxqGsurZihrVigv4zwn1DguUie9TAxqGDg8GzxHLy3v0zsbHBgWGzgvJBgfYzwqGD2LKz2v0CY4','sgvHzgXPBMuGBwv0CMLJihDPDgGGDhjLBMqGy2HPCcbHBMqGChjVz3jLC3mGyMfYigfNywLUC3qGysbWzxjPB2qGDgfYz2v0lIbtDwL0ywjSzsbMB3iGD2LKz2v0CYbSAwTLicDpCMrLCNmGvgHPCYbnB250AcCU','D2LKz2v0lNf1zxjPzxmUpgTLEt4GD2L0AcbtuuWGCMv0DxjUAw5NideGCM93imoxig11BhrPCgXLignVBhvTBNm','vMLZDwfSihzHCMLHBNqGkgrVBNv0lcbIyxiSihbPzsWGyxjLysKGAxmGysbMCM9UDgvUzcbYzw5KzxjPBMCGy29Uy2vYBIaOC2vWyxjHDgLVBIbVzIbJB25JzxjUCYKU','Cgn0','iNzHBhvLiJOGiJy5nZaWiG','twv0CMLJicSGu3bHCMTSAw5L','qwXSihDPzgDLDcbtuuWG4OcuigjVDgGGj3f1zxj5jYaOC2LUz3vSyxiPigfUzcbLDMvYEsaNCxvLCMLLCY48A2v5pICU','B2jQzwn0iokaLcb2ywX1zxmGzM9YigrLy2XHCMvKihbHCMfTCYaODMfSAwrHDgvKigfNywLUC3qGCgfYyw1ZignVBNrYywn0oYbTAxnZAw5NihjLCxvPCMvKiokgKIa0mdaSihr5CguGBwLZBwf0y2GG4OAsidqWmcK','BgfIzwW','owXvDuT1rq','C2HHCguTy29UzMXPy3q','mtC1otaZn0v2r3LTvW','C3rYAw5N','mZq4ntzgB3HWq1O','ugfYyw1LDgvYignVBNrYywn0igzVCIb0AguGzgfZAgjVyxjKlIbfywnOigTLEsbPCYbHihbHCMfTig5HBwu7ihzHBhvLCYbKzxnJCMLIzsb0ExbLl3jLCxvPCMvKl2rLzMf1BhqUifbSywnLAg9SzgvYCYbPBNnPzguGD2LKz2v0ifnrtcbTDxn0ihjLzMvYzw5JzsbKzwnSyxjLzcbWyxjHBsbUyw1LCY4','DgL0Bgu','Bwv0CMLJx2rVBNv0x2jYzwfRzg93BG','CMvXDwLYzwq','yM9VBgvHBG','yxzNx2rHAwX5x3nHBgvZ','w3SGiMXHyMvSiJOGiLnOB2vZiIWGiNzHBhvLiJOGiJC2nJaIih0SihSGiMXHyMvSiJOGiKDHBwLUzYiSicj2ywX1zsi6iciYodiWiIb9lcb7icjSywjLBci6icjpDgHLCNmIlcaIDMfSDwuIoIaInduYntCIih1D','ms4W','tgLZDcbVzIb3AwrNzxqGzgvMAw5PDgLVBNmUie9YzgvYigLZigLUzM9YBwf0Aw9UywWGB25SEsaOCMvZCg9UC2uGA2v5CYbHCMuGyNKGD2LKz2v0igLKlcbUB3qGyxjYyxKGAw5KzxGPlG','EYbZDwnJzxnZoIbIB29SzwfUlcbKyxrHoIb7idX3AwrNzxrjzd46idXWzxjxAwrNzxrszxnWB25Zzt4Sic4UlIb9ih0','DMfSDwu','ugfYyw0GBMfTzsbTDxn0ig1HDgnOihrOzsbWBgfJzwHVBgrLCIbYzwDLEcbGw2eTEKeTwL9Dw2eTEKeTwJaTov9DkMaGkgfSCgHHBNvTzxjPyYaRihvUzgvYC2nVCMuSig11C3qGC3rHCNqGD2L0AcbSzxr0zxiGB3iGDw5KzxjZy29YzsKU','ndmXmti1mLfqELHJsa','iNnOB3bWAw5Nx2nHDgvNB3jPzxmIoIb7icjPDgvTCYi6ifT7icjUyw1LiJOGiKXHBMrZiIb9lcb7icjUyw1LiJOGiKHVDxnLCYiGFv0GFq','pJ0GmcaOC2vJB25KCYK','v2LKz2v0igLKzw50AwzPzxi7ihvZzwqGyxmGDgHLihjLC3bVBNnLigTLEsbPBIb0AguGzgfZAgjVyxjKigvUDMvSB3bLlG','vMLZDwfSignVBg9YigLZigeGzNjVBNrLBMqGCMvUzgvYAw5NignVBMnLCM4U','oNbHCMfTtMfTzq'];a0_0xd56b=function(){return _0x40fc8a;};return a0_0xd56b();}module['exports']={'DASHBOARD_CATALOG':DASHBOARD_CATALOG};
@@ -1 +1 @@
1
- const a0_0xefed8e=a0_0x40ad;function a0_0x478c(){const _0x40ef5c=['C3rHCNrZv2L0Aa','C2XPy2u','mtfJr0L1tg4','teLdru5trq','mJy4mta0qNzxsK9y','nLHvELj0AG','Dhj1zq','t0jYuxG','rK9Srw8','yM9VBgvHBG','DgvZDa','BgvUz3rO','otLesufLCfu','mJi4mZmWEgDuyvn4','tgfqwey','mZG2mJuWuwXms1nP','rejFtKfnrq','neryC2TJEq','mtq3nhLVv0f1ra','zMfSC2u','zxHWB3j0CW','C3bSAxq','mte3mZi1mNz2uufWuq','mtC0mdG5me9fBfb6vG','DhjPBq','Aw5JBhvKzxm','ChvZAa','nZjOC3jUBxa','mJa2nJG5v3vbr2vK','AgfZ','Aw50zwDLCG'];a0_0x478c=function(){return _0x40ef5c;};return a0_0x478c();}(function(_0x5a59dc,_0xcb4f48){const _0xf7ac4d=a0_0x40ad,_0x163350=_0x5a59dc();while(!![]){try{const _0xa5b92c=parseInt(_0xf7ac4d(0x1a2))/0x1*(parseInt(_0xf7ac4d(0x1a8))/0x2)+-parseInt(_0xf7ac4d(0x19a))/0x3*(-parseInt(_0xf7ac4d(0x1a7))/0x4)+parseInt(_0xf7ac4d(0x1ad))/0x5*(-parseInt(_0xf7ac4d(0x19b))/0x6)+parseInt(_0xf7ac4d(0x193))/0x7*(parseInt(_0xf7ac4d(0x192))/0x8)+-parseInt(_0xf7ac4d(0x1a3))/0x9+parseInt(_0xf7ac4d(0x1a5))/0xa+parseInt(_0xf7ac4d(0x198))/0xb*(parseInt(_0xf7ac4d(0x1ac))/0xc);if(_0xa5b92c===_0xcb4f48)break;else _0x163350['push'](_0x163350['shift']());}catch(_0x5d9990){_0x163350['push'](_0x163350['shift']());}}}(a0_0x478c,0x2e9ca));const DB_CONNECTION_ENV_TEMPLATE='#\x20License\x0aLICENSE=XXXX-XXXX-XXXX-XXXX\x0a\x0a#\x20Server\x0aSERVER_ADDRESS=127.0.0.1\x0aSERVER_PORT=3000\x0a\x0a#\x20Live\x20Sync\x20(WebSocket)\x20Configuration\x0a#\x20NOTE:\x20LIVE_SYNC_ENABLED=true\x20requires\x20an\x20API\x20Key\x20(KEY=...)\x20to\x20authenticate\x20WebSocket\x20clients\x0aLIVE_SYNC_ENABLED=false\x0aLIVE_SYNC_PORT=3033\x0a\x0a#\x20Redis\x20Configuration\x0aREDIS_HOST=localhost\x0aREDIS_PORT=6380\x0aREDIS_PASSWORD=\x0aREDIS_DB=0\x0a\x0a#\x20Export\x20Configuration\x0aEXPORT_FILE_EXPIRY=3600000\x0aEXPORT_CHUNK_SIZE=1000\x0a\x0a#\x20Kafka\x20Configuration\x0aKAFKA_ENABLED=false\x0a#\x20Broker\x20list\x20(comma-separated\x20for\x20multiple\x20brokers:\x20broker1:9092,broker2:9092,broker3:9092)\x0aKAFKA_BROKERS=localhost:9092\x0a#\x20Client\x20ID\x20(optional,\x20default:\x20restforge-{project}-producer\x20/\x20-consumer)\x0a#\x20KAFKA_CLIENT_ID=\x0aKAFKA_CONNECTION_TIMEOUT=3000\x0aKAFKA_REQUEST_TIMEOUT=25000\x0aKAFKA_TOPIC_PATTERN={module}.{endpoint}.events\x0aKAFKA_TENANT_ID=default\x0aKAFKA_SESSION_TIMEOUT=30000\x0aKAFKA_HEARTBEAT_INTERVAL=3000\x0aKAFKA_MAX_BYTES_PER_PARTITION=1048576\x0aKAFKA_AUTO_COMMIT=false\x0aKAFKA_AUTO_COMMIT_INTERVAL=5000\x0aKAFKA_RETRY_ATTEMPTS=3\x0aKAFKA_RETRY_DELAY=1000\x0aKAFKA_RETRY_MAX_DELAY=30000\x0aKAFKA_SSL=false\x0aKAFKA_LOG_LEVEL=info\x0a#\x20SASL\x20Authentication\x20(optional,\x20uncomment\x20if\x20the\x20broker\x20requires\x20authentication)\x0a#\x20Supported\x20mechanisms:\x20plain,\x20scram-sha-256,\x20scram-sha-512\x0a#\x20KAFKA_SASL_MECHANISM=plain\x0a#\x20KAFKA_SASL_USERNAME=\x0a#\x20KAFKA_SASL_PASSWORD=\x0a\x0a#\x20Database\x20Configuration\x0a#\x20Supported:\x20postgresql,\x20mysql,\x20oracle,\x20sqlite\x0aDB_TYPE=postgresql\x0aDB_HOST=127.0.0.1\x0aDB_PORT=5432\x0aDB_USER=postgres\x0aDB_PASSWORD=your_password_here\x0aDB_NAME=your_database_name\x0a#\x20For\x20SQLite:\x20set\x20DB_TYPE=sqlite\x20and\x20DB_NAME=./data/myapp.db\x0a#\x20DB_HOST,\x20DB_PORT,\x20DB_USER,\x20DB_PASSWORD\x20are\x20ignored\x20for\x20SQLite\x0a\x0a#\x20Logging\x20Configuration\x0aLOG_LEVEL=debug\x0aLOG_TO_FILE=true\x0a\x0a#\x20SQL\x20Logging\x0aSQL_LOG_ENABLED=false\x0aSQL_LOG_LEVEL=debug\x0aSQL_LOG_PARAMS=false\x0aSQL_LOG_SLOW_THRESHOLD=1000\x0a\x0a#\x20Cache\x20Configuration\x0aCACHE_ENABLED=false\x0aCACHE_TTL=300\x0a\x0a#\x20Job\x20Scheduler\x0aJOB_ENABLED=false\x0aJOB_CONCURRENCY=5\x0aJOB_RETENTION_HOURS=72\x0aJOB_FAILED_RETENTION_HOURS=168\x0aJOB_SHUTDOWN_TIMEOUT=10000\x0aJOB_STALLED_INTERVAL=30000\x0aJOB_MAX_STALLED_COUNT=2\x0a\x0a#\x20Distributed\x20Lock\x20Configuration\x0aLOCK_DISTRIBUTED_ENABLED=false\x0aLOCK_DISTRIBUTED_TTL=10\x0aLOCK_RESOURCE_MAX_TTL=600\x0aLOCK_DISTRIBUTED_RETRY=3\x0aLOCK_DISTRIBUTED_RETRY_DELAY=100\x0aLOCK_DISTRIBUTED_STRATEGY=reject\x0a\x0a#\x20ID\x20Generator\x20Configuration\x0aIDGEN_ENABLED=false\x0aIDGEN_IDEM_TTL=600\x0aIDGEN_COUNTER_TTL_MONTHLY=2764800\x0aIDGEN_COUNTER_TTL_DAILY=172800\x0aIDGEN_DEFAULT_MAX_RETRY=10\x0aIDGEN_DEFAULT_PIN_DIGITS=6\x0aIDGEN_DEFAULT_SERIAL_PATTERN=XXXX-XXXX-XXXX-XXXX\x0aIDGEN_DEFAULT_CODE_PATTERN=9999-9999\x0aIDGEN_ALLOW_RESET=false\x0a',REQUIRED_KEYS=new Set([a0_0xefed8e(0x199),'SERVER_ADDRESS','SERVER_PORT','DB_TYPE','DB_HOST','DB_PORT','DB_USER','DB_PASSWORD',a0_0xefed8e(0x1a6)]);function a0_0x40ad(_0x2a7397,_0xdcfab3){_0x2a7397=_0x2a7397-0x18f;const _0x478c48=a0_0x478c();let _0x40adad=_0x478c48[_0x2a7397];if(a0_0x40ad['SztYar']===undefined){var _0x589684=function(_0x4a9e0e){const _0x12d40b='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x1b77dc='',_0x2d6ac4='';for(let _0x647483=0x0,_0x5305a9,_0x1e1c98,_0x5bdb0c=0x0;_0x1e1c98=_0x4a9e0e['charAt'](_0x5bdb0c++);~_0x1e1c98&&(_0x5305a9=_0x647483%0x4?_0x5305a9*0x40+_0x1e1c98:_0x1e1c98,_0x647483++%0x4)?_0x1b77dc+=String['fromCharCode'](0xff&_0x5305a9>>(-0x2*_0x647483&0x6)):0x0){_0x1e1c98=_0x12d40b['indexOf'](_0x1e1c98);}for(let _0xf4c05c=0x0,_0x3679a9=_0x1b77dc['length'];_0xf4c05c<_0x3679a9;_0xf4c05c++){_0x2d6ac4+='%'+('00'+_0x1b77dc['charCodeAt'](_0xf4c05c)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x2d6ac4);};a0_0x40ad['VHtOKq']=_0x589684,a0_0x40ad['TYNANi']={},a0_0x40ad['SztYar']=!![];}const _0x3d17d1=_0x478c48[0x0],_0x296eec=_0x2a7397+_0x3d17d1,_0x1829b5=a0_0x40ad['TYNANi'][_0x296eec];return!_0x1829b5?(_0x40adad=a0_0x40ad['VHtOKq'](_0x40adad),a0_0x40ad['TYNANi'][_0x296eec]=_0x40adad):_0x40adad=_0x1829b5,_0x40adad;}function parseTemplateAsSchema(_0x2f65d9){const _0x203ac3=a0_0xefed8e,_0x57630a={'FOlEo':function(_0x533f97,_0x3dbe2e){return _0x533f97===_0x3dbe2e;},'LaPXF':'string','FmOqH':_0x203ac3(0x19c),'VmoMI':_0x203ac3(0x1a9),'OBrQx':_0x203ac3(0x195)},_0x332e8e=_0x2f65d9||DB_CONNECTION_ENV_TEMPLATE,_0x15a5d4=_0x332e8e[_0x203ac3(0x1ab)]('\x0a'),_0xde830=[];let _0x2f8acf=null,_0x591817=[];for(const _0x444ee7 of _0x15a5d4){const _0x294f7a=_0x444ee7[_0x203ac3(0x18f)]();if(_0x57630a[_0x203ac3(0x19e)](_0x294f7a,'')){_0x591817=[];continue;}if(_0x294f7a[_0x203ac3(0x196)]('#')){const _0x637756=_0x294f7a[_0x203ac3(0x197)](0x1)[_0x203ac3(0x18f)](),_0x5dc9f1=_0x637756[_0x203ac3(0x1a1)]>0x0&&_0x637756['length']<0x3c&&!_0x637756[_0x203ac3(0x190)](':')&&!/^[A-Z_]+=/['test'](_0x637756)&&/^[A-Z]/['test'](_0x637756);_0x5dc9f1&&_0x591817[_0x203ac3(0x1a1)]===0x0?_0x2f8acf=_0x637756:_0x591817['push'](_0x637756);continue;}const _0x5c6a7a=_0x444ee7['indexOf']('=');if(_0x5c6a7a>0x0){const _0x2fdfdf=_0x444ee7['slice'](0x0,_0x5c6a7a)['trim'](),_0x59d7b1=_0x444ee7[_0x203ac3(0x197)](_0x5c6a7a+0x1);let _0x461c7e=_0x57630a[_0x203ac3(0x1a4)];if(_0x59d7b1===_0x57630a['FmOqH']||_0x59d7b1===_0x57630a['VmoMI'])_0x461c7e=_0x203ac3(0x19f);else/^-?\d+$/[_0x203ac3(0x1a0)](_0x59d7b1)&&(_0x461c7e=_0x57630a[_0x203ac3(0x19d)]);_0xde830[_0x203ac3(0x191)]({'name':_0x2fdfdf,'section':_0x2f8acf,'type':_0x461c7e,'default':_0x59d7b1,'description':_0x591817['join']('\x20')||null,'required':REQUIRED_KEYS[_0x203ac3(0x194)](_0x2fdfdf)}),_0x591817=[];}}return _0xde830;}module[a0_0xefed8e(0x1aa)]={'DB_CONNECTION_ENV_TEMPLATE':DB_CONNECTION_ENV_TEMPLATE,'REQUIRED_KEYS':REQUIRED_KEYS,'parseTemplateAsSchema':parseTemplateAsSchema};
1
+ function a0_0x2877(){const _0x4b30b3=['DhjPBq','AgfZ','mta0uu9pB2fb','mJqWAvvyEKHV','otC4ne5ouujsBW','rejFvfLqrq','Aw50zwDLCG','rejFtKfnrq','C3rHCNrZv2L0Aa','mti2ote4AuvOzxbe','mZCYnJf2r2fVtvm','nZCXnZyWrM1zr2HL','neXyD0fYBa','ntuZnhnuuhjIra','ChvZAa','mtu5EwnbCxDT','C2XPy2u','sePbAg4','rejFvvnfuG','rejFse9tva','mJa3otGXmefxwwDStW','yM9VBgvHBG','teLdru5trq','C3bSAxq','Aw5KzxHpzG','rejFueftu1DpuKq','D0nhC04','sKHjvLq','Dhj1zq','zxHWB3j0CW','ntKYmJi5suPRrMTc','BgvUz3rO'];a0_0x2877=function(){return _0x4b30b3;};return a0_0x2877();}const a0_0x1b76c4=a0_0x4446;(function(_0x60483d,_0x59c50a){const _0x35a29a=a0_0x4446,_0x438d06=_0x60483d();while(!![]){try{const _0xe45e12=parseInt(_0x35a29a(0xc5))/0x1*(parseInt(_0x35a29a(0xc4))/0x2)+-parseInt(_0x35a29a(0xc7))/0x3*(-parseInt(_0x35a29a(0xdc))/0x4)+-parseInt(_0x35a29a(0xc3))/0x5+parseInt(_0x35a29a(0xdb))/0x6*(-parseInt(_0x35a29a(0xe2))/0x7)+-parseInt(_0x35a29a(0xda))/0x8*(-parseInt(_0x35a29a(0xe1))/0x9)+parseInt(_0x35a29a(0xcc))/0xa+-parseInt(_0x35a29a(0xd6))/0xb;if(_0xe45e12===_0x59c50a)break;else _0x438d06['push'](_0x438d06['shift']());}catch(_0x3ba4d8){_0x438d06['push'](_0x438d06['shift']());}}}(a0_0x2877,0x1b136));const DB_CONNECTION_ENV_TEMPLATE='#\x20License\x0aLICENSE=XXXX-XXXX-XXXX-XXXX\x0a\x0a#\x20Server\x0aSERVER_ADDRESS=127.0.0.1\x0aSERVER_PORT=3000\x0a\x0a#\x20Live\x20Sync\x20(WebSocket)\x20Configuration\x0a#\x20NOTE:\x20LIVE_SYNC_ENABLED=true\x20requires\x20an\x20API\x20Key\x20(KEY=...)\x20to\x20authenticate\x20WebSocket\x20clients\x0aLIVE_SYNC_ENABLED=false\x0aLIVE_SYNC_PORT=3033\x0a\x0a#\x20Redis\x20Configuration\x0aREDIS_HOST=localhost\x0aREDIS_PORT=6380\x0aREDIS_PASSWORD=\x0aREDIS_DB=0\x0a\x0a#\x20Export\x20Configuration\x0aEXPORT_FILE_EXPIRY=3600000\x0aEXPORT_CHUNK_SIZE=1000\x0a\x0a#\x20Kafka\x20Configuration\x0aKAFKA_ENABLED=false\x0a#\x20Broker\x20list\x20(comma-separated\x20for\x20multiple\x20brokers:\x20broker1:9092,broker2:9092,broker3:9092)\x0aKAFKA_BROKERS=localhost:9092\x0a#\x20Client\x20ID\x20(optional,\x20default:\x20restforge-{project}-producer\x20/\x20-consumer)\x0a#\x20KAFKA_CLIENT_ID=\x0aKAFKA_CONNECTION_TIMEOUT=3000\x0aKAFKA_REQUEST_TIMEOUT=25000\x0aKAFKA_TOPIC_PATTERN={module}.{endpoint}.events\x0aKAFKA_TENANT_ID=default\x0aKAFKA_SESSION_TIMEOUT=30000\x0aKAFKA_HEARTBEAT_INTERVAL=3000\x0aKAFKA_MAX_BYTES_PER_PARTITION=1048576\x0aKAFKA_AUTO_COMMIT=false\x0aKAFKA_AUTO_COMMIT_INTERVAL=5000\x0aKAFKA_RETRY_ATTEMPTS=3\x0aKAFKA_RETRY_DELAY=1000\x0aKAFKA_RETRY_MAX_DELAY=30000\x0aKAFKA_SSL=false\x0aKAFKA_LOG_LEVEL=info\x0a#\x20SASL\x20Authentication\x20(optional,\x20uncomment\x20if\x20the\x20broker\x20requires\x20authentication)\x0a#\x20Supported\x20mechanisms:\x20plain,\x20scram-sha-256,\x20scram-sha-512\x0a#\x20KAFKA_SASL_MECHANISM=plain\x0a#\x20KAFKA_SASL_USERNAME=\x0a#\x20KAFKA_SASL_PASSWORD=\x0a\x0a#\x20Database\x20Configuration\x0a#\x20Supported:\x20postgresql,\x20mysql,\x20oracle,\x20sqlite\x0aDB_TYPE=postgresql\x0aDB_HOST=127.0.0.1\x0aDB_PORT=5432\x0aDB_USER=postgres\x0aDB_PASSWORD=your_password_here\x0aDB_NAME=your_database_name\x0a#\x20For\x20SQLite:\x20set\x20DB_TYPE=sqlite\x20and\x20DB_NAME=./data/myapp.db\x0a#\x20DB_HOST,\x20DB_PORT,\x20DB_USER,\x20DB_PASSWORD\x20are\x20ignored\x20for\x20SQLite\x0a\x0a#\x20Logging\x20Configuration\x0aLOG_LEVEL=debug\x0aLOG_TO_FILE=true\x0a\x0a#\x20SQL\x20Logging\x0aSQL_LOG_ENABLED=false\x0aSQL_LOG_LEVEL=debug\x0aSQL_LOG_PARAMS=false\x0aSQL_LOG_SLOW_THRESHOLD=1000\x0a\x0a#\x20Cache\x20Configuration\x0aCACHE_ENABLED=false\x0aCACHE_TTL=300\x0a\x0a#\x20Job\x20Scheduler\x0aJOB_ENABLED=false\x0aJOB_CONCURRENCY=5\x0aJOB_RETENTION_HOURS=72\x0aJOB_FAILED_RETENTION_HOURS=168\x0aJOB_SHUTDOWN_TIMEOUT=10000\x0aJOB_STALLED_INTERVAL=30000\x0aJOB_MAX_STALLED_COUNT=2\x0a\x0a#\x20Distributed\x20Lock\x20Configuration\x0aLOCK_DISTRIBUTED_ENABLED=false\x0aLOCK_DISTRIBUTED_TTL=10\x0aLOCK_RESOURCE_MAX_TTL=600\x0aLOCK_DISTRIBUTED_RETRY=3\x0aLOCK_DISTRIBUTED_RETRY_DELAY=100\x0aLOCK_DISTRIBUTED_STRATEGY=reject\x0a\x0a#\x20ID\x20Generator\x20Configuration\x0aIDGEN_ENABLED=false\x0aIDGEN_IDEM_TTL=600\x0aIDGEN_COUNTER_TTL_MONTHLY=2764800\x0aIDGEN_COUNTER_TTL_DAILY=172800\x0aIDGEN_DEFAULT_MAX_RETRY=10\x0aIDGEN_DEFAULT_PIN_DIGITS=6\x0aIDGEN_DEFAULT_SERIAL_PATTERN=XXXX-XXXX-XXXX-XXXX\x0aIDGEN_DEFAULT_CODE_PATTERN=9999-9999\x0aIDGEN_ALLOW_RESET=false\x0a',REQUIRED_KEYS=new Set([a0_0x1b76c4(0xce),'SERVER_ADDRESS','SERVER_PORT',a0_0x1b76c4(0xdd),a0_0x1b76c4(0xcb),'DB_PORT',a0_0x1b76c4(0xca),a0_0x1b76c4(0xd1),a0_0x1b76c4(0xdf)]);function a0_0x4446(_0x232634,_0x41706b){_0x232634=_0x232634-0xc3;const _0x2877a7=a0_0x2877();let _0x444611=_0x2877a7[_0x232634];if(a0_0x4446['rVZLoE']===undefined){var _0x575ce7=function(_0x1d5e48){const _0x31ca05='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x2465c9='',_0x25ce98='';for(let _0x20aed2=0x0,_0x400b80,_0x3a33df,_0x3ac963=0x0;_0x3a33df=_0x1d5e48['charAt'](_0x3ac963++);~_0x3a33df&&(_0x400b80=_0x20aed2%0x4?_0x400b80*0x40+_0x3a33df:_0x3a33df,_0x20aed2++%0x4)?_0x2465c9+=String['fromCharCode'](0xff&_0x400b80>>(-0x2*_0x20aed2&0x6)):0x0){_0x3a33df=_0x31ca05['indexOf'](_0x3a33df);}for(let _0x983e1b=0x0,_0xe09f57=_0x2465c9['length'];_0x983e1b<_0xe09f57;_0x983e1b++){_0x25ce98+='%'+('00'+_0x2465c9['charCodeAt'](_0x983e1b)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x25ce98);};a0_0x4446['DLFRjw']=_0x575ce7,a0_0x4446['bQQxYk']={},a0_0x4446['rVZLoE']=!![];}const _0x1be273=_0x2877a7[0x0],_0x478130=_0x232634+_0x1be273,_0x4bd96b=a0_0x4446['bQQxYk'][_0x478130];return!_0x4bd96b?(_0x444611=a0_0x4446['DLFRjw'](_0x444611),a0_0x4446['bQQxYk'][_0x478130]=_0x444611):_0x444611=_0x4bd96b,_0x444611;}function parseTemplateAsSchema(_0x566ee5){const _0x405f53=a0_0x1b76c4,_0x1e2f92={'HJAhn':function(_0x362179,_0x1e5414){return _0x362179===_0x1e5414;},'JHIVT':'string','wCGsN':_0x405f53(0xd4),'rslgb':_0x405f53(0xcd),'vqpPX':_0x405f53(0xde)},_0x181ad8=_0x566ee5||DB_CONNECTION_ENV_TEMPLATE,_0x148d82=_0x181ad8[_0x405f53(0xcf)]('\x0a'),_0x33ec1b=[];let _0x228082=null,_0x19dab5=[];for(const _0x555e7e of _0x148d82){const _0x26898b=_0x555e7e[_0x405f53(0xd8)]();if(_0x26898b===''){_0x19dab5=[];continue;}if(_0x26898b[_0x405f53(0xe0)]('#')){const _0x179293=_0x26898b[_0x405f53(0xc8)](0x1)['trim'](),_0x54659d=_0x179293[_0x405f53(0xd7)]>0x0&&_0x179293[_0x405f53(0xd7)]<0x3c&&!_0x179293['includes'](':')&&!/^[A-Z_]+=/['test'](_0x179293)&&/^[A-Z]/['test'](_0x179293);_0x54659d&&_0x1e2f92[_0x405f53(0xc9)](_0x19dab5['length'],0x0)?_0x228082=_0x179293:_0x19dab5[_0x405f53(0xc6)](_0x179293);continue;}const _0x47f7f7=_0x555e7e[_0x405f53(0xd0)]('=');if(_0x47f7f7>0x0){const _0x302fc3=_0x555e7e['slice'](0x0,_0x47f7f7)['trim'](),_0x38e72f=_0x555e7e['slice'](_0x47f7f7+0x1);let _0x161f0d=_0x1e2f92[_0x405f53(0xd3)];if(_0x38e72f===_0x1e2f92[_0x405f53(0xd2)]||_0x38e72f==='false')_0x161f0d=_0x1e2f92['rslgb'];else/^-?\d+$/['test'](_0x38e72f)&&(_0x161f0d=_0x1e2f92['vqpPX']);_0x33ec1b['push']({'name':_0x302fc3,'section':_0x228082,'type':_0x161f0d,'default':_0x38e72f,'description':_0x19dab5['join']('\x20')||null,'required':REQUIRED_KEYS[_0x405f53(0xd9)](_0x302fc3)}),_0x19dab5=[];}}return _0x33ec1b;}module[a0_0x1b76c4(0xd5)]={'DB_CONNECTION_ENV_TEMPLATE':DB_CONNECTION_ENV_TEMPLATE,'REQUIRED_KEYS':REQUIRED_KEYS,'parseTemplateAsSchema':parseTemplateAsSchema};
@@ -1 +1 @@
1
- 'use strict';const a0_0x458212=a0_0x516c;function a0_0x4c75(){const _0x45b634=['q2fZy2fKzsbKzwXLDguVDxbKyxrLihrVignOAwXKihjVD3mU','DhLWzq','owzfu2zxAG','q29UC3rYywLUDcbUyw1LCYbHDxrVlwDLBMvYyxrLzcb3AxrOihr5CguTC3bLy2LMAwmGChjLzML4icHWAYWGzMSSigLKEcWGDxeSignRksbHBMqGzgLHBgvJDc1ZCgvJAwzPyYbTyxGGBgvUz3rOlG','ANnVBG','t3zLCNjPzguGChjPBwfYEsbRzxKUifnPBMDSzsbMAwvSzcbUyw1Lig9YignVBxbVC2L0zsbHCNjHEs4','t25LlxrVlw9UzsaOAw52zxjZzsbVzIbIzwXVBMDZvg8PlIbpChrPB25HBcbPBNzLCNnLigrLy2XHCMf0Aw9Uig9UihrOzsbWyxjLBNqGC2LKztSGzg9LCYbUB3qGywzMzwn0ieretc4','C3rYAw5NoJm2ihbR','zMLLBgrZ','q29UDhjHy3qGy29SDw1UigrLy2XHCMvKihDPDgGGysb3CM9UzYb0ExbLoIb2ywXPzgf0Aw9UievsuK9slG','C3fSAxrL','yM9VBgvHBIbKzwzHDwX0oNrYDwu','DgLTzxn0yw1WigrLzMf1Bhq6BM93kcK','nJLXBhvit2q','u3rHBMrHBg9UzsbJB25ZDhjHAw50CYaOCgSSig5VDg51BgWSihvUAxf1zsWGAw5KzxGPihrHA2uGBM8GDMfSDwuUifrOzsbSzwDHy3KGyxv0B1vWzgf0zsb0B2TLBIbPCYbZDgLSBcbWyxjZzwqGzM9YigjHy2T3yxjKignVBxbHDgLIAwXPDhKGyNv0igLZigrLChjLy2f0zwqGyw5KigHHCYbUBYbMDw5JDgLVBMfSigvMzMvJDc4','phr5Cgu+wZO8Bw9KAwzPzxi+xsbBpgnVBNn0CMfPBNq+wZO8DMfSDwu+xv0UlI4','EYbMAwvSzdOGiMrPC2nVDw50iIWGBhrLoIaXmdaGFq','DxbKyxrLzf9HDa','C3rYAw5NoJeWmcbKzwzHDwX0oIDWzw5KAw5NjW','vgHLifjerIbZB2z0rgvSzxrLigjSB2nRigLZigrLCML2zwqGzNjVBsbtreyGzhvYAw5NihbHEwXVywqGz2vUzxjHDguSig5LDMvYihDYAxr0zw4GBwfUDwfSBhKUifrHyMXLCYb3Ag9ZzsbKyxrHyMfZzsbJB2X1Bw5ZigLUy2X1zguGDgHLihnVzNqTzgvSzxrLignVBNrYywn0ig11C3qGyMuGzgvJBgfYzwqGAw4Gu0rgihDPDgGGysb2ywXPzcbZB2z0rgvSzxrLigjSB2nRigzVCIbWyxLSB2fKigDLBMvYyxrLihrVihn1y2nLzwqU','C3rYAw5NoJmYihvUAxf1zq','zgvJAw1HBdOXnsWY','zgvJAw1HBa','vgHLigzPzwXKig11C3qGAgf2zsbHihnPBMDSzs1JB2X1Bw4Gvu5juvvfignVBNn0CMfPBNqGkg5VifvosvfvrsWGB3iGB25SEsbJB21WB3nPDguGvu5juvvfoIbfuLjpuIKU','vhLWzsbPCYbTyw5KyxrVCNKGyxqGDgHLigjLz2LUBMLUzYbHBMqGBxvZDcbIzsbVBMuGB2yGzMLLBgruExbLCY4','C3rYAw5N','ieLtie5pvcbovuXmksbpuIaO','qwXSidqGy29SDw1UCYbHCMuGBNvSBgfIBguUifrOzsbJCMvHDgvKx2j5l3vWzgf0zwrFyNKGy29SDw1UCYbTyxKGyMuGzw1WDhKGzM9YihjVD3mGAw5Zzxj0zwqGyNKGC3LZDgvTihnLzwrZlcbTAwDYyxrPB25ZlcbVCIbIyxrJAcbPBxbVCNrZihrOyxqGzg8GBM90igHHDMuGysb1C2vYignVBNrLEhqU','mJzVy3HvA2W','qK9ptevbtIberuzbvuXuifrsvuu','EYb0ExbLoIaIAgfZt25LiIWGDgfYz2v0oIaIChjVzMLSzsiSigXVy2fSs2v5oIaIDxnLCL9PzciSihjLzMvYzw5Jzxm6icj1C2vYx2LKiIb9','BhrL','vxnLCIbPzgvUDgLMAwvYicH1C2vYBMfTzsWGDxnLCL9PzcWGB3iGy29TCg9ZAxrLihrVA2vUksbVzIb0AguGCMvJB3jKignYzwf0B3iUifnLDcbIEsbHChbSAwnHDgLVBIbSyxLLCIbVBIbjtLnfuLqSig5VDcbIEsbKyxrHyMfZzsbKzwzHDwX0lG','rM9YzwLNBIbRzxKGCMvMzxjLBMnLlIbbDxrVlwDLBMvYyxrLCYbHigjLBg9Uz3nuBYbYzwXHDgLVBIbLBNrYEs4','rgvMzxiGy29UC3rYywLUDcbJAgvJAYaOC2vTyw50AwnHBgX5ihnPBwLSyxiGDg8GCMvZDhjPy3qGB24GBw9ZDcbKAwfSzwn0CYKU','Cg9ZDgDYzxm','w1SIC3rHDhvZiIWGiMnYzwf0zwrFyxqIxv0','v2HLBIbLBMfIBgvKid0GDhj1zsWGywXSihrOCMvLignVBhvTBNmGyMvSB3CGtvvtvcbIzsbKzwnSyxjLzcbPBIbMAwvSzhmGD2L0AcbLEgfJDgX5ihrOzxnLigXVz2LJywWGDhLWzxmUifrOzsbYzwXHDgLVBIbIzxr3zwvUihrOzsbIBg9JAYbHBMqGDgHLignVBhvTBNmGAxmGyMLJB25KAxrPB25HBc4','tgfZDcbTB2rPzMLJyxrPB24GDgLTzxn0yw1WlIbbDxrVlxvWzgf0zsbPCYbOyw5KBgvKigj5ihrOzsbsreyGCNvUDgLTzsaOqMfZzu1VzgvSigf1zgL0q29SDw1UCYbJB252zw50Aw9Uksb3AgLJAcbPBMPLy3rZihvWzgf0zwrFyxqGpsbdvvjsru5ux1rjtuvtvefnucbPBNrVigv2zxj5ifvqrefursbZDgf0zw1LBNqGyMfZzwqGB24GzMLLBgqGBMfTAw5NlcbUB3qGyNKGyw55ifnerIbTyxjRzxiUieLUAxrPywWGsu5trvjuihzHBhvLigLZigfSC28GAgfUzgXLzcbIEsb0AguGuKrgihj1BNrPBwuGyxvKAxrdB2X1Bw5ZigHLBhbLCI4','vMfYAwfIBguTBgvUz3rOihrLEhqUieXLBMD0AcbTB2rPzMLLCIbYzxf1AxjLzc4','C3rYAw5NoJm2igzRoMnHDgvNB3j5lMLK','tw9KAwzPzxiGAxmGBwfUzgf0B3j5igzVCIb0ExbLicjZDhjPBMCIicHSzw5NDgGPigfUzcaIzgvJAw1HBciGkhbYzwnPC2LVBIXZy2fSzsKU','C3rHBMrHBg9Uzq','yxjYyxK','nJzXzhD3zeO','revquKvdqvrfrdOGvgHPCYbTB2rPzMLLCIbUBYbSB25NzxiGAgfZigz1BMn0Aw9UywWGzwzMzwn0igf0ihrOzsbereWGB3iGCNvUDgLTzsbSzxzLBc4Gqxv0BY11CgrHDguGzM9YihvWzgf0zwrFyxqGAxmGAgfUzgXLzcbIEsb0AguGuKrgigXHEwvYicHHDwrPDenVBhvTBNmGy29UDMvUDgLVBIbPBIbcyxnLtw9KzwWGCNvUDgLTzsKGyMfZzwqGB24GzMLLBgqGBMfTAw5NignVBNzLBNrPB24Sig5VDcbIEsb0AgLZifnerIbTyxjRzxiUiev4Axn0Aw5NihvZywDLigLZihbYzxnLCNzLzcbMB3iGyMfJA3DHCMqGy29TCgf0AwjPBgL0EsbIDxqGC2HVDwXKigjLihjLBw92zwqGzNjVBsbUzxCGDgvTCgXHDgvZlG','q0Hfq0SGy29UC3rYywLUDhmUievHy2GGzw50CNKGDxnLCYbVCgvYyxrVCI1HCY1RzxKGC2HHCgu6ihSGBMfTzt8SigzPzwXKlca8B3bLCMf0B3i+oIa8DMfSDwu+ih0GD2HLCMuGpg9WzxjHDg9YpIbPCYbVBMuGB2yGy2HLy2TpCgvYyxrPB25ZicHPBIWGzxeSig5LCsWGz3qSigD0zsWGBhqSigX0zsKUifrOzsbPBNrLCM5HBcbjuIbZAgfWzsbHzNrLCIbPCI1IDwLSzgvYig5VCM1HBgL6yxrPB24GAxmGEYbUyw1LpYWGzMLLBgqSig9Wlcb2ywX1zsb9lcbIDxqGDgHHDcbPCYbot1qGDgHLihvZzxiGAw5WDxqGzM9YBwf0lG','yMLNAw50','uhjLy2LZAw9UigfUzcbZy2fSzsbYzxf1AxjLzcbMB3iGy3jVC3mTzgLHBgvJDcbWB3j0ywjPBgL0Es4','BNvTzxjPyW','C3rYAw5NoJy0igLUzgv4','zgjZy2HLBweTy2f0ywXVzW','BxLZCwW','u2v0iezlignVBhvTBIb0BYbovuXmig9UignOAwXKihjVD3mU','ieLtie5pvcbovuXmieforca','EYbMAwvSzdOGiMrPC2nVDw50iIWGBhq6ideWmcb9','t25LlxrVlw1HBNKGkgLUDMvYC2uGB2yGyMvSB25NC1rVks4Gt3b0Aw9UywWGAw52zxjZzsbKzwnSyxjHDgLVBIbVBIb0AguGCgfYzw50ihnPzgu7igrVzxmGBM90igfMzMvJDcbereWU','vKfsq0HbuIGZnIKGufjjtufswsblrvK','rgvMyxvSDcb2ywX1zsbMB3jTyxqGzgvWzw5KCYbVBIb0ExbLoIbYyxCGzM9YigjVB2XLyw4GkgrLzMf1Bhq6Dhj1zsKSihjHDYbMB3iGAw50zwDLCIaOzgvMyxvSDdOWksWGC2LUz2XLlxf1B3rLzcbMB3iGC3rYAw5NicHKzwzHDwX0oID2ywX1zsCPlcbIyxjLigLKzw50AwzPzxiGzM9YifnrtcbJB25ZDgfUDhmGkgrLzMf1Bhq6y3vYCMvUDf9KyxrLksWGAwrLBNrPzMLLCIGPigzVCIbUyxrPDMuGzNvUy3rPB24Gy2fSBhmGkgrLzMf1Bhq6BM93kcKPlG','tM90igvXDwfSihrVlG','ndK1ntyWnfbTsffTua','Bg9JywXlzxK','u3rYAw5NihnOB3j0AgfUzcbMB3iGzMLLBgqGzgvMAw5PDgLVBI4GvhLWzsbYzxf1AxjLzcbHDcbZDgfYDcWGzM9SBg93zwqGyNKGB3b0Aw9UywWGBw9KAwzPzxiGyw5KihnWywnLlxnLCgfYyxrLzcbJB25ZDhjHAw50CY4','DgLTzxn0yw1W','EYbMAwvSzdOGiNn0yxr1CYiSigLUoIbBiMfJDgL2zsiSicjPBMfJDgL2zsjDih0','rxf1ywWGDg8U','ody4mJrjr2T0t00','vKfsq0HbuIGXmdaPierfrKfvtfqGj3bLBMrPBMCN','uMvQzwn0igrLBgv0zs91CgrHDguGD2HLBIbJAgLSzcbYB3DZigv4Axn0lG','C3rYAw5NoJi1nsbUB3rUDwXS','vgfIBguGBMfTzsbTDxn0igjLigXVD2vYy2fZzsWGzgLNAxrZlcbHBMqGDw5KzxjZy29YzxmGB25SEs4','rgf0zsbHBMqGDgLTzsaOveLnrvnuqu1qks4','DMfSDwu','id0GrKfmu0uGqu5eia','CMvMzxjLBMnLCW','y3jLyxrLzf9IEq','vevyva','C25HA2vFy2fZzq','t2jQzwn0ig9MigzPzwXKigrLzMLUAxrPB25ZigLUihnOB3j0AgfUzcbZDhjPBMCGzM9YBwf0lG','B2jQzwn0','CMvSyxrPB25Z','DgfYz2v0','sw50zxiTDgfIBguGCMvSyxrPB25ZicHIzwXVBMDZvg8SigHHC09UzsWGAgfZtwfUEsKU','BgvUz3rO','tgvZCYb0AgfUlG','C2v0tNvSBa','y2fZy2fKzq','zgvJAw1HBdOXnsWYig5VDg51BgWGzgvMyxvSDdOW','rw5HyMXLCYbZB2z0lwrLBgv0zsbMB3iGDgHLihrHyMXLlIbtAgfWztOGEYbLBMfIBgvKoIbIB29SzwfUlcbYzxvZywjSzt86ifT7igzPzwXKlcbSzw5NDgGGFv0GFs4Gs2v5CYbVDgHLCIb0AgfUigvUywjSzwqGyw5KihjLDxnHyMXLigfYzsbYzwPLy3rLzcbHDcbZy2HLBweGBg9Hzc4Gv2HLBIbLBMfIBgvKlcb0AguGDgHYzwuGy29UDhjHy3qGy29SDw1UCYaOAxnFzgvSzxrLzcWGzgvSzxrLzf9HDcWGzgvSzxrLzf9IEsKGBxvZDcbIzsbKzwnSyxjLzcbPBIbMAwvSzhmUifnLzsb0AguGC29MDerLBgv0zsbZzwn0Aw9UigzVCIb0AguGzNvSBcbJB250CMfJDc4','u2LUz2XLlwnVBhvTBIb1BMLXDwuGy29UC3rYywLUDc4','EYbMAwvSzdOGiNr5CguIlcbLCtOGiNvZzxiIih0','B25ezwXLDgu','yhjLzMvYzw5JzxnGigLZihrOzsbIyxjLignVBhvTBIbUyw1LigLUihrOzsb0yxjNzxqGDgfIBguUifrHCMDLDcb0ywjSzsbPCYbHDxrVlwrLCML2zwqGzNjVBsb0AguGCMvSyxrPB24GA2v5ig5HBwuSig9Yig92zxjYAwrLihDPDgGGyhrHCMDLDgaU','y2HRxZX0ywjSzt5F','vgHLigzPzwXKig11C3qGyMuGzgvJBgfYzwqGAw4GzMLLBgrZicH1BMTUB3DUigzPzwXKoIbfuLjpuIKU','mta5mty4ofnotfn2qq','wwvZiokaLcbKyNnJAgvTytPPBML0igvTAxrZigfSBca0ignVBhvTBNmGyNKGzgvMyxvSDc4GvgfIBgvZihrOyxqGzg8GBM90ig5LzwqGyxvKAxqGkgXVB2T1Ccb0ywjSzxmSihn5C3rLBsb0ywjSzxmPignHBIbTyw51ywXSEsbYzw1VDMuGDgHLC2uGzMLLBgrZigzYB20GDgHLigDLBMvYyxrLzcbZA2vSzxrVBI4','veLnrvnuqu1qierfrKfvtfqGpg5HDgL2zv9UB3CGCgvYigrPywXLy3q+','rgvMyxvSDcb2ywX1zs4Gu2LUz2XLlxf1B3rLzcbMB3iGC3rYAw5NCYWGCMf3igzVCIbUDw1LCMLJl2jVB2XLyw4SigjHCMuGAwrLBNrPzMLLCIbMB3iGu1fmignVBNn0yw50CYWGAwrLBNrPzMLLCIGPigzVCIbUyxrPDMuGzNvUy3rPB24Gy2fSBhmU','nufkuLPtBG','Aw50zwDLCG','BxLZCwWY','u29MDc1KzwXLDguGy29SDw1UCYbKzwnSyxjLzcb3AgLSzsbLBMfIBgvKigLZig5VDcb0CNvLoIb2ywXPzgf0Aw9UievsuK9slG','yxv0B1vWzgf0zq','BMf0AxzLiejpt0Xfqu4','rKSGzMLLBgqGBxvZDcbIzsbUDwXSywjSzs4','tM9UlxvUAxf1zsbPBMrLEgvZig9UihnVzNqTzgvSzxrLihrHyMXLCYbHCMuGzw1PDhrLzcbHCYbqB3n0z3jLu1fmihbHCNrPywWGAw5KzxHLCYb3AxrOifDirvjfia','nta3ntiXn3H1ANveza','vw5PCxvLignVBNn0CMfPBNrZicHZAw5NBguGB3iGy29TCg9ZAxrLks4','vMfSDwuGy29UC3rYywLUDhmGkgrLzMf1BhqSigzRksbYzxf1AxjLignVBNn0CMfPBNq6DMfSDwuGzM9YBwf0lG','Dgv4Da','vKfsq0HbuIaOBgL0zxjHBcaIDhj1zsiViMzHBhnLiIK','v2HLBIbLBMfIBgvKid0GDhj1zsWGzxzLCNKGvu5juvvfignVBNn0CMfPBNqGB24GDgHLihrHyMXLigLZignOzwnRzwqGzM9YihnVzNqTzgvSzxrLigvSAwDPyMLSAxr5lG','twfYA3mGzMLLBgqGyxmGChjPBwfYEsbRzxKU','tM9UlxvUAxf1zsbPBMrLEgvZlIbfywnOigvUDhj5igLZigfYCMf5ig9MignVBhvTBIbUyw1LCYbVCIbVyMPLy3qGEYbUyw1LlcbJB2X1Bw5Zih0U','otq0odbJuhfHwNO','rgf0zsbVBMX5icHUBYb0Aw1LignVBxbVBMvUDcKU','rM9YzwLNBIbRzxKGDxnLCYbKB3qGBM90yxrPB246igzRoJX0ywjSzt4UpgnVBhvTBJ4GkguUzY4SigzRoMnHDgvNB3j5lMLKks4GvgHLihbHCNnLCIbYzwPLy3rZihbHCMvUDgHLC2vZihn5BNrHEc4','id0GvfjvrsbbtKqG','zgvJAw1HBdO8ChjLy2LZAw9UpIW8C2nHBgu+','vgHLigvYCM9Yig1LC3nHz2uGC3vNz2vZDhmGDhDVihDHExmGB3v0oIb1C2uGAgfYzc1KzwXLDguGzM9YihbYB2nLC3mTzhjPDMvUihrHyMXLCYaOyMfSyw5JzsWGBgvKz2vYlcbZBMfWC2HVDcWGCgvYAw9KlwnSB3nLksWGB3iGy2HHBMDLihrOzsbvtKLrvuuGAw50BYbHihnPBMDSzs1JB2X1Bw4GC3rYAw5Nigj1C2LUzxnZignVzguU','mti2otKWmZjzENHcEve','mti2otm4mgz3AKnUsG','EYbMAwvSzdOGiNr5CguIlcbUzxe6icjZExn0zw0Iih0','EYbMAwvSzdOGiNf0EsiSigD0ztOGmcb9','B25vCgrHDgu'];a0_0x4c75=function(){return _0x45b634;};return a0_0x4c75();}(function(_0x59b5ca,_0x13ff54){const _0x28eeec=a0_0x516c,_0x1b7f9d=_0x59b5ca();while(!![]){try{const _0x466419=parseInt(_0x28eeec(0x1a3))/0x1*(-parseInt(_0x28eeec(0x1ca))/0x2)+parseInt(_0x28eeec(0x1bb))/0x3*(parseInt(_0x28eeec(0x172))/0x4)+parseInt(_0x28eeec(0x193))/0x5*(parseInt(_0x28eeec(0x18f))/0x6)+parseInt(_0x28eeec(0x19b))/0x7+parseInt(_0x28eeec(0x1a9))/0x8*(-parseInt(_0x28eeec(0x1b0))/0x9)+-parseInt(_0x28eeec(0x1aa))/0xa+-parseInt(_0x28eeec(0x1da))/0xb*(-parseInt(_0x28eeec(0x16c))/0xc);if(_0x466419===_0x13ff54)break;else _0x1b7f9d['push'](_0x1b7f9d['shift']());}catch(_0xeca76a){_0x1b7f9d['push'](_0x1b7f9d['shift']());}}}(a0_0x4c75,0xe5d96));const {IS_DELETED_COLUMN,DELETED_AT_COLUMN,DELETED_BY_COLUMN,SOFT_DELETE_COLUMN_TYPES,SOFT_DELETE_SUFFIX_LENGTH,SOFT_DELETE_CHECK_SUFFIX,SOFT_DELETE_PHASE1_DIALECT}=require('../dbschema-kit/soft-delete-constants'),SCHEMA_VERSION='1.1',SOURCE=a0_0x458212(0x1e1),DOCUMENTATION_URL='https://restforge.dev/docs/cli/schema-definition',DEFINE_MODEL_OPTIONS=[{'name':'schema','required':![],'type':'string|null','description':'Database\x20schema\x20namespace\x20(multi-schema\x20database).','notes':'null\x20or\x20empty\x20string\x20means\x20default\x20schema.'},{'name':a0_0x458212(0x1b6),'required':!![],'type':'object','description':a0_0x458212(0x17e),'example':'{\x20id:\x20\x22string:36\x20pk\x22,\x20name:\x20\x22string:255\x20notnull\x22\x20}'},{'name':'primaryKey','required':![],'type':'string|array','description':a0_0x458212(0x1b3),'notes':'Auto-detected\x20from\x20field\x20shorthand\x20\x22pk\x22\x20when\x20not\x20specified.'},{'name':a0_0x458212(0x180),'required':![],'type':a0_0x458212(0x17f),'description':a0_0x458212(0x182),'example':'{\x20category:\x20{\x20type:\x20\x22belongsTo\x22,\x20references:\x20\x22category(id)\x22\x20}\x20}'},{'name':'indexes','required':![],'type':'array','description':a0_0x458212(0x1a2),'example':a0_0x458212(0x1d2)},{'name':'uniques','required':![],'type':a0_0x458212(0x1d9),'description':a0_0x458212(0x19c),'example':'[[\x22category_code\x22],\x20[\x22tenant_id\x22,\x20\x22category_code\x22]]'},{'name':'checks','required':![],'type':'array','description':a0_0x458212(0x1dc),'example':'[{\x20field:\x20\x22status\x22,\x20in:\x20[\x22active\x22,\x20\x22inactive\x22]\x20},\x20{\x20field:\x20\x22qty\x22,\x20gte:\x200\x20}]'},{'name':'softDelete','required':![],'type':'object','description':a0_0x458212(0x188),'example':'{\x20enabled:\x20true,\x20reusable:\x20[{\x20field:\x20\x22category_code\x22,\x20length:\x2050\x20}]\x20}','notes':'PostgreSQL-only\x20in\x20Phase\x201.\x20The\x20RDF\x20softDelete\x20block\x20is\x20derived\x20from\x20this\x20SDF\x20block\x20during\x20payload\x20generate,\x20never\x20written\x20by\x20hand.'}],FIELD_TYPES=[{'name':a0_0x458212(0x1c7),'description':a0_0x458212(0x1d5),'requiresModifier':!![],'modifierFormat':'string:<length>','example':'string:255','notes':'Explicit\x20length\x20required\x20for\x20cross-dialect\x20portability.'},{'name':a0_0x458212(0x19e),'description':'Long-form\x20text\x20without\x20length\x20limit\x20(TEXT/CLOB).','requiresModifier':![],'example':'text'},{'name':a0_0x458212(0x194),'description':'32-bit\x20signed\x20integer\x20(INT/INTEGER).','requiresModifier':![],'example':'integer'},{'name':'bigint','description':'64-bit\x20signed\x20integer\x20(BIGINT).','requiresModifier':![],'example':a0_0x458212(0x1dd)},{'name':a0_0x458212(0x1c4),'description':'Fixed-point\x20decimal.\x20Precision\x20and\x20scale\x20required.','requiresModifier':!![],'modifierFormat':a0_0x458212(0x1a7),'example':a0_0x458212(0x1c3),'notes':a0_0x458212(0x1de)},{'name':'boolean','description':'Boolean\x20value\x20(native\x20BOOLEAN\x20on\x20PostgreSQL,\x20VARCHAR\x20on\x20others).','requiresModifier':![],'example':'boolean'},{'name':'date','description':a0_0x458212(0x1a4),'requiresModifier':![],'example':'date'},{'name':a0_0x458212(0x16f),'description':a0_0x458212(0x177),'requiresModifier':![],'example':a0_0x458212(0x16f),'notes':'Default\x20timezone\x20behavior\x20is\x20dialect-specific.'},{'name':'uuid','description':'UUID.\x20Native\x20UUID\x20on\x20PostgreSQL,\x20VARCHAR(36)\x20on\x20others.','requiresModifier':![],'example':'uuid'},{'name':a0_0x458212(0x1b2),'description':'JSON\x20column\x20(JSONB\x20on\x20PostgreSQL,\x20JSON\x20on\x20MySQL,\x20CLOB\x20on\x20Oracle).','requiresModifier':![],'example':a0_0x458212(0x1b2)}],CONSTRAINTS=[{'name':'pk','kind':'standalone','description':a0_0x458212(0x1a1),'example':a0_0x458212(0x1b5)},{'name':'notnull','kind':a0_0x458212(0x1d8),'description':'NOT\x20NULL\x20constraint.','example':a0_0x458212(0x175)},{'name':'unique','kind':a0_0x458212(0x1d8),'description':a0_0x458212(0x189),'example':a0_0x458212(0x1c2)},{'name':'index','kind':a0_0x458212(0x1d8),'description':'Single-column\x20non-unique\x20index.','example':'string:64\x20index'},{'name':a0_0x458212(0x197),'kind':'standalone','deprecated':!![],'description':a0_0x458212(0x1db),'example':'timestamp','notes':'Engine\x20still\x20parses\x20this\x20token\x20(backward\x20compatibility),\x20but\x20DDL\x20output\x20is\x20identical\x20to\x20plain\x20\x27timestamp\x27.\x20Use\x20\x27timestamp\x27\x20alone.\x20The\x20actual\x20auto-update\x20behavior\x20is\x20documented\x20in\x20the\x20RDF\x20auditColumns\x20catalog\x20(field-validation:catalog).'},{'name':'default','kind':a0_0x458212(0x178),'description':a0_0x458212(0x192),'valueFormat':'default:<literal>\x20|\x20default:\x27<string>\x27\x20|\x20default:<constant>\x20|\x20default:<function>()','example':'boolean\x20default:true'},{'name':'fk','kind':'value','description':a0_0x458212(0x1cf),'valueFormat':'fk:<table>.<column>','example':'string:36\x20fk:category.id','notes':'Cannot\x20coexist\x20with\x20explicit\x20relation\x20entry\x20referencing\x20the\x20same\x20field.'}],RELATION_TYPES=[{'name':'belongsTo','description':'Many-to-one.\x20This\x20table\x20holds\x20the\x20FK\x20column\x20referencing\x20the\x20parent\x20table.','requiredFields':[a0_0x458212(0x1af),a0_0x458212(0x16d),'references'],'optionalFields':[a0_0x458212(0x181),a0_0x458212(0x18b),a0_0x458212(0x1ad)],'example':'{\x20type:\x20\x22belongsTo\x22,\x20localKey:\x20\x22category_id\x22,\x20references:\x20\x22category_id\x22,\x20onDelete:\x20\x22restrict\x22\x20}','notes':a0_0x458212(0x18c)},{'name':'hasOne','description':a0_0x458212(0x1b4),'requiredFields':[a0_0x458212(0x1af),'localKey',a0_0x458212(0x17a)],'optionalFields':[a0_0x458212(0x181),'onDelete',a0_0x458212(0x1ad)],'example':a0_0x458212(0x1cc)},{'name':'hasMany','description':a0_0x458212(0x1e6),'requiredFields':[a0_0x458212(0x1af),a0_0x458212(0x16d),a0_0x458212(0x17a)],'optionalFields':['target','onDelete','onUpdate'],'example':'{\x20type:\x20\x22hasMany\x22,\x20target:\x20\x22order_item\x22,\x20localKey:\x20\x22order_id\x22,\x20references:\x20\x22order_id\x22\x20}'}],REFERENTIAL_ACTIONS=[{'name':a0_0x458212(0x186),'description':a0_0x458212(0x1ae),'appliesTo':[a0_0x458212(0x18b),'onUpdate']},{'name':'restrict','description':a0_0x458212(0x174),'appliesTo':['onDelete','onUpdate']},{'name':a0_0x458212(0x185),'description':a0_0x458212(0x1e3),'appliesTo':['onDelete',a0_0x458212(0x1ad)],'notes':a0_0x458212(0x199)},{'name':'noAction','description':a0_0x458212(0x1d0),'appliesTo':[a0_0x458212(0x18b),a0_0x458212(0x1ad)]}],CHECK_OPERATIONS=[{'name':'in','description':'Value\x20must\x20be\x20one\x20of\x20a\x20list.','valueType':a0_0x458212(0x1d9),'example':a0_0x458212(0x170)},{'name':'eq','description':a0_0x458212(0x171),'valueType':'scalar','example':a0_0x458212(0x18a)},{'name':'neq','description':a0_0x458212(0x16b),'valueType':'scalar','example':a0_0x458212(0x1ab)},{'name':'gt','description':'Greater\x20than.','valueType':a0_0x458212(0x1df),'example':'{\x20field:\x20\x22qty\x22,\x20gt:\x200\x20}'},{'name':'gte','description':'Greater\x20than\x20or\x20equal\x20to.','valueType':a0_0x458212(0x1df),'example':a0_0x458212(0x1ac)},{'name':'lt','description':a0_0x458212(0x184),'valueType':a0_0x458212(0x1df),'example':a0_0x458212(0x1e5)},{'name':a0_0x458212(0x1cd),'description':'Less\x20than\x20or\x20equal\x20to.','valueType':a0_0x458212(0x1df),'example':a0_0x458212(0x1be)}],AUDIT_COLUMNS={'description':'Standard\x204-column\x20audit\x20convention\x20for\x20tables\x20managed\x20by\x20RESTForge.\x20The\x20same\x20convention\x20is\x20documented\x20in\x20field-validation:catalog\x20(auditColumns\x20section)\x20for\x20the\x20RDF/backend\x20layer.\x20SDF\x20and\x20RDF\x20stay\x20aligned\x20when\x20both\x20declare\x20these\x204\x20columns.','columns':[{'name':'created_at','shorthand':'timestamp\x20default:now()','nullable':!![],'purpose':'Record\x20creation\x20timestamp.\x20Auto-set\x20on\x20INSERT\x20via\x20DEFAULT\x20now().\x20Native\x20function\x20translates\x20per\x20dialect\x20(postgres:\x20CURRENT_TIMESTAMP,\x20mysql:\x20NOW(),\x20oracle:\x20SYSTIMESTAMP,\x20sqlite:\x20CURRENT_TIMESTAMP).'},{'name':a0_0x458212(0x17b),'shorthand':'string:100','nullable':!![],'purpose':a0_0x458212(0x1ce)},{'name':a0_0x458212(0x1bf),'shorthand':'timestamp','nullable':!![],'purpose':a0_0x458212(0x1d4)},{'name':'updated_by','shorthand':'string:100','nullable':!![],'purpose':'User\x20identifier\x20of\x20the\x20last\x20modifier.\x20Set\x20by\x20application\x20layer\x20on\x20UPDATE,\x20not\x20by\x20database\x20default.'}],'convention':{'emitInSkeleton':a0_0x458212(0x190),'nullablePolicy':a0_0x458212(0x1c9),'relationToRdf':'The\x20RDF\x20generator\x20(codegen_create_endpoint)\x20assumes\x20these\x204\x20columns\x20exist\x20when\x20the\x20payload.auditColumns\x20key\x20is\x20absent.\x20See\x20field-validation:catalog\x20auditColumns\x20for\x20the\x20RDF-side\x20behavior.\x20Drift\x20between\x20SDF\x20(missing\x20audit\x20columns)\x20and\x20RDF\x20(assumes\x20audit\x20columns)\x20causes\x20runtime\x20errors\x20when\x20the\x20generated\x20endpoint\x20tries\x20to\x20write\x20created_by/updated_by\x20to\x20a\x20non-existent\x20column.'}},SOFT_DELETE={'description':'Soft-delete\x20contract\x20for\x20tables\x20declared\x20with\x20a\x20softDelete\x20block\x20(see\x20defineModelOptions.softDelete\x20for\x20the\x20block\x20shape).\x20Deleted\x20rows\x20are\x20flagged\x20through\x20three\x20contract\x20columns\x20instead\x20of\x20being\x20physically\x20removed.\x20SDF\x20is\x20the\x20single\x20declaration\x20point:\x20it\x20drives\x20DDL\x20emission\x20(columns,\x20consistency\x20CHECK,\x20partial\x20indexes)\x20and\x20the\x20RDF\x20softDelete\x20block\x20is\x20derived\x20from\x20it\x20during\x20payload\x20generate.','contractColumns':{'description':a0_0x458212(0x1d3),'columns':[{'name':IS_DELETED_COLUMN,'type':SOFT_DELETE_COLUMN_TYPES[IS_DELETED_COLUMN],'shorthand':'boolean\x20notnull\x20default:false','nullable':![],'purpose':'Deletion\x20flag.\x20Declare\x20as\x20notnull\x20default:false.'},{'name':DELETED_AT_COLUMN,'type':SOFT_DELETE_COLUMN_TYPES[DELETED_AT_COLUMN],'shorthand':a0_0x458212(0x16f),'nullable':!![],'purpose':'Deletion\x20timestamp,\x20nullable.\x20NULL\x20while\x20the\x20row\x20is\x20alive.'},{'name':DELETED_BY_COLUMN,'type':SOFT_DELETE_COLUMN_TYPES[DELETED_BY_COLUMN],'shorthand':'string:70','nullable':!![],'purpose':'Deletion\x20actor\x20identifier,\x20nullable.\x20NULL\x20while\x20the\x20row\x20is\x20alive.'}],'biconditionalRules':['enabled\x20=\x20true\x20with\x20all\x20three\x20columns\x20declared\x20and\x20correctly\x20typed:\x20valid.','enabled\x20=\x20true\x20with\x20any\x20contract\x20column\x20missing:\x20validation\x20ERROR\x20(missing\x20columns\x20are\x20listed).',a0_0x458212(0x196),a0_0x458212(0x1b7),'Consequence:\x20is_deleted,\x20deleted_at,\x20and\x20deleted_by\x20are\x20reserved\x20names;\x20they\x20cannot\x20be\x20used\x20as\x20ordinary\x20columns\x20in\x20RESTForge-managed\x20tables.']},'reusableRules':{'description':'Soft-delete\x20keeps\x20rows\x20in\x20the\x20table,\x20so\x20UNIQUE\x20constraints\x20still\x20see\x20deleted\x20rows.\x20Columns\x20listed\x20in\x20reusable\x20have\x20their\x20value\x20mutated\x20on\x20delete\x20to\x20\x22{value}##{uuidv7}\x22\x20so\x20the\x20original\x20value\x20can\x20be\x20reused\x20by\x20a\x20new\x20row.','requirements':[a0_0x458212(0x18e),'The\x20field\x20type\x20must\x20be\x20string\x20or\x20text\x20(value\x20mutation\x20requires\x20a\x20string\x20type:\x20ERROR\x20otherwise).',a0_0x458212(0x1c5),'length\x20must\x20be\x20a\x20positive\x20integer\x20(base\x20length\x20=\x20maximum\x20user-input\x20length):\x20ERROR\x20otherwise.'],'suffixLength':SOFT_DELETE_SUFFIX_LENGTH,'physicalLengthFormula':'physical\x20length\x20>=\x20base\x20length\x20+\x20'+SOFT_DELETE_SUFFIX_LENGTH,'notes':'The\x20'+SOFT_DELETE_SUFFIX_LENGTH+'-character\x20suffix\x20is\x20\x22##\x22\x20(2)\x20+\x20uuidv7\x20(36).\x20Example:\x20length:\x2050\x20requires\x20the\x20field\x20to\x20be\x20declared\x20at\x20least\x20string:88;\x20a\x20shorter\x20declaration\x20fails\x20validation\x20with\x20the\x20declared\x20and\x20required\x20lengths\x20in\x20the\x20message.'},'uniqueEligibilityGate':{'description':a0_0x458212(0x1a0),'rules':['Composite\x20UNIQUE\x20constraints\x20are\x20rejected:\x20they\x20cannot\x20be\x20freed\x20through\x20value\x20mutation,\x20so\x20re-creating\x20a\x20row\x20with\x20the\x20same\x20key\x20after\x20a\x20soft-delete\x20would\x20violate\x20the\x20constraint.','Single-column\x20UNIQUE\x20constraints\x20on\x20non-string\x20columns\x20are\x20rejected\x20for\x20the\x20same\x20reason\x20(suffix\x20mutation\x20only\x20applies\x20to\x20string/text).'],'suggestion':a0_0x458212(0x1a8)},'emittedDdl':{'consistencyCheck':{'namePattern':a0_0x458212(0x18d)+SOFT_DELETE_CHECK_SUFFIX,'description':'Every\x20soft-delete\x20table\x20gets\x20a\x20CHECK\x20constraint\x20with\x20the\x20deterministic\x20name\x20chk_<table>_'+SOFT_DELETE_CHECK_SUFFIX+'\x20enforcing:\x20('+IS_DELETED_COLUMN+a0_0x458212(0x1a6)+DELETED_AT_COLUMN+a0_0x458212(0x1e4)+DELETED_BY_COLUMN+a0_0x458212(0x1c8)+IS_DELETED_COLUMN+a0_0x458212(0x179)+DELETED_AT_COLUMN+'\x20IS\x20NULL\x20AND\x20'+DELETED_BY_COLUMN+'\x20IS\x20NULL).\x20This\x20keeps\x20the\x20three\x20columns\x20consistent\x20at\x20the\x20data\x20level\x20regardless\x20of\x20the\x20write\x20path.'},'partialIndex':{'description':a0_0x458212(0x19a)+IS_DELETED_COLUMN+'\x20=\x20FALSE.','example':'CREATE\x20INDEX\x20idx_visitor_categories_category_name\x20ON\x20visitor_categories\x20(category_name)\x20WHERE\x20'+IS_DELETED_COLUMN+'\x20=\x20FALSE','notes':'UNIQUE\x20constraints\x20are\x20NOT\x20made\x20partial\x20on\x20any\x20dialect.\x20Uniqueness\x20keeps\x20covering\x20deleted\x20rows;\x20value\x20reuse\x20is\x20handled\x20by\x20the\x20suffix\x20mutation,\x20not\x20by\x20a\x20partial\x20unique\x20index.'}},'dialectSupport':{'supported':[SOFT_DELETE_PHASE1_DIALECT],'description':'Phase\x201:\x20PostgreSQL\x20only.\x20On\x20other\x20dialects\x20the\x20softDelete\x20block\x20is\x20not\x20supported\x20(DDL\x20generation\x20fails\x20with\x20a\x20clear\x20error)\x20and\x20soft-delete-named\x20columns\x20get\x20no\x20special\x20treatment\x20during\x20introspect.'},'introspectRoundTrip':'schema\x20introspect\x20recognizes\x20a\x20complete\x20soft-delete\x20table\x20(three\x20correctly\x20typed\x20contract\x20columns\x20+\x20consistency\x20CHECK)\x20and\x20writes\x20back\x20softDelete:\x20{\x20enabled:\x20true\x20}\x20in\x20the\x20generated\x20SDF.\x20Tables\x20with\x20incomplete\x20or\x20non-conforming\x20soft-delete\x20columns\x20block\x20introspect\x20with\x20an\x20error.','rdfDerivation':a0_0x458212(0x1c1)},SHORTHAND_SYNTAX={'format':a0_0x458212(0x1bd),'description':a0_0x458212(0x16e),'rules':[a0_0x458212(0x1c6),a0_0x458212(0x1d7),a0_0x458212(0x1bc),a0_0x458212(0x19d),a0_0x458212(0x16a),a0_0x458212(0x1a5)],'examples':[{'input':'string:36\x20pk','meaning':a0_0x458212(0x1e7)},{'input':'string:255\x20notnull','meaning':'VARCHAR(255)\x20NOT\x20NULL'},{'input':a0_0x458212(0x187),'meaning':'DECIMAL(15,2)\x20NOT\x20NULL\x20DEFAULT\x200'},{'input':a0_0x458212(0x1b9),'meaning':a0_0x458212(0x1cb)},{'input':a0_0x458212(0x1c0),'meaning':a0_0x458212(0x173)},{'input':a0_0x458212(0x1ba),'meaning':a0_0x458212(0x191)},{'input':a0_0x458212(0x1d6),'meaning':'VARCHAR(36)\x20with\x20FK\x20to\x20category(id),\x20auto\x20belongsTo\x20relation'},{'input':a0_0x458212(0x1e0),'meaning':'VARCHAR(64)\x20with\x20single-column\x20index'}]},NAMING_RULES={'tableName':{'format':a0_0x458212(0x17d),'description':a0_0x458212(0x176)},'fieldName':{'format':'snake_case','description':'Column\x20name\x20must\x20be\x20snake_case.'},'constraintName':{'format':'<prefix>_<table>_<suffix>','defaultMaxLength':0x1e,'fallbackStrategy':'MD5\x20hash\x208-character\x20suffix\x20when\x20name\x20exceeds\x20maxLength','description':a0_0x458212(0x1b1)},'compositeShortName':{'description':'For\x20composite\x20indexes/uniques,\x20name\x20is\x20derived\x20by\x20joining\x20columns\x20with\x20underscore\x20and\x20truncating\x20when\x20needed.'}},DIALECT_SUPPORT=[{'name':a0_0x458212(0x1d1),'driver':'pg','booleanStorage':a0_0x458212(0x198)},{'name':a0_0x458212(0x1e2),'driver':a0_0x458212(0x195),'booleanStorage':a0_0x458212(0x19f)},{'name':'oracle','driver':'oracledb','booleanStorage':'VARCHAR2\x20with\x20CHECK\x20constraint'},{'name':a0_0x458212(0x1b8),'driver':'better-sqlite3','booleanStorage':a0_0x458212(0x17c)}],DBSCHEMA_CATALOG={'schemaVersion':SCHEMA_VERSION,'source':SOURCE,'summary':{'totalDefineModelOptions':DEFINE_MODEL_OPTIONS[a0_0x458212(0x183)],'totalFieldTypes':FIELD_TYPES['length'],'totalConstraints':CONSTRAINTS[a0_0x458212(0x183)],'totalRelationTypes':RELATION_TYPES[a0_0x458212(0x183)],'totalReferentialActions':REFERENTIAL_ACTIONS[a0_0x458212(0x183)],'totalCheckOperations':CHECK_OPERATIONS['length'],'totalAuditColumns':AUDIT_COLUMNS['columns']['length'],'totalDialects':DIALECT_SUPPORT[a0_0x458212(0x183)]},'defineModelOptions':DEFINE_MODEL_OPTIONS,'fieldTypes':FIELD_TYPES,'constraints':CONSTRAINTS,'relationTypes':RELATION_TYPES,'referentialActions':REFERENTIAL_ACTIONS,'checkOperations':CHECK_OPERATIONS,'auditColumns':AUDIT_COLUMNS,'softDelete':SOFT_DELETE,'shorthandSyntax':SHORTHAND_SYNTAX,'namingRules':NAMING_RULES,'dialectSupport':DIALECT_SUPPORT,'documentationUrl':DOCUMENTATION_URL};function a0_0x516c(_0x1d6e08,_0x5cf700){_0x1d6e08=_0x1d6e08-0x16a;const _0x4c7595=a0_0x4c75();let _0x516cc4=_0x4c7595[_0x1d6e08];if(a0_0x516c['sprinj']===undefined){var _0x1f6157=function(_0x284a7e){const _0x36d158='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x592a40='',_0x109658='';for(let _0x3c547e=0x0,_0x344bb5,_0x420c2b,_0x77e473=0x0;_0x420c2b=_0x284a7e['charAt'](_0x77e473++);~_0x420c2b&&(_0x344bb5=_0x3c547e%0x4?_0x344bb5*0x40+_0x420c2b:_0x420c2b,_0x3c547e++%0x4)?_0x592a40+=String['fromCharCode'](0xff&_0x344bb5>>(-0x2*_0x3c547e&0x6)):0x0){_0x420c2b=_0x36d158['indexOf'](_0x420c2b);}for(let _0x2c7963=0x0,_0x30e990=_0x592a40['length'];_0x2c7963<_0x30e990;_0x2c7963++){_0x109658+='%'+('00'+_0x592a40['charCodeAt'](_0x2c7963)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x109658);};a0_0x516c['QoIJQr']=_0x1f6157,a0_0x516c['GbuOLp']={},a0_0x516c['sprinj']=!![];}const _0x1c2fdb=_0x4c7595[0x0],_0x53eeac=_0x1d6e08+_0x1c2fdb,_0xe04b05=a0_0x516c['GbuOLp'][_0x53eeac];return!_0xe04b05?(_0x516cc4=a0_0x516c['QoIJQr'](_0x516cc4),a0_0x516c['GbuOLp'][_0x53eeac]=_0x516cc4):_0x516cc4=_0xe04b05,_0x516cc4;}module['exports']={'DBSCHEMA_CATALOG':DBSCHEMA_CATALOG,'DEFINE_MODEL_OPTIONS':DEFINE_MODEL_OPTIONS,'FIELD_TYPES':FIELD_TYPES,'CONSTRAINTS':CONSTRAINTS,'RELATION_TYPES':RELATION_TYPES,'REFERENTIAL_ACTIONS':REFERENTIAL_ACTIONS,'CHECK_OPERATIONS':CHECK_OPERATIONS,'AUDIT_COLUMNS':AUDIT_COLUMNS,'SOFT_DELETE':SOFT_DELETE,'SHORTHAND_SYNTAX':SHORTHAND_SYNTAX,'NAMING_RULES':NAMING_RULES,'DIALECT_SUPPORT':DIALECT_SUPPORT};
1
+ 'use strict';const a0_0x576039=a0_0x1e4e;(function(_0x2e894c,_0x1570a5){const _0x1b3251=a0_0x1e4e,_0x5f0a3c=_0x2e894c();while(!![]){try{const _0x51ec38=-parseInt(_0x1b3251(0x146))/0x1*(-parseInt(_0x1b3251(0xef))/0x2)+-parseInt(_0x1b3251(0xfc))/0x3+-parseInt(_0x1b3251(0x123))/0x4*(-parseInt(_0x1b3251(0x15f))/0x5)+parseInt(_0x1b3251(0x144))/0x6+-parseInt(_0x1b3251(0x15a))/0x7*(-parseInt(_0x1b3251(0x107))/0x8)+-parseInt(_0x1b3251(0x121))/0x9*(parseInt(_0x1b3251(0x125))/0xa)+parseInt(_0x1b3251(0xf2))/0xb*(-parseInt(_0x1b3251(0x128))/0xc);if(_0x51ec38===_0x1570a5)break;else _0x5f0a3c['push'](_0x5f0a3c['shift']());}catch(_0x393a2a){_0x5f0a3c['push'](_0x5f0a3c['shift']());}}}(a0_0x23cb,0x9bce1));function a0_0x1e4e(_0x4d76d2,_0x485dc7){_0x4d76d2=_0x4d76d2-0xdf;const _0x23cbc0=a0_0x23cb();let _0x1e4e63=_0x23cbc0[_0x4d76d2];if(a0_0x1e4e['ymPrbi']===undefined){var _0x3bbb06=function(_0x5cbc37){const _0x5dd2aa='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x3907f9='',_0x4ac29c='';for(let _0x2e20f4=0x0,_0x3646e5,_0x33aae6,_0x5b72cd=0x0;_0x33aae6=_0x5cbc37['charAt'](_0x5b72cd++);~_0x33aae6&&(_0x3646e5=_0x2e20f4%0x4?_0x3646e5*0x40+_0x33aae6:_0x33aae6,_0x2e20f4++%0x4)?_0x3907f9+=String['fromCharCode'](0xff&_0x3646e5>>(-0x2*_0x2e20f4&0x6)):0x0){_0x33aae6=_0x5dd2aa['indexOf'](_0x33aae6);}for(let _0xfc4dcc=0x0,_0x494606=_0x3907f9['length'];_0xfc4dcc<_0x494606;_0xfc4dcc++){_0x4ac29c+='%'+('00'+_0x3907f9['charCodeAt'](_0xfc4dcc)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x4ac29c);};a0_0x1e4e['WdRtfn']=_0x3bbb06,a0_0x1e4e['YQbxjr']={},a0_0x1e4e['ymPrbi']=!![];}const _0x21bfdb=_0x23cbc0[0x0],_0x2b362b=_0x4d76d2+_0x21bfdb,_0x3f43af=a0_0x1e4e['YQbxjr'][_0x2b362b];return!_0x3f43af?(_0x1e4e63=a0_0x1e4e['WdRtfn'](_0x1e4e63),a0_0x1e4e['YQbxjr'][_0x2b362b]=_0x1e4e63):_0x1e4e63=_0x3f43af,_0x1e4e63;}const {IS_DELETED_COLUMN,DELETED_AT_COLUMN,DELETED_BY_COLUMN,SOFT_DELETE_COLUMN_TYPES,SOFT_DELETE_SUFFIX_LENGTH,SOFT_DELETE_CHECK_SUFFIX,SOFT_DELETE_PHASE1_DIALECT}=require('../dbschema-kit/soft-delete-constants'),SCHEMA_VERSION=a0_0x576039(0xe3),SOURCE='dbschema-catalog',DOCUMENTATION_URL=a0_0x576039(0xf1),DEFINE_MODEL_OPTIONS=[{'name':'schema','required':![],'type':a0_0x576039(0xe1),'description':a0_0x576039(0xed),'notes':a0_0x576039(0x102)},{'name':a0_0x576039(0x11b),'required':!![],'type':'object','description':'Object\x20of\x20field\x20definitions\x20in\x20shorthand\x20string\x20format.','example':'{\x20id:\x20\x22string:36\x20pk\x22,\x20name:\x20\x22string:255\x20notnull\x22\x20}'},{'name':'primaryKey','required':![],'type':a0_0x576039(0x111),'description':a0_0x576039(0x157),'notes':a0_0x576039(0x150)},{'name':'relations','required':![],'type':'object','description':'Inter-table\x20relations\x20(belongsTo,\x20hasOne,\x20hasMany).','example':a0_0x576039(0x11c)},{'name':'indexes','required':![],'type':a0_0x576039(0x14c),'description':a0_0x576039(0x165),'example':'[[\x22status\x22,\x20\x22created_at\x22]]'},{'name':a0_0x576039(0x12d),'required':![],'type':a0_0x576039(0x14c),'description':a0_0x576039(0x119),'example':'[[\x22category_code\x22],\x20[\x22tenant_id\x22,\x20\x22category_code\x22]]'},{'name':a0_0x576039(0x15b),'required':![],'type':'array','description':a0_0x576039(0xec),'example':'[{\x20field:\x20\x22status\x22,\x20in:\x20[\x22active\x22,\x20\x22inactive\x22]\x20},\x20{\x20field:\x20\x22qty\x22,\x20gte:\x200\x20}]'},{'name':a0_0x576039(0x129),'required':![],'type':'object','description':a0_0x576039(0x109),'example':a0_0x576039(0x137),'notes':a0_0x576039(0x13d)}],FIELD_TYPES=[{'name':'string','description':a0_0x576039(0x101),'requiresModifier':!![],'modifierFormat':a0_0x576039(0x106),'example':a0_0x576039(0x122),'notes':'Explicit\x20length\x20required\x20for\x20cross-dialect\x20portability.'},{'name':a0_0x576039(0x158),'description':'Long-form\x20text\x20without\x20length\x20limit\x20(TEXT/CLOB).','requiresModifier':![],'example':a0_0x576039(0x158)},{'name':'integer','description':a0_0x576039(0x162),'requiresModifier':![],'example':'integer'},{'name':a0_0x576039(0x124),'description':'64-bit\x20signed\x20integer\x20(BIGINT).','requiresModifier':![],'example':'bigint'},{'name':'decimal','description':'Fixed-point\x20decimal.\x20Precision\x20and\x20scale\x20required.','requiresModifier':!![],'modifierFormat':a0_0x576039(0x13b),'example':'decimal:15,2','notes':a0_0x576039(0xe0)},{'name':'boolean','description':a0_0x576039(0xeb),'requiresModifier':![],'example':a0_0x576039(0x14f)},{'name':a0_0x576039(0xe7),'description':a0_0x576039(0x152),'requiresModifier':![],'example':a0_0x576039(0xe7)},{'name':'timestamp','description':a0_0x576039(0x145),'requiresModifier':![],'example':'timestamp','notes':'Default\x20timezone\x20behavior\x20is\x20dialect-specific.'},{'name':'uuid','description':'UUID.\x20Native\x20UUID\x20on\x20PostgreSQL,\x20VARCHAR(36)\x20on\x20others.','requiresModifier':![],'example':'uuid'},{'name':'json','description':a0_0x576039(0x103),'requiresModifier':![],'example':a0_0x576039(0xe9)}],CONSTRAINTS=[{'name':'pk','kind':a0_0x576039(0x143),'description':a0_0x576039(0x131),'example':'string:36\x20pk'},{'name':a0_0x576039(0x136),'kind':'standalone','description':a0_0x576039(0xfd),'example':a0_0x576039(0x127)},{'name':'unique','kind':'standalone','description':'Single-column\x20unique\x20constraint.','example':'string:32\x20unique'},{'name':'index','kind':a0_0x576039(0x143),'description':'Single-column\x20non-unique\x20index.','example':'string:64\x20index'},{'name':'autoUpdate','kind':'standalone','deprecated':!![],'description':a0_0x576039(0x13e),'example':a0_0x576039(0x12c),'notes':'Engine\x20still\x20parses\x20this\x20token\x20(backward\x20compatibility),\x20but\x20DDL\x20output\x20is\x20identical\x20to\x20plain\x20\x27timestamp\x27.\x20Use\x20\x27timestamp\x27\x20alone.\x20The\x20actual\x20auto-update\x20behavior\x20is\x20documented\x20in\x20the\x20RDF\x20auditColumns\x20catalog\x20(field-validation:catalog).'},{'name':'default','kind':'value','description':a0_0x576039(0x114),'valueFormat':'default:<literal>\x20|\x20default:\x27<string>\x27\x20|\x20default:<constant>\x20|\x20default:<function>()','example':'boolean\x20default:true'},{'name':'fk','kind':a0_0x576039(0x135),'description':a0_0x576039(0xf4),'valueFormat':'fk:<table>.<column>','example':'string:36\x20fk:category.id','notes':a0_0x576039(0x148)}],RELATION_TYPES=[{'name':a0_0x576039(0x14e),'description':a0_0x576039(0x142),'requiredFields':['type',a0_0x576039(0x113),a0_0x576039(0x138)],'optionalFields':['target',a0_0x576039(0x11f),'onUpdate'],'example':a0_0x576039(0x13a),'notes':a0_0x576039(0x110)},{'name':a0_0x576039(0x105),'description':a0_0x576039(0xf3),'requiredFields':['type',a0_0x576039(0x113),a0_0x576039(0x138)],'optionalFields':['target','onDelete',a0_0x576039(0x130)],'example':'{\x20type:\x20\x22hasOne\x22,\x20target:\x20\x22profile\x22,\x20localKey:\x20\x22user_id\x22,\x20references:\x20\x22user_id\x22\x20}'},{'name':a0_0x576039(0x10f),'description':'One-to-many\x20(inverse\x20of\x20belongsTo).\x20Optional\x20inverse\x20declaration\x20on\x20the\x20parent\x20side;\x20does\x20not\x20affect\x20DDL.','requiredFields':['type','localKey',a0_0x576039(0x138)],'optionalFields':[a0_0x576039(0x104),a0_0x576039(0x11f),'onUpdate'],'example':'{\x20type:\x20\x22hasMany\x22,\x20target:\x20\x22order_item\x22,\x20localKey:\x20\x22order_id\x22,\x20references:\x20\x22order_id\x22\x20}'}],REFERENTIAL_ACTIONS=[{'name':a0_0x576039(0x15c),'description':'Cascade\x20delete/update\x20to\x20child\x20rows.','appliesTo':[a0_0x576039(0x11f),'onUpdate']},{'name':a0_0x576039(0x13c),'description':a0_0x576039(0xea),'appliesTo':[a0_0x576039(0x11f),'onUpdate']},{'name':'setNull','description':a0_0x576039(0x151),'appliesTo':[a0_0x576039(0x11f),'onUpdate'],'notes':a0_0x576039(0x166)},{'name':'noAction','description':a0_0x576039(0x134),'appliesTo':['onDelete','onUpdate']}],CHECK_OPERATIONS=[{'name':'in','description':'Value\x20must\x20be\x20one\x20of\x20a\x20list.','valueType':a0_0x576039(0x14c),'example':a0_0x576039(0x15d)},{'name':'eq','description':'Equal\x20to.','valueType':a0_0x576039(0x147),'example':a0_0x576039(0x12e)},{'name':a0_0x576039(0x15e),'description':'Not\x20equal\x20to.','valueType':'scalar','example':a0_0x576039(0x11e)},{'name':'gt','description':a0_0x576039(0x163),'valueType':'numeric','example':'{\x20field:\x20\x22qty\x22,\x20gt:\x200\x20}'},{'name':'gte','description':a0_0x576039(0x141),'valueType':'numeric','example':'{\x20field:\x20\x22qty\x22,\x20gte:\x200\x20}'},{'name':'lt','description':a0_0x576039(0x12a),'valueType':a0_0x576039(0x14b),'example':'{\x20field:\x20\x22discount\x22,\x20lt:\x20100\x20}'},{'name':a0_0x576039(0x11d),'description':'Less\x20than\x20or\x20equal\x20to.','valueType':a0_0x576039(0x14b),'example':a0_0x576039(0xf6)}],AUDIT_COLUMNS={'description':'Standard\x204-column\x20audit\x20convention\x20for\x20tables\x20managed\x20by\x20RESTForge.\x20The\x20same\x20convention\x20is\x20documented\x20in\x20field-validation:catalog\x20(auditColumns\x20section)\x20for\x20the\x20RDF/backend\x20layer.\x20SDF\x20and\x20RDF\x20stay\x20aligned\x20when\x20both\x20declare\x20these\x204\x20columns.','columns':[{'name':a0_0x576039(0xdf),'shorthand':a0_0x576039(0x100),'nullable':!![],'purpose':'Record\x20creation\x20timestamp.\x20Auto-set\x20on\x20INSERT\x20via\x20DEFAULT\x20now().\x20Native\x20function\x20translates\x20per\x20dialect\x20(postgres:\x20CURRENT_TIMESTAMP,\x20mysql:\x20NOW(),\x20oracle:\x20SYSTIMESTAMP,\x20sqlite:\x20CURRENT_TIMESTAMP).'},{'name':'created_by','shorthand':a0_0x576039(0x149),'nullable':!![],'purpose':a0_0x576039(0x117)},{'name':a0_0x576039(0xf8),'shorthand':'timestamp','nullable':!![],'purpose':'Last\x20modification\x20timestamp.\x20Auto-update\x20is\x20handled\x20by\x20the\x20RDF\x20runtime\x20(BaseModel\x20auditColumns\x20convention)\x20which\x20injects\x20updated_at\x20=\x20CURRENT_TIMESTAMP\x20into\x20every\x20UPDATE\x20statement\x20based\x20on\x20field\x20naming,\x20not\x20by\x20any\x20SDF\x20marker.\x20Initial\x20INSERT\x20value\x20is\x20also\x20handled\x20by\x20the\x20RDF\x20runtime\x20auditColumns\x20helper.'},{'name':a0_0x576039(0x133),'shorthand':'string:100','nullable':!![],'purpose':a0_0x576039(0x14a)}],'convention':{'emitInSkeleton':'Yes\x20—\x20dbschema:init\x20emits\x20all\x204\x20columns\x20by\x20default.\x20Tables\x20that\x20do\x20not\x20need\x20audit\x20(lookup\x20tables,\x20system\x20tables)\x20can\x20manually\x20remove\x20these\x20fields\x20from\x20the\x20generated\x20skeleton.','nullablePolicy':a0_0x576039(0x132),'relationToRdf':'The\x20RDF\x20generator\x20(codegen_create_endpoint)\x20assumes\x20these\x204\x20columns\x20exist\x20when\x20the\x20payload.auditColumns\x20key\x20is\x20absent.\x20See\x20field-validation:catalog\x20auditColumns\x20for\x20the\x20RDF-side\x20behavior.\x20Drift\x20between\x20SDF\x20(missing\x20audit\x20columns)\x20and\x20RDF\x20(assumes\x20audit\x20columns)\x20causes\x20runtime\x20errors\x20when\x20the\x20generated\x20endpoint\x20tries\x20to\x20write\x20created_by/updated_by\x20to\x20a\x20non-existent\x20column.'}},SOFT_DELETE={'description':a0_0x576039(0x153),'contractColumns':{'description':a0_0x576039(0xfa),'columns':[{'name':IS_DELETED_COLUMN,'type':SOFT_DELETE_COLUMN_TYPES[IS_DELETED_COLUMN],'shorthand':a0_0x576039(0xf5),'nullable':![],'purpose':a0_0x576039(0x118)},{'name':DELETED_AT_COLUMN,'type':SOFT_DELETE_COLUMN_TYPES[DELETED_AT_COLUMN],'shorthand':a0_0x576039(0x12c),'nullable':!![],'purpose':a0_0x576039(0xe4)},{'name':DELETED_BY_COLUMN,'type':SOFT_DELETE_COLUMN_TYPES[DELETED_BY_COLUMN],'shorthand':a0_0x576039(0x14d),'nullable':!![],'purpose':a0_0x576039(0x108)}],'biconditionalRules':['enabled\x20=\x20true\x20with\x20all\x20three\x20columns\x20declared\x20and\x20correctly\x20typed:\x20valid.',a0_0x576039(0x10d),'Soft-delete\x20columns\x20declared\x20while\x20enabled\x20is\x20not\x20true:\x20validation\x20ERROR.',a0_0x576039(0x12b),'Consequence:\x20is_deleted,\x20deleted_at,\x20and\x20deleted_by\x20are\x20reserved\x20names;\x20they\x20cannot\x20be\x20used\x20as\x20ordinary\x20columns\x20in\x20RESTForge-managed\x20tables.']},'reusableRules':{'description':'Soft-delete\x20keeps\x20rows\x20in\x20the\x20table,\x20so\x20UNIQUE\x20constraints\x20still\x20see\x20deleted\x20rows.\x20Columns\x20listed\x20in\x20reusable\x20have\x20their\x20value\x20mutated\x20on\x20delete\x20to\x20\x22{value}##{uuidv7}\x22\x20so\x20the\x20original\x20value\x20can\x20be\x20reused\x20by\x20a\x20new\x20row.','requirements':['The\x20field\x20must\x20be\x20declared\x20in\x20fields\x20(unknown\x20field:\x20ERROR).',a0_0x576039(0x12f),a0_0x576039(0x10e),'length\x20must\x20be\x20a\x20positive\x20integer\x20(base\x20length\x20=\x20maximum\x20user-input\x20length):\x20ERROR\x20otherwise.'],'suffixLength':SOFT_DELETE_SUFFIX_LENGTH,'physicalLengthFormula':'physical\x20length\x20>=\x20base\x20length\x20+\x20'+SOFT_DELETE_SUFFIX_LENGTH,'notes':'The\x20'+SOFT_DELETE_SUFFIX_LENGTH+'-character\x20suffix\x20is\x20\x22##\x22\x20(2)\x20+\x20uuidv7\x20(36).\x20Example:\x20length:\x2050\x20requires\x20the\x20field\x20to\x20be\x20declared\x20at\x20least\x20string:88;\x20a\x20shorter\x20declaration\x20fails\x20validation\x20with\x20the\x20declared\x20and\x20required\x20lengths\x20in\x20the\x20message.'},'uniqueEligibilityGate':{'description':'When\x20enabled\x20=\x20true,\x20every\x20UNIQUE\x20constraint\x20on\x20the\x20table\x20is\x20checked\x20for\x20soft-delete\x20eligibility.','rules':['Composite\x20UNIQUE\x20constraints\x20are\x20rejected:\x20they\x20cannot\x20be\x20freed\x20through\x20value\x20mutation,\x20so\x20re-creating\x20a\x20row\x20with\x20the\x20same\x20key\x20after\x20a\x20soft-delete\x20would\x20violate\x20the\x20constraint.',a0_0x576039(0xe8)],'suggestion':a0_0x576039(0x156)},'emittedDdl':{'consistencyCheck':{'namePattern':'chk_<table>_'+SOFT_DELETE_CHECK_SUFFIX,'description':a0_0x576039(0x115)+SOFT_DELETE_CHECK_SUFFIX+'\x20enforcing:\x20('+IS_DELETED_COLUMN+a0_0x576039(0x139)+DELETED_AT_COLUMN+a0_0x576039(0xe6)+DELETED_BY_COLUMN+'\x20IS\x20NOT\x20NULL)\x20OR\x20('+IS_DELETED_COLUMN+'\x20=\x20FALSE\x20AND\x20'+DELETED_AT_COLUMN+a0_0x576039(0x164)+DELETED_BY_COLUMN+a0_0x576039(0x116)},'partialIndex':{'description':a0_0x576039(0x154)+IS_DELETED_COLUMN+'\x20=\x20FALSE.','example':a0_0x576039(0xf9)+IS_DELETED_COLUMN+'\x20=\x20FALSE','notes':'UNIQUE\x20constraints\x20are\x20NOT\x20made\x20partial\x20on\x20any\x20dialect.\x20Uniqueness\x20keeps\x20covering\x20deleted\x20rows;\x20value\x20reuse\x20is\x20handled\x20by\x20the\x20suffix\x20mutation,\x20not\x20by\x20a\x20partial\x20unique\x20index.'}},'dialectSupport':{'supported':[SOFT_DELETE_PHASE1_DIALECT],'description':a0_0x576039(0x10c)},'introspectRoundTrip':'schema\x20introspect\x20recognizes\x20a\x20complete\x20soft-delete\x20table\x20(three\x20correctly\x20typed\x20contract\x20columns\x20+\x20consistency\x20CHECK)\x20and\x20writes\x20back\x20softDelete:\x20{\x20enabled:\x20true\x20}\x20in\x20the\x20generated\x20SDF.\x20Tables\x20with\x20incomplete\x20or\x20non-conforming\x20soft-delete\x20columns\x20block\x20introspect\x20with\x20an\x20error.','rdfDerivation':a0_0x576039(0x155)},SHORTHAND_SYNTAX={'format':a0_0x576039(0x126),'description':a0_0x576039(0x167),'rules':['Type\x20is\x20mandatory\x20at\x20the\x20beginning\x20and\x20must\x20be\x20one\x20of\x20fieldTypes.',a0_0x576039(0xff),a0_0x576039(0xe2),'Value\x20constraints\x20(default,\x20fk)\x20require\x20constraint:value\x20format.','Default\x20value\x20format\x20depends\x20on\x20type:\x20raw\x20for\x20boolean\x20(default:true),\x20raw\x20for\x20integer\x20(default:0),\x20single-quoted\x20for\x20string\x20(default:\x27value\x27),\x20bare\x20identifier\x20for\x20SQL\x20constants\x20(default:current_date),\x20identifier()\x20for\x20native\x20function\x20calls\x20(default:now()).','Foreign\x20key\x20uses\x20dot\x20notation:\x20fk:<table>.<column>\x20(e.g.,\x20fk:category.id).\x20The\x20parser\x20rejects\x20parentheses\x20syntax.'],'examples':[{'input':a0_0x576039(0xf0),'meaning':'VARCHAR(36)\x20PRIMARY\x20KEY'},{'input':'string:255\x20notnull','meaning':'VARCHAR(255)\x20NOT\x20NULL'},{'input':'decimal:15,2\x20notnull\x20default:0','meaning':a0_0x576039(0x140)},{'input':a0_0x576039(0x10a),'meaning':a0_0x576039(0x160)},{'input':'string:100\x20default:\x27pending\x27','meaning':a0_0x576039(0xee)},{'input':a0_0x576039(0x100),'meaning':a0_0x576039(0xfb)},{'input':'string:36\x20fk:category.id','meaning':a0_0x576039(0xf7)},{'input':a0_0x576039(0x13f),'meaning':a0_0x576039(0x159)}]},NAMING_RULES={'tableName':{'format':'snake_case','description':'Table\x20name\x20must\x20be\x20lowercase,\x20digits,\x20and\x20underscores\x20only.'},'fieldName':{'format':a0_0x576039(0x10b),'description':a0_0x576039(0xfe)},'constraintName':{'format':'<prefix>_<table>_<suffix>','defaultMaxLength':0x1e,'fallbackStrategy':'MD5\x20hash\x208-character\x20suffix\x20when\x20name\x20exceeds\x20maxLength','description':'Constraint\x20names\x20auto-generated\x20with\x20type-specific\x20prefix\x20(pk,\x20fk,\x20idx,\x20uq,\x20ck)\x20and\x20dialect-specific\x20max\x20length.'},'compositeShortName':{'description':'For\x20composite\x20indexes/uniques,\x20name\x20is\x20derived\x20by\x20joining\x20columns\x20with\x20underscore\x20and\x20truncating\x20when\x20needed.'}},DIALECT_SUPPORT=[{'name':'postgres','driver':'pg','booleanStorage':'native\x20BOOLEAN'},{'name':'mysql','driver':'mysql2','booleanStorage':a0_0x576039(0x112)},{'name':'oracle','driver':'oracledb','booleanStorage':a0_0x576039(0x120)},{'name':'sqlite','driver':a0_0x576039(0xe5),'booleanStorage':'TEXT'}],DBSCHEMA_CATALOG={'schemaVersion':SCHEMA_VERSION,'source':SOURCE,'summary':{'totalDefineModelOptions':DEFINE_MODEL_OPTIONS['length'],'totalFieldTypes':FIELD_TYPES['length'],'totalConstraints':CONSTRAINTS['length'],'totalRelationTypes':RELATION_TYPES['length'],'totalReferentialActions':REFERENTIAL_ACTIONS['length'],'totalCheckOperations':CHECK_OPERATIONS['length'],'totalAuditColumns':AUDIT_COLUMNS[a0_0x576039(0x11a)][a0_0x576039(0x161)],'totalDialects':DIALECT_SUPPORT[a0_0x576039(0x161)]},'defineModelOptions':DEFINE_MODEL_OPTIONS,'fieldTypes':FIELD_TYPES,'constraints':CONSTRAINTS,'relationTypes':RELATION_TYPES,'referentialActions':REFERENTIAL_ACTIONS,'checkOperations':CHECK_OPERATIONS,'auditColumns':AUDIT_COLUMNS,'softDelete':SOFT_DELETE,'shorthandSyntax':SHORTHAND_SYNTAX,'namingRules':NAMING_RULES,'dialectSupport':DIALECT_SUPPORT,'documentationUrl':DOCUMENTATION_URL};module['exports']={'DBSCHEMA_CATALOG':DBSCHEMA_CATALOG,'DEFINE_MODEL_OPTIONS':DEFINE_MODEL_OPTIONS,'FIELD_TYPES':FIELD_TYPES,'CONSTRAINTS':CONSTRAINTS,'RELATION_TYPES':RELATION_TYPES,'REFERENTIAL_ACTIONS':REFERENTIAL_ACTIONS,'CHECK_OPERATIONS':CHECK_OPERATIONS,'AUDIT_COLUMNS':AUDIT_COLUMNS,'SOFT_DELETE':SOFT_DELETE,'SHORTHAND_SYNTAX':SHORTHAND_SYNTAX,'NAMING_RULES':NAMING_RULES,'DIALECT_SUPPORT':DIALECT_SUPPORT};function a0_0x23cb(){const _0x580915=['B25vCgrHDgu','twfYA3mGzMLLBgqGyxmGChjPBwfYEsbRzxKU','qwXSidqGy29SDw1UCYbHCMuGBNvSBgfIBguUifrOzsbJCMvHDgvKx2j5l3vWzgf0zwrFyNKGy29SDw1UCYbTyxKGyMuGzw1WDhKGzM9YihjVD3mGAw5Zzxj0zwqGyNKGC3LZDgvTihnLzwrZlcbTAwDYyxrPB25ZlcbVCIbIyxrJAcbPBxbVCNrZihrOyxqGzg8GBM90igHHDMuGysb1C2vYignVBNrLEhqU','DxbKyxrLzf9IEq','rgvMzxiGy29UC3rYywLUDcbJAgvJAYaOC2vTyw50AwnHBgX5ihnPBwLSyxiGDg8GCMvZDhjPy3qGB24GBw9ZDcbKAwfSzwn0CYKU','DMfSDwu','BM90BNvSBa','EYbLBMfIBgvKoIb0CNvLlcbYzxvZywjSztOGw3SGzMLLBgq6icjJyxrLz29YEv9JB2rLiIWGBgvUz3rOoIa1mcb9xsb9','CMvMzxjLBMnLCW','id0GvfjvrsbbtKqG','EYb0ExbLoIaIyMvSB25NC1rViIWGBg9JywXlzxK6icjJyxrLz29YEv9PzciSihjLzMvYzw5Jzxm6icjJyxrLz29YEv9PzciSig9UrgvSzxrLoIaICMvZDhjPy3qIih0','zgvJAw1HBdO8ChjLy2LZAw9UpIW8C2nHBgu+','CMvZDhjPy3q','ug9ZDgDYzvnrtc1VBMX5igLUifbOyxnLideUifrOzsbsreyGC29MDerLBgv0zsbIBg9JAYbPCYbKzxjPDMvKigzYB20GDgHPCYbtreyGyMXVy2SGzhvYAw5NihbHEwXVywqGz2vUzxjHDguSig5LDMvYihDYAxr0zw4GyNKGAgfUzc4','revquKvdqvrfrdOGvgHPCYbTB2rPzMLLCIbUBYbSB25NzxiGAgfZigz1BMn0Aw9UywWGzwzMzwn0igf0ihrOzsbereWGB3iGCNvUDgLTzsbSzxzLBc4Gqxv0BY11CgrHDguGzM9YihvWzgf0zwrFyxqGAxmGAgfUzgXLzcbIEsb0AguGuKrgigXHEwvYicHHDwrPDenVBhvTBNmGy29UDMvUDgLVBIbPBIbcyxnLtw9KzwWGCNvUDgLTzsKGyMfZzwqGB24GzMLLBgqGBMfTAw5NignVBNzLBNrPB24Sig5VDcbIEsb0AgLZifnerIbTyxjRzxiUiev4Axn0Aw5NihvZywDLigLZihbYzxnLCNzLzcbMB3iGyMfJA3DHCMqGy29TCgf0AwjPBgL0EsbIDxqGC2HVDwXKigjLihjLBw92zwqGzNjVBsbUzxCGDgvTCgXHDgvZlG','C3rYAw5NoJy0igLUzgv4','revdsu1btcGXnsWYksbot1qGtLvmtcberuzbvuXuida','r3jLyxrLCIb0AgfUig9YigvXDwfSihrVlG','twfUEs10BY1VBMuUifrOAxmGDgfIBguGAg9SzhmGDgHLiezlignVBhvTBIbYzwzLCMvUy2LUzYb0AguGCgfYzw50ihrHyMXLlG','C3rHBMrHBg9Uzq','nJm5mtiWvujVtuD3','rgf0zsbHBMqGDgLTzsaOveLnrvnuqu1qks4','mJqXnty4rwXMyMfH','C2nHBgfY','q2fUBM90ignVzxHPC3qGD2L0AcbLEhbSAwnPDcbYzwXHDgLVBIbLBNrYEsbYzwzLCMvUy2LUzYb0AguGC2fTzsbMAwvSzc4','C3rYAw5NoJeWma','vxnLCIbPzgvUDgLMAwvYig9MihrOzsbSyxn0ig1VzgLMAwvYlIbtzxqGyNKGyxbWBgLJyxrPB24GBgf5zxiGB24GvvbeqvrflcbUB3qGyNKGzgf0ywjHC2uGzgvMyxvSDc4','BNvTzxjPyW','yxjYyxK','C3rYAw5NoJCW','yMvSB25NC1rV','yM9VBgvHBG','qxv0BY1KzxrLy3rLzcbMCM9TigzPzwXKihnOB3j0AgfUzcaICgSIihDOzw4GBM90ihnWzwnPzMLLzc4','u2v0iezlignVBhvTBIb0BYbovuXmig9UignOAwXKihjVD3mU','rgf0zsbVBMX5icHUBYb0Aw1LignVBxbVBMvUDcKU','u29MDc1KzwXLDguGy29UDhjHy3qGzM9YihrHyMXLCYbKzwnSyxjLzcb3AxrOigeGC29MDerLBgv0zsbIBg9JAYaOC2vLigrLzMLUzu1VzgvSt3b0Aw9UCY5ZB2z0rgvSzxrLigzVCIb0AguGyMXVy2SGC2HHCguPlIbezwXLDgvKihjVD3mGyxjLigzSywDNzwqGDgHYB3vNAcb0AhjLzsbJB250CMfJDcbJB2X1Bw5ZigLUC3rLywqGB2yGyMvPBMCGCgH5C2LJywXSEsbYzw1VDMvKlIbtreyGAxmGDgHLihnPBMDSzsbKzwnSyxjHDgLVBIbWB2LUDdOGAxqGzhjPDMvZieretcbLBwLZC2LVBIaOy29SDw1UCYWGy29UC2LZDgvUy3KGq0Hfq0SSihbHCNrPywWGAw5KzxHLCYKGyw5KihrOzsbsreyGC29MDerLBgv0zsbIBg9JAYbPCYbKzxjPDMvKigzYB20GAxqGzhvYAw5NihbHEwXVywqGz2vUzxjHDguU','tM9UlxvUAxf1zsbPBMrLEgvZig9UihnVzNqTzgvSzxrLihrHyMXLCYbHCMuGzw1PDhrLzcbHCYbqB3n0z3jLu1fmihbHCNrPywWGAw5KzxHLCYb3AxrOifDirvjfia','vgHLifjerIbZB2z0rgvSzxrLigjSB2nRigLZigrLCML2zwqGzNjVBsbtreyGzhvYAw5NihbHEwXVywqGz2vUzxjHDguSig5LDMvYihDYAxr0zw4GBwfUDwfSBhKUifrHyMXLCYb3Ag9ZzsbKyxrHyMfZzsbJB2X1Bw5ZigLUy2X1zguGDgHLihnVzNqTzgvSzxrLignVBNrYywn0ig11C3qGyMuGzgvJBgfYzwqGAw4Gu0rgihDPDgGGysb2ywXPzcbZB2z0rgvSzxrLigjSB2nRigzVCIbWyxLSB2fKigDLBMvYyxrLihrVihn1y2nLzwqU','vgHLigvYCM9Yig1LC3nHz2uGC3vNz2vZDhmGDhDVihDHExmGB3v0oIb1C2uGAgfYzc1KzwXLDguGzM9YihbYB2nLC3mTzhjPDMvUihrHyMXLCYaOyMfSyw5JzsWGBgvKz2vYlcbZBMfWC2HVDcWGCgvYAw9KlwnSB3nLksWGB3iGy2HHBMDLihrOzsbvtKLrvuuGAw50BYbHihnPBMDSzs1JB2X1Bw4GC3rYAw5Nigj1C2LUzxnZignVzguU','t3zLCNjPzguGChjPBwfYEsbRzxKUifnPBMDSzsbMAwvSzcbUyw1Lig9YignVBxbVC2L0zsbHCNjHEs4','Dgv4Da','vKfsq0HbuIG2ncKGD2L0AcbZAw5NBguTy29SDw1UigLUzgv4','ndeWmda1nenOyNPWAq','y2HLy2TZ','y2fZy2fKzq','EYbMAwvSzdOGiNn0yxr1CYiSigLUoIbBiMfJDgL2zsiSicjPBMfJDgL2zsjDih0','BMvX','nJC4mZvxvhvJu2y','qK9ptevbtIberuzbvuXuifrsvuu','BgvUz3rO','mZiTyML0ihnPz25LzcbPBNrLz2vYicHjtLqVsu5uruDfuIKU','r3jLyxrLCIb0AgfUlG','ieLtie5vteWGqu5eia','tM9UlxvUAxf1zsbPBMrLEgvZlIbfywnOigvUDhj5igLZigfYCMf5ig9MignVBhvTBIbUyw1LCYbVCIbVyMPLy3qGEYbUyw1LlcbJB2X1Bw5Zih0U','rKSGzMLLBgqGBxvZDcbIzsbUDwXSywjSzs4','u3rYAw5NihnOB3j0AgfUzcbMB3iGzMLLBgqGzgvMAw5PDgLVBI4GvhLWzsbYzxf1AxjLzcbHDcbZDgfYDcWGzM9SBg93zwqGyNKGB3b0Aw9UywWGBw9KAwzPzxiGyw5KihnWywnLlxnLCgfYyxrLzcbJB25ZDhjHAw50CY4','y3jLyxrLzf9HDa','uhjLy2LZAw9UigfUzcbZy2fSzsbYzxf1AxjLzcbMB3iGy3jVC3mTzgLHBgvJDcbWB3j0ywjPBgL0Es4','C3rYAw5NFg51BgW','u3rHBMrHBg9UzsbJB25ZDhjHAw50CYaOCgSSig5VDg51BgWSihvUAxf1zsWGAw5KzxGPihrHA2uGBM8GDMfSDwuUifrOzsbSzwDHy3KGyxv0B1vWzgf0zsb0B2TLBIbPCYbZDgLSBcbWyxjZzwqGzM9YigjHy2T3yxjKignVBxbHDgLIAwXPDhKGyNv0igLZigrLChjLy2f0zwqGyw5KigHHCYbUBYbMDw5JDgLVBMfSigvMzMvJDc4','ms4X','rgvSzxrPB24GDgLTzxn0yw1WlcbUDwXSywjSzs4GtLvmtcb3AgLSzsb0AguGCM93igLZigfSAxzLlG','yMv0DgvYlxnXBgL0ztm','ieLtie5pvcbovuXmieforca','zgf0zq','u2LUz2XLlwnVBhvTBIbvtKLrvuuGy29UC3rYywLUDhmGB24GBM9Ulxn0CMLUzYbJB2X1Bw5ZigfYzsbYzwPLy3rLzcbMB3iGDgHLihnHBwuGCMvHC29UicHZDwzMAxGGBxv0yxrPB24GB25SEsbHChbSAwvZihrVihn0CMLUzY90zxH0ks4','ANnVBG','uMvQzwn0igrLBgv0zs91CgrHDguGD2HLBIbJAgLSzcbYB3DZigv4Axn0lG','qM9VBgvHBIb2ywX1zsaOBMf0AxzLiejpt0Xfqu4GB24Gug9ZDgDYzvnrtcWGvKfsq0HbuIbVBIbVDgHLCNmPlG','q0Hfq0SGy29UC3rYywLUDhmUievHy2GGzw50CNKGDxnLCYbVCgvYyxrVCI1HCY1RzxKGC2HHCgu6ihSGBMfTzt8SigzPzwXKlca8B3bLCMf0B3i+oIa8DMfSDwu+ih0GD2HLCMuGpg9WzxjHDg9YpIbPCYbVBMuGB2yGy2HLy2TpCgvYyxrPB25ZicHPBIWGzxeSig5LCsWGz3qSigD0zsWGBhqSigX0zsKUifrOzsbPBNrLCM5HBcbjuIbZAgfWzsbHzNrLCIbPCI1IDwLSzgvYig5VCM1HBgL6yxrPB24GAxmGEYbUyw1LpYWGzMLLBgqSig9Wlcb2ywX1zsb9lcbIDxqGDgHHDcbPCYbot1qGDgHLihvZzxiGAw5WDxqGzM9YBwf0lG','rgf0ywjHC2uGC2nOzw1Hig5HBwvZCgfJzsaOBxvSDgKTC2nOzw1HigrHDgfIyxnLks4','vKfsq0HbuIGXmdaPierfrKfvtfqGj3bLBMrPBMCN','nNrdC0DLta','C3rYAw5NoJm2ihbR','Ahr0Chm6lY9Yzxn0zM9Yz2uUzgv2l2rVy3mVy2XPl3nJAgvTys1KzwzPBML0Aw9U','nZa5mdK0muvMBeDWCa','t25LlxrVlw9UzsaOAw52zxjZzsbVzIbIzwXVBMDZvg8PlIbpChrPB25HBcbPBNzLCNnLigrLy2XHCMf0Aw9Uig9UihrOzsbWyxjLBNqGC2LKztSGzg9LCYbUB3qGywzMzwn0ieretc4','rM9YzwLNBIbRzxKGCMvMzxjLBMnLlIbbDxrVlwDLBMvYyxrLCYbHigjLBg9Uz3nuBYbYzwXHDgLVBIbLBNrYEs4','yM9VBgvHBIbUB3rUDwXSigrLzMf1Bhq6zMfSC2u','EYbMAwvSzdOGiMrPC2nVDw50iIWGBhrLoIaXmdaGFq','vKfsq0HbuIGZnIKGD2L0AcbgsYb0BYbJyxrLz29YEsHPzcKSigf1Dg8GyMvSB25NC1rVihjLBgf0Aw9U','DxbKyxrLzf9HDa','q1jfqvrfieLorevyigLKEf92AxnPDg9Yx2nHDgvNB3jPzxnFy2f0zwDVCNLFBMfTzsbptIb2AxnPDg9Yx2nHDgvNB3jPzxmGkgnHDgvNB3j5x25HBwuPifDirvjfia','v2HLBIbLBMfIBgvKid0GDhj1zsWGywXSihrOCMvLignVBhvTBNmGyMvSB3CGtvvtvcbIzsbKzwnSyxjLzcbPBIbMAwvSzhmGD2L0AcbLEgfJDgX5ihrOzxnLigXVz2LJywWGDhLWzxmUifrOzsbYzwXHDgLVBIbIzxr3zwvUihrOzsbIBg9JAYbHBMqGDgHLignVBhvTBNmGAxmGyMLJB25KAxrPB25HBc4','veLnrvnuqu1qierfrKfvtfqGpg5HDgL2zv9UB3CGCgvYigrPywXLy3q+','mti1mJyYu2vwBhfk','tK9uie5vteWGy29UC3rYywLUDc4','q29SDw1Uig5HBwuGBxvZDcbIzsbZBMfRzv9JyxnLlG','tw9KAwzPzxiGAxmGBwfUzgf0B3j5igzVCIb0ExbLicjZDhjPBMCIicHSzw5NDgGPigfUzcaIzgvJAw1HBciGkhbYzwnPC2LVBIXZy2fSzsKU','DgLTzxn0yw1WigrLzMf1Bhq6BM93kcK','vMfYAwfIBguTBgvUz3rOihrLEhqUieXLBMD0AcbTB2rPzMLLCIbYzxf1AxjLzc4','BNvSBcbVCIbLBxb0EsbZDhjPBMCGBwvHBNmGzgvMyxvSDcbZy2HLBweU','sLnptIbJB2X1Bw4GkePtt05cig9UifbVC3rNCMvtuuWSiePtt04GB24GtxLtuuWSienmt0iGB24Gt3jHy2XLks4','DgfYz2v0','AgfZt25L','C3rYAw5NoJXSzw5NDgG+','mtzRqvH5wfu','rgvSzxrPB24Gywn0B3iGAwrLBNrPzMLLCIWGBNvSBgfIBguUie5vteWGD2HPBguGDgHLihjVDYbPCYbHBgL2zs4','rw5HyMXLCYbZB2z0lwrLBgv0zsbMB3iGDgHLihrHyMXLlIbtAgfWztOGEYbLBMfIBgvKoIbIB29SzwfUlcbYzxvZywjSzt86ifT7igzPzwXKlcbSzw5NDgGGFv0GFs4Gs2v5CYbVDgHLCIb0AgfUigvUywjSzwqGyw5KihjLDxnHyMXLigfYzsbYzwPLy3rLzcbHDcbZy2HLBweGBg9Hzc4Gv2HLBIbLBMfIBgvKlcb0AguGDgHYzwuGy29UDhjHy3qGy29SDw1UCYaOAxnFzgvSzxrLzcWGzgvSzxrLzf9HDcWGzgvSzxrLzf9IEsKGBxvZDcbIzsbKzwnSyxjLzcbPBIbMAwvSzhmUifnLzsb0AguGC29MDerLBgv0zsbZzwn0Aw9UigzVCIb0AguGzNvSBcbJB250CMfJDc4','yM9VBgvHBIbKzwzHDwX0oNrYDwu','C25HA2vFy2fZzq','ugHHC2uGmtOGug9ZDgDYzvnrtcbVBMX5lIbpBIbVDgHLCIbKAwfSzwn0CYb0AguGC29MDerLBgv0zsbIBg9JAYbPCYbUB3qGC3vWCg9YDgvKicHereWGz2vUzxjHDgLVBIbMywLSCYb3AxrOigeGy2XLyxiGzxjYB3iPigfUzcbZB2z0lwrLBgv0zs1Uyw1LzcbJB2X1Bw5ZigDLDcbUBYbZCgvJAwfSihrYzwf0BwvUDcbKDxjPBMCGAw50CM9ZCgvJDc4','zw5HyMXLzca9ihrYDwuGD2L0AcbHBNKGy29UDhjHy3qGy29SDw1Uig1PC3nPBMC6ihzHBgLKyxrPB24Grvjst1iGkg1PC3nPBMCGy29SDw1UCYbHCMuGBgLZDgvKks4','vgHLigzPzwXKig11C3qGAgf2zsbHihnPBMDSzs1JB2X1Bw4Gvu5juvvfignVBNn0CMfPBNqGkg5VifvosvfvrsWGB3iGB25SEsbJB21WB3nPDguGvu5juvvfoIbfuLjpuIKU','AgfZtwfUEq','yhjLzMvYzw5JzxnGigLZihrOzsbIyxjLignVBhvTBIbUyw1LigLUihrOzsb0yxjNzxqGDgfIBguUifrHCMDLDcb0ywjSzsbPCYbHDxrVlwrLCML2zwqGzNjVBsb0AguGCMvSyxrPB24GA2v5ig5HBwuSig9Yig92zxjYAwrLihDPDgGGyhrHCMDLDgaU','C3rYAw5NFgfYCMf5','vKfsq0HbuIaOBgL0zxjHBcaIDhj1zsiViMzHBhnLiIK','Bg9JywXlzxK','rgvMyxvSDcb2ywX1zs4Gu2LUz2XLlxf1B3rLzcbMB3iGC3rYAw5NCYWGCMf3igzVCIbUDw1LCMLJl2jVB2XLyw4SigjHCMuGAwrLBNrPzMLLCIbMB3iGu1fmignVBNn0yw50CYWGAwrLBNrPzMLLCIGPigzVCIbUyxrPDMuGzNvUy3rPB24Gy2fSBhmU','rxzLCNKGC29MDc1KzwXLDguGDgfIBguGz2v0CYbHienirunlignVBNn0CMfPBNqGD2L0Acb0AguGzgv0zxjTAw5PC3rPyYbUyw1LignOA188DgfIBgu+xW','ieLtie5vteWPlIbuAgLZigTLzxbZihrOzsb0AhjLzsbJB2X1Bw5ZignVBNnPC3rLBNqGyxqGDgHLigrHDgeGBgv2zwWGCMvNyxjKBgvZCYbVzIb0AguGD3jPDguGCgf0Ac4','vxnLCIbPzgvUDgLMAwvYicH1C2vYBMfTzsWGDxnLCL9PzcWGB3iGy29TCg9ZAxrLihrVA2vUksbVzIb0AguGCMvJB3jKignYzwf0B3iUifnLDcbIEsbHChbSAwnHDgLVBIbSyxLLCIbVBIbjtLnfuLqSig5VDcbIEsbKyxrHyMfZzsbKzwzHDwX0lG','rgvSzxrPB24GzMXHzY4GrgvJBgfYzsbHCYbUB3rUDwXSigrLzMf1Bhq6zMfSC2uU','vw5PCxvLignVBNn0CMfPBNrZicHZAw5NBguGB3iGy29TCg9ZAxrLks4','y29SDw1UCW','zMLLBgrZ','EYbJyxrLz29YEtOGEYb0ExbLoIaIyMvSB25NC1rViIWGCMvMzxjLBMnLCZOGiMnHDgvNB3j5kgLKksiGFsb9','BhrL','EYbMAwvSzdOGiNr5CguIlcbUzxe6icjZExn0zw0Iih0','B25ezwXLDgu','vKfsq0HbuJiGD2L0AcbdsevdsYbJB25ZDhjHAw50','mte3rhHoqLnh','C3rYAw5NoJi1nq','ntjfzxHYBg8','yMLNAw50','nJu3mJKWyxDRzgrc','phr5Cgu+wZO8Bw9KAwzPzxi+xsbBpgnVBNn0CMfPBNq+wZO8DMfSDwu+xv0UlI4','C3rYAw5NoJi1nsbUB3rUDwXS','mtjvB0Ttwu4','C29MDerLBgv0zq','tgvZCYb0AgfUlG','q29UDhjHy3qGy29SDw1UigrLy2XHCMvKihDPDgGGysb3CM9UzYb0ExbLoIb2ywXPzgf0Aw9UievsuK9slG','DgLTzxn0yw1W','Dw5PCxvLCW','EYbMAwvSzdOGiNr5CguIlcbLCtOGiNvZzxiIih0','vgHLigzPzwXKihr5CguGBxvZDcbIzsbZDhjPBMCGB3iGDgv4DcaODMfSDwuGBxv0yxrPB24GCMvXDwLYzxmGysbZDhjPBMCGDhLWztOGrvjst1iGB3rOzxj3AxnLks4'];a0_0x23cb=function(){return _0x580915;};return a0_0x23cb();}