http-request-manager 18.7.19 → 18.7.21

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 (198) hide show
  1. package/ARCHITECTURE.md +483 -0
  2. package/DATABASE_README.md +1176 -0
  3. package/HTTP_MANAGER_README.md +579 -0
  4. package/HTTP_SINGNALS_MANAGER_README.md +654 -0
  5. package/HTTP_STATE_MANAGER_README.md +948 -0
  6. package/INTERCEPTOR_README.md +549 -0
  7. package/LOCAL_STORAGE_README.md +1056 -0
  8. package/STORE_STATE_MANAGER_README.md +1322 -0
  9. package/UTILS_README.md +1186 -0
  10. package/WS_MANAGER_README.md +613 -0
  11. package/ng-package.json +8 -0
  12. package/package.json +1 -12
  13. package/src/lib/http-request-manager.module.ts +132 -0
  14. package/src/lib/http-request-services-demo/database-data-demo/database-data-demo.component.html +65 -0
  15. package/src/lib/http-request-services-demo/database-data-demo/database-data-demo.component.scss +0 -0
  16. package/src/lib/http-request-services-demo/database-data-demo/database-data-demo.component.ts +224 -0
  17. package/src/lib/http-request-services-demo/http-request-services-demo.component.html +114 -0
  18. package/src/lib/http-request-services-demo/http-request-services-demo.component.scss +6 -0
  19. package/src/lib/http-request-services-demo/http-request-services-demo.component.ts +52 -0
  20. package/src/lib/http-request-services-demo/local-storage-demo/local-storage-demo.component.html +195 -0
  21. package/src/lib/http-request-services-demo/local-storage-demo/local-storage-demo.component.scss +17 -0
  22. package/src/lib/http-request-services-demo/local-storage-demo/local-storage-demo.component.ts +206 -0
  23. package/src/lib/http-request-services-demo/local-storage-signals-demo/local-storage-signals-demo.component.html +200 -0
  24. package/src/lib/http-request-services-demo/local-storage-signals-demo/local-storage-signals-demo.component.scss +17 -0
  25. package/src/lib/http-request-services-demo/local-storage-signals-demo/local-storage-signals-demo.component.ts +212 -0
  26. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/download-file/download-file.component.html +53 -0
  27. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/download-file/download-file.component.scss +60 -0
  28. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/download-file/download-file.component.ts +72 -0
  29. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/file-download.module.ts +28 -0
  30. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/file-downloader.component.html +10 -0
  31. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/file-downloader.component.scss +29 -0
  32. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/file-downloader.component.ts +100 -0
  33. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/models/download-labels-model.ts +22 -0
  34. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/spinner/spinner.component.html +8 -0
  35. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/spinner/spinner.component.scss +19 -0
  36. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/spinner/spinner.component.ts +26 -0
  37. package/src/lib/http-request-services-demo/request-manager-demo/models/app-session.model.ts +30 -0
  38. package/src/lib/http-request-services-demo/request-manager-demo/models/app.model.ts +19 -0
  39. package/src/lib/http-request-services-demo/request-manager-demo/models/get-sample.model.ts +25 -0
  40. package/src/lib/http-request-services-demo/request-manager-demo/models/sample-ai-prompt.ts +19 -0
  41. package/src/lib/http-request-services-demo/request-manager-demo/models/sample-client-details.ts +24 -0
  42. package/src/lib/http-request-services-demo/request-manager-demo/models/sample-client-info.ts +30 -0
  43. package/src/lib/http-request-services-demo/request-manager-demo/models/sample-client.model.ts +49 -0
  44. package/src/lib/http-request-services-demo/request-manager-demo/models/sample-mapper-client-info.ts +33 -0
  45. package/src/lib/http-request-services-demo/request-manager-demo/request-manager-demo.component.html +392 -0
  46. package/src/lib/http-request-services-demo/request-manager-demo/request-manager-demo.component.scss +24 -0
  47. package/src/lib/http-request-services-demo/request-manager-demo/request-manager-demo.component.ts +461 -0
  48. package/src/lib/http-request-services-demo/request-manager-state-demo/request-manager-state-demo.component.html +393 -0
  49. package/src/lib/http-request-services-demo/request-manager-state-demo/request-manager-state-demo.component.scss +24 -0
  50. package/src/lib/http-request-services-demo/request-manager-state-demo/request-manager-state-demo.component.ts +421 -0
  51. package/src/lib/http-request-services-demo/request-manager-state-demo/services/state-manager-demo.service.ts +87 -0
  52. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/services/state-data-request.service.ts +120 -0
  53. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-ai-messaging/ws-ai-messaging.component.css +0 -0
  54. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-ai-messaging/ws-ai-messaging.component.html +3 -0
  55. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-ai-messaging/ws-ai-messaging.component.ts +16 -0
  56. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-chats/ws-chats.component.css +0 -0
  57. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-chats/ws-chats.component.html +3 -0
  58. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-chats/ws-chats.component.ts +16 -0
  59. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-data-control/ws-data-control.component.css +31 -0
  60. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-data-control/ws-data-control.component.html +72 -0
  61. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-data-control/ws-data-control.component.scss +41 -0
  62. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-data-control/ws-data-control.component.spec.ts +205 -0
  63. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-data-control/ws-data-control.component.ts +77 -0
  64. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-messaging/ws-messaging.component.css +11 -0
  65. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-messaging/ws-messaging.component.html +96 -0
  66. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-messaging/ws-messaging.component.spec.ts +31 -0
  67. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-messaging/ws-messaging.component.ts +229 -0
  68. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-notifications/ws-notifications.component.css +30 -0
  69. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-notifications/ws-notifications.component.html +172 -0
  70. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-notifications/ws-notifications.component.spec.ts +31 -0
  71. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-notifications/ws-notifications.component.ts +239 -0
  72. package/src/lib/http-request-services-demo/request-manager-ws-demo/models/oidc-client.model.ts +31 -0
  73. package/src/lib/http-request-services-demo/request-manager-ws-demo/models/user-data.model.ts +32 -0
  74. package/src/lib/http-request-services-demo/request-manager-ws-demo/request-manager-ws-demo.component.css +0 -0
  75. package/src/lib/http-request-services-demo/request-manager-ws-demo/request-manager-ws-demo.component.html +84 -0
  76. package/src/lib/http-request-services-demo/request-manager-ws-demo/request-manager-ws-demo.component.ts +41 -0
  77. package/src/lib/http-request-services-demo/request-manager-ws-demo/services/index.ts +3 -0
  78. package/src/lib/http-request-services-demo/request-manager-ws-demo/services/message-service-demo.service.ts +83 -0
  79. package/src/lib/http-request-services-demo/request-manager-ws-demo/services/notification-service-demo.service.ts +147 -0
  80. package/src/lib/http-request-services-demo/request-manager-ws-demo/services/state-service-demo.service.ts +158 -0
  81. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/download-file/download-file.component.html +53 -0
  82. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/download-file/download-file.component.scss +60 -0
  83. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/download-file/download-file.component.ts +72 -0
  84. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/file-download.module.ts +28 -0
  85. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/file-downloader.component.html +10 -0
  86. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/file-downloader.component.scss +29 -0
  87. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/file-downloader.component.ts +100 -0
  88. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/models/download-labels-model.ts +22 -0
  89. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/spinner/spinner.component.html +8 -0
  90. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/spinner/spinner.component.scss +19 -0
  91. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/spinner/spinner.component.ts +26 -0
  92. package/src/lib/http-request-services-demo/request-signals-manager-demo/models/app-session.model.ts +30 -0
  93. package/src/lib/http-request-services-demo/request-signals-manager-demo/models/app.model.ts +19 -0
  94. package/src/lib/http-request-services-demo/request-signals-manager-demo/models/get-sample.model.ts +25 -0
  95. package/src/lib/http-request-services-demo/request-signals-manager-demo/models/sample-ai-prompt.ts +19 -0
  96. package/src/lib/http-request-services-demo/request-signals-manager-demo/models/sample-client-details.ts +24 -0
  97. package/src/lib/http-request-services-demo/request-signals-manager-demo/models/sample-client-info.ts +30 -0
  98. package/src/lib/http-request-services-demo/request-signals-manager-demo/models/sample-client.model.ts +49 -0
  99. package/src/lib/http-request-services-demo/request-signals-manager-demo/models/sample-mapper-client-info.ts +33 -0
  100. package/src/lib/http-request-services-demo/request-signals-manager-demo/request-signals-manager-demo.component.html +380 -0
  101. package/src/lib/http-request-services-demo/request-signals-manager-demo/request-signals-manager-demo.component.scss +24 -0
  102. package/src/lib/http-request-services-demo/request-signals-manager-demo/request-signals-manager-demo.component.ts +410 -0
  103. package/src/lib/http-request-services-demo/store-state-manager-demo/models/settings.model.ts +28 -0
  104. package/src/lib/http-request-services-demo/store-state-manager-demo/services/settings-state.service.ts +48 -0
  105. package/src/lib/http-request-services-demo/store-state-manager-demo/store-state-manager-demo.component.css +0 -0
  106. package/src/lib/http-request-services-demo/store-state-manager-demo/store-state-manager-demo.component.html +23 -0
  107. package/src/lib/http-request-services-demo/store-state-manager-demo/store-state-manager-demo.component.ts +36 -0
  108. package/src/lib/index.ts +3 -0
  109. package/src/lib/interceptors/credentials.interceptor.ts +16 -0
  110. package/src/lib/interceptors/index.ts +6 -0
  111. package/src/lib/interceptors/models/error-settings.model.ts +22 -0
  112. package/src/lib/interceptors/models/index.ts +2 -0
  113. package/src/lib/interceptors/proxy-debugger.interceptor.ts +46 -0
  114. package/src/lib/interceptors/request-error.interceptor.ts +65 -0
  115. package/src/lib/interceptors/request-header.interceptor.ts +53 -0
  116. package/src/lib/models/config-http-options.model.ts +42 -0
  117. package/src/lib/models/config-local-storage-options.model.ts +27 -0
  118. package/src/lib/models/config-options.model.ts +27 -0
  119. package/src/lib/models/config-token.model.ts +9 -0
  120. package/src/lib/models/data-type.enum.ts +5 -0
  121. package/src/lib/models/database-storage.model.ts +24 -0
  122. package/src/lib/models/index.ts +12 -0
  123. package/src/lib/models/retry-options.model.ts +22 -0
  124. package/src/lib/services/database-manager-service/database.manager.service.ts +262 -0
  125. package/src/lib/services/database-manager-service/db.storage.service.ts +207 -0
  126. package/src/lib/services/database-manager-service/index.ts +4 -0
  127. package/src/lib/services/database-manager-service/models/index.ts +2 -0
  128. package/src/lib/services/database-manager-service/models/table-schema.ts +33 -0
  129. package/src/lib/services/index.ts +12 -0
  130. package/src/lib/services/local-storage-manager-service/index.ts +4 -0
  131. package/src/lib/services/local-storage-manager-service/local-storage-manager.service.spec.ts +71 -0
  132. package/src/lib/services/local-storage-manager-service/local-storage-manager.service.ts +426 -0
  133. package/src/lib/services/local-storage-manager-service/local-storage-signals-manager.service.spec.ts +67 -0
  134. package/src/lib/services/local-storage-manager-service/local-storage-signals-manager.service.ts +345 -0
  135. package/src/lib/services/local-storage-manager-service/models/global-store-options.model.ts +30 -0
  136. package/src/lib/services/local-storage-manager-service/models/index.ts +6 -0
  137. package/src/lib/services/local-storage-manager-service/models/setting-options.model.ts +35 -0
  138. package/src/lib/services/local-storage-manager-service/models/storage-data.model.ts +24 -0
  139. package/src/lib/services/local-storage-manager-service/models/storage-option.model.ts +32 -0
  140. package/src/lib/services/local-storage-manager-service/models/storage-type.enum.ts +5 -0
  141. package/src/lib/services/request-manager-services/README.md +268 -0
  142. package/src/lib/services/request-manager-services/http-manager-signals.service.ts +246 -0
  143. package/src/lib/services/request-manager-services/http-manager.service.spec.ts +232 -0
  144. package/src/lib/services/request-manager-services/http-manager.service.ts +274 -0
  145. package/src/lib/services/request-manager-services/index.ts +8 -0
  146. package/src/lib/services/request-manager-services/request-signals.service.ts +214 -0
  147. package/src/lib/services/request-manager-services/request.service.ts +309 -0
  148. package/src/lib/services/request-manager-services/rxjs-operators/countdown.ts +17 -0
  149. package/src/lib/services/request-manager-services/rxjs-operators/delay-retry.ts +16 -0
  150. package/src/lib/services/request-manager-services/rxjs-operators/index.ts +4 -0
  151. package/src/lib/services/request-manager-services/rxjs-operators/request-polling.ts +35 -0
  152. package/src/lib/services/request-manager-services/rxjs-operators/request-streaming.ts +436 -0
  153. package/src/lib/services/request-manager-state-service/http-manager-state.store.ts +1321 -0
  154. package/src/lib/services/request-manager-state-service/index.ts +3 -0
  155. package/src/lib/services/request-manager-state-service/models/api-request.model.ts +61 -0
  156. package/src/lib/services/request-manager-state-service/models/index.ts +6 -0
  157. package/src/lib/services/request-manager-state-service/models/request-options.model.ts +22 -0
  158. package/src/lib/services/request-manager-state-service/models/stream-type.enum.ts +13 -0
  159. package/src/lib/services/request-manager-state-service/models/ws-options.model.ts +39 -0
  160. package/src/lib/services/store-state-manager-service/index.ts +3 -0
  161. package/src/lib/services/store-state-manager-service/models/index.ts +2 -0
  162. package/src/lib/services/store-state-manager-service/models/state-storage-options.model.ts +24 -0
  163. package/src/lib/services/store-state-manager-service/store-state-manager.service.ts +88 -0
  164. package/src/lib/services/utils/app.service.spec.ts +25 -0
  165. package/src/lib/services/utils/app.service.ts +21 -0
  166. package/src/lib/services/utils/encryption/README.md +79 -0
  167. package/src/lib/services/utils/encryption/asymmetrical-encryption.service.ts +282 -0
  168. package/src/lib/services/utils/encryption/encryption-test.service.ts +39 -0
  169. package/src/lib/services/utils/encryption/index.ts +5 -0
  170. package/src/lib/services/utils/encryption/random.ts +81 -0
  171. package/src/lib/services/utils/encryption/symmetrical-encryption.service.ts +93 -0
  172. package/src/lib/services/utils/headers.service.spec.ts +80 -0
  173. package/src/lib/services/utils/headers.service.ts +18 -0
  174. package/src/lib/services/utils/index.ts +7 -0
  175. package/src/lib/services/utils/object-merger.service.spec.ts +18 -0
  176. package/src/lib/services/utils/object-merger.service.ts +78 -0
  177. package/src/lib/services/utils/path-query.service.spec.ts +117 -0
  178. package/src/lib/services/utils/path-query.service.ts +69 -0
  179. package/src/lib/services/utils/random-color.utils.ts +83 -0
  180. package/src/lib/services/utils/utils.service.spec.ts +165 -0
  181. package/src/lib/services/utils/utils.service.ts +192 -0
  182. package/src/lib/services/ws-manager-service/index.ts +4 -0
  183. package/src/lib/services/ws-manager-service/models/channel-info.model.ts +24 -0
  184. package/src/lib/services/ws-manager-service/models/channel-message-data.model.ts +24 -0
  185. package/src/lib/services/ws-manager-service/models/channel-message.model.ts +24 -0
  186. package/src/lib/services/ws-manager-service/models/communication-type.enum.ts +5 -0
  187. package/src/lib/services/ws-manager-service/models/index.ts +5 -0
  188. package/src/lib/services/ws-manager-service/models/ws-user.model.ts +38 -0
  189. package/src/lib/services/ws-manager-service/services/index.ts +3 -0
  190. package/src/lib/services/ws-manager-service/services/websocket.service.ts +392 -0
  191. package/src/public-api.ts +14 -0
  192. package/tsconfig.lib.json +32 -0
  193. package/tsconfig.lib.prod.json +10 -0
  194. package/tsconfig.spec.json +14 -0
  195. package/fesm2022/http-request-manager.mjs +0 -7634
  196. package/fesm2022/http-request-manager.mjs.map +0 -1
  197. package/http-request-manager-18.7.19.tgz +0 -0
  198. package/types/http-request-manager.d.ts +0 -2278
