@rxap/config 19.2.0-dev.2 → 19.2.0-dev.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +6 -0
- package/compodoc/changelog.html +5 -0
- package/compodoc/dependencies.html +1 -1
- package/compodoc/injectables/ConfigService.html +142 -68
- package/compodoc/interfaces/ConfigLoadOptions.html +197 -33
- package/compodoc/js/menu-wc.js +3 -0
- package/compodoc/js/menu-wc_es5.js +1 -1
- package/compodoc/js/search/search_index.js +2 -2
- package/compodoc/miscellaneous/enumerations.html +231 -0
- package/compodoc/properties.html +1 -1
- package/docs/documentation.json +780 -644
- package/docs/html/assets/hierarchy.js +1 -1
- package/docs/html/assets/navigation.js +1 -1
- package/docs/html/assets/search.js +1 -1
- package/docs/html/classes/ConfigLoaderService.html +2 -2
- package/docs/html/classes/ConfigService.html +6 -6
- package/docs/html/classes/ConfigTestingService.html +2 -2
- package/docs/html/enums/ConfigLoadingStrategy.html +3 -0
- package/docs/html/functions/ProvideConfig.html +1 -1
- package/docs/html/functions/dnsLookup.html +1 -1
- package/docs/html/functions/dnsResolver.html +1 -1
- package/docs/html/functions/fetchCidContent.html +1 -1
- package/docs/html/functions/fetchCidContentAsJson.html +1 -1
- package/docs/html/functions/fetchCidContentViaHttp.html +1 -1
- package/docs/html/functions/fetchContentViaHttp.html +1 -1
- package/docs/html/functions/raceSuccess.html +2 -2
- package/docs/html/hierarchy.html +1 -1
- package/docs/html/index.html +2 -2
- package/docs/html/interfaces/AppsNavigationConfig.html +2 -2
- package/docs/html/interfaces/Config.html +2 -2
- package/docs/html/interfaces/ConfigLoadOptions.html +7 -5
- package/docs/html/interfaces/LogoConfig.html +2 -2
- package/docs/html/interfaces/NavigationConfig.html +2 -2
- package/docs/html/interfaces/Oauth2Config.html +2 -2
- package/docs/html/interfaces/i18nConfig.html +2 -2
- package/docs/html/modules.html +1 -1
- package/docs/html/types/AnySchema.html +1 -1
- package/docs/html/types/Join.html +1 -1
- package/docs/html/types/LanguagesConfig.html +1 -1
- package/docs/html/types/Leaves.html +1 -1
- package/docs/html/types/NoInferType.html +1 -1
- package/docs/html/types/Paths.html +1 -1
- package/docs/html/variables/RXAP_CONFIG.html +1 -1
- package/docs/markdown/README.md +1 -1
- package/docs/markdown/classes/ConfigLoaderService.md +7 -7
- package/docs/markdown/classes/ConfigService.md +22 -22
- package/docs/markdown/classes/ConfigTestingService.md +8 -8
- package/docs/markdown/enumerations/ConfigLoadingStrategy.md +25 -0
- package/docs/markdown/functions/ProvideConfig.md +2 -2
- package/docs/markdown/functions/dnsLookup.md +2 -2
- package/docs/markdown/functions/dnsResolver.md +2 -2
- package/docs/markdown/functions/fetchCidContent.md +2 -2
- package/docs/markdown/functions/fetchCidContentAsJson.md +2 -2
- package/docs/markdown/functions/fetchCidContentViaHttp.md +2 -2
- package/docs/markdown/functions/fetchContentViaHttp.md +2 -2
- package/docs/markdown/functions/raceSuccess.md +2 -2
- package/docs/markdown/globals.md +6 -2
- package/docs/markdown/interfaces/AppsNavigationConfig.md +12 -12
- package/docs/markdown/interfaces/Config.md +6 -6
- package/docs/markdown/interfaces/ConfigLoadOptions.md +27 -11
- package/docs/markdown/interfaces/LogoConfig.md +5 -5
- package/docs/markdown/interfaces/NavigationConfig.md +9 -9
- package/docs/markdown/interfaces/Oauth2Config.md +3 -3
- package/docs/markdown/interfaces/i18nConfig.md +4 -4
- package/docs/markdown/type-aliases/AnySchema.md +2 -2
- package/docs/markdown/type-aliases/Join.md +2 -2
- package/docs/markdown/type-aliases/LanguagesConfig.md +2 -2
- package/docs/markdown/type-aliases/Leaves.md +2 -2
- package/docs/markdown/type-aliases/NoInferType.md +2 -2
- package/docs/markdown/type-aliases/Paths.md +2 -2
- package/docs/markdown/variables/RXAP_CONFIG.md +2 -2
- package/docs/wiki/Class.ConfigLoaderService.md +6 -6
- package/docs/wiki/Class.ConfigService.md +21 -21
- package/docs/wiki/Class.ConfigTestingService.md +7 -7
- package/docs/wiki/Enumeration.ConfigLoadingStrategy.md +21 -0
- package/docs/wiki/Function.ProvideConfig.md +1 -1
- package/docs/wiki/Function.dnsLookup.md +1 -1
- package/docs/wiki/Function.dnsResolver.md +1 -1
- package/docs/wiki/Function.fetchCidContent.md +1 -1
- package/docs/wiki/Function.fetchCidContentAsJson.md +1 -1
- package/docs/wiki/Function.fetchCidContentViaHttp.md +1 -1
- package/docs/wiki/Function.fetchContentViaHttp.md +1 -1
- package/docs/wiki/Function.raceSuccess.md +1 -1
- package/docs/wiki/Interface.AppsNavigationConfig.md +11 -11
- package/docs/wiki/Interface.Config.md +5 -5
- package/docs/wiki/Interface.ConfigLoadOptions.md +26 -10
- package/docs/wiki/Interface.LogoConfig.md +4 -4
- package/docs/wiki/Interface.NavigationConfig.md +8 -8
- package/docs/wiki/Interface.Oauth2Config.md +2 -2
- package/docs/wiki/Interface.i18nConfig.md +3 -3
- package/docs/wiki/TypeAlias.AnySchema.md +1 -1
- package/docs/wiki/TypeAlias.Join.md +1 -1
- package/docs/wiki/TypeAlias.LanguagesConfig.md +1 -1
- package/docs/wiki/TypeAlias.Leaves.md +1 -1
- package/docs/wiki/TypeAlias.NoInferType.md +1 -1
- package/docs/wiki/TypeAlias.Paths.md +1 -1
- package/docs/wiki/Variable.RXAP_CONFIG.md +1 -1
- package/docs/wiki/_Sidebar.md +4 -0
- package/docs/wiki/globals.md +5 -1
- package/fesm2022/rxap-config.mjs +111 -34
- package/fesm2022/rxap-config.mjs.map +1 -1
- package/lib/config.service.d.ts +9 -0
- package/package.json +6 -6
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,12 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
# [19.2.0-dev.3](https://gitlab.com/rxap/packages/compare/@rxap/config@19.2.0-dev.2...@rxap/config@19.2.0-dev.3) (2026-01-19)
|
|
7
|
+
|
|
8
|
+
### Features
|
|
9
|
+
|
|
10
|
+
- **config:** add `strategy` option and FIFO handling for dynamic config loading ([7534069](https://gitlab.com/rxap/packages/commit/7534069a897493c402d3164d6bb7df7b3f1dc9dd))
|
|
11
|
+
|
|
6
12
|
# [19.2.0-dev.2](https://gitlab.com/rxap/packages/compare/@rxap/config@19.2.0-dev.1...@rxap/config@19.2.0-dev.2) (2025-10-28)
|
|
7
13
|
|
|
8
14
|
### Features
|
package/compodoc/changelog.html
CHANGED
|
@@ -85,6 +85,11 @@
|
|
|
85
85
|
<h1>Change Log</h1>
|
|
86
86
|
<p>All notable changes to this project will be documented in this file.
|
|
87
87
|
See <a href="https://conventionalcommits.org">Conventional Commits</a> for commit guidelines.</p>
|
|
88
|
+
<h1><a href="https://gitlab.com/rxap/packages/compare/@rxap/config@19.2.0-dev.2...@rxap/config@19.2.0-dev.3">19.2.0-dev.3</a> (2026-01-19)</h1>
|
|
89
|
+
<h3>Features</h3>
|
|
90
|
+
<ul>
|
|
91
|
+
<li><strong>config:</strong> add <code>strategy</code> option and FIFO handling for dynamic config loading (<a href="https://gitlab.com/rxap/packages/commit/7534069a897493c402d3164d6bb7df7b3f1dc9dd">7534069</a>)</li>
|
|
92
|
+
</ul>
|
|
88
93
|
<h1><a href="https://gitlab.com/rxap/packages/compare/@rxap/config@19.2.0-dev.1...@rxap/config@19.2.0-dev.2">19.2.0-dev.2</a> (2025-10-28)</h1>
|
|
89
94
|
<h3>Features</h3>
|
|
90
95
|
<ul>
|
|
@@ -260,7 +260,7 @@
|
|
|
260
260
|
</tr>
|
|
261
261
|
<tr>
|
|
262
262
|
<td class="col-md-4">
|
|
263
|
-
<div class="io-line">Defined in <a href="" data-line="
|
|
263
|
+
<div class="io-line">Defined in <a href="" data-line="86" class="link-to-prism">src/lib/config.service.ts:86</a></div>
|
|
264
264
|
</td>
|
|
265
265
|
</tr>
|
|
266
266
|
|
|
@@ -325,8 +325,8 @@
|
|
|
325
325
|
|
|
326
326
|
<tr>
|
|
327
327
|
<td class="col-md-4">
|
|
328
|
-
<div class="io-line">Defined in <a href="" data-line="
|
|
329
|
-
class="link-to-prism">src/lib/config.service.ts:
|
|
328
|
+
<div class="io-line">Defined in <a href="" data-line="504"
|
|
329
|
+
class="link-to-prism">src/lib/config.service.ts:504</a></div>
|
|
330
330
|
</td>
|
|
331
331
|
</tr>
|
|
332
332
|
|
|
@@ -364,8 +364,8 @@
|
|
|
364
364
|
|
|
365
365
|
<tr>
|
|
366
366
|
<td class="col-md-4">
|
|
367
|
-
<div class="io-line">Defined in <a href="" data-line="
|
|
368
|
-
class="link-to-prism">src/lib/config.service.ts:
|
|
367
|
+
<div class="io-line">Defined in <a href="" data-line="508"
|
|
368
|
+
class="link-to-prism">src/lib/config.service.ts:508</a></div>
|
|
369
369
|
</td>
|
|
370
370
|
</tr>
|
|
371
371
|
|
|
@@ -441,8 +441,8 @@
|
|
|
441
441
|
|
|
442
442
|
<tr>
|
|
443
443
|
<td class="col-md-4">
|
|
444
|
-
<div class="io-line">Defined in <a href="" data-line="
|
|
445
|
-
class="link-to-prism">src/lib/config.service.ts:
|
|
444
|
+
<div class="io-line">Defined in <a href="" data-line="509"
|
|
445
|
+
class="link-to-prism">src/lib/config.service.ts:509</a></div>
|
|
446
446
|
</td>
|
|
447
447
|
</tr>
|
|
448
448
|
|
|
@@ -530,8 +530,8 @@
|
|
|
530
530
|
|
|
531
531
|
<tr>
|
|
532
532
|
<td class="col-md-4">
|
|
533
|
-
<div class="io-line">Defined in <a href="" data-line="
|
|
534
|
-
class="link-to-prism">src/lib/config.service.ts:
|
|
533
|
+
<div class="io-line">Defined in <a href="" data-line="510"
|
|
534
|
+
class="link-to-prism">src/lib/config.service.ts:510</a></div>
|
|
535
535
|
</td>
|
|
536
536
|
</tr>
|
|
537
537
|
|
|
@@ -619,8 +619,8 @@
|
|
|
619
619
|
|
|
620
620
|
<tr>
|
|
621
621
|
<td class="col-md-4">
|
|
622
|
-
<div class="io-line">Defined in <a href="" data-line="
|
|
623
|
-
class="link-to-prism">src/lib/config.service.ts:
|
|
622
|
+
<div class="io-line">Defined in <a href="" data-line="442"
|
|
623
|
+
class="link-to-prism">src/lib/config.service.ts:442</a></div>
|
|
624
624
|
</td>
|
|
625
625
|
</tr>
|
|
626
626
|
|
|
@@ -721,8 +721,8 @@
|
|
|
721
721
|
|
|
722
722
|
<tr>
|
|
723
723
|
<td class="col-md-4">
|
|
724
|
-
<div class="io-line">Defined in <a href="" data-line="
|
|
725
|
-
class="link-to-prism">src/lib/config.service.ts:
|
|
724
|
+
<div class="io-line">Defined in <a href="" data-line="448"
|
|
725
|
+
class="link-to-prism">src/lib/config.service.ts:448</a></div>
|
|
726
726
|
</td>
|
|
727
727
|
</tr>
|
|
728
728
|
|
|
@@ -831,8 +831,8 @@
|
|
|
831
831
|
|
|
832
832
|
<tr>
|
|
833
833
|
<td class="col-md-4">
|
|
834
|
-
<div class="io-line">Defined in <a href="" data-line="
|
|
835
|
-
class="link-to-prism">src/lib/config.service.ts:
|
|
834
|
+
<div class="io-line">Defined in <a href="" data-line="514"
|
|
835
|
+
class="link-to-prism">src/lib/config.service.ts:514</a></div>
|
|
836
836
|
</td>
|
|
837
837
|
</tr>
|
|
838
838
|
|
|
@@ -908,8 +908,8 @@
|
|
|
908
908
|
|
|
909
909
|
<tr>
|
|
910
910
|
<td class="col-md-4">
|
|
911
|
-
<div class="io-line">Defined in <a href="" data-line="
|
|
912
|
-
class="link-to-prism">src/lib/config.service.ts:
|
|
911
|
+
<div class="io-line">Defined in <a href="" data-line="515"
|
|
912
|
+
class="link-to-prism">src/lib/config.service.ts:515</a></div>
|
|
913
913
|
</td>
|
|
914
914
|
</tr>
|
|
915
915
|
|
|
@@ -997,8 +997,8 @@
|
|
|
997
997
|
|
|
998
998
|
<tr>
|
|
999
999
|
<td class="col-md-4">
|
|
1000
|
-
<div class="io-line">Defined in <a href="" data-line="
|
|
1001
|
-
class="link-to-prism">src/lib/config.service.ts:
|
|
1000
|
+
<div class="io-line">Defined in <a href="" data-line="516"
|
|
1001
|
+
class="link-to-prism">src/lib/config.service.ts:516</a></div>
|
|
1002
1002
|
</td>
|
|
1003
1003
|
</tr>
|
|
1004
1004
|
|
|
@@ -1087,8 +1087,8 @@
|
|
|
1087
1087
|
|
|
1088
1088
|
<tr>
|
|
1089
1089
|
<td class="col-md-4">
|
|
1090
|
-
<div class="io-line">Defined in <a href="" data-line="
|
|
1091
|
-
class="link-to-prism">src/lib/config.service.ts:
|
|
1090
|
+
<div class="io-line">Defined in <a href="" data-line="106"
|
|
1091
|
+
class="link-to-prism">src/lib/config.service.ts:106</a></div>
|
|
1092
1092
|
</td>
|
|
1093
1093
|
</tr>
|
|
1094
1094
|
|
|
@@ -1173,8 +1173,8 @@
|
|
|
1173
1173
|
|
|
1174
1174
|
<tr>
|
|
1175
1175
|
<td class="col-md-4">
|
|
1176
|
-
<div class="io-line">Defined in <a href="" data-line="
|
|
1177
|
-
class="link-to-prism">src/lib/config.service.ts:
|
|
1176
|
+
<div class="io-line">Defined in <a href="" data-line="500"
|
|
1177
|
+
class="link-to-prism">src/lib/config.service.ts:500</a></div>
|
|
1178
1178
|
</td>
|
|
1179
1179
|
</tr>
|
|
1180
1180
|
|
|
@@ -1243,8 +1243,8 @@
|
|
|
1243
1243
|
|
|
1244
1244
|
<tr>
|
|
1245
1245
|
<td class="col-md-4">
|
|
1246
|
-
<div class="io-line">Defined in <a href="" data-line="
|
|
1247
|
-
class="link-to-prism">src/lib/config.service.ts:
|
|
1246
|
+
<div class="io-line">Defined in <a href="" data-line="423"
|
|
1247
|
+
class="link-to-prism">src/lib/config.service.ts:423</a></div>
|
|
1248
1248
|
</td>
|
|
1249
1249
|
</tr>
|
|
1250
1250
|
|
|
@@ -1353,7 +1353,7 @@
|
|
|
1353
1353
|
</tr>
|
|
1354
1354
|
<tr>
|
|
1355
1355
|
<td class="col-md-4">
|
|
1356
|
-
<div class="io-line">Defined in <a href="" data-line="
|
|
1356
|
+
<div class="io-line">Defined in <a href="" data-line="86" class="link-to-prism">src/lib/config.service.ts:86</a></div>
|
|
1357
1357
|
</td>
|
|
1358
1358
|
</tr>
|
|
1359
1359
|
|
|
@@ -1385,7 +1385,7 @@
|
|
|
1385
1385
|
</tr>
|
|
1386
1386
|
<tr>
|
|
1387
1387
|
<td class="col-md-4">
|
|
1388
|
-
<div class="io-line">Defined in <a href="" data-line="
|
|
1388
|
+
<div class="io-line">Defined in <a href="" data-line="65" class="link-to-prism">src/lib/config.service.ts:65</a></div>
|
|
1389
1389
|
</td>
|
|
1390
1390
|
</tr>
|
|
1391
1391
|
|
|
@@ -1417,7 +1417,7 @@
|
|
|
1417
1417
|
</tr>
|
|
1418
1418
|
<tr>
|
|
1419
1419
|
<td class="col-md-4">
|
|
1420
|
-
<div class="io-line">Defined in <a href="" data-line="
|
|
1420
|
+
<div class="io-line">Defined in <a href="" data-line="72" class="link-to-prism">src/lib/config.service.ts:72</a></div>
|
|
1421
1421
|
</td>
|
|
1422
1422
|
</tr>
|
|
1423
1423
|
|
|
@@ -1457,7 +1457,7 @@ the Urls array.</p>
|
|
|
1457
1457
|
</tr>
|
|
1458
1458
|
<tr>
|
|
1459
1459
|
<td class="col-md-4">
|
|
1460
|
-
<div class="io-line">Defined in <a href="" data-line="
|
|
1460
|
+
<div class="io-line">Defined in <a href="" data-line="80" class="link-to-prism">src/lib/config.service.ts:80</a></div>
|
|
1461
1461
|
</td>
|
|
1462
1462
|
</tr>
|
|
1463
1463
|
|
|
@@ -1483,7 +1483,7 @@ the Urls array.</p>
|
|
|
1483
1483
|
</tr>
|
|
1484
1484
|
<tr>
|
|
1485
1485
|
<td class="col-md-4">
|
|
1486
|
-
<div class="io-line">Defined in <a href="" data-line="
|
|
1486
|
+
<div class="io-line">Defined in <a href="" data-line="59" class="link-to-prism">src/lib/config.service.ts:59</a></div>
|
|
1487
1487
|
</td>
|
|
1488
1488
|
</tr>
|
|
1489
1489
|
|
|
@@ -1515,7 +1515,7 @@ the Urls array.</p>
|
|
|
1515
1515
|
</tr>
|
|
1516
1516
|
<tr>
|
|
1517
1517
|
<td class="col-md-4">
|
|
1518
|
-
<div class="io-line">Defined in <a href="" data-line="
|
|
1518
|
+
<div class="io-line">Defined in <a href="" data-line="62" class="link-to-prism">src/lib/config.service.ts:62</a></div>
|
|
1519
1519
|
</td>
|
|
1520
1520
|
</tr>
|
|
1521
1521
|
|
|
@@ -1541,7 +1541,7 @@ the Urls array.</p>
|
|
|
1541
1541
|
</tr>
|
|
1542
1542
|
<tr>
|
|
1543
1543
|
<td class="col-md-4">
|
|
1544
|
-
<div class="io-line">Defined in <a href="" data-line="
|
|
1544
|
+
<div class="io-line">Defined in <a href="" data-line="60" class="link-to-prism">src/lib/config.service.ts:60</a></div>
|
|
1545
1545
|
</td>
|
|
1546
1546
|
</tr>
|
|
1547
1547
|
|
|
@@ -1573,7 +1573,7 @@ the Urls array.</p>
|
|
|
1573
1573
|
</tr>
|
|
1574
1574
|
<tr>
|
|
1575
1575
|
<td class="col-md-4">
|
|
1576
|
-
<div class="io-line">Defined in <a href="" data-line="
|
|
1576
|
+
<div class="io-line">Defined in <a href="" data-line="63" class="link-to-prism">src/lib/config.service.ts:63</a></div>
|
|
1577
1577
|
</td>
|
|
1578
1578
|
</tr>
|
|
1579
1579
|
|
|
@@ -1605,7 +1605,7 @@ the Urls array.</p>
|
|
|
1605
1605
|
</tr>
|
|
1606
1606
|
<tr>
|
|
1607
1607
|
<td class="col-md-4">
|
|
1608
|
-
<div class="io-line">Defined in <a href="" data-line="
|
|
1608
|
+
<div class="io-line">Defined in <a href="" data-line="78" class="link-to-prism">src/lib/config.service.ts:78</a></div>
|
|
1609
1609
|
</td>
|
|
1610
1610
|
</tr>
|
|
1611
1611
|
|
|
@@ -1649,7 +1649,7 @@ value form the Defaults values or dynamic config files</p>
|
|
|
1649
1649
|
</tr>
|
|
1650
1650
|
<tr>
|
|
1651
1651
|
<td class="col-md-4">
|
|
1652
|
-
<div class="io-line">Defined in <a href="" data-line="
|
|
1652
|
+
<div class="io-line">Defined in <a href="" data-line="85" class="link-to-prism">src/lib/config.service.ts:85</a></div>
|
|
1653
1653
|
</td>
|
|
1654
1654
|
</tr>
|
|
1655
1655
|
|
|
@@ -1685,8 +1685,14 @@ import {
|
|
|
1685
1685
|
|
|
1686
1686
|
export type AnySchema = { validateAsync: (...args: any[]) => any };
|
|
1687
1687
|
|
|
1688
|
+
export enum ConfigLoadingStrategy {
|
|
1689
|
+
DEFAULT = 'default',
|
|
1690
|
+
FIFO = 'fifo',
|
|
1691
|
+
}
|
|
1692
|
+
|
|
1688
1693
|
export interface ConfigLoadOptions {
|
|
1689
1694
|
fromUrlParam?: string | boolean;
|
|
1695
|
+
fromUrls?: boolean;
|
|
1690
1696
|
fromLocalStorage?: boolean;
|
|
1691
1697
|
schema?: AnySchema;
|
|
1692
1698
|
url?: string | string[] | ((environment: Environment) => string | string[]);
|
|
@@ -1706,6 +1712,7 @@ export interface ConfigLoadOptions {
|
|
|
1706
1712
|
fromCid?: string;
|
|
1707
1713
|
fetchCidContent?: (cid: string, path?: string) => Promise<Blob | null>;
|
|
1708
1714
|
dnsServers?: string[];
|
|
1715
|
+
strategy?: ConfigLoadingStrategy;
|
|
1709
1716
|
}
|
|
1710
1717
|
|
|
1711
1718
|
@Injectable({
|
|
@@ -1774,65 +1781,132 @@ export class ConfigService<Config extends Record<string, any> = Re
|
|
|
1774
1781
|
options.fromUrlParam = environment.config.fromUrlParam;
|
|
1775
1782
|
options.fromLocalStorage = environment.config.fromLocalStorage;
|
|
1776
1783
|
options.schema = environment.config.schema;
|
|
1784
|
+
options.strategy = environment.config.strategy as ConfigLoadingStrategy ?? options.strategy;
|
|
1777
1785
|
}
|
|
1778
1786
|
}
|
|
1779
1787
|
|
|
1780
1788
|
config = deepMerge(config, options?.static ?? {});
|
|
1789
|
+
let done = false;
|
|
1781
1790
|
|
|
1782
|
-
|
|
1783
|
-
|
|
1784
|
-
|
|
1785
|
-
|
|
1791
|
+
if (!done && options?.fromUrls !== false) {
|
|
1792
|
+
try {
|
|
1793
|
+
config = deepMerge(config, await this.loadConfigFromUrls(options, environment));
|
|
1794
|
+
if (options.strategy === ConfigLoadingStrategy.FIFO) {
|
|
1795
|
+
done = true;
|
|
1796
|
+
}
|
|
1797
|
+
} catch (error: any) {
|
|
1798
|
+
if (options.strategy !== ConfigLoadingStrategy.FIFO) {
|
|
1799
|
+
console.error('Could not load config from urls', error);
|
|
1800
|
+
throw error;
|
|
1801
|
+
} else {
|
|
1802
|
+
console.warn('Could not load config from urls: ' + error.message + '. Will try next strategy.');
|
|
1786
1803
|
}
|
|
1787
|
-
return coerceArray(url(environment));
|
|
1788
1804
|
}
|
|
1789
|
-
|
|
1790
|
-
}).flat();
|
|
1805
|
+
}
|
|
1791
1806
|
|
|
1792
|
-
|
|
1793
|
-
|
|
1794
|
-
|
|
1795
|
-
|
|
1796
|
-
|
|
1797
|
-
|
|
1798
|
-
|
|
1807
|
+
if (!done && options?.fromLocalStorage !== false) {
|
|
1808
|
+
try {
|
|
1809
|
+
config = deepMerge(config, this.loadConfigFromLocalStorage(options));
|
|
1810
|
+
if (options.strategy === ConfigLoadingStrategy.FIFO) {
|
|
1811
|
+
done = true;
|
|
1812
|
+
}
|
|
1813
|
+
} catch (error: any) {
|
|
1814
|
+
if (options.strategy !== ConfigLoadingStrategy.FIFO) {
|
|
1815
|
+
console.error('Could not load config from local storage', error);
|
|
1816
|
+
throw error;
|
|
1817
|
+
} else {
|
|
1818
|
+
console.warn('Could not load config from local storage: ' + error.message + '. Will try next strategy.');
|
|
1819
|
+
}
|
|
1799
1820
|
}
|
|
1800
1821
|
}
|
|
1801
1822
|
|
|
1802
|
-
|
|
1803
|
-
|
|
1804
|
-
|
|
1805
|
-
|
|
1806
|
-
|
|
1807
|
-
|
|
1808
|
-
|
|
1809
|
-
|
|
1810
|
-
|
|
1811
|
-
|
|
1812
|
-
|
|
1823
|
+
if (!done && options?.fromUrlParam) {
|
|
1824
|
+
try {
|
|
1825
|
+
config = deepMerge(config, this.loadConfigFromUrlParam(options as any));
|
|
1826
|
+
if (options.strategy === ConfigLoadingStrategy.FIFO) {
|
|
1827
|
+
done = true;
|
|
1828
|
+
}
|
|
1829
|
+
} catch (error: any) {
|
|
1830
|
+
if (options.strategy !== ConfigLoadingStrategy.FIFO) {
|
|
1831
|
+
console.error('Could not load config from url param', error);
|
|
1832
|
+
throw error;
|
|
1833
|
+
} else {
|
|
1834
|
+
console.warn('Could not load config from url param: ' + error.message + '. Will try next strategy.');
|
|
1813
1835
|
}
|
|
1814
1836
|
}
|
|
1815
|
-
|
|
1816
1837
|
}
|
|
1817
1838
|
|
|
1818
|
-
if (options?.
|
|
1819
|
-
|
|
1820
|
-
config = deepMerge(config, this.LoadConfigDefaultFromUrlParam(param));
|
|
1839
|
+
if (!done && options?.fromDns) {
|
|
1840
|
+
await this.loadConfigFromDns(options as any);
|
|
1821
1841
|
}
|
|
1822
1842
|
|
|
1823
|
-
if (options?.
|
|
1824
|
-
|
|
1843
|
+
if (!done && options?.fromCid) {
|
|
1844
|
+
try {
|
|
1845
|
+
config = deepMerge(config, await this.loadConfigFromCid(options as any));
|
|
1846
|
+
if (options.strategy === ConfigLoadingStrategy.FIFO) {
|
|
1847
|
+
done = true;
|
|
1848
|
+
}
|
|
1849
|
+
} catch (error: any) {
|
|
1850
|
+
if (options.strategy !== ConfigLoadingStrategy.FIFO) {
|
|
1851
|
+
console.error('Could not load config from cid', error);
|
|
1852
|
+
throw error;
|
|
1853
|
+
} else {
|
|
1854
|
+
console.warn('Could not load config from cid: ' + error.message + '. Will try next strategy.');
|
|
1855
|
+
}
|
|
1856
|
+
}
|
|
1825
1857
|
}
|
|
1826
1858
|
|
|
1827
|
-
if (
|
|
1828
|
-
|
|
1859
|
+
if (!done) {
|
|
1860
|
+
console.warn('No config loading strategy succeeded. Using default config.');
|
|
1829
1861
|
}
|
|
1830
1862
|
|
|
1863
|
+
config = deepMerge(config, this.Overwrites);
|
|
1864
|
+
|
|
1831
1865
|
console.debug('app config', config);
|
|
1832
1866
|
|
|
1833
1867
|
this.Config = config;
|
|
1834
1868
|
}
|
|
1835
1869
|
|
|
1870
|
+
private static loadConfigFromUrlParam(options: ConfigLoadOptions & { fromUrlParam: string | true }) {
|
|
1871
|
+
const param = typeof options.fromUrlParam === 'string' ? options.fromUrlParam : 'config';
|
|
1872
|
+
return this.LoadConfigDefaultFromUrlParam(param);
|
|
1873
|
+
}
|
|
1874
|
+
|
|
1875
|
+
private static loadConfigFromLocalStorage(options: ConfigLoadOptions) {
|
|
1876
|
+
const localConfig = localStorage.getItem(ConfigService.LocalStorageKey);
|
|
1877
|
+
if (localConfig) {
|
|
1878
|
+
return JSON.parse(localConfig);
|
|
1879
|
+
} else {
|
|
1880
|
+
return {};
|
|
1881
|
+
}
|
|
1882
|
+
}
|
|
1883
|
+
|
|
1884
|
+
private static async loadConfigFromUrls(options: ConfigLoadOptions, environment?: Environment) {
|
|
1885
|
+
let config: any = {};
|
|
1886
|
+
const urls = (
|
|
1887
|
+
options?.url ? coerceArray(options.url) : ConfigService.Urls
|
|
1888
|
+
).map(url => {
|
|
1889
|
+
if (typeof url === 'function') {
|
|
1890
|
+
if (!environment) {
|
|
1891
|
+
throw new Error('environment is required when url is a function');
|
|
1892
|
+
}
|
|
1893
|
+
return coerceArray(url(environment));
|
|
1894
|
+
}
|
|
1895
|
+
return coerceArray(url);
|
|
1896
|
+
}).flat();
|
|
1897
|
+
|
|
1898
|
+
for (const url of urls) {
|
|
1899
|
+
const loadedConfig = await this.loadConfig(url, true, options?.schema);
|
|
1900
|
+
const match = url.match(/config\.([a-zA-Z0-9.\-_]+)\.json/);
|
|
1901
|
+
if (match) {
|
|
1902
|
+
SetToObject(config, match[1], loadedConfig);
|
|
1903
|
+
} else {
|
|
1904
|
+
config = deepMerge(config, loadedConfig);
|
|
1905
|
+
}
|
|
1906
|
+
}
|
|
1907
|
+
return config;
|
|
1908
|
+
}
|
|
1909
|
+
|
|
1836
1910
|
private static async loadConfigFromCid(options: ConfigLoadOptions & { fromCid: string | boolean }) {
|
|
1837
1911
|
console.debug('Loading config from CID: ', options.fromCid);
|
|
1838
1912
|
try {
|