@restforgejs/platform 5.2.0 → 5.2.4
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.
- package/build-info.json +2 -2
- package/cli/consumer-deploy.js +2 -2
- package/cli/consumer.js +2 -2
- package/generators/cli/fast-track.js +58 -5
- package/generators/lib/migrate/migrate-runner.js +12 -2
- package/generators/lib/migrate/sql-parser.js +5 -3
- package/generators/lib/payload/payload-runner.js +31 -5
- package/generators/lib/templates/dashboard-catalog.js +1 -1
- package/generators/lib/templates/db-connection-env.js +1 -1
- package/generators/lib/templates/dbschema-catalog.js +1 -1
- package/generators/lib/templates/field-validation-catalog.js +1 -1
- package/generators/lib/templates/mysql-template.js +1 -1
- package/generators/lib/templates/oracle-template.js +1 -1
- package/generators/lib/templates/postgres-template.js +1 -1
- package/generators/lib/templates/query-declarative-catalog.js +1 -1
- package/generators/lib/templates/sqlite-template.js +1 -1
- package/integrity-manifest.json +18 -18
- package/package.json +1 -1
- package/scripts/verify-integrity.js +1 -1
- package/server.js +2 -2
- package/src/components/handlers/adjust_handler.js +1 -1
- package/src/components/handlers/audit_handler.js +1 -1
- package/src/components/handlers/delete_handler.js +1 -1
- package/src/components/handlers/export_handler.js +1 -1
- package/src/components/handlers/import_handler.js +1 -1
- package/src/components/handlers/insert_handler.js +1 -1
- package/src/components/handlers/update_handler.js +1 -1
- package/src/components/handlers/upload_handler.js +1 -1
- package/src/components/handlers/workflow_handler.js +1 -1
- package/src/components/integrations/webhook.js +1 -1
- package/src/consumers/baseConsumer.js +1 -1
- package/src/consumers/declarativeMapper.js +1 -1
- package/src/consumers/handlers/apiHandler.js +1 -1
- package/src/consumers/handlers/consoleHandler.js +1 -1
- package/src/consumers/handlers/databaseHandler.js +1 -1
- package/src/consumers/handlers/index.js +1 -1
- package/src/consumers/handlers/kafkaHandler.js +1 -1
- package/src/consumers/index.js +1 -1
- package/src/consumers/messageTransformer.js +1 -1
- package/src/consumers/validator.js +1 -1
- package/src/core/db/dialect/base-dialect.js +1 -1
- package/src/core/db/dialect/index.js +1 -1
- package/src/core/db/dialect/mysql-dialect.js +1 -1
- package/src/core/db/dialect/oracle-dialect.js +1 -1
- package/src/core/db/dialect/postgres-dialect.js +1 -1
- package/src/core/db/dialect/sqlite-dialect.js +1 -1
- package/src/core/db/flatten-helper.js +1 -1
- package/src/core/db/query-builder-error.js +1 -1
- package/src/core/db/query-builder.js +1 -1
- package/src/core/db/relation-helper.js +1 -1
- package/src/core/handlers/delete_handler.js +1 -1
- package/src/core/handlers/insert_handler.js +1 -1
- package/src/core/handlers/update_handler.js +1 -1
- package/src/core/models/base-model.js +1 -1
- package/src/core/utils/cache-manager.js +1 -1
- package/src/core/utils/component-engine.js +1 -1
- package/src/core/utils/context-builder.js +1 -1
- package/src/core/utils/datetime-formatter.js +1 -1
- package/src/core/utils/datetime-parser.js +1 -1
- package/src/core/utils/db.js +1 -1
- package/src/core/utils/logger.js +1 -1
- package/src/core/utils/payload-loader.js +1 -1
- package/src/core/utils/security-checks.js +1 -1
- package/src/middleware/body-options.js +1 -1
- package/src/middleware/cors.js +1 -1
- package/src/middleware/idempotency.js +1 -1
- package/src/middleware/rate-limiter.js +1 -1
- package/src/middleware/request-logger.js +1 -1
- package/src/middleware/security-headers.js +1 -1
- package/src/models/base-model-mysql.js +1 -1
- package/src/models/base-model-oracle.js +1 -1
- package/src/models/base-model-sqlite.js +1 -1
- package/src/models/base-model.js +1 -1
- package/src/pro/caching/redis-client.js +1 -1
- package/src/pro/caching/redis-helper.js +1 -1
- package/src/pro/consumers/baseConsumer.js +1 -1
- package/src/pro/consumers/declarativeMapper.js +1 -1
- package/src/pro/consumers/handlers/apiHandler.js +1 -1
- package/src/pro/consumers/handlers/consoleHandler.js +1 -1
- package/src/pro/consumers/handlers/databaseHandler.js +1 -1
- package/src/pro/consumers/handlers/index.js +1 -1
- package/src/pro/consumers/handlers/kafkaHandler.js +1 -1
- package/src/pro/consumers/index.js +1 -1
- package/src/pro/consumers/messageTransformer.js +1 -1
- package/src/pro/consumers/validator.js +1 -1
- package/src/pro/database/base-model-mysql.js +1 -1
- package/src/pro/database/base-model-oracle.js +1 -1
- package/src/pro/database/base-model-sqlite.js +1 -1
- package/src/pro/database/db-mysql.js +1 -1
- package/src/pro/database/db-oracle.js +1 -1
- package/src/pro/database/db-sqlite.js +1 -1
- package/src/pro/excel/excel-generator.js +1 -1
- package/src/pro/excel/excel-parser.js +1 -1
- package/src/pro/excel/export-service.js +1 -1
- package/src/pro/excel/export_handler.js +1 -1
- package/src/pro/excel/import-service.js +1 -1
- package/src/pro/excel/import-validator.js +1 -1
- package/src/pro/excel/import_handler.js +1 -1
- package/src/pro/excel/upsert-builder.js +1 -1
- package/src/pro/idgen/idgen-routes.js +1 -1
- package/src/pro/integrations/lookup-resolver.js +1 -1
- package/src/pro/integrations/upload-handler-v2.js +1 -1
- package/src/pro/integrations/upload-handler.js +1 -1
- package/src/pro/integrations/webhook.js +1 -1
- package/src/pro/locking/lock-routes.js +1 -1
- package/src/pro/locking/resource-lock-manager.js +1 -1
- package/src/pro/messaging/kafkaConsumerService.js +1 -1
- package/src/pro/messaging/kafkaService.js +1 -1
- package/src/pro/messaging/messagehubService.js +1 -1
- package/src/pro/messaging/rabbitmqService.js +1 -1
- package/src/pro/scheduler/job-manager.js +1 -1
- package/src/pro/scheduler/job-routes.js +1 -1
- package/src/pro/scheduler/job-validator.js +1 -1
- package/src/pro/storage/base-storage-provider.js +1 -1
- package/src/pro/storage/file-metadata-helper.js +1 -1
- package/src/pro/storage/index.js +1 -1
- package/src/pro/storage/local-storage-provider.js +1 -1
- package/src/pro/storage/s3-storage-provider.js +1 -1
- package/src/pro/storage/upload-cleanup-job.js +1 -1
- package/src/pro/storage/upload-cleanup-scheduler.js +1 -1
- package/src/pro/storage/upload-pending-tracker.js +1 -1
- package/src/pro/websocket/broadcast-helper.js +1 -1
- package/src/pro/websocket/index.js +1 -1
- package/src/pro/websocket/livesync-server.js +1 -1
- package/src/pro/websocket/ws-broadcaster.js +1 -1
- package/src/services/export-service.js +1 -1
- package/src/services/import-service.js +1 -1
- package/src/services/kafkaConsumerService.js +1 -1
- package/src/services/kafkaService.js +1 -1
- package/src/services/messagehubService.js +1 -1
- package/src/services/rabbitmqService.js +1 -1
- package/src/utils/cache-invalidation-registry.js +1 -1
- package/src/utils/cache-manager.js +1 -1
- package/src/utils/component-engine.js +1 -1
- package/src/utils/config-extractor.js +1 -1
- package/src/utils/consumerLogger.js +1 -1
- package/src/utils/context-builder.js +1 -1
- package/src/utils/dashboard-helpers.js +1 -1
- package/src/utils/dateHelper.js +1 -1
- package/src/utils/datetime-formatter.js +1 -1
- package/src/utils/datetime-parser.js +1 -1
- package/src/utils/db-bootstrap.js +1 -1
- package/src/utils/db-mysql.js +1 -1
- package/src/utils/db-oracle.js +1 -1
- package/src/utils/db-sqlite.js +1 -1
- package/src/utils/db.js +1 -1
- package/src/utils/demo-generator.js +1 -1
- package/src/utils/excel-generator.js +1 -1
- package/src/utils/excel-parser.js +1 -1
- package/src/utils/file-watcher.js +1 -1
- package/src/utils/id-generator.js +1 -1
- package/src/utils/idempotency-manager.js +1 -1
- package/src/utils/import-validator.js +1 -1
- package/src/utils/license-client.js +1 -1
- package/src/utils/lock-manager.js +1 -1
- package/src/utils/logger.js +1 -1
- package/src/utils/lookup-resolver.js +1 -1
- package/src/utils/payload-loader.js +1 -1
- package/src/utils/processor-response.js +1 -1
- package/src/utils/rabbitmq.js +1 -1
- package/src/utils/redis-client.js +1 -1
- package/src/utils/redis-helper.js +1 -1
- package/src/utils/request-scope.js +1 -1
- package/src/utils/security-checks.js +1 -1
- package/src/utils/service-resolver.js +1 -1
- package/src/utils/shutdown-coordinator.js +1 -1
- package/src/utils/soft-delete-dashboard-guard.js +1 -1
- package/src/utils/sql-table-extractor.js +1 -1
- package/src/utils/trusted-keys.js +1 -1
- package/src/utils/upload-handler.js +1 -1
- package/src/utils/upsert-builder.js +1 -1
- package/src/utils/workflow-hook-executor.js +1 -1
|
@@ -856,19 +856,49 @@ function tableToKebab(table) {
|
|
|
856
856
|
* displayCols = kolom code/name di luar PK & kolom audit, dipakai sebagai kolom
|
|
857
857
|
* display saat tabel ini menjadi parent FK (untuk `payload sync --expand-fk`).
|
|
858
858
|
*/
|
|
859
|
+
// Postgres 'public' diperlakukan sebagai default implisit (selalu di search_path
|
|
860
|
+
// secara konvensi), SAMA seperti pengecualian di `qualifiedRefTable()`
|
|
861
|
+
// (generators/lib/payload/payload-runner.js). `schema introspect` SELALU menulis
|
|
862
|
+
// field `schema:` eksplisit di SDF hasil introspeksi, termasuk untuk tabel yang
|
|
863
|
+
// sebenarnya di schema default ('public') — tanpa pengecualian ini, SETIAP SDF
|
|
864
|
+
// hasil introspect Postgres default-schema akan ikut di-qualify ('public.visitors'),
|
|
865
|
+
// menghasilkan nama file RDF berprefix 'public-' yang tidak konsisten dengan JOIN
|
|
866
|
+
// SQL (qualifiedRefTable() di payload-runner.js TIDAK menulis prefix 'public.' pada
|
|
867
|
+
// klausa JOIN) — JOIN auto-discovery di `payload migrate` (migrate-runner.js) jadi
|
|
868
|
+
// gagal menemukan file RDF parent, dan page UDF parent tidak pernah dibuat.
|
|
869
|
+
const DEFAULT_SCHEMA_SENTINEL = 'public';
|
|
870
|
+
function isQualifyingSchema(schemaName) {
|
|
871
|
+
return !!schemaName && schemaName !== DEFAULT_SCHEMA_SENTINEL;
|
|
872
|
+
}
|
|
873
|
+
|
|
859
874
|
function loadModels(schemaDir) {
|
|
860
875
|
const models = loadSchemaPath(schemaDir);
|
|
861
876
|
const entries = [];
|
|
862
877
|
for (const model of models.values()) {
|
|
863
|
-
|
|
878
|
+
// qualifiedName (mis. 'myschema.guest_book') dipakai, bukan tableName
|
|
879
|
+
// bare, agar `--table=` yang dikirim ke `payload generate`/`payload sync`
|
|
880
|
+
// tetap menemukan tabel yang ada di custom schema (tanpa prefix, resolver
|
|
881
|
+
// koneksi default ke schema 'public'/setara dan tabel tidak ditemukan).
|
|
882
|
+
// Schema 'public' dikecualikan (lihat isQualifyingSchema) karena memang
|
|
883
|
+
// sudah default tanpa perlu di-qualify.
|
|
884
|
+
const schemaName = model.schemaName || null;
|
|
885
|
+
const table = isQualifyingSchema(schemaName) ? (model.qualifiedName || model.tableName) : model.tableName;
|
|
864
886
|
const primaryKey = Array.isArray(model.primaryKey) ? model.primaryKey : [];
|
|
865
887
|
|
|
866
888
|
const fks = [];
|
|
867
889
|
for (const rel of Object.values(model.relations || {})) {
|
|
868
890
|
if (rel.type !== 'belongsTo' || !rel.localKey || !rel.target) continue;
|
|
891
|
+
// Konvensi SDF (restforge-handbook/catalogs/sdf/multi-schema.md): target
|
|
892
|
+
// relasi ditulis bare bila parent di schema YANG SAMA dengan child, dan
|
|
893
|
+
// fully-qualified hanya bila cross-schema. Qualify bare target dengan
|
|
894
|
+
// schema child di sini supaya konsisten dengan `table` qualified di atas
|
|
895
|
+
// (byTable/parentTables dibangun dari nilai ini, lihat ctx.byTable).
|
|
896
|
+
const parentTable = rel.target.includes('.')
|
|
897
|
+
? rel.target
|
|
898
|
+
: (isQualifyingSchema(schemaName) ? `${schemaName}.${rel.target}` : rel.target);
|
|
869
899
|
fks.push({
|
|
870
900
|
childCol: rel.localKey,
|
|
871
|
-
parentTable
|
|
901
|
+
parentTable,
|
|
872
902
|
parentCol: rel.references || null
|
|
873
903
|
});
|
|
874
904
|
}
|
|
@@ -879,7 +909,17 @@ function loadModels(schemaDir) {
|
|
|
879
909
|
return !isPk && !AUDIT_COLS.has(name) && /(code|name)/i.test(name);
|
|
880
910
|
});
|
|
881
911
|
|
|
882
|
-
|
|
912
|
+
// `kebab` (qualified, mis. 'myschema-guest-book') HARUS dipakai untuk
|
|
913
|
+
// mencocokkan nama file RDF/UDF di disk (`payload generate` menulis
|
|
914
|
+
// baseFilename dari `--table=` literal, jadi ikut prefix schema).
|
|
915
|
+
// `resourceName` (bare, mis. 'guest-book') dipakai khusus untuk identitas
|
|
916
|
+
// REST endpoint (`endpoint create --name=`): endpoint TIDAK mengenal
|
|
917
|
+
// schema (itu murni konsep koneksi database), dan `payload migrate`
|
|
918
|
+
// (RDF -> UDF) sendiri sudah men-strip schema saat menurunkan apiPath/
|
|
919
|
+
// pageId (lihat backend-payload-migrator.js: cleanTable = tableName.split('.').pop()).
|
|
920
|
+
// Memakai `kebab` qualified untuk nama endpoint akan membuat route REST
|
|
921
|
+
// tidak sinkron dengan apiPath yang dipanggil frontend.
|
|
922
|
+
entries.push({ kebab: tableToKebab(table), resourceName: tableToKebab(model.tableName), table, fks, displayCols });
|
|
883
923
|
}
|
|
884
924
|
entries.sort((a, b) => a.table.localeCompare(b.table));
|
|
885
925
|
return entries;
|
|
@@ -894,13 +934,24 @@ function buildTableEntries(schemaDir) {
|
|
|
894
934
|
* Turunkan daftar `--fk-columns` untuk `payload sync --expand-fk` dari SDF:
|
|
895
935
|
* `<parentTable>.<displayCol>` untuk tiap kolom display (code/name) tiap parent.
|
|
896
936
|
* Kosong bila tidak ada kolom display terdeteksi (jatuh ke mode AUTO command).
|
|
937
|
+
*
|
|
938
|
+
* `parentTable` di sini WAJIB bare (tanpa prefix schema), berbeda dari
|
|
939
|
+
* `fk.parentTable` yang dipakai untuk lookup `byTable` (qualified). Alasannya:
|
|
940
|
+
* `payload-runner.js parseFkColumns()` mem-validasi setiap entri persis 2 segmen
|
|
941
|
+
* (`table.column`), dan nilainya dicocokkan terhadap `getForeignKeys().references.table`
|
|
942
|
+
* hasil introspeksi DB — yang SELALU bare (`pg_class.relname`, schema ada di field
|
|
943
|
+
* terpisah `references.schema`). Mengirim `sch02.company.company_name` (3 segmen)
|
|
944
|
+
* ditolak validator; mengirim bare `company.company_name` cocok dengan hasil introspeksi.
|
|
897
945
|
*/
|
|
898
946
|
function fkColumnsForEntry(entry, byTable) {
|
|
899
947
|
const cols = [];
|
|
900
948
|
for (const fk of entry.fks) {
|
|
901
949
|
const parent = byTable.get(fk.parentTable);
|
|
902
950
|
const disp = parent ? parent.displayCols : [];
|
|
903
|
-
|
|
951
|
+
const bareParentTable = fk.parentTable.includes('.')
|
|
952
|
+
? fk.parentTable.split('.').pop()
|
|
953
|
+
: fk.parentTable;
|
|
954
|
+
for (const dc of disp) cols.push(`${bareParentTable}.${dc}`);
|
|
904
955
|
}
|
|
905
956
|
return cols;
|
|
906
957
|
}
|
|
@@ -998,7 +1049,9 @@ function runBackendPipeline(ctx) {
|
|
|
998
1049
|
|
|
999
1050
|
phase('[4/4] REST endpoints');
|
|
1000
1051
|
for (const t of ctx.tableEntries) {
|
|
1001
|
-
|
|
1052
|
+
// --name= = identitas REST endpoint (bare, lihat resourceName di loadModels).
|
|
1053
|
+
// --payload= = nama file RDF di disk (qualified/kebab, ikut prefix schema).
|
|
1054
|
+
run(`npx restforge endpoint create --project=${ctx.project} --name=${t.resourceName} --payload=${t.kebab}.json ${cfgArg} --database=${dbFlag} --force`, ctx.cwd);
|
|
1002
1055
|
}
|
|
1003
1056
|
}
|
|
1004
1057
|
|
|
@@ -176,9 +176,19 @@ function loadRdf(filePath) {
|
|
|
176
176
|
* Petakan nama tabel JOIN (snake_case, mis. visitor_categories) ke file RDF
|
|
177
177
|
* sibling di folder payload. Coba bentuk kebab dulu (visitor-categories.json),
|
|
178
178
|
* lalu bentuk snake (visitor_categories.json).
|
|
179
|
+
*
|
|
180
|
+
* `qualifiedName` (opsional) = identifier JOIN apa adanya sebelum schema
|
|
181
|
+
* di-strip (mis. 'sch02.company'). Tabel di custom schema ditulis `payload
|
|
182
|
+
* generate` dengan baseFilename = `--table=` literal (lihat payload-runner.js),
|
|
183
|
+
* jadi file di disk-nya `sch02-company.json`, BUKAN `company.json`. Tanpa
|
|
184
|
+
* kandidat ini, related table di schema custom selalu gagal ditemukan
|
|
185
|
+
* walau file-nya ada (lihat bug: "no RDF file found ... tried: company.json, company.json").
|
|
179
186
|
*/
|
|
180
|
-
function findRelatedRdfPath(tableName, payloadDir) {
|
|
187
|
+
function findRelatedRdfPath(tableName, payloadDir, qualifiedName) {
|
|
181
188
|
const candidates = [`${snakeToKebab(tableName)}.json`, `${tableName}.json`];
|
|
189
|
+
if (qualifiedName && qualifiedName !== tableName) {
|
|
190
|
+
candidates.push(`${qualifiedName.replace(/[._]/g, '-')}.json`);
|
|
191
|
+
}
|
|
182
192
|
for (const c of candidates) {
|
|
183
193
|
const p = path.join(payloadDir, c);
|
|
184
194
|
if (fs.existsSync(p)) return { path: p, candidates };
|
|
@@ -259,7 +269,7 @@ async function run(args) {
|
|
|
259
269
|
if (!t || seenTables.has(t)) continue;
|
|
260
270
|
seenTables.add(t);
|
|
261
271
|
|
|
262
|
-
const { path: relPath, candidates } = findRelatedRdfPath(t, payloadDir);
|
|
272
|
+
const { path: relPath, candidates } = findRelatedRdfPath(t, payloadDir, join.tableQualified);
|
|
263
273
|
if (!relPath) {
|
|
264
274
|
warnings.push(`Related table '${t}' referenced by JOIN but no RDF file found in ${payloadDir} (tried: ${candidates.join(', ')}); page not generated, only the select reference is kept`);
|
|
265
275
|
continue;
|
|
@@ -23,10 +23,11 @@ function parseTableRef(refstr) {
|
|
|
23
23
|
const afterWhere = refstr.split(WHERE_SPLIT_RE)[0].trim();
|
|
24
24
|
const cleaned = afterWhere.split(ORDER_SPLIT_RE)[0].trim();
|
|
25
25
|
const tokens = cleaned.split(/\s+/).filter(Boolean);
|
|
26
|
-
if (tokens.length === 0) return { tableName: '', alias: '' };
|
|
27
|
-
const
|
|
26
|
+
if (tokens.length === 0) return { tableName: '', alias: '', qualifiedName: '' };
|
|
27
|
+
const qualifiedName = tokens[0];
|
|
28
|
+
const tableName = stripSchema(qualifiedName);
|
|
28
29
|
const alias = tokens.length > 1 ? tokens[1] : '';
|
|
29
|
-
return { tableName, alias };
|
|
30
|
+
return { tableName, alias, qualifiedName };
|
|
30
31
|
}
|
|
31
32
|
|
|
32
33
|
function parseJoinCondition(condition, mainAlias) {
|
|
@@ -108,6 +109,7 @@ function parseDatatablesQuery(sql) {
|
|
|
108
109
|
const cond = parseJoinCondition(condition, mainAlias);
|
|
109
110
|
joins.push({
|
|
110
111
|
tableName: ref.tableName,
|
|
112
|
+
tableQualified: ref.qualifiedName,
|
|
111
113
|
tableAlias: ref.alias,
|
|
112
114
|
localColumn: cond.localColumn,
|
|
113
115
|
remoteColumn: cond.remoteColumn
|
|
@@ -168,6 +168,24 @@ function deriveTableAlias(tableName) {
|
|
|
168
168
|
return initials || 't';
|
|
169
169
|
}
|
|
170
170
|
|
|
171
|
+
/**
|
|
172
|
+
* Qualify nama tabel referensi FK dengan schema-nya bila schema BUKAN 'public'.
|
|
173
|
+
* `public` diperlakukan sebagai default implisit (selalu di search_path Postgres
|
|
174
|
+
* secara konvensi) sehingga TIDAK di-qualify, menjaga SQL JOIN tetap bare seperti
|
|
175
|
+
* sebelumnya untuk kasus non-multi-schema. Schema custom lain (mis. 'sch02') WAJIB
|
|
176
|
+
* di-qualify, karena search_path tidak menjamin mencakupnya — tanpa ini, query
|
|
177
|
+
* introspeksi kolom (`db.getColumns`) maupun JOIN yang dihasilkan akan salah
|
|
178
|
+
* menyasar tabel di schema default (lihat bug: "Available columns: (none)").
|
|
179
|
+
*
|
|
180
|
+
* @param {{references: {schema?: string, table: string}}} fk
|
|
181
|
+
* @returns {string}
|
|
182
|
+
*/
|
|
183
|
+
function qualifiedRefTable(fk) {
|
|
184
|
+
const schema = fk && fk.references && fk.references.schema;
|
|
185
|
+
const table = fk && fk.references && fk.references.table;
|
|
186
|
+
return (schema && schema !== 'public') ? `${schema}.${table}` : table;
|
|
187
|
+
}
|
|
188
|
+
|
|
171
189
|
/**
|
|
172
190
|
* Pilih kolom display dari tabel referensi secara heuristik untuk mode
|
|
173
191
|
* auto-resolve (`--expand-fk` tanpa `--fk-columns`).
|
|
@@ -307,7 +325,10 @@ function buildForeignKeyExpansion(payload, fkSpec, foreignKeys, refColumnsMap, b
|
|
|
307
325
|
refTableAlias.set(key, {
|
|
308
326
|
alias: uniqueAlias(deriveTableAlias(refTableName)),
|
|
309
327
|
fk,
|
|
310
|
-
refTableName
|
|
328
|
+
refTableName,
|
|
329
|
+
// Dipakai khusus untuk klausa JOIN (FROM/LEFT JOIN); refTableName (bare)
|
|
330
|
+
// tetap dipakai untuk alias derivation & penamaan kolom output.
|
|
331
|
+
refQualified: qualifiedRefTable(fk)
|
|
311
332
|
});
|
|
312
333
|
}
|
|
313
334
|
refSelections.push({ alias: refTableAlias.get(key).alias, column: spec.column, refTableName });
|
|
@@ -359,7 +380,7 @@ function buildForeignKeyExpansion(payload, fkSpec, foreignKeys, refColumnsMap, b
|
|
|
359
380
|
for (let i = 0; i < pairCount; i++) {
|
|
360
381
|
conds.push(`${info.alias}.${refCols[i]} = ${baseAlias}.${localCols[i]}`);
|
|
361
382
|
}
|
|
362
|
-
sqlLines.push(`LEFT JOIN ${info.
|
|
383
|
+
sqlLines.push(`LEFT JOIN ${info.refQualified} ${info.alias} ON ${conds.join(' AND ')}`);
|
|
363
384
|
}
|
|
364
385
|
const sqlContent = `${sqlLines.join('\n')}\n`;
|
|
365
386
|
|
|
@@ -2558,11 +2579,15 @@ class SchemaValidator {
|
|
|
2558
2579
|
const rt = fk && fk.references && fk.references.table;
|
|
2559
2580
|
if (!rt) continue;
|
|
2560
2581
|
const key = String(rt).toLowerCase();
|
|
2582
|
+
// qualifiedRefTable() dipakai untuk query ke DB (perlu schema yang benar
|
|
2583
|
+
// bila parent bukan di schema 'public'); `rt` (bare) tetap dipakai sebagai
|
|
2584
|
+
// key map + identitas fkSpec (selaras format `--fk-columns=table.column`).
|
|
2585
|
+
const qualifiedRt = qualifiedRefTable(fk);
|
|
2561
2586
|
if (!refColumnsMap[key]) {
|
|
2562
|
-
refColumnsMap[key] = await this.db.getColumns(
|
|
2587
|
+
refColumnsMap[key] = await this.db.getColumns(qualifiedRt);
|
|
2563
2588
|
}
|
|
2564
2589
|
const refPk = typeof this.db.getPrimaryKey === 'function'
|
|
2565
|
-
? await this.db.getPrimaryKey(
|
|
2590
|
+
? await this.db.getPrimaryKey(qualifiedRt)
|
|
2566
2591
|
: null;
|
|
2567
2592
|
const display = pickDisplayColumn(refColumnsMap[key], refPk);
|
|
2568
2593
|
if (!display) {
|
|
@@ -2584,7 +2609,7 @@ class SchemaValidator {
|
|
|
2584
2609
|
const key = String(rt).toLowerCase();
|
|
2585
2610
|
if (!neededTables.has(key)) continue;
|
|
2586
2611
|
if (!refColumnsMap[key]) {
|
|
2587
|
-
refColumnsMap[key] = await this.db.getColumns(
|
|
2612
|
+
refColumnsMap[key] = await this.db.getColumns(qualifiedRefTable(fk));
|
|
2588
2613
|
}
|
|
2589
2614
|
}
|
|
2590
2615
|
}
|
|
@@ -2826,6 +2851,7 @@ module.exports = {
|
|
|
2826
2851
|
SchemaValidator,
|
|
2827
2852
|
parseFkColumns,
|
|
2828
2853
|
deriveTableAlias,
|
|
2854
|
+
qualifiedRefTable,
|
|
2829
2855
|
pickDisplayColumn,
|
|
2830
2856
|
buildForeignKeyExpansion,
|
|
2831
2857
|
collectStringColumns,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a0_0x37cda6=a0_0x4f69;(function(_0x4da233,_0x426370){const _0x3ba43f=a0_0x4f69,_0x2380b3=_0x4da233();while(!![]){try{const _0x4dbfe2=parseInt(_0x3ba43f(0x177))/0x1*(parseInt(_0x3ba43f(0x149))/0x2)+parseInt(_0x3ba43f(0x12c))/0x3*(-parseInt(_0x3ba43f(0x129))/0x4)+parseInt(_0x3ba43f(0x118))/0x5*(parseInt(_0x3ba43f(0x165))/0x6)+-parseInt(_0x3ba43f(0x14f))/0x7*(parseInt(_0x3ba43f(0x15c))/0x8)+-parseInt(_0x3ba43f(0x16d))/0x9+-parseInt(_0x3ba43f(0x137))/0xa+parseInt(_0x3ba43f(0x141))/0xb;if(_0x4dbfe2===_0x426370)break;else _0x2380b3['push'](_0x2380b3['shift']());}catch(_0x17c222){_0x2380b3['push'](_0x2380b3['shift']());}}}(a0_0xe2f1,0x1cae4));function a0_0xe2f1(){const _0x564dda=['ue9tvcaVyxbPl21PBMKTAw52zw50B3j5l2rHC2GTAw5IB3vUzc9KyxnOyM9HCMq','y2fJAgu','q29SBgfWC2uGDg8GB2jQzwn0ihDOB3nLigTLExmGyxjLifnrtcbJB2X1Bw4GBMfTzxmGkgXVD2vYy2fZzwqPlG','Bgf5B3v0','v2HLBIb0CNvLlcb0AguGCMvXDwvZDcbIB2r5ie1vu1qGAw5JBhvKzsb0AgLZihbHCMfTicHVDgHLCNDPC2uGndaWks4','mteWnZy2nLPSDgXrwG','tM90igeGzgfZAgjVyxjKihbHEwXVywqGkgXPA2vSEsbduLveihDPDgGGDgfIBgvoyw1LlcbVCIbPBNzHBgLKkq','EYaICgfYyw1ZiJOGEYaIEwvHCIi6ihSGiNr5CguIoIaIBNvTyMvYiIWGiNjLCxvPCMvKiJOGDhj1zsb9ih0GFq','CgfYyw1Z','w3SGiMXHyMvSiJOGiLnOB2vZiIWGiNzHBhvLiJOGiJC2nJaIih0SihSGiMXHyMvSiJOGiKDHBwLUzYiSicj2ywX1zsi6iciYodiWiIb9lcb7icjSywjLBci6icjpDgHLCNmIlcaIDMfSDwuIoIaInduYntCIih1D','zxHWzwn0zwrFzwfYBMLUz3m','zgfZAgjVyxjKihbHEwXVywq','ugfYyw0GBMfTzsbTDxn0ig1HDgnOihrOzsbWBgfJzwHVBgrLCIbYzwDLEcbGw2eTEKeTwL9Dw2eTEKeTwJaTov9DkMaGkgfSCgHHBNvTzxjPyYaRihvUzgvYC2nVCMuSig11C3qGC3rHCNqGD2L0AcbSzxr0zxiGB3iGDw5KzxjZy29YzsKU','qsb3AwrNzxqGtvvtvcbKzwnSyxjLigv4ywn0BhKGB25Lig9MoIaNCxvLCNKNie9sicDXDwvYAwvZjY4GqM90AcbVCIbUzwL0AgvYigLZihjLAMvJDgvKlG','l2fWAs97ChjVAMvJDh0VE25HBwv9l2rHC2HIB2fYza','mwDNBgTeDq','msbYB3CGW5CGmsbJB2WSig91Dhb1DcbJB2X1Bw4Gj3zHBhvLjW','BwfW','yw55icGXihjVDYddLYaXignVBcWGtIbYB3DZimoxie0Gy29SCYWGzxrJlIK','BNvTyMvY','C3rYAw5N','B2jQzwn0iokaLcb2ywX1zxmGzM9YigrLy2XHCMvKihbHCMfTCYaODMfSAwrHDgvKigfNywLUC3qGCgfYyw1ZignVBNrYywn0oYbTAxnZAw5NihjLCxvPCMvKiokgKIa0mdaSihr5CguGBwLZBwf0y2GG4OAsidqWmcK','DgL0Bgu','nJK1nJq1zNvrzxzt','Cgf5Bg9Hzcbku09oigzPBguGBg9JyxrPB24','yw55icHTDxn0igjLignVBxbHDgLIBguGD2L0AcbKzwnSyxjLzcaNDhLWzsCP','xMrHC2GTw2eTEKeTwJaTov8TxsSK','zMLSztPXDwvYEs88Cgf0Ad4Vy3vYCMvUDc5ZCwW','zMLSztPXDwvYEs88Cgf0Ad4VDhjLBMqUC3fS','zgf0zq','EYbZDwnJzxnZoIbIB29SzwfUlcbKyxrHoIb7idX3AwrNzxrjzd46idXWzxjxAwrNzxrszxnWB25Zzt4Sic4UlIb9ih0','CxvLCMLLCW','yxzNx2rHAwX5x3nHBgvZ','Cgn0','qwX3yxLZihDYyxaGyxmGEYbPDgvTCZOGwY4UlL0GFsbYzwDHCMrSzxnZig9MifnrtcbYzxn1BhqGC2HHCguU','zgvMyxvSDa','yxjYyxKGB2yGB2jQzwn0CW','yxjYyxK','iJi0mJaI','Bwv0CMLJx3nWyxjRBgLUzq','mtGWmZu2Bgncs1H1','tgf5B3v0igLZigeGzNjVBNrLBMqGCMvUzgvYAw5NignVBMnLCM4U','uMv0DxjUigfZigfYCMf5ig9Mig9IAMvJDhmGkg5VignVBgXHChnLks4','ow5ozKXcqq','yxjYyxK8C3rYAw5NpG','phDPzgDLDf9Pzd4','sgvHzgXPBMuGBwv0CMLJihDPDgGGDhjLBMqGy2HPCcbHBMqGyNjLywTKB3DUigfJCM9ZCYbJyxrLz29YAwvZlIbtDwL0ywjSzsbMB3iGD2LKz2v0CYbSAwTLicDfEhbLy3rLzcbfyxjUAw5NCYCGDgHHDcbZAg93ihrVDgfSihzHBhvLlcbWzxjJzw50ywDLignOyw5NzsWGyw5KihbLCI1JyxrLz29YEsbJB250CMLIDxrPB24U','CgvYAw9K','rNjVBNrLBMqGzgv0zxjTAw5LCYbKB251Dc9WAwuGDMfYAwfUDcWGy29SB3iGCgvYignHDgvNB3j5lcbHBMqGBgfIzwWGB3jKzxiUieLMihbLCI1JyxrLz29YEsbWzxjJzw50ywDLigLZig5LzwrLzcbMB3iGDgHLigrVBNv0igfYyYWGzNjVBNrLBMqGy29TChv0zxmGAxqGzNjVBsbPDgvTC1TPxs52ywX1zsaVihn1BsHPDgvTC1SQxs52ywX1zsKUie5Vig5LzwqGDg8GC2vUzcaNCgn0jYbMCM9TigjHy2TLBMqGDw5SzxnZihrOzsbMAwD1CMuGAxmGysbZDgfIBguGyNvZAw5LC3mGy2fSy3vSyxrPB24GAw5KzxbLBMrLBNqGB2yGDMLZDwfSihjLBMrLCMLUzY4','zgLYzwn0Aw9U','C2nHBgfYihbYAw1PDgL2zq','vgfIBguGzgvJBgfYzwqGAw4GAw52ywXPzgf0zxmSigj1DcbUB3qGzgv0zwn0zwqGAw4Gyw55ihDPzgDLDcbtuuWGkhr5Cg8GB3iGzgvHzcbLBNrYEsK','Dg9WlwXLDMvSicDJywnOzsCGB2jQzwn0','zgfZAgjVyxjKlwnHDgfSB2C','mJa2ndbiALftBee','qwXSihDPzgDLDcbtuuWG4OcuigjVDgGGj3f1zxj5jYaOC2LUz3vSyxiPigfUzcbLDMvYEsaNCxvLCMLLCY48A2v5pICU','DhjLBMq','BgfIzwW','iJe4mZyI','yM9VBgvHBG','ugfYyw0Gzgf0ysb0ExbLlIbwywXPzgf0zxmGCMvXDwvZDcbIB2r5igfUzcbZAgfWzxmGCNvUDgLTzsbWyxjHBwv0zxiGyMLUzgLUzY4','tIbYB3DZimoxie0Gy29SCW','yxjYyxK8C3rYAw5NpIWGB3b0Aw9UywWG4Ocuihn1yNnLDcbVzIb3AwrNzxqGsurZihrVigv4zwn1DguUie9TAxqGDg8GzxHLy3v0zsbHBgWGzgvJBgfYzwqGD2LKz2v0CY4','zNjLztSGlNnXBcbYzwnVBw1LBMrLzcbMB3iGzwrPDg9YigHPz2HSAwDODa','ndu1nZG1mgPdwNzxCW','Cg9PBNrZ','zw5HyMXLza','zxHWB3j0CW','tIbYB3DZimoxidiGy29SDw1UCW','ugvYlwTLEsbIyxnLzcbVBIbZy2fSyxjdB2XSyxbZzvj1BgvZigjLBg93lG','vgfIBguGzgv0zwn0zwqGAw4Gu1fmlcbIDxqGBM90ihjLz2LZDgvYzwqGyxmGq1jvrcbLBMrWB2LUDcbPBIbTzxrHzgf0ysbWCM9Qzwn0icHSAwTLBhKGysb2Awv3lcbdveuGywXPyxmSig9YignYB3nZlxbYB2PLy3qGDgfIBguG4OcuignHC2nHzguGD2LSBcbUB3qGzMLYzsK','vgLTzs10BY1SAxzLigLUihnLy29UzhmUidaGzwzMzwn0AxzLBhKGzgLZywjSzxmGy2fJAguGzM9YihrOAxmGzw50CNKU','odKWndHJugTKu08','B2jQzwn0','B3jKzxjZx3rOAxnFBw9UDgG','iNnOB3bWAw5Nx2nHDgvNB3jPzxmIoIb7icjPDgvTCYi6ifT7icjUyw1LiJOGiKXHBMrZiIb9lcb7icjUyw1LiJOGiKHVDxnLCYiGFv0GFq','z2vUzxjHDgLVBIb0Aw1LicHot1qGCNvUDgLTzsK','EYaIzgLYzwn0Aw9UiJOGiNvWiIWGiNbJDci6iciYlJiIih0','ndLmD3LVCKG','q29SBgfWC2uGDg8GC2nHBgfYihbYAw1PDgL2zsaODgHLihzHBhvLig9MihrOzsbZAw5NBguGy29SDw1Uks4','DMfSDwu','v2LKz2v0igLKzw50AwzPzxi7ihvZzwqGyxmGDgHLihjLC3bVBNnLigTLEsbPBIb0AguGzgfZAgjVyxjKigvUDMvSB3bLlG','tgLZDcbVzIb3AwrNzxqGzgvMAw5PDgLVBNmUie9YzgvYigLZigLUzM9YBwf0Aw9UywWGB25SEsaOCMvZCg9UC2uGA2v5CYbHCMuGyNKGD2LKz2v0igLKlcbUB3qGyxjYyxKGAw5KzxGPlG','BgvUz3rO','zgfZAc1PBMjVDw5K','A2v54OAszMLSztPYzwXHDgL2zs9WyxrOl3rVl3f1zxj5lNnXBa','iML0zw1ZiJOGw3SGiMXHyMvSiJOGiLnOB2vZiIWGiNzHBhvLiJOGiJC2nJaIih0Sic4UlL0','DgfYz2v0','ue9tva','tgLZDcbVzIbduLveihrHyMXLig5HBwvZihrOyxqSihDOzw4GD3jPDhrLBIWGD2LSBcb0CMLNz2vYigLUDMfSAwrHDgLVBIbVzIb0AgLZigrHC2HIB2fYzcbJywnOzs4','twv0CMLJicSGu3bHCMTSAw5L','mJuXnty4zLH6tKjA','twv0CMLJicSGuhjVz3jLC3mGDg8Gr29HBa','msbYB3CGW5CGmIbJB2XZlcbVDxrWDxqGy29SDw1UCYaNzgLYzwn0Aw9UjYWGj3bJDcC','uMvZzxj2zwqGzM9YiensvuqGCgf5Bg9HzhmUieeGzgfZAgjVyxjKihbHEwXVywqGBxvZDcbKzwnSyxjLicD3AwrNzxrZjYbPBNn0zwfKlG','rxzLCNKGCgXHy2vOB2XKzxiGDxnLzcbPBIbtuuWGtvvtvcbIzsbKzwnSyxjLzcbPBIaNCgfYyw1ZjY4GvMfSAwrHDg9YihrOCM93CYbfCNjVCIb3AxrOig1LC3nHz2uGzM9YBwf0oIaIv2LKz2v0icC8Awq+jYbXDwvYEsaNpgXHyMvSpICGDxnLCYb1BMrLy2XHCMvKihbSywnLAg9SzgvYicC6phrVA2vUpICGkgrLy2XHCMuGAw4Gj3bHCMfTCYCPiI4','D2LKz2v0lNf1zxjPzxmUpgTLEt4GD2L0AcbtuuWGCMv0DxjUAw5NideGCM93imoxideGy29SDw1U','zMLSztPXDwvYEs88Cgf0Ad4VyNjLywTKB3DUlNnXBa','msbYB3CGW5CGmIbJB2X1Bw5Z','Dg9Wtgv2zwXbBgXVD2vK','nMjqAgLOuq','msbYB3CGW5CGmsbJB2X1Bw4','Ahr0Chm6lY9Yzxn0zM9Yz2uUzgv2l2rVy3mVC2vYDMvYl3f1zxj5lwrHDgeVzgfZAgjVyxjK'];a0_0xe2f1=function(){return _0x564dda;};return a0_0xe2f1();}const FORBIDDEN_FRONTEND_FIELDS=['widgetType',a0_0x37cda6(0x16b),a0_0x37cda6(0x17e),'subtitle','color'],ALLOWED_PARAM_TYPES=[a0_0x37cda6(0x17c),a0_0x37cda6(0x17b),a0_0x37cda6(0x13c),a0_0x37cda6(0x11e)],FRONTEND_CONCERN_REASONS={'widgetType':'Visual\x20variant\x20(donut,\x20bar,\x20pie,\x20area)\x20is\x20a\x20frontend\x20rendering\x20concern\x20(separation\x20of\x20concerns).','layout':a0_0x37cda6(0x12a),'title':'UI\x20label\x20is\x20a\x20frontend\x20rendering\x20concern.','subtitle':'UI\x20label\x20is\x20a\x20frontend\x20rendering\x20concern.','color':'Visual\x20color\x20is\x20a\x20frontend\x20rendering\x20concern.'},PAYLOAD_SHAPE={'discriminator':{'field':'widgets','presentMeans':a0_0x37cda6(0x173),'absentMeans':a0_0x37cda6(0x16e),'conflictsWith':'tableName','conflictRationale':'A\x20payload\x20with\x20both\x20\x27widgets\x27\x20and\x20\x27tableName\x27\x20is\x20rejected\x20by\x20DashboardValidator.\x20Pick\x20one\x20shape.'},'topLevelAllowed':[{'name':'widgets','type':a0_0x37cda6(0x126),'required':!![],'minItems':0x1,'description':a0_0x37cda6(0x153)},{'name':a0_0x37cda6(0x170),'type':a0_0x37cda6(0x14a),'required':![],'description':'Parameter\x20contract\x20for\x20the\x20dashboard.\x20Each\x20key\x20is\x20a\x20param\x20name;\x20values\x20describe\x20type/required/default.\x20Placeholders\x20inside\x20widget\x20SQL\x20must\x20reference\x20declared\x20param\x20names.'},{'name':a0_0x37cda6(0x169),'type':a0_0x37cda6(0x14a),'required':![],'description':'Optional\x20cache\x20configuration.\x20See\x20cacheSpec\x20for\x20details.'}],'topLevelForbidden':[{'name':'tableName','category':'shape-conflict','reason':a0_0x37cda6(0x15f)},...FORBIDDEN_FRONTEND_FIELDS[a0_0x37cda6(0x179)](_0x40fdad=>({'name':_0x40fdad,'category':'frontend-concern','reason':FRONTEND_CONCERN_REASONS[_0x40fdad]}))]},WIDGET_SPEC={'requiredFields':[{'name':'id','type':a0_0x37cda6(0x17c),'constraint':'non-empty,\x20unique\x20across\x20widgets\x20in\x20the\x20same\x20payload','description':a0_0x37cda6(0x152)}],'exclusiveQueryFields':{'rule':a0_0x37cda6(0x175),'options':[{'name':'query','type':'string','format':'file:relative/path/to/query.sql','description':'Single\x20SQL\x20query\x20for\x20the\x20widget.','responseShape':'Always\x20{\x20items:\x20[...]\x20}\x20regardless\x20of\x20SQL\x20result\x20shape.'},{'name':a0_0x37cda6(0x120),'type':a0_0x37cda6(0x14a),'format':a0_0x37cda6(0x156),'minKeys':0x1,'description':'Multi-SQL\x20widget.\x20Each\x20key\x20becomes\x20a\x20key\x20in\x20the\x20response\x20object.','responseShape':a0_0x37cda6(0x146)}]},'forbiddenFields':FORBIDDEN_FRONTEND_FIELDS},PARAM_SPEC={'container':'top-level\x20\x27params\x27\x20object','keyConvention':a0_0x37cda6(0x174),'perEntryFields':[{'name':'type','required':!![],'allowedValues':ALLOWED_PARAM_TYPES,'description':a0_0x37cda6(0x13d)},{'name':'required','required':![],'type':'boolean','default':![],'description':a0_0x37cda6(0x16c)},{'name':a0_0x37cda6(0x124),'required':![],'type':a0_0x37cda6(0x11a),'description':'Default\x20value\x20applied\x20when\x20the\x20request\x20omits\x20this\x20param.\x20Validator\x20does\x20NOT\x20strictly\x20type-check\x20default;\x20runtime\x20is\x20responsible\x20for\x20compatibility.'}]},SCALAR_COLLAPSE_RULES=[{'appliesTo':'widget.query\x20(singular)','rule':a0_0x37cda6(0x123),'exampleSqlShape':a0_0x37cda6(0x17a),'exampleResponse':a0_0x37cda6(0x14c)},{'appliesTo':a0_0x37cda6(0x161),'rule':a0_0x37cda6(0x150),'exampleSqlShape':a0_0x37cda6(0x178),'exampleResponse':'\x22value\x22:\x20\x2269700\x22'},{'appliesTo':'widget.queries.<key>\x20with\x20SQL\x20returning\x201\x20row\x20×\x20multiple\x20columns','rule':a0_0x37cda6(0x16a),'exampleSqlShape':a0_0x37cda6(0x15e),'exampleResponse':'\x22trend\x22:\x20{\x20\x22direction\x22:\x20\x22up\x22,\x20\x22pct\x22:\x20\x222.2\x22\x20}'},{'appliesTo':'widget.queries.<key>\x20with\x20SQL\x20returning\x20N\x20rows','rule':a0_0x37cda6(0x12b),'exampleSqlShape':a0_0x37cda6(0x13e),'exampleResponse':a0_0x37cda6(0x157)}],COMMON_WIDGET_PATTERNS=[{'id':'metric_donut_breakdown','name':'Metric\x20+\x20Donut\x20Breakdown','useCase':a0_0x37cda6(0x12f),'payloadShape':{'id':a0_0x37cda6(0x12e),'queries':{'value':'file:query/<path>/value.sql','trend':'file:query/<path>/trend.sql','items':a0_0x37cda6(0x162)}},'sqlShapesPerKey':[{'key':'value','shape':a0_0x37cda6(0x166),'outputColumns':[a0_0x37cda6(0x151)],'collapseRule':a0_0x37cda6(0x133)},{'key':a0_0x37cda6(0x139),'shape':'1\x20row\x20×\x202\x20columns','outputColumns':[a0_0x37cda6(0x132),'pct'],'collapseRule':a0_0x37cda6(0x14a)},{'key':'items','shape':a0_0x37cda6(0x145),'outputColumns':[a0_0x37cda6(0x13a),'value'],'collapseRule':a0_0x37cda6(0x125)}],'responseShape':{'value':'\x2269700\x22','trend':a0_0x37cda6(0x14e),'items':a0_0x37cda6(0x171)},'referenceWidgetId':a0_0x37cda6(0x172),'socNotes':a0_0x37cda6(0x131)},{'id':a0_0x37cda6(0x128),'name':a0_0x37cda6(0x15b),'useCase':'Headline\x20metric\x20with\x20trend\x20chip\x20and\x20sparkline\x20mini-chart\x20for\x20short\x20windows\x20(7\x20days,\x2012\x20months,\x20etc.).\x20Suitable\x20for\x20widgets\x20like\x20\x27Average\x20Daily\x20Sales\x27.','payloadShape':{'id':'<widget_id>','queries':{'value':'file:query/<path>/value.sql','trend':a0_0x37cda6(0x11d),'points':'file:query/<path>/points.sql'}},'sqlShapesPerKey':[{'key':'value','shape':a0_0x37cda6(0x166),'outputColumns':[a0_0x37cda6(0x151)],'collapseRule':'scalar\x20primitive'},{'key':a0_0x37cda6(0x139),'shape':'1\x20row\x20×\x202\x20columns','outputColumns':['direction','pct'],'collapseRule':'object'},{'key':a0_0x37cda6(0x142),'shape':a0_0x37cda6(0x145),'outputColumns':[a0_0x37cda6(0x130),a0_0x37cda6(0x151)],'collapseRule':a0_0x37cda6(0x125)}],'responseShape':{'value':a0_0x37cda6(0x127),'trend':'{\x20\x22direction\x22:\x20\x22up\x22,\x20\x22pct\x22:\x20\x222.6\x22\x20}','points':'[{\x20\x22period\x22:\x20\x222026-04-24\x22,\x20\x22value\x22:\x20\x221850\x22\x20},\x20...\x20]'},'referenceWidgetId':a0_0x37cda6(0x121),'socNotes':'Sparkline\x20libraries\x20(ApexCharts,\x20Chartist,\x20etc.)\x20typically\x20need\x20a\x20plain\x20number\x20array.\x20Frontend\x20maps\x20points.map(p\x20=>\x20p.value).\x20The\x20\x27period\x27\x20field\x20stays\x20for\x20tooltip\x20and\x20gap-resilience\x20against\x20missing\x20days.\x20Use\x20generate_series\x20in\x20SQL\x20to\x20ensure\x20consistent\x20row\x20count\x20even\x20for\x20days\x20with\x20no\x20transactions.'},{'id':'metric_progress_to_goal','name':a0_0x37cda6(0x15d),'useCase':'Headline\x20metric\x20with\x20trend\x20chip\x20and\x20progress\x20bar\x20against\x20a\x20period\x20target.\x20Suitable\x20for\x20widgets\x20like\x20\x27Orders\x20This\x20Month\x27.','payloadShape':{'id':a0_0x37cda6(0x12e),'queries':{'value':a0_0x37cda6(0x11c),'trend':'file:query/<path>/trend.sql','target':'file:query/<path>/target.sql'}},'sqlShapesPerKey':[{'key':'value','shape':a0_0x37cda6(0x166),'outputColumns':['value\x20(or\x20current)'],'collapseRule':a0_0x37cda6(0x133)},{'key':a0_0x37cda6(0x139),'shape':a0_0x37cda6(0x163),'outputColumns':['direction',a0_0x37cda6(0x122)],'collapseRule':'object'},{'key':'target','shape':'1\x20row\x20×\x201\x20column','outputColumns':[a0_0x37cda6(0x158)],'collapseRule':a0_0x37cda6(0x133)}],'responseShape':{'value':a0_0x37cda6(0x13b),'trend':'{\x20\x22direction\x22:\x20\x22down\x22,\x20\x22pct\x22:\x20\x222.2\x22\x20}','target':'\x222884\x22'},'referenceWidgetId':a0_0x37cda6(0x14b),'socNotes':'Frontend\x20computes\x20to_goal\x20=\x20target\x20-\x20value\x20and\x20pct\x20=\x20round(value\x20/\x20target\x20*\x20100)\x20for\x20the\x20progress\x20bar.\x20Visual\x20width\x20is\x20presentational\x20and\x20must\x20NOT\x20live\x20in\x20the\x20backend\x20payload.\x20If\x20progress\x20involves\x20complex\x20business\x20rules\x20(e.g.\x20exclude\x20weekends,\x20prorated\x20workdays),\x20use\x20a\x20single\x20multi-column\x20query\x20so\x20\x27pct\x27\x20is\x20a\x20stable\x20business\x20fact\x20rather\x20than\x20visual\x20width.'}],NAMING_CONVENTION={'dashboardName':{'constraint':'MUST\x20start\x20with\x20\x27dash-\x27\x20prefix','minLength':0x6,'maxLength':0x32,'regex':a0_0x37cda6(0x11b),'examples':['dash-sales',a0_0x37cda6(0x155),'dash-author-stats'],'rationale':'The\x20prefix\x20becomes\x20part\x20of\x20the\x20URL\x20segment.\x20The\x20reserved\x20scheme\x20keeps\x20dashboard\x20endpoints\x20visually\x20distinct\x20from\x20CRUD\x20endpoints\x20in\x20the\x20URL\x20space\x20and\x20allows\x20future\x20routing\x20differentiation.'}},URL_PATTERN={'method':a0_0x37cda6(0x159),'path':a0_0x37cda6(0x176),'exampleFull':a0_0x37cda6(0x168),'requestBodyShape':{'params':a0_0x37cda6(0x17d),'widgets':a0_0x37cda6(0x13f)},'responseShape':{'envelope':a0_0x37cda6(0x11f),'perWidgetResponse':'Determined\x20by\x20scalarCollapseRules.\x20Failed\x20widgets\x20produce\x20{\x20error:\x20\x27...\x27\x20}\x20block\x20with\x20top-level\x20success\x20still\x20true\x20(one\x20widget\x20failure\x20does\x20NOT\x20fail\x20the\x20dashboard).'}},FILE_REFERENCE_CONVENTION={'format':'file:relative/path/to/query.sql','pathRelativeTo':a0_0x37cda6(0x119),'fileExtensionPolicy':a0_0x37cda6(0x140),'resolvedAt':a0_0x37cda6(0x14d),'embedStrategy':'SQL\x20file\x20content\x20is\x20embedded\x20as\x20JavaScript\x20template\x20literal\x20inside\x20the\x20generated\x20module\x20file.\x20Runtime\x20performs\x20zero\x20disk\x20I/O\x20per\x20request\x20—\x20all\x20SQL\x20is\x20in\x20memory\x20after\x20module\x20load.','implication':'Updating\x20an\x20SQL\x20file\x20requires\x20regenerating\x20the\x20dashboard\x20module\x20(\x27codegen_create_dashboard\x27)\x20for\x20changes\x20to\x20take\x20effect.'},PLACEHOLDER_CONVENTION={'format':':paramName','regex':'(?<!:):([a-zA-Z_][a-zA-Z0-9_]*)','regexNotes':'Negative\x20lookbehind\x20prevents\x20matching\x20\x27::\x27\x20(Postgres\x20cast\x20syntax)\x20as\x20a\x20placeholder.','scanScope':a0_0x37cda6(0x138),'constraint':a0_0x37cda6(0x160),'exampleSql':'SELECT\x20*\x20FROM\x20stock_inbound\x20WHERE\x20EXTRACT(YEAR\x20FROM\x20inbound_date)\x20=\x20:year','exampleParamDeclaration':a0_0x37cda6(0x16f)},CACHE_SPEC={'container':a0_0x37cda6(0x135),'optional':!![],'rationale':'Dashboard\x20endpoint\x20may\x20opt-in\x20to\x20Redis-based\x20cache.\x20Pattern\x20follows\x20processor\x20cache\x20(see\x20feat-cache.md).\x20Cache\x20scope\x20is\x20the\x20full\x20response\x20envelope;\x20one\x20cache\x20entry\x20per\x20(params\x20+\x20widgets[]\x20subset)\x20combination.','fields':[{'name':a0_0x37cda6(0x143),'type':'boolean','required':!![],'description':'Toggle\x20cache\x20feature\x20for\x20this\x20dashboard.'},{'name':'ttl','type':'number','required':![],'constraint':'>=\x200\x20(seconds)','default':'inherits\x20CACHE_TTL\x20env','description':a0_0x37cda6(0x148)},{'name':'invalidates','type':a0_0x37cda6(0x12d),'required':![],'default':'[]','description':a0_0x37cda6(0x15a)}],'validation':{'sqlCrossReference':'When\x20cache.enabled\x20===\x20true\x20and\x20invalidates\x20is\x20non-empty:\x20validator\x20extracts\x20table\x20candidates\x20from\x20widget\x20SQL\x20(regex\x20FROM/JOIN),\x20cross-references\x20with\x20metadata/{project}.json\x20(endpoints[*].tableName\x20where\x20type\x20===\x20\x22module\x22),\x20and\x20asserts\x20equality\x20of\x20expected\x20vs\x20declared\x20sets.\x20Mismatches\x20are\x20reported\x20per\x20category\x20(missing,\x20extra,\x20unmatched).','errorOn':['Table\x20appears\x20in\x20SQL\x20AND\x20in\x20metadata\x20project,\x20but\x20missing\x20from\x20invalidates\x20(cache\x20stale\x20risk)',a0_0x37cda6(0x134)],'warningOn':[a0_0x37cda6(0x147)]}},DOCUMENTATION_URL=a0_0x37cda6(0x167),DASHBOARD_CATALOG={'schemaVersion':'1.0','source':a0_0x37cda6(0x136),'summary':{'totalAllowedTopLevelFields':PAYLOAD_SHAPE[a0_0x37cda6(0x164)]['length'],'totalForbiddenFrontendFields':FORBIDDEN_FRONTEND_FIELDS['length'],'totalParamTypes':ALLOWED_PARAM_TYPES[a0_0x37cda6(0x154)],'totalScalarCollapseRules':SCALAR_COLLAPSE_RULES[a0_0x37cda6(0x154)],'totalCommonWidgetPatterns':COMMON_WIDGET_PATTERNS['length']},'payloadShape':PAYLOAD_SHAPE,'widgetSpec':WIDGET_SPEC,'paramSpec':PARAM_SPEC,'scalarCollapseRules':SCALAR_COLLAPSE_RULES,'commonWidgetPatterns':COMMON_WIDGET_PATTERNS,'namingConvention':NAMING_CONVENTION,'urlPattern':URL_PATTERN,'fileReferenceConvention':FILE_REFERENCE_CONVENTION,'placeholderConvention':PLACEHOLDER_CONVENTION,'cacheSpec':CACHE_SPEC,'documentationUrl':DOCUMENTATION_URL};function a0_0x4f69(_0x1e2660,_0x4a8154){_0x1e2660=_0x1e2660-0x118;const _0xe2f178=a0_0xe2f1();let _0x4f69e5=_0xe2f178[_0x1e2660];if(a0_0x4f69['SUDayG']===undefined){var _0x2e78f5=function(_0x3e3116){const _0x2ea29a='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x40fdad='',_0x1dc75e='';for(let _0x38b94b=0x0,_0x143d1b,_0x4bec06,_0x304e65=0x0;_0x4bec06=_0x3e3116['charAt'](_0x304e65++);~_0x4bec06&&(_0x143d1b=_0x38b94b%0x4?_0x143d1b*0x40+_0x4bec06:_0x4bec06,_0x38b94b++%0x4)?_0x40fdad+=String['fromCharCode'](0xff&_0x143d1b>>(-0x2*_0x38b94b&0x6)):0x0){_0x4bec06=_0x2ea29a['indexOf'](_0x4bec06);}for(let _0x16b68d=0x0,_0x2f4502=_0x40fdad['length'];_0x16b68d<_0x2f4502;_0x16b68d++){_0x1dc75e+='%'+('00'+_0x40fdad['charCodeAt'](_0x16b68d)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x1dc75e);};a0_0x4f69['gVMMYh']=_0x2e78f5,a0_0x4f69['rSmWGk']={},a0_0x4f69['SUDayG']=!![];}const _0x2523da=_0xe2f178[0x0],_0x5555c2=_0x1e2660+_0x2523da,_0x9a110f=a0_0x4f69['rSmWGk'][_0x5555c2];return!_0x9a110f?(_0x4f69e5=a0_0x4f69['gVMMYh'](_0x4f69e5),a0_0x4f69['rSmWGk'][_0x5555c2]=_0x4f69e5):_0x4f69e5=_0x9a110f,_0x4f69e5;}module[a0_0x37cda6(0x144)]={'DASHBOARD_CATALOG':DASHBOARD_CATALOG};
|
|
1
|
+
const a0_0x6b3219=a0_0x11fa;function a0_0x11fa(_0x55a563,_0x575b08){_0x55a563=_0x55a563-0xe3;const _0x3d161c=a0_0x3d16();let _0x11fac6=_0x3d161c[_0x55a563];if(a0_0x11fa['HsgXgY']===undefined){var _0x33ad11=function(_0x3dd666){const _0x4d3ed3='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x3b2926='',_0x9f28d4='';for(let _0x484932=0x0,_0x5b93cc,_0x1e967a,_0x2d9121=0x0;_0x1e967a=_0x3dd666['charAt'](_0x2d9121++);~_0x1e967a&&(_0x5b93cc=_0x484932%0x4?_0x5b93cc*0x40+_0x1e967a:_0x1e967a,_0x484932++%0x4)?_0x3b2926+=String['fromCharCode'](0xff&_0x5b93cc>>(-0x2*_0x484932&0x6)):0x0){_0x1e967a=_0x4d3ed3['indexOf'](_0x1e967a);}for(let _0x2c5c34=0x0,_0x3c65ee=_0x3b2926['length'];_0x2c5c34<_0x3c65ee;_0x2c5c34++){_0x9f28d4+='%'+('00'+_0x3b2926['charCodeAt'](_0x2c5c34)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x9f28d4);};a0_0x11fa['SITrXM']=_0x33ad11,a0_0x11fa['NkokEU']={},a0_0x11fa['HsgXgY']=!![];}const _0x4b058f=_0x3d161c[0x0],_0x224e89=_0x55a563+_0x4b058f,_0x18650f=a0_0x11fa['NkokEU'][_0x224e89];return!_0x18650f?(_0x11fac6=a0_0x11fa['SITrXM'](_0x11fac6),a0_0x11fa['NkokEU'][_0x224e89]=_0x11fac6):_0x11fac6=_0x18650f,_0x11fac6;}(function(_0x8caa89,_0x210ae2){const _0x482a45=a0_0x11fa,_0x1c97e4=_0x8caa89();while(!![]){try{const _0x483aed=parseInt(_0x482a45(0xf5))/0x1+parseInt(_0x482a45(0xf0))/0x2*(parseInt(_0x482a45(0x11e))/0x3)+-parseInt(_0x482a45(0x114))/0x4+-parseInt(_0x482a45(0x130))/0x5+parseInt(_0x482a45(0x121))/0x6*(-parseInt(_0x482a45(0x10b))/0x7)+-parseInt(_0x482a45(0x104))/0x8*(-parseInt(_0x482a45(0x106))/0x9)+parseInt(_0x482a45(0xee))/0xa*(-parseInt(_0x482a45(0x120))/0xb);if(_0x483aed===_0x210ae2)break;else _0x1c97e4['push'](_0x1c97e4['shift']());}catch(_0x4bb3d0){_0x1c97e4['push'](_0x1c97e4['shift']());}}}(a0_0x3d16,0x2f503));function a0_0x3d16(){const _0x368a7b=['vgfIBguGzgvJBgfYzwqGAw4GAw52ywXPzgf0zxmSigj1DcbUB3qGzgv0zwn0zwqGAw4Gyw55ihDPzgDLDcbtuuWGkhr5Cg8GB3iGzgvHzcbLBNrYEsK','yw55icHTDxn0igjLignVBxbHDgLIBguGD2L0AcbKzwnSyxjLzcaNDhLWzsCP','twv0CMLJicSGuhjVz3jLC3mGDg8Gr29HBa','qwX3yxLZihSGAxrLBxm6ifSUlI5Dih0GCMvNyxjKBgvZCYbVzIbtuuWGCMvZDwX0ihnOyxbLlG','mtK5otu3yMzMC21K','BNvTyMvY','DhjLBMq','ms4W','yM9VBgvHBG','zMLSztPXDwvYEs88Cgf0Ad4VDhjLBMqUC3fS','Aw52ywXPzgf0zxm','C2nHBgfYihbYAw1PDgL2zq','Dg9WlwXLDMvSicDWyxjHBxmNig9IAMvJDa','ugvYlwTLEsbIyxnLzcbVBIbZy2fSyxjdB2XSyxbZzvj1BgvZigjLBg93lG','msbYB3CGW5CGmsbJB2X1Bw4','twv0CMLJicSGu3bHCMTSAw5L','D2LKz2v0lNf1zxjPzxmUpgTLEt4GD2L0AcbtuuWGCMv0DxjUAw5NideGCM93imoxideGy29SDw1U','EYaIzgLYzwn0Aw9UiJOGiNvWiIWGiNbJDci6iciYlJyIih0','u0vmrunuicOGrLjptsbZDg9JA19PBMjVDw5KifDirvjfievyvfjbq1qOwuvbuIbguK9nigLUyM91BMrFzgf0zsKGpsa6EwvHCG','odi2ntuYEK5izxbL','vuKGBgfIzwWGAxmGysbMCM9UDgvUzcbYzw5KzxjPBMCGy29Uy2vYBI4','ow5ZEM93wG','D2LKz2v0lNf1zxj5icHZAw5NDwXHCIK','zNjLztSGlNnXBcbYzwnVBw1LBMrLzcbMB3iGzwrPDg9YigHPz2HSAwDODa','EYaIzgLYzwn0Aw9UiJOGiMrVD24IlcaICgn0iJOGiJiUmIiGFq','iJy5nZaWiG','ndK4neXhC0rHva','rNjVBNrLBMqGzgv0zxjTAw5LCYbKB251Dc9WAwuGDMfYAwfUDcWGy29SB3iGCgvYignHDgvNB3j5lcbHBMqGBgfIzwWGB3jKzxiUieLMihbLCI1JyxrLz29YEsbWzxjJzw50ywDLigLZig5LzwrLzcbMB3iGDgHLigrVBNv0igfYyYWGzNjVBNrLBMqGy29TChv0zxmGAxqGzNjVBsbPDgvTC1TPxs52ywX1zsaVihn1BsHPDgvTC1SQxs52ywX1zsKUie5Vig5LzwqGDg8GC2vUzcaNCgn0jYbMCM9TigjHy2TLBMqGDw5SzxnZihrOzsbMAwD1CMuGAxmGysbZDgfIBguGyNvZAw5LC3mGy2fSy3vSyxrPB24GAw5KzxbLBMrLBNqGB2yGDMLZDwfSihjLBMrLCMLUzY4','phDPzgDLDf9Pzd4','Cg9PBNrZ','Dg9Wtgv2zwXbBgXVD2vK','l2fWAs97ChjVAMvJDh0VE25HBwv9l2rHC2HIB2fYza','kd88itOPoIHBys16qs1Ax11Bys16qs1Amc05x10Qkq','EYaIzgLYzwn0Aw9UiJOGiNvWiIWGiNbJDci6iciYlJiIih0','zMLSztPYzwXHDgL2zs9WyxrOl3rVl3f1zxj5lNnXBa','ntu2mdu2CxbVAMTs','yw55icGXihjVDYddLYaXignVBcWGtIbYB3DZimoxie0Gy29SCYWGzxrJlIK','D2LKz2v0lNf1zxjPzxmUpgTLEt4GD2L0AcbtuuWGCMv0DxjUAw5Nie4GCM93CW','yxjYyxK','vMLZDwfSihzHCMLHBNqGkgrVBNv0lcbIyxiSihbPzsWGyxjLysKGAxmGysbMCM9UDgvUzcbYzw5KzxjPBMCGy29Uy2vYBIaOC2vWyxjHDgLVBIbVzIbJB25JzxjUCYKU','BgvUz3rO','Ahr0Chm6lY9Yzxn0zM9Yz2uUzgv2l2rVy3mVC2vYDMvYl3f1zxj5lwrHDgeVzgfZAgjVyxjK','Bgf5B3v0','zNjVBNrLBMqTy29Uy2vYBG','tgf5B3v0igLZigeGzNjVBNrLBMqGCMvUzgvYAw5NignVBMnLCM4U','mta3mdm0mhj2vg1vwq','C2HHCguTy29UzMXPy3q','nZa0DfrNtNjz','mJi4r2T6z3vL','A2v54OAszMLSztPYzwXHDgL2zs9WyxrOl3rVl3f1zxj5lNnXBa','vg9Nz2XLignHy2HLigzLyxr1CMuGzM9YihrOAxmGzgfZAgjVyxjKlG','zMLSztPXDwvYEs88Cgf0Ad4VyNjLywTKB3DUlNnXBa','zw5HyMXLza','qsb3AwrNzxqGtvvtvcbKzwnSyxjLigv4ywn0BhKGB25Lig9MoIaNCxvLCNKNie9sicDXDwvYAwvZjY4GqM90AcbVCIbUzwL0AgvYigLZihjLAMvJDgvKlG','q29SBgfWC2uGDg8GC2nHBgfYihbYAw1PDgL2zsaODgHLihzHBhvLig9MihrOzsbZAw5NBguGy29SDw1Uks4','t3b0Aw9UywWGy2fJAguGy29UzMLNDxjHDgLVBI4Gu2vLignHy2HLu3bLyYbMB3iGzgv0ywLSCY4','B3jKzxjZx3rOAxnFBw9UDgG','iNzHBhvLiJOGiJy5nZaWiG','tgLZDcbVzIbduLveihrHyMXLig5HBwvZihrOyxqSihDOzw4GD3jPDhrLBIWGD2LSBcb0CMLNz2vYigLUDMfSAwrHDgLVBIbVzIb0AgLZigrHC2HIB2fYzcbJywnOzs4','D2LKz2v0lNf1zxjPzxmUpgTLEt4GD2L0AcbtuuWGCMv0DxjUAw5NideGCM93imoxig11BhrPCgXLignVBhvTBNm','zMLSztPXDwvYEs88Cgf0Ad4VCg9PBNrZlNnXBa','sgvHzgXPBMuGBwv0CMLJihDPDgGGDhjLBMqGy2HPCcbHBMqGC3bHCMTSAw5Lig1PBMKTy2HHCNqGzM9YihnOB3j0ihDPBMrVD3mGkdCGzgf5CYWGmtiGBw9UDgHZlcbLDgmUks4Gu3vPDgfIBguGzM9YihDPzgDLDhmGBgLRzsaNqxzLCMfNzsbeywLSEsbtywXLCYCU','CgfYyw1Z','odyYmZvgvwryBwG','C3rYAw5N','v2HLBIbJywnOzs5LBMfIBgvKid09psb0CNvLigfUzcbPBNzHBgLKyxrLCYbPCYbUB24Tzw1WDhK6ihzHBgLKyxrVCIbLEhrYywn0CYb0ywjSzsbJyw5KAwrHDgvZigzYB20GD2LKz2v0ifnrtcaOCMvNzxGGrLjpts9kt0LoksWGy3jVC3mTCMvMzxjLBMnLCYb3AxrOig1LDgfKyxrHl3TWCM9Qzwn0Fs5QC29UicHLBMrWB2LUDhnBkL0UDgfIBgvoyw1LihDOzxjLihr5CguGpt09icjTB2r1BguIksWGyw5KigfZC2vYDhmGzxf1ywXPDhKGB2yGzxHWzwn0zwqGDNmGzgvJBgfYzwqGC2v0CY4GtwLZBwf0y2HLCYbHCMuGCMvWB3j0zwqGCgvYignHDgvNB3j5icHTAxnZAw5NlcbLEhrYysWGDw5TyxrJAgvKks4','Cgn0','oNbHCMfTtMfTzq','Cgf5Bg9Hzcbku09oigzPBguGBg9JyxrPB24','Bwv0CMLJx3bYB2DYzxnZx3rVx2DVywW','iJi4odqI','v2HLBIb0CNvLlcb0AguGCMvXDwvZDcbIB2r5ie1vu1qGAw5JBhvKzsb0AgLZihbHCMfTicHVDgHLCNDPC2uGndaWks4','msbYB3CGW5CGmIbJB2X1Bw5Z','DhLWzq','tgLZDcbVzIb3AwrNzxqGzgvMAw5PDgLVBNmUie9YzgvYigLZigLUzM9YBwf0Aw9UywWGB25SEsaOCMvZCg9UC2uGA2v5CYbHCMuGyNKGD2LKz2v0igLKlcbUB3qGyxjYyxKGAw5KzxGPlG','y29SB3i','qwXSihDPzgDLDcbtuuWG4OcuigjVDgGGj3f1zxj5jYaOC2LUz3vSyxiPigfUzcbLDMvYEsaNCxvLCMLLCY48A2v5pICU','zMLSztPXDwvYEs88Cgf0Ad4VDgfYz2v0lNnXBa','EYaICgfYyw1ZiJOGEYaIEwvHCIi6ihSGiNr5CguIoIaIBNvTyMvYiIWGiNjLCxvPCMvKiJOGDhj1zsb9ih0GFq','CxvLCNK','iNrYzw5KiJOGEYaIzgLYzwn0Aw9UiJOGiNvWiIWGiNbJDci6iciYlJiIih0','Aw5OzxjPDhmGq0fdsevFvfrmigvUDG','Dg9WlwXLDMvSicDJywnOzsCGB2jQzwn0','B2jQzwn0','zgLYzwn0Aw9U','DgfYz2v0','tIbYB3DZimoxidiGy29SDw1UCW','rgv0zxjTAw5LzcbIEsbZy2fSyxjdB2XSyxbZzvj1BgvZlIbgywLSzwqGD2LKz2v0CYbWCM9KDwnLihSGzxjYB3i6icCUlI4Nih0GyMXVy2SGD2L0Acb0B3aTBgv2zwWGC3vJy2vZCYbZDgLSBcb0CNvLicHVBMuGD2LKz2v0igzHAwX1CMuGzg9LCYbot1qGzMfPBcb0AguGzgfZAgjVyxjKks4','u1fmigzPBguGy29UDgvUDcbPCYbLBwjLzgrLzcbHCYbkyxzHu2nYAxb0ihrLBxbSyxrLigXPDgvYywWGAw5ZAwrLihrOzsbNzw5LCMf0zwqGBw9KDwXLigzPBguUifj1BNrPBwuGCgvYzM9YBxmGEMvYBYbKAxnRieKVtYbWzxiGCMvXDwvZDcdIGjqGywXSifnrtcbPCYbPBIbTzw1VCNKGywz0zxiGBw9KDwXLigXVywqU','ue9tva','C3vIDgL0Bgu','yxzNx2rHAwX5x3nHBgvZ','ndqYmtbPr3rIv0q','DMfSDwu','mKTNy05jBq'];a0_0x3d16=function(){return _0x368a7b;};return a0_0x3d16();}const FORBIDDEN_FRONTEND_FIELDS=['widgetType',a0_0x6b3219(0x11b),'title',a0_0x6b3219(0xec),a0_0x6b3219(0x13c)],ALLOWED_PARAM_TYPES=['string',a0_0x6b3219(0xf6),a0_0x6b3219(0xf9),'date'],FRONTEND_CONCERN_REASONS={'widgetType':a0_0x6b3219(0x118),'layout':a0_0x6b3219(0x11d),'title':a0_0x6b3219(0x105),'subtitle':a0_0x6b3219(0x105),'color':'Visual\x20color\x20is\x20a\x20frontend\x20rendering\x20concern.'},PAYLOAD_SHAPE={'discriminator':{'field':'widgets','presentMeans':'dashboard\x20payload','absentMeans':'Not\x20a\x20dashboard\x20payload\x20(likely\x20CRUD\x20with\x20tableName,\x20or\x20invalid)','conflictsWith':'tableName','conflictRationale':'A\x20payload\x20with\x20both\x20\x27widgets\x27\x20and\x20\x27tableName\x27\x20is\x20rejected\x20by\x20DashboardValidator.\x20Pick\x20one\x20shape.'},'topLevelAllowed':[{'name':'widgets','type':a0_0x6b3219(0x117),'required':!![],'minItems':0x1,'description':a0_0x6b3219(0x13b)},{'name':a0_0x6b3219(0x12f),'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_0x6b3219(0x128)}],'topLevelForbidden':[{'name':'tableName','category':a0_0x6b3219(0x11f),'reason':'Reserved\x20for\x20CRUD\x20payloads.\x20A\x20dashboard\x20payload\x20must\x20declare\x20\x27widgets\x27\x20instead.'},...FORBIDDEN_FRONTEND_FIELDS['map'](_0x3b2926=>({'name':_0x3b2926,'category':a0_0x6b3219(0x11c),'reason':FRONTEND_CONCERN_REASONS[_0x3b2926]}))]},WIDGET_SPEC={'requiredFields':[{'name':'id','type':a0_0x6b3219(0x131),'constraint':'non-empty,\x20unique\x20across\x20widgets\x20in\x20the\x20same\x20payload','description':'Widget\x20identifier;\x20used\x20as\x20the\x20response\x20key\x20in\x20the\x20dashboard\x20envelope.'}],'exclusiveQueryFields':{'rule':a0_0x6b3219(0x126),'options':[{'name':a0_0x6b3219(0x140),'type':'string','format':a0_0x6b3219(0x113),'description':'Single\x20SQL\x20query\x20for\x20the\x20widget.','responseShape':a0_0x6b3219(0xf4)},{'name':'queries','type':a0_0x6b3219(0xe5),'format':a0_0x6b3219(0x122),'minKeys':0x1,'description':'Multi-SQL\x20widget.\x20Each\x20key\x20becomes\x20a\x20key\x20in\x20the\x20response\x20object.','responseShape':a0_0x6b3219(0xfe)}]},'forbiddenFields':FORBIDDEN_FRONTEND_FIELDS},PARAM_SPEC={'container':a0_0x6b3219(0xfd),'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_0x6b3219(0x13a),'required':!![],'allowedValues':ALLOWED_PARAM_TYPES,'description':'Param\x20data\x20type.\x20Validates\x20request\x20body\x20and\x20shapes\x20runtime\x20parameter\x20binding.'},{'name':'required','required':![],'type':'boolean','default':![],'description':a0_0x6b3219(0x138)},{'name':'default','required':![],'type':a0_0x6b3219(0xf2),'description':'Default\x20value\x20applied\x20when\x20the\x20request\x20omits\x20this\x20param.\x20Validator\x20does\x20NOT\x20strictly\x20type-check\x20default;\x20runtime\x20is\x20responsible\x20for\x20compatibility.'}]},SCALAR_COLLAPSE_RULES=[{'appliesTo':a0_0x6b3219(0x107),'rule':'Always\x20wrap\x20as\x20{\x20items:\x20[...]\x20}\x20regardless\x20of\x20SQL\x20result\x20shape.','exampleSqlShape':a0_0x6b3219(0x115),'exampleResponse':'\x22shopping_categories\x22:\x20{\x20\x22items\x22:\x20[{\x20\x22name\x22:\x20\x22Lands\x22\x20},\x20{\x20\x22name\x22:\x20\x22Houses\x22\x20}]\x20}'},{'appliesTo':a0_0x6b3219(0x101),'rule':a0_0x6b3219(0x127),'exampleSqlShape':'1\x20row\x20×\x201\x20col,\x20output\x20column\x20\x27value\x27','exampleResponse':a0_0x6b3219(0x12a)},{'appliesTo':a0_0x6b3219(0x12c),'rule':'Collapse\x20to\x20object\x20whose\x20keys\x20are\x20SQL\x20column\x20names\x20(lowercased).','exampleSqlShape':'1\x20row\x20×\x202\x20cols,\x20output\x20columns\x20\x27direction\x27,\x20\x27pct\x27','exampleResponse':a0_0x6b3219(0x141)},{'appliesTo':a0_0x6b3219(0x116),'rule':'Return\x20as\x20array\x20of\x20objects\x20(no\x20collapse).','exampleSqlShape':'N\x20rows\x20×\x20M\x20cols','exampleResponse':'\x22items\x22:\x20[{\x20\x22label\x22:\x20\x22Shoes\x22,\x20\x22value\x22:\x20\x227660\x22\x20},\x20...]'}],COMMON_WIDGET_PATTERNS=[{'id':'metric_donut_breakdown','name':'Metric\x20+\x20Donut\x20Breakdown','useCase':'Headline\x20metric\x20with\x20trend\x20chip\x20and\x20breakdown\x20across\x20categories.\x20Suitable\x20for\x20widgets\x20like\x20\x27Expected\x20Earnings\x27\x20that\x20show\x20total\x20value,\x20percentage\x20change,\x20and\x20per-category\x20contribution.','payloadShape':{'id':'<widget_id>','queries':{'value':'file:query/<path>/value.sql','trend':a0_0x6b3219(0xfa),'items':a0_0x6b3219(0x124)}},'sqlShapesPerKey':[{'key':a0_0x6b3219(0xef),'shape':'1\x20row\x20×\x201\x20column','outputColumns':[a0_0x6b3219(0xef)],'collapseRule':'scalar\x20primitive'},{'key':a0_0x6b3219(0xf7),'shape':'1\x20row\x20×\x202\x20columns','outputColumns':['direction','pct'],'collapseRule':a0_0x6b3219(0xe5)},{'key':'items','shape':a0_0x6b3219(0xe8),'outputColumns':['label',a0_0x6b3219(0xef)],'collapseRule':'array\x20of\x20objects'}],'responseShape':{'value':a0_0x6b3219(0x10a),'trend':a0_0x6b3219(0x112),'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':'expected_earnings','socNotes':a0_0x6b3219(0x10c)},{'id':'metric_sparkline','name':a0_0x6b3219(0x100),'useCase':a0_0x6b3219(0x12e),'payloadShape':{'id':a0_0x6b3219(0x10d),'queries':{'value':'file:query/<path>/value.sql','trend':'file:query/<path>/trend.sql','points':a0_0x6b3219(0x12d)}},'sqlShapesPerKey':[{'key':'value','shape':'1\x20row\x20×\x201\x20column','outputColumns':['value'],'collapseRule':a0_0x6b3219(0xfc)},{'key':'trend','shape':a0_0x6b3219(0x139),'outputColumns':[a0_0x6b3219(0xe6),a0_0x6b3219(0x133)],'collapseRule':'object'},{'key':a0_0x6b3219(0x10e),'shape':'N\x20rows\x20×\x202\x20columns','outputColumns':['period','value'],'collapseRule':'array\x20of\x20objects'}],'responseShape':{'value':'\x222420\x22','trend':a0_0x6b3219(0x102),'points':'[{\x20\x22period\x22:\x20\x222026-04-24\x22,\x20\x22value\x22:\x20\x221850\x22\x20},\x20...\x20]'},'referenceWidgetId':a0_0x6b3219(0xed),'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':a0_0x6b3219(0x136),'name':a0_0x6b3219(0xf3),'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_0x6b3219(0x10d),'queries':{'value':'file:query/<path>/current.sql','trend':'file:query/<path>/trend.sql','target':a0_0x6b3219(0x13e)}},'sqlShapesPerKey':[{'key':a0_0x6b3219(0xef),'shape':a0_0x6b3219(0xff),'outputColumns':['value\x20(or\x20current)'],'collapseRule':'scalar\x20primitive'},{'key':a0_0x6b3219(0xf7),'shape':'1\x20row\x20×\x202\x20columns','outputColumns':[a0_0x6b3219(0xe6),'pct'],'collapseRule':a0_0x6b3219(0xe5)},{'key':'target','shape':a0_0x6b3219(0xff),'outputColumns':[a0_0x6b3219(0xe7)],'collapseRule':'scalar\x20primitive'}],'responseShape':{'value':'\x221836\x22','trend':a0_0x6b3219(0x109),'target':a0_0x6b3219(0x137)},'referenceWidgetId':a0_0x6b3219(0x129),'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':['dash-sales','dash-inbound','dash-author-stats'],'rationale':'The\x20prefix\x20becomes\x20part\x20of\x20the\x20URL\x20segment.\x20The\x20reserved\x20scheme\x20keeps\x20dashboard\x20endpoints\x20visually\x20distinct\x20from\x20CRUD\x20endpoints\x20in\x20the\x20URL\x20space\x20and\x20allows\x20future\x20routing\x20differentiation.'}},URL_PATTERN={'method':a0_0x6b3219(0xeb),'path':a0_0x6b3219(0x110),'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':'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_0x6b3219(0xe9)}},FILE_REFERENCE_CONVENTION={'format':a0_0x6b3219(0x113),'pathRelativeTo':a0_0x6b3219(0x135),'fileExtensionPolicy':a0_0x6b3219(0x108),'resolvedAt':'generation\x20time\x20(NOT\x20runtime)','embedStrategy':a0_0x6b3219(0xea),'implication':'Updating\x20an\x20SQL\x20file\x20requires\x20regenerating\x20the\x20dashboard\x20module\x20(\x27codegen_create_dashboard\x27)\x20for\x20changes\x20to\x20take\x20effect.'},PLACEHOLDER_CONVENTION={'format':a0_0x6b3219(0x134),'regex':a0_0x6b3219(0x111),'regexNotes':'Negative\x20lookbehind\x20prevents\x20matching\x20\x27::\x27\x20(Postgres\x20cast\x20syntax)\x20as\x20a\x20placeholder.','scanScope':a0_0x6b3219(0x13d),'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_0x6b3219(0x103),'exampleParamDeclaration':a0_0x6b3219(0x13f)},CACHE_SPEC={'container':a0_0x6b3219(0xe4),'optional':!![],'rationale':'Dashboard\x20endpoint\x20may\x20opt-in\x20to\x20Redis-based\x20cache.\x20Pattern\x20follows\x20processor\x20cache\x20(see\x20feat-cache.md).\x20Cache\x20scope\x20is\x20the\x20full\x20response\x20envelope;\x20one\x20cache\x20entry\x20per\x20(params\x20+\x20widgets[]\x20subset)\x20combination.','fields':[{'name':a0_0x6b3219(0x125),'type':a0_0x6b3219(0xf9),'required':!![],'description':a0_0x6b3219(0x123)},{'name':'ttl','type':'number','required':![],'constraint':'>=\x200\x20(seconds)','default':a0_0x6b3219(0xe3),'description':'Time-to-live\x20in\x20seconds.\x200\x20effectively\x20disables\x20cache\x20for\x20this\x20entry.'},{'name':a0_0x6b3219(0xfb),'type':'array<string>','required':![],'default':'[]','description':a0_0x6b3219(0x12b)}],'validation':{'sqlCrossReference':a0_0x6b3219(0x132),'errorOn':['Table\x20appears\x20in\x20SQL\x20AND\x20in\x20metadata\x20project,\x20but\x20missing\x20from\x20invalidates\x20(cache\x20stale\x20risk)',a0_0x6b3219(0xf1)],'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_0x6b3219(0x11a),DASHBOARD_CATALOG={'schemaVersion':a0_0x6b3219(0xf8),'source':'dashboard-catalog','summary':{'totalAllowedTopLevelFields':PAYLOAD_SHAPE[a0_0x6b3219(0x10f)][a0_0x6b3219(0x119)],'totalForbiddenFrontendFields':FORBIDDEN_FRONTEND_FIELDS['length'],'totalParamTypes':ALLOWED_PARAM_TYPES[a0_0x6b3219(0x119)],'totalScalarCollapseRules':SCALAR_COLLAPSE_RULES['length'],'totalCommonWidgetPatterns':COMMON_WIDGET_PATTERNS[a0_0x6b3219(0x119)]},'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
|
|
1
|
+
function a0_0x18a1(){const _0x5c39a3=['C3bSAxq','ndyYuhvxsKDR','zxHWB3j0CW','otuZnfz6qwz1rq','t3j0A3C','AgfZ','DhjPBq','mJD0zNvOyxK','BgvUz3rO','u0vsvKvsx1bpuLq','nty0nZCWtw5Ss1H5','rejFvvnfuG','ChvZAa','mZGYoty0AwPXwKfR','Aw5JBhvKzxm','mtmXmJa4v3vpwvnm','rejFtKfnrq','rw9nz0m','teLdru5trq','otK3oePczM1PDq','ueLMDui','rejFueftu1DpuKq','rejFue9sva','C3rYAw5N','mty5nJvMwNbiq3C','nZK3mdrXywjOA24','nZzuqunPv3q','Dhj1zq','zMf6sLC','whbbruG','C2XPy2u'];a0_0x18a1=function(){return _0x5c39a3;};return a0_0x18a1();}const a0_0x3dd526=a0_0x1576;(function(_0x52d87d,_0xf3e13c){const _0x269349=a0_0x1576,_0x33678c=_0x52d87d();while(!![]){try{const _0x3df77a=-parseInt(_0x269349(0x1c1))/0x1+parseInt(_0x269349(0x1b5))/0x2+parseInt(_0x269349(0x1ca))/0x3*(-parseInt(_0x269349(0x1c2))/0x4)+-parseInt(_0x269349(0x1c0))/0x5+parseInt(_0x269349(0x1bb))/0x6*(-parseInt(_0x269349(0x1c8))/0x7)+parseInt(_0x269349(0x1b7))/0x8+parseInt(_0x269349(0x1ce))/0x9*(parseInt(_0x269349(0x1d1))/0xa);if(_0x3df77a===_0xf3e13c)break;else _0x33678c['push'](_0x33678c['shift']());}catch(_0x161021){_0x33678c['push'](_0x33678c['shift']());}}}(a0_0x18a1,0x1e4ad));const DB_CONNECTION_ENV_TEMPLATE='#\x20License\x0aLICENSE=XXXX-XXXX-XXXX-XXXX\x0a\x0a#\x20Server\x0aSERVER_ADDRESS=127.0.0.1\x0aSERVER_PORT=3000\x0a\x0a#\x20Live\x20Sync\x20(WebSocket)\x20Configuration\x0a#\x20NOTE:\x20LIVE_SYNC_ENABLED=true\x20requires\x20an\x20API\x20Key\x20(KEY=...)\x20to\x20authenticate\x20WebSocket\x20clients\x0aLIVE_SYNC_ENABLED=false\x0aLIVE_SYNC_PORT=3033\x0a\x0a#\x20Redis\x20Configuration\x0aREDIS_HOST=localhost\x0aREDIS_PORT=6380\x0aREDIS_PASSWORD=\x0aREDIS_DB=0\x0a\x0a#\x20Export\x20Configuration\x0aEXPORT_FILE_EXPIRY=3600000\x0aEXPORT_CHUNK_SIZE=1000\x0a\x0a#\x20Kafka\x20Configuration\x0aKAFKA_ENABLED=false\x0a#\x20Broker\x20list\x20(comma-separated\x20for\x20multiple\x20brokers:\x20broker1:9092,broker2:9092,broker3:9092)\x0aKAFKA_BROKERS=localhost:9092\x0a#\x20Client\x20ID\x20(optional,\x20default:\x20restforge-{project}-producer\x20/\x20-consumer)\x0a#\x20KAFKA_CLIENT_ID=\x0aKAFKA_CONNECTION_TIMEOUT=3000\x0aKAFKA_REQUEST_TIMEOUT=25000\x0aKAFKA_TOPIC_PATTERN={module}.{endpoint}.events\x0aKAFKA_TENANT_ID=default\x0aKAFKA_SESSION_TIMEOUT=30000\x0aKAFKA_HEARTBEAT_INTERVAL=3000\x0aKAFKA_MAX_BYTES_PER_PARTITION=1048576\x0aKAFKA_AUTO_COMMIT=false\x0aKAFKA_AUTO_COMMIT_INTERVAL=5000\x0aKAFKA_RETRY_ATTEMPTS=3\x0aKAFKA_RETRY_DELAY=1000\x0aKAFKA_RETRY_MAX_DELAY=30000\x0aKAFKA_SSL=false\x0aKAFKA_LOG_LEVEL=info\x0a#\x20SASL\x20Authentication\x20(optional,\x20uncomment\x20if\x20the\x20broker\x20requires\x20authentication)\x0a#\x20Supported\x20mechanisms:\x20plain,\x20scram-sha-256,\x20scram-sha-512\x0a#\x20KAFKA_SASL_MECHANISM=plain\x0a#\x20KAFKA_SASL_USERNAME=\x0a#\x20KAFKA_SASL_PASSWORD=\x0a\x0a#\x20Database\x20Configuration\x0a#\x20Supported:\x20postgresql,\x20mysql,\x20oracle,\x20sqlite\x0aDB_TYPE=postgresql\x0aDB_HOST=127.0.0.1\x0aDB_PORT=5432\x0aDB_USER=postgres\x0aDB_PASSWORD=your_password_here\x0aDB_NAME=your_database_name\x0a#\x20For\x20SQLite:\x20set\x20DB_TYPE=sqlite\x20and\x20DB_NAME=./data/myapp.db\x0a#\x20DB_HOST,\x20DB_PORT,\x20DB_USER,\x20DB_PASSWORD\x20are\x20ignored\x20for\x20SQLite\x0a\x0a#\x20Logging\x20Configuration\x0aLOG_LEVEL=debug\x0aLOG_TO_FILE=true\x0a\x0a#\x20SQL\x20Logging\x0aSQL_LOG_ENABLED=false\x0aSQL_LOG_LEVEL=debug\x0aSQL_LOG_PARAMS=false\x0aSQL_LOG_SLOW_THRESHOLD=1000\x0a\x0a#\x20Cache\x20Configuration\x0aCACHE_ENABLED=false\x0aCACHE_TTL=300\x0a\x0a#\x20Job\x20Scheduler\x0aJOB_ENABLED=false\x0aJOB_CONCURRENCY=5\x0aJOB_RETENTION_HOURS=72\x0aJOB_FAILED_RETENTION_HOURS=168\x0aJOB_SHUTDOWN_TIMEOUT=10000\x0aJOB_STALLED_INTERVAL=30000\x0aJOB_MAX_STALLED_COUNT=2\x0a\x0a#\x20Distributed\x20Lock\x20Configuration\x0aLOCK_DISTRIBUTED_ENABLED=false\x0aLOCK_DISTRIBUTED_TTL=10\x0aLOCK_RESOURCE_MAX_TTL=600\x0aLOCK_DISTRIBUTED_RETRY=3\x0aLOCK_DISTRIBUTED_RETRY_DELAY=100\x0aLOCK_DISTRIBUTED_STRATEGY=reject\x0a\x0a#\x20ID\x20Generator\x20Configuration\x0aIDGEN_ENABLED=false\x0aIDGEN_IDEM_TTL=600\x0aIDGEN_COUNTER_TTL_MONTHLY=2764800\x0aIDGEN_COUNTER_TTL_DAILY=172800\x0aIDGEN_DEFAULT_MAX_RETRY=10\x0aIDGEN_DEFAULT_PIN_DIGITS=6\x0aIDGEN_DEFAULT_SERIAL_PATTERN=XXXX-XXXX-XXXX-XXXX\x0aIDGEN_DEFAULT_CODE_PATTERN=9999-9999\x0aIDGEN_ALLOW_RESET=false\x0a',REQUIRED_KEYS=new Set([a0_0x3dd526(0x1ba),'SERVER_ADDRESS',a0_0x3dd526(0x1d0),'DB_TYPE','DB_HOST',a0_0x3dd526(0x1be),a0_0x3dd526(0x1b3),a0_0x3dd526(0x1bd),a0_0x3dd526(0x1b8)]);function a0_0x1576(_0x3e7000,_0x1d35da){_0x3e7000=_0x3e7000-0x1b3;const _0x18a12c=a0_0x18a1();let _0x15767d=_0x18a12c[_0x3e7000];if(a0_0x1576['luiFnJ']===undefined){var _0x59d44a=function(_0x5b0257){const _0x37d09e='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x22fb7b='',_0x1a2d65='';for(let _0x4a15dc=0x0,_0x52240d,_0x222ba2,_0x2a97e0=0x0;_0x222ba2=_0x5b0257['charAt'](_0x2a97e0++);~_0x222ba2&&(_0x52240d=_0x4a15dc%0x4?_0x52240d*0x40+_0x222ba2:_0x222ba2,_0x4a15dc++%0x4)?_0x22fb7b+=String['fromCharCode'](0xff&_0x52240d>>(-0x2*_0x4a15dc&0x6)):0x0){_0x222ba2=_0x37d09e['indexOf'](_0x222ba2);}for(let _0x3e9582=0x0,_0x1f959f=_0x22fb7b['length'];_0x3e9582<_0x1f959f;_0x3e9582++){_0x1a2d65+='%'+('00'+_0x22fb7b['charCodeAt'](_0x3e9582)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x1a2d65);};a0_0x1576['DjRqgU']=_0x59d44a,a0_0x1576['fCCcWu']={},a0_0x1576['luiFnJ']=!![];}const _0x2015c9=_0x18a12c[0x0],_0x48a032=_0x3e7000+_0x2015c9,_0x3ec8dc=a0_0x1576['fCCcWu'][_0x48a032];return!_0x3ec8dc?(_0x15767d=a0_0x1576['DjRqgU'](_0x15767d),a0_0x1576['fCCcWu'][_0x48a032]=_0x15767d):_0x15767d=_0x3ec8dc,_0x15767d;}function parseTemplateAsSchema(_0x1fc806){const _0x5e48e6=a0_0x3dd526,_0x20e950={'yVWEq':function(_0x66a659,_0x18818c){return _0x66a659||_0x18818c;},'wBwxL':function(_0x337621,_0xe1a30d){return _0x337621===_0xe1a30d;},'EoMgC':function(_0x1422b7,_0x28ea41){return _0x1422b7<_0x28ea41;},'zbUas':function(_0x2586a6,_0x209e56){return _0x2586a6===_0x209e56;},'fazJW':function(_0x534188,_0x58cc77){return _0x534188+_0x58cc77;},'lYSKi':function(_0x26eb94,_0x5d981f){return _0x26eb94===_0x5d981f;},'XpAEH':_0x5e48e6(0x1c3),'Ortkw':'false','PIfuB':'boolean'},_0x42ec04=_0x20e950['yVWEq'](_0x1fc806,DB_CONNECTION_ENV_TEMPLATE),_0x5bfca3=_0x42ec04[_0x5e48e6(0x1c7)]('\x0a'),_0x4c81ac=[];let _0x5e3308=null,_0x42b66f=[];for(const _0x296bbc of _0x5bfca3){const _0x2f06ff=_0x296bbc['trim']();if(_0x20e950['wBwxL'](_0x2f06ff,'')){_0x42b66f=[];continue;}if(_0x2f06ff['startsWith']('#')){const _0x75a379=_0x2f06ff[_0x5e48e6(0x1c6)](0x1)[_0x5e48e6(0x1cd)](),_0x21544b=_0x75a379['length']>0x0&&_0x20e950[_0x5e48e6(0x1b9)](_0x75a379[_0x5e48e6(0x1cf)],0x3c)&&!_0x75a379[_0x5e48e6(0x1b6)](':')&&!/^[A-Z_]+=/['test'](_0x75a379)&&/^[A-Z]/['test'](_0x75a379);_0x21544b&&_0x20e950['zbUas'](_0x42b66f[_0x5e48e6(0x1cf)],0x0)?_0x5e3308=_0x75a379:_0x42b66f[_0x5e48e6(0x1b4)](_0x75a379);continue;}const _0x158acb=_0x296bbc['indexOf']('=');if(_0x158acb>0x0){const _0xad3780=_0x296bbc[_0x5e48e6(0x1c6)](0x0,_0x158acb)['trim'](),_0x4421fb=_0x296bbc['slice'](_0x20e950[_0x5e48e6(0x1c4)](_0x158acb,0x1));let _0x5e5436=_0x5e48e6(0x1bf);if(_0x20e950['lYSKi'](_0x4421fb,_0x20e950[_0x5e48e6(0x1c5)])||_0x4421fb===_0x20e950[_0x5e48e6(0x1cb)])_0x5e5436=_0x20e950[_0x5e48e6(0x1bc)];else/^-?\d+$/['test'](_0x4421fb)&&(_0x5e5436='integer');_0x4c81ac[_0x5e48e6(0x1b4)]({'name':_0xad3780,'section':_0x5e3308,'type':_0x5e5436,'default':_0x4421fb,'description':_0x42b66f['join']('\x20')||null,'required':REQUIRED_KEYS[_0x5e48e6(0x1cc)](_0xad3780)}),_0x42b66f=[];}}return _0x4c81ac;}module[a0_0x3dd526(0x1c9)]={'DB_CONNECTION_ENV_TEMPLATE':DB_CONNECTION_ENV_TEMPLATE,'REQUIRED_KEYS':REQUIRED_KEYS,'parseTemplateAsSchema':parseTemplateAsSchema};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
'use strict';const a0_0x5c15ad=a0_0x3de9;(function(_0x1c5b78,_0x565c36){const _0x21ebfa=a0_0x3de9,_0x373802=_0x1c5b78();while(!![]){try{const _0x1b8c3a=-parseInt(_0x21ebfa(0x194))/0x1*(-parseInt(_0x21ebfa(0x154))/0x2)+parseInt(_0x21ebfa(0x112))/0x3*(parseInt(_0x21ebfa(0x189))/0x4)+-parseInt(_0x21ebfa(0x172))/0x5*(-parseInt(_0x21ebfa(0x17d))/0x6)+parseInt(_0x21ebfa(0x118))/0x7*(-parseInt(_0x21ebfa(0x171))/0x8)+-parseInt(_0x21ebfa(0x13a))/0x9*(-parseInt(_0x21ebfa(0x165))/0xa)+parseInt(_0x21ebfa(0x164))/0xb*(-parseInt(_0x21ebfa(0x146))/0xc)+-parseInt(_0x21ebfa(0x127))/0xd;if(_0x1b8c3a===_0x565c36)break;else _0x373802['push'](_0x373802['shift']());}catch(_0x225f67){_0x373802['push'](_0x373802['shift']());}}}(a0_0xebd9,0x19cc1));function a0_0x3de9(_0x8f354e,_0x1d5ade){_0x8f354e=_0x8f354e-0x109;const _0xebd923=a0_0xebd9();let _0x3de9f8=_0xebd923[_0x8f354e];if(a0_0x3de9['VpHzMF']===undefined){var _0x5d50bd=function(_0x166476){const _0x45319a='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x9c19e='',_0x52f919='';for(let _0x44ec92=0x0,_0x438fc4,_0x814d95,_0x56fe3c=0x0;_0x814d95=_0x166476['charAt'](_0x56fe3c++);~_0x814d95&&(_0x438fc4=_0x44ec92%0x4?_0x438fc4*0x40+_0x814d95:_0x814d95,_0x44ec92++%0x4)?_0x9c19e+=String['fromCharCode'](0xff&_0x438fc4>>(-0x2*_0x44ec92&0x6)):0x0){_0x814d95=_0x45319a['indexOf'](_0x814d95);}for(let _0x1bf80e=0x0,_0x45a118=_0x9c19e['length'];_0x1bf80e<_0x45a118;_0x1bf80e++){_0x52f919+='%'+('00'+_0x9c19e['charCodeAt'](_0x1bf80e)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x52f919);};a0_0x3de9['wuvNXR']=_0x5d50bd,a0_0x3de9['WOnfBr']={},a0_0x3de9['VpHzMF']=!![];}const _0x1da069=_0xebd923[0x0],_0x4fba76=_0x8f354e+_0x1da069,_0x32c95a=a0_0x3de9['WOnfBr'][_0x4fba76];return!_0x32c95a?(_0x3de9f8=a0_0x3de9['wuvNXR'](_0x3de9f8),a0_0x3de9['WOnfBr'][_0x4fba76]=_0x3de9f8):_0x3de9f8=_0x32c95a,_0x3de9f8;}const {IS_DELETED_COLUMN,DELETED_AT_COLUMN,DELETED_BY_COLUMN,SOFT_DELETE_COLUMN_TYPES,SOFT_DELETE_SUFFIX_LENGTH,SOFT_DELETE_CHECK_SUFFIX,SOFT_DELETE_PHASE1_DIALECT}=require(a0_0x5c15ad(0x152)),SCHEMA_VERSION='1.1',SOURCE=a0_0x5c15ad(0x175),DOCUMENTATION_URL='https://restforge.dev/docs/cli/schema-definition',DEFINE_MODEL_OPTIONS=[{'name':a0_0x5c15ad(0x163),'required':![],'type':'string|null','description':a0_0x5c15ad(0x16d),'notes':a0_0x5c15ad(0x11e)},{'name':a0_0x5c15ad(0x18f),'required':!![],'type':a0_0x5c15ad(0x174),'description':a0_0x5c15ad(0x15a),'example':'{\x20id:\x20\x22string:36\x20pk\x22,\x20name:\x20\x22string:255\x20notnull\x22\x20}'},{'name':a0_0x5c15ad(0x138),'required':![],'type':'string|array','description':'Override\x20primary\x20key.\x20Single\x20field\x20name\x20or\x20composite\x20array.','notes':'Auto-detected\x20from\x20field\x20shorthand\x20\x22pk\x22\x20when\x20not\x20specified.'},{'name':'relations','required':![],'type':'object','description':a0_0x5c15ad(0x16a),'example':'{\x20category:\x20{\x20type:\x20\x22belongsTo\x22,\x20references:\x20\x22category(id)\x22\x20}\x20}'},{'name':'indexes','required':![],'type':a0_0x5c15ad(0x17e),'description':a0_0x5c15ad(0x17c),'example':a0_0x5c15ad(0x162)},{'name':'uniques','required':![],'type':a0_0x5c15ad(0x17e),'description':a0_0x5c15ad(0x17f),'example':'[[\x22category_code\x22],\x20[\x22tenant_id\x22,\x20\x22category_code\x22]]'},{'name':'checks','required':![],'type':a0_0x5c15ad(0x17e),'description':'CHECK\x20constraints.\x20Each\x20entry\x20uses\x20operator-as-key\x20shape:\x20{\x20name?,\x20field,\x20<operator>:\x20<value>\x20}\x20where\x20<operator>\x20is\x20one\x20of\x20checkOperations\x20(in,\x20eq,\x20neq,\x20gt,\x20gte,\x20lt,\x20lte).\x20The\x20internal\x20IR\x20shape\x20after\x20ir-builder\x20normalization\x20is\x20{\x20name?,\x20field,\x20op,\x20value\x20},\x20but\x20that\x20is\x20NOT\x20the\x20user\x20input\x20format.','example':'[{\x20field:\x20\x22status\x22,\x20in:\x20[\x22active\x22,\x20\x22inactive\x22]\x20},\x20{\x20field:\x20\x22qty\x22,\x20gte:\x200\x20}]'},{'name':a0_0x5c15ad(0x130),'required':![],'type':'object','description':a0_0x5c15ad(0x13e),'example':'{\x20enabled:\x20true,\x20reusable:\x20[{\x20field:\x20\x22category_code\x22,\x20length:\x2050\x20}]\x20}','notes':a0_0x5c15ad(0x160)}],FIELD_TYPES=[{'name':a0_0x5c15ad(0x150),'description':a0_0x5c15ad(0x14f),'requiresModifier':!![],'modifierFormat':a0_0x5c15ad(0x155),'example':a0_0x5c15ad(0x18b),'notes':'Explicit\x20length\x20required\x20for\x20cross-dialect\x20portability.'},{'name':a0_0x5c15ad(0x14d),'description':a0_0x5c15ad(0x14e),'requiresModifier':![],'example':'text'},{'name':a0_0x5c15ad(0x17a),'description':'32-bit\x20signed\x20integer\x20(INT/INTEGER).','requiresModifier':![],'example':a0_0x5c15ad(0x17a)},{'name':a0_0x5c15ad(0x11d),'description':a0_0x5c15ad(0x179),'requiresModifier':![],'example':'bigint'},{'name':a0_0x5c15ad(0x11c),'description':'Fixed-point\x20decimal.\x20Precision\x20and\x20scale\x20required.','requiresModifier':!![],'modifierFormat':a0_0x5c15ad(0x131),'example':'decimal:15,2','notes':a0_0x5c15ad(0x134)},{'name':a0_0x5c15ad(0x16c),'description':a0_0x5c15ad(0x18c),'requiresModifier':![],'example':a0_0x5c15ad(0x16c)},{'name':a0_0x5c15ad(0x16e),'description':'Date\x20only\x20(no\x20time\x20component).','requiresModifier':![],'example':a0_0x5c15ad(0x16e)},{'name':a0_0x5c15ad(0x122),'description':'Date\x20and\x20time\x20(TIMESTAMP).','requiresModifier':![],'example':'timestamp','notes':a0_0x5c15ad(0x14a)},{'name':'uuid','description':a0_0x5c15ad(0x193),'requiresModifier':![],'example':'uuid'},{'name':'json','description':a0_0x5c15ad(0x115),'requiresModifier':![],'example':a0_0x5c15ad(0x11b)}],CONSTRAINTS=[{'name':'pk','kind':'standalone','description':a0_0x5c15ad(0x166),'example':a0_0x5c15ad(0x181)},{'name':a0_0x5c15ad(0x153),'kind':a0_0x5c15ad(0x12a),'description':a0_0x5c15ad(0x178),'example':'string:255\x20notnull'},{'name':a0_0x5c15ad(0x15f),'kind':a0_0x5c15ad(0x12a),'description':a0_0x5c15ad(0x16f),'example':a0_0x5c15ad(0x184)},{'name':'index','kind':'standalone','description':'Single-column\x20non-unique\x20index.','example':'string:64\x20index'},{'name':'autoUpdate','kind':a0_0x5c15ad(0x12a),'deprecated':!![],'description':'DEPRECATED:\x20This\x20modifier\x20no\x20longer\x20has\x20functional\x20effect\x20at\x20the\x20DDL\x20or\x20runtime\x20level.\x20Auto-update\x20for\x20updated_at\x20is\x20handled\x20by\x20the\x20RDF\x20layer\x20(auditColumns\x20convention\x20in\x20BaseModel\x20runtime)\x20based\x20on\x20field\x20naming\x20convention,\x20not\x20by\x20this\x20SDF\x20marker.\x20Existing\x20usage\x20is\x20preserved\x20for\x20backward\x20compatibility\x20but\x20should\x20be\x20removed\x20from\x20new\x20templates.','example':'timestamp','notes':'Engine\x20still\x20parses\x20this\x20token\x20(backward\x20compatibility),\x20but\x20DDL\x20output\x20is\x20identical\x20to\x20plain\x20\x27timestamp\x27.\x20Use\x20\x27timestamp\x27\x20alone.\x20The\x20actual\x20auto-update\x20behavior\x20is\x20documented\x20in\x20the\x20RDF\x20auditColumns\x20catalog\x20(field-validation:catalog).'},{'name':a0_0x5c15ad(0x123),'kind':a0_0x5c15ad(0x14c),'description':a0_0x5c15ad(0x18e),'valueFormat':'default:<literal>\x20|\x20default:\x27<string>\x27\x20|\x20default:<constant>\x20|\x20default:<function>()','example':a0_0x5c15ad(0x114)},{'name':'fk','kind':'value','description':'Foreign\x20key\x20reference.\x20Auto-generates\x20a\x20belongsTo\x20relation\x20entry.','valueFormat':a0_0x5c15ad(0x109),'example':'string:36\x20fk:category.id','notes':a0_0x5c15ad(0x120)}],RELATION_TYPES=[{'name':'belongsTo','description':'Many-to-one.\x20This\x20table\x20holds\x20the\x20FK\x20column\x20referencing\x20the\x20parent\x20table.','requiredFields':[a0_0x5c15ad(0x10a),a0_0x5c15ad(0x149),'references'],'optionalFields':[a0_0x5c15ad(0x136),a0_0x5c15ad(0x121),'onUpdate'],'example':'{\x20type:\x20\x22belongsTo\x22,\x20localKey:\x20\x22category_id\x22,\x20references:\x20\x22category_id\x22,\x20onDelete:\x20\x22restrict\x22\x20}','notes':a0_0x5c15ad(0x111)},{'name':'hasOne','description':a0_0x5c15ad(0x133),'requiredFields':['type','localKey',a0_0x5c15ad(0x15c)],'optionalFields':[a0_0x5c15ad(0x136),a0_0x5c15ad(0x121),a0_0x5c15ad(0x173)],'example':a0_0x5c15ad(0x12e)},{'name':'hasMany','description':'One-to-many\x20(inverse\x20of\x20belongsTo).\x20Optional\x20inverse\x20declaration\x20on\x20the\x20parent\x20side;\x20does\x20not\x20affect\x20DDL.','requiredFields':['type',a0_0x5c15ad(0x149),'references'],'optionalFields':['target',a0_0x5c15ad(0x121),a0_0x5c15ad(0x173)],'example':a0_0x5c15ad(0x180)}],REFERENTIAL_ACTIONS=[{'name':'cascade','description':'Cascade\x20delete/update\x20to\x20child\x20rows.','appliesTo':[a0_0x5c15ad(0x121),a0_0x5c15ad(0x173)]},{'name':a0_0x5c15ad(0x157),'description':'Reject\x20delete/update\x20when\x20child\x20rows\x20exist.','appliesTo':[a0_0x5c15ad(0x121),'onUpdate']},{'name':a0_0x5c15ad(0x190),'description':'Set\x20FK\x20column\x20to\x20NULL\x20on\x20child\x20rows.','appliesTo':[a0_0x5c15ad(0x121),'onUpdate'],'notes':'FK\x20field\x20must\x20be\x20nullable.'},{'name':a0_0x5c15ad(0x142),'description':a0_0x5c15ad(0x124),'appliesTo':['onDelete','onUpdate']}],CHECK_OPERATIONS=[{'name':'in','description':a0_0x5c15ad(0x182),'valueType':'array','example':'{\x20field:\x20\x22status\x22,\x20in:\x20[\x22active\x22,\x20\x22inactive\x22]\x20}'},{'name':'eq','description':'Equal\x20to.','valueType':'scalar','example':'{\x20field:\x20\x22type\x22,\x20eq:\x20\x22user\x22\x20}'},{'name':a0_0x5c15ad(0x187),'description':'Not\x20equal\x20to.','valueType':a0_0x5c15ad(0x191),'example':'{\x20field:\x20\x22type\x22,\x20neq:\x20\x22system\x22\x20}'},{'name':'gt','description':a0_0x5c15ad(0x15d),'valueType':'numeric','example':'{\x20field:\x20\x22qty\x22,\x20gt:\x200\x20}'},{'name':a0_0x5c15ad(0x14b),'description':'Greater\x20than\x20or\x20equal\x20to.','valueType':'numeric','example':a0_0x5c15ad(0x129)},{'name':'lt','description':a0_0x5c15ad(0x12d),'valueType':'numeric','example':'{\x20field:\x20\x22discount\x22,\x20lt:\x20100\x20}'},{'name':'lte','description':'Less\x20than\x20or\x20equal\x20to.','valueType':'numeric','example':'{\x20field:\x20\x22discount\x22,\x20lte:\x20100\x20}'}],AUDIT_COLUMNS={'description':'Standard\x204-column\x20audit\x20convention\x20for\x20tables\x20managed\x20by\x20RESTForge.\x20The\x20same\x20convention\x20is\x20documented\x20in\x20field-validation:catalog\x20(auditColumns\x20section)\x20for\x20the\x20RDF/backend\x20layer.\x20SDF\x20and\x20RDF\x20stay\x20aligned\x20when\x20both\x20declare\x20these\x204\x20columns.','columns':[{'name':'created_at','shorthand':a0_0x5c15ad(0x186),'nullable':!![],'purpose':a0_0x5c15ad(0x16b)},{'name':'created_by','shorthand':a0_0x5c15ad(0x161),'nullable':!![],'purpose':a0_0x5c15ad(0x125)},{'name':a0_0x5c15ad(0x117),'shorthand':'timestamp','nullable':!![],'purpose':'Last\x20modification\x20timestamp.\x20Auto-update\x20is\x20handled\x20by\x20the\x20RDF\x20runtime\x20(BaseModel\x20auditColumns\x20convention)\x20which\x20injects\x20updated_at\x20=\x20CURRENT_TIMESTAMP\x20into\x20every\x20UPDATE\x20statement\x20based\x20on\x20field\x20naming,\x20not\x20by\x20any\x20SDF\x20marker.\x20Initial\x20INSERT\x20value\x20is\x20also\x20handled\x20by\x20the\x20RDF\x20runtime\x20auditColumns\x20helper.'},{'name':'updated_by','shorthand':a0_0x5c15ad(0x161),'nullable':!![],'purpose':'User\x20identifier\x20of\x20the\x20last\x20modifier.\x20Set\x20by\x20application\x20layer\x20on\x20UPDATE,\x20not\x20by\x20database\x20default.'}],'convention':{'emitInSkeleton':a0_0x5c15ad(0x139),'nullablePolicy':a0_0x5c15ad(0x156),'relationToRdf':'The\x20RDF\x20generator\x20(codegen_create_endpoint)\x20assumes\x20these\x204\x20columns\x20exist\x20when\x20the\x20payload.auditColumns\x20key\x20is\x20absent.\x20See\x20field-validation:catalog\x20auditColumns\x20for\x20the\x20RDF-side\x20behavior.\x20Drift\x20between\x20SDF\x20(missing\x20audit\x20columns)\x20and\x20RDF\x20(assumes\x20audit\x20columns)\x20causes\x20runtime\x20errors\x20when\x20the\x20generated\x20endpoint\x20tries\x20to\x20write\x20created_by/updated_by\x20to\x20a\x20non-existent\x20column.'}},SOFT_DELETE={'description':'Soft-delete\x20contract\x20for\x20tables\x20declared\x20with\x20a\x20softDelete\x20block\x20(see\x20defineModelOptions.softDelete\x20for\x20the\x20block\x20shape).\x20Deleted\x20rows\x20are\x20flagged\x20through\x20three\x20contract\x20columns\x20instead\x20of\x20being\x20physically\x20removed.\x20SDF\x20is\x20the\x20single\x20declaration\x20point:\x20it\x20drives\x20DDL\x20emission\x20(columns,\x20consistency\x20CHECK,\x20partial\x20indexes)\x20and\x20the\x20RDF\x20softDelete\x20block\x20is\x20derived\x20from\x20it\x20during\x20payload\x20generate.','contractColumns':{'description':a0_0x5c15ad(0x176),'columns':[{'name':IS_DELETED_COLUMN,'type':SOFT_DELETE_COLUMN_TYPES[IS_DELETED_COLUMN],'shorthand':a0_0x5c15ad(0x177),'nullable':![],'purpose':a0_0x5c15ad(0x170)},{'name':DELETED_AT_COLUMN,'type':SOFT_DELETE_COLUMN_TYPES[DELETED_AT_COLUMN],'shorthand':a0_0x5c15ad(0x122),'nullable':!![],'purpose':'Deletion\x20timestamp,\x20nullable.\x20NULL\x20while\x20the\x20row\x20is\x20alive.'},{'name':DELETED_BY_COLUMN,'type':SOFT_DELETE_COLUMN_TYPES[DELETED_BY_COLUMN],'shorthand':'string:70','nullable':!![],'purpose':a0_0x5c15ad(0x11a)}],'biconditionalRules':[a0_0x5c15ad(0x140),'enabled\x20=\x20true\x20with\x20any\x20contract\x20column\x20missing:\x20validation\x20ERROR\x20(missing\x20columns\x20are\x20listed).',a0_0x5c15ad(0x167),'Contract\x20column\x20declared\x20with\x20a\x20wrong\x20type:\x20validation\x20ERROR.','Consequence:\x20is_deleted,\x20deleted_at,\x20and\x20deleted_by\x20are\x20reserved\x20names;\x20they\x20cannot\x20be\x20used\x20as\x20ordinary\x20columns\x20in\x20RESTForge-managed\x20tables.']},'reusableRules':{'description':'Soft-delete\x20keeps\x20rows\x20in\x20the\x20table,\x20so\x20UNIQUE\x20constraints\x20still\x20see\x20deleted\x20rows.\x20Columns\x20listed\x20in\x20reusable\x20have\x20their\x20value\x20mutated\x20on\x20delete\x20to\x20\x22{value}##{uuidv7}\x22\x20so\x20the\x20original\x20value\x20can\x20be\x20reused\x20by\x20a\x20new\x20row.','requirements':[a0_0x5c15ad(0x159),a0_0x5c15ad(0x11f),'The\x20field\x20must\x20have\x20a\x20single-column\x20UNIQUE\x20constraint\x20(no\x20UNIQUE,\x20or\x20only\x20composite\x20UNIQUE:\x20ERROR).','length\x20must\x20be\x20a\x20positive\x20integer\x20(base\x20length\x20=\x20maximum\x20user-input\x20length):\x20ERROR\x20otherwise.'],'suffixLength':SOFT_DELETE_SUFFIX_LENGTH,'physicalLengthFormula':'physical\x20length\x20>=\x20base\x20length\x20+\x20'+SOFT_DELETE_SUFFIX_LENGTH,'notes':a0_0x5c15ad(0x188)+SOFT_DELETE_SUFFIX_LENGTH+a0_0x5c15ad(0x143)},'uniqueEligibilityGate':{'description':a0_0x5c15ad(0x10e),'rules':[a0_0x5c15ad(0x13c),a0_0x5c15ad(0x10c)],'suggestion':a0_0x5c15ad(0x147)},'emittedDdl':{'consistencyCheck':{'namePattern':a0_0x5c15ad(0x183)+SOFT_DELETE_CHECK_SUFFIX,'description':a0_0x5c15ad(0x126)+SOFT_DELETE_CHECK_SUFFIX+a0_0x5c15ad(0x18a)+IS_DELETED_COLUMN+a0_0x5c15ad(0x168)+DELETED_AT_COLUMN+a0_0x5c15ad(0x148)+DELETED_BY_COLUMN+'\x20IS\x20NOT\x20NULL)\x20OR\x20('+IS_DELETED_COLUMN+'\x20=\x20FALSE\x20AND\x20'+DELETED_AT_COLUMN+a0_0x5c15ad(0x17b)+DELETED_BY_COLUMN+a0_0x5c15ad(0x119)},'partialIndex':{'description':a0_0x5c15ad(0x12b)+IS_DELETED_COLUMN+'\x20=\x20FALSE.','example':a0_0x5c15ad(0x113)+IS_DELETED_COLUMN+'\x20=\x20FALSE','notes':a0_0x5c15ad(0x144)}},'dialectSupport':{'supported':[SOFT_DELETE_PHASE1_DIALECT],'description':'Phase\x201:\x20PostgreSQL\x20only.\x20On\x20other\x20dialects\x20the\x20softDelete\x20block\x20is\x20not\x20supported\x20(DDL\x20generation\x20fails\x20with\x20a\x20clear\x20error)\x20and\x20soft-delete-named\x20columns\x20get\x20no\x20special\x20treatment\x20during\x20introspect.'},'introspectRoundTrip':a0_0x5c15ad(0x151),'rdfDerivation':a0_0x5c15ad(0x169)},SHORTHAND_SYNTAX={'format':'<type>[:<modifier>]\x20[<constraint>[:<value>]]...','description':a0_0x5c15ad(0x128),'rules':['Type\x20is\x20mandatory\x20at\x20the\x20beginning\x20and\x20must\x20be\x20one\x20of\x20fieldTypes.',a0_0x5c15ad(0x15e),a0_0x5c15ad(0x13f),'Value\x20constraints\x20(default,\x20fk)\x20require\x20constraint:value\x20format.','Default\x20value\x20format\x20depends\x20on\x20type:\x20raw\x20for\x20boolean\x20(default:true),\x20raw\x20for\x20integer\x20(default:0),\x20single-quoted\x20for\x20string\x20(default:\x27value\x27),\x20bare\x20identifier\x20for\x20SQL\x20constants\x20(default:current_date),\x20identifier()\x20for\x20native\x20function\x20calls\x20(default:now()).','Foreign\x20key\x20uses\x20dot\x20notation:\x20fk:<table>.<column>\x20(e.g.,\x20fk:category.id).\x20The\x20parser\x20rejects\x20parentheses\x20syntax.'],'examples':[{'input':'string:36\x20pk','meaning':a0_0x5c15ad(0x13b)},{'input':a0_0x5c15ad(0x10d),'meaning':'VARCHAR(255)\x20NOT\x20NULL'},{'input':a0_0x5c15ad(0x145),'meaning':a0_0x5c15ad(0x137)},{'input':a0_0x5c15ad(0x114),'meaning':'BOOLEAN\x20DEFAULT\x20TRUE'},{'input':a0_0x5c15ad(0x116),'meaning':a0_0x5c15ad(0x12c)},{'input':a0_0x5c15ad(0x186),'meaning':'TIMESTAMP\x20DEFAULT\x20<native_now\x20per\x20dialect>'},{'input':'string:36\x20fk:category.id','meaning':'VARCHAR(36)\x20with\x20FK\x20to\x20category(id),\x20auto\x20belongsTo\x20relation'},{'input':a0_0x5c15ad(0x192),'meaning':'VARCHAR(64)\x20with\x20single-column\x20index'}]},NAMING_RULES={'tableName':{'format':'snake_case','description':a0_0x5c15ad(0x185)},'fieldName':{'format':a0_0x5c15ad(0x13d),'description':'Column\x20name\x20must\x20be\x20snake_case.'},'constraintName':{'format':'<prefix>_<table>_<suffix>','defaultMaxLength':0x1e,'fallbackStrategy':'MD5\x20hash\x208-character\x20suffix\x20when\x20name\x20exceeds\x20maxLength','description':'Constraint\x20names\x20auto-generated\x20with\x20type-specific\x20prefix\x20(pk,\x20fk,\x20idx,\x20uq,\x20ck)\x20and\x20dialect-specific\x20max\x20length.'},'compositeShortName':{'description':a0_0x5c15ad(0x12f)}},DIALECT_SUPPORT=[{'name':a0_0x5c15ad(0x141),'driver':'pg','booleanStorage':a0_0x5c15ad(0x15b)},{'name':a0_0x5c15ad(0x158),'driver':'mysql2','booleanStorage':a0_0x5c15ad(0x18d)},{'name':a0_0x5c15ad(0x132),'driver':'oracledb','booleanStorage':a0_0x5c15ad(0x10b)},{'name':'sqlite','driver':'better-sqlite3','booleanStorage':a0_0x5c15ad(0x10f)}],DBSCHEMA_CATALOG={'schemaVersion':SCHEMA_VERSION,'source':SOURCE,'summary':{'totalDefineModelOptions':DEFINE_MODEL_OPTIONS[a0_0x5c15ad(0x135)],'totalFieldTypes':FIELD_TYPES['length'],'totalConstraints':CONSTRAINTS[a0_0x5c15ad(0x135)],'totalRelationTypes':RELATION_TYPES[a0_0x5c15ad(0x135)],'totalReferentialActions':REFERENTIAL_ACTIONS[a0_0x5c15ad(0x135)],'totalCheckOperations':CHECK_OPERATIONS['length'],'totalAuditColumns':AUDIT_COLUMNS[a0_0x5c15ad(0x110)][a0_0x5c15ad(0x135)],'totalDialects':DIALECT_SUPPORT[a0_0x5c15ad(0x135)]},'defineModelOptions':DEFINE_MODEL_OPTIONS,'fieldTypes':FIELD_TYPES,'constraints':CONSTRAINTS,'relationTypes':RELATION_TYPES,'referentialActions':REFERENTIAL_ACTIONS,'checkOperations':CHECK_OPERATIONS,'auditColumns':AUDIT_COLUMNS,'softDelete':SOFT_DELETE,'shorthandSyntax':SHORTHAND_SYNTAX,'namingRules':NAMING_RULES,'dialectSupport':DIALECT_SUPPORT,'documentationUrl':DOCUMENTATION_URL};module['exports']={'DBSCHEMA_CATALOG':DBSCHEMA_CATALOG,'DEFINE_MODEL_OPTIONS':DEFINE_MODEL_OPTIONS,'FIELD_TYPES':FIELD_TYPES,'CONSTRAINTS':CONSTRAINTS,'RELATION_TYPES':RELATION_TYPES,'REFERENTIAL_ACTIONS':REFERENTIAL_ACTIONS,'CHECK_OPERATIONS':CHECK_OPERATIONS,'AUDIT_COLUMNS':AUDIT_COLUMNS,'SOFT_DELETE':SOFT_DELETE,'SHORTHAND_SYNTAX':SHORTHAND_SYNTAX,'NAMING_RULES':NAMING_RULES,'DIALECT_SUPPORT':DIALECT_SUPPORT};function a0_0xebd9(){const _0x201bad=['DhLWzq','vKfsq0HbuJiGD2L0AcbdsevdsYbJB25ZDhjHAw50','u2LUz2XLlwnVBhvTBIbvtKLrvuuGy29UC3rYywLUDhmGB24GBM9Ulxn0CMLUzYbJB2X1Bw5ZigfYzsbYzwPLy3rLzcbMB3iGDgHLihnHBwuGCMvHC29UicHZDwzMAxGGBxv0yxrPB24GB25SEsbHChbSAwvZihrVihn0CMLUzY90zxH0ks4','C3rYAw5NoJi1nsbUB3rUDwXS','v2HLBIbLBMfIBgvKid0GDhj1zsWGzxzLCNKGvu5juvvfignVBNn0CMfPBNqGB24GDgHLihrHyMXLigLZignOzwnRzwqGzM9YihnVzNqTzgvSzxrLigvSAwDPyMLSAxr5lG','vevyva','y29SDw1UCW','yhjLzMvYzw5JzxnGigLZihrOzsbIyxjLignVBhvTBIbUyw1LigLUihrOzsb0yxjNzxqGDgfIBguUifrHCMDLDcb0ywjSzsbPCYbHDxrVlwrLCML2zwqGzNjVBsb0AguGCMvSyxrPB24GA2v5ig5HBwuSig9Yig92zxjYAwrLihDPDgGGyhrHCMDLDgaU','m09qCKj5zq','q1jfqvrfieLorevyigLKEf92AxnPDg9Yx2nHDgvNB3jPzxnFy2f0zwDVCNLFBMfTzsbptIb2AxnPDg9Yx2nHDgvNB3jPzxmGkgnHDgvNB3j5x25HBwuPifDirvjfia','yM9VBgvHBIbKzwzHDwX0oNrYDwu','sLnptIbJB2X1Bw4GkePtt05cig9UifbVC3rNCMvtuuWSiePtt04GB24GtxLtuuWSienmt0iGB24Gt3jHy2XLks4','C3rYAw5NoJeWmcbKzwzHDwX0oIDWzw5KAw5NjW','DxbKyxrLzf9HDa','mJe3DgLovLbb','ieLtie5vteWPlIbuAgLZigTLzxbZihrOzsb0AhjLzsbJB2X1Bw5ZignVBNnPC3rLBNqGyxqGDgHLigrHDgeGBgv2zwWGCMvNyxjKBgvZCYbVzIb0AguGD3jPDguGCgf0Ac4','rgvSzxrPB24Gywn0B3iGAwrLBNrPzMLLCIWGBNvSBgfIBguUie5vteWGD2HPBguGDgHLihjVDYbPCYbHBgL2zs4','ANnVBG','zgvJAw1HBa','yMLNAw50','BNvSBcbVCIbLBxb0EsbZDhjPBMCGBwvHBNmGzgvMyxvSDcbZy2HLBweU','vgHLigzPzwXKihr5CguGBxvZDcbIzsbZDhjPBMCGB3iGDgv4DcaODMfSDwuGBxv0yxrPB24GCMvXDwLYzxmGysbZDhjPBMCGDhLWztOGrvjst1iGB3rOzxj3AxnLks4','q2fUBM90ignVzxHPC3qGD2L0AcbLEhbSAwnPDcbYzwXHDgLVBIbLBNrYEsbYzwzLCMvUy2LUzYb0AguGC2fTzsbMAwvSzc4','B25ezwXLDgu','DgLTzxn0yw1W','zgvMyxvSDa','rgvMzxiGy29UC3rYywLUDcbJAgvJAYaOC2vTyw50AwnHBgX5ihnPBwLSyxiGDg8GCMvZDhjPy3qGB24GBw9ZDcbKAwfSzwn0CYKU','vxnLCIbPzgvUDgLMAwvYicH1C2vYBMfTzsWGDxnLCL9PzcWGB3iGy29TCg9ZAxrLihrVA2vUksbVzIb0AguGCMvJB3jKignYzwf0B3iUifnLDcbIEsbHChbSAwnHDgLVBIbSyxLLCIbVBIbjtLnfuLqSig5VDcbIEsbKyxrHyMfZzsbKzwzHDwX0lG','rxzLCNKGC29MDc1KzwXLDguGDgfIBguGz2v0CYbHienirunlignVBNn0CMfPBNqGD2L0Acb0AguGzgv0zxjTAw5PC3rPyYbUyw1LignOA188DgfIBgu+xW','mtG3nduWovPoD2T2AG','u3rYAw5NihnOB3j0AgfUzcbMB3iGzMLLBgqGzgvMAw5PDgLVBI4GvhLWzsbYzxf1AxjLzcbHDcbZDgfYDcWGzM9SBg93zwqGyNKGB3b0Aw9UywWGBw9KAwzPzxiGyw5KihnWywnLlxnLCgfYyxrLzcbJB25ZDhjHAw50CY4','EYbMAwvSzdOGiNf0EsiSigD0ztOGmcb9','C3rHBMrHBg9Uzq','tM9UlxvUAxf1zsbPBMrLEgvZig9UihnVzNqTzgvSzxrLihrHyMXLCYbHCMuGzw1PDhrLzcbHCYbqB3n0z3jLu1fmihbHCNrPywWGAw5KzxHLCYb3AxrOifDirvjfia','vKfsq0HbuIGXmdaPierfrKfvtfqGj3bLBMrPBMCN','tgvZCYb0AgfUlG','EYb0ExbLoIaIAgfZt25LiIWGDgfYz2v0oIaIChjVzMLSzsiSigXVy2fSs2v5oIaIDxnLCL9PzciSihjLzMvYzw5Jzxm6icj1C2vYx2LKiIb9','rM9YignVBxbVC2L0zsbPBMrLEgvZl3vUAxf1zxmSig5HBwuGAxmGzgvYAxzLzcbIEsbQB2LUAw5NignVBhvTBNmGD2L0Acb1BMrLCNnJB3jLigfUzcb0CNvUy2f0Aw5NihDOzw4GBMvLzgvKlG','C29MDerLBgv0zq','zgvJAw1HBdO8ChjLy2LZAw9UpIW8C2nHBgu+','B3jHy2XL','t25LlxrVlw9UzsaOAw52zxjZzsbVzIbIzwXVBMDZvg8PlIbpChrPB25HBcbPBNzLCNnLigrLy2XHCMf0Aw9Uig9UihrOzsbWyxjLBNqGC2LKztSGzg9LCYbUB3qGywzMzwn0ieretc4','uhjLy2LZAw9UigfUzcbZy2fSzsbYzxf1AxjLzcbMB3iGy3jVC3mTzgLHBgvJDcbWB3j0ywjPBgL0Es4','BgvUz3rO','DgfYz2v0','revdsu1btcGXnsWYksbot1qGtLvmtcberuzbvuXuida','ChjPBwfYEuTLEq','wwvZiokaLcbKyNnJAgvTytPPBML0igvTAxrZigfSBca0ignVBhvTBNmGyNKGzgvMyxvSDc4GvgfIBgvZihrOyxqGzg8GBM90ig5LzwqGyxvKAxqGkgXVB2T1Ccb0ywjSzxmSihn5C3rLBsb0ywjSzxmPignHBIbTyw51ywXSEsbYzw1VDMuGDgHLC2uGzMLLBgrZigzYB20GDgHLigDLBMvYyxrLzcbZA2vSzxrVBI4','nda0mvDlBvrMBa','vKfsq0HbuIGZnIKGufjjtufswsblrvK','q29TCg9ZAxrLifvosvfvrsbJB25ZDhjHAw50CYbHCMuGCMvQzwn0zwq6ihrOzxKGy2fUBM90igjLigzYzwvKihrOCM91z2GGDMfSDwuGBxv0yxrPB24SihnVihjLlwnYzwf0Aw5NigeGCM93ihDPDgGGDgHLihnHBwuGA2v5igfMDgvYigeGC29MDc1KzwXLDguGD291BgqGDMLVBgf0zsb0AguGy29UC3rYywLUDc4','C25HA2vFy2fZzq','rw5HyMXLCYbZB2z0lwrLBgv0zsbMB3iGDgHLihrHyMXLlIbtAgfWztOGEYbLBMfIBgvKoIbIB29SzwfUlcbYzxvZywjSzt86ifT7igzPzwXKlcbSzw5NDgGGFv0GFs4Gs2v5CYbVDgHLCIb0AgfUigvUywjSzwqGyw5KihjLDxnHyMXLigfYzsbYzwPLy3rLzcbHDcbZy2HLBweGBg9Hzc4Gv2HLBIbLBMfIBgvKlcb0AguGDgHYzwuGy29UDhjHy3qGy29SDw1UCYaOAxnFzgvSzxrLzcWGzgvSzxrLzf9HDcWGzgvSzxrLzf9IEsKGBxvZDcbIzsbKzwnSyxjLzcbPBIbMAwvSzhmUifnLzsb0AguGC29MDerLBgv0zsbZzwn0Aw9UigzVCIb0AguGzNvSBcbJB250CMfJDc4','u3rHBMrHBg9UzsbJB25ZDhjHAw50CYaOCgSSig5VDg51BgWSihvUAxf1zsWGAw5KzxGPihrHA2uGBM8GDMfSDwuUifrOzsbSzwDHy3KGyxv0B1vWzgf0zsb0B2TLBIbPCYbZDgLSBcbWyxjZzwqGzM9YigjHy2T3yxjKignVBxbHDgLIAwXPDhKGyNv0igLZigrLChjLy2f0zwqGyw5KigHHCYbUBYbMDw5JDgLVBMfSigvMzMvJDc4','zw5HyMXLzca9ihrYDwuGD2L0AcbHBgWGDgHYzwuGy29SDw1UCYbKzwnSyxjLzcbHBMqGy29YCMvJDgX5ihr5CgvKoIb2ywXPzc4','Cg9ZDgDYzxm','BM9by3rPB24','lwnOyxjHy3rLCIbZDwzMAxGGAxmGiImJiIaOmIKGkYb1DwLKDJCGkdm2ks4GrxHHBxbSztOGBgvUz3rOoIa1mcbYzxf1AxjLCYb0AguGzMLLBgqGDg8GyMuGzgvJBgfYzwqGyxqGBgvHC3qGC3rYAw5NoJG4oYbHihnOB3j0zxiGzgvJBgfYyxrPB24GzMfPBhmGDMfSAwrHDgLVBIb3AxrOihrOzsbKzwnSyxjLzcbHBMqGCMvXDwLYzwqGBgvUz3rOCYbPBIb0AguGBwvZC2fNzs4','vu5juvvfignVBNn0CMfPBNrZigfYzsbot1qGBwfKzsbWyxj0AwfSig9UigfUEsbKAwfSzwn0lIbvBMLXDwvUzxnZigTLzxbZignVDMvYAw5NigrLBgv0zwqGCM93CZSGDMfSDwuGCMv1C2uGAxmGAgfUzgXLzcbIEsb0AguGC3vMzML4ig11Dgf0Aw9UlcbUB3qGyNKGysbWyxj0AwfSihvUAxf1zsbPBMrLEc4','zgvJAw1HBdOXnsWYig5VDg51BgWGzgvMyxvSDdOW','nti0ndi0BuDMBwPl','vgHLigvYCM9Yig1LC3nHz2uGC3vNz2vZDhmGDhDVihDHExmGB3v0oIb1C2uGAgfYzc1KzwXLDguGzM9YihbYB2nLC3mTzhjPDMvUihrHyMXLCYaOyMfSyw5JzsWGBgvKz2vYlcbZBMfWC2HVDcWGCgvYAw9KlwnSB3nLksWGB3iGy2HHBMDLihrOzsbvtKLrvuuGAw50BYbHihnPBMDSzs1JB2X1Bw4GC3rYAw5Nigj1C2LUzxnZignVzguU','ieLtie5pvcbovuXmieforca','Bg9JywXlzxK','rgvMyxvSDcb0Aw1LEM9UzsbIzwHHDMLVCIbPCYbKAwfSzwn0lxnWzwnPzMLJlG','z3rL','DMfSDwu','Dgv4Da','tg9UzY1MB3jTihrLEhqGD2L0Ag91DcbSzw5NDgGGBgLTAxqGkfrfwfqVq0XpqIKU','vMfYAwfIBguTBgvUz3rOihrLEhqUieXLBMD0AcbTB2rPzMLLCIbYzxf1AxjLzc4','C3rYAw5N','C2nOzw1HigLUDhjVC3bLy3qGCMvJB2DUAxPLCYbHignVBxbSzxrLihnVzNqTzgvSzxrLihrHyMXLicH0AhjLzsbJB3jYzwn0BhKGDhLWzwqGy29UDhjHy3qGy29SDw1UCYaRignVBNnPC3rLBMn5ienirunlksbHBMqGD3jPDgvZigjHy2SGC29MDerLBgv0ztOGEYbLBMfIBgvKoIb0CNvLih0GAw4GDgHLigDLBMvYyxrLzcbtreyUifrHyMXLCYb3AxrOigLUy29TCgXLDguGB3iGBM9UlwnVBMzVCM1PBMCGC29MDc1KzwXLDguGy29SDw1UCYbIBg9JAYbPBNrYB3nWzwn0ihDPDgGGyw4GzxjYB3iU','lI4VzgjZy2HLBweTA2L0l3nVzNqTzgvSzxrLlwnVBNn0yw50CW','BM90BNvSBa','mJiZndjgBhPVA1C','C3rYAw5NoJXSzw5NDgG+','qwXSidqGy29SDw1UCYbHCMuGBNvSBgfIBguUifrOzsbJCMvHDgvKx2j5l3vWzgf0zwrFyNKGy29SDw1UCYbTyxKGyMuGzw1WDhKGzM9YihjVD3mGAw5Zzxj0zwqGyNKGC3LZDgvTihnLzwrZlcbTAwDYyxrPB25ZlcbVCIbIyxrJAcbPBxbVCNrZihrOyxqGzg8GBM90igHHDMuGysb1C2vYignVBNrLEhqU','CMvZDhjPy3q','BxLZCwW','vgHLigzPzwXKig11C3qGyMuGzgvJBgfYzwqGAw4GzMLLBgrZicH1BMTUB3DUigzPzwXKoIbfuLjpuIKU','t2jQzwn0ig9MigzPzwXKigrLzMLUAxrPB25ZigLUihnOB3j0AgfUzcbZDhjPBMCGzM9YBwf0lG','BMf0AxzLiejpt0Xfqu4','CMvMzxjLBMnLCW','r3jLyxrLCIb0AgfUlG','tw9KAwzPzxiGAxmGBwfUzgf0B3j5igzVCIb0ExbLicjZDhjPBMCIicHSzw5NDgGPigfUzcaIzgvJAw1HBciGkhbYzwnPC2LVBIXZy2fSzsKU','Dw5PCxvL','ug9ZDgDYzvnrtc1VBMX5igLUifbOyxnLideUifrOzsbsreyGC29MDerLBgv0zsbIBg9JAYbPCYbKzxjPDMvKigzYB20GDgHPCYbtreyGyMXVy2SGzhvYAw5NihbHEwXVywqGz2vUzxjHDguSig5LDMvYihDYAxr0zw4GyNKGAgfUzc4','C3rYAw5NoJeWma','w1SIC3rHDhvZiIWGiMnYzwf0zwrFyxqIxv0','C2nOzw1H','mJj1z21hq3y','mZG4mePmu1PKsG','twfYA3mGzMLLBgqGyxmGChjPBwfYEsbRzxKU','u29MDc1KzwXLDguGy29SDw1UCYbKzwnSyxjLzcb3AgLSzsbLBMfIBgvKigLZig5VDcb0CNvLoIb2ywXPzgf0Aw9UievsuK9slG','id0GvfjvrsbbtKqG','vgHLifjerIbZB2z0rgvSzxrLigjSB2nRigLZigrLCML2zwqGzNjVBsbtreyGzhvYAw5NihbHEwXVywqGz2vUzxjHDguSig5LDMvYihDYAxr0zw4GBwfUDwfSBhKUifrHyMXLCYb3Ag9ZzsbKyxrHyMfZzsbJB2X1Bw5ZigLUy2X1zguGDgHLihnVzNqTzgvSzxrLignVBNrYywn0ig11C3qGyMuGzgvJBgfYzwqGAw4Gu0rgihDPDgGGysb2ywXPzcbZB2z0rgvSzxrLigjSB2nRigzVCIbWyxLSB2fKigDLBMvYyxrLihrVihn1y2nLzwqU','sw50zxiTDgfIBguGCMvSyxrPB25ZicHIzwXVBMDZvg8SigHHC09UzsWGAgfZtwfUEsKU','uMvJB3jKignYzwf0Aw9UihrPBwvZDgfTCc4Gqxv0BY1ZzxqGB24Gsu5trvjuihzPysberuzbvuXuig5VDYGPlIboyxrPDMuGzNvUy3rPB24GDhjHBNnSyxrLCYbWzxiGzgLHBgvJDcaOCg9ZDgDYzxm6ienvuLjftLrFveLnrvnuqu1qlcbTExnXBdOGtK9xkcKSig9YywnSztOGu1LtveLnrvnuqu1qlcbZCwXPDgu6ienvuLjftLrFveLnrvnuqu1qks4','yM9VBgvHBG','rgf0ywjHC2uGC2nOzw1Hig5HBwvZCgfJzsaOBxvSDgKTC2nOzw1HigrHDgfIyxnLks4','zgf0zq','u2LUz2XLlwnVBhvTBIb1BMLXDwuGy29UC3rYywLUDc4','rgvSzxrPB24GzMXHzY4GrgvJBgfYzsbHCYbUB3rUDwXSigrLzMf1Bhq6zMfSC2uU','nduZmdrRtgDvqMW','ntu3nxbkv0rdEa','B25vCgrHDgu','B2jQzwn0','zgjZy2HLBweTy2f0ywXVzW','v2HLBIbLBMfIBgvKid0GDhj1zsWGywXSihrOCMvLignVBhvTBNmGyMvSB3CGtvvtvcbIzsbKzwnSyxjLzcbPBIbMAwvSzhmGD2L0AcbLEgfJDgX5ihrOzxnLigXVz2LJywWGDhLWzxmUifrOzsbYzwXHDgLVBIbIzxr3zwvUihrOzsbIBg9JAYbHBMqGDgHLignVBhvTBNmGAxmGyMLJB25KAxrPB25HBc4','yM9VBgvHBIbUB3rUDwXSigrLzMf1Bhq6zMfSC2u','tK9uie5vteWGy29UC3rYywLUDc4','nJqTyML0ihnPz25LzcbPBNrLz2vYicHcsuDjtLqPlG','Aw50zwDLCG','ieLtie5vteWGqu5eia','tM9UlxvUAxf1zsbPBMrLEgvZlIbfywnOigvUDhj5igLZigfYCMf5ig9MignVBhvTBIbUyw1LCYbVCIbVyMPLy3qGEYbUyw1LlcbJB2X1Bw5Zih0U','ndC0EhLTB29c','yxjYyxK','vw5PCxvLignVBNn0CMfPBNrZicHZAw5NBguGB3iGy29TCg9ZAxrLks4','EYb0ExbLoIaIAgfZtwfUEsiSihrHCMDLDdOGiM9YzgvYx2L0zw0IlcbSB2nHBeTLEtOGiM9YzgvYx2LKiIWGCMvMzxjLBMnLCZOGiM9YzgvYx2LKiIb9','C3rYAw5NoJm2ihbR','vMfSDwuGBxvZDcbIzsbVBMuGB2yGysbSAxn0lG','y2HRxZX0ywjSzt5F','C3rYAw5NoJmYihvUAxf1zq','vgfIBguGBMfTzsbTDxn0igjLigXVD2vYy2fZzsWGzgLNAxrZlcbHBMqGDw5KzxjZy29YzxmGB25SEs4','DgLTzxn0yw1WigrLzMf1Bhq6BM93kcK','BMvX','vgHLia','mZC2ndK2BuHJDLfN','igvUzM9Yy2LUzZOGka','C3rYAw5NoJi1nq','qM9VBgvHBIb2ywX1zsaOBMf0AxzLiejpt0Xfqu4GB24Gug9ZDgDYzvnrtcWGvKfsq0HbuIbVBIbVDgHLCNmPlG','vKfsq0HbuIaOBgL0zxjHBcaIDhj1zsiViMzHBhnLiIK','rgvMyxvSDcb2ywX1zs4Gu2LUz2XLlxf1B3rLzcbMB3iGC3rYAw5NCYWGCMf3igzVCIbUDw1LCMLJl2jVB2XLyw4SigjHCMuGAwrLBNrPzMLLCIbMB3iGu1fmignVBNn0yw50CYWGAwrLBNrPzMLLCIGPigzVCIbUyxrPDMuGzNvUy3rPB24Gy2fSBhmU','zMLLBgrZ','C2v0tNvSBa','C2nHBgfY','C3rYAw5NoJy0igLUzgv4','vvvjrc4GtMf0AxzLifvvsuqGB24Gug9ZDgDYzvnrtcWGvKfsq0HbuIGZnIKGB24GB3rOzxjZlG','mtrcDfvIwKW','zMS6phrHyMXLpI48y29SDw1UpG'];a0_0xebd9=function(){return _0x201bad;};return a0_0xebd9();}
|
|
1
|
+
'use strict';function a0_0x14e4(){const _0x13502a=['BNvTzxjPyW','BNvSBcbVCIbLBxb0EsbZDhjPBMCGBwvHBNmGzgvMyxvSDcbZy2HLBweU','yMvSB25NC1rV','twfUEs10BY1VBMuUifrOAxmGDgfIBguGAg9SzhmGDgHLiezlignVBhvTBIbYzwzLCMvUy2LUzYb0AguGCgfYzw50ihrHyMXLlG','Ahr0Chm6lY9Yzxn0zM9Yz2uUzgv2l2rVy3mVy2XPl3nJAgvTys1KzwzPBML0Aw9U','mtKXmZj0zMTVr3G','id0GrKfmu0uU','C3rYAw5NoJi1nsbUB3rUDwXS','B25vCgrHDgu','yMLNAw50','vgHLigzPzwXKig11C3qGyMuGzgvJBgfYzwqGAw4GzMLLBgrZicH1BMTUB3DUigzPzwXKoIbfuLjpuIKU','id0GrKfmu0u','nJi5ndK5nMLYvxLjAW','ode4nJKWuKDXq0nf','Bg9JywXlzxK','u3rHBMrHBg9UzsbJB25ZDhjHAw50CYaOCgSSig5VDg51BgWSihvUAxf1zsWGAw5KzxGPihrHA2uGBM8GDMfSDwuUifrOzsbSzwDHy3KGyxv0B1vWzgf0zsb0B2TLBIbPCYbZDgLSBcbWyxjZzwqGzM9YigjHy2T3yxjKignVBxbHDgLIAwXPDhKGyNv0igLZigrLChjLy2f0zwqGyw5KigHHCYbUBYbMDw5JDgLVBMfSigvMzMvJDc4','Dw5PCxvLCW','u2LUz2XLlwnVBhvTBIbUB24TDw5PCxvLigLUzgv4lG','C25HA2vFy2fZzq','vxnLCIbPzgvUDgLMAwvYig9MihrOzsbSyxn0ig1VzgLMAwvYlIbtzxqGyNKGyxbWBgLJyxrPB24GBgf5zxiGB24GvvbeqvrflcbUB3qGyNKGzgf0ywjHC2uGzgvMyxvSDc4','CMvMzxjLBMnLCW','u3rYAw5NihnOB3j0AgfUzcbMB3iGzMLLBgqGzgvMAw5PDgLVBI4GvhLWzsbYzxf1AxjLzcbHDcbZDgfYDcWGzM9SBg93zwqGyNKGB3b0Aw9UywWGBw9KAwzPzxiGyw5KihnWywnLlxnLCgfYyxrLzcbJB25ZDhjHAw50CY4','q29SDw1Uig5HBwuGBxvZDcbIzsbZBMfRzv9JyxnLlG','phr5Cgu+wZO8Bw9KAwzPzxi+xsbBpgnVBNn0CMfPBNq+wZO8DMfSDwu+xv0UlI4','BgvUz3rOig11C3qGyMuGysbWB3nPDgL2zsbPBNrLz2vYicHIyxnLigXLBMD0Aca9ig1HEgLTDw0GDxnLCI1PBNb1DcbSzw5NDgGPoIbfuLjpuIbVDgHLCNDPC2uU','y2fZy2fKzq','C3rYAw5NoJeWma','Aw50zwDLCG','zw5HyMXLzca9ihrYDwuGD2L0AcbHBgWGDgHYzwuGy29SDw1UCYbKzwnSyxjLzcbHBMqGy29YCMvJDgX5ihr5CgvKoIb2ywXPzc4','vvvjrc4GtMf0AxzLifvvsuqGB24Gug9ZDgDYzvnrtcWGvKfsq0HbuIGZnIKGB24GB3rOzxjZlG','mtaYmZjYyLzPEeC','u2LUz2XLlwnVBhvTBIb1BMLXDwuGy29UC3rYywLUDc4','vevyva','EYbMAwvSzdOGiNf0EsiSigD0oIaWih0','w1SIy2f0zwDVCNLFy29KzsjDlcbBiNrLBMfUDf9PzciSicjJyxrLz29YEv9JB2rLiL1D','sw50zxiTDgfIBguGCMvSyxrPB25ZicHIzwXVBMDZvg8SigHHC09UzsWGAgfZtwfUEsKU','tgvZCYb0AgfUig9YigvXDwfSihrVlG','revquKvdqvrfrdOGvgHPCYbTB2rPzMLLCIbUBYbSB25NzxiGAgfZigz1BMn0Aw9UywWGzwzMzwn0igf0ihrOzsbereWGB3iGCNvUDgLTzsbSzxzLBc4Gqxv0BY11CgrHDguGzM9YihvWzgf0zwrFyxqGAxmGAgfUzgXLzcbIEsb0AguGuKrgigXHEwvYicHHDwrPDenVBhvTBNmGy29UDMvUDgLVBIbPBIbcyxnLtw9KzwWGCNvUDgLTzsKGyMfZzwqGB24GzMLLBgqGBMfTAw5NignVBNzLBNrPB24Sig5VDcbIEsb0AgLZifnerIbTyxjRzxiUiev4Axn0Aw5NihvZywDLigLZihbYzxnLCNzLzcbMB3iGyMfJA3DHCMqGy29TCgf0AwjPBgL0EsbIDxqGC2HVDwXKigjLihjLBw92zwqGzNjVBsbUzxCGDgvTCgXHDgvZlG','ieLtie5vteWGqu5eia','igvUzM9Yy2LUzZOGka','mtCWofnbAM52yq','EYbMAwvSzdOGiNr5CguIlcbLCtOGiNvZzxiIih0','mZiTyML0ihnPz25LzcbPBNrLz2vYicHjtLqVsu5uruDfuIKU','EYbMAwvSzdOGiMrPC2nVDw50iIWGBhrLoIaXmdaGFq','r3jLyxrLCIb0AgfUlG','y2HRxZX0ywjSzt5F','u2v0iezlignVBhvTBIb0BYbovuXmig9UignOAwXKihjVD3mU','mZC4otG3mfjfs0nctq','C3rYAw5NoJeWmcbKzwzHDwX0oIDWzw5KAw5NjW','C3rYAw5NoJi1nq','EYbPzdOGiNn0CMLUzZOZnIbWAYiSig5HBwu6icjZDhjPBMC6mJu1ig5VDg51BgWIih0','DMfSDwu','rML4zwqTCg9PBNqGzgvJAw1HBc4GuhjLy2LZAw9UigfUzcbZy2fSzsbYzxf1AxjLzc4','rgvMyxvSDcb0Aw1LEM9UzsbIzwHHDMLVCIbPCYbKAwfSzwn0lxnWzwnPzMLJlG','DgLTzxn0yw1WigrLzMf1Bhq6BM93kcK','ugHHC2uGmtOGug9ZDgDYzvnrtcbVBMX5lIbpBIbVDgHLCIbKAwfSzwn0CYb0AguGC29MDerLBgv0zsbIBg9JAYbPCYbUB3qGC3vWCg9YDgvKicHereWGz2vUzxjHDgLVBIbMywLSCYb3AxrOigeGy2XLyxiGzxjYB3iPigfUzcbZB2z0lwrLBgv0zs1Uyw1LzcbJB2X1Bw5ZigDLDcbUBYbZCgvJAwfSihrYzwf0BwvUDcbKDxjPBMCGAw50CM9ZCgvJDc4','zgjZy2HLBweTy2f0ywXVzW','BgvUz3rO','veLnrvnuqu1qierfrKfvtfqGpg5HDgL2zv9UB3CGCgvYigrPywXLy3q+','EYbMAwvSzdOGiNf0EsiSigD0ztOGmcb9','vKfsq0HbuIaOBgL0zxjHBcaIDhj1zsiViMzHBhnLiIK','wwvZiokaLcbKyNnJAgvTytPPBML0igvTAxrZigfSBca0ignVBhvTBNmGyNKGzgvMyxvSDc4GvgfIBgvZihrOyxqGzg8GBM90ig5LzwqGyxvKAxqGkgXVB2T1Ccb0ywjSzxmSihn5C3rLBsb0ywjSzxmPignHBIbTyw51ywXSEsbYzw1VDMuGDgHLC2uGzMLLBgrZigzYB20GDgHLigDLBMvYyxrLzcbZA2vSzxrVBI4','C3rHBMrHBg9Uzq','ms4X','DgLTzxn0yw1W','EYb0ExbLoIaIAgfZt25LiIWGDgfYz2v0oIaIChjVzMLSzsiSigXVy2fSs2v5oIaIDxnLCL9PzciSihjLzMvYzw5Jzxm6icj1C2vYx2LKiIb9','BM9by3rPB24','C3rYAw5N','yxjYyxK','rxzLCNKGC29MDc1KzwXLDguGDgfIBguGz2v0CYbHienirunlignVBNn0CMfPBNqGD2L0Acb0AguGzgv0zxjTAw5PC3rPyYbUyw1LignOA188DgfIBgu+xW','rgvSzxrPB24GzMXHzY4GrgvJBgfYzsbHCYbUB3rUDwXSigrLzMf1Bhq6zMfSC2uU','uMvJB3jKignYzwf0Aw9UihrPBwvZDgfTCc4Gqxv0BY1ZzxqGB24Gsu5trvjuihzPysberuzbvuXuig5VDYGPlIboyxrPDMuGzNvUy3rPB24GDhjHBNnSyxrLCYbWzxiGzgLHBgvJDcaOCg9ZDgDYzxm6ienvuLjftLrFveLnrvnuqu1qlcbTExnXBdOGtK9xkcKSig9YywnSztOGu1LtveLnrvnuqu1qlcbZCwXPDgu6ienvuLjftLrFveLnrvnuqu1qks4','BxLZCwWY','rKSGzMLLBgqGBxvZDcbIzsbUDwXSywjSzs4','zgvJAw1HBdOXnsWY','C3rYAw5NoJCW','zgvMyxvSDdO8BgL0zxjHBd4GFcbKzwzHDwX0oIC8C3rYAw5NpICGFcbKzwzHDwX0oJXJB25ZDgfUDd4GFcbKzwzHDwX0oJXMDw5JDgLVBJ4Okq','mtG3ohHWwwT5qG','qK9ptevbtIberuzbvuXuifrsvuu','rgf0zsbHBMqGDgLTzsaOveLnrvnuqu1qks4','yM9VBgvHBIbUB3rUDwXSigrLzMf1Bhq6zMfSC2u','DxbKyxrLzf9HDa','yM9VBgvHBIbKzwzHDwX0oNrYDwu','vMfYAwfIBguTBgvUz3rOihrLEhqUieXLBMD0AcbTB2rPzMLLCIbYzxf1AxjLzc4','zgvMyxvSDa','phbYzwzPEd5FphrHyMXLpL88C3vMzML4pG','qwXSidqGy29SDw1UCYbHCMuGBNvSBgfIBguUifrOzsbJCMvHDgvKx2j5l3vWzgf0zwrFyNKGy29SDw1UCYbTyxKGyMuGzw1WDhKGzM9YihjVD3mGAw5Zzxj0zwqGyNKGC3LZDgvTihnLzwrZlcbTAwDYyxrPB25ZlcbVCIbIyxrJAcbPBxbVCNrZihrOyxqGzg8GBM90igHHDMuGysb1C2vYignVBNrLEhqU','EYbMAwvSzdOGiNn0yxr1CYiSigLUoIbBiMfJDgL2zsiSicjPBMfJDgL2zsjDih0','q2fZy2fKzsbKzwXLDguVDxbKyxrLihrVignOAwXKihjVD3mU','w1SIC3rHDhvZiIWGiMnYzwf0zwrFyxqIxv0','w3SGzMLLBgq6icjZDgf0DxmIlcbPBJOGwYjHy3rPDMuIlcaIAw5Hy3rPDMuIxsb9lcb7igzPzwXKoIaICxr5iIWGz3rLoIaWih1D','qxv0BY1KzxrLy3rLzcbMCM9TigzPzwXKihnOB3j0AgfUzcaICgSIihDOzw4GBM90ihnWzwnPzMLLzc4','CgH5C2LJywWGBgvUz3rOid49igjHC2uGBgvUz3rOicSG','u29MDc1KzwXLDguGy29UDhjHy3qGzM9YihrHyMXLCYbKzwnSyxjLzcb3AxrOigeGC29MDerLBgv0zsbIBg9JAYaOC2vLigrLzMLUzu1VzgvSt3b0Aw9UCY5ZB2z0rgvSzxrLigzVCIb0AguGyMXVy2SGC2HHCguPlIbezwXLDgvKihjVD3mGyxjLigzSywDNzwqGDgHYB3vNAcb0AhjLzsbJB250CMfJDcbJB2X1Bw5ZigLUC3rLywqGB2yGyMvPBMCGCgH5C2LJywXSEsbYzw1VDMvKlIbtreyGAxmGDgHLihnPBMDSzsbKzwnSyxjHDgLVBIbWB2LUDdOGAxqGzhjPDMvZieretcbLBwLZC2LVBIaOy29SDw1UCYWGy29UC2LZDgvUy3KGq0Hfq0SSihbHCNrPywWGAw5KzxHLCYKGyw5KihrOzsbsreyGC29MDerLBgv0zsbIBg9JAYbPCYbKzxjPDMvKigzYB20GAxqGzhvYAw5NihbHEwXVywqGz2vUzxjHDguU','tM9UlxvUAxf1zsbPBMrLEgvZig9UihnVzNqTzgvSzxrLihrHyMXLCYbHCMuGzw1PDhrLzcbHCYbqB3n0z3jLu1fmihbHCNrPywWGAw5KzxHLCYb3AxrOifDirvjfia','y2HLy2TZ','u2LUz2XLlwnVBhvTBIbvtKLrvuuGy29UC3rYywLUDhmGB24GBM9Ulxn0CMLUzYbJB2X1Bw5ZigfYzsbYzwPLy3rLzcbMB3iGDgHLihnHBwuGCMvHC29UicHZDwzMAxGGBxv0yxrPB24GB25SEsbHChbSAwvZihrVihn0CMLUzY90zxH0ks4','B2jQzwn0','rM9YignVBxbVC2L0zsbPBMrLEgvZl3vUAxf1zxmSig5HBwuGAxmGzgvYAxzLzcbIEsbQB2LUAw5NignVBhvTBNmGD2L0Acb1BMrLCNnJB3jLigfUzcb0CNvUy2f0Aw5NihDOzw4GBMvLzgvKlG','zgf0zq','mZncEejytue','DhLWzq','otyXmfrkrw9fCq','mJe5DfDLr3jg','EYbMAwvSzdOGiNr5CguIlcbUzxe6icjZExn0zw0Iih0','rxf1ywWGDg8U','Aw5KzxG','vgHLigzPzwXKihr5CguGBxvZDcbIzsbZDhjPBMCGB3iGDgv4DcaODMfSDwuGBxv0yxrPB24GCMvXDwLYzxmGysbZDhjPBMCGDhLWztOGrvjst1iGB3rOzxj3AxnLks4','mZiXnJG4vLbstgzr','lI4VzgjZy2HLBweTA2L0l3nVzNqTzgvSzxrLlwnVBNn0yw50CW','Aw5KzxHLCW','EYb0ExbLoIaIyMvSB25NC1rViIWGBg9JywXlzxK6icjJyxrLz29YEv9PzciSihjLzMvYzw5Jzxm6icjJyxrLz29YEv9PzciSig9UrgvSzxrLoIaICMvZDhjPy3qIih0','t2jQzwn0ig9MigzPzwXKigrLzMLUAxrPB25ZigLUihnOB3j0AgfUzcbZDhjPBMCGzM9YBwf0lG','vw5PCxvLignVBNn0CMfPBNrZicHZAw5NBguGB3iGy29TCg9ZAxrLks4','BhrL','B25ezwXLDgu','tw9KAwzPzxiGAxmGBwfUzgf0B3j5igzVCIb0ExbLicjZDhjPBMCIicHSzw5NDgGPigfUzcaIzgvJAw1HBciGkhbYzwnPC2LVBIXZy2fSzsKU','C3rYAw5NoJm2igzRoMnHDgvNB3j5lMLK','C29MDerLBgv0zq','BMf0AxzLiejpt0Xfqu4','ANnVBG','q29UC2vXDwvUy2u6igLZx2rLBgv0zwqSigrLBgv0zwrFyxqSigfUzcbKzwXLDgvKx2j5igfYzsbYzxnLCNzLzcbUyw1LCZSGDgHLEsbJyw5UB3qGyMuGDxnLzcbHCYbVCMrPBMfYEsbJB2X1Bw5ZigLUifjfu1rgB3jNzs1Tyw5Hz2vKihrHyMXLCY4','DgfYz2v0','q0Hfq0SGy29UC3rYywLUDhmUievHy2GGzw50CNKGDxnLCYbVCgvYyxrVCI1HCY1RzxKGC2HHCgu6ihSGBMfTzt8SigzPzwXKlca8B3bLCMf0B3i+oIa8DMfSDwu+ih0GD2HLCMuGpg9WzxjHDg9YpIbPCYbVBMuGB2yGy2HLy2TpCgvYyxrPB25ZicHPBIWGzxeSig5LCsWGz3qSigD0zsWGBhqSigX0zsKUifrOzsbPBNrLCM5HBcbjuIbZAgfWzsbHzNrLCIbPCI1IDwLSzgvYig5VCM1HBgL6yxrPB24GAxmGEYbUyw1LpYWGzMLLBgqSig9Wlcb2ywX1zsb9lcbIDxqGDgHHDcbPCYbot1qGDgHLihvZzxiGAw5WDxqGzM9YBwf0lG','twfYA3mGzMLLBgqGyxmGChjPBwfYEsbRzxKU','C3fSAxrL'];a0_0x14e4=function(){return _0x13502a;};return a0_0x14e4();}const a0_0x506501=a0_0x2922;function a0_0x2922(_0x26164e,_0x462a5f){_0x26164e=_0x26164e-0xd1;const _0x14e42b=a0_0x14e4();let _0x292245=_0x14e42b[_0x26164e];if(a0_0x2922['xMmsTi']===undefined){var _0x198415=function(_0x167c60){const _0x329dcf='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x1ad54e='',_0x456736='';for(let _0x4b51f8=0x0,_0x4741ee,_0x7147ce,_0x44c11d=0x0;_0x7147ce=_0x167c60['charAt'](_0x44c11d++);~_0x7147ce&&(_0x4741ee=_0x4b51f8%0x4?_0x4741ee*0x40+_0x7147ce:_0x7147ce,_0x4b51f8++%0x4)?_0x1ad54e+=String['fromCharCode'](0xff&_0x4741ee>>(-0x2*_0x4b51f8&0x6)):0x0){_0x7147ce=_0x329dcf['indexOf'](_0x7147ce);}for(let _0x5ee70d=0x0,_0x134d6c=_0x1ad54e['length'];_0x5ee70d<_0x134d6c;_0x5ee70d++){_0x456736+='%'+('00'+_0x1ad54e['charCodeAt'](_0x5ee70d)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x456736);};a0_0x2922['aJdMKS']=_0x198415,a0_0x2922['ZEtsUq']={},a0_0x2922['xMmsTi']=!![];}const _0x2e5a67=_0x14e42b[0x0],_0xd9c7fc=_0x26164e+_0x2e5a67,_0x1e653d=a0_0x2922['ZEtsUq'][_0xd9c7fc];return!_0x1e653d?(_0x292245=a0_0x2922['aJdMKS'](_0x292245),a0_0x2922['ZEtsUq'][_0xd9c7fc]=_0x292245):_0x292245=_0x1e653d,_0x292245;}(function(_0x304ded,_0x37f9b7){const _0x26bb0d=a0_0x2922,_0x10e79b=_0x304ded();while(!![]){try{const _0x345cd6=parseInt(_0x26bb0d(0x142))/0x1+parseInt(_0x26bb0d(0xe3))/0x2+-parseInt(_0x26bb0d(0x13d))/0x3*(-parseInt(_0x26bb0d(0xdb))/0x4)+-parseInt(_0x26bb0d(0x13c))/0x5*(parseInt(_0x26bb0d(0x123))/0x6)+parseInt(_0x26bb0d(0xfe))/0x7*(parseInt(_0x26bb0d(0xf4))/0x8)+parseInt(_0x26bb0d(0xe2))/0x9+parseInt(_0x26bb0d(0x105))/0xa*(-parseInt(_0x26bb0d(0x13a))/0xb);if(_0x345cd6===_0x37f9b7)break;else _0x10e79b['push'](_0x10e79b['shift']());}catch(_0x5f001d){_0x10e79b['push'](_0x10e79b['shift']());}}}(a0_0x14e4,0x5638d));const {IS_DELETED_COLUMN,DELETED_AT_COLUMN,DELETED_BY_COLUMN,SOFT_DELETE_COLUMN_TYPES,SOFT_DELETE_SUFFIX_LENGTH,SOFT_DELETE_CHECK_SUFFIX,SOFT_DELETE_PHASE1_DIALECT}=require(a0_0x506501(0x143)),SCHEMA_VERSION=a0_0x506501(0x115),SOURCE=a0_0x506501(0x10e),DOCUMENTATION_URL=a0_0x506501(0xda),DEFINE_MODEL_OPTIONS=[{'name':'schema','required':![],'type':'string|null','description':'Database\x20schema\x20namespace\x20(multi-schema\x20database).','notes':a0_0x506501(0xd7)},{'name':'fields','required':!![],'type':'object','description':a0_0x506501(0x146),'example':a0_0x506501(0x108)},{'name':'primaryKey','required':![],'type':'string|array','description':'Override\x20primary\x20key.\x20Single\x20field\x20name\x20or\x20composite\x20array.','notes':a0_0x506501(0x131)},{'name':'relations','required':![],'type':a0_0x506501(0x137),'description':a0_0x506501(0xf9),'example':'{\x20category:\x20{\x20type:\x20\x22belongsTo\x22,\x20references:\x20\x22category(id)\x22\x20}\x20}'},{'name':a0_0x506501(0x144),'required':![],'type':a0_0x506501(0x11a),'description':'Non-unique\x20indexes.\x20Each\x20entry\x20is\x20array\x20of\x20column\x20names\x20or\x20object\x20{\x20name,\x20columns\x20}.','example':a0_0x506501(0x12f)},{'name':a0_0x506501(0xe6),'required':![],'type':a0_0x506501(0x11a),'description':a0_0x506501(0x147),'example':a0_0x506501(0xf8)},{'name':a0_0x506501(0x135),'required':![],'type':'array','description':a0_0x506501(0xd3),'example':a0_0x506501(0x130)},{'name':a0_0x506501(0x14c),'required':![],'type':'object','description':'Enables\x20soft-delete\x20for\x20the\x20table.\x20Shape:\x20{\x20enabled:\x20boolean,\x20reusable?:\x20[{\x20field,\x20length\x20}]\x20}.\x20Keys\x20other\x20than\x20enabled\x20and\x20reusable\x20are\x20rejected\x20at\x20schema\x20load.\x20When\x20enabled,\x20the\x20three\x20contract\x20columns\x20(is_deleted,\x20deleted_at,\x20deleted_by)\x20must\x20be\x20declared\x20in\x20fields.\x20See\x20the\x20softDelete\x20section\x20for\x20the\x20full\x20contract.','example':'{\x20enabled:\x20true,\x20reusable:\x20[{\x20field:\x20\x22category_code\x22,\x20length:\x2050\x20}]\x20}','notes':'PostgreSQL-only\x20in\x20Phase\x201.\x20The\x20RDF\x20softDelete\x20block\x20is\x20derived\x20from\x20this\x20SDF\x20block\x20during\x20payload\x20generate,\x20never\x20written\x20by\x20hand.'}],FIELD_TYPES=[{'name':a0_0x506501(0x119),'description':a0_0x506501(0x129),'requiresModifier':!![],'modifierFormat':'string:<length>','example':a0_0x506501(0x107),'notes':'Explicit\x20length\x20required\x20for\x20cross-dialect\x20portability.'},{'name':'text','description':'Long-form\x20text\x20without\x20length\x20limit\x20(TEXT/CLOB).','requiresModifier':![],'example':'text'},{'name':a0_0x506501(0xf1),'description':a0_0x506501(0x100),'requiresModifier':![],'example':a0_0x506501(0xf1)},{'name':a0_0x506501(0xdf),'description':'64-bit\x20signed\x20integer\x20(BIGINT).','requiresModifier':![],'example':a0_0x506501(0xdf)},{'name':'decimal','description':a0_0x506501(0x10a),'requiresModifier':!![],'modifierFormat':'decimal:<precision>,<scale>','example':a0_0x506501(0x120),'notes':'Precision\x20and\x20scale\x20required\x20for\x20cross-dialect\x20portability.'},{'name':'boolean','description':'Boolean\x20value\x20(native\x20BOOLEAN\x20on\x20PostgreSQL,\x20VARCHAR\x20on\x20others).','requiresModifier':![],'example':'boolean'},{'name':a0_0x506501(0x139),'description':'Date\x20only\x20(no\x20time\x20component).','requiresModifier':![],'example':'date'},{'name':'timestamp','description':a0_0x506501(0x125),'requiresModifier':![],'example':'timestamp','notes':a0_0x506501(0x10b)},{'name':'uuid','description':a0_0x506501(0xf3),'requiresModifier':![],'example':'uuid'},{'name':'json','description':'JSON\x20column\x20(JSONB\x20on\x20PostgreSQL,\x20JSON\x20on\x20MySQL,\x20CLOB\x20on\x20Oracle).','requiresModifier':![],'example':a0_0x506501(0x14e)}],CONSTRAINTS=[{'name':'pk','kind':a0_0x506501(0x114),'description':a0_0x506501(0xd4),'example':'string:36\x20pk'},{'name':'notnull','kind':a0_0x506501(0x114),'description':'NOT\x20NULL\x20constraint.','example':a0_0x506501(0xdd)},{'name':'unique','kind':a0_0x506501(0x114),'description':a0_0x506501(0xf5),'example':'string:32\x20unique'},{'name':a0_0x506501(0x140),'kind':'standalone','description':a0_0x506501(0xe7),'example':'string:64\x20index'},{'name':'autoUpdate','kind':a0_0x506501(0x114),'deprecated':!![],'description':a0_0x506501(0xfb),'example':a0_0x506501(0x116),'notes':'Engine\x20still\x20parses\x20this\x20token\x20(backward\x20compatibility),\x20but\x20DDL\x20output\x20is\x20identical\x20to\x20plain\x20\x27timestamp\x27.\x20Use\x20\x27timestamp\x27\x20alone.\x20The\x20actual\x20auto-update\x20behavior\x20is\x20documented\x20in\x20the\x20RDF\x20auditColumns\x20catalog\x20(field-validation:catalog).'},{'name':a0_0x506501(0x12a),'kind':'value','description':'Default\x20value.\x20Single-quoted\x20for\x20strings,\x20raw\x20for\x20numeric/boolean,\x20bare\x20identifier\x20for\x20SQL\x20constants,\x20identifier()\x20for\x20native\x20function\x20calls.','valueFormat':a0_0x506501(0x122),'example':a0_0x506501(0x128)},{'name':'fk','kind':a0_0x506501(0x109),'description':'Foreign\x20key\x20reference.\x20Auto-generates\x20a\x20belongsTo\x20relation\x20entry.','valueFormat':'fk:<table>.<column>','example':a0_0x506501(0x14b),'notes':'Cannot\x20coexist\x20with\x20explicit\x20relation\x20entry\x20referencing\x20the\x20same\x20field.'}],RELATION_TYPES=[{'name':a0_0x506501(0xd8),'description':a0_0x506501(0xd9),'requiredFields':[a0_0x506501(0x13b),a0_0x506501(0xe4),'references'],'optionalFields':[a0_0x506501(0xd2),a0_0x506501(0x149),'onUpdate'],'example':a0_0x506501(0x145),'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':'One-to-one\x20(inverse\x20of\x20belongsTo).\x20Optional\x20inverse\x20declaration\x20on\x20the\x20parent\x20side;\x20does\x20not\x20affect\x20DDL.','requiredFields':[a0_0x506501(0x13b),'localKey',a0_0x506501(0xea)],'optionalFields':[a0_0x506501(0xd2),'onDelete','onUpdate'],'example':a0_0x506501(0x117)},{'name':'hasMany','description':'One-to-many\x20(inverse\x20of\x20belongsTo).\x20Optional\x20inverse\x20declaration\x20on\x20the\x20parent\x20side;\x20does\x20not\x20affect\x20DDL.','requiredFields':['type','localKey',a0_0x506501(0xea)],'optionalFields':['target',a0_0x506501(0x149),a0_0x506501(0xde)],'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_0x506501(0xef),'description':a0_0x506501(0x12e),'appliesTo':[a0_0x506501(0x149),'onUpdate']},{'name':'restrict','description':'Reject\x20delete/update\x20when\x20child\x20rows\x20exist.','appliesTo':[a0_0x506501(0x149),'onUpdate']},{'name':'setNull','description':a0_0x506501(0x104),'appliesTo':['onDelete','onUpdate'],'notes':a0_0x506501(0x11f)},{'name':a0_0x506501(0x118),'description':'Defer\x20constraint\x20check\x20(semantically\x20similar\x20to\x20restrict\x20on\x20most\x20dialects).','appliesTo':[a0_0x506501(0x149),'onUpdate']}],CHECK_OPERATIONS=[{'name':'in','description':'Value\x20must\x20be\x20one\x20of\x20a\x20list.','valueType':a0_0x506501(0x11a),'example':a0_0x506501(0x12d)},{'name':'eq','description':a0_0x506501(0x13f),'valueType':'scalar','example':a0_0x506501(0xff)},{'name':'neq','description':'Not\x20equal\x20to.','valueType':'scalar','example':a0_0x506501(0x13e)},{'name':'gt','description':a0_0x506501(0x102),'valueType':'numeric','example':a0_0x506501(0xf7)},{'name':'gte','description':'Greater\x20than\x20or\x20equal\x20to.','valueType':a0_0x506501(0xd6),'example':a0_0x506501(0x111)},{'name':'lt','description':'Less\x20than.','valueType':'numeric','example':'{\x20field:\x20\x22discount\x22,\x20lt:\x20100\x20}'},{'name':a0_0x506501(0x148),'description':a0_0x506501(0xfa),'valueType':'numeric','example':a0_0x506501(0x101)}],AUDIT_COLUMNS={'description':'Standard\x204-column\x20audit\x20convention\x20for\x20tables\x20managed\x20by\x20RESTForge.\x20The\x20same\x20convention\x20is\x20documented\x20in\x20field-validation:catalog\x20(auditColumns\x20section)\x20for\x20the\x20RDF/backend\x20layer.\x20SDF\x20and\x20RDF\x20stay\x20aligned\x20when\x20both\x20declare\x20these\x204\x20columns.','columns':[{'name':'created_at','shorthand':a0_0x506501(0x10c),'nullable':!![],'purpose':a0_0x506501(0x11d)},{'name':'created_by','shorthand':a0_0x506501(0xf0),'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_0x506501(0x127),'shorthand':'timestamp','nullable':!![],'purpose':'Last\x20modification\x20timestamp.\x20Auto-update\x20is\x20handled\x20by\x20the\x20RDF\x20runtime\x20(BaseModel\x20auditColumns\x20convention)\x20which\x20injects\x20updated_at\x20=\x20CURRENT_TIMESTAMP\x20into\x20every\x20UPDATE\x20statement\x20based\x20on\x20field\x20naming,\x20not\x20by\x20any\x20SDF\x20marker.\x20Initial\x20INSERT\x20value\x20is\x20also\x20handled\x20by\x20the\x20RDF\x20runtime\x20auditColumns\x20helper.'},{'name':'updated_by','shorthand':'string:100','nullable':!![],'purpose':a0_0x506501(0xe9)}],'convention':{'emitInSkeleton':a0_0x506501(0x113),'nullablePolicy':a0_0x506501(0x12c),'relationToRdf':'The\x20RDF\x20generator\x20(codegen_create_endpoint)\x20assumes\x20these\x204\x20columns\x20exist\x20when\x20the\x20payload.auditColumns\x20key\x20is\x20absent.\x20See\x20field-validation:catalog\x20auditColumns\x20for\x20the\x20RDF-side\x20behavior.\x20Drift\x20between\x20SDF\x20(missing\x20audit\x20columns)\x20and\x20RDF\x20(assumes\x20audit\x20columns)\x20causes\x20runtime\x20errors\x20when\x20the\x20generated\x20endpoint\x20tries\x20to\x20write\x20created_by/updated_by\x20to\x20a\x20non-existent\x20column.'}},SOFT_DELETE={'description':a0_0x506501(0x133),'contractColumns':{'description':'When\x20enabled\x20=\x20true,\x20all\x20three\x20columns\x20below\x20MUST\x20be\x20declared\x20in\x20fields\x20with\x20exactly\x20these\x20logical\x20types.\x20The\x20relation\x20between\x20the\x20block\x20and\x20the\x20columns\x20is\x20biconditional.','columns':[{'name':IS_DELETED_COLUMN,'type':SOFT_DELETE_COLUMN_TYPES[IS_DELETED_COLUMN],'shorthand':a0_0x506501(0x126),'nullable':![],'purpose':a0_0x506501(0x11c)},{'name':DELETED_AT_COLUMN,'type':SOFT_DELETE_COLUMN_TYPES[DELETED_AT_COLUMN],'shorthand':'timestamp','nullable':!![],'purpose':'Deletion\x20timestamp,\x20nullable.\x20NULL\x20while\x20the\x20row\x20is\x20alive.'},{'name':DELETED_BY_COLUMN,'type':SOFT_DELETE_COLUMN_TYPES[DELETED_BY_COLUMN],'shorthand':a0_0x506501(0x121),'nullable':!![],'purpose':'Deletion\x20actor\x20identifier,\x20nullable.\x20NULL\x20while\x20the\x20row\x20is\x20alive.'}],'biconditionalRules':[a0_0x506501(0xf2),'enabled\x20=\x20true\x20with\x20any\x20contract\x20column\x20missing:\x20validation\x20ERROR\x20(missing\x20columns\x20are\x20listed).','Soft-delete\x20columns\x20declared\x20while\x20enabled\x20is\x20not\x20true:\x20validation\x20ERROR.','Contract\x20column\x20declared\x20with\x20a\x20wrong\x20type:\x20validation\x20ERROR.',a0_0x506501(0xd1)]},'reusableRules':{'description':'Soft-delete\x20keeps\x20rows\x20in\x20the\x20table,\x20so\x20UNIQUE\x20constraints\x20still\x20see\x20deleted\x20rows.\x20Columns\x20listed\x20in\x20reusable\x20have\x20their\x20value\x20mutated\x20on\x20delete\x20to\x20\x22{value}##{uuidv7}\x22\x20so\x20the\x20original\x20value\x20can\x20be\x20reused\x20by\x20a\x20new\x20row.','requirements':[a0_0x506501(0xe0),a0_0x506501(0x141),'The\x20field\x20must\x20have\x20a\x20single-column\x20UNIQUE\x20constraint\x20(no\x20UNIQUE,\x20or\x20only\x20composite\x20UNIQUE:\x20ERROR).',a0_0x506501(0xee)],'suffixLength':SOFT_DELETE_SUFFIX_LENGTH,'physicalLengthFormula':a0_0x506501(0x132)+SOFT_DELETE_SUFFIX_LENGTH,'notes':'The\x20'+SOFT_DELETE_SUFFIX_LENGTH+'-character\x20suffix\x20is\x20\x22##\x22\x20(2)\x20+\x20uuidv7\x20(36).\x20Example:\x20length:\x2050\x20requires\x20the\x20field\x20to\x20be\x20declared\x20at\x20least\x20string:88;\x20a\x20shorter\x20declaration\x20fails\x20validation\x20with\x20the\x20declared\x20and\x20required\x20lengths\x20in\x20the\x20message.'},'uniqueEligibilityGate':{'description':'When\x20enabled\x20=\x20true,\x20every\x20UNIQUE\x20constraint\x20on\x20the\x20table\x20is\x20checked\x20for\x20soft-delete\x20eligibility.','rules':['Composite\x20UNIQUE\x20constraints\x20are\x20rejected:\x20they\x20cannot\x20be\x20freed\x20through\x20value\x20mutation,\x20so\x20re-creating\x20a\x20row\x20with\x20the\x20same\x20key\x20after\x20a\x20soft-delete\x20would\x20violate\x20the\x20constraint.',a0_0x506501(0x136)],'suggestion':'The\x20error\x20message\x20suggests\x20two\x20ways\x20out:\x20use\x20hard-delete\x20for\x20process-driven\x20tables\x20(balance,\x20ledger,\x20snapshot,\x20period-close),\x20or\x20change\x20the\x20UNIQUE\x20into\x20a\x20single-column\x20string\x20business\x20code.'},'emittedDdl':{'consistencyCheck':{'namePattern':a0_0x506501(0x103)+SOFT_DELETE_CHECK_SUFFIX,'description':a0_0x506501(0x11b)+SOFT_DELETE_CHECK_SUFFIX+a0_0x506501(0xfd)+IS_DELETED_COLUMN+'\x20=\x20TRUE\x20AND\x20'+DELETED_AT_COLUMN+'\x20IS\x20NOT\x20NULL\x20AND\x20'+DELETED_BY_COLUMN+'\x20IS\x20NOT\x20NULL)\x20OR\x20('+IS_DELETED_COLUMN+'\x20=\x20FALSE\x20AND\x20'+DELETED_AT_COLUMN+a0_0x506501(0xfc)+DELETED_BY_COLUMN+'\x20IS\x20NULL).\x20This\x20keeps\x20the\x20three\x20columns\x20consistent\x20at\x20the\x20data\x20level\x20regardless\x20of\x20the\x20write\x20path.'},'partialIndex':{'description':a0_0x506501(0x134)+IS_DELETED_COLUMN+a0_0x506501(0xdc),'example':'CREATE\x20INDEX\x20idx_visitor_categories_category_name\x20ON\x20visitor_categories\x20(category_name)\x20WHERE\x20'+IS_DELETED_COLUMN+a0_0x506501(0xe1),'notes':'UNIQUE\x20constraints\x20are\x20NOT\x20made\x20partial\x20on\x20any\x20dialect.\x20Uniqueness\x20keeps\x20covering\x20deleted\x20rows;\x20value\x20reuse\x20is\x20handled\x20by\x20the\x20suffix\x20mutation,\x20not\x20by\x20a\x20partial\x20unique\x20index.'}},'dialectSupport':{'supported':[SOFT_DELETE_PHASE1_DIALECT],'description':a0_0x506501(0x10d)},'introspectRoundTrip':'schema\x20introspect\x20recognizes\x20a\x20complete\x20soft-delete\x20table\x20(three\x20correctly\x20typed\x20contract\x20columns\x20+\x20consistency\x20CHECK)\x20and\x20writes\x20back\x20softDelete:\x20{\x20enabled:\x20true\x20}\x20in\x20the\x20generated\x20SDF.\x20Tables\x20with\x20incomplete\x20or\x20non-conforming\x20soft-delete\x20columns\x20block\x20introspect\x20with\x20an\x20error.','rdfDerivation':'The\x20RDF\x20softDelete\x20block\x20is\x20derived\x20from\x20SDF\x20during\x20payload\x20generate,\x20never\x20written\x20manually.\x20Tables\x20whose\x20database\x20columns\x20include\x20the\x20soft-delete\x20contract\x20must\x20be\x20declared\x20in\x20SDF\x20with\x20a\x20valid\x20softDelete\x20block\x20for\x20payload\x20generate\x20to\x20succeed.'},SHORTHAND_SYNTAX={'format':a0_0x506501(0xed),'description':a0_0x506501(0xeb),'rules':['Type\x20is\x20mandatory\x20at\x20the\x20beginning\x20and\x20must\x20be\x20one\x20of\x20fieldTypes.',a0_0x506501(0x14a),a0_0x506501(0xe5),'Value\x20constraints\x20(default,\x20fk)\x20require\x20constraint:value\x20format.','Default\x20value\x20format\x20depends\x20on\x20type:\x20raw\x20for\x20boolean\x20(default:true),\x20raw\x20for\x20integer\x20(default:0),\x20single-quoted\x20for\x20string\x20(default:\x27value\x27),\x20bare\x20identifier\x20for\x20SQL\x20constants\x20(default:current_date),\x20identifier()\x20for\x20native\x20function\x20calls\x20(default:now()).','Foreign\x20key\x20uses\x20dot\x20notation:\x20fk:<table>.<column>\x20(e.g.,\x20fk:category.id).\x20The\x20parser\x20rejects\x20parentheses\x20syntax.'],'examples':[{'input':'string:36\x20pk','meaning':'VARCHAR(36)\x20PRIMARY\x20KEY'},{'input':'string:255\x20notnull','meaning':'VARCHAR(255)\x20NOT\x20NULL'},{'input':'decimal:15,2\x20notnull\x20default:0','meaning':'DECIMAL(15,2)\x20NOT\x20NULL\x20DEFAULT\x200'},{'input':a0_0x506501(0x128),'meaning':a0_0x506501(0x124)},{'input':a0_0x506501(0x106),'meaning':'VARCHAR(100)\x20DEFAULT\x20\x27pending\x27'},{'input':a0_0x506501(0x10c),'meaning':a0_0x506501(0x110)},{'input':a0_0x506501(0x14b),'meaning':'VARCHAR(36)\x20with\x20FK\x20to\x20category(id),\x20auto\x20belongsTo\x20relation'},{'input':'string:64\x20index','meaning':'VARCHAR(64)\x20with\x20single-column\x20index'}]},NAMING_RULES={'tableName':{'format':'snake_case','description':'Table\x20name\x20must\x20be\x20lowercase,\x20digits,\x20and\x20underscores\x20only.'},'fieldName':{'format':a0_0x506501(0xe8),'description':a0_0x506501(0xec)},'constraintName':{'format':a0_0x506501(0x12b),'defaultMaxLength':0x1e,'fallbackStrategy':'MD5\x20hash\x208-character\x20suffix\x20when\x20name\x20exceeds\x20maxLength','description':'Constraint\x20names\x20auto-generated\x20with\x20type-specific\x20prefix\x20(pk,\x20fk,\x20idx,\x20uq,\x20ck)\x20and\x20dialect-specific\x20max\x20length.'},'compositeShortName':{'description':a0_0x506501(0x138)}},DIALECT_SUPPORT=[{'name':'postgres','driver':'pg','booleanStorage':a0_0x506501(0x14d)},{'name':'mysql','driver':a0_0x506501(0x11e),'booleanStorage':a0_0x506501(0x112)},{'name':'oracle','driver':'oracledb','booleanStorage':'VARCHAR2\x20with\x20CHECK\x20constraint'},{'name':a0_0x506501(0xd5),'driver':'better-sqlite3','booleanStorage':a0_0x506501(0xf6)}],DBSCHEMA_CATALOG={'schemaVersion':SCHEMA_VERSION,'source':SOURCE,'summary':{'totalDefineModelOptions':DEFINE_MODEL_OPTIONS[a0_0x506501(0x10f)],'totalFieldTypes':FIELD_TYPES['length'],'totalConstraints':CONSTRAINTS[a0_0x506501(0x10f)],'totalRelationTypes':RELATION_TYPES['length'],'totalReferentialActions':REFERENTIAL_ACTIONS['length'],'totalCheckOperations':CHECK_OPERATIONS[a0_0x506501(0x10f)],'totalAuditColumns':AUDIT_COLUMNS['columns'][a0_0x506501(0x10f)],'totalDialects':DIALECT_SUPPORT[a0_0x506501(0x10f)]},'defineModelOptions':DEFINE_MODEL_OPTIONS,'fieldTypes':FIELD_TYPES,'constraints':CONSTRAINTS,'relationTypes':RELATION_TYPES,'referentialActions':REFERENTIAL_ACTIONS,'checkOperations':CHECK_OPERATIONS,'auditColumns':AUDIT_COLUMNS,'softDelete':SOFT_DELETE,'shorthandSyntax':SHORTHAND_SYNTAX,'namingRules':NAMING_RULES,'dialectSupport':DIALECT_SUPPORT,'documentationUrl':DOCUMENTATION_URL};module['exports']={'DBSCHEMA_CATALOG':DBSCHEMA_CATALOG,'DEFINE_MODEL_OPTIONS':DEFINE_MODEL_OPTIONS,'FIELD_TYPES':FIELD_TYPES,'CONSTRAINTS':CONSTRAINTS,'RELATION_TYPES':RELATION_TYPES,'REFERENTIAL_ACTIONS':REFERENTIAL_ACTIONS,'CHECK_OPERATIONS':CHECK_OPERATIONS,'AUDIT_COLUMNS':AUDIT_COLUMNS,'SOFT_DELETE':SOFT_DELETE,'SHORTHAND_SYNTAX':SHORTHAND_SYNTAX,'NAMING_RULES':NAMING_RULES,'DIALECT_SUPPORT':DIALECT_SUPPORT};
|