@restforgejs/platform 5.2.0 → 5.2.10

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 (174) hide show
  1. package/build-info.json +2 -2
  2. package/cli/consumer-deploy.js +2 -2
  3. package/cli/consumer.js +2 -2
  4. package/generators/cli/fast-track.js +293 -35
  5. package/generators/lib/migrate/backend-payload-migrator.js +39 -17
  6. package/generators/lib/migrate/field-type-resolver.js +64 -7
  7. package/generators/lib/migrate/migrate-runner.js +12 -2
  8. package/generators/lib/migrate/sql-parser.js +5 -3
  9. package/generators/lib/payload/payload-runner.js +103 -11
  10. package/generators/lib/templates/dashboard-catalog.js +1 -1
  11. package/generators/lib/templates/db-connection-env.js +1 -1
  12. package/generators/lib/templates/dbschema-catalog.js +1 -1
  13. package/generators/lib/templates/field-validation-catalog.js +1 -1
  14. package/generators/lib/templates/mysql-template.js +1 -1
  15. package/generators/lib/templates/oracle-template.js +1 -1
  16. package/generators/lib/templates/postgres-template.js +1 -1
  17. package/generators/lib/templates/query-declarative-catalog.js +1 -1
  18. package/generators/lib/templates/sqlite-template.js +1 -1
  19. package/integrity-manifest.json +18 -18
  20. package/package.json +1 -1
  21. package/scripts/verify-integrity.js +1 -1
  22. package/server.js +2 -2
  23. package/src/components/handlers/adjust_handler.js +1 -1
  24. package/src/components/handlers/audit_handler.js +1 -1
  25. package/src/components/handlers/delete_handler.js +1 -1
  26. package/src/components/handlers/export_handler.js +1 -1
  27. package/src/components/handlers/import_handler.js +1 -1
  28. package/src/components/handlers/insert_handler.js +1 -1
  29. package/src/components/handlers/update_handler.js +1 -1
  30. package/src/components/handlers/upload_handler.js +1 -1
  31. package/src/components/handlers/workflow_handler.js +1 -1
  32. package/src/components/integrations/webhook.js +1 -1
  33. package/src/consumers/baseConsumer.js +1 -1
  34. package/src/consumers/declarativeMapper.js +1 -1
  35. package/src/consumers/handlers/apiHandler.js +1 -1
  36. package/src/consumers/handlers/consoleHandler.js +1 -1
  37. package/src/consumers/handlers/databaseHandler.js +1 -1
  38. package/src/consumers/handlers/index.js +1 -1
  39. package/src/consumers/handlers/kafkaHandler.js +1 -1
  40. package/src/consumers/index.js +1 -1
  41. package/src/consumers/messageTransformer.js +1 -1
  42. package/src/consumers/validator.js +1 -1
  43. package/src/core/db/dialect/base-dialect.js +1 -1
  44. package/src/core/db/dialect/index.js +1 -1
  45. package/src/core/db/dialect/mysql-dialect.js +1 -1
  46. package/src/core/db/dialect/oracle-dialect.js +1 -1
  47. package/src/core/db/dialect/postgres-dialect.js +1 -1
  48. package/src/core/db/dialect/sqlite-dialect.js +1 -1
  49. package/src/core/db/flatten-helper.js +1 -1
  50. package/src/core/db/query-builder-error.js +1 -1
  51. package/src/core/db/query-builder.js +1 -1
  52. package/src/core/db/relation-helper.js +1 -1
  53. package/src/core/handlers/delete_handler.js +1 -1
  54. package/src/core/handlers/insert_handler.js +1 -1
  55. package/src/core/handlers/update_handler.js +1 -1
  56. package/src/core/models/base-model.js +1 -1
  57. package/src/core/utils/cache-manager.js +1 -1
  58. package/src/core/utils/component-engine.js +1 -1
  59. package/src/core/utils/context-builder.js +1 -1
  60. package/src/core/utils/datetime-formatter.js +1 -1
  61. package/src/core/utils/datetime-parser.js +1 -1
  62. package/src/core/utils/db.js +1 -1
  63. package/src/core/utils/logger.js +1 -1
  64. package/src/core/utils/payload-loader.js +1 -1
  65. package/src/core/utils/security-checks.js +1 -1
  66. package/src/middleware/body-options.js +1 -1
  67. package/src/middleware/cors.js +1 -1
  68. package/src/middleware/idempotency.js +1 -1
  69. package/src/middleware/rate-limiter.js +1 -1
  70. package/src/middleware/request-logger.js +1 -1
  71. package/src/middleware/security-headers.js +1 -1
  72. package/src/models/base-model-mysql.js +1 -1
  73. package/src/models/base-model-oracle.js +1 -1
  74. package/src/models/base-model-sqlite.js +1 -1
  75. package/src/models/base-model.js +1 -1
  76. package/src/pro/caching/redis-client.js +1 -1
  77. package/src/pro/caching/redis-helper.js +1 -1
  78. package/src/pro/consumers/baseConsumer.js +1 -1
  79. package/src/pro/consumers/declarativeMapper.js +1 -1
  80. package/src/pro/consumers/handlers/apiHandler.js +1 -1
  81. package/src/pro/consumers/handlers/consoleHandler.js +1 -1
  82. package/src/pro/consumers/handlers/databaseHandler.js +1 -1
  83. package/src/pro/consumers/handlers/index.js +1 -1
  84. package/src/pro/consumers/handlers/kafkaHandler.js +1 -1
  85. package/src/pro/consumers/index.js +1 -1
  86. package/src/pro/consumers/messageTransformer.js +1 -1
  87. package/src/pro/consumers/validator.js +1 -1
  88. package/src/pro/database/base-model-mysql.js +1 -1
  89. package/src/pro/database/base-model-oracle.js +1 -1
  90. package/src/pro/database/base-model-sqlite.js +1 -1
  91. package/src/pro/database/db-mysql.js +1 -1
  92. package/src/pro/database/db-oracle.js +1 -1
  93. package/src/pro/database/db-sqlite.js +1 -1
  94. package/src/pro/excel/excel-generator.js +1 -1
  95. package/src/pro/excel/excel-parser.js +1 -1
  96. package/src/pro/excel/export-service.js +1 -1
  97. package/src/pro/excel/export_handler.js +1 -1
  98. package/src/pro/excel/import-service.js +1 -1
  99. package/src/pro/excel/import-validator.js +1 -1
  100. package/src/pro/excel/import_handler.js +1 -1
  101. package/src/pro/excel/upsert-builder.js +1 -1
  102. package/src/pro/idgen/idgen-routes.js +1 -1
  103. package/src/pro/integrations/lookup-resolver.js +1 -1
  104. package/src/pro/integrations/upload-handler-v2.js +1 -1
  105. package/src/pro/integrations/upload-handler.js +1 -1
  106. package/src/pro/integrations/webhook.js +1 -1
  107. package/src/pro/locking/lock-routes.js +1 -1
  108. package/src/pro/locking/resource-lock-manager.js +1 -1
  109. package/src/pro/messaging/kafkaConsumerService.js +1 -1
  110. package/src/pro/messaging/kafkaService.js +1 -1
  111. package/src/pro/messaging/messagehubService.js +1 -1
  112. package/src/pro/messaging/rabbitmqService.js +1 -1
  113. package/src/pro/scheduler/job-manager.js +1 -1
  114. package/src/pro/scheduler/job-routes.js +1 -1
  115. package/src/pro/scheduler/job-validator.js +1 -1
  116. package/src/pro/storage/base-storage-provider.js +1 -1
  117. package/src/pro/storage/file-metadata-helper.js +1 -1
  118. package/src/pro/storage/index.js +1 -1
  119. package/src/pro/storage/local-storage-provider.js +1 -1
  120. package/src/pro/storage/s3-storage-provider.js +1 -1
  121. package/src/pro/storage/upload-cleanup-job.js +1 -1
  122. package/src/pro/storage/upload-cleanup-scheduler.js +1 -1
  123. package/src/pro/storage/upload-pending-tracker.js +1 -1
  124. package/src/pro/websocket/broadcast-helper.js +1 -1
  125. package/src/pro/websocket/index.js +1 -1
  126. package/src/pro/websocket/livesync-server.js +1 -1
  127. package/src/pro/websocket/ws-broadcaster.js +1 -1
  128. package/src/services/export-service.js +1 -1
  129. package/src/services/import-service.js +1 -1
  130. package/src/services/kafkaConsumerService.js +1 -1
  131. package/src/services/kafkaService.js +1 -1
  132. package/src/services/messagehubService.js +1 -1
  133. package/src/services/rabbitmqService.js +1 -1
  134. package/src/utils/cache-invalidation-registry.js +1 -1
  135. package/src/utils/cache-manager.js +1 -1
  136. package/src/utils/component-engine.js +1 -1
  137. package/src/utils/config-extractor.js +1 -1
  138. package/src/utils/consumerLogger.js +1 -1
  139. package/src/utils/context-builder.js +1 -1
  140. package/src/utils/dashboard-helpers.js +1 -1
  141. package/src/utils/dateHelper.js +1 -1
  142. package/src/utils/datetime-formatter.js +1 -1
  143. package/src/utils/datetime-parser.js +1 -1
  144. package/src/utils/db-bootstrap.js +1 -1
  145. package/src/utils/db-mysql.js +1 -1
  146. package/src/utils/db-oracle.js +1 -1
  147. package/src/utils/db-sqlite.js +1 -1
  148. package/src/utils/db.js +1 -1
  149. package/src/utils/demo-generator.js +1 -1
  150. package/src/utils/excel-generator.js +1 -1
  151. package/src/utils/excel-parser.js +1 -1
  152. package/src/utils/file-watcher.js +1 -1
  153. package/src/utils/id-generator.js +1 -1
  154. package/src/utils/idempotency-manager.js +1 -1
  155. package/src/utils/import-validator.js +1 -1
  156. package/src/utils/license-client.js +1 -1
  157. package/src/utils/lock-manager.js +1 -1
  158. package/src/utils/logger.js +1 -1
  159. package/src/utils/lookup-resolver.js +1 -1
  160. package/src/utils/payload-loader.js +1 -1
  161. package/src/utils/processor-response.js +1 -1
  162. package/src/utils/rabbitmq.js +1 -1
  163. package/src/utils/redis-client.js +1 -1
  164. package/src/utils/redis-helper.js +1 -1
  165. package/src/utils/request-scope.js +1 -1
  166. package/src/utils/security-checks.js +1 -1
  167. package/src/utils/service-resolver.js +1 -1
  168. package/src/utils/shutdown-coordinator.js +1 -1
  169. package/src/utils/soft-delete-dashboard-guard.js +1 -1
  170. package/src/utils/sql-table-extractor.js +1 -1
  171. package/src/utils/trusted-keys.js +1 -1
  172. package/src/utils/upload-handler.js +1 -1
  173. package/src/utils/upsert-builder.js +1 -1
  174. package/src/utils/workflow-hook-executor.js +1 -1
@@ -23,10 +23,11 @@ function parseTableRef(refstr) {
23
23
  const afterWhere = refstr.split(WHERE_SPLIT_RE)[0].trim();
24
24
  const cleaned = afterWhere.split(ORDER_SPLIT_RE)[0].trim();
25
25
  const tokens = cleaned.split(/\s+/).filter(Boolean);
26
- if (tokens.length === 0) return { tableName: '', alias: '' };
27
- const tableName = stripSchema(tokens[0]);
26
+ if (tokens.length === 0) return { tableName: '', alias: '', qualifiedName: '' };
27
+ const qualifiedName = tokens[0];
28
+ const tableName = stripSchema(qualifiedName);
28
29
  const alias = tokens.length > 1 ? tokens[1] : '';
29
- return { tableName, alias };
30
+ return { tableName, alias, qualifiedName };
30
31
  }
31
32
 
