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.
Files changed (319) hide show
  1. package/.dockerignore +10 -0
  2. package/.grype.yaml +16 -0
  3. package/.ncurc.yaml +9 -0
  4. package/.nvmrc +1 -0
  5. package/.versionrc.js +16 -0
  6. package/CHANGELOG.md +504 -0
  7. package/CODEOWNERS +30 -0
  8. package/Dockerfile +42 -0
  9. package/Dockerfile-newman +13 -0
  10. package/LICENSE.md +9 -0
  11. package/README.md +119 -0
  12. package/assets/diagrams/architectural/architectural-diagram.svg +3 -0
  13. package/assets/diagrams/flow/flow-diagram.svg +3 -0
  14. package/assets/images/Sample-Response-Failure.png +0 -0
  15. package/assets/images/Screenshot 2020-04-16 at 22.58.04.png +0 -0
  16. package/assets/images/TLS-Enabled-on-Environment.png +0 -0
  17. package/assets/images/adapter-mutual-tls-enabled.png +0 -0
  18. package/assets/images/add-additional-input-values.png +0 -0
  19. package/assets/images/add-condition-button.png +0 -0
  20. package/assets/images/add-new-assertion.png +0 -0
  21. package/assets/images/add-new-input-value.png +0 -0
  22. package/assets/images/add-new-input-variable.png +0 -0
  23. package/assets/images/additional-transfers.png +0 -0
  24. package/assets/images/api-provisioning-add-new-api-confirmation.png +0 -0
  25. package/assets/images/api-provisioning-file-input-window.png +0 -0
  26. package/assets/images/api-provisioning-list-apis-view.png +0 -0
  27. package/assets/images/api-provisioning-menu-item.png +0 -0
  28. package/assets/images/apply_and_restart.jpg +0 -0
  29. package/assets/images/assess-request-or-response.png +0 -0
  30. package/assets/images/assess-response-equation-save.png +0 -0
  31. package/assets/images/assess-response-equation.png +0 -0
  32. package/assets/images/assess-response-status.png +0 -0
  33. package/assets/images/building-new-rules-file.png +0 -0
  34. package/assets/images/callback-rules-screen.png +0 -0
  35. package/assets/images/configurable-parameter-assertion.png +0 -0
  36. package/assets/images/configurable-parameter-currency.png +0 -0
  37. package/assets/images/configurable-parameter.png +0 -0
  38. package/assets/images/connection-manager-ui-opening.png +0 -0
  39. package/assets/images/create-inbound-user-simulator.png +0 -0
  40. package/assets/images/creating-new-rule-file.png +0 -0
  41. package/assets/images/dfsp-client-cacert.png +0 -0
  42. package/assets/images/dfsp-client-submit.png +0 -0
  43. package/assets/images/dfsp-client.png +0 -0
  44. package/assets/images/dfsp-p2p-happy-path.png +0 -0
  45. package/assets/images/dfsp-server-cacert.png +0 -0
  46. package/assets/images/dfsp-server-cert.png +0 -0
  47. package/assets/images/download-report.png +0 -0
  48. package/assets/images/drive_have_not_been_shared.jpg +0 -0
  49. package/assets/images/event-response-options.png +0 -0
  50. package/assets/images/expand-monitoring-messages.png +0 -0
  51. package/assets/images/fixed-response-sample.png +0 -0
  52. package/assets/images/header-selection.png +0 -0
  53. package/assets/images/heap_error_windows.jpg +0 -0
  54. package/assets/images/hosted-mode-docker-compose-intro.png +0 -0
  55. package/assets/images/hub-client-cert.png +0 -0
  56. package/assets/images/import-template.png +0 -0
  57. package/assets/images/inbound-requests-environment.png +0 -0
  58. package/assets/images/inbound-requests-scripts.png +0 -0
  59. package/assets/images/jws-certificate-submit.png +0 -0
  60. package/assets/images/jws-certificate.png +0 -0
  61. package/assets/images/jws-certs-keys.png +0 -0
  62. package/assets/images/jws-hub-certs-keys.png +0 -0
  63. package/assets/images/local-enable-jws-publickey.png +0 -0
  64. package/assets/images/local-mutual-tls-enabled.png +0 -0
  65. package/assets/images/local_drives_to_be_available.jpg +0 -0
  66. package/assets/images/mcm-environment-opening.png +0 -0
  67. package/assets/images/menu-items.png +0 -0
  68. package/assets/images/mock-response-sample.png +0 -0
  69. package/assets/images/monitoring-initial-state.png +0 -0
  70. package/assets/images/monitoring-messages.png +0 -0
  71. package/assets/images/new-empty-assertion.png +0 -0
  72. package/assets/images/opened-imported-template.png +0 -0
  73. package/assets/images/opening-default-settings.png +0 -0
  74. package/assets/images/opening-sync-response-rules.png +0 -0
  75. package/assets/images/opening-view.png +0 -0
  76. package/assets/images/outbound-display-opening-hub.png +0 -0
  77. package/assets/images/outbound-display-opening.png +0 -0
  78. package/assets/images/override-with-environment-variable.png +0 -0
  79. package/assets/images/populate-with-sample-body.png +0 -0
  80. package/assets/images/resource-selection.png +0 -0
  81. package/assets/images/rule-builder-select-api.png +0 -0
  82. package/assets/images/sample-condition-add-configurable-params.png +0 -0
  83. package/assets/images/sample-condition.png +0 -0
  84. package/assets/images/sample-editor.png +0 -0
  85. package/assets/images/sample-request.png +0 -0
  86. package/assets/images/sample-test-assertion.png +0 -0
  87. package/assets/images/send-transfer.png +0 -0
  88. package/assets/images/sending-single-test-case-1.png +0 -0
  89. package/assets/images/sending-single-test-case-2.png +0 -0
  90. package/assets/images/sending-test-cases.png +0 -0
  91. package/assets/images/server-certificates-submitted.png +0 -0
  92. package/assets/images/simulator-response.png +0 -0
  93. package/assets/images/simulator-scheme-adapter-endpoint.png +0 -0
  94. package/assets/images/summarized-view-of-rule.png +0 -0
  95. package/assets/images/template-window.png +0 -0
  96. package/assets/images/test-case-editor-console-log.png +0 -0
  97. package/assets/images/test-case-editor-environment-state.png +0 -0
  98. package/assets/images/test-case-editor-scripts.png +0 -0
  99. package/assets/images/test-case-editor.png +0 -0
  100. package/assets/images/testcase-definition-download.png +0 -0
  101. package/assets/images/testcase-definition-edit-meta-info.png +0 -0
  102. package/assets/images/testing-toolkit-mojaloop-testing-toolkit-endpoint.png +0 -0
  103. package/assets/images/tls-hub-certs-keys.png +0 -0
  104. package/assets/images/tls-jws-enabled-on-environment.png +0 -0
  105. package/assets/images/updated-sample-body-data.png +0 -0
  106. package/assets/images/using-configurable-parameter.png +0 -0
  107. package/assets/images/validation-rules-screen.png +0 -0
  108. package/assets/images/view-response.png +0 -0
  109. package/audit-ci.jsonc +7 -0
  110. package/connection-manager/docker-compose.yml +55 -0
  111. package/database/docker-compose.yml +16 -0
  112. package/docker/hosted-mode/docker-compose.yaml +107 -0
  113. package/docker/hosted-mode/keycloak/keycloak-realm.json +2298 -0
  114. package/docker/hosted-mode/mongo-init.sh +1 -0
  115. package/docker/hosted-mode-tls/docker-compose.yaml +171 -0
  116. package/docker/hosted-mode-tls/keycloak/keycloak-realm.json +2298 -0
  117. package/docker/hosted-mode-tls/mongo-init.sh +1 -0
  118. package/docker-compose.yml +62 -0
  119. package/documents/Mojaloop-Testing-Toolkit.md +296 -0
  120. package/documents/RULES_ENGINE.md +403 -0
  121. package/documents/User-Guide-API-Provisioning.md +121 -0
  122. package/documents/User-Guide-CLI.md +218 -0
  123. package/documents/User-Guide-Connection-Manager.md +282 -0
  124. package/documents/User-Guide-Frequently-Asked-Questions.md +39 -0
  125. package/documents/User-Guide-Hosted-Mode-Docker-Compose.md +110 -0
  126. package/documents/User-Guide-Installation.md +163 -0
  127. package/documents/User-Guide-Mojaloop-Testing-Toolkit.md +642 -0
  128. package/documents/User-Guide-OAuth-Server-Deployment.md +283 -0
  129. package/documents/User-Guide-Onboarding-DFSP.md +197 -0
  130. package/documents/User-Guide-Onboarding-HUB.md +191 -0
  131. package/documents/User-Guide.md +53 -0
  132. package/examples/collections/dfsp/p2p_failed_tests.json +7161 -0
  133. package/examples/collections/dfsp/p2p_fx_happy_path.json +502 -0
  134. package/examples/collections/dfsp/p2p_happy_path.json +350 -0
  135. package/examples/collections/dfsp/p2p_happy_path_extended.json +6106 -0
  136. package/examples/collections/dfsp/p2p_happy_path_jws.json +511 -0
  137. package/examples/collections/dfsp/p2p_payee_assertions_websocket.json +441 -0
  138. package/examples/collections/dfsp/sample.json +5029 -0
  139. package/examples/collections/dfsp/transaction_request_service.json +240 -0
  140. package/examples/collections/fxp/FXP.json +264 -0
  141. package/examples/collections/fxp/SDK_backend.json +98 -0
  142. package/examples/collections/fxp/SDK_outbound.json +163 -0
  143. package/examples/collections/hub/hub_01_p2p_happy_path/hub_p2p_receive_quote.json +400 -0
  144. package/examples/collections/hub/hub_01_p2p_happy_path/hub_p2p_send_quote.json +395 -0
  145. package/examples/collections/hub/hub_02_block_transfer/hub_block_transfer.json +393 -0
  146. package/examples/collections/hub/hub_03_funds_in_out/hub_funds_in.json +224 -0
  147. package/examples/collections/hub/hub_03_funds_in_out/hub_funds_out.json +780 -0
  148. package/examples/collections/hub/hub_04_settlements/hub_settlements.json +3138 -0
  149. package/examples/collections/hub/hub_05_transfer_negative_scenarios/hub_transfer_negative_payee_abort.json +475 -0
  150. package/examples/collections/hub/hub_05_transfer_negative_scenarios/hub_transfer_negative_payee_invalid_fulfillment.json +370 -0
  151. package/examples/collections/hub/hub_05_transfer_negative_scenarios/hub_transfer_negative_transfer_timeout.json +262 -0
  152. package/examples/collections/hub/hub_06_transaction_requests_service/hub_trs_authorizations.json +117 -0
  153. package/examples/collections/hub/hub_06_transaction_requests_service/hub_trs_error_framework.json +591 -0
  154. package/examples/collections/hub/hub_06_transaction_requests_service/hub_trs_received_state.json +379 -0
  155. package/examples/collections/hub/hub_06_transaction_requests_service/hub_trs_reject_state.json +361 -0
  156. package/examples/collections/hub/hub_07_quoting_service.json +525 -0
  157. package/examples/collections/hub/hub_08_participant_inactive_stop_transfers.json +706 -0
  158. package/examples/collections/hub/hub_09_duplicate_handling_transfers.json +1377 -0
  159. package/examples/collections/hub/hub_10_on_us_transfers.json +245 -0
  160. package/examples/collections/hub/hub_11_accented_and_spl_chars.json +629 -0
  161. package/examples/collections/hub/hub_12_fspiop_version_1.1.json +646 -0
  162. package/examples/collections/hub/hub_13_bulk_transfers.json +1857 -0
  163. package/examples/collections/iso20022/self_referencing_iso20022.json +926 -0
  164. package/examples/collections/provisioning/testingtoolkitdfsp.json +904 -0
  165. package/examples/environments/dfsp_local_environment.json +46 -0
  166. package/examples/environments/hub_local_environment.json +57 -0
  167. package/jest.config.js +17 -0
  168. package/package.json +199 -0
  169. package/sbom-v18.12.4.csv +1553 -0
  170. package/secrets/keygen.sh +5 -0
  171. package/secrets/privatekey.pem +27 -0
  172. package/secrets/publickey.cer +21 -0
  173. package/secrets/tls/01.pem +132 -0
  174. package/secrets/tls/createSecrets.sh +20 -0
  175. package/secrets/tls/hub_client.csr +32 -0
  176. package/secrets/tls/hub_client_cacert.pem +35 -0
  177. package/secrets/tls/hub_client_cakey.pem +52 -0
  178. package/secrets/tls/hub_client_key.key +52 -0
  179. package/secrets/tls/hub_server.csr +31 -0
  180. package/secrets/tls/hub_server_cacert.pem +35 -0
  181. package/secrets/tls/hub_server_cakey.pem +52 -0
  182. package/secrets/tls/hub_server_cert.pem +132 -0
  183. package/secrets/tls/hub_server_key.key +52 -0
  184. package/secrets/tls/index.txt +1 -0
  185. package/secrets/tls/index.txt.attr +1 -0
  186. package/secrets/tls/openssl-client.cnf +36 -0
  187. package/secrets/tls/openssl-clientca.cnf +71 -0
  188. package/secrets/tls/openssl-server.cnf +39 -0
  189. package/secrets/tls/openssl-serverca.cnf +71 -0
  190. package/secrets/tls/serial.txt +1 -0
  191. package/spec_files/api_definitions/als_admin_1.1/api_spec.yaml +804 -0
  192. package/spec_files/api_definitions/central_admin_1.0/api_spec.yaml +1850 -0
  193. package/spec_files/api_definitions/central_admin_1.0/response_map.json +96 -0
  194. package/spec_files/api_definitions/central_admin_old_9.3/api_spec.yaml +2467 -0
  195. package/spec_files/api_definitions/central_admin_old_9.3/response_map.json +96 -0
  196. package/spec_files/api_definitions/fspiop_1.0/api_spec.yaml +4187 -0
  197. package/spec_files/api_definitions/fspiop_1.0/callback_map.json +568 -0
  198. package/spec_files/api_definitions/fspiop_1.0/mockRef.json +79 -0
  199. package/spec_files/api_definitions/fspiop_1.0/trigger_templates/transaction_request_followup.json +126 -0
  200. package/spec_files/api_definitions/fspiop_1.0/trigger_templates/transaction_request_followup_quotes_only.json +97 -0
  201. package/spec_files/api_definitions/fspiop_1.1/api_spec.yaml +3778 -0
  202. package/spec_files/api_definitions/fspiop_1.1/callback_map.json +568 -0
  203. package/spec_files/api_definitions/fspiop_1.1/mockRef.json +79 -0
  204. package/spec_files/api_definitions/fspiop_1.1/trigger_templates/transaction_request_followup.json +125 -0
  205. package/spec_files/api_definitions/fspiop_2.0/api_spec.yaml +4839 -0
  206. package/spec_files/api_definitions/fspiop_2.0/callback_map.json +716 -0
  207. package/spec_files/api_definitions/fspiop_2.0/mockRef.json +79 -0
  208. package/spec_files/api_definitions/fspiop_2.0/trigger_templates/transaction_request_followup.json +125 -0
  209. package/spec_files/api_definitions/fspiop_2.0_iso20022/api_spec.yaml +8331 -0
  210. package/spec_files/api_definitions/fspiop_2.0_iso20022/callback_map.json +508 -0
  211. package/spec_files/api_definitions/fspiop_2.0_iso20022/mockRef.json +66 -0
  212. package/spec_files/api_definitions/fx-api_2.0/api_spec.yaml +1768 -0
  213. package/spec_files/api_definitions/fx-api_2.0/callback_map.json +188 -0
  214. package/spec_files/api_definitions/fx-api_2.0/mockRef.json +83 -0
  215. package/spec_files/api_definitions/mojaloop_sdk_outbound_scheme_adapter_1.0/api_spec.yaml +2612 -0
  216. package/spec_files/api_definitions/mojaloop_sdk_outbound_scheme_adapter_1.0/mockRef.json +22 -0
  217. package/spec_files/api_definitions/mojaloop_sdk_outbound_scheme_adapter_1.0/response_map.json +35 -0
  218. package/spec_files/api_definitions/mojaloop_simulator_0.1/api_spec.yaml +225 -0
  219. package/spec_files/api_definitions/mojaloop_simulator_sim_1.4/api_spec.yaml +1087 -0
  220. package/spec_files/api_definitions/mojaloop_simulator_sim_1.4/mockRef.json +75 -0
  221. package/spec_files/api_definitions/mojaloop_simulator_sim_1.4/response_map.json +55 -0
  222. package/spec_files/api_definitions/payment_manager_1.4/api_spec.yaml +1389 -0
  223. package/spec_files/api_definitions/sdk-scheme-adapter-backend-v2_1_0-openapi3-snippets_2.1/api_spec.yaml +2834 -0
  224. package/spec_files/api_definitions/sdk-scheme-adapter-outbound-v2_1_0-openapi3-snippets_2.1/api_spec.yaml +3449 -0
  225. package/spec_files/api_definitions/settlements_1.0/api_spec.yaml +983 -0
  226. package/spec_files/api_definitions/settlements_1.0/mockRef.json +38 -0
  227. package/spec_files/api_definitions/settlements_1.0/response_map.json +34 -0
  228. package/spec_files/api_definitions/settlements_2.0/api_spec.yaml +1001 -0
  229. package/spec_files/api_definitions/settlements_2.0/mockRef.json +38 -0
  230. package/spec_files/api_definitions/settlements_2.0/response_map.json +34 -0
  231. package/spec_files/api_definitions/thirdparty_sdk_outbound_0.1/api_spec.yaml +2139 -0
  232. package/spec_files/reports/templates/newman/html_template.html +1202 -0
  233. package/spec_files/reports/templates/newman/pdf_template.html +790 -0
  234. package/spec_files/reports/templates/testcase_definition/table_view.html +1602 -0
  235. package/spec_files/rules_callback/config.json +3 -0
  236. package/spec_files/rules_callback/default.json +2698 -0
  237. package/spec_files/rules_callback/p2p-limit.json +129 -0
  238. package/spec_files/rules_forward/config.json +3 -0
  239. package/spec_files/rules_forward/default.json +482 -0
  240. package/spec_files/rules_response/config.json +3 -0
  241. package/spec_files/rules_response/default.json +295 -0
  242. package/spec_files/rules_validation/config.json +3 -0
  243. package/spec_files/rules_validation/default.json +1 -0
  244. package/spec_files/rules_validation/p2p-limit.json +55 -0
  245. package/spec_files/system_config.json +175 -0
  246. package/spec_files/user_config.json +109 -0
  247. package/src/index.js +67 -0
  248. package/src/lib/MyEventEmitter.js +54 -0
  249. package/src/lib/api-management.js +143 -0
  250. package/src/lib/api-routes/config.js +83 -0
  251. package/src/lib/api-routes/history.js +139 -0
  252. package/src/lib/api-routes/keycloak.js +54 -0
  253. package/src/lib/api-routes/longpolling.js +70 -0
  254. package/src/lib/api-routes/oauth2.js +149 -0
  255. package/src/lib/api-routes/objectstore.js +53 -0
  256. package/src/lib/api-routes/openapi.js +224 -0
  257. package/src/lib/api-routes/outbound.js +134 -0
  258. package/src/lib/api-routes/reports.js +72 -0
  259. package/src/lib/api-routes/rules.js +356 -0
  260. package/src/lib/api-routes/samples.js +92 -0
  261. package/src/lib/api-routes/server-logs.js +44 -0
  262. package/src/lib/api-routes/settings.js +71 -0
  263. package/src/lib/api-server.js +135 -0
  264. package/src/lib/arrayStore.js +101 -0
  265. package/src/lib/callbackHandler.js +201 -0
  266. package/src/lib/config.js +177 -0
  267. package/src/lib/configuration-providers/mb-connection-manager.js +625 -0
  268. package/src/lib/db/adapters/dbAdapter.js +184 -0
  269. package/src/lib/db/dfspMockUsers.js +64 -0
  270. package/src/lib/db/models/mongoDBWrapper.js +78 -0
  271. package/src/lib/eventListenerClient/inboundEventListener.js +176 -0
  272. package/src/lib/fileAdapter.js +57 -0
  273. package/src/lib/httpAgentStore.js +135 -0
  274. package/src/lib/importExport.js +186 -0
  275. package/src/lib/jws/JwsSigning.js +141 -0
  276. package/src/lib/loadSamples.js +128 -0
  277. package/src/lib/logger.js +20 -0
  278. package/src/lib/longpollingEmitter.js +56 -0
  279. package/src/lib/metrics.js +51 -0
  280. package/src/lib/mocking/custom-functions/generic.js +57 -0
  281. package/src/lib/mocking/middleware-functions/ilpModel.js +238 -0
  282. package/src/lib/mocking/middleware-functions/quotesAssociation.js +75 -0
  283. package/src/lib/mocking/middleware-functions/transactionRequestsService.js +78 -0
  284. package/src/lib/mocking/openApiDefinitionsModel.js +64 -0
  285. package/src/lib/mocking/openApiMockHandler.js +466 -0
  286. package/src/lib/mocking/openApiRulesEngine.js +492 -0
  287. package/src/lib/mocking/openApiVersionTools.js +136 -0
  288. package/src/lib/mocking/transformers/fspiopToISO20022.js +230 -0
  289. package/src/lib/mocking/transformers/index.js +41 -0
  290. package/src/lib/notificationEmitter.js +64 -0
  291. package/src/lib/oauth/KeycloakHelper.js +220 -0
  292. package/src/lib/oauth/LoginService.js +133 -0
  293. package/src/lib/oauth/OAuthHelper.js +181 -0
  294. package/src/lib/oauth/OAuthValidator.js +118 -0
  295. package/src/lib/oauth/Wso2Client.js +64 -0
  296. package/src/lib/objectStore/inMemoryImpl.js +50 -0
  297. package/src/lib/objectStore/objectStoreInterface.js +51 -0
  298. package/src/lib/objectStore.js +122 -0
  299. package/src/lib/report-generator/generator.js +126 -0
  300. package/src/lib/report-generator/helpers.js +154 -0
  301. package/src/lib/requestLogger.js +190 -0
  302. package/src/lib/resources/wso2carbon-publickey.cert +20 -0
  303. package/src/lib/rulesEngine.js +95 -0
  304. package/src/lib/rulesEngineModel.js +463 -0
  305. package/src/lib/scripting-engines/postman-sandbox.js +142 -0
  306. package/src/lib/scripting-engines/vm-javascript-sandbox.js +294 -0
  307. package/src/lib/server-logs/adapters/elastic-search.js +102 -0
  308. package/src/lib/server-logs/adapters/grafana.js +0 -0
  309. package/src/lib/server-logs/index.js +75 -0
  310. package/src/lib/socket-server.js +55 -0
  311. package/src/lib/storageAdapter.js +109 -0
  312. package/src/lib/test-outbound/TestCaseRunner.js +173 -0
  313. package/src/lib/test-outbound/getTracing.js +19 -0
  314. package/src/lib/test-outbound/outbound-initiator.js +1107 -0
  315. package/src/lib/uniqueIdGenerator.js +35 -0
  316. package/src/lib/utils.js +89 -0
  317. package/src/lib/utilsInternal.js +56 -0
  318. package/src/lib/webSocketClient/WebSocketClientManager.js +197 -0
  319. package/src/server.js +218 -0
