@restforgejs/platform 4.3.8 → 5.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (193) hide show
  1. package/bin/sdf-tools.exe +0 -0
  2. package/build-info.json +2 -2
  3. package/cli/consumer-deploy.js +1 -1
  4. package/cli/consumer.js +1 -1
  5. package/generators/cli/init.js +4 -104
  6. package/generators/cli/payload/migrate.js +96 -96
  7. package/generators/cli/schema/list.js +82 -18
  8. package/generators/cli/schema/migrate.js +23 -3
  9. package/generators/lib/dbschema-kit/apply-engine.js +211 -46
  10. package/generators/lib/dbschema-kit/diff-engine.js +715 -703
  11. package/generators/lib/dbschema-kit/emitters/alter-table.js +96 -2
  12. package/generators/lib/dbschema-kit/introspect-mapper.js +9 -0
  13. package/generators/lib/migrate/backend-payload-migrator.js +221 -221
  14. package/generators/lib/migrate/field-type-resolver.js +325 -319
  15. package/generators/lib/migrate/label-generator.js +38 -38
  16. package/generators/lib/migrate/migrate-runner.js +244 -38
  17. package/generators/lib/migrate/naming.js +52 -43
  18. package/generators/lib/migrate/sql-parser.js +124 -124
  19. package/generators/lib/templates/dashboard-catalog.js +1 -1
  20. package/generators/lib/templates/db-connection-env.js +1 -1
  21. package/generators/lib/templates/dbschema-catalog.js +1 -1
  22. package/generators/lib/templates/field-validation-catalog.js +1 -1
  23. package/generators/lib/templates/mysql-template.js +1 -1
  24. package/generators/lib/templates/oracle-template.js +1 -1
  25. package/generators/lib/templates/postgres-template.js +1 -1
  26. package/generators/lib/templates/query-declarative-catalog.js +1 -1
  27. package/generators/lib/templates/sqlite-template.js +1 -1
  28. package/integrity-manifest.json +18 -18
  29. package/node_modules/brace-expansion/index.js +1 -1
  30. package/node_modules/brace-expansion/package.json +1 -1
  31. package/node_modules/dayjs/CHANGELOG.md +7 -0
  32. package/node_modules/dayjs/README.md +12 -10
  33. package/node_modules/dayjs/dayjs.min.js +1 -1
  34. package/node_modules/dayjs/esm/constant.js +1 -1
  35. package/node_modules/dayjs/esm/plugin/duration/index.js +5 -4
  36. package/node_modules/dayjs/locale.json +1 -1
  37. package/node_modules/dayjs/package.json +2 -2
  38. package/node_modules/dayjs/plugin/duration.js +1 -1
  39. package/node_modules/tmp/lib/tmp.js +37 -7
  40. package/node_modules/tmp/package.json +4 -16
  41. package/package.json +1 -1
  42. package/scripts/verify-integrity.js +1 -1
  43. package/server.js +1 -1
  44. package/src/components/handlers/adjust_handler.js +1 -1
  45. package/src/components/handlers/audit_handler.js +1 -1
  46. package/src/components/handlers/delete_handler.js +1 -1
  47. package/src/components/handlers/export_handler.js +1 -1
  48. package/src/components/handlers/import_handler.js +1 -1
  49. package/src/components/handlers/insert_handler.js +1 -1
  50. package/src/components/handlers/update_handler.js +1 -1
  51. package/src/components/handlers/upload_handler.js +1 -1
  52. package/src/components/handlers/workflow_handler.js +1 -1
  53. package/src/components/integrations/webhook.js +1 -1
  54. package/src/consumers/baseConsumer.js +1 -1
  55. package/src/consumers/declarativeMapper.js +1 -1
  56. package/src/consumers/handlers/apiHandler.js +1 -1
  57. package/src/consumers/handlers/consoleHandler.js +1 -1
  58. package/src/consumers/handlers/databaseHandler.js +1 -1
  59. package/src/consumers/handlers/index.js +1 -1
  60. package/src/consumers/handlers/kafkaHandler.js +1 -1
  61. package/src/consumers/index.js +1 -1
  62. package/src/consumers/messageTransformer.js +1 -1
  63. package/src/consumers/validator.js +1 -1
  64. package/src/core/db/dialect/base-dialect.js +1 -1
  65. package/src/core/db/dialect/index.js +1 -1
  66. package/src/core/db/dialect/mysql-dialect.js +1 -1
  67. package/src/core/db/dialect/oracle-dialect.js +1 -1
  68. package/src/core/db/dialect/postgres-dialect.js +1 -1
  69. package/src/core/db/dialect/sqlite-dialect.js +1 -1
  70. package/src/core/db/flatten-helper.js +1 -1
  71. package/src/core/db/query-builder-error.js +1 -1
  72. package/src/core/db/query-builder.js +1 -1
  73. package/src/core/db/relation-helper.js +1 -1
  74. package/src/core/handlers/delete_handler.js +1 -1
  75. package/src/core/handlers/insert_handler.js +1 -1
  76. package/src/core/handlers/update_handler.js +1 -1
  77. package/src/core/models/base-model.js +1 -1
  78. package/src/core/utils/cache-manager.js +1 -1
  79. package/src/core/utils/component-engine.js +1 -1
  80. package/src/core/utils/context-builder.js +1 -1
  81. package/src/core/utils/datetime-formatter.js +1 -1
  82. package/src/core/utils/datetime-parser.js +1 -1
  83. package/src/core/utils/db.js +1 -1
  84. package/src/core/utils/logger.js +1 -1
  85. package/src/core/utils/payload-loader.js +1 -1
  86. package/src/core/utils/security-checks.js +1 -1
  87. package/src/middleware/body-options.js +1 -1
  88. package/src/middleware/cors.js +1 -1
  89. package/src/middleware/idempotency.js +1 -1
  90. package/src/middleware/rate-limiter.js +1 -1
  91. package/src/middleware/request-logger.js +1 -1
  92. package/src/middleware/security-headers.js +1 -1
  93. package/src/models/base-model-mysql.js +1 -1
  94. package/src/models/base-model-oracle.js +1 -1
  95. package/src/models/base-model-sqlite.js +1 -1
  96. package/src/models/base-model.js +1 -1
  97. package/src/pro/caching/redis-client.js +1 -1
  98. package/src/pro/caching/redis-helper.js +1 -1
  99. package/src/pro/consumers/baseConsumer.js +1 -1
  100. package/src/pro/consumers/declarativeMapper.js +1 -1
  101. package/src/pro/consumers/handlers/apiHandler.js +1 -1
  102. package/src/pro/consumers/handlers/consoleHandler.js +1 -1
  103. package/src/pro/consumers/handlers/databaseHandler.js +1 -1
  104. package/src/pro/consumers/handlers/index.js +1 -1
  105. package/src/pro/consumers/handlers/kafkaHandler.js +1 -1
  106. package/src/pro/consumers/index.js +1 -1
  107. package/src/pro/consumers/messageTransformer.js +1 -1
  108. package/src/pro/consumers/validator.js +1 -1
  109. package/src/pro/database/base-model-mysql.js +1 -1
  110. package/src/pro/database/base-model-oracle.js +1 -1
  111. package/src/pro/database/base-model-sqlite.js +1 -1
  112. package/src/pro/database/db-mysql.js +1 -1
  113. package/src/pro/database/db-oracle.js +1 -1
  114. package/src/pro/database/db-sqlite.js +1 -1
  115. package/src/pro/excel/excel-generator.js +1 -1
  116. package/src/pro/excel/excel-parser.js +1 -1
  117. package/src/pro/excel/export-service.js +1 -1
  118. package/src/pro/excel/export_handler.js +1 -1
  119. package/src/pro/excel/import-service.js +1 -1
  120. package/src/pro/excel/import-validator.js +1 -1
  121. package/src/pro/excel/import_handler.js +1 -1
  122. package/src/pro/excel/upsert-builder.js +1 -1
  123. package/src/pro/idgen/idgen-routes.js +1 -1
  124. package/src/pro/integrations/lookup-resolver.js +1 -1
  125. package/src/pro/integrations/upload-handler-v2.js +1 -1
  126. package/src/pro/integrations/upload-handler.js +1 -1
  127. package/src/pro/integrations/webhook.js +1 -1
  128. package/src/pro/locking/lock-routes.js +1 -1
  129. package/src/pro/locking/resource-lock-manager.js +1 -1
  130. package/src/pro/messaging/kafkaConsumerService.js +1 -1
  131. package/src/pro/messaging/kafkaService.js +1 -1
  132. package/src/pro/messaging/messagehubService.js +1 -1
  133. package/src/pro/messaging/rabbitmqService.js +1 -1
  134. package/src/pro/scheduler/job-manager.js +1 -1
  135. package/src/pro/scheduler/job-routes.js +1 -1
  136. package/src/pro/scheduler/job-validator.js +1 -1
  137. package/src/pro/storage/base-storage-provider.js +1 -1
  138. package/src/pro/storage/file-metadata-helper.js +1 -1
  139. package/src/pro/storage/index.js +1 -1
  140. package/src/pro/storage/local-storage-provider.js +1 -1
  141. package/src/pro/storage/s3-storage-provider.js +1 -1
  142. package/src/pro/storage/upload-cleanup-job.js +1 -1
  143. package/src/pro/storage/upload-cleanup-scheduler.js +1 -1
  144. package/src/pro/storage/upload-pending-tracker.js +1 -1
  145. package/src/pro/websocket/broadcast-helper.js +1 -1
  146. package/src/pro/websocket/index.js +1 -1
  147. package/src/pro/websocket/livesync-server.js +1 -1
  148. package/src/pro/websocket/ws-broadcaster.js +1 -1
  149. package/src/services/export-service.js +1 -1
  150. package/src/services/import-service.js +1 -1
  151. package/src/services/kafkaConsumerService.js +1 -1
  152. package/src/services/kafkaService.js +1 -1
  153. package/src/services/messagehubService.js +1 -1
  154. package/src/services/rabbitmqService.js +1 -1
  155. package/src/utils/cache-invalidation-registry.js +1 -1
  156. package/src/utils/cache-manager.js +1 -1
  157. package/src/utils/component-engine.js +1 -1
  158. package/src/utils/config-extractor.js +1 -1
  159. package/src/utils/consumerLogger.js +1 -1
  160. package/src/utils/context-builder.js +1 -1
  161. package/src/utils/dashboard-helpers.js +1 -1
  162. package/src/utils/dateHelper.js +1 -1
  163. package/src/utils/datetime-formatter.js +1 -1
  164. package/src/utils/datetime-parser.js +1 -1
  165. package/src/utils/db-bootstrap.js +1 -1
  166. package/src/utils/db-mysql.js +1 -1
  167. package/src/utils/db-oracle.js +1 -1
  168. package/src/utils/db-sqlite.js +1 -1
  169. package/src/utils/db.js +1 -1
  170. package/src/utils/demo-generator.js +1 -1
  171. package/src/utils/excel-generator.js +1 -1
  172. package/src/utils/excel-parser.js +1 -1
  173. package/src/utils/file-watcher.js +1 -1
  174. package/src/utils/id-generator.js +1 -1
  175. package/src/utils/idempotency-manager.js +1 -1
  176. package/src/utils/import-validator.js +1 -1
  177. package/src/utils/license-client.js +1 -1
  178. package/src/utils/lock-manager.js +1 -1
  179. package/src/utils/logger.js +1 -1
  180. package/src/utils/lookup-resolver.js +1 -1
  181. package/src/utils/payload-loader.js +1 -1
  182. package/src/utils/processor-response.js +1 -1
  183. package/src/utils/rabbitmq.js +1 -1
  184. package/src/utils/redis-client.js +1 -1
  185. package/src/utils/redis-helper.js +1 -1
  186. package/src/utils/request-scope.js +1 -1
  187. package/src/utils/security-checks.js +1 -1
  188. package/src/utils/service-resolver.js +1 -1
  189. package/src/utils/shutdown-coordinator.js +1 -1
  190. package/src/utils/trusted-keys.js +1 -1
  191. package/src/utils/upload-handler.js +1 -1
  192. package/src/utils/upsert-builder.js +1 -1
  193. package/src/utils/workflow-hook-executor.js +1 -1
