ml-testing-toolkit 18.13.0
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/.dockerignore +10 -0
- package/.grype.yaml +16 -0
- package/.ncurc.yaml +9 -0
- package/.nvmrc +1 -0
- package/.versionrc.js +16 -0
- package/CHANGELOG.md +504 -0
- package/CODEOWNERS +30 -0
- package/Dockerfile +42 -0
- package/Dockerfile-newman +13 -0
- package/LICENSE.md +9 -0
- package/README.md +119 -0
- package/assets/diagrams/architectural/architectural-diagram.svg +3 -0
- package/assets/diagrams/flow/flow-diagram.svg +3 -0
- package/assets/images/Sample-Response-Failure.png +0 -0
- package/assets/images/Screenshot 2020-04-16 at 22.58.04.png +0 -0
- package/assets/images/TLS-Enabled-on-Environment.png +0 -0
- package/assets/images/adapter-mutual-tls-enabled.png +0 -0
- package/assets/images/add-additional-input-values.png +0 -0
- package/assets/images/add-condition-button.png +0 -0
- package/assets/images/add-new-assertion.png +0 -0
- package/assets/images/add-new-input-value.png +0 -0
- package/assets/images/add-new-input-variable.png +0 -0
- package/assets/images/additional-transfers.png +0 -0
- package/assets/images/api-provisioning-add-new-api-confirmation.png +0 -0
- package/assets/images/api-provisioning-file-input-window.png +0 -0
- package/assets/images/api-provisioning-list-apis-view.png +0 -0
- package/assets/images/api-provisioning-menu-item.png +0 -0
- package/assets/images/apply_and_restart.jpg +0 -0
- package/assets/images/assess-request-or-response.png +0 -0
- package/assets/images/assess-response-equation-save.png +0 -0
- package/assets/images/assess-response-equation.png +0 -0
- package/assets/images/assess-response-status.png +0 -0
- package/assets/images/building-new-rules-file.png +0 -0
- package/assets/images/callback-rules-screen.png +0 -0
- package/assets/images/configurable-parameter-assertion.png +0 -0
- package/assets/images/configurable-parameter-currency.png +0 -0
- package/assets/images/configurable-parameter.png +0 -0
- package/assets/images/connection-manager-ui-opening.png +0 -0
- package/assets/images/create-inbound-user-simulator.png +0 -0
- package/assets/images/creating-new-rule-file.png +0 -0
- package/assets/images/dfsp-client-cacert.png +0 -0
- package/assets/images/dfsp-client-submit.png +0 -0
- package/assets/images/dfsp-client.png +0 -0
- package/assets/images/dfsp-p2p-happy-path.png +0 -0
- package/assets/images/dfsp-server-cacert.png +0 -0
- package/assets/images/dfsp-server-cert.png +0 -0
- package/assets/images/download-report.png +0 -0
- package/assets/images/drive_have_not_been_shared.jpg +0 -0
- package/assets/images/event-response-options.png +0 -0
- package/assets/images/expand-monitoring-messages.png +0 -0
- package/assets/images/fixed-response-sample.png +0 -0
- package/assets/images/header-selection.png +0 -0
- package/assets/images/heap_error_windows.jpg +0 -0
- package/assets/images/hosted-mode-docker-compose-intro.png +0 -0
- package/assets/images/hub-client-cert.png +0 -0
- package/assets/images/import-template.png +0 -0
- package/assets/images/inbound-requests-environment.png +0 -0
- package/assets/images/inbound-requests-scripts.png +0 -0
- package/assets/images/jws-certificate-submit.png +0 -0
- package/assets/images/jws-certificate.png +0 -0
- package/assets/images/jws-certs-keys.png +0 -0
- package/assets/images/jws-hub-certs-keys.png +0 -0
- package/assets/images/local-enable-jws-publickey.png +0 -0
- package/assets/images/local-mutual-tls-enabled.png +0 -0
- package/assets/images/local_drives_to_be_available.jpg +0 -0
- package/assets/images/mcm-environment-opening.png +0 -0
- package/assets/images/menu-items.png +0 -0
- package/assets/images/mock-response-sample.png +0 -0
- package/assets/images/monitoring-initial-state.png +0 -0
- package/assets/images/monitoring-messages.png +0 -0
- package/assets/images/new-empty-assertion.png +0 -0
- package/assets/images/opened-imported-template.png +0 -0
- package/assets/images/opening-default-settings.png +0 -0
- package/assets/images/opening-sync-response-rules.png +0 -0
- package/assets/images/opening-view.png +0 -0
- package/assets/images/outbound-display-opening-hub.png +0 -0
- package/assets/images/outbound-display-opening.png +0 -0
- package/assets/images/override-with-environment-variable.png +0 -0
- package/assets/images/populate-with-sample-body.png +0 -0
- package/assets/images/resource-selection.png +0 -0
- package/assets/images/rule-builder-select-api.png +0 -0
- package/assets/images/sample-condition-add-configurable-params.png +0 -0
- package/assets/images/sample-condition.png +0 -0
- package/assets/images/sample-editor.png +0 -0
- package/assets/images/sample-request.png +0 -0
- package/assets/images/sample-test-assertion.png +0 -0
- package/assets/images/send-transfer.png +0 -0
- package/assets/images/sending-single-test-case-1.png +0 -0
- package/assets/images/sending-single-test-case-2.png +0 -0
- package/assets/images/sending-test-cases.png +0 -0
- package/assets/images/server-certificates-submitted.png +0 -0
- package/assets/images/simulator-response.png +0 -0
- package/assets/images/simulator-scheme-adapter-endpoint.png +0 -0
- package/assets/images/summarized-view-of-rule.png +0 -0
- package/assets/images/template-window.png +0 -0
- package/assets/images/test-case-editor-console-log.png +0 -0
- package/assets/images/test-case-editor-environment-state.png +0 -0
- package/assets/images/test-case-editor-scripts.png +0 -0
- package/assets/images/test-case-editor.png +0 -0
- package/assets/images/testcase-definition-download.png +0 -0
- package/assets/images/testcase-definition-edit-meta-info.png +0 -0
- package/assets/images/testing-toolkit-mojaloop-testing-toolkit-endpoint.png +0 -0
- package/assets/images/tls-hub-certs-keys.png +0 -0
- package/assets/images/tls-jws-enabled-on-environment.png +0 -0
- package/assets/images/updated-sample-body-data.png +0 -0
- package/assets/images/using-configurable-parameter.png +0 -0
- package/assets/images/validation-rules-screen.png +0 -0
- package/assets/images/view-response.png +0 -0
- package/audit-ci.jsonc +7 -0
- package/connection-manager/docker-compose.yml +55 -0
- package/database/docker-compose.yml +16 -0
- package/docker/hosted-mode/docker-compose.yaml +107 -0
- package/docker/hosted-mode/keycloak/keycloak-realm.json +2298 -0
- package/docker/hosted-mode/mongo-init.sh +1 -0
- package/docker/hosted-mode-tls/docker-compose.yaml +171 -0
- package/docker/hosted-mode-tls/keycloak/keycloak-realm.json +2298 -0
- package/docker/hosted-mode-tls/mongo-init.sh +1 -0
- package/docker-compose.yml +62 -0
- package/documents/Mojaloop-Testing-Toolkit.md +296 -0
- package/documents/RULES_ENGINE.md +403 -0
- package/documents/User-Guide-API-Provisioning.md +121 -0
- package/documents/User-Guide-CLI.md +218 -0
- package/documents/User-Guide-Connection-Manager.md +282 -0
- package/documents/User-Guide-Frequently-Asked-Questions.md +39 -0
- package/documents/User-Guide-Hosted-Mode-Docker-Compose.md +110 -0
- package/documents/User-Guide-Installation.md +163 -0
- package/documents/User-Guide-Mojaloop-Testing-Toolkit.md +642 -0
- package/documents/User-Guide-OAuth-Server-Deployment.md +283 -0
- package/documents/User-Guide-Onboarding-DFSP.md +197 -0
- package/documents/User-Guide-Onboarding-HUB.md +191 -0
- package/documents/User-Guide.md +53 -0
- package/examples/collections/dfsp/p2p_failed_tests.json +7161 -0
- package/examples/collections/dfsp/p2p_fx_happy_path.json +502 -0
- package/examples/collections/dfsp/p2p_happy_path.json +350 -0
- package/examples/collections/dfsp/p2p_happy_path_extended.json +6106 -0
- package/examples/collections/dfsp/p2p_happy_path_jws.json +511 -0
- package/examples/collections/dfsp/p2p_payee_assertions_websocket.json +441 -0
- package/examples/collections/dfsp/sample.json +5029 -0
- package/examples/collections/dfsp/transaction_request_service.json +240 -0
- package/examples/collections/fxp/FXP.json +264 -0
- package/examples/collections/fxp/SDK_backend.json +98 -0
- package/examples/collections/fxp/SDK_outbound.json +163 -0
- package/examples/collections/hub/hub_01_p2p_happy_path/hub_p2p_receive_quote.json +400 -0
- package/examples/collections/hub/hub_01_p2p_happy_path/hub_p2p_send_quote.json +395 -0
- package/examples/collections/hub/hub_02_block_transfer/hub_block_transfer.json +393 -0
- package/examples/collections/hub/hub_03_funds_in_out/hub_funds_in.json +224 -0
- package/examples/collections/hub/hub_03_funds_in_out/hub_funds_out.json +780 -0
- package/examples/collections/hub/hub_04_settlements/hub_settlements.json +3138 -0
- package/examples/collections/hub/hub_05_transfer_negative_scenarios/hub_transfer_negative_payee_abort.json +475 -0
- package/examples/collections/hub/hub_05_transfer_negative_scenarios/hub_transfer_negative_payee_invalid_fulfillment.json +370 -0
- package/examples/collections/hub/hub_05_transfer_negative_scenarios/hub_transfer_negative_transfer_timeout.json +262 -0
- package/examples/collections/hub/hub_06_transaction_requests_service/hub_trs_authorizations.json +117 -0
- package/examples/collections/hub/hub_06_transaction_requests_service/hub_trs_error_framework.json +591 -0
- package/examples/collections/hub/hub_06_transaction_requests_service/hub_trs_received_state.json +379 -0
- package/examples/collections/hub/hub_06_transaction_requests_service/hub_trs_reject_state.json +361 -0
- package/examples/collections/hub/hub_07_quoting_service.json +525 -0
- package/examples/collections/hub/hub_08_participant_inactive_stop_transfers.json +706 -0
- package/examples/collections/hub/hub_09_duplicate_handling_transfers.json +1377 -0
- package/examples/collections/hub/hub_10_on_us_transfers.json +245 -0
- package/examples/collections/hub/hub_11_accented_and_spl_chars.json +629 -0
- package/examples/collections/hub/hub_12_fspiop_version_1.1.json +646 -0
- package/examples/collections/hub/hub_13_bulk_transfers.json +1857 -0
- package/examples/collections/iso20022/self_referencing_iso20022.json +926 -0
- package/examples/collections/provisioning/testingtoolkitdfsp.json +904 -0
- package/examples/environments/dfsp_local_environment.json +46 -0
- package/examples/environments/hub_local_environment.json +57 -0
- package/jest.config.js +17 -0
- package/package.json +199 -0
- package/sbom-v18.12.4.csv +1553 -0
- package/secrets/keygen.sh +5 -0
- package/secrets/privatekey.pem +27 -0
- package/secrets/publickey.cer +21 -0
- package/secrets/tls/01.pem +132 -0
- package/secrets/tls/createSecrets.sh +20 -0
- package/secrets/tls/hub_client.csr +32 -0
- package/secrets/tls/hub_client_cacert.pem +35 -0
- package/secrets/tls/hub_client_cakey.pem +52 -0
- package/secrets/tls/hub_client_key.key +52 -0
- package/secrets/tls/hub_server.csr +31 -0
- package/secrets/tls/hub_server_cacert.pem +35 -0
- package/secrets/tls/hub_server_cakey.pem +52 -0
- package/secrets/tls/hub_server_cert.pem +132 -0
- package/secrets/tls/hub_server_key.key +52 -0
- package/secrets/tls/index.txt +1 -0
- package/secrets/tls/index.txt.attr +1 -0
- package/secrets/tls/openssl-client.cnf +36 -0
- package/secrets/tls/openssl-clientca.cnf +71 -0
- package/secrets/tls/openssl-server.cnf +39 -0
- package/secrets/tls/openssl-serverca.cnf +71 -0
- package/secrets/tls/serial.txt +1 -0
- package/spec_files/api_definitions/als_admin_1.1/api_spec.yaml +804 -0
- package/spec_files/api_definitions/central_admin_1.0/api_spec.yaml +1850 -0
- package/spec_files/api_definitions/central_admin_1.0/response_map.json +96 -0
- package/spec_files/api_definitions/central_admin_old_9.3/api_spec.yaml +2467 -0
- package/spec_files/api_definitions/central_admin_old_9.3/response_map.json +96 -0
- package/spec_files/api_definitions/fspiop_1.0/api_spec.yaml +4187 -0
- package/spec_files/api_definitions/fspiop_1.0/callback_map.json +568 -0
- package/spec_files/api_definitions/fspiop_1.0/mockRef.json +79 -0
- package/spec_files/api_definitions/fspiop_1.0/trigger_templates/transaction_request_followup.json +126 -0
- package/spec_files/api_definitions/fspiop_1.0/trigger_templates/transaction_request_followup_quotes_only.json +97 -0
- package/spec_files/api_definitions/fspiop_1.1/api_spec.yaml +3778 -0
- package/spec_files/api_definitions/fspiop_1.1/callback_map.json +568 -0
- package/spec_files/api_definitions/fspiop_1.1/mockRef.json +79 -0
- package/spec_files/api_definitions/fspiop_1.1/trigger_templates/transaction_request_followup.json +125 -0
- package/spec_files/api_definitions/fspiop_2.0/api_spec.yaml +4839 -0
- package/spec_files/api_definitions/fspiop_2.0/callback_map.json +716 -0
- package/spec_files/api_definitions/fspiop_2.0/mockRef.json +79 -0
- package/spec_files/api_definitions/fspiop_2.0/trigger_templates/transaction_request_followup.json +125 -0
- package/spec_files/api_definitions/fspiop_2.0_iso20022/api_spec.yaml +8331 -0
- package/spec_files/api_definitions/fspiop_2.0_iso20022/callback_map.json +508 -0
- package/spec_files/api_definitions/fspiop_2.0_iso20022/mockRef.json +66 -0
- package/spec_files/api_definitions/fx-api_2.0/api_spec.yaml +1768 -0
- package/spec_files/api_definitions/fx-api_2.0/callback_map.json +188 -0
- package/spec_files/api_definitions/fx-api_2.0/mockRef.json +83 -0
- package/spec_files/api_definitions/mojaloop_sdk_outbound_scheme_adapter_1.0/api_spec.yaml +2612 -0
- package/spec_files/api_definitions/mojaloop_sdk_outbound_scheme_adapter_1.0/mockRef.json +22 -0
- package/spec_files/api_definitions/mojaloop_sdk_outbound_scheme_adapter_1.0/response_map.json +35 -0
- package/spec_files/api_definitions/mojaloop_simulator_0.1/api_spec.yaml +225 -0
- package/spec_files/api_definitions/mojaloop_simulator_sim_1.4/api_spec.yaml +1087 -0
- package/spec_files/api_definitions/mojaloop_simulator_sim_1.4/mockRef.json +75 -0
- package/spec_files/api_definitions/mojaloop_simulator_sim_1.4/response_map.json +55 -0
- package/spec_files/api_definitions/payment_manager_1.4/api_spec.yaml +1389 -0
- package/spec_files/api_definitions/sdk-scheme-adapter-backend-v2_1_0-openapi3-snippets_2.1/api_spec.yaml +2834 -0
- package/spec_files/api_definitions/sdk-scheme-adapter-outbound-v2_1_0-openapi3-snippets_2.1/api_spec.yaml +3449 -0
- package/spec_files/api_definitions/settlements_1.0/api_spec.yaml +983 -0
- package/spec_files/api_definitions/settlements_1.0/mockRef.json +38 -0
- package/spec_files/api_definitions/settlements_1.0/response_map.json +34 -0
- package/spec_files/api_definitions/settlements_2.0/api_spec.yaml +1001 -0
- package/spec_files/api_definitions/settlements_2.0/mockRef.json +38 -0
- package/spec_files/api_definitions/settlements_2.0/response_map.json +34 -0
- package/spec_files/api_definitions/thirdparty_sdk_outbound_0.1/api_spec.yaml +2139 -0
- package/spec_files/reports/templates/newman/html_template.html +1202 -0
- package/spec_files/reports/templates/newman/pdf_template.html +790 -0
- package/spec_files/reports/templates/testcase_definition/table_view.html +1602 -0
- package/spec_files/rules_callback/config.json +3 -0
- package/spec_files/rules_callback/default.json +2698 -0
- package/spec_files/rules_callback/p2p-limit.json +129 -0
- package/spec_files/rules_forward/config.json +3 -0
- package/spec_files/rules_forward/default.json +482 -0
- package/spec_files/rules_response/config.json +3 -0
- package/spec_files/rules_response/default.json +295 -0
- package/spec_files/rules_validation/config.json +3 -0
- package/spec_files/rules_validation/default.json +1 -0
- package/spec_files/rules_validation/p2p-limit.json +55 -0
- package/spec_files/system_config.json +175 -0
- package/spec_files/user_config.json +109 -0
- package/src/index.js +67 -0
- package/src/lib/MyEventEmitter.js +54 -0
- package/src/lib/api-management.js +143 -0
- package/src/lib/api-routes/config.js +83 -0
- package/src/lib/api-routes/history.js +139 -0
- package/src/lib/api-routes/keycloak.js +54 -0
- package/src/lib/api-routes/longpolling.js +70 -0
- package/src/lib/api-routes/oauth2.js +149 -0
- package/src/lib/api-routes/objectstore.js +53 -0
- package/src/lib/api-routes/openapi.js +224 -0
- package/src/lib/api-routes/outbound.js +134 -0
- package/src/lib/api-routes/reports.js +72 -0
- package/src/lib/api-routes/rules.js +356 -0
- package/src/lib/api-routes/samples.js +92 -0
- package/src/lib/api-routes/server-logs.js +44 -0
- package/src/lib/api-routes/settings.js +71 -0
- package/src/lib/api-server.js +135 -0
- package/src/lib/arrayStore.js +101 -0
- package/src/lib/callbackHandler.js +201 -0
- package/src/lib/config.js +177 -0
- package/src/lib/configuration-providers/mb-connection-manager.js +625 -0
- package/src/lib/db/adapters/dbAdapter.js +184 -0
- package/src/lib/db/dfspMockUsers.js +64 -0
- package/src/lib/db/models/mongoDBWrapper.js +78 -0
- package/src/lib/eventListenerClient/inboundEventListener.js +176 -0
- package/src/lib/fileAdapter.js +57 -0
- package/src/lib/httpAgentStore.js +135 -0
- package/src/lib/importExport.js +186 -0
- package/src/lib/jws/JwsSigning.js +141 -0
- package/src/lib/loadSamples.js +128 -0
- package/src/lib/logger.js +20 -0
- package/src/lib/longpollingEmitter.js +56 -0
- package/src/lib/metrics.js +51 -0
- package/src/lib/mocking/custom-functions/generic.js +57 -0
- package/src/lib/mocking/middleware-functions/ilpModel.js +238 -0
- package/src/lib/mocking/middleware-functions/quotesAssociation.js +75 -0
- package/src/lib/mocking/middleware-functions/transactionRequestsService.js +78 -0
- package/src/lib/mocking/openApiDefinitionsModel.js +64 -0
- package/src/lib/mocking/openApiMockHandler.js +466 -0
- package/src/lib/mocking/openApiRulesEngine.js +492 -0
- package/src/lib/mocking/openApiVersionTools.js +136 -0
- package/src/lib/mocking/transformers/fspiopToISO20022.js +230 -0
- package/src/lib/mocking/transformers/index.js +41 -0
- package/src/lib/notificationEmitter.js +64 -0
- package/src/lib/oauth/KeycloakHelper.js +220 -0
- package/src/lib/oauth/LoginService.js +133 -0
- package/src/lib/oauth/OAuthHelper.js +181 -0
- package/src/lib/oauth/OAuthValidator.js +118 -0
- package/src/lib/oauth/Wso2Client.js +64 -0
- package/src/lib/objectStore/inMemoryImpl.js +50 -0
- package/src/lib/objectStore/objectStoreInterface.js +51 -0
- package/src/lib/objectStore.js +122 -0
- package/src/lib/report-generator/generator.js +126 -0
- package/src/lib/report-generator/helpers.js +154 -0
- package/src/lib/requestLogger.js +190 -0
- package/src/lib/resources/wso2carbon-publickey.cert +20 -0
- package/src/lib/rulesEngine.js +95 -0
- package/src/lib/rulesEngineModel.js +463 -0
- package/src/lib/scripting-engines/postman-sandbox.js +142 -0
- package/src/lib/scripting-engines/vm-javascript-sandbox.js +294 -0
- package/src/lib/server-logs/adapters/elastic-search.js +102 -0
- package/src/lib/server-logs/adapters/grafana.js +0 -0
- package/src/lib/server-logs/index.js +75 -0
- package/src/lib/socket-server.js +55 -0
- package/src/lib/storageAdapter.js +109 -0
- package/src/lib/test-outbound/TestCaseRunner.js +173 -0
- package/src/lib/test-outbound/getTracing.js +19 -0
- package/src/lib/test-outbound/outbound-initiator.js +1107 -0
- package/src/lib/uniqueIdGenerator.js +35 -0
- package/src/lib/utils.js +89 -0
- package/src/lib/utilsInternal.js +56 -0
- package/src/lib/webSocketClient/WebSocketClientManager.js +197 -0
- package/src/server.js +218 -0
|
@@ -0,0 +1,356 @@
|
|
|
1
|
+
/*****
|
|
2
|
+
License
|
|
3
|
+
--------------
|
|
4
|
+
Copyright © 2020-2025 Mojaloop Foundation
|
|
5
|
+
The Mojaloop files are made available by the Mojaloop Foundation under the Apache License, Version 2.0 (the "License") and you may not use these files except in compliance with the License. You may obtain a copy of the License at
|
|
6
|
+
|
|
7
|
+
http://www.apache.org/licenses/LICENSE-2.0
|
|
8
|
+
|
|
9
|
+
Unless required by applicable law or agreed to in writing, the Mojaloop files are distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
|
|
10
|
+
|
|
11
|
+
Contributors
|
|
12
|
+
--------------
|
|
13
|
+
This is the official list of the Mojaloop project contributors for this file.
|
|
14
|
+
Names of the original copyright holders (individuals or organizations)
|
|
15
|
+
should be listed with a '*' in the first column. People who have
|
|
16
|
+
contributed from an organization can be listed under the organization
|
|
17
|
+
that actually holds the copyright for their contributions (see the
|
|
18
|
+
Mojaloop Foundation for an example). Those individuals should have
|
|
19
|
+
their names indented and be marked with a '-'. Email address can be added
|
|
20
|
+
optionally within square brackets <email>.
|
|
21
|
+
|
|
22
|
+
* Mojaloop Foundation
|
|
23
|
+
- Name Surname <name.surname@mojaloop.io>
|
|
24
|
+
|
|
25
|
+
* ModusBox
|
|
26
|
+
* Vijaya Kumar Guthi <vijaya.guthi@modusbox.com> (Original Author)
|
|
27
|
+
--------------
|
|
28
|
+
******/
|
|
29
|
+
|
|
30
|
+
const express = require('express')
|
|
31
|
+
const importExport = require('../importExport')
|
|
32
|
+
const rulesEngineModel = require('../rulesEngineModel')
|
|
33
|
+
|
|
34
|
+
const router = new express.Router()
|
|
35
|
+
|
|
36
|
+
// Validation Rules
|
|
37
|
+
// Get all validation rules files
|
|
38
|
+
router.get('/files/validation', async (req, res, next) => {
|
|
39
|
+
try {
|
|
40
|
+
const result = await rulesEngineModel.getValidationRulesFiles(req.user)
|
|
41
|
+
res.status(200).json(result)
|
|
42
|
+
} catch (err) {
|
|
43
|
+
res.status(500).json({ error: err && err.message })
|
|
44
|
+
}
|
|
45
|
+
})
|
|
46
|
+
|
|
47
|
+
// Route to get content of a validation rule file
|
|
48
|
+
router.get('/files/validation/:fileName', async (req, res, next) => {
|
|
49
|
+
const fileName = req.params.fileName
|
|
50
|
+
try {
|
|
51
|
+
const result = await rulesEngineModel.getValidationRulesFileContent(fileName, req.user)
|
|
52
|
+
res.status(200).json(result)
|
|
53
|
+
} catch (err) {
|
|
54
|
+
res.status(500).json({ error: err && err.message })
|
|
55
|
+
}
|
|
56
|
+
})
|
|
57
|
+
|
|
58
|
+
// Route to edit a validation rule file
|
|
59
|
+
router.put('/files/validation/:fileName', async (req, res, next) => {
|
|
60
|
+
const fileName = req.params.fileName
|
|
61
|
+
|
|
62
|
+
try {
|
|
63
|
+
await rulesEngineModel.setValidationRulesFileContent(fileName, req.body, req.user)
|
|
64
|
+
res.status(200).json({ status: 'OK' })
|
|
65
|
+
} catch (err) {
|
|
66
|
+
res.status(500).json({ error: err && err.message })
|
|
67
|
+
}
|
|
68
|
+
})
|
|
69
|
+
|
|
70
|
+
// Route to delete a validation rule file
|
|
71
|
+
router.delete('/files/validation/:fileName', async (req, res, next) => {
|
|
72
|
+
const fileName = req.params.fileName
|
|
73
|
+
|
|
74
|
+
try {
|
|
75
|
+
await rulesEngineModel.deleteValidationRulesFile(fileName, req.user)
|
|
76
|
+
res.status(200).json({ status: 'OK' })
|
|
77
|
+
} catch (err) {
|
|
78
|
+
res.status(500).json({ error: err && err.message })
|
|
79
|
+
}
|
|
80
|
+
})
|
|
81
|
+
|
|
82
|
+
// Route to modify configuration in validation rules
|
|
83
|
+
router.put('/files/validation', async (req, res, next) => {
|
|
84
|
+
const reqType = req.body.type
|
|
85
|
+
try {
|
|
86
|
+
switch (reqType) {
|
|
87
|
+
case 'activeRulesFile':
|
|
88
|
+
await rulesEngineModel.setActiveValidationRulesFile(req.body.fileName, req.user)
|
|
89
|
+
res.status(200).json({ status: 'OK' })
|
|
90
|
+
break
|
|
91
|
+
default:
|
|
92
|
+
throw (new Error('Unknown update type'))
|
|
93
|
+
}
|
|
94
|
+
} catch (err) {
|
|
95
|
+
res.status(500).json({ error: err && err.message })
|
|
96
|
+
}
|
|
97
|
+
})
|
|
98
|
+
|
|
99
|
+
// Callback Rules
|
|
100
|
+
// Get all callback rules files
|
|
101
|
+
router.get('/files/callback', async (req, res, next) => {
|
|
102
|
+
try {
|
|
103
|
+
const result = await rulesEngineModel.getCallbackRulesFiles(req.user)
|
|
104
|
+
res.status(200).json(result)
|
|
105
|
+
} catch (err) {
|
|
106
|
+
res.status(500).json({ error: err && err.message })
|
|
107
|
+
}
|
|
108
|
+
})
|
|
109
|
+
|
|
110
|
+
// Route to get content of a callback rule file
|
|
111
|
+
router.get('/files/callback/:fileName', async (req, res, next) => {
|
|
112
|
+
const fileName = req.params.fileName
|
|
113
|
+
|
|
114
|
+
try {
|
|
115
|
+
const result = await rulesEngineModel.getCallbackRulesFileContent(fileName, req.user)
|
|
116
|
+
res.status(200).json(result)
|
|
117
|
+
} catch (err) {
|
|
118
|
+
res.status(500).json({ error: err && err.message })
|
|
119
|
+
}
|
|
120
|
+
})
|
|
121
|
+
|
|
122
|
+
// Route to edit a callback rule file
|
|
123
|
+
router.put('/files/callback/:fileName', async (req, res, next) => {
|
|
124
|
+
const fileName = req.params.fileName
|
|
125
|
+
|
|
126
|
+
try {
|
|
127
|
+
await rulesEngineModel.setCallbackRulesFileContent(fileName, req.body, req.user)
|
|
128
|
+
res.status(200).json({ status: 'OK' })
|
|
129
|
+
} catch (err) {
|
|
130
|
+
res.status(500).json({ error: err && err.message })
|
|
131
|
+
}
|
|
132
|
+
})
|
|
133
|
+
|
|
134
|
+
// Route to delete a callback rule file
|
|
135
|
+
router.delete('/files/callback/:fileName', async (req, res, next) => {
|
|
136
|
+
const fileName = req.params.fileName
|
|
137
|
+
|
|
138
|
+
try {
|
|
139
|
+
await rulesEngineModel.deleteCallbackRulesFile(fileName, req.user)
|
|
140
|
+
res.status(200).json({ status: 'OK' })
|
|
141
|
+
} catch (err) {
|
|
142
|
+
res.status(500).json({ error: err && err.message })
|
|
143
|
+
}
|
|
144
|
+
})
|
|
145
|
+
|
|
146
|
+
// Route to modify configuration in callback rules
|
|
147
|
+
router.put('/files/callback', async (req, res, next) => {
|
|
148
|
+
const reqType = req.body.type
|
|
149
|
+
try {
|
|
150
|
+
switch (reqType) {
|
|
151
|
+
case 'activeRulesFile':
|
|
152
|
+
await rulesEngineModel.setActiveCallbackRulesFile(req.body.fileName, req.user)
|
|
153
|
+
res.status(200).json({ status: 'OK' })
|
|
154
|
+
break
|
|
155
|
+
default:
|
|
156
|
+
throw (new Error('Unknown update type'))
|
|
157
|
+
}
|
|
158
|
+
} catch (err) {
|
|
159
|
+
res.status(500).json({ error: err && err.message })
|
|
160
|
+
}
|
|
161
|
+
})
|
|
162
|
+
|
|
163
|
+
// Response Rules
|
|
164
|
+
// Get all response rules files
|
|
165
|
+
router.get('/files/response', async (req, res, next) => {
|
|
166
|
+
try {
|
|
167
|
+
const result = await rulesEngineModel.getResponseRulesFiles(req.user)
|
|
168
|
+
res.status(200).json(result)
|
|
169
|
+
} catch (err) {
|
|
170
|
+
res.status(500).json({ error: err && err.message })
|
|
171
|
+
}
|
|
172
|
+
})
|
|
173
|
+
|
|
174
|
+
// Route to get content of a response rule file
|
|
175
|
+
router.get('/files/response/:fileName', async (req, res, next) => {
|
|
176
|
+
const fileName = req.params.fileName
|
|
177
|
+
|
|
178
|
+
try {
|
|
179
|
+
const result = await rulesEngineModel.getResponseRulesFileContent(fileName, req.user)
|
|
180
|
+
res.status(200).json(result)
|
|
181
|
+
} catch (err) {
|
|
182
|
+
res.status(500).json({ error: err && err.message })
|
|
183
|
+
}
|
|
184
|
+
})
|
|
185
|
+
|
|
186
|
+
// Route to edit a response rule file
|
|
187
|
+
router.put('/files/response/:fileName', async (req, res, next) => {
|
|
188
|
+
const fileName = req.params.fileName
|
|
189
|
+
|
|
190
|
+
try {
|
|
191
|
+
await rulesEngineModel.setResponseRulesFileContent(fileName, req.body, req.user)
|
|
192
|
+
res.status(200).json({ status: 'OK' })
|
|
193
|
+
} catch (err) {
|
|
194
|
+
res.status(500).json({ error: err && err.message })
|
|
195
|
+
}
|
|
196
|
+
})
|
|
197
|
+
|
|
198
|
+
// Route to delete a response rule file
|
|
199
|
+
router.delete('/files/response/:fileName', async (req, res, next) => {
|
|
200
|
+
const fileName = req.params.fileName
|
|
201
|
+
|
|
202
|
+
try {
|
|
203
|
+
await rulesEngineModel.deleteResponseRulesFile(fileName, req.user)
|
|
204
|
+
res.status(200).json({ status: 'OK' })
|
|
205
|
+
} catch (err) {
|
|
206
|
+
res.status(500).json({ error: err && err.message })
|
|
207
|
+
}
|
|
208
|
+
})
|
|
209
|
+
|
|
210
|
+
// Route to modify configuration in response rules
|
|
211
|
+
router.put('/files/response', async (req, res, next) => {
|
|
212
|
+
const reqType = req.body.type
|
|
213
|
+
try {
|
|
214
|
+
switch (reqType) {
|
|
215
|
+
case 'activeRulesFile':
|
|
216
|
+
await rulesEngineModel.setActiveResponseRulesFile(req.body.fileName, req.user)
|
|
217
|
+
res.status(200).json({ status: 'OK' })
|
|
218
|
+
break
|
|
219
|
+
default:
|
|
220
|
+
throw (new Error('Unknown update type'))
|
|
221
|
+
}
|
|
222
|
+
} catch (err) {
|
|
223
|
+
res.status(500).json({ error: err && err.message })
|
|
224
|
+
}
|
|
225
|
+
})
|
|
226
|
+
|
|
227
|
+
// Forward Rules
|
|
228
|
+
// Get all forward rules files
|
|
229
|
+
router.get('/files/forward', async (req, res, next) => {
|
|
230
|
+
try {
|
|
231
|
+
const result = await rulesEngineModel.getForwardRulesFiles(req.user)
|
|
232
|
+
res.status(200).json(result)
|
|
233
|
+
} catch (err) {
|
|
234
|
+
res.status(500).json({ error: err && err.message })
|
|
235
|
+
}
|
|
236
|
+
})
|
|
237
|
+
|
|
238
|
+
// Route to get content of a forward rule file
|
|
239
|
+
router.get('/files/forward/:fileName', async (req, res, next) => {
|
|
240
|
+
const fileName = req.params.fileName
|
|
241
|
+
try {
|
|
242
|
+
const result = await rulesEngineModel.getForwardRulesFileContent(fileName, req.user)
|
|
243
|
+
res.status(200).json(result)
|
|
244
|
+
} catch (err) {
|
|
245
|
+
res.status(500).json({ error: err && err.message })
|
|
246
|
+
}
|
|
247
|
+
})
|
|
248
|
+
|
|
249
|
+
// Route to edit a forward rule file
|
|
250
|
+
router.put('/files/forward/:fileName', async (req, res, next) => {
|
|
251
|
+
const fileName = req.params.fileName
|
|
252
|
+
|
|
253
|
+
try {
|
|
254
|
+
await rulesEngineModel.setForwardRulesFileContent(fileName, req.body, req.user)
|
|
255
|
+
res.status(200).json({ status: 'OK' })
|
|
256
|
+
} catch (err) {
|
|
257
|
+
res.status(500).json({ error: err && err.message })
|
|
258
|
+
}
|
|
259
|
+
})
|
|
260
|
+
|
|
261
|
+
// Route to delete a callback rule file
|
|
262
|
+
router.delete('/files/forward/:fileName', async (req, res, next) => {
|
|
263
|
+
const fileName = req.params.fileName
|
|
264
|
+
|
|
265
|
+
try {
|
|
266
|
+
await rulesEngineModel.deleteForwardRulesFile(fileName, req.user)
|
|
267
|
+
res.status(200).json({ status: 'OK' })
|
|
268
|
+
} catch (err) {
|
|
269
|
+
res.status(500).json({ error: err && err.message })
|
|
270
|
+
}
|
|
271
|
+
})
|
|
272
|
+
|
|
273
|
+
// Route to modify configuration in forward rules
|
|
274
|
+
router.put('/files/forward', async (req, res, next) => {
|
|
275
|
+
const reqType = req.body.type
|
|
276
|
+
try {
|
|
277
|
+
switch (reqType) {
|
|
278
|
+
case 'activeRulesFile':
|
|
279
|
+
await rulesEngineModel.setActiveForwardRulesFile(req.body.fileName, req.user)
|
|
280
|
+
res.status(200).json({ status: 'OK' })
|
|
281
|
+
break
|
|
282
|
+
default:
|
|
283
|
+
throw (new Error('Unknown update type'))
|
|
284
|
+
}
|
|
285
|
+
} catch (err) {
|
|
286
|
+
res.status(500).json({ error: err && err.message })
|
|
287
|
+
}
|
|
288
|
+
})
|
|
289
|
+
|
|
290
|
+
router.get('/files/response/:fileName/export', async (req, res, next) => {
|
|
291
|
+
try {
|
|
292
|
+
const fileName = req.params.fileName
|
|
293
|
+
const path = `rules_response/${fileName}`
|
|
294
|
+
const resp = await importExport.exportSpecFile(path, req.user)
|
|
295
|
+
res.status(200).json({ status: 'OK', body: resp })
|
|
296
|
+
} catch (err) {
|
|
297
|
+
res.status(404).json({ error: err && err.message })
|
|
298
|
+
}
|
|
299
|
+
})
|
|
300
|
+
|
|
301
|
+
router.post('/files/response/import', async (req, res, next) => {
|
|
302
|
+
try {
|
|
303
|
+
const path = `rules_response/${req.query.rulesFilename}`
|
|
304
|
+
await importExport.importSpecFile(req.body.buffer, path, req.user)
|
|
305
|
+
await rulesEngineModel.reloadResponseRules(req.user)
|
|
306
|
+
res.status(200).json({ status: 'OK' })
|
|
307
|
+
} catch (err) {
|
|
308
|
+
res.status(400).send(err.message)
|
|
309
|
+
}
|
|
310
|
+
})
|
|
311
|
+
|
|
312
|
+
router.get('/files/callback/:fileName/export', async (req, res, next) => {
|
|
313
|
+
try {
|
|
314
|
+
const fileName = req.params.fileName
|
|
315
|
+
const path = `rules_callback/${fileName}`
|
|
316
|
+
const resp = await importExport.exportSpecFile(path, req.user)
|
|
317
|
+
res.status(200).json({ status: 'OK', body: resp })
|
|
318
|
+
} catch (err) {
|
|
319
|
+
res.status(404).json({ error: err && err.message })
|
|
320
|
+
}
|
|
321
|
+
})
|
|
322
|
+
|
|
323
|
+
router.post('/files/callback/import', async (req, res, next) => {
|
|
324
|
+
try {
|
|
325
|
+
const path = `rules_callback/${req.query.rulesFilename}`
|
|
326
|
+
await importExport.importSpecFile(req.body.buffer, path, req.user)
|
|
327
|
+
await rulesEngineModel.reloadCallbackRules(req.user)
|
|
328
|
+
res.status(200).json({ status: 'OK' })
|
|
329
|
+
} catch (err) {
|
|
330
|
+
res.status(400).send(err.message)
|
|
331
|
+
}
|
|
332
|
+
})
|
|
333
|
+
|
|
334
|
+
router.get('/files/validation/:fileName/export', async (req, res, next) => {
|
|
335
|
+
try {
|
|
336
|
+
const fileName = req.params.fileName
|
|
337
|
+
const path = `rules_validation/${fileName}`
|
|
338
|
+
const resp = await importExport.exportSpecFile(path, req.user)
|
|
339
|
+
res.status(200).json({ status: 'OK', body: resp })
|
|
340
|
+
} catch (err) {
|
|
341
|
+
res.status(404).json({ error: err && err.message })
|
|
342
|
+
}
|
|
343
|
+
})
|
|
344
|
+
|
|
345
|
+
router.post('/files/validation/import', async (req, res, next) => {
|
|
346
|
+
try {
|
|
347
|
+
const path = `rules_validation/${req.query.rulesFilename}`
|
|
348
|
+
await importExport.importSpecFile(req.body.buffer, path, req.user)
|
|
349
|
+
await rulesEngineModel.reloadValidationRules(req.user)
|
|
350
|
+
res.status(200).json({ status: 'OK' })
|
|
351
|
+
} catch (err) {
|
|
352
|
+
res.status(400).send(err.message)
|
|
353
|
+
}
|
|
354
|
+
})
|
|
355
|
+
|
|
356
|
+
module.exports = router
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
/*****
|
|
2
|
+
License
|
|
3
|
+
--------------
|
|
4
|
+
Copyright © 2020-2025 Mojaloop Foundation
|
|
5
|
+
The Mojaloop files are made available by the Mojaloop Foundation under the Apache License, Version 2.0 (the "License") and you may not use these files except in compliance with the License. You may obtain a copy of the License at
|
|
6
|
+
|
|
7
|
+
http://www.apache.org/licenses/LICENSE-2.0
|
|
8
|
+
|
|
9
|
+
Unless required by applicable law or agreed to in writing, the Mojaloop files are distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
|
|
10
|
+
|
|
11
|
+
Contributors
|
|
12
|
+
--------------
|
|
13
|
+
This is the official list of the Mojaloop project contributors for this file.
|
|
14
|
+
Names of the original copyright holders (individuals or organizations)
|
|
15
|
+
should be listed with a '*' in the first column. People who have
|
|
16
|
+
contributed from an organization can be listed under the organization
|
|
17
|
+
that actually holds the copyright for their contributions (see the
|
|
18
|
+
Mojaloop Foundation for an example). Those individuals should have
|
|
19
|
+
their names indented and be marked with a '-'. Email address can be added
|
|
20
|
+
optionally within square brackets <email>.
|
|
21
|
+
|
|
22
|
+
* Mojaloop Foundation
|
|
23
|
+
- Name Surname <name.surname@mojaloop.io>
|
|
24
|
+
|
|
25
|
+
* ModusBox
|
|
26
|
+
* Georgi Logodazhki <georgi.logodazhki@modusbox.com> (Original Author)
|
|
27
|
+
--------------
|
|
28
|
+
******/
|
|
29
|
+
|
|
30
|
+
const express = require('express')
|
|
31
|
+
const loadSamples = require('../loadSamples')
|
|
32
|
+
const Config = require('../config')
|
|
33
|
+
|
|
34
|
+
const router = new express.Router()
|
|
35
|
+
|
|
36
|
+
const filterDFSPSamples = (files) => {
|
|
37
|
+
if (Config.getSystemConfig().HOSTING_ENABLED) {
|
|
38
|
+
return files.filter(file => file.name.startsWith('examples/collections/dfsp') || file.name.startsWith('examples/environments/dfsp'))
|
|
39
|
+
}
|
|
40
|
+
return files
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
// Route to load a sample
|
|
44
|
+
// query param 'collections': list of filenames
|
|
45
|
+
// query param 'environment': filename
|
|
46
|
+
router.get('/load', async (req, res, next) => {
|
|
47
|
+
try {
|
|
48
|
+
const files = await loadSamples.getSample(req.query)
|
|
49
|
+
return res.status(200).json({ status: 'OK', body: files })
|
|
50
|
+
} catch (err) {
|
|
51
|
+
res.status(500).json({ error: err && err.message })
|
|
52
|
+
}
|
|
53
|
+
})
|
|
54
|
+
|
|
55
|
+
// Route to load a sample in folder structure format
|
|
56
|
+
// query param 'collections': list of filenames
|
|
57
|
+
router.get('/loadFolderWise', async (req, res, next) => {
|
|
58
|
+
try {
|
|
59
|
+
const files = await loadSamples.getSampleWithFolderWise(req.query)
|
|
60
|
+
console.log('/loadFolderWise', files)
|
|
61
|
+
return res.status(200).json({ status: 'OK', body: files })
|
|
62
|
+
} catch (err) {
|
|
63
|
+
res.status(500).json({ error: err && err.message })
|
|
64
|
+
}
|
|
65
|
+
})
|
|
66
|
+
|
|
67
|
+
// Route to get root filenames
|
|
68
|
+
// uri param 'exampleType': supported values: 'collections', 'environments'
|
|
69
|
+
// query param 'type': examples: 'hub', 'dfsp'
|
|
70
|
+
router.get('/load/:exampleType', async (req, res, next) => {
|
|
71
|
+
try {
|
|
72
|
+
const filenames = await loadSamples.getCollectionsOrEnvironments(req.params.exampleType, req.query.type)
|
|
73
|
+
console.log('/load/:exampleType', filenames)
|
|
74
|
+
return res.status(200).json({ status: 'OK', body: filenames })
|
|
75
|
+
} catch (err) {
|
|
76
|
+
res.status(500).json({ error: err && err.message })
|
|
77
|
+
}
|
|
78
|
+
})
|
|
79
|
+
|
|
80
|
+
// Route to get root filenames with file size
|
|
81
|
+
// uri param 'exampleType': supported values: 'collections', 'environments'
|
|
82
|
+
// query param 'type': examples: 'hub', 'dfsp'
|
|
83
|
+
router.get('/list/:exampleType', async (req, res, next) => {
|
|
84
|
+
try {
|
|
85
|
+
const fileList = filterDFSPSamples(await loadSamples.getCollectionsOrEnvironmentsWithFileSize(req.params.exampleType, req.query.type))
|
|
86
|
+
return res.status(200).json({ status: 'OK', body: fileList })
|
|
87
|
+
} catch (err) {
|
|
88
|
+
res.status(500).json({ error: err && err.message })
|
|
89
|
+
}
|
|
90
|
+
})
|
|
91
|
+
|
|
92
|
+
module.exports = router
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
/*****
|
|
2
|
+
License
|
|
3
|
+
--------------
|
|
4
|
+
Copyright © 2020-2025 Mojaloop Foundation
|
|
5
|
+
The Mojaloop files are made available by the Mojaloop Foundation under the Apache License, Version 2.0 (the "License") and you may not use these files except in compliance with the License. You may obtain a copy of the License at
|
|
6
|
+
|
|
7
|
+
http://www.apache.org/licenses/LICENSE-2.0
|
|
8
|
+
|
|
9
|
+
Unless required by applicable law or agreed to in writing, the Mojaloop files are distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
|
|
10
|
+
|
|
11
|
+
Contributors
|
|
12
|
+
--------------
|
|
13
|
+
This is the official list of the Mojaloop project contributors for this file.
|
|
14
|
+
Names of the original copyright holders (individuals or organizations)
|
|
15
|
+
should be listed with a '*' in the first column. People who have
|
|
16
|
+
contributed from an organization can be listed under the organization
|
|
17
|
+
that actually holds the copyright for their contributions (see the
|
|
18
|
+
Mojaloop Foundation for an example). Those individuals should have
|
|
19
|
+
their names indented and be marked with a '-'. Email address can be added
|
|
20
|
+
optionally within square brackets <email>.
|
|
21
|
+
|
|
22
|
+
* Mojaloop Foundation
|
|
23
|
+
- Name Surname <name.surname@mojaloop.io>
|
|
24
|
+
|
|
25
|
+
* ModusBox
|
|
26
|
+
* Steven Oderayi <steven.oderayi@modusbox.com> (Original Author)
|
|
27
|
+
--------------
|
|
28
|
+
******/
|
|
29
|
+
|
|
30
|
+
const express = require('express')
|
|
31
|
+
const router = new express.Router()
|
|
32
|
+
const serverLogs = require('../server-logs')
|
|
33
|
+
|
|
34
|
+
router.get('/search', async (req, res, next) => {
|
|
35
|
+
try {
|
|
36
|
+
let results = []
|
|
37
|
+
if (Object.keys(req.query).length) results = await serverLogs.search({ query: req.query })
|
|
38
|
+
res.status(200).send(results)
|
|
39
|
+
} catch (err) {
|
|
40
|
+
res.status(500).json({ error: err && err.message })
|
|
41
|
+
}
|
|
42
|
+
})
|
|
43
|
+
|
|
44
|
+
module.exports = router
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
/*****
|
|
2
|
+
License
|
|
3
|
+
--------------
|
|
4
|
+
Copyright © 2020-2025 Mojaloop Foundation
|
|
5
|
+
The Mojaloop files are made available by the Mojaloop Foundation under the Apache License, Version 2.0 (the "License") and you may not use these files except in compliance with the License. You may obtain a copy of the License at
|
|
6
|
+
|
|
7
|
+
http://www.apache.org/licenses/LICENSE-2.0
|
|
8
|
+
|
|
9
|
+
Unless required by applicable law or agreed to in writing, the Mojaloop files are distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
|
|
10
|
+
|
|
11
|
+
Contributors
|
|
12
|
+
--------------
|
|
13
|
+
This is the official list of the Mojaloop project contributors for this file.
|
|
14
|
+
Names of the original copyright holders (individuals or organizations)
|
|
15
|
+
should be listed with a '*' in the first column. People who have
|
|
16
|
+
contributed from an organization can be listed under the organization
|
|
17
|
+
that actually holds the copyright for their contributions (see the
|
|
18
|
+
Mojaloop Foundation for an example). Those individuals should have
|
|
19
|
+
their names indented and be marked with a '-'. Email address can be added
|
|
20
|
+
optionally within square brackets <email>.
|
|
21
|
+
|
|
22
|
+
* Mojaloop Foundation
|
|
23
|
+
- Name Surname <name.surname@mojaloop.io>
|
|
24
|
+
|
|
25
|
+
* ModusBox
|
|
26
|
+
* Georgi Logodazhki <georgi.logodazhki@modusbox.com> (Original Author)
|
|
27
|
+
--------------
|
|
28
|
+
******/
|
|
29
|
+
|
|
30
|
+
const express = require('express')
|
|
31
|
+
const router = new express.Router()
|
|
32
|
+
const Config = require('../config')
|
|
33
|
+
const importExport = require('../importExport')
|
|
34
|
+
const RulesEngineModel = require('../rulesEngineModel')
|
|
35
|
+
|
|
36
|
+
// export and import from spec files
|
|
37
|
+
|
|
38
|
+
router.get('/export', async (req, res, next) => {
|
|
39
|
+
try {
|
|
40
|
+
if (!req.query || !req.query.options) {
|
|
41
|
+
res.status(400).send('options query param is required')
|
|
42
|
+
} else {
|
|
43
|
+
const resp = await importExport.exportSpecFiles(req.query.options, req.user)
|
|
44
|
+
res.status(200).json({ status: 'OK', body: resp })
|
|
45
|
+
}
|
|
46
|
+
} catch (err) {
|
|
47
|
+
// next(err)
|
|
48
|
+
res.status(404).json({ error: err && err.message })
|
|
49
|
+
}
|
|
50
|
+
})
|
|
51
|
+
|
|
52
|
+
router.post('/import', async (req, res, next) => {
|
|
53
|
+
try {
|
|
54
|
+
const options = req.query.options
|
|
55
|
+
await importExport.importSpecFiles(req.body.buffer, options, req.user)
|
|
56
|
+
for (const index in options) {
|
|
57
|
+
switch (options[index]) {
|
|
58
|
+
case 'rules_response': await RulesEngineModel.reloadResponseRules(req.user); break
|
|
59
|
+
case 'rules_callback': await RulesEngineModel.reloadCallbackRules(req.user); break
|
|
60
|
+
case 'rules_validation': await RulesEngineModel.reloadValidationRules(req.user); break
|
|
61
|
+
case 'user_config.json': await Config.loadUserConfig(req.user); break
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
res.status(200).json({ status: 'OK' })
|
|
65
|
+
} catch (err) {
|
|
66
|
+
res.status(400).send(err.message)
|
|
67
|
+
// next(err)
|
|
68
|
+
}
|
|
69
|
+
})
|
|
70
|
+
|
|
71
|
+
module.exports = router
|