@restforgejs/platform 4.2.8 → 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.
- package/SECURITY.md +83 -4
- package/bin/sdf-tools.exe +0 -0
- package/build-info.json +2 -2
- package/cli/consumer-deploy.js +1 -1
- package/cli/consumer.js +1 -1
- package/generators/cli/dashboard/create.js +4 -1
- package/generators/cli/endpoint/create.js +1 -1
- package/generators/cli/key/generate.js +2 -1
- package/generators/cli/key/revoke.js +2 -1
- package/generators/cli/payload/diff.js +3 -2
- package/generators/cli/payload/generate.js +3 -2
- package/generators/cli/payload/sync.js +3 -2
- package/generators/cli/payload/validate.js +3 -2
- package/generators/cli/processor/create.js +14 -3
- package/generators/cli/project/delete.js +2 -1
- package/generators/cli/query/validate.js +3 -2
- package/generators/cli/schema/apply.js +3 -2
- package/generators/cli/schema/describe.js +3 -2
- package/generators/cli/schema/diff.js +3 -2
- package/generators/cli/schema/introspect.js +3 -2
- package/generators/cli/schema/list.js +3 -2
- package/generators/cli/schema/migrate.js +3 -2
- package/generators/lib/migration/audit-table-runner.js +213 -215
- package/generators/lib/templates/dashboard-catalog.js +1 -437
- package/generators/lib/templates/db-connection-env.js +1 -212
- package/generators/lib/templates/dbschema-catalog.js +1 -489
- package/generators/lib/templates/field-validation-catalog.js +1 -531
- package/generators/lib/templates/mysql-template.js +1 -3863
- package/generators/lib/templates/oracle-template.js +1 -3915
- package/generators/lib/templates/postgres-template.js +1 -5838
- package/generators/lib/templates/query-declarative-catalog.js +1 -199
- package/generators/lib/templates/sqlite-template.js +1 -3440
- package/generators/lib/utils/env-manager.js +6 -0
- package/generators/lib/utils/path-validator.js +71 -0
- package/generators/lib/validators/payload-validator.js +1 -2
- package/integrity-manifest.json +28 -10
- package/package.json +11 -3
- package/scripts/verify-integrity.js +1 -1
- package/server.js +1 -1
- package/src/components/handlers/adjust_handler.js +1 -1
- package/src/components/handlers/audit_handler.js +1 -1
- package/src/components/handlers/delete_handler.js +1 -1
- package/src/components/handlers/export_handler.js +1 -1
- package/src/components/handlers/import_handler.js +1 -1
- package/src/components/handlers/insert_handler.js +1 -1
- package/src/components/handlers/update_handler.js +1 -1
- package/src/components/handlers/upload_handler.js +1 -1
- package/src/components/handlers/workflow_handler.js +1 -1
- package/src/components/integrations/webhook.js +1 -1
- package/src/consumers/baseConsumer.js +1 -1
- package/src/consumers/declarativeMapper.js +1 -1
- package/src/consumers/handlers/apiHandler.js +1 -1
- package/src/consumers/handlers/consoleHandler.js +1 -1
- package/src/consumers/handlers/databaseHandler.js +1 -1
- package/src/consumers/handlers/index.js +1 -1
- package/src/consumers/handlers/kafkaHandler.js +1 -1
- package/src/consumers/index.js +1 -1
- package/src/consumers/messageTransformer.js +1 -1
- package/src/consumers/validator.js +1 -1
- package/src/core/db/dialect/base-dialect.js +1 -1
- package/src/core/db/dialect/index.js +1 -1
- package/src/core/db/dialect/mysql-dialect.js +1 -1
- package/src/core/db/dialect/oracle-dialect.js +1 -1
- package/src/core/db/dialect/postgres-dialect.js +1 -1
- package/src/core/db/dialect/sqlite-dialect.js +1 -1
- package/src/core/db/flatten-helper.js +1 -1
- package/src/core/db/query-builder-error.js +1 -1
- package/src/core/db/query-builder.js +1 -1
- package/src/core/db/relation-helper.js +1 -1
- package/src/core/handlers/delete_handler.js +1 -1
- package/src/core/handlers/insert_handler.js +1 -1
- package/src/core/handlers/update_handler.js +1 -1
- package/src/core/models/base-model.js +1 -1
- package/src/core/utils/cache-manager.js +1 -1
- package/src/core/utils/component-engine.js +1 -1
- package/src/core/utils/context-builder.js +1 -1
- package/src/core/utils/datetime-formatter.js +1 -1
- package/src/core/utils/datetime-parser.js +1 -1
- package/src/core/utils/db.js +1 -1
- package/src/core/utils/logger.js +1 -1
- package/src/core/utils/payload-loader.js +1 -1
- package/src/core/utils/security-checks.js +1 -1
- package/src/middleware/body-options.js +1 -1
- package/src/middleware/cors.js +1 -1
- package/src/middleware/idempotency.js +1 -1
- package/src/middleware/rate-limiter.js +1 -1
- package/src/middleware/request-logger.js +1 -1
- package/src/middleware/security-headers.js +1 -1
- package/src/models/base-model-mysql.js +1 -1
- package/src/models/base-model-oracle.js +1 -1
- package/src/models/base-model-sqlite.js +1 -1
- package/src/models/base-model.js +1 -1
- package/src/pro/caching/redis-client.js +1 -1
- package/src/pro/caching/redis-helper.js +1 -1
- package/src/pro/consumers/baseConsumer.js +1 -1
- package/src/pro/consumers/declarativeMapper.js +1 -1
- package/src/pro/consumers/handlers/apiHandler.js +1 -1
- package/src/pro/consumers/handlers/consoleHandler.js +1 -1
- package/src/pro/consumers/handlers/databaseHandler.js +1 -1
- package/src/pro/consumers/handlers/index.js +1 -1
- package/src/pro/consumers/handlers/kafkaHandler.js +1 -1
- package/src/pro/consumers/index.js +1 -1
- package/src/pro/consumers/messageTransformer.js +1 -1
- package/src/pro/consumers/validator.js +1 -1
- package/src/pro/database/base-model-mysql.js +1 -1
- package/src/pro/database/base-model-oracle.js +1 -1
- package/src/pro/database/base-model-sqlite.js +1 -1
- package/src/pro/database/db-mysql.js +1 -1
- package/src/pro/database/db-oracle.js +1 -1
- package/src/pro/database/db-sqlite.js +1 -1
- package/src/pro/excel/excel-generator.js +1 -1
- package/src/pro/excel/excel-parser.js +1 -1
- package/src/pro/excel/export-service.js +1 -1
- package/src/pro/excel/export_handler.js +1 -1
- package/src/pro/excel/import-service.js +1 -1
- package/src/pro/excel/import-validator.js +1 -1
- package/src/pro/excel/import_handler.js +1 -1
- package/src/pro/excel/upsert-builder.js +1 -1
- package/src/pro/idgen/idgen-routes.js +1 -1
- package/src/pro/integrations/lookup-resolver.js +1 -1
- package/src/pro/integrations/upload-handler-v2.js +1 -1
- package/src/pro/integrations/upload-handler.js +1 -1
- package/src/pro/integrations/webhook.js +1 -1
- package/src/pro/locking/lock-routes.js +1 -1
- package/src/pro/locking/resource-lock-manager.js +1 -1
- package/src/pro/messaging/kafkaConsumerService.js +1 -1
- package/src/pro/messaging/kafkaService.js +1 -1
- package/src/pro/messaging/messagehubService.js +1 -1
- package/src/pro/messaging/rabbitmqService.js +1 -1
- package/src/pro/scheduler/job-manager.js +1 -1
- package/src/pro/scheduler/job-routes.js +1 -1
- package/src/pro/scheduler/job-validator.js +1 -1
- package/src/pro/storage/base-storage-provider.js +1 -1
- package/src/pro/storage/file-metadata-helper.js +1 -1
- package/src/pro/storage/index.js +1 -1
- package/src/pro/storage/local-storage-provider.js +1 -1
- package/src/pro/storage/s3-storage-provider.js +1 -1
- package/src/pro/storage/upload-cleanup-job.js +1 -1
- package/src/pro/storage/upload-cleanup-scheduler.js +1 -1
- package/src/pro/storage/upload-pending-tracker.js +1 -1
- package/src/pro/websocket/broadcast-helper.js +1 -1
- package/src/pro/websocket/index.js +1 -1
- package/src/pro/websocket/livesync-server.js +1 -1
- package/src/pro/websocket/ws-broadcaster.js +1 -1
- package/src/services/export-service.js +1 -1
- package/src/services/import-service.js +1 -1
- package/src/services/kafkaConsumerService.js +1 -1
- package/src/services/kafkaService.js +1 -1
- package/src/services/messagehubService.js +1 -1
- package/src/services/rabbitmqService.js +1 -1
- package/src/utils/cache-invalidation-registry.js +1 -1
- package/src/utils/cache-manager.js +1 -1
- package/src/utils/component-engine.js +1 -1
- package/src/utils/config-extractor.js +1 -1
- package/src/utils/consumerLogger.js +1 -1
- package/src/utils/context-builder.js +1 -1
- package/src/utils/dashboard-helpers.js +1 -1
- package/src/utils/dateHelper.js +1 -1
- package/src/utils/datetime-formatter.js +1 -1
- package/src/utils/datetime-parser.js +1 -1
- package/src/utils/db-bootstrap.js +1 -1
- package/src/utils/db-mysql.js +1 -1
- package/src/utils/db-oracle.js +1 -1
- package/src/utils/db-sqlite.js +1 -1
- package/src/utils/db.js +1 -1
- package/src/utils/demo-generator.js +1 -1
- package/src/utils/excel-generator.js +1 -1
- package/src/utils/excel-parser.js +1 -1
- package/src/utils/file-watcher.js +1 -1
- package/src/utils/id-generator.js +1 -1
- package/src/utils/idempotency-manager.js +1 -1
- package/src/utils/import-validator.js +1 -1
- package/src/utils/license-client.js +1 -1
- package/src/utils/lock-manager.js +1 -1
- package/src/utils/logger.js +1 -1
- package/src/utils/lookup-resolver.js +1 -1
- package/src/utils/payload-loader.js +1 -1
- package/src/utils/processor-response.js +1 -1
- package/src/utils/rabbitmq.js +1 -1
- package/src/utils/redis-client.js +1 -1
- package/src/utils/redis-helper.js +1 -1
- package/src/utils/request-scope.js +1 -1
- package/src/utils/security-checks.js +1 -1
- package/src/utils/service-resolver.js +1 -1
- package/src/utils/shutdown-coordinator.js +1 -1
- package/src/utils/trusted-keys.js +1 -1
- package/src/utils/upload-handler.js +1 -1
- package/src/utils/upsert-builder.js +1 -1
- package/src/utils/workflow-hook-executor.js +1 -1
- package/generators/metadata/global.json +0 -58
- package/generators/metadata/test-mysql-workbench.json +0 -118
- package/generators/metadata/test-mysql.json +0 -56
- package/generators/metadata/test-oracle-workbench.json +0 -118
- package/generators/metadata/test-oracle.json +0 -56
- package/generators/metadata/test-pg-workbench.json +0 -118
- package/generators/metadata/test-pg.json +0 -56
- package/generators/scripts/obfuscate-source.js +0 -356
- package/generators/scripts/validate-catalog.js +0 -430
- package/generators/scripts/validate-dbschema-catalog.js +0 -708
- package/generators/tests/baseline/mysql/mini_inventory_item/src/models/mini-inventory/item.js +0 -944
- package/generators/tests/baseline/mysql/mini_inventory_item/src/modules/mini-inventory/item.js +0 -740
- package/generators/tests/baseline/mysql/mini_inventory_item/src/modules/mini-inventory.js +0 -336
- package/generators/tests/baseline/oracle/mini_inventory_item/src/models/mini-inventory/item.js +0 -1002
- package/generators/tests/baseline/oracle/mini_inventory_item/src/modules/mini-inventory/item.js +0 -740
- package/generators/tests/baseline/oracle/mini_inventory_item/src/modules/mini-inventory.js +0 -336
- package/generators/tests/baseline/postgres/mini_inventory_item/src/models/mini-inventory/item.js +0 -1333
- package/generators/tests/baseline/postgres/mini_inventory_item/src/modules/mini-inventory/item.js +0 -1173
- package/generators/tests/baseline/postgres/mini_inventory_item/src/modules/mini-inventory.js +0 -496
- package/generators/tests/fixtures/payloads/custom-sensitive.json +0 -27
- package/generators/tests/fixtures/payloads/dynamic-search-optout.json +0 -23
- package/generators/tests/fixtures/payloads/login-with-password.json +0 -22
- package/generators/tests/fixtures/payloads/order-process.json +0 -52
- package/generators/tests/fixtures/payloads/with-inline-sql.json +0 -26
- package/generators/tests/integration-tahap4b/README.md +0 -145
- package/generators/tests/integration-tahap4b/run-concurrent.js +0 -77
- package/generators/tests/integration-tahap4b/seed.sql +0 -53
- package/generators/tests/integration-tahap4b/verify.sql +0 -110
- package/generators/tests/unit/cli/create-dashboard.test.js +0 -505
- package/generators/tests/unit/cli/create-processor.test.js +0 -319
- package/generators/tests/unit/cli/dispatch-dashboard.test.js +0 -149
- package/generators/tests/unit/lib/dashboard-generator.test.js +0 -895
- package/generators/tests/unit/lib/dashboard-validator.test.js +0 -354
- package/generators/tests/unit/lib/dbschema-kit/apply-executor.test.js +0 -437
- package/generators/tests/unit/lib/dbschema-kit/cli/dbschema-introspect.test.js +0 -393
- package/generators/tests/unit/lib/dbschema-kit/cli/dbschema-kit-generate-ddl.test.js +0 -104
- package/generators/tests/unit/lib/dbschema-kit/cli/dbschema-kit-init.test.js +0 -119
- package/generators/tests/unit/lib/dbschema-kit/cli/dbschema-kit-list.test.js +0 -48
- package/generators/tests/unit/lib/dbschema-kit/cli/dbschema-kit-migrate.test.js +0 -175
- package/generators/tests/unit/lib/dbschema-kit/cli/dbschema-kit-validate.test.js +0 -102
- package/generators/tests/unit/lib/dbschema-kit/cli/dbschema-models.test.js +0 -43
- package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/introspect-stubs/all-schemas-listing.js +0 -84
- package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/introspect-stubs/connection-error.js +0 -13
- package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/introspect-stubs/empty.js +0 -12
- package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/introspect-stubs/multi-schema.js +0 -124
- package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/introspect-stubs/single-schema-inventory.js +0 -64
- package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/introspect-stubs/two-tables.js +0 -66
- package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/migrate-stubs/connection-error.js +0 -9
- package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/migrate-stubs/partial.js +0 -29
- package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/migrate-stubs/rollback.js +0 -26
- package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/migrate-stubs/success.js +0 -43
- package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/multi-schema/audit/events.js +0 -18
- package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/multi-schema/inventory/products.js +0 -9
- package/generators/tests/unit/lib/dbschema-kit/cli/fixtures/multi-schema/users.js +0 -8
- package/generators/tests/unit/lib/dbschema-kit/connection.test.js +0 -112
- package/generators/tests/unit/lib/dbschema-kit/ddl-generator.test.js +0 -205
- package/generators/tests/unit/lib/dbschema-kit/define-model.test.js +0 -56
- package/generators/tests/unit/lib/dbschema-kit/dialect/index.test.js +0 -46
- package/generators/tests/unit/lib/dbschema-kit/dialect/mysql.test.js +0 -126
- package/generators/tests/unit/lib/dbschema-kit/dialect/oracle.test.js +0 -126
- package/generators/tests/unit/lib/dbschema-kit/dialect/postgres.test.js +0 -131
- package/generators/tests/unit/lib/dbschema-kit/dialect/sqlite.test.js +0 -126
- package/generators/tests/unit/lib/dbschema-kit/driver-loader.test.js +0 -93
- package/generators/tests/unit/lib/dbschema-kit/emitters/create-index.test.js +0 -173
- package/generators/tests/unit/lib/dbschema-kit/emitters/create-table.test.js +0 -376
- package/generators/tests/unit/lib/dbschema-kit/emitters/drop-table.test.js +0 -78
- package/generators/tests/unit/lib/dbschema-kit/fixtures/connection/invalid-dialect.env +0 -6
- package/generators/tests/unit/lib/dbschema-kit/fixtures/connection/missing-dialect.env +0 -5
- package/generators/tests/unit/lib/dbschema-kit/fixtures/connection/missing-host.env +0 -5
- package/generators/tests/unit/lib/dbschema-kit/fixtures/connection/oracle-valid.env +0 -6
- package/generators/tests/unit/lib/dbschema-kit/fixtures/connection/postgres-valid.env +0 -7
- package/generators/tests/unit/lib/dbschema-kit/fixtures/connection/sqlite-valid.env +0 -2
- package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory/category.js +0 -11
- package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory/item_product.js +0 -11
- package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory/stock_inbound.js +0 -24
- package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory/stock_inbound_item.js +0 -28
- package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory/supplier.js +0 -9
- package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory/warehouse.js +0 -9
- package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory-invalid/orphan.js +0 -17
- package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory-multifolder/master/category.js +0 -11
- package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory-multifolder/master/item_product.js +0 -11
- package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory-multifolder/master/supplier.js +0 -9
- package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory-multifolder/master/warehouse.js +0 -9
- package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory-multifolder/transactions/stock_inbound.js +0 -24
- package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/mini-inventory-multifolder/transactions/stock_inbound_item.js +0 -28
- package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/multi-schema/audit/events.js +0 -18
- package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/multi-schema/inventory/products.js +0 -9
- package/generators/tests/unit/lib/dbschema-kit/fixtures/integration/multi-schema/public/users.js +0 -9
- package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/duplicate-subfolder/extra/category.js +0 -8
- package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/duplicate-subfolder/master/category.js +0 -8
- package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/duplicate-tablename/bar.js +0 -8
- package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/duplicate-tablename/foo.js +0 -8
- package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/empty-folder/README.md +0 -1
- package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/invalid-export/plain.js +0 -3
- package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/invalid-schema/bad.js +0 -6
- package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/legacy-pattern/legacy.js +0 -12
- package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/multi-schema-distinct/audit/products.js +0 -9
- package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/multi-schema-distinct/inventory/products.js +0 -9
- package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/multi-schema-duplicate/a/products.js +0 -8
- package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/multi-schema-duplicate/b/products.js +0 -8
- package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/nested-deep/a/b/c/deep_table.js +0 -8
- package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/recursive-multi-folder/.hidden/ignored.js +0 -7
- package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/recursive-multi-folder/master/category.js +0 -8
- package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/recursive-multi-folder/master/supplier.js +0 -8
- package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/recursive-multi-folder/transactions/stock_inbound.js +0 -8
- package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/recursive-multi-folder/transactions/stock_inbound_item.js +0 -8
- package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/valid-multiple/category.js +0 -8
- package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/valid-multiple/item_product.js +0 -9
- package/generators/tests/unit/lib/dbschema-kit/fixtures/loader/valid-single/category.js +0 -8
- package/generators/tests/unit/lib/dbschema-kit/integration.test.js +0 -217
- package/generators/tests/unit/lib/dbschema-kit/introspect-mapper.test.js +0 -403
- package/generators/tests/unit/lib/dbschema-kit/ir-builder.test.js +0 -390
- package/generators/tests/unit/lib/dbschema-kit/loader.test.js +0 -128
- package/generators/tests/unit/lib/dbschema-kit/naming.test.js +0 -170
- package/generators/tests/unit/lib/dbschema-kit/parser/shorthand-parser.test.js +0 -237
- package/generators/tests/unit/lib/dbschema-kit/schema-printer.test.js +0 -251
- package/generators/tests/unit/lib/dbschema-kit/statement-modifier.test.js +0 -105
- package/generators/tests/unit/lib/dbschema-kit/statement-splitter.test.js +0 -165
- package/generators/tests/unit/lib/dbschema-kit/topological-sort.test.js +0 -135
- package/generators/tests/unit/lib/dbschema-kit/validator/check-compatibility-validator.test.js +0 -373
- package/generators/tests/unit/lib/dbschema-kit/validator/circular-relation-validator.test.js +0 -454
- package/generators/tests/unit/lib/dbschema-kit/validator/cross-model-validator.test.js +0 -512
- package/generators/tests/unit/lib/dbschema-kit/validator/enhanced-validate-integration.test.js +0 -390
- package/generators/tests/unit/lib/dbschema-kit/validator/naming-convention-validator.test.js +0 -306
- package/generators/tests/unit/lib/dbschema-kit/validator/schema-validator.test.js +0 -443
- package/generators/tests/unit/lib/dbschema-kit/validator/type-compatibility-validator.test.js +0 -440
- package/generators/tests/unit/lib/dbschema-kit/validator/validator-reporter.test.js +0 -172
- package/generators/tests/unit/lib/metadata-manager-dashboard.test.js +0 -256
- package/generators/tests/unit/lib/payload-validator-fieldpolicy.test.js +0 -240
- package/generators/tests/unit/lib/processor-validation-generator.test.js +0 -300
- package/generators/tests/unit/lib/sensitive-field-masker.test.js +0 -170
- package/generators/tests/unit/lib/sql-table-extractor.test.js +0 -119
- package/scripts/generate-integrity-manifest.js +0 -124
- package/scripts/snapshot-cli-contracts.js +0 -194
- 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.
|
|
14
|
-
|
|
|
15
|
-
|
|
|
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
package/cli/consumer-deploy.js
CHANGED
|
@@ -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_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);});
|