@@ -1,124 +1,124 @@
1
- 'use strict';
2
-
3
- /**
4
- * Port dari packages/designer/src/migrators/sql_parser.rs.
5
- * Regex-based parser untuk SELECT/JOIN dari `datatablesQuery` string.
6
- */
7
-
8
- const SELECT_RE = /select\s+([\s\S]*?)\s+from\s+/i;
9
- const FROM_RE = /\bfrom\s+([\s\S]*)/i;
10
- const JOIN_SPLIT_RE = /\b(left\s+join|inner\s+join|right\s+join|cross\s+join|join)\b/i;
11
- const JOIN_SPLIT_RE_GLOBAL = /\b(left\s+join|inner\s+join|right\s+join|cross\s+join|join)\b/ig;
12
- const WHERE_SPLIT_RE = /\s+where\s+/i;
13
- const ORDER_SPLIT_RE = /\s+order\s+/i;
14
- const ON_CLAUSE_RE = /([\s\S]*?)\s+on\s+([\s\S]*)/i;
15
- const JOIN_COND_RE = /(\w+)\.(\w+)\s*=\s*(\w+)\.(\w+)/;
16
-
17
- function stripSchema(name) {
18
- const idx = name.lastIndexOf('.');
19
- return idx >= 0 ? name.slice(idx + 1) : name;
20
- }
21
-
22
- function parseTableRef(refstr) {
23
- const afterWhere = refstr.split(WHERE_SPLIT_RE)[0].trim();
24
- const cleaned = afterWhere.split(ORDER_SPLIT_RE)[0].trim();
25
- const tokens = cleaned.split(/\s+/).filter(Boolean);
26
- if (tokens.length === 0) return { tableName: '', alias: '' };
27
- const tableName = stripSchema(tokens[0]);
28
- const alias = tokens.length > 1 ? tokens[1] : '';
29
- return { tableName, alias };
30
- }
31
-
32
- function parseJoinCondition(condition, mainAlias) {
33
- const m = JOIN_COND_RE.exec(condition.trim());
34
- if (!m) return { localColumn: '', remoteColumn: '' };
35
- const alias1 = m[1];
36
- const col1 = m[2];
37
- const col2 = m[4];
38
- if (alias1 === mainAlias) {
39
- return { localColumn: col1, remoteColumn: col2 };
40
- }
41
- return { localColumn: col2, remoteColumn: col1 };
42
- }
43
-
44
- function parseDatatablesQuery(sql) {
45
- const trimmed = String(sql || '').trim();
46
- if (!trimmed) {
47
- return { selectColumns: [], joins: [], mainTable: '', mainAlias: '' };
48
- }
49
- const sqlClean = trimmed.replace(/;+\s*$/, '');
50
-
51
- const selectMatch = SELECT_RE.exec(sqlClean);
52
- if (!selectMatch) {
53
- return { selectColumns: [], joins: [], mainTable: '', mainAlias: '' };
54
- }
55
-
56
- const columnsStr = selectMatch[1];
57
- const rawColumns = columnsStr.split(',');
58
- const selectColumns = [];
59
- for (let i = 0; i < rawColumns.length; i++) {
60
- const col = rawColumns[i].trim();
61
- if (!col) continue;
62
- const parts = col.split('.');
63
- let tableAlias = '';
64
- let name;
65
- if (parts.length >= 2) {
66
- tableAlias = parts[parts.length - 2].trim();
67
- name = parts[parts.length - 1].trim();
68
- } else {
69
- name = parts[0].trim();
70
- }
71
- selectColumns.push({ name, tableAlias, position: i + 1 });
72
- }
73
-
74
- const fromMatch = FROM_RE.exec(sqlClean);
75
- if (!fromMatch) {
76
- return { selectColumns, joins: [], mainTable: '', mainAlias: '' };
77
- }
78
- const fromClause = fromMatch[1];
79
-
80
- // Python re.split with capture group returns [before, kw, body, kw, body, ...]
81
- const parts = [];
82
- let lastEnd = 0;
83
- JOIN_SPLIT_RE_GLOBAL.lastIndex = 0;
84
- let match;
85
- while ((match = JOIN_SPLIT_RE_GLOBAL.exec(fromClause)) !== null) {
86
- parts.push(fromClause.slice(lastEnd, match.index));
87
- parts.push(match[0]);
88
- lastEnd = match.index + match[0].length;
89
- }
90
- parts.push(fromClause.slice(lastEnd));
91
-
92
- const mainRef = parseTableRef(parts[0] || '');
93
- const mainTable = mainRef.tableName;
94
- const mainAlias = mainRef.alias;
95
-
96
- const joins = [];
97
- let j = 1;
98
- while (j + 1 < parts.length) {
99
- const joinBody = parts[j + 1].trim();
100
- const onMatch = ON_CLAUSE_RE.exec(joinBody);
101
- if (!onMatch) {
102
- j += 2;
103
- continue;
104
- }
105
- const tableRef = onMatch[1];
106
- const condition = onMatch[2];
107
- const ref = parseTableRef(tableRef);
108
- const cond = parseJoinCondition(condition, mainAlias);
109
- joins.push({
110
- tableName: ref.tableName,
111
- tableAlias: ref.alias,
112
- localColumn: cond.localColumn,
113
- remoteColumn: cond.remoteColumn
114
- });
115
- j += 2;
116
- }
117
-
118
- return { selectColumns, joins, mainTable, mainAlias };
119
- }
120
-
121
- module.exports = {
122
- parseDatatablesQuery,
123
- stripSchema
124
- };
1
+ 'use strict';
2
+
3
+ /**
4
+ * Port dari packages/designer/src/migrators/sql_parser.rs.
5
+ * Regex-based parser untuk SELECT/JOIN dari `datatablesQuery` string.
6
+ */
7
+
8
+ const SELECT_RE = /select\s+([\s\S]*?)\s+from\s+/i;
9
+ const FROM_RE = /\bfrom\s+([\s\S]*)/i;
10
+ const JOIN_SPLIT_RE = /\b(left\s+join|inner\s+join|right\s+join|cross\s+join|join)\b/i;
11
+ const JOIN_SPLIT_RE_GLOBAL = /\b(left\s+join|inner\s+join|right\s+join|cross\s+join|join)\b/ig;
12
+ const WHERE_SPLIT_RE = /\s+where\s+/i;
13
+ const ORDER_SPLIT_RE = /\s+order\s+/i;
14
+ const ON_CLAUSE_RE = /([\s\S]*?)\s+on\s+([\s\S]*)/i;
15
+ const JOIN_COND_RE = /(\w+)\.(\w+)\s*=\s*(\w+)\.(\w+)/;
16
+
17
+ function stripSchema(name) {
18
+ const idx = name.lastIndexOf('.');
19
+ return idx >= 0 ? name.slice(idx + 1) : name;
20
+ }
21
+
22
+ function parseTableRef(refstr) {
23
+ const afterWhere = refstr.split(WHERE_SPLIT_RE)[0].trim();
24
+ const cleaned = afterWhere.split(ORDER_SPLIT_RE)[0].trim();
25
+ const tokens = cleaned.split(/\s+/).filter(Boolean);
26
+ if (tokens.length === 0) return { tableName: '', alias: '' };
27
+ const tableName = stripSchema(tokens[0]);
28
+ const alias = tokens.length > 1 ? tokens[1] : '';
29
+ return { tableName, alias };
30
+ }
31
+
32
+ function parseJoinCondition(condition, mainAlias) {
33
+ const m = JOIN_COND_RE.exec(condition.trim());
34
+ if (!m) return { localColumn: '', remoteColumn: '' };
35
+ const alias1 = m[1];
36
+ const col1 = m[2];
37
+ const col2 = m[4];
38
+ if (alias1 === mainAlias) {
39
+ return { localColumn: col1, remoteColumn: col2 };
40
+ }
41
+ return { localColumn: col2, remoteColumn: col1 };
42
+ }
43
+
44
+ function parseDatatablesQuery(sql) {
45
+ const trimmed = String(sql || '').trim();
46
+ if (!trimmed) {
47
+ return { selectColumns: [], joins: [], mainTable: '', mainAlias: '' };
48
+ }
49
+ const sqlClean = trimmed.replace(/;+\s*$/, '');
50
+
51
+ const selectMatch = SELECT_RE.exec(sqlClean);
52
+ if (!selectMatch) {
53
+ return { selectColumns: [], joins: [], mainTable: '', mainAlias: '' };
54
+ }
55
+
56
+ const columnsStr = selectMatch[1];
57
+ const rawColumns = columnsStr.split(',');
58
+ const selectColumns = [];
59
+ for (let i = 0; i < rawColumns.length; i++) {
60
+ const col = rawColumns[i].trim();
61
+ if (!col) continue;
62
+ const parts = col.split('.');
63
+ let tableAlias = '';
64
+ let name;
65
+ if (parts.length >= 2) {
66
+ tableAlias = parts[parts.length - 2].trim();
67
+ name = parts[parts.length - 1].trim();
68
+ } else {
69
+ name = parts[0].trim();
70
+ }
71
+ selectColumns.push({ name, tableAlias, position: i + 1 });
72
+ }
73
+
74
+ const fromMatch = FROM_RE.exec(sqlClean);
75
+ if (!fromMatch) {
76
+ return { selectColumns, joins: [], mainTable: '', mainAlias: '' };
77
+ }
78
+ const fromClause = fromMatch[1];
79
+
80
+ // Python re.split with capture group returns [before, kw, body, kw, body, ...]
81
+ const parts = [];
82
+ let lastEnd = 0;
83
+ JOIN_SPLIT_RE_GLOBAL.lastIndex = 0;
84
+ let match;
85
+ while ((match = JOIN_SPLIT_RE_GLOBAL.exec(fromClause)) !== null) {
86
+ parts.push(fromClause.slice(lastEnd, match.index));
87
+ parts.push(match[0]);
88
+ lastEnd = match.index + match[0].length;
89
+ }
90
+ parts.push(fromClause.slice(lastEnd));
91
+
92
+ const mainRef = parseTableRef(parts[0] || '');
93
+ const mainTable = mainRef.tableName;
94
+ const mainAlias = mainRef.alias;
95
+
96
+ const joins = [];
97
+ let j = 1;
98
+ while (j + 1 < parts.length) {
99
+ const joinBody = parts[j + 1].trim();
100
+ const onMatch = ON_CLAUSE_RE.exec(joinBody);
101
+ if (!onMatch) {
102
+ j += 2;
103
+ continue;
104
+ }
105
+ const tableRef = onMatch[1];
106
+ const condition = onMatch[2];
107
+ const ref = parseTableRef(tableRef);
108
+ const cond = parseJoinCondition(condition, mainAlias);
109
+ joins.push({
110
+ tableName: ref.tableName,
111
+ tableAlias: ref.alias,
112
+ localColumn: cond.localColumn,
113
+ remoteColumn: cond.remoteColumn
114
+ });
115
+ j += 2;
116
+ }
117
+
118
+ return { selectColumns, joins, mainTable, mainAlias };
119
+ }
120
+
121
+ module.exports = {
122
+ parseDatatablesQuery,
123
+ stripSchema
124
+ };
@@ -1 +1 @@
1
- const a0_0x2459e2=a0_0x4b8a;(function(_0x1e901a,_0x5e33ae){const _0x3524d2=a0_0x4b8a,_0x40b5ca=_0x1e901a();while(!![]){try{const _0x12e3b2=-parseInt(_0x3524d2(0xbb))/0x1*(parseInt(_0x3524d2(0x104))/0x2)+parseInt(_0x3524d2(0xc4))/0x3*(-parseInt(_0x3524d2(0xd6))/0x4)+parseInt(_0x3524d2(0xfe))/0x5*(parseInt(_0x3524d2(0xce))/0x6)+parseInt(_0x3524d2(0xff))/0x7*(parseInt(_0x3524d2(0xb0))/0x8)+parseInt(_0x3524d2(0xd9))/0x9*(-parseInt(_0x3524d2(0xd8))/0xa)+parseInt(_0x3524d2(0xc8))/0xb+parseInt(_0x3524d2(0xf9))/0xc;if(_0x12e3b2===_0x5e33ae)break;else _0x40b5ca['push'](_0x40b5ca['shift']());}catch(_0x3c1020){_0x40b5ca['push'](_0x40b5ca['shift']());}}}(a0_0x1b7d,0xafe7b));function a0_0x1b7d(){const _0x1769b2=['zMLSztPXDwvYEs88Cgf0Ad4VDhjLBMqUC3fS','DhjLBMq','mJDguMXuA3m','iJi4odqI','msbYB3CGW5CGmIbJB2X1Bw5Z','msbYB3CGW5CGmIbJB2XZlcbVDxrWDxqGy29SDw1UCYaNzgLYzwn0Aw9UjYWGj3bJDcC','mZa0nZG4u1fwsLbX','sgvHzgXPBMuGBwv0CMLJihDPDgGGDhjLBMqGy2HPCcbHBMqGC3bHCMTSAw5Lig1PBMKTy2HHCNqGzM9YihnOB3j0ihDPBMrVD3mGkdCGzgf5CYWGmtiGBw9UDgHZlcbLDgmUks4Gu3vPDgfIBguGzM9YihDPzgDLDhmGBgLRzsaNqxzLCMfNzsbeywLSEsbtywXLCYCU','tIbYB3DZimoxie0Gy29SCW','yM9VBgvHBG','B2jQzwn0iokaLcb2ywX1zxmGzM9YigrLy2XHCMvKihbHCMfTCYaODMfSAwrHDgvKigfNywLUC3qGCgfYyw1ZignVBNrYywn0oYbTAxnZAw5NihjLCxvPCMvKiokgKIa0mdaSihr5CguGBwLZBwf0y2GG4OAsidqWmcK','yxjYyxKGB2yGB2jQzwn0CW','mZGZmtz1yvjdvxC','BNvTyMvY','zw5HyMXLza','Aw5OzxjPDhmGq0fdsevFvfrmigvUDG','Cgn0','tvvtvcbZDgfYDcb3AxrOicDKyxnOlsCGChjLzML4','v2HLBIbJywnOzs5LBMfIBgvKid09psb0CNvLigfUzcbPBNzHBgLKyxrLCYbPCYbUB24Tzw1WDhK6ihzHBgLKyxrVCIbLEhrYywn0CYb0ywjSzsbJyw5KAwrHDgvZigzYB20GD2LKz2v0ifnrtcaOCMvNzxGGrLjpts9kt0LoksWGy3jVC3mTCMvMzxjLBMnLCYb3AxrOig1LDgfKyxrHl3TWCM9Qzwn0Fs5QC29UicHLBMrWB2LUDhnBkL0UDgfIBgvoyw1LihDOzxjLihr5CguGpt09icjTB2r1BguIksWGyw5KigfZC2vYDhmGzxf1ywXPDhKGB2yGzxHWzwn0zwqGDNmGzgvJBgfYzwqGC2v0CY4GtwLZBwf0y2HLCYbHCMuGCMvWB3j0zwqGCgvYignHDgvNB3j5icHTAxnZAw5NlcbLEhrYysWGDw5TyxrJAgvKks4','C2nHBgfYihbYAw1PDgL2zq','nJmWnZK2t0zXAMHs','tgLZDcbVzIbduLveihrHyMXLig5HBwvZihrOyxqSihDOzw4GD3jPDhrLBIWGD2LSBcb0CMLNz2vYigLUDMfSAwrHDgLVBIbVzIb0AgLZigrHC2HIB2fYzcbJywnOzs4','mJbmt3zRDwq','ndyWmdm3n0Phq1f3Ea','sgvHzgXPBMuGBwv0CMLJihDPDgGGDhjLBMqGy2HPCcbHBMqGyNjLywTKB3DUigfJCM9ZCYbJyxrLz29YAwvZlIbtDwL0ywjSzsbMB3iGD2LKz2v0CYbSAwTLicDfEhbLy3rLzcbfyxjUAw5NCYCGDgHHDcbZAg93ihrVDgfSihzHBhvLlcbWzxjJzw50ywDLignOyw5NzsWGyw5KihbLCI1JyxrLz29YEsbJB250CMLIDxrPB24U','EYaIzgLYzwn0Aw9UiJOGiNvWiIWGiNbJDci6iciYlJiIih0','ugvYlwTLEsbIyxnLzcbVBIbZy2fSyxjdB2XSyxbZzvj1BgvZigjLBg93lG','ue9tva','zNjLztSGlNnXBcbYzwnVBw1LBMrLzcbMB3iGzwrPDg9YigHPz2HSAwDODa','pJ0GmcaOC2vJB25KCYK','vxbKyxrPBMCGyw4Gu1fmigzPBguGCMvXDwLYzxmGCMvNzw5LCMf0Aw5NihrOzsbKyxnOyM9HCMqGBw9KDwXLicGNy29KzwDLBL9JCMvHDgvFzgfZAgjVyxjKjYKGzM9YignOyw5NzxmGDg8GDgfRzsbLzMzLy3qU','CgfYyw1Z','DhLWzq','A2v54OAszMLSztPYzwXHDgL2zs9WyxrOl3rVl3f1zxj5lNnXBa','u0vmrunuicOGrLjptsbZDg9JA19PBMjVDw5KifDirvjfievyvfjbq1qOwuvbuIbguK9nigLUyM91BMrFzgf0zsKGpsa6EwvHCG','oNbHCMfTtMfTzq','D2LKz2v0lNf1zxj5icHZAw5NDwXHCIK','zNjVBNrLBMqTy29Uy2vYBG','l2fWAs97ChjVAMvJDh0VE25HBwv9l2rHC2HIB2fYza','iNnOB3bWAw5Nx2nHDgvNB3jPzxmIoIb7icjPDgvTCYi6ifT7icjUyw1LiJOGiKXHBMrZiIb9lcb7icjUyw1LiJOGiKHVDxnLCYiGFv0GFq','qsb3AwrNzxqGtvvtvcbKzwnSyxjLigv4ywn0BhKGB25Lig9MoIaNCxvLCNKNie9sicDXDwvYAwvZjY4GqM90AcbVCIbUzwL0AgvYigLZihjLAMvJDgvKlG','DMfSDwuGkg9Yign1CNjLBNqP','iML0zw1ZiJOGw3SGiMXHyMvSiJOGiLnOB2vZiIWGiNzHBhvLiJOGiJC2nJaIih0Sic4UlL0','rgfZAgjVyxjKigvUzhbVAw50ig1HEsbVChqTAw4GDg8GuMvKAxmTyMfZzwqGy2fJAguUifbHDhrLCM4GzM9SBg93CYbWCM9JzxnZB3iGy2fJAguGkhnLzsbMzwf0lwnHy2HLlM1Kks4Gq2fJAguGC2nVCguGAxmGDgHLigz1BgWGCMvZCg9UC2uGzw52zwXVCgu7ig9UzsbJywnOzsbLBNrYEsbWzxiGkhbHCMfTCYaRihDPzgDLDhnBxsbZDwjZzxqPignVBwjPBMf0Aw9UlG','B2jQzwn0','Ahr0Chm6lY9Yzxn0zM9Yz2uUzgv2l2rVy3mVC2vYDMvYl3f1zxj5lwrHDgeVzgfZAgjVyxjK','tIbYB3DZimoxidiGy29SDw1UCW','CxvLCNK','vg9Nz2XLignHy2HLigzLyxr1CMuGzM9YihrOAxmGzgfZAgjVyxjKlG','zgfZAgjVyxjKihbHEwXVywq','twv0CMLJicSGrg9UDxqGqNjLywTKB3DU','zgLYzwn0Aw9U','z2vUzxjHDgLVBIb0Aw1LicHot1qGCNvUDgLTzsK','zxHWB3j0CW','q29SBgfWC2uGDg8GB2jQzwn0ihDOB3nLigTLExmGyxjLifnrtcbJB2X1Bw4GBMfTzxmGkgXVD2vYy2fZzwqPlG','mZG3ntKXnJbNwxjeB08','vMLZDwfSihzHCMLHBNqGkgrVBNv0lcbIyxiSihbPzsWGyxjLysKGAxmGysbMCM9UDgvUzcbYzw5KzxjPBMCGy29Uy2vYBIaOC2vWyxjHDgLVBIbVzIbJB25JzxjUCYKU','rgvMyxvSDcb2ywX1zsbHChbSAwvKihDOzw4GDgHLihjLCxvLC3qGB21PDhmGDgHPCYbWyxjHBs4GvMfSAwrHDg9YigrVzxmGtK9uihn0CMLJDgX5ihr5CguTy2HLy2SGzgvMyxvSDdSGCNvUDgLTzsbPCYbYzxnWB25ZAwjSzsbMB3iGy29TCgf0AwjPBgL0Es4','vMLZDwfSignVBg9YigLZigeGzNjVBNrLBMqGCMvUzgvYAw5NignVBMnLCM4U','twv0CMLJicSGu3bHCMTSAw5L','nJu1uMnZr0n3','ntzTCurjtxe','twv0CMLJicSGuhjVz3jLC3mGDg8Gr29HBa','zMLSztPXDwvYEs88Cgf0Ad4VyNjLywTKB3DUlNnXBa','Dg9WlwXLDMvSicDWyxjHBxmNig9IAMvJDa','rNjVBNrLBMqGy29TChv0zxmGDg9Fz29HBca9ihrHCMDLDcaTihzHBhvLigfUzcbWy3qGpsbYB3vUzcH2ywX1zsaVihrHCMDLDcaQideWmcKGzM9YihrOzsbWCM9NCMvZCYbIyxiUifzPC3vHBcb3Awr0AcbPCYbWCMvZzw50yxrPB25HBcbHBMqGBxvZDcbot1qGBgL2zsbPBIb0AguGyMfJA2vUzcbWyxLSB2fKlIbjzIbWCM9NCMvZCYbPBNzVBhzLCYbJB21WBgv4igj1C2LUzxnZihj1BgvZicHLlMCUigv4y2X1zguGD2vLA2vUzhmSihbYB3jHDgvKihDVCMTKyxLZksWGDxnLigeGC2LUz2XLig11BhrPlwnVBhvTBIbXDwvYEsbZBYaNCgn0jYbPCYbHihn0ywjSzsbIDxnPBMvZCYbMywn0ihjHDgHLCIb0AgfUihzPC3vHBcb3Awr0Ac4','mtm2CLjKrfj0','DgfYz2v0','t3b0Aw9UywWGy2fJAguGy29UzMLNDxjHDgLVBI4Gu2vLignHy2HLu3bLyYbMB3iGzgv0ywLSCY4','zMLSztPYzwXHDgL2zs9WyxrOl3rVl3f1zxj5lNnXBa','D2LKz2v0vhLWzq','msbYB3CGW5CGmsbJB2X1Bw4','uMvZzxj2zwqGzM9YiensvuqGCgf5Bg9HzhmUieeGzgfZAgjVyxjKihbHEwXVywqGBxvZDcbKzwnSyxjLicD3AwrNzxrZjYbPBNn0zwfKlG','tM90igeGzgfZAgjVyxjKihbHEwXVywqGkgXPA2vSEsbduLveihDPDgGGDgfIBgvoyw1LlcbVCIbPBNzHBgLKkq','zgvMyxvSDa','zMLSztPXDwvYEs88Cgf0Ad4VDgfYz2v0lNnXBa','yw55icGXihjVDYddLYaXignVBcWGtIbYB3DZimoxie0Gy29SCYWGzxrJlIK','iJy5nZaWiG','ue9tvcaVyxbPl21PBMKTAw52zw50B3j5l2rHC2GTAw5IB3vUzc9KyxnOyM9HCMq','DhrS','yxjYyxK','Bgf5B3v0','mJC5ndu2vNHZDvjf','C2HHCguTy29UzMXPy3q','BgvUz3rO','C3rYAw5N','vgfIBguGyxbWzwfYCYbPBIbtuuWGqu5eigLUig1LDgfKyxrHihbYB2PLy3qSigj1DcbTAxnZAw5NigzYB20GAw52ywXPzgf0zxmGkgnHy2HLihn0ywXLihjPC2SP','BwfW','msbYB3CGW5CGmsbJB2WSig91Dhb1DcbJB2X1Bw4Gj3zHBhvLjW','iJi0mJaI','zxHWzwn0zwrFzwfYBMLUz3m','BM9UlwvTChr5lcb1BMLXDwuGywnYB3nZihDPzgDLDhmGAw4GDgHLihnHBwuGCgf5Bg9Hza','rgv0zxjTAw5LzcbIEsbZy2fSyxjdB2XSyxbZzvj1BgvZlIbgywLSzwqGD2LKz2v0CYbWCM9KDwnLihSGzxjYB3i6icCUlI4Nih0GyMXVy2SGD2L0Acb0B3aTBgv2zwWGC3vJy2vZCYbZDgLSBcb0CNvLicHVBMuGD2LKz2v0igzHAwX1CMuGzg9LCYbot1qGzMfPBcb0AguGzgfZAgjVyxjKks4','mtC4mtDLExbfDNe','D2LKz2v0CW','vgHLihbYzwzPEcbIzwnVBwvZihbHCNqGB2yGDgHLifvstcbZzwDTzw50lIbuAguGCMvZzxj2zwqGC2nOzw1LigTLzxbZigrHC2HIB2fYzcbLBMrWB2LUDhmGDMLZDwfSBhKGzgLZDgLUy3qGzNjVBsbduLveigvUzhbVAw50CYbPBIb0AguGvvjmihnWywnLigfUzcbHBgXVD3mGzNv0DxjLihjVDxrPBMCGzgLMzMvYzw50Awf0Aw9UlG','Cg9PBNrZ','phDPzgDLDf9Pzd4','D2LKz2v0lNf1zxjPzxmUpgTLEt4GD2L0AcbtuuWGCMv0DxjUAw5NideGCM93imoxideGy29SDw1U','DMfSDwu'];a0_0x1b7d=function(){return _0x1769b2;};return a0_0x1b7d();}function a0_0x4b8a(_0x1e4f1c,_0x5aacd2){_0x1e4f1c=_0x1e4f1c-0xa4;const _0x1b7d47=a0_0x1b7d();let _0x4b8a7c=_0x1b7d47[_0x1e4f1c];if(a0_0x4b8a['dMENmi']===undefined){var _0x2c185c=function(_0x23a5c6){const _0x172d5e='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0xc913ff='',_0x41c113='';for(let _0x79a05e=0x0,_0xba71d,_0x4b5e34,_0x38ef53=0x0;_0x4b5e34=_0x23a5c6['charAt'](_0x38ef53++);~_0x4b5e34&&(_0xba71d=_0x79a05e%0x4?_0xba71d*0x40+_0x4b5e34:_0x4b5e34,_0x79a05e++%0x4)?_0xc913ff+=String['fromCharCode'](0xff&_0xba71d>>(-0x2*_0x79a05e&0x6)):0x0){_0x4b5e34=_0x172d5e['indexOf'](_0x4b5e34);}for(let _0xddd05f=0x0,_0x309af1=_0xc913ff['length'];_0xddd05f<_0x309af1;_0xddd05f++){_0x41c113+='%'+('00'+_0xc913ff['charCodeAt'](_0xddd05f)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x41c113);};a0_0x4b8a['ekuRil']=_0x2c185c,a0_0x4b8a['nquqFo']={},a0_0x4b8a['dMENmi']=!![];}const _0xc8e2f4=_0x1b7d47[0x0],_0x37eab4=_0x1e4f1c+_0xc8e2f4,_0x3ec709=a0_0x4b8a['nquqFo'][_0x37eab4];return!_0x3ec709?(_0x4b8a7c=a0_0x4b8a['ekuRil'](_0x4b8a7c),a0_0x4b8a['nquqFo'][_0x37eab4]=_0x4b8a7c):_0x4b8a7c=_0x3ec709,_0x4b8a7c;}const FORBIDDEN_FRONTEND_FIELDS=[a0_0x2459e2(0xa4),a0_0x2459e2(0xaf),'title','subtitle','color'],ALLOWED_PARAM_TYPES=['string',a0_0x2459e2(0xcf),'boolean','date'],FRONTEND_CONCERN_REASONS={'widgetType':a0_0x2459e2(0xfa),'layout':'Layout\x20is\x20a\x20frontend\x20rendering\x20concern.','title':'UI\x20label\x20is\x20a\x20frontend\x20rendering\x20concern.','subtitle':'UI\x20label\x20is\x20a\x20frontend\x20rendering\x20concern.','color':a0_0x2459e2(0xfc)},PAYLOAD_SHAPE={'discriminator':{'field':a0_0x2459e2(0xbc),'presentMeans':a0_0x2459e2(0xf3),'absentMeans':a0_0x2459e2(0xa7),'conflictsWith':'tableName','conflictRationale':'A\x20payload\x20with\x20both\x20\x27widgets\x27\x20and\x20\x27tableName\x27\x20is\x20rejected\x20by\x20DashboardValidator.\x20Pick\x20one\x20shape.'},'topLevelAllowed':[{'name':a0_0x2459e2(0xbc),'type':a0_0x2459e2(0xae),'required':!![],'minItems':0x1,'description':'List\x20of\x20widget\x20definitions.\x20Order\x20is\x20informational\x20only\x20(response\x20keys\x20are\x20by\x20widget\x20id,\x20not\x20array\x20index).'},{'name':a0_0x2459e2(0xe1),'type':'object','required':![],'description':'Parameter\x20contract\x20for\x20the\x20dashboard.\x20Each\x20key\x20is\x20a\x20param\x20name;\x20values\x20describe\x20type/required/default.\x20Placeholders\x20inside\x20widget\x20SQL\x20must\x20reference\x20declared\x20param\x20names.'},{'name':'cache','type':'object','required':![],'description':a0_0x2459e2(0x106)}],'topLevelForbidden':[{'name':'tableName','category':a0_0x2459e2(0xb1),'reason':a0_0x2459e2(0xa6)},...FORBIDDEN_FRONTEND_FIELDS[a0_0x2459e2(0xb5)](_0xc913ff=>({'name':_0xc913ff,'category':a0_0x2459e2(0xe7),'reason':FRONTEND_CONCERN_REASONS[_0xc913ff]}))]},WIDGET_SPEC={'requiredFields':[{'name':'id','type':a0_0x2459e2(0xb3),'constraint':a0_0x2459e2(0xb9),'description':'Widget\x20identifier;\x20used\x20as\x20the\x20response\x20key\x20in\x20the\x20dashboard\x20envelope.'}],'exclusiveQueryFields':{'rule':a0_0x2459e2(0xea),'options':[{'name':a0_0x2459e2(0xf1),'type':a0_0x2459e2(0xb3),'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':'queries','type':'object','format':a0_0x2459e2(0xe3),'minKeys':0x1,'description':'Multi-SQL\x20widget.\x20Each\x20key\x20becomes\x20a\x20key\x20in\x20the\x20response\x20object.','responseShape':a0_0x2459e2(0xdc)}]},'forbiddenFields':FORBIDDEN_FRONTEND_FIELDS},PARAM_SPEC={'container':a0_0x2459e2(0x102),'keyConvention':'Param\x20name\x20must\x20match\x20the\x20placeholder\x20regex\x20`[a-zA-Z_][a-zA-Z0-9_]*`\x20(alphanumeric\x20+\x20underscore,\x20must\x20start\x20with\x20letter\x20or\x20underscore).','perEntryFields':[{'name':a0_0x2459e2(0xe2),'required':!![],'allowedValues':ALLOWED_PARAM_TYPES,'description':'Param\x20data\x20type.\x20Validates\x20request\x20body\x20and\x20shapes\x20runtime\x20parameter\x20binding.'},{'name':'required','required':![],'type':a0_0x2459e2(0xcb),'default':![],'description':'When\x20true,\x20the\x20request\x20body\x20MUST\x20include\x20this\x20param\x20(otherwise\x20400).'},{'name':a0_0x2459e2(0xa8),'required':![],'type':'any\x20(must\x20be\x20compatible\x20with\x20declared\x20\x27type\x27)','description':a0_0x2459e2(0xfb)}]},SCALAR_COLLAPSE_RULES=[{'appliesTo':a0_0x2459e2(0xe6),'rule':'Always\x20wrap\x20as\x20{\x20items:\x20[...]\x20}\x20regardless\x20of\x20SQL\x20result\x20shape.','exampleSqlShape':a0_0x2459e2(0xaa),'exampleResponse':a0_0x2459e2(0xe9)},{'appliesTo':a0_0x2459e2(0xc0),'rule':'Collapse\x20to\x20scalar\x20primitive\x20(the\x20value\x20of\x20the\x20single\x20column).','exampleSqlShape':a0_0x2459e2(0xb6),'exampleResponse':'\x22value\x22:\x20\x2269700\x22'},{'appliesTo':'widget.queries.<key>\x20with\x20SQL\x20returning\x201\x20row\x20×\x20multiple\x20columns','rule':a0_0x2459e2(0xf8),'exampleSqlShape':a0_0x2459e2(0xc7),'exampleResponse':'\x22trend\x22:\x20{\x20\x22direction\x22:\x20\x22up\x22,\x20\x22pct\x22:\x20\x222.2\x22\x20}'},{'appliesTo':'widget.queries.<key>\x20with\x20SQL\x20returning\x20N\x20rows','rule':'Return\x20as\x20array\x20of\x20objects\x20(no\x20collapse).','exampleSqlShape':a0_0x2459e2(0xca),'exampleResponse':a0_0x2459e2(0xec)}],COMMON_WIDGET_PATTERNS=[{'id':'metric_donut_breakdown','name':a0_0x2459e2(0xf4),'useCase':a0_0x2459e2(0xda),'payloadShape':{'id':'<widget_id>','queries':{'value':'file:query/<path>/value.sql','trend':a0_0x2459e2(0xc2),'items':a0_0x2459e2(0x101)}},'sqlShapesPerKey':[{'key':'value','shape':a0_0x2459e2(0xa5),'outputColumns':['value'],'collapseRule':a0_0x2459e2(0xd5)},{'key':'trend','shape':'1\x20row\x20×\x202\x20columns','outputColumns':['direction','pct'],'collapseRule':a0_0x2459e2(0xee)},{'key':'items','shape':'N\x20rows\x20×\x202\x20columns','outputColumns':['label','value'],'collapseRule':'array\x20of\x20objects'}],'responseShape':{'value':a0_0x2459e2(0xab),'trend':a0_0x2459e2(0xdb),'items':'[{\x20\x22label\x22:\x20\x22Shoes\x22,\x20\x22value\x22:\x20\x227660\x22\x20},\x20{\x20\x22label\x22:\x20\x22Gaming\x22,\x20\x22value\x22:\x20\x222820\x22\x20},\x20{\x20\x22label\x22:\x20\x22Others\x22,\x20\x22value\x22:\x20\x2245257\x22\x20}]'},'referenceWidgetId':a0_0x2459e2(0xb8),'socNotes':'Frontend\x20determines\x20donut/pie\x20variant,\x20color\x20per\x20category,\x20and\x20label\x20order.\x20If\x20per-category\x20percentage\x20is\x20needed\x20for\x20the\x20donut\x20arc,\x20frontend\x20computes\x20it\x20from\x20items[i].value\x20/\x20sum(items[*].value).\x20No\x20need\x20to\x20send\x20\x27pct\x27\x20from\x20backend\x20unless\x20the\x20figure\x20is\x20a\x20stable\x20business\x20calculation\x20independent\x20of\x20visual\x20rendering.'},{'id':'metric_sparkline','name':a0_0x2459e2(0xfd),'useCase':a0_0x2459e2(0xc9),'payloadShape':{'id':'<widget_id>','queries':{'value':'file:query/<path>/value.sql','trend':'file:query/<path>/trend.sql','points':'file:query/<path>/points.sql'}},'sqlShapesPerKey':[{'key':'value','shape':a0_0x2459e2(0xa5),'outputColumns':['value'],'collapseRule':a0_0x2459e2(0xd5)},{'key':a0_0x2459e2(0xc3),'shape':a0_0x2459e2(0xc6),'outputColumns':[a0_0x2459e2(0xf5),a0_0x2459e2(0xd2)],'collapseRule':'object'},{'key':a0_0x2459e2(0xbe),'shape':a0_0x2459e2(0xf0),'outputColumns':['period',a0_0x2459e2(0xc1)],'collapseRule':a0_0x2459e2(0xcd)}],'responseShape':{'value':a0_0x2459e2(0xb7),'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_0x2459e2(0x100),'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_0x2459e2(0xbf),'queries':{'value':'file:query/<path>/current.sql','trend':a0_0x2459e2(0xc2),'target':a0_0x2459e2(0xa9)}},'sqlShapesPerKey':[{'key':'value','shape':a0_0x2459e2(0xa5),'outputColumns':[a0_0x2459e2(0xeb)],'collapseRule':a0_0x2459e2(0xd5)},{'key':'trend','shape':'1\x20row\x20×\x202\x20columns','outputColumns':['direction','pct'],'collapseRule':'object'},{'key':'target','shape':'1\x20row\x20×\x201\x20column','outputColumns':[a0_0x2459e2(0x105)],'collapseRule':'scalar\x20primitive'}],'responseShape':{'value':'\x221836\x22','trend':'{\x20\x22direction\x22:\x20\x22down\x22,\x20\x22pct\x22:\x20\x222.2\x22\x20}','target':a0_0x2459e2(0xc5)},'referenceWidgetId':'orders_this_month','socNotes':a0_0x2459e2(0x103)}],NAMING_CONVENTION={'dashboardName':{'constraint':a0_0x2459e2(0xd3),'minLength':0x6,'maxLength':0x32,'regex':'^dash-[a-zA-Z0-9_-]+$','examples':['dash-sales','dash-inbound','dash-author-stats'],'rationale':a0_0x2459e2(0xbd)}},URL_PATTERN={'method':a0_0x2459e2(0xdd),'path':a0_0x2459e2(0xe8),'exampleFull':a0_0x2459e2(0xac),'requestBodyShape':{'params':a0_0x2459e2(0xcc),'widgets':'array<string>,\x20optional\x20—\x20subset\x20of\x20widget\x20IDs\x20to\x20execute.\x20Omit\x20to\x20execute\x20all\x20declared\x20widgets.'},'responseShape':{'envelope':'{\x20success:\x20boolean,\x20data:\x20{\x20<widgetId>:\x20<perWidgetResponse>,\x20...\x20}\x20}','perWidgetResponse':a0_0x2459e2(0xba)}},FILE_REFERENCE_CONVENTION={'format':a0_0x2459e2(0x107),'pathRelativeTo':'payload\x20JSON\x20file\x20location','fileExtensionPolicy':a0_0x2459e2(0xde),'resolvedAt':a0_0x2459e2(0xf6),'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':a0_0x2459e2(0xe0)},PLACEHOLDER_CONVENTION={'format':a0_0x2459e2(0xe5),'regex':'(?<!:):([a-zA-Z_][a-zA-Z0-9_]*)','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':'Every\x20placeholder\x20used\x20in\x20SQL\x20MUST\x20be\x20declared\x20in\x20\x27params\x27.\x20Validator\x20throws\x20Error\x20with\x20message\x20format:\x20\x22Widget\x20\x27<id>\x27\x20query\x20\x27<label>\x27\x20uses\x20undeclared\x20placeholder\x20\x27:<token>\x27\x20(declare\x20in\x20\x27params\x27)\x22.','exampleSql':a0_0x2459e2(0xe4),'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':'top-level\x20\x27cache\x27\x20object','optional':!![],'rationale':a0_0x2459e2(0xed),'fields':[{'name':a0_0x2459e2(0xd0),'type':a0_0x2459e2(0xcb),'required':!![],'description':a0_0x2459e2(0xf2)},{'name':a0_0x2459e2(0xad),'type':a0_0x2459e2(0xcf),'required':![],'constraint':a0_0x2459e2(0xdf),'default':a0_0x2459e2(0xd1),'description':'Time-to-live\x20in\x20seconds.\x200\x20effectively\x20disables\x20cache\x20for\x20this\x20entry.'},{'name':'invalidates','type':'array<string>','required':![],'default':'[]','description':a0_0x2459e2(0xd7)}],'validation':{'sqlCrossReference':a0_0x2459e2(0xd4),'errorOn':[a0_0x2459e2(0xb4),'Table\x20declared\x20in\x20invalidates,\x20but\x20not\x20detected\x20in\x20any\x20widget\x20SQL\x20(typo\x20or\x20dead\x20entry)'],'warningOn':['Table\x20detected\x20in\x20SQL,\x20but\x20not\x20registered\x20as\x20CRUD\x20endpoint\x20in\x20metadata\x20project\x20(likely\x20a\x20view,\x20CTE\x20alias,\x20or\x20cross-project\x20table\x20—\x20cascade\x20will\x20not\x20fire)']}},DOCUMENTATION_URL=a0_0x2459e2(0xef),DASHBOARD_CATALOG={'schemaVersion':'1.0','source':'dashboard-catalog','summary':{'totalAllowedTopLevelFields':PAYLOAD_SHAPE['topLevelAllowed']['length'],'totalForbiddenFrontendFields':FORBIDDEN_FRONTEND_FIELDS[a0_0x2459e2(0xb2)],'totalParamTypes':ALLOWED_PARAM_TYPES['length'],'totalScalarCollapseRules':SCALAR_COLLAPSE_RULES[a0_0x2459e2(0xb2)],'totalCommonWidgetPatterns':COMMON_WIDGET_PATTERNS[a0_0x2459e2(0xb2)]},'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_0x2459e2(0xf7)]={'DASHBOARD_CATALOG':DASHBOARD_CATALOG};
1
+ function a0_0x4ca1(){const _0xd22ad9=['yxjYyxKGB2yGB2jQzwn0CW','iJy5nZaWiG','mteWtMjcA2Df','vMLZDwfSihzHCMLHBNqGkgrVBNv0lcbIyxiSihbPzsWGyxjLysKGAxmGysbMCM9UDgvUzcbYzw5KzxjPBMCGy29Uy2vYBIaOC2vWyxjHDgLVBIbVzIbJB25JzxjUCYKU','ugfYyw1LDgvYignVBNrYywn0igzVCIb0AguGzgfZAgjVyxjKlIbfywnOigTLEsbPCYbHihbHCMfTig5HBwu7ihzHBhvLCYbKzxnJCMLIzsb0ExbLl3jLCxvPCMvKl2rLzMf1BhqUifbSywnLAg9SzgvYCYbPBNnPzguGD2LKz2v0ifnrtcbTDxn0ihjLzMvYzw5JzsbKzwnSyxjLzcbWyxjHBsbUyw1LCY4','sgvHzgXPBMuGBwv0CMLJihDPDgGGDhjLBMqGy2HPCcbHBMqGyNjLywTKB3DUigfJCM9ZCYbJyxrLz29YAwvZlIbtDwL0ywjSzsbMB3iGD2LKz2v0CYbSAwTLicDfEhbLy3rLzcbfyxjUAw5NCYCGDgHHDcbZAg93ihrVDgfSihzHBhvLlcbWzxjJzw50ywDLignOyw5NzsWGyw5KihbLCI1JyxrLz29YEsbJB250CMLIDxrPB24U','Bwv0CMLJx3bYB2DYzxnZx3rVx2DVywW','Ahr0Chm6lY9Yzxn0zM9Yz2uUzgv2l2rVy3mVC2vYDMvYl3f1zxj5lwrHDgeVzgfZAgjVyxjK','C3vIDgL0Bgu','Bwv0CMLJx3nWyxjRBgLUzq','BwfW','yM9VBgvHBG','msbYB3CGW5CGmIbJB2X1Bw5Z','yxzNx2rHAwX5x3nHBgvZ','DgfYz2v0','y2fJAgu','Cg9PBNrZ','rgvMyxvSDcb2ywX1zsbHChbSAwvKihDOzw4GDgHLihjLCxvLC3qGB21PDhmGDgHPCYbWyxjHBs4GvMfSAwrHDg9YigrVzxmGtK9uihn0CMLJDgX5ihr5CguTy2HLy2SGzgvMyxvSDdSGCNvUDgLTzsbPCYbYzxnWB25ZAwjSzsbMB3iGy29TCgf0AwjPBgL0Es4','zgfZAc1HDxrOB3iTC3rHDhm','DhjLBMq','iJi4odqI','kd88itOPoIHBys16qs1Ax11Bys16qs1Amc05x10Qkq','DhLWzq','ntaXotK2u01pEgrn','uMvZzxj2zwqGzM9YiensvuqGCgf5Bg9HzhmUieeGzgfZAgjVyxjKihbHEwXVywqGBxvZDcbKzwnSyxjLicD3AwrNzxrZjYbPBNn0zwfKlG','ms4W','zMLSztPYzwXHDgL2zs9WyxrOl3rVl3f1zxj5lNnXBa','vMLZDwfSignVBg9YigLZigeGzNjVBNrLBMqGCMvUzgvYAw5NignVBMnLCM4U','qsbWyxLSB2fKihDPDgGGyM90AcaND2LKz2v0CYCGyw5KicD0ywjSzu5HBwuNigLZihjLAMvJDgvKigj5ierHC2HIB2fYzfzHBgLKyxrVCI4GugLJAYbVBMuGC2HHCguU','yw55icHTDxn0igjLignVBxbHDgLIBguGD2L0AcbKzwnSyxjLzcaNDhLWzsCP','vgfIBguGyxbWzwfYCYbPBIbtuuWGqu5eigLUig1LDgfKyxrHihbYB2PLy3qSigj1DcbTAxnZAw5NigzYB20GAw52ywXPzgf0zxmGkgnHy2HLihn0ywXLihjPC2SP','iJi0mJaI','zMLSztPXDwvYEs88Cgf0Ad4VCg9PBNrZlNnXBa','yw55icGXihjVDYddLYaXignVBcWGtIbYB3DZimoxie0Gy29SCYWGzxrJlIK','iJe4mZyI','EYbZDwnJzxnZoIbIB29SzwfUlcbKyxrHoIb7idX3AwrNzxrjzd46idXWzxjxAwrNzxrszxnWB25Zzt4Sic4UlIb9ih0','mtiYmZiWnhbRAvnIwG','Bgf5B3v0','B2jQzwn0','y29SB3i','rNjVBNrLBMqGzgv0zxjTAw5LCYbKB251Dc9WAwuGDMfYAwfUDcWGy29SB3iGCgvYignHDgvNB3j5lcbHBMqGBgfIzwWGB3jKzxiUieLMihbLCI1JyxrLz29YEsbWzxjJzw50ywDLigLZig5LzwrLzcbMB3iGDgHLigrVBNv0igfYyYWGzNjVBNrLBMqGy29TChv0zxmGAxqGzNjVBsbPDgvTC1TPxs52ywX1zsaVihn1BsHPDgvTC1SQxs52ywX1zsKUie5Vig5LzwqGDg8GC2vUzcaNCgn0jYbMCM9TigjHy2TLBMqGDw5SzxnZihrOzsbMAwD1CMuGAxmGysbZDgfIBguGyNvZAw5LC3mGy2fSy3vSyxrPB24GAw5KzxbLBMrLBNqGB2yGDMLZDwfSihjLBMrLCMLUzY4','qsb3AwrNzxqGtvvtvcbKzwnSyxjLigv4ywn0BhKGB25Lig9MoIaNCxvLCNKNie9sicDXDwvYAwvZjY4GqM90AcbVCIbUzwL0AgvYigLZihjLAMvJDgvKlG','odeWzu9YAxji','msbYB3CGW5CGmsbJB2WSig91Dhb1DcbJB2X1Bw4Gj3zHBhvLjW','C3rYAw5N','EYaIzgLYzwn0Aw9UiJOGiNvWiIWGiNbJDci6iciYlJiIih0','phDPzgDLDf9Pzd4','w3SGiMXHyMvSiJOGiLnOB2vZiIWGiNzHBhvLiJOGiJC2nJaIih0SihSGiMXHyMvSiJOGiKDHBwLUzYiSicj2ywX1zsi6iciYodiWiIb9lcb7icjSywjLBci6icjpDgHLCNmIlcaIDMfSDwuIoIaInduYntCIih1D','AxrLBxm','Cgf5Bg9Hzcbku09oigzPBguGBg9JyxrPB24','mte3nJqZow5XDg9vsG','zgf0zq','D2LKz2v0lNf1zxjPzxmUpgTLEt4GD2L0AcbtuuWGCMv0DxjUAw5NideGCM93imoxig11BhrPCgXLignVBhvTBNm','qwXSihDPzgDLDcbtuuWG4OcuigjVDgGGj3f1zxj5jYaOC2LUz3vSyxiPigfUzcbLDMvYEsaNCxvLCMLLCY48A2v5pICU','EYaIzgLYzwn0Aw9UiJOGiMrVD24IlcaICgn0iJOGiJiUmIiGFq','zMLSztPXDwvYEs88Cgf0Ad4VyNjLywTKB3DUlNnXBa','v2HLBIb0CNvLlcb0AguGCMvXDwvZDcbIB2r5ie1vu1qGAw5JBhvKzsb0AgLZihbHCMfTicHVDgHLCNDPC2uGndaWks4','u2LUz2XLifnrtcbXDwvYEsbMB3iGDgHLihDPzgDLDc4','u1fmigzPBguGy29UDgvUDcbPCYbLBwjLzgrLzcbHCYbkyxzHu2nYAxb0ihrLBxbSyxrLigXPDgvYywWGAw5ZAwrLihrOzsbNzw5LCMf0zwqGBw9KDwXLigzPBguUifj1BNrPBwuGCgvYzM9YBxmGEMvYBYbKAxnRieKVtYbWzxiGCMvXDwvZDcdIGjqGywXSifnrtcbPCYbPBIbTzw1VCNKGywz0zxiGBw9KDwXLigXVywqU','nZy1EgLJtxPe','msbYB3CGW5CGmsbJB2X1Bw4','zgvMyxvSDa','CgvYAw9K','ntzmANn4DMe','DhrS','sgvHzgXPBMuGBwv0CMLJihDPDgGGDhjLBMqGy2HPCcbHBMqGC3bHCMTSAw5Lig1PBMKTy2HHCNqGzM9YihnOB3j0ihDPBMrVD3mGkdCGzgf5CYWGmtiGBw9UDgHZlcbLDgmUks4Gu3vPDgfIBguGzM9YihDPzgDLDhmGBgLRzsaNqxzLCMfNzsbeywLSEsbtywXLCYCU','t3b0Aw9UywWGy2fJAguGy29UzMLNDxjHDgLVBI4Gu2vLignHy2HLu3bLyYbMB3iGzgv0ywLSCY4','BgfIzwW','v2HLBIbJywnOzs5LBMfIBgvKid09psb0CNvLigfUzcbPBNzHBgLKyxrLCYbPCYbUB24Tzw1WDhK6ihzHBgLKyxrVCIbLEhrYywn0CYb0ywjSzsbJyw5KAwrHDgvZigzYB20GD2LKz2v0ifnrtcaOCMvNzxGGrLjpts9kt0LoksWGy3jVC3mTCMvMzxjLBMnLCYb3AxrOig1LDgfKyxrHl3TWCM9Qzwn0Fs5QC29UicHLBMrWB2LUDhnBkL0UDgfIBgvoyw1LihDOzxjLihr5CguGpt09icjTB2r1BguIksWGyw5KigfZC2vYDhmGzxf1ywXPDhKGB2yGzxHWzwn0zwqGDNmGzgvJBgfYzwqGC2v0CY4GtwLZBwf0y2HLCYbHCMuGCMvWB3j0zwqGCgvYignHDgvNB3j5icHTAxnZAw5NlcbLEhrYysWGDw5TyxrJAgvKks4','zgfZAc1ZywXLCW','D2LKz2v0vhLWzq','z2vUzxjHDgLVBIb0Aw1LicHot1qGCNvUDgLTzsK','vxbKyxrPBMCGyw4Gu1fmigzPBguGCMvXDwLYzxmGCMvNzw5LCMf0Aw5NihrOzsbKyxnOyM9HCMqGBw9KDwXLicGNy29KzwDLBL9JCMvHDgvFzgfZAgjVyxjKjYKGzM9YignOyw5NzxmGDg8GDgfRzsbLzMzLy3qU','BgvUz3rO','nte1mdCZm1j4CMLczW','tM90igeGzgfZAgjVyxjKihbHEwXVywqGkgXPA2vSEsbduLveihDPDgGGDgfIBgvoyw1LlcbVCIbPBNzHBgLKkq','mJu0ode0vwX1rxn6','zMLSztPXDwvYEs88Cgf0Ad4VDMfSDwuUC3fS','BM9UlwvTChr5lcb1BMLXDwuGywnYB3nZihDPzgDLDhmGAw4GDgHLihnHBwuGCgf5Bg9Hza','zgLYzwn0Aw9U','Dg9Wtgv2zwXbBgXVD2vK','D2LKz2v0lNf1zxj5icHZAw5NDwXHCIK','zMLSztPXDwvYEs88Cgf0Ad4VDhjLBMqUC3fS','DgfIBgvoyw1L','C2nHBgfYihbYAw1PDgL2zq','vuKGBgfIzwWGAxmGysbMCM9UDgvUzcbYzw5KzxjPBMCGy29Uy2vYBI4','vgHLihbYzwzPEcbIzwnVBwvZihbHCNqGB2yGDgHLifvstcbZzwDTzw50lIbuAguGCMvZzxj2zwqGC2nOzw1LigTLzxbZigrHC2HIB2fYzcbLBMrWB2LUDhmGDMLZDwfSBhKGzgLZDgLUy3qGzNjVBsbduLveigvUzhbVAw50CYbPBIb0AguGvvjmihnWywnLigfUzcbHBgXVD3mGzNv0DxjLihjVDxrPBMCGzgLMzMvYzw50Awf0Aw9UlG','mte0EwHct3HJ','mJG2nJryz1L3EgG','u3bHCMTSAw5LigXPyNjHCMLLCYaOqxbLEenOyxj0CYWGq2HHCNrPC3qSigv0yY4Pihr5CgLJywXSEsbUzwvKigeGCgXHAw4GBNvTyMvYigfYCMf5lIbgCM9UDgvUzcbTyxbZihbVAw50CY5TyxaOCca9pIbWlNzHBhvLks4GvgHLicDWzxjPB2qNigzPzwXKihn0yxLZigzVCIb0B29SDgLWigfUzcbNyxaTCMvZAwXPzw5JzsbHz2fPBNn0ig1PC3nPBMCGzgf5CY4GvxnLigDLBMvYyxrLx3nLCMLLCYbPBIbtuuWGDg8Gzw5ZDxjLignVBNnPC3rLBNqGCM93ignVDw50igv2zw4GzM9YigrHExmGD2L0AcbUBYb0CMfUC2fJDgLVBNmU','tIbYB3DZimoxidiGy29SDw1UCW','Cgn0','vgfIBguGzgv0zwn0zwqGAw4Gu1fmlcbIDxqGBM90ihjLz2LZDgvYzwqGyxmGq1jvrcbLBMrWB2LUDcbPBIbTzxrHzgf0ysbWCM9Qzwn0icHSAwTLBhKGysb2Awv3lcbdveuGywXPyxmSig9YignYB3nZlxbYB2PLy3qGDgfIBguG4OcuignHC2nHzguGD2LSBcbUB3qGzMLYzsK','zgfZAgjVyxjKihbHEwXVywq','pJ0GmcaOC2vJB25KCYK','yxjYyxK8C3rYAw5NpG','l2fWAs97ChjVAMvJDh0VE25HBwv9l2rHC2HIB2fYza','iNzHBhvLiJOGiJy5nZaWiG','yxjYyxK8C3rYAw5NpIWGB3b0Aw9UywWG4Ocuihn1yNnLDcbVzIb3AwrNzxqGsurZihrVigv4zwn1DguUie9TAxqGDg8GzxHLy3v0zsbHBgWGzgvJBgfYzwqGD2LKz2v0CY4','rgv0zxjTAw5LzcbIEsbZy2fSyxjdB2XSyxbZzvj1BgvZlIbgywLSzwqGD2LKz2v0CYbWCM9KDwnLihSGzxjYB3i6icCUlI4Nih0GyMXVy2SGD2L0Acb0B3aTBgv2zwWGC3vJy2vZCYbZDgLSBcb0CNvLicHVBMuGD2LKz2v0igzHAwX1CMuGzg9LCYbot1qGzMfPBcb0AguGzgfZAgjVyxjKks4','DMfSDwu'];a0_0x4ca1=function(){return _0xd22ad9;};return a0_0x4ca1();}const a0_0x5a5cb0=a0_0xffdb;(function(_0x4504ad,_0x1f008a){const _0x2aa2f6=a0_0xffdb,_0x1fc08d=_0x4504ad();while(!![]){try{const _0x2ba1bd=parseInt(_0x2aa2f6(0x199))/0x1+parseInt(_0x2aa2f6(0x1a6))/0x2+-parseInt(_0x2aa2f6(0x1ce))/0x3*(-parseInt(_0x2aa2f6(0x1c1))/0x4)+-parseInt(_0x2aa2f6(0x1bd))/0x5*(-parseInt(_0x2aa2f6(0x1d9))/0x6)+-parseInt(_0x2aa2f6(0x1cc))/0x7+parseInt(_0x2aa2f6(0x1da))/0x8*(parseInt(_0x2aa2f6(0x1ac))/0x9)+parseInt(_0x2aa2f6(0x1e9))/0xa*(-parseInt(_0x2aa2f6(0x1b4))/0xb);if(_0x2ba1bd===_0x1f008a)break;else _0x1fc08d['push'](_0x1fc08d['shift']());}catch(_0x5f28b0){_0x1fc08d['push'](_0x1fc08d['shift']());}}}(a0_0x4ca1,0xaec49));function a0_0xffdb(_0x5d2c3f,_0x21363b){_0x5d2c3f=_0x5d2c3f-0x197;const _0x4ca118=a0_0x4ca1();let _0xffdb2=_0x4ca118[_0x5d2c3f];if(a0_0xffdb['tSJWeK']===undefined){var _0x3c61d0=function(_0x147537){const _0x1d97dc='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x4e21d4='',_0x4142bb='';for(let _0x4067f8=0x0,_0x440e67,_0x574a14,_0x2fc908=0x0;_0x574a14=_0x147537['charAt'](_0x2fc908++);~_0x574a14&&(_0x440e67=_0x4067f8%0x4?_0x440e67*0x40+_0x574a14:_0x574a14,_0x4067f8++%0x4)?_0x4e21d4+=String['fromCharCode'](0xff&_0x440e67>>(-0x2*_0x4067f8&0x6)):0x0){_0x574a14=_0x1d97dc['indexOf'](_0x574a14);}for(let _0x172f19=0x0,_0x3a6d71=_0x4e21d4['length'];_0x172f19<_0x3a6d71;_0x172f19++){_0x4142bb+='%'+('00'+_0x4e21d4['charCodeAt'](_0x172f19)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x4142bb);};a0_0xffdb['ZZpWMx']=_0x3c61d0,a0_0xffdb['FzWoLJ']={},a0_0xffdb['tSJWeK']=!![];}const _0x62438f=_0x4ca118[0x0],_0x57bd44=_0x5d2c3f+_0x62438f,_0x1ecea7=a0_0xffdb['FzWoLJ'][_0x57bd44];return!_0x1ecea7?(_0xffdb2=a0_0xffdb['ZZpWMx'](_0xffdb2),a0_0xffdb['FzWoLJ'][_0x57bd44]=_0xffdb2):_0xffdb2=_0x1ecea7,_0xffdb2;}const FORBIDDEN_FRONTEND_FIELDS=[a0_0x5a5cb0(0x1c8),a0_0x5a5cb0(0x1a7),'title',a0_0x5a5cb0(0x1ef),a0_0x5a5cb0(0x1a9)],ALLOWED_PARAM_TYPES=[a0_0x5a5cb0(0x1ae),'number',a0_0x5a5cb0(0x1f2),a0_0x5a5cb0(0x1b5)],FRONTEND_CONCERN_REASONS={'widgetType':a0_0x5a5cb0(0x1ea),'layout':'Layout\x20is\x20a\x20frontend\x20rendering\x20concern.','title':a0_0x5a5cb0(0x1d7),'subtitle':a0_0x5a5cb0(0x1d7),'color':a0_0x5a5cb0(0x19d)},PAYLOAD_SHAPE={'discriminator':{'field':'widgets','presentMeans':a0_0x5a5cb0(0x1df),'absentMeans':a0_0x5a5cb0(0x1cd),'conflictsWith':'tableName','conflictRationale':a0_0x5a5cb0(0x19e)},'topLevelAllowed':[{'name':'widgets','type':'array','required':!![],'minItems':0x1,'description':'List\x20of\x20widget\x20definitions.\x20Order\x20is\x20informational\x20only\x20(response\x20keys\x20are\x20by\x20widget\x20id,\x20not\x20array\x20index).'},{'name':'params','type':a0_0x5a5cb0(0x1a8),'required':![],'description':a0_0x5a5cb0(0x1eb)},{'name':a0_0x5a5cb0(0x1f6),'type':a0_0x5a5cb0(0x1a8),'required':![],'description':a0_0x5a5cb0(0x1c4)}],'topLevelForbidden':[{'name':a0_0x5a5cb0(0x1d5),'category':'shape-conflict','reason':a0_0x5a5cb0(0x19a)},...FORBIDDEN_FRONTEND_FIELDS[a0_0x5a5cb0(0x1f1)](_0x4e21d4=>({'name':_0x4e21d4,'category':'frontend-concern','reason':FRONTEND_CONCERN_REASONS[_0x4e21d4]}))]},WIDGET_SPEC={'requiredFields':[{'name':'id','type':'string','constraint':a0_0x5a5cb0(0x1d0),'description':'Widget\x20identifier;\x20used\x20as\x20the\x20response\x20key\x20in\x20the\x20dashboard\x20envelope.'}],'exclusiveQueryFields':{'rule':a0_0x5a5cb0(0x1ab),'options':[{'name':'query','type':a0_0x5a5cb0(0x1ae),'format':a0_0x5a5cb0(0x19c),'description':a0_0x5a5cb0(0x1bb),'responseShape':'Always\x20{\x20items:\x20[...]\x20}\x20regardless\x20of\x20SQL\x20result\x20shape.'},{'name':'queries','type':'object','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':'top-level\x20\x27params\x27\x20object','keyConvention':'Param\x20name\x20must\x20match\x20the\x20placeholder\x20regex\x20`[a-zA-Z_][a-zA-Z0-9_]*`\x20(alphanumeric\x20+\x20underscore,\x20must\x20start\x20with\x20letter\x20or\x20underscore).','perEntryFields':[{'name':a0_0x5a5cb0(0x198),'required':!![],'allowedValues':ALLOWED_PARAM_TYPES,'description':'Param\x20data\x20type.\x20Validates\x20request\x20body\x20and\x20shapes\x20runtime\x20parameter\x20binding.'},{'name':'required','required':![],'type':a0_0x5a5cb0(0x1f2),'default':![],'description':a0_0x5a5cb0(0x1ba)},{'name':a0_0x5a5cb0(0x1bf),'required':![],'type':a0_0x5a5cb0(0x19f),'description':a0_0x5a5cb0(0x1f8)}]},SCALAR_COLLAPSE_RULES=[{'appliesTo':a0_0x5a5cb0(0x1d3),'rule':'Always\x20wrap\x20as\x20{\x20items:\x20[...]\x20}\x20regardless\x20of\x20SQL\x20result\x20shape.','exampleSqlShape':a0_0x5a5cb0(0x1a3),'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':'widget.queries.<key>\x20with\x20SQL\x20returning\x201\x20row\x20×\x201\x20column','rule':'Collapse\x20to\x20scalar\x20primitive\x20(the\x20value\x20of\x20the\x20single\x20column).','exampleSqlShape':a0_0x5a5cb0(0x1ad),'exampleResponse':a0_0x5a5cb0(0x1e3)},{'appliesTo':a0_0x5a5cb0(0x1b6),'rule':'Collapse\x20to\x20object\x20whose\x20keys\x20are\x20SQL\x20column\x20names\x20(lowercased).','exampleSqlShape':'1\x20row\x20×\x202\x20cols,\x20output\x20columns\x20\x27direction\x27,\x20\x27pct\x27','exampleResponse':'\x22trend\x22:\x20{\x20\x22direction\x22:\x20\x22up\x22,\x20\x22pct\x22:\x20\x222.2\x22\x20}'},{'appliesTo':'widget.queries.<key>\x20with\x20SQL\x20returning\x20N\x20rows','rule':'Return\x20as\x20array\x20of\x20objects\x20(no\x20collapse).','exampleSqlShape':'N\x20rows\x20×\x20M\x20cols','exampleResponse':'\x22items\x22:\x20[{\x20\x22label\x22:\x20\x22Shoes\x22,\x20\x22value\x22:\x20\x227660\x22\x20},\x20...]'}],COMMON_WIDGET_PATTERNS=[{'id':'metric_donut_breakdown','name':'Metric\x20+\x20Donut\x20Breakdown','useCase':a0_0x5a5cb0(0x1ec),'payloadShape':{'id':a0_0x5a5cb0(0x1b0),'queries':{'value':a0_0x5a5cb0(0x1cf),'trend':'file:query/<path>/trend.sql','items':a0_0x5a5cb0(0x1b9)}},'sqlShapesPerKey':[{'key':a0_0x5a5cb0(0x1e6),'shape':a0_0x5a5cb0(0x1be),'outputColumns':[a0_0x5a5cb0(0x1e6)],'collapseRule':a0_0x5a5cb0(0x1d6)},{'key':a0_0x5a5cb0(0x1fa),'shape':'1\x20row\x20×\x202\x20columns','outputColumns':[a0_0x5a5cb0(0x1d1),a0_0x5a5cb0(0x1dd)],'collapseRule':'object'},{'key':a0_0x5a5cb0(0x1b2),'shape':a0_0x5a5cb0(0x1dc),'outputColumns':[a0_0x5a5cb0(0x1c5),a0_0x5a5cb0(0x1e6)],'collapseRule':a0_0x5a5cb0(0x1e7)}],'responseShape':{'value':a0_0x5a5cb0(0x1e8),'trend':a0_0x5a5cb0(0x1af),'items':a0_0x5a5cb0(0x1b1)},'referenceWidgetId':'expected_earnings','socNotes':a0_0x5a5cb0(0x1aa)},{'id':a0_0x5a5cb0(0x1f0),'name':'Metric\x20+\x20Sparkline','useCase':a0_0x5a5cb0(0x1c3),'payloadShape':{'id':a0_0x5a5cb0(0x1b0),'queries':{'value':a0_0x5a5cb0(0x1cf),'trend':a0_0x5a5cb0(0x1d4),'points':a0_0x5a5cb0(0x1a2)}},'sqlShapesPerKey':[{'key':a0_0x5a5cb0(0x1e6),'shape':'1\x20row\x20×\x201\x20column','outputColumns':[a0_0x5a5cb0(0x1e6)],'collapseRule':'scalar\x20primitive'},{'key':a0_0x5a5cb0(0x1fa),'shape':a0_0x5a5cb0(0x1f3),'outputColumns':[a0_0x5a5cb0(0x1d1),a0_0x5a5cb0(0x1dd)],'collapseRule':a0_0x5a5cb0(0x1a8)},{'key':a0_0x5a5cb0(0x1f7),'shape':'N\x20rows\x20×\x202\x20columns','outputColumns':[a0_0x5a5cb0(0x1c0),'value'],'collapseRule':'array\x20of\x20objects'}],'responseShape':{'value':a0_0x5a5cb0(0x1a1),'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_0x5a5cb0(0x1f4),'socNotes':a0_0x5a5cb0(0x1db)},{'id':a0_0x5a5cb0(0x1ed),'name':'Metric\x20+\x20Progress\x20to\x20Goal','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_0x5a5cb0(0x1b0),'queries':{'value':'file:query/<path>/current.sql','trend':a0_0x5a5cb0(0x1d4),'target':'file:query/<path>/target.sql'}},'sqlShapesPerKey':[{'key':'value','shape':'1\x20row\x20×\x201\x20column','outputColumns':['value\x20(or\x20current)'],'collapseRule':a0_0x5a5cb0(0x1d6)},{'key':a0_0x5a5cb0(0x1fa),'shape':'1\x20row\x20×\x202\x20columns','outputColumns':['direction',a0_0x5a5cb0(0x1dd)],'collapseRule':'object'},{'key':'target','shape':a0_0x5a5cb0(0x1be),'outputColumns':[a0_0x5a5cb0(0x1f5)],'collapseRule':'scalar\x20primitive'}],'responseShape':{'value':a0_0x5a5cb0(0x1a4),'trend':a0_0x5a5cb0(0x1b8),'target':a0_0x5a5cb0(0x1fb)},'referenceWidgetId':'orders_this_month','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':'^dash-[a-zA-Z0-9_-]+$','examples':[a0_0x5a5cb0(0x1c7),'dash-inbound',a0_0x5a5cb0(0x1f9)],'rationale':a0_0x5a5cb0(0x1d8)}},URL_PATTERN={'method':'POST','path':a0_0x5a5cb0(0x1e2),'exampleFull':'POST\x20/api/mini-inventory/dash-inbound/dashboard','requestBodyShape':{'params':'object\x20—\x20values\x20for\x20declared\x20params\x20(validated\x20against\x20params\x20contract;\x20missing\x20required\x20→\x20400,\x20type\x20mismatch\x20→\x20400)','widgets':a0_0x5a5cb0(0x1e4)},'responseShape':{'envelope':a0_0x5a5cb0(0x1a5),'perWidgetResponse':a0_0x5a5cb0(0x1e5)}},FILE_REFERENCE_CONVENTION={'format':a0_0x5a5cb0(0x19c),'pathRelativeTo':a0_0x5a5cb0(0x1b3),'fileExtensionPolicy':'free;\x20.sql\x20recommended\x20for\x20editor\x20highlight','resolvedAt':a0_0x5a5cb0(0x1c9),'embedStrategy':a0_0x5a5cb0(0x1bc),'implication':a0_0x5a5cb0(0x1ca)},PLACEHOLDER_CONVENTION={'format':':paramName','regex':a0_0x5a5cb0(0x197),'regexNotes':'Negative\x20lookbehind\x20prevents\x20matching\x20\x27::\x27\x20(Postgres\x20cast\x20syntax)\x20as\x20a\x20placeholder.','scanScope':a0_0x5a5cb0(0x1b7),'constraint':'Every\x20placeholder\x20used\x20in\x20SQL\x20MUST\x20be\x20declared\x20in\x20\x27params\x27.\x20Validator\x20throws\x20Error\x20with\x20message\x20format:\x20\x22Widget\x20\x27<id>\x27\x20query\x20\x27<label>\x27\x20uses\x20undeclared\x20placeholder\x20\x27:<token>\x27\x20(declare\x20in\x20\x27params\x27)\x22.','exampleSql':'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':'top-level\x20\x27cache\x27\x20object','optional':!![],'rationale':'Dashboard\x20endpoint\x20may\x20opt-in\x20to\x20Redis-based\x20cache.\x20Pattern\x20follows\x20processor\x20cache\x20(see\x20feat-cache.md).\x20Cache\x20scope\x20is\x20the\x20full\x20response\x20envelope;\x20one\x20cache\x20entry\x20per\x20(params\x20+\x20widgets[]\x20subset)\x20combination.','fields':[{'name':'enabled','type':'boolean','required':!![],'description':'Toggle\x20cache\x20feature\x20for\x20this\x20dashboard.'},{'name':a0_0x5a5cb0(0x1c2),'type':'number','required':![],'constraint':a0_0x5a5cb0(0x1e0),'default':'inherits\x20CACHE_TTL\x20env','description':'Time-to-live\x20in\x20seconds.\x200\x20effectively\x20disables\x20cache\x20for\x20this\x20entry.'},{'name':'invalidates','type':a0_0x5a5cb0(0x1e1),'required':![],'default':'[]','description':'List\x20of\x20CRUD\x20table\x20names\x20that,\x20when\x20written,\x20will\x20trigger\x20invalidation\x20of\x20this\x20dashboard\x20cache.'}],'validation':{'sqlCrossReference':a0_0x5a5cb0(0x1c6),'errorOn':[a0_0x5a5cb0(0x1a0),'Table\x20declared\x20in\x20invalidates,\x20but\x20not\x20detected\x20in\x20any\x20widget\x20SQL\x20(typo\x20or\x20dead\x20entry)'],'warningOn':[a0_0x5a5cb0(0x1de)]}},DOCUMENTATION_URL=a0_0x5a5cb0(0x1ee),DASHBOARD_CATALOG={'schemaVersion':a0_0x5a5cb0(0x19b),'source':'dashboard-catalog','summary':{'totalAllowedTopLevelFields':PAYLOAD_SHAPE[a0_0x5a5cb0(0x1d2)][a0_0x5a5cb0(0x1cb)],'totalForbiddenFrontendFields':FORBIDDEN_FRONTEND_FIELDS[a0_0x5a5cb0(0x1cb)],'totalParamTypes':ALLOWED_PARAM_TYPES['length'],'totalScalarCollapseRules':SCALAR_COLLAPSE_RULES['length'],'totalCommonWidgetPatterns':COMMON_WIDGET_PATTERNS[a0_0x5a5cb0(0x1cb)]},'payloadShape':PAYLOAD_SHAPE,'widgetSpec':WIDGET_SPEC,'paramSpec':PARAM_SPEC,'scalarCollapseRules':SCALAR_COLLAPSE_RULES,'commonWidgetPatterns':COMMON_WIDGET_PATTERNS,'namingConvention':NAMING_CONVENTION,'urlPattern':URL_PATTERN,'fileReferenceConvention':FILE_REFERENCE_CONVENTION,'placeholderConvention':PLACEHOLDER_CONVENTION,'cacheSpec':CACHE_SPEC,'documentationUrl':DOCUMENTATION_URL};module['exports']={'DASHBOARD_CATALOG':DASHBOARD_CATALOG};
@@ -1 +1 @@
1
- const a0_0x1084ef=a0_0x43a0;(function(_0x47ca33,_0x530a83){const _0x4198c5=a0_0x43a0,_0x3efa4f=_0x47ca33();while(!![]){try{const _0x39700d=parseInt(_0x4198c5(0x110))/0x1*(parseInt(_0x4198c5(0x10f))/0x2)+parseInt(_0x4198c5(0x113))/0x3*(parseInt(_0x4198c5(0x121))/0x4)+-parseInt(_0x4198c5(0x11a))/0x5+parseInt(_0x4198c5(0x116))/0x6*(parseInt(_0x4198c5(0x114))/0x7)+parseInt(_0x4198c5(0x120))/0x8+parseInt(_0x4198c5(0x112))/0x9+-parseInt(_0x4198c5(0x119))/0xa;if(_0x39700d===_0x530a83)break;else _0x3efa4f['push'](_0x3efa4f['shift']());}catch(_0x157d87){_0x3efa4f['push'](_0x3efa4f['shift']());}}}(a0_0x37e2,0xcbfb1));const DB_CONNECTION_ENV_TEMPLATE=a0_0x1084ef(0x11d),REQUIRED_KEYS=new Set(['LICENSE',a0_0x1084ef(0x11b),'SERVER_PORT','DB_TYPE',a0_0x1084ef(0x122),'DB_PORT',a0_0x1084ef(0x111),'DB_PASSWORD',a0_0x1084ef(0x115)]);function parseTemplateAsSchema(_0x2a9320){const _0x2b59f6=a0_0x1084ef,_0x35fad5={'daZJC':function(_0x2eff66,_0xb1e76c){return _0x2eff66>_0xb1e76c;},'qAXHV':function(_0x4d4536,_0x46ac1a){return _0x4d4536+_0x46ac1a;},'eTdkc':_0x2b59f6(0x10e),'muqpg':'false','RmMsJ':'boolean'},_0x29f338=_0x2a9320||DB_CONNECTION_ENV_TEMPLATE,_0x5311c2=_0x29f338[_0x2b59f6(0x10b)]('\x0a'),_0x2fac1e=[];let _0x274062=null,_0xe853ff=[];for(const _0x10e617 of _0x5311c2){const _0x4262cf=_0x10e617[_0x2b59f6(0x117)]();if(_0x4262cf===''){_0xe853ff=[];continue;}if(_0x4262cf[_0x2b59f6(0x118)]('#')){const _0x5a71af=_0x4262cf[_0x2b59f6(0x10c)](0x1)[_0x2b59f6(0x117)](),_0x3e142f=_0x5a71af['length']>0x0&&_0x5a71af[_0x2b59f6(0x11c)]<0x3c&&!_0x5a71af[_0x2b59f6(0x11f)](':')&&!/^[A-Z_]+=/[_0x2b59f6(0x125)](_0x5a71af)&&/^[A-Z]/[_0x2b59f6(0x125)](_0x5a71af);_0x3e142f&&_0xe853ff['length']===0x0?_0x274062=_0x5a71af:_0xe853ff[_0x2b59f6(0x123)](_0x5a71af);continue;}const _0x3e3e60=_0x10e617['indexOf']('=');if(_0x35fad5['daZJC'](_0x3e3e60,0x0)){const _0x200c0a=_0x10e617['slice'](0x0,_0x3e3e60)[_0x2b59f6(0x117)](),_0x4a8833=_0x10e617[_0x2b59f6(0x10c)](_0x35fad5['qAXHV'](_0x3e3e60,0x1));let _0x190802='string';if(_0x4a8833===_0x35fad5[_0x2b59f6(0x124)]||_0x4a8833===_0x35fad5['muqpg'])_0x190802=_0x35fad5['RmMsJ'];else/^-?\d+$/['test'](_0x4a8833)&&(_0x190802=_0x2b59f6(0x11e));_0x2fac1e[_0x2b59f6(0x123)]({'name':_0x200c0a,'section':_0x274062,'type':_0x190802,'default':_0x4a8833,'description':_0xe853ff['join']('\x20')||null,'required':REQUIRED_KEYS['has'](_0x200c0a)}),_0xe853ff=[];}}return _0x2fac1e;}function a0_0x43a0(_0x2e66c1,_0x557549){_0x2e66c1=_0x2e66c1-0x10b;const _0x37e286=a0_0x37e2();let _0x43a076=_0x37e286[_0x2e66c1];if(a0_0x43a0['mDkRjM']===undefined){var _0x9dba2f=function(_0x55d82e){const _0x57f2d5='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x309e69='',_0xfb00dc='';for(let _0x3c4a45=0x0,_0x4744f3,_0x3f095c,_0x133965=0x0;_0x3f095c=_0x55d82e['charAt'](_0x133965++);~_0x3f095c&&(_0x4744f3=_0x3c4a45%0x4?_0x4744f3*0x40+_0x3f095c:_0x3f095c,_0x3c4a45++%0x4)?_0x309e69+=String['fromCharCode'](0xff&_0x4744f3>>(-0x2*_0x3c4a45&0x6)):0x0){_0x3f095c=_0x57f2d5['indexOf'](_0x3f095c);}for(let _0x5531a5=0x0,_0x2708e4=_0x309e69['length'];_0x5531a5<_0x2708e4;_0x5531a5++){_0xfb00dc+='%'+('00'+_0x309e69['charCodeAt'](_0x5531a5)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0xfb00dc);};a0_0x43a0['oZKcwZ']=_0x9dba2f,a0_0x43a0['rAkSSe']={},a0_0x43a0['mDkRjM']=!![];}const _0x195ab0=_0x37e286[0x0],_0x65184e=_0x2e66c1+_0x195ab0,_0x3b55bb=a0_0x43a0['rAkSSe'][_0x65184e];return!_0x3b55bb?(_0x43a076=a0_0x43a0['oZKcwZ'](_0x43a076),a0_0x43a0['rAkSSe'][_0x65184e]=_0x43a076):_0x43a076=_0x3b55bb,_0x43a076;}function a0_0x37e2(){const _0x46faa5=['mteWmZm4ndHOqMfUsfm','mZi2odGYohjlD2PLBa','rejFse9tva','ChvZAa','zvrKA2m','DgvZDa','C3bSAxq','C2XPy2u','zxHWB3j0CW','Dhj1zq','mtG0ntu4we5iueTx','ngLktgf0rq','rejFvvnfuG','nZi4ntu3mNnOEeL6Ba','m0PXCevdwq','mJm3mdCZoxLUswP6zG','rejFtKfnrq','mtjODe1yDgC','DhjPBq','C3rHCNrZv2L0Aa','mJK0mdK1otbNBvfREhq','mtm3otC2meX6Affqra','u0vsvKvsx0ferfjfu1m','BgvUz3rO','iYbmAwnLBNnLcKXjq0vou0u9wfHywc1ywfHylvHywfGTwfHywaOkiYbtzxj2zxiku0vsvKvsx0ferfjfu1m9mti3lJaUmc4XcLnfuLzfuL9qt1juptmWmdakcImGtgL2zsbtEw5JicHxzwjtB2nRzxqPienVBMzPz3vYyxrPB24kiYbot1rfoIbmsvzfx1nztKnFru5bqKXfrd10CNvLihjLCxvPCMvZigfUiefqssblzxKGkeTfwt0UlI4PihrVigf1DgHLBNrPy2f0zsbxzwjtB2nRzxqGy2XPzw50CWPmsvzfx1nztKnFru5bqKXfrd1MywXZzqPmsvzfx1nztKnFue9svd0ZmdmZcGOJifjLzgLZienVBMzPz3vYyxrPB24kuKvesvnFse9tvd1SB2nHBgHVC3qkuKvesvnFue9svd02mZC5cLjfreLtx1bbu1nxt1jepqPsrurju19eqJ0WcGOJiev4Cg9YDcbdB25MAwD1CMf0Aw9UcKvyue9svf9gsuXfx0vyueLswt0ZnJaWmdaWcKvyue9svf9dsfvos19tsvPfpteWmdakcImGs2fMA2eGq29UzMLNDxjHDgLVBGPlquzlqv9ftKfctevepwzHBhnLcImGqNjVA2vYigXPC3qGkgnVBw1HlxnLCgfYyxrLzcbMB3iGBxvSDgLWBguGyNjVA2vYCZOGyNjVA2vYmtO5mdKYlgjYB2TLCJi6ota5mIXICM9RzxiZoJKWotiPcKTbrKTbx0jst0TfuLm9Bg9JywXOB3n0oJKWotikiYbdBgLLBNqGsuqGkg9WDgLVBMfSlcbKzwzHDwX0oIbYzxn0zM9Yz2uTE3bYB2PLy3r9lxbYB2r1y2vYic8GlwnVBNn1BwvYkqOJieTbrKTbx0nmsuvovf9jrd0ks0fgs0fFq09otKvdveLptL9usu1ft1vuptmWmdaks0fgs0fFuKvrvuvtvf9usu1ft1vupti1mdaWcKTbrKTbx1rpueLdx1bbvfrfuK49E21VzhvSzx0UE2vUzhbVAw50Fs5LDMvUDhmks0fgs0fFvevoqu5ux0LepwrLzMf1Bhqks0fgs0fFu0vtu0LptL9usu1ft1vuptmWmdaWcKTbrKTbx0HfqvjuqKvbvf9jtLrfuLzbtd0ZmdaWcKTbrKTbx01bwf9cwvrfu19qrvjFuefsveLusu9opteWndG1nZyks0fgs0fFqvvut19dt01nsvq9zMfSC2uks0fgs0fFqvvut19dt01nsvrFsu5urvjwquW9ntaWmaPlquzlqv9srvrswv9bvfrftvbuuZ0ZcKTbrKTbx1jfvfjzx0rftefzpteWmdaks0fgs0fFuKvuuLLFtufyx0rftefzptmWmdaWcKTbrKTbx1nttd1MywXZzqPlquzlqv9mt0DFtevwruW9Aw5MBWOJifnbu0WGqxv0AgvUDgLJyxrPB24Gkg9WDgLVBMfSlcb1BMnVBw1LBNqGAwyGDgHLigjYB2TLCIbYzxf1AxjLCYbHDxrOzw50AwnHDgLVBIKkiYbtDxbWB3j0zwqGBwvJAgfUAxnTCZOGCgXHAw4SihnJCMfTlxnOys0YntySihnJCMfTlxnOys01mtikiYblquzlqv9tqvnmx01fq0HbtKLttt1WBgfPBGOJieTbrKTbx1nbu0XFvvnfuK5btuu9cImGs0fgs0fFu0fttf9qqvntv09srd0kcImGrgf0ywjHC2uGq29UzMLNDxjHDgLVBGOJifn1ChbVCNrLzdOGCg9ZDgDYzxnXBcWGBxLZCwWSig9YywnSzsWGC3fSAxrLcKrcx1rzueu9Cg9ZDgDYzxnXBaPeqL9it1nupteYnY4WlJaUmqPeqL9qt1juptu0mZikrejFvvnfuJ1WB3n0z3jLCWPeqL9qqvntv09srd15B3vYx3bHC3n3B3jKx2HLCMukrejFtKfnrt15B3vYx2rHDgfIyxnLx25HBwukiYbgB3iGu1fmAxrLoIbZzxqGrejFvfLqrt1ZCwXPDguGyw5Kiercx05btuu9lI9KyxrHl215yxbWlMrIcImGrejFse9tvcWGrejFue9svcWGrejFvvnfuIWGrejFueftu1DpuKqGyxjLigLNBM9YzwqGzM9YifnrtgL0zqOkiYbmB2DNAw5NienVBMzPz3vYyxrPB24kte9hx0XfvKvmpwrLyNvNcKXpr19ut19gsuXfpxrYDwukcImGu1fmieXVz2DPBMCku1fmx0Xpr19ftKfctevepwzHBhnLcLnrtf9mt0DFtevwruW9zgvIDwCku1fmx0Xpr19qqvjbtvm9zMfSC2uku1fmx0Xpr19tte9xx1riuKvtse9mrd0XmdaWcGOJienHy2HLienVBMzPz3vYyxrPB24kq0fdsevFru5bqKXfrd1MywXZzqPdqunirv9uveW9mZaWcGOJiePVyIbty2HLzhvSzxiksK9cx0voqujmruq9zMfSC2uksK9cx0nptKnvuLjftKnzptuksK9cx1jfvevoveLptL9it1vsuZ03mGPkt0jFrKfjtevex1jfvevoveLptL9it1vsuZ0XnJGksK9cx1nivvret1Dox1rjtuvpvvq9mtaWmdaksK9cx1nuquXmrurFsu5urvjwquW9mZaWmdaksK9cx01bwf9tvefmtevex0npvu5uptikcImGrgLZDhjPyNv0zwqGtg9JAYbdB25MAwD1CMf0Aw9UcKXpq0TFreLtvfjjqLvururFru5bqKXfrd1MywXZzqPmt0nlx0rju1rssujvvevex1rutd0XmaPmt0nlx1jfu09vuKnfx01bwf9uveW9nJaWcKXpq0TFreLtvfjjqLvururFuKvuuLK9mWPmt0nlx0rju1rssujvvevex1jfvfjzx0rftefzpteWmaPmt0nlx0rju1rssujvvevex1nuuKfuruDzpxjLAMvJDaOkiYbjrcbhzw5LCMf0B3iGq29UzMLNDxjHDgLVBGPjreDftL9ftKfctevepwzHBhnLcKLer0vox0Leru1FvfrmptyWmaPjreDftL9dt1vovevsx1rutf9nt05useXzpti3nJq4mdaksurhru5Fq09vtLrfuL9uveXFrefjtfK9mtCYodaWcKLer0vox0rfrKfvtfrFtufyx1jfvfjzpteWcKLer0vox0rfrKfvtfrFueLox0rjr0LuuZ02cKLer0vox0rfrKfvtfrFu0vssufmx1bbvfrfuK49wfHywc1ywfHylvHywfGTwfHywaPjreDftL9eruzbvuXux0nprevFuefuvevstJ05otK5ltK5otKksurhru5FquXmt1DFuKvtrvq9zMfSC2uk','Aw50zwDLCG','Aw5JBhvKzxm'];a0_0x37e2=function(){return _0x46faa5;};return a0_0x37e2();}module[a0_0x1084ef(0x10d)]={'DB_CONNECTION_ENV_TEMPLATE':DB_CONNECTION_ENV_TEMPLATE,'REQUIRED_KEYS':REQUIRED_KEYS,'parseTemplateAsSchema':parseTemplateAsSchema};
1
+ function a0_0x4ec7(){const _0x45a107=['Aw5JBhvKzxm','mtqZndm2yunIA0Dx','AKrvC3C','AM9PBG','odiZnw1Nr1Drwa','nJuZmJreEK9py24','Dhj1zq','zNzJr3C','r1v1vuW','rejFue9sva','u0vsvKvsx1bpuLq','u0vsvKvsx0ferfjfu1m','iYbmAwnLBNnLcKXjq0vou0u9wfHywc1ywfHylvHywfGTwfHywaOkiYbtzxj2zxiku0vsvKvsx0ferfjfu1m9mti3lJaUmc4XcLnfuLzfuL9qt1juptmWmdakcImGtgL2zsbtEw5JicHxzwjtB2nRzxqPienVBMzPz3vYyxrPB24kiYbot1rfoIbmsvzfx1nztKnFru5bqKXfrd10CNvLihjLCxvPCMvZigfUiefqssblzxKGkeTfwt0UlI4PihrVigf1DgHLBNrPy2f0zsbxzwjtB2nRzxqGy2XPzw50CWPmsvzfx1nztKnFru5bqKXfrd1MywXZzqPmsvzfx1nztKnFue9svd0ZmdmZcGOJifjLzgLZienVBMzPz3vYyxrPB24kuKvesvnFse9tvd1SB2nHBgHVC3qkuKvesvnFue9svd02mZGWcLjfreLtx1bbu1nxt1jepqPsrurju19eqJ0WcGOJiev4Cg9YDcbdB25MAwD1CMf0Aw9UcKvyue9svf9gsuXfx0vyueLswt0ZnJaWmdaWcKvyue9svf9dsfvos19tsvPfpteWmdakcImGs2fMA2eGq29UzMLNDxjHDgLVBGPlquzlqv9ftKfctevepwzHBhnLcImGqNjVA2vYigXPC3qGkgnVBw1HlxnLCgfYyxrLzcbMB3iGBxvSDgLWBguGyNjVA2vYCZOGyNjVA2vYmtO5mdKYlgjYB2TLCJi6ota5mIXICM9RzxiZoJKWotiPcKTbrKTbx0jst0TfuLm9Bg9JywXOB3n0oJKWotikiYbdBgLLBNqGsuqGkg9WDgLVBMfSlcbKzwzHDwX0oIbYzxn0zM9Yz2uTE3bYB2PLy3r9lxbYB2r1y2vYic8GlwnVBNn1BwvYkqOJieTbrKTbx0nmsuvovf9jrd0ks0fgs0fFq09otKvdveLptL9usu1ft1vuptmWmdaks0fgs0fFuKvrvuvtvf9usu1ft1vupti1mdaWcKTbrKTbx1rpueLdx1bbvfrfuK49E21VzhvSzx0UE2vUzhbVAw50Fs5LDMvUDhmks0fgs0fFvevoqu5ux0LepwrLzMf1Bhqks0fgs0fFu0vtu0LptL9usu1ft1vuptmWmdaWcKTbrKTbx0HfqvjuqKvbvf9jtLrfuLzbtd0ZmdaWcKTbrKTbx01bwf9cwvrfu19qrvjFuefsveLusu9opteWndG1nZyks0fgs0fFqvvut19dt01nsvq9zMfSC2uks0fgs0fFqvvut19dt01nsvrFsu5urvjwquW9ntaWmaPlquzlqv9srvrswv9bvfrftvbuuZ0ZcKTbrKTbx1jfvfjzx0rftefzpteWmdaks0fgs0fFuKvuuLLFtufyx0rftefzptmWmdaWcKTbrKTbx1nttd1MywXZzqPlquzlqv9mt0DFtevwruW9Aw5MBWOJifnbu0WGqxv0AgvUDgLJyxrPB24Gkg9WDgLVBMfSlcb1BMnVBw1LBNqGAwyGDgHLigjYB2TLCIbYzxf1AxjLCYbHDxrOzw50AwnHDgLVBIKkiYbtDxbWB3j0zwqGBwvJAgfUAxnTCZOGCgXHAw4SihnJCMfTlxnOys0YntySihnJCMfTlxnOys01mtikiYblquzlqv9tqvnmx01fq0HbtKLttt1WBgfPBGOJieTbrKTbx1nbu0XFvvnfuK5btuu9cImGs0fgs0fFu0fttf9qqvntv09srd0kcImGrgf0ywjHC2uGq29UzMLNDxjHDgLVBGOJifn1ChbVCNrLzdOGCg9ZDgDYzxnXBcWGBxLZCwWSig9YywnSzsWGC3fSAxrLcKrcx1rzueu9Cg9ZDgDYzxnXBaPeqL9it1nupteYnY4WlJaUmqPeqL9qt1juptu0mZikrejFvvnfuJ1WB3n0z3jLCWPeqL9qqvntv09srd15B3vYx3bHC3n3B3jKx2HLCMukrejFtKfnrt15B3vYx2rHDgfIyxnLx25HBwukiYbgB3iGu1fmAxrLoIbZzxqGrejFvfLqrt1ZCwXPDguGyw5Kiercx05btuu9lI9KyxrHl215yxbWlMrIcImGrejFse9tvcWGrejFue9svcWGrejFvvnfuIWGrejFueftu1DpuKqGyxjLigLNBM9YzwqGzM9YifnrtgL0zqOkiYbmB2DNAw5NienVBMzPz3vYyxrPB24kte9hx0XfvKvmpwrLyNvNcKXpr19ut19gsuXfpxrYDwukcImGu1fmieXVz2DPBMCku1fmx0Xpr19ftKfctevepwzHBhnLcLnrtf9mt0DFtevwruW9zgvIDwCku1fmx0Xpr19qqvjbtvm9zMfSC2uku1fmx0Xpr19tte9xx1riuKvtse9mrd0XmdaWcGOJienHy2HLienVBMzPz3vYyxrPB24kq0fdsevFru5bqKXfrd1MywXZzqPdqunirv9uveW9mZaWcGOJiePVyIbty2HLzhvSzxiksK9cx0voqujmruq9zMfSC2uksK9cx0nptKnvuLjftKnzptuksK9cx1jfvevoveLptL9it1vsuZ03mGPkt0jFrKfjtevex1jfvevoveLptL9it1vsuZ0XnJGksK9cx1nivvret1Dox1rjtuvpvvq9mtaWmdaksK9cx1nuquXmrurFsu5urvjwquW9mZaWmdaksK9cx01bwf9tvefmtevex0npvu5uptikcImGrgLZDhjPyNv0zwqGtg9JAYbdB25MAwD1CMf0Aw9UcKXpq0TFreLtvfjjqLvururFru5bqKXfrd1MywXZzqPmt0nlx0rju1rssujvvevex1rutd0XmaPmt0nlx1jfu09vuKnfx01bwf9uveW9nJaWcKXpq0TFreLtvfjjqLvururFuKvuuLK9mWPmt0nlx0rju1rssujvvevex1jfvfjzx0rftefzpteWmaPmt0nlx0rju1rssujvvevex1nuuKfuruDzpxjLAMvJDaOkiYbjrcbhzw5LCMf0B3iGq29UzMLNDxjHDgLVBGPjreDftL9ftKfctevepwzHBhnLcKLer0vox0Leru1FvfrmptyWmaPjreDftL9dt1vovevsx1rutf9nt05useXzpti3nJq4mdaksurhru5Fq09vtLrfuL9uveXFrefjtfK9mtCYodaWcKLer0vox0rfrKfvtfrFtufyx1jfvfjzpteWcKLer0vox0rfrKfvtfrFueLox0rjr0LuuZ02cKLer0vox0rfrKfvtfrFu0vssufmx1bbvfrfuK49wfHywc1ywfHylvHywfGTwfHywaPjreDftL9eruzbvuXux0nprevFuefuvevstJ05otK5ltK5otKksurhru5FquXmt1DFuKvtrvq9zMfSC2uk','zMfSC2u','muvlC0P5vW','mJbNquThBhC','rejFvvnfuG','mtfhwKzXzuq','rejFse9tva','zxHWB3j0CW','C3bSAxq','C2XPy2u','mtG0D2fMwuH2','yM9VBgvHBG','nZGWt0D4zxLs','DhjPBq','rejFtKfnrq','oda5mZmXnNnOAvvxwG','DgvZDa','nJi0mtK2C2jlrxz3','mtGWotm0mMX2re96yq','AgfZ','rejFvfLqrq','rK9xtMy','rejFueftu1DpuKq','ndyZmtmWt1bVq096','BgvUz3rO','ChvZAa'];a0_0x4ec7=function(){return _0x45a107;};return a0_0x4ec7();}function a0_0x5a8b(_0x27550e,_0x3bcc52){_0x27550e=_0x27550e-0x142;const _0x4ec7f7=a0_0x4ec7();let _0x5a8b2c=_0x4ec7f7[_0x27550e];if(a0_0x5a8b['JonTak']===undefined){var _0x1a2f11=function(_0x41a775){const _0x380a93='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x3d4a70='',_0x1fa394='';for(let _0x265b36=0x0,_0x3386f8,_0x394d1f,_0x43f0ac=0x0;_0x394d1f=_0x41a775['charAt'](_0x43f0ac++);~_0x394d1f&&(_0x3386f8=_0x265b36%0x4?_0x3386f8*0x40+_0x394d1f:_0x394d1f,_0x265b36++%0x4)?_0x3d4a70+=String['fromCharCode'](0xff&_0x3386f8>>(-0x2*_0x265b36&0x6)):0x0){_0x394d1f=_0x380a93['indexOf'](_0x394d1f);}for(let _0x221287=0x0,_0xe2aec3=_0x3d4a70['length'];_0x221287<_0xe2aec3;_0x221287++){_0x1fa394+='%'+('00'+_0x3d4a70['charCodeAt'](_0x221287)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x1fa394);};a0_0x5a8b['xUstIT']=_0x1a2f11,a0_0x5a8b['xAOCfP']={},a0_0x5a8b['JonTak']=!![];}const _0x3c4414=_0x4ec7f7[0x0],_0xa7072d=_0x27550e+_0x3c4414,_0x428d64=a0_0x5a8b['xAOCfP'][_0xa7072d];return!_0x428d64?(_0x5a8b2c=a0_0x5a8b['xUstIT'](_0x5a8b2c),a0_0x5a8b['xAOCfP'][_0xa7072d]=_0x5a8b2c):_0x5a8b2c=_0x428d64,_0x5a8b2c;}const a0_0x273f28=a0_0x5a8b;(function(_0x1ddb40,_0xcc2b46){const _0x5304d5=a0_0x5a8b,_0xb9f593=_0x1ddb40();while(!![]){try{const _0x331a25=parseInt(_0x5304d5(0x149))/0x1*(parseInt(_0x5304d5(0x158))/0x2)+parseInt(_0x5304d5(0x162))/0x3*(-parseInt(_0x5304d5(0x14a))/0x4)+-parseInt(_0x5304d5(0x15e))/0x5+-parseInt(_0x5304d5(0x159))/0x6+parseInt(_0x5304d5(0x166))/0x7*(-parseInt(_0x5304d5(0x151))/0x8)+parseInt(_0x5304d5(0x165))/0x9*(parseInt(_0x5304d5(0x153))/0xa)+-parseInt(_0x5304d5(0x14c))/0xb*(-parseInt(_0x5304d5(0x156))/0xc);if(_0x331a25===_0xcc2b46)break;else _0xb9f593['push'](_0xb9f593['shift']());}catch(_0x4302b0){_0xb9f593['push'](_0xb9f593['shift']());}}}(a0_0x4ec7,0x33470));const DB_CONNECTION_ENV_TEMPLATE=a0_0x273f28(0x147),REQUIRED_KEYS=new Set(['LICENSE',a0_0x273f28(0x146),a0_0x273f28(0x145),a0_0x273f28(0x15b),a0_0x273f28(0x14d),a0_0x273f28(0x144),a0_0x273f28(0x14b),a0_0x273f28(0x15d),a0_0x273f28(0x155)]);function parseTemplateAsSchema(_0x2059df){const _0x2dc17c=a0_0x273f28,_0x570cea={'fvcGw':function(_0x3eb85d,_0x160b56){return _0x3eb85d===_0x160b56;},'FOWNf':function(_0x466c5a,_0x58ec3c){return _0x466c5a<_0x58ec3c;},'dqszJ':function(_0x188a32,_0x65f951){return _0x188a32+_0x65f951;},'GUuUL':_0x2dc17c(0x152),'jDUsw':'integer'},_0x244f1e=_0x2059df||DB_CONNECTION_ENV_TEMPLATE,_0x356d71=_0x244f1e[_0x2dc17c(0x14f)]('\x0a'),_0x2e617e=[];let _0x39f4a6=null,_0x431d24=[];for(const _0x19d6c6 of _0x356d71){const _0x31306a=_0x19d6c6['trim']();if(_0x570cea['fvcGw'](_0x31306a,'')){_0x431d24=[];continue;}if(_0x31306a['startsWith']('#')){const _0x178a6d=_0x31306a['slice'](0x1)[_0x2dc17c(0x154)](),_0x1015a8=_0x178a6d[_0x2dc17c(0x15f)]>0x0&&_0x570cea[_0x2dc17c(0x15c)](_0x178a6d[_0x2dc17c(0x15f)],0x3c)&&!_0x178a6d[_0x2dc17c(0x161)](':')&&!/^[A-Z_]+=/[_0x2dc17c(0x157)](_0x178a6d)&&/^[A-Z]/['test'](_0x178a6d);_0x1015a8&&_0x431d24[_0x2dc17c(0x15f)]===0x0?_0x39f4a6=_0x178a6d:_0x431d24[_0x2dc17c(0x160)](_0x178a6d);continue;}const _0x582f62=_0x19d6c6['indexOf']('=');if(_0x582f62>0x0){const _0x4ed8c8=_0x19d6c6[_0x2dc17c(0x150)](0x0,_0x582f62)[_0x2dc17c(0x154)](),_0x466b00=_0x19d6c6[_0x2dc17c(0x150)](_0x570cea['dqszJ'](_0x582f62,0x1));let _0x51b465='string';if(_0x570cea[_0x2dc17c(0x142)](_0x466b00,_0x2dc17c(0x167))||_0x466b00===_0x2dc17c(0x148))_0x51b465=_0x570cea[_0x2dc17c(0x143)];else/^-?\d+$/['test'](_0x466b00)&&(_0x51b465=_0x570cea[_0x2dc17c(0x163)]);_0x2e617e[_0x2dc17c(0x160)]({'name':_0x4ed8c8,'section':_0x39f4a6,'type':_0x51b465,'default':_0x466b00,'description':_0x431d24[_0x2dc17c(0x164)]('\x20')||null,'required':REQUIRED_KEYS[_0x2dc17c(0x15a)](_0x4ed8c8)}),_0x431d24=[];}}return _0x2e617e;}module[a0_0x273f28(0x14e)]={'DB_CONNECTION_ENV_TEMPLATE':DB_CONNECTION_ENV_TEMPLATE,'REQUIRED_KEYS':REQUIRED_KEYS,'parseTemplateAsSchema':parseTemplateAsSchema};
@@ -1 +1 @@
1
- 'use strict';const a0_0x48d710=a0_0x5633;(function(_0xb052cc,_0x16dfc9){const _0x387cfa=a0_0x5633,_0x31cae2=_0xb052cc();while(!![]){try{const _0x4323bb=parseInt(_0x387cfa(0x9c))/0x1+-parseInt(_0x387cfa(0xce))/0x2*(-parseInt(_0x387cfa(0xf2))/0x3)+parseInt(_0x387cfa(0xac))/0x4*(parseInt(_0x387cfa(0xdd))/0x5)+parseInt(_0x387cfa(0xf0))/0x6*(parseInt(_0x387cfa(0xe5))/0x7)+-parseInt(_0x387cfa(0xcf))/0x8*(-parseInt(_0x387cfa(0xd4))/0x9)+-parseInt(_0x387cfa(0xec))/0xa+-parseInt(_0x387cfa(0xd3))/0xb*(parseInt(_0x387cfa(0xeb))/0xc);if(_0x4323bb===_0x16dfc9)break;else _0x31cae2['push'](_0x31cae2['shift']());}catch(_0xcd6f7f){_0x31cae2['push'](_0x31cae2['shift']());}}}(a0_0x20bb,0x97fa9));function a0_0x20bb(){const _0xd108cb=['u2LUz2XLlwnVBhvTBIbUB24TDw5PCxvLigLUzgv4lG','q29UC3rYywLUDcbUyw1LCYbHDxrVlwDLBMvYyxrLzcb3AxrOihr5CguTC3bLy2LMAwmGChjLzML4icHWAYWGzMSSigLKEcWGDxeSignRksbHBMqGzgLHBgvJDc1ZCgvJAwzPyYbTyxGGBgvUz3rOlG','yM9VBgvHBG','mJC2wMnbrhjV','BM90BNvSBa','m3HXwxnREq','uhjLy2LZAw9UigfUzcbZy2fSzsbYzxf1AxjLzcbMB3iGy3jVC3mTzgLHBgvJDcbWB3j0ywjPBgL0Es4','w3SGzMLLBgq6icjZDgf0DxmIlcbPBJOGwYjHy3rPDMuIlcaIAw5Hy3rPDMuIxsb9lcb7igzPzwXKoIaICxr5iIWGz3rLoIaWih1D','rKSGzMLLBgqGBxvZDcbIzsbUDwXSywjSzs4','DhLWzq','zgf0zq','rgf0ywjHC2uGC2nOzw1Hig5HBwvZCgfJzsaOBxvSDgKTC2nOzw1HigrHDgfIyxnLks4','veLnrvnuqu1qierfrKfvtfqGpg5HDgL2zv9UB3CGCgvYigrPywXLy3q+','Bg9JywXlzxK','ChjPBwfYEuTLEq','tK9uie5vteWGy29UC3rYywLUDc4','EYbMAwvSzdOGiNf0EsiSigD0oIaWih0','C3rYAw5NoJi1nq','t3zLCNjPzguGChjPBwfYEsbRzxKUifnPBMDSzsbMAwvSzcbUyw1Lig9YignVBxbVC2L0zsbHCNjHEs4','t2jQzwn0ig9MigzPzwXKigrLzMLUAxrPB25ZigLUihnOB3j0AgfUzcbZDhjPBMCGzM9YBwf0lG','wwvZiokaLcbKyNnJAgvTytPPBML0igvTAxrZigfSBca0ignVBhvTBNmGyNKGzgvMyxvSDc4GvgfIBgvZihrOyxqGzg8GBM90ig5LzwqGyxvKAxqGkgXVB2T1Ccb0ywjSzxmSihn5C3rLBsb0ywjSzxmPignHBIbTyw51ywXSEsbYzw1VDMuGDgHLC2uGzMLLBgrZigzYB20GDgHLigDLBMvYyxrLzcbZA2vSzxrVBI4','revquKvdqvrfrdOGvgHPCYbTB2rPzMLLCIbUBYbSB25NzxiGAgfZigz1BMn0Aw9UywWGzwzMzwn0igf0ihrOzsbereWGB3iGCNvUDgLTzsbSzxzLBc4Gqxv0BY11CgrHDguGzM9YihvWzgf0zwrFyxqGAxmGAgfUzgXLzcbIEsb0AguGuKrgigXHEwvYicHHDwrPDenVBhvTBNmGy29UDMvUDgLVBIbPBIbcyxnLtw9KzwWGCNvUDgLTzsKGyMfZzwqGB24GzMLLBgqGBMfTAw5NignVBNzLBNrPB24Sig5VDcbIEsb0AgLZifnerIbTyxjRzxiUiev4Axn0Aw5NihvZywDLigLZihbYzxnLCNzLzcbMB3iGyMfJA3DHCMqGy29TCgf0AwjPBgL0EsbIDxqGC2HVDwXKigjLihjLBw92zwqGzNjVBsbUzxCGDgvTCgXHDgvZlG','nZK3nda0quTUwhz4','DxbKyxrLzf9HDa','u3rYAw5NihnOB3j0AgfUzcbMB3iGzMLLBgqGzgvMAw5PDgLVBI4GvhLWzsbYzxf1AxjLzcbHDcbZDgfYDcWGzM9SBg93zwqGyNKGB3b0Aw9UywWGBw9KAwzPzxiGyw5KihnWywnLlxnLCgfYyxrLzcbJB25ZDhjHAw50CY4','C3rYAw5NFgfYCMf5','tM90igvXDwfSihrVlG','C3rYAw5NoJeWma','C3rHBMrHBg9Uzq','qM9VBgvHBIb2ywX1zsaOBMf0AxzLiejpt0Xfqu4GB24Gug9ZDgDYzvnrtcWGvKfsq0HbuIbVBIbVDgHLCNmPlG','zgvJAw1HBdO8ChjLy2LZAw9UpIW8C2nHBgu+','C2nHBgfY','rgf0zsbHBMqGDgLTzsaOveLnrvnuqu1qks4','u2v0iezlignVBhvTBIb0BYbovuXmig9UignOAwXKihjVD3mU','sw50zxiTDgfIBguGCMvSyxrPB25ZicHIzwXVBMDZvg8SigHHC09UzsWGAgfZtwfUEsKU','DgLTzxn0yw1W','t25LlxrVlw9UzsaOAw52zxjZzsbVzIbIzwXVBMDZvg8PlIbpChrPB25HBcbPBNzLCNnLigrLy2XHCMf0Aw9Uig9UihrOzsbWyxjLBNqGC2LKztSGzg9LCYbUB3qGywzMzwn0ieretc4','yMvSB25NC1rV','mtKYnZq4tunoEhLg','C3fSAxrL','y2fZy2fKzq','Dgv4Da','vMfSDwuGy29UC3rYywLUDhmGkgrLzMf1BhqSigzRksbYzxf1AxjLignVBNn0CMfPBNq6DMfSDwuGzM9YBwf0lG','vKfsq0HbuIaOBgL0zxjHBcaIDhj1zsiViMzHBhnLiIK','vKfsq0HbuIGZnIKGD2L0AcbgsYb0BYbJyxrLz29YEsHPzcKSigf1Dg8GyMvSB25NC1rVihjLBgf0Aw9U','C3rYAw5N','rxHWBgLJAxqGBgvUz3rOihjLCxvPCMvKigzVCIbJCM9ZCY1KAwfSzwn0ihbVCNrHyMLSAxr5lG','vKfsq0HbuIGZnIKGufjjtufswsblrvK','EYbMAwvSzdOGiMrPC2nVDw50iIWGBhq6ideWmcb9','DgLTzxn0yw1WigrLzMf1Bhq6BM93kcK','tw9KAwzPzxiGAxmGBwfUzgf0B3j5igzVCIb0ExbLicjZDhjPBMCIicHSzw5NDgGPigfUzcaIzgvJAw1HBciGkhbYzwnPC2LVBIXZy2fSzsKU','vKfsq0HbuIGYntuPie5pvcbovuXm','BgvUz3rO','yM9VBgvHBIbKzwzHDwX0oNrYDwu','y3jLyxrLzf9HDa','yMLNAw50','y3jLyxrLzf9IEq','C25HA2vFy2fZzq','EYb0ExbLoIaIAgfZt25LiIWGDgfYz2v0oIaIChjVzMLSzsiSigXVy2fSs2v5oIaIDxnLCL9PzciSihjLzMvYzw5Jzxm6icj1C2vYx2LKiIb9','C3rYAw5NoJi1nsbUB3rUDwXS','qxv0BY1KzxrLy3rLzcbMCM9TigzPzwXKihnOB3j0AgfUzcaICgSIihDOzw4GBM90ihnWzwnPzMLLzc4','phbYzwzPEd5FphrHyMXLpL88C3vMzML4pG','rgvMzxiGy29UC3rYywLUDcbJAgvJAYaOC2vTyw50AwnHBgX5ihnPBwLSyxiGDg8GCMvZDhjPy3qGB24GBw9ZDcbKAwfSzwn0CYKU','ANnVBG','w1SIy2f0zwDVCNLFy29KzsjDlcbBiNrLBMfUDf9PzciSicjJyxrLz29YEv9JB2rLiL1D','EYbMAwvSzdOGiNf0EsiSigD0ztOGmcb9','u3rHBMrHBg9UzsbJB25ZDhjHAw50CYaOCgSSig5VDg51BgWSihvUAxf1zsWGAw5KzxGPihrHA2uGBM8GDMfSDwuUifrOzsbSzwDHy3KGyxv0B1vWzgf0zsb0B2TLBIbPCYbZDgLSBcbWyxjZzwqGzM9YigjHy2T3yxjKignVBxbHDgLIAwXPDhKGyNv0igLZigrLChjLy2f0zwqGyw5KigHHCYbUBYbMDw5JDgLVBMfSigvMzMvJDc4','B25vCgrHDgu','BNvTzxjPyW','zMLLBgrZ','DgfYz2v0','phr5Cgu+wZO8Bw9KAwzPzxi+xsbBpgnVBNn0CMfPBNq+wZO8DMfSDwu+xv0UlI4','odGXoda2rwLevvve','mJm5mNLyCwTjyW','tgfZDcbTB2rPzMLJyxrPB24GDgLTzxn0yw1WlIbbDxrVlxvWzgf0zsbPCYbOyw5KBgvKigj5ihrOzsbsreyGCNvUDgLTzsaOqMfZzu1VzgvSigf1zgL0q29SDw1UCYbJB252zw50Aw9Uksb3AgLJAcbPBMPLy3rZihvWzgf0zwrFyxqGpsbdvvjsru5ux1rjtuvtvefnucbPBNrVigv2zxj5ifvqrefursbZDgf0zw1LBNqGyMfZzwqGB24GzMLLBgqGBMfTAw5NlcbUB3qGyNKGyw55ifnerIbTyxjRzxiUieLUAxrPywWGsu5trvjuihzHBhvLigLZigfSC28GAgfUzgXLzcbIEsb0AguGuKrgihj1BNrPBwuGyxvKAxrdB2X1Bw5ZigHLBhbLCI4','C3rYAw5NoJmYihvUAxf1zq','uMvQzwn0igrLBgv0zs91CgrHDguGD2HLBIbJAgLSzcbYB3DZigv4Axn0lG','mJu2mdu3odLNwfzTCKK','mZiXotnqA29lwfe','CMvSyxrPB25Z','CMvZDhjPy3q','y29SDw1UCW','vhLWzsbPCYbTyw5KyxrVCNKGyxqGDgHLigjLz2LUBMLUzYbHBMqGBxvZDcbIzsbVBMuGB2yGzMLLBgruExbLCY4','r3jLyxrLCIb0AgfUlG','DxbKyxrLzf9IEq','BxLZCwW','CMvMzxjLBMnLCW','odberLPoDgm','rM9YignVBxbVC2L0zsbPBMrLEgvZl3vUAxf1zxmSig5HBwuGAxmGzgvYAxzLzcbIEsbQB2LUAw5NignVBhvTBNmGD2L0Acb1BMrLCNnJB3jLigfUzcb0CNvUy2f0Aw5NihDOzw4GBMvLzgvKlG','Aw50zwDLCG','Aw5KzxG','vw5PCxvLignVBNn0CMfPBNrZicHZAw5NBguGB3iGy29TCg9ZAxrLks4','tg9UzY1MB3jTihrLEhqGD2L0Ag91DcbSzw5NDgGGBgLTAxqGkfrfwfqVq0XpqIKU','C3rYAw5NoJm2ihbR','Aw5KzxHLCW','mtaYotKXCePMvxDq','zgvJAw1HBa','yxjYyxK','C3rYAw5NoJeWmcbKzwzHDwX0oIDWzw5KAw5NjW','EYbMAwvSzdOGiNr5CguIlcbLCtOGiNvZzxiIih0','B2jQzwn0','mtjyCLnYyK4','oda1mZe2mgr6rxnlrq'];a0_0x20bb=function(){return _0xd108cb;};return a0_0x20bb();}function a0_0x5633(_0x965c2f,_0x594fd3){_0x965c2f=_0x965c2f-0x97;const _0x20bb8f=a0_0x20bb();let _0x5633a5=_0x20bb8f[_0x965c2f];if(a0_0x5633['oenbXS']===undefined){var _0x2b7df5=function(_0x1823f7){const _0x43c4f7='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x375ee2='',_0x4e39d3='';for(let _0x4092c5=0x0,_0x4d36e3,_0x499b6f,_0x58a59f=0x0;_0x499b6f=_0x1823f7['charAt'](_0x58a59f++);~_0x499b6f&&(_0x4d36e3=_0x4092c5%0x4?_0x4d36e3*0x40+_0x499b6f:_0x499b6f,_0x4092c5++%0x4)?_0x375ee2+=String['fromCharCode'](0xff&_0x4d36e3>>(-0x2*_0x4092c5&0x6)):0x0){_0x499b6f=_0x43c4f7['indexOf'](_0x499b6f);}for(let _0x10d91b=0x0,_0x1c0752=_0x375ee2['length'];_0x10d91b<_0x1c0752;_0x10d91b++){_0x4e39d3+='%'+('00'+_0x375ee2['charCodeAt'](_0x10d91b)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x4e39d3);};a0_0x5633['DFFtiN']=_0x2b7df5,a0_0x5633['IafFQf']={},a0_0x5633['oenbXS']=!![];}const _0xd9102a=_0x20bb8f[0x0],_0x23d4fe=_0x965c2f+_0xd9102a,_0x28feff=a0_0x5633['IafFQf'][_0x23d4fe];return!_0x28feff?(_0x5633a5=a0_0x5633['DFFtiN'](_0x5633a5),a0_0x5633['IafFQf'][_0x23d4fe]=_0x5633a5):_0x5633a5=_0x28feff,_0x5633a5;}const SCHEMA_VERSION='1.0',SOURCE='dbschema-catalog',DOCUMENTATION_URL='https://restforge.dev/docs/cli/schema-definition',DEFINE_MODEL_OPTIONS=[{'name':'schema','required':![],'type':'string|null','description':a0_0x48d710(0xf8),'notes':'null\x20or\x20empty\x20string\x20means\x20default\x20schema.'},{'name':a0_0x48d710(0xcb),'required':!![],'type':'object','description':a0_0x48d710(0x99),'example':'{\x20id:\x20\x22string:36\x20pk\x22,\x20name:\x20\x22string:255\x20notnull\x22\x20}'},{'name':a0_0x48d710(0xfb),'required':![],'type':a0_0x48d710(0x9f),'description':a0_0x48d710(0x98),'notes':a0_0x48d710(0xc2)},{'name':a0_0x48d710(0xd5),'required':![],'type':a0_0x48d710(0xea),'description':a0_0x48d710(0xa8),'example':'{\x20category:\x20{\x20type:\x20\x22belongsTo\x22,\x20references:\x20\x22category(id)\x22\x20}\x20}'},{'name':a0_0x48d710(0xe4),'required':![],'type':a0_0x48d710(0xe7),'description':'Non-unique\x20indexes.\x20Each\x20entry\x20is\x20array\x20of\x20column\x20names\x20or\x20object\x20{\x20name,\x20columns\x20}.','example':'[[\x22status\x22,\x20\x22created_at\x22]]'},{'name':'uniques','required':![],'type':'array','description':a0_0x48d710(0xe1),'example':a0_0x48d710(0xc6)},{'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_0x48d710(0xf4)}],FIELD_TYPES=[{'name':a0_0x48d710(0xb3),'description':'Variable-length\x20text.\x20Length\x20modifier\x20required.','requiresModifier':!![],'modifierFormat':'string:<length>','example':a0_0x48d710(0x97),'notes':a0_0x48d710(0xb4)},{'name':'text','description':a0_0x48d710(0xe2),'requiresModifier':![],'example':a0_0x48d710(0xaf)},{'name':'integer','description':'32-bit\x20signed\x20integer\x20(INT/INTEGER).','requiresModifier':![],'example':a0_0x48d710(0xdf)},{'name':a0_0x48d710(0xbd),'description':'64-bit\x20signed\x20integer\x20(BIGINT).','requiresModifier':![],'example':'bigint'},{'name':a0_0x48d710(0xe6),'description':'Fixed-point\x20decimal.\x20Precision\x20and\x20scale\x20required.','requiresModifier':!![],'modifierFormat':a0_0x48d710(0xa4),'example':'decimal:15,2','notes':a0_0x48d710(0xf3)},{'name':a0_0x48d710(0xef),'description':a0_0x48d710(0xa3),'requiresModifier':![],'example':'boolean'},{'name':a0_0x48d710(0xf7),'description':'Date\x20only\x20(no\x20time\x20component).','requiresModifier':![],'example':'date'},{'name':'timestamp','description':a0_0x48d710(0xa6),'requiresModifier':![],'example':a0_0x48d710(0xa9),'notes':'Default\x20timezone\x20behavior\x20is\x20dialect-specific.'},{'name':'uuid','description':'UUID.\x20Native\x20UUID\x20on\x20PostgreSQL,\x20VARCHAR(36)\x20on\x20others.','requiresModifier':![],'example':'uuid'},{'name':'json','description':'JSON\x20column\x20(JSONB\x20on\x20PostgreSQL,\x20JSON\x20on\x20MySQL,\x20CLOB\x20on\x20Oracle).','requiresModifier':![],'example':a0_0x48d710(0xc5)}],CONSTRAINTS=[{'name':'pk','kind':a0_0x48d710(0xa2),'description':'Marks\x20field\x20as\x20primary\x20key.','example':'string:36\x20pk'},{'name':a0_0x48d710(0xf1),'kind':a0_0x48d710(0xa2),'description':a0_0x48d710(0xfc),'example':a0_0x48d710(0xc1)},{'name':'unique','kind':a0_0x48d710(0xa2),'description':'Single-column\x20unique\x20constraint.','example':a0_0x48d710(0xd1)},{'name':a0_0x48d710(0xe0),'kind':a0_0x48d710(0xa2),'description':a0_0x48d710(0xed),'example':'string:64\x20index'},{'name':'autoUpdate','kind':a0_0x48d710(0xa2),'deprecated':!![],'description':a0_0x48d710(0x9b),'example':a0_0x48d710(0xa9),'notes':'Engine\x20still\x20parses\x20this\x20token\x20(backward\x20compatibility),\x20but\x20DDL\x20output\x20is\x20identical\x20to\x20plain\x20\x27timestamp\x27.\x20Use\x20\x27timestamp\x27\x20alone.\x20The\x20actual\x20auto-update\x20behavior\x20is\x20documented\x20in\x20the\x20RDF\x20auditColumns\x20catalog\x20(field-validation:catalog).'},{'name':'default','kind':'value','description':'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':'boolean\x20default:true'},{'name':'fk','kind':'value','description':'Foreign\x20key\x20reference.\x20Auto-generates\x20a\x20belongsTo\x20relation\x20entry.','valueFormat':'fk:<table>.<column>','example':'string:36\x20fk:category.id','notes':'Cannot\x20coexist\x20with\x20explicit\x20relation\x20entry\x20referencing\x20the\x20same\x20field.'}],RELATION_TYPES=[{'name':a0_0x48d710(0xab),'description':'Many-to-one.\x20This\x20table\x20holds\x20the\x20FK\x20column\x20referencing\x20the\x20parent\x20table.','requiredFields':['type',a0_0x48d710(0xfa),a0_0x48d710(0xdc)],'optionalFields':['target','onDelete',a0_0x48d710(0xc9)],'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_0x48d710(0xaa),'requiredFields':[a0_0x48d710(0xf6),a0_0x48d710(0xfa),'references'],'optionalFields':['target','onDelete',a0_0x48d710(0xc9)],'example':a0_0x48d710(0xc0)},{'name':'hasMany','description':'One-to-many\x20(inverse\x20of\x20belongsTo).\x20Optional\x20inverse\x20declaration\x20on\x20the\x20parent\x20side;\x20does\x20not\x20affect\x20DDL.','requiredFields':['type',a0_0x48d710(0xfa),'references'],'optionalFields':[a0_0x48d710(0xcc),'onDelete',a0_0x48d710(0xc9)],'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_0x48d710(0xae),'description':'Cascade\x20delete/update\x20to\x20child\x20rows.','appliesTo':['onDelete',a0_0x48d710(0xc9)]},{'name':a0_0x48d710(0xd6),'description':a0_0x48d710(0xd2),'appliesTo':['onDelete','onUpdate']},{'name':'setNull','description':a0_0x48d710(0xa7),'appliesTo':['onDelete',a0_0x48d710(0xc9)],'notes':a0_0x48d710(0xf5)},{'name':'noAction','description':a0_0x48d710(0xc4),'appliesTo':['onDelete','onUpdate']}],CHECK_OPERATIONS=[{'name':'in','description':'Value\x20must\x20be\x20one\x20of\x20a\x20list.','valueType':a0_0x48d710(0xe7),'example':'{\x20field:\x20\x22status\x22,\x20in:\x20[\x22active\x22,\x20\x22inactive\x22]\x20}'},{'name':'eq','description':'Equal\x20to.','valueType':'scalar','example':a0_0x48d710(0xe9)},{'name':'neq','description':a0_0x48d710(0xa0),'valueType':a0_0x48d710(0xa5),'example':'{\x20field:\x20\x22type\x22,\x20neq:\x20\x22system\x22\x20}'},{'name':'gt','description':a0_0x48d710(0xd9),'valueType':a0_0x48d710(0xca),'example':a0_0x48d710(0xfd)},{'name':'gte','description':'Greater\x20than\x20or\x20equal\x20to.','valueType':'numeric','example':a0_0x48d710(0xc7)},{'name':'lt','description':'Less\x20than.','valueType':'numeric','example':a0_0x48d710(0xb6)},{'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':a0_0x48d710(0xbc),'shorthand':a0_0x48d710(0xb7),'nullable':!![],'purpose':'Record\x20creation\x20timestamp.\x20Auto-set\x20on\x20INSERT\x20via\x20DEFAULT\x20now().\x20Native\x20function\x20translates\x20per\x20dialect\x20(postgres:\x20CURRENT_TIMESTAMP,\x20mysql:\x20NOW(),\x20oracle:\x20SYSTIMESTAMP,\x20sqlite:\x20CURRENT_TIMESTAMP).'},{'name':a0_0x48d710(0xbe),'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':a0_0x48d710(0x9d),'shorthand':a0_0x48d710(0xa9),'nullable':!![],'purpose':a0_0x48d710(0xd0)},{'name':a0_0x48d710(0xda),'shorthand':a0_0x48d710(0xa1),'nullable':!![],'purpose':'User\x20identifier\x20of\x20the\x20last\x20modifier.\x20Set\x20by\x20application\x20layer\x20on\x20UPDATE,\x20not\x20by\x20database\x20default.'}],'convention':{'emitInSkeleton':a0_0x48d710(0x9a),'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':'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.'}},SHORTHAND_SYNTAX={'format':a0_0x48d710(0xcd),'description':a0_0x48d710(0x9e),'rules':[a0_0x48d710(0xd8),a0_0x48d710(0xb8),a0_0x48d710(0xc8),a0_0x48d710(0xb0),'Default\x20value\x20format\x20depends\x20on\x20type:\x20raw\x20for\x20boolean\x20(default:true),\x20raw\x20for\x20integer\x20(default:0),\x20single-quoted\x20for\x20string\x20(default:\x27value\x27),\x20bare\x20identifier\x20for\x20SQL\x20constants\x20(default:current_date),\x20identifier()\x20for\x20native\x20function\x20calls\x20(default:now()).','Foreign\x20key\x20uses\x20dot\x20notation:\x20fk:<table>.<column>\x20(e.g.,\x20fk:category.id).\x20The\x20parser\x20rejects\x20parentheses\x20syntax.'],'examples':[{'input':a0_0x48d710(0xe3),'meaning':a0_0x48d710(0xb5)},{'input':a0_0x48d710(0xc1),'meaning':a0_0x48d710(0xb9)},{'input':'decimal:15,2\x20notnull\x20default:0','meaning':'DECIMAL(15,2)\x20NOT\x20NULL\x20DEFAULT\x200'},{'input':a0_0x48d710(0xbb),'meaning':'BOOLEAN\x20DEFAULT\x20TRUE'},{'input':a0_0x48d710(0xe8),'meaning':'VARCHAR(100)\x20DEFAULT\x20\x27pending\x27'},{'input':'timestamp\x20default:now()','meaning':a0_0x48d710(0xf9)},{'input':'string:36\x20fk:category.id','meaning':a0_0x48d710(0xb2)},{'input':'string:64\x20index','meaning':'VARCHAR(64)\x20with\x20single-column\x20index'}]},NAMING_RULES={'tableName':{'format':a0_0x48d710(0xbf),'description':'Table\x20name\x20must\x20be\x20lowercase,\x20digits,\x20and\x20underscores\x20only.'},'fieldName':{'format':a0_0x48d710(0xbf),'description':'Column\x20name\x20must\x20be\x20snake_case.'},'constraintName':{'format':a0_0x48d710(0xc3),'defaultMaxLength':0x1e,'fallbackStrategy':'MD5\x20hash\x208-character\x20suffix\x20when\x20name\x20exceeds\x20maxLength','description':a0_0x48d710(0xee)},'compositeShortName':{'description':a0_0x48d710(0xde)}},DIALECT_SUPPORT=[{'name':'postgres','driver':'pg','booleanStorage':'native\x20BOOLEAN'},{'name':a0_0x48d710(0xdb),'driver':'mysql2','booleanStorage':a0_0x48d710(0xb1)},{'name':'oracle','driver':'oracledb','booleanStorage':'VARCHAR2\x20with\x20CHECK\x20constraint'},{'name':a0_0x48d710(0xad),'driver':'better-sqlite3','booleanStorage':'TEXT'}],DBSCHEMA_CATALOG={'schemaVersion':SCHEMA_VERSION,'source':SOURCE,'summary':{'totalDefineModelOptions':DEFINE_MODEL_OPTIONS[a0_0x48d710(0xba)],'totalFieldTypes':FIELD_TYPES[a0_0x48d710(0xba)],'totalConstraints':CONSTRAINTS['length'],'totalRelationTypes':RELATION_TYPES[a0_0x48d710(0xba)],'totalReferentialActions':REFERENTIAL_ACTIONS[a0_0x48d710(0xba)],'totalCheckOperations':CHECK_OPERATIONS['length'],'totalAuditColumns':AUDIT_COLUMNS[a0_0x48d710(0xd7)]['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,'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,'SHORTHAND_SYNTAX':SHORTHAND_SYNTAX,'NAMING_RULES':NAMING_RULES,'DIALECT_SUPPORT':DIALECT_SUPPORT};
1
+ 'use strict';const a0_0x2c951a=a0_0x23aa;(function(_0xaf6061,_0x2fece9){const _0x50cb07=a0_0x23aa,_0x106491=_0xaf6061();while(!![]){try{const _0x4e2159=parseInt(_0x50cb07(0x1d3))/0x1+parseInt(_0x50cb07(0x1d0))/0x2*(parseInt(_0x50cb07(0x196))/0x3)+parseInt(_0x50cb07(0x1a0))/0x4*(parseInt(_0x50cb07(0x1b4))/0x5)+-parseInt(_0x50cb07(0x1ba))/0x6*(-parseInt(_0x50cb07(0x1d4))/0x7)+parseInt(_0x50cb07(0x1e4))/0x8*(parseInt(_0x50cb07(0x1f8))/0x9)+parseInt(_0x50cb07(0x1c6))/0xa+-parseInt(_0x50cb07(0x1c4))/0xb;if(_0x4e2159===_0x2fece9)break;else _0x106491['push'](_0x106491['shift']());}catch(_0xd6a6f8){_0x106491['push'](_0x106491['shift']());}}}(a0_0x521e,0x7fb36));function a0_0x23aa(_0x32d51c,_0x155368){_0x32d51c=_0x32d51c-0x191;const _0x521ef2=a0_0x521e();let _0x23aa4f=_0x521ef2[_0x32d51c];if(a0_0x23aa['kIOYUg']===undefined){var _0x33dbbe=function(_0x5b3197){const _0xaf6b3d='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x2cd598='',_0x50b6c2='';for(let _0x5d7d73=0x0,_0x4719b2,_0x490472,_0x44553a=0x0;_0x490472=_0x5b3197['charAt'](_0x44553a++);~_0x490472&&(_0x4719b2=_0x5d7d73%0x4?_0x4719b2*0x40+_0x490472:_0x490472,_0x5d7d73++%0x4)?_0x2cd598+=String['fromCharCode'](0xff&_0x4719b2>>(-0x2*_0x5d7d73&0x6)):0x0){_0x490472=_0xaf6b3d['indexOf'](_0x490472);}for(let _0x36020d=0x0,_0x2c38d3=_0x2cd598['length'];_0x36020d<_0x2c38d3;_0x36020d++){_0x50b6c2+='%'+('00'+_0x2cd598['charCodeAt'](_0x36020d)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x50b6c2);};a0_0x23aa['MSYPtC']=_0x33dbbe,a0_0x23aa['QmQKvz']={},a0_0x23aa['kIOYUg']=!![];}const _0x1f211d=_0x521ef2[0x0],_0xdc46f8=_0x32d51c+_0x1f211d,_0x5100de=a0_0x23aa['QmQKvz'][_0xdc46f8];return!_0x5100de?(_0x23aa4f=a0_0x23aa['MSYPtC'](_0x23aa4f),a0_0x23aa['QmQKvz'][_0xdc46f8]=_0x23aa4f):_0x23aa4f=_0x5100de,_0x23aa4f;}const SCHEMA_VERSION=a0_0x2c951a(0x1ae),SOURCE='dbschema-catalog',DOCUMENTATION_URL='https://restforge.dev/docs/cli/schema-definition',DEFINE_MODEL_OPTIONS=[{'name':a0_0x2c951a(0x1a9),'required':![],'type':'string|null','description':'Database\x20schema\x20namespace\x20(multi-schema\x20database).','notes':a0_0x2c951a(0x1af)},{'name':'fields','required':!![],'type':'object','description':'Object\x20of\x20field\x20definitions\x20in\x20shorthand\x20string\x20format.','example':a0_0x2c951a(0x19b)},{'name':'primaryKey','required':![],'type':a0_0x2c951a(0x1aa),'description':'Override\x20primary\x20key.\x20Single\x20field\x20name\x20or\x20composite\x20array.','notes':a0_0x2c951a(0x1bb)},{'name':'relations','required':![],'type':'object','description':'Inter-table\x20relations\x20(belongsTo,\x20hasOne,\x20hasMany).','example':a0_0x2c951a(0x1b1)},{'name':a0_0x2c951a(0x1fb),'required':![],'type':'array','description':a0_0x2c951a(0x1fe),'example':a0_0x2c951a(0x1e1)},{'name':'uniques','required':![],'type':a0_0x2c951a(0x192),'description':a0_0x2c951a(0x1e3),'example':a0_0x2c951a(0x1d6)},{'name':'checks','required':![],'type':a0_0x2c951a(0x192),'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}]'}],FIELD_TYPES=[{'name':a0_0x2c951a(0x1b0),'description':'Variable-length\x20text.\x20Length\x20modifier\x20required.','requiresModifier':!![],'modifierFormat':'string:<length>','example':a0_0x2c951a(0x1bc),'notes':'Explicit\x20length\x20required\x20for\x20cross-dialect\x20portability.'},{'name':'text','description':a0_0x2c951a(0x19c),'requiresModifier':![],'example':a0_0x2c951a(0x1b9)},{'name':'integer','description':'32-bit\x20signed\x20integer\x20(INT/INTEGER).','requiresModifier':![],'example':a0_0x2c951a(0x1c9)},{'name':'bigint','description':'64-bit\x20signed\x20integer\x20(BIGINT).','requiresModifier':![],'example':'bigint'},{'name':a0_0x2c951a(0x1b2),'description':a0_0x2c951a(0x1f4),'requiresModifier':!![],'modifierFormat':a0_0x2c951a(0x1dc),'example':a0_0x2c951a(0x1c2),'notes':'Precision\x20and\x20scale\x20required\x20for\x20cross-dialect\x20portability.'},{'name':a0_0x2c951a(0x1a1),'description':a0_0x2c951a(0x1c8),'requiresModifier':![],'example':'boolean'},{'name':'date','description':a0_0x2c951a(0x19a),'requiresModifier':![],'example':'date'},{'name':a0_0x2c951a(0x1f7),'description':a0_0x2c951a(0x1a6),'requiresModifier':![],'example':a0_0x2c951a(0x1f7),'notes':'Default\x20timezone\x20behavior\x20is\x20dialect-specific.'},{'name':'uuid','description':a0_0x2c951a(0x1cb),'requiresModifier':![],'example':'uuid'},{'name':a0_0x2c951a(0x1e5),'description':'JSON\x20column\x20(JSONB\x20on\x20PostgreSQL,\x20JSON\x20on\x20MySQL,\x20CLOB\x20on\x20Oracle).','requiresModifier':![],'example':a0_0x2c951a(0x1e5)}],CONSTRAINTS=[{'name':'pk','kind':a0_0x2c951a(0x1b7),'description':'Marks\x20field\x20as\x20primary\x20key.','example':a0_0x2c951a(0x1a5)},{'name':'notnull','kind':a0_0x2c951a(0x1b7),'description':'NOT\x20NULL\x20constraint.','example':a0_0x2c951a(0x1ec)},{'name':'unique','kind':a0_0x2c951a(0x1b7),'description':a0_0x2c951a(0x1a7),'example':a0_0x2c951a(0x1be)},{'name':'index','kind':'standalone','description':a0_0x2c951a(0x1d5),'example':a0_0x2c951a(0x1ed)},{'name':a0_0x2c951a(0x1fd),'kind':'standalone','deprecated':!![],'description':a0_0x2c951a(0x1ac),'example':'timestamp','notes':a0_0x2c951a(0x197)},{'name':a0_0x2c951a(0x1ea),'kind':a0_0x2c951a(0x1f2),'description':'Default\x20value.\x20Single-quoted\x20for\x20strings,\x20raw\x20for\x20numeric/boolean,\x20bare\x20identifier\x20for\x20SQL\x20constants,\x20identifier()\x20for\x20native\x20function\x20calls.','valueFormat':a0_0x2c951a(0x1d7),'example':'boolean\x20default:true'},{'name':'fk','kind':'value','description':a0_0x2c951a(0x1e0),'valueFormat':a0_0x2c951a(0x1b6),'example':'string:36\x20fk:category.id','notes':a0_0x2c951a(0x1b8)}],RELATION_TYPES=[{'name':'belongsTo','description':a0_0x2c951a(0x1d1),'requiredFields':['type','localKey',a0_0x2c951a(0x193)],'optionalFields':[a0_0x2c951a(0x1fc),'onDelete',a0_0x2c951a(0x1c5)],'example':'{\x20type:\x20\x22belongsTo\x22,\x20localKey:\x20\x22category_id\x22,\x20references:\x20\x22category_id\x22,\x20onDelete:\x20\x22restrict\x22\x20}','notes':a0_0x2c951a(0x1e6)},{'name':'hasOne','description':a0_0x2c951a(0x1ad),'requiredFields':['type',a0_0x2c951a(0x1d8),'references'],'optionalFields':['target','onDelete',a0_0x2c951a(0x1c5)],'example':a0_0x2c951a(0x194)},{'name':'hasMany','description':a0_0x2c951a(0x1ce),'requiredFields':['type',a0_0x2c951a(0x1d8),'references'],'optionalFields':[a0_0x2c951a(0x1fc),a0_0x2c951a(0x19f),'onUpdate'],'example':'{\x20type:\x20\x22hasMany\x22,\x20target:\x20\x22order_item\x22,\x20localKey:\x20\x22order_id\x22,\x20references:\x20\x22order_id\x22\x20}'}],REFERENTIAL_ACTIONS=[{'name':a0_0x2c951a(0x1bf),'description':a0_0x2c951a(0x1ab),'appliesTo':['onDelete','onUpdate']},{'name':'restrict','description':a0_0x2c951a(0x1c0),'appliesTo':[a0_0x2c951a(0x19f),'onUpdate']},{'name':'setNull','description':'Set\x20FK\x20column\x20to\x20NULL\x20on\x20child\x20rows.','appliesTo':[a0_0x2c951a(0x19f),a0_0x2c951a(0x1c5)],'notes':'FK\x20field\x20must\x20be\x20nullable.'},{'name':'noAction','description':a0_0x2c951a(0x1cd),'appliesTo':[a0_0x2c951a(0x19f),'onUpdate']}],CHECK_OPERATIONS=[{'name':'in','description':a0_0x2c951a(0x1db),'valueType':a0_0x2c951a(0x192),'example':'{\x20field:\x20\x22status\x22,\x20in:\x20[\x22active\x22,\x20\x22inactive\x22]\x20}'},{'name':'eq','description':a0_0x2c951a(0x1ca),'valueType':a0_0x2c951a(0x1e9),'example':a0_0x2c951a(0x1ef)},{'name':a0_0x2c951a(0x1b5),'description':a0_0x2c951a(0x1fa),'valueType':'scalar','example':a0_0x2c951a(0x1f3)},{'name':'gt','description':a0_0x2c951a(0x1eb),'valueType':a0_0x2c951a(0x1b3),'example':a0_0x2c951a(0x1e2)},{'name':a0_0x2c951a(0x199),'description':'Greater\x20than\x20or\x20equal\x20to.','valueType':a0_0x2c951a(0x1b3),'example':'{\x20field:\x20\x22qty\x22,\x20gte:\x200\x20}'},{'name':'lt','description':a0_0x2c951a(0x198),'valueType':'numeric','example':a0_0x2c951a(0x19d)},{'name':a0_0x2c951a(0x1a4),'description':a0_0x2c951a(0x191),'valueType':'numeric','example':a0_0x2c951a(0x1dd)}],AUDIT_COLUMNS={'description':'Standard\x204-column\x20audit\x20convention\x20for\x20tables\x20managed\x20by\x20RESTForge.\x20The\x20same\x20convention\x20is\x20documented\x20in\x20field-validation:catalog\x20(auditColumns\x20section)\x20for\x20the\x20RDF/backend\x20layer.\x20SDF\x20and\x20RDF\x20stay\x20aligned\x20when\x20both\x20declare\x20these\x204\x20columns.','columns':[{'name':a0_0x2c951a(0x1c7),'shorthand':'timestamp\x20default:now()','nullable':!![],'purpose':'Record\x20creation\x20timestamp.\x20Auto-set\x20on\x20INSERT\x20via\x20DEFAULT\x20now().\x20Native\x20function\x20translates\x20per\x20dialect\x20(postgres:\x20CURRENT_TIMESTAMP,\x20mysql:\x20NOW(),\x20oracle:\x20SYSTIMESTAMP,\x20sqlite:\x20CURRENT_TIMESTAMP).'},{'name':a0_0x2c951a(0x1a8),'shorthand':a0_0x2c951a(0x195),'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':'timestamp','nullable':!![],'purpose':a0_0x2c951a(0x1f0)},{'name':'updated_by','shorthand':a0_0x2c951a(0x195),'nullable':!![],'purpose':'User\x20identifier\x20of\x20the\x20last\x20modifier.\x20Set\x20by\x20application\x20layer\x20on\x20UPDATE,\x20not\x20by\x20database\x20default.'}],'convention':{'emitInSkeleton':a0_0x2c951a(0x1df),'nullablePolicy':a0_0x2c951a(0x1cf),'relationToRdf':a0_0x2c951a(0x1c1)}},SHORTHAND_SYNTAX={'format':a0_0x2c951a(0x1f9),'description':a0_0x2c951a(0x200),'rules':[a0_0x2c951a(0x1a2),a0_0x2c951a(0x1f5),'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.','Default\x20value\x20format\x20depends\x20on\x20type:\x20raw\x20for\x20boolean\x20(default:true),\x20raw\x20for\x20integer\x20(default:0),\x20single-quoted\x20for\x20string\x20(default:\x27value\x27),\x20bare\x20identifier\x20for\x20SQL\x20constants\x20(default:current_date),\x20identifier()\x20for\x20native\x20function\x20calls\x20(default:now()).','Foreign\x20key\x20uses\x20dot\x20notation:\x20fk:<table>.<column>\x20(e.g.,\x20fk:category.id).\x20The\x20parser\x20rejects\x20parentheses\x20syntax.'],'examples':[{'input':a0_0x2c951a(0x1a5),'meaning':'VARCHAR(36)\x20PRIMARY\x20KEY'},{'input':a0_0x2c951a(0x1ec),'meaning':'VARCHAR(255)\x20NOT\x20NULL'},{'input':'decimal:15,2\x20notnull\x20default:0','meaning':'DECIMAL(15,2)\x20NOT\x20NULL\x20DEFAULT\x200'},{'input':'boolean\x20default:true','meaning':'BOOLEAN\x20DEFAULT\x20TRUE'},{'input':a0_0x2c951a(0x1cc),'meaning':'VARCHAR(100)\x20DEFAULT\x20\x27pending\x27'},{'input':'timestamp\x20default:now()','meaning':'TIMESTAMP\x20DEFAULT\x20<native_now\x20per\x20dialect>'},{'input':a0_0x2c951a(0x1e7),'meaning':a0_0x2c951a(0x1f6)},{'input':'string:64\x20index','meaning':'VARCHAR(64)\x20with\x20single-column\x20index'}]},NAMING_RULES={'tableName':{'format':a0_0x2c951a(0x1a3),'description':'Table\x20name\x20must\x20be\x20lowercase,\x20digits,\x20and\x20underscores\x20only.'},'fieldName':{'format':'snake_case','description':'Column\x20name\x20must\x20be\x20snake_case.'},'constraintName':{'format':a0_0x2c951a(0x1c3),'defaultMaxLength':0x1e,'fallbackStrategy':'MD5\x20hash\x208-character\x20suffix\x20when\x20name\x20exceeds\x20maxLength','description':a0_0x2c951a(0x1de)},'compositeShortName':{'description':a0_0x2c951a(0x1ff)}},DIALECT_SUPPORT=[{'name':a0_0x2c951a(0x1d9),'driver':'pg','booleanStorage':'native\x20BOOLEAN'},{'name':'mysql','driver':'mysql2','booleanStorage':'VARCHAR\x20(literal\x20\x22true\x22/\x22false\x22)'},{'name':a0_0x2c951a(0x1ee),'driver':'oracledb','booleanStorage':a0_0x2c951a(0x1d2)},{'name':a0_0x2c951a(0x1f1),'driver':a0_0x2c951a(0x1e8),'booleanStorage':'TEXT'}],DBSCHEMA_CATALOG={'schemaVersion':SCHEMA_VERSION,'source':SOURCE,'summary':{'totalDefineModelOptions':DEFINE_MODEL_OPTIONS['length'],'totalFieldTypes':FIELD_TYPES['length'],'totalConstraints':CONSTRAINTS['length'],'totalRelationTypes':RELATION_TYPES[a0_0x2c951a(0x19e)],'totalReferentialActions':REFERENTIAL_ACTIONS[a0_0x2c951a(0x19e)],'totalCheckOperations':CHECK_OPERATIONS[a0_0x2c951a(0x19e)],'totalAuditColumns':AUDIT_COLUMNS[a0_0x2c951a(0x1da)][a0_0x2c951a(0x19e)],'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,'shorthandSyntax':SHORTHAND_SYNTAX,'namingRules':NAMING_RULES,'dialectSupport':DIALECT_SUPPORT,'documentationUrl':DOCUMENTATION_URL};module[a0_0x2c951a(0x1bd)]={'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,'SHORTHAND_SYNTAX':SHORTHAND_SYNTAX,'NAMING_RULES':NAMING_RULES,'DIALECT_SUPPORT':DIALECT_SUPPORT};function a0_0x521e(){const _0x3264ea=['y2fZy2fKzq','uMvQzwn0igrLBgv0zs91CgrHDguGD2HLBIbJAgLSzcbYB3DZigv4Axn0lG','vgHLifjerIbNzw5LCMf0B3iGkgnVzgvNzw5Fy3jLyxrLx2vUzhbVAw50ksbHC3n1BwvZihrOzxnLidqGy29SDw1UCYbLEgLZDcb3AgvUihrOzsbWyxLSB2fKlMf1zgL0q29SDw1UCYbRzxKGAxmGywjZzw50lIbtzwuGzMLLBgqTDMfSAwrHDgLVBJPJyxrHBg9Nigf1zgL0q29SDw1UCYbMB3iGDgHLifjerI1ZAwrLigjLAgf2Aw9YlIbeCMLMDcbIzxr3zwvUifnerIaOBwLZC2LUzYbHDwrPDcbJB2X1Bw5ZksbHBMqGuKrgicHHC3n1BwvZigf1zgL0ignVBhvTBNmPignHDxnLCYbYDw50Aw1LigvYCM9YCYb3AgvUihrOzsbNzw5LCMf0zwqGzw5KCg9PBNqGDhjPzxmGDg8GD3jPDguGy3jLyxrLzf9IEs91CgrHDgvKx2j5ihrVigeGBM9Ulwv4Axn0zw50ignVBhvTBI4','zgvJAw1HBdOXnsWY','phbYzwzPEd5FphrHyMXLpL88C3vMzML4pG','mZe1ndi3ndjdqMrdrve','B25vCgrHDgu','mtm4nJu3meHXzKnACq','y3jLyxrLzf9HDa','qM9VBgvHBIb2ywX1zsaOBMf0AxzLiejpt0Xfqu4GB24Gug9ZDgDYzvnrtcWGvKfsq0HbuIbVBIbVDgHLCNmPlG','Aw50zwDLCG','rxf1ywWGDg8U','vvvjrc4GtMf0AxzLifvvsuqGB24Gug9ZDgDYzvnrtcWGvKfsq0HbuIGZnIKGB24GB3rOzxjZlG','C3rYAw5NoJeWmcbKzwzHDwX0oIDWzw5KAw5NjW','rgvMzxiGy29UC3rYywLUDcbJAgvJAYaOC2vTyw50AwnHBgX5ihnPBwLSyxiGDg8GCMvZDhjPy3qGB24GBw9ZDcbKAwfSzwn0CYKU','t25LlxrVlw1HBNKGkgLUDMvYC2uGB2yGyMvSB25NC1rVks4Gt3b0Aw9UywWGAw52zxjZzsbKzwnSyxjHDgLVBIbVBIb0AguGCgfYzw50ihnPzgu7igrVzxmGBM90igfMzMvJDcbereWU','qwXSidqGy29SDw1UCYbHCMuGBNvSBgfIBguUifrOzsbJCMvHDgvKx2j5l3vWzgf0zwrFyNKGy29SDw1UCYbTyxKGyMuGzw1WDhKGzM9YihjVD3mGAw5Zzxj0zwqGyNKGC3LZDgvTihnLzwrZlcbTAwDYyxrPB25ZlcbVCIbIyxrJAcbPBxbVCNrZihrOyxqGzg8GBM90igHHDMuGysb1C2vYignVBNrLEhqU','mta2ruXet09W','twfUEs10BY1VBMuUifrOAxmGDgfIBguGAg9SzhmGDgHLiezlignVBhvTBIbYzwzLCMvUy2LUzYb0AguGCgfYzw50ihrHyMXLlG','vKfsq0HbuJiGD2L0AcbdsevdsYbJB25ZDhjHAw50','nZi0nJeXz1bOD0Hm','nZDpEuvbBhq','u2LUz2XLlwnVBhvTBIbUB24TDw5PCxvLigLUzgv4lG','w1SIy2f0zwDVCNLFy29KzsjDlcbBiNrLBMfUDf9PzciSicjJyxrLz29YEv9JB2rLiL1D','zgvMyxvSDdO8BgL0zxjHBd4GFcbKzwzHDwX0oIC8C3rYAw5NpICGFcbKzwzHDwX0oJXJB25ZDgfUDd4GFcbKzwzHDwX0oJXMDw5JDgLVBJ4Okq','Bg9JywXlzxK','Cg9ZDgDYzxm','y29SDw1UCW','vMfSDwuGBxvZDcbIzsbVBMuGB2yGysbSAxn0lG','zgvJAw1HBdO8ChjLy2LZAw9UpIW8C2nHBgu+','EYbMAwvSzdOGiMrPC2nVDw50iIWGBhrLoIaXmdaGFq','q29UC3rYywLUDcbUyw1LCYbHDxrVlwDLBMvYyxrLzcb3AxrOihr5CguTC3bLy2LMAwmGChjLzML4icHWAYWGzMSSigLKEcWGDxeSignRksbHBMqGzgLHBgvJDc1ZCgvJAwzPyYbTyxGGBgvUz3rOlG','wwvZiokaLcbKyNnJAgvTytPPBML0igvTAxrZigfSBca0ignVBhvTBNmGyNKGzgvMyxvSDc4GvgfIBgvZihrOyxqGzg8GBM90ig5LzwqGyxvKAxqGkgXVB2T1Ccb0ywjSzxmSihn5C3rLBsb0ywjSzxmPignHBIbTyw51ywXSEsbYzw1VDMuGDgHLC2uGzMLLBgrZigzYB20GDgHLigDLBMvYyxrLzcbZA2vSzxrVBI4','rM9YzwLNBIbRzxKGCMvMzxjLBMnLlIbbDxrVlwDLBMvYyxrLCYbHigjLBg9Uz3nuBYbYzwXHDgLVBIbLBNrYEs4','w1SIC3rHDhvZiIWGiMnYzwf0zwrFyxqIxv0','EYbMAwvSzdOGiNf0EsiSigD0oIaWih0','vw5PCxvLignVBNn0CMfPBNrZicHZAw5NBguGB3iGy29TCg9ZAxrLks4','mtyWuhvbzwXl','ANnVBG','yhjLzMvYzw5JzxnGigLZihrOzsbIyxjLignVBhvTBIbUyw1LigLUihrOzsb0yxjNzxqGDgfIBguUifrHCMDLDcb0ywjSzsbPCYbHDxrVlwrLCML2zwqGzNjVBsb0AguGCMvSyxrPB24GA2v5ig5HBwuSig9Yig92zxjYAwrLihDPDgGGyhrHCMDLDgaU','C3rYAw5NoJm2igzRoMnHDgvNB3j5lMLK','yMv0DgvYlxnXBgL0ztm','C2nHBgfY','zgvMyxvSDa','r3jLyxrLCIb0AgfUlG','C3rYAw5NoJi1nsbUB3rUDwXS','C3rYAw5NoJy0igLUzgv4','B3jHy2XL','EYbMAwvSzdOGiNr5CguIlcbLCtOGiNvZzxiIih0','tgfZDcbTB2rPzMLJyxrPB24GDgLTzxn0yw1WlIbbDxrVlxvWzgf0zsbPCYbOyw5KBgvKigj5ihrOzsbsreyGCNvUDgLTzsaOqMfZzu1VzgvSigf1zgL0q29SDw1UCYbJB252zw50Aw9Uksb3AgLJAcbPBMPLy3rZihvWzgf0zwrFyxqGpsbdvvjsru5ux1rjtuvtvefnucbPBNrVigv2zxj5ifvqrefursbZDgf0zw1LBNqGyMfZzwqGB24GzMLLBgqGBMfTAw5NlcbUB3qGyNKGyw55ifnerIbTyxjRzxiUieLUAxrPywWGsu5trvjuihzHBhvLigLZigfSC28GAgfUzgXLzcbIEsb0AguGuKrgihj1BNrPBwuGyxvKAxrdB2X1Bw5ZigHLBhbLCI4','C3fSAxrL','DMfSDwu','EYbMAwvSzdOGiNr5CguIlcbUzxe6icjZExn0zw0Iih0','rML4zwqTCg9PBNqGzgvJAw1HBc4GuhjLy2LZAw9UigfUzcbZy2fSzsbYzxf1AxjLzc4','tw9KAwzPzxiGAxmGBwfUzgf0B3j5igzVCIb0ExbLicjZDhjPBMCIicHSzw5NDgGPigfUzcaIzgvJAw1HBciGkhbYzwnPC2LVBIXZy2fSzsKU','vKfsq0HbuIGZnIKGD2L0AcbgsYb0BYbJyxrLz29YEsHPzcKSigf1Dg8GyMvSB25NC1rVihjLBgf0Aw9U','DgLTzxn0yw1W','mJaZodmYuufwsfzS','phr5Cgu+wZO8Bw9KAwzPzxi+xsbBpgnVBNn0CMfPBNq+wZO8DMfSDwu+xv0UlI4','tM90igvXDwfSihrVlG','Aw5KzxHLCW','DgfYz2v0','yxv0B1vWzgf0zq','tM9UlxvUAxf1zsbPBMrLEgvZlIbfywnOigvUDhj5igLZigfYCMf5ig9MignVBhvTBIbUyw1LCYbVCIbVyMPLy3qGEYbUyw1LlcbJB2X1Bw5Zih0U','rM9YignVBxbVC2L0zsbPBMrLEgvZl3vUAxf1zxmSig5HBwuGAxmGzgvYAxzLzcbIEsbQB2LUAw5NignVBhvTBNmGD2L0Acb1BMrLCNnJB3jLigfUzcb0CNvUy2f0Aw5NihDOzw4GBMvLzgvKlG','u3rYAw5NihnOB3j0AgfUzcbMB3iGzMLLBgqGzgvMAw5PDgLVBI4GvhLWzsbYzxf1AxjLzcbHDcbZDgfYDcWGzM9SBg93zwqGyNKGB3b0Aw9UywWGBw9KAwzPzxiGyw5KihnWywnLlxnLCgfYyxrLzcbJB25ZDhjHAw50CY4','tgvZCYb0AgfUig9YigvXDwfSihrVlG','yxjYyxK','CMvMzxjLBMnLCW','EYb0ExbLoIaIAgfZt25LiIWGDgfYz2v0oIaIChjVzMLSzsiSigXVy2fSs2v5oIaIDxnLCL9PzciSihjLzMvYzw5Jzxm6icj1C2vYx2LKiIb9','C3rYAw5NoJeWma','nty4odnMwxDiD0q','rw5NAw5Lihn0AwXSihbHCNnLCYb0AgLZihrVA2vUicHIywnRD2fYzcbJB21WyxrPyMLSAxr5ksWGyNv0ieretcbVDxrWDxqGAxmGAwrLBNrPy2fSihrVihbSywLUicD0Aw1LC3rHBxaNlIbvC2uGj3rPBwvZDgfTCcCGywXVBMuUifrOzsbHy3r1ywWGyxv0BY11CgrHDguGyMvOyxzPB3iGAxmGzg9JDw1LBNrLzcbPBIb0AguGuKrgigf1zgL0q29SDw1UCYbJyxrHBg9NicHMAwvSzc12ywXPzgf0Aw9UoMnHDgfSB2CPlG','tgvZCYb0AgfUlG','z3rL','rgf0zsbVBMX5icHUBYb0Aw1LignVBxbVBMvUDcKU','EYbPzdOGiNn0CMLUzZOZnIbWAYiSig5HBwu6icjZDhjPBMC6mJu1ig5VDg51BgWIih0','tg9UzY1MB3jTihrLEhqGD2L0Ag91DcbSzw5NDgGGBgLTAxqGkfrfwfqVq0XpqIKU','EYbMAwvSzdOGiMrPC2nVDw50iIWGBhq6ideWmcb9','BgvUz3rO','B25ezwXLDgu','nteYngjMve9xsa','yM9VBgvHBG','vhLWzsbPCYbTyw5KyxrVCNKGyxqGDgHLigjLz2LUBMLUzYbHBMqGBxvZDcbIzsbVBMuGB2yGzMLLBgruExbLCY4','C25HA2vFy2fZzq','BhrL','C3rYAw5NoJm2ihbR','rgf0zsbHBMqGDgLTzsaOveLnrvnuqu1qks4','u2LUz2XLlwnVBhvTBIb1BMLXDwuGy29UC3rYywLUDc4','y3jLyxrLzf9IEq','C2nOzw1H','C3rYAw5NFgfYCMf5','q2fZy2fKzsbKzwXLDguVDxbKyxrLihrVignOAwXKihjVD3mU','revquKvdqvrfrdOGvgHPCYbTB2rPzMLLCIbUBYbSB25NzxiGAgfZigz1BMn0Aw9UywWGzwzMzwn0igf0ihrOzsbereWGB3iGCNvUDgLTzsbSzxzLBc4Gqxv0BY11CgrHDguGzM9YihvWzgf0zwrFyxqGAxmGAgfUzgXLzcbIEsb0AguGuKrgigXHEwvYicHHDwrPDenVBhvTBNmGy29UDMvUDgLVBIbPBIbcyxnLtw9KzwWGCNvUDgLTzsKGyMfZzwqGB24GzMLLBgqGBMfTAw5NignVBNzLBNrPB24Sig5VDcbIEsb0AgLZifnerIbTyxjRzxiUiev4Axn0Aw5NihvZywDLigLZihbYzxnLCNzLzcbMB3iGyMfJA3DHCMqGy29TCgf0AwjPBgL0EsbIDxqGC2HVDwXKigjLihjLBw92zwqGzNjVBsbUzxCGDgvTCgXHDgvZlG','t25LlxrVlw9UzsaOAw52zxjZzsbVzIbIzwXVBMDZvg8PlIbpChrPB25HBcbPBNzLCNnLigrLy2XHCMf0Aw9Uig9UihrOzsbWyxjLBNqGC2LKztSGzg9LCYbUB3qGywzMzwn0ieretc4','ms4W','BNvSBcbVCIbLBxb0EsbZDhjPBMCGBwvHBNmGzgvMyxvSDcbZy2HLBweU','C3rYAw5N','EYbJyxrLz29YEtOGEYb0ExbLoIaIyMvSB25NC1rViIWGCMvMzxjLBMnLCZOGiMnHDgvNB3j5kgLKksiGFsb9','zgvJAw1HBa','BNvTzxjPyW','mJaWnvbJCxjZra','BMvX','zMS6phrHyMXLpI48y29SDw1UpG','C3rHBMrHBg9Uzq','q2fUBM90ignVzxHPC3qGD2L0AcbLEhbSAwnPDcbYzwXHDgLVBIbLBNrYEsbYzwzLCMvUy2LUzYb0AguGC2fTzsbMAwvSzc4','Dgv4Da','mZaZmtmYs0fJyvPL','qxv0BY1KzxrLy3rLzcbMCM9TigzPzwXKihnOB3j0AgfUzcaICgSIihDOzw4GBM90ihnWzwnPzMLLzc4','C3rYAw5NoJi1nq','zxHWB3j0CW','C3rYAw5NoJmYihvUAxf1zq'];a0_0x521e=function(){return _0x3264ea;};return a0_0x521e();}