@restforgejs/platform 4.2.8 → 4.3.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (325) hide show
  1. package/SECURITY.md +83 -4
  2. package/bin/sdf-tools.exe +0 -0
  3. package/build-info.json +2 -2
  4. package/cli/consumer-deploy.js +1 -1
  5. package/cli/consumer.js +1 -1
  6. package/generators/cli/dashboard/create.js +4 -1
  7. package/generators/cli/endpoint/create.js +1 -1
  8. package/generators/cli/key/generate.js +2 -1
  9. package/generators/cli/key/revoke.js +2 -1
  10. package/generators/cli/payload/diff.js +3 -2
  11. package/generators/cli/payload/generate.js +3 -2
  12. package/generators/cli/payload/sync.js +3 -2
  13. package/generators/cli/payload/validate.js +3 -2
  14. package/generators/cli/processor/create.js +14 -3
  15. package/generators/cli/project/delete.js +2 -1
  16. package/generators/cli/query/validate.js +3 -2
  17. package/generators/cli/schema/apply.js +3 -2
  18. package/generators/cli/schema/describe.js +3 -2
  19. package/generators/cli/schema/diff.js +3 -2
  20. package/generators/cli/schema/introspect.js +3 -2
  21. package/generators/cli/schema/list.js +3 -2
  22. package/generators/cli/schema/migrate.js +3 -2
  23. package/generators/lib/migration/audit-table-runner.js +213 -215
  24. package/generators/lib/payload/payload-runner.js +1 -1
  25. package/generators/lib/templates/dashboard-catalog.js +1 -437
  26. package/generators/lib/templates/db-connection-env.js +1 -212
  27. package/generators/lib/templates/dbschema-catalog.js +1 -489
  28. package/generators/lib/templates/field-validation-catalog.js +1 -531
  29. package/generators/lib/templates/mysql-template.js +1 -3863
  30. package/generators/lib/templates/oracle-template.js +1 -3915
  31. package/generators/lib/templates/postgres-template.js +1 -5838
  32. package/generators/lib/templates/query-declarative-catalog.js +1 -199
  33. package/generators/lib/templates/sqlite-template.js +1 -3440
  34. package/generators/lib/utils/env-manager.js +6 -0
  35. package/generators/lib/utils/path-validator.js +71 -0
  36. package/generators/lib/validators/payload-validator.js +1 -2
  37. package/integrity-manifest.json +28 -10
  38. package/package.json +11 -3
  39. package/scripts/verify-integrity.js +1 -1
  40. package/server.js +1 -1
  41. package/src/components/handlers/adjust_handler.js +1 -1
  42. package/src/components/handlers/audit_handler.js +1 -1
  43. package/src/components/handlers/delete_handler.js +1 -1
  44. package/src/components/handlers/export_handler.js +1 -1
  45. package/src/components/handlers/import_handler.js +1 -1
  46. package/src/components/handlers/insert_handler.js +1 -1
  47. package/src/components/handlers/update_handler.js +1 -1
  48. package/src/components/handlers/upload_handler.js +1 -1
  49. package/src/components/handlers/workflow_handler.js +1 -1
  50. package/src/components/integrations/webhook.js +1 -1
  51. package/src/consumers/baseConsumer.js +1 -1
  52. package/src/consumers/declarativeMapper.js +1 -1
  53. package/src/consumers/handlers/apiHandler.js +1 -1
  54. package/src/consumers/handlers/consoleHandler.js +1 -1
  55. package/src/consumers/handlers/databaseHandler.js +1 -1
  56. package/src/consumers/handlers/index.js +1 -1
  57. package/src/consumers/handlers/kafkaHandler.js +1 -1
  58. package/src/consumers/index.js +1 -1
  59. package/src/consumers/messageTransformer.js +1 -1
  60. package/src/consumers/validator.js +1 -1
  61. package/src/core/db/dialect/base-dialect.js +1 -1
  62. package/src/core/db/dialect/index.js +1 -1
  63. package/src/core/db/dialect/mysql-dialect.js +1 -1
  64. package/src/core/db/dialect/oracle-dialect.js +1 -1
  65. package/src/core/db/dialect/postgres-dialect.js +1 -1
  66. package/src/core/db/dialect/sqlite-dialect.js +1 -1
  67. package/src/core/db/flatten-helper.js +1 -1
  68. package/src/core/db/query-builder-error.js +1 -1
  69. package/src/core/db/query-builder.js +1 -1
  70. package/src/core/db/relation-helper.js +1 -1
  71. package/src/core/handlers/delete_handler.js +1 -1
  72. package/src/core/handlers/insert_handler.js +1 -1
  73. package/src/core/handlers/update_handler.js +1 -1
  74. package/src/core/models/base-model.js +1 -1
  75. package/src/core/utils/cache-manager.js +1 -1
  76. package/src/core/utils/component-engine.js +1 -1
  77. package/src/core/utils/context-builder.js +1 -1
  78. package/src/core/utils/datetime-formatter.js +1 -1
  79. package/src/core/utils/datetime-parser.js +1 -1
  80. package/src/core/utils/db.js +1 -1
  81. package/src/core/utils/logger.js +1 -1
  82. package/src/core/utils/payload-loader.js +1 -1
  83. package/src/core/utils/security-checks.js +1 -1
  84. package/src/middleware/body-options.js +1 -1
  85. package/src/middleware/cors.js +1 -1
  86. package/src/middleware/idempotency.js +1 -1
  87. package/src/middleware/rate-limiter.js +1 -1
  88. package/src/middleware/request-logger.js +1 -1
  89. package/src/middleware/security-headers.js +1 -1
  90. package/src/models/base-model-mysql.js +1 -1
  91. package/src/models/base-model-oracle.js +1 -1
  92. package/src/models/base-model-sqlite.js +1 -1
  93. package/src/models/base-model.js +1 -1
  94. package/src/pro/caching/redis-client.js +1 -1
  95. package/src/pro/caching/redis-helper.js +1 -1
  96. package/src/pro/consumers/baseConsumer.js +1 -1
  97. package/src/pro/consumers/declarativeMapper.js +1 -1
  98. package/src/pro/consumers/handlers/apiHandler.js +1 -1
  99. package/src/pro/consumers/handlers/consoleHandler.js +1 -1
  100. package/src/pro/consumers/handlers/databaseHandler.js +1 -1
  101. package/src/pro/consumers/handlers/index.js +1 -1
  102. package/src/pro/consumers/handlers/kafkaHandler.js +1 -1
  103. package/src/pro/consumers/index.js +1 -1
  104. package/src/pro/consumers/messageTransformer.js +1 -1
  105. package/src/pro/consumers/validator.js +1 -1
  106. package/src/pro/database/base-model-mysql.js +1 -1
  107. package/src/pro/database/base-model-oracle.js +1 -1
  108. package/src/pro/database/base-model-sqlite.js +1 -1
  109. package/src/pro/database/db-mysql.js +1 -1
  110. package/src/pro/database/db-oracle.js +1 -1
  111. package/src/pro/database/db-sqlite.js +1 -1
  112. package/src/pro/excel/excel-generator.js +1 -1
  113. package/src/pro/excel/excel-parser.js +1 -1
  114. package/src/pro/excel/export-service.js +1 -1
  115. package/src/pro/excel/export_handler.js +1 -1
  116. package/src/pro/excel/import-service.js +1 -1
  117. package/src/pro/excel/import-validator.js +1 -1
  118. package/src/pro/excel/import_handler.js +1 -1
  119. package/src/pro/excel/upsert-builder.js +1 -1
  120. package/src/pro/idgen/idgen-routes.js +1 -1
  121. package/src/pro/integrations/lookup-resolver.js +1 -1
  122. package/src/pro/integrations/upload-handler-v2.js +1 -1
  123. package/src/pro/integrations/upload-handler.js +1 -1
  124. package/src/pro/integrations/webhook.js +1 -1
  125. package/src/pro/locking/lock-routes.js +1 -1
  126. package/src/pro/locking/resource-lock-manager.js +1 -1
  127. package/src/pro/messaging/kafkaConsumerService.js +1 -1
  128. package/src/pro/messaging/kafkaService.js +1 -1
  129. package/src/pro/messaging/messagehubService.js +1 -1
  130. package/src/pro/messaging/rabbitmqService.js +1 -1
  131. package/src/pro/scheduler/job-manager.js +1 -1
  132. package/src/pro/scheduler/job-routes.js +1 -1
  133. package/src/pro/scheduler/job-validator.js +1 -1
  134. package/src/pro/storage/base-storage-provider.js +1 -1
  135. package/src/pro/storage/file-metadata-helper.js +1 -1
  136. package/src/pro/storage/index.js +1 -1
  137. package/src/pro/storage/local-storage-provider.js +1 -1
  138. package/src/pro/storage/s3-storage-provider.js +1 -1
  139. package/src/pro/storage/upload-cleanup-job.js +1 -1
  140. package/src/pro/storage/upload-cleanup-scheduler.js +1 -1
  141. package/src/pro/storage/upload-pending-tracker.js +1 -1
  142. package/src/pro/websocket/broadcast-helper.js +1 -1
  143. package/src/pro/websocket/index.js +1 -1
  144. package/src/pro/websocket/livesync-server.js +1 -1
  145. package/src/pro/websocket/ws-broadcaster.js +1 -1
  146. package/src/services/export-service.js +1 -1
  147. package/src/services/import-service.js +1 -1
  148. package/src/services/kafkaConsumerService.js +1 -1
  149. package/src/services/kafkaService.js +1 -1
  150. package/src/services/messagehubService.js +1 -1
  151. package/src/services/rabbitmqService.js +1 -1
  152. package/src/utils/cache-invalidation-registry.js +1 -1
  153. package/src/utils/cache-manager.js +1 -1
  154. package/src/utils/component-engine.js +1 -1
  155. package/src/utils/config-extractor.js +1 -1
  156. package/src/utils/consumerLogger.js +1 -1
  157. package/src/utils/context-builder.js +1 -1
  158. package/src/utils/dashboard-helpers.js +1 -1
  159. package/src/utils/dateHelper.js +1 -1
  160. package/src/utils/datetime-formatter.js +1 -1
  161. package/src/utils/datetime-parser.js +1 -1
  162. package/src/utils/db-bootstrap.js +1 -1
  163. package/src/utils/db-mysql.js +1 -1
  164. package/src/utils/db-oracle.js +1 -1
  165. package/src/utils/db-sqlite.js +1 -1
  166. package/src/utils/db.js +1 -1
  167. package/src/utils/demo-generator.js +1 -1
  168. package/src/utils/excel-generator.js +1 -1
  169. package/src/utils/excel-parser.js +1 -1
  170. package/src/utils/file-watcher.js +1 -1
  171. package/src/utils/id-generator.js +1 -1
  172. package/src/utils/idempotency-manager.js +1 -1
  173. package/src/utils/import-validator.js +1 -1
  174. package/src/utils/license-client.js +1 -1
  175. package/src/utils/lock-manager.js +1 -1
  176. package/src/utils/logger.js +1 -1
  177. package/src/utils/lookup-resolver.js +1 -1
  178. package/src/utils/payload-loader.js +1 -1
  179. package/src/utils/processor-response.js +1 -1
  180. package/src/utils/rabbitmq.js +1 -1
  181. package/src/utils/redis-client.js +1 -1
  182. package/src/utils/redis-helper.js +1 -1
  183. package/src/utils/request-scope.js +1 -1
  184. package/src/utils/security-checks.js +1 -1
  185. package/src/utils/service-resolver.js +1 -1
  186. package/src/utils/shutdown-coordinator.js +1 -1
  187. package/src/utils/trusted-keys.js +1 -1
  188. package/src/utils/upload-handler.js +1 -1
  189. package/src/utils/upsert-builder.js +1 -1
  190. package/src/utils/workflow-hook-executor.js +1 -1
  191. package/generators/metadata/global.json +0 -58
  192. package/generators/metadata/test-mysql-workbench.json +0 -118
  193. package/generators/metadata/test-mysql.json +0 -56
  194. package/generators/metadata/test-oracle-workbench.json +0 -118
  195. package/generators/metadata/test-oracle.json +0 -56
  196. package/generators/metadata/test-pg-workbench.json +0 -118
  197. package/generators/metadata/test-pg.json +0 -56
  198. package/generators/scripts/obfuscate-source.js +0 -356
  199. package/generators/scripts/validate-catalog.js +0 -430
  200. package/generators/scripts/validate-dbschema-catalog.js +0 -708
  201. package/generators/tests/baseline/mysql/mini_inventory_item/src/models/mini-inventory/item.js +0 -944
  202. package/generators/tests/baseline/mysql/mini_inventory_item/src/modules/mini-inventory/item.js +0 -740
  203. package/generators/tests/baseline/mysql/mini_inventory_item/src/modules/mini-inventory.js +0 -336
  204. package/generators/tests/baseline/oracle/mini_inventory_item/src/models/mini-inventory/item.js +0 -1002
  205. package/generators/tests/baseline/oracle/mini_inventory_item/src/modules/mini-inventory/item.js +0 -740
  206. package/generators/tests/baseline/oracle/mini_inventory_item/src/modules/mini-inventory.js +0 -336
  207. package/generators/tests/baseline/postgres/mini_inventory_item/src/models/mini-inventory/item.js +0 -1333
  208. package/generators/tests/baseline/postgres/mini_inventory_item/src/modules/mini-inventory/item.js +0 -1173
  209. package/generators/tests/baseline/postgres/mini_inventory_item/src/modules/mini-inventory.js +0 -496
  210. package/generators/tests/fixtures/payloads/custom-sensitive.json +0 -27
  211. package/generators/tests/fixtures/payloads/dynamic-search-optout.json +0 -23
  212. package/generators/tests/fixtures/payloads/login-with-password.json +0 -22
  213. package/generators/tests/fixtures/payloads/order-process.json +0 -52
  214. package/generators/tests/fixtures/payloads/with-inline-sql.json +0 -26
  215. package/generators/tests/integration-tahap4b/README.md +0 -145
  216. package/generators/tests/integration-tahap4b/run-concurrent.js +0 -77
  217. package/generators/tests/integration-tahap4b/seed.sql +0 -53
  218. package/generators/tests/integration-tahap4b/verify.sql +0 -110
  219. package/generators/tests/unit/cli/create-dashboard.test.js +0 -505
  220. package/generators/tests/unit/cli/create-processor.test.js +0 -319
  221. package/generators/tests/unit/cli/dispatch-dashboard.test.js +0 -149
  222. package/generators/tests/unit/lib/dashboard-generator.test.js +0 -895
  223. package/generators/tests/unit/lib/dashboard-validator.test.js +0 -354
  224. package/generators/tests/unit/lib/dbschema-kit/apply-executor.test.js +0 -437
  225. package/generators/tests/unit/lib/dbschema-kit/cli/dbschema-introspect.test.js +0 -393
  226. package/generators/tests/unit/lib/dbschema-kit/cli/dbschema-kit-generate-ddl.test.js +0 -104
  227. package/generators/tests/unit/lib/dbschema-kit/cli/dbschema-kit-init.test.js +0 -119
  228. package/generators/tests/unit/lib/dbschema-kit/cli/dbschema-kit-list.test.js +0 -48
  229. package/generators/tests/unit/lib/dbschema-kit/cli/dbschema-kit-migrate.test.js +0 -175
  230. package/generators/tests/unit/lib/dbschema-kit/cli/dbschema-kit-validate.test.js +0 -102
  231. package/generators/tests/unit/lib/dbschema-kit/cli/dbschema-models.test.js +0 -43
  232. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/introspect-stubs/all-schemas-listing.js +0 -84
  233. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/introspect-stubs/connection-error.js +0 -13
  234. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/introspect-stubs/empty.js +0 -12
  235. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/introspect-stubs/multi-schema.js +0 -124
  236. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/introspect-stubs/single-schema-inventory.js +0 -64
  237. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/introspect-stubs/two-tables.js +0 -66
  238. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/migrate-stubs/connection-error.js +0 -9
  239. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/migrate-stubs/partial.js +0 -29
  240. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/migrate-stubs/rollback.js +0 -26
  241. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/migrate-stubs/success.js +0 -43
  242. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/multi-schema/audit/events.js +0 -18
  243. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/multi-schema/inventory/products.js +0 -9
  244. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/multi-schema/users.js +0 -8
  245. package/generators/tests/unit/lib/dbschema-kit/connection.test.js +0 -112
  246. package/generators/tests/unit/lib/dbschema-kit/ddl-generator.test.js +0 -205
  247. package/generators/tests/unit/lib/dbschema-kit/define-model.test.js +0 -56
  248. package/generators/tests/unit/lib/dbschema-kit/dialect/index.test.js +0 -46
  249. package/generators/tests/unit/lib/dbschema-kit/dialect/mysql.test.js +0 -126
  250. package/generators/tests/unit/lib/dbschema-kit/dialect/oracle.test.js +0 -126
  251. package/generators/tests/unit/lib/dbschema-kit/dialect/postgres.test.js +0 -131
  252. package/generators/tests/unit/lib/dbschema-kit/dialect/sqlite.test.js +0 -126
  253. package/generators/tests/unit/lib/dbschema-kit/driver-loader.test.js +0 -93
  254. package/generators/tests/unit/lib/dbschema-kit/emitters/create-index.test.js +0 -173
  255. package/generators/tests/unit/lib/dbschema-kit/emitters/create-table.test.js +0 -376
  256. package/generators/tests/unit/lib/dbschema-kit/emitters/drop-table.test.js +0 -78
  257. package/generators/tests/unit/lib/dbschema-kit/fixtures/connection/invalid-dialect.env +0 -6
  258. package/generators/tests/unit/lib/dbschema-kit/fixtures/connection/missing-dialect.env +0 -5
  259. package/generators/tests/unit/lib/dbschema-kit/fixtures/connection/missing-host.env +0 -5
  260. package/generators/tests/unit/lib/dbschema-kit/fixtures/connection/oracle-valid.env +0 -6
  261. package/generators/tests/unit/lib/dbschema-kit/fixtures/connection/postgres-valid.env +0 -7
  262. package/generators/tests/unit/lib/dbschema-kit/fixtures/connection/sqlite-valid.env +0 -2
  263. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory/category.js +0 -11
  264. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory/item_product.js +0 -11
  265. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory/stock_inbound.js +0 -24
  266. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory/stock_inbound_item.js +0 -28
  267. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory/supplier.js +0 -9
  268. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory/warehouse.js +0 -9
  269. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory-invalid/orphan.js +0 -17
  270. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory-multifolder/master/category.js +0 -11
  271. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory-multifolder/master/item_product.js +0 -11
  272. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory-multifolder/master/supplier.js +0 -9
  273. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory-multifolder/master/warehouse.js +0 -9
  274. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory-multifolder/transactions/stock_inbound.js +0 -24
  275. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory-multifolder/transactions/stock_inbound_item.js +0 -28
  276. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/multi-schema/audit/events.js +0 -18
  277. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/multi-schema/inventory/products.js +0 -9
  278. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/multi-schema/public/users.js +0 -9
  279. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/duplicate-subfolder/extra/category.js +0 -8
  280. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/duplicate-subfolder/master/category.js +0 -8
  281. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/duplicate-tablename/bar.js +0 -8
  282. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/duplicate-tablename/foo.js +0 -8
  283. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/empty-folder/README.md +0 -1
  284. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/invalid-export/plain.js +0 -3
  285. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/invalid-schema/bad.js +0 -6
  286. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/legacy-pattern/legacy.js +0 -12
  287. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/multi-schema-distinct/audit/products.js +0 -9
  288. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/multi-schema-distinct/inventory/products.js +0 -9
  289. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/multi-schema-duplicate/a/products.js +0 -8
  290. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/multi-schema-duplicate/b/products.js +0 -8
  291. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/nested-deep/a/b/c/deep_table.js +0 -8
  292. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/recursive-multi-folder/.hidden/ignored.js +0 -7
  293. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/recursive-multi-folder/master/category.js +0 -8
  294. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/recursive-multi-folder/master/supplier.js +0 -8
  295. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/recursive-multi-folder/transactions/stock_inbound.js +0 -8
  296. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/recursive-multi-folder/transactions/stock_inbound_item.js +0 -8
  297. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/valid-multiple/category.js +0 -8
  298. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/valid-multiple/item_product.js +0 -9
  299. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/valid-single/category.js +0 -8
  300. package/generators/tests/unit/lib/dbschema-kit/integration.test.js +0 -217
  301. package/generators/tests/unit/lib/dbschema-kit/introspect-mapper.test.js +0 -403
  302. package/generators/tests/unit/lib/dbschema-kit/ir-builder.test.js +0 -390
  303. package/generators/tests/unit/lib/dbschema-kit/loader.test.js +0 -128
  304. package/generators/tests/unit/lib/dbschema-kit/naming.test.js +0 -170
  305. package/generators/tests/unit/lib/dbschema-kit/parser/shorthand-parser.test.js +0 -237
  306. package/generators/tests/unit/lib/dbschema-kit/schema-printer.test.js +0 -251
  307. package/generators/tests/unit/lib/dbschema-kit/statement-modifier.test.js +0 -105
  308. package/generators/tests/unit/lib/dbschema-kit/statement-splitter.test.js +0 -165
  309. package/generators/tests/unit/lib/dbschema-kit/topological-sort.test.js +0 -135
  310. package/generators/tests/unit/lib/dbschema-kit/validator/check-compatibility-validator.test.js +0 -373
  311. package/generators/tests/unit/lib/dbschema-kit/validator/circular-relation-validator.test.js +0 -454
  312. package/generators/tests/unit/lib/dbschema-kit/validator/cross-model-validator.test.js +0 -512
  313. package/generators/tests/unit/lib/dbschema-kit/validator/enhanced-validate-integration.test.js +0 -390
  314. package/generators/tests/unit/lib/dbschema-kit/validator/naming-convention-validator.test.js +0 -306
  315. package/generators/tests/unit/lib/dbschema-kit/validator/schema-validator.test.js +0 -443
  316. package/generators/tests/unit/lib/dbschema-kit/validator/type-compatibility-validator.test.js +0 -440
  317. package/generators/tests/unit/lib/dbschema-kit/validator/validator-reporter.test.js +0 -172
  318. package/generators/tests/unit/lib/metadata-manager-dashboard.test.js +0 -256
  319. package/generators/tests/unit/lib/payload-validator-fieldpolicy.test.js +0 -240
  320. package/generators/tests/unit/lib/processor-validation-generator.test.js +0 -300
  321. package/generators/tests/unit/lib/sensitive-field-masker.test.js +0 -170
  322. package/generators/tests/unit/lib/sql-table-extractor.test.js +0 -119
  323. package/scripts/generate-integrity-manifest.js +0 -124
  324. package/scripts/snapshot-cli-contracts.js +0 -194
  325. package/scripts/verify-publish.js +0 -56
