@restforgejs/platform 5.1.7 → 5.1.20
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-hwinfo-linux +0 -0
- package/bin/restforge-hwinfo.exe +0 -0
- package/build-info.json +2 -2
- package/cli/consumer-deploy.js +1 -1
- package/cli/consumer.js +1 -1
- package/generators/cli/catalog/dbschema.js +2 -1
- package/generators/cli/endpoint/list.js +264 -0
- package/generators/cli/fast-track.js +395 -37
- package/generators/cli/payload/generate.js +10 -2
- package/generators/cli/processor/create.js +7 -7
- package/generators/cli/processor/list.js +229 -0
- package/generators/cli/schema/apply.js +6 -1
- package/generators/cli/schema/diff.js +6 -1
- package/generators/cli/schema/introspect.js +32 -11
- package/generators/lib/data/db-executor.js +8 -8
- package/generators/lib/data/envelope.js +3 -3
- package/generators/lib/dbschema-kit/apply-engine.js +20 -0
- package/generators/lib/dbschema-kit/dialect/mysql.js +2 -0
- package/generators/lib/dbschema-kit/dialect/oracle.js +2 -0
- package/generators/lib/dbschema-kit/dialect/postgres.js +4 -0
- package/generators/lib/dbschema-kit/dialect/sqlite.js +5 -0
- package/generators/lib/dbschema-kit/diff-engine.js +22 -1
- package/generators/lib/dbschema-kit/diff-reporter.js +293 -272
- package/generators/lib/dbschema-kit/emitters/create-index.js +23 -1
- package/generators/lib/dbschema-kit/emitters/create-table.js +48 -0
- package/generators/lib/dbschema-kit/introspect-mapper.js +154 -2
- package/generators/lib/dbschema-kit/ir-builder.js +84 -1
- package/generators/lib/dbschema-kit/schema-printer.js +20 -0
- package/generators/lib/dbschema-kit/soft-delete-constants.js +111 -0
- package/generators/lib/dbschema-kit/validator/schema-validator.js +231 -0
- package/generators/lib/generators/dashboard-generator.js +5 -5
- package/generators/lib/generators/processor-validation-generator.js +16 -16
- package/generators/lib/payload/payload-runner.js +774 -1
- package/generators/lib/payload/schema-diff.js +7 -0
- 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/generators/lib/utils/database-introspector.js +48 -0
- package/generators/lib/utils/env-manager.js +4 -4
- package/generators/lib/utils/file-utils.js +6 -6
- package/generators/lib/utils/payload-processor.js +18 -2
- package/generators/lib/validators/argument-validator.js +2 -2
- package/generators/lib/validators/dashboard-validator.js +35 -1
- package/generators/lib/validators/payload-validator.js +460 -33
- package/integrity-manifest.json +20 -20
- package/package.json +2 -1
- package/scripts/check-install.js +8 -8
- 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 -0
- package/src/utils/sql-table-extractor.js +1 -0
- 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
- package/generators/lib/utils/sql-table-extractor.js +0 -83
|
@@ -1 +1 @@
|
|
|
1
|
-
const a0_0x286130=a0_0x18ac;(function(_0x5d5220,_0x5084c4){const _0x2a6631=a0_0x18ac,_0x5ae711=_0x5d5220();while(!![]){try{const _0x1d46f8=-parseInt(_0x2a6631(0xd0))/0x1*(-parseInt(_0x2a6631(0xd8))/0x2)+-parseInt(_0x2a6631(0xf1))/0x3+parseInt(_0x2a6631(0xe0))/0x4+-parseInt(_0x2a6631(0xec))/0x5*(parseInt(_0x2a6631(0xc2))/0x6)+-parseInt(_0x2a6631(0xe2))/0x7*(parseInt(_0x2a6631(0xe5))/0x8)+-parseInt(_0x2a6631(0xe4))/0x9*(parseInt(_0x2a6631(0xd2))/0xa)+parseInt(_0x2a6631(0xd7))/0xb;if(_0x1d46f8===_0x5084c4)break;else _0x5ae711['push'](_0x5ae711['shift']());}catch(_0x1eba5d){_0x5ae711['push'](_0x5ae711['shift']());}}}(a0_0x15b0,0x71c71));const QUERY_PROPERTIES=[{'name':a0_0x286130(0xf0),'type':'string','required':!![],'nestedPath':null,'supportsFileReference':!![],'endpointsServed':['/datatables'],'priority':0x1,'fallback':a0_0x286130(0xe9),'requires':null,'description':'Primary\x20query\x20for\x20/datatables\x20endpoint\x20with\x20pagination\x20and\x20search\x20support.\x20Mandatory\x20for\x20every\x20payload\x20because\x20/datatables\x20is\x20the\x20standard\x20list\x20endpoint.','example':'SELECT\x20a.id,\x20a.code,\x20b.category_name\x20FROM\x20item_product\x20a\x20INNER\x20JOIN\x20category\x20b\x20ON\x20b.category_id\x20=\x20a.category_id'},{'name':a0_0x286130(0xc3),'type':'string','required':![],'nestedPath':null,'supportsFileReference':!![],'endpointsServed':[a0_0x286130(0xe8),a0_0x286130(0xc9),'/read-composite\x20(header)'],'priority':0x2,'fallback':null,'requires':null,'description':'Virtual\x20view\x20query\x20as\x20alternative\x20to\x20creating\x20a\x20database\x20VIEW.\x20Used\x20when\x20DDL\x20access\x20is\x20restricted.\x20Priority\x20below\x20`viewName`\x20and\x20above\x20`tableName`.','example':'SELECT\x20a.id,\x20a.name,\x20b.category_name\x20FROM\x20item_product\x20a\x20INNER\x20JOIN\x20category\x20b\x20ON\x20b.category_id\x20=\x20a.category_id'},{'name':a0_0x286130(0xc6),'type':a0_0x286130(0xd6),'required':![],'nestedPath':null,'supportsFileReference':![],'endpointsServed':[a0_0x286130(0xe8),a0_0x286130(0xc9),a0_0x286130(0xf2),'/read-composite\x20(header)'],'priority':0x1,'fallback':null,'requires':null,'description':a0_0x286130(0xc7),'example':a0_0x286130(0xdb)},{'name':'exportQuery','type':a0_0x286130(0xd6),'required':![],'nestedPath':null,'supportsFileReference':!![],'endpointsServed':[a0_0x286130(0xde)],'priority':0x1,'fallback':'SELECT\x20{fieldName}\x20FROM\x20{tableName}','requires':[a0_0x286130(0xdf)],'description':a0_0x286130(0xe6),'example':a0_0x286130(0xd3)},{'name':'detailQuery','type':'string','required':![],'nestedPath':a0_0x286130(0xea),'supportsFileReference':!![],'endpointsServed':[a0_0x286130(0xcc)],'priority':0x1,'fallback':'SELECT\x20*\x20FROM\x20{detailTable}\x20WHERE\x20{foreignKey}\x20=\x20?\x20ORDER\x20BY\x20line_number','requires':[a0_0x286130(0xcf),a0_0x286130(0xf3)],'description':a0_0x286130(0xd9),'example':a0_0x286130(0xef)}],ENDPOINT_RESOLUTION=[{'endpoint':'/datatables','priorityOrder':[a0_0x286130(0xf0)],'fallback':a0_0x286130(0xe9),'description':'List\x20endpoint\x20with\x20pagination\x20and\x20search.\x20Independent\x20from\x20/read;\x20does\x20not\x20fall\x20back\x20to\x20viewName\x20or\x20viewQuery.'},{'endpoint':'/read','priorityOrder':[a0_0x286130(0xc6),a0_0x286130(0xc3),'tableName'],'fallback':'SELECT\x20*\x20FROM\x20tableName','description':'Multi-record\x20read\x20with\x20WHERE\x20clauses.\x20Three-level\x20priority:\x20existing\x20database\x20VIEW\x20→\x20declarative\x20virtual\x20view\x20→\x20raw\x20table.'},{'endpoint':'/first','priorityOrder':['viewName','viewQuery','tableName'],'fallback':a0_0x286130(0xee),'description':a0_0x286130(0xc5)},{'endpoint':a0_0x286130(0xf2),'priorityOrder':['viewName',a0_0x286130(0xda)],'fallback':'SELECT\x20{key},\x20{label}\x20FROM\x20tableName','description':'Dropdown/select2\x20endpoint.\x20NOTE:\x20`viewQuery`\x20is\x20NOT\x20consulted\x20here,\x20only\x20`viewName`\x20or\x20fallback\x20to\x20`tableName`.'},{'endpoint':'/export','priorityOrder':['exportQuery'],'fallback':'SELECT\x20{fieldName}\x20FROM\x20{tableName}','description':a0_0x286130(0xc4)},{'endpoint':'/read-composite\x20(header)','priorityOrder':['viewName',a0_0x286130(0xc3),a0_0x286130(0xda)],'fallback':a0_0x286130(0xd1),'description':'Master-detail\x20composite\x20endpoint,\x20header\x20portion.\x20Identical\x20priority\x20to\x20/read\x20so\x20any\x20read\x20setup\x20transparently\x20applies.'},{'endpoint':a0_0x286130(0xcc),'priorityOrder':['detailQuery'],'fallback':'SELECT\x20*\x20FROM\x20{detailTable}\x20WHERE\x20{foreignKey}\x20=\x20?\x20ORDER\x20BY\x20line_number','description':a0_0x286130(0xca)}],FILE_REFERENCE_CONVENTION={'format':'file:<relative-path-to-sql-file>','pathRelativeTo':a0_0x286130(0xed),'fileExtensionPolicy':a0_0x286130(0xdc),'resolvedAt':a0_0x286130(0xc8),'generationCopyTarget':a0_0x286130(0xcd),'recommendedFolderStructure':['payload/',a0_0x286130(0xdd),a0_0x286130(0xe7),a0_0x286130(0xeb),a0_0x286130(0xe3),a0_0x286130(0xce)],'placeholderByDatabase':[{'database':a0_0x286130(0xd4),'placeholder':'$1','example':'WHERE\x20stock_inbound_id\x20=\x20$1'},{'database':a0_0x286130(0xd5),'placeholder':'?','example':a0_0x286130(0xc1)},{'database':a0_0x286130(0xe1),'placeholder':':1','example':'WHERE\x20stock_inbound_id\x20=\x20:1'}],'placeholderConversionRules':{'inlineMode':'PostgreSQL\x20syntax\x20($1)\x20is\x20auto-converted\x20to\x20\x27?\x27\x20(MySQL)\x20and\x20\x27:1\x27\x20(Oracle)\x20at\x20generation\x20time\x20for\x20backward\x20compatibility','fileMode':'No\x20automatic\x20conversion.\x20SQL\x20file\x20content\x20must\x20use\x20the\x20native\x20placeholder\x20for\x20the\x20target\x20database.\x20Document\x20this\x20when\x20authoring\x20multi-database\x20payloads.'},'applicableProperties':[a0_0x286130(0xf0),a0_0x286130(0xc3),'exportQuery','masterDetail.detailConfig.detailQuery']},QUERY_DECLARATIVE_CATALOG={'schemaVersion':a0_0x286130(0xcb),'source':'query-declarative-catalog','queryProperties':QUERY_PROPERTIES,'endpointResolution':ENDPOINT_RESOLUTION,'fileReferenceConvention':FILE_REFERENCE_CONVENTION,'documentationUrl':'https://restforge.dev/docs/server/query-filtering/query-declarative'};function a0_0x15b0(){const _0x1277c4=['ndq0nJKYEwPWB2XM','rgv0ywLSigL0zw1Zihf1zxj5igzVCIb0AguGl3jLywqTy29TCg9ZAxrLigvUzhbVAw50lIbozxn0zwqGDw5KzxiGyg1HC3rLCKrLDgfPBc5KzxrHAwXdB25MAwDGlIbnDxn0ignVBNrHAw4GzxHHy3rSEsbVBMuGCgXHy2vOB2XKzxiGzM9YihrOzsbMB3jLAwDUigTLEsb2ywX1zsbTyxrJAgLUzYb0AguGDgfYz2v0igrHDgfIyxnLig5HDgL2zsbZEw50yxGU','DgfIBgvoyw1L','DL9PDgvTx3bYB2r1y3q','zNjLzsWGlNnXBcbYzwnVBw1LBMrLza','icdILjZILidILiaGAxrLBs1WCM9KDwn0lMPZB24','l2v4Cg9YDa','ywn0Aw9UlMv4Cg9YDca9ihrYDwu','nZy3otmYteXjAMTd','B3jHy2XL','ode5tfjywxLe','icaGicaG4PsC4Psa4PsaigL0zw1FChjVzhvJDf9SAxn0lNnXBa','mZe5nduXnhLWsKjJva','ndK2ntzmBgPsD2W','q3vZDg9TifnftevdvcbXDwvYEsbMB3iGl2v4Cg9YDcbLBMrWB2LUDc4Gq29SDw1UigfSAwfZzxmGyw5Kifnrtcb0CMfUC2zVCM1HDgLVBNmGy29UDhjVBcb0AguGrxHJzwWGB3v0Chv0igzVCM1HDc4','icdILjZILidILiaGC3rVy2STAw5IB3vUzc5QC29U','l3jLywq','u0vmrunuicOGrLjptsbYzwfKu291CMnL','BwfZDgvYrgv0ywLSlMrLDgfPBenVBMzPzY5KzxrHAwXrDwvYEq','icdILjtILidILiaGCxvLCNKV','mtv2z3fvDvq','Cgf5Bg9Hzcbku09oigzPBguGBg9JyxrPB24','u0vmrunuihTZzwXLy3r9iezst00GDgfIBgvoyw1LifDirvjfic4UlIbmsu1jvcaX','u0vmrunuigeUBgLUzv9UDw1IzxiSigeUCxr5x3jLy2vPDMvKlcbIlNbYB2r1y3rFy29KzsbguK9nihn0B2nRx2LUyM91BMrFAxrLBsbHieLotKvsiePpsu4GAxrLBv9WCM9KDwn0igiGt04GyI5PDgvTx3bYB2r1y3rFAwqGpsbHlML0zw1FChjVzhvJDf9PzcbxsevsrsbHlNn0B2nRx2LUyM91BMrFAwqGpsaKmsbpuKrfuIbcwsbHlMXPBMvFBNvTyMvY','zgf0yxrHyMXLC1f1zxj5','mtGWmdG3oxjVuwf2uq','l2XVB2T1Ca','ywn0Aw9UlNjLywrdB21WB3nPDguGpsb0CNvL','v0HfuKuGC3rVy2TFAw5IB3vUzf9Pzca9id8','mZuYmJKWBMfAyxLW','DMLLD1f1zxj5','rxHJzwWGzxHWB3j0lIbgywXSCYbIywnRihrVihnLBgvJDgLUzYb3AgL0zwXPC3rLzcbMAwvSzhmGzNjVBsbYyxCGDgfIBguGAwyGzxHWB3j0uxvLCNKGAxmGywjZzw50lG','u2LUz2XLlxjLy29YzcbYzwfKigj5ihbYAw1HCNKGA2v5ig9YihvUAxf1zsbMAwvSzc4Gu2fTzsbWCMLVCML0EsbVCMrLCIbHCYaVCMvHzc4','DMLLD05HBwu','tMfTzsbVzIbHBIbLEgLZDgLUzYbKyxrHyMfZzsbwsuvxlIbiAwDOzxn0ihbYAw9YAxr5igzVCIbYzwfKigvUzhbVAw50CY4Gv3jPDguGB3bLCMf0Aw9UCYaOAw5Zzxj0l3vWzgf0zs9KzwXLDguPihn0AwXSihvZzsbGDgfIBgvoyw1Lyc4Grg9LCYbUB3qGC3vWCg9YDcbGzMLSztPGihbYzwzPEcbIzwnHDxnLihrOAxmGAxmGysbKyxrHyMfZzsbVyMPLy3qGBMfTzsWGBM90ifnrtcbJB250zw50lG','z2vUzxjHDgLVBIb0Aw1L','l2zPCNn0','twfZDgvYlwrLDgfPBcbJB21WB3nPDguGzw5KCg9PBNqSigrLDgfPBcbPDgvTCYbWB3j0Aw9UlIbgB3jLAwDUigTLEsbWBgfJzwHVBgrLCIb1C2vZig5HDgL2zsbKyxrHyMfZzsbZEw50yxGU','ms4W','l3jLywqTy29TCg9ZAxrLicHKzxrHAwWP','C3jJl21VzgvSCY97Bw9KDwXLtMfTzx0VCxvLCNKV','icaGicaG4Psu4Psa4Psaihn0B2nRlwLUyM91BMqTzgv0ywLSCxvLCNKUC3fS','BwfZDgvYrgv0ywLSlMvUywjSzwqGpsb0CNvL','neXMz2jvDW','u0vmrunuicOGrLjptsb0ywjSzu5HBwu','mJbTzfnvuwG','u0vmrunuihbYB2r1y3rFy29KzsbbuYaIs29KzsbqCM9KDwSIlcbWCM9KDwn0x25HBwuGqvmGiK5HBweGuhjVzhvRiIbguK9nigL0zw1FChjVzhvJDa','Cg9ZDgDYzxnXBa','BxLZCwW','C3rYAw5N','mtC1nJKZnJvdz09Sq1a'];a0_0x15b0=function(){return _0x1277c4;};return a0_0x15b0();}function a0_0x18ac(_0x5988d1,_0x3a9bf9){_0x5988d1=_0x5988d1-0xc1;const _0x15b013=a0_0x15b0();let _0x18ac25=_0x15b013[_0x5988d1];if(a0_0x18ac['sheuCC']===undefined){var _0x430a54=function(_0x2c6bdb){const _0x1a864b='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x26cab8='',_0x5d2f1c='';for(let _0x10fb27=0x0,_0x398258,_0x26ad8e,_0xa8a1a6=0x0;_0x26ad8e=_0x2c6bdb['charAt'](_0xa8a1a6++);~_0x26ad8e&&(_0x398258=_0x10fb27%0x4?_0x398258*0x40+_0x26ad8e:_0x26ad8e,_0x10fb27++%0x4)?_0x26cab8+=String['fromCharCode'](0xff&_0x398258>>(-0x2*_0x10fb27&0x6)):0x0){_0x26ad8e=_0x1a864b['indexOf'](_0x26ad8e);}for(let _0xb5fe7f=0x0,_0x466a1b=_0x26cab8['length'];_0xb5fe7f<_0x466a1b;_0xb5fe7f++){_0x5d2f1c+='%'+('00'+_0x26cab8['charCodeAt'](_0xb5fe7f)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x5d2f1c);};a0_0x18ac['HbqqZb']=_0x430a54,a0_0x18ac['FpOGOV']={},a0_0x18ac['sheuCC']=!![];}const _0x1e8ce8=_0x15b013[0x0],_0x4d9c9b=_0x5988d1+_0x1e8ce8,_0x5df8cc=a0_0x18ac['FpOGOV'][_0x4d9c9b];return!_0x5df8cc?(_0x18ac25=a0_0x18ac['HbqqZb'](_0x18ac25),a0_0x18ac['FpOGOV'][_0x4d9c9b]=_0x18ac25):_0x18ac25=_0x5df8cc,_0x18ac25;}module['exports']={'QUERY_DECLARATIVE_CATALOG':QUERY_DECLARATIVE_CATALOG};
|
|
1
|
+
const a0_0x3954b3=a0_0x566a;function a0_0x2983(){const _0x11c51e=['mty4ntGZmNPnyu5Yua','u0vmrunuicOGrLjptsbYzwfKu291CMnL','ywn0Aw9UlNjLywrdB21WB3nPDguGpsb0CNvL','C3rYAw5N','l2v4Cg9YDa','icaGicaG4Psu4Psa4Psaihn0B2nRlwLUyM91BMqTzgv0ywLSCxvLCNKUC3fS','rgv0ywLSigL0zw1Zihf1zxj5igzVCIb0AguGl3jLywqTy29TCg9ZAxrLigvUzhbVAw50lIbozxn0zwqGDw5KzxiGyg1HC3rLCKrLDgfPBc5KzxrHAwXdB25MAwDGlIbnDxn0ignVBNrHAw4GzxHHy3rSEsbVBMuGCgXHy2vOB2XKzxiGzM9YihrOzsbMB3jLAwDUigTLEsb2ywX1zsbTyxrJAgLUzYb0AguGDgfYz2v0igrHDgfIyxnLig5HDgL2zsbZEw50yxGU','ndm0mde4mLvyuNjeCG','ohjMwLrQta','u0vmrunuicOGrLjptsb7zgv0ywLSvgfIBgv9ifDirvjfihTMB3jLAwDUs2v5Fsa9id8Gt1jerviGqLKGBgLUzv9UDw1Izxi','tgLZDcbLBMrWB2LUDcb3AxrOihbHz2LUyxrPB24Gyw5KihnLyxjJAc4Gsw5KzxbLBMrLBNqGzNjVBsaVCMvHzdSGzg9LCYbUB3qGzMfSBcbIywnRihrVihzPzxDoyw1Lig9YihzPzxDrDwvYEs4','l2rHDgf0ywjSzxm','zxHWB3j0uxvLCNK','l2zPCNn0','uhjPBwfYEsbXDwvYEsbMB3iGl2rHDgf0ywjSzxmGzw5KCg9PBNqGD2L0AcbWywDPBMf0Aw9UigfUzcbZzwfYy2GGC3vWCg9YDc4GtwfUzgf0B3j5igzVCIbLDMvYEsbWyxLSB2fKigjLy2f1C2uGl2rHDgf0ywjSzxmGAxmGDgHLihn0yw5KyxjKigXPC3qGzw5KCg9PBNqU','v0HfuKuGC3rVy2TFAw5IB3vUzf9Pzca9idOX','DMLLD1f1zxj5','icdILjZILidILiaGC3rVy2STAw5IB3vUzc5QC29U','ntrvEKLvqMm','tM8Gyxv0B21HDgLJignVBNzLCNnPB24UifnrtcbMAwXLignVBNrLBNqGBxvZDcb1C2uGDgHLig5HDgL2zsbWBgfJzwHVBgrLCIbMB3iGDgHLihrHCMDLDcbKyxrHyMfZzs4Grg9JDw1LBNqGDgHPCYb3AgvUigf1DgHVCMLUzYbTDwX0As1KyxrHyMfZzsbWyxLSB2fKCY4','CxvLCNKTzgvJBgfYyxrPDMuTy2f0ywXVzW','icdILjZILidILiaGAxrLBs1WCM9KDwn0lMPZB24','odaXmJi2mgL4zfHItW','v0HfuKuGC3rVy2TFAw5IB3vUzf9Pzca9icqX','u0vmrunuihbYB2r1y3rFy29KzsbbuYaIs29KzsbqCM9KDwSIlcbWCM9KDwn0x25HBwuGqvmGiK5HBweGuhjVzhvRiIbguK9nigL0zw1FChjVzhvJDa','u0vmrunuicOGrLjptsb0ywjSzu5HBwu','rhjVCgrVD24VC2vSzwn0mIbLBMrWB2LUDc4GtK9urtOGyhzPzxDrDwvYEwaGAxmGtK9uignVBNn1BhrLzcbOzxjLlcbVBMX5igb2Awv3tMfTzwaGB3iGzMfSBgjHy2SGDg8GyhrHyMXLtMfTzwaU','Cg9ZDgDYzxnXBa','l3jLywq','ywn0Aw9UlMv4Cg9YDca9ihrYDwu','DgfIBgvoyw1L','mte0BvLNCejL','DMLLD05HBwu','mta2mJGWoe5OwM5vyq','zgv0ywLSuxvLCNK','u2LUz2XLlxjLy29YzcbYzwfKigj5ihbYAw1HCNKGA2v5ig9YihvUAxf1zsbMAwvSzc4Gu2fTzsbWCMLVCML0EsbVCMrLCIbHCYaVCMvHzc4','mZyXmZeZntLOCxDAqKS','zgf0yxrHyMXLC1f1zxj5','l2XVB2T1Ca','u0vmrunuihTMAwvSze5HBwv9iezst00GE3rHyMXLtMfTzx0','q3vZDg9TifnftevdvcbXDwvYEsbMB3iGl2v4Cg9YDcbLBMrWB2LUDc4Gq29SDw1UigfSAwfZzxmGyw5Kifnrtcb0CMfUC2zVCM1HDgLVBNmGy29UDhjVBcb0AguGrxHJzwWGB3v0Chv0igzVCM1HDc4','l3jLywqTy29TCg9ZAxrLicHOzwfKzxiP','u0vmrunuigeUAwqSigeUBMfTzsWGyI5JyxrLz29YEv9Uyw1Liezst00GAxrLBv9WCM9KDwn0igeGsu5orviGsK9jtIbJyxrLz29YEsbIie9oigiUy2f0zwDVCNLFAwqGpsbHlMnHDgvNB3j5x2LK','mZa1mZKWzNfvEwPz','nZK0mZHeBLbdz1e','ouLTuLjxDq'];a0_0x2983=function(){return _0x11c51e;};return a0_0x2983();}function a0_0x566a(_0x14b63d,_0x46e2d6){_0x14b63d=_0x14b63d-0x133;const _0x298303=a0_0x2983();let _0x566ad2=_0x298303[_0x14b63d];if(a0_0x566a['FxgsNF']===undefined){var _0x32fbd7=function(_0x197fbf){const _0xff37d='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x44045c='',_0x3b2cf7='';for(let _0xb92a56=0x0,_0xa659b5,_0x1bc3a4,_0x1612e7=0x0;_0x1bc3a4=_0x197fbf['charAt'](_0x1612e7++);~_0x1bc3a4&&(_0xa659b5=_0xb92a56%0x4?_0xa659b5*0x40+_0x1bc3a4:_0x1bc3a4,_0xb92a56++%0x4)?_0x44045c+=String['fromCharCode'](0xff&_0xa659b5>>(-0x2*_0xb92a56&0x6)):0x0){_0x1bc3a4=_0xff37d['indexOf'](_0x1bc3a4);}for(let _0x496f7e=0x0,_0x3b220b=_0x44045c['length'];_0x496f7e<_0x3b220b;_0x496f7e++){_0x3b2cf7+='%'+('00'+_0x44045c['charCodeAt'](_0x496f7e)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x3b2cf7);};a0_0x566a['FOJOak']=_0x32fbd7,a0_0x566a['JNfsCE']={},a0_0x566a['FxgsNF']=!![];}const _0x1155b3=_0x298303[0x0],_0xfe698d=_0x14b63d+_0x1155b3,_0x1e0de8=a0_0x566a['JNfsCE'][_0xfe698d];return!_0x1e0de8?(_0x566ad2=a0_0x566a['FOJOak'](_0x566ad2),a0_0x566a['JNfsCE'][_0xfe698d]=_0x566ad2):_0x566ad2=_0x1e0de8,_0x566ad2;}(function(_0x198fa6,_0x386161){const _0x411eca=a0_0x566a,_0x3f9326=_0x198fa6();while(!![]){try{const _0x5b488a=parseInt(_0x411eca(0x15c))/0x1*(parseInt(_0x411eca(0x15b))/0x2)+parseInt(_0x411eca(0x15d))/0x3*(-parseInt(_0x411eca(0x137))/0x4)+parseInt(_0x411eca(0x15a))/0x5*(-parseInt(_0x411eca(0x14e))/0x6)+-parseInt(_0x411eca(0x136))/0x7+-parseInt(_0x411eca(0x150))/0x8*(parseInt(_0x411eca(0x141))/0x9)+parseInt(_0x411eca(0x145))/0xa+parseInt(_0x411eca(0x153))/0xb;if(_0x5b488a===_0x386161)break;else _0x3f9326['push'](_0x3f9326['shift']());}catch(_0x202c66){_0x3f9326['push'](_0x3f9326['shift']());}}}(a0_0x2983,0xb51e8));const QUERY_PROPERTIES=[{'name':'datatablesQuery','type':a0_0x3954b3(0x160),'required':!![],'nestedPath':null,'supportsFileReference':!![],'endpointsServed':['/datatables'],'priority':0x1,'fallback':'SELECT\x20*\x20FROM\x20readSource','requires':null,'description':a0_0x3954b3(0x13d),'example':'SELECT\x20a.id,\x20a.code,\x20b.category_name\x20FROM\x20item_product\x20a\x20INNER\x20JOIN\x20category\x20b\x20ON\x20b.category_id\x20=\x20a.category_id'},{'name':a0_0x3954b3(0x13f),'type':'string','required':![],'nestedPath':null,'supportsFileReference':!![],'endpointsServed':[a0_0x3954b3(0x14b),a0_0x3954b3(0x13c),'/read-composite\x20(header)'],'priority':0x2,'fallback':null,'requires':null,'description':'Virtual\x20view\x20query\x20as\x20alternative\x20to\x20creating\x20a\x20database\x20VIEW.\x20Used\x20when\x20DDL\x20access\x20is\x20restricted.\x20Priority\x20below\x20`viewName`\x20and\x20above\x20`tableName`.','example':a0_0x3954b3(0x159)},{'name':a0_0x3954b3(0x14f),'type':a0_0x3954b3(0x160),'required':![],'nestedPath':null,'supportsFileReference':![],'endpointsServed':[a0_0x3954b3(0x14b),'/first',a0_0x3954b3(0x155),a0_0x3954b3(0x158)],'priority':0x1,'fallback':null,'requires':null,'description':'Name\x20of\x20an\x20existing\x20database\x20VIEW.\x20Highest\x20priority\x20for\x20read\x20endpoints.\x20Write\x20operations\x20(insert/update/delete)\x20still\x20use\x20`tableName`.\x20Does\x20not\x20support\x20`file:`\x20prefix\x20because\x20this\x20is\x20a\x20database\x20object\x20name,\x20not\x20SQL\x20content.','example':'v_item_product'},{'name':a0_0x3954b3(0x13b),'type':a0_0x3954b3(0x160),'required':![],'nestedPath':null,'supportsFileReference':!![],'endpointsServed':[a0_0x3954b3(0x133)],'priority':0x1,'fallback':a0_0x3954b3(0x156),'requires':[a0_0x3954b3(0x14c)],'description':a0_0x3954b3(0x157),'example':a0_0x3954b3(0x147)},{'name':a0_0x3954b3(0x151),'type':'string','required':![],'nestedPath':'masterDetail.detailConfig.detailQuery','supportsFileReference':!![],'endpointsServed':['/read-composite\x20(detail)'],'priority':0x1,'fallback':'SELECT\x20*\x20FROM\x20{detailTable}\x20WHERE\x20{foreignKey}\x20=\x20?\x20ORDER\x20BY\x20line_number','requires':['masterDetail.enabled\x20=\x20true',a0_0x3954b3(0x15f)],'description':a0_0x3954b3(0x135),'example':'SELECT\x20a.line_number,\x20a.qty_received,\x20b.product_code\x20FROM\x20stock_inbound_item\x20a\x20INNER\x20JOIN\x20item_product\x20b\x20ON\x20b.item_product_id\x20=\x20a.item_product_id\x20WHERE\x20a.stock_inbound_id\x20=\x20$1\x20ORDER\x20BY\x20a.line_number'}],ENDPOINT_RESOLUTION=[{'endpoint':a0_0x3954b3(0x13a),'priorityOrder':[a0_0x3954b3(0x154)],'fallback':a0_0x3954b3(0x15e),'description':a0_0x3954b3(0x139)},{'endpoint':'/read','priorityOrder':['viewName','viewQuery',a0_0x3954b3(0x14d)],'fallback':a0_0x3954b3(0x148),'description':'Multi-record\x20read\x20with\x20WHERE\x20clauses.\x20Three-level\x20priority:\x20existing\x20database\x20VIEW\x20→\x20declarative\x20virtual\x20view\x20→\x20raw\x20table.'},{'endpoint':'/first','priorityOrder':['viewName','viewQuery',a0_0x3954b3(0x14d)],'fallback':'SELECT\x20{select}\x20FROM\x20tableName\x20WHERE\x20...\x20LIMIT\x201','description':a0_0x3954b3(0x152)},{'endpoint':'/lookup','priorityOrder':[a0_0x3954b3(0x14f),a0_0x3954b3(0x14d)],'fallback':'SELECT\x20{key},\x20{label}\x20FROM\x20tableName','description':a0_0x3954b3(0x149)},{'endpoint':a0_0x3954b3(0x133),'priorityOrder':[a0_0x3954b3(0x13b)],'fallback':'SELECT\x20{fieldName}\x20FROM\x20{tableName}','description':'Excel\x20export.\x20Falls\x20back\x20to\x20selecting\x20whitelisted\x20fields\x20from\x20raw\x20table\x20if\x20exportQuery\x20is\x20absent.'},{'endpoint':a0_0x3954b3(0x158),'priorityOrder':['viewName',a0_0x3954b3(0x13f),a0_0x3954b3(0x14d)],'fallback':'SELECT\x20*\x20FROM\x20tableName','description':'Master-detail\x20composite\x20endpoint,\x20header\x20portion.\x20Identical\x20priority\x20to\x20/read\x20so\x20any\x20read\x20setup\x20transparently\x20applies.'},{'endpoint':'/read-composite\x20(detail)','priorityOrder':[a0_0x3954b3(0x151)],'fallback':a0_0x3954b3(0x138),'description':'Master-detail\x20composite\x20endpoint,\x20detail\x20items\x20portion.\x20Foreign\x20key\x20placeholder\x20uses\x20native\x20database\x20syntax.'}],FILE_REFERENCE_CONVENTION={'format':'file:<relative-path-to-sql-file>','pathRelativeTo':'payload\x20JSON\x20file\x20location','fileExtensionPolicy':'free,\x20.sql\x20recommended','resolvedAt':'generation\x20time','generationCopyTarget':'src/models/{moduleName}/query/','recommendedFolderStructure':['payload/',a0_0x3954b3(0x144),a0_0x3954b3(0x140),'\x20\x20└──\x20query/','\x20\x20\x20\x20\x20\x20├──\x20item_product_list.sql',a0_0x3954b3(0x134)],'placeholderByDatabase':[{'database':a0_0x3954b3(0x14a),'placeholder':'$1','example':a0_0x3954b3(0x146)},{'database':'mysql','placeholder':'?','example':'WHERE\x20stock_inbound_id\x20=\x20?'},{'database':'oracle','placeholder':':1','example':a0_0x3954b3(0x13e)}],'placeholderConversionRules':{'inlineMode':'PostgreSQL\x20syntax\x20($1)\x20is\x20auto-converted\x20to\x20\x27?\x27\x20(MySQL)\x20and\x20\x27:1\x27\x20(Oracle)\x20at\x20generation\x20time\x20for\x20backward\x20compatibility','fileMode':a0_0x3954b3(0x142)},'applicableProperties':['datatablesQuery','viewQuery',a0_0x3954b3(0x13b),'masterDetail.detailConfig.detailQuery']},QUERY_DECLARATIVE_CATALOG={'schemaVersion':'1.0','source':a0_0x3954b3(0x143),'queryProperties':QUERY_PROPERTIES,'endpointResolution':ENDPOINT_RESOLUTION,'fileReferenceConvention':FILE_REFERENCE_CONVENTION,'documentationUrl':'https://restforge.dev/docs/server/query-filtering/query-declarative'};module['exports']={'QUERY_DECLARATIVE_CATALOG':QUERY_DECLARATIVE_CATALOG};
|