@@ -0,0 +1,410 @@
1
+ import { Component, OnInit, ViewChild, inject } from '@angular/core'
2
+
3
+ import { FormArray, FormBuilder, Validators } from '@angular/forms'
4
+
5
+ import { ClientInfo } from './models/sample-client-info'
6
+ import { ClientInfoMapper } from './models/sample-mapper-client-info'
7
+ import { AIPrompt } from './models/sample-ai-prompt'
8
+ import { ApiRequest, HTTPManagerSignalsService } from '../..'
9
+
10
+ import { ToastColors, ToastDisplay, ToastMessageDisplayService } from 'toast-message-display'
11
+
12
+ @Component({
13
+ selector: 'app-request-signals-manager-demo',
14
+ templateUrl: './request-signals-manager-demo.component.html',
15
+ styleUrls: ['./request-signals-manager-demo.component.scss'],
16
+ standalone: false
17
+ })
18
+ export class RequestSignalsManagerDemoComponent implements OnInit {
19
+
20
+ displayedColumns = ['id','name', 'lastName', 'age']
21
+
22
+ private fb = inject(FormBuilder)
23
+ private toastMessage = inject(ToastMessageDisplayService)
24
+
25
+ httpManagerSignalsService = inject(HTTPManagerSignalsService)
26
+
27
+ // Using signals service: signals are callable in templates (e.g. isPending())
28
+ isPending = this.httpManagerSignalsService.isPending
29
+ countdown = this.httpManagerSignalsService.countdown
30
+
31
+ // per-operation plain results and error messages (no rxjs in component)
32
+ GET_result: any = null
33
+ POST_result: any = null
34
+ PUT_result: any = null
35
+ DELETE_result: any = null
36
+
37
+ STREAM_result: any = null
38
+ STREAM_AI_result: any = null
39
+
40
+ GET_error: string = ''
41
+ POST_error: string = ''
42
+ PUT_error: string = ''
43
+ DELETE_error: string = ''
44
+ STREAM_error: string = ''
45
+ STREAM_AI_error: string = ''
46
+
47
+ requestParams = {
48
+ GET: ApiRequest.adapt(),
49
+ POST: ApiRequest.adapt(),
50
+ PUT: ApiRequest.adapt(),
51
+ DELETE: ApiRequest.adapt(),
52
+ STREAM: ApiRequest.adapt(),
53
+ }
54
+
55
+ @ViewChild("failedState", { static: true }) failedState: any
56
+ @ViewChild("pollingState", { static: true }) pollingState: any
57
+
58
+ questionControl = this.fb.control("", [Validators.required])
59
+
60
+ downloadRequest = ApiRequest.adapt({
61
+ server: 'assets/images',
62
+ path: ['me.jpg'],
63
+ // saveAs: 'john.jpg' // Optional
64
+ })
65
+
66
+ // downloadRequest = ApiRequest.adapt({
67
+ // server: 'oidc/ai/file'
68
+ // })
69
+
70
+ sampleClientData = {
71
+ id: 0,
72
+ name: "Old School Dates",
73
+ domain: "osd.com",
74
+ service: "osd",
75
+ spiffe: "osd.com/osd",
76
+ secret: "SMOPECXP-OS4P-USOG-X2II-3XMD1FQDR3IJX",
77
+ created: 1693003138,
78
+ modified: 1693003138,
79
+ icon: "",
80
+ imageFile: "",
81
+ email: "wavecoders@gmail.com"
82
+ }
83
+
84
+ requestForm = this.fb.group({
85
+ path: this.fb.control<string>("ai/"),
86
+ headers: this.fb.array([]),
87
+ adapter: [null],
88
+ mapper: [null],
89
+ retry: this.fb.group({
90
+ times: [3],
91
+ delay: [3],
92
+ }),
93
+ polling: [3],
94
+ })
95
+
96
+ AIType = 0
97
+
98
+ sampleAdaptors = [
99
+ { label: "ClientInfo Basic", value: ClientInfo.adapt },
100
+ { label: "AI Prompt", value: AIPrompt.adapt },
101
+ ]
102
+
103
+ sampleMappers = [
104
+ { label: "Mapper Basic", value: ClientInfoMapper.adapt },
105
+ { label: "AI Prompt", value: AIPrompt.adapt },
106
+ ]
107
+
108
+ get retry() {
109
+ return this.requestForm.get('retry')?.value
110
+ }
111
+
112
+ get headers(): FormArray {
113
+ return this.requestForm.get('headers') as FormArray
114
+ }
115
+
116
+ get isValid() {
117
+ this.requestForm.markAllAsTouched()
118
+ return this.requestForm.valid
119
+ }
120
+
121
+ hasId = (arr: any[]) => {
122
+ if (arr.length === 0) return false
123
+ return !isNaN(arr[arr.length - 1])
124
+ }
125
+
126
+ props = (adapter: any) => {
127
+ return (adapter) ? adapter() : null
128
+ }
129
+
130
+ // server = `http://sample-endpoint/as/authorization.oauth2`
131
+
132
+ arrayObjectsToObjects = (arr: any[]) => {
133
+ return Array.isArray(arr) ? arr.reduce((obj, item) => Object.assign(obj, { [item.key]: item.value }), {}) : {}
134
+ }
135
+
136
+ constructor() { }
137
+
138
+ ngOnInit() {
139
+
140
+ // const reqGet2 = ApiRequest.adapt({
141
+ // server,
142
+ // path: ['clients'],
143
+ // headers: { authentication: "Bearer <KEY>" },
144
+ // adapter: ClientInfo,
145
+ // dataType: DataType.OBJECT,
146
+ // // concurrent: false,
147
+ // // polling: 3, //seconds
148
+ // })
149
+
150
+ // const req2 = [1024,1025,1026].map(item => {
151
+ // return this.httpManagerService.getRequest<ClientInfo[]>(reqGet2, [item])
152
+ // .pipe(
153
+ // catchError(error => {
154
+ // return throwError(() => new Error(error.error.message))
155
+ // })
156
+ // )
157
+ // })
158
+
159
+ // forkJoin(req2)
160
+ // .subscribe(res => console.log(res))
161
+
162
+ }
163
+
164
+ addHeader() {
165
+ const header = this.fb.group({
166
+ key: ['', Validators.required],
167
+ value: ['']
168
+ })
169
+ this.headers.push(header)
170
+ }
171
+
172
+ removeHeader(index: number) {
173
+ this.headers.removeAt(index)
174
+ }
175
+
176
+ compileRequest() {
177
+
178
+ const requestParams = this.requestForm.value
179
+
180
+ requestParams.headers = this.arrayObjectsToObjects(
181
+ requestParams.headers || []
182
+ )
183
+
184
+ const pathReq = (requestParams.path === "") ? [] : (requestParams.path || "").split("/")
185
+
186
+ if (!this.pollingState.checked) requestParams.polling = 0
187
+
188
+ if (!this.failedState.checked) {
189
+ requestParams.retry = { times: 0,delay: 0 }
190
+ }
191
+
192
+ const apiOptions = ApiRequest.adapt(requestParams)
193
+ apiOptions.path = []
194
+
195
+ return { apiOptions: apiOptions, path: pathReq }
196
+
197
+ }
198
+
199
+ onGetRequest() {
200
+
201
+ if(!this.isValid) return
202
+
203
+ const reqParams = this.compileRequest()
204
+
205
+ this.requestParams.GET = reqParams.apiOptions
206
+
207
+ // reset local state
208
+ this.GET_result = null
209
+ this.GET_error = ''
210
+
211
+ this.httpManagerSignalsService.getRequest<ClientInfo[]>(reqParams.apiOptions, reqParams.path)
212
+ .subscribe({
213
+ next: (res) => this.GET_result = res,
214
+ error: (err) => this.errorHandling(err, 'GET')
215
+ })
216
+
217
+ }
218
+
219
+ onCreateRequest() {
220
+
221
+ if(!this.isValid) return
222
+
223
+ const reqParams = this.compileRequest()
224
+ this.requestParams.POST = reqParams.apiOptions
225
+
226
+ // reset local state
227
+ this.POST_result = null
228
+ this.POST_error = ''
229
+
230
+ this.httpManagerSignalsService.postRequest<ClientInfo>(this.sampleClientData, reqParams.apiOptions, reqParams.path)
231
+ .subscribe({
232
+ next: (res) => this.POST_result = res,
233
+ error: (err) => this.errorHandling(err, 'POST')
234
+ })
235
+
236
+ }
237
+
238
+ onUpdateRequest() {
239
+
240
+ if(!this.isValid) return
241
+
242
+ const reqParams = this.compileRequest()
243
+
244
+ if(!this.hasId(reqParams.path)) {
245
+ console.log("Missing ID")
246
+ return
247
+ }
248
+
249
+ this.sampleClientData.id = parseInt(reqParams.path[reqParams.path.length-1])
250
+ this.requestParams.PUT = reqParams.apiOptions
251
+
252
+ // reset local state
253
+ this.PUT_result = null
254
+ this.PUT_error = ''
255
+
256
+ this.httpManagerSignalsService.putRequest<any>(this.sampleClientData, reqParams.apiOptions, reqParams.path)
257
+ .subscribe({
258
+ next: (res) => this.PUT_result = res,
259
+ error: (err) => this.errorHandling(err, 'PUT')
260
+ })
261
+
262
+ }
263
+
264
+ onDeleteRequest() {
265
+
266
+ if(!this.isValid) return
267
+
268
+ const reqParams = this.compileRequest()
269
+ this.requestParams.DELETE = reqParams.apiOptions
270
+
271
+ if(!this.hasId(reqParams.path)) {
272
+ console.log("Missing ID")
273
+ return
274
+ }
275
+
276
+ this.sampleClientData.id = parseInt(reqParams.path[reqParams.path.length-1])
277
+ this.requestParams.DELETE = reqParams.apiOptions
278
+
279
+ // reset local state
280
+ this.DELETE_result = null
281
+ this.DELETE_error = ''
282
+
283
+ this.httpManagerSignalsService.deleteRequest<ClientInfo>(reqParams.apiOptions, reqParams.path)
284
+ .subscribe({
285
+ next: (res) => this.DELETE_result = res,
286
+ error: (err) => this.errorHandling(err, 'DELETE')
287
+ })
288
+
289
+ }
290
+
291
+ onStreamPostRequest() {
292
+
293
+ if (!this.isValid) return
294
+
295
+ const reqParams = this.compileRequest()
296
+
297
+ let payload = {}
298
+ let apiPath: string[] = reqParams.path
299
+ let apiOptions = reqParams.apiOptions
300
+ let responseMapper: (items: any) => any = (items) => items.response
301
+
302
+ if (this.AIType === 0) {
303
+
304
+ // API request
305
+ payload = { prompt: this.questionControl.value }
306
+
307
+ } else {
308
+
309
+ // Local Ollama request
310
+ apiOptions.server = "api"
311
+ apiPath = ["generate"]
312
+ apiOptions.stream = true
313
+ payload = {
314
+ model: "phi3:latest",
315
+ prompt: this.questionControl.value,
316
+ stream: true,
317
+ }
318
+
319
+ responseMapper = (items) => items.map((word: any) => word.response).flat().join('')
320
+
321
+ }
322
+
323
+ this.requestParams.STREAM = apiOptions
324
+ this.STREAM_AI_result = null
325
+ this.STREAM_AI_error = ''
326
+
327
+ this.httpManagerSignalsService.postRequest<any>(payload, apiOptions, apiPath)
328
+ .subscribe({
329
+ next: (res) => {
330
+ try {
331
+ this.STREAM_AI_result = responseMapper(res)
332
+ } catch (e) {
333
+ this.STREAM_AI_result = res
334
+ }
335
+ this.questionControl.reset()
336
+ },
337
+ error: (err) => this.errorHandling(err, 'STREAM')
338
+ })
339
+
340
+ }
341
+
342
+
343
+ onStreamRequest() {
344
+
345
+ if(!this.isValid) return
346
+
347
+ const reqParams = this.compileRequest()
348
+
349
+ reqParams.apiOptions.stream = true
350
+
351
+ this.requestParams.GET = reqParams.apiOptions
352
+ this.STREAM_result = null
353
+ this.STREAM_error = ''
354
+
355
+ this.httpManagerSignalsService.getRequest<ClientInfo[]>(reqParams.apiOptions, reqParams.path)
356
+ .subscribe({
357
+ next: (res) => this.STREAM_result = res,
358
+ error: (err) => this.errorHandling(err, 'STREAM')
359
+ })
360
+
361
+ }
362
+
363
+ onDownloadCompleted() {
364
+
365
+ const message = "Download Completed"
366
+
367
+ const display = ToastDisplay.adapt({
368
+ message,
369
+ action: 'Ok',
370
+ color: ToastColors.SUCCESS,
371
+ icon: 'sentiment_satisfied_alt',
372
+ })
373
+
374
+ this.toastMessage.toastMessage(display)
375
+ }
376
+
377
+ onDownloadFailed(err: string) {
378
+
379
+ const message = "Download Failed"
380
+
381
+ const display = ToastDisplay.adapt({
382
+ message,
383
+ action: 'Ok',
384
+ color: ToastColors.ERROR,
385
+ icon: 'warning',
386
+ })
387
+
388
+ this.toastMessage.toastMessage(display)
389
+ }
390
+
391
+ errorHandling(err: any, type: string) {
392
+ const message = err?.message || String(err)
393
+ // set local error state
394
+ if (type === 'GET') this.GET_error = message
395
+ if (type === 'POST') this.POST_error = message
396
+ if (type === 'PUT') this.PUT_error = message
397
+ if (type === 'DELETE') this.DELETE_error = message
398
+ if (type === 'STREAM') this.STREAM_error = message
399
+
400
+ // also set the shared service error signal
401
+ this.httpManagerSignalsService.error.set(message)
402
+
403
+ return err
404
+ }
405
+
406
+ onSelectAIType(type: number) {
407
+ this.AIType = type
408
+ }
409
+
410
+ }
@@ -0,0 +1,28 @@
1
+ export interface SettingsInterface {
2
+ enum_1: any
3
+ enum_2: any
4
+ enum_3: any
5
+ enum_4: any
6
+ }
7
+
8
+ export class Settings implements SettingsInterface {
9
+
10
+ constructor(
11
+ public enum_1 = [],
12
+ public enum_2 = [],
13
+ public enum_3 = [],
14
+ public enum_4 = [],
15
+ ) {}
16
+
17
+ static adapt(item?: any): Settings {
18
+
19
+ return new Settings(
20
+ item?.enum_1,
21
+ item?.enum_2,
22
+ item?.enum_3,
23
+ item?.enum_4,
24
+ )
25
+
26
+ }
27
+
28
+ }
@@ -0,0 +1,48 @@
1
+ import { Injectable } from '@angular/core';
2
+
3
+ import { map } from 'rxjs';
4
+
5
+ import { SettingOptions, StorageType } from '../../../services';
6
+ import { StoreStateManagerService, StateStorageOptions } from '../../../services/store-state-manager-service';
7
+ import { Settings } from '../models/settings.model';
8
+
9
+
10
+ @Injectable()
11
+ export class SettingsStateService extends StoreStateManagerService {
12
+
13
+ constructor() {
14
+
15
+ super(
16
+ StateStorageOptions.adapt({
17
+ store: 'sampleStore',
18
+ options: SettingOptions.adapt({
19
+ storage: StorageType.SESSION,
20
+ encrypted: false
21
+ }),
22
+ model: Settings.adapt,
23
+ }
24
+ ))
25
+
26
+ }
27
+
28
+ updateEnum_1(value: any) {
29
+ this.updateData(value)
30
+ }
31
+
32
+ updateEnum_2(value: any) {
33
+ this.updateData(value)
34
+ }
35
+
36
+ getEnum(key: string) {
37
+ return this.data$.pipe(
38
+ map(item => item[key])
39
+ )
40
+ }
41
+
42
+ getEnum_1() {
43
+ return this.data$.pipe(
44
+ map(item => item?.enum_1)
45
+ )
46
+ }
47
+
48
+ }
@@ -0,0 +1,23 @@
1
+ <div style="margin: 2rem;">
2
+
3
+ <h2>
4
+ <span>Store State Manager</span>
5
+ <span style="margin-left: .5rem;">
6
+ <mat-icon color="accent">fiber_new</mat-icon>
7
+ </span>
8
+ </h2>
9
+
10
+ {{ dataState$ | async | json}}
11
+
12
+ <div style="display: flex; gap:.5rem; margin-top: 1rem; margin-bottom: 1rem;">
13
+ <button mat-stroked-button (click)="onUpdateEnum_1()">Update Start</button>
14
+ <button mat-stroked-button (click)="onUpdateEnum_2()">Update End</button>
15
+ <button mat-stroked-button (click)="onGetEnum_1()">Dump</button>
16
+ </div>
17
+
18
+ <div>
19
+ <h3 style="margin: 0;">Enum 1</h3>
20
+ {{ dataEnum$ | async | json}}
21
+ </div>
22
+
23
+ </div>
@@ -0,0 +1,36 @@
1
+ import { Component, inject, OnInit } from '@angular/core';
2
+ import { RandomNumber } from '../../services';
3
+ import { SettingsStateService } from './services/settings-state.service';
4
+
5
+ @Component({
6
+ selector: 'app-store-state-manager-demo',
7
+ templateUrl: './store-state-manager-demo.component.html',
8
+ styleUrls: ['./store-state-manager-demo.component.css'],
9
+ providers: [SettingsStateService],
10
+ standalone: false
11
+ })
12
+ export class StoreStateManagerDemoComponent implements OnInit {
13
+
14
+ settingsStateService = inject(SettingsStateService)
15
+ dataState$ = this.settingsStateService.data$
16
+
17
+ dataEnum$ = this.settingsStateService.getEnum_1()
18
+
19
+ ngOnInit() {
20
+ }
21
+
22
+ onUpdateEnum_1() {
23
+ const rnd = RandomNumber(1000, 9999)
24
+ this.settingsStateService.updateEnum_1({enum_1: [{ users: [1,2,3, rnd], random: rnd }]})
25
+ }
26
+
27
+ onUpdateEnum_2() {
28
+ const rnd = RandomNumber(1000, 9999)
29
+ this.settingsStateService.updateEnum_2({enum_2: [{ users: [1,2,3, rnd], random: rnd }]})
30
+ }
31
+
32
+ onGetEnum_1() {
33
+ this.settingsStateService.getEnum_1().subscribe(data => console.log('DUMP:', data))
34
+ }
35
+
36
+ }
@@ -0,0 +1,3 @@
1
+ export * from "./services/index"
2
+ export * from "./interceptors/index"
3
+ export * from "./models/index"
@@ -0,0 +1,16 @@
1
+ import { Injectable } from '@angular/core';
2
+ import { HttpEvent, HttpInterceptor, HttpHandler, HttpRequest } from '@angular/common/http';
3
+
4
+ import { Observable } from 'rxjs';
5
+
6
+ @Injectable()
7
+ export class WithCredentialsInterceptor implements HttpInterceptor {
8
+
9
+ intercept(req: HttpRequest<any>, next: HttpHandler):
10
+ Observable<HttpEvent<any>> {
11
+
12
+ req = req.clone({ withCredentials: true })
13
+
14
+ return next.handle(req);
15
+ }
16
+ }
@@ -0,0 +1,6 @@
1
+
2
+ export * from "./models/index";
3
+
4
+ export * from "./credentials.interceptor";
5
+ export * from "./request-header.interceptor";
6
+ export * from "./request-error.interceptor";
@@ -0,0 +1,22 @@
1
+ export interface ErrorDisplaySettingsInterface {
2
+ displayTime: number
3
+ position: string
4
+ }
5
+
6
+ export class ErrorDisplaySettings implements ErrorDisplaySettingsInterface {
7
+
8
+ constructor(
9
+ public displayTime = 3 * 1000,
10
+ public position = 'top'
11
+ ) {}
12
+
13
+ static adapt(item?: any): ErrorDisplaySettings {
14
+
15
+ return new ErrorDisplaySettings(
16
+ (item?.displayTime) ? item.displayTime * 1000 : 3 * 1000,
17
+ item?.position,
18
+ )
19
+
20
+ }
21
+
22
+ }
@@ -0,0 +1,2 @@
1
+
2
+ export * from "./error-settings.model";
@@ -0,0 +1,46 @@
1
+ import { Inject, Injectable, InjectionToken, Optional } from '@angular/core';
2
+ import { HttpInterceptor, HttpRequest, HttpHandler, HttpEvent } from '@angular/common/http';
3
+ import { Observable } from 'rxjs';
4
+
5
+ export const PROXY_CONFIG = new InjectionToken<Record<string, any>>('PROXY_CONFIG');
6
+
7
+ @Injectable()
8
+ export class ProxyDebuggerInterceptor implements HttpInterceptor {
9
+
10
+ constructor(@Optional() @Inject(PROXY_CONFIG) private proxyConfig: Record<string, any>) {}
11
+
12
+ intercept(req: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {
13
+
14
+ if (!this.proxyConfig) {
15
+ return next.handle(req);
16
+ }
17
+
18
+ const headers = req.headers.keys().reduce((acc, key) => {
19
+ acc[key] = req.headers.get(key) || '';
20
+ return acc;
21
+ }, {} as Record<string, string>);
22
+
23
+ for (const proxyPath in this.proxyConfig) {
24
+ if (this.proxyConfig.hasOwnProperty(proxyPath)) {
25
+ const proxyDetails = this.proxyConfig[proxyPath];
26
+ const regex = new RegExp('^' + proxyPath.replace('/', '').replace('*', '(.*)'));
27
+
28
+ if (regex.test(req.url)) {
29
+ const target = proxyDetails.target;
30
+ const endpoint = req.url.replace(regex, '$1');
31
+ const actualPath = target + '/' + endpoint;
32
+
33
+ console.log('Request Proxied:', {
34
+ requestUrl: req.url,
35
+ requestPayload: req.body,
36
+ headers: headers,
37
+ proxyPath: proxyPath,
38
+ actualPath: actualPath,
39
+ });
40
+ }
41
+ }
42
+ }
43
+
44
+ return next.handle(req);
45
+ }
46
+ }