package/SECURITY.md CHANGED
@@ -10,10 +10,9 @@ Security updates are provided for the two most recent minor releases on the stab
10
10
 
11
11
  | Version | Channel | Supported |
12
12
  |---------|---------|-----------|
13
- | 2.3.x | beta | Yes |
14
- | 2.2.x | stable | Yes |
15
- | 2.1.x | stable | Yes |
16
- | < 2.1 | legacy | No |
13
+ | 4.2.x | stable | Yes |
14
+ | 4.1.x | stable | Yes |
15
+ | < 4.1 | legacy | No |
17
16
 
18
17
  Users on older versions are encouraged to upgrade to a supported release.
19
18
 
@@ -105,6 +104,86 @@ A successful verification confirms that the installed package matches the manife
105
104
 
106
105
  ---
107
106
 
107
+ ## Default Security Configuration
108
+
109
+ The following defaults apply when corresponding environment variables are not explicitly set. Values reflect the runtime middleware implementation in this release. Operators are encouraged to review and override based on their threat model and compliance requirements.
110
+
111
+ ### CORS
112
+
113
+ - `CORS_ENABLED`: `true` (backward-compatible default — CORS is active when the variable is not set)
114
+ - `CORS_ORIGINS`: `*` (all origins permitted; set to a comma-separated allowlist for production)
115
+ - Allowed methods: `GET, POST, PUT, DELETE, OPTIONS`
116
+ - Allowed request headers: `Origin, X-Requested-With, Content-Type, Accept, Authorization, X-API-Key, X-Request-Mode, X-Request-ID, Idempotency-Key`
117
+ - Exposed response headers: `Idempotent-Replayed, Idempotency-Key`
118
+ - When a disallowed origin issues a preflight `OPTIONS`, the response is `HTTP 403`. Non-preflight requests proceed without CORS headers and are blocked client-side by the browser.
119
+
120
+ ### Security Headers (Helmet)
121
+
122
+ - `HELMET_ENABLED`: `false` (security headers are not emitted by default; operators behind a reverse proxy or framework that already injects headers can leave this unset)
123
+
124
+ When `HELMET_ENABLED=true`, the following headers are added to every response:
125
+
126
+ | Header | Value |
127
+ |--------|-------|
128
+ | `X-Content-Type-Options` | `nosniff` |
129
+ | `X-Frame-Options` | `DENY` |
130
+ | `X-XSS-Protection` | `0` (legacy auditor disabled) |
131
+ | `Strict-Transport-Security` | `max-age=15552000; includeSubDomains` (180 days) |
132
+ | `Referrer-Policy` | `no-referrer` |
133
+ | `X-Permitted-Cross-Domain-Policies` | `none` |
134
+ | `X-Download-Options` | `noopen` |
135
+ | `Content-Security-Policy` | `default-src 'none'` |
136
+ | `X-DNS-Prefetch-Control` | `off` |
137
+
138
+ The `X-Powered-By` header is always removed when this middleware is active.
139
+
140
+ ### Rate Limiting
141
+
142
+ - `RATE_LIMIT_ENABLED`: `false`
143
+ - `RATE_LIMIT_WINDOW_MS`: `60000` (60 seconds)
144
+ - `RATE_LIMIT_MAX_REQUESTS`: `100` requests per IP per window
145
+ - Storage backend: in-memory (single mode) or Redis Lua script (cluster mode, Redis required)
146
+ - Response headers always set when enabled: `X-RateLimit-Limit`, `X-RateLimit-Remaining`, `X-RateLimit-Reset`
147
+ - When the limit is exceeded, response is `HTTP 429` with `Retry-After` header
148
+
149
+ ### Idempotency
150
+
151
+ - `IDEMPOTENCY_ENABLED`: `false`
152
+ - `IDEMPOTENCY_TTL`: `300` seconds (cached response retention)
153
+ - Idempotency key header: `Idempotency-Key` (maximum 255 characters)
154
+ - Protected mutation actions (`POST` only): `create`, `create-composite`, `adjust`, `update-composite`
155
+ - Storage backend: Redis (requires `CACHE_ENABLED=true`)
156
+ - Replay returns the original status code with header `Idempotent-Replayed: true`
157
+ - Conflicting body for the same key returns `HTTP 422 Idempotency-Key conflict`
158
+
159
+ ### File Upload (Excel import)
160
+
161
+ - Maximum file size: `10 MB` (compile-time constant)
162
+ - Maximum files per request: `1`
163
+ - Allowed MIME types: `application/vnd.openxmlformats-officedocument.spreadsheetml.sheet`, `application/vnd.ms-excel`
164
+ - Allowed file extensions: `.xlsx`, `.xls`
165
+ - Stored filename pattern: `upload-<timestamp>-<8-byte-random-hex><ext>` (random suffix prevents collision and disclosure of original filename)
166
+ - `UPLOAD_DIR`: override the upload destination directory (default: `<package-root>/temp/uploads/<project>`)
167
+
168
+ ### Body Parser
169
+
170
+ - JSON payload limit: `10 MB`
171
+ - URL-encoded payload limit: `10 MB`
172
+ - Invalid JSON returns `HTTP 400` with body `{ "success": false, "error": "Invalid JSON payload", ... }`
173
+
174
+ ### API Key
175
+
176
+ - Authentication header: `X-API-Key`
177
+ - Comparison: `crypto.timingSafeEqual` (constant-time, hardened in v4.3.0 — see CHANGELOG)
178
+ - Source: CLI argument `--key=<value>` or `key` field in the project config file
179
+ - Missing or mismatched key returns `HTTP 401 Unauthorized`
180
+
181
+ ### JWT
182
+
183
+ RESTForge runtime does not perform JSON Web Token signing or verification natively. Operators that require JWT-based authentication should implement it at the processor or application middleware layer using a vetted library such as `jsonwebtoken`.
184
+
185
+ ---
186
+
108
187
  ## Third-Party Dependencies
109
188
 
110
189
  RESTForge depends on well-established packages maintained by the Node.js ecosystem. The full dependency list is declared in `package.json`. Dependency updates follow these guidelines:
