@futdevpro/fsm-dynamo 1.15.17 → 1.15.20

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 (543) hide show
  1. package/.cursor/rules/__assistant_guide.mdc +30 -30
  2. package/.cursor/rules/_ag_backend-structure.mdc +85 -85
  3. package/.cursor/rules/_ag_backend.mdc +16 -16
  4. package/.cursor/rules/_ag_frontend-structure.mdc +86 -86
  5. package/.cursor/rules/_ag_frontend.mdc +39 -39
  6. package/.cursor/rules/_ag_import-rules.mdc +44 -44
  7. package/.cursor/rules/_ag_naming.mdc +115 -115
  8. package/.cursor/rules/_ag_should-be.mdc +6 -6
  9. package/.cursor/rules/ai_development_guide.md +60 -60
  10. package/.cursor/rules/cursor-rules.md +160 -160
  11. package/.cursor/rules/default-command.mdc +464 -464
  12. package/.cursor/rules/error_code_pattern.md +39 -39
  13. package/.cursor/rules/saved rule mcp server use.md +15 -15
  14. package/.dynamo/pipeline.cicd.config.json +128 -128
  15. package/.github/workflows/main.yml +433 -433
  16. package/.vscode/settings.json +11 -11
  17. package/LICENSE +21 -21
  18. package/__documentations/2026-06-01-fr047-fc-foundation.md +48 -0
  19. package/build/_models/data-models/errors.data-model.d.ts +43 -0
  20. package/build/_models/data-models/errors.data-model.d.ts.map +1 -1
  21. package/build/_models/data-models/errors.data-model.js +30 -0
  22. package/build/_models/data-models/errors.data-model.js.map +1 -1
  23. package/build/_modules/ai/_models/ai-model-capabilities.interface.d.ts +8 -0
  24. package/build/_modules/ai/_models/ai-model-capabilities.interface.d.ts.map +1 -1
  25. package/build/_modules/ai/_modules/anthropic/_collections/aai-models.const.d.ts.map +1 -1
  26. package/build/_modules/ai/_modules/anthropic/_collections/aai-models.const.js +3 -0
  27. package/build/_modules/ai/_modules/anthropic/_collections/aai-models.const.js.map +1 -1
  28. package/build/_modules/ai/_modules/fdp-ai/_collections/fdpai-models.const.d.ts.map +1 -1
  29. package/build/_modules/ai/_modules/fdp-ai/_collections/fdpai-models.const.js +1 -0
  30. package/build/_modules/ai/_modules/fdp-ai/_collections/fdpai-models.const.js.map +1 -1
  31. package/build/_modules/ai/_modules/google-ai/_collections/gai-models.const.d.ts.map +1 -1
  32. package/build/_modules/ai/_modules/google-ai/_collections/gai-models.const.js +4 -0
  33. package/build/_modules/ai/_modules/google-ai/_collections/gai-models.const.js.map +1 -1
  34. package/build/_modules/ai/_modules/local-ai/_collections/lai-models.const.d.ts.map +1 -1
  35. package/build/_modules/ai/_modules/local-ai/_collections/lai-models.const.js +2 -0
  36. package/build/_modules/ai/_modules/local-ai/_collections/lai-models.const.js.map +1 -1
  37. package/build/_modules/ai/_modules/open-ai/_collections/oai-models.const.d.ts.map +1 -1
  38. package/build/_modules/ai/_modules/open-ai/_collections/oai-models.const.js +11 -0
  39. package/build/_modules/ai/_modules/open-ai/_collections/oai-models.const.js.map +1 -1
  40. package/build/_modules/socket/_models/sck-socket-event.control-model.js +1 -1
  41. package/eslint.config.js +4 -4
  42. package/nodemon.json +22 -22
  43. package/package.json +11 -11
  44. package/scripts/crypto/CRYPTO-STABILITY-SOLUTION.md +196 -196
  45. package/scripts/crypto/README.md +113 -113
  46. package/scripts/crypto/demo-crypto-stability.js +120 -120
  47. package/scripts/crypto/stress-test-crypto.js +379 -379
  48. package/scripts/run-coverage-tests.js +24 -24
  49. package/spec/support/helpers/ts-node-helper.js +9 -9
  50. package/spec/support/jasmine.coverage.json +23 -23
  51. package/spec/support/jasmine.json +24 -24
  52. package/src/_collections/constants/data-sizes.const.ts +40 -40
  53. package/src/_collections/constants/error-defaults.const.ts +20 -20
  54. package/src/_collections/constants/global-settings.const.ts +24 -24
  55. package/src/_collections/constants/numbers.const.ts +40 -40
  56. package/src/_collections/constants/times.const.ts +45 -45
  57. package/src/_collections/utils/array.util.spec.ts +306 -306
  58. package/src/_collections/utils/array.util.ts +813 -813
  59. package/src/_collections/utils/async.util.spec.ts +354 -354
  60. package/src/_collections/utils/async.util.ts +197 -197
  61. package/src/_collections/utils/data.util.spec.ts +345 -345
  62. package/src/_collections/utils/data.util.ts +226 -226
  63. package/src/_collections/utils/json-error-helper.util.spec.ts +521 -521
  64. package/src/_collections/utils/json-error-helper.util.ts +301 -301
  65. package/src/_collections/utils/log.util.spec.ts +975 -975
  66. package/src/_collections/utils/log.util.ts +665 -665
  67. package/src/_collections/utils/math/box-bounds.spec.ts +73 -73
  68. package/src/_collections/utils/math/box-bounds.util.ts +183 -183
  69. package/src/_collections/utils/math/math.util.spec.ts +94 -94
  70. package/src/_collections/utils/math/math.util.ts +141 -141
  71. package/src/_collections/utils/math/random.util.spec.ts +82 -82
  72. package/src/_collections/utils/math/random.util.ts +139 -139
  73. package/src/_collections/utils/math/trigonometry.util.spec.ts +57 -57
  74. package/src/_collections/utils/math/trigonometry.util.ts +102 -102
  75. package/src/_collections/utils/math/vector2.util.spec.ts +94 -94
  76. package/src/_collections/utils/math/vector2.util.ts +653 -653
  77. package/src/_collections/utils/object.util.spec.ts +646 -646
  78. package/src/_collections/utils/regex/password-regex.util.spec.ts +51 -51
  79. package/src/_collections/utils/regex/password-regex.util.ts +65 -65
  80. package/src/_collections/utils/regex/regex.util.spec.ts +42 -42
  81. package/src/_collections/utils/regex/regex.util.ts +6 -6
  82. package/src/_collections/utils/regex/username-regex.util.spec.ts +61 -61
  83. package/src/_collections/utils/regex/username-regex.util.ts +35 -35
  84. package/src/_collections/utils/round-list.util.spec.ts +79 -79
  85. package/src/_collections/utils/round-list.util.ts +162 -162
  86. package/src/_collections/utils/stack.util.spec.ts +372 -372
  87. package/src/_collections/utils/stack.util.ts +164 -164
  88. package/src/_collections/utils/string-case.util.spec.ts +441 -441
  89. package/src/_collections/utils/string-case.util.ts +362 -362
  90. package/src/_collections/utils/string.util.spec.ts +975 -975
  91. package/src/_collections/utils/string.util.ts +449 -449
  92. package/src/_collections/utils/time.util.spec.ts +50 -50
  93. package/src/_collections/utils/time.util.ts +481 -481
  94. package/src/_collections/utils/type-cloning-facility.util.spec.ts +51 -51
  95. package/src/_collections/utils/type-cloning-facility.util.ts +168 -168
  96. package/src/_collections/utils/utilities.util.spec.ts +201 -201
  97. package/src/_collections/utils/utilities.util.ts +68 -68
  98. package/src/_collections/utils/uuid.util.spec.ts +30 -30
  99. package/src/_collections/utils/uuid.util.ts +50 -50
  100. package/src/_enums/basic-property-type.enum.ts +20 -20
  101. package/src/_enums/data-model-type.enum.ts +29 -29
  102. package/src/_enums/environment-flag.enum.ts +28 -28
  103. package/src/_enums/error-level.enum.ts +28 -28
  104. package/src/_enums/http/http-call-type.enum.ts +43 -43
  105. package/src/_enums/http/http-event-type.enum.ts +40 -40
  106. package/src/_enums/http/http-response-type.enum.ts +18 -18
  107. package/src/_enums/log-style.enum.ts +44 -44
  108. package/src/_enums/server-connection-status.enum.ts +6 -6
  109. package/src/_enums/time/day-of-week.enum.ts +55 -55
  110. package/src/_enums/time/month.enum.ts +25 -25
  111. package/src/_enums/time/relative-date.enum.ts +24 -24
  112. package/src/_models/control-models/data-model-params.control-model.spec.ts +85 -85
  113. package/src/_models/control-models/data-model-params.control-model.ts +300 -300
  114. package/src/_models/control-models/data-property-params.control-model.spec.ts +93 -93
  115. package/src/_models/control-models/data-property-params.control-model.ts +201 -201
  116. package/src/_models/control-models/error.control-model.spec.ts +912 -912
  117. package/src/_models/control-models/error.control-model.ts +1215 -1215
  118. package/src/_models/control-models/http/http-error-response.control-model.spec.ts +116 -116
  119. package/src/_models/control-models/http/http-error-response.control-model.ts +52 -52
  120. package/src/_models/control-models/http/http-headers.control-model.spec.ts +25 -25
  121. package/src/_models/control-models/http/http-headers.control-model.ts +124 -124
  122. package/src/_models/control-models/http/http-response.model-base.spec.ts +46 -46
  123. package/src/_models/control-models/http/http-response.model-base.ts +57 -57
  124. package/src/_models/control-models/poll.control-model.spec.ts +63 -63
  125. package/src/_models/control-models/poll.control-model.ts +151 -151
  126. package/src/_models/control-models/range-value.control-model.spec.ts +187 -187
  127. package/src/_models/control-models/range-value.control-model.ts +289 -289
  128. package/src/_models/control-models/server-status.control-model.spec.ts +66 -66
  129. package/src/_models/control-models/server-status.control-model.ts +85 -85
  130. package/src/_models/control-models/service-endpoint-settings-base.control-model.spec.ts +145 -145
  131. package/src/_models/control-models/service-endpoint-settings-base.control-model.ts +186 -186
  132. package/src/_models/data-models/errors.data-model.spec.ts +71 -71
  133. package/src/_models/data-models/errors.data-model.ts +148 -91
  134. package/src/_models/data-models/metadata.data-model.spec.ts +184 -184
  135. package/src/_models/data-models/metadata.data-model.ts +128 -128
  136. package/src/_models/interfaces/box-bounds.interface.ts +7 -7
  137. package/src/_models/interfaces/environment/global-log-settings.interface.ts +86 -86
  138. package/src/_models/interfaces/environment/global-settings.interface.ts +47 -47
  139. package/src/_models/interfaces/error-defaults.interface.ts +11 -11
  140. package/src/_models/interfaces/paged.interface.ts +12 -12
  141. package/src/_models/interfaces/random-weight.interface.ts +7 -7
  142. package/src/_models/interfaces/route-settings.interface.ts +15 -15
  143. package/src/_models/interfaces/search-query.interface.ts +23 -23
  144. package/src/_models/interfaces/search-result.interface.ts +5 -5
  145. package/src/_models/interfaces/server-error-statistics.interface.ts +24 -24
  146. package/src/_models/interfaces/vector2.interface.ts +20 -20
  147. package/src/_models/types/db-filter.type.ts +110 -110
  148. package/src/_models/types/db-sort.type.ts +4 -4
  149. package/src/_models/types/ds-filter.type.ts +68 -68
  150. package/src/_models/types/ds-sort.type.ts +21 -21
  151. package/src/_modules/ai/_collections/ai-model-ref.util.ts +88 -88
  152. package/src/_modules/ai/_collections/ai-model-registry.util.spec.ts +37 -37
  153. package/src/_modules/ai/_collections/ai-model-registry.util.ts +30 -30
  154. package/src/_modules/ai/_enums/ai-message-role.enum.ts +7 -7
  155. package/src/_modules/ai/_enums/ai-model-type.enum.ts +7 -7
  156. package/src/_modules/ai/_enums/ai-provider.enum.ts +7 -7
  157. package/src/_modules/ai/_models/ai-call-settings.interface.ts +84 -84
  158. package/src/_modules/ai/_models/ai-embedding-request.interface.ts +20 -20
  159. package/src/_modules/ai/_models/ai-embedding-response.interface.ts +26 -26
  160. package/src/_modules/ai/_models/ai-llm-request.interface.ts +24 -24
  161. package/src/_modules/ai/_models/ai-llm-response.interface.ts +30 -30
  162. package/src/_modules/ai/_models/ai-message.interface.ts +12 -12
  163. package/src/_modules/ai/_models/ai-model-capabilities.interface.ts +35 -27
  164. package/src/_modules/ai/_models/ai-model-info.interface.ts +63 -63
  165. package/src/_modules/ai/_models/ai-model-settings-schema.interface.ts +52 -52
  166. package/src/_modules/ai/_models/ai-provider-capabilities.interface.ts +28 -28
  167. package/src/_modules/ai/_models/ai-settings.interface.ts +17 -17
  168. package/src/_modules/ai/_models/ai-tool-call.interface.ts +18 -18
  169. package/src/_modules/ai/_models/ai-tool-handler.type.ts +11 -11
  170. package/src/_modules/ai/_models/ai-tool-result.interface.ts +16 -16
  171. package/src/_modules/ai/_models/ai-tool.interface.ts +16 -16
  172. package/src/_modules/ai/_models/ai-user-provider-config.control-model.ts +29 -29
  173. package/src/_modules/ai/_modules/anthropic/_collections/aai-models.const.ts +81 -78
  174. package/src/_modules/ai/_modules/anthropic/_enums/aai-model.enum.ts +19 -19
  175. package/src/_modules/ai/_modules/anthropic/_models/aai-call-settings.control-model.spec.ts +28 -28
  176. package/src/_modules/ai/_modules/anthropic/_models/aai-call-settings.control-model.ts +23 -23
  177. package/src/_modules/ai/_modules/anthropic/_models/aai-client-options.interface.ts +10 -10
  178. package/src/_modules/ai/_modules/anthropic/_models/aai-settings.control-model.spec.ts +22 -22
  179. package/src/_modules/ai/_modules/anthropic/_models/aai-settings.control-model.ts +27 -27
  180. package/src/_modules/ai/_modules/anthropic/_models/aai-user-provider-config.control-model.ts +20 -20
  181. package/src/_modules/ai/_modules/anthropic/index.ts +14 -14
  182. package/src/_modules/ai/_modules/document-ai/_models/dai-embedding-info.interface.ts +12 -12
  183. package/src/_modules/ai/_modules/document-ai/_models/dai-vector-search-params.interface.ts +22 -22
  184. package/src/_modules/ai/_modules/document-ai/index.ts +4 -4
  185. package/src/_modules/ai/_modules/fdp-ai/_collections/fdpai-models.const.ts +34 -33
  186. package/src/_modules/ai/_modules/fdp-ai/_enums/fdpai-model.enum.ts +6 -6
  187. package/src/_modules/ai/_modules/fdp-ai/_models/fdpai-call-settings.control-model.ts +19 -19
  188. package/src/_modules/ai/_modules/fdp-ai/_models/fdpai-client-options.interface.ts +11 -11
  189. package/src/_modules/ai/_modules/fdp-ai/_models/fdpai-settings.control-model.ts +24 -24
  190. package/src/_modules/ai/_modules/fdp-ai/_models/fdpai-user-provider-config.control-model.ts +20 -20
  191. package/src/_modules/ai/_modules/fdp-ai/index.ts +11 -11
  192. package/src/_modules/ai/_modules/google-ai/_collections/gai-models.const.ts +99 -95
  193. package/src/_modules/ai/_modules/google-ai/_enums/gai-model.enum.ts +16 -16
  194. package/src/_modules/ai/_modules/google-ai/_models/gai-call-settings.control-model.spec.ts +28 -28
  195. package/src/_modules/ai/_modules/google-ai/_models/gai-call-settings.control-model.ts +21 -21
  196. package/src/_modules/ai/_modules/google-ai/_models/gai-client-options.interface.ts +8 -8
  197. package/src/_modules/ai/_modules/google-ai/_models/gai-settings.control-model.spec.ts +22 -22
  198. package/src/_modules/ai/_modules/google-ai/_models/gai-settings.control-model.ts +25 -25
  199. package/src/_modules/ai/_modules/google-ai/_models/gai-user-provider-config.control-model.ts +20 -20
  200. package/src/_modules/ai/_modules/google-ai/index.ts +14 -14
  201. package/src/_modules/ai/_modules/local-ai/_collections/lai-models.const.ts +53 -51
  202. package/src/_modules/ai/_modules/local-ai/_enums/lai-model.enum.ts +6 -6
  203. package/src/_modules/ai/_modules/local-ai/_models/lai-call-settings.control-model.spec.ts +28 -28
  204. package/src/_modules/ai/_modules/local-ai/_models/lai-call-settings.control-model.ts +18 -18
  205. package/src/_modules/ai/_modules/local-ai/_models/lai-client-options.interface.ts +9 -9
  206. package/src/_modules/ai/_modules/local-ai/_models/lai-settings.control-model.spec.ts +22 -22
  207. package/src/_modules/ai/_modules/local-ai/_models/lai-settings.control-model.ts +23 -23
  208. package/src/_modules/ai/_modules/local-ai/index.ts +14 -14
  209. package/src/_modules/ai/_modules/open-ai/_collections/oai-embedding-model-dimensions.const.ts +7 -7
  210. package/src/_modules/ai/_modules/open-ai/_collections/oai-models.const.ts +252 -241
  211. package/src/_modules/ai/_modules/open-ai/_enums/oai-model.enum.ts +179 -179
  212. package/src/_modules/ai/_modules/open-ai/_models/oai-call-settings.control-model.spec.ts +28 -28
  213. package/src/_modules/ai/_modules/open-ai/_models/oai-call-settings.control-model.ts +21 -21
  214. package/src/_modules/ai/_modules/open-ai/_models/oai-client-options.interface.ts +81 -81
  215. package/src/_modules/ai/_modules/open-ai/_models/oai-embedding-info.interface.ts +13 -13
  216. package/src/_modules/ai/_modules/open-ai/_models/oai-settings.control-model.spec.ts +22 -22
  217. package/src/_modules/ai/_modules/open-ai/_models/oai-settings.control-model.ts +25 -25
  218. package/src/_modules/ai/_modules/open-ai/_models/oai-user-provider-config.control-model.ts +21 -21
  219. package/src/_modules/ai/_modules/open-ai/index.ts +28 -28
  220. package/src/_modules/ai/index.ts +27 -27
  221. package/src/_modules/ci-tools/_enums/cit-ci-result-code.enum.ts +11 -11
  222. package/src/_modules/ci-tools/_enums/cit-ci-step-result-code.enum.ts +9 -9
  223. package/src/_modules/ci-tools/_models/cit-ci-result-info.data-models.spec.ts +58 -58
  224. package/src/_modules/ci-tools/_models/cit-ci-result-info.data-models.ts +77 -77
  225. package/src/_modules/ci-tools/_models/cit-ci-step-result.interface.ts +12 -12
  226. package/src/_modules/ci-tools/index.ts +8 -8
  227. package/src/_modules/crypto/_collections/crypto.util.simple.spec.ts +512 -512
  228. package/src/_modules/crypto/index.ts +13 -13
  229. package/src/_modules/custom-data/_collections/cud-module-settings.const.ts +21 -21
  230. package/src/_modules/custom-data/_models/cud.data-model.spec.ts +38 -38
  231. package/src/_modules/custom-data/_models/cud.data-model.ts +39 -39
  232. package/src/_modules/custom-data/index.ts +10 -10
  233. package/src/_modules/data-handler/_models/data-handler-settings.control-model.spec.ts +110 -110
  234. package/src/_modules/data-handler/_models/data-handler-settings.control-model.ts +110 -110
  235. package/src/_modules/data-handler/_models/data-handler.control-model.spec.ts +445 -445
  236. package/src/_modules/data-handler/_models/data-handler.control-model.ts +459 -459
  237. package/src/_modules/data-handler/_models/data-list-handler.control-model.spec.ts +263 -263
  238. package/src/_modules/data-handler/_models/data-list-handler.control-model.ts +252 -252
  239. package/src/_modules/data-handler/_models/data-search-handler.control-model.spec.ts +417 -417
  240. package/src/_modules/data-handler/_models/data-search-handler.control-model.ts +390 -390
  241. package/src/_modules/data-handler/_models/list-collector-data-handler.control-model.spec.ts +374 -374
  242. package/src/_modules/data-handler/_models/list-collector-data-handler.control-model.ts +274 -274
  243. package/src/_modules/data-handler/index.ts +6 -6
  244. package/src/_modules/location/_collections/assets/country-codes-ISO-3166.json +3239 -3239
  245. package/src/_modules/location/_collections/assets/country-divisions-ISO-3166-all-list.json +19035 -19035
  246. package/src/_modules/location/_collections/assets/country-divisions-ISO-3166.json +4993 -4993
  247. package/src/_modules/location/_collections/assets/country-phone-codes.json +1203 -1203
  248. package/src/_modules/location/_collections/assets/country-subdivisions/afghanistan.json +137 -137
  249. package/src/_modules/location/_collections/assets/country-subdivisions/albania.json +49 -49
  250. package/src/_modules/location/_collections/assets/country-subdivisions/algeria.json +193 -193
  251. package/src/_modules/location/_collections/assets/country-subdivisions/andorra.json +29 -29
  252. package/src/_modules/location/_collections/assets/country-subdivisions/angola.json +73 -73
  253. package/src/_modules/location/_collections/assets/country-subdivisions/antigua-and-barbuda.json +33 -33
  254. package/src/_modules/location/_collections/assets/country-subdivisions/argentina.json +97 -97
  255. package/src/_modules/location/_collections/assets/country-subdivisions/armenia.json +45 -45
  256. package/src/_modules/location/_collections/assets/country-subdivisions/australia.json +33 -33
  257. package/src/_modules/location/_collections/assets/country-subdivisions/austria.json +37 -37
  258. package/src/_modules/location/_collections/assets/country-subdivisions/azerbaijan.json +5 -5
  259. package/src/_modules/location/_collections/assets/country-subdivisions/bahamas.json +125 -125
  260. package/src/_modules/location/_collections/assets/country-subdivisions/bahrain.json +21 -21
  261. package/src/_modules/location/_collections/assets/country-subdivisions/bangladesh.json +29 -29
  262. package/src/_modules/location/_collections/assets/country-subdivisions/barbados.json +45 -45
  263. package/src/_modules/location/_collections/assets/country-subdivisions/belarus.json +29 -29
  264. package/src/_modules/location/_collections/assets/country-subdivisions/belgium.json +13 -13
  265. package/src/_modules/location/_collections/assets/country-subdivisions/belize.json +25 -25
  266. package/src/_modules/location/_collections/assets/country-subdivisions/benin.json +49 -49
  267. package/src/_modules/location/_collections/assets/country-subdivisions/bhutan.json +81 -81
  268. package/src/_modules/location/_collections/assets/country-subdivisions/bolivia.json +37 -37
  269. package/src/_modules/location/_collections/assets/country-subdivisions/bosnia-and-herzegovina.json +13 -13
  270. package/src/_modules/location/_collections/assets/country-subdivisions/botswana.json +65 -65
  271. package/src/_modules/location/_collections/assets/country-subdivisions/brazil.json +109 -109
  272. package/src/_modules/location/_collections/assets/country-subdivisions/brunei-darussalam.json +17 -17
  273. package/src/_modules/location/_collections/assets/country-subdivisions/bulgaria.json +113 -113
  274. package/src/_modules/location/_collections/assets/country-subdivisions/burkina-faso.json +53 -53
  275. package/src/_modules/location/_collections/assets/country-subdivisions/burundi.json +69 -69
  276. package/src/_modules/location/_collections/assets/country-subdivisions/cambodia.json +97 -97
  277. package/src/_modules/location/_collections/assets/country-subdivisions/cameroon.json +41 -41
  278. package/src/_modules/location/_collections/assets/country-subdivisions/canada.json +79 -79
  279. package/src/_modules/location/_collections/assets/country-subdivisions/cape-verde.json +9 -9
  280. package/src/_modules/location/_collections/assets/country-subdivisions/central-african-republic.json +69 -69
  281. package/src/_modules/location/_collections/assets/country-subdivisions/chad.json +89 -89
  282. package/src/_modules/location/_collections/assets/country-subdivisions/chile.json +61 -61
  283. package/src/_modules/location/_collections/assets/country-subdivisions/china.json +205 -205
  284. package/src/_modules/location/_collections/assets/country-subdivisions/colombia.json +133 -133
  285. package/src/_modules/location/_collections/assets/country-subdivisions/comoros.json +13 -13
  286. package/src/_modules/location/_collections/assets/country-subdivisions/congo-the-democratic-republic-of-the.json +45 -45
  287. package/src/_modules/location/_collections/assets/country-subdivisions/congo.json +49 -49
  288. package/src/_modules/location/_collections/assets/country-subdivisions/costa-rica.json +29 -29
  289. package/src/_modules/location/_collections/assets/country-subdivisions/cote-d-ivoire-republic-of.json +77 -77
  290. package/src/_modules/location/_collections/assets/country-subdivisions/croatia.json +85 -85
  291. package/src/_modules/location/_collections/assets/country-subdivisions/cuba.json +65 -65
  292. package/src/_modules/location/_collections/assets/country-subdivisions/cyprus.json +25 -25
  293. package/src/_modules/location/_collections/assets/country-subdivisions/czech-republic.json +57 -57
  294. package/src/_modules/location/_collections/assets/country-subdivisions/denmark.json +21 -21
  295. package/src/_modules/location/_collections/assets/country-subdivisions/djibouti.json +25 -25
  296. package/src/_modules/location/_collections/assets/country-subdivisions/dominica.json +41 -41
  297. package/src/_modules/location/_collections/assets/country-subdivisions/dominican-republic.json +41 -41
  298. package/src/_modules/location/_collections/assets/country-subdivisions/ecuador.json +97 -97
  299. package/src/_modules/location/_collections/assets/country-subdivisions/egypt.json +117 -117
  300. package/src/_modules/location/_collections/assets/country-subdivisions/el-salvador.json +57 -57
  301. package/src/_modules/location/_collections/assets/country-subdivisions/equatorial-guinea.json +9 -9
  302. package/src/_modules/location/_collections/assets/country-subdivisions/eritrea.json +25 -25
  303. package/src/_modules/location/_collections/assets/country-subdivisions/estonia.json +61 -61
  304. package/src/_modules/location/_collections/assets/country-subdivisions/ethiopia.json +45 -45
  305. package/src/_modules/location/_collections/assets/country-subdivisions/fiji.json +21 -21
  306. package/src/_modules/location/_collections/assets/country-subdivisions/finland.json +77 -77
  307. package/src/_modules/location/_collections/assets/country-subdivisions/france.json +133 -133
  308. package/src/_modules/location/_collections/assets/country-subdivisions/gabon.json +37 -37
  309. package/src/_modules/location/_collections/assets/country-subdivisions/gambia.json +25 -25
  310. package/src/_modules/location/_collections/assets/country-subdivisions/georgia.json +49 -49
  311. package/src/_modules/location/_collections/assets/country-subdivisions/germany.json +65 -65
  312. package/src/_modules/location/_collections/assets/country-subdivisions/ghana.json +41 -41
  313. package/src/_modules/location/_collections/assets/country-subdivisions/greece.json +53 -53
  314. package/src/_modules/location/_collections/assets/country-subdivisions/greenland.json +17 -17
  315. package/src/_modules/location/_collections/assets/country-subdivisions/grenada.json +29 -29
  316. package/src/_modules/location/_collections/assets/country-subdivisions/guatemala.json +89 -89
  317. package/src/_modules/location/_collections/assets/country-subdivisions/guinea-bissau.json +13 -13
  318. package/src/_modules/location/_collections/assets/country-subdivisions/guinea.json +33 -33
  319. package/src/_modules/location/_collections/assets/country-subdivisions/guyana.json +41 -41
  320. package/src/_modules/location/_collections/assets/country-subdivisions/haiti.json +41 -41
  321. package/src/_modules/location/_collections/assets/country-subdivisions/honduras.json +73 -73
  322. package/src/_modules/location/_collections/assets/country-subdivisions/hong-kong.json +4 -4
  323. package/src/_modules/location/_collections/assets/country-subdivisions/hungary.json +173 -173
  324. package/src/_modules/location/_collections/assets/country-subdivisions/iceland.json +37 -37
  325. package/src/_modules/location/_collections/assets/country-subdivisions/india.json +181 -181
  326. package/src/_modules/location/_collections/assets/country-subdivisions/indonesia.json +29 -29
  327. package/src/_modules/location/_collections/assets/country-subdivisions/iran-islamic-republic-of.json +125 -125
  328. package/src/_modules/location/_collections/assets/country-subdivisions/iraq.json +73 -73
  329. package/src/_modules/location/_collections/assets/country-subdivisions/ireland.json +17 -17
  330. package/src/_modules/location/_collections/assets/country-subdivisions/israel.json +25 -25
  331. package/src/_modules/location/_collections/assets/country-subdivisions/italy.json +81 -81
  332. package/src/_modules/location/_collections/assets/country-subdivisions/jamaica.json +57 -57
  333. package/src/_modules/location/_collections/assets/country-subdivisions/japan.json +189 -189
  334. package/src/_modules/location/_collections/assets/country-subdivisions/jordan.json +49 -49
  335. package/src/_modules/location/_collections/assets/country-subdivisions/kazakhstan.json +65 -65
  336. package/src/_modules/location/_collections/assets/country-subdivisions/kenya.json +33 -33
  337. package/src/_modules/location/_collections/assets/country-subdivisions/kiribati.json +13 -13
  338. package/src/_modules/location/_collections/assets/country-subdivisions/korea-democratic-people-s-republic-of.json +45 -45
  339. package/src/_modules/location/_collections/assets/country-subdivisions/korea-republic-of.json +69 -69
  340. package/src/_modules/location/_collections/assets/country-subdivisions/kuwait.json +25 -25
  341. package/src/_modules/location/_collections/assets/country-subdivisions/kyrgyzstan.json +33 -33
  342. package/src/_modules/location/_collections/assets/country-subdivisions/lao-people-s-democratic-republic.json +73 -73
  343. package/src/_modules/location/_collections/assets/country-subdivisions/latvia.json +477 -477
  344. package/src/_modules/location/_collections/assets/country-subdivisions/lebanon.json +33 -33
  345. package/src/_modules/location/_collections/assets/country-subdivisions/lesotho.json +41 -41
  346. package/src/_modules/location/_collections/assets/country-subdivisions/liberia.json +61 -61
  347. package/src/_modules/location/_collections/assets/country-subdivisions/libyan-arab-jamahiriya.json +89 -89
  348. package/src/_modules/location/_collections/assets/country-subdivisions/liechtenstein.json +45 -45
  349. package/src/_modules/location/_collections/assets/country-subdivisions/lithuania.json +41 -41
  350. package/src/_modules/location/_collections/assets/country-subdivisions/luxembourg.json +13 -13
  351. package/src/_modules/location/_collections/assets/country-subdivisions/macedonia-the-former-yugoslav-republic-of.json +337 -337
  352. package/src/_modules/location/_collections/assets/country-subdivisions/madagascar.json +25 -25
  353. package/src/_modules/location/_collections/assets/country-subdivisions/malawi.json +13 -13
  354. package/src/_modules/location/_collections/assets/country-subdivisions/malaysia.json +81 -81
  355. package/src/_modules/location/_collections/assets/country-subdivisions/maldives.json +33 -33
  356. package/src/_modules/location/_collections/assets/country-subdivisions/mali.json +37 -37
  357. package/src/_modules/location/_collections/assets/country-subdivisions/malta.json +273 -273
  358. package/src/_modules/location/_collections/assets/country-subdivisions/marshall-islands.json +9 -9
  359. package/src/_modules/location/_collections/assets/country-subdivisions/mauritania.json +53 -53
  360. package/src/_modules/location/_collections/assets/country-subdivisions/mauritius.json +69 -69
  361. package/src/_modules/location/_collections/assets/country-subdivisions/mexico.json +161 -161
  362. package/src/_modules/location/_collections/assets/country-subdivisions/micronesia-federated-states-of.json +17 -17
  363. package/src/_modules/location/_collections/assets/country-subdivisions/moldova-republic-of.json +149 -149
  364. package/src/_modules/location/_collections/assets/country-subdivisions/monaco.json +69 -69
  365. package/src/_modules/location/_collections/assets/country-subdivisions/mongolia.json +89 -89
  366. package/src/_modules/location/_collections/assets/country-subdivisions/montenegro.json +93 -93
  367. package/src/_modules/location/_collections/assets/country-subdivisions/morocco.json +65 -65
  368. package/src/_modules/location/_collections/assets/country-subdivisions/mozambique.json +45 -45
  369. package/src/_modules/location/_collections/assets/country-subdivisions/myanmar.json +57 -57
  370. package/src/_modules/location/_collections/assets/country-subdivisions/namibia.json +57 -57
  371. package/src/_modules/location/_collections/assets/country-subdivisions/nauru.json +57 -57
  372. package/src/_modules/location/_collections/assets/country-subdivisions/nepal.json +21 -21
  373. package/src/_modules/location/_collections/assets/country-subdivisions/netherlands.json +91 -91
  374. package/src/_modules/location/_collections/assets/country-subdivisions/new-zealand.json +111 -111
  375. package/src/_modules/location/_collections/assets/country-subdivisions/nicaragua.json +69 -69
  376. package/src/_modules/location/_collections/assets/country-subdivisions/niger.json +33 -33
  377. package/src/_modules/location/_collections/assets/country-subdivisions/nigeria.json +149 -149
  378. package/src/_modules/location/_collections/assets/country-subdivisions/norway.json +85 -85
  379. package/src/_modules/location/_collections/assets/country-subdivisions/oman.json +37 -37
  380. package/src/_modules/location/_collections/assets/country-subdivisions/pakistan.json +33 -33
  381. package/src/_modules/location/_collections/assets/country-subdivisions/palau.json +65 -65
  382. package/src/_modules/location/_collections/assets/country-subdivisions/palestinian-territory-occupied.json +65 -65
  383. package/src/_modules/location/_collections/assets/country-subdivisions/panama.json +53 -53
  384. package/src/_modules/location/_collections/assets/country-subdivisions/papua-new-guinea.json +81 -81
  385. package/src/_modules/location/_collections/assets/country-subdivisions/paraguay.json +73 -73
  386. package/src/_modules/location/_collections/assets/country-subdivisions/peru.json +105 -105
  387. package/src/_modules/location/_collections/assets/country-subdivisions/philippines.json +69 -69
  388. package/src/_modules/location/_collections/assets/country-subdivisions/poland.json +65 -65
  389. package/src/_modules/location/_collections/assets/country-subdivisions/portugal.json +81 -81
  390. package/src/_modules/location/_collections/assets/country-subdivisions/qatar.json +29 -29
  391. package/src/_modules/location/_collections/assets/country-subdivisions/romania.json +169 -169
  392. package/src/_modules/location/_collections/assets/country-subdivisions/russian-federation.json +499 -499
  393. package/src/_modules/location/_collections/assets/country-subdivisions/rwanda.json +21 -21
  394. package/src/_modules/location/_collections/assets/country-subdivisions/saint-helena-ascension-and-tristan-da-cunha.json +13 -13
  395. package/src/_modules/location/_collections/assets/country-subdivisions/saint-kitts-and-nevis.json +9 -9
  396. package/src/_modules/location/_collections/assets/country-subdivisions/saint-lucia.json +45 -45
  397. package/src/_modules/location/_collections/assets/country-subdivisions/saint-vincent-and-the-grenadines.json +25 -25
  398. package/src/_modules/location/_collections/assets/country-subdivisions/samoa.json +45 -45
  399. package/src/_modules/location/_collections/assets/country-subdivisions/san-marino.json +37 -37
  400. package/src/_modules/location/_collections/assets/country-subdivisions/sao-tome-and-principe.json +9 -9
  401. package/src/_modules/location/_collections/assets/country-subdivisions/saudi-arabia.json +53 -53
  402. package/src/_modules/location/_collections/assets/country-subdivisions/senegal.json +57 -57
  403. package/src/_modules/location/_collections/assets/country-subdivisions/serbia.json +9 -9
  404. package/src/_modules/location/_collections/assets/country-subdivisions/seychelles.json +101 -101
  405. package/src/_modules/location/_collections/assets/country-subdivisions/sierra-leone.json +17 -17
  406. package/src/_modules/location/_collections/assets/country-subdivisions/singapore.json +21 -21
  407. package/src/_modules/location/_collections/assets/country-subdivisions/slovakia.json +33 -33
  408. package/src/_modules/location/_collections/assets/country-subdivisions/slovenia.json +841 -841
  409. package/src/_modules/location/_collections/assets/country-subdivisions/solomon-islands.json +41 -41
  410. package/src/_modules/location/_collections/assets/country-subdivisions/somalia.json +73 -73
  411. package/src/_modules/location/_collections/assets/country-subdivisions/south-africa.json +37 -37
  412. package/src/_modules/location/_collections/assets/country-subdivisions/south-sudan.json +41 -41
  413. package/src/_modules/location/_collections/assets/country-subdivisions/spain.json +346 -346
  414. package/src/_modules/location/_collections/assets/country-subdivisions/sri-lanka.json +37 -37
  415. package/src/_modules/location/_collections/assets/country-subdivisions/sudan.json +69 -69
  416. package/src/_modules/location/_collections/assets/country-subdivisions/suriname.json +41 -41
  417. package/src/_modules/location/_collections/assets/country-subdivisions/swaziland.json +17 -17
  418. package/src/_modules/location/_collections/assets/country-subdivisions/sweden.json +85 -85
  419. package/src/_modules/location/_collections/assets/country-subdivisions/switzerland.json +105 -105
  420. package/src/_modules/location/_collections/assets/country-subdivisions/syrian-arab-republic.json +57 -57
  421. package/src/_modules/location/_collections/assets/country-subdivisions/taiwan-province-of-china.json +93 -93
  422. package/src/_modules/location/_collections/assets/country-subdivisions/tajikistan.json +17 -17
  423. package/src/_modules/location/_collections/assets/country-subdivisions/tanzania-united-republic-of.json +105 -105
  424. package/src/_modules/location/_collections/assets/country-subdivisions/thailand.json +313 -313
  425. package/src/_modules/location/_collections/assets/country-subdivisions/timor-leste.json +53 -53
  426. package/src/_modules/location/_collections/assets/country-subdivisions/togo.json +21 -21
  427. package/src/_modules/location/_collections/assets/country-subdivisions/tonga.json +21 -21
  428. package/src/_modules/location/_collections/assets/country-subdivisions/trinidad-and-tobago.json +65 -65
  429. package/src/_modules/location/_collections/assets/country-subdivisions/tunisia.json +97 -97
  430. package/src/_modules/location/_collections/assets/country-subdivisions/turkey.json +325 -325
  431. package/src/_modules/location/_collections/assets/country-subdivisions/turkmenistan.json +25 -25
  432. package/src/_modules/location/_collections/assets/country-subdivisions/tuvalu.json +33 -33
  433. package/src/_modules/location/_collections/assets/country-subdivisions/uganda.json +17 -17
  434. package/src/_modules/location/_collections/assets/country-subdivisions/ukraine.json +109 -109
  435. package/src/_modules/location/_collections/assets/country-subdivisions/united-arab-emirates.json +29 -29
  436. package/src/_modules/location/_collections/assets/country-subdivisions/united-kingdom.json +1196 -1196
  437. package/src/_modules/location/_collections/assets/country-subdivisions/united-states-minor-outlying-islands.json +37 -37
  438. package/src/_modules/location/_collections/assets/country-subdivisions/united-states.json +286 -286
  439. package/src/_modules/location/_collections/assets/country-subdivisions/uruguay.json +77 -77
  440. package/src/_modules/location/_collections/assets/country-subdivisions/uzbekistan.json +57 -57
  441. package/src/_modules/location/_collections/assets/country-subdivisions/vanuatu.json +25 -25
  442. package/src/_modules/location/_collections/assets/country-subdivisions/venezuela.json +101 -101
  443. package/src/_modules/location/_collections/assets/country-subdivisions/viet-nam.json +257 -257
  444. package/src/_modules/location/_collections/assets/country-subdivisions/yemen.json +85 -85
  445. package/src/_modules/location/_collections/assets/country-subdivisions/zambia.json +37 -37
  446. package/src/_modules/location/_collections/assets/country-subdivisions/zimbabwe.json +41 -41
  447. package/src/_modules/location/_collections/loc-country-divisions.const.ts +10 -10
  448. package/src/_modules/location/_collections/loc-country-isos.const.ts +8 -8
  449. package/src/_modules/location/_collections/loc-regions.util.spec.ts +61 -61
  450. package/src/_modules/location/_collections/loc-regions.util.ts +137 -137
  451. package/src/_modules/location/_collections/loc.util.spec.ts +52 -52
  452. package/src/_modules/location/_collections/loc.util.ts +74 -74
  453. package/src/_modules/location/_enums/loc-region.enum.ts +14 -14
  454. package/src/_modules/location/_enums/loc-sub-region.enum.ts +31 -31
  455. package/src/_modules/location/_enums/loc-subdivision-region-type.enum.ts +47 -47
  456. package/src/_modules/location/_models/loc-coordinates.interface.ts +7 -7
  457. package/src/_modules/location/_models/loc-country-division.interface.ts +8 -8
  458. package/src/_modules/location/_models/loc-country-iso.interface.ts +23 -23
  459. package/src/_modules/location/_models/loc-country-phone-code.interface.ts +9 -9
  460. package/src/_modules/location/_models/loc-division-collection.interface.ts +12 -12
  461. package/src/_modules/location/_models/loc-division-region-data.interface.ts +9 -9
  462. package/src/_modules/location/_models/loc-geo-ip-location.interface.ts +27 -27
  463. package/src/_modules/location/index.ts +22 -22
  464. package/src/_modules/messaging/README.md +279 -279
  465. package/src/_modules/messaging/_collections/msg-module-settings.const.ts +46 -46
  466. package/src/_modules/messaging/_enums/msg-attachment-type.enum.ts +26 -26
  467. package/src/_modules/messaging/_enums/msg-delivery-status.enum.ts +17 -17
  468. package/src/_modules/messaging/_enums/msg-event-key.enum.ts +31 -31
  469. package/src/_modules/messaging/_enums/msg-participant-role.enum.ts +20 -20
  470. package/src/_modules/messaging/_enums/msg-provider-type.enum.ts +7 -7
  471. package/src/_modules/messaging/_enums/msg-type.enum.ts +23 -23
  472. package/src/_modules/messaging/_models/msg-attachment.interface.ts +46 -46
  473. package/src/_modules/messaging/_models/msg-conversation.data-model.spec.ts +69 -69
  474. package/src/_modules/messaging/_models/msg-conversation.data-model.ts +96 -96
  475. package/src/_modules/messaging/_models/msg-mention.interface.ts +29 -29
  476. package/src/_modules/messaging/_models/msg-message.data-model.spec.ts +79 -79
  477. package/src/_modules/messaging/_models/msg-message.data-model.ts +127 -127
  478. package/src/_modules/messaging/_models/msg-participant.interface.ts +46 -46
  479. package/src/_modules/messaging/_models/msg-reaction.interface.ts +20 -20
  480. package/src/_modules/messaging/_models/msg-thread-info.interface.ts +35 -35
  481. package/src/_modules/messaging/_modules/agent/_enums/agt-process-step-type.enum.ts +35 -35
  482. package/src/_modules/messaging/_modules/agent/_enums/agt-tool-status.enum.ts +23 -23
  483. package/src/_modules/messaging/_modules/agent/_models/agt-process-step.interface.ts +55 -55
  484. package/src/_modules/messaging/_modules/agent/_models/agt-reasoning-info.interface.ts +26 -26
  485. package/src/_modules/messaging/_modules/agent/_models/agt-tool-usage.interface.ts +37 -37
  486. package/src/_modules/messaging/_modules/agent/index.ts +8 -8
  487. package/src/_modules/messaging/index.ts +28 -28
  488. package/src/_modules/pipe/_collections/pip-transforms.const.ts +42 -42
  489. package/src/_modules/pipe/_collections/utils/pip-country-pipe.util.spec.ts +47 -47
  490. package/src/_modules/pipe/_collections/utils/pip-country-pipe.util.ts +41 -41
  491. package/src/_modules/pipe/_collections/utils/pip-custom-pipe.util.spec.ts +39 -39
  492. package/src/_modules/pipe/_collections/utils/pip-custom-pipe.util.ts +30 -30
  493. package/src/_modules/pipe/_collections/utils/pip-division-pipe.util.spec.ts +41 -41
  494. package/src/_modules/pipe/_collections/utils/pip-division-pipe.util.ts +36 -36
  495. package/src/_modules/pipe/_collections/utils/pip-json-pipe.util.spec.ts +62 -62
  496. package/src/_modules/pipe/_collections/utils/pip-json-pipe.util.ts +17 -17
  497. package/src/_modules/pipe/_collections/utils/pip-list-pipe.util.spec.ts +34 -34
  498. package/src/_modules/pipe/_collections/utils/pip-list-pipe.util.ts +25 -25
  499. package/src/_modules/pipe/_collections/utils/pip-multi-pipe-pipe.util.spec.ts +67 -67
  500. package/src/_modules/pipe/_collections/utils/pip-multi-pipe-pipe.util.ts +226 -226
  501. package/src/_modules/pipe/_collections/utils/pip-obj-key-pipe.util.spec.ts +28 -28
  502. package/src/_modules/pipe/_collections/utils/pip-obj-key-pipe.util.ts +21 -21
  503. package/src/_modules/pipe/_collections/utils/pip-range-pipe.util.spec.ts +59 -59
  504. package/src/_modules/pipe/_collections/utils/pip-range-pipe.util.ts +106 -106
  505. package/src/_modules/pipe/_collections/utils/pip-region-pipe.util.spec.ts +31 -31
  506. package/src/_modules/pipe/_collections/utils/pip-region-pipe.util.ts +35 -35
  507. package/src/_modules/pipe/_collections/utils/pip-replace-pipe.util.spec.ts +44 -44
  508. package/src/_modules/pipe/_collections/utils/pip-replace-pipe.util.ts +23 -23
  509. package/src/_modules/pipe/_collections/utils/pip-slider-pipe.util.spec.ts +21 -21
  510. package/src/_modules/pipe/_collections/utils/pip-slider-pipe.util.ts +33 -33
  511. package/src/_modules/pipe/_collections/utils/pip-smart-replace-pipe.util.spec.ts +62 -62
  512. package/src/_modules/pipe/_collections/utils/pip-smart-replace-pipe.util.ts +80 -80
  513. package/src/_modules/pipe/_enums/pip-range-pipe-setting.enum.ts +15 -15
  514. package/src/_modules/pipe/_enums/pip.enum.ts +65 -65
  515. package/src/_modules/pipe/_models/pip-multi-pipe-settings.type.ts +8 -8
  516. package/src/_modules/pipe/_models/pip-transforms.interface.ts +30 -30
  517. package/src/_modules/pipe/index.ts +30 -30
  518. package/src/_modules/socket/_enums/sck-event-key.enum.ts +21 -21
  519. package/src/_modules/socket/_models/sck-client-params.control-model.spec.ts +67 -67
  520. package/src/_modules/socket/_models/sck-client-params.control-model.ts +50 -50
  521. package/src/_modules/socket/_models/sck-socket-event.control-model.spec.ts +66 -66
  522. package/src/_modules/socket/_models/sck-socket-event.control-model.ts +172 -172
  523. package/src/_modules/socket/_services/sck-client.service-base.spec.ts +99 -99
  524. package/src/_modules/socket/_services/sck-client.service-base.ts +353 -353
  525. package/src/_modules/socket/index.ts +14 -14
  526. package/src/_modules/test/_collections/tst-module-settings.const.ts +67 -67
  527. package/src/_modules/test/index.ts +5 -5
  528. package/src/_modules/usage/_collections/usg-module-settings.const.ts +33 -33
  529. package/src/_modules/usage/_models/usg-action.control-model.spec.ts +27 -27
  530. package/src/_modules/usage/_models/usg-action.control-model.ts +28 -28
  531. package/src/_modules/usage/_models/usg-daily-usage-data.control-model.spec.ts +36 -36
  532. package/src/_modules/usage/_models/usg-daily-usage-data.control-model.ts +35 -35
  533. package/src/_modules/usage/_models/usg-data.control-model.spec.ts +41 -41
  534. package/src/_modules/usage/_models/usg-data.control-model.ts +35 -35
  535. package/src/_modules/usage/_models/usg-session.data-model.spec.ts +97 -97
  536. package/src/_modules/usage/_models/usg-session.data-model.ts +72 -72
  537. package/src/_modules/usage/index.ts +11 -11
  538. package/src/index.ts +102 -102
  539. package/tsconfig.app.json +12 -12
  540. package/tsconfig.json +31 -31
  541. package/tsconfig.test.json +16 -16
  542. package/tslint.json +153 -153
  543. package/pipeline.cicd.config.json +0 -128
