@restforgejs/platform 5.3.5 → 5.3.7
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/bin/restforge-designer-linux +0 -0
- package/bin/restforge-designer.exe +0 -0
- package/build-info.json +2 -2
- package/cli/consumer-deploy.js +1 -1
- package/cli/consumer.js +1 -1
- package/cli/designer.js +3 -0
- package/generators/cli/fast-track.js +105 -34
- 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 +3 -2
- package/scripts/verify-integrity.js +1 -1
- package/server.js +1 -1
- 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
|
@@ -259,7 +259,7 @@ function checkDesigner() {
|
|
|
259
259
|
|
|
260
260
|
// Probe nyata: jalankan `restforge-designer --version`. shell:true memilih
|
|
261
261
|
// cmd.exe (Windows) atau /bin/sh (Linux/macOS) otomatis, termasuk resolusi PATH.
|
|
262
|
-
const r = spawnSync('restforge-designer --version', { shell: true, encoding: 'utf8' });
|
|
262
|
+
const r = spawnSync('npx restforge-designer --version', { shell: true, encoding: 'utf8' });
|
|
263
263
|
const found = !r.error && r.status === 0;
|
|
264
264
|
let version = '';
|
|
265
265
|
if (found && r.stdout) version = r.stdout.trim().split(/\r?\n/)[0];
|
|
@@ -268,12 +268,12 @@ function checkDesigner() {
|
|
|
268
268
|
console.log(leader(' > restforge-designer', 'NOT FOUND', 32));
|
|
269
269
|
console.log('');
|
|
270
270
|
console.log(` ${rule('=', 60)}`);
|
|
271
|
-
console.log(' ERROR: restforge-designer
|
|
271
|
+
console.log(' ERROR: restforge-designer could not be started.');
|
|
272
272
|
console.log(` ${rule('=', 60)}`);
|
|
273
|
-
console.log('
|
|
274
|
-
console.log('
|
|
273
|
+
console.log(' restforge-designer is bundled in @restforgejs/platform.');
|
|
274
|
+
console.log(' If this error appears, reinstall the package:');
|
|
275
275
|
console.log('');
|
|
276
|
-
console.log('
|
|
276
|
+
console.log(' npm install @restforgejs/platform');
|
|
277
277
|
console.log('');
|
|
278
278
|
console.log(' Then re-run this command.');
|
|
279
279
|
console.log('');
|
|
@@ -657,7 +657,7 @@ const ANSI_RE = /\x1b\[[0-9;]*m/g;
|
|
|
657
657
|
* (list hanya membaca metadata plugin built-in).
|
|
658
658
|
*/
|
|
659
659
|
function runDesignerPluginsList() {
|
|
660
|
-
const r = spawnSync('restforge-designer plugins list', { shell: true, encoding: 'utf8' });
|
|
660
|
+
const r = spawnSync('npx restforge-designer plugins list', { shell: true, encoding: 'utf8' });
|
|
661
661
|
if (r.error || r.status !== 0) return null;
|
|
662
662
|
return r.stdout || '';
|
|
663
663
|
}
|
|
@@ -1251,7 +1251,7 @@ function runFrontendPipeline(ctx) {
|
|
|
1251
1251
|
} catch {
|
|
1252
1252
|
// File belum ada (first run) - abaikan.
|
|
1253
1253
|
}
|
|
1254
|
-
run(`restforge-designer generate --payload=payload/${appCode}.json --output=./apps/${ctx.project} ${pluginArg} --overwrite`, frontendDir);
|
|
1254
|
+
run(`npx restforge-designer generate --payload=payload/${appCode}.json --output=./apps/${ctx.project} ${pluginArg} --overwrite`, frontendDir);
|
|
1255
1255
|
}
|
|
1256
1256
|
|
|
1257
1257
|
/**
|
|
@@ -1344,13 +1344,58 @@ function pm2Name(project, kind) {
|
|
|
1344
1344
|
*/
|
|
1345
1345
|
function pm2StartScript(name, scriptPath, cwd) {
|
|
1346
1346
|
spawnSync(`pm2 delete ${name} --silent`, { shell: true, stdio: 'ignore' });
|
|
1347
|
+
// Windows menjalankan .bat via cmd.exe secara otomatis; --interpreter bash
|
|
1348
|
+
// hanya diperlukan untuk .sh di Linux/macOS.
|
|
1349
|
+
const interpreterFlag = process.platform !== 'win32' ? ' --interpreter bash' : '';
|
|
1347
1350
|
const r = spawnSync(
|
|
1348
|
-
`pm2 start "${scriptPath}" --name ${name} --cwd "${cwd}"
|
|
1351
|
+
`pm2 start "${scriptPath}" --name ${name} --cwd "${cwd}"${interpreterFlag}`,
|
|
1349
1352
|
{ shell: true, stdio: 'inherit' }
|
|
1350
1353
|
);
|
|
1351
1354
|
return !r.error && r.status === 0;
|
|
1352
1355
|
}
|
|
1353
1356
|
|
|
1357
|
+
// ---------------------------------------------------------------------------
|
|
1358
|
+
// Pemilihan mode run service (Windows only): terminal baru atau pm2
|
|
1359
|
+
// ---------------------------------------------------------------------------
|
|
1360
|
+
|
|
1361
|
+
const RUN_MODE_MENU = [
|
|
1362
|
+
{ key: 'terminal', text: 'New terminal window' },
|
|
1363
|
+
{ key: 'pm2', text: 'pm2 (process manager)' }
|
|
1364
|
+
];
|
|
1365
|
+
|
|
1366
|
+
/**
|
|
1367
|
+
* Dialog pemilihan mode run: hanya muncul di Windows. Linux selalu pakai pm2.
|
|
1368
|
+
* Mengikuti pola arrowSelect (TTY) / numbered fallback (non-TTY) seperti
|
|
1369
|
+
* selectScope dan selectConfigAction.
|
|
1370
|
+
*
|
|
1371
|
+
* @returns {Promise<'terminal'|'pm2'>}
|
|
1372
|
+
*/
|
|
1373
|
+
async function selectRunMode(prompter) {
|
|
1374
|
+
if (!process.stdin.isTTY) {
|
|
1375
|
+
console.log('');
|
|
1376
|
+
console.log(' How to run the service?');
|
|
1377
|
+
console.log('');
|
|
1378
|
+
RUN_MODE_MENU.forEach((m, i) => console.log(` ${i + 1}. ${m.text}`));
|
|
1379
|
+
console.log('');
|
|
1380
|
+
let choice = null;
|
|
1381
|
+
while (!choice) {
|
|
1382
|
+
const c = (await prompter.ask(' Choice (1-2) [1]: ')).trim() || '1';
|
|
1383
|
+
const idx = parseInt(c, 10) - 1;
|
|
1384
|
+
if (idx >= 0 && idx < RUN_MODE_MENU.length) choice = RUN_MODE_MENU[idx];
|
|
1385
|
+
else console.log(' Invalid choice. Enter 1 or 2.');
|
|
1386
|
+
}
|
|
1387
|
+
return choice.key;
|
|
1388
|
+
}
|
|
1389
|
+
|
|
1390
|
+
const chosen = await arrowSelect({
|
|
1391
|
+
title: 'How to run the service?',
|
|
1392
|
+
items: RUN_MODE_MENU.map((m) => m.text),
|
|
1393
|
+
initialIndex: 0,
|
|
1394
|
+
prompter
|
|
1395
|
+
});
|
|
1396
|
+
return RUN_MODE_MENU[chosen].key;
|
|
1397
|
+
}
|
|
1398
|
+
|
|
1354
1399
|
function printFinalSummary(ctx) {
|
|
1355
1400
|
const parts = [];
|
|
1356
1401
|
if (ctx.scope.backend) parts.push('REST API generated');
|
|
@@ -1380,7 +1425,7 @@ function printFinalSummary(ctx) {
|
|
|
1380
1425
|
* REST API Only) maupun `maybeRunServerAndFrontend` (scope REST API +
|
|
1381
1426
|
* Frontend, server harus start lebih dulu sebelum frontend).
|
|
1382
1427
|
*/
|
|
1383
|
-
async function startServerNow(ctx) {
|
|
1428
|
+
async function startServerNow(ctx, runMode = 'terminal') {
|
|
1384
1429
|
// Samakan dengan pola server-start.bat: serve + --watch (auto-restart pada
|
|
1385
1430
|
// perubahan src/). Format log rapi (pino-pretty) berasal dari NODE_ENV
|
|
1386
1431
|
// development yang di-set saat spawn di bawah.
|
|
@@ -1395,14 +1440,26 @@ async function startServerNow(ctx) {
|
|
|
1395
1440
|
const serveEnv = { ...process.env, NODE_ENV: 'development' };
|
|
1396
1441
|
|
|
1397
1442
|
if (process.platform === 'win32') {
|
|
1398
|
-
|
|
1399
|
-
|
|
1400
|
-
|
|
1401
|
-
|
|
1402
|
-
|
|
1403
|
-
|
|
1443
|
+
if (runMode === 'pm2') {
|
|
1444
|
+
console.log(`\n Starting via pm2: "${title}"`);
|
|
1445
|
+
const name = pm2Name(ctx.project, 'server');
|
|
1446
|
+
const ok = pm2StartScript(name, ctx.serverStartFile, ctx.cwd);
|
|
1447
|
+
if (!ok) {
|
|
1448
|
+
console.log(' Failed to start via pm2. Is pm2 installed? (npm install -g pm2)');
|
|
1449
|
+
return false;
|
|
1450
|
+
}
|
|
1451
|
+
console.log(` ✓ Server started via pm2 as "${name}".`);
|
|
1452
|
+
console.log(` pm2 logs ${name} | pm2 reload ${name} | pm2 stop ${name}`);
|
|
1453
|
+
} else {
|
|
1454
|
+
console.log(`\n Opening new window: "${title}"`);
|
|
1455
|
+
console.log(`#${serveCmd}`);
|
|
1456
|
+
const r = spawnSync('cmd', ['/C', 'start', title, 'cmd', '/k', serveCmd], { cwd: ctx.cwd, stdio: 'inherit', env: serveEnv });
|
|
1457
|
+
if (r.error) {
|
|
1458
|
+
console.log(` Failed to open server window: ${r.error.message}`);
|
|
1459
|
+
return false;
|
|
1460
|
+
}
|
|
1461
|
+
console.log(' ✓ Server window opened. Keep it open. Stop with Ctrl+C.');
|
|
1404
1462
|
}
|
|
1405
|
-
console.log(' ✓ Server window opened. Keep it open. Stop with Ctrl+C.');
|
|
1406
1463
|
} else {
|
|
1407
1464
|
// Tidak ada konsep "window baru" di Linux/macOS (terutama session SSH headless) -
|
|
1408
1465
|
// pakai pm2 supaya proses bisa dikelola normal (pm2 list/logs/reload/stop).
|
|
@@ -1432,16 +1489,17 @@ async function startServerNow(ctx) {
|
|
|
1432
1489
|
return true;
|
|
1433
1490
|
}
|
|
1434
1491
|
|
|
1435
|
-
/** Konfirmasi lalu jalankan runtime server
|
|
1436
|
-
async function maybeRunServer(ctx, ask) {
|
|
1492
|
+
/** Konfirmasi lalu jalankan runtime server. Dipakai scope REST API Only. */
|
|
1493
|
+
async function maybeRunServer(ctx, ask, prompter) {
|
|
1437
1494
|
const serveCmd = `npx restforge serve --project=${ctx.project} --config=${ctx.configFlag} --watch`;
|
|
1438
1495
|
console.log('');
|
|
1439
|
-
const answer = (await ask(' Run Runtime Server now
|
|
1496
|
+
const answer = (await ask(' Run Runtime Server now? (Y/n): ')).trim().toLowerCase();
|
|
1440
1497
|
if (answer === 'n' || answer === 'no') {
|
|
1441
1498
|
console.log(` Skipped. Start later: ${serveCmd}`);
|
|
1442
1499
|
return;
|
|
1443
1500
|
}
|
|
1444
|
-
await
|
|
1501
|
+
const runMode = process.platform === 'win32' ? await selectRunMode(prompter) : 'pm2';
|
|
1502
|
+
await startServerNow(ctx, runMode);
|
|
1445
1503
|
}
|
|
1446
1504
|
|
|
1447
1505
|
/**
|
|
@@ -1449,7 +1507,7 @@ async function maybeRunServer(ctx, ask) {
|
|
|
1449
1507
|
* lalu otomatis buka browser default ke index.html agar user tidak perlu
|
|
1450
1508
|
* membukanya manual. Eksekusi murni (tanpa prompt).
|
|
1451
1509
|
*/
|
|
1452
|
-
async function startFrontendNow(ctx) {
|
|
1510
|
+
async function startFrontendNow(ctx, runMode = 'terminal') {
|
|
1453
1511
|
const appDir = path.join(ctx.cwd, 'frontend', 'apps', ctx.project);
|
|
1454
1512
|
const webPort = ctx.cfg.WEB_SERVER_PORT;
|
|
1455
1513
|
// Jalankan langsung `npx serve . -l <port>` (identik untuk Windows & Linux),
|
|
@@ -1465,14 +1523,26 @@ async function startFrontendNow(ctx) {
|
|
|
1465
1523
|
const title = `RESTForge Frontend - ${ctx.project}`;
|
|
1466
1524
|
|
|
1467
1525
|
if (process.platform === 'win32') {
|
|
1468
|
-
|
|
1469
|
-
|
|
1470
|
-
|
|
1471
|
-
|
|
1472
|
-
|
|
1473
|
-
|
|
1526
|
+
if (runMode === 'pm2') {
|
|
1527
|
+
console.log(`\n Starting via pm2: "${title}"`);
|
|
1528
|
+
const name = pm2Name(ctx.project, 'frontend');
|
|
1529
|
+
const ok = pm2StartScript(name, ctx.frontendStartFile, appDir);
|
|
1530
|
+
if (!ok) {
|
|
1531
|
+
console.log(' Failed to start via pm2. Is pm2 installed? (npm install -g pm2)');
|
|
1532
|
+
return false;
|
|
1533
|
+
}
|
|
1534
|
+
console.log(` ✓ Frontend started via pm2 as "${name}" (WEB_SERVER_PORT ${webPort}).`);
|
|
1535
|
+
console.log(` pm2 logs ${name} | pm2 reload ${name} | pm2 stop ${name}`);
|
|
1536
|
+
} else {
|
|
1537
|
+
console.log(`\n Opening new window: "${title}"`);
|
|
1538
|
+
console.log(`#${serveCmd}`);
|
|
1539
|
+
const r = spawnSync('cmd', ['/C', 'start', title, 'cmd', '/k', serveCmd], { cwd: appDir, stdio: 'inherit' });
|
|
1540
|
+
if (r.error) {
|
|
1541
|
+
console.log(` Failed to open frontend window: ${r.error.message}`);
|
|
1542
|
+
return false;
|
|
1543
|
+
}
|
|
1544
|
+
console.log(` ✓ Frontend window opened (WEB_SERVER_PORT ${webPort}).`);
|
|
1474
1545
|
}
|
|
1475
|
-
console.log(` ✓ Frontend window opened (WEB_SERVER_PORT ${webPort}).`);
|
|
1476
1546
|
} else {
|
|
1477
1547
|
console.log(`\n Starting via pm2: "${title}"`);
|
|
1478
1548
|
const name = pm2Name(ctx.project, 'frontend');
|
|
@@ -1517,18 +1587,19 @@ async function startFrontendNow(ctx) {
|
|
|
1517
1587
|
* butuh API sudah hidup), baru lanjut frontend setelah server window
|
|
1518
1588
|
* terbuka + health check selesai.
|
|
1519
1589
|
*/
|
|
1520
|
-
async function maybeRunServerAndFrontend(ctx, ask) {
|
|
1590
|
+
async function maybeRunServerAndFrontend(ctx, ask, prompter) {
|
|
1521
1591
|
const serveCmd = `npx restforge serve --project=${ctx.project} --config=${ctx.configFlag} --watch`;
|
|
1522
1592
|
const frontendCmd = `npx serve . -l ${ctx.cfg.WEB_SERVER_PORT}`;
|
|
1523
1593
|
console.log('');
|
|
1524
|
-
const answer = (await ask(' Run Runtime Server and frontend application now
|
|
1594
|
+
const answer = (await ask(' Run Runtime Server and frontend application now? (Y/n): ')).trim().toLowerCase();
|
|
1525
1595
|
if (answer === 'n' || answer === 'no') {
|
|
1526
1596
|
console.log(` Skipped. Start later: ${serveCmd}`);
|
|
1527
1597
|
console.log(` Skipped. Start later (in frontend/apps/${ctx.project}): ${frontendCmd}`);
|
|
1528
1598
|
return;
|
|
1529
1599
|
}
|
|
1530
|
-
await
|
|
1531
|
-
await
|
|
1600
|
+
const runMode = process.platform === 'win32' ? await selectRunMode(prompter) : 'pm2';
|
|
1601
|
+
await startServerNow(ctx, runMode);
|
|
1602
|
+
await startFrontendNow(ctx, runMode);
|
|
1532
1603
|
}
|
|
1533
1604
|
|
|
1534
1605
|
// ---------------------------------------------------------------------------
|
|
@@ -1681,9 +1752,9 @@ module.exports = {
|
|
|
1681
1752
|
// Scope REST API Only -> dialog server saja (tidak ada frontend
|
|
1682
1753
|
// yang di-generate, SCOPES tidak punya opsi frontend-only).
|
|
1683
1754
|
if (ctx.scope.backend && ctx.scope.frontend) {
|
|
1684
|
-
await maybeRunServerAndFrontend(ctx, prompter.ask);
|
|
1755
|
+
await maybeRunServerAndFrontend(ctx, prompter.ask, prompter);
|
|
1685
1756
|
} else if (ctx.scope.backend) {
|
|
1686
|
-
await maybeRunServer(ctx, prompter.ask);
|
|
1757
|
+
await maybeRunServer(ctx, prompter.ask, prompter);
|
|
1687
1758
|
}
|
|
1688
1759
|
} finally {
|
|
1689
1760
|
prompter.close();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
function a0_0x18d8(){const _0x47e7db=['Cgn0','rgv0zxjTAw5LzcbIEsbZy2fSyxjdB2XSyxbZzvj1BgvZlIbgywLSzwqGD2LKz2v0CYbWCM9KDwnLihSGzxjYB3i6icCUlI4Nih0GyMXVy2SGD2L0Acb0B3aTBgv2zwWGC3vJy2vZCYbZDgLSBcb0CNvLicHVBMuGD2LKz2v0igzHAwX1CMuGzg9LCYbot1qGzMfPBcb0AguGzgfZAgjVyxjKks4','q29SBgfWC2uGDg8GC2nHBgfYihbYAw1PDgL2zsaODgHLihzHBhvLig9MihrOzsbZAw5NBguGy29SDw1Uks4','C3vIDgL0Bgu','vgLTzs10BY1SAxzLigLUihnLy29UzhmUidaGzwzMzwn0AxzLBhKGzgLZywjSzxmGy2fJAguGzM9YihrOAxmGzw50CNKU','DhrS','rNjVBNrLBMqGy29TChv0zxmGDg9Fz29HBca9ihrHCMDLDcaTihzHBhvLigfUzcbWy3qGpsbYB3vUzcH2ywX1zsaVihrHCMDLDcaQideWmcKGzM9YihrOzsbWCM9NCMvZCYbIyxiUifzPC3vHBcb3Awr0AcbPCYbWCMvZzw50yxrPB25HBcbHBMqGBxvZDcbot1qGBgL2zsbPBIb0AguGyMfJA2vUzcbWyxLSB2fKlIbjzIbWCM9NCMvZCYbPBNzVBhzLCYbJB21WBgv4igj1C2LUzxnZihj1BgvZicHLlMCUigv4y2X1zguGD2vLA2vUzhmSihbYB3jHDgvKihDVCMTKyxLZksWGDxnLigeGC2LUz2XLig11BhrPlwnVBhvTBIbXDwvYEsbZBYaNCgn0jYbPCYbHihn0ywjSzsbIDxnPBMvZCYbMywn0ihjHDgHLCIb0AgfUihzPC3vHBcb3Awr0Ac4','Ahr0Chm6lY9Yzxn0zM9Yz2uUzgv2l2rVy3mVC2vYDMvYl3f1zxj5lwrHDgeVzgfZAgjVyxjK','A2v54OAszMLSztPYzwXHDgL2zs9WyxrOl3rVl3f1zxj5lNnXBa','BNvTyMvY','zMLSztPXDwvYEs88Cgf0Ad4VDMfSDwuUC3fS','iNrYzw5KiJOGEYaIzgLYzwn0Aw9UiJOGiNvWiIWGiNbJDci6iciYlJiIih0','ugfYyw0Gzgf0ysb0ExbLlIbwywXPzgf0zxmGCMvXDwvZDcbIB2r5igfUzcbZAgfWzxmGCNvUDgLTzsbWyxjHBwv0zxiGyMLUzgLUzY4','z2vUzxjHDgLVBIb0Aw1LicHot1qGCNvUDgLTzsK','rgvMyxvSDcb2ywX1zsbHChbSAwvKihDOzw4GDgHLihjLCxvLC3qGB21PDhmGDgHPCYbWyxjHBs4GvMfSAwrHDg9YigrVzxmGtK9uihn0CMLJDgX5ihr5CguTy2HLy2SGzgvMyxvSDdSGCNvUDgLTzsbPCYbYzxnWB25ZAwjSzsbMB3iGy29TCgf0AwjPBgL0Es4','t3b0Aw9UywWGy2fJAguGy29UzMLNDxjHDgLVBI4Gu2vLignHy2HLu3bLyYbMB3iGzgv0ywLSCY4','D2LKz2v0CW','q29SBgfWC2uGDg8GB2jQzwn0ihDOB3nLigTLExmGyxjLifnrtcbJB2X1Bw4GBMfTzxmGkgXVD2vYy2fZzwqPlG','mta2mde5mKH0yKXHuG','ms4W','tvvtvcbZDgfYDcb3AxrOicDKyxnOlsCGChjLzML4','yxzNx2rHAwX5x3nHBgvZ','zxHWB3j0CW','zMLSztPXDwvYEs88Cgf0Ad4VDhjLBMqUC3fS','zgLYzwn0Aw9U','qsb3AwrNzxqGtvvtvcbKzwnSyxjLigv4ywn0BhKGB25Lig9MoIaNCxvLCNKNie9sicDXDwvYAwvZjY4GqM90AcbVCIbUzwL0AgvYigLZihjLAMvJDgvKlG','mJe5ndK2AxHxt2Lb','Dg9Wtgv2zwXbBgXVD2vK','BgvUz3rO','DMfSDwu','EYaIzgLYzwn0Aw9UiJOGiNvWiIWGiNbJDci6iciYlJyIih0','ugvYlwTLEsbIyxnLzcbVBIbZy2fSyxjdB2XSyxbZzvj1BgvZigjLBg93lG','zgfZAgjVyxjKlwnHDgfSB2C','rxzLCNKGCgXHy2vOB2XKzxiGDxnLzcbPBIbtuuWGtvvtvcbIzsbKzwnSyxjLzcbPBIaNCgfYyw1ZjY4GvMfSAwrHDg9YihrOCM93CYbfCNjVCIb3AxrOig1LC3nHz2uGzM9YBwf0oIaIv2LKz2v0icC8Awq+jYbXDwvYEsaNpgXHyMvSpICGDxnLCYb1BMrLy2XHCMvKihbSywnLAg9SzgvYicC6phrVA2vUpICGkgrLy2XHCMuGAw4Gj3bHCMfTCYCPiI4','D2LKz2v0lNf1zxjPzxmUpgTLEt4GD2L0AcbtuuWGCMv0DxjUAw5NideGCM93imoxideGy29SDw1U','u1fmigzPBguGy29UDgvUDcbPCYbLBwjLzgrLzcbHCYbkyxzHu2nYAxb0ihrLBxbSyxrLigXPDgvYywWGAw5ZAwrLihrOzsbNzw5LCMf0zwqGBw9KDwXLigzPBguUifj1BNrPBwuGCgvYzM9YBxmGEMvYBYbKAxnRieKVtYbWzxiGCMvXDwvZDcdIGjqGywXSifnrtcbPCYbPBIbTzw1VCNKGywz0zxiGBw9KDwXLigXVywqU','zMLSztPXDwvYEs88Cgf0Ad4Vy3vYCMvUDc5ZCwW','Dg9WlwXLDMvSicDWyxjHBxmNig9IAMvJDa','zgf0zq','EYaIzgLYzwn0Aw9UiJOGiMrVD24IlcaICgn0iJOGiJiUmIiGFq','sgvHzgXPBMuGBwv0CMLJihDPDgGGDhjLBMqGy2HPCcbHBMqGC3bHCMTSAw5Lig1PBMKTy2HHCNqGzM9YihnOB3j0ihDPBMrVD3mGkdCGzgf5CYWGmtiGBw9UDgHZlcbLDgmUks4Gu3vPDgfIBguGzM9YihDPzgDLDhmGBgLRzsaNqxzLCMfNzsbeywLSEsbtywXLCYCU','D2LKz2v0lNf1zxjPzxmUpgTLEt4GD2L0AcbtuuWGCMv0DxjUAw5NideGCM93imoxig11BhrPCgXLignVBhvTBNm','mtKWq054s25j','y29SB3i','C3rYAw5N','v2HLBIbJywnOzs5LBMfIBgvKid09psb0CNvLigfUzcbPBNzHBgLKyxrLCYbPCYbUB24Tzw1WDhK6ihzHBgLKyxrVCIbLEhrYywn0CYb0ywjSzsbJyw5KAwrHDgvZigzYB20GD2LKz2v0ifnrtcaOCMvNzxGGrLjpts9kt0LoksWGy3jVC3mTCMvMzxjLBMnLCYb3AxrOig1LDgfKyxrHl3TWCM9Qzwn0Fs5QC29UicHLBMrWB2LUDhnBkL0UDgfIBgvoyw1LihDOzxjLihr5CguGpt09icjTB2r1BguIksWGyw5KigfZC2vYDhmGzxf1ywXPDhKGB2yGzxHWzwn0zwqGDNmGzgvJBgfYzwqGC2v0CY4GtwLZBwf0y2HLCYbHCMuGCMvWB3j0zwqGCgvYignHDgvNB3j5icHTAxnZAw5NlcbLEhrYysWGDw5TyxrJAgvKks4','zw5HyMXLza','msbYB3CGW5CGmsbJB2X1Bw4','zMLSztPYzwXHDgL2zs9WyxrOl3rVl3f1zxj5lNnXBa','qsbWyxLSB2fKihDPDgGGyM90AcaND2LKz2v0CYCGyw5KicD0ywjSzu5HBwuNigLZihjLAMvJDgvKigj5ierHC2HIB2fYzfzHBgLKyxrVCI4GugLJAYbVBMuGC2HHCguU','kd88itOPoIHBys16qs1Ax11Bys16qs1Amc05x10Qkq','mZC4mJe4ELvVDer3','pJ0GmcaOC2vJB25KCYK','zNjVBNrLBMqTy29Uy2vYBG','mty3oti0mxjOAxvszW','n2fbsu1KEa','vgfIBguGyxbWzwfYCYbPBIbtuuWGqu5eigLUig1LDgfKyxrHihbYB2PLy3qSigj1DcbTAxnZAw5NigzYB20GAw52ywXPzgf0zxmGkgnHy2HLihn0ywXLihjPC2SP','zgfZAc1HDxrOB3iTC3rHDhm','Bwv0CMLJx3bYB2DYzxnZx3rVx2DVywW','tIbYB3DZimoxidiGy29SDw1UCW','C2nHBgfYihbYAw1PDgL2zq','Cgf5Bg9Hzcbku09oigzPBguGBg9JyxrPB24','BgfIzwW','vuKGBgfIzwWGAxmGysbMCM9UDgvUzcbYzw5KzxjPBMCGy29Uy2vYBI4','DgfIBgvoyw1L','ue9tvcaVyxbPl21PBMKTAw52zw50B3j5l2rHC2GTAw5IB3vUzc9KyxnOyM9HCMq','qwX3yxLZihSGAxrLBxm6ifSUlI5Dih0GCMvNyxjKBgvZCYbVzIbtuuWGCMvZDwX0ihnOyxbLlG','nZu4ntGZELvvDwHx','mtq0nJK2tgDtCfrQ','u2LUz2XLifnrtcbXDwvYEsbMB3iGDgHLihDPzgDLDc4','B2jQzwn0','phDPzgDLDf9Pzd4','DgfYz2v0','vxbKyxrPBMCGyw4Gu1fmigzPBguGCMvXDwLYzxmGCMvNzw5LCMf0Aw5NihrOzsbKyxnOyM9HCMqGBw9KDwXLicGNy29KzwDLBL9JCMvHDgvFzgfZAgjVyxjKjYKGzM9YignOyw5NzxmGDg8GDgfRzsbLzMzLy3qU','yw55icHTDxn0igjLignVBxbHDgLIBguGD2L0AcbKzwnSyxjLzcaNDhLWzsCP','DhjLBMq','otvnCxbYt3e','nff2BhbXrW','Dg9WlwXLDMvSicDJywnOzsCGB2jQzwn0','yw55icGXihjVDYddLYaXignVBcWGtIbYB3DZimoxie0Gy29SCYWGzxrJlIK','yM9VBgvHBG','zMLSztPXDwvYEs88Cgf0Ad4VCg9PBNrZlNnXBa','yxjYyxK','zxHWzwn0zwrFzwfYBMLUz3m','iNzHBhvLiJOGiJy5nZaWiG','v2LKz2v0igLKzw50AwzPzxi7ihvZzwqGyxmGDgHLihjLC3bVBNnLigTLEsbPBIb0AguGzgfZAgjVyxjKigvUDMvSB3bLlG','twv0CMLJicSGrg9UDxqGqNjLywTKB3DU','odGXoti1yKLpvvPI','txvSDgKTu1fmihDPzgDLDc4GrwfJAcbRzxKGyMvJB21LCYbHigTLEsbPBIb0AguGCMvZCg9UC2uGB2jQzwn0lG','AxrLBxm','EYbZDwnJzxnZoIbIB29SzwfUlcbKyxrHoIb7idX3AwrNzxrjzd46idXWzxjxAwrNzxrszxnWB25Zzt4Sic4UlIb9ih0','sgvHzgXPBMuGBwv0CMLJihDPDgGGDhjLBMqGy2HPCcbHBMqGyNjLywTKB3DUigfJCM9ZCYbJyxrLz29YAwvZlIbtDwL0ywjSzsbMB3iGD2LKz2v0CYbSAwTLicDfEhbLy3rLzcbfyxjUAw5NCYCGDgHHDcbZAg93ihrVDgfSihzHBhvLlcbWzxjJzw50ywDLignOyw5NzsWGyw5KihbLCI1JyxrLz29YEsbJB250CMLIDxrPB24U','l2fWAs97ChjVAMvJDh0VE25HBwv9l2rHC2HIB2fYza','msbYB3CGW5CGmsbJB2WSig91Dhb1DcbJB2X1Bw4Gj3zHBhvLjW','u0vmrunuicOGrLjptsbZDg9JA19PBMjVDw5KifDirvjfievyvfjbq1qOwuvbuIbguK9nigLUyM91BMrFzgf0zsKGpsa6EwvHCG','vMLZDwfSignVBg9YigLZigeGzNjVBNrLBMqGCMvUzgvYAw5NignVBMnLCM4U','tgf5B3v0igLZigeGzNjVBNrLBMqGCMvUzgvYAw5NignVBMnLCM4U'];a0_0x18d8=function(){return _0x47e7db;};return a0_0x18d8();}const a0_0x59fd6d=a0_0x5b15;function a0_0x5b15(_0x2e5b15,_0x58bb27){_0x2e5b15=_0x2e5b15-0x7e;const _0x18d8fc=a0_0x18d8();let _0x5b1512=_0x18d8fc[_0x2e5b15];if(a0_0x5b15['zGOJnb']===undefined){var _0x5d411f=function(_0xfa0d8a){const _0x414ce1='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x324d63='',_0x13a036='';for(let _0x101135=0x0,_0x38dd34,_0xe3ec6,_0x961452=0x0;_0xe3ec6=_0xfa0d8a['charAt'](_0x961452++);~_0xe3ec6&&(_0x38dd34=_0x101135%0x4?_0x38dd34*0x40+_0xe3ec6:_0xe3ec6,_0x101135++%0x4)?_0x324d63+=String['fromCharCode'](0xff&_0x38dd34>>(-0x2*_0x101135&0x6)):0x0){_0xe3ec6=_0x414ce1['indexOf'](_0xe3ec6);}for(let _0x3ac4ad=0x0,_0x28a441=_0x324d63['length'];_0x3ac4ad<_0x28a441;_0x3ac4ad++){_0x13a036+='%'+('00'+_0x324d63['charCodeAt'](_0x3ac4ad)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x13a036);};a0_0x5b15['GXdGwp']=_0x5d411f,a0_0x5b15['CnpewU']={},a0_0x5b15['zGOJnb']=!![];}const _0x2b10fa=_0x18d8fc[0x0],_0x56403c=_0x2e5b15+_0x2b10fa,_0x370d7d=a0_0x5b15['CnpewU'][_0x56403c];return!_0x370d7d?(_0x5b1512=a0_0x5b15['GXdGwp'](_0x5b1512),a0_0x5b15['CnpewU'][_0x56403c]=_0x5b1512):_0x5b1512=_0x370d7d,_0x5b1512;}(function(_0x1ea101,_0x5a14be){const _0x276e9c=a0_0x5b15,_0x4c8039=_0x1ea101();while(!![]){try{const _0x1d2d09=-parseInt(_0x276e9c(0xc2))/0x1+parseInt(_0x276e9c(0xa9))/0x2+parseInt(_0x276e9c(0xc5))/0x3*(-parseInt(_0x276e9c(0xdc))/0x4)+parseInt(_0x276e9c(0xdb))/0x5*(-parseInt(_0x276e9c(0xd3))/0x6)+parseInt(_0x276e9c(0xc6))/0x7*(parseInt(_0x276e9c(0xa1))/0x8)+-parseInt(_0x276e9c(0xd2))/0x9+-parseInt(_0x276e9c(0xb9))/0xa*(-parseInt(_0x276e9c(0x85))/0xb);if(_0x1d2d09===_0x5a14be)break;else _0x4c8039['push'](_0x4c8039['shift']());}catch(_0x324773){_0x4c8039['push'](_0x4c8039['shift']());}}}(a0_0x18d8,0x459d5));const FORBIDDEN_FRONTEND_FIELDS=['widgetType','layout','title',a0_0x59fd6d(0x92),a0_0x59fd6d(0xba)],ALLOWED_PARAM_TYPES=[a0_0x59fd6d(0xbb),a0_0x59fd6d(0x98),'boolean',a0_0x59fd6d(0xb5)],FRONTEND_CONCERN_REASONS={'widgetType':'Visual\x20variant\x20(donut,\x20bar,\x20pie,\x20area)\x20is\x20a\x20frontend\x20rendering\x20concern\x20(separation\x20of\x20concerns).','layout':a0_0x59fd6d(0x8e),'title':a0_0x59fd6d(0xce),'subtitle':'UI\x20label\x20is\x20a\x20frontend\x20rendering\x20concern.','color':a0_0x59fd6d(0x8d)},PAYLOAD_SHAPE={'discriminator':{'field':'widgets','presentMeans':'dashboard\x20payload','absentMeans':'Not\x20a\x20dashboard\x20payload\x20(likely\x20CRUD\x20with\x20tableName,\x20or\x20invalid)','conflictsWith':a0_0x59fd6d(0xcf),'conflictRationale':a0_0x59fd6d(0xc0)},'topLevelAllowed':[{'name':a0_0x59fd6d(0x9f),'type':a0_0x59fd6d(0x80),'required':!![],'minItems':0x1,'description':'List\x20of\x20widget\x20definitions.\x20Order\x20is\x20informational\x20only\x20(response\x20keys\x20are\x20by\x20widget\x20id,\x20not\x20array\x20index).'},{'name':'params','type':'object','required':![],'description':'Parameter\x20contract\x20for\x20the\x20dashboard.\x20Each\x20key\x20is\x20a\x20param\x20name;\x20values\x20describe\x20type/required/default.\x20Placeholders\x20inside\x20widget\x20SQL\x20must\x20reference\x20declared\x20param\x20names.'},{'name':'cache','type':'object','required':![],'description':a0_0x59fd6d(0x9e)}],'topLevelForbidden':[{'name':'tableName','category':'shape-conflict','reason':'Reserved\x20for\x20CRUD\x20payloads.\x20A\x20dashboard\x20payload\x20must\x20declare\x20\x27widgets\x27\x20instead.'},...FORBIDDEN_FRONTEND_FIELDS['map'](_0x324d63=>({'name':_0x324d63,'category':a0_0x59fd6d(0xc4),'reason':FRONTEND_CONCERN_REASONS[_0x324d63]}))]},WIDGET_SPEC={'requiredFields':[{'name':'id','type':'string','constraint':'non-empty,\x20unique\x20across\x20widgets\x20in\x20the\x20same\x20payload','description':a0_0x59fd6d(0x83)}],'exclusiveQueryFields':{'rule':a0_0x59fd6d(0xa8),'options':[{'name':'query','type':'string','format':'file:relative/path/to/query.sql','description':a0_0x59fd6d(0xd4),'responseShape':a0_0x59fd6d(0xd1)},{'name':'queries','type':a0_0x59fd6d(0xd5),'format':a0_0x59fd6d(0x97),'minKeys':0x1,'description':a0_0x59fd6d(0x86),'responseShape':a0_0x59fd6d(0xae)}]},'forbiddenFields':FORBIDDEN_FRONTEND_FIELDS},PARAM_SPEC={'container':a0_0x59fd6d(0xb4),'keyConvention':'Param\x20name\x20must\x20match\x20the\x20placeholder\x20regex\x20`[a-zA-Z_][a-zA-Z0-9_]*`\x20(alphanumeric\x20+\x20underscore,\x20must\x20start\x20with\x20letter\x20or\x20underscore).','perEntryFields':[{'name':'type','required':!![],'allowedValues':ALLOWED_PARAM_TYPES,'description':a0_0x59fd6d(0x9b)},{'name':'required','required':![],'type':a0_0x59fd6d(0x7e),'default':![],'description':'When\x20true,\x20the\x20request\x20body\x20MUST\x20include\x20this\x20param\x20(otherwise\x20400).'},{'name':'default','required':![],'type':a0_0x59fd6d(0xd9),'description':a0_0x59fd6d(0x9d)}]},SCALAR_COLLAPSE_RULES=[{'appliesTo':'widget.query\x20(singular)','rule':'Always\x20wrap\x20as\x20{\x20items:\x20[...]\x20}\x20regardless\x20of\x20SQL\x20result\x20shape.','exampleSqlShape':a0_0x59fd6d(0xde),'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_0x59fd6d(0xb1),'rule':a0_0x59fd6d(0x91),'exampleSqlShape':a0_0x59fd6d(0x8b),'exampleResponse':a0_0x59fd6d(0x82)},{'appliesTo':a0_0x59fd6d(0xb8),'rule':a0_0x59fd6d(0xa0),'exampleSqlShape':'1\x20row\x20×\x202\x20cols,\x20output\x20columns\x20\x27direction\x27,\x20\x27pct\x27','exampleResponse':a0_0x59fd6d(0x9a)},{'appliesTo':'widget.queries.<key>\x20with\x20SQL\x20returning\x20N\x20rows','rule':'Return\x20as\x20array\x20of\x20objects\x20(no\x20collapse).','exampleSqlShape':'N\x20rows\x20×\x20M\x20cols','exampleResponse':'\x22items\x22:\x20[{\x20\x22label\x22:\x20\x22Shoes\x22,\x20\x22value\x22:\x20\x227660\x22\x20},\x20...]'}],COMMON_WIDGET_PATTERNS=[{'id':'metric_donut_breakdown','name':a0_0x59fd6d(0x84),'useCase':a0_0x59fd6d(0x89),'payloadShape':{'id':a0_0x59fd6d(0xd6),'queries':{'value':a0_0x59fd6d(0x99),'trend':'file:query/<path>/trend.sql','items':'file:query/<path>/breakdown.sql'}},'sqlShapesPerKey':[{'key':'value','shape':'1\x20row\x20×\x201\x20column','outputColumns':[a0_0x59fd6d(0xac)],'collapseRule':'scalar\x20primitive'},{'key':'trend','shape':'1\x20row\x20×\x202\x20columns','outputColumns':[a0_0x59fd6d(0xa7),'pct'],'collapseRule':a0_0x59fd6d(0xd5)},{'key':a0_0x59fd6d(0x87),'shape':a0_0x59fd6d(0xca),'outputColumns':[a0_0x59fd6d(0xcd),a0_0x59fd6d(0xac)],'collapseRule':'array\x20of\x20objects'}],'responseShape':{'value':'\x2269700\x22','trend':'{\x20\x22direction\x22:\x20\x22up\x22,\x20\x22pct\x22:\x20\x222.2\x22\x20}','items':'[{\x20\x22label\x22:\x20\x22Shoes\x22,\x20\x22value\x22:\x20\x227660\x22\x20},\x20{\x20\x22label\x22:\x20\x22Gaming\x22,\x20\x22value\x22:\x20\x222820\x22\x20},\x20{\x20\x22label\x22:\x20\x22Others\x22,\x20\x22value\x22:\x20\x2245257\x22\x20}]'},'referenceWidgetId':a0_0x59fd6d(0x81),'socNotes':'Frontend\x20determines\x20donut/pie\x20variant,\x20color\x20per\x20category,\x20and\x20label\x20order.\x20If\x20per-category\x20percentage\x20is\x20needed\x20for\x20the\x20donut\x20arc,\x20frontend\x20computes\x20it\x20from\x20items[i].value\x20/\x20sum(items[*].value).\x20No\x20need\x20to\x20send\x20\x27pct\x27\x20from\x20backend\x20unless\x20the\x20figure\x20is\x20a\x20stable\x20business\x20calculation\x20independent\x20of\x20visual\x20rendering.'},{'id':'metric_sparkline','name':'Metric\x20+\x20Sparkline','useCase':a0_0x59fd6d(0xb7),'payloadShape':{'id':'<widget_id>','queries':{'value':a0_0x59fd6d(0x99),'trend':'file:query/<path>/trend.sql','points':a0_0x59fd6d(0x7f)}},'sqlShapesPerKey':[{'key':a0_0x59fd6d(0xac),'shape':a0_0x59fd6d(0xbe),'outputColumns':['value'],'collapseRule':a0_0x59fd6d(0xcb)},{'key':'trend','shape':'1\x20row\x20×\x202\x20columns','outputColumns':['direction',a0_0x59fd6d(0x8f)],'collapseRule':a0_0x59fd6d(0xd5)},{'key':'points','shape':'N\x20rows\x20×\x202\x20columns','outputColumns':['period','value'],'collapseRule':'array\x20of\x20objects'}],'responseShape':{'value':'\x222420\x22','trend':a0_0x59fd6d(0xad),'points':'[{\x20\x22period\x22:\x20\x222026-04-24\x22,\x20\x22value\x22:\x20\x221850\x22\x20},\x20...\x20]'},'referenceWidgetId':a0_0x59fd6d(0xa4),'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_0x59fd6d(0xc9),'name':'Metric\x20+\x20Progress\x20to\x20Goal','useCase':'Headline\x20metric\x20with\x20trend\x20chip\x20and\x20progress\x20bar\x20against\x20a\x20period\x20target.\x20Suitable\x20for\x20widgets\x20like\x20\x27Orders\x20This\x20Month\x27.','payloadShape':{'id':a0_0x59fd6d(0xd6),'queries':{'value':a0_0x59fd6d(0xb3),'trend':a0_0x59fd6d(0xa6),'target':'file:query/<path>/target.sql'}},'sqlShapesPerKey':[{'key':'value','shape':a0_0x59fd6d(0xbe),'outputColumns':['value\x20(or\x20current)'],'collapseRule':a0_0x59fd6d(0xcb)},{'key':a0_0x59fd6d(0xda),'shape':'1\x20row\x20×\x202\x20columns','outputColumns':['direction',a0_0x59fd6d(0x8f)],'collapseRule':a0_0x59fd6d(0xd5)},{'key':'target','shape':'1\x20row\x20×\x201\x20column','outputColumns':[a0_0x59fd6d(0xd7)],'collapseRule':a0_0x59fd6d(0xcb)}],'responseShape':{'value':'\x221836\x22','trend':a0_0x59fd6d(0xb6),'target':'\x222884\x22'},'referenceWidgetId':'orders_this_month','socNotes':a0_0x59fd6d(0x95)}],NAMING_CONVENTION={'dashboardName':{'constraint':a0_0x59fd6d(0xa3),'minLength':0x6,'maxLength':0x32,'regex':'^dash-[a-zA-Z0-9_-]+$','examples':['dash-sales','dash-inbound',a0_0x59fd6d(0xc8)],'rationale':'The\x20prefix\x20becomes\x20part\x20of\x20the\x20URL\x20segment.\x20The\x20reserved\x20scheme\x20keeps\x20dashboard\x20endpoints\x20visually\x20distinct\x20from\x20CRUD\x20endpoints\x20in\x20the\x20URL\x20space\x20and\x20allows\x20future\x20routing\x20differentiation.'}},URL_PATTERN={'method':'POST','path':a0_0x59fd6d(0x8a),'exampleFull':a0_0x59fd6d(0xd0),'requestBodyShape':{'params':'object\x20—\x20values\x20for\x20declared\x20params\x20(validated\x20against\x20params\x20contract;\x20missing\x20required\x20→\x20400,\x20type\x20mismatch\x20→\x20400)','widgets':'array<string>,\x20optional\x20—\x20subset\x20of\x20widget\x20IDs\x20to\x20execute.\x20Omit\x20to\x20execute\x20all\x20declared\x20widgets.'},'responseShape':{'envelope':a0_0x59fd6d(0x88),'perWidgetResponse':a0_0x59fd6d(0x90)}},FILE_REFERENCE_CONVENTION={'format':a0_0x59fd6d(0xbf),'pathRelativeTo':a0_0x59fd6d(0xcc),'fileExtensionPolicy':'free;\x20.sql\x20recommended\x20for\x20editor\x20highlight','resolvedAt':a0_0x59fd6d(0x9c),'embedStrategy':a0_0x59fd6d(0xb2),'implication':a0_0x59fd6d(0xd8)},PLACEHOLDER_CONVENTION={'format':':paramName','regex':a0_0x59fd6d(0xc1),'regexNotes':'Negative\x20lookbehind\x20prevents\x20matching\x20\x27::\x27\x20(Postgres\x20cast\x20syntax)\x20as\x20a\x20placeholder.','scanScope':'All\x20widget\x20SQL\x20—\x20both\x20\x27query\x27\x20(singular)\x20and\x20every\x20\x27queries.<key>\x27.','constraint':a0_0x59fd6d(0xb0),'exampleSql':a0_0x59fd6d(0x8c),'exampleParamDeclaration':'{\x20\x22params\x22:\x20{\x20\x22year\x22:\x20{\x20\x22type\x22:\x20\x22number\x22,\x20\x22required\x22:\x20true\x20}\x20}\x20}'},CACHE_SPEC={'container':a0_0x59fd6d(0xdd),'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_0x59fd6d(0xbd),'type':a0_0x59fd6d(0x7e),'required':!![],'description':'Toggle\x20cache\x20feature\x20for\x20this\x20dashboard.'},{'name':a0_0x59fd6d(0x94),'type':'number','required':![],'constraint':a0_0x59fd6d(0xc3),'default':'inherits\x20CACHE_TTL\x20env','description':a0_0x59fd6d(0x93)},{'name':'invalidates','type':'array<string>','required':![],'default':'[]','description':'List\x20of\x20CRUD\x20table\x20names\x20that,\x20when\x20written,\x20will\x20trigger\x20invalidation\x20of\x20this\x20dashboard\x20cache.'}],'validation':{'sqlCrossReference':a0_0x59fd6d(0xbc),'errorOn':[a0_0x59fd6d(0xc7),'Table\x20declared\x20in\x20invalidates,\x20but\x20not\x20detected\x20in\x20any\x20widget\x20SQL\x20(typo\x20or\x20dead\x20entry)'],'warningOn':['Table\x20detected\x20in\x20SQL,\x20but\x20not\x20registered\x20as\x20CRUD\x20endpoint\x20in\x20metadata\x20project\x20(likely\x20a\x20view,\x20CTE\x20alias,\x20or\x20cross-project\x20table\x20—\x20cascade\x20will\x20not\x20fire)']}},DOCUMENTATION_URL=a0_0x59fd6d(0x96),DASHBOARD_CATALOG={'schemaVersion':a0_0x59fd6d(0xa2),'source':a0_0x59fd6d(0xaf),'summary':{'totalAllowedTopLevelFields':PAYLOAD_SHAPE[a0_0x59fd6d(0xaa)][a0_0x59fd6d(0xab)],'totalForbiddenFrontendFields':FORBIDDEN_FRONTEND_FIELDS['length'],'totalParamTypes':ALLOWED_PARAM_TYPES[a0_0x59fd6d(0xab)],'totalScalarCollapseRules':SCALAR_COLLAPSE_RULES['length'],'totalCommonWidgetPatterns':COMMON_WIDGET_PATTERNS[a0_0x59fd6d(0xab)]},'payloadShape':PAYLOAD_SHAPE,'widgetSpec':WIDGET_SPEC,'paramSpec':PARAM_SPEC,'scalarCollapseRules':SCALAR_COLLAPSE_RULES,'commonWidgetPatterns':COMMON_WIDGET_PATTERNS,'namingConvention':NAMING_CONVENTION,'urlPattern':URL_PATTERN,'fileReferenceConvention':FILE_REFERENCE_CONVENTION,'placeholderConvention':PLACEHOLDER_CONVENTION,'cacheSpec':CACHE_SPEC,'documentationUrl':DOCUMENTATION_URL};module[a0_0x59fd6d(0xa5)]={'DASHBOARD_CATALOG':DASHBOARD_CATALOG};
|
|
1
|
+
const a0_0x10f767=a0_0x1b52;(function(_0x172be3,_0x57469a){const _0x7ec4a=a0_0x1b52,_0x46386f=_0x172be3();while(!![]){try{const _0x19e174=-parseInt(_0x7ec4a(0x1a4))/0x1+parseInt(_0x7ec4a(0x1ac))/0x2*(-parseInt(_0x7ec4a(0x1c4))/0x3)+parseInt(_0x7ec4a(0x1a7))/0x4+parseInt(_0x7ec4a(0x187))/0x5+parseInt(_0x7ec4a(0x1d3))/0x6+parseInt(_0x7ec4a(0x196))/0x7+parseInt(_0x7ec4a(0x1c2))/0x8*(-parseInt(_0x7ec4a(0x192))/0x9);if(_0x19e174===_0x57469a)break;else _0x46386f['push'](_0x46386f['shift']());}catch(_0x49c208){_0x46386f['push'](_0x46386f['shift']());}}}(a0_0xaa7d,0x39d29));const FORBIDDEN_FRONTEND_FIELDS=[a0_0x10f767(0x1c5),a0_0x10f767(0x199),'title','subtitle','color'],ALLOWED_PARAM_TYPES=[a0_0x10f767(0x1c9),a0_0x10f767(0x19d),'boolean','date'],FRONTEND_CONCERN_REASONS={'widgetType':'Visual\x20variant\x20(donut,\x20bar,\x20pie,\x20area)\x20is\x20a\x20frontend\x20rendering\x20concern\x20(separation\x20of\x20concerns).','layout':'Layout\x20is\x20a\x20frontend\x20rendering\x20concern.','title':a0_0x10f767(0x191),'subtitle':a0_0x10f767(0x191),'color':'Visual\x20color\x20is\x20a\x20frontend\x20rendering\x20concern.'},PAYLOAD_SHAPE={'discriminator':{'field':a0_0x10f767(0x1a9),'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':a0_0x10f767(0x1a9),'type':'array','required':!![],'minItems':0x1,'description':a0_0x10f767(0x183)},{'name':a0_0x10f767(0x1d1),'type':'object','required':![],'description':a0_0x10f767(0x18a)},{'name':'cache','type':'object','required':![],'description':'Optional\x20cache\x20configuration.\x20See\x20cacheSpec\x20for\x20details.'}],'topLevelForbidden':[{'name':'tableName','category':a0_0x10f767(0x197),'reason':'Reserved\x20for\x20CRUD\x20payloads.\x20A\x20dashboard\x20payload\x20must\x20declare\x20\x27widgets\x27\x20instead.'},...FORBIDDEN_FRONTEND_FIELDS['map'](_0x58eedc=>({'name':_0x58eedc,'category':a0_0x10f767(0x19f),'reason':FRONTEND_CONCERN_REASONS[_0x58eedc]}))]},WIDGET_SPEC={'requiredFields':[{'name':'id','type':a0_0x10f767(0x1c9),'constraint':a0_0x10f767(0x1a5),'description':'Widget\x20identifier;\x20used\x20as\x20the\x20response\x20key\x20in\x20the\x20dashboard\x20envelope.'}],'exclusiveQueryFields':{'rule':'A\x20widget\x20MUST\x20declare\x20exactly\x20one\x20of:\x20\x27query\x27\x20OR\x20\x27queries\x27.\x20Both\x20or\x20neither\x20is\x20rejected.','options':[{'name':'query','type':'string','format':a0_0x10f767(0x1ba),'description':a0_0x10f767(0x1bc),'responseShape':a0_0x10f767(0x194)},{'name':a0_0x10f767(0x19c),'type':'object','format':a0_0x10f767(0x1cb),'minKeys':0x1,'description':a0_0x10f767(0x1a8),'responseShape':a0_0x10f767(0x1c1)}]},'forbiddenFields':FORBIDDEN_FRONTEND_FIELDS},PARAM_SPEC={'container':'top-level\x20\x27params\x27\x20object','keyConvention':a0_0x10f767(0x1b0),'perEntryFields':[{'name':a0_0x10f767(0x1b4),'required':!![],'allowedValues':ALLOWED_PARAM_TYPES,'description':'Param\x20data\x20type.\x20Validates\x20request\x20body\x20and\x20shapes\x20runtime\x20parameter\x20binding.'},{'name':a0_0x10f767(0x1ae),'required':![],'type':'boolean','default':![],'description':'When\x20true,\x20the\x20request\x20body\x20MUST\x20include\x20this\x20param\x20(otherwise\x20400).'},{'name':a0_0x10f767(0x1bf),'required':![],'type':a0_0x10f767(0x19b),'description':a0_0x10f767(0x180)}]},SCALAR_COLLAPSE_RULES=[{'appliesTo':a0_0x10f767(0x1a3),'rule':'Always\x20wrap\x20as\x20{\x20items:\x20[...]\x20}\x20regardless\x20of\x20SQL\x20result\x20shape.','exampleSqlShape':a0_0x10f767(0x1ab),'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_0x10f767(0x193),'rule':'Collapse\x20to\x20scalar\x20primitive\x20(the\x20value\x20of\x20the\x20single\x20column).','exampleSqlShape':a0_0x10f767(0x1aa),'exampleResponse':a0_0x10f767(0x18d)},{'appliesTo':'widget.queries.<key>\x20with\x20SQL\x20returning\x201\x20row\x20×\x20multiple\x20columns','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_0x10f767(0x1b6)},{'appliesTo':a0_0x10f767(0x1b1),'rule':'Return\x20as\x20array\x20of\x20objects\x20(no\x20collapse).','exampleSqlShape':'N\x20rows\x20×\x20M\x20cols','exampleResponse':a0_0x10f767(0x190)}],COMMON_WIDGET_PATTERNS=[{'id':a0_0x10f767(0x184),'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':a0_0x10f767(0x188),'trend':a0_0x10f767(0x18e),'items':a0_0x10f767(0x1be)}},'sqlShapesPerKey':[{'key':a0_0x10f767(0x198),'shape':a0_0x10f767(0x1c6),'outputColumns':[a0_0x10f767(0x198)],'collapseRule':'scalar\x20primitive'},{'key':'trend','shape':a0_0x10f767(0x189),'outputColumns':[a0_0x10f767(0x1ce),'pct'],'collapseRule':'object'},{'key':a0_0x10f767(0x18b),'shape':a0_0x10f767(0x182),'outputColumns':['label',a0_0x10f767(0x198)],'collapseRule':a0_0x10f767(0x1bd)}],'responseShape':{'value':'\x2269700\x22','trend':'{\x20\x22direction\x22:\x20\x22up\x22,\x20\x22pct\x22:\x20\x222.2\x22\x20}','items':'[{\x20\x22label\x22:\x20\x22Shoes\x22,\x20\x22value\x22:\x20\x227660\x22\x20},\x20{\x20\x22label\x22:\x20\x22Gaming\x22,\x20\x22value\x22:\x20\x222820\x22\x20},\x20{\x20\x22label\x22:\x20\x22Others\x22,\x20\x22value\x22:\x20\x2245257\x22\x20}]'},'referenceWidgetId':a0_0x10f767(0x1b2),'socNotes':a0_0x10f767(0x186)},{'id':'metric_sparkline','name':a0_0x10f767(0x195),'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':a0_0x10f767(0x1c8),'queries':{'value':'file:query/<path>/value.sql','trend':a0_0x10f767(0x18e),'points':'file:query/<path>/points.sql'}},'sqlShapesPerKey':[{'key':a0_0x10f767(0x198),'shape':a0_0x10f767(0x1c6),'outputColumns':[a0_0x10f767(0x198)],'collapseRule':a0_0x10f767(0x1a6)},{'key':a0_0x10f767(0x18f),'shape':a0_0x10f767(0x189),'outputColumns':['direction',a0_0x10f767(0x1d4)],'collapseRule':'object'},{'key':'points','shape':'N\x20rows\x20×\x202\x20columns','outputColumns':['period','value'],'collapseRule':'array\x20of\x20objects'}],'responseShape':{'value':a0_0x10f767(0x1b3),'trend':'{\x20\x22direction\x22:\x20\x22up\x22,\x20\x22pct\x22:\x20\x222.6\x22\x20}','points':'[{\x20\x22period\x22:\x20\x222026-04-24\x22,\x20\x22value\x22:\x20\x221850\x22\x20},\x20...\x20]'},'referenceWidgetId':'avg_daily_sales','socNotes':a0_0x10f767(0x1af)},{'id':'metric_progress_to_goal','name':'Metric\x20+\x20Progress\x20to\x20Goal','useCase':'Headline\x20metric\x20with\x20trend\x20chip\x20and\x20progress\x20bar\x20against\x20a\x20period\x20target.\x20Suitable\x20for\x20widgets\x20like\x20\x27Orders\x20This\x20Month\x27.','payloadShape':{'id':a0_0x10f767(0x1c8),'queries':{'value':a0_0x10f767(0x1d7),'trend':'file:query/<path>/trend.sql','target':a0_0x10f767(0x1cf)}},'sqlShapesPerKey':[{'key':'value','shape':a0_0x10f767(0x1c6),'outputColumns':['value\x20(or\x20current)'],'collapseRule':a0_0x10f767(0x1a6)},{'key':a0_0x10f767(0x18f),'shape':'1\x20row\x20×\x202\x20columns','outputColumns':[a0_0x10f767(0x1ce),a0_0x10f767(0x1d4)],'collapseRule':a0_0x10f767(0x1ad)},{'key':'target','shape':'1\x20row\x20×\x201\x20column','outputColumns':[a0_0x10f767(0x1cc)],'collapseRule':'scalar\x20primitive'}],'responseShape':{'value':'\x221836\x22','trend':'{\x20\x22direction\x22:\x20\x22down\x22,\x20\x22pct\x22:\x20\x222.2\x22\x20}','target':a0_0x10f767(0x1c7)},'referenceWidgetId':'orders_this_month','socNotes':'Frontend\x20computes\x20to_goal\x20=\x20target\x20-\x20value\x20and\x20pct\x20=\x20round(value\x20/\x20target\x20*\x20100)\x20for\x20the\x20progress\x20bar.\x20Visual\x20width\x20is\x20presentational\x20and\x20must\x20NOT\x20live\x20in\x20the\x20backend\x20payload.\x20If\x20progress\x20involves\x20complex\x20business\x20rules\x20(e.g.\x20exclude\x20weekends,\x20prorated\x20workdays),\x20use\x20a\x20single\x20multi-column\x20query\x20so\x20\x27pct\x27\x20is\x20a\x20stable\x20business\x20fact\x20rather\x20than\x20visual\x20width.'}],NAMING_CONVENTION={'dashboardName':{'constraint':'MUST\x20start\x20with\x20\x27dash-\x27\x20prefix','minLength':0x6,'maxLength':0x32,'regex':a0_0x10f767(0x185),'examples':[a0_0x10f767(0x1c0),'dash-inbound','dash-author-stats'],'rationale':a0_0x10f767(0x181)}},URL_PATTERN={'method':'POST','path':'/api/{project}/{name}/dashboard','exampleFull':a0_0x10f767(0x1bb),'requestBodyShape':{'params':a0_0x10f767(0x1b8),'widgets':a0_0x10f767(0x1d0)},'responseShape':{'envelope':'{\x20success:\x20boolean,\x20data:\x20{\x20<widgetId>:\x20<perWidgetResponse>,\x20...\x20}\x20}','perWidgetResponse':'Determined\x20by\x20scalarCollapseRules.\x20Failed\x20widgets\x20produce\x20{\x20error:\x20\x27...\x27\x20}\x20block\x20with\x20top-level\x20success\x20still\x20true\x20(one\x20widget\x20failure\x20does\x20NOT\x20fail\x20the\x20dashboard).'}},FILE_REFERENCE_CONVENTION={'format':a0_0x10f767(0x1ba),'pathRelativeTo':'payload\x20JSON\x20file\x20location','fileExtensionPolicy':a0_0x10f767(0x1ca),'resolvedAt':'generation\x20time\x20(NOT\x20runtime)','embedStrategy':a0_0x10f767(0x1cd),'implication':'Updating\x20an\x20SQL\x20file\x20requires\x20regenerating\x20the\x20dashboard\x20module\x20(\x27codegen_create_dashboard\x27)\x20for\x20changes\x20to\x20take\x20effect.'},PLACEHOLDER_CONVENTION={'format':a0_0x10f767(0x17f),'regex':a0_0x10f767(0x19a),'regexNotes':'Negative\x20lookbehind\x20prevents\x20matching\x20\x27::\x27\x20(Postgres\x20cast\x20syntax)\x20as\x20a\x20placeholder.','scanScope':a0_0x10f767(0x1d2),'constraint':'Every\x20placeholder\x20used\x20in\x20SQL\x20MUST\x20be\x20declared\x20in\x20\x27params\x27.\x20Validator\x20throws\x20Error\x20with\x20message\x20format:\x20\x22Widget\x20\x27<id>\x27\x20query\x20\x27<label>\x27\x20uses\x20undeclared\x20placeholder\x20\x27:<token>\x27\x20(declare\x20in\x20\x27params\x27)\x22.','exampleSql':'SELECT\x20*\x20FROM\x20stock_inbound\x20WHERE\x20EXTRACT(YEAR\x20FROM\x20inbound_date)\x20=\x20:year','exampleParamDeclaration':'{\x20\x22params\x22:\x20{\x20\x22year\x22:\x20{\x20\x22type\x22:\x20\x22number\x22,\x20\x22required\x22:\x20true\x20}\x20}\x20}'},CACHE_SPEC={'container':'top-level\x20\x27cache\x27\x20object','optional':!![],'rationale':'Dashboard\x20endpoint\x20may\x20opt-in\x20to\x20Redis-based\x20cache.\x20Pattern\x20follows\x20processor\x20cache\x20(see\x20feat-cache.md).\x20Cache\x20scope\x20is\x20the\x20full\x20response\x20envelope;\x20one\x20cache\x20entry\x20per\x20(params\x20+\x20widgets[]\x20subset)\x20combination.','fields':[{'name':'enabled','type':a0_0x10f767(0x1d5),'required':!![],'description':a0_0x10f767(0x1a2)},{'name':a0_0x10f767(0x1d6),'type':'number','required':![],'constraint':'>=\x200\x20(seconds)','default':'inherits\x20CACHE_TTL\x20env','description':a0_0x10f767(0x1b7)},{'name':'invalidates','type':a0_0x10f767(0x18c),'required':![],'default':'[]','description':a0_0x10f767(0x1a1)}],'validation':{'sqlCrossReference':a0_0x10f767(0x1a0),'errorOn':[a0_0x10f767(0x1c3),'Table\x20declared\x20in\x20invalidates,\x20but\x20not\x20detected\x20in\x20any\x20widget\x20SQL\x20(typo\x20or\x20dead\x20entry)'],'warningOn':['Table\x20detected\x20in\x20SQL,\x20but\x20not\x20registered\x20as\x20CRUD\x20endpoint\x20in\x20metadata\x20project\x20(likely\x20a\x20view,\x20CTE\x20alias,\x20or\x20cross-project\x20table\x20—\x20cascade\x20will\x20not\x20fire)']}},DOCUMENTATION_URL=a0_0x10f767(0x19e),DASHBOARD_CATALOG={'schemaVersion':'1.0','source':'dashboard-catalog','summary':{'totalAllowedTopLevelFields':PAYLOAD_SHAPE[a0_0x10f767(0x1b5)][a0_0x10f767(0x1b9)],'totalForbiddenFrontendFields':FORBIDDEN_FRONTEND_FIELDS['length'],'totalParamTypes':ALLOWED_PARAM_TYPES[a0_0x10f767(0x1b9)],'totalScalarCollapseRules':SCALAR_COLLAPSE_RULES[a0_0x10f767(0x1b9)],'totalCommonWidgetPatterns':COMMON_WIDGET_PATTERNS[a0_0x10f767(0x1b9)]},'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};function a0_0x1b52(_0x47edfb,_0x4232a4){_0x47edfb=_0x47edfb-0x17f;const _0xaa7dba=a0_0xaa7d();let _0x1b5232=_0xaa7dba[_0x47edfb];if(a0_0x1b52['JdJtkH']===undefined){var _0x590e5e=function(_0x41e4a8){const _0x2cf039='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x58eedc='',_0xe8223f='';for(let _0x29c237=0x0,_0xc24a8e,_0x4a0b83,_0x3b14c9=0x0;_0x4a0b83=_0x41e4a8['charAt'](_0x3b14c9++);~_0x4a0b83&&(_0xc24a8e=_0x29c237%0x4?_0xc24a8e*0x40+_0x4a0b83:_0x4a0b83,_0x29c237++%0x4)?_0x58eedc+=String['fromCharCode'](0xff&_0xc24a8e>>(-0x2*_0x29c237&0x6)):0x0){_0x4a0b83=_0x2cf039['indexOf'](_0x4a0b83);}for(let _0x47d892=0x0,_0x35e381=_0x58eedc['length'];_0x47d892<_0x35e381;_0x47d892++){_0xe8223f+='%'+('00'+_0x58eedc['charCodeAt'](_0x47d892)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0xe8223f);};a0_0x1b52['udMYia']=_0x590e5e,a0_0x1b52['LAjQYv']={},a0_0x1b52['JdJtkH']=!![];}const _0x41a2a3=_0xaa7dba[0x0],_0x31cceb=_0x47edfb+_0x41a2a3,_0x27b632=a0_0x1b52['LAjQYv'][_0x31cceb];return!_0x27b632?(_0x1b5232=a0_0x1b52['udMYia'](_0x1b5232),a0_0x1b52['LAjQYv'][_0x31cceb]=_0x1b5232):_0x1b5232=_0x27b632,_0x1b5232;}function a0_0xaa7d(){const _0x578d2e=['ue9tvcaVyxbPl21PBMKTAw52zw50B3j5l2rHC2GTAw5IB3vUzc9KyxnOyM9HCMq','u2LUz2XLifnrtcbXDwvYEsbMB3iGDgHLihDPzgDLDc4','yxjYyxKGB2yGB2jQzwn0CW','zMLSztPXDwvYEs88Cgf0Ad4VyNjLywTKB3DUlNnXBa','zgvMyxvSDa','zgfZAc1ZywXLCW','ugvYlwTLEsbIyxnLzcbVBIbZy2fSyxjdB2XSyxbZzvj1BgvZigjLBg93lG','ntznAhn6Evi','vgfIBguGyxbWzwfYCYbPBIbtuuWGqu5eigLUig1LDgfKyxrHihbYB2PLy3qSigj1DcbTAxnZAw5NigzYB20GAw52ywXPzgf0zxmGkgnHy2HLihn0ywXLihjPC2SP','mta1otqXmvz4zM9OAq','D2LKz2v0vhLWzq','msbYB3CGW5CGmsbJB2X1Bw4','iJi4odqI','phDPzgDLDf9Pzd4','C3rYAw5N','zNjLztSGlNnXBcbYzwnVBw1LBMrLzcbMB3iGzwrPDg9YigHPz2HSAwDODa','A2v54OAszMLSztPYzwXHDgL2zs9WyxrOl3rVl3f1zxj5lNnXBa','DgfYz2v0','u1fmigzPBguGy29UDgvUDcbPCYbLBwjLzgrLzcbHCYbkyxzHu2nYAxb0ihrLBxbSyxrLigXPDgvYywWGAw5ZAwrLihrOzsbNzw5LCMf0zwqGBw9KDwXLigzPBguUifj1BNrPBwuGCgvYzM9YBxmGEMvYBYbKAxnRieKVtYbWzxiGCMvXDwvZDcdIGjqGywXSifnrtcbPCYbPBIbTzw1VCNKGywz0zxiGBw9KDwXLigXVywqU','zgLYzwn0Aw9U','zMLSztPXDwvYEs88Cgf0Ad4VDgfYz2v0lNnXBa','yxjYyxK8C3rYAw5NpIWGB3b0Aw9UywWG4Ocuihn1yNnLDcbVzIb3AwrNzxqGsurZihrVigv4zwn1DguUie9TAxqGDg8GzxHLy3v0zsbHBgWGzgvJBgfYzwqGD2LKz2v0CY4','CgfYyw1Z','qwXSihDPzgDLDcbtuuWG4OcuigjVDgGGj3f1zxj5jYaOC2LUz3vSyxiPigfUzcbLDMvYEsaNCxvLCMLLCY48A2v5pICU','mtq0mdaWnNv0v2rsqG','Cgn0','yM9VBgvHBG','DhrS','zMLSztPXDwvYEs88Cgf0Ad4Vy3vYCMvUDc5ZCwW','oNbHCMfTtMfTzq','rgvMyxvSDcb2ywX1zsbHChbSAwvKihDOzw4GDgHLihjLCxvLC3qGB21PDhmGDgHPCYbWyxjHBs4GvMfSAwrHDg9YigrVzxmGtK9uihn0CMLJDgX5ihr5CguTy2HLy2SGzgvMyxvSDdSGCNvUDgLTzsbPCYbYzxnWB25ZAwjSzsbMB3iGy29TCgf0AwjPBgL0Es4','vgHLihbYzwzPEcbIzwnVBwvZihbHCNqGB2yGDgHLifvstcbZzwDTzw50lIbuAguGCMvZzxj2zwqGC2nOzw1LigTLzxbZigrHC2HIB2fYzcbLBMrWB2LUDhmGDMLZDwfSBhKGzgLZDgLUy3qGzNjVBsbduLveigvUzhbVAw50CYbPBIb0AguGvvjmihnWywnLigfUzcbHBgXVD3mGzNv0DxjLihjVDxrPBMCGzgLMzMvYzw50Awf0Aw9UlG','tIbYB3DZimoxidiGy29SDw1UCW','tgLZDcbVzIb3AwrNzxqGzgvMAw5PDgLVBNmUie9YzgvYigLZigLUzM9YBwf0Aw9UywWGB25SEsaOCMvZCg9UC2uGA2v5CYbHCMuGyNKGD2LKz2v0igLKlcbUB3qGyxjYyxKGAw5KzxGPlG','Bwv0CMLJx2rVBNv0x2jYzwfRzg93BG','xMrHC2GTw2eTEKeTwJaTov8TxsSK','rNjVBNrLBMqGzgv0zxjTAw5LCYbKB251Dc9WAwuGDMfYAwfUDcWGy29SB3iGCgvYignHDgvNB3j5lcbHBMqGBgfIzwWGB3jKzxiUieLMihbLCI1JyxrLz29YEsbWzxjJzw50ywDLigLZig5LzwrLzcbMB3iGDgHLigrVBNv0igfYyYWGzNjVBNrLBMqGy29TChv0zxmGAxqGzNjVBsbPDgvTC1TPxs52ywX1zsaVihn1BsHPDgvTC1SQxs52ywX1zsKUie5Vig5LzwqGDg8GC2vUzcaNCgn0jYbMCM9TigjHy2TLBMqGDw5SzxnZihrOzsbMAwD1CMuGAxmGysbZDgfIBguGyNvZAw5LC3mGy2fSy3vSyxrPB24GAw5KzxbLBMrLBNqGB2yGDMLZDwfSihjLBMrLCMLUzY4','nty1oti1r0Lbv3fX','zMLSztPXDwvYEs88Cgf0Ad4VDMfSDwuUC3fS','msbYB3CGW5CGmIbJB2X1Bw5Z','ugfYyw1LDgvYignVBNrYywn0igzVCIb0AguGzgfZAgjVyxjKlIbfywnOigTLEsbPCYbHihbHCMfTig5HBwu7ihzHBhvLCYbKzxnJCMLIzsb0ExbLl3jLCxvPCMvKl2rLzMf1BhqUifbSywnLAg9SzgvYCYbPBNnPzguGD2LKz2v0ifnrtcbTDxn0ihjLzMvYzw5JzsbKzwnSyxjLzcbWyxjHBsbUyw1LCY4','AxrLBxm','yxjYyxK8C3rYAw5NpG','iNzHBhvLiJOGiJy5nZaWiG','zMLSztPXDwvYEs88Cgf0Ad4VDhjLBMqUC3fS','DhjLBMq','iML0zw1ZiJOGw3SGiMXHyMvSiJOGiLnOB2vZiIWGiNzHBhvLiJOGiJC2nJaIih0Sic4UlL0','vuKGBgfIzwWGAxmGysbMCM9UDgvUzcbYzw5KzxjPBMCGy29Uy2vYBI4','mZu2nJDIufnMqw8','D2LKz2v0lNf1zxjPzxmUpgTLEt4GD2L0AcbtuuWGCMv0DxjUAw5NideGCM93imoxideGy29SDw1U','qwX3yxLZihSGAxrLBxm6ifSUlI5Dih0GCMvNyxjKBgvZCYbVzIbtuuWGCMvZDwX0ihnOyxbLlG','twv0CMLJicSGu3bHCMTSAw5L','ndmXmtG2zeHYrKTZ','C2HHCguTy29UzMXPy3q','DMfSDwu','Bgf5B3v0','kd88itOPoIHBys16qs1Ax11Bys16qs1Amc05x10Qkq','yw55icHTDxn0igjLignVBxbHDgLIBguGD2L0AcbKzwnSyxjLzcaNDhLWzsCP','CxvLCMLLCW','BNvTyMvY','Ahr0Chm6lY9Yzxn0zM9Yz2uUzgv2l2rVy3mVC2vYDMvYl3f1zxj5lwrHDgeVzgfZAgjVyxjK','zNjVBNrLBMqTy29Uy2vYBG','v2HLBIbJywnOzs5LBMfIBgvKid09psb0CNvLigfUzcbPBNzHBgLKyxrLCYbPCYbUB24Tzw1WDhK6ihzHBgLKyxrVCIbLEhrYywn0CYb0ywjSzsbJyw5KAwrHDgvZigzYB20GD2LKz2v0ifnrtcaOCMvNzxGGrLjpts9kt0LoksWGy3jVC3mTCMvMzxjLBMnLCYb3AxrOig1LDgfKyxrHl3TWCM9Qzwn0Fs5QC29UicHLBMrWB2LUDhnBkL0UDgfIBgvoyw1LihDOzxjLihr5CguGpt09icjTB2r1BguIksWGyw5KigfZC2vYDhmGzxf1ywXPDhKGB2yGzxHWzwn0zwqGDNmGzgvJBgfYzwqGC2v0CY4GtwLZBwf0y2HLCYbHCMuGCMvWB3j0zwqGCgvYignHDgvNB3j5icHTAxnZAw5NlcbLEhrYysWGDw5TyxrJAgvKks4','tgLZDcbVzIbduLveihrHyMXLig5HBwvZihrOyxqSihDOzw4GD3jPDhrLBIWGD2LSBcb0CMLNz2vYigLUDMfSAwrHDgLVBIbVzIb0AgLZigrHC2HIB2fYzcbJywnOzs4','vg9Nz2XLignHy2HLigzLyxr1CMuGzM9YihrOAxmGzgfZAgjVyxjKlG','D2LKz2v0lNf1zxj5icHZAw5NDwXHCIK','ntG5mtjbrgvsrNm','BM9UlwvTChr5lcb1BMLXDwuGywnYB3nZihDPzgDLDhmGAw4GDgHLihnHBwuGCgf5Bg9Hza','C2nHBgfYihbYAw1PDgL2zq','mta0nZm4offMBMzfEG','txvSDgKTu1fmihDPzgDLDc4GrwfJAcbRzxKGyMvJB21LCYbHigTLEsbPBIb0AguGCMvZCg9UC2uGB2jQzwn0lG','D2LKz2v0CW','msbYB3CGW5CGmsbJB2WSig91Dhb1DcbJB2X1Bw4Gj3zHBhvLjW','yw55icGXihjVDYddLYaXignVBcWGtIbYB3DZimoxie0Gy29SCYWGzxrJlIK','mMH0r09YBW','B2jQzwn0','CMvXDwLYzwq','u3bHCMTSAw5LigXPyNjHCMLLCYaOqxbLEenOyxj0CYWGq2HHCNrPC3qSigv0yY4Pihr5CgLJywXSEsbUzwvKigeGCgXHAw4GBNvTyMvYigfYCMf5lIbgCM9UDgvUzcbTyxbZihbVAw50CY5TyxaOCca9pIbWlNzHBhvLks4GvgHLicDWzxjPB2qNigzPzwXKihn0yxLZigzVCIb0B29SDgLWigfUzcbNyxaTCMvZAwXPzw5JzsbHz2fPBNn0ig1PC3nPBMCGzgf5CY4GvxnLigDLBMvYyxrLx3nLCMLLCYbPBIbtuuWGDg8Gzw5ZDxjLignVBNnPC3rLBNqGCM93ignVDw50igv2zw4GzM9YigrHExmGD2L0AcbUBYb0CMfUC2fJDgLVBNmU','ugfYyw0GBMfTzsbTDxn0ig1HDgnOihrOzsbWBgfJzwHVBgrLCIbYzwDLEcbGw2eTEKeTwL9Dw2eTEKeTwJaTov9DkMaGkgfSCgHHBNvTzxjPyYaRihvUzgvYC2nVCMuSig11C3qGC3rHCNqGD2L0AcbSzxr0zxiGB3iGDw5KzxjZy29YzsKU','D2LKz2v0lNf1zxjPzxmUpgTLEt4GD2L0AcbtuuWGCMv0DxjUAw5Nie4GCM93CW','zxHWzwn0zwrFzwfYBMLUz3m','iJi0mJaI','DhLWzq','Dg9Wtgv2zwXbBgXVD2vK','iNrYzw5KiJOGEYaIzgLYzwn0Aw9UiJOGiNvWiIWGiNbJDci6iciYlJiIih0','vgLTzs10BY1SAxzLigLUihnLy29UzhmUidaGzwzMzwn0AxzLBhKGzgLZywjSzxmGy2fJAguGzM9YihrOAxmGzw50CNKU','B2jQzwn0iokaLcb2ywX1zxmGzM9YigrLy2XHCMvKihbHCMfTCYaODMfSAwrHDgvKigfNywLUC3qGCgfYyw1ZignVBNrYywn0oYbTAxnZAw5NihjLCxvPCMvKiokgKIa0mdaSihr5CguGBwLZBwf0y2GG4OAsidqWmcK','BgvUz3rO','zMLSztPYzwXHDgL2zs9WyxrOl3rVl3f1zxj5lNnXBa'];a0_0xaa7d=function(){return _0x578d2e;};return a0_0xaa7d();}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
function
|
|
1
|
+
const a0_0x3aeee5=a0_0x5b9d;function a0_0x4050(){const _0x12537d=['u0vsvKvsx1bpuLq','yM9VBgvHBG','C3rYAw5N','mtu4mZC5mhLWvefTDW','mZa5mdKWnK5VzhjUzG','AgfZ','v1rTswu','nda3mdyXnNLnCKDtBa','nty5me5Zt01qzW','ndeWoeXNAgPysW','DhjPBq','mJH2sKnJsuy','mty2mJnIDMvWzwG','CxPVtNu','iYbfBNzPCM9UBwvUDaOJie9WDgLVBNm6ihbYB2r1y3rPB24GFcbKzxzLBg9WBwvUDaOJicDKzxzLBg9WBwvUDcCGzxHWB3nLCYbLEhrYysbLCNjVCIbKzxrHAwWGkguUzY4GDMfSAwrgAwvSzhmGBgLZDcWGzxjYB3iGC3rHy2SPlGOJieTLzxaGj3bYB2r1y3rPB24NigLUigrLCgXVEwvKigvUDMLYB25Tzw50CYb0BYbHDM9PzcbPBMzVCM1HDgLVBIbKAxnJBg9ZDxjLlGPot0rfx0vovJ1WCM9KDwn0Aw9UcGOJieXPy2vUC2ukteLdru5trt1ywfHylvHywfGTwfHywc1ywfHycGOJifnLCNzLCGPtrvjwrvjFqureuKvtuZ0XmJCUmc4WlJeku0vsvKvsx1bpuLq9mZaWmaOkiYbmAxzLifn5BMmGkfDLyLnVy2TLDcKGq29UzMLNDxjHDgLVBGOJie5pveu6ieXjvKvFu1Loq19ftKfctevepxrYDwuGCMvXDwLYzxmGyw4GqvbjieTLEsaOs0vzps4UlIKGDg8Gyxv0AgvUDgLJyxrLifDLyLnVy2TLDcbJBgLLBNrZcKXjvKvFu1Loq19ftKfctevepwzHBhnLcKXjvKvFu1Loq19qt1juptmWmZmkcImGuMvKAxmGq29UzMLNDxjHDgLVBGPsrurju19it1nupwXVy2fSAg9ZDaPsrurju19qt1juptyZodakuKvesvnFueftu1DpuKq9cLjfreLtx0rcptakcImGrxHWB3j0ienVBMzPz3vYyxrPB24krvHqt1jux0zjtevFrvHqsvjzptm2mdaWmdakrvHqt1jux0nivu5lx1njwKu9mtaWmaOkiYblywzRysbdB25MAwD1CMf0Aw9UcKTbrKTbx0voqujmruq9zMfSC2ukiYbcCM9RzxiGBgLZDcaOy29TBweTC2vWyxjHDgvKigzVCIbTDwX0AxbSzsbICM9RzxjZoIbICM9RzxiXoJKWotiSyNjVA2vYmJO5mdKYlgjYB2TLCJm6ota5mIKks0fgs0fFqLjps0vsuZ1SB2nHBgHVC3q6ota5mGOJienSAwvUDcbjrcaOB3b0Aw9UywWSigrLzMf1Bhq6ihjLC3rMB3jNzs17ChjVAMvJDh0TChjVzhvJzxiGlYaTy29UC3vTzxiPcImGs0fgs0fFq0Xjru5ux0LepqPlquzlqv9dt05orunusu9ox1rjtuvpvvq9mZaWmaPlquzlqv9srvfvrvnux1rjtuvpvvq9mJuWmdaks0fgs0fFve9qsunFuefuvevstJ17Bw9KDwXLFs57zw5KCg9PBNr9lMv2zw50CWPlquzlqv9uru5btLrFsuq9zgvMyxvSDaPlquzlqv9trvntsu9ox1rjtuvpvvq9mZaWmdaks0fgs0fFsevbuLrcrufux0LovevsvKfmptmWmdaks0fgs0fFtufyx0jzvevtx1bfuL9qqvjusvrjt049mta0odu3nGPlquzlqv9bvvrpx0nptu1jvd1MywXZzqPlquzlqv9bvvrpx0nptu1jvf9jtLrfuLzbtd01mdaWcKTbrKTbx1jfvfjzx0fuvevnufrtptmks0fgs0fFuKvuuLLFrevmqvK9mtaWmaPlquzlqv9srvrswv9nqvHFrevmqvK9mZaWmdaks0fgs0fFu1nmpwzHBhnLcKTbrKTbx0Xpr19mrvzftd1PBMzVcImGu0fttcbbDxrOzw50AwnHDgLVBIaOB3b0Aw9UywWSihvUy29TBwvUDcbPzIb0AguGyNjVA2vYihjLCxvPCMvZigf1DgHLBNrPy2f0Aw9UkqOJifn1ChbVCNrLzcbTzwnOyw5PC21ZoIbWBgfPBIWGC2nYyw0TC2HHlti1nIWGC2nYyw0TC2HHltuXmGOJieTbrKTbx1nbu0XFtuvdsefosvnnpxbSywLUcImGs0fgs0fFu0fttf9vu0vstKfnrt0kiYblquzlqv9tqvnmx1bbu1nxt1jepqOkiYbeyxrHyMfZzsbdB25MAwD1CMf0Aw9UcImGu3vWCg9YDgvKoIbWB3n0z3jLC3fSlcbTExnXBcWGB3jHy2XLlcbZCwXPDgukrejFvfLqrt1WB3n0z3jLC3fScKrcx0Hpu1q9mti3lJaUmc4XcKrcx1bpuLq9ntqZmGPeqL9vu0vspxbVC3rNCMvZcKrcx1bbu1nxt1jepxLVDxjFCgfZC3DVCMrFAgvYzqPeqL9oqu1fpxLVDxjFzgf0ywjHC2vFBMfTzqOJiezVCIbtuuXPDgu6ihnLDcbeqL9uwvbfpxnXBgL0zsbHBMqGrejFtKfnrt0Ul2rHDgeVBxLHChaUzgikiYbeqL9it1nulcbeqL9qt1julcbeqL9vu0vslcbeqL9qqvntv09srcbHCMuGAwDUB3jLzcbMB3iGu1fmAxrLcGOJifrLBMfUy3KkiYburu5btLrFtu9ertOGC2LUz2XLicHKzwzHDwX0ksdIGjqGB25Lig9Yz2fUAxPHDgLVBIWGBM8GDgvUyw50igzPBhrLCMLUzWOJicaGicaGicaGicaGicbTDwX0AsaGicaGicaGicaGiokaLcbKyxrHihbHCNrPDgLVBMvKigj5ihrLBMfUDdSGvevoqu5ux0nptfvntIbYzxf1AxjLzaOJifrftKfovf9dt0Xvtu46ignVBhvTBIbUyw1LihvZzwqGyxmGDgvUyw50igLKzw50AwzPzxiGAw4GzxzLCNKGDgfIBguGkg11BhrPig9UBhKPcLrftKfovf9nt0rfpxnPBMDSzqPuru5btLrFq09mvu1opxrLBMfUDf9PzaOkiYbdB2rLieDLBMvYyxrPB24kiYbgs19bvvrpx0Ppsu4Gy29UDhjVBhmGDgHLiePpsu4GDhLWzsb1C2vKigLUihbHEwXVywqGC3LUyYaTlwv4CgfUzc1MAY4kiYbSzwz0ica6ieXfrLqGsK9jtIdIGjqGywXSihjLy29YzhmGC2HVD24SiezlignVBhvTBIbTyxKGyMuGtLvmtcaOzgf0ysbJB21WBgv0zw5LC3mPcImGAw5UzxiGoIbjtK5fuIbkt0LoiokaLcbVBMX5ihjLy29YzhmGD2L0Acb2ywXPzcbgsYbYzwzLCMvUy2vZihnOB3DUicHZDhjPy3qGAw50zwDYAxr5kqPgs19bvvrpx0Ppsu49BgvMDaOkiYbmB2DNAw5NienVBMzPz3vYyxrPB24kte9hx0XfvKvmpwrLyNvNcKXpr19ut19gsuXfpxrYDwukcImGu1fmieXVz2DPBMCku1fmx0Xpr19ftKfctevepwzHBhnLcLnrtf9mt0DFtevwruW9zgvIDwCku1fmx0Xpr19qqvjbtvm9zMfSC2uku1fmx0Xpr19tte9xx1riuKvtse9mrd0XmdaWcGOJienHy2HLienVBMzPz3vYyxrPB24kq0fdsevFru5bqKXfrd1MywXZzqPdqunirv9uveW9mZaWcGOJiePVyIbty2HLzhvSzxiksK9cx0voqujmruq9zMfSC2uksK9cx0nptKnvuLjftKnzptuksK9cx1jfvevoveLptL9it1vsuZ03mGPkt0jFrKfjtevex1jfvevoveLptL9it1vsuZ0XnJGksK9cx1nivvret1Dox1rjtuvpvvq9mtaWmdaksK9cx1nuquXmrurFsu5urvjwquW9mZaWmdaksK9cx01bwf9tvefmtevex0npvu5uptikcImGrgLZDhjPyNv0zwqGtg9JAYbdB25MAwD1CMf0Aw9UcKXpq0TFreLtvfjjqLvururFru5bqKXfrd1MywXZzqPmt0nlx0rju1rssujvvevex1rutd0XmaPmt0nlx1jfu09vuKnfx01bwf9uveW9nJaWcKXpq0TFreLtvfjjqLvururFuKvuuLK9mWPmt0nlx0rju1rssujvvevex1jfvfjzx0rftefzpteWmaPmt0nlx0rju1rssujvvevex1nuuKfuruDzpxjLAMvJDaOkiYbjrcbhzw5LCMf0B3iGq29UzMLNDxjHDgLVBGPjreDftL9ftKfctevepwzHBhnLcKLer0vox0Leru1FvfrmptyWmaPjreDftL9dt1vovevsx1rutf9nt05useXzpti3nJq4mdaksurhru5Fq09vtLrfuL9uveXFrefjtfK9mtCYodaWcKLer0vox0rfrKfvtfrFtufyx1jfvfjzpteWcKLer0vox0rfrKfvtfrFueLox0rjr0LuuZ02cKLer0vox0rfrKfvtfrFu0vssufmx1bbvfrfuK49wfHywc1ywfHylvHywfGTwfHywaPjreDftL9eruzbvuXux0nprevFuefuvevstJ05otK5ltK5otKksurhru5FquXmt1DFuKvtrvq9zMfSC2uk','C2XPy2u','odmXntGYtM1WC1P6','C3bSAxq','Aw5JBhvKzxm','ChvZAa','rejFtKfnrq','DgvZDa','BgvUz3rO','zxHWB3j0CW','teLdru5trq','ndu5mZC4AvHsqwjf','nhDuz1PLEq'];a0_0x4050=function(){return _0x12537d;};return a0_0x4050();}(function(_0x4bed35,_0x54e36b){const _0x2d28da=a0_0x5b9d,_0x22d41a=_0x4bed35();while(!![]){try{const _0x3aee15=parseInt(_0x2d28da(0x1f6))/0x1*(parseInt(_0x2d28da(0x1f8))/0x2)+parseInt(_0x2d28da(0x1fd))/0x3*(-parseInt(_0x2d28da(0x207))/0x4)+parseInt(_0x2d28da(0x20b))/0x5+parseInt(_0x2d28da(0x206))/0x6+-parseInt(_0x2d28da(0x1f1))/0x7+-parseInt(_0x2d28da(0x1f4))/0x8+-parseInt(_0x2d28da(0x1f9))/0x9*(-parseInt(_0x2d28da(0x1f5))/0xa);if(_0x3aee15===_0x54e36b)break;else _0x22d41a['push'](_0x22d41a['shift']());}catch(_0x439d55){_0x22d41a['push'](_0x22d41a['shift']());}}}(a0_0x4050,0x42f15));const DB_CONNECTION_ENV_TEMPLATE=a0_0x3aeee5(0x1fb),REQUIRED_KEYS=new Set([a0_0x3aeee5(0x205),'SERVER_ADDRESS',a0_0x3aeee5(0x208),'DB_TYPE','DB_HOST','DB_PORT','DB_USER','DB_PASSWORD',a0_0x3aeee5(0x201)]);function a0_0x5b9d(_0x18a498,_0x328162){_0x18a498=_0x18a498-0x1f1;const _0x405020=a0_0x4050();let _0x5b9d0d=_0x405020[_0x18a498];if(a0_0x5b9d['AHnnMB']===undefined){var _0x2eb82f=function(_0x115625){const _0x366eaf='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x447b4c='',_0x5a3c5f='';for(let _0x288cb7=0x0,_0x1c177c,_0x2d4c57,_0x4d0a3b=0x0;_0x2d4c57=_0x115625['charAt'](_0x4d0a3b++);~_0x2d4c57&&(_0x1c177c=_0x288cb7%0x4?_0x1c177c*0x40+_0x2d4c57:_0x2d4c57,_0x288cb7++%0x4)?_0x447b4c+=String['fromCharCode'](0xff&_0x1c177c>>(-0x2*_0x288cb7&0x6)):0x0){_0x2d4c57=_0x366eaf['indexOf'](_0x2d4c57);}for(let _0x54b4b=0x0,_0x3b8604=_0x447b4c['length'];_0x54b4b<_0x3b8604;_0x54b4b++){_0x5a3c5f+='%'+('00'+_0x447b4c['charCodeAt'](_0x54b4b)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x5a3c5f);};a0_0x5b9d['seYiQp']=_0x2eb82f,a0_0x5b9d['yrIKwY']={},a0_0x5b9d['AHnnMB']=!![];}const _0x32511d=_0x405020[0x0],_0x468f0a=_0x18a498+_0x32511d,_0x2ffa0c=a0_0x5b9d['yrIKwY'][_0x468f0a];return!_0x2ffa0c?(_0x5b9d0d=a0_0x5b9d['seYiQp'](_0x5b9d0d),a0_0x5b9d['yrIKwY'][_0x468f0a]=_0x5b9d0d):_0x5b9d0d=_0x2ffa0c,_0x5b9d0d;}function parseTemplateAsSchema(_0x4264f2){const _0x251604=a0_0x3aeee5,_0x5d6b5e={'qbjOh':function(_0x30e761,_0x1f2a9f){return _0x30e761<_0x1f2a9f;},'WTmIe':function(_0x3aa1f5,_0xd4e9ce){return _0x3aa1f5===_0xd4e9ce;},'LjkwB':function(_0x2dd350,_0x22948f){return _0x2dd350+_0x22948f;},'qzoNu':_0x251604(0x20a),'drswX':'true'},_0x455a35=_0x4264f2||DB_CONNECTION_ENV_TEMPLATE,_0x1addb1=_0x455a35[_0x251604(0x1fe)]('\x0a'),_0x4bda28=[];let _0x24cf57=null,_0x4bebfe=[];for(const _0x511a5e of _0x1addb1){const _0x172796=_0x511a5e[_0x251604(0x1f7)]();if(_0x172796===''){_0x4bebfe=[];continue;}if(_0x172796['startsWith']('#')){const _0x5828f2=_0x172796[_0x251604(0x1fc)](0x1)[_0x251604(0x1f7)](),_0xead778=_0x5828f2['length']>0x0&&_0x5d6b5e['qbjOh'](_0x5828f2[_0x251604(0x203)],0x3c)&&!_0x5828f2[_0x251604(0x1ff)](':')&&!/^[A-Z_]+=/[_0x251604(0x202)](_0x5828f2)&&/^[A-Z]/['test'](_0x5828f2);_0xead778&&_0x5d6b5e[_0x251604(0x1f3)](_0x4bebfe['length'],0x0)?_0x24cf57=_0x5828f2:_0x4bebfe['push'](_0x5828f2);continue;}const _0xc0a5f2=_0x511a5e['indexOf']('=');if(_0xc0a5f2>0x0){const _0x138bd6=_0x511a5e[_0x251604(0x1fc)](0x0,_0xc0a5f2)[_0x251604(0x1f7)](),_0x2d4d9f=_0x511a5e[_0x251604(0x1fc)](_0x5d6b5e['LjkwB'](_0xc0a5f2,0x1));let _0xa21737=_0x5d6b5e[_0x251604(0x1fa)];if(_0x2d4d9f===_0x5d6b5e['drswX']||_0x2d4d9f==='false')_0xa21737=_0x251604(0x209);else/^-?\d+$/['test'](_0x2d4d9f)&&(_0xa21737='integer');_0x4bda28[_0x251604(0x200)]({'name':_0x138bd6,'section':_0x24cf57,'type':_0xa21737,'default':_0x2d4d9f,'description':_0x4bebfe['join']('\x20')||null,'required':REQUIRED_KEYS[_0x251604(0x1f2)](_0x138bd6)}),_0x4bebfe=[];}}return _0x4bda28;}module[a0_0x3aeee5(0x204)]={'DB_CONNECTION_ENV_TEMPLATE':DB_CONNECTION_ENV_TEMPLATE,'REQUIRED_KEYS':REQUIRED_KEYS,'parseTemplateAsSchema':parseTemplateAsSchema};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
'use strict';const a0_0x4291a0=a0_0x2ae1;(function(_0x5f1a7e,_0x839fc1){const _0x12cb63=a0_0x2ae1,_0x5205a1=_0x5f1a7e();while(!![]){try{const _0x382e24=-parseInt(_0x12cb63(0xfc))/0x1+parseInt(_0x12cb63(0x14d))/0x2+parseInt(_0x12cb63(0x142))/0x3+parseInt(_0x12cb63(0x119))/0x4+parseInt(_0x12cb63(0xfd))/0x5+parseInt(_0x12cb63(0x12b))/0x6*(parseInt(_0x12cb63(0x122))/0x7)+parseInt(_0x12cb63(0x126))/0x8*(-parseInt(_0x12cb63(0x168))/0x9);if(_0x382e24===_0x839fc1)break;else _0x5205a1['push'](_0x5205a1['shift']());}catch(_0x153e8f){_0x5205a1['push'](_0x5205a1['shift']());}}}(a0_0x2780,0x4b3f6));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_0x4291a0(0x163)),SCHEMA_VERSION='1.1',SOURCE='dbschema-catalog',DOCUMENTATION_URL='https://restforge.dev/docs/cli/schema-definition',DEFINE_MODEL_OPTIONS=[{'name':'schema','required':![],'type':a0_0x4291a0(0x152),'description':'Database\x20schema\x20namespace\x20(multi-schema\x20database).','notes':a0_0x4291a0(0x10f)},{'name':a0_0x4291a0(0x111),'required':!![],'type':'object','description':'Object\x20of\x20field\x20definitions\x20in\x20shorthand\x20string\x20format.','example':a0_0x4291a0(0x10d)},{'name':'primaryKey','required':![],'type':a0_0x4291a0(0x12d),'description':'Override\x20primary\x20key.\x20Single\x20field\x20name\x20or\x20composite\x20array.','notes':a0_0x4291a0(0x103)},{'name':a0_0x4291a0(0x13a),'required':![],'type':a0_0x4291a0(0x113),'description':a0_0x4291a0(0xf0),'example':'{\x20category:\x20{\x20type:\x20\x22belongsTo\x22,\x20references:\x20\x22category(id)\x22\x20}\x20}'},{'name':'indexes','required':![],'type':'array','description':a0_0x4291a0(0x12e),'example':a0_0x4291a0(0x159)},{'name':a0_0x4291a0(0xf9),'required':![],'type':'array','description':'Unique\x20constraints\x20(single\x20or\x20composite).','example':'[[\x22category_code\x22],\x20[\x22tenant_id\x22,\x20\x22category_code\x22]]'},{'name':'checks','required':![],'type':a0_0x4291a0(0x157),'description':'CHECK\x20constraints.\x20Each\x20entry\x20uses\x20operator-as-key\x20shape:\x20{\x20name?,\x20field,\x20<operator>:\x20<value>\x20}\x20where\x20<operator>\x20is\x20one\x20of\x20checkOperations\x20(in,\x20eq,\x20neq,\x20gt,\x20gte,\x20lt,\x20lte).\x20The\x20internal\x20IR\x20shape\x20after\x20ir-builder\x20normalization\x20is\x20{\x20name?,\x20field,\x20op,\x20value\x20},\x20but\x20that\x20is\x20NOT\x20the\x20user\x20input\x20format.','example':a0_0x4291a0(0x13c)},{'name':'softDelete','required':![],'type':'object','description':'Enables\x20soft-delete\x20for\x20the\x20table.\x20Shape:\x20{\x20enabled:\x20boolean,\x20reusable?:\x20[{\x20field,\x20length\x20}]\x20}.\x20Keys\x20other\x20than\x20enabled\x20and\x20reusable\x20are\x20rejected\x20at\x20schema\x20load.\x20When\x20enabled,\x20the\x20three\x20contract\x20columns\x20(is_deleted,\x20deleted_at,\x20deleted_by)\x20must\x20be\x20declared\x20in\x20fields.\x20See\x20the\x20softDelete\x20section\x20for\x20the\x20full\x20contract.','example':'{\x20enabled:\x20true,\x20reusable:\x20[{\x20field:\x20\x22category_code\x22,\x20length:\x2050\x20}]\x20}','notes':a0_0x4291a0(0x10b)}],FIELD_TYPES=[{'name':'string','description':'Variable-length\x20text.\x20Length\x20modifier\x20required.','requiresModifier':!![],'modifierFormat':'string:<length>','example':'string:255','notes':'Explicit\x20length\x20required\x20for\x20cross-dialect\x20portability.'},{'name':'text','description':a0_0x4291a0(0x14c),'requiresModifier':![],'example':a0_0x4291a0(0x16b)},{'name':'integer','description':'32-bit\x20signed\x20integer\x20(INT/INTEGER).','requiresModifier':![],'example':a0_0x4291a0(0x11b)},{'name':'bigint','description':a0_0x4291a0(0x162),'requiresModifier':![],'example':a0_0x4291a0(0x128)},{'name':'decimal','description':a0_0x4291a0(0x154),'requiresModifier':!![],'modifierFormat':'decimal:<precision>,<scale>','example':'decimal:15,2','notes':a0_0x4291a0(0xf6)},{'name':'boolean','description':'Boolean\x20value\x20(native\x20BOOLEAN\x20on\x20PostgreSQL,\x20VARCHAR\x20on\x20others).','requiresModifier':![],'example':a0_0x4291a0(0x123)},{'name':a0_0x4291a0(0x16a),'description':a0_0x4291a0(0x153),'requiresModifier':![],'example':'date'},{'name':a0_0x4291a0(0x105),'description':a0_0x4291a0(0x116),'requiresModifier':![],'example':a0_0x4291a0(0x105),'notes':'Default\x20timezone\x20behavior\x20is\x20dialect-specific.'},{'name':'uuid','description':a0_0x4291a0(0x150),'requiresModifier':![],'example':'uuid'},{'name':'json','description':a0_0x4291a0(0x124),'requiresModifier':![],'example':a0_0x4291a0(0x102)}],CONSTRAINTS=[{'name':'pk','kind':'standalone','description':'Marks\x20field\x20as\x20primary\x20key.','example':a0_0x4291a0(0x11e)},{'name':'notnull','kind':'standalone','description':'NOT\x20NULL\x20constraint.','example':a0_0x4291a0(0x164)},{'name':'unique','kind':a0_0x4291a0(0x16d),'description':a0_0x4291a0(0x161),'example':a0_0x4291a0(0x14a)},{'name':'index','kind':'standalone','description':'Single-column\x20non-unique\x20index.','example':a0_0x4291a0(0xf5)},{'name':a0_0x4291a0(0x12c),'kind':'standalone','deprecated':!![],'description':a0_0x4291a0(0x13b),'example':'timestamp','notes':a0_0x4291a0(0x11a)},{'name':'default','kind':'value','description':'Default\x20value.\x20Single-quoted\x20for\x20strings,\x20raw\x20for\x20numeric/boolean,\x20bare\x20identifier\x20for\x20SQL\x20constants,\x20identifier()\x20for\x20native\x20function\x20calls.','valueFormat':a0_0x4291a0(0x106),'example':a0_0x4291a0(0xff)},{'name':'fk','kind':a0_0x4291a0(0x151),'description':'Foreign\x20key\x20reference.\x20Auto-generates\x20a\x20belongsTo\x20relation\x20entry.','valueFormat':a0_0x4291a0(0x16c),'example':'string:36\x20fk:category.id','notes':'Cannot\x20coexist\x20with\x20explicit\x20relation\x20entry\x20referencing\x20the\x20same\x20field.'}],RELATION_TYPES=[{'name':'belongsTo','description':'Many-to-one.\x20This\x20table\x20holds\x20the\x20FK\x20column\x20referencing\x20the\x20parent\x20table.','requiredFields':[a0_0x4291a0(0x11d),'localKey',a0_0x4291a0(0x134)],'optionalFields':[a0_0x4291a0(0xef),'onDelete','onUpdate'],'example':'{\x20type:\x20\x22belongsTo\x22,\x20localKey:\x20\x22category_id\x22,\x20references:\x20\x22category_id\x22,\x20onDelete:\x20\x22restrict\x22\x20}','notes':'`references`\x20is\x20the\x20bare\x20column\x20name\x20in\x20the\x20target\x20table.\x20Target\x20table\x20is\x20auto-derived\x20from\x20the\x20relation\x20key\x20name,\x20or\x20override\x20with\x20`target`.'},{'name':'hasOne','description':'One-to-one\x20(inverse\x20of\x20belongsTo).\x20Optional\x20inverse\x20declaration\x20on\x20the\x20parent\x20side;\x20does\x20not\x20affect\x20DDL.','requiredFields':[a0_0x4291a0(0x11d),'localKey','references'],'optionalFields':['target',a0_0x4291a0(0xfb),'onUpdate'],'example':'{\x20type:\x20\x22hasOne\x22,\x20target:\x20\x22profile\x22,\x20localKey:\x20\x22user_id\x22,\x20references:\x20\x22user_id\x22\x20}'},{'name':a0_0x4291a0(0x130),'description':a0_0x4291a0(0x156),'requiredFields':['type','localKey','references'],'optionalFields':[a0_0x4291a0(0xef),a0_0x4291a0(0xfb),a0_0x4291a0(0x10c)],'example':a0_0x4291a0(0xf7)}],REFERENTIAL_ACTIONS=[{'name':'cascade','description':'Cascade\x20delete/update\x20to\x20child\x20rows.','appliesTo':[a0_0x4291a0(0xfb),a0_0x4291a0(0x10c)]},{'name':a0_0x4291a0(0xf3),'description':a0_0x4291a0(0x135),'appliesTo':[a0_0x4291a0(0xfb),'onUpdate']},{'name':a0_0x4291a0(0xfe),'description':a0_0x4291a0(0x11c),'appliesTo':['onDelete',a0_0x4291a0(0x10c)],'notes':a0_0x4291a0(0x129)},{'name':'noAction','description':'Defer\x20constraint\x20check\x20(semantically\x20similar\x20to\x20restrict\x20on\x20most\x20dialects).','appliesTo':['onDelete',a0_0x4291a0(0x10c)]}],CHECK_OPERATIONS=[{'name':'in','description':a0_0x4291a0(0x15e),'valueType':'array','example':'{\x20field:\x20\x22status\x22,\x20in:\x20[\x22active\x22,\x20\x22inactive\x22]\x20}'},{'name':'eq','description':'Equal\x20to.','valueType':a0_0x4291a0(0x127),'example':a0_0x4291a0(0x15c)},{'name':'neq','description':a0_0x4291a0(0x101),'valueType':'scalar','example':'{\x20field:\x20\x22type\x22,\x20neq:\x20\x22system\x22\x20}'},{'name':'gt','description':a0_0x4291a0(0xf2),'valueType':'numeric','example':'{\x20field:\x20\x22qty\x22,\x20gt:\x200\x20}'},{'name':a0_0x4291a0(0x14e),'description':a0_0x4291a0(0xf8),'valueType':'numeric','example':'{\x20field:\x20\x22qty\x22,\x20gte:\x200\x20}'},{'name':'lt','description':'Less\x20than.','valueType':'numeric','example':a0_0x4291a0(0x108)},{'name':'lte','description':'Less\x20than\x20or\x20equal\x20to.','valueType':a0_0x4291a0(0x155),'example':a0_0x4291a0(0x138)}],AUDIT_COLUMNS={'description':'Standard\x204-column\x20audit\x20convention\x20for\x20tables\x20managed\x20by\x20RESTForge.\x20The\x20same\x20convention\x20is\x20documented\x20in\x20field-validation:catalog\x20(auditColumns\x20section)\x20for\x20the\x20RDF/backend\x20layer.\x20SDF\x20and\x20RDF\x20stay\x20aligned\x20when\x20both\x20declare\x20these\x204\x20columns.','columns':[{'name':'created_at','shorthand':'timestamp\x20default:now()','nullable':!![],'purpose':'Record\x20creation\x20timestamp.\x20Auto-set\x20on\x20INSERT\x20via\x20DEFAULT\x20now().\x20Native\x20function\x20translates\x20per\x20dialect\x20(postgres:\x20CURRENT_TIMESTAMP,\x20mysql:\x20NOW(),\x20oracle:\x20SYSTIMESTAMP,\x20sqlite:\x20CURRENT_TIMESTAMP).'},{'name':'created_by','shorthand':a0_0x4291a0(0x112),'nullable':!![],'purpose':a0_0x4291a0(0x158)},{'name':a0_0x4291a0(0x117),'shorthand':a0_0x4291a0(0x105),'nullable':!![],'purpose':a0_0x4291a0(0x14b)},{'name':a0_0x4291a0(0x115),'shorthand':'string:100','nullable':!![],'purpose':'User\x20identifier\x20of\x20the\x20last\x20modifier.\x20Set\x20by\x20application\x20layer\x20on\x20UPDATE,\x20not\x20by\x20database\x20default.'}],'convention':{'emitInSkeleton':'Yes\x20—\x20dbschema:init\x20emits\x20all\x204\x20columns\x20by\x20default.\x20Tables\x20that\x20do\x20not\x20need\x20audit\x20(lookup\x20tables,\x20system\x20tables)\x20can\x20manually\x20remove\x20these\x20fields\x20from\x20the\x20generated\x20skeleton.','nullablePolicy':'All\x204\x20columns\x20are\x20nullable.\x20The\x20created_by/updated_by\x20columns\x20may\x20be\x20empty\x20for\x20rows\x20inserted\x20by\x20system\x20seeds,\x20migrations,\x20or\x20batch\x20imports\x20that\x20do\x20not\x20have\x20a\x20user\x20context.','relationToRdf':a0_0x4291a0(0x15d)}},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':'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_0x4291a0(0x13d),'nullable':![],'purpose':a0_0x4291a0(0x109)},{'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_0x4291a0(0x118),'nullable':!![],'purpose':'Deletion\x20actor\x20identifier,\x20nullable.\x20NULL\x20while\x20the\x20row\x20is\x20alive.'}],'biconditionalRules':['enabled\x20=\x20true\x20with\x20all\x20three\x20columns\x20declared\x20and\x20correctly\x20typed:\x20valid.',a0_0x4291a0(0x13f),'Soft-delete\x20columns\x20declared\x20while\x20enabled\x20is\x20not\x20true:\x20validation\x20ERROR.',a0_0x4291a0(0x160),'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_0x4291a0(0x169),a0_0x4291a0(0x121),'The\x20field\x20must\x20have\x20a\x20single-column\x20UNIQUE\x20constraint\x20(no\x20UNIQUE,\x20or\x20only\x20composite\x20UNIQUE:\x20ERROR).',a0_0x4291a0(0xf1)],'suffixLength':SOFT_DELETE_SUFFIX_LENGTH,'physicalLengthFormula':'physical\x20length\x20>=\x20base\x20length\x20+\x20'+SOFT_DELETE_SUFFIX_LENGTH,'notes':a0_0x4291a0(0x139)+SOFT_DELETE_SUFFIX_LENGTH+'-character\x20suffix\x20is\x20\x22##\x22\x20(2)\x20+\x20uuidv7\x20(36).\x20Example:\x20length:\x2050\x20requires\x20the\x20field\x20to\x20be\x20declared\x20at\x20least\x20string:88;\x20a\x20shorter\x20declaration\x20fails\x20validation\x20with\x20the\x20declared\x20and\x20required\x20lengths\x20in\x20the\x20message.'},'uniqueEligibilityGate':{'description':a0_0x4291a0(0xfa),'rules':['Composite\x20UNIQUE\x20constraints\x20are\x20rejected:\x20they\x20cannot\x20be\x20freed\x20through\x20value\x20mutation,\x20so\x20re-creating\x20a\x20row\x20with\x20the\x20same\x20key\x20after\x20a\x20soft-delete\x20would\x20violate\x20the\x20constraint.','Single-column\x20UNIQUE\x20constraints\x20on\x20non-string\x20columns\x20are\x20rejected\x20for\x20the\x20same\x20reason\x20(suffix\x20mutation\x20only\x20applies\x20to\x20string/text).'],'suggestion':a0_0x4291a0(0x13e)},'emittedDdl':{'consistencyCheck':{'namePattern':a0_0x4291a0(0x145)+SOFT_DELETE_CHECK_SUFFIX,'description':a0_0x4291a0(0x10e)+SOFT_DELETE_CHECK_SUFFIX+a0_0x4291a0(0x149)+IS_DELETED_COLUMN+a0_0x4291a0(0x131)+DELETED_AT_COLUMN+a0_0x4291a0(0x166)+DELETED_BY_COLUMN+'\x20IS\x20NOT\x20NULL)\x20OR\x20('+IS_DELETED_COLUMN+a0_0x4291a0(0x165)+DELETED_AT_COLUMN+a0_0x4291a0(0x136)+DELETED_BY_COLUMN+'\x20IS\x20NULL).\x20This\x20keeps\x20the\x20three\x20columns\x20consistent\x20at\x20the\x20data\x20level\x20regardless\x20of\x20the\x20write\x20path.'},'partialIndex':{'description':'Non-unique\x20indexes\x20on\x20soft-delete\x20tables\x20are\x20emitted\x20as\x20PostgreSQL\x20partial\x20indexes\x20with\x20WHERE\x20'+IS_DELETED_COLUMN+a0_0x4291a0(0x167),'example':a0_0x4291a0(0x137)+IS_DELETED_COLUMN+a0_0x4291a0(0x15a),'notes':a0_0x4291a0(0x125)}},'dialectSupport':{'supported':[SOFT_DELETE_PHASE1_DIALECT],'description':'Phase\x201:\x20PostgreSQL\x20only.\x20On\x20other\x20dialects\x20the\x20softDelete\x20block\x20is\x20not\x20supported\x20(DDL\x20generation\x20fails\x20with\x20a\x20clear\x20error)\x20and\x20soft-delete-named\x20columns\x20get\x20no\x20special\x20treatment\x20during\x20introspect.'},'introspectRoundTrip':'schema\x20introspect\x20recognizes\x20a\x20complete\x20soft-delete\x20table\x20(three\x20correctly\x20typed\x20contract\x20columns\x20+\x20consistency\x20CHECK)\x20and\x20writes\x20back\x20softDelete:\x20{\x20enabled:\x20true\x20}\x20in\x20the\x20generated\x20SDF.\x20Tables\x20with\x20incomplete\x20or\x20non-conforming\x20soft-delete\x20columns\x20block\x20introspect\x20with\x20an\x20error.','rdfDerivation':'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_0x4291a0(0xf4),'description':a0_0x4291a0(0x147),'rules':['Type\x20is\x20mandatory\x20at\x20the\x20beginning\x20and\x20must\x20be\x20one\x20of\x20fieldTypes.',a0_0x4291a0(0x120),a0_0x4291a0(0x141),'Value\x20constraints\x20(default,\x20fk)\x20require\x20constraint:value\x20format.',a0_0x4291a0(0x133),'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_0x4291a0(0x146)},{'input':a0_0x4291a0(0x164),'meaning':a0_0x4291a0(0x12f)},{'input':'decimal:15,2\x20notnull\x20default:0','meaning':a0_0x4291a0(0x104)},{'input':a0_0x4291a0(0xff),'meaning':'BOOLEAN\x20DEFAULT\x20TRUE'},{'input':a0_0x4291a0(0x15b),'meaning':a0_0x4291a0(0x143)},{'input':a0_0x4291a0(0x144),'meaning':'TIMESTAMP\x20DEFAULT\x20<native_now\x20per\x20dialect>'},{'input':a0_0x4291a0(0x107),'meaning':a0_0x4291a0(0x148)},{'input':'string:64\x20index','meaning':a0_0x4291a0(0x100)}]},NAMING_RULES={'tableName':{'format':a0_0x4291a0(0x132),'description':'Table\x20name\x20must\x20be\x20lowercase,\x20digits,\x20and\x20underscores\x20only.'},'fieldName':{'format':'snake_case','description':a0_0x4291a0(0x14f)},'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_0x4291a0(0x12a)}},DIALECT_SUPPORT=[{'name':'postgres','driver':'pg','booleanStorage':'native\x20BOOLEAN'},{'name':'mysql','driver':'mysql2','booleanStorage':a0_0x4291a0(0x110)},{'name':a0_0x4291a0(0x10a),'driver':'oracledb','booleanStorage':'VARCHAR2\x20with\x20CHECK\x20constraint'},{'name':a0_0x4291a0(0x15f),'driver':a0_0x4291a0(0x11f),'booleanStorage':'TEXT'}],DBSCHEMA_CATALOG={'schemaVersion':SCHEMA_VERSION,'source':SOURCE,'summary':{'totalDefineModelOptions':DEFINE_MODEL_OPTIONS['length'],'totalFieldTypes':FIELD_TYPES['length'],'totalConstraints':CONSTRAINTS['length'],'totalRelationTypes':RELATION_TYPES['length'],'totalReferentialActions':REFERENTIAL_ACTIONS[a0_0x4291a0(0x140)],'totalCheckOperations':CHECK_OPERATIONS['length'],'totalAuditColumns':AUDIT_COLUMNS[a0_0x4291a0(0x114)]['length'],'totalDialects':DIALECT_SUPPORT['length']},'defineModelOptions':DEFINE_MODEL_OPTIONS,'fieldTypes':FIELD_TYPES,'constraints':CONSTRAINTS,'relationTypes':RELATION_TYPES,'referentialActions':REFERENTIAL_ACTIONS,'checkOperations':CHECK_OPERATIONS,'auditColumns':AUDIT_COLUMNS,'softDelete':SOFT_DELETE,'shorthandSyntax':SHORTHAND_SYNTAX,'namingRules':NAMING_RULES,'dialectSupport':DIALECT_SUPPORT,'documentationUrl':DOCUMENTATION_URL};module['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_0x2ae1(_0x1695e3,_0x5b1031){_0x1695e3=_0x1695e3-0xef;const _0x27800c=a0_0x2780();let _0x2ae186=_0x27800c[_0x1695e3];if(a0_0x2ae1['xXSxVV']===undefined){var _0x5d36fc=function(_0x4b0664){const _0x3e6ef1='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x16120f='',_0xb4126b='';for(let _0x432a50=0x0,_0x5c3ea9,_0x548641,_0x4b18dc=0x0;_0x548641=_0x4b0664['charAt'](_0x4b18dc++);~_0x548641&&(_0x5c3ea9=_0x432a50%0x4?_0x5c3ea9*0x40+_0x548641:_0x548641,_0x432a50++%0x4)?_0x16120f+=String['fromCharCode'](0xff&_0x5c3ea9>>(-0x2*_0x432a50&0x6)):0x0){_0x548641=_0x3e6ef1['indexOf'](_0x548641);}for(let _0x48e5e5=0x0,_0x23505b=_0x16120f['length'];_0x48e5e5<_0x23505b;_0x48e5e5++){_0xb4126b+='%'+('00'+_0x16120f['charCodeAt'](_0x48e5e5)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0xb4126b);};a0_0x2ae1['gbjAzH']=_0x5d36fc,a0_0x2ae1['MyplnM']={},a0_0x2ae1['xXSxVV']=!![];}const _0x5d39d6=_0x27800c[0x0],_0x142764=_0x1695e3+_0x5d39d6,_0x133fb7=a0_0x2ae1['MyplnM'][_0x142764];return!_0x133fb7?(_0x2ae186=a0_0x2ae1['gbjAzH'](_0x2ae186),a0_0x2ae1['MyplnM'][_0x142764]=_0x2ae186):_0x2ae186=_0x133fb7,_0x2ae186;}function a0_0x2780(){const _0x319cfc=['w1SIC3rHDhvZiIWGiMnYzwf0zwrFyxqIxv0','id0GrKfmu0u','C3rYAw5NoJeWmcbKzwzHDwX0oIDWzw5KAw5NjW','EYbMAwvSzdOGiNr5CguIlcbLCtOGiNvZzxiIih0','vgHLifjerIbNzw5LCMf0B3iGkgnVzgvNzw5Fy3jLyxrLx2vUzhbVAw50ksbHC3n1BwvZihrOzxnLidqGy29SDw1UCYbLEgLZDcb3AgvUihrOzsbWyxLSB2fKlMf1zgL0q29SDw1UCYbRzxKGAxmGywjZzw50lIbtzwuGzMLLBgqTDMfSAwrHDgLVBJPJyxrHBg9Nigf1zgL0q29SDw1UCYbMB3iGDgHLifjerI1ZAwrLigjLAgf2Aw9YlIbeCMLMDcbIzxr3zwvUifnerIaOBwLZC2LUzYbHDwrPDcbJB2X1Bw5ZksbHBMqGuKrgicHHC3n1BwvZigf1zgL0ignVBhvTBNmPignHDxnLCYbYDw50Aw1LigvYCM9YCYb3AgvUihrOzsbNzw5LCMf0zwqGzw5KCg9PBNqGDhjPzxmGDg8GD3jPDguGy3jLyxrLzf9IEs91CgrHDgvKx2j5ihrVigeGBM9Ulwv4Axn0zw50ignVBhvTBI4','vMfSDwuGBxvZDcbIzsbVBMuGB2yGysbSAxn0lG','C3fSAxrL','q29UDhjHy3qGy29SDw1UigrLy2XHCMvKihDPDgGGysb3CM9UzYb0ExbLoIb2ywXPzgf0Aw9UievsuK9slG','u2LUz2XLlwnVBhvTBIb1BMLXDwuGy29UC3rYywLUDc4','nJqTyML0ihnPz25LzcbPBNrLz2vYicHcsuDjtLqPlG','lI4VzgjZy2HLBweTA2L0l3nVzNqTzgvSzxrLlwnVBNn0yw50CW','C3rYAw5NoJi1nsbUB3rUDwXS','id0GrKfmu0uGqu5eia','ieLtie5pvcbovuXmieforca','id0GrKfmu0uU','mJe2zvf0vhvW','vgHLigzPzwXKig11C3qGyMuGzgvJBgfYzwqGAw4GzMLLBgrZicH1BMTUB3DUigzPzwXKoIbfuLjpuIKU','zgf0zq','Dgv4Da','zMS6phrHyMXLpI48y29SDw1UpG','C3rHBMrHBg9Uzq','DgfYz2v0','sw50zxiTDgfIBguGCMvSyxrPB25ZicHIzwXVBMDZvg8SigHHC09UzsWGAgfZtwfUEsKU','BgvUz3rOig11C3qGyMuGysbWB3nPDgL2zsbPBNrLz2vYicHIyxnLigXLBMD0Aca9ig1HEgLTDw0GDxnLCI1PBNb1DcbSzw5NDgGPoIbfuLjpuIbVDgHLCNDPC2uU','r3jLyxrLCIb0AgfUlG','CMvZDhjPy3q','phr5Cgu+wZO8Bw9KAwzPzxi+xsbBpgnVBNn0CMfPBNq+wZO8DMfSDwu+xv0UlI4','C3rYAw5NoJy0igLUzgv4','uhjLy2LZAw9UigfUzcbZy2fSzsbYzxf1AxjLzcbMB3iGy3jVC3mTzgLHBgvJDcbWB3j0ywjPBgL0Es4','EYb0ExbLoIaIAgfZtwfUEsiSihrHCMDLDdOGiM9YzgvYx2L0zw0IlcbSB2nHBeTLEtOGiM9YzgvYx2LKiIWGCMvMzxjLBMnLCZOGiM9YzgvYx2LKiIb9','r3jLyxrLCIb0AgfUig9YigvXDwfSihrVlG','Dw5PCxvLCW','v2HLBIbLBMfIBgvKid0GDhj1zsWGzxzLCNKGvu5juvvfignVBNn0CMfPBNqGB24GDgHLihrHyMXLigLZignOzwnRzwqGzM9YihnVzNqTzgvSzxrLigvSAwDPyMLSAxr5lG','B25ezwXLDgu','ndCXmdq1ExLTEu5X','mtC3mtC5nvHYBMXrAq','C2v0tNvSBa','yM9VBgvHBIbKzwzHDwX0oNrYDwu','vKfsq0HbuIG2ncKGD2L0AcbZAw5NBguTy29SDw1UigLUzgv4','tM90igvXDwfSihrVlG','ANnVBG','qxv0BY1KzxrLy3rLzcbMCM9TigzPzwXKihnOB3j0AgfUzcaICgSIihDOzw4GBM90ihnWzwnPzMLLzc4','revdsu1btcGXnsWYksbot1qGtLvmtcberuzbvuXuida','DgLTzxn0yw1W','zgvMyxvSDdO8BgL0zxjHBd4GFcbKzwzHDwX0oIC8C3rYAw5NpICGFcbKzwzHDwX0oJXJB25ZDgfUDd4GFcbKzwzHDwX0oJXMDw5JDgLVBJ4Okq','C3rYAw5NoJm2igzRoMnHDgvNB3j5lMLK','EYbMAwvSzdOGiMrPC2nVDw50iIWGBhq6ideWmcb9','rgvSzxrPB24GzMXHzY4GrgvJBgfYzsbHCYbUB3rUDwXSigrLzMf1Bhq6zMfSC2uU','B3jHy2XL','ug9ZDgDYzvnrtc1VBMX5igLUifbOyxnLideUifrOzsbsreyGC29MDerLBgv0zsbIBg9JAYbPCYbKzxjPDMvKigzYB20GDgHPCYbtreyGyMXVy2SGzhvYAw5NihbHEwXVywqGz2vUzxjHDguSig5LDMvYihDYAxr0zw4GyNKGAgfUzc4','B25vCgrHDgu','EYbPzdOGiNn0CMLUzZOZnIbWAYiSig5HBwu6icjZDhjPBMC6mJu1ig5VDg51BgWIih0','rxzLCNKGC29MDc1KzwXLDguGDgfIBguGz2v0CYbHienirunlignVBNn0CMfPBNqGD2L0Acb0AguGzgv0zxjTAw5PC3rPyYbUyw1LignOA188DgfIBgu+xW','BNvSBcbVCIbLBxb0EsbZDhjPBMCGBwvHBNmGzgvMyxvSDcbZy2HLBweU','vKfsq0HbuIaOBgL0zxjHBcaIDhj1zsiViMzHBhnLiIK','zMLLBgrZ','C3rYAw5NoJeWma','B2jQzwn0','y29SDw1UCW','DxbKyxrLzf9IEq','rgf0zsbHBMqGDgLTzsaOveLnrvnuqu1qks4','DxbKyxrLzf9HDa','C3rYAw5NoJCW','mtKWndK2ohb5vunxEG','rw5NAw5Lihn0AwXSihbHCNnLCYb0AgLZihrVA2vUicHIywnRD2fYzcbJB21WyxrPyMLSAxr5ksWGyNv0ieretcbVDxrWDxqGAxmGAwrLBNrPy2fSihrVihbSywLUicD0Aw1LC3rHBxaNlIbvC2uGj3rPBwvZDgfTCcCGywXVBMuUifrOzsbHy3r1ywWGyxv0BY11CgrHDguGyMvOyxzPB3iGAxmGzg9JDw1LBNrLzcbPBIb0AguGuKrgigf1zgL0q29SDw1UCYbJyxrHBg9NicHMAwvSzc12ywXPzgf0Aw9UoMnHDgfSB2CPlG','Aw50zwDLCG','u2v0iezlignVBhvTBIb0BYbovuXmig9UignOAwXKihjVD3mU','DhLWzq','C3rYAw5NoJm2ihbR','yMv0DgvYlxnXBgL0ztm','tw9KAwzPzxiGAxmGBwfUzgf0B3j5igzVCIb0ExbLicjZDhjPBMCIicHSzw5NDgGPigfUzcaIzgvJAw1HBciGkhbYzwnPC2LVBIXZy2fSzsKU','vgHLigzPzwXKihr5CguGBxvZDcbIzsbZDhjPBMCGB3iGDgv4DcaODMfSDwuGBxv0yxrPB24GCMvXDwLYzxmGysbZDhjPBMCGDhLWztOGrvjst1iGB3rOzxj3AxnLks4','ndm1ne5dwe1fyq','yM9VBgvHBG','sLnptIbJB2X1Bw4GkePtt05cig9UifbVC3rNCMvtuuWSiePtt04GB24GtxLtuuWSienmt0iGB24Gt3jHy2XLks4','vu5juvvfignVBNn0CMfPBNrZigfYzsbot1qGBwfKzsbWyxj0AwfSig9UigfUEsbKAwfSzwn0lIbvBMLXDwvUzxnZigTLzxbZignVDMvYAw5NigrLBgv0zwqGCM93CZSGDMfSDwuGCMv1C2uGAxmGAgfUzgXLzcbIEsb0AguGC3vMzML4ig11Dgf0Aw9UlcbUB3qGyNKGysbWyxj0AwfSihvUAxf1zsbPBMrLEc4','ndaXnZeYq3jZq0PL','C2nHBgfY','yMLNAw50','rKSGzMLLBgqGBxvZDcbIzsbUDwXSywjSzs4','rM9YignVBxbVC2L0zsbPBMrLEgvZl3vUAxf1zxmSig5HBwuGAxmGzgvYAxzLzcbIEsbQB2LUAw5NignVBhvTBNmGD2L0Acb1BMrLCNnJB3jLigfUzcb0CNvUy2f0Aw5NihDOzw4GBMvLzgvKlG','mZe0neXJqxv4yG','yxv0B1vWzgf0zq','C3rYAw5NFgfYCMf5','tM9UlxvUAxf1zsbPBMrLEgvZlIbfywnOigvUDhj5igLZigfYCMf5ig9MignVBhvTBIbUyw1LCYbVCIbVyMPLy3qGEYbUyw1LlcbJB2X1Bw5Zih0U','vKfsq0HbuIGYntuPie5pvcbovuXm','AgfZtwfUEq','id0GvfjvrsbbtKqG','C25HA2vFy2fZzq','rgvMyxvSDcb2ywX1zsbMB3jTyxqGzgvWzw5KCYbVBIb0ExbLoIbYyxCGzM9YigjVB2XLyw4GkgrLzMf1Bhq6Dhj1zsKSihjHDYbMB3iGAw50zwDLCIaOzgvMyxvSDdOWksWGC2LUz2XLlxf1B3rLzcbMB3iGC3rYAw5NicHKzwzHDwX0oID2ywX1zsCPlcbIyxjLigLKzw50AwzPzxiGzM9YifnrtcbJB25ZDgfUDhmGkgrLzMf1Bhq6y3vYCMvUDf9KyxrLksWGAwrLBNrPzMLLCIGPigzVCIbUyxrPDMuGzNvUy3rPB24Gy2fSBhmGkgrLzMf1Bhq6BM93kcKPlG','CMvMzxjLBMnLCW','uMvQzwn0igrLBgv0zs91CgrHDguGD2HLBIbJAgLSzcbYB3DZigv4Axn0lG','ieLtie5vteWGqu5eia','q1jfqvrfieLorevyigLKEf92AxnPDg9Yx2nHDgvNB3jPzxnFy2f0zwDVCNLFBMfTzsbptIb2AxnPDg9Yx2nHDgvNB3jPzxmGkgnHDgvNB3j5x25HBwuPifDirvjfia','EYbMAwvSzdOGiMrPC2nVDw50iIWGBhrLoIaXmdaGFq','vgHLia','CMvSyxrPB25Z','revquKvdqvrfrdOGvgHPCYbTB2rPzMLLCIbUBYbSB25NzxiGAgfZigz1BMn0Aw9UywWGzwzMzwn0igf0ihrOzsbereWGB3iGCNvUDgLTzsbSzxzLBc4Gqxv0BY11CgrHDguGzM9YihvWzgf0zwrFyxqGAxmGAgfUzgXLzcbIEsb0AguGuKrgigXHEwvYicHHDwrPDenVBhvTBNmGy29UDMvUDgLVBIbPBIbcyxnLtw9KzwWGCNvUDgLTzsKGyMfZzwqGB24GzMLLBgqGBMfTAw5NignVBNzLBNrPB24Sig5VDcbIEsb0AgLZifnerIbTyxjRzxiUiev4Axn0Aw5NihvZywDLigLZihbYzxnLCNzLzcbMB3iGyMfJA3DHCMqGy29TCgf0AwjPBgL0EsbIDxqGC2HVDwXKigjLihjLBw92zwqGzNjVBsbUzxCGDgvTCgXHDgvZlG','w3SGzMLLBgq6icjZDgf0DxmIlcbPBJOGwYjHy3rPDMuIlcaIAw5Hy3rPDMuIxsb9lcb7igzPzwXKoIaICxr5iIWGz3rLoIaWih1D','yM9VBgvHBIbUB3rUDwXSigrLzMf1Bhq6zMfSC2u','vgHLigvYCM9Yig1LC3nHz2uGC3vNz2vZDhmGDhDVihDHExmGB3v0oIb1C2uGAgfYzc1KzwXLDguGzM9YihbYB2nLC3mTzhjPDMvUihrHyMXLCYaOyMfSyw5JzsWGBgvKz2vYlcbZBMfWC2HVDcWGCgvYAw9KlwnSB3nLksWGB3iGy2HHBMDLihrOzsbvtKLrvuuGAw50BYbHihnPBMDSzs1JB2X1Bw4GC3rYAw5Nigj1C2LUzxnZignVzguU','zw5HyMXLzca9ihrYDwuGD2L0AcbHBNKGy29UDhjHy3qGy29SDw1Uig1PC3nPBMC6ihzHBgLKyxrPB24Grvjst1iGkg1PC3nPBMCGy29SDw1UCYbHCMuGBgLZDgvKks4','BgvUz3rO','u3rHBMrHBg9UzsbJB25ZDhjHAw50CYaOCgSSig5VDg51BgWSihvUAxf1zsWGAw5KzxGPihrHA2uGBM8GDMfSDwuUifrOzsbSzwDHy3KGyxv0B1vWzgf0zsb0B2TLBIbPCYbZDgLSBcbWyxjZzwqGzM9YigjHy2T3yxjKignVBxbHDgLIAwXPDhKGyNv0igLZigrLChjLy2f0zwqGyw5KigHHCYbUBYbMDw5JDgLVBMfSigvMzMvJDc4','mtCYode2oe9VB3Dpwa','vKfsq0HbuIGXmdaPierfrKfvtfqGj3bLBMrPBMCN','DgLTzxn0yw1WigrLzMf1Bhq6BM93kcK','y2HRxZX0ywjSzt5F','vKfsq0HbuIGZnIKGufjjtufswsblrvK','u3rYAw5NihnOB3j0AgfUzcbMB3iGzMLLBgqGzgvMAw5PDgLVBI4GvhLWzsbYzxf1AxjLzcbHDcbZDgfYDcWGzM9SBg93zwqGyNKGB3b0Aw9UywWGBw9KAwzPzxiGyw5KihnWywnLlxnLCgfYyxrLzcbJB25ZDhjHAw50CY4','vKfsq0HbuIGZnIKGD2L0AcbgsYb0BYbJyxrLz29YEsHPzcKSigf1Dg8GyMvSB25NC1rVihjLBgf0Aw9U','igvUzM9Yy2LUzZOGka','C3rYAw5NoJmYihvUAxf1zq','tgfZDcbTB2rPzMLJyxrPB24GDgLTzxn0yw1WlIbbDxrVlxvWzgf0zsbPCYbOyw5KBgvKigj5ihrOzsbsreyGCNvUDgLTzsaOqMfZzu1VzgvSigf1zgL0q29SDw1UCYbJB252zw50Aw9Uksb3AgLJAcbPBMPLy3rZihvWzgf0zwrFyxqGpsbdvvjsru5ux1rjtuvtvefnucbPBNrVigv2zxj5ifvqrefursbZDgf0zw1LBNqGyMfZzwqGB24GzMLLBgqGBMfTAw5NlcbUB3qGyNKGyw55ifnerIbTyxjRzxiUieLUAxrPywWGsu5trvjuihzHBhvLigLZigfSC28GAgfUzgXLzcbIEsb0AguGuKrgihj1BNrPBwuGyxvKAxrdB2X1Bw5ZigHLBhbLCI4','tg9UzY1MB3jTihrLEhqGD2L0Ag91DcbSzw5NDgGGBgLTAxqGkfrfwfqVq0XpqIKU','ntaZnJiWr2vqzxnM','z3rL','q29SDw1Uig5HBwuGBxvZDcbIzsbZBMfRzv9JyxnLlG','vvvjrc4GtMf0AxzLifvvsuqGB24Gug9ZDgDYzvnrtcWGvKfsq0HbuIGZnIKGB24GB3rOzxjZlG','DMfSDwu','C3rYAw5NFg51BgW','rgf0zsbVBMX5icHUBYb0Aw1LignVBxbVBMvUDcKU','rML4zwqTCg9PBNqGzgvJAw1HBc4GuhjLy2LZAw9UigfUzcbZy2fSzsbYzxf1AxjLzc4','BNvTzxjPyW','t25LlxrVlw1HBNKGkgLUDMvYC2uGB2yGyMvSB25NC1rVks4Gt3b0Aw9UywWGAw52zxjZzsbKzwnSyxjHDgLVBIbVBIb0AguGCgfYzw50ihnPzgu7igrVzxmGBM90igfMzMvJDcbereWU','yxjYyxK','vxnLCIbPzgvUDgLMAwvYicH1C2vYBMfTzsWGDxnLCL9PzcWGB3iGy29TCg9ZAxrLihrVA2vUksbVzIb0AguGCMvJB3jKignYzwf0B3iUifnLDcbIEsbHChbSAwnHDgLVBIbSyxLLCIbVBIbjtLnfuLqSig5VDcbIEsbKyxrHyMfZzsbKzwzHDwX0lG'];a0_0x2780=function(){return _0x319cfc;};return a0_0x2780();}
|
|
1
|
+
'use strict';const a0_0x968dcd=a0_0x4423;function a0_0x2350(){const _0x178d54=['AgfZt25L','yhjLzMvYzw5JzxnGigLZihrOzsbIyxjLignVBhvTBIbUyw1LigLUihrOzsb0yxjNzxqGDgfIBguUifrHCMDLDcb0ywjSzsbPCYbHDxrVlwrLCML2zwqGzNjVBsb0AguGCMvSyxrPB24GA2v5ig5HBwuSig9Yig92zxjYAwrLihDPDgGGyhrHCMDLDgaU','C2nOzw1H','rgvMyxvSDcb2ywX1zs4Gu2LUz2XLlxf1B3rLzcbMB3iGC3rYAw5NCYWGCMf3igzVCIbUDw1LCMLJl2jVB2XLyw4SigjHCMuGAwrLBNrPzMLLCIbMB3iGu1fmignVBNn0yw50CYWGAwrLBNrPzMLLCIGPigzVCIbUyxrPDMuGzNvUy3rPB24Gy2fSBhmU','mJy2mdvPvNnlDha','BM9by3rPB24','rML4zwqTCg9PBNqGzgvJAw1HBc4GuhjLy2LZAw9UigfUzcbZy2fSzsbYzxf1AxjLzc4','ANnVBG','nJqTyML0ihnPz25LzcbPBNrLz2vYicHcsuDjtLqPlG','q2fZy2fKzsbKzwXLDguVDxbKyxrLihrVignOAwXKihjVD3mU','B3jHy2XL','uhjLy2LZAw9UigfUzcbZy2fSzsbYzxf1AxjLzcbMB3iGy3jVC3mTzgLHBgvJDcbWB3j0ywjPBgL0Es4','vxnLCIbPzgvUDgLMAwvYicH1C2vYBMfTzsWGDxnLCL9PzcWGB3iGy29TCg9ZAxrLihrVA2vUksbVzIb0AguGCMvJB3jKignYzwf0B3iUifnLDcbIEsbHChbSAwnHDgLVBIbSyxLLCIbVBIbjtLnfuLqSig5VDcbIEsbKyxrHyMfZzsbKzwzHDwX0lG','BgvUz3rO','vhLWzsbPCYbTyw5KyxrVCNKGyxqGDgHLigjLz2LUBMLUzYbHBMqGBxvZDcbIzsbVBMuGB2yGzMLLBgruExbLCY4','vKfsq0HbuJiGD2L0AcbdsevdsYbJB25ZDhjHAw50','ieLtie5vteWGqu5eia','rgf0zsbHBMqGDgLTzsaOveLnrvnuqu1qks4','rgf0ywjHC2uGC2nOzw1Hig5HBwvZCgfJzsaOBxvSDgKTC2nOzw1HigrHDgfIyxnLks4','mti5mdG4nuLyyvv6uq','Dw5PCxvLCW','u29MDc1KzwXLDguGy29UDhjHy3qGzM9YihrHyMXLCYbKzwnSyxjLzcb3AxrOigeGC29MDerLBgv0zsbIBg9JAYaOC2vLigrLzMLUzu1VzgvSt3b0Aw9UCY5ZB2z0rgvSzxrLigzVCIb0AguGyMXVy2SGC2HHCguPlIbezwXLDgvKihjVD3mGyxjLigzSywDNzwqGDgHYB3vNAcb0AhjLzsbJB250CMfJDcbJB2X1Bw5ZigLUC3rLywqGB2yGyMvPBMCGCgH5C2LJywXSEsbYzw1VDMvKlIbtreyGAxmGDgHLihnPBMDSzsbKzwnSyxjHDgLVBIbWB2LUDdOGAxqGzhjPDMvZieretcbLBwLZC2LVBIaOy29SDw1UCYWGy29UC2LZDgvUy3KGq0Hfq0SSihbHCNrPywWGAw5KzxHLCYKGyw5KihrOzsbsreyGC29MDerLBgv0zsbIBg9JAYbPCYbKzxjPDMvKigzYB20GAxqGzhvYAw5NihbHEwXVywqGz2vUzxjHDguU','C3rYAw5NoJeWma','q29SDw1Uig5HBwuGBxvZDcbIzsbZBMfRzv9JyxnLlG','rw5HyMXLCYbZB2z0lwrLBgv0zsbMB3iGDgHLihrHyMXLlIbtAgfWztOGEYbLBMfIBgvKoIbIB29SzwfUlcbYzxvZywjSzt86ifT7igzPzwXKlcbSzw5NDgGGFv0GFs4Gs2v5CYbVDgHLCIb0AgfUigvUywjSzwqGyw5KihjLDxnHyMXLigfYzsbYzwPLy3rLzcbHDcbZy2HLBweGBg9Hzc4Gv2HLBIbLBMfIBgvKlcb0AguGDgHYzwuGy29UDhjHy3qGy29SDw1UCYaOAxnFzgvSzxrLzcWGzgvSzxrLzf9HDcWGzgvSzxrLzf9IEsKGBxvZDcbIzsbKzwnSyxjLzcbPBIbMAwvSzhmUifnLzsb0AguGC29MDerLBgv0zsbZzwn0Aw9UigzVCIb0AguGzNvSBcbJB250CMfJDc4','C2nHBgfY','EYb0ExbLoIaIyMvSB25NC1rViIWGBg9JywXlzxK6icjJyxrLz29YEv9PzciSihjLzMvYzw5Jzxm6icjJyxrLz29YEv9PzciSig9UrgvSzxrLoIaICMvZDhjPy3qIih0','tgvZCYb0AgfUig9YigvXDwfSihrVlG','yxjYyxK','revdsu1btcGXnsWYksbot1qGtLvmtcberuzbvuXuida','EYbMAwvSzdOGiNf0EsiSigD0oIaWih0','BhrL','DxbKyxrLzf9IEq','B25vCgrHDgu','BNvTzxjPyW','mZy4mZCWnMDcq0jzqq','EYbLBMfIBgvKoIb0CNvLlcbYzxvZywjSztOGw3SGzMLLBgq6icjJyxrLz29YEv9JB2rLiIWGBgvUz3rOoIa1mcb9xsb9','vKfsq0HbuIGXmdaPierfrKfvtfqGj3bLBMrPBMCN','C3rYAw5NoJm2igzRoMnHDgvNB3j5lMLK','vgfIBguGBMfTzsbTDxn0igjLigXVD2vYy2fZzsWGzgLNAxrZlcbHBMqGDw5KzxjZy29YzxmGB25SEs4','vKfsq0HbuIaOBgL0zxjHBcaIDhj1zsiViMzHBhnLiIK','vgHLifjerIbNzw5LCMf0B3iGkgnVzgvNzw5Fy3jLyxrLx2vUzhbVAw50ksbHC3n1BwvZihrOzxnLidqGy29SDw1UCYbLEgLZDcb3AgvUihrOzsbWyxLSB2fKlMf1zgL0q29SDw1UCYbRzxKGAxmGywjZzw50lIbtzwuGzMLLBgqTDMfSAwrHDgLVBJPJyxrHBg9Nigf1zgL0q29SDw1UCYbMB3iGDgHLifjerI1ZAwrLigjLAgf2Aw9YlIbeCMLMDcbIzxr3zwvUifnerIaOBwLZC2LUzYbHDwrPDcbJB2X1Bw5ZksbHBMqGuKrgicHHC3n1BwvZigf1zgL0ignVBhvTBNmPignHDxnLCYbYDw50Aw1LigvYCM9YCYb3AgvUihrOzsbNzw5LCMf0zwqGzw5KCg9PBNqGDhjPzxmGDg8GD3jPDguGy3jLyxrLzf9IEs91CgrHDgvKx2j5ihrVigeGBM9Ulwv4Axn0zw50ignVBhvTBI4','nteXmNzstML5ra','EYbMAwvSzdOGiNn0yxr1CYiSigLUoIbBiMfJDgL2zsiSicjPBMfJDgL2zsjDih0','yMvSB25NC1rV','CMvSyxrPB25Z','DxbKyxrLzf9HDa','sLnptIbJB2X1Bw4GkePtt05cig9UifbVC3rNCMvtuuWSiePtt04GB24GtxLtuuWSienmt0iGB24Gt3jHy2XLks4','uMvQzwn0igrLBgv0zs91CgrHDguGD2HLBIbJAgLSzcbYB3DZigv4Axn0lG','revquKvdqvrfrdOGvgHPCYbTB2rPzMLLCIbUBYbSB25NzxiGAgfZigz1BMn0Aw9UywWGzwzMzwn0igf0ihrOzsbereWGB3iGCNvUDgLTzsbSzxzLBc4Gqxv0BY11CgrHDguGzM9YihvWzgf0zwrFyxqGAxmGAgfUzgXLzcbIEsb0AguGuKrgigXHEwvYicHHDwrPDenVBhvTBNmGy29UDMvUDgLVBIbPBIbcyxnLtw9KzwWGCNvUDgLTzsKGyMfZzwqGB24GzMLLBgqGBMfTAw5NignVBNzLBNrPB24Sig5VDcbIEsb0AgLZifnerIbTyxjRzxiUiev4Axn0Aw5NihvZywDLigLZihbYzxnLCNzLzcbMB3iGyMfJA3DHCMqGy29TCgf0AwjPBgL0EsbIDxqGC2HVDwXKigjLihjLBw92zwqGzNjVBsbUzxCGDgvTCgXHDgvZlG','ChjPBwfYEuTLEq','rgvMzxiGy29UC3rYywLUDcbJAgvJAYaOC2vTyw50AwnHBgX5ihnPBwLSyxiGDg8GCMvZDhjPy3qGB24GBw9ZDcbKAwfSzwn0CYKU','q29UC2vXDwvUy2u6igLZx2rLBgv0zwqSigrLBgv0zwrFyxqSigfUzcbKzwXLDgvKx2j5igfYzsbYzxnLCNzLzcbUyw1LCZSGDgHLEsbJyw5UB3qGyMuGDxnLzcbHCYbVCMrPBMfYEsbJB2X1Bw5ZigLUifjfu1rgB3jNzs1Tyw5Hz2vKihrHyMXLCY4','rgvMyxvSDcb2ywX1zsbMB3jTyxqGzgvWzw5KCYbVBIb0ExbLoIbYyxCGzM9YigjVB2XLyw4GkgrLzMf1Bhq6Dhj1zsKSihjHDYbMB3iGAw50zwDLCIaOzgvMyxvSDdOWksWGC2LUz2XLlxf1B3rLzcbMB3iGC3rYAw5NicHKzwzHDwX0oID2ywX1zsCPlcbIyxjLigLKzw50AwzPzxiGzM9YifnrtcbJB25ZDgfUDhmGkgrLzMf1Bhq6y3vYCMvUDf9KyxrLksWGAwrLBNrPzMLLCIGPigzVCIbUyxrPDMuGzNvUy3rPB24Gy2fSBhmGkgrLzMf1Bhq6BM93kcKPlG','rM9YzwLNBIbRzxKGDxnLCYbKB3qGBM90yxrPB246igzRoJX0ywjSzt4UpgnVBhvTBJ4GkguUzY4SigzRoMnHDgvNB3j5lMLKks4GvgHLihbHCNnLCIbYzwPLy3rZihbHCMvUDgHLC2vZihn5BNrHEc4','C3rYAw5NFgfYCMf5','zxHWB3j0CW','Dgv4Da','zgvMyxvSDdO8BgL0zxjHBd4GFcbKzwzHDwX0oIC8C3rYAw5NpICGFcbKzwzHDwX0oJXJB25ZDgfUDd4GFcbKzwzHDwX0oJXMDw5JDgLVBJ4Okq','vgHLigzPzwXKig11C3qGAgf2zsbHihnPBMDSzs1JB2X1Bw4Gvu5juvvfignVBNn0CMfPBNqGkg5VifvosvfvrsWGB3iGB25SEsbJB21WB3nPDguGvu5juvvfoIbfuLjpuIKU','r3jLyxrLCIb0AgfUlG','ntrmB05hB3i','ndy1mZK5ouX2vK5mrq','id0GrKfmu0u','EYbMAwvSzdOGiMrPC2nVDw50iIWGBhrLoIaXmdaGFq','qwXSidqGy29SDw1UCYbHCMuGBNvSBgfIBguUifrOzsbJCMvHDgvKx2j5l3vWzgf0zwrFyNKGy29SDw1UCYbTyxKGyMuGzw1WDhKGzM9YihjVD3mGAw5Zzxj0zwqGyNKGC3LZDgvTihnLzwrZlcbTAwDYyxrPB25ZlcbVCIbIyxrJAcbPBxbVCNrZihrOyxqGzg8GBM90igHHDMuGysb1C2vYignVBNrLEhqU','C3rYAw5NoJCW','veLnrvnuqu1qierfrKfvtfqGpg5HDgL2zv9UB3CGCgvYigrPywXLy3q+','tgfZDcbTB2rPzMLJyxrPB24GDgLTzxn0yw1WlIbbDxrVlxvWzgf0zsbPCYbOyw5KBgvKigj5ihrOzsbsreyGCNvUDgLTzsaOqMfZzu1VzgvSigf1zgL0q29SDw1UCYbJB252zw50Aw9Uksb3AgLJAcbPBMPLy3rZihvWzgf0zwrFyxqGpsbdvvjsru5ux1rjtuvtvefnucbPBNrVigv2zxj5ifvqrefursbZDgf0zw1LBNqGyMfZzwqGB24GzMLLBgqGBMfTAw5NlcbUB3qGyNKGyw55ifnerIbTyxjRzxiUieLUAxrPywWGsu5trvjuihzHBhvLigLZigfSC28GAgfUzgXLzcbIEsb0AguGuKrgihj1BNrPBwuGyxvKAxrdB2X1Bw5ZigHLBhbLCI4','zgf0zq','C3rYAw5NFg51BgW','DhLWzq','tM9UlxvUAxf1zsbPBMrLEgvZlIbfywnOigvUDhj5igLZigfYCMf5ig9MignVBhvTBIbUyw1LCYbVCIbVyMPLy3qGEYbUyw1LlcbJB2X1Bw5Zih0U','tuq1igHHC2GGoc1JAgfYywn0zxiGC3vMzML4ihDOzw4GBMfTzsbLEgnLzwrZig1HEeXLBMD0Aa','u3rHBMrHBg9UzsbJB25ZDhjHAw50CYaOCgSSig5VDg51BgWSihvUAxf1zsWGAw5KzxGPihrHA2uGBM8GDMfSDwuUifrOzsbSzwDHy3KGyxv0B1vWzgf0zsb0B2TLBIbPCYbZDgLSBcbWyxjZzwqGzM9YigjHy2T3yxjKignVBxbHDgLIAwXPDhKGyNv0igLZigrLChjLy2f0zwqGyw5KigHHCYbUBYbMDw5JDgLVBMfSigvMzMvJDc4','Aw50zwDLCG','EYb0ExbLoIaIAgfZt25LiIWGDgfYz2v0oIaIChjVzMLSzsiSigXVy2fSs2v5oIaIDxnLCL9PzciSihjLzMvYzw5Jzxm6icj1C2vYx2LKiIb9','yM9VBgvHBG','Bg9JywXlzxK','y3jLyxrLzf9HDa','Aw5KzxG','BxLZCwWY','r3jLyxrLCIb0AgfUig9YigvXDwfSihrVlG','rKSGzMLLBgqGBxvZDcbIzsbUDwXSywjSzs4','y2HLy2TZ','BMf0AxzLiejpt0Xfqu4','zw5HyMXLzca9ihrYDwuGD2L0AcbHBNKGy29UDhjHy3qGy29SDw1Uig1PC3nPBMC6ihzHBgLKyxrPB24Grvjst1iGkg1PC3nPBMCGy29SDw1UCYbHCMuGBgLZDgvKks4','rgvSzxrPB24Gywn0B3iGAwrLBNrPzMLLCIWGBNvSBgfIBguUie5vteWGD2HPBguGDgHLihjVDYbPCYbHBgL2zs4','rw5NAw5Lihn0AwXSihbHCNnLCYb0AgLZihrVA2vUicHIywnRD2fYzcbJB21WyxrPyMLSAxr5ksWGyNv0ieretcbVDxrWDxqGAxmGAwrLBNrPy2fSihrVihbSywLUicD0Aw1LC3rHBxaNlIbvC2uGj3rPBwvZDgfTCcCGywXVBMuUifrOzsbHy3r1ywWGyxv0BY11CgrHDguGyMvOyxzPB3iGAxmGzg9JDw1LBNrLzcbPBIb0AguGuKrgigf1zgL0q29SDw1UCYbJyxrHBg9NicHMAwvSzc12ywXPzgf0Aw9UoMnHDgfSB2CPlG','t25LlxrVlw9UzsaOAw52zxjZzsbVzIbIzwXVBMDZvg8PlIbpChrPB25HBcbPBNzLCNnLigrLy2XHCMf0Aw9Uig9UihrOzsbWyxjLBNqGC2LKztSGzg9LCYbUB3qGywzMzwn0ieretc4','vgHLigvYCM9Yig1LC3nHz2uGC3vNz2vZDhmGDhDVihDHExmGB3v0oIb1C2uGAgfYzc1KzwXLDguGzM9YihbYB2nLC3mTzhjPDMvUihrHyMXLCYaOyMfSyw5JzsWGBgvKz2vYlcbZBMfWC2HVDcWGCgvYAw9KlwnSB3nLksWGB3iGy2HHBMDLihrOzsbvtKLrvuuGAw50BYbHihnPBMDSzs1JB2X1Bw4GC3rYAw5Nigj1C2LUzxnZignVzguU','DgLTzxn0yw1WigrLzMf1Bhq6BM93kcK','vMfSDwuGy29UC3rYywLUDhmGkgrLzMf1BhqSigzRksbYzxf1AxjLignVBNn0CMfPBNq6DMfSDwuGzM9YBwf0lG','mtvltfnQwhi','yMLNAw50','mty2odKXmdbby29fsM4','qxv0BY1KzxrLy3rLzcbMCM9TigzPzwXKihnOB3j0AgfUzcaICgSIihDOzw4GBM90ihnWzwnPzMLLzc4','rxf1ywWGDg8U','DgLTzxn0yw1W','vKfsq0HbuIGZnIKGufjjtufswsblrvK','DMfSDwu','u3rYAw5NihnOB3j0AgfUzcbMB3iGzMLLBgqGzgvMAw5PDgLVBI4GvhLWzsbYzxf1AxjLzcbHDcbZDgfYDcWGzM9SBg93zwqGyNKGB3b0Aw9UywWGBw9KAwzPzxiGyw5KihnWywnLlxnLCgfYyxrLzcbJB25ZDhjHAw50CY4','B25ezwXLDgu','Ahr0Chm6lY9Yzxn0zM9Yz2uUzgv2l2rVy3mVy2XPl3nJAgvTys1KzwzPBML0Aw9U','B2jQzwn0','C3rHBMrHBg9Uzq','vgHLigzPzwXKihr5CguGBxvZDcbIzsbZDhjPBMCGB3iGDgv4DcaODMfSDwuGBxv0yxrPB24GCMvXDwLYzxmGysbZDhjPBMCGDhLWztOGrvjst1iGB3rOzxj3AxnLks4','id0GrKfmu0uGqu5eia','vKfsq0HbuIG2ncKGD2L0AcbZAw5NBguTy29SDw1UigLUzgv4','ntK3oda4tvznDwfm','vMfYAwfIBguTBgvUz3rOihrLEhqUieXLBMD0AcbTB2rPzMLLCIbYzxf1AxjLzc4','rgvSzxrPB24GDgLTzxn0yw1WlcbUDwXSywjSzs4GtLvmtcb3AgLSzsb0AguGCM93igLZigfSAxzLlG','EYbMAwvSzdOGiNr5CguIlcbUzxe6icjZExn0zw0Iih0','zw5HyMXLzca9ihrYDwuGD2L0AcbHBgWGDgHYzwuGy29SDw1UCYbKzwnSyxjLzcbHBMqGy29YCMvJDgX5ihr5CgvKoIb2ywXPzc4','ody2nKDJvKXQrW','CgH5C2LJywWGBgvUz3rOid49igjHC2uGBgvUz3rOicSG','C3rYAw5NoJi1nsbUB3rUDwXS','tg9UzY1MB3jTihrLEhqGD2L0Ag91DcbSzw5NDgGGBgLTAxqGkfrfwfqVq0XpqIKU','w1SIy2f0zwDVCNLFy29KzsjDlcbBiNrLBMfUDf9PzciSicjJyxrLz29YEv9JB2rLiL1D','u29MDc1KzwXLDguGy29SDw1UCYbKzwnSyxjLzcb3AgLSzsbLBMfIBgvKigLZig5VDcb0CNvLoIb2ywXPzgf0Aw9UievsuK9slG','vMfSDwuGBxvZDcbIzsbVBMuGB2yGysbSAxn0lG','zMS6phrHyMXLpI48y29SDw1UpG','CMvZDhjPy3q','BgvUz3rOig11C3qGyMuGysbWB3nPDgL2zsbPBNrLz2vYicHIyxnLigXLBMD0Aca9ig1HEgLTDw0GDxnLCI1PBNb1DcbSzw5NDgGPoIbfuLjpuIbVDgHLCNDPC2uU','ieLtie5pvcbovuXmksbpuIaO','v2HLBIbLBMfIBgvKid0GDhj1zsWGzxzLCNKGvu5juvvfignVBNn0CMfPBNqGB24GDgHLihrHyMXLigLZignOzwnRzwqGzM9YihnVzNqTzgvSzxrLigvSAwDPyMLSAxr5lG','C3rYAw5NoJeWmcbKzwzHDwX0oIDWzw5KAw5NjW','vKfsq0HbuIGZnIKGD2L0AcbgsYb0BYbJyxrLz29YEsHPzcKSigf1Dg8GyMvSB25NC1rVihjLBgf0Aw9U','rxzLCNKGC29MDc1KzwXLDguGDgfIBguGz2v0CYbHienirunlignVBNn0CMfPBNqGD2L0Acb0AguGzgv0zxjTAw5PC3rPyYbUyw1LignOA188DgfIBgu+xW','C25HA2vFy2fZzq','ieLtie5pvcbovuXmieforca','CMvMzxjLBMnLCW','C3rYAw5NoJi1nq','vxnLCIbPzgvUDgLMAwvYig9MihrOzsbSyxn0ig1VzgLMAwvYlIbtzxqGyNKGyxbWBgLJyxrPB24GBgf5zxiGB24GvvbeqvrflcbUB3qGyNKGzgf0ywjHC2uGzgvMyxvSDc4','vKfsq0HbuIGYntuPie5pvcbovuXm','C3rYAw5NoJy0igLUzgv4','zMLLBgrZ','u2LUz2XLlwnVBhvTBIbvtKLrvuuGy29UC3rYywLUDhmGB24GBM9Ulxn0CMLUzYbJB2X1Bw5ZigfYzsbYzwPLy3rLzcbMB3iGDgHLihnHBwuGCMvHC29UicHZDwzMAxGGBxv0yxrPB24GB25SEsbHChbSAwvZihrVihn0CMLUzY90zxH0ks4','q2fUBM90ignVzxHPC3qGD2L0AcbLEhbSAwnPDcbYzwXHDgLVBIbLBNrYEsbYzwzLCMvUy2LUzYb0AguGC2fTzsbMAwvSzc4','t2jQzwn0ig9MigzPzwXKigrLzMLUAxrPB25ZigLUihnOB3j0AgfUzcbZDhjPBMCGzM9YBwf0lG','lwnOyxjHy3rLCIbZDwzMAxGGAxmGiImJiIaOmIKGkYb1DwLKDJCGkdm2ks4GrxHHBxbSztOGBgvUz3rOoIa1mcbYzxf1AxjLCYb0AguGzMLLBgqGDg8GyMuGzgvJBgfYzwqGyxqGBgvHC3qGC3rYAw5NoJG4oYbHihnOB3j0zxiGzgvJBgfYyxrPB24GzMfPBhmGDMfSAwrHDgLVBIb3AxrOihrOzsbKzwnSyxjLzcbHBMqGCMvXDwLYzwqGBgvUz3rOCYbPBIb0AguGBwvZC2fNzs4'];a0_0x2350=function(){return _0x178d54;};return a0_0x2350();}function a0_0x4423(_0x42fac2,_0xef2bcd){_0x42fac2=_0x42fac2-0x1c9;const _0x235028=a0_0x2350();let _0x4423b8=_0x235028[_0x42fac2];if(a0_0x4423['Fdigxf']===undefined){var _0x52dfba=function(_0xebf14){const _0x5811fd='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x24c790='',_0x55fed0='';for(let _0x46a28f=0x0,_0x17c762,_0xef2b84,_0x5808ff=0x0;_0xef2b84=_0xebf14['charAt'](_0x5808ff++);~_0xef2b84&&(_0x17c762=_0x46a28f%0x4?_0x17c762*0x40+_0xef2b84:_0xef2b84,_0x46a28f++%0x4)?_0x24c790+=String['fromCharCode'](0xff&_0x17c762>>(-0x2*_0x46a28f&0x6)):0x0){_0xef2b84=_0x5811fd['indexOf'](_0xef2b84);}for(let _0x141cbf=0x0,_0x3a8e4e=_0x24c790['length'];_0x141cbf<_0x3a8e4e;_0x141cbf++){_0x55fed0+='%'+('00'+_0x24c790['charCodeAt'](_0x141cbf)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x55fed0);};a0_0x4423['WqyxHt']=_0x52dfba,a0_0x4423['YzslnK']={},a0_0x4423['Fdigxf']=!![];}const _0x47142a=_0x235028[0x0],_0xcdd250=_0x42fac2+_0x47142a,_0x4da77c=a0_0x4423['YzslnK'][_0xcdd250];return!_0x4da77c?(_0x4423b8=a0_0x4423['WqyxHt'](_0x4423b8),a0_0x4423['YzslnK'][_0xcdd250]=_0x4423b8):_0x4423b8=_0x4da77c,_0x4423b8;}(function(_0x33197c,_0x35df00){const _0x2bacbc=a0_0x4423,_0x2f11ee=_0x33197c();while(!![]){try{const _0x1792aa=-parseInt(_0x2bacbc(0x20b))/0x1*(-parseInt(_0x2bacbc(0x244))/0x2)+parseInt(_0x2bacbc(0x21a))/0x3+parseInt(_0x2bacbc(0x1e7))/0x4*(-parseInt(_0x2bacbc(0x1d7))/0x5)+-parseInt(_0x2bacbc(0x22a))/0x6+-parseInt(_0x2bacbc(0x1ec))/0x7*(parseInt(_0x2bacbc(0x231))/0x8)+-parseInt(_0x2bacbc(0x245))/0x9+parseInt(_0x2bacbc(0x1d9))/0xa;if(_0x1792aa===_0x35df00)break;else _0x2f11ee['push'](_0x2f11ee['shift']());}catch(_0x2b55dc){_0x2f11ee['push'](_0x2f11ee['shift']());}}}(a0_0x2350,0x6d240));const {IS_DELETED_COLUMN,DELETED_AT_COLUMN,DELETED_BY_COLUMN,SOFT_DELETE_COLUMN_TYPES,SOFT_DELETE_SUFFIX_LENGTH,SOFT_DELETE_CHECK_SUFFIX,SOFT_DELETE_PHASE1_DIALECT}=require('../dbschema-kit/soft-delete-constants'),SCHEMA_VERSION='1.1',SOURCE='dbschema-catalog',DOCUMENTATION_URL=a0_0x968dcd(0x1e1),DEFINE_MODEL_OPTIONS=[{'name':a0_0x968dcd(0x209),'required':![],'type':a0_0x968dcd(0x24d),'description':a0_0x968dcd(0x219),'notes':'null\x20or\x20empty\x20string\x20means\x20default\x20schema.'},{'name':a0_0x968dcd(0x202),'required':!![],'type':'object','description':a0_0x968dcd(0x205),'example':'{\x20id:\x20\x22string:36\x20pk\x22,\x20name:\x20\x22string:255\x20notnull\x22\x20}'},{'name':a0_0x968dcd(0x239),'required':![],'type':a0_0x968dcd(0x23e),'description':'Override\x20primary\x20key.\x20Single\x20field\x20name\x20or\x20composite\x20array.','notes':a0_0x968dcd(0x1da)},{'name':a0_0x968dcd(0x234),'required':![],'type':'object','description':'Inter-table\x20relations\x20(belongsTo,\x20hasOne,\x20hasMany).','example':'{\x20category:\x20{\x20type:\x20\x22belongsTo\x22,\x20references:\x20\x22category(id)\x22\x20}\x20}'},{'name':'indexes','required':![],'type':a0_0x968dcd(0x223),'description':a0_0x968dcd(0x24f),'example':'[[\x22status\x22,\x20\x22created_at\x22]]'},{'name':a0_0x968dcd(0x21b),'required':![],'type':a0_0x968dcd(0x223),'description':'Unique\x20constraints\x20(single\x20or\x20composite).','example':a0_0x968dcd(0x1f0)},{'name':a0_0x968dcd(0x1ce),'required':![],'type':'array','description':'CHECK\x20constraints.\x20Each\x20entry\x20uses\x20operator-as-key\x20shape:\x20{\x20name?,\x20field,\x20<operator>:\x20<value>\x20}\x20where\x20<operator>\x20is\x20one\x20of\x20checkOperations\x20(in,\x20eq,\x20neq,\x20gt,\x20gte,\x20lt,\x20lte).\x20The\x20internal\x20IR\x20shape\x20after\x20ir-builder\x20normalization\x20is\x20{\x20name?,\x20field,\x20op,\x20value\x20},\x20but\x20that\x20is\x20NOT\x20the\x20user\x20input\x20format.','example':'[{\x20field:\x20\x22status\x22,\x20in:\x20[\x22active\x22,\x20\x22inactive\x22]\x20},\x20{\x20field:\x20\x22qty\x22,\x20gte:\x200\x20}]'},{'name':'softDelete','required':![],'type':a0_0x968dcd(0x1e2),'description':a0_0x968dcd(0x21f),'example':a0_0x968dcd(0x22b),'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':'string','description':a0_0x968dcd(0x1e8),'requiresModifier':!![],'modifierFormat':'string:<length>','example':a0_0x968dcd(0x1fe),'notes':'Explicit\x20length\x20required\x20for\x20cross-dialect\x20portability.'},{'name':a0_0x968dcd(0x240),'description':a0_0x968dcd(0x1ef),'requiresModifier':![],'example':'text'},{'name':a0_0x968dcd(0x252),'description':'32-bit\x20signed\x20integer\x20(INT/INTEGER).','requiresModifier':![],'example':a0_0x968dcd(0x252)},{'name':'bigint','description':a0_0x968dcd(0x20f),'requiresModifier':![],'example':a0_0x968dcd(0x1d8)},{'name':'decimal','description':a0_0x968dcd(0x20d),'requiresModifier':!![],'modifierFormat':'decimal:<precision>,<scale>','example':'decimal:15,2','notes':a0_0x968dcd(0x212)},{'name':a0_0x968dcd(0x254),'description':'Boolean\x20value\x20(native\x20BOOLEAN\x20on\x20PostgreSQL,\x20VARCHAR\x20on\x20others).','requiresModifier':![],'example':'boolean'},{'name':'date','description':'Date\x20only\x20(no\x20time\x20component).','requiresModifier':![],'example':a0_0x968dcd(0x24c)},{'name':'timestamp','description':a0_0x968dcd(0x218),'requiresModifier':![],'example':a0_0x968dcd(0x1dc),'notes':'Default\x20timezone\x20behavior\x20is\x20dialect-specific.'},{'name':'uuid','description':'UUID.\x20Native\x20UUID\x20on\x20PostgreSQL,\x20VARCHAR(36)\x20on\x20others.','requiresModifier':![],'example':'uuid'},{'name':'json','description':a0_0x968dcd(0x236),'requiresModifier':![],'example':a0_0x968dcd(0x20e)}],CONSTRAINTS=[{'name':'pk','kind':'standalone','description':'Marks\x20field\x20as\x20primary\x20key.','example':'string:36\x20pk'},{'name':'notnull','kind':a0_0x968dcd(0x1e3),'description':'NOT\x20NULL\x20constraint.','example':a0_0x968dcd(0x1ee)},{'name':'unique','kind':a0_0x968dcd(0x1e3),'description':'Single-column\x20unique\x20constraint.','example':'string:32\x20unique'},{'name':a0_0x968dcd(0x1ca),'kind':a0_0x968dcd(0x1e3),'description':'Single-column\x20non-unique\x20index.','example':a0_0x968dcd(0x201)},{'name':'autoUpdate','kind':'standalone','deprecated':!![],'description':a0_0x968dcd(0x238),'example':'timestamp','notes':a0_0x968dcd(0x1d2)},{'name':'default','kind':'value','description':a0_0x968dcd(0x20a),'valueFormat':a0_0x968dcd(0x241),'example':'boolean\x20default:true'},{'name':'fk','kind':a0_0x968dcd(0x1de),'description':'Foreign\x20key\x20reference.\x20Auto-generates\x20a\x20belongsTo\x20relation\x20entry.','valueFormat':a0_0x968dcd(0x1f3),'example':'string:36\x20fk:category.id','notes':a0_0x968dcd(0x204)}],RELATION_TYPES=[{'name':a0_0x968dcd(0x233),'description':'Many-to-one.\x20This\x20table\x20holds\x20the\x20FK\x20column\x20referencing\x20the\x20parent\x20table.','requiredFields':['type','localKey','references'],'optionalFields':['target',a0_0x968dcd(0x1e0),a0_0x968dcd(0x228)],'example':a0_0x968dcd(0x221),'notes':a0_0x968dcd(0x208)},{'name':a0_0x968dcd(0x207),'description':a0_0x968dcd(0x1d3),'requiredFields':[a0_0x968dcd(0x24e),'localKey','references'],'optionalFields':['target',a0_0x968dcd(0x1e0),'onUpdate'],'example':a0_0x968dcd(0x253)},{'name':'hasMany','description':'One-to-many\x20(inverse\x20of\x20belongsTo).\x20Optional\x20inverse\x20declaration\x20on\x20the\x20parent\x20side;\x20does\x20not\x20affect\x20DDL.','requiredFields':[a0_0x968dcd(0x24e),a0_0x968dcd(0x255),a0_0x968dcd(0x1fd)],'optionalFields':['target',a0_0x968dcd(0x1e0),a0_0x968dcd(0x228)],'example':'{\x20type:\x20\x22hasMany\x22,\x20target:\x20\x22order_item\x22,\x20localKey:\x20\x22order_id\x22,\x20references:\x20\x22order_id\x22\x20}'}],REFERENTIAL_ACTIONS=[{'name':'cascade','description':a0_0x968dcd(0x210),'appliesTo':[a0_0x968dcd(0x1e0),'onUpdate']},{'name':a0_0x968dcd(0x1f4),'description':a0_0x968dcd(0x237),'appliesTo':['onDelete','onUpdate']},{'name':'setNull','description':'Set\x20FK\x20column\x20to\x20NULL\x20on\x20child\x20rows.','appliesTo':[a0_0x968dcd(0x1e0),'onUpdate'],'notes':a0_0x968dcd(0x1cd)},{'name':a0_0x968dcd(0x20c),'description':a0_0x968dcd(0x23a),'appliesTo':[a0_0x968dcd(0x1e0),a0_0x968dcd(0x228)]}],CHECK_OPERATIONS=[{'name':'in','description':a0_0x968dcd(0x1f2),'valueType':'array','example':a0_0x968dcd(0x232)},{'name':'eq','description':a0_0x968dcd(0x1db),'valueType':a0_0x968dcd(0x220),'example':'{\x20field:\x20\x22type\x22,\x20eq:\x20\x22user\x22\x20}'},{'name':'neq','description':'Not\x20equal\x20to.','valueType':'scalar','example':a0_0x968dcd(0x1ea)},{'name':'gt','description':a0_0x968dcd(0x243),'valueType':'numeric','example':a0_0x968dcd(0x225)},{'name':'gte','description':a0_0x968dcd(0x1cc),'valueType':a0_0x968dcd(0x229),'example':'{\x20field:\x20\x22qty\x22,\x20gte:\x200\x20}'},{'name':'lt','description':'Less\x20than.','valueType':'numeric','example':'{\x20field:\x20\x22discount\x22,\x20lt:\x20100\x20}'},{'name':a0_0x968dcd(0x226),'description':a0_0x968dcd(0x222),'valueType':a0_0x968dcd(0x229),'example':a0_0x968dcd(0x247)}],AUDIT_COLUMNS={'description':'Standard\x204-column\x20audit\x20convention\x20for\x20tables\x20managed\x20by\x20RESTForge.\x20The\x20same\x20convention\x20is\x20documented\x20in\x20field-validation:catalog\x20(auditColumns\x20section)\x20for\x20the\x20RDF/backend\x20layer.\x20SDF\x20and\x20RDF\x20stay\x20aligned\x20when\x20both\x20declare\x20these\x204\x20columns.','columns':[{'name':a0_0x968dcd(0x1c9),'shorthand':a0_0x968dcd(0x1d5),'nullable':!![],'purpose':'Record\x20creation\x20timestamp.\x20Auto-set\x20on\x20INSERT\x20via\x20DEFAULT\x20now().\x20Native\x20function\x20translates\x20per\x20dialect\x20(postgres:\x20CURRENT_TIMESTAMP,\x20mysql:\x20NOW(),\x20oracle:\x20SYSTIMESTAMP,\x20sqlite:\x20CURRENT_TIMESTAMP).'},{'name':'created_by','shorthand':a0_0x968dcd(0x21d),'nullable':!![],'purpose':a0_0x968dcd(0x213)},{'name':a0_0x968dcd(0x235),'shorthand':a0_0x968dcd(0x1dc),'nullable':!![],'purpose':a0_0x968dcd(0x24b)},{'name':a0_0x968dcd(0x227),'shorthand':'string:100','nullable':!![],'purpose':a0_0x968dcd(0x1ff)}],'convention':{'emitInSkeleton':'Yes\x20—\x20dbschema:init\x20emits\x20all\x204\x20columns\x20by\x20default.\x20Tables\x20that\x20do\x20not\x20need\x20audit\x20(lookup\x20tables,\x20system\x20tables)\x20can\x20manually\x20remove\x20these\x20fields\x20from\x20the\x20generated\x20skeleton.','nullablePolicy':a0_0x968dcd(0x248),'relationToRdf':a0_0x968dcd(0x230)}},SOFT_DELETE={'description':a0_0x968dcd(0x21c),'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':'boolean\x20notnull\x20default:false','nullable':![],'purpose':'Deletion\x20flag.\x20Declare\x20as\x20notnull\x20default:false.'},{'name':DELETED_AT_COLUMN,'type':SOFT_DELETE_COLUMN_TYPES[DELETED_AT_COLUMN],'shorthand':a0_0x968dcd(0x1dc),'nullable':!![],'purpose':a0_0x968dcd(0x1e9)},{'name':DELETED_BY_COLUMN,'type':SOFT_DELETE_COLUMN_TYPES[DELETED_BY_COLUMN],'shorthand':a0_0x968dcd(0x249),'nullable':!![],'purpose':a0_0x968dcd(0x1d1)}],'biconditionalRules':[a0_0x968dcd(0x1eb),a0_0x968dcd(0x1d0),a0_0x968dcd(0x1f1),'Contract\x20column\x20declared\x20with\x20a\x20wrong\x20type:\x20validation\x20ERROR.',a0_0x968dcd(0x23b)]},'reusableRules':{'description':'Soft-delete\x20keeps\x20rows\x20in\x20the\x20table,\x20so\x20UNIQUE\x20constraints\x20still\x20see\x20deleted\x20rows.\x20Columns\x20listed\x20in\x20reusable\x20have\x20their\x20value\x20mutated\x20on\x20delete\x20to\x20\x22{value}##{uuidv7}\x22\x20so\x20the\x20original\x20value\x20can\x20be\x20reused\x20by\x20a\x20new\x20row.','requirements':['The\x20field\x20must\x20be\x20declared\x20in\x20fields\x20(unknown\x20field:\x20ERROR).',a0_0x968dcd(0x1e4),a0_0x968dcd(0x242),a0_0x968dcd(0x1f5)],'suffixLength':SOFT_DELETE_SUFFIX_LENGTH,'physicalLengthFormula':a0_0x968dcd(0x1ed)+SOFT_DELETE_SUFFIX_LENGTH,'notes':'The\x20'+SOFT_DELETE_SUFFIX_LENGTH+a0_0x968dcd(0x206)},'uniqueEligibilityGate':{'description':a0_0x968dcd(0x1f7),'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_0x968dcd(0x203)],'suggestion':a0_0x968dcd(0x1d4)},'emittedDdl':{'consistencyCheck':{'namePattern':'chk_<table>_'+SOFT_DELETE_CHECK_SUFFIX,'description':a0_0x968dcd(0x1fa)+SOFT_DELETE_CHECK_SUFFIX+'\x20enforcing:\x20('+IS_DELETED_COLUMN+'\x20=\x20TRUE\x20AND\x20'+DELETED_AT_COLUMN+a0_0x968dcd(0x1fc)+DELETED_BY_COLUMN+a0_0x968dcd(0x1f6)+IS_DELETED_COLUMN+a0_0x968dcd(0x1e5)+DELETED_AT_COLUMN+a0_0x968dcd(0x217)+DELETED_BY_COLUMN+'\x20IS\x20NULL).\x20This\x20keeps\x20the\x20three\x20columns\x20consistent\x20at\x20the\x20data\x20level\x20regardless\x20of\x20the\x20write\x20path.'},'partialIndex':{'description':'Non-unique\x20indexes\x20on\x20soft-delete\x20tables\x20are\x20emitted\x20as\x20PostgreSQL\x20partial\x20indexes\x20with\x20WHERE\x20'+IS_DELETED_COLUMN+'\x20=\x20FALSE.','example':'CREATE\x20INDEX\x20idx_visitor_categories_category_name\x20ON\x20visitor_categories\x20(category_name)\x20WHERE\x20'+IS_DELETED_COLUMN+a0_0x968dcd(0x246),'notes':'UNIQUE\x20constraints\x20are\x20NOT\x20made\x20partial\x20on\x20any\x20dialect.\x20Uniqueness\x20keeps\x20covering\x20deleted\x20rows;\x20value\x20reuse\x20is\x20handled\x20by\x20the\x20suffix\x20mutation,\x20not\x20by\x20a\x20partial\x20unique\x20index.'}},'dialectSupport':{'supported':[SOFT_DELETE_PHASE1_DIALECT],'description':'Phase\x201:\x20PostgreSQL\x20only.\x20On\x20other\x20dialects\x20the\x20softDelete\x20block\x20is\x20not\x20supported\x20(DDL\x20generation\x20fails\x20with\x20a\x20clear\x20error)\x20and\x20soft-delete-named\x20columns\x20get\x20no\x20special\x20treatment\x20during\x20introspect.'},'introspectRoundTrip':'schema\x20introspect\x20recognizes\x20a\x20complete\x20soft-delete\x20table\x20(three\x20correctly\x20typed\x20contract\x20columns\x20+\x20consistency\x20CHECK)\x20and\x20writes\x20back\x20softDelete:\x20{\x20enabled:\x20true\x20}\x20in\x20the\x20generated\x20SDF.\x20Tables\x20with\x20incomplete\x20or\x20non-conforming\x20soft-delete\x20columns\x20block\x20introspect\x20with\x20an\x20error.','rdfDerivation':'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':'<type>[:<modifier>]\x20[<constraint>[:<value>]]...','description':a0_0x968dcd(0x1df),'rules':[a0_0x968dcd(0x215),'Modifier\x20is\x20mandatory\x20for\x20type\x20\x22string\x22\x20(length)\x20and\x20\x22decimal\x22\x20(precision,scale).',a0_0x968dcd(0x251),a0_0x968dcd(0x1d6),a0_0x968dcd(0x23c),a0_0x968dcd(0x23d)],'examples':[{'input':'string:36\x20pk','meaning':a0_0x968dcd(0x1dd)},{'input':'string:255\x20notnull','meaning':a0_0x968dcd(0x200)},{'input':'decimal:15,2\x20notnull\x20default:0','meaning':a0_0x968dcd(0x224)},{'input':'boolean\x20default:true','meaning':'BOOLEAN\x20DEFAULT\x20TRUE'},{'input':a0_0x968dcd(0x1f8),'meaning':a0_0x968dcd(0x22c)},{'input':a0_0x968dcd(0x1d5),'meaning':a0_0x968dcd(0x24a)},{'input':a0_0x968dcd(0x22d),'meaning':a0_0x968dcd(0x1f9)},{'input':'string:64\x20index','meaning':a0_0x968dcd(0x1e6)}]},NAMING_RULES={'tableName':{'format':a0_0x968dcd(0x1fb),'description':a0_0x968dcd(0x22e)},'fieldName':{'format':a0_0x968dcd(0x1fb),'description':a0_0x968dcd(0x21e)},'constraintName':{'format':'<prefix>_<table>_<suffix>','defaultMaxLength':0x1e,'fallbackStrategy':a0_0x968dcd(0x250),'description':'Constraint\x20names\x20auto-generated\x20with\x20type-specific\x20prefix\x20(pk,\x20fk,\x20idx,\x20uq,\x20ck)\x20and\x20dialect-specific\x20max\x20length.'},'compositeShortName':{'description':'For\x20composite\x20indexes/uniques,\x20name\x20is\x20derived\x20by\x20joining\x20columns\x20with\x20underscore\x20and\x20truncating\x20when\x20needed.'}},DIALECT_SUPPORT=[{'name':'postgres','driver':'pg','booleanStorage':a0_0x968dcd(0x1cf)},{'name':'mysql','driver':a0_0x968dcd(0x1cb),'booleanStorage':a0_0x968dcd(0x22f)},{'name':a0_0x968dcd(0x211),'driver':'oracledb','booleanStorage':a0_0x968dcd(0x216)},{'name':'sqlite','driver':'better-sqlite3','booleanStorage':'TEXT'}],DBSCHEMA_CATALOG={'schemaVersion':SCHEMA_VERSION,'source':SOURCE,'summary':{'totalDefineModelOptions':DEFINE_MODEL_OPTIONS[a0_0x968dcd(0x214)],'totalFieldTypes':FIELD_TYPES[a0_0x968dcd(0x214)],'totalConstraints':CONSTRAINTS['length'],'totalRelationTypes':RELATION_TYPES[a0_0x968dcd(0x214)],'totalReferentialActions':REFERENTIAL_ACTIONS['length'],'totalCheckOperations':CHECK_OPERATIONS[a0_0x968dcd(0x214)],'totalAuditColumns':AUDIT_COLUMNS['columns'][a0_0x968dcd(0x214)],'totalDialects':DIALECT_SUPPORT[a0_0x968dcd(0x214)]},'defineModelOptions':DEFINE_MODEL_OPTIONS,'fieldTypes':FIELD_TYPES,'constraints':CONSTRAINTS,'relationTypes':RELATION_TYPES,'referentialActions':REFERENTIAL_ACTIONS,'checkOperations':CHECK_OPERATIONS,'auditColumns':AUDIT_COLUMNS,'softDelete':SOFT_DELETE,'shorthandSyntax':SHORTHAND_SYNTAX,'namingRules':NAMING_RULES,'dialectSupport':DIALECT_SUPPORT,'documentationUrl':DOCUMENTATION_URL};module[a0_0x968dcd(0x23f)]={'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};
|