package/bin/sdf-tools.exe CHANGED
Binary file
package/build-info.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@restforgejs/platform",
3
- "version": "4.2.8",
4
- "buildDate": "2026-05-21T01:20:53.371Z",
3
+ "version": "4.3.2",
4
+ "buildDate": "2026-05-23T21:09:34.136Z",
5
5
  "dialects": [
6
6
  "postgresql",
7
7
  "mysql",
@@ -1,3 +1,3 @@
1
1
  #!/usr/bin/env node
2
2
 
3
- const a0_0x593a30=a0_0x3d64;function a0_0x3d64(_0x52e046,_0x30d325){_0x52e046=_0x52e046-0x94;const _0x3d4554=a0_0x3d45();let _0x3d6478=_0x3d4554[_0x52e046];if(a0_0x3d64['KIqBgP']===undefined){var _0x46b05d=function(_0x276e99){const _0x5c3570='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x3f7462='',_0x473036='';for(let _0x3adc10=0x0,_0x5bbd83,_0x21a69e,_0x39e278=0x0;_0x21a69e=_0x276e99['charAt'](_0x39e278++);~_0x21a69e&&(_0x5bbd83=_0x3adc10%0x4?_0x5bbd83*0x40+_0x21a69e:_0x21a69e,_0x3adc10++%0x4)?_0x3f7462+=String['fromCharCode'](0xff&_0x5bbd83>>(-0x2*_0x3adc10&0x6)):0x0){_0x21a69e=_0x5c3570['indexOf'](_0x21a69e);}for(let _0x4bdcd9=0x0,_0x5bf85a=_0x3f7462['length'];_0x4bdcd9<_0x5bf85a;_0x4bdcd9++){_0x473036+='%'+('00'+_0x3f7462['charCodeAt'](_0x4bdcd9)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x473036);};a0_0x3d64['YSHBQD']=_0x46b05d,a0_0x3d64['PWNHAG']={},a0_0x3d64['KIqBgP']=!![];}const _0x57987e=_0x3d4554[0x0],_0x3a32cc=_0x52e046+_0x57987e,_0x22c668=a0_0x3d64['PWNHAG'][_0x3a32cc];return!_0x22c668?(_0x3d6478=a0_0x3d64['YSHBQD'](_0x3d6478),a0_0x3d64['PWNHAG'][_0x3a32cc]=_0x3d6478):_0x3d6478=_0x22c668,_0x3d6478;}(function(_0x17c407,_0x264675){const _0x2a4a9e=a0_0x3d64,_0x2ea824=_0x17c407();while(!![]){try{const _0x253e09=parseInt(_0x2a4a9e(0xe1))/0x1+parseInt(_0x2a4a9e(0xd2))/0x2+parseInt(_0x2a4a9e(0x97))/0x3*(-parseInt(_0x2a4a9e(0xc7))/0x4)+parseInt(_0x2a4a9e(0xb6))/0x5*(parseInt(_0x2a4a9e(0xf5))/0x6)+-parseInt(_0x2a4a9e(0x9a))/0x7*(parseInt(_0x2a4a9e(0xd9))/0x8)+-parseInt(_0x2a4a9e(0xdb))/0x9+parseInt(_0x2a4a9e(0xe0))/0xa*(parseInt(_0x2a4a9e(0xe6))/0xb);if(_0x253e09===_0x264675)break;else _0x2ea824['push'](_0x2ea824['shift']());}catch(_0x5b89cc){_0x2ea824['push'](_0x2ea824['shift']());}}}(a0_0x3d45,0xeef08));function a0_0x3d45(){const _0x171c7e=['AxneAxjLy3rVCNK','tMv4DcbZDgvWCYbMB3iGzgvWBg95BwvUDdO','vxnLic0TAgvSCcbMB3iGDxnHz2uGAw5MB3jTyxrPB24','lwvYCM9YlMXVzW','Cefgvfm','oti1otm2qNr3txHe','icaGicbJzca','Cg0Y','y1jRu0e','ica1lIbtzxr1CcbHDxrVlxn0yxj0ig9UigjVB3q6','Aw5KzxGUANm','ls1OzwXW','mJu0ndy1nMvSy29vwa','cN07cG','mJC2nJa5nKDkvenvua','y29UC3vTzxjZ','rxjYB3i6ienVBNn1BwvYig5VDcbMB3vUzdOG','ic0TCg9YDd0','C3jJ','mtb3BNj4D1G','mJeYmtaXAwPTwMPg','pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09','ic0TBgLJzw5Zzt0','BNzfywy','CxvLC3rPB24','mtG0nZyXmdzRtLbKEKS','tw9KztOGu2LUz2XLignVBNn1BwvYicG','lYOQcIaQifbnmIbfy29ZExn0zw0Gq29UzMLNDxjHDgLVBGOGkIbqCM9Qzwn0oIa','zxHPC3rZu3LUyW','wg1zrem','cIaQcIaQifvZywDLoGOGkIaGihbTmIbZDgfYDcbLy29ZExn0zw0Uy29UzMLNlMPZcIaQicaGCg0Yihn0B3aGzwnVC3LZDgvTlMnVBMzPzY5QCWOGkIaGihbTmIbYzxn0yxj0igvJB3n5C3rLBs5JB25MAwCUANmkicOGicbWBtiGzgvSzxrLigvJB3n5C3rLBs5JB25MAwCUANmkicOVcGPTB2r1BguUzxHWB3j0CYa9ihSkicbHChbZoIa','zM9Yy2u','t3v0Chv0oIa','r2vUzxjHDgLUzYbJB25ZDw1LCI1Tyw5Hz2vYlNnOlI4U','rMf0ywWGzxjYB3i6ia','r2vUzxjHDgLVBIbJyw5JzwXSzwqU','ls1WB3j0pq','ls1JB25ZDw1LCJ0','ls1TB2r1Bgu9','y2HTB2rtEw5J','mti2De1ruhre','cImkiYbhzw5LCMf0zwqGyNK6ifjfu1rgB3jNzsbdB25ZDw1LCIbezxbSB3KGq0XjcImGr2vUzxjHDgvKigf0oIa','tNfoAe4','ChjVzhvJDgLVBG','y29UzMLN','u1v0rLC','icbBmv0Gt3zLCNDYAxrLigv4Axn0Aw5NigzPBgvZ','r2vUzxjHDgLUzYbLy29ZExn0zw0Uy29UzMLNlMPZlI4U','ic0Ty29UC3vTzxi9','icbdCMvHDgvKoIa','CMvHzgrPCLn5BMm','CMvSyxrPDMu','y29UC3vTzxiTBwfUywDLCI5ZAa','CNjfzMS','Bg9NCW','C3rKB3v0','ls1WCM9Qzwn0pq','pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09','cLjfu1rgB3jNzsbdB25ZDw1LCIbezxbSB3KGq0XjcLzLCNnPB246ideUmc4WcKj1AwXKoIaYmdi2ltaXlteZcIaG','tw9KztOGtxvSDgKGy29UC3vTzxiGka','yxjNDG','t3b0Aw9UCZO','y3DK','lw91Dc5SB2C','zxHPDa','D3jPDgvgAwXLu3LUyW','ntm1mZv1y2TNAeG','qKPsr0m','rxHWzwn0zwqGyxq6ihnYyY9JB25ZDw1LCNmV','n3HhCgf4DG','uKvtvezVCMDLienVBNn1BwvYierLCgXVEsbhzw5LCMf0B3i','ls1VDxrWDxq9','q29UzMLNoIa','ls1SAwnLBNnLpq','cImGq29UC3vTzxjZoIa','CMvZDgzVCMDLlwnVBNn1BwvYic0TChjVAMvJDd0','C3nKsgG','lI9SB2DZl3bTmI8','y29UC3vTzxi','BMfTzq','ntaWtq','C01Qzeq','zxjYB3i','u0fjqKq','Bg9N','z2H4tLe','BKfiuNK','icaGicbWBtiGC2f2zq','Ahrxu2e','Dg9ju09tDhjPBMC','icaTia','icbhzw5LCMf0Aw9UignVBxbSzxrLzcbZDwnJzxnZzNvSBhKH','zxHkD0y','cImJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiWOkiYbdB2XVCNmkuKvepsDCmdmZwZa7mZfTjWPhuKvftJ0NxdaZm1SWoZmYBsCkwuvmte9xpsDCmdmZwZe7mZnTjWPctfvfpsDCmdmZwZa7mZrTjWPdwufopsDCmdmZwZa7mZzTjWPoqZ0NxdaZm1SWBsCGiYboBYbdB2XVCGOkiYbqCM9Qzwn0igLUzM8kufjpsKvdvf9oqu1fpsi','CMvZB2X2zq','BxbnzKO','s2fqtvi','mtG2nJG1qMDrCgHQ','sxjtyLu','icbBmL0Gq2fUy2vS','ica0lIbpCIb1C2uGAw50zxjHy3rPDMuGBwfUywDLCJO','C2XPy2u','iYeVyMLUl2jHC2GkcImJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiWOJifjfu1rgB3jNzsbdB25ZDw1LCIbnyw5Hz2vYcImGuhjVAMvJDdOG','B3v0Chv0','B25qyMO','ls1MB3jJzq','AM9PBG','BgvUz3rO','zg90zw52','icaYlIbjBNn0ywXSifbnmIbNBg9IywXSEsaOAwyGBM90igLUC3rHBgXLzcK6','AgvSCa','BgLJzw5Zzq','C3bSAxq','ChvZAa','mZq0yK5mueXn','y2XVC2u','DhjPBq','ChjVAMvJDa','qLHJDK8','AvPbwfi'];a0_0x3d45=function(){return _0x171c7e;};return a0_0x3d45();}const path=require('path'),fs=require('fs'),readline=require('readline');require(a0_0x593a30(0xc1))['config']();function prompt(_0x1489a7){const _0x52fc27=a0_0x593a30,_0x1016fa=readline['createInterface']({'input':process['stdin'],'output':process[_0x52fc27(0x104)]});return new Promise(_0x3519b4=>{const _0x30a2ac=_0x52fc27;_0x1016fa[_0x30a2ac(0xe5)](_0x1489a7,_0x31c88f=>{const _0x382bad=_0x30a2ac;_0x1016fa[_0x382bad(0xc8)](),_0x3519b4(_0x31c88f[_0x382bad(0xc9)]());});});}const args=parseArgs(process[a0_0x593a30(0x109)][a0_0x593a30(0xba)](0x2));function parseArgs(_0x4c85d4){const _0x4ddfb=a0_0x593a30,_0x2342a={'pAFTS':function(_0x4525b7,_0x35f271){return _0x4525b7===_0x35f271;},'fFsho':function(_0x55f425,_0x1d24b9){return _0x55f425===_0x1d24b9;},'mpMfJ':_0x4ddfb(0xf3),'ITfOP':_0x4ddfb(0xf1),'xHItd':_0x4ddfb(0x9c),'BXcvO':_0x4ddfb(0xbe),'cRkSA':function(_0x436706,_0x234ec3){return _0x436706===_0x234ec3;}},_0xfd749b={'project':null,'consumer':null,'config':null,'license':null,'port':0xbb9,'output':null,'force':![],'help':![],'version':![]};for(const _0x1257b5 of _0x4c85d4){if(_0x2342a['pAFTS'](_0x1257b5,_0x4ddfb(0xd8))||_0x2342a['fFsho'](_0x1257b5,'-h'))_0xfd749b[_0x4ddfb(0xc3)]=!![];else{if(_0x1257b5==='--version'||_0x1257b5==='-v')_0xfd749b['version']=!![];else{if(_0x1257b5['startsWith'](_0x4ddfb(0x105)))_0xfd749b[_0x4ddfb(0xca)]=_0x1257b5[_0x4ddfb(0xc5)]('=')[0x1];else{if(_0x1257b5['startsWith'](_0x2342a[_0x4ddfb(0xb4)]))_0xfd749b['project']=_0x1257b5[_0x4ddfb(0xc5)]('=')[0x1];else{if(_0x1257b5['startsWith'](_0x4ddfb(0xf2)))_0xfd749b[_0x4ddfb(0xa3)]=_0x1257b5[_0x4ddfb(0xc5)]('=')[0x1];else{if(_0x1257b5['startsWith']('--config='))_0xfd749b[_0x4ddfb(0xf9)]=_0x1257b5[_0x4ddfb(0xc5)]('=')[0x1];else{if(_0x1257b5['startsWith'](_0x4ddfb(0x9e)))_0xfd749b[_0x4ddfb(0xc4)]=_0x1257b5['split']('=')[0x1];else{if(_0x1257b5['startsWith'](_0x2342a['ITfOP']))_0xfd749b['port']=parseInt(_0x1257b5[_0x4ddfb(0xc5)]('=')[0x1],0xa)||0xbb9;else{if(_0x1257b5['startsWith'](_0x2342a['xHItd']))_0xfd749b[_0x4ddfb(0xbc)]=_0x1257b5['split']('=')[0x1];else(_0x2342a[_0x4ddfb(0xd1)](_0x1257b5,_0x2342a[_0x4ddfb(0xcb)])||_0x2342a[_0x4ddfb(0xd5)](_0x1257b5,'-f'))&&(_0xfd749b[_0x4ddfb(0xec)]=!![]);}}}}}}}}}return _0xfd749b;}function printHelp(){const _0x2d7ccc=a0_0x593a30;console[_0x2d7ccc(0xa9)]('\x0aRESTForge\x20Consumer\x20Deploy\x20CLI\x0a=============================\x0a\x0aGenerate\x20PM2\x20ecosystem\x20config\x20and\x20shell\x20script\x20for\x20production\x20deployment.\x0a\x0aUsage:\x0a\x20\x20npx\x20restforge-consumer-deploy\x20--project=<PROJECT>\x20--config=<FILE.env>\x20[options]\x0a\x0aOptions:\x0a\x20\x20--project=<NAME>\x20\x20\x20\x20Project\x20name\x20(required)\x0a\x20\x20--module=<NAME>\x20\x20\x20\x20\x20Alias\x20for\x20--project\x0a\x20\x20--config=<FILE.env>\x20Environment\x20configuration\x20file\x20(required)\x0a\x20\x20--consumer=<NAME>\x20\x20\x20Specific\x20consumer\x20(optional,\x20default:\x20all\x20consumers)\x0a\x20\x20--license=<KEY>\x20\x20\x20\x20\x20License\x20key\x20(optional,\x20can\x20be\x20set\x20in\x20.env)\x0a\x20\x20--port=<PORT>\x20\x20\x20\x20\x20\x20\x20Port\x20for\x20Control\x20API\x20(default:\x203001)\x0a\x20\x20--output=<DIR>\x20\x20\x20\x20\x20\x20Output\x20directory\x20(default:\x20./deploy/)\x0a\x20\x20--force,\x20-f\x20\x20\x20\x20\x20\x20\x20\x20\x20Overwrite\x20existing\x20files\x0a\x20\x20--help,\x20-h\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20Show\x20this\x20help\x20message\x0a\x20\x20--version,\x20-v\x20\x20\x20\x20\x20\x20\x20Show\x20version\x0a\x0aExamples:\x0a\x20\x20#\x20Generate\x20for\x20ALL\x20consumers\x20in\x20a\x20project\x0a\x20\x20npx\x20restforge-consumer-deploy\x20--project=dbx-mini-inventory\x20--config=mini-inventory.env\x20--license=XXXX-XXXX-XXXX-XXXX\x0a\x0a\x20\x20#\x20Generate\x20for\x20a\x20specific\x20consumer\x20only\x0a\x20\x20npx\x20restforge-consumer-deploy\x20--project=dbx-mini-inventory\x20--config=mini-inventory.env\x20--consumer=supplier-console\x20--license=XXXX-XXXX-XXXX-XXXX\x0a\x0a\x20\x20#\x20Output\x20to\x20a\x20custom\x20folder\x0a\x20\x20npx\x20restforge-consumer-deploy\x20--project=dbx-mini-inventory\x20--config=mini-inventory.env\x20--output=./production/\x0a\x0aOutput\x20Files:\x0a\x20\x20deploy/\x0a\x20\x20├──\x20ecosystem.config.js\x20\x20\x20\x20#\x20PM2\x20ecosystem\x20configuration\x0a\x20\x20└──\x20consumer-manager.sh\x20\x20\x20\x20#\x20Interactive\x20shell\x20script\x20for\x20PM2\x20management\x0a\x20\x20');}function printVersion(){const _0x2e009e=a0_0x593a30;console['log'](_0x2e009e(0x107));}function scanConsumers(_0x510d41,_0x557152){const _0x3ae3b8=a0_0x593a30,_0xb4521e=path['join'](_0x510d41,_0x3ae3b8(0xdf),_0x3ae3b8(0xdc),_0x557152);if(!fs['existsSync'](_0xb4521e))return[];const _0x5bda67=fs[_0x3ae3b8(0xff)](_0xb4521e,{'withFileTypes':!![]}),_0x4579cb=[];for(const _0x45c76e of _0x5bda67){if(_0x45c76e[_0x3ae3b8(0xcd)]()){const _0x1e34eb=path['join'](_0xb4521e,_0x45c76e[_0x3ae3b8(0xa4)],'index.js');fs[_0x3ae3b8(0xe9)](_0x1e34eb)&&_0x4579cb['push'](_0x45c76e['name']);}}return _0x4579cb;}function generateEcosystemConfig(_0x35502e){const _0x437802=a0_0x593a30,_0x356a20={'IrSbU':function(_0x4b44fe,_0x191dc4){return _0x4b44fe===_0x191dc4;},'NqNhN':'YYYY-MM-DD\x20HH:mm:ss\x20Z'},{projectName:_0x331bf5,consumers:_0x2d3daa,configFile:_0x170087,license:_0x64d498,port:_0xd1c022,projectDir:_0xada9b9}=_0x35502e,_0x571164=[];if(_0x356a20[_0x437802(0xb7)](_0x2d3daa[_0x437802(0xc0)],0x1)){const _0x4610a4=_0x2d3daa[0x0];_0x571164[_0x437802(0xc6)]({'name':'consumer-'+_0x331bf5+'-'+_0x4610a4,'script':'npx','args':_0x437802(0xa0)+_0x331bf5+'\x20--config='+_0x170087+_0x437802(0xfd)+_0x4610a4+(_0x64d498?_0x437802(0xe3)+_0x64d498:'')+_0x437802(0xde)+_0xd1c022,'cwd':_0xada9b9,'instances':0x1,'autorestart':!![],'watch':![],'maxMemoryRestart':'500M','env':{'NODE_ENV':_0x437802(0xf8)},'errorFile':_0x437802(0xa2)+_0x4610a4+'-error.log','outFile':_0x437802(0xa2)+_0x4610a4+_0x437802(0x94),'logDateFormat':_0x356a20[_0x437802(0xf7)]});}else{let _0xc459cd=_0xd1c022;for(const _0x37f2b9 of _0x2d3daa){_0x571164[_0x437802(0xc6)]({'name':'consumer-'+_0x331bf5+'-'+_0x37f2b9,'script':'npx','args':'restforge-consumer\x20--project='+_0x331bf5+'\x20--config='+_0x170087+'\x20--consumer='+_0x37f2b9+(_0x64d498?'\x20--license='+_0x64d498:'')+_0x437802(0xde)+_0xc459cd,'cwd':_0xada9b9,'instances':0x1,'autorestart':!![],'watch':![],'maxMemoryRestart':_0x437802(0xa5),'env':{'NODE_ENV':_0x437802(0xf8)},'errorFile':'./logs/pm2/'+_0x37f2b9+_0x437802(0xd0),'outFile':_0x437802(0xa2)+_0x37f2b9+_0x437802(0x94),'logDateFormat':_0x356a20['NqNhN']}),_0xc459cd++;}}const _0x1de29c=_0x437802(0xe8)+_0x331bf5+'\x0a\x20*\x20Consumers:\x20'+_0x2d3daa[_0x437802(0xbf)](',\x20')+'\x0a\x20*\x0a\x20*\x20Generated\x20by:\x20RESTForge\x20Consumer\x20Deploy\x20CLI\x0a\x20*\x20Generated\x20at:\x20'+new Date()[_0x437802(0xae)]()+_0x437802(0xeb)+JSON['stringify'](_0x571164,null,0x4)['replace'](/"(\w+)":/g,'$1:')+_0x437802(0xda);return _0x1de29c;}function generateShellScript(_0x436513){const _0x491426=a0_0x593a30,{projectName:_0x126e6a,consumers:_0x2fd0f4}=_0x436513,_0x32cdce=_0x2fd0f4['map'](_0x27eb6c=>'consumer-'+_0x126e6a+'-'+_0x27eb6c),_0x41a057=_0x32cdce[_0x491426(0xbf)]('\x20'),_0x429995=_0x32cdce[0x0];return _0x491426(0xbb)+_0x126e6a+_0x491426(0x9f)+_0x2fd0f4[_0x491426(0xbf)](',\x20')+_0x491426(0xf6)+new Date()['toISOString']()+_0x491426(0xb2)+_0x126e6a+'\x22\x0aAPP_NAMES=\x22'+_0x41a057+'\x22\x0aECOSYSTEM_FILE=\x22ecosystem.config.js\x22\x0a\x0a#\x20Get\x20script\x20directory\x0aSCRIPT_DIR=\x22$(\x20cd\x20\x22$(\x20dirname\x20\x22${BASH_SOURCE[0]}\x22\x20)\x22\x20&&\x20pwd\x20)\x22\x0acd\x20\x22$SCRIPT_DIR\x22\x0a\x0a#\x20Check\x20if\x20PM2\x20is\x20installed\x0acheck_pm2()\x20{\x0a\x20\x20\x20\x20if\x20!\x20command\x20-v\x20pm2\x20&>\x20/dev/null;\x20then\x0a\x20\x20\x20\x20\x20\x20\x20\x20echo\x20-e\x20\x22${RED}Error:\x20PM2\x20is\x20not\x20installed.${NC}\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20echo\x20\x22Install\x20PM2\x20with:\x20npm\x20install\x20-g\x20pm2\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20exit\x201\x0a\x20\x20\x20\x20fi\x0a}\x0a\x0a#\x20Print\x20header\x0aprint_header()\x20{\x0a\x20\x20\x20\x20clear\x0a\x20\x20\x20\x20echo\x20-e\x20\x22${CYAN}============================================${NC}\x22\x0a\x20\x20\x20\x20echo\x20-e\x20\x22${CYAN}\x20\x20RESTForge\x20Consumer\x20Manager${NC}\x22\x0a\x20\x20\x20\x20echo\x20-e\x20\x22${CYAN}============================================${NC}\x22\x0a\x20\x20\x20\x20echo\x20-e\x20\x22\x20\x20Project:\x20${GREEN}$PROJECT_NAME${NC}\x22\x0a\x20\x20\x20\x20echo\x20-e\x20\x22\x20\x20Consumers:\x20${YELLOW}'+_0x2fd0f4['length']+'${NC}\x22\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a}\x0a\x0a#\x20Show\x20status\x0ashow_status()\x20{\x0a\x20\x20\x20\x20echo\x20-e\x20\x22${BLUE}Current\x20Status:${NC}\x22\x0a\x20\x20\x20\x20echo\x20\x22--------------------------------------------\x22\x0a\x20\x20\x20\x20pm2\x20list\x20|\x20grep\x20-E\x20\x22('+_0x32cdce['join']('|')+'|Name|─)\x22\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a}\x0a\x0a#\x20Start\x20all\x20consumers\x0astart_all()\x20{\x0a\x20\x20\x20\x20echo\x20-e\x20\x22${GREEN}Starting\x20all\x20consumers...${NC}\x22\x0a\x20\x20\x20\x20pm2\x20start\x20$ECOSYSTEM_FILE\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20show_status\x0a}\x0a\x0a#\x20Stop\x20all\x20consumers\x0astop_all()\x20{\x0a\x20\x20\x20\x20echo\x20-e\x20\x22${YELLOW}Stopping\x20all\x20consumers...${NC}\x22\x0a\x20\x20\x20\x20for\x20app\x20in\x20$APP_NAMES;\x20do\x0a\x20\x20\x20\x20\x20\x20\x20\x20pm2\x20stop\x20$app\x202>/dev/null\x0a\x20\x20\x20\x20done\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20show_status\x0a}\x0a\x0a#\x20Restart\x20all\x20consumers\x0arestart_all()\x20{\x0a\x20\x20\x20\x20echo\x20-e\x20\x22${YELLOW}Restarting\x20all\x20consumers...${NC}\x22\x0a\x20\x20\x20\x20for\x20app\x20in\x20$APP_NAMES;\x20do\x0a\x20\x20\x20\x20\x20\x20\x20\x20pm2\x20restart\x20$app\x202>/dev/null\x0a\x20\x20\x20\x20done\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20show_status\x0a}\x0a\x0a#\x20Delete\x20all\x20from\x20PM2\x0adelete_all()\x20{\x0a\x20\x20\x20\x20echo\x20-e\x20\x22${RED}Deleting\x20all\x20consumers\x20from\x20PM2...${NC}\x22\x0a\x20\x20\x20\x20for\x20app\x20in\x20$APP_NAMES;\x20do\x0a\x20\x20\x20\x20\x20\x20\x20\x20pm2\x20delete\x20$app\x202>/dev/null\x0a\x20\x20\x20\x20done\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20show_status\x0a}\x0a\x0a#\x20Show\x20logs\x0ashow_logs()\x20{\x0a\x20\x20\x20\x20echo\x20-e\x20\x22${BLUE}Select\x20consumer\x20to\x20view\x20logs:${NC}\x22\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20local\x20i=1\x0a\x20\x20\x20\x20for\x20app\x20in\x20$APP_NAMES;\x20do\x0a\x20\x20\x20\x20\x20\x20\x20\x20echo\x20\x22\x20\x20[$i]\x20$app\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20((i++))\x0a\x20\x20\x20\x20done\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[a]\x20All\x20consumers\x22\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[0]\x20Back\x20to\x20menu\x22\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20read\x20-p\x20\x22Your\x20choice:\x20\x22\x20choice\x0a\x0a\x20\x20\x20\x20if\x20[\x20\x22$choice\x22\x20==\x20\x220\x22\x20];\x20then\x0a\x20\x20\x20\x20\x20\x20\x20\x20return\x0a\x20\x20\x20\x20elif\x20[\x20\x22$choice\x22\x20==\x20\x22a\x22\x20]\x20||\x20[\x20\x22$choice\x22\x20==\x20\x22A\x22\x20];\x20then\x0a\x20\x20\x20\x20\x20\x20\x20\x20pm2\x20logs\x0a\x20\x20\x20\x20else\x0a\x20\x20\x20\x20\x20\x20\x20\x20local\x20apps_array=($APP_NAMES)\x0a\x20\x20\x20\x20\x20\x20\x20\x20local\x20idx=$((choice\x20-\x201))\x0a\x20\x20\x20\x20\x20\x20\x20\x20if\x20[\x20$idx\x20-ge\x200\x20]\x20&&\x20[\x20$idx\x20-lt\x20${#apps_array[@]}\x20];\x20then\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20pm2\x20logs\x20${apps_array[$idx]}\x0a\x20\x20\x20\x20\x20\x20\x20\x20else\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20echo\x20-e\x20\x22${RED}Invalid\x20choice${NC}\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20fi\x0a\x20\x20\x20\x20fi\x0a}\x0a\x0a#\x20Monitor\x0ashow_monitor()\x20{\x0a\x20\x20\x20\x20pm2\x20monit\x0a}\x0a\x0a#\x20Setup\x20startup\x0asetup_startup()\x20{\x0a\x20\x20\x20\x20echo\x20-e\x20\x22${GREEN}Setting\x20up\x20PM2\x20startup...${NC}\x22\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20echo\x20\x22This\x20will\x20configure\x20PM2\x20to\x20start\x20automatically\x20on\x20system\x20boot.\x22\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20read\x20-p\x20\x22Continue?\x20(y/n):\x20\x22\x20confirm\x0a\x0a\x20\x20\x20\x20if\x20[\x20\x22$confirm\x22\x20==\x20\x22y\x22\x20]\x20||\x20[\x20\x22$confirm\x22\x20==\x20\x22Y\x22\x20];\x20then\x0a\x20\x20\x20\x20\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20echo\x20-e\x20\x22${YELLOW}Step\x201:\x20Generate\x20startup\x20script${NC}\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20pm2\x20startup\x0a\x20\x20\x20\x20\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20echo\x20-e\x20\x22${YELLOW}Step\x202:\x20Save\x20current\x20process\x20list${NC}\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20pm2\x20save\x0a\x20\x20\x20\x20\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20echo\x20-e\x20\x22${GREEN}Startup\x20configuration\x20complete!${NC}\x22\x0a\x20\x20\x20\x20fi\x0a}\x0a\x0a#\x20Reload\x20with\x20zero\x20downtime\x0areload_all()\x20{\x0a\x20\x20\x20\x20echo\x20-e\x20\x22${GREEN}Reloading\x20all\x20consumers\x20(zero\x20downtime)...${NC}\x22\x0a\x20\x20\x20\x20for\x20app\x20in\x20$APP_NAMES;\x20do\x0a\x20\x20\x20\x20\x20\x20\x20\x20pm2\x20reload\x20$app\x202>/dev/null\x0a\x20\x20\x20\x20done\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20show_status\x0a}\x0a\x0a#\x20Show\x20detailed\x20info\x0ashow_info()\x20{\x0a\x20\x20\x20\x20echo\x20-e\x20\x22${BLUE}Select\x20consumer\x20to\x20view\x20details:${NC}\x22\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20local\x20i=1\x0a\x20\x20\x20\x20for\x20app\x20in\x20$APP_NAMES;\x20do\x0a\x20\x20\x20\x20\x20\x20\x20\x20echo\x20\x22\x20\x20[$i]\x20$app\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20((i++))\x0a\x20\x20\x20\x20done\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[0]\x20Back\x20to\x20menu\x22\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20read\x20-p\x20\x22Your\x20choice:\x20\x22\x20choice\x0a\x0a\x20\x20\x20\x20if\x20[\x20\x22$choice\x22\x20==\x20\x220\x22\x20];\x20then\x0a\x20\x20\x20\x20\x20\x20\x20\x20return\x0a\x20\x20\x20\x20else\x0a\x20\x20\x20\x20\x20\x20\x20\x20local\x20apps_array=($APP_NAMES)\x0a\x20\x20\x20\x20\x20\x20\x20\x20local\x20idx=$((choice\x20-\x201))\x0a\x20\x20\x20\x20\x20\x20\x20\x20if\x20[\x20$idx\x20-ge\x200\x20]\x20&&\x20[\x20$idx\x20-lt\x20${#apps_array[@]}\x20];\x20then\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20pm2\x20show\x20${apps_array[$idx]}\x0a\x20\x20\x20\x20\x20\x20\x20\x20else\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20echo\x20-e\x20\x22${RED}Invalid\x20choice${NC}\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20fi\x0a\x20\x20\x20\x20fi\x0a\x20\x20\x20\x20read\x20-p\x20\x22Press\x20Enter\x20to\x20continue...\x22\x0a}\x0a\x0a#\x20Main\x20menu\x0ashow_menu()\x20{\x0a\x20\x20\x20\x20echo\x20-e\x20\x22${BLUE}Menu:${NC}\x22\x0a\x20\x20\x20\x20echo\x20\x22--------------------------------------------\x22\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[1]\x20Start\x20all\x20consumers\x22\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[2]\x20Stop\x20all\x20consumers\x22\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[3]\x20Restart\x20all\x20consumers\x22\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[4]\x20Reload\x20all\x20(zero\x20downtime)\x22\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[5]\x20Delete\x20all\x20from\x20PM2\x22\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[6]\x20View\x20logs\x22\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[7]\x20Monitor\x20(real-time)\x22\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[8]\x20Show\x20consumer\x20details\x22\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[9]\x20Setup\x20startup\x20(auto-start\x20on\x20boot)\x22\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[s]\x20Show\x20status\x22\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[q]\x20Quit\x22\x0a\x20\x20\x20\x20echo\x20\x22--------------------------------------------\x22\x0a}\x0a\x0a#\x20Main\x20loop\x0amain()\x20{\x0a\x20\x20\x20\x20check_pm2\x0a\x0a\x20\x20\x20\x20while\x20true;\x20do\x0a\x20\x20\x20\x20\x20\x20\x20\x20print_header\x0a\x20\x20\x20\x20\x20\x20\x20\x20show_status\x0a\x20\x20\x20\x20\x20\x20\x20\x20show_menu\x0a\x20\x20\x20\x20\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20read\x20-p\x20\x22Your\x20choice:\x20\x22\x20choice\x0a\x20\x20\x20\x20\x20\x20\x20\x20echo\x20\x22\x22\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20case\x20$choice\x20in\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x201)\x20start_all\x20;;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x202)\x20stop_all\x20;;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x203)\x20restart_all\x20;;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x204)\x20reload_all\x20;;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x205)\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20read\x20-p\x20\x22Are\x20you\x20sure\x20you\x20want\x20to\x20delete\x20all?\x20(y/n):\x20\x22\x20confirm\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20if\x20[\x20\x22$confirm\x22\x20==\x20\x22y\x22\x20]\x20||\x20[\x20\x22$confirm\x22\x20==\x20\x22Y\x22\x20];\x20then\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20delete_all\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20fi\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20;;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x206)\x20show_logs\x20;;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x207)\x20show_monitor\x20;;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x208)\x20show_info\x20;;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x209)\x20setup_startup\x20;;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20s|S)\x20show_status\x20;;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20q|Q)\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20echo\x20-e\x20\x22${GREEN}Goodbye!${NC}\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20exit\x200\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20;;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20*)\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20echo\x20-e\x20\x22${RED}Invalid\x20choice${NC}\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20;;\x0a\x20\x20\x20\x20\x20\x20\x20\x20esac\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20if\x20[\x20\x22$choice\x22\x20!=\x20\x227\x22\x20];\x20then\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20read\x20-p\x20\x22Press\x20Enter\x20to\x20continue...\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20fi\x0a\x20\x20\x20\x20done\x0a}\x0a\x0a#\x20Run\x20main\x0amain\x0a';}async function main(){const _0x45b1ae=a0_0x593a30,_0x4df60f={'hHGnD':function(_0x5b9e36){return _0x5b9e36();},'ssdHh':'Error:\x20--project=<NAME>\x20is\x20required','nvEaf':'Use\x20--help\x20for\x20usage\x20information','exJwF':'deploy','CyqpZ':'src','BJRGC':function(_0x37fd20,_0x1d199a,_0x5ac3ae){return _0x37fd20(_0x1d199a,_0x5ac3ae);},'tNrbe':function(_0x223ede,_0x46d430){return _0x223ede===_0x46d430;},'KaPMR':'ecosystem.config.js','sMjdD':_0x45b1ae(0x101),'ghxNQ':'WARNING:\x20The\x20following\x20files\x20already\x20exist:','wpzLG':_0x45b1ae(0xfb),'CaNEu':_0x45b1ae(0xb8),'nAHRy':'Your\x20choice\x20(1/2):\x20','htWSa':_0x45b1ae(0x103),'UzvOL':_0x45b1ae(0xd4),'xNRRa':_0x45b1ae(0xfc),'utpCk':function(_0x462c65,_0x50734c){return _0x462c65(_0x50734c);},'XmYDC':'755','jOHgj':'==========================================','SAIBD':_0x45b1ae(0xb0),'rrEfk':'Generated\x20files:','unECl':_0x45b1ae(0xce),'iZAXR':'\x20\x201.\x20Copy\x20project\x20to\x20production\x20server','VLIRz':'\x20\x20\x20\x20\x20npm\x20install\x20-g\x20pm2','SUtFW':_0x45b1ae(0xb9),'onPbj':_0x45b1ae(0xac)};console['log'](''),console[_0x45b1ae(0xa9)](_0x45b1ae(0x9b)),console['log'](_0x45b1ae(0x106)),console[_0x45b1ae(0xa9)]('');args['help']&&(printHelp(),process['exit'](0x0));args['version']&&(_0x4df60f['hHGnD'](printVersion),process['exit'](0x0));!args['project']&&(console['error'](_0x4df60f[_0x45b1ae(0xa1)]),console[_0x45b1ae(0xa9)](_0x45b1ae(0xcf)),process['exit'](0x1));!args[_0x45b1ae(0xf9)]&&(console[_0x45b1ae(0xa7)]('Error:\x20--config=<FILE.env>\x20is\x20required'),console['log'](_0x4df60f[_0x45b1ae(0xe4)]),process[_0x45b1ae(0x95)](0x1));const _0xcc9cb7=args['project']['toLowerCase'](),_0x33af35=process[_0x45b1ae(0x10b)](),_0x5175bc=args['output']?path['resolve'](_0x33af35,args['output']):path[_0x45b1ae(0xb3)](_0x33af35,_0x4df60f[_0x45b1ae(0xb1)]);console[_0x45b1ae(0xa9)]('Project:\x20'+_0xcc9cb7),console[_0x45b1ae(0xa9)](_0x45b1ae(0x9d)+args[_0x45b1ae(0xf9)]),console[_0x45b1ae(0xa9)](_0x45b1ae(0xed)+_0x5175bc),console['log']('');let _0x1db655=[];if(args[_0x45b1ae(0xa3)]){const _0x3f02a9=path[_0x45b1ae(0xbf)](_0x33af35,_0x4df60f['CyqpZ'],'consumers',_0xcc9cb7,args[_0x45b1ae(0xa3)],_0x45b1ae(0xd7));!fs['existsSync'](_0x3f02a9)&&(console['error'](_0x45b1ae(0xdd)+args[_0x45b1ae(0xa3)]),console['error']('Expected\x20at:\x20'+_0x3f02a9),process['exit'](0x1)),_0x1db655=[args[_0x45b1ae(0xa3)]],console['log'](_0x45b1ae(0xe7)+args[_0x45b1ae(0xa3)]+')');}else _0x1db655=_0x4df60f[_0x45b1ae(0x98)](scanConsumers,_0x33af35,_0xcc9cb7),_0x4df60f['tNrbe'](_0x1db655['length'],0x0)&&(console[_0x45b1ae(0xa7)]('Error:\x20No\x20consumers\x20found\x20in\x20project:\x20'+_0xcc9cb7),console[_0x45b1ae(0xa7)](_0x45b1ae(0x99)+_0xcc9cb7+'/'),process[_0x45b1ae(0x95)](0x1)),console[_0x45b1ae(0xa9)](_0x45b1ae(0x108)+_0x1db655['length']+'\x20found)');console[_0x45b1ae(0xa9)]('Consumers:\x20'+_0x1db655['join'](',\x20')),console['log']('');const _0x1668b0=path[_0x45b1ae(0xbf)](_0x5175bc,_0x4df60f[_0x45b1ae(0xb5)]),_0x1f6188=path['join'](_0x5175bc,_0x4df60f[_0x45b1ae(0xa6)]),_0x505b75=[];if(fs['existsSync'](_0x1668b0))_0x505b75['push'](_0x1668b0);if(fs[_0x45b1ae(0xe9)](_0x1f6188))_0x505b75['push'](_0x1f6188);if(_0x505b75['length']>0x0&&!args[_0x45b1ae(0xec)]){console['log'](_0x4df60f[_0x45b1ae(0xaa)]),_0x505b75['forEach'](_0x45a05e=>{const _0x318b10=_0x45b1ae;console[_0x318b10(0xa9)]('\x20\x20-\x20'+path['relative'](_0x33af35,_0x45a05e));}),console[_0x45b1ae(0xa9)](''),console[_0x45b1ae(0xa9)](_0x45b1ae(0x10a)),console['log'](_0x4df60f['wpzLG']),console['log'](_0x4df60f['CaNEu']),console[_0x45b1ae(0xa9)]('');const _0x31afa8=await prompt(_0x4df60f[_0x45b1ae(0xab)]);_0x31afa8!=='1'&&(console['log'](''),console['log'](_0x45b1ae(0xf0)),process[_0x45b1ae(0x95)](0x0)),console[_0x45b1ae(0xa9)]('');}!fs[_0x45b1ae(0xe9)](_0x5175bc)&&(fs['mkdirSync'](_0x5175bc,{'recursive':!![]}),console[_0x45b1ae(0xa9)]('Created\x20directory:\x20'+_0x5175bc));const _0x7ca91a=path['join'](_0x33af35,_0x4df60f[_0x45b1ae(0xad)],_0x4df60f['UzvOL']);!fs['existsSync'](_0x7ca91a)&&(fs['mkdirSync'](_0x7ca91a,{'recursive':!![]}),console['log']('Created\x20directory:\x20'+_0x7ca91a));const _0x210fb2={'projectName':_0xcc9cb7,'consumers':_0x1db655,'configFile':args['config'],'license':args['license'],'port':args['port'],'projectDir':_0x33af35};console['log'](''),console['log'](_0x4df60f['xNRRa']);const _0x53994f=generateEcosystemConfig(_0x210fb2);fs[_0x45b1ae(0x96)](_0x1668b0,_0x53994f),console[_0x45b1ae(0xa9)](_0x45b1ae(0xfe)+path['relative'](_0x33af35,_0x1668b0)),console['log'](''),console['log'](_0x45b1ae(0xee));const _0x352569=_0x4df60f['utpCk'](generateShellScript,_0x210fb2);fs[_0x45b1ae(0x96)](_0x1f6188,_0x352569);try{fs[_0x45b1ae(0xf4)](_0x1f6188,_0x4df60f[_0x45b1ae(0xea)]);}catch(_0x3e30f5){}console[_0x45b1ae(0xa9)]('\x20\x20Created:\x20'+path['relative'](_0x33af35,_0x1f6188)),console[_0x45b1ae(0xa9)](''),console[_0x45b1ae(0xa9)](_0x4df60f['jOHgj']),console['log'](_0x4df60f[_0x45b1ae(0xa8)]),console[_0x45b1ae(0xa9)]('=========================================='),console['log'](''),console['log'](_0x4df60f[_0x45b1ae(0x102)]),console['log'](_0x45b1ae(0xaf)+path[_0x45b1ae(0x100)](_0x33af35,_0x1668b0)),console['log']('\x20\x20-\x20'+path['relative'](_0x33af35,_0x1f6188)),console['log'](''),console['log'](_0x4df60f['unECl']),console['log'](''),console[_0x45b1ae(0xa9)](_0x4df60f[_0x45b1ae(0xcc)]),console['log'](''),console['log'](_0x45b1ae(0xc2)),console[_0x45b1ae(0xa9)](_0x4df60f['VLIRz']),console['log'](''),console[_0x45b1ae(0xa9)]('\x20\x203.\x20Start\x20consumers\x20with\x20PM2:'),console['log'](_0x45b1ae(0xd3)+path['relative'](_0x33af35,_0x5175bc)),console['log']('\x20\x20\x20\x20\x20pm2\x20start\x20ecosystem.config.js'),console['log'](''),console[_0x45b1ae(0xa9)](_0x4df60f[_0x45b1ae(0xfa)]),console['log']('\x20\x20\x20\x20\x20./consumer-manager.sh'),console[_0x45b1ae(0xa9)](''),console['log'](_0x45b1ae(0xd6)),console[_0x45b1ae(0xa9)]('\x20\x20\x20\x20\x20pm2\x20startup'),console['log'](_0x4df60f[_0x45b1ae(0xbd)]),console['log'](''),console['log'](_0x45b1ae(0xe2)),process['exit'](0x0);}main()['catch'](_0x41e838=>{const _0x4e4183=a0_0x593a30;console['error'](_0x4e4183(0xef)+_0x41e838['message']),process['exit'](0x1);});
3
+ const a0_0x5b8024=a0_0x3e94;(function(_0x40853e,_0x5cc545){const _0x37c7ae=a0_0x3e94,_0x38726a=_0x40853e();while(!![]){try{const _0x19fa76=parseInt(_0x37c7ae(0x149))/0x1*(-parseInt(_0x37c7ae(0x12a))/0x2)+-parseInt(_0x37c7ae(0x13a))/0x3+-parseInt(_0x37c7ae(0x13c))/0x4*(-parseInt(_0x37c7ae(0x15f))/0x5)+-parseInt(_0x37c7ae(0x161))/0x6+-parseInt(_0x37c7ae(0x11f))/0x7+-parseInt(_0x37c7ae(0x15c))/0x8+-parseInt(_0x37c7ae(0x178))/0x9*(-parseInt(_0x37c7ae(0x179))/0xa);if(_0x19fa76===_0x5cc545)break;else _0x38726a['push'](_0x38726a['shift']());}catch(_0x7118c0){_0x38726a['push'](_0x38726a['shift']());}}}(a0_0x1ef9,0xf0658));const path=require('path'),fs=require('fs'),readline=require('readline');require('dotenv')['config']();function a0_0x3e94(_0x13bf08,_0x5c2fa3){_0x13bf08=_0x13bf08-0x11f;const _0x1ef943=a0_0x1ef9();let _0x3e9416=_0x1ef943[_0x13bf08];if(a0_0x3e94['TVDFbd']===undefined){var _0x330c1d=function(_0x2b008c){const _0x132776='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x2bf836='',_0x368142='';for(let _0x40529c=0x0,_0x540626,_0xa5458e,_0x5549fc=0x0;_0xa5458e=_0x2b008c['charAt'](_0x5549fc++);~_0xa5458e&&(_0x540626=_0x40529c%0x4?_0x540626*0x40+_0xa5458e:_0xa5458e,_0x40529c++%0x4)?_0x2bf836+=String['fromCharCode'](0xff&_0x540626>>(-0x2*_0x40529c&0x6)):0x0){_0xa5458e=_0x132776['indexOf'](_0xa5458e);}for(let _0x478fa5=0x0,_0x1cbe81=_0x2bf836['length'];_0x478fa5<_0x1cbe81;_0x478fa5++){_0x368142+='%'+('00'+_0x2bf836['charCodeAt'](_0x478fa5)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x368142);};a0_0x3e94['bfmoOm']=_0x330c1d,a0_0x3e94['uGJlrq']={},a0_0x3e94['TVDFbd']=!![];}const _0x4234f1=_0x1ef943[0x0],_0x5d339c=_0x13bf08+_0x4234f1,_0x42dcef=a0_0x3e94['uGJlrq'][_0x5d339c];return!_0x42dcef?(_0x3e9416=a0_0x3e94['bfmoOm'](_0x3e9416),a0_0x3e94['uGJlrq'][_0x5d339c]=_0x3e9416):_0x3e9416=_0x42dcef,_0x3e9416;}function prompt(_0x128b22){const _0x1abc5f=a0_0x3e94,_0x414a4c=readline[_0x1abc5f(0x165)]({'input':process['stdin'],'output':process['stdout']});return new Promise(_0x269bc2=>{const _0x2a5c61=_0x1abc5f;_0x414a4c[_0x2a5c61(0x14e)](_0x128b22,_0x505669=>{const _0x32fd65=_0x2a5c61;_0x414a4c['close'](),_0x269bc2(_0x505669[_0x32fd65(0x18d)]());});});}const args=parseArgs(process['argv'][a0_0x5b8024(0x158)](0x2));function parseArgs(_0x42f842){const _0x5b5ceb=a0_0x5b8024,_0x22b958={'dBVhQ':_0x5b5ceb(0x12c),'ZzGrU':function(_0x469225,_0x3c92a5){return _0x469225===_0x3c92a5;},'gUaUy':function(_0x207680,_0x342c06){return _0x207680===_0x342c06;},'GsxEJ':_0x5b5ceb(0x19e),'nsjlf':'--module=','yQLJc':_0x5b5ceb(0x182),'iJFpH':_0x5b5ceb(0x15b),'dOofi':_0x5b5ceb(0x174),'nFsWo':function(_0xf5162b,_0x38fef9,_0x50d9a2){return _0xf5162b(_0x38fef9,_0x50d9a2);},'EnVkp':_0x5b5ceb(0x14b),'lOVOZ':function(_0x543db4,_0x164ae3){return _0x543db4===_0x164ae3;}},_0x3841a0={'project':null,'consumer':null,'config':null,'license':null,'port':0xbb9,'output':null,'force':![],'help':![],'version':![]};for(const _0x37036c of _0x42f842){if(_0x37036c===_0x22b958[_0x5b5ceb(0x193)]||_0x22b958[_0x5b5ceb(0x148)](_0x37036c,'-h'))_0x3841a0[_0x5b5ceb(0x13e)]=!![];else{if(_0x22b958[_0x5b5ceb(0x150)](_0x37036c,_0x22b958[_0x5b5ceb(0x187)])||_0x37036c==='-v')_0x3841a0[_0x5b5ceb(0x15e)]=!![];else{if(_0x37036c['startsWith'](_0x5b5ceb(0x189)))_0x3841a0['project']=_0x37036c['split']('=')[0x1];else{if(_0x37036c[_0x5b5ceb(0x180)](_0x22b958[_0x5b5ceb(0x126)]))_0x3841a0['project']=_0x37036c['split']('=')[0x1];else{if(_0x37036c[_0x5b5ceb(0x180)](_0x22b958[_0x5b5ceb(0x138)]))_0x3841a0[_0x5b5ceb(0x155)]=_0x37036c['split']('=')[0x1];else{if(_0x37036c['startsWith'](_0x22b958[_0x5b5ceb(0x14c)]))_0x3841a0[_0x5b5ceb(0x120)]=_0x37036c['split']('=')[0x1];else{if(_0x37036c['startsWith']('--license='))_0x3841a0[_0x5b5ceb(0x199)]=_0x37036c[_0x5b5ceb(0x17a)]('=')[0x1];else{if(_0x37036c['startsWith'](_0x22b958[_0x5b5ceb(0x130)]))_0x3841a0['port']=_0x22b958['nFsWo'](parseInt,_0x37036c[_0x5b5ceb(0x17a)]('=')[0x1],0xa)||0xbb9;else{if(_0x37036c['startsWith'](_0x22b958[_0x5b5ceb(0x12b)]))_0x3841a0[_0x5b5ceb(0x18a)]=_0x37036c[_0x5b5ceb(0x17a)]('=')[0x1];else(_0x37036c===_0x5b5ceb(0x16e)||_0x22b958['lOVOZ'](_0x37036c,'-f'))&&(_0x3841a0['force']=!![]);}}}}}}}}}return _0x3841a0;}function a0_0x1ef9(){const _0x1aa228=['Bg9N','t3b0Aw9UCZO','wNPhCLu','mta3DKTOv1bn','BgvUz3rO','ls1VDxrWDxq9','AuPgCeG','EwDqChq','CxvLC3rPB24','twDLAei','z1vHvxK','nZu1','C3rYAw5NAwz5','Cg9YDa','y2HTB2rtEw5J','y29UC3vTzxi','AM9PBG','CMvSyxrPDMu','C2XPy2u','sLLAugK','cN07cG','ls1JB25MAwC9','ntuYnZK2mfbUwNLXzW','ic0TCg9YDd0','DMvYC2LVBG','mJK4mtvQuNvnz0K','icaZlIbtDgfYDcbJB25ZDw1LCNmGD2L0Acbqtti6','mtm3mZK3mgznt25jza','Dg9ju09tDhjPBMC','rMf0ywWGzxjYB3i6ia','tw9KztOGu2LUz2XLignVBNn1BwvYicG','y3jLyxrLsw50zxjMywnL','pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09','q29UC3vTzxjZoIa','icbBmL0Gq2fUy2vS','BwTKAxjtEw5J','tMv4DcbZDgvWCYbMB3iGzgvWBg95BwvUDdO','igzVDw5Kkq','r2vUzxjHDgLUzYbLy29ZExn0zw0Uy29UzMLNlMPZlI4U','DwXLAhK','ls1MB3jJzq','q3jLyxrLzcbKAxjLy3rVCNK6ia','ntaWtq','D3jPDgvgAwXLu3LUyW','lw91Dc5SB2C','BwvZC2fNzq','ls1WB3j0pq','rMfUwu4','icbhzw5LCMf0Aw9UignVBxbSzxrLzcbZDwnJzxnZzNvSBhKH','ic0TBgLJzw5Zzt0','mte4ndK3ntfowLnuAgm','mZbUyMr1zuu','C3bSAxq','ic0Ty29UC3vTzxi9','Bhr6vg0','y29UC3vTzxjZ','cImJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiWOkiYbdB2XVCNmkuKvepsDCmdmZwZa7mZfTjWPhuKvftJ0NxdaZm1SWoZmYBsCkwuvmte9xpsDCmdmZwZe7mZnTjWPctfvfpsDCmdmZwZa7mZrTjWPdwufopsDCmdmZwZa7mZzTjWPoqZ0NxdaZm1SWBsCGiYboBYbdB2XVCGOkiYbqCM9Qzwn0igLUzM8kufjpsKvdvf9oqu1fpsi','ww91CIbJAg9Py2uGkdeVmIK6ia','C3rHCNrZv2L0Aa','y29UC3vTzxiTBwfUywDLCI5ZAa','ls1JB25ZDw1LCJ0','rxHWzwn0zwqGyxq6ia','icaTia','lwvYCM9YlMXVzW','zxHPDa','r3n4ruO','iGPfq09twvnuru1FrKLmrt0IzwnVC3LZDgvTlMnVBMzPzY5QCYikcImGr2v0ihnJCMLWDcbKAxjLy3rVCNKku0nssvbux0rjuJ0IjcGGy2qGiIqOigrPCM5HBwuGiIr7qKftsf9tt1vsq0vBmf19iIaPiIaMjIbWD2qGksiky2qGiIrtq1jjufrFreLsiGOkiYbdAgvJAYbPzIbqttiGAxmGAw5ZDgfSBgvKcMnOzwnRx3bTmIGPihSkicaGigLMiceGy29TBwfUzcaTDIbWBtiGjJ4Gl2rLDI9UDwXSoYb0AgvUcIaGicaGicaGzwnOBYaTzsaIjhTsrur9rxjYB3i6ifbnmIbPCYbUB3qGAw5ZDgfSBgvKlIr7tKn9iGOGicaGicaGigvJAg8GiKLUC3rHBgWGue0YihDPDgG6ig5WBsbPBNn0ywXSic1NihbTmIikicaGicaGicbLEgL0idekicaGigzPcN0kcImGuhjPBNqGAgvHzgvYcNbYAw50x2HLywrLCIGPihSkicaGignSzwfYcIaGicbLy2HVic1LiciKE0nzqu59pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt0KE05dFsikicaGigvJAg8GlwuGiIr7q1LbtN0Gifjfu1rgB3jNzsbdB25ZDw1LCIbnyw5Hz2vYjhToq30IcIaGicbLy2HVic1LiciKE0nzqu59pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt0KE05dFsikicaGigvJAg8GlwuGiIaGuhjVAMvJDdOGjhThuKvftN0KufjpsKvdvf9oqu1fjhToq30IcIaGicbLy2HVic1LiciGienVBNn1BwvYCZOGjhTzruXmt1D9','ls1WCM9Qzwn0pq','B3v0Chv0','ic0Ty29UzMLNpq','ChvZAa','DhjPBq','y29UC3vTzxiT','qKnLtNu','cLjfu1rgB3jNzsbdB25ZDw1LCIbezxbSB3KGq0XjcLzLCNnPB246ideUmc4WcKj1AwXKoIaYmdi2ltaXlteZcIaG','icbdCMvHDgvKoIa','twTdv1C','zejwAfe','BNb4','DujLt1a','wNrbwem','r2vUzxjHDgvKigzPBgvZoG','icaGicbWBtiGC2f2zq','BgLJzw5Zzq','vxnLic0TAgvSCcbMB3iGDxnHz2uGAw5MB3jTyxrPB24','sLPhwwm','ChjVAMvJDa','rxfTzxe','ls12zxjZAw9U','nZy0otKYmNLyvu9fqW','y29UzMLN','Aw5KzxGUANm','iGPbufbFtKfnrvm9iG','icbBmv0Gt3zLCNDYAxrLigv4Axn0Aw5NigzPBgvZ','tvbSAwi','pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09','BNnQBgy','icaGicbWBtiGC3rHCNr1Ca','AevVyLa','CMvZDgzVCMDLlwnVBNn1BwvYic0TChjVAMvJDd0','mZu1otrNBvDmBeK','rw5wA3a','ls1OzwXW','BMfTzq','ica1lIbtzxr1CcbHDxrVlxn0yxj0ig9UigjVB3q6','t3v0Chv0oIa','ze9VzMK','qwPitxm','lYOQcIaQifbnmIbfy29ZExn0zw0Gq29UzMLNDxjHDgLVBGOGkIbqCM9Qzwn0oIa','rxjYB3i6ic0TChjVAMvJDd08tKfnrt4GAxmGCMvXDwLYzwq','Cun4wxq','icaGicbWBtiGC3rHCNqGzwnVC3LZDgvTlMnVBMzPzY5QCW','C3jJ','lI9SB2DZl3bTmI8','EvfmsMm','icaYlIbjBNn0ywXSifbnmIbNBg9IywXSEsaOAwyGBM90igLUC3rHBgXLzcK6','mJyXodq0off6CNbKwq','icaXlIbdB3b5ihbYB2PLy3qGDg8GChjVzhvJDgLVBIbZzxj2zxi','mtiYnfzlCKjstq','r2vUzxjHDgLUzYbJB25ZDw1LCI1Tyw5Hz2vYlNnOlI4U','AgvSCa','icaGicbUCg0GAw5ZDgfSBcaTzYbWBti','DNPPrMO','zxjYB3i','Bg9NCW','cLjfu1rgB3jNzsbdB25ZDw1LCIbezxbSB3KGq0XjcJ09pt09pt09pt09pt09pt09pt09pt09pt09pt09cGPhzw5LCMf0zsbqttiGzwnVC3LZDgvTignVBMzPzYbHBMqGC2HLBgWGC2nYAxb0igzVCIbWCM9KDwn0Aw9UigrLCgXVEw1LBNqUcGPvC2fNztOkicbUChGGCMvZDgzVCMDLlwnVBNn1BwvYlwrLCgXVEsaTlxbYB2PLy3q9pfbst0Pfq1q+ic0Ty29UzMLNptXgsuXflMvUDJ4Gw29WDgLVBNnDcGPpChrPB25ZoGOGic0TChjVAMvJDd08tKfnrt4GicaGuhjVAMvJDcbUyw1LicHYzxf1AxjLzcKkicaTlw1VzhvSzt08tKfnrt4GicaGiefSAwfZigzVCIaTlxbYB2PLy3qkicaTlwnVBMzPzZ08rKLmrs5LBNy+ievUDMLYB25Tzw50ignVBMzPz3vYyxrPB24GzMLSzsaOCMvXDwLYzwqPcIaGls1JB25ZDw1LCJ08tKfnrt4GicbtCgvJAwzPyYbJB25ZDw1LCIaOB3b0Aw9UywWSigrLzMf1Bhq6igfSBcbJB25ZDw1LCNmPcIaGls1SAwnLBNnLptXlrvK+icaGicbmAwnLBNnLigTLEsaOB3b0Aw9UywWSignHBIbIzsbZzxqGAw4GlMvUDIKkicaTlxbVCNq9pfbpuLq+icaGicaGifbVCNqGzM9YienVBNrYB2WGqvbjicHKzwzHDwX0oIaZmdaXkqOGic0TB3v0Chv0ptXesvi+icaGicaGt3v0Chv0igrPCMvJDg9YEsaOzgvMyxvSDdOGlI9KzxbSB3KVkqOGic0TzM9Yy2uSic1MicaGicaGicaGt3zLCNDYAxrLigv4Axn0Aw5NigzPBgvZcIaGls1OzwXWlcaTAcaGicaGicaGicbtAg93ihrOAxmGAgvSCcbTzxnZywDLcIaGls12zxjZAw9UlcaTDIaGicaGicbtAg93ihzLCNnPB24kcKv4yw1WBgvZoGOGicmGr2vUzxjHDguGzM9YiefmtcbJB25ZDw1LCNmGAw4GysbWCM9Qzwn0cIaGBNb4ihjLC3rMB3jNzs1JB25ZDw1LCI1KzxbSB3KGls1WCM9Qzwn0pwrIEc1TAw5PlwLUDMvUDg9YEsaTlwnVBMzPzZ1TAw5PlwLUDMvUDg9YEs5LBNyGls1SAwnLBNnLpvHywfGTwfHywc1ywfHylvHywfGkcIaGiYbhzw5LCMf0zsbMB3iGysbZCgvJAwzPyYbJB25ZDw1LCIbVBMX5cIaGBNb4ihjLC3rMB3jNzs1JB25ZDw1LCI1KzxbSB3KGls1WCM9Qzwn0pwrIEc1TAw5PlwLUDMvUDg9YEsaTlwnVBMzPzZ1TAw5PlwLUDMvUDg9YEs5LBNyGls1JB25ZDw1LCJ1ZDxbWBgLLCI1JB25ZB2XLic0TBgLJzw5Zzt1ywfHylvHywfGTwfHywc1ywfHycGOGicmGt3v0Chv0ihrVigeGy3vZDg9TigzVBgrLCGOGig5WEcbYzxn0zM9Yz2uTy29UC3vTzxiTzgvWBg95ic0TChjVAMvJDd1KyNGTBwLUAs1PBNzLBNrVCNKGls1JB25MAwC9BwLUAs1PBNzLBNrVCNKUzw52ic0TB3v0Chv0ps4VChjVzhvJDgLVBI8kcK91Dhb1DcbgAwXLCZOkicbKzxbSB3KVcIaG4PsC4Psa4PsaigvJB3n5C3rLBs5JB25MAwCUANmGicaGiYbqttiGzwnVC3LZDgvTignVBMzPz3vYyxrPB24kicdILjtILidILiaGy29UC3vTzxiTBwfUywDLCI5ZAcaGicaJieLUDgvYywn0AxzLihnOzwXSihnJCMLWDcbMB3iGue0Yig1HBMfNzw1LBNqkica','sw10qLe','zxHPC3rZu3LUyW'];a0_0x1ef9=function(){return _0x1aa228;};return a0_0x1ef9();}function printHelp(){const _0xec0456=a0_0x5b8024;console['log'](_0xec0456(0x143));}function printVersion(){const _0x9685a2=a0_0x5b8024;console[_0x9685a2(0x146)](_0x9685a2(0x190));}function scanConsumers(_0x116bd5,_0x16d281){const _0x180cfd=a0_0x5b8024,_0xcd4a59={'ltzTm':_0x180cfd(0x136),'qCxYt':'consumers'},_0x4fd46f=path['join'](_0x116bd5,_0xcd4a59[_0x180cfd(0x17c)],_0xcd4a59[_0x180cfd(0x134)],_0x16d281);if(!fs['existsSync'](_0x4fd46f))return[];const _0x3a9b45=fs['readdirSync'](_0x4fd46f,{'withFileTypes':!![]}),_0x6ea223=[];for(const _0x23648c of _0x3a9b45){if(_0x23648c['isDirectory']()){const _0x26117c=path['join'](_0x4fd46f,_0x23648c[_0x180cfd(0x12d)],_0x180cfd(0x121));fs['existsSync'](_0x26117c)&&_0x6ea223['push'](_0x23648c[_0x180cfd(0x12d)]);}}return _0x6ea223;}function generateEcosystemConfig(_0x254c4e){const _0x59431e=a0_0x5b8024,_0x52f781={'hEobP':_0x59431e(0x170),'MgehB':'YYYY-MM-DD\x20HH:mm:ss\x20Z','ygPpt':_0x59431e(0x194),'ImtBQ':'production'},{projectName:_0x106a80,consumers:_0x36a54b,configFile:_0x234d08,license:_0x3a3be6,port:_0x229af2,projectDir:_0x21fca4}=_0x254c4e,_0x382f31=[];if(_0x36a54b[_0x59431e(0x14a)]===0x1){const _0xacfc2f=_0x36a54b[0x0];_0x382f31[_0x59431e(0x18c)]({'name':'consumer-'+_0x106a80+'-'+_0xacfc2f,'script':'npx','args':_0x59431e(0x129)+_0x106a80+_0x59431e(0x18b)+_0x234d08+'\x20--consumer='+_0xacfc2f+(_0x3a3be6?_0x59431e(0x177)+_0x3a3be6:'')+_0x59431e(0x15d)+_0x229af2,'cwd':_0x21fca4,'instances':0x1,'autorestart':!![],'watch':![],'maxMemoryRestart':_0x52f781[_0x59431e(0x128)],'env':{'NODE_ENV':'production'},'errorFile':_0x59431e(0x137)+_0xacfc2f+'-error.log','outFile':_0x59431e(0x137)+_0xacfc2f+_0x59431e(0x172),'logDateFormat':_0x52f781[_0x59431e(0x14f)]});}else{let _0x3bf328=_0x229af2;for(const _0x31dc10 of _0x36a54b){_0x382f31[_0x59431e(0x18c)]({'name':_0x59431e(0x18e)+_0x106a80+'-'+_0x31dc10,'script':_0x52f781[_0x59431e(0x14d)],'args':_0x59431e(0x129)+_0x106a80+_0x59431e(0x18b)+_0x234d08+_0x59431e(0x17b)+_0x31dc10+(_0x3a3be6?'\x20--license='+_0x3a3be6:'')+'\x20--port='+_0x3bf328,'cwd':_0x21fca4,'instances':0x1,'autorestart':!![],'watch':![],'maxMemoryRestart':'500M','env':{'NODE_ENV':_0x52f781[_0x59431e(0x144)]},'errorFile':'./logs/pm2/'+_0x31dc10+_0x59431e(0x185),'outFile':_0x59431e(0x137)+_0x31dc10+_0x59431e(0x172),'logDateFormat':_0x52f781['MgehB']}),_0x3bf328++;}}const _0x586a52=_0x59431e(0x132)+_0x106a80+'\x0a\x20*\x20Consumers:\x20'+_0x36a54b[_0x59431e(0x156)](',\x20')+'\x0a\x20*\x0a\x20*\x20Generated\x20by:\x20RESTForge\x20Consumer\x20Deploy\x20CLI\x0a\x20*\x20Generated\x20at:\x20'+new Date()[_0x59431e(0x162)]()+'\x0a\x20*\x0a\x20*\x20Usage:\x0a\x20*\x20\x20\x20pm2\x20start\x20ecosystem.config.js\x0a\x20*\x20\x20\x20pm2\x20stop\x20ecosystem.config.js\x0a\x20*\x20\x20\x20pm2\x20restart\x20ecosystem.config.js\x0a\x20*\x20\x20\x20pm2\x20delete\x20ecosystem.config.js\x0a\x20*/\x0a\x0amodule.exports\x20=\x20{\x0a\x20\x20apps:\x20'+JSON[_0x59431e(0x152)](_0x382f31,null,0x4)['replace'](/"(\w+)":/g,'$1:')+_0x59431e(0x15a);return _0x586a52;}function generateShellScript(_0x104d4e){const _0x239306=a0_0x5b8024,{projectName:_0x558361,consumers:_0x110272}=_0x104d4e,_0x9c0935=_0x110272['map'](_0x2d9ae7=>'consumer-'+_0x558361+'-'+_0x2d9ae7),_0x19c5c4=_0x9c0935['join']('\x20'),_0x1d98ab=_0x9c0935[0x0];return'#!/bin/bash\x0a\x0a#############################################\x0a#\x20RESTForge\x20Consumer\x20Manager\x0a#\x20Project:\x20'+_0x558361+'\x0a#\x20Consumers:\x20'+_0x110272[_0x239306(0x156)](',\x20')+'\x0a#\x0a#\x20Generated\x20by:\x20RESTForge\x20Consumer\x20Deploy\x20CLI\x0a#\x20Generated\x20at:\x20'+new Date()['toISOString']()+_0x239306(0x17e)+_0x558361+_0x239306(0x122)+_0x19c5c4+_0x239306(0x188)+_0x110272[_0x239306(0x14a)]+'${NC}\x22\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a}\x0a\x0a#\x20Show\x20status\x0ashow_status()\x20{\x0a\x20\x20\x20\x20echo\x20-e\x20\x22${BLUE}Current\x20Status:${NC}\x22\x0a\x20\x20\x20\x20echo\x20\x22--------------------------------------------\x22\x0a\x20\x20\x20\x20pm2\x20list\x20|\x20grep\x20-E\x20\x22('+_0x9c0935['join']('|')+'|Name|─)\x22\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a}\x0a\x0a#\x20Start\x20all\x20consumers\x0astart_all()\x20{\x0a\x20\x20\x20\x20echo\x20-e\x20\x22${GREEN}Starting\x20all\x20consumers...${NC}\x22\x0a\x20\x20\x20\x20pm2\x20start\x20$ECOSYSTEM_FILE\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20show_status\x0a}\x0a\x0a#\x20Stop\x20all\x20consumers\x0astop_all()\x20{\x0a\x20\x20\x20\x20echo\x20-e\x20\x22${YELLOW}Stopping\x20all\x20consumers...${NC}\x22\x0a\x20\x20\x20\x20for\x20app\x20in\x20$APP_NAMES;\x20do\x0a\x20\x20\x20\x20\x20\x20\x20\x20pm2\x20stop\x20$app\x202>/dev/null\x0a\x20\x20\x20\x20done\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20show_status\x0a}\x0a\x0a#\x20Restart\x20all\x20consumers\x0arestart_all()\x20{\x0a\x20\x20\x20\x20echo\x20-e\x20\x22${YELLOW}Restarting\x20all\x20consumers...${NC}\x22\x0a\x20\x20\x20\x20for\x20app\x20in\x20$APP_NAMES;\x20do\x0a\x20\x20\x20\x20\x20\x20\x20\x20pm2\x20restart\x20$app\x202>/dev/null\x0a\x20\x20\x20\x20done\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20show_status\x0a}\x0a\x0a#\x20Delete\x20all\x20from\x20PM2\x0adelete_all()\x20{\x0a\x20\x20\x20\x20echo\x20-e\x20\x22${RED}Deleting\x20all\x20consumers\x20from\x20PM2...${NC}\x22\x0a\x20\x20\x20\x20for\x20app\x20in\x20$APP_NAMES;\x20do\x0a\x20\x20\x20\x20\x20\x20\x20\x20pm2\x20delete\x20$app\x202>/dev/null\x0a\x20\x20\x20\x20done\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20show_status\x0a}\x0a\x0a#\x20Show\x20logs\x0ashow_logs()\x20{\x0a\x20\x20\x20\x20echo\x20-e\x20\x22${BLUE}Select\x20consumer\x20to\x20view\x20logs:${NC}\x22\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20local\x20i=1\x0a\x20\x20\x20\x20for\x20app\x20in\x20$APP_NAMES;\x20do\x0a\x20\x20\x20\x20\x20\x20\x20\x20echo\x20\x22\x20\x20[$i]\x20$app\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20((i++))\x0a\x20\x20\x20\x20done\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[a]\x20All\x20consumers\x22\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[0]\x20Back\x20to\x20menu\x22\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20read\x20-p\x20\x22Your\x20choice:\x20\x22\x20choice\x0a\x0a\x20\x20\x20\x20if\x20[\x20\x22$choice\x22\x20==\x20\x220\x22\x20];\x20then\x0a\x20\x20\x20\x20\x20\x20\x20\x20return\x0a\x20\x20\x20\x20elif\x20[\x20\x22$choice\x22\x20==\x20\x22a\x22\x20]\x20||\x20[\x20\x22$choice\x22\x20==\x20\x22A\x22\x20];\x20then\x0a\x20\x20\x20\x20\x20\x20\x20\x20pm2\x20logs\x0a\x20\x20\x20\x20else\x0a\x20\x20\x20\x20\x20\x20\x20\x20local\x20apps_array=($APP_NAMES)\x0a\x20\x20\x20\x20\x20\x20\x20\x20local\x20idx=$((choice\x20-\x201))\x0a\x20\x20\x20\x20\x20\x20\x20\x20if\x20[\x20$idx\x20-ge\x200\x20]\x20&&\x20[\x20$idx\x20-lt\x20${#apps_array[@]}\x20];\x20then\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20pm2\x20logs\x20${apps_array[$idx]}\x0a\x20\x20\x20\x20\x20\x20\x20\x20else\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20echo\x20-e\x20\x22${RED}Invalid\x20choice${NC}\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20fi\x0a\x20\x20\x20\x20fi\x0a}\x0a\x0a#\x20Monitor\x0ashow_monitor()\x20{\x0a\x20\x20\x20\x20pm2\x20monit\x0a}\x0a\x0a#\x20Setup\x20startup\x0asetup_startup()\x20{\x0a\x20\x20\x20\x20echo\x20-e\x20\x22${GREEN}Setting\x20up\x20PM2\x20startup...${NC}\x22\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20echo\x20\x22This\x20will\x20configure\x20PM2\x20to\x20start\x20automatically\x20on\x20system\x20boot.\x22\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20read\x20-p\x20\x22Continue?\x20(y/n):\x20\x22\x20confirm\x0a\x0a\x20\x20\x20\x20if\x20[\x20\x22$confirm\x22\x20==\x20\x22y\x22\x20]\x20||\x20[\x20\x22$confirm\x22\x20==\x20\x22Y\x22\x20];\x20then\x0a\x20\x20\x20\x20\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20echo\x20-e\x20\x22${YELLOW}Step\x201:\x20Generate\x20startup\x20script${NC}\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20pm2\x20startup\x0a\x20\x20\x20\x20\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20echo\x20-e\x20\x22${YELLOW}Step\x202:\x20Save\x20current\x20process\x20list${NC}\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20pm2\x20save\x0a\x20\x20\x20\x20\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20echo\x20-e\x20\x22${GREEN}Startup\x20configuration\x20complete!${NC}\x22\x0a\x20\x20\x20\x20fi\x0a}\x0a\x0a#\x20Reload\x20with\x20zero\x20downtime\x0areload_all()\x20{\x0a\x20\x20\x20\x20echo\x20-e\x20\x22${GREEN}Reloading\x20all\x20consumers\x20(zero\x20downtime)...${NC}\x22\x0a\x20\x20\x20\x20for\x20app\x20in\x20$APP_NAMES;\x20do\x0a\x20\x20\x20\x20\x20\x20\x20\x20pm2\x20reload\x20$app\x202>/dev/null\x0a\x20\x20\x20\x20done\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20show_status\x0a}\x0a\x0a#\x20Show\x20detailed\x20info\x0ashow_info()\x20{\x0a\x20\x20\x20\x20echo\x20-e\x20\x22${BLUE}Select\x20consumer\x20to\x20view\x20details:${NC}\x22\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20local\x20i=1\x0a\x20\x20\x20\x20for\x20app\x20in\x20$APP_NAMES;\x20do\x0a\x20\x20\x20\x20\x20\x20\x20\x20echo\x20\x22\x20\x20[$i]\x20$app\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20((i++))\x0a\x20\x20\x20\x20done\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[0]\x20Back\x20to\x20menu\x22\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20read\x20-p\x20\x22Your\x20choice:\x20\x22\x20choice\x0a\x0a\x20\x20\x20\x20if\x20[\x20\x22$choice\x22\x20==\x20\x220\x22\x20];\x20then\x0a\x20\x20\x20\x20\x20\x20\x20\x20return\x0a\x20\x20\x20\x20else\x0a\x20\x20\x20\x20\x20\x20\x20\x20local\x20apps_array=($APP_NAMES)\x0a\x20\x20\x20\x20\x20\x20\x20\x20local\x20idx=$((choice\x20-\x201))\x0a\x20\x20\x20\x20\x20\x20\x20\x20if\x20[\x20$idx\x20-ge\x200\x20]\x20&&\x20[\x20$idx\x20-lt\x20${#apps_array[@]}\x20];\x20then\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20pm2\x20show\x20${apps_array[$idx]}\x0a\x20\x20\x20\x20\x20\x20\x20\x20else\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20echo\x20-e\x20\x22${RED}Invalid\x20choice${NC}\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20fi\x0a\x20\x20\x20\x20fi\x0a\x20\x20\x20\x20read\x20-p\x20\x22Press\x20Enter\x20to\x20continue...\x22\x0a}\x0a\x0a#\x20Main\x20menu\x0ashow_menu()\x20{\x0a\x20\x20\x20\x20echo\x20-e\x20\x22${BLUE}Menu:${NC}\x22\x0a\x20\x20\x20\x20echo\x20\x22--------------------------------------------\x22\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[1]\x20Start\x20all\x20consumers\x22\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[2]\x20Stop\x20all\x20consumers\x22\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[3]\x20Restart\x20all\x20consumers\x22\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[4]\x20Reload\x20all\x20(zero\x20downtime)\x22\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[5]\x20Delete\x20all\x20from\x20PM2\x22\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[6]\x20View\x20logs\x22\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[7]\x20Monitor\x20(real-time)\x22\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[8]\x20Show\x20consumer\x20details\x22\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[9]\x20Setup\x20startup\x20(auto-start\x20on\x20boot)\x22\x0a\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[s]\x20Show\x20status\x22\x0a\x20\x20\x20\x20echo\x20\x22\x20\x20[q]\x20Quit\x22\x0a\x20\x20\x20\x20echo\x20\x22--------------------------------------------\x22\x0a}\x0a\x0a#\x20Main\x20loop\x0amain()\x20{\x0a\x20\x20\x20\x20check_pm2\x0a\x0a\x20\x20\x20\x20while\x20true;\x20do\x0a\x20\x20\x20\x20\x20\x20\x20\x20print_header\x0a\x20\x20\x20\x20\x20\x20\x20\x20show_status\x0a\x20\x20\x20\x20\x20\x20\x20\x20show_menu\x0a\x20\x20\x20\x20\x20\x20\x20\x20echo\x20\x22\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20read\x20-p\x20\x22Your\x20choice:\x20\x22\x20choice\x0a\x20\x20\x20\x20\x20\x20\x20\x20echo\x20\x22\x22\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20case\x20$choice\x20in\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x201)\x20start_all\x20;;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x202)\x20stop_all\x20;;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x203)\x20restart_all\x20;;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x204)\x20reload_all\x20;;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x205)\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20read\x20-p\x20\x22Are\x20you\x20sure\x20you\x20want\x20to\x20delete\x20all?\x20(y/n):\x20\x22\x20confirm\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20if\x20[\x20\x22$confirm\x22\x20==\x20\x22y\x22\x20]\x20||\x20[\x20\x22$confirm\x22\x20==\x20\x22Y\x22\x20];\x20then\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20delete_all\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20fi\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20;;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x206)\x20show_logs\x20;;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x207)\x20show_monitor\x20;;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x208)\x20show_info\x20;;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x209)\x20setup_startup\x20;;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20s|S)\x20show_status\x20;;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20q|Q)\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20echo\x20-e\x20\x22${GREEN}Goodbye!${NC}\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20exit\x200\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20;;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20*)\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20echo\x20-e\x20\x22${RED}Invalid\x20choice${NC}\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20;;\x0a\x20\x20\x20\x20\x20\x20\x20\x20esac\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20if\x20[\x20\x22$choice\x22\x20!=\x20\x227\x22\x20];\x20then\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20read\x20-p\x20\x22Press\x20Enter\x20to\x20continue...\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20fi\x0a\x20\x20\x20\x20done\x0a}\x0a\x0a#\x20Run\x20main\x0amain\x0a';}async function main(){const _0x2789df=a0_0x5b8024,_0x12d43f={'fWufG':_0x2789df(0x125),'FanYN':function(_0x1a160b){return _0x1a160b();},'JZGYc':_0x2789df(0x19a),'BCeNu':'deploy','yyctP':_0x2789df(0x17d),'AjHMs':_0x2789df(0x181),'ZtAXC':_0x2789df(0x147),'MkCWW':_0x2789df(0x123),'tnXjT':_0x2789df(0x168),'MPlib':_0x2789df(0x17f),'ulehy':'pm2','uBeOP':function(_0x4376b7,_0x596a23){return _0x4376b7(_0x596a23);},'PoISx':_0x2789df(0x151),'AGzsM':'==========================================','Eqmeq':_0x2789df(0x16a),'vziFj':_0x2789df(0x139),'DRMXG':_0x2789df(0x13f),'IOKmy':_0x2789df(0x160),'zlNGG':_0x2789df(0x135),'JYZPi':_0x2789df(0x12e),'wCicI':_0x2789df(0x198)};console[_0x2789df(0x146)](''),console['log']('RESTForge\x20Consumer\x20Deploy\x20Generator'),console['log'](_0x12d43f['fWufG']),console['log']('');args[_0x2789df(0x13e)]&&(_0x12d43f[_0x2789df(0x175)](printHelp),process[_0x2789df(0x186)](0x0));args[_0x2789df(0x15e)]&&(_0x12d43f[_0x2789df(0x175)](printVersion),process[_0x2789df(0x186)](0x0));!args[_0x2789df(0x19c)]&&(console[_0x2789df(0x141)](_0x2789df(0x133)),console['log'](_0x12d43f['JZGYc']),process['exit'](0x1));!args['config']&&(console['error']('Error:\x20--config=<FILE.env>\x20is\x20required'),console[_0x2789df(0x146)](_0x12d43f[_0x2789df(0x19b)]),process['exit'](0x1));const _0x4df9e9=args['project']['toLowerCase'](),_0x215e90=process['cwd'](),_0x4b056a=args[_0x2789df(0x18a)]?path['resolve'](_0x215e90,args[_0x2789df(0x18a)]):path['resolve'](_0x215e90,_0x12d43f[_0x2789df(0x18f)]);console[_0x2789df(0x146)]('Project:\x20'+_0x4df9e9),console[_0x2789df(0x146)]('Config:\x20'+args['config']),console[_0x2789df(0x146)](_0x2789df(0x12f)+_0x4b056a),console[_0x2789df(0x146)]('');let _0x111a9b=[];if(args[_0x2789df(0x155)]){const _0x10875b=path[_0x2789df(0x156)](_0x215e90,_0x2789df(0x136),_0x12d43f['yyctP'],_0x4df9e9,args[_0x2789df(0x155)],'index.js');!fs[_0x2789df(0x145)](_0x10875b)&&(console['error']('Error:\x20Consumer\x20not\x20found:\x20'+args[_0x2789df(0x155)]),console[_0x2789df(0x141)](_0x2789df(0x183)+_0x10875b),process[_0x2789df(0x186)](0x1)),_0x111a9b=[args['consumer']],console[_0x2789df(0x146)](_0x2789df(0x164)+args[_0x2789df(0x155)]+')');}else _0x111a9b=scanConsumers(_0x215e90,_0x4df9e9),_0x111a9b[_0x2789df(0x14a)]===0x0&&(console[_0x2789df(0x141)]('Error:\x20No\x20consumers\x20found\x20in\x20project:\x20'+_0x4df9e9),console['error']('Expected\x20at:\x20src/consumers/'+_0x4df9e9+'/'),process[_0x2789df(0x186)](0x1)),console['log']('Mode:\x20Multi\x20consumer\x20('+_0x111a9b[_0x2789df(0x14a)]+_0x2789df(0x16b));console[_0x2789df(0x146)](_0x2789df(0x167)+_0x111a9b[_0x2789df(0x156)](',\x20')),console[_0x2789df(0x146)]('');const _0x485c60=path['join'](_0x4b056a,'ecosystem.config.js'),_0x20fe7e=path[_0x2789df(0x156)](_0x4b056a,_0x12d43f[_0x2789df(0x131)]),_0x52b0df=[];if(fs[_0x2789df(0x145)](_0x485c60))_0x52b0df['push'](_0x485c60);if(fs['existsSync'](_0x20fe7e))_0x52b0df['push'](_0x20fe7e);if(_0x52b0df[_0x2789df(0x14a)]>0x0&&!args['force']){console[_0x2789df(0x146)]('WARNING:\x20The\x20following\x20files\x20already\x20exist:'),_0x52b0df['forEach'](_0x2f03e3=>{const _0x129a8f=_0x2789df;console['log'](_0x129a8f(0x184)+path['relative'](_0x215e90,_0x2f03e3));}),console[_0x2789df(0x146)](''),console[_0x2789df(0x146)](_0x12d43f[_0x2789df(0x196)]),console['log'](_0x12d43f[_0x2789df(0x192)]),console['log'](_0x12d43f['tnXjT']),console[_0x2789df(0x146)]('');const _0x3bc1f2=await prompt(_0x12d43f[_0x2789df(0x124)]);_0x3bc1f2!=='1'&&(console[_0x2789df(0x146)](''),console[_0x2789df(0x146)]('Generation\x20cancelled.'),process[_0x2789df(0x186)](0x0)),console[_0x2789df(0x146)]('');}!fs[_0x2789df(0x145)](_0x4b056a)&&(fs[_0x2789df(0x169)](_0x4b056a,{'recursive':!![]}),console['log'](_0x2789df(0x16f)+_0x4b056a));const _0x1851de=path['join'](_0x215e90,_0x2789df(0x142),_0x12d43f[_0x2789df(0x16d)]);!fs[_0x2789df(0x145)](_0x1851de)&&(fs['mkdirSync'](_0x1851de,{'recursive':!![]}),console['log']('Created\x20directory:\x20'+_0x1851de));const _0x4d9f2c={'projectName':_0x4df9e9,'consumers':_0x111a9b,'configFile':args['config'],'license':args['license'],'port':args[_0x2789df(0x153)],'projectDir':_0x215e90};console['log'](''),console['log'](_0x2789df(0x16c));const _0x32379a=_0x12d43f[_0x2789df(0x195)](generateEcosystemConfig,_0x4d9f2c);fs[_0x2789df(0x171)](_0x485c60,_0x32379a),console[_0x2789df(0x146)](_0x2789df(0x191)+path[_0x2789df(0x157)](_0x215e90,_0x485c60)),console[_0x2789df(0x146)](''),console[_0x2789df(0x146)](_0x2789df(0x13d));const _0x577dc1=generateShellScript(_0x4d9f2c);fs[_0x2789df(0x171)](_0x20fe7e,_0x577dc1);try{fs[_0x2789df(0x154)](_0x20fe7e,_0x12d43f['PoISx']);}catch(_0x12e3fd){}console[_0x2789df(0x146)]('\x20\x20Created:\x20'+path[_0x2789df(0x157)](_0x215e90,_0x20fe7e)),console['log'](''),console[_0x2789df(0x146)]('=========================================='),console[_0x2789df(0x146)](_0x2789df(0x176)),console[_0x2789df(0x146)](_0x12d43f['AGzsM']),console['log'](''),console['log'](_0x2789df(0x197)),console[_0x2789df(0x146)](_0x2789df(0x184)+path[_0x2789df(0x157)](_0x215e90,_0x485c60)),console['log'](_0x2789df(0x184)+path['relative'](_0x215e90,_0x20fe7e)),console['log'](''),console['log'](_0x12d43f[_0x2789df(0x19d)]),console[_0x2789df(0x146)](''),console['log'](_0x2789df(0x13b)),console[_0x2789df(0x146)](''),console['log'](_0x12d43f[_0x2789df(0x140)]),console[_0x2789df(0x146)](_0x12d43f['DRMXG']),console[_0x2789df(0x146)](''),console[_0x2789df(0x146)](_0x12d43f['IOKmy']),console[_0x2789df(0x146)]('\x20\x20\x20\x20\x20cd\x20'+path[_0x2789df(0x157)](_0x215e90,_0x4b056a)),console[_0x2789df(0x146)](_0x12d43f['zlNGG']),console['log'](''),console[_0x2789df(0x146)]('\x20\x204.\x20Or\x20use\x20interactive\x20manager:'),console['log']('\x20\x20\x20\x20\x20./consumer-manager.sh'),console[_0x2789df(0x146)](''),console[_0x2789df(0x146)](_0x12d43f[_0x2789df(0x159)]),console['log'](_0x2789df(0x127)),console[_0x2789df(0x146)](_0x12d43f['wCicI']),console['log'](''),console['log'](_0x2789df(0x166)),process['exit'](0x0);}main()['catch'](_0x1d1026=>{const _0x5734a4=a0_0x5b8024;console[_0x5734a4(0x141)](_0x5734a4(0x163)+_0x1d1026[_0x5734a4(0x173)]),process[_0x5734a4(0x186)](0x1);});