32
33
  function parseJoinCondition(condition, mainAlias) {
@@ -108,6 +109,7 @@ function parseDatatablesQuery(sql) {
108
109
  const cond = parseJoinCondition(condition, mainAlias);
109
110
  joins.push({
110
111
  tableName: ref.tableName,
112
+ tableQualified: ref.qualifiedName,
111
113
  tableAlias: ref.alias,
112
114
  localColumn: cond.localColumn,
113
115
  remoteColumn: cond.remoteColumn
@@ -168,6 +168,24 @@ function deriveTableAlias(tableName) {
168
168
  return initials || 't';
169
169
  }
170
170
 
171
+ /**
172
+ * Qualify nama tabel referensi FK dengan schema-nya bila schema BUKAN 'public'.
173
+ * `public` diperlakukan sebagai default implisit (selalu di search_path Postgres
174
+ * secara konvensi) sehingga TIDAK di-qualify, menjaga SQL JOIN tetap bare seperti
175
+ * sebelumnya untuk kasus non-multi-schema. Schema custom lain (mis. 'sch02') WAJIB
176
+ * di-qualify, karena search_path tidak menjamin mencakupnya — tanpa ini, query
177
+ * introspeksi kolom (`db.getColumns`) maupun JOIN yang dihasilkan akan salah
178
+ * menyasar tabel di schema default (lihat bug: "Available columns: (none)").
179
+ *
180
+ * @param {{references: {schema?: string, table: string}}} fk
181
+ * @returns {string}
182
+ */
183
+ function qualifiedRefTable(fk) {
184
+ const schema = fk && fk.references && fk.references.schema;
185
+ const table = fk && fk.references && fk.references.table;
186
+ return (schema && schema !== 'public') ? `${schema}.${table}` : table;
187
+ }
188
+
171
189
  /**
172
190
  * Pilih kolom display dari tabel referensi secara heuristik untuk mode
173
191
  * auto-resolve (`--expand-fk` tanpa `--fk-columns`).
@@ -307,7 +325,10 @@ function buildForeignKeyExpansion(payload, fkSpec, foreignKeys, refColumnsMap, b
307
325
  refTableAlias.set(key, {
308
326
  alias: uniqueAlias(deriveTableAlias(refTableName)),
309
327
  fk,
310
- refTableName
328
+ refTableName,
329
+ // Dipakai khusus untuk klausa JOIN (FROM/LEFT JOIN); refTableName (bare)
330
+ // tetap dipakai untuk alias derivation & penamaan kolom output.
331
+ refQualified: qualifiedRefTable(fk)
311
332
  });
312
333
  }
313
334
  refSelections.push({ alias: refTableAlias.get(key).alias, column: spec.column, refTableName });
@@ -359,7 +380,7 @@ function buildForeignKeyExpansion(payload, fkSpec, foreignKeys, refColumnsMap, b
359
380
  for (let i = 0; i < pairCount; i++) {
360
381
  conds.push(`${info.alias}.${refCols[i]} = ${baseAlias}.${localCols[i]}`);
361
382
  }
362
- sqlLines.push(`LEFT JOIN ${info.refTableName} ${info.alias} ON ${conds.join(' AND ')}`);
383
+ sqlLines.push(`LEFT JOIN ${info.refQualified} ${info.alias} ON ${conds.join(' AND ')}`);
363
384
  }
364
385
  const sqlContent = `${sqlLines.join('\n')}\n`;
365
386
 
@@ -1219,13 +1240,13 @@ class PayloadGenerator {
1219
1240
  if (dataType === 'date') {
1220
1241
  dateTimeFields[fieldName] = {
1221
1242
  type: 'date',
1222
- format: 'dd/MM/yyyy'
1243
+ format: 'yyyy-MM-dd'
1223
1244
  };
1224
1245
  } else if (['timestamp', 'timestamp without time zone', 'timestamp with time zone'].includes(dataType)
1225
1246
  || dataType.startsWith('timestamp')) {
1226
1247
  dateTimeFields[fieldName] = {
1227
1248
  type: 'timestamp',
1228
- format: 'dd/MM/yyyy HH:mm'
1249
+ format: 'yyyy-MM-dd HH:mm'
1229
1250
  };
1230
1251
  } else if (['time', 'time without time zone', 'time with time zone'].includes(dataType)) {
1231
1252
  dateTimeFields[fieldName] = {
@@ -1236,7 +1257,7 @@ class PayloadGenerator {
1236
1257
  // MySQL datetime type
1237
1258
  dateTimeFields[fieldName] = {
1238
1259
  type: 'timestamp',
1239
- format: 'dd/MM/yyyy HH:mm'
1260
+ format: 'yyyy-MM-dd HH:mm'
1240
1261
  };
1241
1262
  }
1242
1263
  }
@@ -1329,6 +1350,46 @@ class PayloadGenerator {
1329
1350
  * @param {string} primaryKey - Primary key field name
1330
1351
  * @returns {Array} fieldValidation array
1331
1352
  */
1353
+ /**
1354
+ * Ekstrak literal default value dari raw `column_default` hasil introspeksi
1355
+ * DB. Dipakai untuk tipe yang nilainya tetap berupa string mentah setelah
1356
+ * di-strip quote (string/text, DAN date/time yang literal-nya juga dikutip
1357
+ * dengan konvensi sama persis: 'YYYY-MM-DD'::date / 'HH:mm:ss'::time).
1358
+ * Berbeda dari integer/number/boolean (parseInt/parseFloat/match
1359
+ * 'true'/'false' otomatis mengabaikan noise), tipe-tipe ini butuh strip
1360
+ * eksplisit karena tiap dialect membungkus literal secara berbeda:
1361
+ * PostgreSQL: 'waiting'::character varying (quoted + type-cast suffix)
1362
+ * Oracle: 'waiting' (quoted, sudah di-trim)
1363
+ * SQLite: 'waiting' (quoted, dari pragma_table_info)
1364
+ * MySQL: waiting (bare, tanpa quote di versi baru)
1365
+ * Default berupa ekspresi/fungsi (uuid_generate_v4(), CURRENT_TIMESTAMP,
1366
+ * CURRENT_DATE, CURRENT_TIME, dst.) BUKAN literal statis -> return undefined
1367
+ * (tidak actionable sebagai default form/payload, konsisten dengan branch
1368
+ * integer/number yang skip non-numeric; juga konsisten dengan autoGenerate
1369
+ * yang menangani kasus "nilai dinamis saat insert" secara terpisah).
1370
+ * @param {string|null} rawDefault - col.column_default mentah dari introspeksi
1371
+ * @returns {string|undefined}
1372
+ */
1373
+ extractLiteralDefault(rawDefault) {
1374
+ if (rawDefault === null || rawDefault === undefined) return undefined;
1375
+ const str = String(rawDefault).trim();
1376
+ if (str === '') return undefined;
1377
+
1378
+ // Quoted literal, dengan/tanpa type-cast suffix (::type). '' di dalam quote
1379
+ // adalah escape untuk satu single-quote literal (konvensi SQL standard).
1380
+ const quotedMatch = str.match(/^'((?:[^']|'')*)'(?:::[\w\s."]+)?$/);
1381
+ if (quotedMatch) {
1382
+ return quotedMatch[1].replace(/''/g, "'");
1383
+ }
1384
+
1385
+ // Bare literal (MySQL) vs ekspresi/fungsi/keyword -> tolak yang terakhir.
1386
+ if (/^[A-Za-z_][\w]*\s*\(.*\)$/.test(str)) return undefined;
1387
+ if (/^(NULL|CURRENT_TIMESTAMP|CURRENT_DATE|CURRENT_TIME)$/i.test(str)) return undefined;
1388
+
1389
+ return str;
1390
+ }
1391
+
1392
+
1332
1393
  generateFieldValidation(detailedColumns, fieldNames, primaryKey) {
1333
1394
  const fieldValidation = [];
1334
1395
 
@@ -1498,10 +1559,24 @@ class PayloadGenerator {
1498
1559
  name: fieldName,
1499
1560
  type: 'date',
1500
1561
  constraints: {
1501
- format: 'dd/MM/yyyy'
1562
+ format: 'yyyy-MM-dd'
1502
1563
  }
1503
1564
  };
1504
1565
 
1566
+ // Detect auto-generate: CURRENT_DATE (mirror timestamp's now()/
1567
+ // CURRENT_TIMESTAMP/SYSTIMESTAMP). Didukung per handbook
1568
+ // field-validation.md ("autoGenerate ... Tipe yang didukung: uuid,
1569
+ // string, date, datetime, timestamp") tapi sebelumnya tidak pernah
1570
+ // di-deteksi generator ini.
1571
+ if (columnDefault.includes('current_date')) {
1572
+ entry.constraints.autoGenerate = true;
1573
+ } else {
1574
+ const defaultVal = this.extractLiteralDefault(col.column_default);
1575
+ if (defaultVal !== undefined) {
1576
+ entry.constraints.default = defaultVal;
1577
+ }
1578
+ }
1579
+
1505
1580
  fieldValidation.push(entry);
1506
1581
  continue;
1507
1582
  }
@@ -1516,7 +1591,7 @@ class PayloadGenerator {
1516
1591
  name: fieldName,
1517
1592
  type: 'datetime',
1518
1593
  constraints: {
1519
- format: 'dd/MM/yyyy HH:mm:ss'
1594
+ format: 'yyyy-MM-dd HH:mm'
1520
1595
  }
1521
1596
  };
1522
1597
 
@@ -1536,10 +1611,17 @@ class PayloadGenerator {
1536
1611
  name: fieldName,
1537
1612
  type: 'time',
1538
1613
  constraints: {
1539
- format: 'HH:mm:ss'
1614
+ format: 'HH:mm'
1540
1615
  }
1541
1616
  };
1542
1617
 
1618
+ // autoGenerate TIDAK didukung untuk time per handbook
1619
+ // field-validation.md - hanya literal default yang relevan di sini.
1620
+ const defaultVal = this.extractLiteralDefault(col.column_default);
1621
+ if (defaultVal !== undefined) {
1622
+ entry.constraints.default = defaultVal;
1623
+ }
1624
+
1543
1625
  fieldValidation.push(entry);
1544
1626
  continue;
1545
1627
  }
@@ -1588,6 +1670,11 @@ class PayloadGenerator {
1588
1670
  entry.constraints.unique = true;
1589
1671
  }
1590
1672
 
1673
+ const defaultVal = this.extractLiteralDefault(col.column_default);
1674
+ if (defaultVal !== undefined) {
1675
+ entry.constraints.default = defaultVal;
1676
+ }
1677
+
1591
1678
  // Skip entry tanpa constraint agar payload tidak bloat — KECUALI type:'text'.
1592
1679
  // Untuk text, tipe itu sendiri adalah sinyal "unbounded/long text" first-class
1593
1680
  // yang harus bertahan di payload meski tidak ada constraint lain.
@@ -2558,11 +2645,15 @@ class SchemaValidator {
2558
2645
  const rt = fk && fk.references && fk.references.table;
2559
2646
  if (!rt) continue;
2560
2647
  const key = String(rt).toLowerCase();
2648
+ // qualifiedRefTable() dipakai untuk query ke DB (perlu schema yang benar
2649
+ // bila parent bukan di schema 'public'); `rt` (bare) tetap dipakai sebagai
2650
+ // key map + identitas fkSpec (selaras format `--fk-columns=table.column`).
2651
+ const qualifiedRt = qualifiedRefTable(fk);
2561
2652
  if (!refColumnsMap[key]) {
2562
- refColumnsMap[key] = await this.db.getColumns(rt);
2653
+ refColumnsMap[key] = await this.db.getColumns(qualifiedRt);
2563
2654
  }
2564
2655
  const refPk = typeof this.db.getPrimaryKey === 'function'
2565
- ? await this.db.getPrimaryKey(rt)
2656
+ ? await this.db.getPrimaryKey(qualifiedRt)
2566
2657
  : null;
2567
2658
  const display = pickDisplayColumn(refColumnsMap[key], refPk);
2568
2659
  if (!display) {
@@ -2584,7 +2675,7 @@ class SchemaValidator {
2584
2675
  const key = String(rt).toLowerCase();
2585
2676
  if (!neededTables.has(key)) continue;
2586
2677
  if (!refColumnsMap[key]) {
2587
- refColumnsMap[key] = await this.db.getColumns(rt);
2678
+ refColumnsMap[key] = await this.db.getColumns(qualifiedRefTable(fk));
2588
2679
  }
2589
2680
  }
2590
2681
  }
@@ -2826,6 +2917,7 @@ module.exports = {
2826
2917
  SchemaValidator,
2827
2918
  parseFkColumns,
2828
2919
  deriveTableAlias,
2920
+ qualifiedRefTable,
2829
2921
  pickDisplayColumn,
2830
2922
  buildForeignKeyExpansion,
2831
2923
  collectStringColumns,
@@ -1 +1 @@
1
- const a0_0x37cda6=a0_0x4f69;(function(_0x4da233,_0x426370){const _0x3ba43f=a0_0x4f69,_0x2380b3=_0x4da233();while(!![]){try{const _0x4dbfe2=parseInt(_0x3ba43f(0x177))/0x1*(parseInt(_0x3ba43f(0x149))/0x2)+parseInt(_0x3ba43f(0x12c))/0x3*(-parseInt(_0x3ba43f(0x129))/0x4)+parseInt(_0x3ba43f(0x118))/0x5*(parseInt(_0x3ba43f(0x165))/0x6)+-parseInt(_0x3ba43f(0x14f))/0x7*(parseInt(_0x3ba43f(0x15c))/0x8)+-parseInt(_0x3ba43f(0x16d))/0x9+-parseInt(_0x3ba43f(0x137))/0xa+parseInt(_0x3ba43f(0x141))/0xb;if(_0x4dbfe2===_0x426370)break;else _0x2380b3['push'](_0x2380b3['shift']());}catch(_0x17c222){_0x2380b3['push'](_0x2380b3['shift']());}}}(a0_0xe2f1,0x1cae4));function a0_0xe2f1(){const _0x564dda=['ue9tvcaVyxbPl21PBMKTAw52zw50B3j5l2rHC2GTAw5IB3vUzc9KyxnOyM9HCMq','y2fJAgu','q29SBgfWC2uGDg8GB2jQzwn0ihDOB3nLigTLExmGyxjLifnrtcbJB2X1Bw4GBMfTzxmGkgXVD2vYy2fZzwqPlG','Bgf5B3v0','v2HLBIb0CNvLlcb0AguGCMvXDwvZDcbIB2r5ie1vu1qGAw5JBhvKzsb0AgLZihbHCMfTicHVDgHLCNDPC2uGndaWks4','mteWnZy2nLPSDgXrwG','tM90igeGzgfZAgjVyxjKihbHEwXVywqGkgXPA2vSEsbduLveihDPDgGGDgfIBgvoyw1LlcbVCIbPBNzHBgLKkq','EYaICgfYyw1ZiJOGEYaIEwvHCIi6ihSGiNr5CguIoIaIBNvTyMvYiIWGiNjLCxvPCMvKiJOGDhj1zsb9ih0GFq','CgfYyw1Z','w3SGiMXHyMvSiJOGiLnOB2vZiIWGiNzHBhvLiJOGiJC2nJaIih0SihSGiMXHyMvSiJOGiKDHBwLUzYiSicj2ywX1zsi6iciYodiWiIb9lcb7icjSywjLBci6icjpDgHLCNmIlcaIDMfSDwuIoIaInduYntCIih1D','zxHWzwn0zwrFzwfYBMLUz3m','zgfZAgjVyxjKihbHEwXVywq','ugfYyw0GBMfTzsbTDxn0ig1HDgnOihrOzsbWBgfJzwHVBgrLCIbYzwDLEcbGw2eTEKeTwL9Dw2eTEKeTwJaTov9DkMaGkgfSCgHHBNvTzxjPyYaRihvUzgvYC2nVCMuSig11C3qGC3rHCNqGD2L0AcbSzxr0zxiGB3iGDw5KzxjZy29YzsKU','qsb3AwrNzxqGtvvtvcbKzwnSyxjLigv4ywn0BhKGB25Lig9MoIaNCxvLCNKNie9sicDXDwvYAwvZjY4GqM90AcbVCIbUzwL0AgvYigLZihjLAMvJDgvKlG','l2fWAs97ChjVAMvJDh0VE25HBwv9l2rHC2HIB2fYza','mwDNBgTeDq','msbYB3CGW5CGmsbJB2WSig91Dhb1DcbJB2X1Bw4Gj3zHBhvLjW','BwfW','yw55icGXihjVDYddLYaXignVBcWGtIbYB3DZimoxie0Gy29SCYWGzxrJlIK','BNvTyMvY','C3rYAw5N','B2jQzwn0iokaLcb2ywX1zxmGzM9YigrLy2XHCMvKihbHCMfTCYaODMfSAwrHDgvKigfNywLUC3qGCgfYyw1ZignVBNrYywn0oYbTAxnZAw5NihjLCxvPCMvKiokgKIa0mdaSihr5CguGBwLZBwf0y2GG4OAsidqWmcK','DgL0Bgu','nJK1nJq1zNvrzxzt','Cgf5Bg9Hzcbku09oigzPBguGBg9JyxrPB24','yw55icHTDxn0igjLignVBxbHDgLIBguGD2L0AcbKzwnSyxjLzcaNDhLWzsCP','xMrHC2GTw2eTEKeTwJaTov8TxsSK','zMLSztPXDwvYEs88Cgf0Ad4Vy3vYCMvUDc5ZCwW','zMLSztPXDwvYEs88Cgf0Ad4VDhjLBMqUC3fS','zgf0zq','EYbZDwnJzxnZoIbIB29SzwfUlcbKyxrHoIb7idX3AwrNzxrjzd46idXWzxjxAwrNzxrszxnWB25Zzt4Sic4UlIb9ih0','CxvLCMLLCW','yxzNx2rHAwX5x3nHBgvZ','Cgn0','qwX3yxLZihDYyxaGyxmGEYbPDgvTCZOGwY4UlL0GFsbYzwDHCMrSzxnZig9MifnrtcbYzxn1BhqGC2HHCguU','zgvMyxvSDa','yxjYyxKGB2yGB2jQzwn0CW','yxjYyxK','iJi0mJaI','Bwv0CMLJx3nWyxjRBgLUzq','mtGWmZu2Bgncs1H1','tgf5B3v0igLZigeGzNjVBNrLBMqGCMvUzgvYAw5NignVBMnLCM4U','uMv0DxjUigfZigfYCMf5ig9Mig9IAMvJDhmGkg5VignVBgXHChnLks4','ow5ozKXcqq','yxjYyxK8C3rYAw5NpG','phDPzgDLDf9Pzd4','sgvHzgXPBMuGBwv0CMLJihDPDgGGDhjLBMqGy2HPCcbHBMqGyNjLywTKB3DUigfJCM9ZCYbJyxrLz29YAwvZlIbtDwL0ywjSzsbMB3iGD2LKz2v0CYbSAwTLicDfEhbLy3rLzcbfyxjUAw5NCYCGDgHHDcbZAg93ihrVDgfSihzHBhvLlcbWzxjJzw50ywDLignOyw5NzsWGyw5KihbLCI1JyxrLz29YEsbJB250CMLIDxrPB24U','CgvYAw9K','rNjVBNrLBMqGzgv0zxjTAw5LCYbKB251Dc9WAwuGDMfYAwfUDcWGy29SB3iGCgvYignHDgvNB3j5lcbHBMqGBgfIzwWGB3jKzxiUieLMihbLCI1JyxrLz29YEsbWzxjJzw50ywDLigLZig5LzwrLzcbMB3iGDgHLigrVBNv0igfYyYWGzNjVBNrLBMqGy29TChv0zxmGAxqGzNjVBsbPDgvTC1TPxs52ywX1zsaVihn1BsHPDgvTC1SQxs52ywX1zsKUie5Vig5LzwqGDg8GC2vUzcaNCgn0jYbMCM9TigjHy2TLBMqGDw5SzxnZihrOzsbMAwD1CMuGAxmGysbZDgfIBguGyNvZAw5LC3mGy2fSy3vSyxrPB24GAw5KzxbLBMrLBNqGB2yGDMLZDwfSihjLBMrLCMLUzY4','zgLYzwn0Aw9U','C2nHBgfYihbYAw1PDgL2zq','vgfIBguGzgvJBgfYzwqGAw4GAw52ywXPzgf0zxmSigj1DcbUB3qGzgv0zwn0zwqGAw4Gyw55ihDPzgDLDcbtuuWGkhr5Cg8GB3iGzgvHzcbLBNrYEsK','Dg9WlwXLDMvSicDJywnOzsCGB2jQzwn0','zgfZAgjVyxjKlwnHDgfSB2C','mJa2ndbiALftBee','qwXSihDPzgDLDcbtuuWG4OcuigjVDgGGj3f1zxj5jYaOC2LUz3vSyxiPigfUzcbLDMvYEsaNCxvLCMLLCY48A2v5pICU','DhjLBMq','BgfIzwW','iJe4mZyI','yM9VBgvHBG','ugfYyw0Gzgf0ysb0ExbLlIbwywXPzgf0zxmGCMvXDwvZDcbIB2r5igfUzcbZAgfWzxmGCNvUDgLTzsbWyxjHBwv0zxiGyMLUzgLUzY4','tIbYB3DZimoxie0Gy29SCW','yxjYyxK8C3rYAw5NpIWGB3b0Aw9UywWG4Ocuihn1yNnLDcbVzIb3AwrNzxqGsurZihrVigv4zwn1DguUie9TAxqGDg8GzxHLy3v0zsbHBgWGzgvJBgfYzwqGD2LKz2v0CY4','zNjLztSGlNnXBcbYzwnVBw1LBMrLzcbMB3iGzwrPDg9YigHPz2HSAwDODa','ndu1nZG1mgPdwNzxCW','Cg9PBNrZ','zw5HyMXLza','zxHWB3j0CW','tIbYB3DZimoxidiGy29SDw1UCW','ugvYlwTLEsbIyxnLzcbVBIbZy2fSyxjdB2XSyxbZzvj1BgvZigjLBg93lG','vgfIBguGzgv0zwn0zwqGAw4Gu1fmlcbIDxqGBM90ihjLz2LZDgvYzwqGyxmGq1jvrcbLBMrWB2LUDcbPBIbTzxrHzgf0ysbWCM9Qzwn0icHSAwTLBhKGysb2Awv3lcbdveuGywXPyxmSig9YignYB3nZlxbYB2PLy3qGDgfIBguG4OcuignHC2nHzguGD2LSBcbUB3qGzMLYzsK','vgLTzs10BY1SAxzLigLUihnLy29UzhmUidaGzwzMzwn0AxzLBhKGzgLZywjSzxmGy2fJAguGzM9YihrOAxmGzw50CNKU','odKWndHJugTKu08','B2jQzwn0','B3jKzxjZx3rOAxnFBw9UDgG','iNnOB3bWAw5Nx2nHDgvNB3jPzxmIoIb7icjPDgvTCYi6ifT7icjUyw1LiJOGiKXHBMrZiIb9lcb7icjUyw1LiJOGiKHVDxnLCYiGFv0GFq','z2vUzxjHDgLVBIb0Aw1LicHot1qGCNvUDgLTzsK','EYaIzgLYzwn0Aw9UiJOGiNvWiIWGiNbJDci6iciYlJiIih0','ndLmD3LVCKG','q29SBgfWC2uGDg8GC2nHBgfYihbYAw1PDgL2zsaODgHLihzHBhvLig9MihrOzsbZAw5NBguGy29SDw1Uks4','DMfSDwu','v2LKz2v0igLKzw50AwzPzxi7ihvZzwqGyxmGDgHLihjLC3bVBNnLigTLEsbPBIb0AguGzgfZAgjVyxjKigvUDMvSB3bLlG','tgLZDcbVzIb3AwrNzxqGzgvMAw5PDgLVBNmUie9YzgvYigLZigLUzM9YBwf0Aw9UywWGB25SEsaOCMvZCg9UC2uGA2v5CYbHCMuGyNKGD2LKz2v0igLKlcbUB3qGyxjYyxKGAw5KzxGPlG','BgvUz3rO','zgfZAc1PBMjVDw5K','A2v54OAszMLSztPYzwXHDgL2zs9WyxrOl3rVl3f1zxj5lNnXBa','iML0zw1ZiJOGw3SGiMXHyMvSiJOGiLnOB2vZiIWGiNzHBhvLiJOGiJC2nJaIih0Sic4UlL0','DgfYz2v0','ue9tva','tgLZDcbVzIbduLveihrHyMXLig5HBwvZihrOyxqSihDOzw4GD3jPDhrLBIWGD2LSBcb0CMLNz2vYigLUDMfSAwrHDgLVBIbVzIb0AgLZigrHC2HIB2fYzcbJywnOzs4','twv0CMLJicSGu3bHCMTSAw5L','mJuXnty4zLH6tKjA','twv0CMLJicSGuhjVz3jLC3mGDg8Gr29HBa','msbYB3CGW5CGmIbJB2XZlcbVDxrWDxqGy29SDw1UCYaNzgLYzwn0Aw9UjYWGj3bJDcC','uMvZzxj2zwqGzM9YiensvuqGCgf5Bg9HzhmUieeGzgfZAgjVyxjKihbHEwXVywqGBxvZDcbKzwnSyxjLicD3AwrNzxrZjYbPBNn0zwfKlG','rxzLCNKGCgXHy2vOB2XKzxiGDxnLzcbPBIbtuuWGtvvtvcbIzsbKzwnSyxjLzcbPBIaNCgfYyw1ZjY4GvMfSAwrHDg9YihrOCM93CYbfCNjVCIb3AxrOig1LC3nHz2uGzM9YBwf0oIaIv2LKz2v0icC8Awq+jYbXDwvYEsaNpgXHyMvSpICGDxnLCYb1BMrLy2XHCMvKihbSywnLAg9SzgvYicC6phrVA2vUpICGkgrLy2XHCMuGAw4Gj3bHCMfTCYCPiI4','D2LKz2v0lNf1zxjPzxmUpgTLEt4GD2L0AcbtuuWGCMv0DxjUAw5NideGCM93imoxideGy29SDw1U','zMLSztPXDwvYEs88Cgf0Ad4VyNjLywTKB3DUlNnXBa','msbYB3CGW5CGmIbJB2X1Bw5Z','Dg9Wtgv2zwXbBgXVD2vK','nMjqAgLOuq','msbYB3CGW5CGmsbJB2X1Bw4','Ahr0Chm6lY9Yzxn0zM9Yz2uUzgv2l2rVy3mVC2vYDMvYl3f1zxj5lwrHDgeVzgfZAgjVyxjK'];a0_0xe2f1=function(){return _0x564dda;};return a0_0xe2f1();}const FORBIDDEN_FRONTEND_FIELDS=['widgetType',a0_0x37cda6(0x16b),a0_0x37cda6(0x17e),'subtitle','color'],ALLOWED_PARAM_TYPES=[a0_0x37cda6(0x17c),a0_0x37cda6(0x17b),a0_0x37cda6(0x13c),a0_0x37cda6(0x11e)],FRONTEND_CONCERN_REASONS={'widgetType':'Visual\x20variant\x20(donut,\x20bar,\x20pie,\x20area)\x20is\x20a\x20frontend\x20rendering\x20concern\x20(separation\x20of\x20concerns).','layout':a0_0x37cda6(0x12a),'title':'UI\x20label\x20is\x20a\x20frontend\x20rendering\x20concern.','subtitle':'UI\x20label\x20is\x20a\x20frontend\x20rendering\x20concern.','color':'Visual\x20color\x20is\x20a\x20frontend\x20rendering\x20concern.'},PAYLOAD_SHAPE={'discriminator':{'field':'widgets','presentMeans':a0_0x37cda6(0x173),'absentMeans':a0_0x37cda6(0x16e),'conflictsWith':'tableName','conflictRationale':'A\x20payload\x20with\x20both\x20\x27widgets\x27\x20and\x20\x27tableName\x27\x20is\x20rejected\x20by\x20DashboardValidator.\x20Pick\x20one\x20shape.'},'topLevelAllowed':[{'name':'widgets','type':a0_0x37cda6(0x126),'required':!![],'minItems':0x1,'description':a0_0x37cda6(0x153)},{'name':a0_0x37cda6(0x170),'type':a0_0x37cda6(0x14a),'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':a0_0x37cda6(0x169),'type':a0_0x37cda6(0x14a),'required':![],'description':'Optional\x20cache\x20configuration.\x20See\x20cacheSpec\x20for\x20details.'}],'topLevelForbidden':[{'name':'tableName','category':'shape-conflict','reason':a0_0x37cda6(0x15f)},...FORBIDDEN_FRONTEND_FIELDS[a0_0x37cda6(0x179)](_0x40fdad=>({'name':_0x40fdad,'category':'frontend-concern','reason':FRONTEND_CONCERN_REASONS[_0x40fdad]}))]},WIDGET_SPEC={'requiredFields':[{'name':'id','type':a0_0x37cda6(0x17c),'constraint':'non-empty,\x20unique\x20across\x20widgets\x20in\x20the\x20same\x20payload','description':a0_0x37cda6(0x152)}],'exclusiveQueryFields':{'rule':a0_0x37cda6(0x175),'options':[{'name':'query','type':'string','format':'file:relative/path/to/query.sql','description':'Single\x20SQL\x20query\x20for\x20the\x20widget.','responseShape':'Always\x20{\x20items:\x20[...]\x20}\x20regardless\x20of\x20SQL\x20result\x20shape.'},{'name':a0_0x37cda6(0x120),'type':a0_0x37cda6(0x14a),'format':a0_0x37cda6(0x156),'minKeys':0x1,'description':'Multi-SQL\x20widget.\x20Each\x20key\x20becomes\x20a\x20key\x20in\x20the\x20response\x20object.','responseShape':a0_0x37cda6(0x146)}]},'forbiddenFields':FORBIDDEN_FRONTEND_FIELDS},PARAM_SPEC={'container':'top-level\x20\x27params\x27\x20object','keyConvention':a0_0x37cda6(0x174),'perEntryFields':[{'name':'type','required':!![],'allowedValues':ALLOWED_PARAM_TYPES,'description':a0_0x37cda6(0x13d)},{'name':'required','required':![],'type':'boolean','default':![],'description':a0_0x37cda6(0x16c)},{'name':a0_0x37cda6(0x124),'required':![],'type':a0_0x37cda6(0x11a),'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_0x37cda6(0x123),'exampleSqlShape':a0_0x37cda6(0x17a),'exampleResponse':a0_0x37cda6(0x14c)},{'appliesTo':a0_0x37cda6(0x161),'rule':a0_0x37cda6(0x150),'exampleSqlShape':a0_0x37cda6(0x178),'exampleResponse':'\x22value\x22:\x20\x2269700\x22'},{'appliesTo':'widget.queries.<key>\x20with\x20SQL\x20returning\x201\x20row\x20×\x20multiple\x20columns','rule':a0_0x37cda6(0x16a),'exampleSqlShape':a0_0x37cda6(0x15e),'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':a0_0x37cda6(0x12b),'exampleSqlShape':a0_0x37cda6(0x13e),'exampleResponse':a0_0x37cda6(0x157)}],COMMON_WIDGET_PATTERNS=[{'id':'metric_donut_breakdown','name':'Metric\x20+\x20Donut\x20Breakdown','useCase':a0_0x37cda6(0x12f),'payloadShape':{'id':a0_0x37cda6(0x12e),'queries':{'value':'file:query/<path>/value.sql','trend':'file:query/<path>/trend.sql','items':a0_0x37cda6(0x162)}},'sqlShapesPerKey':[{'key':'value','shape':a0_0x37cda6(0x166),'outputColumns':[a0_0x37cda6(0x151)],'collapseRule':a0_0x37cda6(0x133)},{'key':a0_0x37cda6(0x139),'shape':'1\x20row\x20×\x202\x20columns','outputColumns':[a0_0x37cda6(0x132),'pct'],'collapseRule':a0_0x37cda6(0x14a)},{'key':'items','shape':a0_0x37cda6(0x145),'outputColumns':[a0_0x37cda6(0x13a),'value'],'collapseRule':a0_0x37cda6(0x125)}],'responseShape':{'value':'\x2269700\x22','trend':a0_0x37cda6(0x14e),'items':a0_0x37cda6(0x171)},'referenceWidgetId':a0_0x37cda6(0x172),'socNotes':a0_0x37cda6(0x131)},{'id':a0_0x37cda6(0x128),'name':a0_0x37cda6(0x15b),'useCase':'Headline\x20metric\x20with\x20trend\x20chip\x20and\x20sparkline\x20mini-chart\x20for\x20short\x20windows\x20(7\x20days,\x2012\x20months,\x20etc.).\x20Suitable\x20for\x20widgets\x20like\x20\x27Average\x20Daily\x20Sales\x27.','payloadShape':{'id':'<widget_id>','queries':{'value':'file:query/<path>/value.sql','trend':a0_0x37cda6(0x11d),'points':'file:query/<path>/points.sql'}},'sqlShapesPerKey':[{'key':'value','shape':a0_0x37cda6(0x166),'outputColumns':[a0_0x37cda6(0x151)],'collapseRule':'scalar\x20primitive'},{'key':a0_0x37cda6(0x139),'shape':'1\x20row\x20×\x202\x20columns','outputColumns':['direction','pct'],'collapseRule':'object'},{'key':a0_0x37cda6(0x142),'shape':a0_0x37cda6(0x145),'outputColumns':[a0_0x37cda6(0x130),a0_0x37cda6(0x151)],'collapseRule':a0_0x37cda6(0x125)}],'responseShape':{'value':a0_0x37cda6(0x127),'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_0x37cda6(0x121),'socNotes':'Sparkline\x20libraries\x20(ApexCharts,\x20Chartist,\x20etc.)\x20typically\x20need\x20a\x20plain\x20number\x20array.\x20Frontend\x20maps\x20points.map(p\x20=>\x20p.value).\x20The\x20\x27period\x27\x20field\x20stays\x20for\x20tooltip\x20and\x20gap-resilience\x20against\x20missing\x20days.\x20Use\x20generate_series\x20in\x20SQL\x20to\x20ensure\x20consistent\x20row\x20count\x20even\x20for\x20days\x20with\x20no\x20transactions.'},{'id':'metric_progress_to_goal','name':a0_0x37cda6(0x15d),'useCase':'Headline\x20metric\x20with\x20trend\x20chip\x20and\x20progress\x20bar\x20against\x20a\x20period\x20target.\x20Suitable\x20for\x20widgets\x20like\x20\x27Orders\x20This\x20Month\x27.','payloadShape':{'id':a0_0x37cda6(0x12e),'queries':{'value':a0_0x37cda6(0x11c),'trend':'file:query/<path>/trend.sql','target':'file:query/<path>/target.sql'}},'sqlShapesPerKey':[{'key':'value','shape':a0_0x37cda6(0x166),'outputColumns':['value\x20(or\x20current)'],'collapseRule':a0_0x37cda6(0x133)},{'key':a0_0x37cda6(0x139),'shape':a0_0x37cda6(0x163),'outputColumns':['direction',a0_0x37cda6(0x122)],'collapseRule':'object'},{'key':'target','shape':'1\x20row\x20×\x201\x20column','outputColumns':[a0_0x37cda6(0x158)],'collapseRule':a0_0x37cda6(0x133)}],'responseShape':{'value':a0_0x37cda6(0x13b),'trend':'{\x20\x22direction\x22:\x20\x22down\x22,\x20\x22pct\x22:\x20\x222.2\x22\x20}','target':'\x222884\x22'},'referenceWidgetId':a0_0x37cda6(0x14b),'socNotes':'Frontend\x20computes\x20to_goal\x20=\x20target\x20-\x20value\x20and\x20pct\x20=\x20round(value\x20/\x20target\x20*\x20100)\x20for\x20the\x20progress\x20bar.\x20Visual\x20width\x20is\x20presentational\x20and\x20must\x20NOT\x20live\x20in\x20the\x20backend\x20payload.\x20If\x20progress\x20involves\x20complex\x20business\x20rules\x20(e.g.\x20exclude\x20weekends,\x20prorated\x20workdays),\x20use\x20a\x20single\x20multi-column\x20query\x20so\x20\x27pct\x27\x20is\x20a\x20stable\x20business\x20fact\x20rather\x20than\x20visual\x20width.'}],NAMING_CONVENTION={'dashboardName':{'constraint':'MUST\x20start\x20with\x20\x27dash-\x27\x20prefix','minLength':0x6,'maxLength':0x32,'regex':a0_0x37cda6(0x11b),'examples':['dash-sales',a0_0x37cda6(0x155),'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':a0_0x37cda6(0x159),'path':a0_0x37cda6(0x176),'exampleFull':a0_0x37cda6(0x168),'requestBodyShape':{'params':a0_0x37cda6(0x17d),'widgets':a0_0x37cda6(0x13f)},'responseShape':{'envelope':a0_0x37cda6(0x11f),'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':'file:relative/path/to/query.sql','pathRelativeTo':a0_0x37cda6(0x119),'fileExtensionPolicy':a0_0x37cda6(0x140),'resolvedAt':a0_0x37cda6(0x14d),'embedStrategy':'SQL\x20file\x20content\x20is\x20embedded\x20as\x20JavaScript\x20template\x20literal\x20inside\x20the\x20generated\x20module\x20file.\x20Runtime\x20performs\x20zero\x20disk\x20I/O\x20per\x20request\x20—\x20all\x20SQL\x20is\x20in\x20memory\x20after\x20module\x20load.','implication':'Updating\x20an\x20SQL\x20file\x20requires\x20regenerating\x20the\x20dashboard\x20module\x20(\x27codegen_create_dashboard\x27)\x20for\x20changes\x20to\x20take\x20effect.'},PLACEHOLDER_CONVENTION={'format':':paramName','regex':'(?<!:):([a-zA-Z_][a-zA-Z0-9_]*)','regexNotes':'Negative\x20lookbehind\x20prevents\x20matching\x20\x27::\x27\x20(Postgres\x20cast\x20syntax)\x20as\x20a\x20placeholder.','scanScope':a0_0x37cda6(0x138),'constraint':a0_0x37cda6(0x160),'exampleSql':'SELECT\x20*\x20FROM\x20stock_inbound\x20WHERE\x20EXTRACT(YEAR\x20FROM\x20inbound_date)\x20=\x20:year','exampleParamDeclaration':a0_0x37cda6(0x16f)},CACHE_SPEC={'container':a0_0x37cda6(0x135),'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':a0_0x37cda6(0x143),'type':'boolean','required':!![],'description':'Toggle\x20cache\x20feature\x20for\x20this\x20dashboard.'},{'name':'ttl','type':'number','required':![],'constraint':'>=\x200\x20(seconds)','default':'inherits\x20CACHE_TTL\x20env','description':a0_0x37cda6(0x148)},{'name':'invalidates','type':a0_0x37cda6(0x12d),'required':![],'default':'[]','description':a0_0x37cda6(0x15a)}],'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_0x37cda6(0x134)],'warningOn':[a0_0x37cda6(0x147)]}},DOCUMENTATION_URL=a0_0x37cda6(0x167),DASHBOARD_CATALOG={'schemaVersion':'1.0','source':a0_0x37cda6(0x136),'summary':{'totalAllowedTopLevelFields':PAYLOAD_SHAPE[a0_0x37cda6(0x164)]['length'],'totalForbiddenFrontendFields':FORBIDDEN_FRONTEND_FIELDS['length'],'totalParamTypes':ALLOWED_PARAM_TYPES[a0_0x37cda6(0x154)],'totalScalarCollapseRules':SCALAR_COLLAPSE_RULES[a0_0x37cda6(0x154)],'totalCommonWidgetPatterns':COMMON_WIDGET_PATTERNS['length']},'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_0x4f69(_0x1e2660,_0x4a8154){_0x1e2660=_0x1e2660-0x118;const _0xe2f178=a0_0xe2f1();let _0x4f69e5=_0xe2f178[_0x1e2660];if(a0_0x4f69['SUDayG']===undefined){var _0x2e78f5=function(_0x3e3116){const _0x2ea29a='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x40fdad='',_0x1dc75e='';for(let _0x38b94b=0x0,_0x143d1b,_0x4bec06,_0x304e65=0x0;_0x4bec06=_0x3e3116['charAt'](_0x304e65++);~_0x4bec06&&(_0x143d1b=_0x38b94b%0x4?_0x143d1b*0x40+_0x4bec06:_0x4bec06,_0x38b94b++%0x4)?_0x40fdad+=String['fromCharCode'](0xff&_0x143d1b>>(-0x2*_0x38b94b&0x6)):0x0){_0x4bec06=_0x2ea29a['indexOf'](_0x4bec06);}for(let _0x16b68d=0x0,_0x2f4502=_0x40fdad['length'];_0x16b68d<_0x2f4502;_0x16b68d++){_0x1dc75e+='%'+('00'+_0x40fdad['charCodeAt'](_0x16b68d)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x1dc75e);};a0_0x4f69['gVMMYh']=_0x2e78f5,a0_0x4f69['rSmWGk']={},a0_0x4f69['SUDayG']=!![];}const _0x2523da=_0xe2f178[0x0],_0x5555c2=_0x1e2660+_0x2523da,_0x9a110f=a0_0x4f69['rSmWGk'][_0x5555c2];return!_0x9a110f?(_0x4f69e5=a0_0x4f69['gVMMYh'](_0x4f69e5),a0_0x4f69['rSmWGk'][_0x5555c2]=_0x4f69e5):_0x4f69e5=_0x9a110f,_0x4f69e5;}module[a0_0x37cda6(0x144)]={'DASHBOARD_CATALOG':DASHBOARD_CATALOG};
1
+ const a0_0x20f86c=a0_0x2283;(function(_0x5b5bff,_0x206b7d){const _0x4bdb08=a0_0x2283,_0x46a584=_0x5b5bff();while(!![]){try{const _0x8d6e45=parseInt(_0x4bdb08(0x134))/0x1+parseInt(_0x4bdb08(0x108))/0x2*(parseInt(_0x4bdb08(0x120))/0x3)+parseInt(_0x4bdb08(0x10f))/0x4+-parseInt(_0x4bdb08(0x10a))/0x5+parseInt(_0x4bdb08(0x12e))/0x6*(parseInt(_0x4bdb08(0x125))/0x7)+parseInt(_0x4bdb08(0x166))/0x8*(parseInt(_0x4bdb08(0x136))/0x9)+-parseInt(_0x4bdb08(0x152))/0xa;if(_0x8d6e45===_0x206b7d)break;else _0x46a584['push'](_0x46a584['shift']());}catch(_0x40804b){_0x46a584['push'](_0x46a584['shift']());}}}(a0_0x1538,0x93c66));function a0_0x2283(_0x2e320c,_0x4f958e){_0x2e320c=_0x2e320c-0x106;const _0x1538ac=a0_0x1538();let _0x2283c5=_0x1538ac[_0x2e320c];if(a0_0x2283['MdNWvK']===undefined){var _0xe908e=function(_0x3bd183){const _0x3fbce5='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x14c42a='',_0x358bd1='';for(let _0x35093b=0x0,_0x4efde2,_0x541bd2,_0x2592a6=0x0;_0x541bd2=_0x3bd183['charAt'](_0x2592a6++);~_0x541bd2&&(_0x4efde2=_0x35093b%0x4?_0x4efde2*0x40+_0x541bd2:_0x541bd2,_0x35093b++%0x4)?_0x14c42a+=String['fromCharCode'](0xff&_0x4efde2>>(-0x2*_0x35093b&0x6)):0x0){_0x541bd2=_0x3fbce5['indexOf'](_0x541bd2);}for(let _0x3160f8=0x0,_0x5d7dab=_0x14c42a['length'];_0x3160f8<_0x5d7dab;_0x3160f8++){_0x358bd1+='%'+('00'+_0x14c42a['charCodeAt'](_0x3160f8)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x358bd1);};a0_0x2283['zLtAEQ']=_0xe908e,a0_0x2283['uYIOpr']={},a0_0x2283['MdNWvK']=!![];}const _0x18f5a0=_0x1538ac[0x0],_0x203ecc=_0x2e320c+_0x18f5a0,_0x228efa=a0_0x2283['uYIOpr'][_0x203ecc];return!_0x228efa?(_0x2283c5=a0_0x2283['zLtAEQ'](_0x2283c5),a0_0x2283['uYIOpr'][_0x203ecc]=_0x2283c5):_0x2283c5=_0x228efa,_0x2283c5;}function a0_0x1538(){const _0x43c469=['Dg9WlwXLDMvSicDWyxjHBxmNig9IAMvJDa','zgfZAc1ZywXLCW','nKzQBLj5ta','sgvHzgXPBMuGBwv0CMLJihDPDgGGDhjLBMqGy2HPCcbHBMqGyNjLywTKB3DUigfJCM9ZCYbJyxrLz29YAwvZlIbtDwL0ywjSzsbMB3iGD2LKz2v0CYbSAwTLicDfEhbLy3rLzcbfyxjUAw5NCYCGDgHHDcbZAg93ihrVDgfSihzHBhvLlcbWzxjJzw50ywDLignOyw5NzsWGyw5KihbLCI1JyxrLz29YEsbJB250CMLIDxrPB24U','rgvMyxvSDcb2ywX1zsbHChbSAwvKihDOzw4GDgHLihjLCxvLC3qGB21PDhmGDgHPCYbWyxjHBs4GvMfSAwrHDg9YigrVzxmGtK9uihn0CMLJDgX5ihr5CguTy2HLy2SGzgvMyxvSDdSGCNvUDgLTzsbPCYbYzxnWB25ZAwjSzsbMB3iGy29TCgf0AwjPBgL0Es4','Dg9WlwXLDMvSicDJywnOzsCGB2jQzwn0','tgLZDcbVzIb3AwrNzxqGzgvMAw5PDgLVBNmUie9YzgvYigLZigLUzM9YBwf0Aw9UywWGB25SEsaOCMvZCg9UC2uGA2v5CYbHCMuGyNKGD2LKz2v0igLKlcbUB3qGyxjYyxKGAw5KzxGPlG','phDPzgDLDf9Pzd4','mtm1nZC1yujnuMXe','tIbYB3DZimoxie0Gy29SCW','mta0nJyZndnNAgnVwvO','DgfYz2v0','zxHWzwn0zwrFzwfYBMLUz3m','vgHLihbYzwzPEcbIzwnVBwvZihbHCNqGB2yGDgHLifvstcbZzwDTzw50lIbuAguGCMvZzxj2zwqGC2nOzw1LigTLzxbZigrHC2HIB2fYzcbLBMrWB2LUDhmGDMLZDwfSBhKGzgLZDgLUy3qGzNjVBsbduLveigvUzhbVAw50CYbPBIb0AguGvvjmihnWywnLigfUzcbHBgXVD3mGzNv0DxjLihjVDxrPBMCGzgLMzMvYzw50Awf0Aw9UlG','vuKGBgfIzwWGAxmGysbMCM9UDgvUzcbYzw5KzxjPBMCGy29Uy2vYBI4','B2jQzwn0','u2LUz2XLifnrtcbXDwvYEsbMB3iGDgHLihDPzgDLDc4','zgfZAc1PBMjVDw5K','zgfZAc1HDxrOB3iTC3rHDhm','tIbYB3DZimoxidiGy29SDw1UCW','yxjYyxK8C3rYAw5NpIWGB3b0Aw9UywWG4Ocuihn1yNnLDcbVzIb3AwrNzxqGsurZihrVigv4zwn1DguUie9TAxqGDg8GzxHLy3v0zsbHBgWGzgvJBgfYzwqGD2LKz2v0CY4','zMLSztPXDwvYEs88Cgf0Ad4VDhjLBMqUC3fS','qsbWyxLSB2fKihDPDgGGyM90AcaND2LKz2v0CYCGyw5KicD0ywjSzu5HBwuNigLZihjLAMvJDgvKigj5ierHC2HIB2fYzfzHBgLKyxrVCI4GugLJAYbVBMuGC2HHCguU','vMLZDwfSignVBg9YigLZigeGzNjVBNrLBMqGCMvUzgvYAw5NignVBMnLCM4U','D2LKz2v0lNf1zxjPzxmUpgTLEt4GD2L0AcbtuuWGCMv0DxjUAw5NideGCM93imoxig11BhrPCgXLignVBhvTBNm','ue9tvcaVyxbPl21PBMKTAw52zw50B3j5l2rHC2GTAw5IB3vUzc9KyxnOyM9HCMq','CxvLCNK','Aw5OzxjPDhmGq0fdsevFvfrmigvUDG','vgfIBguGzgv0zwn0zwqGAw4Gu1fmlcbIDxqGBM90ihjLz2LZDgvYzwqGyxmGq1jvrcbLBMrWB2LUDcbPBIbTzxrHzgf0ysbWCM9Qzwn0icHSAwTLBhKGysb2Awv3lcbdveuGywXPyxmSig9YignYB3nZlxbYB2PLy3qGDgfIBguG4OcuignHC2nHzguGD2LSBcbUB3qGzMLYzsK','zMLSztPXDwvYEs88Cgf0Ad4VCg9PBNrZlNnXBa','D2LKz2v0lNf1zxj5icHZAw5NDwXHCIK','zMLSztPYzwXHDgL2zs9WyxrOl3rVl3f1zxj5lNnXBa','BgvUz3rO','ugfYyw0Gzgf0ysb0ExbLlIbwywXPzgf0zxmGCMvXDwvZDcbIB2r5igfUzcbZAgfWzxmGCNvUDgLTzsbWyxjHBwv0zxiGyMLUzgLUzY4','DhjLBMq','zMLSztPXDwvYEs88Cgf0Ad4VDMfSDwuUC3fS','B2jQzwn0iokaLcb2ywX1zxmGzM9YigrLy2XHCMvKihbHCMfTCYaODMfSAwrHDgvKigfNywLUC3qGCgfYyw1ZignVBNrYywn0oYbTAxnZAw5NihjLCxvPCMvKiokgKIa0mdaSihr5CguGBwLZBwf0y2GG4OAsidqWmcK','y2fJAgu','mtmWndy0nJbHqxfKsMK','sgvHzgXPBMuGBwv0CMLJihDPDgGGDhjLBMqGy2HPCcbHBMqGC3bHCMTSAw5Lig1PBMKTy2HHCNqGzM9YihnOB3j0ihDPBMrVD3mGkdCGzgf5CYWGmtiGBw9UDgHZlcbLDgmUks4Gu3vPDgfIBguGzM9YihDPzgDLDhmGBgLRzsaNqxzLCMfNzsbeywLSEsbtywXLCYCU','yM9VBgvHBG','zgLYzwn0Aw9U','q29SBgfWC2uGDg8GB2jQzwn0ihDOB3nLigTLExmGyxjLifnrtcbJB2X1Bw4GBMfTzxmGkgXVD2vYy2fZzwqPlG','yxjYyxK8C3rYAw5NpG','CgvYAw9K','D2LKz2v0CW','msbYB3CGW5CGmsbJB2X1Bw4','DMfSDwu','iJe4mZyI','msbYB3CGW5CGmIbJB2X1Bw5Z','rxzLCNKGCgXHy2vOB2XKzxiGDxnLzcbPBIbtuuWGtvvtvcbIzsbKzwnSyxjLzcbPBIaNCgfYyw1ZjY4GvMfSAwrHDg9YihrOCM93CYbfCNjVCIb3AxrOig1LC3nHz2uGzM9YBwf0oIaIv2LKz2v0icC8Awq+jYbXDwvYEsaNpgXHyMvSpICGDxnLCYb1BMrLy2XHCMvKihbSywnLAg9SzgvYicC6phrVA2vUpICGkgrLy2XHCMuGAw4Gj3bHCMfTCYCPiI4','zMLSztPXDwvYEs88Cgf0Ad4Vy3vYCMvUDc5ZCwW','zxHWB3j0CW','C2nHBgfYihbYAw1PDgL2zq','q29SBgfWC2uGDg8GC2nHBgfYihbYAw1PDgL2zsaODgHLihzHBhvLig9MihrOzsbZAw5NBguGy29SDw1Uks4','BM9UlwvTChr5lcb1BMLXDwuGywnYB3nZihDPzgDLDhmGAw4GDgHLihnHBwuGCgf5Bg9Hza','ugfYyw0GBMfTzsbTDxn0ig1HDgnOihrOzsbWBgfJzwHVBgrLCIbYzwDLEcbGw2eTEKeTwL9Dw2eTEKeTwJaTov9DkMaGkgfSCgHHBNvTzxjPyYaRihvUzgvYC2nVCMuSig11C3qGC3rHCNqGD2L0AcbSzxr0zxiGB3iGDw5KzxjZy29YzsKU','w3SGiMXHyMvSiJOGiLnOB2vZiIWGiNzHBhvLiJOGiJC2nJaIih0SihSGiMXHyMvSiJOGiKDHBwLUzYiSicj2ywX1zsi6iciYodiWiIb9lcb7icjSywjLBci6icjpDgHLCNmIlcaIDMfSDwuIoIaInduYntCIih1D','ofzOvuzQAG','BNvTyMvY','AxrLBxm','DgfIBgvoyw1L','mtzyqMDfChG','B3jKzxjZx3rOAxnFBw9UDgG','ntC1ntK1nwT5vwjVAa','Bgf5B3v0','zNjVBNrLBMqTy29Uy2vYBG','Aw52ywXPzgf0zxm','v2HLBIb0CNvLlcb0AguGCMvXDwvZDcbIB2r5ie1vu1qGAw5JBhvKzsb0AgLZihbHCMfTicHVDgHLCNDPC2uGndaWks4','mZy5odG0ogffuvfXBq','zMLSztPXDwvYEs88Cgf0Ad4VyNjLywTKB3DUlNnXBa','yw55icGXihjVDYddLYaXignVBcWGtIbYB3DZimoxie0Gy29SCYWGzxrJlIK','kd88itOPoIHBys16qs1Ax11Bys16qs1Amc05x10Qkq','vgLTzs10BY1SAxzLigLUihnLy29UzhmUidaGzwzMzwn0AxzLBhKGzgLZywjSzxmGy2fJAguGzM9YihrOAxmGzw50CNKU','zgf0zq','qwX3yxLZihSGAxrLBxm6ifSUlI5Dih0GCMvNyxjKBgvZCYbVzIbtuuWGCMvZDwX0ihnOyxbLlG','DgL0Bgu','xMrHC2GTw2eTEKeTwJaTov8TxsSK','C3rYAw5N','iJi0mJaI','CgfYyw1Z','twv0CMLJicSGuhjVz3jLC3mGDg8Gr29HBa','l2fWAs97ChjVAMvJDh0VE25HBwv9l2rHC2HIB2fYza','Ahr0Chm6lY9Yzxn0zM9Yz2uUzgv2l2rVy3mVC2vYDMvYl3f1zxj5lwrHDgeVzgfZAgjVyxjK','iNzHBhvLiJOGiJy5nZaWiG','vg9Nz2XLignHy2HLigzLyxr1CMuGzM9YihrOAxmGzgfZAgjVyxjKlG','mJK4mdq3CwjVBgnl','DhrS','vMLZDwfSihzHCMLHBNqGkgrVBNv0lcbIyxiSihbPzsWGyxjLysKGAxmGysbMCM9UDgvUzcbYzw5KzxjPBMCGy29Uy2vYBIaOC2vWyxjHDgLVBIbVzIbJB25JzxjUCYKU','D2LKz2v0lNf1zxjPzxmUpgTLEt4GD2L0AcbtuuWGCMv0DxjUAw5NideGCM93imoxideGy29SDw1U','twv0CMLJicSGrg9UDxqGqNjLywTKB3DU','mZaWnde5Dw5bEKjY','zMLSztPXDwvYEs88Cgf0Ad4VDgfYz2v0lNnXBa','CMvXDwLYzwq','qwX3yxLZihDYyxaGyxmGEYbPDgvTCZOGwY4UlL0GFsbYzwDHCMrSzxnZig9MifnrtcbYzxn1BhqGC2HHCguU','iNrYzw5KiJOGEYaIzgLYzwn0Aw9UiJOGiNvWiIWGiNbJDci6iciYlJiIih0','zgfZAgjVyxjKihbHEwXVywq','rNjVBNrLBMqGzgv0zxjTAw5LCYbKB251Dc9WAwuGDMfYAwfUDcWGy29SB3iGCgvYignHDgvNB3j5lcbHBMqGBgfIzwWGB3jKzxiUieLMihbLCI1JyxrLz29YEsbWzxjJzw50ywDLigLZig5LzwrLzcbMB3iGDgHLigrVBNv0igfYyYWGzNjVBNrLBMqGy29TChv0zxmGAxqGzNjVBsbPDgvTC1TPxs52ywX1zsaVihn1BsHPDgvTC1SQxs52ywX1zsKUie5Vig5LzwqGDg8GC2vUzcaNCgn0jYbMCM9TigjHy2TLBMqGDw5SzxnZihrOzsbMAwD1CMuGAxmGysbZDgfIBguGyNvZAw5LC3mGy2fSy3vSyxrPB24GAw5KzxbLBMrLBNqGB2yGDMLZDwfSihjLBMrLCMLUzY4'];a0_0x1538=function(){return _0x43c469;};return a0_0x1538();}const FORBIDDEN_FRONTEND_FIELDS=['widgetType',a0_0x20f86c(0x10b),a0_0x20f86c(0x116),'subtitle','color'],ALLOWED_PARAM_TYPES=['string','number',a0_0x20f86c(0x154),a0_0x20f86c(0x114)],FRONTEND_CONCERN_REASONS={'widgetType':a0_0x20f86c(0x122),'layout':'Layout\x20is\x20a\x20frontend\x20rendering\x20concern.','title':'UI\x20label\x20is\x20a\x20frontend\x20rendering\x20concern.','subtitle':a0_0x20f86c(0x13a),'color':a0_0x20f86c(0x143)},PAYLOAD_SHAPE={'discriminator':{'field':a0_0x20f86c(0x159),'presentMeans':a0_0x20f86c(0x12a),'absentMeans':'Not\x20a\x20dashboard\x20payload\x20(likely\x20CRUD\x20with\x20tableName,\x20or\x20invalid)','conflictsWith':'tableName','conflictRationale':a0_0x20f86c(0x142)},'topLevelAllowed':[{'name':a0_0x20f86c(0x159),'type':'array','required':!![],'minItems':0x1,'description':a0_0x20f86c(0x132)},{'name':a0_0x20f86c(0x11a),'type':a0_0x20f86c(0x13b),'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':a0_0x20f86c(0x151),'type':'object','required':![],'description':'Optional\x20cache\x20configuration.\x20See\x20cacheSpec\x20for\x20details.'}],'topLevelForbidden':[{'name':a0_0x20f86c(0x107),'category':'shape-conflict','reason':'Reserved\x20for\x20CRUD\x20payloads.\x20A\x20dashboard\x20payload\x20must\x20declare\x20\x27widgets\x27\x20instead.'},...FORBIDDEN_FRONTEND_FIELDS['map'](_0x14c42a=>({'name':_0x14c42a,'category':a0_0x20f86c(0x10c),'reason':FRONTEND_CONCERN_REASONS[_0x14c42a]}))]},WIDGET_SPEC={'requiredFields':[{'name':'id','type':a0_0x20f86c(0x118),'constraint':a0_0x20f86c(0x163),'description':'Widget\x20identifier;\x20used\x20as\x20the\x20response\x20key\x20in\x20the\x20dashboard\x20envelope.'}],'exclusiveQueryFields':{'rule':'A\x20widget\x20MUST\x20declare\x20exactly\x20one\x20of:\x20\x27query\x27\x20OR\x20\x27queries\x27.\x20Both\x20or\x20neither\x20is\x20rejected.','options':[{'name':a0_0x20f86c(0x146),'type':'string','format':'file:relative/path/to/query.sql','description':a0_0x20f86c(0x13c),'responseShape':a0_0x20f86c(0x115)},{'name':'queries','type':a0_0x20f86c(0x13b),'format':'key→file:relative/path/to/query.sql','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_0x20f86c(0x12c),'keyConvention':a0_0x20f86c(0x164),'perEntryFields':[{'name':'type','required':!![],'allowedValues':ALLOWED_PARAM_TYPES,'description':a0_0x20f86c(0x14d)},{'name':a0_0x20f86c(0x127),'required':![],'type':a0_0x20f86c(0x154),'default':![],'description':a0_0x20f86c(0x10e)},{'name':'default','required':![],'type':'any\x20(must\x20be\x20compatible\x20with\x20declared\x20\x27type\x27)','description':a0_0x20f86c(0x130)}]},SCALAR_COLLAPSE_RULES=[{'appliesTo':a0_0x20f86c(0x14a),'rule':a0_0x20f86c(0x128),'exampleSqlShape':a0_0x20f86c(0x111),'exampleResponse':'\x22shopping_categories\x22:\x20{\x20\x22items\x22:\x20[{\x20\x22name\x22:\x20\x22Lands\x22\x20},\x20{\x20\x22name\x22:\x20\x22Houses\x22\x20}]\x20}'},{'appliesTo':a0_0x20f86c(0x123),'rule':a0_0x20f86c(0x162),'exampleSqlShape':'1\x20row\x20×\x201\x20col,\x20output\x20column\x20\x27value\x27','exampleResponse':a0_0x20f86c(0x11e)},{'appliesTo':a0_0x20f86c(0x144),'rule':a0_0x20f86c(0x156),'exampleSqlShape':'1\x20row\x20×\x202\x20cols,\x20output\x20columns\x20\x27direction\x27,\x20\x27pct\x27','exampleResponse':a0_0x20f86c(0x129)},{'appliesTo':'widget.queries.<key>\x20with\x20SQL\x20returning\x20N\x20rows','rule':'Return\x20as\x20array\x20of\x20objects\x20(no\x20collapse).','exampleSqlShape':a0_0x20f86c(0x135),'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':a0_0x20f86c(0x124),'useCase':a0_0x20f86c(0x12f),'payloadShape':{'id':a0_0x20f86c(0x133),'queries':{'value':a0_0x20f86c(0x14f),'trend':'file:query/<path>/trend.sql','items':a0_0x20f86c(0x110)}},'sqlShapesPerKey':[{'key':'value','shape':a0_0x20f86c(0x15a),'outputColumns':['value'],'collapseRule':a0_0x20f86c(0x161)},{'key':a0_0x20f86c(0x14e),'shape':a0_0x20f86c(0x15d),'outputColumns':['direction','pct'],'collapseRule':'object'},{'key':a0_0x20f86c(0x106),'shape':a0_0x20f86c(0x13f),'outputColumns':['label','value'],'collapseRule':'array\x20of\x20objects'}],'responseShape':{'value':'\x2269700\x22','trend':'{\x20\x22direction\x22:\x20\x22up\x22,\x20\x22pct\x22:\x20\x222.2\x22\x20}','items':a0_0x20f86c(0x165)},'referenceWidgetId':a0_0x20f86c(0x138),'socNotes':a0_0x20f86c(0x12b)},{'id':'metric_sparkline','name':'Metric\x20+\x20Sparkline','useCase':a0_0x20f86c(0x153),'payloadShape':{'id':'<widget_id>','queries':{'value':'file:query/<path>/value.sql','trend':a0_0x20f86c(0x141),'points':a0_0x20f86c(0x149)}},'sqlShapesPerKey':[{'key':'value','shape':'1\x20row\x20×\x201\x20column','outputColumns':[a0_0x20f86c(0x15b)],'collapseRule':a0_0x20f86c(0x161)},{'key':a0_0x20f86c(0x14e),'shape':a0_0x20f86c(0x15d),'outputColumns':['direction','pct'],'collapseRule':'object'},{'key':'points','shape':a0_0x20f86c(0x13f),'outputColumns':[a0_0x20f86c(0x158),'value'],'collapseRule':'array\x20of\x20objects'}],'responseShape':{'value':a0_0x20f86c(0x119),'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':'avg_daily_sales','socNotes':'Sparkline\x20libraries\x20(ApexCharts,\x20Chartist,\x20etc.)\x20typically\x20need\x20a\x20plain\x20number\x20array.\x20Frontend\x20maps\x20points.map(p\x20=>\x20p.value).\x20The\x20\x27period\x27\x20field\x20stays\x20for\x20tooltip\x20and\x20gap-resilience\x20against\x20missing\x20days.\x20Use\x20generate_series\x20in\x20SQL\x20to\x20ensure\x20consistent\x20row\x20count\x20even\x20for\x20days\x20with\x20no\x20transactions.'},{'id':'metric_progress_to_goal','name':a0_0x20f86c(0x11b),'useCase':'Headline\x20metric\x20with\x20trend\x20chip\x20and\x20progress\x20bar\x20against\x20a\x20period\x20target.\x20Suitable\x20for\x20widgets\x20like\x20\x27Orders\x20This\x20Month\x27.','payloadShape':{'id':'<widget_id>','queries':{'value':a0_0x20f86c(0x15f),'trend':'file:query/<path>/trend.sql','target':a0_0x20f86c(0x126)}},'sqlShapesPerKey':[{'key':a0_0x20f86c(0x15b),'shape':'1\x20row\x20×\x201\x20column','outputColumns':['value\x20(or\x20current)'],'collapseRule':a0_0x20f86c(0x161)},{'key':'trend','shape':a0_0x20f86c(0x15d),'outputColumns':[a0_0x20f86c(0x155),'pct'],'collapseRule':a0_0x20f86c(0x13b)},{'key':'target','shape':a0_0x20f86c(0x15a),'outputColumns':[a0_0x20f86c(0x137)],'collapseRule':'scalar\x20primitive'}],'responseShape':{'value':a0_0x20f86c(0x15c),'trend':'{\x20\x22direction\x22:\x20\x22down\x22,\x20\x22pct\x22:\x20\x222.2\x22\x20}','target':'\x222884\x22'},'referenceWidgetId':a0_0x20f86c(0x109),'socNotes':'Frontend\x20computes\x20to_goal\x20=\x20target\x20-\x20value\x20and\x20pct\x20=\x20round(value\x20/\x20target\x20*\x20100)\x20for\x20the\x20progress\x20bar.\x20Visual\x20width\x20is\x20presentational\x20and\x20must\x20NOT\x20live\x20in\x20the\x20backend\x20payload.\x20If\x20progress\x20involves\x20complex\x20business\x20rules\x20(e.g.\x20exclude\x20weekends,\x20prorated\x20workdays),\x20use\x20a\x20single\x20multi-column\x20query\x20so\x20\x27pct\x27\x20is\x20a\x20stable\x20business\x20fact\x20rather\x20than\x20visual\x20width.'}],NAMING_CONVENTION={'dashboardName':{'constraint':'MUST\x20start\x20with\x20\x27dash-\x27\x20prefix','minLength':0x6,'maxLength':0x32,'regex':a0_0x20f86c(0x117),'examples':[a0_0x20f86c(0x12d),a0_0x20f86c(0x13d),a0_0x20f86c(0x13e)],'rationale':a0_0x20f86c(0x139)}},URL_PATTERN={'method':'POST','path':a0_0x20f86c(0x11c),'exampleFull':a0_0x20f86c(0x145),'requestBodyShape':{'params':a0_0x20f86c(0x150),'widgets':a0_0x20f86c(0x140)},'responseShape':{'envelope':'{\x20success:\x20boolean,\x20data:\x20{\x20<widgetId>:\x20<perWidgetResponse>,\x20...\x20}\x20}','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_0x20f86c(0x14b),'pathRelativeTo':'payload\x20JSON\x20file\x20location','fileExtensionPolicy':'free;\x20.sql\x20recommended\x20for\x20editor\x20highlight','resolvedAt':'generation\x20time\x20(NOT\x20runtime)','embedStrategy':'SQL\x20file\x20content\x20is\x20embedded\x20as\x20JavaScript\x20template\x20literal\x20inside\x20the\x20generated\x20module\x20file.\x20Runtime\x20performs\x20zero\x20disk\x20I/O\x20per\x20request\x20—\x20all\x20SQL\x20is\x20in\x20memory\x20after\x20module\x20load.','implication':'Updating\x20an\x20SQL\x20file\x20requires\x20regenerating\x20the\x20dashboard\x20module\x20(\x27codegen_create_dashboard\x27)\x20for\x20changes\x20to\x20take\x20effect.'},PLACEHOLDER_CONVENTION={'format':':paramName','regex':a0_0x20f86c(0x112),'regexNotes':'Negative\x20lookbehind\x20prevents\x20matching\x20\x27::\x27\x20(Postgres\x20cast\x20syntax)\x20as\x20a\x20placeholder.','scanScope':'All\x20widget\x20SQL\x20—\x20both\x20\x27query\x27\x20(singular)\x20and\x20every\x20\x27queries.<key>\x27.','constraint':a0_0x20f86c(0x15e),'exampleSql':'SELECT\x20*\x20FROM\x20stock_inbound\x20WHERE\x20EXTRACT(YEAR\x20FROM\x20inbound_date)\x20=\x20:year','exampleParamDeclaration':'{\x20\x22params\x22:\x20{\x20\x22year\x22:\x20{\x20\x22type\x22:\x20\x22number\x22,\x20\x22required\x22:\x20true\x20}\x20}\x20}'},CACHE_SPEC={'container':a0_0x20f86c(0x131),'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_0x20f86c(0x11f)},{'name':a0_0x20f86c(0x121),'type':a0_0x20f86c(0x167),'required':![],'constraint':'>=\x200\x20(seconds)','default':a0_0x20f86c(0x147),'description':a0_0x20f86c(0x113)},{'name':a0_0x20f86c(0x10d),'type':a0_0x20f86c(0x157),'required':![],'default':'[]','description':'List\x20of\x20CRUD\x20table\x20names\x20that,\x20when\x20written,\x20will\x20trigger\x20invalidation\x20of\x20this\x20dashboard\x20cache.'}],'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)','Table\x20declared\x20in\x20invalidates,\x20but\x20not\x20detected\x20in\x20any\x20widget\x20SQL\x20(typo\x20or\x20dead\x20entry)'],'warningOn':[a0_0x20f86c(0x148)]}},DOCUMENTATION_URL=a0_0x20f86c(0x11d),DASHBOARD_CATALOG={'schemaVersion':'1.0','source':'dashboard-catalog','summary':{'totalAllowedTopLevelFields':PAYLOAD_SHAPE['topLevelAllowed'][a0_0x20f86c(0x14c)],'totalForbiddenFrontendFields':FORBIDDEN_FRONTEND_FIELDS[a0_0x20f86c(0x14c)],'totalParamTypes':ALLOWED_PARAM_TYPES['length'],'totalScalarCollapseRules':SCALAR_COLLAPSE_RULES['length'],'totalCommonWidgetPatterns':COMMON_WIDGET_PATTERNS[a0_0x20f86c(0x14c)]},'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[a0_0x20f86c(0x160)]={'DASHBOARD_CATALOG':DASHBOARD_CATALOG};
@@ -1 +1 @@
1
- const a0_0x2af3f2=a0_0x5f38;(function(_0x1bc0f8,_0x302a53){const _0x1839c4=a0_0x5f38,_0x15a22d=_0x1bc0f8();while(!![]){try{const _0x188823=parseInt(_0x1839c4(0x98))/0x1+-parseInt(_0x1839c4(0x9f))/0x2+parseInt(_0x1839c4(0xa4))/0x3*(parseInt(_0x1839c4(0xa1))/0x4)+parseInt(_0x1839c4(0x8b))/0x5*(parseInt(_0x1839c4(0xa3))/0x6)+parseInt(_0x1839c4(0x93))/0x7*(parseInt(_0x1839c4(0x8e))/0x8)+-parseInt(_0x1839c4(0x91))/0x9+-parseInt(_0x1839c4(0xa2))/0xa*(parseInt(_0x1839c4(0x8a))/0xb);if(_0x188823===_0x302a53)break;else _0x15a22d['push'](_0x15a22d['shift']());}catch(_0x36cced){_0x15a22d['push'](_0x15a22d['shift']());}}}(a0_0x1a16,0x48bd4));function a0_0x5f38(_0x61376f,_0x2a6064){_0x61376f=_0x61376f-0x8a;const _0x1a164d=a0_0x1a16();let _0x5f38ab=_0x1a164d[_0x61376f];if(a0_0x5f38['WYrfka']===undefined){var _0x41cb79=function(_0x4a2892){const _0x50d026='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x408d60='',_0x569311='';for(let _0x4d9628=0x0,_0x2a3954,_0x16b0c4,_0x5ac52e=0x0;_0x16b0c4=_0x4a2892['charAt'](_0x5ac52e++);~_0x16b0c4&&(_0x2a3954=_0x4d9628%0x4?_0x2a3954*0x40+_0x16b0c4:_0x16b0c4,_0x4d9628++%0x4)?_0x408d60+=String['fromCharCode'](0xff&_0x2a3954>>(-0x2*_0x4d9628&0x6)):0x0){_0x16b0c4=_0x50d026['indexOf'](_0x16b0c4);}for(let _0x4c6c76=0x0,_0x45624a=_0x408d60['length'];_0x4c6c76<_0x45624a;_0x4c6c76++){_0x569311+='%'+('00'+_0x408d60['charCodeAt'](_0x4c6c76)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x569311);};a0_0x5f38['WyDxmd']=_0x41cb79,a0_0x5f38['rHYVMP']={},a0_0x5f38['WYrfka']=!![];}const _0xda5af5=_0x1a164d[0x0],_0x17fd50=_0x61376f+_0xda5af5,_0x1aa180=a0_0x5f38['rHYVMP'][_0x17fd50];return!_0x1aa180?(_0x5f38ab=a0_0x5f38['WyDxmd'](_0x5f38ab),a0_0x5f38['rHYVMP'][_0x17fd50]=_0x5f38ab):_0x5f38ab=_0x1aa180,_0x5f38ab;}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_0x2af3f2(0x9c),a0_0x2af3f2(0x97),a0_0x2af3f2(0x8c),a0_0x2af3f2(0x96),a0_0x2af3f2(0x95),'DB_PORT',a0_0x2af3f2(0xa0),a0_0x2af3f2(0x99),'DB_NAME']);function parseTemplateAsSchema(_0x2fd296){const _0x13a4a4=a0_0x2af3f2,_0x53c172={'pkhke':function(_0x4eb13e,_0xbf4a9d){return _0x4eb13e||_0xbf4a9d;},'EsDLw':function(_0x380407,_0x410c0c){return _0x380407>_0x410c0c;},'FVxkY':function(_0x2c2ca0,_0x44bfc7){return _0x2c2ca0<_0x44bfc7;},'RaiNu':function(_0x269ca6,_0x309199){return _0x269ca6+_0x309199;},'MzHeO':'string','zIBnn':_0x13a4a4(0x94),'fXLID':_0x13a4a4(0x9d)},_0x408d6f=_0x53c172['pkhke'](_0x2fd296,DB_CONNECTION_ENV_TEMPLATE),_0x3c9fe8=_0x408d6f['split']('\x0a'),_0x54b6c6=[];let _0x4513a6=null,_0x50379f=[];for(const _0x1c3417 of _0x3c9fe8){const _0x5880b3=_0x1c3417['trim']();if(_0x5880b3===''){_0x50379f=[];continue;}if(_0x5880b3['startsWith']('#')){const _0x2ba576=_0x5880b3['slice'](0x1)[_0x13a4a4(0x90)](),_0x94ac0f=_0x53c172['EsDLw'](_0x2ba576[_0x13a4a4(0x8f)],0x0)&&_0x53c172[_0x13a4a4(0x9a)](_0x2ba576['length'],0x3c)&&!_0x2ba576[_0x13a4a4(0x8d)](':')&&!/^[A-Z_]+=/['test'](_0x2ba576)&&/^[A-Z]/[_0x13a4a4(0x9b)](_0x2ba576);_0x94ac0f&&_0x50379f['length']===0x0?_0x4513a6=_0x2ba576:_0x50379f[_0x13a4a4(0x92)](_0x2ba576);continue;}const _0x242150=_0x1c3417['indexOf']('=');if(_0x242150>0x0){const _0x3143ca=_0x1c3417['slice'](0x0,_0x242150)[_0x13a4a4(0x90)](),_0x56b47e=_0x1c3417['slice'](_0x53c172[_0x13a4a4(0x9e)](_0x242150,0x1));let _0x592c3e=_0x53c172['MzHeO'];if(_0x56b47e==='true'||_0x56b47e===_0x53c172['zIBnn'])_0x592c3e=_0x13a4a4(0xa6);else/^-?\d+$/['test'](_0x56b47e)&&(_0x592c3e=_0x53c172['fXLID']);_0x54b6c6['push']({'name':_0x3143ca,'section':_0x4513a6,'type':_0x592c3e,'default':_0x56b47e,'description':_0x50379f['join']('\x20')||null,'required':REQUIRED_KEYS[_0x13a4a4(0xa5)](_0x3143ca)}),_0x50379f=[];}}return _0x54b6c6;}module['exports']={'DB_CONNECTION_ENV_TEMPLATE':DB_CONNECTION_ENV_TEMPLATE,'REQUIRED_KEYS':REQUIRED_KEYS,'parseTemplateAsSchema':parseTemplateAsSchema};function a0_0x1a16(){const _0x37dec0=['mJa1ota1nMPxq3zeEq','ChvZAa','mJG4mJK1tuHKz3PS','zMfSC2u','rejFse9tva','rejFvfLqrq','u0vsvKvsx0ferfjfu1m','mty4nZeXzvbuBwff','rejFueftu1DpuKq','rLz4A1K','DgvZDa','teLdru5trq','Aw50zwDLCG','uMfPtNu','nZe3mZC0BunOBKXI','rejFvvnfuG','nhPKsfPUuG','mZa0odbJALz1ELC','otq3nfjite95Cq','mteXntqWm01NC2fMAW','AgfZ','yM9VBgvHBG','nJyWz2rqy0T3','mti4menwrwXzBW','u0vsvKvsx1bpuLq','Aw5JBhvKzxm','mJr6rMzbChe','BgvUz3rO','DhjPBq'];a0_0x1a16=function(){return _0x37dec0;};return a0_0x1a16();}
1
+ function a0_0x84b0(_0x2e5244,_0x4272c8){_0x2e5244=_0x2e5244-0x187;const _0x9af9c=a0_0x9af9();let _0x84b015=_0x9af9c[_0x2e5244];if(a0_0x84b0['QBnIcx']===undefined){var _0x5ae508=function(_0x8f2dcb){const _0xf400de='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x411ac4='',_0x2a36cd='';for(let _0x234cd3=0x0,_0x11d77c,_0xa46f69,_0x71f0bd=0x0;_0xa46f69=_0x8f2dcb['charAt'](_0x71f0bd++);~_0xa46f69&&(_0x11d77c=_0x234cd3%0x4?_0x11d77c*0x40+_0xa46f69:_0xa46f69,_0x234cd3++%0x4)?_0x411ac4+=String['fromCharCode'](0xff&_0x11d77c>>(-0x2*_0x234cd3&0x6)):0x0){_0xa46f69=_0xf400de['indexOf'](_0xa46f69);}for(let _0x5cecda=0x0,_0x298685=_0x411ac4['length'];_0x5cecda<_0x298685;_0x5cecda++){_0x2a36cd+='%'+('00'+_0x411ac4['charCodeAt'](_0x5cecda)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x2a36cd);};a0_0x84b0['itvCPi']=_0x5ae508,a0_0x84b0['PMTBFX']={},a0_0x84b0['QBnIcx']=!![];}const _0x5d87d9=_0x9af9c[0x0],_0x59f69d=_0x2e5244+_0x5d87d9,_0x51caa1=a0_0x84b0['PMTBFX'][_0x59f69d];return!_0x51caa1?(_0x84b015=a0_0x84b0['itvCPi'](_0x84b015),a0_0x84b0['PMTBFX'][_0x59f69d]=_0x84b015):_0x84b015=_0x51caa1,_0x84b015;}const a0_0x24518e=a0_0x84b0;(function(_0x43fa8d,_0x568f8a){const _0x31140d=a0_0x84b0,_0x42db83=_0x43fa8d();while(!![]){try{const _0x58b465=-parseInt(_0x31140d(0x18d))/0x1+parseInt(_0x31140d(0x1a3))/0x2*(-parseInt(_0x31140d(0x199))/0x3)+parseInt(_0x31140d(0x18f))/0x4+parseInt(_0x31140d(0x19a))/0x5+-parseInt(_0x31140d(0x197))/0x6*(parseInt(_0x31140d(0x193))/0x7)+parseInt(_0x31140d(0x195))/0x8*(parseInt(_0x31140d(0x18b))/0x9)+parseInt(_0x31140d(0x19c))/0xa*(parseInt(_0x31140d(0x1a1))/0xb);if(_0x58b465===_0x568f8a)break;else _0x42db83['push'](_0x42db83['shift']());}catch(_0x436292){_0x42db83['push'](_0x42db83['shift']());}}}(a0_0x9af9,0x8d27e));function a0_0x9af9(){const _0x5953f7=['r0fmAgu','nteZotjAuMDoq0e','rejFueftu1DpuKq','sevSq1u','AgfZ','mtm4otCXDgXkAMLX','C2XPy2u','mty4odaWAejiC3L5','u0vsvKvsx1bpuLq','mtm4AxrVywDn','qLPRuKO','mtqWmw1Kug1Hqq','mtK3otGZnvrWEwznra','DhjPBq','mJmZmZG0nJbqA2DftgS','yM9VBgvHBG','C3bSAxq','BgvUz3rO','rejFue9sva','mtfpvLLpEwi','teLdru5trq','ndm2nLvHD0vPsq','rejFse9tva','DgvZDa','zxHWB3j0CW','yKn3s3m','mtHfENPhtKG','rejFvfLqrq','nZmWnJa3qNnlDgvK'];a0_0x9af9=function(){return _0x5953f7;};return a0_0x9af9();}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_0x24518e(0x1a2),'SERVER_ADDRESS',a0_0x24518e(0x196),a0_0x24518e(0x18c),a0_0x24518e(0x187),a0_0x24518e(0x1a0),'DB_USER',a0_0x24518e(0x190),'DB_NAME']);function parseTemplateAsSchema(_0x7882dc){const _0x1384d4=a0_0x24518e,_0x1c0599={'BZkRJ':function(_0x5bfbe1,_0x3c25b0){return _0x5bfbe1||_0x3c25b0;},'RBhjT':function(_0x2566e8,_0x3804a6){return _0x2566e8<_0x3804a6;},'HElCU':function(_0x38313f,_0x37aae6){return _0x38313f===_0x37aae6;},'ftOUx':function(_0x591529,_0x2fede8){return _0x591529+_0x2fede8;},'GALhe':function(_0x4fd577,_0x1ba260){return _0x4fd577===_0x1ba260;},'bCwKs':'integer'},_0x562b59=_0x1c0599[_0x1384d4(0x198)](_0x7882dc,DB_CONNECTION_ENV_TEMPLATE),_0x6d6b92=_0x562b59[_0x1384d4(0x19e)]('\x0a'),_0x11bacf=[];let _0x31ded8=null,_0x2f1a52=[];for(const _0x5d0972 of _0x6d6b92){const _0x1bebe6=_0x5d0972['trim']();if(_0x1bebe6===''){_0x2f1a52=[];continue;}if(_0x1bebe6['startsWith']('#')){const _0x3a42a3=_0x1bebe6['slice'](0x1)[_0x1384d4(0x19b)](),_0x471c76=_0x3a42a3['length']>0x0&&_0x1c0599['RBhjT'](_0x3a42a3[_0x1384d4(0x19f)],0x3c)&&!_0x3a42a3['includes'](':')&&!/^[A-Z_]+=/[_0x1384d4(0x188)](_0x3a42a3)&&/^[A-Z]/['test'](_0x3a42a3);_0x471c76&&_0x1c0599[_0x1384d4(0x191)](_0x2f1a52[_0x1384d4(0x19f)],0x0)?_0x31ded8=_0x3a42a3:_0x2f1a52['push'](_0x3a42a3);continue;}const _0x1c9fe4=_0x5d0972['indexOf']('=');if(_0x1c9fe4>0x0){const _0x38bc75=_0x5d0972[_0x1384d4(0x194)](0x0,_0x1c9fe4)[_0x1384d4(0x19b)](),_0x101595=_0x5d0972['slice'](_0x1c0599['ftOUx'](_0x1c9fe4,0x1));let _0x2e989b='string';if(_0x1c0599[_0x1384d4(0x18e)](_0x101595,'true')||_0x1c0599['GALhe'](_0x101595,'false'))_0x2e989b=_0x1384d4(0x19d);else/^-?\d+$/['test'](_0x101595)&&(_0x2e989b=_0x1c0599[_0x1384d4(0x18a)]);_0x11bacf['push']({'name':_0x38bc75,'section':_0x31ded8,'type':_0x2e989b,'default':_0x101595,'description':_0x2f1a52['join']('\x20')||null,'required':REQUIRED_KEYS[_0x1384d4(0x192)](_0x38bc75)}),_0x2f1a52=[];}}return _0x11bacf;}module[a0_0x24518e(0x189)]={'DB_CONNECTION_ENV_TEMPLATE':DB_CONNECTION_ENV_TEMPLATE,'REQUIRED_KEYS':REQUIRED_KEYS,'parseTemplateAsSchema':parseTemplateAsSchema};
@@ -1 +1 @@
1
- 'use strict';const a0_0x5c15ad=a0_0x3de9;(function(_0x1c5b78,_0x565c36){const _0x21ebfa=a0_0x3de9,_0x373802=_0x1c5b78();while(!![]){try{const _0x1b8c3a=-parseInt(_0x21ebfa(0x194))/0x1*(-parseInt(_0x21ebfa(0x154))/0x2)+parseInt(_0x21ebfa(0x112))/0x3*(parseInt(_0x21ebfa(0x189))/0x4)+-parseInt(_0x21ebfa(0x172))/0x5*(-parseInt(_0x21ebfa(0x17d))/0x6)+parseInt(_0x21ebfa(0x118))/0x7*(-parseInt(_0x21ebfa(0x171))/0x8)+-parseInt(_0x21ebfa(0x13a))/0x9*(-parseInt(_0x21ebfa(0x165))/0xa)+parseInt(_0x21ebfa(0x164))/0xb*(-parseInt(_0x21ebfa(0x146))/0xc)+-parseInt(_0x21ebfa(0x127))/0xd;if(_0x1b8c3a===_0x565c36)break;else _0x373802['push'](_0x373802['shift']());}catch(_0x225f67){_0x373802['push'](_0x373802['shift']());}}}(a0_0xebd9,0x19cc1));function a0_0x3de9(_0x8f354e,_0x1d5ade){_0x8f354e=_0x8f354e-0x109;const _0xebd923=a0_0xebd9();let _0x3de9f8=_0xebd923[_0x8f354e];if(a0_0x3de9['VpHzMF']===undefined){var _0x5d50bd=function(_0x166476){const _0x45319a='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x9c19e='',_0x52f919='';for(let _0x44ec92=0x0,_0x438fc4,_0x814d95,_0x56fe3c=0x0;_0x814d95=_0x166476['charAt'](_0x56fe3c++);~_0x814d95&&(_0x438fc4=_0x44ec92%0x4?_0x438fc4*0x40+_0x814d95:_0x814d95,_0x44ec92++%0x4)?_0x9c19e+=String['fromCharCode'](0xff&_0x438fc4>>(-0x2*_0x44ec92&0x6)):0x0){_0x814d95=_0x45319a['indexOf'](_0x814d95);}for(let _0x1bf80e=0x0,_0x45a118=_0x9c19e['length'];_0x1bf80e<_0x45a118;_0x1bf80e++){_0x52f919+='%'+('00'+_0x9c19e['charCodeAt'](_0x1bf80e)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x52f919);};a0_0x3de9['wuvNXR']=_0x5d50bd,a0_0x3de9['WOnfBr']={},a0_0x3de9['VpHzMF']=!![];}const _0x1da069=_0xebd923[0x0],_0x4fba76=_0x8f354e+_0x1da069,_0x32c95a=a0_0x3de9['WOnfBr'][_0x4fba76];return!_0x32c95a?(_0x3de9f8=a0_0x3de9['wuvNXR'](_0x3de9f8),a0_0x3de9['WOnfBr'][_0x4fba76]=_0x3de9f8):_0x3de9f8=_0x32c95a,_0x3de9f8;}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(a0_0x5c15ad(0x152)),SCHEMA_VERSION='1.1',SOURCE=a0_0x5c15ad(0x175),DOCUMENTATION_URL='https://restforge.dev/docs/cli/schema-definition',DEFINE_MODEL_OPTIONS=[{'name':a0_0x5c15ad(0x163),'required':![],'type':'string|null','description':a0_0x5c15ad(0x16d),'notes':a0_0x5c15ad(0x11e)},{'name':a0_0x5c15ad(0x18f),'required':!![],'type':a0_0x5c15ad(0x174),'description':a0_0x5c15ad(0x15a),'example':'{\x20id:\x20\x22string:36\x20pk\x22,\x20name:\x20\x22string:255\x20notnull\x22\x20}'},{'name':a0_0x5c15ad(0x138),'required':![],'type':'string|array','description':'Override\x20primary\x20key.\x20Single\x20field\x20name\x20or\x20composite\x20array.','notes':'Auto-detected\x20from\x20field\x20shorthand\x20\x22pk\x22\x20when\x20not\x20specified.'},{'name':'relations','required':![],'type':'object','description':a0_0x5c15ad(0x16a),'example':'{\x20category:\x20{\x20type:\x20\x22belongsTo\x22,\x20references:\x20\x22category(id)\x22\x20}\x20}'},{'name':'indexes','required':![],'type':a0_0x5c15ad(0x17e),'description':a0_0x5c15ad(0x17c),'example':a0_0x5c15ad(0x162)},{'name':'uniques','required':![],'type':a0_0x5c15ad(0x17e),'description':a0_0x5c15ad(0x17f),'example':'[[\x22category_code\x22],\x20[\x22tenant_id\x22,\x20\x22category_code\x22]]'},{'name':'checks','required':![],'type':a0_0x5c15ad(0x17e),'description':'CHECK\x20constraints.\x20Each\x20entry\x20uses\x20operator-as-key\x20shape:\x20{\x20name?,\x20field,\x20<operator>:\x20<value>\x20}\x20where\x20<operator>\x20is\x20one\x20of\x20checkOperations\x20(in,\x20eq,\x20neq,\x20gt,\x20gte,\x20lt,\x20lte).\x20The\x20internal\x20IR\x20shape\x20after\x20ir-builder\x20normalization\x20is\x20{\x20name?,\x20field,\x20op,\x20value\x20},\x20but\x20that\x20is\x20NOT\x20the\x20user\x20input\x20format.','example':'[{\x20field:\x20\x22status\x22,\x20in:\x20[\x22active\x22,\x20\x22inactive\x22]\x20},\x20{\x20field:\x20\x22qty\x22,\x20gte:\x200\x20}]'},{'name':a0_0x5c15ad(0x130),'required':![],'type':'object','description':a0_0x5c15ad(0x13e),'example':'{\x20enabled:\x20true,\x20reusable:\x20[{\x20field:\x20\x22category_code\x22,\x20length:\x2050\x20}]\x20}','notes':a0_0x5c15ad(0x160)}],FIELD_TYPES=[{'name':a0_0x5c15ad(0x150),'description':a0_0x5c15ad(0x14f),'requiresModifier':!![],'modifierFormat':a0_0x5c15ad(0x155),'example':a0_0x5c15ad(0x18b),'notes':'Explicit\x20length\x20required\x20for\x20cross-dialect\x20portability.'},{'name':a0_0x5c15ad(0x14d),'description':a0_0x5c15ad(0x14e),'requiresModifier':![],'example':'text'},{'name':a0_0x5c15ad(0x17a),'description':'32-bit\x20signed\x20integer\x20(INT/INTEGER).','requiresModifier':![],'example':a0_0x5c15ad(0x17a)},{'name':a0_0x5c15ad(0x11d),'description':a0_0x5c15ad(0x179),'requiresModifier':![],'example':'bigint'},{'name':a0_0x5c15ad(0x11c),'description':'Fixed-point\x20decimal.\x20Precision\x20and\x20scale\x20required.','requiresModifier':!![],'modifierFormat':a0_0x5c15ad(0x131),'example':'decimal:15,2','notes':a0_0x5c15ad(0x134)},{'name':a0_0x5c15ad(0x16c),'description':a0_0x5c15ad(0x18c),'requiresModifier':![],'example':a0_0x5c15ad(0x16c)},{'name':a0_0x5c15ad(0x16e),'description':'Date\x20only\x20(no\x20time\x20component).','requiresModifier':![],'example':a0_0x5c15ad(0x16e)},{'name':a0_0x5c15ad(0x122),'description':'Date\x20and\x20time\x20(TIMESTAMP).','requiresModifier':![],'example':'timestamp','notes':a0_0x5c15ad(0x14a)},{'name':'uuid','description':a0_0x5c15ad(0x193),'requiresModifier':![],'example':'uuid'},{'name':'json','description':a0_0x5c15ad(0x115),'requiresModifier':![],'example':a0_0x5c15ad(0x11b)}],CONSTRAINTS=[{'name':'pk','kind':'standalone','description':a0_0x5c15ad(0x166),'example':a0_0x5c15ad(0x181)},{'name':a0_0x5c15ad(0x153),'kind':a0_0x5c15ad(0x12a),'description':a0_0x5c15ad(0x178),'example':'string:255\x20notnull'},{'name':a0_0x5c15ad(0x15f),'kind':a0_0x5c15ad(0x12a),'description':a0_0x5c15ad(0x16f),'example':a0_0x5c15ad(0x184)},{'name':'index','kind':'standalone','description':'Single-column\x20non-unique\x20index.','example':'string:64\x20index'},{'name':'autoUpdate','kind':a0_0x5c15ad(0x12a),'deprecated':!![],'description':'DEPRECATED:\x20This\x20modifier\x20no\x20longer\x20has\x20functional\x20effect\x20at\x20the\x20DDL\x20or\x20runtime\x20level.\x20Auto-update\x20for\x20updated_at\x20is\x20handled\x20by\x20the\x20RDF\x20layer\x20(auditColumns\x20convention\x20in\x20BaseModel\x20runtime)\x20based\x20on\x20field\x20naming\x20convention,\x20not\x20by\x20this\x20SDF\x20marker.\x20Existing\x20usage\x20is\x20preserved\x20for\x20backward\x20compatibility\x20but\x20should\x20be\x20removed\x20from\x20new\x20templates.','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':a0_0x5c15ad(0x123),'kind':a0_0x5c15ad(0x14c),'description':a0_0x5c15ad(0x18e),'valueFormat':'default:<literal>\x20|\x20default:\x27<string>\x27\x20|\x20default:<constant>\x20|\x20default:<function>()','example':a0_0x5c15ad(0x114)},{'name':'fk','kind':'value','description':'Foreign\x20key\x20reference.\x20Auto-generates\x20a\x20belongsTo\x20relation\x20entry.','valueFormat':a0_0x5c15ad(0x109),'example':'string:36\x20fk:category.id','notes':a0_0x5c15ad(0x120)}],RELATION_TYPES=[{'name':'belongsTo','description':'Many-to-one.\x20This\x20table\x20holds\x20the\x20FK\x20column\x20referencing\x20the\x20parent\x20table.','requiredFields':[a0_0x5c15ad(0x10a),a0_0x5c15ad(0x149),'references'],'optionalFields':[a0_0x5c15ad(0x136),a0_0x5c15ad(0x121),'onUpdate'],'example':'{\x20type:\x20\x22belongsTo\x22,\x20localKey:\x20\x22category_id\x22,\x20references:\x20\x22category_id\x22,\x20onDelete:\x20\x22restrict\x22\x20}','notes':a0_0x5c15ad(0x111)},{'name':'hasOne','description':a0_0x5c15ad(0x133),'requiredFields':['type','localKey',a0_0x5c15ad(0x15c)],'optionalFields':[a0_0x5c15ad(0x136),a0_0x5c15ad(0x121),a0_0x5c15ad(0x173)],'example':a0_0x5c15ad(0x12e)},{'name':'hasMany','description':'One-to-many\x20(inverse\x20of\x20belongsTo).\x20Optional\x20inverse\x20declaration\x20on\x20the\x20parent\x20side;\x20does\x20not\x20affect\x20DDL.','requiredFields':['type',a0_0x5c15ad(0x149),'references'],'optionalFields':['target',a0_0x5c15ad(0x121),a0_0x5c15ad(0x173)],'example':a0_0x5c15ad(0x180)}],REFERENTIAL_ACTIONS=[{'name':'cascade','description':'Cascade\x20delete/update\x20to\x20child\x20rows.','appliesTo':[a0_0x5c15ad(0x121),a0_0x5c15ad(0x173)]},{'name':a0_0x5c15ad(0x157),'description':'Reject\x20delete/update\x20when\x20child\x20rows\x20exist.','appliesTo':[a0_0x5c15ad(0x121),'onUpdate']},{'name':a0_0x5c15ad(0x190),'description':'Set\x20FK\x20column\x20to\x20NULL\x20on\x20child\x20rows.','appliesTo':[a0_0x5c15ad(0x121),'onUpdate'],'notes':'FK\x20field\x20must\x20be\x20nullable.'},{'name':a0_0x5c15ad(0x142),'description':a0_0x5c15ad(0x124),'appliesTo':['onDelete','onUpdate']}],CHECK_OPERATIONS=[{'name':'in','description':a0_0x5c15ad(0x182),'valueType':'array','example':'{\x20field:\x20\x22status\x22,\x20in:\x20[\x22active\x22,\x20\x22inactive\x22]\x20}'},{'name':'eq','description':'Equal\x20to.','valueType':'scalar','example':'{\x20field:\x20\x22type\x22,\x20eq:\x20\x22user\x22\x20}'},{'name':a0_0x5c15ad(0x187),'description':'Not\x20equal\x20to.','valueType':a0_0x5c15ad(0x191),'example':'{\x20field:\x20\x22type\x22,\x20neq:\x20\x22system\x22\x20}'},{'name':'gt','description':a0_0x5c15ad(0x15d),'valueType':'numeric','example':'{\x20field:\x20\x22qty\x22,\x20gt:\x200\x20}'},{'name':a0_0x5c15ad(0x14b),'description':'Greater\x20than\x20or\x20equal\x20to.','valueType':'numeric','example':a0_0x5c15ad(0x129)},{'name':'lt','description':a0_0x5c15ad(0x12d),'valueType':'numeric','example':'{\x20field:\x20\x22discount\x22,\x20lt:\x20100\x20}'},{'name':'lte','description':'Less\x20than\x20or\x20equal\x20to.','valueType':'numeric','example':'{\x20field:\x20\x22discount\x22,\x20lte:\x20100\x20}'}],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':a0_0x5c15ad(0x186),'nullable':!![],'purpose':a0_0x5c15ad(0x16b)},{'name':'created_by','shorthand':a0_0x5c15ad(0x161),'nullable':!![],'purpose':a0_0x5c15ad(0x125)},{'name':a0_0x5c15ad(0x117),'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':'updated_by','shorthand':a0_0x5c15ad(0x161),'nullable':!![],'purpose':'User\x20identifier\x20of\x20the\x20last\x20modifier.\x20Set\x20by\x20application\x20layer\x20on\x20UPDATE,\x20not\x20by\x20database\x20default.'}],'convention':{'emitInSkeleton':a0_0x5c15ad(0x139),'nullablePolicy':a0_0x5c15ad(0x156),'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_0x5c15ad(0x176),'columns':[{'name':IS_DELETED_COLUMN,'type':SOFT_DELETE_COLUMN_TYPES[IS_DELETED_COLUMN],'shorthand':a0_0x5c15ad(0x177),'nullable':![],'purpose':a0_0x5c15ad(0x170)},{'name':DELETED_AT_COLUMN,'type':SOFT_DELETE_COLUMN_TYPES[DELETED_AT_COLUMN],'shorthand':a0_0x5c15ad(0x122),'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':a0_0x5c15ad(0x11a)}],'biconditionalRules':[a0_0x5c15ad(0x140),'enabled\x20=\x20true\x20with\x20any\x20contract\x20column\x20missing:\x20validation\x20ERROR\x20(missing\x20columns\x20are\x20listed).',a0_0x5c15ad(0x167),'Contract\x20column\x20declared\x20with\x20a\x20wrong\x20type:\x20validation\x20ERROR.','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_0x5c15ad(0x159),a0_0x5c15ad(0x11f),'The\x20field\x20must\x20have\x20a\x20single-column\x20UNIQUE\x20constraint\x20(no\x20UNIQUE,\x20or\x20only\x20composite\x20UNIQUE:\x20ERROR).','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':a0_0x5c15ad(0x188)+SOFT_DELETE_SUFFIX_LENGTH+a0_0x5c15ad(0x143)},'uniqueEligibilityGate':{'description':a0_0x5c15ad(0x10e),'rules':[a0_0x5c15ad(0x13c),a0_0x5c15ad(0x10c)],'suggestion':a0_0x5c15ad(0x147)},'emittedDdl':{'consistencyCheck':{'namePattern':a0_0x5c15ad(0x183)+SOFT_DELETE_CHECK_SUFFIX,'description':a0_0x5c15ad(0x126)+SOFT_DELETE_CHECK_SUFFIX+a0_0x5c15ad(0x18a)+IS_DELETED_COLUMN+a0_0x5c15ad(0x168)+DELETED_AT_COLUMN+a0_0x5c15ad(0x148)+DELETED_BY_COLUMN+'\x20IS\x20NOT\x20NULL)\x20OR\x20('+IS_DELETED_COLUMN+'\x20=\x20FALSE\x20AND\x20'+DELETED_AT_COLUMN+a0_0x5c15ad(0x17b)+DELETED_BY_COLUMN+a0_0x5c15ad(0x119)},'partialIndex':{'description':a0_0x5c15ad(0x12b)+IS_DELETED_COLUMN+'\x20=\x20FALSE.','example':a0_0x5c15ad(0x113)+IS_DELETED_COLUMN+'\x20=\x20FALSE','notes':a0_0x5c15ad(0x144)}},'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':a0_0x5c15ad(0x151),'rdfDerivation':a0_0x5c15ad(0x169)},SHORTHAND_SYNTAX={'format':'<type>[:<modifier>]\x20[<constraint>[:<value>]]...','description':a0_0x5c15ad(0x128),'rules':['Type\x20is\x20mandatory\x20at\x20the\x20beginning\x20and\x20must\x20be\x20one\x20of\x20fieldTypes.',a0_0x5c15ad(0x15e),a0_0x5c15ad(0x13f),'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':'string:36\x20pk','meaning':a0_0x5c15ad(0x13b)},{'input':a0_0x5c15ad(0x10d),'meaning':'VARCHAR(255)\x20NOT\x20NULL'},{'input':a0_0x5c15ad(0x145),'meaning':a0_0x5c15ad(0x137)},{'input':a0_0x5c15ad(0x114),'meaning':'BOOLEAN\x20DEFAULT\x20TRUE'},{'input':a0_0x5c15ad(0x116),'meaning':a0_0x5c15ad(0x12c)},{'input':a0_0x5c15ad(0x186),'meaning':'TIMESTAMP\x20DEFAULT\x20<native_now\x20per\x20dialect>'},{'input':'string:36\x20fk:category.id','meaning':'VARCHAR(36)\x20with\x20FK\x20to\x20category(id),\x20auto\x20belongsTo\x20relation'},{'input':a0_0x5c15ad(0x192),'meaning':'VARCHAR(64)\x20with\x20single-column\x20index'}]},NAMING_RULES={'tableName':{'format':'snake_case','description':a0_0x5c15ad(0x185)},'fieldName':{'format':a0_0x5c15ad(0x13d),'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':'Constraint\x20names\x20auto-generated\x20with\x20type-specific\x20prefix\x20(pk,\x20fk,\x20idx,\x20uq,\x20ck)\x20and\x20dialect-specific\x20max\x20length.'},'compositeShortName':{'description':a0_0x5c15ad(0x12f)}},DIALECT_SUPPORT=[{'name':a0_0x5c15ad(0x141),'driver':'pg','booleanStorage':a0_0x5c15ad(0x15b)},{'name':a0_0x5c15ad(0x158),'driver':'mysql2','booleanStorage':a0_0x5c15ad(0x18d)},{'name':a0_0x5c15ad(0x132),'driver':'oracledb','booleanStorage':a0_0x5c15ad(0x10b)},{'name':'sqlite','driver':'better-sqlite3','booleanStorage':a0_0x5c15ad(0x10f)}],DBSCHEMA_CATALOG={'schemaVersion':SCHEMA_VERSION,'source':SOURCE,'summary':{'totalDefineModelOptions':DEFINE_MODEL_OPTIONS[a0_0x5c15ad(0x135)],'totalFieldTypes':FIELD_TYPES['length'],'totalConstraints':CONSTRAINTS[a0_0x5c15ad(0x135)],'totalRelationTypes':RELATION_TYPES[a0_0x5c15ad(0x135)],'totalReferentialActions':REFERENTIAL_ACTIONS[a0_0x5c15ad(0x135)],'totalCheckOperations':CHECK_OPERATIONS['length'],'totalAuditColumns':AUDIT_COLUMNS[a0_0x5c15ad(0x110)][a0_0x5c15ad(0x135)],'totalDialects':DIALECT_SUPPORT[a0_0x5c15ad(0x135)]},'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_0xebd9(){const _0x201bad=['DhLWzq','vKfsq0HbuJiGD2L0AcbdsevdsYbJB25ZDhjHAw50','u2LUz2XLlwnVBhvTBIbvtKLrvuuGy29UC3rYywLUDhmGB24GBM9Ulxn0CMLUzYbJB2X1Bw5ZigfYzsbYzwPLy3rLzcbMB3iGDgHLihnHBwuGCMvHC29UicHZDwzMAxGGBxv0yxrPB24GB25SEsbHChbSAwvZihrVihn0CMLUzY90zxH0ks4','C3rYAw5NoJi1nsbUB3rUDwXS','v2HLBIbLBMfIBgvKid0GDhj1zsWGzxzLCNKGvu5juvvfignVBNn0CMfPBNqGB24GDgHLihrHyMXLigLZignOzwnRzwqGzM9YihnVzNqTzgvSzxrLigvSAwDPyMLSAxr5lG','vevyva','y29SDw1UCW','yhjLzMvYzw5JzxnGigLZihrOzsbIyxjLignVBhvTBIbUyw1LigLUihrOzsb0yxjNzxqGDgfIBguUifrHCMDLDcb0ywjSzsbPCYbHDxrVlwrLCML2zwqGzNjVBsb0AguGCMvSyxrPB24GA2v5ig5HBwuSig9Yig92zxjYAwrLihDPDgGGyhrHCMDLDgaU','m09qCKj5zq','q1jfqvrfieLorevyigLKEf92AxnPDg9Yx2nHDgvNB3jPzxnFy2f0zwDVCNLFBMfTzsbptIb2AxnPDg9Yx2nHDgvNB3jPzxmGkgnHDgvNB3j5x25HBwuPifDirvjfia','yM9VBgvHBIbKzwzHDwX0oNrYDwu','sLnptIbJB2X1Bw4GkePtt05cig9UifbVC3rNCMvtuuWSiePtt04GB24GtxLtuuWSienmt0iGB24Gt3jHy2XLks4','C3rYAw5NoJeWmcbKzwzHDwX0oIDWzw5KAw5NjW','DxbKyxrLzf9HDa','mJe3DgLovLbb','ieLtie5vteWPlIbuAgLZigTLzxbZihrOzsb0AhjLzsbJB2X1Bw5ZignVBNnPC3rLBNqGyxqGDgHLigrHDgeGBgv2zwWGCMvNyxjKBgvZCYbVzIb0AguGD3jPDguGCgf0Ac4','rgvSzxrPB24Gywn0B3iGAwrLBNrPzMLLCIWGBNvSBgfIBguUie5vteWGD2HPBguGDgHLihjVDYbPCYbHBgL2zs4','ANnVBG','zgvJAw1HBa','yMLNAw50','BNvSBcbVCIbLBxb0EsbZDhjPBMCGBwvHBNmGzgvMyxvSDcbZy2HLBweU','vgHLigzPzwXKihr5CguGBxvZDcbIzsbZDhjPBMCGB3iGDgv4DcaODMfSDwuGBxv0yxrPB24GCMvXDwLYzxmGysbZDhjPBMCGDhLWztOGrvjst1iGB3rOzxj3AxnLks4','q2fUBM90ignVzxHPC3qGD2L0AcbLEhbSAwnPDcbYzwXHDgLVBIbLBNrYEsbYzwzLCMvUy2LUzYb0AguGC2fTzsbMAwvSzc4','B25ezwXLDgu','DgLTzxn0yw1W','zgvMyxvSDa','rgvMzxiGy29UC3rYywLUDcbJAgvJAYaOC2vTyw50AwnHBgX5ihnPBwLSyxiGDg8GCMvZDhjPy3qGB24GBw9ZDcbKAwfSzwn0CYKU','vxnLCIbPzgvUDgLMAwvYicH1C2vYBMfTzsWGDxnLCL9PzcWGB3iGy29TCg9ZAxrLihrVA2vUksbVzIb0AguGCMvJB3jKignYzwf0B3iUifnLDcbIEsbHChbSAwnHDgLVBIbSyxLLCIbVBIbjtLnfuLqSig5VDcbIEsbKyxrHyMfZzsbKzwzHDwX0lG','rxzLCNKGC29MDc1KzwXLDguGDgfIBguGz2v0CYbHienirunlignVBNn0CMfPBNqGD2L0Acb0AguGzgv0zxjTAw5PC3rPyYbUyw1LignOA188DgfIBgu+xW','mtG3nduWovPoD2T2AG','u3rYAw5NihnOB3j0AgfUzcbMB3iGzMLLBgqGzgvMAw5PDgLVBI4GvhLWzsbYzxf1AxjLzcbHDcbZDgfYDcWGzM9SBg93zwqGyNKGB3b0Aw9UywWGBw9KAwzPzxiGyw5KihnWywnLlxnLCgfYyxrLzcbJB25ZDhjHAw50CY4','EYbMAwvSzdOGiNf0EsiSigD0ztOGmcb9','C3rHBMrHBg9Uzq','tM9UlxvUAxf1zsbPBMrLEgvZig9UihnVzNqTzgvSzxrLihrHyMXLCYbHCMuGzw1PDhrLzcbHCYbqB3n0z3jLu1fmihbHCNrPywWGAw5KzxHLCYb3AxrOifDirvjfia','vKfsq0HbuIGXmdaPierfrKfvtfqGj3bLBMrPBMCN','tgvZCYb0AgfUlG','EYb0ExbLoIaIAgfZt25LiIWGDgfYz2v0oIaIChjVzMLSzsiSigXVy2fSs2v5oIaIDxnLCL9PzciSihjLzMvYzw5Jzxm6icj1C2vYx2LKiIb9','rM9YignVBxbVC2L0zsbPBMrLEgvZl3vUAxf1zxmSig5HBwuGAxmGzgvYAxzLzcbIEsbQB2LUAw5NignVBhvTBNmGD2L0Acb1BMrLCNnJB3jLigfUzcb0CNvUy2f0Aw5NihDOzw4GBMvLzgvKlG','C29MDerLBgv0zq','zgvJAw1HBdO8ChjLy2LZAw9UpIW8C2nHBgu+','B3jHy2XL','t25LlxrVlw9UzsaOAw52zxjZzsbVzIbIzwXVBMDZvg8PlIbpChrPB25HBcbPBNzLCNnLigrLy2XHCMf0Aw9Uig9UihrOzsbWyxjLBNqGC2LKztSGzg9LCYbUB3qGywzMzwn0ieretc4','uhjLy2LZAw9UigfUzcbZy2fSzsbYzxf1AxjLzcbMB3iGy3jVC3mTzgLHBgvJDcbWB3j0ywjPBgL0Es4','BgvUz3rO','DgfYz2v0','revdsu1btcGXnsWYksbot1qGtLvmtcberuzbvuXuida','ChjPBwfYEuTLEq','wwvZiokaLcbKyNnJAgvTytPPBML0igvTAxrZigfSBca0ignVBhvTBNmGyNKGzgvMyxvSDc4GvgfIBgvZihrOyxqGzg8GBM90ig5LzwqGyxvKAxqGkgXVB2T1Ccb0ywjSzxmSihn5C3rLBsb0ywjSzxmPignHBIbTyw51ywXSEsbYzw1VDMuGDgHLC2uGzMLLBgrZigzYB20GDgHLigDLBMvYyxrLzcbZA2vSzxrVBI4','nda0mvDlBvrMBa','vKfsq0HbuIGZnIKGufjjtufswsblrvK','q29TCg9ZAxrLifvosvfvrsbJB25ZDhjHAw50CYbHCMuGCMvQzwn0zwq6ihrOzxKGy2fUBM90igjLigzYzwvKihrOCM91z2GGDMfSDwuGBxv0yxrPB24SihnVihjLlwnYzwf0Aw5NigeGCM93ihDPDgGGDgHLihnHBwuGA2v5igfMDgvYigeGC29MDc1KzwXLDguGD291BgqGDMLVBgf0zsb0AguGy29UC3rYywLUDc4','C25HA2vFy2fZzq','rw5HyMXLCYbZB2z0lwrLBgv0zsbMB3iGDgHLihrHyMXLlIbtAgfWztOGEYbLBMfIBgvKoIbIB29SzwfUlcbYzxvZywjSzt86ifT7igzPzwXKlcbSzw5NDgGGFv0GFs4Gs2v5CYbVDgHLCIb0AgfUigvUywjSzwqGyw5KihjLDxnHyMXLigfYzsbYzwPLy3rLzcbHDcbZy2HLBweGBg9Hzc4Gv2HLBIbLBMfIBgvKlcb0AguGDgHYzwuGy29UDhjHy3qGy29SDw1UCYaOAxnFzgvSzxrLzcWGzgvSzxrLzf9HDcWGzgvSzxrLzf9IEsKGBxvZDcbIzsbKzwnSyxjLzcbPBIbMAwvSzhmUifnLzsb0AguGC29MDerLBgv0zsbZzwn0Aw9UigzVCIb0AguGzNvSBcbJB250CMfJDc4','u3rHBMrHBg9UzsbJB25ZDhjHAw50CYaOCgSSig5VDg51BgWSihvUAxf1zsWGAw5KzxGPihrHA2uGBM8GDMfSDwuUifrOzsbSzwDHy3KGyxv0B1vWzgf0zsb0B2TLBIbPCYbZDgLSBcbWyxjZzwqGzM9YigjHy2T3yxjKignVBxbHDgLIAwXPDhKGyNv0igLZigrLChjLy2f0zwqGyw5KigHHCYbUBYbMDw5JDgLVBMfSigvMzMvJDc4','zw5HyMXLzca9ihrYDwuGD2L0AcbHBgWGDgHYzwuGy29SDw1UCYbKzwnSyxjLzcbHBMqGy29YCMvJDgX5ihr5CgvKoIb2ywXPzc4','Cg9ZDgDYzxm','BM9by3rPB24','lwnOyxjHy3rLCIbZDwzMAxGGAxmGiImJiIaOmIKGkYb1DwLKDJCGkdm2ks4GrxHHBxbSztOGBgvUz3rOoIa1mcbYzxf1AxjLCYb0AguGzMLLBgqGDg8GyMuGzgvJBgfYzwqGyxqGBgvHC3qGC3rYAw5NoJG4oYbHihnOB3j0zxiGzgvJBgfYyxrPB24GzMfPBhmGDMfSAwrHDgLVBIb3AxrOihrOzsbKzwnSyxjLzcbHBMqGCMvXDwLYzwqGBgvUz3rOCYbPBIb0AguGBwvZC2fNzs4','vu5juvvfignVBNn0CMfPBNrZigfYzsbot1qGBwfKzsbWyxj0AwfSig9UigfUEsbKAwfSzwn0lIbvBMLXDwvUzxnZigTLzxbZignVDMvYAw5NigrLBgv0zwqGCM93CZSGDMfSDwuGCMv1C2uGAxmGAgfUzgXLzcbIEsb0AguGC3vMzML4ig11Dgf0Aw9UlcbUB3qGyNKGysbWyxj0AwfSihvUAxf1zsbPBMrLEc4','zgvJAw1HBdOXnsWYig5VDg51BgWGzgvMyxvSDdOW','nti0ndi0BuDMBwPl','vgHLigvYCM9Yig1LC3nHz2uGC3vNz2vZDhmGDhDVihDHExmGB3v0oIb1C2uGAgfYzc1KzwXLDguGzM9YihbYB2nLC3mTzhjPDMvUihrHyMXLCYaOyMfSyw5JzsWGBgvKz2vYlcbZBMfWC2HVDcWGCgvYAw9KlwnSB3nLksWGB3iGy2HHBMDLihrOzsbvtKLrvuuGAw50BYbHihnPBMDSzs1JB2X1Bw4GC3rYAw5Nigj1C2LUzxnZignVzguU','ieLtie5pvcbovuXmieforca','Bg9JywXlzxK','rgvMyxvSDcb0Aw1LEM9UzsbIzwHHDMLVCIbPCYbKAwfSzwn0lxnWzwnPzMLJlG','z3rL','DMfSDwu','Dgv4Da','tg9UzY1MB3jTihrLEhqGD2L0Ag91DcbSzw5NDgGGBgLTAxqGkfrfwfqVq0XpqIKU','vMfYAwfIBguTBgvUz3rOihrLEhqUieXLBMD0AcbTB2rPzMLLCIbYzxf1AxjLzc4','C3rYAw5N','C2nOzw1HigLUDhjVC3bLy3qGCMvJB2DUAxPLCYbHignVBxbSzxrLihnVzNqTzgvSzxrLihrHyMXLicH0AhjLzsbJB3jYzwn0BhKGDhLWzwqGy29UDhjHy3qGy29SDw1UCYaRignVBNnPC3rLBMn5ienirunlksbHBMqGD3jPDgvZigjHy2SGC29MDerLBgv0ztOGEYbLBMfIBgvKoIb0CNvLih0GAw4GDgHLigDLBMvYyxrLzcbtreyUifrHyMXLCYb3AxrOigLUy29TCgXLDguGB3iGBM9UlwnVBMzVCM1PBMCGC29MDc1KzwXLDguGy29SDw1UCYbIBg9JAYbPBNrYB3nWzwn0ihDPDgGGyw4GzxjYB3iU','lI4VzgjZy2HLBweTA2L0l3nVzNqTzgvSzxrLlwnVBNn0yw50CW','BM90BNvSBa','mJiZndjgBhPVA1C','C3rYAw5NoJXSzw5NDgG+','qwXSidqGy29SDw1UCYbHCMuGBNvSBgfIBguUifrOzsbJCMvHDgvKx2j5l3vWzgf0zwrFyNKGy29SDw1UCYbTyxKGyMuGzw1WDhKGzM9YihjVD3mGAw5Zzxj0zwqGyNKGC3LZDgvTihnLzwrZlcbTAwDYyxrPB25ZlcbVCIbIyxrJAcbPBxbVCNrZihrOyxqGzg8GBM90igHHDMuGysb1C2vYignVBNrLEhqU','CMvZDhjPy3q','BxLZCwW','vgHLigzPzwXKig11C3qGyMuGzgvJBgfYzwqGAw4GzMLLBgrZicH1BMTUB3DUigzPzwXKoIbfuLjpuIKU','t2jQzwn0ig9MigzPzwXKigrLzMLUAxrPB25ZigLUihnOB3j0AgfUzcbZDhjPBMCGzM9YBwf0lG','BMf0AxzLiejpt0Xfqu4','CMvMzxjLBMnLCW','r3jLyxrLCIb0AgfUlG','tw9KAwzPzxiGAxmGBwfUzgf0B3j5igzVCIb0ExbLicjZDhjPBMCIicHSzw5NDgGPigfUzcaIzgvJAw1HBciGkhbYzwnPC2LVBIXZy2fSzsKU','Dw5PCxvL','ug9ZDgDYzvnrtc1VBMX5igLUifbOyxnLideUifrOzsbsreyGC29MDerLBgv0zsbIBg9JAYbPCYbKzxjPDMvKigzYB20GDgHPCYbtreyGyMXVy2SGzhvYAw5NihbHEwXVywqGz2vUzxjHDguSig5LDMvYihDYAxr0zw4GyNKGAgfUzc4','C3rYAw5NoJeWma','w1SIC3rHDhvZiIWGiMnYzwf0zwrFyxqIxv0','C2nOzw1H','mJj1z21hq3y','mZG4mePmu1PKsG','twfYA3mGzMLLBgqGyxmGChjPBwfYEsbRzxKU','u29MDc1KzwXLDguGy29SDw1UCYbKzwnSyxjLzcb3AgLSzsbLBMfIBgvKigLZig5VDcb0CNvLoIb2ywXPzgf0Aw9UievsuK9slG','id0GvfjvrsbbtKqG','vgHLifjerIbZB2z0rgvSzxrLigjSB2nRigLZigrLCML2zwqGzNjVBsbtreyGzhvYAw5NihbHEwXVywqGz2vUzxjHDguSig5LDMvYihDYAxr0zw4GBwfUDwfSBhKUifrHyMXLCYb3Ag9ZzsbKyxrHyMfZzsbJB2X1Bw5ZigLUy2X1zguGDgHLihnVzNqTzgvSzxrLignVBNrYywn0ig11C3qGyMuGzgvJBgfYzwqGAw4Gu0rgihDPDgGGysb2ywXPzcbZB2z0rgvSzxrLigjSB2nRigzVCIbWyxLSB2fKigDLBMvYyxrLihrVihn1y2nLzwqU','sw50zxiTDgfIBguGCMvSyxrPB25ZicHIzwXVBMDZvg8SigHHC09UzsWGAgfZtwfUEsKU','uMvJB3jKignYzwf0Aw9UihrPBwvZDgfTCc4Gqxv0BY1ZzxqGB24Gsu5trvjuihzPysberuzbvuXuig5VDYGPlIboyxrPDMuGzNvUy3rPB24GDhjHBNnSyxrLCYbWzxiGzgLHBgvJDcaOCg9ZDgDYzxm6ienvuLjftLrFveLnrvnuqu1qlcbTExnXBdOGtK9xkcKSig9YywnSztOGu1LtveLnrvnuqu1qlcbZCwXPDgu6ienvuLjftLrFveLnrvnuqu1qks4','yM9VBgvHBG','rgf0ywjHC2uGC2nOzw1Hig5HBwvZCgfJzsaOBxvSDgKTC2nOzw1HigrHDgfIyxnLks4','zgf0zq','u2LUz2XLlwnVBhvTBIb1BMLXDwuGy29UC3rYywLUDc4','rgvSzxrPB24GzMXHzY4GrgvJBgfYzsbHCYbUB3rUDwXSigrLzMf1Bhq6zMfSC2uU','nduZmdrRtgDvqMW','ntu3nxbkv0rdEa','B25vCgrHDgu','B2jQzwn0','zgjZy2HLBweTy2f0ywXVzW','v2HLBIbLBMfIBgvKid0GDhj1zsWGywXSihrOCMvLignVBhvTBNmGyMvSB3CGtvvtvcbIzsbKzwnSyxjLzcbPBIbMAwvSzhmGD2L0AcbLEgfJDgX5ihrOzxnLigXVz2LJywWGDhLWzxmUifrOzsbYzwXHDgLVBIbIzxr3zwvUihrOzsbIBg9JAYbHBMqGDgHLignVBhvTBNmGAxmGyMLJB25KAxrPB25HBc4','yM9VBgvHBIbUB3rUDwXSigrLzMf1Bhq6zMfSC2u','tK9uie5vteWGy29UC3rYywLUDc4','nJqTyML0ihnPz25LzcbPBNrLz2vYicHcsuDjtLqPlG','Aw50zwDLCG','ieLtie5vteWGqu5eia','tM9UlxvUAxf1zsbPBMrLEgvZlIbfywnOigvUDhj5igLZigfYCMf5ig9MignVBhvTBIbUyw1LCYbVCIbVyMPLy3qGEYbUyw1LlcbJB2X1Bw5Zih0U','ndC0EhLTB29c','yxjYyxK','vw5PCxvLignVBNn0CMfPBNrZicHZAw5NBguGB3iGy29TCg9ZAxrLks4','EYb0ExbLoIaIAgfZtwfUEsiSihrHCMDLDdOGiM9YzgvYx2L0zw0IlcbSB2nHBeTLEtOGiM9YzgvYx2LKiIWGCMvMzxjLBMnLCZOGiM9YzgvYx2LKiIb9','C3rYAw5NoJm2ihbR','vMfSDwuGBxvZDcbIzsbVBMuGB2yGysbSAxn0lG','y2HRxZX0ywjSzt5F','C3rYAw5NoJmYihvUAxf1zq','vgfIBguGBMfTzsbTDxn0igjLigXVD2vYy2fZzsWGzgLNAxrZlcbHBMqGDw5KzxjZy29YzxmGB25SEs4','DgLTzxn0yw1WigrLzMf1Bhq6BM93kcK','BMvX','vgHLia','mZC2ndK2BuHJDLfN','igvUzM9Yy2LUzZOGka','C3rYAw5NoJi1nq','qM9VBgvHBIb2ywX1zsaOBMf0AxzLiejpt0Xfqu4GB24Gug9ZDgDYzvnrtcWGvKfsq0HbuIbVBIbVDgHLCNmPlG','vKfsq0HbuIaOBgL0zxjHBcaIDhj1zsiViMzHBhnLiIK','rgvMyxvSDcb2ywX1zs4Gu2LUz2XLlxf1B3rLzcbMB3iGC3rYAw5NCYWGCMf3igzVCIbUDw1LCMLJl2jVB2XLyw4SigjHCMuGAwrLBNrPzMLLCIbMB3iGu1fmignVBNn0yw50CYWGAwrLBNrPzMLLCIGPigzVCIbUyxrPDMuGzNvUy3rPB24Gy2fSBhmU','zMLLBgrZ','C2v0tNvSBa','C2nHBgfY','C3rYAw5NoJy0igLUzgv4','vvvjrc4GtMf0AxzLifvvsuqGB24Gug9ZDgDYzvnrtcWGvKfsq0HbuIGZnIKGB24GB3rOzxjZlG','mtrcDfvIwKW','zMS6phrHyMXLpI48y29SDw1UpG'];a0_0xebd9=function(){return _0x201bad;};return a0_0xebd9();}
1
+ 'use strict';const a0_0xac60ef=a0_0x292c;function a0_0x292c(_0x5a9155,_0x1fa00b){_0x5a9155=_0x5a9155-0x1e1;const _0x1cd2bb=a0_0x1cd2();let _0x292cb7=_0x1cd2bb[_0x5a9155];if(a0_0x292c['FwYqUn']===undefined){var _0x16b277=function(_0x558d7e){const _0x1aa8dc='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x259916='',_0x58348e='';for(let _0x51a113=0x0,_0x5c651c,_0x2d5db5,_0x2925a2=0x0;_0x2d5db5=_0x558d7e['charAt'](_0x2925a2++);~_0x2d5db5&&(_0x5c651c=_0x51a113%0x4?_0x5c651c*0x40+_0x2d5db5:_0x2d5db5,_0x51a113++%0x4)?_0x259916+=String['fromCharCode'](0xff&_0x5c651c>>(-0x2*_0x51a113&0x6)):0x0){_0x2d5db5=_0x1aa8dc['indexOf'](_0x2d5db5);}for(let _0x555041=0x0,_0x271aff=_0x259916['length'];_0x555041<_0x271aff;_0x555041++){_0x58348e+='%'+('00'+_0x259916['charCodeAt'](_0x555041)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x58348e);};a0_0x292c['WjbIAN']=_0x16b277,a0_0x292c['ssVvEo']={},a0_0x292c['FwYqUn']=!![];}const _0x4bc538=_0x1cd2bb[0x0],_0xf184f1=_0x5a9155+_0x4bc538,_0x53e338=a0_0x292c['ssVvEo'][_0xf184f1];return!_0x53e338?(_0x292cb7=a0_0x292c['WjbIAN'](_0x292cb7),a0_0x292c['ssVvEo'][_0xf184f1]=_0x292cb7):_0x292cb7=_0x53e338,_0x292cb7;}(function(_0x414eb7,_0x5a5529){const _0x143e9a=a0_0x292c,_0x285fb1=_0x414eb7();while(!![]){try{const _0x53853c=parseInt(_0x143e9a(0x1fe))/0x1+parseInt(_0x143e9a(0x23e))/0x2*(parseInt(_0x143e9a(0x254))/0x3)+parseInt(_0x143e9a(0x255))/0x4*(parseInt(_0x143e9a(0x245))/0x5)+-parseInt(_0x143e9a(0x1f4))/0x6*(parseInt(_0x143e9a(0x20b))/0x7)+parseInt(_0x143e9a(0x231))/0x8*(-parseInt(_0x143e9a(0x1f6))/0x9)+parseInt(_0x143e9a(0x258))/0xa+-parseInt(_0x143e9a(0x21a))/0xb*(parseInt(_0x143e9a(0x265))/0xc);if(_0x53853c===_0x5a5529)break;else _0x285fb1['push'](_0x285fb1['shift']());}catch(_0x2e8264){_0x285fb1['push'](_0x285fb1['shift']());}}}(a0_0x1cd2,0x6f06d));function a0_0x1cd2(){const _0x1373fe=['rgf0zsbHBMqGDgLTzsaOveLnrvnuqu1qks4','vgHLifjerIbNzw5LCMf0B3iGkgnVzgvNzw5Fy3jLyxrLx2vUzhbVAw50ksbHC3n1BwvZihrOzxnLidqGy29SDw1UCYbLEgLZDcb3AgvUihrOzsbWyxLSB2fKlMf1zgL0q29SDw1UCYbRzxKGAxmGywjZzw50lIbtzwuGzMLLBgqTDMfSAwrHDgLVBJPJyxrHBg9Nigf1zgL0q29SDw1UCYbMB3iGDgHLifjerI1ZAwrLigjLAgf2Aw9YlIbeCMLMDcbIzxr3zwvUifnerIaOBwLZC2LUzYbHDwrPDcbJB2X1Bw5ZksbHBMqGuKrgicHHC3n1BwvZigf1zgL0ignVBhvTBNmPignHDxnLCYbYDw50Aw1LigvYCM9YCYb3AgvUihrOzsbNzw5LCMf0zwqGzw5KCg9PBNqGDhjPzxmGDg8GD3jPDguGy3jLyxrLzf9IEs91CgrHDgvKx2j5ihrVigeGBM9Ulwv4Axn0zw50ignVBhvTBI4','mJC3ndGYrKH2wLDs','nefMtxH2uG','w3SGzMLLBgq6icjZDgf0DxmIlcbPBJOGwYjHy3rPDMuIlcaIAw5Hy3rPDMuIxsb9lcb7igzPzwXKoIaICxr5iIWGz3rLoIaWih1D','ieLtie5pvcbovuXmieforca','nZe3nZqWmgngyuDhuW','yM9VBgvHBIbKzwzHDwX0oNrYDwu','Aw5KzxHLCW','B2jQzwn0','EYbLBMfIBgvKoIb0CNvLlcbYzxvZywjSztOGw3SGzMLLBgq6icjJyxrLz29YEv9JB2rLiIWGBgvUz3rOoIa1mcb9xsb9','BxLZCwWY','vhLWzsbPCYbTyw5KyxrVCNKGyxqGDgHLigjLz2LUBMLUzYbHBMqGBxvZDcbIzsbVBMuGB2yGzMLLBgruExbLCY4','zw5HyMXLzca9ihrYDwuGD2L0AcbHBNKGy29UDhjHy3qGy29SDw1Uig1PC3nPBMC6ihzHBgLKyxrPB24Grvjst1iGkg1PC3nPBMCGy29SDw1UCYbHCMuGBgLZDgvKks4','C2nHBgfY','CgH5C2LJywWGBgvUz3rOid49igjHC2uGBgvUz3rOicSG','uMvQzwn0igrLBgv0zs91CgrHDguGD2HLBIbJAgLSzcbYB3DZigv4Axn0lG','vKfsq0HbuIGZnIKGufjjtufswsblrvK','vgfIBguGBMfTzsbTDxn0igjLigXVD2vYy2fZzsWGzgLNAxrZlcbHBMqGDw5KzxjZy29YzxmGB25SEs4','mtG4mteYsez3uxzL','Cg9ZDgDYzxm','zgvJAw1HBdOXnsWYig5VDg51BgWGzgvMyxvSDdOW','q29UC2vXDwvUy2u6igLZx2rLBgv0zwqSigrLBgv0zwrFyxqSigfUzcbKzwXLDgvKx2j5igfYzsbYzxnLCNzLzcbUyw1LCZSGDgHLEsbJyw5UB3qGyMuGDxnLzcbHCYbVCMrPBMfYEsbJB2X1Bw5ZigLUifjfu1rgB3jNzs1Tyw5Hz2vKihrHyMXLCY4','tgvZCYb0AgfUig9YigvXDwfSihrVlG','q29TCg9ZAxrLifvosvfvrsbJB25ZDhjHAw50CYbHCMuGCMvQzwn0zwq6ihrOzxKGy2fUBM90igjLigzYzwvKihrOCM91z2GGDMfSDwuGBxv0yxrPB24SihnVihjLlwnYzwf0Aw5NigeGCM93ihDPDgGGDgHLihnHBwuGA2v5igfMDgvYigeGC29MDc1KzwXLDguGD291BgqGDMLVBgf0zsb0AguGy29UC3rYywLUDc4','zgf0zq','rM9YignVBxbVC2L0zsbPBMrLEgvZl3vUAxf1zxmSig5HBwuGAxmGzgvYAxzLzcbIEsbQB2LUAw5NignVBhvTBNmGD2L0Acb1BMrLCNnJB3jLigfUzcb0CNvUy2f0Aw5NihDOzw4GBMvLzgvKlG','u29MDc1KzwXLDguGy29SDw1UCYbKzwnSyxjLzcb3AgLSzsbLBMfIBgvKigLZig5VDcb0CNvLoIb2ywXPzgf0Aw9UievsuK9slG','EYbMAwvSzdOGiNf0EsiSigD0oIaWih0','rgvMyxvSDcb2ywX1zsbMB3jTyxqGzgvWzw5KCYbVBIb0ExbLoIbYyxCGzM9YigjVB2XLyw4GkgrLzMf1Bhq6Dhj1zsKSihjHDYbMB3iGAw50zwDLCIaOzgvMyxvSDdOWksWGC2LUz2XLlxf1B3rLzcbMB3iGC3rYAw5NicHKzwzHDwX0oID2ywX1zsCPlcbIyxjLigLKzw50AwzPzxiGzM9YifnrtcbJB25ZDgfUDhmGkgrLzMf1Bhq6y3vYCMvUDf9KyxrLksWGAwrLBNrPzMLLCIGPigzVCIbUyxrPDMuGzNvUy3rPB24Gy2fSBhmGkgrLzMf1Bhq6BM93kcKPlG','tgfZDcbTB2rPzMLJyxrPB24GDgLTzxn0yw1WlIbbDxrVlxvWzgf0zsbPCYbOyw5KBgvKigj5ihrOzsbsreyGCNvUDgLTzsaOqMfZzu1VzgvSigf1zgL0q29SDw1UCYbJB252zw50Aw9Uksb3AgLJAcbPBMPLy3rZihvWzgf0zwrFyxqGpsbdvvjsru5ux1rjtuvtvefnucbPBNrVigv2zxj5ifvqrefursbZDgf0zw1LBNqGyMfZzwqGB24GzMLLBgqGBMfTAw5NlcbUB3qGyNKGyw55ifnerIbTyxjRzxiUieLUAxrPywWGsu5trvjuihzHBhvLigLZigfSC28GAgfUzgXLzcbIEsb0AguGuKrgihj1BNrPBwuGyxvKAxrdB2X1Bw5ZigHLBhbLCI4','vevyva','CMvMzxjLBMnLCW','t3zLCNjPzguGChjPBwfYEsbRzxKUifnPBMDSzsbMAwvSzcbUyw1Lig9YignVBxbVC2L0zsbHCNjHEs4','q2fZy2fKzsbKzwXLDguVDxbKyxrLihrVignOAwXKihjVD3mU','EYbMAwvSzdOGiNn0yxr1CYiSigLUoIbBiMfJDgL2zsiSicjPBMfJDgL2zsjDih0','q1jfqvrfieLorevyigLKEf92AxnPDg9Yx2nHDgvNB3jPzxnFy2f0zwDVCNLFBMfTzsbptIb2AxnPDg9Yx2nHDgvNB3jPzxmGkgnHDgvNB3j5x25HBwuPifDirvjfia','zxHWB3j0CW','C3rYAw5NoJXSzw5NDgG+','C3rYAw5NoJi1nq','nNHyELbICW','rgvSzxrPB24GzMXHzY4GrgvJBgfYzsbHCYbUB3rUDwXSigrLzMf1Bhq6zMfSC2uU','mZG3tgX2rLze','lI4VzgjZy2HLBweTA2L0l3nVzNqTzgvSzxrLlwnVBNn0yw50CW','sw50zxiTDgfIBguGCMvSyxrPB25ZicHIzwXVBMDZvg8SigHHC09UzsWGAgfZtwfUEsKU','vgHLigvYCM9Yig1LC3nHz2uGC3vNz2vZDhmGDhDVihDHExmGB3v0oIb1C2uGAgfYzc1KzwXLDguGzM9YihbYB2nLC3mTzhjPDMvUihrHyMXLCYaOyMfSyw5JzsWGBgvKz2vYlcbZBMfWC2HVDcWGCgvYAw9KlwnSB3nLksWGB3iGy2HHBMDLihrOzsbvtKLrvuuGAw50BYbHihnPBMDSzs1JB2X1Bw4GC3rYAw5Nigj1C2LUzxnZignVzguU','EYbPzdOGiNn0CMLUzZOZnIbWAYiSig5HBwu6icjZDhjPBMC6mJu1ig5VDg51BgWIih0','yMLNAw50','u29MDc1KzwXLDguGA2vLChmGCM93CYbPBIb0AguGDgfIBguSihnVifvosvfvrsbJB25ZDhjHAw50CYbZDgLSBcbZzwuGzgvSzxrLzcbYB3DZlIbdB2X1Bw5ZigXPC3rLzcbPBIbYzxvZywjSzsbOyxzLihrOzwLYihzHBhvLig11Dgf0zwqGB24GzgvSzxrLihrVicj7DMfSDwv9iYn7DxvPzhy3FsiGC28GDgHLig9YAwDPBMfSihzHBhvLignHBIbIzsbYzxvZzwqGyNKGysbUzxCGCM93lG','vu5juvvfignVBNn0CMfPBNrZigfYzsbot1qGBwfKzsbWyxj0AwfSig9UigfUEsbKAwfSzwn0lIbvBMLXDwvUzxnZigTLzxbZignVDMvYAw5NigrLBgv0zwqGCM93CZSGDMfSDwuGCMv1C2uGAxmGAgfUzgXLzcbIEsb0AguGC3vMzML4ig11Dgf0Aw9UlcbUB3qGyNKGysbWyxj0AwfSihvUAxf1zsbPBMrLEc4','nZCYota1rxrHDxzx','DMfSDwu','yM9VBgvHBG','vKfsq0HbuIGXmdaPierfrKfvtfqGj3bLBMrPBMCN','EYbMAwvSzdOGiMrPC2nVDw50iIWGBhrLoIaXmdaGFq','phr5Cgu+wZO8Bw9KAwzPzxi+xsbBpgnVBNn0CMfPBNq+wZO8DMfSDwu+xv0UlI4','vgHLigzPzwXKihr5CguGBxvZDcbIzsbZDhjPBMCGB3iGDgv4DcaODMfSDwuGBxv0yxrPB24GCMvXDwLYzxmGysbZDhjPBMCGDhLWztOGrvjst1iGB3rOzxj3AxnLks4','ugHHC2uGmtOGug9ZDgDYzvnrtcbVBMX5lIbpBIbVDgHLCIbKAwfSzwn0CYb0AguGC29MDerLBgv0zsbIBg9JAYbPCYbUB3qGC3vWCg9YDgvKicHereWGz2vUzxjHDgLVBIbMywLSCYb3AxrOigeGy2XLyxiGzxjYB3iPigfUzcbZB2z0lwrLBgv0zs1Uyw1LzcbJB2X1Bw5ZigDLDcbUBYbZCgvJAwfSihrYzwf0BwvUDcbKDxjPBMCGAw50CM9ZCgvJDc4','DhLWzq','C3rYAw5NFg51BgW','DgfYz2v0','C3rYAw5NoJCW','yM9VBgvHBIbUB3rUDwXSigrLzMf1Bhq6zMfSC2u','mZeWmtiXzxnSrfjt','tM9UlxvUAxf1zsbPBMrLEgvZlIbfywnOigvUDhj5igLZigfYCMf5ig9MignVBhvTBIbUyw1LCYbVCIbVyMPLy3qGEYbUyw1LlcbJB2X1Bw5Zih0U','id0GvfjvrsbbtKqG','BhrL','revdsu1btcGXnsWYksbot1qGtLvmtcberuzbvuXuida','ieLtie5vteWGqu5eia','C3rYAw5NoJm2ihbR','y2fZy2fKzq','BgvUz3rOig11C3qGyMuGysbWB3nPDgL2zsbPBNrLz2vYicHIyxnLigXLBMD0Aca9ig1HEgLTDw0GDxnLCI1PBNb1DcbSzw5NDgGPoIbfuLjpuIbVDgHLCNDPC2uU','C25HA2vFy2fZzq','Aw5KzxG','tuq1igHHC2GGoc1JAgfYywn0zxiGC3vMzML4ihDOzw4GBMfTzsbLEgnLzwrZig1HEeXLBMD0Aa','ANnVBG','BNvTzxjPyW','ieLtie5pvcbovuXmksbpuIaO','mty2mujqB3POCa','Ahr0Chm6lY9Yzxn0zM9Yz2uUzgv2l2rVy3mVy2XPl3nJAgvTys1KzwzPBML0Aw9U','rM9YzwLNBIbRzxKGCMvMzxjLBMnLlIbbDxrVlwDLBMvYyxrLCYbHigjLBg9Uz3nuBYbYzwXHDgLVBIbLBNrYEs4','Bg9JywXlzxK','rgvMzxiGy29UC3rYywLUDcbJAgvJAYaOC2vTyw50AwnHBgX5ihnPBwLSyxiGDg8GCMvZDhjPy3qGB24GBw9ZDcbKAwfSzwn0CYKU','yMv0DgvYlxnXBgL0ztm','rgvSzxrPB24GDgLTzxn0yw1WlcbUDwXSywjSzs4GtLvmtcb3AgLSzsb0AguGCM93igLZigfSAxzLlG','rgf0zsbVBMX5icHUBYb0Aw1LignVBxbVBMvUDcKU','ug9ZDgDYzvnrtc1VBMX5igLUifbOyxnLideUifrOzsbsreyGC29MDerLBgv0zsbIBg9JAYbPCYbKzxjPDMvKigzYB20GDgHPCYbtreyGyMXVy2SGzhvYAw5NihbHEwXVywqGz2vUzxjHDguSig5LDMvYihDYAxr0zw4GyNKGAgfUzc4','tM90igvXDwfSihrVlG','EYb0ExbLoIaIAgfZt25LiIWGDgfYz2v0oIaIChjVzMLSzsiSigXVy2fSs2v5oIaIDxnLCL9PzciSihjLzMvYzw5Jzxm6icj1C2vYx2LKiIb9','tK9uie5vteWGy29UC3rYywLUDc4','twfUEs10BY1VBMuUifrOAxmGDgfIBguGAg9SzhmGDgHLiezlignVBhvTBIbYzwzLCMvUy2LUzYb0AguGCgfYzw50ihrHyMXLlG','EYbMAwvSzdOGiNf0EsiSigD0ztOGmcb9','vgHLigzPzwXKig11C3qGAgf2zsbHihnPBMDSzs1JB2X1Bw4Gvu5juvvfignVBNn0CMfPBNqGkg5VifvosvfvrsWGB3iGB25SEsbJB21WB3nPDguGvu5juvvfoIbfuLjpuIKU','C3rYAw5N','qM9VBgvHBIb2ywX1zsaOBMf0AxzLiejpt0Xfqu4GB24Gug9ZDgDYzvnrtcWGvKfsq0HbuIbVBIbVDgHLCNmPlG','C3rHBMrHBg9Uzq','B25vCgrHDgu','vKfsq0HbuIGZnIKGD2L0AcbgsYb0BYbJyxrLz29YEsHPzcKSigf1Dg8GyMvSB25NC1rVihjLBgf0Aw9U','BNvSBcbVCIbLBxb0EsbZDhjPBMCGBwvHBNmGzgvMyxvSDcbZy2HLBweU','C3fSAxrL','t2jQzwn0ig9MigzPzwXKigrLzMLUAxrPB25ZigLUihnOB3j0AgfUzcbZDhjPBMCGzM9YBwf0lG','mJmYmtzjyu9OAei','revquKvdqvrfrdOGvgHPCYbTB2rPzMLLCIbUBYbSB25NzxiGAgfZigz1BMn0Aw9UywWGzwzMzwn0igf0ihrOzsbereWGB3iGCNvUDgLTzsbSzxzLBc4Gqxv0BY11CgrHDguGzM9YihvWzgf0zwrFyxqGAxmGAgfUzgXLzcbIEsb0AguGuKrgigXHEwvYicHHDwrPDenVBhvTBNmGy29UDMvUDgLVBIbPBIbcyxnLtw9KzwWGCNvUDgLTzsKGyMfZzwqGB24GzMLLBgqGBMfTAw5NignVBNzLBNrPB24Sig5VDcbIEsb0AgLZifnerIbTyxjRzxiUiev4Axn0Aw5NihvZywDLigLZihbYzxnLCNzLzcbMB3iGyMfJA3DHCMqGy29TCgf0AwjPBgL0EsbIDxqGC2HVDwXKigjLihjLBw92zwqGzNjVBsbUzxCGDgvTCgXHDgvZlG','id0GrKfmu0uGqu5eia','zgvMyxvSDa','B25ezwXLDgu','EYbMAwvSzdOGiNr5CguIlcbUzxe6icjZExn0zw0Iih0','C3rYAw5NoJeWma','yxjYyxK','BgvUz3rO','rM9YzwLNBIbRzxKGDxnLCYbKB3qGBM90yxrPB246igzRoJX0ywjSzt4UpgnVBhvTBJ4GkguUzY4SigzRoMnHDgvNB3j5lMLKks4GvgHLihbHCNnLCIbYzwPLy3rZihbHCMvUDgHLC2vZihn5BNrHEc4','EYbMAwvSzdOGiNr5CguIlcbLCtOGiNvZzxiIih0','q29SDw1Uig5HBwuGBxvZDcbIzsbZBMfRzv9JyxnLlG','C3rYAw5NoJy0igLUzgv4','mtrPyxLzA3O','AgfZtwfUEq','t25LlxrVlw9UzsaOAw52zxjZzsbVzIbIzwXVBMDZvg8PlIbpChrPB25HBcbPBNzLCNnLigrLy2XHCMf0Aw9Uig9UihrOzsbWyxjLBNqGC2LKztSGzg9LCYbUB3qGywzMzwn0ieretc4','mZiTyML0ihnPz25LzcbPBNrLz2vYicHjtLqVsu5uruDfuIKU','vMfSDwuGBxvZDcbIzsbVBMuGB2yGysbSAxn0lG','u2LUz2XLlwnVBhvTBIbUB24TDw5PCxvLigLUzgv4lG','w1SIy2f0zwDVCNLFy29KzsjDlcbBiNrLBMfUDf9PzciSicjJyxrLz29YEv9JB2rLiL1D','ndi2ndeZnwPPtKn2Aq','v2HLBIbLBMfIBgvKid0GDhj1zsWGywXSihrOCMvLignVBhvTBNmGyMvSB3CGtvvtvcbIzsbKzwnSyxjLzcbPBIbMAwvSzhmGD2L0AcbLEgfJDgX5ihrOzxnLigXVz2LJywWGDhLWzxmUifrOzsbYzwXHDgLVBIbIzxr3zwvUihrOzsbIBg9JAYbHBMqGDgHLignVBhvTBNmGAxmGyMLJB25KAxrPB25HBc4','ms4X','yxv0B1vWzgf0zq','y29SDw1UCW','nJqTyML0ihnPz25LzcbPBNrLz2vYicHcsuDjtLqPlG','DgLTzxn0yw1W','BMf0AxzLiejpt0Xfqu4','u3rYAw5NihnOB3j0AgfUzcbMB3iGzMLLBgqGzgvMAw5PDgLVBI4GvhLWzsbYzxf1AxjLzcbHDcbZDgfYDcWGzM9SBg93zwqGyNKGB3b0Aw9UywWGBw9KAwzPzxiGyw5KihnWywnLlxnLCgfYyxrLzcbJB25ZDhjHAw50CY4','C3rYAw5NFgfYCMf5','C3rYAw5NoJi1nsbUB3rUDwXS','DxbKyxrLzf9IEq','rgvMyxvSDcb0Aw1LEM9UzsbIzwHHDMLVCIbPCYbKAwfSzwn0lxnWzwnPzMLJlG'];a0_0x1cd2=function(){return _0x1373fe;};return a0_0x1cd2();}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(a0_0xac60ef(0x1f7)),SCHEMA_VERSION=a0_0xac60ef(0x247),SOURCE='dbschema-catalog',DOCUMENTATION_URL=a0_0xac60ef(0x21b),DEFINE_MODEL_OPTIONS=[{'name':'schema','required':![],'type':a0_0xac60ef(0x207),'description':'Database\x20schema\x20namespace\x20(multi-schema\x20database).','notes':a0_0xac60ef(0x22e)},{'name':'fields','required':!![],'type':a0_0xac60ef(0x25b),'description':a0_0xac60ef(0x230),'example':a0_0xac60ef(0x1fa)},{'name':'primaryKey','required':![],'type':a0_0xac60ef(0x24e),'description':a0_0xac60ef(0x1ed),'notes':'Auto-detected\x20from\x20field\x20shorthand\x20\x22pk\x22\x20when\x20not\x20specified.'},{'name':'relations','required':![],'type':'object','description':a0_0xac60ef(0x1f8),'example':'{\x20category:\x20{\x20type:\x20\x22belongsTo\x22,\x20references:\x20\x22category(id)\x22\x20}\x20}'},{'name':a0_0xac60ef(0x25a),'required':![],'type':'array','description':a0_0xac60ef(0x20c),'example':'[[\x22status\x22,\x20\x22created_at\x22]]'},{'name':'uniques','required':![],'type':a0_0xac60ef(0x238),'description':'Unique\x20constraints\x20(single\x20or\x20composite).','example':a0_0xac60ef(0x244)},{'name':'checks','required':![],'type':'array','description':'CHECK\x20constraints.\x20Each\x20entry\x20uses\x20operator-as-key\x20shape:\x20{\x20name?,\x20field,\x20<operator>:\x20<value>\x20}\x20where\x20<operator>\x20is\x20one\x20of\x20checkOperations\x20(in,\x20eq,\x20neq,\x20gt,\x20gte,\x20lt,\x20lte).\x20The\x20internal\x20IR\x20shape\x20after\x20ir-builder\x20normalization\x20is\x20{\x20name?,\x20field,\x20op,\x20value\x20},\x20but\x20that\x20is\x20NOT\x20the\x20user\x20input\x20format.','example':a0_0xac60ef(0x256)},{'name':'softDelete','required':![],'type':'object','description':'Enables\x20soft-delete\x20for\x20the\x20table.\x20Shape:\x20{\x20enabled:\x20boolean,\x20reusable?:\x20[{\x20field,\x20length\x20}]\x20}.\x20Keys\x20other\x20than\x20enabled\x20and\x20reusable\x20are\x20rejected\x20at\x20schema\x20load.\x20When\x20enabled,\x20the\x20three\x20contract\x20columns\x20(is_deleted,\x20deleted_at,\x20deleted_by)\x20must\x20be\x20declared\x20in\x20fields.\x20See\x20the\x20softDelete\x20section\x20for\x20the\x20full\x20contract.','example':a0_0xac60ef(0x25c),'notes':a0_0xac60ef(0x222)}],FIELD_TYPES=[{'name':a0_0xac60ef(0x229),'description':'Variable-length\x20text.\x20Length\x20modifier\x20required.','requiresModifier':!![],'modifierFormat':a0_0xac60ef(0x1f2),'example':a0_0xac60ef(0x1f3),'notes':'Explicit\x20length\x20required\x20for\x20cross-dialect\x20portability.'},{'name':'text','description':'Long-form\x20text\x20without\x20length\x20limit\x20(TEXT/CLOB).','requiresModifier':![],'example':'text'},{'name':'integer','description':a0_0xac60ef(0x241),'requiresModifier':![],'example':'integer'},{'name':a0_0xac60ef(0x1fb),'description':a0_0xac60ef(0x24a),'requiresModifier':![],'example':'bigint'},{'name':'decimal','description':'Fixed-point\x20decimal.\x20Precision\x20and\x20scale\x20required.','requiresModifier':!![],'modifierFormat':'decimal:<precision>,<scale>','example':'decimal:15,2','notes':'Precision\x20and\x20scale\x20required\x20for\x20cross-dialect\x20portability.'},{'name':a0_0xac60ef(0x200),'description':a0_0xac60ef(0x22a),'requiresModifier':![],'example':a0_0xac60ef(0x200)},{'name':'date','description':a0_0xac60ef(0x221),'requiresModifier':![],'example':a0_0xac60ef(0x1e5)},{'name':'timestamp','description':a0_0xac60ef(0x252),'requiresModifier':![],'example':a0_0xac60ef(0x24b),'notes':a0_0xac60ef(0x251)},{'name':'uuid','description':'UUID.\x20Native\x20UUID\x20on\x20PostgreSQL,\x20VARCHAR(36)\x20on\x20others.','requiresModifier':![],'example':'uuid'},{'name':'json','description':'JSON\x20column\x20(JSONB\x20on\x20PostgreSQL,\x20JSON\x20on\x20MySQL,\x20CLOB\x20on\x20Oracle).','requiresModifier':![],'example':a0_0xac60ef(0x217)}],CONSTRAINTS=[{'name':'pk','kind':'standalone','description':'Marks\x20field\x20as\x20primary\x20key.','example':'string:36\x20pk'},{'name':'notnull','kind':a0_0xac60ef(0x22b),'description':a0_0xac60ef(0x225),'example':a0_0xac60ef(0x24f)},{'name':'unique','kind':a0_0xac60ef(0x22b),'description':'Single-column\x20unique\x20constraint.','example':'string:32\x20unique'},{'name':a0_0xac60ef(0x215),'kind':'standalone','description':a0_0xac60ef(0x243),'example':'string:64\x20index'},{'name':a0_0xac60ef(0x248),'kind':a0_0xac60ef(0x22b),'deprecated':!![],'description':a0_0xac60ef(0x232),'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':a0_0xac60ef(0x234),'kind':'value','description':'Default\x20value.\x20Single-quoted\x20for\x20strings,\x20raw\x20for\x20numeric/boolean,\x20bare\x20identifier\x20for\x20SQL\x20constants,\x20identifier()\x20for\x20native\x20function\x20calls.','valueFormat':'default:<literal>\x20|\x20default:\x27<string>\x27\x20|\x20default:<constant>\x20|\x20default:<function>()','example':a0_0xac60ef(0x259)},{'name':'fk','kind':a0_0xac60ef(0x1ff),'description':a0_0xac60ef(0x21c),'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':a0_0xac60ef(0x226),'requiredFields':[a0_0xac60ef(0x206),a0_0xac60ef(0x21d),a0_0xac60ef(0x1ec)],'optionalFields':['target','onDelete',a0_0xac60ef(0x22c)],'example':'{\x20type:\x20\x22belongsTo\x22,\x20localKey:\x20\x22category_id\x22,\x20references:\x20\x22category_id\x22,\x20onDelete:\x20\x22restrict\x22\x20}','notes':'`references`\x20is\x20the\x20bare\x20column\x20name\x20in\x20the\x20target\x20table.\x20Target\x20table\x20is\x20auto-derived\x20from\x20the\x20relation\x20key\x20name,\x20or\x20override\x20with\x20`target`.'},{'name':'hasOne','description':a0_0xac60ef(0x240),'requiredFields':[a0_0xac60ef(0x206),'localKey',a0_0xac60ef(0x1ec)],'optionalFields':[a0_0xac60ef(0x208),a0_0xac60ef(0x235),'onUpdate'],'example':a0_0xac60ef(0x224)},{'name':a0_0xac60ef(0x23f),'description':'One-to-many\x20(inverse\x20of\x20belongsTo).\x20Optional\x20inverse\x20declaration\x20on\x20the\x20parent\x20side;\x20does\x20not\x20affect\x20DDL.','requiredFields':['type',a0_0xac60ef(0x21d),a0_0xac60ef(0x1ec)],'optionalFields':[a0_0xac60ef(0x208),'onDelete',a0_0xac60ef(0x22c)],'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_0xac60ef(0x212),'description':a0_0xac60ef(0x1ee),'appliesTo':['onDelete',a0_0xac60ef(0x22c)]},{'name':'restrict','description':a0_0xac60ef(0x262),'appliesTo':['onDelete','onUpdate']},{'name':'setNull','description':'Set\x20FK\x20column\x20to\x20NULL\x20on\x20child\x20rows.','appliesTo':[a0_0xac60ef(0x235),a0_0xac60ef(0x22c)],'notes':'FK\x20field\x20must\x20be\x20nullable.'},{'name':'noAction','description':a0_0xac60ef(0x21e),'appliesTo':[a0_0xac60ef(0x235),'onUpdate']}],CHECK_OPERATIONS=[{'name':'in','description':a0_0xac60ef(0x242),'valueType':'array','example':a0_0xac60ef(0x1ef)},{'name':'eq','description':'Equal\x20to.','valueType':a0_0xac60ef(0x260),'example':a0_0xac60ef(0x23b)},{'name':'neq','description':a0_0xac60ef(0x223),'valueType':'scalar','example':a0_0xac60ef(0x236)},{'name':'gt','description':'Greater\x20than.','valueType':'numeric','example':a0_0xac60ef(0x1e8)},{'name':'gte','description':'Greater\x20than\x20or\x20equal\x20to.','valueType':'numeric','example':a0_0xac60ef(0x227)},{'name':'lt','description':'Less\x20than.','valueType':a0_0xac60ef(0x218),'example':'{\x20field:\x20\x22discount\x22,\x20lt:\x20100\x20}'},{'name':a0_0xac60ef(0x20e),'description':a0_0xac60ef(0x1e3),'valueType':a0_0xac60ef(0x218),'example':a0_0xac60ef(0x202)}],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':'created_by','shorthand':'string:100','nullable':!![],'purpose':'User\x20identifier\x20(username,\x20user_id,\x20or\x20composite\x20token)\x20of\x20the\x20record\x20creator.\x20Set\x20by\x20application\x20layer\x20on\x20INSERT,\x20not\x20by\x20database\x20default.'},{'name':'updated_at','shorthand':a0_0xac60ef(0x24b),'nullable':!![],'purpose':a0_0xac60ef(0x1ea)},{'name':a0_0xac60ef(0x250),'shorthand':a0_0xac60ef(0x237),'nullable':!![],'purpose':'User\x20identifier\x20of\x20the\x20last\x20modifier.\x20Set\x20by\x20application\x20layer\x20on\x20UPDATE,\x20not\x20by\x20database\x20default.'}],'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':'All\x204\x20columns\x20are\x20nullable.\x20The\x20created_by/updated_by\x20columns\x20may\x20be\x20empty\x20for\x20rows\x20inserted\x20by\x20system\x20seeds,\x20migrations,\x20or\x20batch\x20imports\x20that\x20do\x20not\x20have\x20a\x20user\x20context.','relationToRdf':a0_0xac60ef(0x253)}},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_0xac60ef(0x246),'columns':[{'name':IS_DELETED_COLUMN,'type':SOFT_DELETE_COLUMN_TYPES[IS_DELETED_COLUMN],'shorthand':a0_0xac60ef(0x20a),'nullable':![],'purpose':a0_0xac60ef(0x1f5)},{'name':DELETED_AT_COLUMN,'type':SOFT_DELETE_COLUMN_TYPES[DELETED_AT_COLUMN],'shorthand':'timestamp','nullable':!![],'purpose':a0_0xac60ef(0x220)},{'name':DELETED_BY_COLUMN,'type':SOFT_DELETE_COLUMN_TYPES[DELETED_BY_COLUMN],'shorthand':a0_0xac60ef(0x209),'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.',a0_0xac60ef(0x25f),a0_0xac60ef(0x1e7),'Contract\x20column\x20declared\x20with\x20a\x20wrong\x20type:\x20validation\x20ERROR.',a0_0xac60ef(0x1e2)]},'reusableRules':{'description':a0_0xac60ef(0x1fc),'requirements':['The\x20field\x20must\x20be\x20declared\x20in\x20fields\x20(unknown\x20field:\x20ERROR).',a0_0xac60ef(0x204),a0_0xac60ef(0x228),a0_0xac60ef(0x213)],'suffixLength':SOFT_DELETE_SUFFIX_LENGTH,'physicalLengthFormula':a0_0xac60ef(0x261)+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':[a0_0xac60ef(0x1e4),'Single-column\x20UNIQUE\x20constraints\x20on\x20non-string\x20columns\x20are\x20rejected\x20for\x20the\x20same\x20reason\x20(suffix\x20mutation\x20only\x20applies\x20to\x20string/text).'],'suggestion':a0_0xac60ef(0x1f9)},'emittedDdl':{'consistencyCheck':{'namePattern':'chk_<table>_'+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_0xac60ef(0x20d)+DELETED_AT_COLUMN+a0_0xac60ef(0x257)+DELETED_BY_COLUMN+a0_0xac60ef(0x219)+IS_DELETED_COLUMN+a0_0xac60ef(0x233)+DELETED_AT_COLUMN+a0_0xac60ef(0x210)+DELETED_BY_COLUMN+'\x20IS\x20NULL).\x20This\x20keeps\x20the\x20three\x20columns\x20consistent\x20at\x20the\x20data\x20level\x20regardless\x20of\x20the\x20write\x20path.'},'partialIndex':{'description':'Non-unique\x20indexes\x20on\x20soft-delete\x20tables\x20are\x20emitted\x20as\x20PostgreSQL\x20partial\x20indexes\x20with\x20WHERE\x20'+IS_DELETED_COLUMN+'\x20=\x20FALSE.','example':a0_0xac60ef(0x1f0)+IS_DELETED_COLUMN+'\x20=\x20FALSE','notes':a0_0xac60ef(0x1fd)}},'dialectSupport':{'supported':[SOFT_DELETE_PHASE1_DIALECT],'description':a0_0xac60ef(0x205)},'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':'The\x20RDF\x20softDelete\x20block\x20is\x20derived\x20from\x20SDF\x20during\x20payload\x20generate,\x20never\x20written\x20manually.\x20Tables\x20whose\x20database\x20columns\x20include\x20the\x20soft-delete\x20contract\x20must\x20be\x20declared\x20in\x20SDF\x20with\x20a\x20valid\x20softDelete\x20block\x20for\x20payload\x20generate\x20to\x20succeed.'},SHORTHAND_SYNTAX={'format':a0_0xac60ef(0x203),'description':a0_0xac60ef(0x24d),'rules':[a0_0xac60ef(0x25e),'Modifier\x20is\x20mandatory\x20for\x20type\x20\x22string\x22\x20(length)\x20and\x20\x22decimal\x22\x20(precision,scale).','Standalone\x20constraints\x20(pk,\x20notnull,\x20unique,\x20index)\x20take\x20no\x20value.\x20The\x20legacy\x20autoUpdate\x20token\x20is\x20still\x20parsed\x20for\x20backward\x20compatibility\x20but\x20is\x20deprecated\x20and\x20has\x20no\x20functional\x20effect.','Value\x20constraints\x20(default,\x20fk)\x20require\x20constraint:value\x20format.',a0_0xac60ef(0x1e9),a0_0xac60ef(0x23a)],'examples':[{'input':a0_0xac60ef(0x211),'meaning':a0_0xac60ef(0x263)},{'input':'string:255\x20notnull','meaning':'VARCHAR(255)\x20NOT\x20NULL'},{'input':a0_0xac60ef(0x1e1),'meaning':a0_0xac60ef(0x20f)},{'input':'boolean\x20default:true','meaning':'BOOLEAN\x20DEFAULT\x20TRUE'},{'input':'string:100\x20default:\x27pending\x27','meaning':a0_0xac60ef(0x201)},{'input':'timestamp\x20default:now()','meaning':'TIMESTAMP\x20DEFAULT\x20<native_now\x20per\x20dialect>'},{'input':'string:36\x20fk:category.id','meaning':a0_0xac60ef(0x22d)},{'input':a0_0xac60ef(0x23d),'meaning':'VARCHAR(64)\x20with\x20single-column\x20index'}]},NAMING_RULES={'tableName':{'format':a0_0xac60ef(0x214),'description':a0_0xac60ef(0x264)},'fieldName':{'format':a0_0xac60ef(0x214),'description':a0_0xac60ef(0x23c)},'constraintName':{'format':'<prefix>_<table>_<suffix>','defaultMaxLength':0x1e,'fallbackStrategy':a0_0xac60ef(0x216),'description':'Constraint\x20names\x20auto-generated\x20with\x20type-specific\x20prefix\x20(pk,\x20fk,\x20idx,\x20uq,\x20ck)\x20and\x20dialect-specific\x20max\x20length.'},'compositeShortName':{'description':a0_0xac60ef(0x1e6)}},DIALECT_SUPPORT=[{'name':a0_0xac60ef(0x266),'driver':'pg','booleanStorage':a0_0xac60ef(0x24c)},{'name':'mysql','driver':a0_0xac60ef(0x25d),'booleanStorage':'VARCHAR\x20(literal\x20\x22true\x22/\x22false\x22)'},{'name':'oracle','driver':'oracledb','booleanStorage':'VARCHAR2\x20with\x20CHECK\x20constraint'},{'name':a0_0xac60ef(0x22f),'driver':a0_0xac60ef(0x21f),'booleanStorage':a0_0xac60ef(0x1eb)}],DBSCHEMA_CATALOG={'schemaVersion':SCHEMA_VERSION,'source':SOURCE,'summary':{'totalDefineModelOptions':DEFINE_MODEL_OPTIONS[a0_0xac60ef(0x239)],'totalFieldTypes':FIELD_TYPES['length'],'totalConstraints':CONSTRAINTS[a0_0xac60ef(0x239)],'totalRelationTypes':RELATION_TYPES[a0_0xac60ef(0x239)],'totalReferentialActions':REFERENTIAL_ACTIONS[a0_0xac60ef(0x239)],'totalCheckOperations':CHECK_OPERATIONS['length'],'totalAuditColumns':AUDIT_COLUMNS[a0_0xac60ef(0x249)]['length'],'totalDialects':DIALECT_SUPPORT['length']},'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[a0_0xac60ef(0x1f1)]={'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};