@@ -1,459 +1,459 @@
1
- import { DyFM_Log, DyFM_Metadata, DyFM_SearchQuery, DyFM_SearchResult } from '../../..';
2
- import { BehaviorSubject, Observable } from 'rxjs';
3
-
4
- import { DyFM_DataHandler_Settings } from './data-handler-settings.control-model';
5
-
6
- /**
7
- * DyFM_DataHandlerDataLoadInProgress
8
- */
9
- export interface DyFM_DataHandlerDataLoadInProgress<T_LoadBy> {
10
- loadBy: T_LoadBy;
11
- progress: Promise<any>;
12
- }
13
-
14
- /**
15
- * DyFM_DataHandlerDataPostProcess
16
- */
17
- export type DyFM_DataHandlerDataLoadPostProcess<T_LoadBy> = (data: any, loadedBy: T_LoadBy) => Promise<any> | any;
18
-
19
- /**
20
- * DynamoDataHandler is used to create application wide data handling
21
- * used to create subscribeAble data handler
22
- *
23
- * this implements data reload function that uses predefined apiService,
24
- * using previous or given id,
25
- * prevents multiple load calls and triggers data change subscriptions when done
26
- *
27
- * load post processes can be implemented to ensure special conditions
28
- *
29
- * @example
30
- * personalInformationDH = new DynamoDataHandler<PersonalInformation>({
31
- * apiService: this.accountApiService,
32
- * getDataFunctionName: 'getPersonalInformation',
33
- * });
34
- */
35
- export abstract class DyFM_DataHandler<
36
- T extends DyFM_Metadata | DyFM_Metadata[],
37
- T_Dependency extends DyFM_Metadata = any,
38
- T_LoadBy = string
39
- > {
40
- name: string;
41
-
42
- /**
43
- * BehaviorSubject that holds the current data value.
44
- * This is the source of truth for data in DyFM.
45
- */
46
- protected readonly data_BS: BehaviorSubject<T>;
47
-
48
- /**
49
- * Observable that emits the current data value.
50
- * Derived from the BehaviorSubject.
51
- */
52
- readonly data$: Observable<T>;
53
-
54
- /**
55
- * BehaviorSubject that indicates whether the data has been loaded.
56
- * True when data is loaded, false otherwise.
57
- */
58
- protected readonly loaded_BS: BehaviorSubject<boolean>;
59
-
60
- /**
61
- * Observable that indicates whether the data has been loaded.
62
- */
63
- readonly loaded$: Observable<boolean>;
64
-
65
- /**
66
- * BehaviorSubject that tracks the current loading operation.
67
- * Contains information about the ongoing data load operation or false if no load is in progress.
68
- */
69
- protected readonly loadInProgress_BS: BehaviorSubject<DyFM_DataHandlerDataLoadInProgress<T_LoadBy> | false>;
70
-
71
- /**
72
- * Observable that tracks the current loading operation.
73
- */
74
- readonly loadInProgress$: Observable<DyFM_DataHandlerDataLoadInProgress<T_LoadBy> | false>;
75
-
76
- /**
77
- * Gets the current data value.
78
- * @returns The current data value
79
- */
80
- abstract get data(): T;
81
-
82
- /**
83
- * last loaded by will work properly only if you use the Dynamo form of "_id" for loading
84
- */
85
- lastLoadedBy: T_LoadBy; // for lists
86
- defaultLoadBy: T_LoadBy; // for lists
87
-
88
- /** this will handle the data loading from the api */
89
- protected readonly get: (loadBy?: T_LoadBy) => Promise<any>;
90
- /** this will handle the data setting to the data handler */
91
- protected readonly set: (data: T) => Promise<T>;
92
- /** this will handle the data patching to the data handler */
93
- /* patch: (data: T) => Promise<T>; */
94
-
95
- // TODO
96
- /* directApiSetup: any; */
97
-
98
- /**
99
- * post processes will be called as pipes after data is loaded by get function,
100
- * but before data is set to data handler by data_$.set (after get, before Signal triggers)
101
- */
102
- protected readonly getPostProcesses: DyFM_DataHandlerDataLoadPostProcess<T_LoadBy>[] = [];
103
-
104
- noId?: boolean;
105
-
106
- waitsOnLoad: {
107
- promise: Promise<void>;
108
- resolve: () => void;
109
- }[] = [];
110
-
111
- protected readonly dependentDataHandlers?: DyFM_DataHandler<any>[] = [];
112
-
113
- debugLog?: boolean;
114
-
115
- /**
116
- * DynamoDataHandler
117
- * @param apiService any service can be used as apiService
118
- * as long as the function, you pass in getDataFunctionName exists,
119
- * uses (or not uses an ID as input) and returns the data as Promise<Type>
120
- * @param getDataFunctionName the function name on the apiService,
121
- * that will be used as get api call
122
- *
123
- * @param successfulReloadCallBack you can create direct callback for successful reloads
124
- * by passing it here
125
- *
126
- * @param getPostPreprocessLoad post processes can be implemented to ensure special conditions on data
127
- *
128
- * @param defaultValue you can set default value that will be used before any load
129
- * @param noId this flag needs to be true, when using api function without id
130
- *
131
- * @example
132
- * personalInformationDH = new DynamoDataHandler<PersonalInformation>({
133
- * apiService: this.accountApiService,
134
- * getDataFunctionName: 'getPersonalInformation',
135
- * });
136
- */
137
- constructor(
138
- set: DyFM_DataHandler_Settings<T, T_Dependency, T_LoadBy>,
139
- /** is in construct?
140
- * so the dependent data handlers are not added here, but in the extended class */
141
- skipDependencyConnections?: boolean
142
- ) {
143
- // TODO: + TRYTOGETTYPE(this.data);
144
- if (!set.name) {
145
- set.name = 'Unnamed DataHandler ' + (+new Date());
146
-
147
- DyFM_Log.warn(
148
- `DYNAMO DH.constructor (${this.name}) WARN: ` +
149
- `\n Name is not set!`,
150
- '\n\n', new Error()
151
- );
152
- }
153
-
154
- this.name = set.name;
155
- this.debugLog = set?.debugLog;
156
-
157
- // Initialize BehaviorSubjects
158
- this.data_BS = new BehaviorSubject<T>(set.defaultValue);
159
- this.data$ = this.data_BS.asObservable();
160
-
161
- this.loaded_BS = new BehaviorSubject<boolean>(false);
162
- this.loaded$ = this.loaded_BS.asObservable();
163
-
164
- this.loadInProgress_BS = new BehaviorSubject<DyFM_DataHandlerDataLoadInProgress<T_LoadBy> | false>(false);
165
- this.loadInProgress$ = this.loadInProgress_BS.asObservable();
166
-
167
- if (set.get) {
168
- this.get = set.get;
169
- }
170
-
171
- if (set.set) {
172
- this.set = set.set;
173
- }
174
-
175
- this.noId = !!set.noId;
176
-
177
- if (set.defaultLoadBy) {
178
- this.defaultLoadBy = set.defaultLoadBy;
179
- }
180
-
181
- if (!skipDependencyConnections) {
182
- if (set.dependencyDataHandler) {
183
- this.addDependencyDataHandler(set.dependencyDataHandler);
184
- }
185
-
186
- if (set.dependentDataHandlers) {
187
- this.addDependentDataHandlers(set.dependentDataHandlers, true);
188
- }
189
- }
190
-
191
- if (set.getPostProcess) {
192
- this.getPostProcesses.push(set.getPostProcess);
193
- }
194
- }
195
-
196
- addDependencyDataHandler(dependencyDataHandler: DyFM_DataHandler<any>): void {
197
- try {
198
- if (!dependencyDataHandler) {
199
- throw new Error(
200
- `DYNAMO DH.addDependencyDataHandler (${this.name}) ERROR: ` +
201
- `\n Dependent DataHandler is null or undefined! (${this.name})`
202
- );
203
- }
204
-
205
- if (!(dependencyDataHandler instanceof DyFM_DataHandler)) {
206
- throw new Error(
207
- `DYNAMO DH.addDependencyDataHandler (${this.name}) ERROR: ` +
208
- `\n Dependent DataHandler is not instance of DyFM_DataHandler! (${this.name})`
209
- );
210
- }
211
-
212
- dependencyDataHandler.addDependentDataHandlers([ this ]);
213
- } catch (error) {
214
- console.error(
215
- `DYNAMO DH.addDependencyDataHandler (${this.name}) ERROR: ` +
216
- `\n Failed to add dependency data handler! ("${this.name}": "${this.constructor.name}")`,
217
- '\n\n', error,
218
- '\n\n', new Error()
219
- );
220
- }
221
- }
222
-
223
- addDependentDataHandlers(
224
- dependentDataHandlers: DyFM_DataHandler<any, any, any>[],
225
- isInConstruct?: boolean
226
- ): void {
227
- dependentDataHandlers.forEach((dependent_DH: DyFM_DataHandler<any>): void => {
228
- if (!dependent_DH) {
229
- throw new Error(
230
- `DYNAMO DH.addDependentDataHandlers (${this.name}) ERROR: ` +
231
- `\n Dependent DataHandler is null or undefined! (${this.name})`
232
- );
233
- }
234
-
235
- if (!(dependent_DH instanceof DyFM_DataHandler)) {
236
- throw new Error(
237
- `DYNAMO DH.addDependentDataHandlers (${this.name}) ERROR: ` +
238
- `\n Dependent DataHandler is not instance of DyFM_DataHandler! (${this.name})`
239
- );
240
- }
241
-
242
- if (dependent_DH.name === this.name) {
243
- throw new Error(
244
- `DYNAMO DH.addDependentDataHandlers (${this.name}) ERROR: ` +
245
- `\n Dependent DataHandler has the same name as the current DataHandler! (${this.name})`
246
- );
247
- }
248
-
249
- if (!dependent_DH.data_BS) {
250
- throw new Error(
251
- `DYNAMO DH.addDependentDataHandlers (${this.name}) ERROR: ` +
252
- `\n Dependent DataHandler has not been set up yet! ` +
253
- `(this: "${this.name}", dependent: "${dependent_DH.name}")` +
254
- `\n Try the opposite direction of dependency!\n\n`
255
- );
256
- }
257
-
258
- if (!dependentDataHandlers.includes(dependent_DH)) {
259
- dependentDataHandlers.push(dependent_DH);
260
- }
261
-
262
- if (this.debugLog) {
263
- this.getPostProcesses.push(async (newData: T): Promise<T> => {
264
- console.log(
265
- `DYNAMO DH.addDependentDataHandlers (${this.name}) DEBUG:` +
266
- `\nDataHandler triggering dependent dataHandler (${dependent_DH.name}) to reload... ` +
267
- `\n(using id: ${newData && (newData as DyFM_Metadata)._id ? (newData as DyFM_Metadata)._id : ''})`
268
- );
269
-
270
- return newData;
271
- });
272
- }
273
-
274
- this.getPostProcesses.push(
275
- async (newData: T): Promise<T> => {
276
- if (newData && (newData as DyFM_Metadata)._id && (newData as DyFM_Metadata)._id !== dependent_DH.lastLoadedBy) {
277
- dependent_DH.reloadData((newData as DyFM_Metadata)._id);
278
- } else if (!newData) {
279
- dependent_DH.clear();
280
- }
281
-
282
- return newData;
283
- }
284
- );
285
-
286
- if (!isInConstruct && this.data) {
287
- dependent_DH.reloadData((this.data as DyFM_Metadata)._id);
288
- }
289
- });
290
- }
291
-
292
- /**
293
- * reloads data on DynamoDataHandler using predefined apiservice,
294
- * using previous or given id,
295
- * prevents multiple load calls and triggers data change subscriptions when done
296
- * @param loadBy previous or given id (or can be disabled trough setup by: { noId: true })
297
- * @returns the data as Promise<T>, finishes when the call ends (throws error on fail)
298
- */
299
- async reloadData(loadBy?: T_LoadBy): Promise<T> {
300
- try {
301
- const loadInProgress = this.loadInProgress_BS.value;
302
- const useLoadBy: T_LoadBy = loadBy ??
303
- ((this.data as DyFM_Metadata)?._id as T_LoadBy) ??
304
- this.lastLoadedBy ??
305
- this.defaultLoadBy;
306
-
307
- if (!useLoadBy && !this.noId) {
308
- console.error(
309
- `DynamoERROR (DH.reloadData): Missing ID! (${this.name})`,
310
- this.data,
311
- '\n\n', new Error()
312
- );
313
-
314
- throw new Error(`DynamoERROR (DH.reloadData): Missing ID! (${this.name})`);
315
- }
316
-
317
- if (loadInProgress && loadInProgress.loadBy === useLoadBy) {
318
- if (this.debugLog) {
319
- console.log(
320
- `DYNAMO DH.reloadData (${this.name}) DEBUG:` +
321
- `\n DataHandler reloadData... (using id: ${useLoadBy})` +
322
- `\n DataHandler is already loading data...`
323
- );
324
- }
325
-
326
- return this.data;
327
- }
328
-
329
- if (this.debugLog) {
330
- console.log(
331
- `DYNAMO DH.reloadData (${this.name}) DEBUG:` +
332
- `\n DataHandler reloadData... (using id: ${useLoadBy})`
333
- );
334
- }
335
-
336
- const loadProgress = this.doReloadDataBy(useLoadBy);
337
- this.loadInProgress_BS.next({
338
- loadBy: useLoadBy,
339
- progress: loadProgress
340
- });
341
- loadProgress.finally(() => {
342
- this.loadInProgress_BS.next(false);
343
- });
344
-
345
- return await loadProgress;
346
- } catch (error) {
347
- this.loadInProgress_BS.next(false);
348
- this.loaded_BS.next(false);
349
-
350
- if (!error?.error?.handled) {
351
- console.error(
352
- `DYNAMO DH.reloadData (${this.name}) ERROR: ` +
353
- `\n reloadData was UNSUCCESSFUL`,
354
- '\n\n', error,
355
- '\n\n', new Error()
356
- );
357
-
358
- if (error?.error?.flag?.includes('DYNAMO')) {
359
- error.error.handled = true;
360
- }
361
- }
362
-
363
- throw error;
364
- }
365
- }
366
-
367
- async getData(): Promise<T> {
368
- if (!this.data) {
369
- const loadProgress = this.loadInProgress_BS.value;
370
- if (loadProgress) {
371
- return await loadProgress.progress;
372
- } else {
373
- return await this.reloadData();
374
- }
375
- } else {
376
- return this.data;
377
- }
378
- }
379
-
380
- protected async doReloadDataBy(loadedBy: T_LoadBy): Promise<T> {
381
- try {
382
- this.lastLoadedBy = loadedBy;
383
-
384
- return await this.processLoadResult(await this.get(loadedBy), loadedBy);
385
- } catch (error) {
386
- this.resolveWaitsOnLoad();
387
- throw error;
388
- }
389
- }
390
-
391
- async updateData(data: T, dontSendUpdate?: boolean): Promise<void> {
392
- if (this.set && !dontSendUpdate) {
393
- this.data_BS.next(await this.set(data));
394
- } else {
395
- this.data_BS.next(data);
396
- }
397
- }
398
-
399
- clear(dontClearDependents?: boolean): void {
400
- this.data_BS.next(undefined);
401
- this.lastLoadedBy = undefined;
402
- if (!dontClearDependents) {
403
- this.dependentDataHandlers.forEach((ddh: DyFM_DataHandler<any>): void => {
404
- ddh.clear();
405
- });
406
- }
407
- }
408
-
409
- protected async processLoadResult(result: any, loadedBy: T_LoadBy): Promise<T> {
410
- if (this.debugLog) {
411
- console.log(
412
- `DYNAMO DH.processLoadResult (${this.name}) DEBUG:` +
413
- `\n DataHandler processLoadResult... (using id: ${loadedBy})` +
414
- `\n Result:`, result
415
- );
416
- }
417
-
418
- for (const postProcess of this.getPostProcesses) {
419
- if (this.debugLog) {
420
- console.log(
421
- `DYNAMO DH.processLoadResult (${this.name}) DEBUG:` +
422
- `\n Post process:`, postProcess
423
- );
424
- }
425
-
426
- result = await postProcess(result, loadedBy);
427
-
428
- if (!result) {
429
- DyFM_Log.warn(
430
- `DYNAMO DH.processLoadResult (${this.name}) WARN: ` +
431
- `\nPost process returned null or undefined!`,
432
- '\n\n', new Error()
433
- );
434
- }
435
- }
436
- this.data_BS.next(result);
437
- this.loaded_BS.next(true);
438
- this.resolveWaitsOnLoad();
439
- return result;
440
- }
441
-
442
- private resolveWaitsOnLoad(): void {
443
- this.waitsOnLoad.forEach(({ promise, resolve }) => {
444
- resolve();
445
- });
446
- this.waitsOnLoad = [];
447
- }
448
-
449
- /**
450
- * waits for the first load to finish
451
- * @returns a promise that resolves when the first load finishes after this "subscription"
452
- */
453
- waitForLoad(): Promise<void> {
454
- let resolve: (value: void) => void;
455
- const promise = new Promise<void>((r) => { resolve = r; });
456
- this.waitsOnLoad.push({ promise, resolve });
457
- return promise;
458
- }
459
- }
1
+ import { DyFM_Log, DyFM_Metadata, DyFM_SearchQuery, DyFM_SearchResult } from '../../..';
2
+ import { BehaviorSubject, Observable } from 'rxjs';
3
+
4
+ import { DyFM_DataHandler_Settings } from './data-handler-settings.control-model';
5
+
6
+ /**
7
+ * DyFM_DataHandlerDataLoadInProgress
8
+ */
9
+ export interface DyFM_DataHandlerDataLoadInProgress<T_LoadBy> {
10
+ loadBy: T_LoadBy;
11
+ progress: Promise<any>;
12
+ }
13
+
14
+ /**
15
+ * DyFM_DataHandlerDataPostProcess
16
+ */
17
+ export type DyFM_DataHandlerDataLoadPostProcess<T_LoadBy> = (data: any, loadedBy: T_LoadBy) => Promise<any> | any;
18
+
19
+ /**
20
+ * DynamoDataHandler is used to create application wide data handling
21
+ * used to create subscribeAble data handler
22
+ *
23
+ * this implements data reload function that uses predefined apiService,
24
+ * using previous or given id,
25
+ * prevents multiple load calls and triggers data change subscriptions when done
26
+ *
27
+ * load post processes can be implemented to ensure special conditions
28
+ *
29
+ * @example
30
+ * personalInformationDH = new DynamoDataHandler<PersonalInformation>({
31
+ * apiService: this.accountApiService,
32
+ * getDataFunctionName: 'getPersonalInformation',
33
+ * });
34
+ */
35
+ export abstract class DyFM_DataHandler<
36
+ T extends DyFM_Metadata | DyFM_Metadata[],
37
+ T_Dependency extends DyFM_Metadata = any,
38
+ T_LoadBy = string
39
+ > {
40
+ name: string;
41
+
42
+ /**
43
+ * BehaviorSubject that holds the current data value.
44
+ * This is the source of truth for data in DyFM.
45
+ */
46
+ protected readonly data_BS: BehaviorSubject<T>;
47
+
48
+ /**
49
+ * Observable that emits the current data value.
50
+ * Derived from the BehaviorSubject.
51
+ */
52
+ readonly data$: Observable<T>;
53
+
54
+ /**
55
+ * BehaviorSubject that indicates whether the data has been loaded.
56
+ * True when data is loaded, false otherwise.
57
+ */
58
+ protected readonly loaded_BS: BehaviorSubject<boolean>;
59
+
60
+ /**
61
+ * Observable that indicates whether the data has been loaded.
62
+ */
63
+ readonly loaded$: Observable<boolean>;
64
+
65
+ /**
66
+ * BehaviorSubject that tracks the current loading operation.
67
+ * Contains information about the ongoing data load operation or false if no load is in progress.
68
+ */
69
+ protected readonly loadInProgress_BS: BehaviorSubject<DyFM_DataHandlerDataLoadInProgress<T_LoadBy> | false>;
70
+
71
+ /**
72
+ * Observable that tracks the current loading operation.
73
+ */
74
+ readonly loadInProgress$: Observable<DyFM_DataHandlerDataLoadInProgress<T_LoadBy> | false>;
75
+
76
+ /**
77
+ * Gets the current data value.
78
+ * @returns The current data value
79
+ */
80
+ abstract get data(): T;
81
+
82
+ /**
83
+ * last loaded by will work properly only if you use the Dynamo form of "_id" for loading
84
+ */
85
+ lastLoadedBy: T_LoadBy; // for lists
86
+ defaultLoadBy: T_LoadBy; // for lists
87
+
88
+ /** this will handle the data loading from the api */
89
+ protected readonly get: (loadBy?: T_LoadBy) => Promise<any>;
90
+ /** this will handle the data setting to the data handler */
91
+ protected readonly set: (data: T) => Promise<T>;
92
+ /** this will handle the data patching to the data handler */
93
+ /* patch: (data: T) => Promise<T>; */
94
+
95
+ // TODO
96
+ /* directApiSetup: any; */
97
+
98
+ /**
99
+ * post processes will be called as pipes after data is loaded by get function,
100
+ * but before data is set to data handler by data_$.set (after get, before Signal triggers)
101
+ */
102
+ protected readonly getPostProcesses: DyFM_DataHandlerDataLoadPostProcess<T_LoadBy>[] = [];
103
+
104
+ noId?: boolean;
105
+
106
+ waitsOnLoad: {
107
+ promise: Promise<void>;
108
+ resolve: () => void;
109
+ }[] = [];
110
+
111
+ protected readonly dependentDataHandlers?: DyFM_DataHandler<any>[] = [];
112
+
113
+ debugLog?: boolean;
114
+
115
+ /**
116
+ * DynamoDataHandler
117
+ * @param apiService any service can be used as apiService
118
+ * as long as the function, you pass in getDataFunctionName exists,
119
+ * uses (or not uses an ID as input) and returns the data as Promise<Type>
120
+ * @param getDataFunctionName the function name on the apiService,
121
+ * that will be used as get api call
122
+ *
123
+ * @param successfulReloadCallBack you can create direct callback for successful reloads
124
+ * by passing it here
125
+ *
126
+ * @param getPostPreprocessLoad post processes can be implemented to ensure special conditions on data
127
+ *
128
+ * @param defaultValue you can set default value that will be used before any load
129
+ * @param noId this flag needs to be true, when using api function without id
130
+ *
131
+ * @example
132
+ * personalInformationDH = new DynamoDataHandler<PersonalInformation>({
133
+ * apiService: this.accountApiService,
134
+ * getDataFunctionName: 'getPersonalInformation',
135
+ * });
136
+ */
137
+ constructor(
138
+ set: DyFM_DataHandler_Settings<T, T_Dependency, T_LoadBy>,
139
+ /** is in construct?
140
+ * so the dependent data handlers are not added here, but in the extended class */
141
+ skipDependencyConnections?: boolean
142
+ ) {
143
+ // TODO: + TRYTOGETTYPE(this.data);
144
+ if (!set.name) {
145
+ set.name = 'Unnamed DataHandler ' + (+new Date());
146
+
147
+ DyFM_Log.warn(
148
+ `DYNAMO DH.constructor (${this.name}) WARN: ` +
149
+ `\n Name is not set!`,
150
+ '\n\n', new Error()
151
+ );
152
+ }
153
+
154
+ this.name = set.name;
155
+ this.debugLog = set?.debugLog;
156
+
157
+ // Initialize BehaviorSubjects
158
+ this.data_BS = new BehaviorSubject<T>(set.defaultValue);
159
+ this.data$ = this.data_BS.asObservable();
160
+
161
+ this.loaded_BS = new BehaviorSubject<boolean>(false);
162
+ this.loaded$ = this.loaded_BS.asObservable();
163
+
164
+ this.loadInProgress_BS = new BehaviorSubject<DyFM_DataHandlerDataLoadInProgress<T_LoadBy> | false>(false);
165
+ this.loadInProgress$ = this.loadInProgress_BS.asObservable();
166
+
167
+ if (set.get) {
168
+ this.get = set.get;
169
+ }
170
+
171
+ if (set.set) {
172
+ this.set = set.set;
173
+ }
174
+
175
+ this.noId = !!set.noId;
176
+
177
+ if (set.defaultLoadBy) {
178
+ this.defaultLoadBy = set.defaultLoadBy;
179
+ }
180
+
181
+ if (!skipDependencyConnections) {
182
+ if (set.dependencyDataHandler) {
183
+ this.addDependencyDataHandler(set.dependencyDataHandler);
184
+ }
185
+
186
+ if (set.dependentDataHandlers) {
187
+ this.addDependentDataHandlers(set.dependentDataHandlers, true);
188
+ }
189
+ }
190
+
191
+ if (set.getPostProcess) {
192
+ this.getPostProcesses.push(set.getPostProcess);
193
+ }
194
+ }
195
+
196
+ addDependencyDataHandler(dependencyDataHandler: DyFM_DataHandler<any>): void {
197
+ try {
198
+ if (!dependencyDataHandler) {
199
+ throw new Error(
200
+ `DYNAMO DH.addDependencyDataHandler (${this.name}) ERROR: ` +
201
+ `\n Dependent DataHandler is null or undefined! (${this.name})`
202
+ );
203
+ }
204
+
205
+ if (!(dependencyDataHandler instanceof DyFM_DataHandler)) {
206
+ throw new Error(
207
+ `DYNAMO DH.addDependencyDataHandler (${this.name}) ERROR: ` +
208
+ `\n Dependent DataHandler is not instance of DyFM_DataHandler! (${this.name})`
209
+ );
210
+ }
211
+
212
+ dependencyDataHandler.addDependentDataHandlers([ this ]);
213
+ } catch (error) {
214
+ console.error(
215
+ `DYNAMO DH.addDependencyDataHandler (${this.name}) ERROR: ` +
216
+ `\n Failed to add dependency data handler! ("${this.name}": "${this.constructor.name}")`,
217
+ '\n\n', error,
218
+ '\n\n', new Error()
219
+ );
220
+ }
221
+ }
222
+
223
+ addDependentDataHandlers(
224
+ dependentDataHandlers: DyFM_DataHandler<any, any, any>[],
225
+ isInConstruct?: boolean
226
+ ): void {
227
+ dependentDataHandlers.forEach((dependent_DH: DyFM_DataHandler<any>): void => {
228
+ if (!dependent_DH) {
229
+ throw new Error(
230
+ `DYNAMO DH.addDependentDataHandlers (${this.name}) ERROR: ` +
231
+ `\n Dependent DataHandler is null or undefined! (${this.name})`
232
+ );
233
+ }
234
+
235
+ if (!(dependent_DH instanceof DyFM_DataHandler)) {
236
+ throw new Error(
237
+ `DYNAMO DH.addDependentDataHandlers (${this.name}) ERROR: ` +
238
+ `\n Dependent DataHandler is not instance of DyFM_DataHandler! (${this.name})`
239
+ );
240
+ }
241
+
242
+ if (dependent_DH.name === this.name) {
243
+ throw new Error(
244
+ `DYNAMO DH.addDependentDataHandlers (${this.name}) ERROR: ` +
245
+ `\n Dependent DataHandler has the same name as the current DataHandler! (${this.name})`
246
+ );
247
+ }
248
+
249
+ if (!dependent_DH.data_BS) {
250
+ throw new Error(
251
+ `DYNAMO DH.addDependentDataHandlers (${this.name}) ERROR: ` +
252
+ `\n Dependent DataHandler has not been set up yet! ` +
253
+ `(this: "${this.name}", dependent: "${dependent_DH.name}")` +
254
+ `\n Try the opposite direction of dependency!\n\n`
255
+ );
256
+ }
257
+
258
+ if (!dependentDataHandlers.includes(dependent_DH)) {
259
+ dependentDataHandlers.push(dependent_DH);
260
+ }
261
+
262
+ if (this.debugLog) {
263
+ this.getPostProcesses.push(async (newData: T): Promise<T> => {
264
+ console.log(
265
+ `DYNAMO DH.addDependentDataHandlers (${this.name}) DEBUG:` +
266
+ `\nDataHandler triggering dependent dataHandler (${dependent_DH.name}) to reload... ` +
267
+ `\n(using id: ${newData && (newData as DyFM_Metadata)._id ? (newData as DyFM_Metadata)._id : ''})`
268
+ );
269
+
270
+ return newData;
271
+ });
272
+ }
273
+
274
+ this.getPostProcesses.push(
275
+ async (newData: T): Promise<T> => {
276
+ if (newData && (newData as DyFM_Metadata)._id && (newData as DyFM_Metadata)._id !== dependent_DH.lastLoadedBy) {
277
+ dependent_DH.reloadData((newData as DyFM_Metadata)._id);
278
+ } else if (!newData) {
279
+ dependent_DH.clear();
280
+ }
281
+
282
+ return newData;
283
+ }
284
+ );
285
+
286
+ if (!isInConstruct && this.data) {
287
+ dependent_DH.reloadData((this.data as DyFM_Metadata)._id);
288
+ }
289
+ });
290
+ }
291
+
292
+ /**
293
+ * reloads data on DynamoDataHandler using predefined apiservice,
294
+ * using previous or given id,
295
+ * prevents multiple load calls and triggers data change subscriptions when done
296
+ * @param loadBy previous or given id (or can be disabled trough setup by: { noId: true })
297
+ * @returns the data as Promise<T>, finishes when the call ends (throws error on fail)
298
+ */
299
+ async reloadData(loadBy?: T_LoadBy): Promise<T> {
300
+ try {
301
+ const loadInProgress = this.loadInProgress_BS.value;
302
+ const useLoadBy: T_LoadBy = loadBy ??
303
+ ((this.data as DyFM_Metadata)?._id as T_LoadBy) ??
304
+ this.lastLoadedBy ??
305
+ this.defaultLoadBy;
306
+
307
+ if (!useLoadBy && !this.noId) {
308
+ console.error(
309
+ `DynamoERROR (DH.reloadData): Missing ID! (${this.name})`,
310
+ this.data,
311
+ '\n\n', new Error()
312
+ );
313
+
314
+ throw new Error(`DynamoERROR (DH.reloadData): Missing ID! (${this.name})`);
315
+ }
316
+
317
+ if (loadInProgress && loadInProgress.loadBy === useLoadBy) {
318
+ if (this.debugLog) {
319
+ console.log(
320
+ `DYNAMO DH.reloadData (${this.name}) DEBUG:` +
321
+ `\n DataHandler reloadData... (using id: ${useLoadBy})` +
322
+ `\n DataHandler is already loading data...`
323
+ );
324
+ }
325
+
326
+ return this.data;
327
+ }
328
+
329
+ if (this.debugLog) {
330
+ console.log(
331
+ `DYNAMO DH.reloadData (${this.name}) DEBUG:` +
332
+ `\n DataHandler reloadData... (using id: ${useLoadBy})`
333
+ );
334
+ }
335
+
336
+ const loadProgress = this.doReloadDataBy(useLoadBy);
337
+ this.loadInProgress_BS.next({
338
+ loadBy: useLoadBy,
339
+ progress: loadProgress
340
+ });
341
+ loadProgress.finally(() => {
342
+ this.loadInProgress_BS.next(false);
343
+ });
344
+
345
+ return await loadProgress;
346
+ } catch (error) {
347
+ this.loadInProgress_BS.next(false);
348
+ this.loaded_BS.next(false);
349
+
350
+ if (!error?.error?.handled) {
351
+ console.error(
352
+ `DYNAMO DH.reloadData (${this.name}) ERROR: ` +
353
+ `\n reloadData was UNSUCCESSFUL`,
354
+ '\n\n', error,
355
+ '\n\n', new Error()
356
+ );
357
+
358
+ if (error?.error?.flag?.includes('DYNAMO')) {
359
+ error.error.handled = true;
360
+ }
361
+ }
362
+
363
+ throw error;
364
+ }
365
+ }
366
+
367
+ async getData(): Promise<T> {
368
+ if (!this.data) {
369
+ const loadProgress = this.loadInProgress_BS.value;
370
+ if (loadProgress) {
371
+ return await loadProgress.progress;
372
+ } else {
373
+ return await this.reloadData();
374
+ }
375
+ } else {
376
+ return this.data;
377
+ }
378
+ }
379
+
380
+ protected async doReloadDataBy(loadedBy: T_LoadBy): Promise<T> {
381
+ try {
382
+ this.lastLoadedBy = loadedBy;
383
+
384
+ return await this.processLoadResult(await this.get(loadedBy), loadedBy);
385
+ } catch (error) {
386
+ this.resolveWaitsOnLoad();
387
+ throw error;
388
+ }
389
+ }
390
+
391
+ async updateData(data: T, dontSendUpdate?: boolean): Promise<void> {
392
+ if (this.set && !dontSendUpdate) {
393
+ this.data_BS.next(await this.set(data));
394
+ } else {
395
+ this.data_BS.next(data);
396
+ }
397
+ }
398
+
399
+ clear(dontClearDependents?: boolean): void {
400
+ this.data_BS.next(undefined);
401
+ this.lastLoadedBy = undefined;
402
+ if (!dontClearDependents) {
403
+ this.dependentDataHandlers.forEach((ddh: DyFM_DataHandler<any>): void => {
404
+ ddh.clear();
405
+ });
406
+ }
407
+ }
408
+
409
+ protected async processLoadResult(result: any, loadedBy: T_LoadBy): Promise<T> {
410
+ if (this.debugLog) {
411
+ console.log(
412
+ `DYNAMO DH.processLoadResult (${this.name}) DEBUG:` +
413
+ `\n DataHandler processLoadResult... (using id: ${loadedBy})` +
414
+ `\n Result:`, result
415
+ );
416
+ }
417
+
418
+ for (const postProcess of this.getPostProcesses) {
419
+ if (this.debugLog) {
420
+ console.log(
421
+ `DYNAMO DH.processLoadResult (${this.name}) DEBUG:` +
422
+ `\n Post process:`, postProcess
423
+ );
424
+ }
425
+
426
+ result = await postProcess(result, loadedBy);
427
+
428
+ if (!result) {
429
+ DyFM_Log.warn(
430
+ `DYNAMO DH.processLoadResult (${this.name}) WARN: ` +
431
+ `\nPost process returned null or undefined!`,
432
+ '\n\n', new Error()
433
+ );
434
+ }
435
+ }
436
+ this.data_BS.next(result);
437
+ this.loaded_BS.next(true);
438
+ this.resolveWaitsOnLoad();
439
+ return result;
440
+ }
441
+
442
+ private resolveWaitsOnLoad(): void {
443
+ this.waitsOnLoad.forEach(({ promise, resolve }) => {
444
+ resolve();
445
+ });
446
+ this.waitsOnLoad = [];
447
+ }
448
+
449
+ /**
450
+ * waits for the first load to finish
451
+ * @returns a promise that resolves when the first load finishes after this "subscription"
452
+ */
453
+ waitForLoad(): Promise<void> {
454
+ let resolve: (value: void) => void;
455
+ const promise = new Promise<void>((r) => { resolve = r; });
456
+ this.waitsOnLoad.push({ promise, resolve });
457
+ return promise;
458
+ }
459
+ }