@restforgejs/platform 4.1.1 → 4.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (340) 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 +43 -4
  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 +526 -0
  18. package/generators/cli/schema/describe.js +3 -2
  19. package/generators/cli/schema/diff.js +322 -0
  20. package/generators/cli/schema/generate-ddl.js +7 -10
  21. package/generators/cli/schema/init.js +95 -172
  22. package/generators/cli/schema/introspect.js +3 -2
  23. package/generators/cli/schema/list.js +3 -2
  24. package/generators/cli/schema/migrate.js +13 -18
  25. package/generators/cli/schema/models.js +8 -12
  26. package/generators/cli/schema/template.js +222 -0
  27. package/generators/cli/schema/validate.js +8 -12
  28. package/generators/cli-entry.js +17 -2
  29. package/generators/lib/dbschema-kit/apply-engine.js +582 -0
  30. package/generators/lib/dbschema-kit/diff-engine.js +703 -0
  31. package/generators/lib/dbschema-kit/diff-reporter.js +272 -0
  32. package/generators/lib/dbschema-kit/emitters/alter-table.js +275 -0
  33. package/generators/lib/migration/audit-table-runner.js +213 -215
  34. package/generators/lib/payload/endpoint-schema-validator.js +171 -0
  35. package/generators/lib/payload/payload-runner.js +137 -220
  36. package/generators/lib/payload/schema-diff.js +277 -0
  37. package/generators/lib/templates/dashboard-catalog.js +1 -437
  38. package/generators/lib/templates/db-connection-env.js +1 -212
  39. package/generators/lib/templates/dbschema-catalog.js +1 -489
  40. package/generators/lib/templates/field-validation-catalog.js +1 -531
  41. package/generators/lib/templates/mysql-template.js +1 -3863
  42. package/generators/lib/templates/oracle-template.js +1 -3915
  43. package/generators/lib/templates/postgres-template.js +1 -5838
  44. package/generators/lib/templates/query-declarative-catalog.js +1 -199
  45. package/generators/lib/templates/sqlite-template.js +1 -3440
  46. package/generators/lib/utils/audit-columns.js +181 -0
  47. package/generators/lib/utils/cli-output.js +17 -0
  48. package/generators/lib/utils/database-introspector.js +16 -13
  49. package/generators/lib/utils/env-manager.js +6 -0
  50. package/generators/lib/utils/path-validator.js +71 -0
  51. package/generators/lib/validators/payload-validator.js +1 -2
  52. package/integrity-manifest.json +28 -10
  53. package/package.json +11 -3
  54. package/scripts/verify-integrity.js +1 -1
  55. package/server.js +1 -1
  56. package/src/components/handlers/adjust_handler.js +1 -1
  57. package/src/components/handlers/audit_handler.js +1 -1
  58. package/src/components/handlers/delete_handler.js +1 -1
  59. package/src/components/handlers/export_handler.js +1 -1
  60. package/src/components/handlers/import_handler.js +1 -1
  61. package/src/components/handlers/insert_handler.js +1 -1
  62. package/src/components/handlers/update_handler.js +1 -1
  63. package/src/components/handlers/upload_handler.js +1 -1
  64. package/src/components/handlers/workflow_handler.js +1 -1
  65. package/src/components/integrations/webhook.js +1 -1
  66. package/src/consumers/baseConsumer.js +1 -1
  67. package/src/consumers/declarativeMapper.js +1 -1
  68. package/src/consumers/handlers/apiHandler.js +1 -1
  69. package/src/consumers/handlers/consoleHandler.js +1 -1
  70. package/src/consumers/handlers/databaseHandler.js +1 -1
  71. package/src/consumers/handlers/index.js +1 -1
  72. package/src/consumers/handlers/kafkaHandler.js +1 -1
  73. package/src/consumers/index.js +1 -1
  74. package/src/consumers/messageTransformer.js +1 -1
  75. package/src/consumers/validator.js +1 -1
  76. package/src/core/db/dialect/base-dialect.js +1 -1
  77. package/src/core/db/dialect/index.js +1 -1
  78. package/src/core/db/dialect/mysql-dialect.js +1 -1
  79. package/src/core/db/dialect/oracle-dialect.js +1 -1
  80. package/src/core/db/dialect/postgres-dialect.js +1 -1
  81. package/src/core/db/dialect/sqlite-dialect.js +1 -1
  82. package/src/core/db/flatten-helper.js +1 -1
  83. package/src/core/db/query-builder-error.js +1 -1
  84. package/src/core/db/query-builder.js +1 -1
  85. package/src/core/db/relation-helper.js +1 -1
  86. package/src/core/handlers/delete_handler.js +1 -1
  87. package/src/core/handlers/insert_handler.js +1 -1
  88. package/src/core/handlers/update_handler.js +1 -1
  89. package/src/core/models/base-model.js +1 -1
  90. package/src/core/utils/cache-manager.js +1 -1
  91. package/src/core/utils/component-engine.js +1 -1
  92. package/src/core/utils/context-builder.js +1 -1
  93. package/src/core/utils/datetime-formatter.js +1 -1
  94. package/src/core/utils/datetime-parser.js +1 -1
  95. package/src/core/utils/db.js +1 -1
  96. package/src/core/utils/logger.js +1 -1
  97. package/src/core/utils/payload-loader.js +1 -1
  98. package/src/core/utils/security-checks.js +1 -1
  99. package/src/middleware/body-options.js +1 -1
  100. package/src/middleware/cors.js +1 -1
  101. package/src/middleware/idempotency.js +1 -1
  102. package/src/middleware/rate-limiter.js +1 -1
  103. package/src/middleware/request-logger.js +1 -1
  104. package/src/middleware/security-headers.js +1 -1
  105. package/src/models/base-model-mysql.js +1 -1
  106. package/src/models/base-model-oracle.js +1 -1
  107. package/src/models/base-model-sqlite.js +1 -1
  108. package/src/models/base-model.js +1 -1
  109. package/src/pro/caching/redis-client.js +1 -1
  110. package/src/pro/caching/redis-helper.js +1 -1
  111. package/src/pro/consumers/baseConsumer.js +1 -1
  112. package/src/pro/consumers/declarativeMapper.js +1 -1
  113. package/src/pro/consumers/handlers/apiHandler.js +1 -1
  114. package/src/pro/consumers/handlers/consoleHandler.js +1 -1
  115. package/src/pro/consumers/handlers/databaseHandler.js +1 -1
  116. package/src/pro/consumers/handlers/index.js +1 -1
  117. package/src/pro/consumers/handlers/kafkaHandler.js +1 -1
  118. package/src/pro/consumers/index.js +1 -1
  119. package/src/pro/consumers/messageTransformer.js +1 -1
  120. package/src/pro/consumers/validator.js +1 -1
  121. package/src/pro/database/base-model-mysql.js +1 -1
  122. package/src/pro/database/base-model-oracle.js +1 -1
  123. package/src/pro/database/base-model-sqlite.js +1 -1
  124. package/src/pro/database/db-mysql.js +1 -1
  125. package/src/pro/database/db-oracle.js +1 -1
  126. package/src/pro/database/db-sqlite.js +1 -1
  127. package/src/pro/excel/excel-generator.js +1 -1
  128. package/src/pro/excel/excel-parser.js +1 -1
  129. package/src/pro/excel/export-service.js +1 -1
  130. package/src/pro/excel/export_handler.js +1 -1
  131. package/src/pro/excel/import-service.js +1 -1
  132. package/src/pro/excel/import-validator.js +1 -1
  133. package/src/pro/excel/import_handler.js +1 -1
  134. package/src/pro/excel/upsert-builder.js +1 -1
  135. package/src/pro/idgen/idgen-routes.js +1 -1
  136. package/src/pro/integrations/lookup-resolver.js +1 -1
  137. package/src/pro/integrations/upload-handler-v2.js +1 -1
  138. package/src/pro/integrations/upload-handler.js +1 -1
  139. package/src/pro/integrations/webhook.js +1 -1
  140. package/src/pro/locking/lock-routes.js +1 -1
  141. package/src/pro/locking/resource-lock-manager.js +1 -1
  142. package/src/pro/messaging/kafkaConsumerService.js +1 -1
  143. package/src/pro/messaging/kafkaService.js +1 -1
  144. package/src/pro/messaging/messagehubService.js +1 -1
  145. package/src/pro/messaging/rabbitmqService.js +1 -1
  146. package/src/pro/scheduler/job-manager.js +1 -1
  147. package/src/pro/scheduler/job-routes.js +1 -1
  148. package/src/pro/scheduler/job-validator.js +1 -1
  149. package/src/pro/storage/base-storage-provider.js +1 -1
  150. package/src/pro/storage/file-metadata-helper.js +1 -1
  151. package/src/pro/storage/index.js +1 -1
  152. package/src/pro/storage/local-storage-provider.js +1 -1
  153. package/src/pro/storage/s3-storage-provider.js +1 -1
  154. package/src/pro/storage/upload-cleanup-job.js +1 -1
  155. package/src/pro/storage/upload-cleanup-scheduler.js +1 -1
  156. package/src/pro/storage/upload-pending-tracker.js +1 -1
  157. package/src/pro/websocket/broadcast-helper.js +1 -1
  158. package/src/pro/websocket/index.js +1 -1
  159. package/src/pro/websocket/livesync-server.js +1 -1
  160. package/src/pro/websocket/ws-broadcaster.js +1 -1
  161. package/src/services/export-service.js +1 -1
  162. package/src/services/import-service.js +1 -1
  163. package/src/services/kafkaConsumerService.js +1 -1
  164. package/src/services/kafkaService.js +1 -1
  165. package/src/services/messagehubService.js +1 -1
  166. package/src/services/rabbitmqService.js +1 -1
  167. package/src/utils/cache-invalidation-registry.js +1 -1
  168. package/src/utils/cache-manager.js +1 -1
  169. package/src/utils/component-engine.js +1 -1
  170. package/src/utils/config-extractor.js +1 -1
  171. package/src/utils/consumerLogger.js +1 -1
  172. package/src/utils/context-builder.js +1 -1
  173. package/src/utils/dashboard-helpers.js +1 -1
  174. package/src/utils/dateHelper.js +1 -1
  175. package/src/utils/datetime-formatter.js +1 -1
  176. package/src/utils/datetime-parser.js +1 -1
  177. package/src/utils/db-bootstrap.js +1 -1
  178. package/src/utils/db-mysql.js +1 -1
  179. package/src/utils/db-oracle.js +1 -1
  180. package/src/utils/db-sqlite.js +1 -1
  181. package/src/utils/db.js +1 -1
  182. package/src/utils/demo-generator.js +1 -1
  183. package/src/utils/excel-generator.js +1 -1
  184. package/src/utils/excel-parser.js +1 -1
  185. package/src/utils/file-watcher.js +1 -1
  186. package/src/utils/id-generator.js +1 -1
  187. package/src/utils/idempotency-manager.js +1 -1
  188. package/src/utils/import-validator.js +1 -1
  189. package/src/utils/license-client.js +1 -1
  190. package/src/utils/lock-manager.js +1 -1
  191. package/src/utils/logger.js +1 -1
  192. package/src/utils/lookup-resolver.js +1 -1
  193. package/src/utils/payload-loader.js +1 -1
  194. package/src/utils/processor-response.js +1 -1
  195. package/src/utils/rabbitmq.js +1 -1
  196. package/src/utils/redis-client.js +1 -1
  197. package/src/utils/redis-helper.js +1 -1
  198. package/src/utils/request-scope.js +1 -1
  199. package/src/utils/security-checks.js +1 -1
  200. package/src/utils/service-resolver.js +1 -1
  201. package/src/utils/shutdown-coordinator.js +1 -1
  202. package/src/utils/trusted-keys.js +1 -1
  203. package/src/utils/upload-handler.js +1 -1
  204. package/src/utils/upsert-builder.js +1 -1
  205. package/src/utils/workflow-hook-executor.js +1 -1
  206. package/generators/metadata/global.json +0 -58
  207. package/generators/metadata/test-mysql-workbench.json +0 -118
  208. package/generators/metadata/test-mysql.json +0 -56
  209. package/generators/metadata/test-oracle-workbench.json +0 -118
  210. package/generators/metadata/test-oracle.json +0 -56
  211. package/generators/metadata/test-pg-workbench.json +0 -118
  212. package/generators/metadata/test-pg.json +0 -56
  213. package/generators/scripts/obfuscate-source.js +0 -356
  214. package/generators/scripts/validate-catalog.js +0 -430
  215. package/generators/scripts/validate-dbschema-catalog.js +0 -708
  216. package/generators/tests/baseline/mysql/mini_inventory_item/src/models/mini-inventory/item.js +0 -944
  217. package/generators/tests/baseline/mysql/mini_inventory_item/src/modules/mini-inventory/item.js +0 -740
  218. package/generators/tests/baseline/mysql/mini_inventory_item/src/modules/mini-inventory.js +0 -336
  219. package/generators/tests/baseline/oracle/mini_inventory_item/src/models/mini-inventory/item.js +0 -1002
  220. package/generators/tests/baseline/oracle/mini_inventory_item/src/modules/mini-inventory/item.js +0 -740
  221. package/generators/tests/baseline/oracle/mini_inventory_item/src/modules/mini-inventory.js +0 -336
  222. package/generators/tests/baseline/postgres/mini_inventory_item/src/models/mini-inventory/item.js +0 -1333
  223. package/generators/tests/baseline/postgres/mini_inventory_item/src/modules/mini-inventory/item.js +0 -1173
  224. package/generators/tests/baseline/postgres/mini_inventory_item/src/modules/mini-inventory.js +0 -496
  225. package/generators/tests/fixtures/payloads/custom-sensitive.json +0 -27
  226. package/generators/tests/fixtures/payloads/dynamic-search-optout.json +0 -23
  227. package/generators/tests/fixtures/payloads/login-with-password.json +0 -22
  228. package/generators/tests/fixtures/payloads/order-process.json +0 -52
  229. package/generators/tests/fixtures/payloads/with-inline-sql.json +0 -26
  230. package/generators/tests/integration-tahap4b/README.md +0 -145
  231. package/generators/tests/integration-tahap4b/run-concurrent.js +0 -77
  232. package/generators/tests/integration-tahap4b/seed.sql +0 -53
  233. package/generators/tests/integration-tahap4b/verify.sql +0 -110
  234. package/generators/tests/unit/cli/create-dashboard.test.js +0 -505
  235. package/generators/tests/unit/cli/create-processor.test.js +0 -319
  236. package/generators/tests/unit/cli/dispatch-dashboard.test.js +0 -149
  237. package/generators/tests/unit/lib/dashboard-generator.test.js +0 -895
  238. package/generators/tests/unit/lib/dashboard-validator.test.js +0 -354
  239. package/generators/tests/unit/lib/dbschema-kit/apply-executor.test.js +0 -437
  240. package/generators/tests/unit/lib/dbschema-kit/cli/dbschema-introspect.test.js +0 -393
  241. package/generators/tests/unit/lib/dbschema-kit/cli/dbschema-kit-generate-ddl.test.js +0 -104
  242. package/generators/tests/unit/lib/dbschema-kit/cli/dbschema-kit-init.test.js +0 -119
  243. package/generators/tests/unit/lib/dbschema-kit/cli/dbschema-kit-list.test.js +0 -48
  244. package/generators/tests/unit/lib/dbschema-kit/cli/dbschema-kit-migrate.test.js +0 -175
  245. package/generators/tests/unit/lib/dbschema-kit/cli/dbschema-kit-validate.test.js +0 -102
  246. package/generators/tests/unit/lib/dbschema-kit/cli/dbschema-models.test.js +0 -43
  247. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/introspect-stubs/all-schemas-listing.js +0 -84
  248. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/introspect-stubs/connection-error.js +0 -13
  249. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/introspect-stubs/empty.js +0 -12
  250. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/introspect-stubs/multi-schema.js +0 -124
  251. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/introspect-stubs/single-schema-inventory.js +0 -64
  252. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/introspect-stubs/two-tables.js +0 -66
  253. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/migrate-stubs/connection-error.js +0 -9
  254. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/migrate-stubs/partial.js +0 -29
  255. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/migrate-stubs/rollback.js +0 -26
  256. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/migrate-stubs/success.js +0 -43
  257. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/multi-schema/audit/events.js +0 -18
  258. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/multi-schema/inventory/products.js +0 -9
  259. package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/multi-schema/users.js +0 -8
  260. package/generators/tests/unit/lib/dbschema-kit/connection.test.js +0 -112
  261. package/generators/tests/unit/lib/dbschema-kit/ddl-generator.test.js +0 -205
  262. package/generators/tests/unit/lib/dbschema-kit/define-model.test.js +0 -56
  263. package/generators/tests/unit/lib/dbschema-kit/dialect/index.test.js +0 -46
  264. package/generators/tests/unit/lib/dbschema-kit/dialect/mysql.test.js +0 -126
  265. package/generators/tests/unit/lib/dbschema-kit/dialect/oracle.test.js +0 -126
  266. package/generators/tests/unit/lib/dbschema-kit/dialect/postgres.test.js +0 -131
  267. package/generators/tests/unit/lib/dbschema-kit/dialect/sqlite.test.js +0 -126
  268. package/generators/tests/unit/lib/dbschema-kit/driver-loader.test.js +0 -93
  269. package/generators/tests/unit/lib/dbschema-kit/emitters/create-index.test.js +0 -173
  270. package/generators/tests/unit/lib/dbschema-kit/emitters/create-table.test.js +0 -376
  271. package/generators/tests/unit/lib/dbschema-kit/emitters/drop-table.test.js +0 -78
  272. package/generators/tests/unit/lib/dbschema-kit/fixtures/connection/invalid-dialect.env +0 -6
  273. package/generators/tests/unit/lib/dbschema-kit/fixtures/connection/missing-dialect.env +0 -5
  274. package/generators/tests/unit/lib/dbschema-kit/fixtures/connection/missing-host.env +0 -5
  275. package/generators/tests/unit/lib/dbschema-kit/fixtures/connection/oracle-valid.env +0 -6
  276. package/generators/tests/unit/lib/dbschema-kit/fixtures/connection/postgres-valid.env +0 -7
  277. package/generators/tests/unit/lib/dbschema-kit/fixtures/connection/sqlite-valid.env +0 -2
  278. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory/category.js +0 -11
  279. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory/item_product.js +0 -11
  280. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory/stock_inbound.js +0 -24
  281. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory/stock_inbound_item.js +0 -28
  282. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory/supplier.js +0 -9
  283. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory/warehouse.js +0 -9
  284. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory-invalid/orphan.js +0 -17
  285. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory-multifolder/master/category.js +0 -11
  286. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory-multifolder/master/item_product.js +0 -11
  287. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory-multifolder/master/supplier.js +0 -9
  288. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory-multifolder/master/warehouse.js +0 -9
  289. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory-multifolder/transactions/stock_inbound.js +0 -24
  290. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory-multifolder/transactions/stock_inbound_item.js +0 -28
  291. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/multi-schema/audit/events.js +0 -18
  292. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/multi-schema/inventory/products.js +0 -9
  293. package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/multi-schema/public/users.js +0 -9
  294. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/duplicate-subfolder/extra/category.js +0 -8
  295. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/duplicate-subfolder/master/category.js +0 -8
  296. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/duplicate-tablename/bar.js +0 -8
  297. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/duplicate-tablename/foo.js +0 -8
  298. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/empty-folder/README.md +0 -1
  299. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/invalid-export/plain.js +0 -3
  300. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/invalid-schema/bad.js +0 -6
  301. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/legacy-pattern/legacy.js +0 -12
  302. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/multi-schema-distinct/audit/products.js +0 -9
  303. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/multi-schema-distinct/inventory/products.js +0 -9
  304. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/multi-schema-duplicate/a/products.js +0 -8
  305. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/multi-schema-duplicate/b/products.js +0 -8
  306. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/nested-deep/a/b/c/deep_table.js +0 -8
  307. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/recursive-multi-folder/.hidden/ignored.js +0 -7
  308. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/recursive-multi-folder/master/category.js +0 -8
  309. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/recursive-multi-folder/master/supplier.js +0 -8
  310. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/recursive-multi-folder/transactions/stock_inbound.js +0 -8
  311. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/recursive-multi-folder/transactions/stock_inbound_item.js +0 -8
  312. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/valid-multiple/category.js +0 -8
  313. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/valid-multiple/item_product.js +0 -9
  314. package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/valid-single/category.js +0 -8
  315. package/generators/tests/unit/lib/dbschema-kit/integration.test.js +0 -217
  316. package/generators/tests/unit/lib/dbschema-kit/introspect-mapper.test.js +0 -403
  317. package/generators/tests/unit/lib/dbschema-kit/ir-builder.test.js +0 -390
  318. package/generators/tests/unit/lib/dbschema-kit/loader.test.js +0 -128
  319. package/generators/tests/unit/lib/dbschema-kit/naming.test.js +0 -170
  320. package/generators/tests/unit/lib/dbschema-kit/parser/shorthand-parser.test.js +0 -237
  321. package/generators/tests/unit/lib/dbschema-kit/schema-printer.test.js +0 -251
  322. package/generators/tests/unit/lib/dbschema-kit/statement-modifier.test.js +0 -105
  323. package/generators/tests/unit/lib/dbschema-kit/statement-splitter.test.js +0 -165
  324. package/generators/tests/unit/lib/dbschema-kit/topological-sort.test.js +0 -135
  325. package/generators/tests/unit/lib/dbschema-kit/validator/check-compatibility-validator.test.js +0 -373
  326. package/generators/tests/unit/lib/dbschema-kit/validator/circular-relation-validator.test.js +0 -454
  327. package/generators/tests/unit/lib/dbschema-kit/validator/cross-model-validator.test.js +0 -512
  328. package/generators/tests/unit/lib/dbschema-kit/validator/enhanced-validate-integration.test.js +0 -390
  329. package/generators/tests/unit/lib/dbschema-kit/validator/naming-convention-validator.test.js +0 -306
  330. package/generators/tests/unit/lib/dbschema-kit/validator/schema-validator.test.js +0 -443
  331. package/generators/tests/unit/lib/dbschema-kit/validator/type-compatibility-validator.test.js +0 -440
  332. package/generators/tests/unit/lib/dbschema-kit/validator/validator-reporter.test.js +0 -172
  333. package/generators/tests/unit/lib/metadata-manager-dashboard.test.js +0 -256
  334. package/generators/tests/unit/lib/payload-validator-fieldpolicy.test.js +0 -240
  335. package/generators/tests/unit/lib/processor-validation-generator.test.js +0 -300
  336. package/generators/tests/unit/lib/sensitive-field-masker.test.js +0 -170
  337. package/generators/tests/unit/lib/sql-table-extractor.test.js +0 -119
  338. package/scripts/generate-integrity-manifest.js +0 -124
  339. package/scripts/snapshot-cli-contracts.js +0 -194
  340. 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:
Binary file
package/build-info.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@restforgejs/platform",
3
- "version": "4.1.1",
4
- "buildDate": "2026-05-19T01:38:06.792Z",
3
+ "version": "4.3.1",
4
+ "buildDate": "2026-05-23T07:28:02.204Z",
5
5
  "dialects": [
6
6
  "postgresql",
7
7
  "mysql",
@@ -1,3 +1,3 @@
1
1
  #!/usr/bin/env node
2
2
 
3
- const a0_0x34c8f1=a0_0x5739;(function(_0x19d788,_0x5b3ec6){const _0x4e3dd5=a0_0x5739,_0x2b7f35=_0x19d788();while(!![]){try{const _0x331e4f=parseInt(_0x4e3dd5(0xf8))/0x1*(parseInt(_0x4e3dd5(0xf3))/0x2)+parseInt(_0x4e3dd5(0xe9))/0x3+parseInt(_0x4e3dd5(0xed))/0x4+parseInt(_0x4e3dd5(0xae))/0x5+parseInt(_0x4e3dd5(0xca))/0x6+parseInt(_0x4e3dd5(0xf0))/0x7+parseInt(_0x4e3dd5(0x106))/0x8*(-parseInt(_0x4e3dd5(0xb9))/0x9);if(_0x331e4f===_0x5b3ec6)break;else _0x2b7f35['push'](_0x2b7f35['shift']());}catch(_0x4bdb14){_0x2b7f35['push'](_0x2b7f35['shift']());}}}(a0_0x4dd8,0xb1ac2));const path=require(a0_0x34c8f1(0x100)),fs=require('fs'),readline=require('readline');function a0_0x4dd8(){const _0x2e2ded=['r2vUzxjHDgLVBIbJyw5JzwXSzwqU','iGPbufbFtKfnrvm9iG','lYOQcIaQifbnmIbfy29ZExn0zw0Gq29UzMLNDxjHDgLVBGOGkIbqCM9Qzwn0oIa','tu1guwy','cImJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiWOkiYbdB2XVCNmkuKvepsDCmdmZwZa7mZfTjWPhuKvftJ0NxdaZm1SWoZmYBsCkwuvmte9xpsDCmdmZwZe7mZnTjWPctfvfpsDCmdmZwZa7mZrTjWPdwufopsDCmdmZwZa7mZzTjWPoqZ0NxdaZm1SWBsCGiYboBYbdB2XVCGOkiYbqCM9Qzwn0igLUzM8kufjpsKvdvf9oqu1fpsi','mZKZotCXndrozKTKvu4','u1HxDMC','cLjfu1rgB3jNzsbdB25ZDw1LCIbezxbSB3KGq0XjcLzLCNnPB246ideUmc4WcKj1AwXKoIaYmdi2ltaXlteZcIaG','CMvHzgrPCLn5BMm','icbhzw5LCMf0Aw9UignVBxbSzxrLzcbZDwnJzxnZzNvSBhKH','CgjnDeu','Bg9N','C3bSAxq','ChjVzhvJDgLVBG','ic0TBgLJzw5Zzt0','r2vUzxjHDgLUzYbLy29ZExn0zw0Uy29UzMLNlMPZlI4U','q3jLyxrLzcbKAxjLy3rVCNK6ia','Cg0Y','q09Ksfe','zM9YrwfJAa','twzIrhe','nJuZntKXnvvxqMHRtG','ls1JB25ZDw1LCJ0','CxvLC3rPB24','pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09','BwvZC2fNzq','uhHtuuC','lw91Dc5SB2C','zxjYB3i','zxLHt1e','zgvWBg95','y3jLyxrLsw50zxjMywnL','owHkEKvXAG','ChvZAa','wMr1rva','ic0Ty29UC3vTzxi9','CMvSyxrPDMu','y2f0y2G','wuTrBMS','zxHPC3rZu3LUyW','vxnLic0TAgvSCcbMB3iGDxnHz2uGAw5MB3jTyxrPB24','CMvZDgzVCMDLlwnVBNn1BwvYic0TChjVAMvJDd0','AgvSCa','icbBmv0Gt3zLCNDYAxrLigv4Axn0Aw5NigzPBgvZ','ic0TCg9YDd0','r2vUzxjHDgvKigzPBgvZoG','y0THwM0','ls1MB3jJzq','D3jPDgvgAwXLu3LUyW','ndm2ndGWogzlC01IsG','uNDOwvC','icaGicbWBtiGC3rHCNqGzwnVC3LZDgvTlMnVBMzPzY5QCW','t2vyquO','Cg9YDa','uePVrM8','wvLzws1nts1ercbisdPTBtPZCYbA','lwvYCM9YlMXVzW','icbBmL0Gq2fUy2vS','ls1WCM9Qzwn0pq','zg90zw52','icaGicbJzca','ls1SAwnLBNnLpq','v0fstKLorZOGvgHLigzVBgXVD2LUzYbMAwXLCYbHBhjLywr5igv4Axn0oG','BgvUz3rO','rxjYB3i6ic0Ty29UzMLNptXgsuXflMvUDJ4GAxmGCMvXDwLYzwq','Dg9ju09tDhjPBMC','CuPhy0W','vwzxt2m','DhjPBq','y29UC3vTzxi','igzVDw5Kkq','ChjVAMvJDa','y3DK','Aw5KzxGUANm','C3rKB3v0','zNfrD0q','q29UC3vTzxjZoIa','AM9PBG','ls1JB25MAwC9','cImkiYbhzw5LCMf0zwqGyNK6ifjfu1rgB3jNzsbdB25ZDw1LCIbezxbSB3KGq0XjcImGr2vUzxjHDgvKigf0oIa','nde1mdy1mgj4zuDyuq','zxHPDa','C2XPy2u','ic0Ty29UzMLNpq','mJa5mdm2nfPHzuz3qG','C3rHCNrZv2L0Aa','y29UC3vTzxjZ','mZqXmty4mxHHt2TPuG','cIaQcIaQifvZywDLoGOGkIaGihbTmIbZDgfYDcbLy29ZExn0zw0Uy29UzMLNlMPZcIaQicaGCg0Yihn0B3aGzwnVC3LZDgvTlMnVBMzPzY5QCWOGkIaGihbTmIbYzxn0yxj0igvJB3n5C3rLBs5JB25MAwCUANmkicOGicbWBtiGzgvSzxrLigvJB3n5C3rLBs5JB25MAwCUANmkicOVcGPTB2r1BguUzxHWB3j0CYa9ihSkicbHChbZoIa','Buziuhe','nhn2sfvYyG','cIaQcIaQieDLBMvYyxrLzcbIEtOGuKvtvezVCMDLienVBNn1BwvYierLCgXVEsbdteKkicOGr2vUzxjHDgvKigf0oIa','rMf0ywWGzxjYB3i6ia','BwTKAxjtEw5J','CMvZB2X2zq','nJeYmta3BK1fre9z','pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09','B3v0Chv0','ls1TB2r1Bgu9','rxHWzwn0zwqGyxq6ia','twH1rNC','BNb4','y29UzMLN','Cgf0Aa'];a0_0x4dd8=function(){return _0x2e2ded;};return a0_0x4dd8();}require(a0_0x34c8f1(0xd4))['config']();function prompt(_0x4727f8){const _0x3a0cb5=a0_0x34c8f1,_0x5b1ebf=readline[_0x3a0cb5(0xb8)]({'input':process['stdin'],'output':process[_0x3a0cb5(0xe3)]});return new Promise(_0x528ce6=>{const _0xd5c933=_0x3a0cb5;_0x5b1ebf[_0xd5c933(0xb0)](_0x4727f8,_0x9e13a7=>{const _0x19d49a=_0xd5c933;_0x5b1ebf['close'](),_0x528ce6(_0x9e13a7[_0x19d49a(0xdd)]());});});}const args=parseArgs(process['argv'][a0_0x34c8f1(0xeb)](0x2));function parseArgs(_0x5553de){const _0x307b9a=a0_0x34c8f1,_0x40e0a5={'pwJeE':function(_0x58c3fc,_0x1b43ff){return _0x58c3fc===_0x1b43ff;},'mFHPq':'--version','ZduEP':_0x307b9a(0xd3),'Mecvb':_0x307b9a(0xfb),'PxSQG':_0x307b9a(0xaf),'lchxd':_0x307b9a(0xd6),'SlhoI':'--port='},_0x5015bc={'project':null,'consumer':null,'config':null,'license':null,'port':0xbb9,'output':null,'force':![],'help':![],'version':![]};for(const _0x86a98d of _0x5553de){if(_0x40e0a5['pwJeE'](_0x86a98d,'--help')||_0x40e0a5['pwJeE'](_0x86a98d,'-h'))_0x5015bc[_0x307b9a(0xc3)]=!![];else{if(_0x40e0a5['pwJeE'](_0x86a98d,_0x40e0a5[_0x307b9a(0xf2)])||_0x86a98d==='-v')_0x5015bc['version']=!![];else{if(_0x86a98d['startsWith'](_0x40e0a5[_0x307b9a(0xbb)]))_0x5015bc[_0x307b9a(0xe0)]=_0x86a98d['split']('=')[0x1];else{if(_0x86a98d[_0x307b9a(0xee)](_0x40e0a5['Mecvb']))_0x5015bc['project']=_0x86a98d[_0x307b9a(0x10d)]('=')[0x1];else{if(_0x86a98d['startsWith'](_0x40e0a5[_0x307b9a(0xb3)]))_0x5015bc[_0x307b9a(0xde)]=_0x86a98d[_0x307b9a(0x10d)]('=')[0x1];else{if(_0x86a98d['startsWith'](_0x307b9a(0xe7)))_0x5015bc['config']=_0x86a98d[_0x307b9a(0x10d)]('=')[0x1];else{if(_0x86a98d['startsWith'](_0x40e0a5['lchxd']))_0x5015bc['license']=_0x86a98d[_0x307b9a(0x10d)]('=')[0x1];else{if(_0x86a98d[_0x307b9a(0xee)](_0x40e0a5['SlhoI']))_0x5015bc['port']=parseInt(_0x86a98d[_0x307b9a(0x10d)]('=')[0x1],0xa)||0xbb9;else{if(_0x86a98d[_0x307b9a(0xee)]('--output='))_0x5015bc[_0x307b9a(0xfa)]=_0x86a98d[_0x307b9a(0x10d)]('=')[0x1];else(_0x86a98d===_0x307b9a(0xc8)||_0x40e0a5['pwJeE'](_0x86a98d,'-f'))&&(_0x5015bc['force']=!![]);}}}}}}}}}return _0x5015bc;}function printHelp(){console['log']('\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 _0x280346=a0_0x34c8f1;console[_0x280346(0x10c)](_0x280346(0x108));}function scanConsumers(_0x287211,_0x5d7ec2){const _0x1759ef=a0_0x34c8f1,_0x30d1a8={'MhuFw':_0x1759ef(0xe2)},_0x137ceb=path['join'](_0x287211,'src','consumers',_0x5d7ec2);if(!fs['existsSync'](_0x137ceb))return[];const _0x48ea25=fs[_0x1759ef(0x109)](_0x137ceb,{'withFileTypes':!![]}),_0xe5548d=[];for(const _0x427524 of _0x48ea25){if(_0x427524['isDirectory']()){const _0xcfe38=path['join'](_0x137ceb,_0x427524['name'],_0x30d1a8[_0x1759ef(0xfd)]);fs[_0x1759ef(0xc0)](_0xcfe38)&&_0xe5548d[_0x1759ef(0xba)](_0x427524['name']);}}return _0xe5548d;}function generateEcosystemConfig(_0x564c45){const _0x49797f=a0_0x34c8f1,_0x4bf727={'MMFQf':function(_0x38b60f,_0x15088e){return _0x38b60f===_0x15088e;},'vSQpJ':_0x49797f(0xfe),'fqQwD':_0x49797f(0x10e),'qJGcL':'$1:'},{projectName:_0x145398,consumers:_0x4557c0,configFile:_0x58c09d,license:_0x17750e,port:_0x2609cb,projectDir:_0xfaef99}=_0x564c45,_0x57c94d=[];if(_0x4bf727[_0x49797f(0x104)](_0x4557c0[_0x49797f(0xd8)],0x1)){const _0x110999=_0x4557c0[0x0];_0x57c94d['push']({'name':'consumer-'+_0x145398+'-'+_0x110999,'script':_0x4bf727['vSQpJ'],'args':'restforge-consumer\x20--project='+_0x145398+'\x20--config='+_0x58c09d+_0x49797f(0xbc)+_0x110999+(_0x17750e?_0x49797f(0x10f)+_0x17750e:'')+'\x20--port='+_0x2609cb,'cwd':_0xfaef99,'instances':0x1,'autorestart':!![],'watch':![],'maxMemoryRestart':'500M','env':{'NODE_ENV':_0x4bf727['fqQwD']},'errorFile':'./logs/pm2/'+_0x110999+_0x49797f(0xd1),'outFile':'./logs/pm2/'+_0x110999+_0x49797f(0xb4),'logDateFormat':'YYYY-MM-DD\x20HH:mm:ss\x20Z'});}else{let _0x5b5a11=_0x2609cb;for(const _0x1483b1 of _0x4557c0){_0x57c94d[_0x49797f(0xba)]({'name':'consumer-'+_0x145398+'-'+_0x1483b1,'script':'npx','args':_0x49797f(0xc2)+_0x145398+_0x49797f(0xec)+_0x58c09d+'\x20--consumer='+_0x1483b1+(_0x17750e?'\x20--license='+_0x17750e:'')+_0x49797f(0xc5)+_0x5b5a11,'cwd':_0xfaef99,'instances':0x1,'autorestart':!![],'watch':![],'maxMemoryRestart':'500M','env':{'NODE_ENV':_0x4bf727[_0x49797f(0xe4)]},'errorFile':'./logs/pm2/'+_0x1483b1+_0x49797f(0xd1),'outFile':'./logs/pm2/'+_0x1483b1+'-out.log','logDateFormat':_0x49797f(0xd0)}),_0x5b5a11++;}}const _0x27c1c2=_0x49797f(0x103)+_0x145398+'\x0a\x20*\x20Consumers:\x20'+_0x4557c0['join'](',\x20')+_0x49797f(0xf4)+new Date()[_0x49797f(0xda)]()+_0x49797f(0xf1)+JSON['stringify'](_0x57c94d,null,0x4)['replace'](/"(\w+)":/g,_0x4bf727[_0x49797f(0xdb)])+'\x0a};\x0a';return _0x27c1c2;}function generateShellScript(_0x4967b8){const _0x1ff871=a0_0x34c8f1,{projectName:_0x1600fc,consumers:_0x3dfa2b}=_0x4967b8,_0x2b0454=_0x3dfa2b['map'](_0x13e59b=>'consumer-'+_0x1600fc+'-'+_0x13e59b),_0x573502=_0x2b0454[_0x1ff871(0xe6)]('\x20'),_0x454618=_0x2b0454[0x0];return'#!/bin/bash\x0a\x0a#############################################\x0a#\x20RESTForge\x20Consumer\x20Manager\x0a#\x20Project:\x20'+_0x1600fc+'\x0a#\x20Consumers:\x20'+_0x3dfa2b['join'](',\x20')+_0x1ff871(0xe8)+new Date()['toISOString']()+_0x1ff871(0x105)+_0x1600fc+_0x1ff871(0x102)+_0x573502+'\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}'+_0x3dfa2b[_0x1ff871(0xd8)]+'${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('+_0x2b0454[_0x1ff871(0xe6)]('|')+'|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 _0x34eb64=a0_0x34c8f1,_0x365e42={'JdzcX':'RESTForge\x20Consumer\x20Deploy\x20Generator','wUmZe':function(_0x480ed3){return _0x480ed3();},'fEDDT':'Error:\x20--project=<NAME>\x20is\x20required','TLXZw':_0x34eb64(0xb7),'mSPGI':'src','PZAjY':'index.js','MfbDq':function(_0x116881,_0x24c4b2,_0x51ae98){return _0x116881(_0x24c4b2,_0x51ae98);},'ZwkhE':function(_0x584f83,_0x36856b){return _0x584f83===_0x36856b;},'FsBUn':'ecosystem.config.js','tQCkI':'consumer-manager.sh','SXWvg':function(_0x48649a,_0x3685f3){return _0x48649a>_0x3685f3;},'eyaOQ':'Options:','YKQnk':_0x34eb64(0xc4),'OeXAJ':'Your\x20choice\x20(1/2):\x20','BqQJA':_0x34eb64(0x101),'pbMtE':'logs','COdHQ':function(_0x593e46,_0x35f4ee){return _0x593e46(_0x35f4ee);},'RwhYW':'755','pwjzR':_0x34eb64(0xc6),'cKaZm':'Next\x20steps\x20for\x20deployment:','EUNKq':'\x20\x202.\x20Install\x20PM2\x20globally\x20(if\x20not\x20installed):','FBtly':'\x20\x20\x20\x20\x20npm\x20install\x20-g\x20pm2','UfWOc':_0x34eb64(0xcc),'PJoFo':'\x20\x204.\x20Or\x20use\x20interactive\x20manager:','NUGcZ':_0x34eb64(0xb1)};console['log'](''),console[_0x34eb64(0x10c)](_0x365e42['JdzcX']),console[_0x34eb64(0x10c)](_0x34eb64(0xf9)),console['log']('');args['help']&&(printHelp(),process[_0x34eb64(0xea)](0x0));args['version']&&(_0x365e42['wUmZe'](printVersion),process['exit'](0x0));!args[_0x34eb64(0xe0)]&&(console[_0x34eb64(0xb5)](_0x365e42['fEDDT']),console['log']('Use\x20--help\x20for\x20usage\x20information'),process['exit'](0x1));!args[_0x34eb64(0xff)]&&(console['error'](_0x34eb64(0xd9)),console[_0x34eb64(0x10c)](_0x34eb64(0xc1)),process[_0x34eb64(0xea)](0x1));const _0x3888a7=args['project']['toLowerCase'](),_0x3963f7=process[_0x34eb64(0xe1)](),_0x3cfdeb=args[_0x34eb64(0xfa)]?path[_0x34eb64(0xf7)](_0x3963f7,args[_0x34eb64(0xfa)]):path['resolve'](_0x3963f7,_0x365e42['TLXZw']);console[_0x34eb64(0x10c)]('Project:\x20'+_0x3888a7),console[_0x34eb64(0x10c)]('Config:\x20'+args[_0x34eb64(0xff)]),console['log']('Output:\x20'+_0x3cfdeb),console[_0x34eb64(0x10c)]('');let _0x584951=[];if(args['consumer']){const _0x1b616e=path['join'](_0x3963f7,_0x365e42['mSPGI'],_0x34eb64(0xef),_0x3888a7,args[_0x34eb64(0xde)],_0x365e42['PZAjY']);!fs[_0x34eb64(0xc0)](_0x1b616e)&&(console[_0x34eb64(0xb5)]('Error:\x20Consumer\x20not\x20found:\x20'+args[_0x34eb64(0xde)]),console['error'](_0x34eb64(0xfc)+_0x1b616e),process['exit'](0x1)),_0x584951=[args['consumer']],console[_0x34eb64(0x10c)]('Mode:\x20Single\x20consumer\x20('+args['consumer']+')');}else _0x584951=_0x365e42[_0x34eb64(0xad)](scanConsumers,_0x3963f7,_0x3888a7),_0x365e42['ZwkhE'](_0x584951['length'],0x0)&&(console['error']('Error:\x20No\x20consumers\x20found\x20in\x20project:\x20'+_0x3888a7),console[_0x34eb64(0xb5)]('Expected\x20at:\x20src/consumers/'+_0x3888a7+'/'),process[_0x34eb64(0xea)](0x1)),console[_0x34eb64(0x10c)]('Mode:\x20Multi\x20consumer\x20('+_0x584951['length']+_0x34eb64(0xdf));console[_0x34eb64(0x10c)](_0x34eb64(0xe5)+_0x584951[_0x34eb64(0xe6)](',\x20')),console[_0x34eb64(0x10c)]('');const _0x50b735=path[_0x34eb64(0xe6)](_0x3cfdeb,_0x365e42['FsBUn']),_0x49246a=path[_0x34eb64(0xe6)](_0x3cfdeb,_0x365e42['tQCkI']),_0x1b643e=[];if(fs[_0x34eb64(0xc0)](_0x50b735))_0x1b643e[_0x34eb64(0xba)](_0x50b735);if(fs[_0x34eb64(0xc0)](_0x49246a))_0x1b643e[_0x34eb64(0xba)](_0x49246a);if(_0x365e42[_0x34eb64(0x107)](_0x1b643e[_0x34eb64(0xd8)],0x0)&&!args['force']){console['log'](_0x34eb64(0xd7)),_0x1b643e[_0x34eb64(0x114)](_0x555c9a=>{const _0x18c600=_0x34eb64;console['log']('\x20\x20-\x20'+path[_0x18c600(0xbd)](_0x3963f7,_0x555c9a));}),console['log'](''),console['log'](_0x365e42[_0x34eb64(0xb6)]),console['log'](_0x365e42[_0x34eb64(0xbf)]),console[_0x34eb64(0x10c)](_0x34eb64(0xd2)),console['log']('');const _0x4fd1d7=await prompt(_0x365e42[_0x34eb64(0xcd)]);_0x4fd1d7!=='1'&&(console['log'](''),console[_0x34eb64(0x10c)](_0x365e42['BqQJA']),process['exit'](0x0)),console['log']('');}!fs['existsSync'](_0x3cfdeb)&&(fs['mkdirSync'](_0x3cfdeb,{'recursive':!![]}),console['log'](_0x34eb64(0x111)+_0x3cfdeb));const _0x39c574=path['join'](_0x3963f7,_0x365e42[_0x34eb64(0x10b)],_0x34eb64(0x112));!fs[_0x34eb64(0xc0)](_0x39c574)&&(fs[_0x34eb64(0xf6)](_0x39c574,{'recursive':!![]}),console[_0x34eb64(0x10c)](_0x34eb64(0x111)+_0x39c574));const _0x33f56b={'projectName':_0x3888a7,'consumers':_0x584951,'configFile':args['config'],'license':args['license'],'port':args[_0x34eb64(0xce)],'projectDir':_0x3963f7};console['log'](''),console[_0x34eb64(0x10c)](_0x34eb64(0x110));const _0x5b6071=_0x365e42[_0x34eb64(0x113)](generateEcosystemConfig,_0x33f56b);fs[_0x34eb64(0xc9)](_0x50b735,_0x5b6071),console[_0x34eb64(0x10c)]('\x20\x20Created:\x20'+path[_0x34eb64(0xbd)](_0x3963f7,_0x50b735)),console[_0x34eb64(0x10c)](''),console[_0x34eb64(0x10c)]('Generating\x20consumer-manager.sh...');const _0x48d203=_0x365e42['COdHQ'](generateShellScript,_0x33f56b);fs[_0x34eb64(0xc9)](_0x49246a,_0x48d203);try{fs['chmodSync'](_0x49246a,_0x365e42[_0x34eb64(0xcb)]);}catch(_0x1131be){}console['log']('\x20\x20Created:\x20'+path[_0x34eb64(0xbd)](_0x3963f7,_0x49246a)),console[_0x34eb64(0x10c)](''),console['log'](_0x34eb64(0xb1)),console['log'](_0x34eb64(0x10a)),console['log'](_0x34eb64(0xb1)),console['log'](''),console['log'](_0x365e42['pwjzR']),console[_0x34eb64(0x10c)]('\x20\x20-\x20'+path['relative'](_0x3963f7,_0x50b735)),console[_0x34eb64(0x10c)]('\x20\x20-\x20'+path[_0x34eb64(0xbd)](_0x3963f7,_0x49246a)),console[_0x34eb64(0x10c)](''),console['log'](_0x365e42[_0x34eb64(0xc7)]),console['log'](''),console['log']('\x20\x201.\x20Copy\x20project\x20to\x20production\x20server'),console['log'](''),console[_0x34eb64(0x10c)](_0x365e42['EUNKq']),console['log'](_0x365e42['FBtly']),console['log'](''),console[_0x34eb64(0x10c)]('\x20\x203.\x20Start\x20consumers\x20with\x20PM2:'),console['log'](_0x34eb64(0xd5)+path['relative'](_0x3963f7,_0x3cfdeb)),console[_0x34eb64(0x10c)](_0x365e42[_0x34eb64(0xdc)]),console[_0x34eb64(0x10c)](''),console[_0x34eb64(0x10c)](_0x365e42[_0x34eb64(0xcf)]),console[_0x34eb64(0x10c)]('\x20\x20\x20\x20\x20./consumer-manager.sh'),console['log'](''),console['log']('\x20\x205.\x20Setup\x20auto-start\x20on\x20boot:'),console['log']('\x20\x20\x20\x20\x20pm2\x20startup'),console[_0x34eb64(0x10c)]('\x20\x20\x20\x20\x20pm2\x20save'),console[_0x34eb64(0x10c)](''),console['log'](_0x365e42['NUGcZ']),process[_0x34eb64(0xea)](0x0);}function a0_0x5739(_0x9fdd63,_0x3e664d){_0x9fdd63=_0x9fdd63-0xad;const _0x4dd8e2=a0_0x4dd8();let _0x57392f=_0x4dd8e2[_0x9fdd63];if(a0_0x5739['yLFNhD']===undefined){var _0x2cb37e=function(_0x188205){const _0x4b7c54='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x1b0911='',_0x57efea='';for(let _0x5c895d=0x0,_0x20091d,_0x384194,_0x22bd17=0x0;_0x384194=_0x188205['charAt'](_0x22bd17++);~_0x384194&&(_0x20091d=_0x5c895d%0x4?_0x20091d*0x40+_0x384194:_0x384194,_0x5c895d++%0x4)?_0x1b0911+=String['fromCharCode'](0xff&_0x20091d>>(-0x2*_0x5c895d&0x6)):0x0){_0x384194=_0x4b7c54['indexOf'](_0x384194);}for(let _0x5cc067=0x0,_0x4625a3=_0x1b0911['length'];_0x5cc067<_0x4625a3;_0x5cc067++){_0x57efea+='%'+('00'+_0x1b0911['charCodeAt'](_0x5cc067)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x57efea);};a0_0x5739['FFCSmx']=_0x2cb37e,a0_0x5739['ioOtiM']={},a0_0x5739['yLFNhD']=!![];}const _0x2a5786=_0x4dd8e2[0x0],_0x18a949=_0x9fdd63+_0x2a5786,_0x337a0c=a0_0x5739['ioOtiM'][_0x18a949];return!_0x337a0c?(_0x57392f=a0_0x5739['FFCSmx'](_0x57392f),a0_0x5739['ioOtiM'][_0x18a949]=_0x57392f):_0x57392f=_0x337a0c,_0x57392f;}main()[a0_0x34c8f1(0xbe)](_0x4638d1=>{const _0x5e5ef7=a0_0x34c8f1;console[_0x5e5ef7(0xb5)](_0x5e5ef7(0xf5)+_0x4638d1[_0x5e5ef7(0xb2)]),process[_0x5e5ef7(0xea)](0x1);});
3
+ const a0_0x57c3ca=a0_0x1db5;(function(_0x590899,_0x50827c){const _0x5afc65=a0_0x1db5,_0x2294cf=_0x590899();while(!![]){try{const _0x2e64e4=parseInt(_0x5afc65(0x159))/0x1*(parseInt(_0x5afc65(0x16a))/0x2)+-parseInt(_0x5afc65(0x162))/0x3+-parseInt(_0x5afc65(0x160))/0x4+parseInt(_0x5afc65(0x11b))/0x5+-parseInt(_0x5afc65(0x12d))/0x6+parseInt(_0x5afc65(0x138))/0x7+-parseInt(_0x5afc65(0x10a))/0x8*(-parseInt(_0x5afc65(0x153))/0x9);if(_0x2e64e4===_0x50827c)break;else _0x2294cf['push'](_0x2294cf['shift']());}catch(_0x55125f){_0x2294cf['push'](_0x2294cf['shift']());}}}(a0_0x2c5c,0x21385));const path=require(a0_0x57c3ca(0x15f)),fs=require('fs'),readline=require(a0_0x57c3ca(0x12b));require('dotenv')[a0_0x57c3ca(0x113)]();function prompt(_0x3ca9aa){const _0x4aadc8=readline['createInterface']({'input':process['stdin'],'output':process['stdout']});return new Promise(_0x99fb6b=>{_0x4aadc8['question'](_0x3ca9aa,_0x297f7d=>{const _0x16e550=a0_0x1db5;_0x4aadc8['close'](),_0x99fb6b(_0x297f7d[_0x16e550(0x124)]());});});}const args=parseArgs(process[a0_0x57c3ca(0x142)]['slice'](0x2));function parseArgs(_0x3152cd){const _0x49daef=a0_0x57c3ca,_0x58c945={'fspnQ':function(_0x4f1e77,_0x5c2c1e){return _0x4f1e77===_0x5c2c1e;},'quBMX':'--version','cJTYp':_0x49daef(0x151),'TElKf':'--config=','LJTui':'--output='},_0xa1a884={'project':null,'consumer':null,'config':null,'license':null,'port':0xbb9,'output':null,'force':![],'help':![],'version':![]};for(const _0x27c482 of _0x3152cd){if(_0x58c945['fspnQ'](_0x27c482,_0x49daef(0x163))||_0x58c945[_0x49daef(0x13c)](_0x27c482,'-h'))_0xa1a884['help']=!![];else{if(_0x27c482===_0x58c945[_0x49daef(0x126)]||_0x58c945['fspnQ'](_0x27c482,'-v'))_0xa1a884[_0x49daef(0x129)]=!![];else{if(_0x27c482['startsWith']('--project='))_0xa1a884[_0x49daef(0x121)]=_0x27c482[_0x49daef(0x12c)]('=')[0x1];else{if(_0x27c482[_0x49daef(0x14a)](_0x49daef(0x156)))_0xa1a884[_0x49daef(0x121)]=_0x27c482['split']('=')[0x1];else{if(_0x27c482[_0x49daef(0x14a)](_0x58c945['cJTYp']))_0xa1a884[_0x49daef(0x10e)]=_0x27c482['split']('=')[0x1];else{if(_0x27c482[_0x49daef(0x14a)](_0x58c945['TElKf']))_0xa1a884[_0x49daef(0x113)]=_0x27c482['split']('=')[0x1];else{if(_0x27c482[_0x49daef(0x14a)]('--license='))_0xa1a884[_0x49daef(0x115)]=_0x27c482[_0x49daef(0x12c)]('=')[0x1];else{if(_0x27c482[_0x49daef(0x14a)](_0x49daef(0x116)))_0xa1a884[_0x49daef(0x15e)]=parseInt(_0x27c482['split']('=')[0x1],0xa)||0xbb9;else{if(_0x27c482['startsWith'](_0x58c945[_0x49daef(0x147)]))_0xa1a884[_0x49daef(0x11c)]=_0x27c482[_0x49daef(0x12c)]('=')[0x1];else(_0x27c482===_0x49daef(0x130)||_0x58c945[_0x49daef(0x13c)](_0x27c482,'-f'))&&(_0xa1a884[_0x49daef(0x157)]=!![]);}}}}}}}}}return _0xa1a884;}function printHelp(){console['log']('\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(){console['log']('\x0aRESTForge\x20Consumer\x20Deploy\x20CLI\x0aVersion:\x201.0.0\x0aBuild:\x202026-01-13\x0a\x20\x20');}function scanConsumers(_0x436e73,_0x290122){const _0x58f52e=a0_0x57c3ca,_0x99cfa2={'ieGIV':'src','yloEm':'index.js'},_0x5c1482=path['join'](_0x436e73,_0x99cfa2['ieGIV'],'consumers',_0x290122);if(!fs[_0x58f52e(0x11e)](_0x5c1482))return[];const _0x389b19=fs[_0x58f52e(0x13b)](_0x5c1482,{'withFileTypes':!![]}),_0xef9264=[];for(const _0x325b4f of _0x389b19){if(_0x325b4f[_0x58f52e(0x12a)]()){const _0x277761=path['join'](_0x5c1482,_0x325b4f['name'],_0x99cfa2[_0x58f52e(0x14e)]);fs[_0x58f52e(0x11e)](_0x277761)&&_0xef9264['push'](_0x325b4f['name']);}}return _0xef9264;}function generateEcosystemConfig(_0x3d995c){const _0x4376ff=a0_0x57c3ca,_0x33ef9c={'HeLZi':function(_0x1b89a0,_0x58e239){return _0x1b89a0===_0x58e239;},'LptyB':_0x4376ff(0x10d),'uDlIJ':'500M','iewCj':_0x4376ff(0x11d)},{projectName:_0x2c0d4f,consumers:_0x52c8c0,configFile:_0x2b9b83,license:_0x163da7,port:_0x26f371,projectDir:_0x17663d}=_0x3d995c,_0x2debc6=[];if(_0x33ef9c[_0x4376ff(0x131)](_0x52c8c0['length'],0x1)){const _0x22a5e4=_0x52c8c0[0x0];_0x2debc6[_0x4376ff(0x123)]({'name':_0x4376ff(0x133)+_0x2c0d4f+'-'+_0x22a5e4,'script':_0x33ef9c['LptyB'],'args':_0x4376ff(0x132)+_0x2c0d4f+_0x4376ff(0x120)+_0x2b9b83+'\x20--consumer='+_0x22a5e4+(_0x163da7?_0x4376ff(0x16c)+_0x163da7:'')+_0x4376ff(0x166)+_0x26f371,'cwd':_0x17663d,'instances':0x1,'autorestart':!![],'watch':![],'maxMemoryRestart':_0x33ef9c['uDlIJ'],'env':{'NODE_ENV':_0x4376ff(0x10f)},'errorFile':_0x4376ff(0x10c)+_0x22a5e4+_0x4376ff(0x118),'outFile':_0x4376ff(0x10c)+_0x22a5e4+'-out.log','logDateFormat':_0x33ef9c['iewCj']});}else{let _0x20110b=_0x26f371;for(const _0x536017 of _0x52c8c0){_0x2debc6[_0x4376ff(0x123)]({'name':'consumer-'+_0x2c0d4f+'-'+_0x536017,'script':_0x33ef9c[_0x4376ff(0x141)],'args':_0x4376ff(0x132)+_0x2c0d4f+_0x4376ff(0x120)+_0x2b9b83+'\x20--consumer='+_0x536017+(_0x163da7?'\x20--license='+_0x163da7:'')+_0x4376ff(0x166)+_0x20110b,'cwd':_0x17663d,'instances':0x1,'autorestart':!![],'watch':![],'maxMemoryRestart':'500M','env':{'NODE_ENV':'production'},'errorFile':_0x4376ff(0x10c)+_0x536017+_0x4376ff(0x118),'outFile':_0x4376ff(0x10c)+_0x536017+'-out.log','logDateFormat':_0x33ef9c['iewCj']}),_0x20110b++;}}const _0x5684cb='/**\x0a\x20*\x20PM2\x20Ecosystem\x20Configuration\x0a\x20*\x20Project:\x20'+_0x2c0d4f+_0x4376ff(0x114)+_0x52c8c0['join'](',\x20')+'\x0a\x20*\x0a\x20*\x20Generated\x20by:\x20RESTForge\x20Consumer\x20Deploy\x20CLI\x0a\x20*\x20Generated\x20at:\x20'+new Date()['toISOString']()+'\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[_0x4376ff(0x136)](_0x2debc6,null,0x4)[_0x4376ff(0x139)](/"(\w+)":/g,'$1:')+'\x0a};\x0a';return _0x5684cb;}function generateShellScript(_0x4779db){const _0x45a676=a0_0x57c3ca,{projectName:_0x2494a9,consumers:_0x4a1fd7}=_0x4779db,_0x4a5fea=_0x4a1fd7[_0x45a676(0x13d)](_0x35dd31=>_0x45a676(0x133)+_0x2494a9+'-'+_0x35dd31),_0x3b1a31=_0x4a5fea['join']('\x20'),_0x61ae96=_0x4a5fea[0x0];return _0x45a676(0x168)+_0x2494a9+_0x45a676(0x125)+_0x4a1fd7[_0x45a676(0x140)](',\x20')+'\x0a#\x0a#\x20Generated\x20by:\x20RESTForge\x20Consumer\x20Deploy\x20CLI\x0a#\x20Generated\x20at:\x20'+new Date()[_0x45a676(0x165)]()+_0x45a676(0x148)+_0x2494a9+_0x45a676(0x10b)+_0x3b1a31+_0x45a676(0x144)+_0x4a1fd7['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('+_0x4a5fea['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';}function a0_0x1db5(_0x657fb4,_0x4f3f8c){_0x657fb4=_0x657fb4-0x107;const _0x2c5c33=a0_0x2c5c();let _0x1db59d=_0x2c5c33[_0x657fb4];if(a0_0x1db5['UPoeHa']===undefined){var _0x32d378=function(_0x2fac95){const _0x5544c7='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x54a387='',_0x2c275c='';for(let _0x3d82e3=0x0,_0x1dd747,_0x49cd10,_0x166ff3=0x0;_0x49cd10=_0x2fac95['charAt'](_0x166ff3++);~_0x49cd10&&(_0x1dd747=_0x3d82e3%0x4?_0x1dd747*0x40+_0x49cd10:_0x49cd10,_0x3d82e3++%0x4)?_0x54a387+=String['fromCharCode'](0xff&_0x1dd747>>(-0x2*_0x3d82e3&0x6)):0x0){_0x49cd10=_0x5544c7['indexOf'](_0x49cd10);}for(let _0x29e966=0x0,_0x168379=_0x54a387['length'];_0x29e966<_0x168379;_0x29e966++){_0x2c275c+='%'+('00'+_0x54a387['charCodeAt'](_0x29e966)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x2c275c);};a0_0x1db5['TDXiwL']=_0x32d378,a0_0x1db5['RuhdiO']={},a0_0x1db5['UPoeHa']=!![];}const _0x25aec0=_0x2c5c33[0x0],_0x1c57e6=_0x657fb4+_0x25aec0,_0x5c7343=a0_0x1db5['RuhdiO'][_0x1c57e6];return!_0x5c7343?(_0x1db59d=a0_0x1db5['TDXiwL'](_0x1db59d),a0_0x1db5['RuhdiO'][_0x1c57e6]=_0x1db59d):_0x1db59d=_0x5c7343,_0x1db59d;}async function main(){const _0x134ecd=a0_0x57c3ca,_0x306d4e={'oCYxZ':function(_0x4d29a1){return _0x4d29a1();},'JEner':'Error:\x20--project=<NAME>\x20is\x20required','AQoBl':'Use\x20--help\x20for\x20usage\x20information','obIox':'src','OphFW':_0x134ecd(0x14f),'lnmfV':'WARNING:\x20The\x20following\x20files\x20already\x20exist:','jmQwe':'\x20\x20[1]\x20Overwrite\x20existing\x20files','vOZae':_0x134ecd(0x107),'xKPmP':function(_0x14cb22,_0x167dfa){return _0x14cb22(_0x167dfa);},'Fijvj':'pm2','ylkqa':_0x134ecd(0x16e),'qySEL':_0x134ecd(0x167),'EEgag':'==========================================','TJrLM':_0x134ecd(0x135),'hfZRl':_0x134ecd(0x13e),'oYQDI':'\x20\x202.\x20Install\x20PM2\x20globally\x20(if\x20not\x20installed):','yriNA':_0x134ecd(0x11a),'fdWky':_0x134ecd(0x119),'hIKrT':_0x134ecd(0x169)};console['log'](''),console['log']('RESTForge\x20Consumer\x20Deploy\x20Generator'),console['log'](_0x134ecd(0x16b)),console[_0x134ecd(0x111)]('');args[_0x134ecd(0x13a)]&&(_0x306d4e['oCYxZ'](printHelp),process['exit'](0x0));args['version']&&(printVersion(),process[_0x134ecd(0x15b)](0x0));!args[_0x134ecd(0x121)]&&(console['error'](_0x306d4e['JEner']),console['log'](_0x306d4e[_0x134ecd(0x152)]),process[_0x134ecd(0x15b)](0x1));!args[_0x134ecd(0x113)]&&(console['error'](_0x134ecd(0x158)),console[_0x134ecd(0x111)](_0x306d4e['AQoBl']),process['exit'](0x1));const _0x1890e7=args[_0x134ecd(0x121)]['toLowerCase'](),_0x4184d7=process['cwd'](),_0x491cc7=args['output']?path['resolve'](_0x4184d7,args[_0x134ecd(0x11c)]):path[_0x134ecd(0x110)](_0x4184d7,_0x134ecd(0x150));console[_0x134ecd(0x111)]('Project:\x20'+_0x1890e7),console['log'](_0x134ecd(0x161)+args[_0x134ecd(0x113)]),console[_0x134ecd(0x111)](_0x134ecd(0x14c)+_0x491cc7),console['log']('');let _0x6ef8d0=[];if(args['consumer']){const _0xf69c9a=path[_0x134ecd(0x140)](_0x4184d7,_0x306d4e[_0x134ecd(0x143)],'consumers',_0x1890e7,args['consumer'],_0x134ecd(0x11f));!fs[_0x134ecd(0x11e)](_0xf69c9a)&&(console[_0x134ecd(0x112)]('Error:\x20Consumer\x20not\x20found:\x20'+args[_0x134ecd(0x10e)]),console['error']('Expected\x20at:\x20'+_0xf69c9a),process[_0x134ecd(0x15b)](0x1)),_0x6ef8d0=[args[_0x134ecd(0x10e)]],console[_0x134ecd(0x111)]('Mode:\x20Single\x20consumer\x20('+args[_0x134ecd(0x10e)]+')');}else _0x6ef8d0=scanConsumers(_0x4184d7,_0x1890e7),_0x6ef8d0[_0x134ecd(0x12e)]===0x0&&(console[_0x134ecd(0x112)]('Error:\x20No\x20consumers\x20found\x20in\x20project:\x20'+_0x1890e7),console[_0x134ecd(0x112)]('Expected\x20at:\x20src/consumers/'+_0x1890e7+'/'),process['exit'](0x1)),console[_0x134ecd(0x111)](_0x134ecd(0x15c)+_0x6ef8d0['length']+'\x20found)');console['log'](_0x134ecd(0x12f)+_0x6ef8d0[_0x134ecd(0x140)](',\x20')),console[_0x134ecd(0x111)]('');const _0x406ce5=path['join'](_0x491cc7,_0x134ecd(0x13f)),_0x5e3716=path['join'](_0x491cc7,_0x306d4e['OphFW']),_0x28b568=[];if(fs[_0x134ecd(0x11e)](_0x406ce5))_0x28b568['push'](_0x406ce5);if(fs[_0x134ecd(0x11e)](_0x5e3716))_0x28b568['push'](_0x5e3716);if(_0x28b568[_0x134ecd(0x12e)]>0x0&&!args['force']){console['log'](_0x306d4e[_0x134ecd(0x164)]),_0x28b568['forEach'](_0x52f561=>{const _0x5b2788=_0x134ecd;console[_0x5b2788(0x111)](_0x5b2788(0x109)+path['relative'](_0x4184d7,_0x52f561));}),console['log'](''),console['log']('Options:'),console['log'](_0x306d4e['jmQwe']),console['log'](_0x306d4e[_0x134ecd(0x108)]),console['log']('');const _0x49cca6=await _0x306d4e['xKPmP'](prompt,'Your\x20choice\x20(1/2):\x20');_0x49cca6!=='1'&&(console['log'](''),console['log']('Generation\x20cancelled.'),process['exit'](0x0)),console[_0x134ecd(0x111)]('');}!fs[_0x134ecd(0x11e)](_0x491cc7)&&(fs['mkdirSync'](_0x491cc7,{'recursive':!![]}),console[_0x134ecd(0x111)]('Created\x20directory:\x20'+_0x491cc7));const _0x1a886e=path['join'](_0x4184d7,_0x134ecd(0x145),_0x306d4e[_0x134ecd(0x137)]);!fs[_0x134ecd(0x11e)](_0x1a886e)&&(fs[_0x134ecd(0x15a)](_0x1a886e,{'recursive':!![]}),console[_0x134ecd(0x111)]('Created\x20directory:\x20'+_0x1a886e));const _0x2c84ab={'projectName':_0x1890e7,'consumers':_0x6ef8d0,'configFile':args[_0x134ecd(0x113)],'license':args[_0x134ecd(0x115)],'port':args['port'],'projectDir':_0x4184d7};console['log'](''),console[_0x134ecd(0x111)]('Generating\x20ecosystem.config.js...');const _0x2c1c41=generateEcosystemConfig(_0x2c84ab);fs[_0x134ecd(0x14b)](_0x406ce5,_0x2c1c41),console[_0x134ecd(0x111)](_0x134ecd(0x155)+path['relative'](_0x4184d7,_0x406ce5)),console[_0x134ecd(0x111)](''),console['log']('Generating\x20consumer-manager.sh...');const _0xf455ce=generateShellScript(_0x2c84ab);fs['writeFileSync'](_0x5e3716,_0xf455ce);try{fs[_0x134ecd(0x128)](_0x5e3716,_0x306d4e[_0x134ecd(0x16d)]);}catch(_0x29f8f4){}console['log'](_0x134ecd(0x155)+path[_0x134ecd(0x122)](_0x4184d7,_0x5e3716)),console[_0x134ecd(0x111)](''),console['log']('=========================================='),console['log'](_0x306d4e['qySEL']),console['log'](_0x306d4e['EEgag']),console['log'](''),console[_0x134ecd(0x111)](_0x306d4e['TJrLM']),console['log'](_0x134ecd(0x109)+path['relative'](_0x4184d7,_0x406ce5)),console['log'](_0x134ecd(0x109)+path[_0x134ecd(0x122)](_0x4184d7,_0x5e3716)),console['log'](''),console['log']('Next\x20steps\x20for\x20deployment:'),console['log'](''),console[_0x134ecd(0x111)](_0x306d4e[_0x134ecd(0x146)]),console[_0x134ecd(0x111)](''),console[_0x134ecd(0x111)](_0x306d4e['oYQDI']),console['log'](_0x306d4e[_0x134ecd(0x134)]),console['log'](''),console['log'](_0x306d4e['fdWky']),console[_0x134ecd(0x111)](_0x134ecd(0x14d)+path['relative'](_0x4184d7,_0x491cc7)),console['log'](_0x306d4e['hIKrT']),console[_0x134ecd(0x111)](''),console[_0x134ecd(0x111)](_0x134ecd(0x15d)),console['log']('\x20\x20\x20\x20\x20./consumer-manager.sh'),console[_0x134ecd(0x111)](''),console[_0x134ecd(0x111)](_0x134ecd(0x154)),console[_0x134ecd(0x111)](_0x134ecd(0x149)),console['log']('\x20\x20\x20\x20\x20pm2\x20save'),console[_0x134ecd(0x111)](''),console[_0x134ecd(0x111)](_0x306d4e['EEgag']),process['exit'](0x0);}function a0_0x2c5c(){const _0xc8b82e=['mta0mJG2y3LywwfA','ls1OzwXW','Bg5TzLy','Dg9ju09tDhjPBMC','ic0TCg9YDd0','icbhzw5LCMf0Aw9UignVBxbSzxrLzcbZDwnJzxnZzNvSBhKH','iYeVyMLUl2jHC2GkcImJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiWOJifjfu1rgB3jNzsbdB25ZDw1LCIbnyw5Hz2vYcImGuhjVAMvJDdOG','icaGicbWBtiGC3rHCNqGzwnVC3LZDgvTlMnVBMzPzY5QCW','mteYA1zTvvbi','pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09','ic0TBgLJzw5Zzt0','EwXRCwe','nZu1','icbBmL0Gq2fUy2vS','DK9Aywu','icaTia','mJi0oejctMPgtW','iGPbufbFtKfnrvm9iG','lI9SB2DZl3bTmI8','BNb4','y29UC3vTzxi','ChjVzhvJDgLVBG','CMvZB2X2zq','Bg9N','zxjYB3i','y29UzMLN','cIaQienVBNn1BwvYCZOG','BgLJzw5Zzq','ls1WB3j0pq','BwvZC2fNzq','lwvYCM9YlMXVzW','icaZlIbtDgfYDcbJB25ZDw1LCNmGD2L0Acbqtti6','icaGicbUCg0GAw5ZDgfSBcaTzYbWBti','mta2mteXmgH2yuLKwq','B3v0Chv0','wvLzws1nts1ercbisdPTBtPZCYbA','zxHPC3rZu3LUyW','Aw5KzxGUANm','ic0Ty29UzMLNpq','ChjVAMvJDa','CMvSyxrPDMu','ChvZAa','DhjPBq','cImGq29UC3vTzxjZoIa','CxvctvG','rMf0ywWGzxjYB3i6ia','y2HTB2rtEw5J','DMvYC2LVBG','AxneAxjLy3rVCNK','CMvHzgXPBMu','C3bSAxq','mtaZnJyXnezWt2XTAa','BgvUz3rO','q29UC3vTzxjZoIa','ls1MB3jJzq','sgvmwMK','CMvZDgzVCMDLlwnVBNn1BwvYic0TChjVAMvJDd0','y29UC3vTzxiT','ExjPtKe','r2vUzxjHDgvKigzPBgvZoG','C3rYAw5NAwz5','rMLQDMO','mte3mdmZre5Ru2f2','CMvWBgfJzq','AgvSCa','CMvHzgrPCLn5BMm','zNnWBLe','BwfW','icaXlIbdB3b5ihbYB2PLy3qGDg8GChjVzhvJDgLVBIbZzxj2zxi','zwnVC3LZDgvTlMnVBMzPzY5QCW','AM9PBG','thb0Eui','yxjNDG','B2jjB3G','iGPfq09twvnuru1FrKLmrt0IzwnVC3LZDgvTlMnVBMzPzY5QCYikcImGr2v0ihnJCMLWDcbKAxjLy3rVCNKku0nssvbux0rjuJ0IjcGGy2qGiIqOigrPCM5HBwuGiIr7qKftsf9tt1vsq0vBmf19iIaPiIaMjIbWD2qGksiky2qGiIrtq1jjufrFreLsiGOkiYbdAgvJAYbPzIbqttiGAxmGAw5ZDgfSBgvKcMnOzwnRx3bTmIGPihSkicaGigLMiceGy29TBwfUzcaTDIbWBtiGjJ4Gl2rLDI9UDwXSoYb0AgvUcIaGicaGicaGzwnOBYaTzsaIjhTsrur9rxjYB3i6ifbnmIbPCYbUB3qGAw5ZDgfSBgvKlIr7tKn9iGOGicaGicaGigvJAg8GiKLUC3rHBgWGue0YihDPDgG6ig5WBsbPBNn0ywXSic1NihbTmIikicaGicaGicbLEgL0idekicaGigzPcN0kcImGuhjPBNqGAgvHzgvYcNbYAw50x2HLywrLCIGPihSkicaGignSzwfYcIaGicbLy2HVic1LiciKE0nzqu59pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt0KE05dFsikicaGigvJAg8GlwuGiIr7q1LbtN0Gifjfu1rgB3jNzsbdB25ZDw1LCIbnyw5Hz2vYjhToq30IcIaGicbLy2HVic1LiciKE0nzqu59pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt09pt0KE05dFsikicaGigvJAg8GlwuGiIaGuhjVAMvJDdOGjhThuKvftN0KufjpsKvdvf9oqu1fjhToq30IcIaGicbLy2HVic1LiciGienVBNn1BwvYCZOGjhTzruXmt1D9','Bg9NCW','AgzAuMW','tePuDwK','cImJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiYmJiWOkiYbdB2XVCNmkuKvepsDCmdmZwZa7mZfTjWPhuKvftJ0NxdaZm1SWoZmYBsCkwuvmte9xpsDCmdmZwZe7mZnTjWPctfvfpsDCmdmZwZa7mZrTjWPdwufopsDCmdmZwZa7mZzTjWPoqZ0NxdaZm1SWBsCGiYboBYbdB2XVCGOkiYbqCM9Qzwn0igLUzM8kufjpsKvdvf9oqu1fpsi','icaGicbWBtiGC3rHCNr1Ca','C3rHCNrZv2L0Aa','D3jPDgvgAwXLu3LUyW','t3v0Chv0oIa','icaGicbJzca','EwXVrw0','y29UC3vTzxiTBwfUywDLCI5ZAa','zgvWBg95','ls1JB25ZDw1LCJ0','qvfVqMW','otG5mujeELfZCq','ica1lIbtzxr1CcbHDxrVlxn0yxj0ig9UigjVB3q6','icbdCMvHDgvKoIa','ls1TB2r1Bgu9','zM9Yy2u','rxjYB3i6ic0Ty29UzMLNptXgsuXflMvUDJ4GAxmGCMvXDwLYzwq','ndmXCefLAvrh','BwTKAxjtEw5J','zxHPDa','tw9KztOGtxvSDgKGy29UC3vTzxiGka','ica0lIbpCIb1C2uGAw50zxjHy3rPDMuGBwfUywDLCJO','Cg9YDa','Cgf0Aa','odCZmtG0qM5wB09n','q29UzMLNoIa'];a0_0x2c5c=function(){return _0xc8b82e;};return a0_0x2c5c();}main()['catch'](_0xc99f4=>{const _0xf05f93=a0_0x57c3ca;console['error'](_0xf05f93(0x127)+_0xc99f4[_0xf05f93(0x117)]),process['exit'](0x1);});