@hkdigital/lib-core 0.3.11 → 0.3.13

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 (293) hide show
  1. package/README.md +173 -149
  2. package/dist/assets/autospuiten/car-paint-picker.js +41 -41
  3. package/dist/assets/autospuiten/labels.js +7 -7
  4. package/dist/classes/data/IterableTree.js +242 -242
  5. package/dist/classes/data/Selector.js +190 -190
  6. package/dist/classes/data/index.js +2 -2
  7. package/dist/classes/data/typedef.js +9 -9
  8. package/dist/classes/event-emitter/EventEmitter.js +273 -273
  9. package/dist/classes/event-emitter/index.js +2 -2
  10. package/dist/classes/index.js +4 -4
  11. package/dist/classes/promise/HkPromise.js +384 -384
  12. package/dist/classes/promise/index.js +1 -1
  13. package/dist/classes/stores/SubscribersCount.js +107 -107
  14. package/dist/classes/stores/index.js +1 -1
  15. package/dist/classes/streams/LogTransformStream.js +19 -19
  16. package/dist/classes/streams/ServerEventsStore.js +111 -111
  17. package/dist/classes/streams/TimeStampSource.js +26 -26
  18. package/dist/classes/streams/index.js +3 -3
  19. package/dist/classes/svelte/finite-state-machine/FiniteStateMachine.svelte.js +133 -133
  20. package/dist/classes/svelte/finite-state-machine/index.js +1 -1
  21. package/dist/classes/svelte/index.js +1 -11
  22. package/dist/classes/svelte/loading-state-machine/LoadingStateMachine.svelte.js +109 -109
  23. package/dist/classes/svelte/loading-state-machine/constants.js +16 -16
  24. package/dist/classes/svelte/loading-state-machine/index.js +3 -3
  25. package/dist/config/README.md +197 -196
  26. package/dist/config/generators/imagetools.js +189 -189
  27. package/dist/config/generators/vite.js +148 -142
  28. package/dist/config/imagetools.d.ts +72 -72
  29. package/dist/config/vite.js +4 -4
  30. package/dist/constants/bases/index.js +13 -13
  31. package/dist/constants/http/headers.js +6 -6
  32. package/dist/constants/http/index.js +2 -2
  33. package/dist/constants/http/methods.js +14 -14
  34. package/dist/constants/index.js +6 -6
  35. package/dist/constants/mime/application.js +5 -5
  36. package/dist/constants/mime/audio.js +13 -13
  37. package/dist/constants/mime/image.js +3 -3
  38. package/dist/constants/mime/index.js +4 -4
  39. package/dist/constants/mime/text.js +2 -2
  40. package/dist/constants/regexp/README.md +96 -95
  41. package/dist/constants/regexp/index.js +31 -31
  42. package/dist/constants/regexp/inspiratie.js__ +95 -95
  43. package/dist/constants/regexp/text.d.ts +4 -4
  44. package/dist/constants/regexp/text.js +49 -49
  45. package/dist/constants/regexp/url.js +3 -3
  46. package/dist/constants/regexp/user.js +29 -29
  47. package/dist/constants/states/drag.js +6 -6
  48. package/dist/constants/states/drop.js +6 -6
  49. package/dist/constants/states/index.js +4 -4
  50. package/dist/constants/states/input.js +11 -11
  51. package/dist/constants/states/submit.js +4 -4
  52. package/dist/constants/time/index.js +28 -28
  53. package/dist/css/utilities.css +43 -43
  54. package/dist/design/README.md +405 -405
  55. package/dist/design/config/design-config.js +73 -73
  56. package/dist/design/generators/index.js +288 -288
  57. package/dist/design/index.js +96 -96
  58. package/dist/design/plugins/skeleton.js +208 -208
  59. package/dist/design/tailwind-theme-extend.js +158 -158
  60. package/dist/design/themes/README.md +102 -102
  61. package/dist/design/themes/hkdev/components/blocks/text-block.css +34 -34
  62. package/dist/design/themes/hkdev/components/boxes/game-box.css +11 -11
  63. package/dist/design/themes/hkdev/components/buttons/button-icon-steeze.css +22 -22
  64. package/dist/design/themes/hkdev/components/buttons/button-text.css +32 -32
  65. package/dist/design/themes/hkdev/components/buttons/button.css +146 -146
  66. package/dist/design/themes/hkdev/components/buttons/skip-button.css +5 -5
  67. package/dist/design/themes/hkdev/components/drag-drop/draggable.css +73 -73
  68. package/dist/design/themes/hkdev/components/drag-drop/drop-zone.css +58 -58
  69. package/dist/design/themes/hkdev/components/icons/icon-steeze.css +15 -15
  70. package/dist/design/themes/hkdev/components/inputs/text-input.css +102 -102
  71. package/dist/design/themes/hkdev/components/panels/panel.css +25 -25
  72. package/dist/design/themes/hkdev/components/rows/panel-grid-row.css +4 -4
  73. package/dist/design/themes/hkdev/components/rows/panel-row-2.css +5 -5
  74. package/dist/design/themes/hkdev/components.css +29 -29
  75. package/dist/design/themes/hkdev/debug.css +1 -1
  76. package/dist/design/themes/hkdev/global/layout.css +32 -32
  77. package/dist/design/themes/hkdev/global/on-colors.css +32 -32
  78. package/dist/design/themes/hkdev/globals.css +3 -3
  79. package/dist/design/themes/hkdev/responsive.css +12 -12
  80. package/dist/design/themes/hkdev/theme-ext.js +12 -12
  81. package/dist/design/themes/hkdev/theme.css +218 -218
  82. package/dist/design/utils/clamp.js +66 -66
  83. package/dist/design/utils/root-vars.js +102 -102
  84. package/dist/design/utils/scaling.js +228 -228
  85. package/dist/design/utils/states.js +22 -22
  86. package/dist/errors/api.js +9 -9
  87. package/dist/errors/generic.js +20 -20
  88. package/dist/errors/http.js +16 -16
  89. package/dist/errors/index.js +5 -5
  90. package/dist/errors/jwt.js +5 -5
  91. package/dist/errors/promise.js +25 -25
  92. package/dist/logging/README.md +158 -0
  93. package/dist/logging/index.d.ts +3 -1
  94. package/dist/logging/index.js +11 -7
  95. package/dist/logging/internal/adapters/console.js +114 -114
  96. package/dist/logging/internal/adapters/index.js +2 -2
  97. package/dist/logging/internal/adapters/pino.js +160 -142
  98. package/dist/logging/internal/adapters/typedef.js +10 -10
  99. package/dist/logging/internal/{unified-logger/constants.js → constants.js} +22 -22
  100. package/dist/logging/internal/factories/client.d.ts +1 -1
  101. package/dist/logging/internal/factories/client.js +21 -21
  102. package/dist/logging/internal/factories/server.d.ts +1 -1
  103. package/dist/logging/internal/factories/server.js +22 -22
  104. package/dist/logging/internal/factories/universal.d.ts +2 -2
  105. package/dist/logging/internal/factories/universal.js +22 -22
  106. package/dist/logging/internal/{unified-logger → logger}/Logger.d.ts +2 -2
  107. package/dist/logging/internal/{unified-logger → logger}/Logger.js +217 -217
  108. package/dist/logging/internal/logger/index.d.ts +1 -0
  109. package/dist/logging/internal/logger/index.js +1 -0
  110. package/dist/logging/internal/{unified-logger/typedef.d.ts → typedef.d.ts} +2 -1
  111. package/dist/logging/internal/{unified-logger/typedef.js → typedef.js} +21 -17
  112. package/dist/network/README.md +172 -172
  113. package/dist/network/cache/IndexedDbCache.js +1407 -1407
  114. package/dist/network/cache/MemoryResponseCache.js +138 -138
  115. package/dist/network/cache/index.js +5 -5
  116. package/dist/network/cache/typedef.js +41 -41
  117. package/dist/network/cache.js +3 -3
  118. package/dist/network/http/caching.js +261 -261
  119. package/dist/network/http/errors.js +97 -97
  120. package/dist/network/http/headers.js +75 -75
  121. package/dist/network/http/http-request.js +578 -578
  122. package/dist/network/http/index.js +22 -22
  123. package/dist/network/http/json-request.js +224 -224
  124. package/dist/network/http/mocks.js +65 -65
  125. package/dist/network/http/response.js +318 -318
  126. package/dist/network/http/test-data__/content-length-test-hkdigital-small.V4HfZyBQ.avif +0 -0
  127. package/dist/network/http/typedef.js +93 -93
  128. package/dist/network/http/url.js +52 -52
  129. package/dist/network/http.js +5 -5
  130. package/dist/network/loaders/README.md +254 -254
  131. package/dist/network/loaders/audio/AudioLoader.svelte.js +58 -58
  132. package/dist/network/loaders/audio/AudioScene.svelte.js +324 -324
  133. package/dist/network/loaders/audio/mocks.js +35 -35
  134. package/dist/network/loaders/audio.js +1 -1
  135. package/dist/network/loaders/image/ImageLoader.svelte.js +44 -44
  136. package/dist/network/loaders/image/ImageScene.svelte.js +248 -248
  137. package/dist/network/loaders/image/ImageVariantsLoader.svelte.js +150 -150
  138. package/dist/network/loaders/image/index.js +4 -4
  139. package/dist/network/loaders/image/mocks.js +35 -35
  140. package/dist/network/loaders/image/typedef.js +8 -8
  141. package/dist/network/loaders/image/utils/index.js +86 -86
  142. package/dist/network/loaders/image.js +7 -7
  143. package/dist/network/loaders/typedef.js +38 -38
  144. package/dist/network/loaders.js +2 -2
  145. package/dist/network/states/NetworkLoader.svelte.js +338 -338
  146. package/dist/network/states/constants.js +3 -3
  147. package/dist/network/states/index.js +3 -3
  148. package/dist/network/states/mocks.js +30 -30
  149. package/dist/network/states/typedef.js +8 -8
  150. package/dist/network/typedef.js +9 -9
  151. package/dist/services/README.md +200 -0
  152. package/dist/services/index.d.ts +6 -1
  153. package/dist/services/index.js +8 -1
  154. package/dist/services/{internal/service-base → service-base}/ServiceBase.d.ts +2 -2
  155. package/dist/services/{internal/service-base → service-base}/ServiceBase.js +462 -462
  156. package/dist/services/{internal/service-base → service-base}/constants.d.ts +0 -12
  157. package/dist/services/{internal/service-base → service-base}/constants.js +98 -110
  158. package/dist/services/{internal/service-base → service-base}/index.js +3 -3
  159. package/dist/services/{internal/service-base → service-base}/typedef.d.ts +1 -1
  160. package/dist/services/{internal/service-base → service-base}/typedef.js +101 -101
  161. package/dist/services/{internal/service-manager → service-manager}/ServiceManager.d.ts +2 -2
  162. package/dist/services/{internal/service-manager → service-manager}/ServiceManager.js +608 -608
  163. package/dist/services/{internal/service-manager → service-manager}/constants.js +6 -6
  164. package/dist/services/{internal/service-manager → service-manager}/typedef.js +90 -90
  165. package/dist/states/index.js +1 -1
  166. package/dist/states/navigation.svelte.js +55 -55
  167. package/dist/stores/index.js +1 -1
  168. package/dist/stores/theme.js +80 -80
  169. package/dist/typedef/context.js +6 -6
  170. package/dist/typedef/drag.js +25 -25
  171. package/dist/typedef/drop.js +12 -12
  172. package/dist/typedef/index.d.ts +1 -0
  173. package/dist/typedef/index.js +4 -4
  174. package/dist/ui/components/button-group/ButtonGroup.svelte +82 -82
  175. package/dist/ui/components/button-group/typedef.js +10 -10
  176. package/dist/ui/components/compare-left-right/CompareLeftRight.svelte +179 -179
  177. package/dist/ui/components/compare-left-right/index.js +1 -1
  178. package/dist/ui/components/game-box/GameBox.svelte +577 -577
  179. package/dist/ui/components/game-box/gamebox.util.js +83 -83
  180. package/dist/ui/components/hk-app-layout/HkAppLayout.state.svelte.js +25 -25
  181. package/dist/ui/components/hk-app-layout/HkAppLayout.svelte +251 -251
  182. package/dist/ui/components/image-box/ImageBox.svelte +210 -210
  183. package/dist/ui/components/image-box/index.js +5 -5
  184. package/dist/ui/components/image-box/typedef.js +32 -32
  185. package/dist/ui/components/index.js +23 -23
  186. package/dist/ui/components/presenter/ImageSlide.svelte +64 -64
  187. package/dist/ui/components/presenter/Presenter.state.svelte.js +638 -638
  188. package/dist/ui/components/presenter/Presenter.svelte +142 -142
  189. package/dist/ui/components/presenter/constants.js +7 -7
  190. package/dist/ui/components/presenter/index.js +10 -10
  191. package/dist/ui/components/presenter/typedef.js +106 -106
  192. package/dist/ui/components/presenter/util.js +210 -210
  193. package/dist/ui/components/virtual-viewport/VirtualViewport.svelte +196 -196
  194. package/dist/ui/primitives/area/HkArea.svelte +49 -49
  195. package/dist/ui/primitives/area/HkGridArea.svelte +77 -77
  196. package/dist/ui/primitives/area/index.js +2 -2
  197. package/dist/ui/primitives/buttons/button/Button.svelte +82 -82
  198. package/dist/ui/primitives/buttons/button-icon-steeze/SteezeIconButton.svelte +30 -30
  199. package/dist/ui/primitives/buttons/button-text/TextButton.svelte +21 -21
  200. package/dist/ui/primitives/buttons/index.js +3 -3
  201. package/dist/ui/primitives/debug/debug-panel-design-scaling/DebugPanelDesignScaling.svelte +146 -146
  202. package/dist/ui/primitives/debug/index.js +1 -1
  203. package/dist/ui/primitives/drag-drop/DragController.js +44 -44
  204. package/dist/ui/primitives/drag-drop/DragDropContext.svelte +111 -111
  205. package/dist/ui/primitives/drag-drop/Draggable.svelte +519 -519
  206. package/dist/ui/primitives/drag-drop/DropZone.svelte +258 -258
  207. package/dist/ui/primitives/drag-drop/DropZoneArea.svelte +119 -119
  208. package/dist/ui/primitives/drag-drop/DropZoneList.svelte +125 -125
  209. package/dist/ui/primitives/drag-drop/actions.js +26 -26
  210. package/dist/ui/primitives/drag-drop/drag-state.svelte.js +322 -322
  211. package/dist/ui/primitives/drag-drop/index.js +7 -7
  212. package/dist/ui/primitives/drag-drop/util.js +85 -85
  213. package/dist/ui/primitives/hkdev/blocks/TextBlock.svelte +46 -46
  214. package/dist/ui/primitives/hkdev/buttons/CheckButton.svelte +62 -62
  215. package/dist/ui/primitives/icons/HkIcon.svelte +86 -86
  216. package/dist/ui/primitives/icons/HkTabIcon.svelte +116 -116
  217. package/dist/ui/primitives/icons/SteezeIcon.svelte +97 -97
  218. package/dist/ui/primitives/icons/index.js +6 -6
  219. package/dist/ui/primitives/icons/typedef.js +16 -16
  220. package/dist/ui/primitives/index.js +2 -2
  221. package/dist/ui/primitives/inputs/index.js +1 -1
  222. package/dist/ui/primitives/inputs/text-input/TestTextInput.svelte__ +102 -0
  223. package/dist/ui/primitives/inputs/text-input/TextInput.svelte +223 -223
  224. package/dist/ui/primitives/inputs/text-input/TextInput.svelte___ +83 -0
  225. package/dist/ui/primitives/inputs/text-input/assets/IconInvalid.svelte +14 -14
  226. package/dist/ui/primitives/inputs/text-input/assets/IconValid.svelte +12 -12
  227. package/dist/ui/primitives/layout/grid-layers/GridLayers.svelte +63 -63
  228. package/dist/ui/primitives/layout/grid-layers/GridLayers.svelte__heightFrom__ +372 -0
  229. package/dist/ui/primitives/layout/grid-layers/util.js +74 -74
  230. package/dist/ui/primitives/layout/index.js +1 -1
  231. package/dist/ui/primitives/panels/index.js +1 -1
  232. package/dist/ui/primitives/panels/panel/Panel.svelte +43 -43
  233. package/dist/ui/primitives/rows/index.js +3 -3
  234. package/dist/ui/primitives/rows/panel-grid-row/PanelGridRow.svelte +104 -104
  235. package/dist/ui/primitives/rows/panel-row-2/PanelRow2.svelte +40 -40
  236. package/dist/ui/primitives/tab-bar/HkTabBar.state.svelte.js +149 -149
  237. package/dist/ui/primitives/tab-bar/HkTabBar.svelte +74 -74
  238. package/dist/ui/primitives/tab-bar/HkTabBarSelector.state.svelte.js +93 -93
  239. package/dist/ui/primitives/tab-bar/HkTabBarSelector.svelte +49 -49
  240. package/dist/ui/primitives/tab-bar/index.js +17 -17
  241. package/dist/ui/primitives/tab-bar/typedef.js +11 -11
  242. package/dist/util/array/index.js +436 -436
  243. package/dist/util/bases/base58.js +262 -262
  244. package/dist/util/bases/index.js +1 -1
  245. package/dist/util/compare/index.js +247 -247
  246. package/dist/util/css/css-vars.js +83 -83
  247. package/dist/util/css/index.js +1 -1
  248. package/dist/util/env/index.js +9 -9
  249. package/dist/util/exceptions/index.d.ts +4 -3
  250. package/dist/util/exceptions/index.js +26 -23
  251. package/dist/util/expect/arrays.js +47 -47
  252. package/dist/util/expect/index.js +259 -259
  253. package/dist/util/expect/primitives.js +55 -55
  254. package/dist/util/expect/url.js +60 -60
  255. package/dist/util/function/index.js +218 -218
  256. package/dist/util/geo/index.js +26 -26
  257. package/dist/util/index.js +7 -7
  258. package/dist/util/is/index.js +147 -147
  259. package/dist/util/iterate/index.js +204 -204
  260. package/dist/util/object/index.js +1345 -1345
  261. package/dist/util/singleton/index.js +97 -97
  262. package/dist/util/string/array-path.js +75 -75
  263. package/dist/util/string/convert.js +54 -54
  264. package/dist/util/string/fs.js +226 -226
  265. package/dist/util/string/index.js +5 -5
  266. package/dist/util/string/interpolate.js +61 -61
  267. package/dist/util/string/pad.js +10 -10
  268. package/dist/util/svelte/index.js +4 -4
  269. package/dist/util/svelte/loading/loading-tracker.svelte.js +108 -108
  270. package/dist/util/svelte/observe/index.js +49 -49
  271. package/dist/util/svelte/state-context/index.js +117 -117
  272. package/dist/util/svelte/wait/index.js +38 -38
  273. package/dist/util/sveltekit/index.js +1 -1
  274. package/dist/util/sveltekit/route-folders/index.js +101 -101
  275. package/dist/util/time/index.js +328 -328
  276. package/dist/util/unique/index.js +231 -231
  277. package/dist/valibot/README.md +61 -50
  278. package/dist/valibot/index.js +8 -8
  279. package/dist/valibot/parsers/date.js__ +10 -0
  280. package/dist/valibot/parsers/email.d.ts +12 -0
  281. package/dist/valibot/parsers/email.js +34 -0
  282. package/dist/valibot/parsers/url.js +110 -110
  283. package/dist/valibot/parsers/user.js +23 -23
  284. package/dist/valibot/parsers.js +3 -3
  285. package/package.json +131 -131
  286. package/dist/logging/internal/unified-logger/index.d.ts +0 -3
  287. package/dist/logging/internal/unified-logger/index.js +0 -6
  288. package/dist/services/internal/index.d.ts +0 -6
  289. package/dist/services/internal/index.js +0 -8
  290. /package/dist/logging/internal/{unified-logger/constants.d.ts → constants.d.ts} +0 -0
  291. /package/dist/services/{internal/service-base → service-base}/index.d.ts +0 -0
  292. /package/dist/services/{internal/service-manager → service-manager}/constants.d.ts +0 -0
  293. /package/dist/services/{internal/service-manager → service-manager}/typedef.d.ts +0 -0