@@ -0,0 +1,780 @@
1
+ {
2
+ "name": "hub-p2p-fundsinout-block-transfers",
3
+ "test_cases": [
4
+ {
5
+ "id": 2,
6
+ "name": "funds_out - Reserve&Commit",
7
+ "requests": [
8
+ {
9
+ "id": 1,
10
+ "description": "Record Funds Out Prepare&Reserve- payerfsp",
11
+ "apiVersion": {
12
+ "minorVersion": 3,
13
+ "majorVersion": 9,
14
+ "type": "central_admin"
15
+ },
16
+ "operationPath": "/participants/{name}/accounts/{id}",
17
+ "path": "/participants/{$inputs.fromFspId}/accounts/{$environment.accountId}",
18
+ "method": "post",
19
+ "params": {
20
+ "name": "{$inputs.fromFspId}",
21
+ "id": "{$environment.accountId}"
22
+ },
23
+ "headers": {
24
+ "FSPIOP-Source": "{$inputs.fromFspId}",
25
+ "Content-Type": "application/json"
26
+ },
27
+ "body": {
28
+ "transferId": "{$function.generic.generateID}",
29
+ "externalReference": "string",
30
+ "action": "recordFundsOutPrepareReserve",
31
+ "reason": "string",
32
+ "amount": {
33
+ "amount": "{$environment.fundsOutPrepareReserveAmount}",
34
+ "currency": "{$environment.currency}"
35
+ },
36
+ "extensionList": {
37
+ "extension": [
38
+ {
39
+ "key": "string",
40
+ "value": "string"
41
+ }
42
+ ]
43
+ }
44
+ },
45
+ "url": "{$inputs.HOST_CENTRAL_LEDGER}",
46
+ "tests": {
47
+ "assertions": [
48
+ {
49
+ "id": 1,
50
+ "description": "status code to be 202",
51
+ "exec": [
52
+ "expect(response.status).to.equal(202)"
53
+ ]
54
+ },
55
+ {
56
+ "id": 3,
57
+ "description": "hub Recon Account Balance After Funds In is as expected",
58
+ "exec": [
59
+ "expect(Number(environment.hubReconAccountBalanceAfterFundsOutPrepare)).to.equal(Number(environment.hubReconAccountBalanceBeforeFundsOutPrepare))"
60
+ ]
61
+ },
62
+ {
63
+ "id": 4,
64
+ "description": "payerfsp Settlement Account Balance After Funds In is as expected",
65
+ "exec": [
66
+ "expect(Number(environment.payerfspSettlementAccountBalanceAfterFundsOutPrepare)).to.equal(Number(environment.payerfspSettlementAccountBalanceBeforeFundsOutPrepare) + environment.fundsOutPrepareReserveAmount)"
67
+ ]
68
+ }
69
+ ]
70
+ },
71
+ "scripts": {
72
+ "preRequest": {
73
+ "exec": [
74
+ "pm.environment.set('fundsOutPrepareReserveAmount', 1000);\r",
75
+ "\r",
76
+ "const payerfspGetStatusRequest = {\r",
77
+ " url: pm.environment.get(\"HOST_CENTRAL_LEDGER\") + pm.environment.get(\"BASE_CENTRAL_LEDGER_ADMIN\") + '/participants/' + pm.environment.get(\"payerfsp\") + '/accounts',\r",
78
+ " method: 'GET',\r",
79
+ " header: {\r",
80
+ " \"Authorization\": \"Bearer \" + pm.environment.get(\"HUB_OPERATOR_BEARER_TOKEN\"),\r",
81
+ " \"FSPIOP-Source\": pm.environment.get(\"hub_operator\"),\r",
82
+ " \"Content-Type\": \"application/json\"\r",
83
+ " }\r",
84
+ "};\r",
85
+ "\r",
86
+ "pm.sendRequest(payerfspGetStatusRequest, function (err, response) {\r",
87
+ " console.log(response.json())\r",
88
+ " var jsonData = response.json()\r",
89
+ " for (var i in jsonData) {\r",
90
+ " if (jsonData[i].ledgerAccountType === 'SETTLEMENT' && (jsonData[i].currency === pm.environment.get(\"currency\"))) {\r",
91
+ " pm.environment.set(\"payerfspSettlementAccountId\", jsonData[i].id)\r",
92
+ " pm.environment.set(\"payerfspSettlementAccountBalanceBeforeFundsOutPrepare\", jsonData[i].value)\r",
93
+ " }\r",
94
+ " }\r",
95
+ "});\r",
96
+ "\r",
97
+ "const hubGetStatusRequest = {\r",
98
+ " url: pm.environment.get(\"HOST_CENTRAL_LEDGER\") + pm.environment.get(\"BASE_CENTRAL_LEDGER_ADMIN\") + '/participants/Hub/accounts',\r",
99
+ " method: 'GET',\r",
100
+ " header: {\r",
101
+ " \"Authorization\": \"Bearer \" + pm.environment.get(\"HUB_OPERATOR_BEARER_TOKEN\"),\r",
102
+ " \"FSPIOP-Source\": pm.environment.get(\"hub_operator\"),\r",
103
+ " \"Content-Type\": \"application/json\"\r",
104
+ " }\r",
105
+ "};\r",
106
+ "pm.sendRequest(hubGetStatusRequest, function (err, response) {\r",
107
+ " console.log(response.json())\r",
108
+ " var jsonData = response.json()\r",
109
+ " for (var i in jsonData) {\r",
110
+ " if (jsonData[i].ledgerAccountType === 'HUB_RECONCILIATION' && (jsonData[i].currency === pm.environment.get(\"currency\"))) {\r",
111
+ " pm.environment.set(\"hubReconAccountBalanceBeforeFundsOutPrepare\", jsonData[i].value)\r",
112
+ " }\r",
113
+ " }\r",
114
+ "});"
115
+ ]
116
+ },
117
+ "postRequest": {
118
+ "exec": [
119
+ "setTimeout(function () {\r",
120
+ " const payerfspGetStatusRequest = {\r",
121
+ " url: pm.environment.get(\"HOST_CENTRAL_LEDGER\") + pm.environment.get(\"BASE_CENTRAL_LEDGER_ADMIN\") + '/participants/' + pm.environment.get(\"payerfsp\") + '/accounts',\r",
122
+ " method: 'GET',\r",
123
+ " header: {\r",
124
+ " \"Authorization\": \"Bearer \" + pm.environment.get(\"HUB_OPERATOR_BEARER_TOKEN\"),\r",
125
+ " \"FSPIOP-Source\": pm.environment.get(\"hub_operator\"),\r",
126
+ " \"Content-Type\": \"application/json\"\r",
127
+ " }\r",
128
+ " };\r",
129
+ " pm.sendRequest(payerfspGetStatusRequest, function (err, response) {\r",
130
+ " console.log(response.json())\r",
131
+ " var jsonData = response.json()\r",
132
+ " var payerfspSettlementAccountBalanceAfterFundsOutPrepare\r",
133
+ " for (var i in jsonData) {\r",
134
+ " if (jsonData[i].ledgerAccountType === 'SETTLEMENT' && (jsonData[i].currency === pm.environment.get(\"currency\"))) {\r",
135
+ " pm.environment.set(\"payerfspSettlementAccountBalanceAfterFundsOutPrepare\", jsonData[i].value)\r",
136
+ " }\r",
137
+ " }\r",
138
+ "\r",
139
+ " });\r",
140
+ "\r",
141
+ " const hubGetStatusRequest = {\r",
142
+ " url: pm.environment.get(\"HOST_CENTRAL_LEDGER\") + pm.environment.get(\"BASE_CENTRAL_LEDGER_ADMIN\") + '/participants/Hub/accounts',\r",
143
+ " method: 'GET',\r",
144
+ " header: {\r",
145
+ " \"Authorization\": \"Bearer \" + pm.environment.get(\"HUB_OPERATOR_BEARER_TOKEN\"),\r",
146
+ " \"FSPIOP-Source\": pm.environment.get(\"hub_operator\"),\r",
147
+ " \"Content-Type\": \"application/json\"\r",
148
+ " }\r",
149
+ " };\r",
150
+ " pm.sendRequest(hubGetStatusRequest, function (err, response) {\r",
151
+ " console.log(response.json())\r",
152
+ " var jsonData = response.json()\r",
153
+ " var hubReconAccountBalanceAfterFundsOutPrepare\r",
154
+ " for (var i in jsonData) {\r",
155
+ " if (jsonData[i].ledgerAccountType === 'HUB_RECONCILIATION' && (jsonData[i].currency === pm.environment.get(\"currency\"))) {\r",
156
+ " pm.environment.set(\"hubReconAccountBalanceAfterFundsOutPrepare\", jsonData[i].value)\r",
157
+ " }\r",
158
+ " }\r",
159
+ " });\r",
160
+ "}, 500)"
161
+ ]
162
+ }
163
+ }
164
+ },
165
+ {
166
+ "id": 2,
167
+ "description": "Record Funds Out Prepare&Reserve - transfer status",
168
+ "apiVersion": {
169
+ "minorVersion": 0,
170
+ "majorVersion": 1,
171
+ "type": "fspiop",
172
+ "asynchronous": true
173
+ },
174
+ "operationPath": "/transfers/{ID}",
175
+ "path": "/transfers/{$prev.1.request.body.transferId}",
176
+ "method": "get",
177
+ "params": {
178
+ "ID": "{$prev.1.request.body.transferId}"
179
+ },
180
+ "headers": {
181
+ "Content-Type": "{$inputs.contentTransfers}",
182
+ "Date": "{$function.generic.curDate}",
183
+ "FSPIOP-Source": "{$inputs.fromFspId}",
184
+ "Accept": "{$inputs.acceptTransfers}"
185
+ },
186
+ "url": "{$inputs.HOST_ML_API_ADAPTER}",
187
+ "tests": {
188
+ "assertions": [
189
+ {
190
+ "id": 1,
191
+ "description": "test",
192
+ "exec": [
193
+ "expect(response.status).to.equal(202)"
194
+ ]
195
+ },
196
+ {
197
+ "id": 2,
198
+ "description": "RESERVED",
199
+ "exec": [
200
+ "expect(callback.body.transferState).to.equal('RESERVED')"
201
+ ]
202
+ }
203
+ ]
204
+ }
205
+ },
206
+ {
207
+ "id": 3,
208
+ "description": "Record Funds Out Commit - payerfsp",
209
+ "apiVersion": {
210
+ "minorVersion": 3,
211
+ "majorVersion": 9,
212
+ "type": "central_admin"
213
+ },
214
+ "operationPath": "/participants/{name}/accounts/{id}/transfers/{transferId}",
215
+ "path": "/participants/{$inputs.fromFspId}/accounts/{$environment.accountId}/transfers/{$prev.1.request.body.transferId}",
216
+ "method": "put",
217
+ "params": {
218
+ "name": "{$inputs.fromFspId}",
219
+ "id": "{$environment.accountId}",
220
+ "transferId": "{$prev.1.request.body.transferId}"
221
+ },
222
+ "url": "{$inputs.HOST_CENTRAL_LEDGER}",
223
+ "headers": {
224
+ "FSPIOP-Source": "{$inputs.hub_operator}",
225
+ "Content-Type": "application/json"
226
+ },
227
+ "tests": {
228
+ "assertions": [
229
+ {
230
+ "id": 1,
231
+ "description": "status code to be 202",
232
+ "exec": [
233
+ "expect(response.status).to.equal(202)"
234
+ ]
235
+ },
236
+ {
237
+ "id": 3,
238
+ "description": "hub Recon Account Balance After Funds In is as expected",
239
+ "exec": [
240
+ "expect(Number(environment.payerfspSettlementAccountBalanceAfterFundsOutCommit)).to.equal(Number(environment.payerfspSettlementAccountBalanceBeforeFundsOutCommit))"
241
+ ]
242
+ },
243
+ {
244
+ "id": 4,
245
+ "description": "payerfsp Settlement Account Balance After Funds In is as expected",
246
+ "exec": [
247
+ "expect(Number(environment.hubReconAccountBalanceAfterFundsOutCommit)).to.equal(Number(environment.hubReconAccountBalanceBeforeFundsOutCommit) - environment.fundsOutCommitAmount)"
248
+ ]
249
+ }
250
+ ]
251
+ },
252
+ "body": {
253
+ "action": "recordFundsOutCommit",
254
+ "reason": "Reason for out flow of funds"
255
+ },
256
+ "scripts": {
257
+ "preRequest": {
258
+ "exec": [
259
+ "pm.environment.set('fundsOutCommitAmount', 1000);\r",
260
+ "\r",
261
+ "\r",
262
+ "const payerfspGetStatusRequest = {\r",
263
+ " url: pm.environment.get(\"HOST_CENTRAL_LEDGER\")+pm.environment.get(\"BASE_CENTRAL_LEDGER_ADMIN\")+'/participants/'+pm.environment.get(\"payerfsp\")+'/accounts',\r",
264
+ " method: 'GET',\r",
265
+ " header: {\r",
266
+ " \"Authorization\":\"Bearer \"+pm.environment.get(\"HUB_OPERATOR_BEARER_TOKEN\"),\r",
267
+ " \"FSPIOP-Source\": pm.environment.get(\"hub_operator\"),\r",
268
+ " \"Content-Type\": \"application/json\"\r",
269
+ " }\r",
270
+ "};\r",
271
+ "pm.sendRequest(payerfspGetStatusRequest, function (err, response) {\r",
272
+ " console.log(response.json())\r",
273
+ " var jsonData = response.json()\r",
274
+ " for(var i in jsonData) {\r",
275
+ " if(jsonData[i].ledgerAccountType === 'SETTLEMENT' && (jsonData[i].currency === pm.environment.get(\"currency\"))) {\r",
276
+ " pm.environment.set(\"payerfspSettlementAccountBalanceBeforeFundsOutCommit\",jsonData[i].value)\r",
277
+ " }\r",
278
+ " }\r",
279
+ "});\r",
280
+ "\r",
281
+ "const hubGetStatusRequest = {\r",
282
+ " url: pm.environment.get(\"HOST_CENTRAL_LEDGER\")+pm.environment.get(\"BASE_CENTRAL_LEDGER_ADMIN\")+'/participants/Hub/accounts',\r",
283
+ " method: 'GET',\r",
284
+ " header: {\r",
285
+ " \"Authorization\":\"Bearer \"+pm.environment.get(\"HUB_OPERATOR_BEARER_TOKEN\"),\r",
286
+ " \"FSPIOP-Source\": pm.environment.get(\"hub_operator\"),\r",
287
+ " \"Content-Type\": \"application/json\"\r",
288
+ " }\r",
289
+ "};\r",
290
+ "pm.sendRequest(hubGetStatusRequest, function (err, response) {\r",
291
+ " console.log(response.json())\r",
292
+ " var jsonData = response.json()\r",
293
+ " for(var i in jsonData) {\r",
294
+ " if(jsonData[i].ledgerAccountType === 'HUB_RECONCILIATION' && (jsonData[i].currency === pm.environment.get(\"currency\"))) {\r",
295
+ " pm.environment.set(\"hubReconAccountBalanceBeforeFundsOutCommit\",jsonData[i].value)\r",
296
+ " }\r",
297
+ " }\r",
298
+ "});"
299
+ ]
300
+ },
301
+ "postRequest": {
302
+ "exec": [
303
+ "setTimeout(function () {\r",
304
+ " const payerfspGetStatusRequest = {\r",
305
+ " url: pm.environment.get(\"HOST_CENTRAL_LEDGER\") + pm.environment.get(\"BASE_CENTRAL_LEDGER_ADMIN\") + '/participants/' + pm.environment.get(\"payerfsp\") + '/accounts',\r",
306
+ " method: 'GET',\r",
307
+ " header: {\r",
308
+ " \"Authorization\": \"Bearer \" + pm.environment.get(\"HUBOPERATOR_BEARER_TOKEN\"),\r",
309
+ " \"FSPIOP-Source\": pm.environment.get(\"hub_operator\"),\r",
310
+ " \"Content-Type\": \"application/json\"\r",
311
+ " }\r",
312
+ " };\r",
313
+ " pm.sendRequest(payerfspGetStatusRequest, function (err, response) {\r",
314
+ " console.log(response.json())\r",
315
+ " var jsonData = response.json()\r",
316
+ " var payerfspSettlementAccountBalanceAfterFundsOutCommit\r",
317
+ " for (var i in jsonData) {\r",
318
+ " if (jsonData[i].ledgerAccountType === 'SETTLEMENT' && (jsonData[i].currency === pm.environment.get(\"currency\"))) {\r",
319
+ " pm.environment.set(\"payerfspSettlementAccountBalanceAfterFundsOutCommit\", jsonData[i].value)\r",
320
+ " }\r",
321
+ " }\r",
322
+ " });\r",
323
+ "\r",
324
+ " const hubGetStatusRequest = {\r",
325
+ " url: pm.environment.get(\"HOST_CENTRAL_LEDGER\") + pm.environment.get(\"BASE_CENTRAL_LEDGER_ADMIN\") + '/participants/Hub/accounts',\r",
326
+ " method: 'GET',\r",
327
+ " header: {\r",
328
+ " \"Authorization\": \"Bearer \" + pm.environment.get(\"HUBOPERATOR_BEARER_TOKEN\"),\r",
329
+ " \"FSPIOP-Source\": pm.environment.get(\"hub_operator\"),\r",
330
+ " \"Content-Type\": \"application/json\"\r",
331
+ " }\r",
332
+ " };\r",
333
+ " pm.sendRequest(hubGetStatusRequest, function (err, response) {\r",
334
+ " console.log(response.json())\r",
335
+ " var jsonData = response.json()\r",
336
+ " var hubReconAccountBalanceAfterFundsOutCommit\r",
337
+ " for (var i in jsonData) {\r",
338
+ " if (jsonData[i].ledgerAccountType === 'HUB_RECONCILIATION' && (jsonData[i].currency === pm.environment.get(\"currency\"))) {\r",
339
+ " pm.environment.set(\"hubReconAccountBalanceAfterFundsOutCommit\", jsonData[i].value)\r",
340
+ " }\r",
341
+ " }\r",
342
+ " });\r",
343
+ "}, 500)"
344
+ ]
345
+ }
346
+ }
347
+ },
348
+ {
349
+ "id": 4,
350
+ "description": "Record Funds Out Commit - transfer status",
351
+ "apiVersion": {
352
+ "minorVersion": 0,
353
+ "majorVersion": 1,
354
+ "type": "fspiop",
355
+ "asynchronous": true
356
+ },
357
+ "operationPath": "/transfers/{ID}",
358
+ "path": "/transfers/{$prev.1.request.body.transferId}",
359
+ "method": "get",
360
+ "params": {
361
+ "ID": "{$prev.1.request.body.transferId}"
362
+ },
363
+ "headers": {
364
+ "Content-Type": "{$inputs.contentTransfers}",
365
+ "Date": "{$function.generic.curDate}",
366
+ "FSPIOP-Source": "{$inputs.fromFspId}",
367
+ "Accept": "{$inputs.acceptTransfers}"
368
+ },
369
+ "url": "{$inputs.HOST_ML_API_ADAPTER}",
370
+ "tests": {
371
+ "assertions": [
372
+ {
373
+ "id": 1,
374
+ "description": "test",
375
+ "exec": [
376
+ "expect(response.status).to.equal(202)"
377
+ ]
378
+ },
379
+ {
380
+ "id": 2,
381
+ "description": "COMMITTED",
382
+ "exec": [
383
+ "expect(callback.body.transferState).to.equal('COMMITTED')"
384
+ ]
385
+ }
386
+ ]
387
+ }
388
+ }
389
+ ]
390
+ },
391
+ {
392
+ "id": 3,
393
+ "name": "funds_out - Reserve&Abort",
394
+ "requests": [
395
+ {
396
+ "id": 1,
397
+ "description": "test",
398
+ "apiVersion": {
399
+ "minorVersion": 3,
400
+ "majorVersion": 9,
401
+ "type": "central_admin"
402
+ },
403
+ "operationPath": "/participants/{name}/accounts/{id}",
404
+ "path": "/participants/{$inputs.fromFspId}/accounts/{$environment.accountId}",
405
+ "method": "post",
406
+ "params": {
407
+ "name": "{$inputs.fromFspId}",
408
+ "id": "{$environment.accountId}"
409
+ },
410
+ "headers": {
411
+ "FSPIOP-Source": "{$inputs.fromFspId}",
412
+ "Content-Type": "application/json"
413
+ },
414
+ "body": {
415
+ "transferId": "{$function.generic.generateID}",
416
+ "externalReference": "string",
417
+ "action": "recordFundsOutPrepareReserve",
418
+ "reason": "string",
419
+ "amount": {
420
+ "amount": "{$environment.fundsOutPrepareReserveAmount}",
421
+ "currency": "{$environment.currency}"
422
+ },
423
+ "extensionList": {
424
+ "extension": [
425
+ {
426
+ "key": "string",
427
+ "value": "string"
428
+ }
429
+ ]
430
+ }
431
+ },
432
+ "url": "{$inputs.HOST_CENTRAL_LEDGER}",
433
+ "tests": {
434
+ "assertions": [
435
+ {
436
+ "id": 1,
437
+ "description": "status code to be 202",
438
+ "exec": [
439
+ "expect(response.status).to.equal(202)"
440
+ ]
441
+ },
442
+ {
443
+ "id": 3,
444
+ "description": "hub Recon Account Balance After Funds In is as expected",
445
+ "exec": [
446
+ "expect(Number(environment.hubReconAccountBalanceAfterFundsOutPrepare)).to.equal(Number(environment.hubReconAccountBalanceBeforeFundsOutPrepare))"
447
+ ]
448
+ },
449
+ {
450
+ "id": 4,
451
+ "description": "payerfsp Settlement Account Balance After Funds In is as expected",
452
+ "exec": [
453
+ "expect(Number(environment.payerfspSettlementAccountBalanceAfterFundsOutPrepare)).to.equal(Number(environment.payerfspSettlementAccountBalanceBeforeFundsOutPrepare) + environment.fundsOutPrepareReserveAmount)"
454
+ ]
455
+ }
456
+ ]
457
+ },
458
+ "scripts": {
459
+ "preRequest": {
460
+ "exec": [
461
+ "pm.environment.set('fundsOutPrepareReserveAmount', 1000);\r",
462
+ "\r",
463
+ "const payerfspGetStatusRequest = {\r",
464
+ " url: pm.environment.get(\"HOST_CENTRAL_LEDGER\") + pm.environment.get(\"BASE_CENTRAL_LEDGER_ADMIN\") + '/participants/' + pm.environment.get(\"payerfsp\") + '/accounts',\r",
465
+ " method: 'GET',\r",
466
+ " header: {\r",
467
+ " \"Authorization\": \"Bearer \" + pm.environment.get(\"HUB_OPERATOR_BEARER_TOKEN\"),\r",
468
+ " \"FSPIOP-Source\": pm.environment.get(\"hub_operator\"),\r",
469
+ " \"Content-Type\": \"application/json\"\r",
470
+ " }\r",
471
+ "};\r",
472
+ "\r",
473
+ "pm.sendRequest(payerfspGetStatusRequest, function (err, response) {\r",
474
+ " console.log(response.json())\r",
475
+ " var jsonData = response.json()\r",
476
+ " for (var i in jsonData) {\r",
477
+ " if (jsonData[i].ledgerAccountType === 'SETTLEMENT' && (jsonData[i].currency === pm.environment.get(\"currency\"))) {\r",
478
+ " pm.environment.set(\"payerfspSettlementAccountId\", jsonData[i].id)\r",
479
+ " pm.environment.set(\"payerfspSettlementAccountBalanceBeforeFundsOutPrepare\", jsonData[i].value)\r",
480
+ " }\r",
481
+ " }\r",
482
+ "});\r",
483
+ "\r",
484
+ "const hubGetStatusRequest = {\r",
485
+ " url: pm.environment.get(\"HOST_CENTRAL_LEDGER\") + pm.environment.get(\"BASE_CENTRAL_LEDGER_ADMIN\") + '/participants/Hub/accounts',\r",
486
+ " method: 'GET',\r",
487
+ " header: {\r",
488
+ " \"Authorization\": \"Bearer \" + pm.environment.get(\"HUB_OPERATOR_BEARER_TOKEN\"),\r",
489
+ " \"FSPIOP-Source\": pm.environment.get(\"hub_operator\"),\r",
490
+ " \"Content-Type\": \"application/json\"\r",
491
+ " }\r",
492
+ "};\r",
493
+ "pm.sendRequest(hubGetStatusRequest, function (err, response) {\r",
494
+ " console.log(response.json())\r",
495
+ " var jsonData = response.json()\r",
496
+ " for (var i in jsonData) {\r",
497
+ " if (jsonData[i].ledgerAccountType === 'HUB_RECONCILIATION' && (jsonData[i].currency === pm.environment.get(\"currency\"))) {\r",
498
+ " pm.environment.set(\"hubReconAccountBalanceBeforeFundsOutPrepare\", jsonData[i].value)\r",
499
+ " }\r",
500
+ " }\r",
501
+ "});"
502
+ ]
503
+ },
504
+ "postRequest": {
505
+ "exec": [
506
+ "setTimeout(function () {\r",
507
+ " const payerfspGetStatusRequest = {\r",
508
+ " url: pm.environment.get(\"HOST_CENTRAL_LEDGER\") + pm.environment.get(\"BASE_CENTRAL_LEDGER_ADMIN\") + '/participants/' + pm.environment.get(\"payerfsp\") + '/accounts',\r",
509
+ " method: 'GET',\r",
510
+ " header: {\r",
511
+ " \"Authorization\": \"Bearer \" + pm.environment.get(\"HUB_OPERATOR_BEARER_TOKEN\"),\r",
512
+ " \"FSPIOP-Source\": pm.environment.get(\"hub_operator\"),\r",
513
+ " \"Content-Type\": \"application/json\"\r",
514
+ " }\r",
515
+ " };\r",
516
+ " pm.sendRequest(payerfspGetStatusRequest, function (err, response) {\r",
517
+ " console.log(response.json())\r",
518
+ " var jsonData = response.json()\r",
519
+ " var payerfspSettlementAccountBalanceAfterFundsOutPrepare\r",
520
+ " for (var i in jsonData) {\r",
521
+ " if (jsonData[i].ledgerAccountType === 'SETTLEMENT' && (jsonData[i].currency === pm.environment.get(\"currency\"))) {\r",
522
+ " pm.environment.set(\"payerfspSettlementAccountBalanceAfterFundsOutPrepare\", jsonData[i].value)\r",
523
+ " }\r",
524
+ " }\r",
525
+ "\r",
526
+ " });\r",
527
+ "\r",
528
+ " const hubGetStatusRequest = {\r",
529
+ " url: pm.environment.get(\"HOST_CENTRAL_LEDGER\") + pm.environment.get(\"BASE_CENTRAL_LEDGER_ADMIN\") + '/participants/Hub/accounts',\r",
530
+ " method: 'GET',\r",
531
+ " header: {\r",
532
+ " \"Authorization\": \"Bearer \" + pm.environment.get(\"HUB_OPERATOR_BEARER_TOKEN\"),\r",
533
+ " \"FSPIOP-Source\": pm.environment.get(\"hub_operator\"),\r",
534
+ " \"Content-Type\": \"application/json\"\r",
535
+ " }\r",
536
+ " };\r",
537
+ " pm.sendRequest(hubGetStatusRequest, function (err, response) {\r",
538
+ " console.log(response.json())\r",
539
+ " var jsonData = response.json()\r",
540
+ " var hubReconAccountBalanceAfterFundsOutPrepare\r",
541
+ " for (var i in jsonData) {\r",
542
+ " if (jsonData[i].ledgerAccountType === 'HUB_RECONCILIATION' && (jsonData[i].currency === pm.environment.get(\"currency\"))) {\r",
543
+ " pm.environment.set(\"hubReconAccountBalanceAfterFundsOutPrepare\", jsonData[i].value)\r",
544
+ " }\r",
545
+ " }\r",
546
+ " });\r",
547
+ "}, 500)"
548
+ ]
549
+ }
550
+ }
551
+ },
552
+ {
553
+ "id": 2,
554
+ "description": "Record Funds In - prepare transfer status",
555
+ "apiVersion": {
556
+ "minorVersion": 0,
557
+ "majorVersion": 1,
558
+ "type": "fspiop",
559
+ "asynchronous": true
560
+ },
561
+ "operationPath": "/transfers/{ID}",
562
+ "path": "/transfers/{$prev.1.request.body.transferId}",
563
+ "method": "get",
564
+ "params": {
565
+ "ID": "{$prev.1.request.body.transferId}"
566
+ },
567
+ "headers": {
568
+ "Content-Type": "{$inputs.contentTransfers}",
569
+ "Date": "{$function.generic.curDate}",
570
+ "FSPIOP-Source": "{$inputs.fromFspId}",
571
+ "Accept": "{$inputs.acceptTransfers}"
572
+ },
573
+ "url": "{$inputs.HOST_ML_API_ADAPTER}",
574
+ "tests": {
575
+ "assertions": [
576
+ {
577
+ "id": 1,
578
+ "description": "Status code is 202",
579
+ "exec": [
580
+ "expect(response.status).to.equal(202)"
581
+ ]
582
+ },
583
+ {
584
+ "id": 2,
585
+ "description": "RESERVED",
586
+ "exec": [
587
+ "expect(callback.body.transferState).to.equal('RESERVED')"
588
+ ]
589
+ }
590
+ ]
591
+ }
592
+ },
593
+ {
594
+ "id": 3,
595
+ "description": "Record Funds Out Abort - payerfsp",
596
+ "apiVersion": {
597
+ "minorVersion": 3,
598
+ "majorVersion": 9,
599
+ "type": "central_admin"
600
+ },
601
+ "operationPath": "/participants/{name}/accounts/{id}/transfers/{transferId}",
602
+ "path": "/participants/{$inputs.fromFspId}/accounts/{$environment.accountId}/transfers/{$prev.1.request.body.transferId}",
603
+ "method": "put",
604
+ "params": {
605
+ "name": "{$inputs.fromFspId}",
606
+ "id": "{$environment.accountId}",
607
+ "transferId": "{$prev.1.request.body.transferId}"
608
+ },
609
+ "url": "{$inputs.HOST_CENTRAL_LEDGER}",
610
+ "headers": {
611
+ "FSPIOP-Source": "{$inputs.hub_operator}",
612
+ "Content-Type": "application/json"
613
+ },
614
+ "tests": {
615
+ "assertions": [
616
+ {
617
+ "id": 1,
618
+ "description": "status code to be 202",
619
+ "exec": [
620
+ "expect(response.status).to.equal(202)"
621
+ ]
622
+ },
623
+ {
624
+ "id": 3,
625
+ "description": "hub Recon Account Balance After Funds In is as expected",
626
+ "exec": [
627
+ "expect(Number(environment.payerfspSettlementAccountBalanceAfterFundsOutAbort)).to.equal(Number(environment.payerfspSettlementAccountBalanceBeforeFundsOutPrepare))"
628
+ ]
629
+ },
630
+ {
631
+ "id": 4,
632
+ "description": "payerfsp Settlement Account Balance After Funds In is as expected",
633
+ "exec": [
634
+ "expect(Number(environment.hubReconAccountBalanceAfterFundsOutAbort)).to.equal(Number(environment.hubReconAccountBalanceBeforeFundsOutAbort))"
635
+ ]
636
+ }
637
+ ]
638
+ },
639
+ "body": {
640
+ "action": "recordFundsOutAbort",
641
+ "reason": "Reason for out flow of funds"
642
+ },
643
+ "scripts": {
644
+ "preRequest": {
645
+ "exec": [
646
+ "pm.environment.set('fundsOutCommitAmount', 1000);\r",
647
+ "\r",
648
+ "setTimeout(function () {\r",
649
+ " const payerfspGetStatusRequest = {\r",
650
+ " url: pm.environment.get(\"HOST_CENTRAL_LEDGER\")+pm.environment.get(\"BASE_CENTRAL_LEDGER_ADMIN\")+'/participants/'+pm.environment.get(\"payerfsp\")+'/accounts',\r",
651
+ " method: 'GET',\r",
652
+ " header: {\r",
653
+ " \"Authorization\":\"Bearer \"+pm.environment.get(\"HUB_OPERATOR_BEARER_TOKEN\"),\r",
654
+ " \"FSPIOP-Source\": pm.environment.get(\"hub_operator\"),\r",
655
+ " \"Content-Type\": \"application/json\"\r",
656
+ " }\r",
657
+ " };\r",
658
+ " pm.sendRequest(payerfspGetStatusRequest, function (err, response) {\r",
659
+ " console.log(response.json())\r",
660
+ " var jsonData = response.json()\r",
661
+ " for(var i in jsonData) {\r",
662
+ " if(jsonData[i].ledgerAccountType === 'SETTLEMENT' && (jsonData[i].currency === pm.environment.get(\"currency\"))) {\r",
663
+ " pm.environment.set(\"payerfspSettlementAccountBalanceBeforeFundsOutAbort\",jsonData[i].value)\r",
664
+ " }\r",
665
+ " }\r",
666
+ " });\r",
667
+ " \r",
668
+ " const hubGetStatusRequest = {\r",
669
+ " url: pm.environment.get(\"HOST_CENTRAL_LEDGER\")+pm.environment.get(\"BASE_CENTRAL_LEDGER_ADMIN\")+'/participants/Hub/accounts',\r",
670
+ " method: 'GET',\r",
671
+ " header: {\r",
672
+ " \"Authorization\":\"Bearer \"+pm.environment.get(\"HUB_OPERATOR_BEARER_TOKEN\"),\r",
673
+ " \"FSPIOP-Source\": pm.environment.get(\"hub_operator\"),\r",
674
+ " \"Content-Type\": \"application/json\"\r",
675
+ " }\r",
676
+ " };\r",
677
+ " pm.sendRequest(hubGetStatusRequest, function (err, response) {\r",
678
+ " console.log(response.json())\r",
679
+ " var jsonData = response.json()\r",
680
+ " for(var i in jsonData) {\r",
681
+ " if(jsonData[i].ledgerAccountType === 'HUB_RECONCILIATION' && (jsonData[i].currency === pm.environment.get(\"currency\"))) {\r",
682
+ " pm.environment.set(\"hubReconAccountBalanceBeforeFundsOutAbort\",jsonData[i].value)\r",
683
+ " }\r",
684
+ " }\r",
685
+ " });\r",
686
+ "}, 500)"
687
+ ]
688
+ },
689
+ "postRequest": {
690
+ "exec": [
691
+ "setTimeout(function () {\r",
692
+ " const payerfspGetStatusRequest = {\r",
693
+ " url: pm.environment.get(\"HOST_CENTRAL_LEDGER\") + pm.environment.get(\"BASE_CENTRAL_LEDGER_ADMIN\") + '/participants/' + pm.environment.get(\"payerfsp\") + '/accounts',\r",
694
+ " method: 'GET',\r",
695
+ " header: {\r",
696
+ " \"Authorization\": \"Bearer \" + pm.environment.get(\"HUBOPERATOR_BEARER_TOKEN\"),\r",
697
+ " \"FSPIOP-Source\": pm.environment.get(\"hub_operator\"),\r",
698
+ " \"Content-Type\": \"application/json\"\r",
699
+ " }\r",
700
+ " };\r",
701
+ " pm.sendRequest(payerfspGetStatusRequest, function (err, response) {\r",
702
+ " console.log(response.json())\r",
703
+ " var jsonData = response.json()\r",
704
+ " var payerfspSettlementAccountBalanceAfterFundsOutCommit\r",
705
+ " for (var i in jsonData) {\r",
706
+ " if (jsonData[i].ledgerAccountType === 'SETTLEMENT' && (jsonData[i].currency === pm.environment.get(\"currency\"))) {\r",
707
+ " pm.environment.set(\"payerfspSettlementAccountBalanceAfterFundsOutAbort\", jsonData[i].value)\r",
708
+ " }\r",
709
+ " }\r",
710
+ " });\r",
711
+ "\r",
712
+ " const hubGetStatusRequest = {\r",
713
+ " url: pm.environment.get(\"HOST_CENTRAL_LEDGER\") + pm.environment.get(\"BASE_CENTRAL_LEDGER_ADMIN\") + '/participants/Hub/accounts',\r",
714
+ " method: 'GET',\r",
715
+ " header: {\r",
716
+ " \"Authorization\": \"Bearer \" + pm.environment.get(\"HUBOPERATOR_BEARER_TOKEN\"),\r",
717
+ " \"FSPIOP-Source\": pm.environment.get(\"hub_operator\"),\r",
718
+ " \"Content-Type\": \"application/json\"\r",
719
+ " }\r",
720
+ " };\r",
721
+ " pm.sendRequest(hubGetStatusRequest, function (err, response) {\r",
722
+ " console.log(response.json())\r",
723
+ " var jsonData = response.json()\r",
724
+ " var hubReconAccountBalanceAfterFundsOutCommit\r",
725
+ " for (var i in jsonData) {\r",
726
+ " if (jsonData[i].ledgerAccountType === 'HUB_RECONCILIATION' && (jsonData[i].currency === pm.environment.get(\"currency\"))) {\r",
727
+ " pm.environment.set(\"hubReconAccountBalanceAfterFundsOutAbort\", jsonData[i].value)\r",
728
+ " }\r",
729
+ " }\r",
730
+ " });\r",
731
+ "}, 500)"
732
+ ]
733
+ }
734
+ }
735
+ },
736
+ {
737
+ "id": 4,
738
+ "description": "Record Funds In - prepare transfer status Copy",
739
+ "apiVersion": {
740
+ "minorVersion": 0,
741
+ "majorVersion": 1,
742
+ "type": "fspiop",
743
+ "asynchronous": true
744
+ },
745
+ "operationPath": "/transfers/{ID}",
746
+ "path": "/transfers/{$prev.1.request.body.transferId}",
747
+ "method": "get",
748
+ "params": {
749
+ "ID": "{$prev.1.request.body.transferId}"
750
+ },
751
+ "headers": {
752
+ "Content-Type": "{$inputs.contentTransfers}",
753
+ "Date": "{$function.generic.curDate}",
754
+ "FSPIOP-Source": "{$inputs.fromFspId}",
755
+ "Accept": "{$inputs.acceptTransfers}"
756
+ },
757
+ "url": "{$inputs.HOST_ML_API_ADAPTER}",
758
+ "tests": {
759
+ "assertions": [
760
+ {
761
+ "id": 1,
762
+ "description": "Status code is 202",
763
+ "exec": [
764
+ "expect(response.status).to.equal(202)"
765
+ ]
766
+ },
767
+ {
768
+ "id": 2,
769
+ "description": "ABORTED",
770
+ "exec": [
771
+ "expect(callback.body.transferState).to.equal('ABORTED')"
772
+ ]
773
+ }
774
+ ]
775
+ }
776
+ }
777
+ ]
778
+ }
779
+ ]
780
+ }