@@ -1,261 +1,261 @@
1
- import MemoryResponseCache from '../cache/MemoryResponseCache.js';
2
- import IndexedDbCache from '../cache/IndexedDbCache.js';
3
-
4
- import { browser } from '$app/environment';
5
-
6
- import { isTestEnv } from '../../util/env';
7
-
8
- let defaultCacheStorage = null;
9
-
10
- function getCacheStorage()
11
- {
12
- if( !defaultCacheStorage )
13
- {
14
- let type;
15
-
16
- if( !browser || isTestEnv )
17
- {
18
- type = 'memory';
19
- }
20
- else {
21
- type = 'indexed-db';
22
- }
23
-
24
- defaultCacheStorage = createCacheStorage( type);
25
- }
26
-
27
- return defaultCacheStorage
28
- }
29
-
30
- /**
31
- * Store a response in the cache
32
- *
33
- * @param {object} cacheKeyParams - Parameters to use for cache key generation
34
- * @param {string|URL} cacheKeyParams.url - URL string or URL object
35
- * @param {object} [cacheKeyParams.headers] - Request headers that affect caching
36
- * @param {Response} response - Response to cache
37
- * @param {object} metadata - Cache metadata
38
- * @returns {Promise<void>}
39
- */
40
- export async function storeResponseInCache(cacheKeyParams, response, metadata) {
41
- try {
42
- const { url: rawUrl, ...headers } = cacheKeyParams;
43
- const url = typeof rawUrl === 'string' ? rawUrl : rawUrl.toString();
44
-
45
- // Generate cache key
46
- const cacheKey = generateCacheKey(url, headers);
47
-
48
- // Extract Vary header info
49
- const varyHeader = response.headers.get('Vary');
50
- let varyHeaders = null;
51
-
52
- if (varyHeader) {
53
- varyHeaders = {};
54
- const varyFields = varyHeader.split(',').map(field => field.trim().toLowerCase());
55
-
56
- // Store hashes of headers mentioned in Vary
57
- for (const field of varyFields) {
58
- if (field !== '*') {
59
- const value = headers[field];
60
- varyHeaders[field] = hashValue(value);
61
- }
62
- }
63
- }
64
-
65
- // Add vary headers to metadata
66
- const enhancedMetadata = {
67
- ...metadata,
68
- varyHeaders
69
- };
70
-
71
- // Store in cache
72
- await getCacheStorage().set(cacheKey, response, enhancedMetadata);
73
- } catch (error) {
74
- console.error('Cache storage error:', error);
75
- }
76
- }
77
-
78
- /**
79
- * Get a cached response if available and valid
80
- *
81
- * @param {object} cacheKeyParams - Parameters to use for cache key generation
82
- * @param {string|URL} cacheKeyParams.url - URL string or URL object
83
- * @param {object} [cacheKeyParams.headers] - Request headers that affect caching
84
- *
85
- * @returns {Promise<Response|import('./typedef').ResponseWithStale|null>}
86
- * Cached response or null
87
- */
88
- export async function getCachedResponse(cacheKeyParams) {
89
- try {
90
- const { url: rawUrl, ...headers } = cacheKeyParams;
91
- const url = typeof rawUrl === 'string' ? rawUrl : rawUrl.toString();
92
-
93
- // Generate cache key
94
- const cacheKey = generateCacheKey(url, headers);
95
-
96
- // Get cached entry
97
- const cachedEntry = await getCacheStorage().get(cacheKey);
98
-
99
- if (!cachedEntry) {
100
- return null;
101
- }
102
-
103
- // Validate based on Vary headers
104
- if (!isValidForVaryHeaders(cachedEntry, headers)) {
105
- return null;
106
- }
107
-
108
- const { response, metadata } = cachedEntry;
109
-
110
- // Check if expired
111
- const isExpired = metadata.expires && Date.now() > metadata.expires;
112
-
113
- if (!isExpired) {
114
- // Not expired, return as-is
115
- return response;
116
- }
117
-
118
- // Response is stale, add stale info
119
- return enhanceResponseWithStale(response, {
120
- isStale: true,
121
- fresh: null, // No fresh data available yet
122
- timestamp: metadata.timestamp,
123
- expires: metadata.expires
124
- });
125
- } catch (error) {
126
- console.error('Cache retrieval error:', error);
127
- return null;
128
- }
129
- }
130
-
131
- // > Internal functions
132
-
133
- /**
134
- * Create a cache storage adapter
135
- * @param {string} type Type of storage ('indexed-db', 'memory')
136
- * @param {Object} options Options for the storage adapter
137
- *
138
- * @returns {import('../../classes/cache').CacheStorage}
139
- */
140
- function createCacheStorage(type = 'indexed-db', options = {}) {
141
- switch (type) {
142
- case 'indexed-db':
143
- return new IndexedDbCache(
144
- {
145
- dbName: 'http-cache',
146
- storeName: 'responses'
147
- } );
148
-
149
- case 'memory':
150
- return new MemoryResponseCache();
151
-
152
- default:
153
- throw new Error(`Unsupported cache storage type: ${type}`);
154
- }
155
- }
156
-
157
- /**
158
- * Check if cached entry is valid based on Vary headers
159
- *
160
- * @param {object} cachedEntry - Cached entry with response and metadata
161
- * @param {object} headers - Current request headers
162
- * @returns {boolean} True if valid for these headers
163
- */
164
- function isValidForVaryHeaders(cachedEntry, headers) {
165
- const { metadata } = cachedEntry;
166
-
167
- // If no vary headers stored, consider valid
168
- if (!metadata.varyHeaders) {
169
- return true;
170
- }
171
-
172
- // Check each stored vary header
173
- for (const [name, storedHash] of Object.entries(metadata.varyHeaders)) {
174
- const currentValue = headers[name];
175
- const currentHash = hashValue(currentValue);
176
-
177
- // Compare hashes
178
- if (currentHash !== storedHash) {
179
- return false;
180
- }
181
- }
182
-
183
- return true;
184
- }
185
-
186
- /**
187
- * Generate a cache key based on URL and relevant headers
188
- *
189
- * @param {string} url - URL string
190
- * @param {object} headers - Request headers
191
- * @returns {string} Cache key
192
- */
193
- function generateCacheKey(url, headers) {
194
- // Start with a hash of the URL
195
- const keyParts = [hashValue(url)];
196
-
197
- // If we have headers
198
- if (headers && Object.keys(headers).length > 0) {
199
- // Get all header names, sorted for consistency
200
- const headerNames = Object.keys(headers).sort();
201
-
202
- // Create a hash for each header value
203
- const headerHashes = headerNames.map(name => {
204
- const value = headers[name];
205
- // Format: "name:hash_of_value"
206
- return `${name}:${hashValue(value)}`;
207
- });
208
-
209
- if (headerHashes.length > 0) {
210
- keyParts.push(headerHashes.join('|'));
211
- }
212
- }
213
-
214
- return keyParts.join('::');
215
- }
216
-
217
- /**
218
- * Create a hash of a value
219
- *
220
- * @param {string} value - Value to hash
221
- * @returns {string} Hash representation
222
- */
223
- function hashValue(value) {
224
- if (!value) return '';
225
-
226
- // Convert to string if not already
227
- const stringValue = String(value);
228
-
229
- // Simple non-cryptographic hash function
230
- let hash = 0;
231
- for (let i = 0; i < stringValue.length; i++) {
232
- const char = stringValue.charCodeAt(i);
233
- hash = ((hash << 5) - hash) + char;
234
- hash = hash & hash; // Convert to 32bit integer
235
- }
236
- return hash.toString(16); // Convert to hex
237
- }
238
-
239
-
240
- /**
241
- * Enhance a Response object with stale data properties
242
- *
243
- * @param {Response} response - The original Response object
244
- * @param {import('./typedef').StaleInfo} staleInfo - Stale data information
245
- *
246
- * @returns {import('./typedef').ResponseWithStale}
247
- * Enhanced response with stale data properties
248
- */
249
- function enhanceResponseWithStale(response, staleInfo) {
250
- // Create a new object that inherits from Response prototype
251
- const enhanced = Object.create(
252
- Object.getPrototypeOf(response),
253
- Object.getOwnPropertyDescriptors(response)
254
- );
255
-
256
- // Add stale properties
257
- enhanced.isStale = staleInfo.isStale || false;
258
- enhanced.fresh = staleInfo.fresh || null;
259
-
260
- return enhanced;
261
- }
1
+ import MemoryResponseCache from '../cache/MemoryResponseCache.js';
2
+ import IndexedDbCache from '../cache/IndexedDbCache.js';
3
+
4
+ import { browser } from '$app/environment';
5
+
6
+ import { isTestEnv } from '../../util/env';
7
+
8
+ let defaultCacheStorage = null;
9
+
10
+ function getCacheStorage()
11
+ {
12
+ if( !defaultCacheStorage )
13
+ {
14
+ let type;
15
+
16
+ if( !browser || isTestEnv )
17
+ {
18
+ type = 'memory';
19
+ }
20
+ else {
21
+ type = 'indexed-db';
22
+ }
23
+
24
+ defaultCacheStorage = createCacheStorage( type);
25
+ }
26
+
27
+ return defaultCacheStorage
28
+ }
29
+
30
+ /**
31
+ * Store a response in the cache
32
+ *
33
+ * @param {object} cacheKeyParams - Parameters to use for cache key generation
34
+ * @param {string|URL} cacheKeyParams.url - URL string or URL object
35
+ * @param {object} [cacheKeyParams.headers] - Request headers that affect caching
36
+ * @param {Response} response - Response to cache
37
+ * @param {object} metadata - Cache metadata
38
+ * @returns {Promise<void>}
39
+ */
40
+ export async function storeResponseInCache(cacheKeyParams, response, metadata) {
41
+ try {
42
+ const { url: rawUrl, ...headers } = cacheKeyParams;
43
+ const url = typeof rawUrl === 'string' ? rawUrl : rawUrl.toString();
44
+
45
+ // Generate cache key
46
+ const cacheKey = generateCacheKey(url, headers);
47
+
48
+ // Extract Vary header info
49
+ const varyHeader = response.headers.get('Vary');
50
+ let varyHeaders = null;
51
+
52
+ if (varyHeader) {
53
+ varyHeaders = {};
54
+ const varyFields = varyHeader.split(',').map(field => field.trim().toLowerCase());
55
+
56
+ // Store hashes of headers mentioned in Vary
57
+ for (const field of varyFields) {
58
+ if (field !== '*') {
59
+ const value = headers[field];
60
+ varyHeaders[field] = hashValue(value);
61
+ }
62
+ }
63
+ }
64
+
65
+ // Add vary headers to metadata
66
+ const enhancedMetadata = {
67
+ ...metadata,
68
+ varyHeaders
69
+ };
70
+
71
+ // Store in cache
72
+ await getCacheStorage().set(cacheKey, response, enhancedMetadata);
73
+ } catch (error) {
74
+ console.error('Cache storage error:', error);
75
+ }
76
+ }
77
+
78
+ /**
79
+ * Get a cached response if available and valid
80
+ *
81
+ * @param {object} cacheKeyParams - Parameters to use for cache key generation
82
+ * @param {string|URL} cacheKeyParams.url - URL string or URL object
83
+ * @param {object} [cacheKeyParams.headers] - Request headers that affect caching
84
+ *
85
+ * @returns {Promise<Response|import('./typedef').ResponseWithStale|null>}
86
+ * Cached response or null
87
+ */
88
+ export async function getCachedResponse(cacheKeyParams) {
89
+ try {
90
+ const { url: rawUrl, ...headers } = cacheKeyParams;
91
+ const url = typeof rawUrl === 'string' ? rawUrl : rawUrl.toString();
92
+
93
+ // Generate cache key
94
+ const cacheKey = generateCacheKey(url, headers);
95
+
96
+ // Get cached entry
97
+ const cachedEntry = await getCacheStorage().get(cacheKey);
98
+
99
+ if (!cachedEntry) {
100
+ return null;
101
+ }
102
+
103
+ // Validate based on Vary headers
104
+ if (!isValidForVaryHeaders(cachedEntry, headers)) {
105
+ return null;
106
+ }
107
+
108
+ const { response, metadata } = cachedEntry;
109
+
110
+ // Check if expired
111
+ const isExpired = metadata.expires && Date.now() > metadata.expires;
112
+
113
+ if (!isExpired) {
114
+ // Not expired, return as-is
115
+ return response;
116
+ }
117
+
118
+ // Response is stale, add stale info
119
+ return enhanceResponseWithStale(response, {
120
+ isStale: true,
121
+ fresh: null, // No fresh data available yet
122
+ timestamp: metadata.timestamp,
123
+ expires: metadata.expires
124
+ });
125
+ } catch (error) {
126
+ console.error('Cache retrieval error:', error);
127
+ return null;
128
+ }
129
+ }
130
+
131
+ // > Internal functions
132
+
133
+ /**
134
+ * Create a cache storage adapter
135
+ * @param {string} type Type of storage ('indexed-db', 'memory')
136
+ * @param {Object} options Options for the storage adapter
137
+ *
138
+ * @returns {import('../../classes/cache').CacheStorage}
139
+ */
140
+ function createCacheStorage(type = 'indexed-db', options = {}) {
141
+ switch (type) {
142
+ case 'indexed-db':
143
+ return new IndexedDbCache(
144
+ {
145
+ dbName: 'http-cache',
146
+ storeName: 'responses'
147
+ } );
148
+
149
+ case 'memory':
150
+ return new MemoryResponseCache();
151
+
152
+ default:
153
+ throw new Error(`Unsupported cache storage type: ${type}`);
154
+ }
155
+ }
156
+
157
+ /**
158
+ * Check if cached entry is valid based on Vary headers
159
+ *
160
+ * @param {object} cachedEntry - Cached entry with response and metadata
161
+ * @param {object} headers - Current request headers
162
+ * @returns {boolean} True if valid for these headers
163
+ */
164
+ function isValidForVaryHeaders(cachedEntry, headers) {
165
+ const { metadata } = cachedEntry;
166
+
167
+ // If no vary headers stored, consider valid
168
+ if (!metadata.varyHeaders) {
169
+ return true;
170
+ }
171
+
172
+ // Check each stored vary header
173
+ for (const [name, storedHash] of Object.entries(metadata.varyHeaders)) {
174
+ const currentValue = headers[name];
175
+ const currentHash = hashValue(currentValue);
176
+
177
+ // Compare hashes
178
+ if (currentHash !== storedHash) {
179
+ return false;
180
+ }
181
+ }
182
+
183
+ return true;
184
+ }
185
+
186
+ /**
187
+ * Generate a cache key based on URL and relevant headers
188
+ *
189
+ * @param {string} url - URL string
190
+ * @param {object} headers - Request headers
191
+ * @returns {string} Cache key
192
+ */
193
+ function generateCacheKey(url, headers) {
194
+ // Start with a hash of the URL
195
+ const keyParts = [hashValue(url)];
196
+
197
+ // If we have headers
198
+ if (headers && Object.keys(headers).length > 0) {
199
+ // Get all header names, sorted for consistency
200
+ const headerNames = Object.keys(headers).sort();
201
+
202
+ // Create a hash for each header value
203
+ const headerHashes = headerNames.map(name => {
204
+ const value = headers[name];
205
+ // Format: "name:hash_of_value"
206
+ return `${name}:${hashValue(value)}`;
207
+ });
208
+
209
+ if (headerHashes.length > 0) {
210
+ keyParts.push(headerHashes.join('|'));
211
+ }
212
+ }
213
+
214
+ return keyParts.join('::');
215
+ }
216
+
217
+ /**
218
+ * Create a hash of a value
219
+ *
220
+ * @param {string} value - Value to hash
221
+ * @returns {string} Hash representation
222
+ */
223
+ function hashValue(value) {
224
+ if (!value) return '';
225
+
226
+ // Convert to string if not already
227
+ const stringValue = String(value);
228
+
229
+ // Simple non-cryptographic hash function
230
+ let hash = 0;
231
+ for (let i = 0; i < stringValue.length; i++) {
232
+ const char = stringValue.charCodeAt(i);
233
+ hash = ((hash << 5) - hash) + char;
234
+ hash = hash & hash; // Convert to 32bit integer
235
+ }
236
+ return hash.toString(16); // Convert to hex
237
+ }
238
+
239
+
240
+ /**
241
+ * Enhance a Response object with stale data properties
242
+ *
243
+ * @param {Response} response - The original Response object
244
+ * @param {import('./typedef').StaleInfo} staleInfo - Stale data information
245
+ *
246
+ * @returns {import('./typedef').ResponseWithStale}
247
+ * Enhanced response with stale data properties
248
+ */
249
+ function enhanceResponseWithStale(response, staleInfo) {
250
+ // Create a new object that inherits from Response prototype
251
+ const enhanced = Object.create(
252
+ Object.getPrototypeOf(response),
253
+ Object.getOwnPropertyDescriptors(response)
254
+ );
255
+
256
+ // Add stale properties
257
+ enhanced.isStale = staleInfo.isStale || false;
258
+ enhanced.fresh = staleInfo.fresh || null;
259
+
260
+ return enhanced;
261
+ }