@splitsoftware/splitio-commons 1.15.1-rc.3 → 1.16.1-rc.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (141) hide show
  1. package/CHANGES.txt +5 -3
  2. package/cjs/evaluator/matchers/index.js +3 -1
  3. package/cjs/evaluator/matchers/large_segment.js +16 -0
  4. package/cjs/evaluator/matchers/matcherTypes.js +1 -0
  5. package/cjs/evaluator/matchersTransform/index.js +1 -1
  6. package/cjs/logger/constants.js +4 -4
  7. package/cjs/logger/messages/info.js +0 -1
  8. package/cjs/readiness/readinessManager.js +11 -6
  9. package/cjs/readiness/sdkReadinessManager.js +5 -6
  10. package/cjs/sdkClient/sdkClientMethodCS.js +3 -4
  11. package/cjs/sdkClient/sdkClientMethodCSWithTT.js +4 -5
  12. package/cjs/sdkFactory/index.js +1 -1
  13. package/cjs/services/splitApi.js +4 -0
  14. package/cjs/storages/AbstractSplitsCacheAsync.js +2 -2
  15. package/cjs/storages/AbstractSplitsCacheSync.js +5 -5
  16. package/cjs/storages/KeyBuilder.js +3 -0
  17. package/cjs/storages/KeyBuilderCS.js +17 -5
  18. package/cjs/storages/inLocalStorage/SplitsCacheInLocal.js +16 -4
  19. package/cjs/storages/inLocalStorage/index.js +6 -2
  20. package/cjs/storages/inMemory/InMemoryStorageCS.js +5 -0
  21. package/cjs/storages/inMemory/SplitsCacheInMemory.js +20 -11
  22. package/cjs/storages/inMemory/TelemetryCacheInMemory.js +7 -10
  23. package/cjs/sync/polling/pollingManagerCS.js +54 -30
  24. package/cjs/sync/polling/syncTasks/mySegmentsSyncTask.js +2 -2
  25. package/cjs/sync/polling/updaters/mySegmentsUpdater.js +13 -8
  26. package/cjs/sync/polling/updaters/splitChangesUpdater.js +2 -1
  27. package/cjs/sync/streaming/SSEHandler/index.js +1 -0
  28. package/cjs/sync/streaming/UpdateWorkers/MySegmentsUpdateWorker.js +6 -5
  29. package/cjs/sync/streaming/constants.js +2 -1
  30. package/cjs/sync/streaming/pushManager.js +96 -64
  31. package/cjs/sync/submitters/telemetrySubmitter.js +2 -0
  32. package/cjs/sync/syncManagerOnline.js +24 -14
  33. package/cjs/utils/constants/index.js +5 -1
  34. package/cjs/utils/settingsValidation/index.js +9 -4
  35. package/esm/evaluator/matchers/index.js +3 -1
  36. package/esm/evaluator/matchers/large_segment.js +12 -0
  37. package/esm/evaluator/matchers/matcherTypes.js +1 -0
  38. package/esm/evaluator/matchersTransform/index.js +1 -1
  39. package/esm/logger/constants.js +1 -1
  40. package/esm/logger/messages/info.js +0 -1
  41. package/esm/readiness/readinessManager.js +11 -6
  42. package/esm/readiness/sdkReadinessManager.js +5 -6
  43. package/esm/sdkClient/sdkClientMethodCS.js +4 -5
  44. package/esm/sdkClient/sdkClientMethodCSWithTT.js +5 -6
  45. package/esm/sdkFactory/index.js +1 -1
  46. package/esm/services/splitApi.js +5 -1
  47. package/esm/storages/AbstractSplitsCacheAsync.js +2 -2
  48. package/esm/storages/AbstractSplitsCacheSync.js +3 -3
  49. package/esm/storages/KeyBuilder.js +3 -0
  50. package/esm/storages/KeyBuilderCS.js +15 -4
  51. package/esm/storages/inLocalStorage/SplitsCacheInLocal.js +17 -5
  52. package/esm/storages/inLocalStorage/index.js +7 -3
  53. package/esm/storages/inMemory/InMemoryStorageCS.js +5 -0
  54. package/esm/storages/inMemory/SplitsCacheInMemory.js +21 -12
  55. package/esm/storages/inMemory/TelemetryCacheInMemory.js +7 -10
  56. package/esm/sync/polling/pollingManagerCS.js +55 -31
  57. package/esm/sync/polling/syncTasks/mySegmentsSyncTask.js +2 -2
  58. package/esm/sync/polling/updaters/mySegmentsUpdater.js +11 -6
  59. package/esm/sync/polling/updaters/splitChangesUpdater.js +2 -1
  60. package/esm/sync/streaming/SSEHandler/index.js +2 -1
  61. package/esm/sync/streaming/UpdateWorkers/MySegmentsUpdateWorker.js +6 -5
  62. package/esm/sync/streaming/constants.js +1 -0
  63. package/esm/sync/streaming/pushManager.js +96 -65
  64. package/esm/sync/submitters/telemetrySubmitter.js +2 -0
  65. package/esm/sync/syncManagerOnline.js +25 -15
  66. package/esm/utils/constants/index.js +4 -0
  67. package/esm/utils/settingsValidation/index.js +10 -5
  68. package/package.json +1 -1
  69. package/src/dtos/types.ts +7 -1
  70. package/src/evaluator/matchers/index.ts +2 -0
  71. package/src/evaluator/matchers/large_segment.ts +18 -0
  72. package/src/evaluator/matchers/matcherTypes.ts +1 -0
  73. package/src/evaluator/matchersTransform/index.ts +1 -1
  74. package/src/logger/constants.ts +1 -1
  75. package/src/logger/messages/info.ts +0 -1
  76. package/src/readiness/readinessManager.ts +11 -5
  77. package/src/readiness/sdkReadinessManager.ts +7 -7
  78. package/src/readiness/types.ts +3 -2
  79. package/src/sdkClient/sdkClientMethodCS.ts +4 -6
  80. package/src/sdkClient/sdkClientMethodCSWithTT.ts +5 -7
  81. package/src/sdkFactory/index.ts +1 -1
  82. package/src/services/splitApi.ts +6 -1
  83. package/src/services/types.ts +1 -0
  84. package/src/storages/AbstractSplitsCacheAsync.ts +2 -2
  85. package/src/storages/AbstractSplitsCacheSync.ts +4 -4
  86. package/src/storages/KeyBuilder.ts +3 -0
  87. package/src/storages/KeyBuilderCS.ts +25 -5
  88. package/src/storages/inLocalStorage/MySegmentsCacheInLocal.ts +3 -3
  89. package/src/storages/inLocalStorage/SplitsCacheInLocal.ts +20 -5
  90. package/src/storages/inLocalStorage/index.ts +8 -4
  91. package/src/storages/inMemory/InMemoryStorageCS.ts +5 -0
  92. package/src/storages/inMemory/SplitsCacheInMemory.ts +15 -10
  93. package/src/storages/inMemory/TelemetryCacheInMemory.ts +7 -11
  94. package/src/storages/types.ts +6 -4
  95. package/src/sync/polling/pollingManagerCS.ts +62 -27
  96. package/src/sync/polling/syncTasks/mySegmentsSyncTask.ts +8 -9
  97. package/src/sync/polling/types.ts +4 -3
  98. package/src/sync/polling/updaters/mySegmentsUpdater.ts +13 -10
  99. package/src/sync/polling/updaters/splitChangesUpdater.ts +4 -3
  100. package/src/sync/streaming/SSEHandler/index.ts +2 -1
  101. package/src/sync/streaming/SSEHandler/types.ts +14 -2
  102. package/src/sync/streaming/UpdateWorkers/MySegmentsUpdateWorker.ts +7 -5
  103. package/src/sync/streaming/constants.ts +1 -0
  104. package/src/sync/streaming/pushManager.ts +101 -63
  105. package/src/sync/streaming/types.ts +5 -3
  106. package/src/sync/submitters/telemetrySubmitter.ts +2 -0
  107. package/src/sync/submitters/types.ts +10 -4
  108. package/src/sync/syncManagerOnline.ts +19 -11
  109. package/src/types.ts +26 -1
  110. package/src/utils/constants/index.ts +5 -0
  111. package/src/utils/settingsValidation/index.ts +11 -6
  112. package/src/utils/settingsValidation/types.ts +1 -1
  113. package/types/dtos/types.d.ts +5 -1
  114. package/types/evaluator/matchers/large_segment.d.ts +5 -0
  115. package/types/logger/constants.d.ts +1 -1
  116. package/types/readiness/readinessManager.d.ts +2 -2
  117. package/types/readiness/sdkReadinessManager.d.ts +2 -3
  118. package/types/readiness/types.d.ts +3 -2
  119. package/types/services/types.d.ts +1 -0
  120. package/types/storages/AbstractSplitsCacheAsync.d.ts +1 -1
  121. package/types/storages/AbstractSplitsCacheSync.d.ts +3 -3
  122. package/types/storages/KeyBuilder.d.ts +1 -0
  123. package/types/storages/KeyBuilderCS.d.ts +7 -2
  124. package/types/storages/inLocalStorage/MySegmentsCacheInLocal.d.ts +2 -2
  125. package/types/storages/inLocalStorage/SplitsCacheInLocal.d.ts +1 -1
  126. package/types/storages/inMemory/SplitsCacheInMemory.d.ts +3 -2
  127. package/types/storages/inMemory/TelemetryCacheInMemory.d.ts +4 -6
  128. package/types/storages/types.d.ts +4 -3
  129. package/types/sync/polling/syncTasks/mySegmentsSyncTask.d.ts +2 -3
  130. package/types/sync/polling/types.d.ts +10 -3
  131. package/types/sync/polling/updaters/mySegmentsUpdater.d.ts +4 -4
  132. package/types/sync/streaming/SSEHandler/types.d.ts +13 -2
  133. package/types/sync/streaming/UpdateWorkers/MySegmentsUpdateWorker.d.ts +2 -1
  134. package/types/sync/streaming/constants.d.ts +1 -0
  135. package/types/sync/streaming/pushManager.d.ts +2 -0
  136. package/types/sync/streaming/types.d.ts +5 -4
  137. package/types/sync/submitters/types.d.ts +9 -3
  138. package/types/types.d.ts +25 -0
  139. package/types/utils/constants/index.d.ts +3 -0
  140. package/types/utils/settingsValidation/index.d.ts +2 -0
  141. package/types/utils/settingsValidation/types.d.ts +1 -1
@@ -25,7 +25,7 @@ export interface ISettingsValidationParams {
25
25
  /** Localhost mode validator (`settings.sync.localhostMode`) */
26
26
  localhost?: (settings: ISettings) => ISettings['sync']['localhostMode'],
27
27
  /** User consent validator (`settings.userConsent`) */
28
- consent: (settings: ISettings) => ISettings['userConsent'],
28
+ consent?: (settings: ISettings) => ISettings['userConsent'],
29
29
  /** Flag spec version validation. Configurable by the JS Synchronizer but not by the SDKs */
30
30
  flagSpec?: (settings: ISettings) => ISettings['sync']['flagSpecVersion']
31
31
  }
@@ -48,6 +48,10 @@ interface IInSegmentMatcher extends ISplitMatcherBase {
48
48
  matcherType: 'IN_SEGMENT';
49
49
  userDefinedSegmentMatcherData: IInSegmentMatcherData;
50
50
  }
51
+ interface IInLargeSegmentMatcher extends ISplitMatcherBase {
52
+ matcherType: 'IN_LARGE_SEGMENT';
53
+ userDefinedSegmentMatcherData: IInSegmentMatcherData;
54
+ }
51
55
  interface IWhitelistMatcher extends ISplitMatcherBase {
52
56
  matcherType: 'WHITELIST';
53
57
  whitelistMatcherData: IWhitelistMatcherData;
@@ -128,7 +132,7 @@ interface IInListSemverMatcher extends ISplitMatcherBase {
128
132
  matcherType: 'IN_LIST_SEMVER';
129
133
  whitelistMatcherData: IWhitelistMatcherData;
130
134
  }
131
- export declare type ISplitMatcher = IAllKeysMatcher | IInSegmentMatcher | IWhitelistMatcher | IEqualToMatcher | IGreaterThanOrEqualToMatcher | ILessThanOrEqualToMatcher | IBetweenMatcher | IEqualToSetMatcher | IContainsAnyOfSetMatcher | IContainsAllOfSetMatcher | IPartOfSetMatcher | IStartsWithMatcher | IEndsWithMatcher | IContainsStringMatcher | IInSplitTreatmentMatcher | IEqualToBooleanMatcher | IMatchesStringMatcher | IEqualToSemverMatcher | IGreaterThanOrEqualToSemverMatcher | ILessThanOrEqualToSemverMatcher | IBetweenSemverMatcher | IInListSemverMatcher;
135
+ export declare type ISplitMatcher = IAllKeysMatcher | IInSegmentMatcher | IWhitelistMatcher | IEqualToMatcher | IGreaterThanOrEqualToMatcher | ILessThanOrEqualToMatcher | IBetweenMatcher | IEqualToSetMatcher | IContainsAnyOfSetMatcher | IContainsAllOfSetMatcher | IPartOfSetMatcher | IStartsWithMatcher | IEndsWithMatcher | IContainsStringMatcher | IInSplitTreatmentMatcher | IEqualToBooleanMatcher | IMatchesStringMatcher | IEqualToSemverMatcher | IGreaterThanOrEqualToSemverMatcher | ILessThanOrEqualToSemverMatcher | IBetweenSemverMatcher | IInListSemverMatcher | IInLargeSegmentMatcher;
132
136
  /** Split object */
133
137
  export interface ISplitPartition {
134
138
  treatment: string;
@@ -0,0 +1,5 @@
1
+ import { MaybeThenable } from '../../dtos/types';
2
+ import { ISegmentsCacheBase } from '../../storages/types';
3
+ export declare function largeSegmentMatcherContext(largeSegmentName: string, storage: {
4
+ largeSegments?: ISegmentsCacheBase;
5
+ }): (key: string) => MaybeThenable<boolean>;
@@ -35,7 +35,6 @@ export declare const IMPRESSION = 102;
35
35
  export declare const IMPRESSION_QUEUEING = 103;
36
36
  export declare const NEW_SHARED_CLIENT = 104;
37
37
  export declare const NEW_FACTORY = 105;
38
- export declare const POLLING_SMART_PAUSING = 106;
39
38
  export declare const POLLING_START = 107;
40
39
  export declare const POLLING_STOP = 108;
41
40
  export declare const SYNC_SPLITS_FETCH_RETRY = 109;
@@ -115,6 +114,7 @@ export declare const ERROR_SETS_FILTER_EXCLUSIVE = 328;
115
114
  export declare const ENGINE_MATCHER_ERROR = 329;
116
115
  export declare const LOG_PREFIX_SETTINGS = "settings";
117
116
  export declare const LOG_PREFIX_INSTANTIATION = "Factory instantiation";
117
+ export declare const LOG_PREFIX_CLIENT_INSTANTIATION = "Client instantiation";
118
118
  export declare const LOG_PREFIX_ENGINE = "engine";
119
119
  export declare const LOG_PREFIX_ENGINE_COMBINER: string;
120
120
  export declare const LOG_PREFIX_ENGINE_MATCHER: string;
@@ -1,6 +1,6 @@
1
- import { IEventEmitter } from '../types';
1
+ import { IEventEmitter, ISettings } from '../types';
2
2
  import { IReadinessManager, ISplitsEventEmitter } from './types';
3
3
  /**
4
4
  * Factory of readiness manager, which handles the ready / update event propagation.
5
5
  */
6
- export declare function readinessManagerFactory(EventEmitter: new () => IEventEmitter, readyTimeout?: number, splits?: ISplitsEventEmitter): IReadinessManager;
6
+ export declare function readinessManagerFactory(EventEmitter: new () => IEventEmitter, settings: ISettings, splits?: ISplitsEventEmitter): IReadinessManager;
@@ -1,6 +1,5 @@
1
1
  import { ISdkReadinessManager } from './types';
2
- import { IEventEmitter } from '../types';
3
- import { ILogger } from '../logger/types';
2
+ import { IEventEmitter, ISettings } from '../types';
4
3
  /**
5
4
  * SdkReadinessManager factory, which provides the public status API of SDK clients and manager: ready promise, readiness event emitter and constants (SDK_READY, etc).
6
5
  * It also updates logs related warnings and errors.
@@ -8,4 +7,4 @@ import { ILogger } from '../logger/types';
8
7
  * @param readyTimeout time in millis to emit SDK_READY_TIME_OUT event
9
8
  * @param readinessManager optional readinessManager to use. only used internally for `shared` method
10
9
  */
11
- export declare function sdkReadinessManagerFactory(log: ILogger, EventEmitter: new () => IEventEmitter, readyTimeout?: number, readinessManager?: import("./types").IReadinessManager): ISdkReadinessManager;
10
+ export declare function sdkReadinessManagerFactory(EventEmitter: new () => IEventEmitter, settings: ISettings, readinessManager?: import("./types").IReadinessManager): ISdkReadinessManager;
@@ -34,6 +34,7 @@ export interface IReadinessManager {
34
34
  /** Event emitters */
35
35
  splits: ISplitsEventEmitter;
36
36
  segments: ISegmentsEventEmitter;
37
+ largeSegments?: ISegmentsEventEmitter;
37
38
  gate: IReadinessEventEmitter;
38
39
  /** Readiness status */
39
40
  isReady(): boolean;
@@ -45,7 +46,7 @@ export interface IReadinessManager {
45
46
  setDestroyed(): void;
46
47
  destroy(): void;
47
48
  /** for client-side */
48
- shared(readyTimeout?: number): IReadinessManager;
49
+ shared(): IReadinessManager;
49
50
  }
50
51
  /** SDK readiness manager */
51
52
  export interface ISdkReadinessManager {
@@ -57,6 +58,6 @@ export interface ISdkReadinessManager {
57
58
  */
58
59
  incInternalReadyCbCount(): void;
59
60
  /** for client-side */
60
- shared(readyTimeout?: number): ISdkReadinessManager;
61
+ shared(): ISdkReadinessManager;
61
62
  }
62
63
  export {};
@@ -33,6 +33,7 @@ export interface ISplitApi {
33
33
  fetchSplitChanges: IFetchSplitChanges;
34
34
  fetchSegmentChanges: IFetchSegmentChanges;
35
35
  fetchMySegments: IFetchMySegments;
36
+ fetchMyLargeSegments: IFetchMySegments;
36
37
  postEventsBulk: IPostEventsBulk;
37
38
  postUniqueKeysBulkCs: IPostUniqueKeysBulkCs;
38
39
  postUniqueKeysBulkSs: IPostUniqueKeysBulkSs;
@@ -18,7 +18,7 @@ export declare abstract class AbstractSplitsCacheAsync implements ISplitsCacheAs
18
18
  abstract getNamesByFlagSets(flagSets: string[]): Promise<ISet<string>[]>;
19
19
  abstract trafficTypeExists(trafficType: string): Promise<boolean>;
20
20
  abstract clear(): Promise<boolean | void>;
21
- usesSegments(): Promise<boolean>;
21
+ usesMatcher(): Promise<boolean>;
22
22
  /**
23
23
  * Check if the splits information is already stored in cache.
24
24
  * Noop, just keeping the interface. This is used by client-side implementations only.
@@ -17,7 +17,7 @@ export declare abstract class AbstractSplitsCacheSync implements ISplitsCacheSyn
17
17
  getAll(): ISplit[];
18
18
  abstract getSplitNames(): string[];
19
19
  abstract trafficTypeExists(trafficType: string): boolean;
20
- abstract usesSegments(): boolean;
20
+ abstract usesMatcher(matcherType: string): boolean;
21
21
  abstract clear(): void;
22
22
  /**
23
23
  * Check if the splits information is already stored in cache. This data can be preloaded.
@@ -39,6 +39,6 @@ export declare abstract class AbstractSplitsCacheSync implements ISplitsCacheSyn
39
39
  }
40
40
  /**
41
41
  * Given a parsed split, it returns a boolean flagging if its conditions use segments matchers (rules & whitelists).
42
- * This util is intended to simplify the implementation of `splitsCache::usesSegments` method
42
+ * This util is intended to simplify the implementation of `splitsCache::usesMatcher` method
43
43
  */
44
- export declare function usesSegments(split: ISplit): boolean;
44
+ export declare function usesMatcher(split: ISplit, matcherType: string): boolean;
@@ -10,6 +10,7 @@ export declare class KeyBuilder {
10
10
  isSplitKey(key: string): boolean;
11
11
  buildSplitKeyPrefix(): string;
12
12
  buildSplitsWithSegmentCountKey(): string;
13
+ buildSplitsWithLargeSegmentCountKey(): string;
13
14
  buildSegmentNameKey(segmentName: string): string;
14
15
  buildSegmentTillKey(segmentName: string): string;
15
16
  extractKey(builtKey: string): string;
@@ -1,5 +1,10 @@
1
1
  import { KeyBuilder } from './KeyBuilder';
2
- export declare class KeyBuilderCS extends KeyBuilder {
2
+ export interface MySegmentsKeyBuilder {
3
+ buildSegmentNameKey(segmentName: string): string;
4
+ extractSegmentName(builtSegmentKeyName: string): string | undefined;
5
+ extractOldSegmentKey(builtSegmentKeyName: string): string | undefined;
6
+ }
7
+ export declare class KeyBuilderCS extends KeyBuilder implements MySegmentsKeyBuilder {
3
8
  protected readonly regexSplitsCacheKey: RegExp;
4
9
  protected readonly matchingKey: string;
5
10
  constructor(prefix: string, matchingKey: string);
@@ -8,8 +13,8 @@ export declare class KeyBuilderCS extends KeyBuilder {
8
13
  */
9
14
  buildSegmentNameKey(segmentName: string): string;
10
15
  extractSegmentName(builtSegmentKeyName: string): string | undefined;
11
- buildOldSegmentNameKey(segmentName: string): string;
12
16
  extractOldSegmentKey(builtSegmentKeyName: string): string | undefined;
13
17
  buildLastUpdatedKey(): string;
14
18
  isSplitsCacheKey(key: string): boolean;
15
19
  }
20
+ export declare function myLargeSegmentsKeyBuilder(prefix: string, matchingKey: string): MySegmentsKeyBuilder;
@@ -1,10 +1,10 @@
1
1
  import { ILogger } from '../../logger/types';
2
2
  import { AbstractSegmentsCacheSync } from '../AbstractSegmentsCacheSync';
3
- import { KeyBuilderCS } from '../KeyBuilderCS';
3
+ import type { MySegmentsKeyBuilder } from '../KeyBuilderCS';
4
4
  export declare class MySegmentsCacheInLocal extends AbstractSegmentsCacheSync {
5
5
  private readonly keys;
6
6
  private readonly log;
7
- constructor(log: ILogger, keys: KeyBuilderCS);
7
+ constructor(log: ILogger, keys: MySegmentsKeyBuilder);
8
8
  /**
9
9
  * Removes list of segments from localStorage
10
10
  * @NOTE this method is not being used at the moment.
@@ -34,7 +34,7 @@ export declare class SplitsCacheInLocal extends AbstractSplitsCacheSync {
34
34
  getChangeNumber(): number;
35
35
  getSplitNames(): string[];
36
36
  trafficTypeExists(trafficType: string): boolean;
37
- usesSegments(): boolean;
37
+ usesMatcher(matcherType: string): boolean;
38
38
  /**
39
39
  * Check if the splits information is already stored in browser LocalStorage.
40
40
  * In this function we could add more code to check if the data is valid.
@@ -10,7 +10,8 @@ export declare class SplitsCacheInMemory extends AbstractSplitsCacheSync {
10
10
  private splitsCache;
11
11
  private ttCache;
12
12
  private changeNumber;
13
- private splitsWithSegmentsCount;
13
+ private segmentsCount;
14
+ private largeSegmentsCount;
14
15
  private flagSetsCache;
15
16
  constructor(splitFiltersValidation?: ISplitFiltersValidation);
16
17
  clear(): void;
@@ -21,7 +22,7 @@ export declare class SplitsCacheInMemory extends AbstractSplitsCacheSync {
21
22
  getChangeNumber(): number;
22
23
  getSplitNames(): string[];
23
24
  trafficTypeExists(trafficType: string): boolean;
24
- usesSegments(): boolean;
25
+ usesMatcher(matcherType: string): boolean;
25
26
  getNamesByFlagSets(flagSets: string[]): ISet<string>[];
26
27
  private addToFlagSets;
27
28
  private removeFromFlagSets;
@@ -1,4 +1,4 @@
1
- import { ImpressionDataType, EventDataType, StreamingEvent, Method, OperationType, TelemetryUsageStatsPayload, UpdatesFromSSEEnum } from '../../sync/submitters/types';
1
+ import { ImpressionDataType, EventDataType, StreamingEvent, Method, OperationType, TelemetryUsageStatsPayload, UpdatesFromSSEEnum, UpdatesFromSSE } from '../../sync/submitters/types';
2
2
  import { ISegmentsCacheSync, ISplitsCacheSync, IStorageFactoryParams, ITelemetryCacheSync } from '../types';
3
3
  export declare const MAX_LATENCY_BUCKET_COUNT = 23;
4
4
  export declare function newBuckets(): number[];
@@ -10,7 +10,8 @@ export declare function shouldRecordTelemetry({ settings }: IStorageFactoryParam
10
10
  export declare class TelemetryCacheInMemory implements ITelemetryCacheSync {
11
11
  private splits?;
12
12
  private segments?;
13
- constructor(splits?: ISplitsCacheSync | undefined, segments?: ISegmentsCacheSync | undefined);
13
+ private largeSegments?;
14
+ constructor(splits?: ISplitsCacheSync | undefined, segments?: ISegmentsCacheSync | undefined, largeSegments?: ISegmentsCacheSync | undefined);
14
15
  private e;
15
16
  isEmpty(): boolean;
16
17
  clear(): void;
@@ -65,9 +66,6 @@ export declare class TelemetryCacheInMemory implements ITelemetryCacheSync {
65
66
  popLatencies(): Partial<Record<Method, number[]>>;
66
67
  recordLatency(method: Method, latencyMs: number): void;
67
68
  private updatesFromSSE;
68
- popUpdatesFromSSE(): {
69
- sp: number;
70
- ms: number;
71
- };
69
+ popUpdatesFromSSE(): UpdatesFromSSE;
72
70
  recordUpdatesFromSSE(type: UpdatesFromSSEEnum): void;
73
71
  }
@@ -189,7 +189,7 @@ export interface ISplitsCacheBase {
189
189
  getAll(): MaybeThenable<ISplit[]>;
190
190
  getSplitNames(): MaybeThenable<string[]>;
191
191
  trafficTypeExists(trafficType: string): MaybeThenable<boolean>;
192
- usesSegments(): MaybeThenable<boolean>;
192
+ usesMatcher(matcherType: string): MaybeThenable<boolean>;
193
193
  clear(): MaybeThenable<boolean | void>;
194
194
  checkCache(): MaybeThenable<boolean>;
195
195
  killLocally(name: string, defaultTreatment: string, changeNumber: number): MaybeThenable<boolean>;
@@ -205,7 +205,7 @@ export interface ISplitsCacheSync extends ISplitsCacheBase {
205
205
  getAll(): ISplit[];
206
206
  getSplitNames(): string[];
207
207
  trafficTypeExists(trafficType: string): boolean;
208
- usesSegments(): boolean;
208
+ usesMatcher(matcherType: string): boolean;
209
209
  clear(): void;
210
210
  checkCache(): boolean;
211
211
  killLocally(name: string, defaultTreatment: string, changeNumber: number): boolean;
@@ -221,7 +221,7 @@ export interface ISplitsCacheAsync extends ISplitsCacheBase {
221
221
  getAll(): Promise<ISplit[]>;
222
222
  getSplitNames(): Promise<string[]>;
223
223
  trafficTypeExists(trafficType: string): Promise<boolean>;
224
- usesSegments(): Promise<boolean>;
224
+ usesMatcher(matcherType: string): Promise<boolean>;
225
225
  clear(): Promise<boolean | void>;
226
226
  checkCache(): Promise<boolean>;
227
227
  killLocally(name: string, defaultTreatment: string, changeNumber: number): Promise<boolean>;
@@ -388,6 +388,7 @@ export interface IStorageBase<TSplitsCache extends ISplitsCacheBase, TSegmentsCa
388
388
  shared?: (matchingKey: string, onReadyCb: (error?: any) => void) => this;
389
389
  }
390
390
  export interface IStorageSync extends IStorageBase<ISplitsCacheSync, ISegmentsCacheSync, IImpressionsCacheSync, IImpressionCountsCacheSync, IEventsCacheSync, ITelemetryCacheSync, IUniqueKeysCacheSync> {
391
+ largeSegments?: ISegmentsCacheSync;
391
392
  }
392
393
  export interface IStorageAsync extends IStorageBase<ISplitsCacheAsync, ISegmentsCacheAsync, IImpressionsCacheAsync | IImpressionsCacheSync, IImpressionCountsCacheBase, IEventsCacheAsync | IEventsCacheSync, ITelemetryCacheAsync | ITelemetryCacheSync, IUniqueKeysCacheBase> {
393
394
  }
@@ -1,9 +1,8 @@
1
- import { IStorageSync } from '../../../storages/types';
2
- import { IReadinessManager } from '../../../readiness/types';
1
+ import { ISegmentsCacheSync } from '../../../storages/types';
3
2
  import { IMySegmentsSyncTask } from '../types';
4
3
  import { IFetchMySegments } from '../../../services/types';
5
4
  import { ISettings } from '../../../types';
6
5
  /**
7
6
  * Creates a sync task that periodically executes a `mySegmentsUpdater` task
8
7
  */
9
- export declare function mySegmentsSyncTaskFactory(fetchMySegments: IFetchMySegments, storage: IStorageSync, readiness: IReadinessManager, settings: ISettings, matchingKey: string): IMySegmentsSyncTask;
8
+ export declare function mySegmentsSyncTaskFactory(fetchMySegments: IFetchMySegments, mySegmentsCache: ISegmentsCacheSync, notifyUpdate: () => void, settings: ISettings, matchingKey: string, segmentsRefreshRate: number): IMySegmentsSyncTask;
@@ -13,18 +13,25 @@ export declare type MySegmentsData = string[] | {
13
13
  name: string;
14
14
  add: boolean;
15
15
  };
16
- export interface IMySegmentsSyncTask extends ISyncTask<[segmentsData?: MySegmentsData, noCache?: boolean], boolean> {
16
+ export interface IMySegmentsSyncTask extends ISyncTask<[segmentsData?: MySegmentsData, noCache?: boolean, delay?: number], boolean> {
17
17
  }
18
18
  export interface IPollingManager extends ITask {
19
19
  syncAll(): Promise<any>;
20
20
  splitsSyncTask: ISplitsSyncTask;
21
21
  segmentsSyncTask: ISyncTask;
22
+ largeSegmentsSyncTask?: ISyncTask;
22
23
  }
23
24
  /**
24
25
  * PollingManager for client-side with support for multiple clients
25
26
  */
26
27
  export interface IPollingManagerCS extends IPollingManager {
27
- add(matchingKey: string, readiness: IReadinessManager, storage: IStorageSync): IMySegmentsSyncTask;
28
+ add(matchingKey: string, readiness: IReadinessManager, storage: IStorageSync): {
29
+ msSyncTask: IMySegmentsSyncTask;
30
+ mlsSyncTask?: IMySegmentsSyncTask;
31
+ };
28
32
  remove(matchingKey: string): void;
29
- get(matchingKey: string): IMySegmentsSyncTask | undefined;
33
+ get(matchingKey: string): {
34
+ msSyncTask: IMySegmentsSyncTask;
35
+ mlsSyncTask?: IMySegmentsSyncTask;
36
+ } | undefined;
30
37
  }
@@ -1,13 +1,13 @@
1
1
  import { IMySegmentsFetcher } from '../fetchers/types';
2
- import { ISegmentsCacheSync, ISplitsCacheSync } from '../../../storages/types';
3
- import { ISegmentsEventEmitter } from '../../../readiness/types';
2
+ import { ISegmentsCacheSync } from '../../../storages/types';
4
3
  import { ILogger } from '../../../logger/types';
5
- declare type IMySegmentsUpdater = (segmentList?: string[], noCache?: boolean) => Promise<boolean>;
4
+ import { MySegmentsData } from '../types';
5
+ declare type IMySegmentsUpdater = (segmentList?: MySegmentsData, noCache?: boolean) => Promise<boolean>;
6
6
  /**
7
7
  * factory of MySegments updater, a task that:
8
8
  * - fetches mySegments using `mySegmentsFetcher`
9
9
  * - updates `mySegmentsCache`
10
10
  * - uses `segmentsEventEmitter` to emit events related to segments data updates
11
11
  */
12
- export declare function mySegmentsUpdaterFactory(log: ILogger, mySegmentsFetcher: IMySegmentsFetcher, splitsCache: ISplitsCacheSync, mySegmentsCache: ISegmentsCacheSync, segmentsEventEmitter: ISegmentsEventEmitter, requestTimeoutBeforeReady: number, retriesOnFailureBeforeReady: number, matchingKey: string): IMySegmentsUpdater;
12
+ export declare function mySegmentsUpdaterFactory(log: ILogger, mySegmentsFetcher: IMySegmentsFetcher, mySegmentsCache: ISegmentsCacheSync, notifyUpdate: () => void, requestTimeoutBeforeReady: number, retriesOnFailureBeforeReady: number, matchingKey: string): IMySegmentsUpdater;
13
13
  export {};
@@ -1,5 +1,5 @@
1
1
  import { ControlType } from '../constants';
2
- import { MY_SEGMENTS_UPDATE, MY_SEGMENTS_UPDATE_V2, SEGMENT_UPDATE, SPLIT_UPDATE, SPLIT_KILL, CONTROL, OCCUPANCY } from '../types';
2
+ import { MY_SEGMENTS_UPDATE, MY_SEGMENTS_UPDATE_V2, SEGMENT_UPDATE, SPLIT_UPDATE, SPLIT_KILL, CONTROL, OCCUPANCY, MY_LARGE_SEGMENTS_UPDATE } from '../types';
3
3
  export interface IMySegmentsUpdateData {
4
4
  type: MY_SEGMENTS_UPDATE;
5
5
  changeNumber: number;
@@ -29,6 +29,17 @@ export interface IMySegmentsUpdateV2Data {
29
29
  d: string;
30
30
  u: UpdateStrategy;
31
31
  }
32
+ export interface IMyLargeSegmentsUpdateData {
33
+ type: MY_LARGE_SEGMENTS_UPDATE;
34
+ changeNumber: number;
35
+ largeSegments: string[];
36
+ c: Compression;
37
+ d: string;
38
+ u: UpdateStrategy;
39
+ i?: number;
40
+ h?: number;
41
+ s?: number;
42
+ }
32
43
  export interface ISegmentUpdateData {
33
44
  type: SEGMENT_UPDATE;
34
45
  changeNumber: number;
@@ -57,7 +68,7 @@ export interface IOccupancyData {
57
68
  publishers: number;
58
69
  };
59
70
  }
60
- export declare type INotificationData = IMySegmentsUpdateData | IMySegmentsUpdateV2Data | ISegmentUpdateData | ISplitUpdateData | ISplitKillData | IControlData | IOccupancyData;
71
+ export declare type INotificationData = IMySegmentsUpdateData | IMySegmentsUpdateV2Data | IMyLargeSegmentsUpdateData | ISegmentUpdateData | ISplitUpdateData | ISplitKillData | IControlData | IOccupancyData;
61
72
  export declare type INotificationMessage = {
62
73
  parsedData: INotificationData;
63
74
  channel: string;
@@ -1,7 +1,8 @@
1
1
  import { IMySegmentsSyncTask } from '../../polling/types';
2
2
  import { IUpdateWorker } from './types';
3
3
  import { ITelemetryTracker } from '../../../trackers/types';
4
+ import { UpdatesFromSSEEnum } from '../../submitters/types';
4
5
  /**
5
6
  * MySegmentsUpdateWorker factory
6
7
  */
7
- export declare function MySegmentsUpdateWorker(mySegmentsSyncTask: IMySegmentsSyncTask, telemetryTracker: ITelemetryTracker): IUpdateWorker;
8
+ export declare function MySegmentsUpdateWorker(mySegmentsSyncTask: IMySegmentsSyncTask, telemetryTracker: ITelemetryTracker, updateType: UpdatesFromSSEEnum): IUpdateWorker;
@@ -24,6 +24,7 @@ export declare const MY_SEGMENTS_UPDATE_V2 = "MY_SEGMENTS_UPDATE_V2";
24
24
  export declare const SEGMENT_UPDATE = "SEGMENT_UPDATE";
25
25
  export declare const SPLIT_KILL = "SPLIT_KILL";
26
26
  export declare const SPLIT_UPDATE = "SPLIT_UPDATE";
27
+ export declare const MY_LARGE_SEGMENTS_UPDATE = "MY_LARGE_SEGMENTS_UPDATE";
27
28
  export declare const CONTROL = "CONTROL";
28
29
  export declare const OCCUPANCY = "OCCUPANCY";
29
30
  export declare enum ControlType {
@@ -1,6 +1,8 @@
1
1
  import { IPushManager } from './types';
2
2
  import { IPollingManager } from '../polling/types';
3
+ import { IMyLargeSegmentsUpdateData } from './SSEHandler/types';
3
4
  import { ISdkFactoryContextSync } from '../../sdkFactory/types';
5
+ export declare function getDelay(parsedData: IMyLargeSegmentsUpdateData, matchingKey: string): number;
4
6
  /**
5
7
  * PushManager factory:
6
8
  * - for server-side if key is not provided in settings.
@@ -1,4 +1,4 @@
1
- import { IMySegmentsUpdateData, IMySegmentsUpdateV2Data, ISegmentUpdateData, ISplitUpdateData, ISplitKillData } from './SSEHandler/types';
1
+ import { IMySegmentsUpdateData, IMySegmentsUpdateV2Data, ISegmentUpdateData, ISplitUpdateData, ISplitKillData, IMyLargeSegmentsUpdateData } from './SSEHandler/types';
2
2
  import { ITask } from '../types';
3
3
  import { IMySegmentsSyncTask } from '../polling/types';
4
4
  import { IEventEmitter } from '../../types';
@@ -12,10 +12,11 @@ export declare type MY_SEGMENTS_UPDATE_V2 = 'MY_SEGMENTS_UPDATE_V2';
12
12
  export declare type SEGMENT_UPDATE = 'SEGMENT_UPDATE';
13
13
  export declare type SPLIT_KILL = 'SPLIT_KILL';
14
14
  export declare type SPLIT_UPDATE = 'SPLIT_UPDATE';
15
+ export declare type MY_LARGE_SEGMENTS_UPDATE = 'MY_LARGE_SEGMENTS_UPDATE';
15
16
  export declare type CONTROL = 'CONTROL';
16
17
  export declare type OCCUPANCY = 'OCCUPANCY';
17
- export declare type IPushEvent = PUSH_SUBSYSTEM_UP | PUSH_SUBSYSTEM_DOWN | PUSH_NONRETRYABLE_ERROR | PUSH_RETRYABLE_ERROR | MY_SEGMENTS_UPDATE | MY_SEGMENTS_UPDATE_V2 | SEGMENT_UPDATE | SPLIT_UPDATE | SPLIT_KILL | ControlType.STREAMING_RESET;
18
- declare type IParsedData<T extends IPushEvent> = T extends MY_SEGMENTS_UPDATE ? IMySegmentsUpdateData : T extends MY_SEGMENTS_UPDATE_V2 ? IMySegmentsUpdateV2Data : T extends SEGMENT_UPDATE ? ISegmentUpdateData : T extends SPLIT_UPDATE ? ISplitUpdateData : T extends SPLIT_KILL ? ISplitKillData : undefined;
18
+ export declare type IPushEvent = PUSH_SUBSYSTEM_UP | PUSH_SUBSYSTEM_DOWN | PUSH_NONRETRYABLE_ERROR | PUSH_RETRYABLE_ERROR | MY_SEGMENTS_UPDATE | MY_SEGMENTS_UPDATE_V2 | SEGMENT_UPDATE | SPLIT_UPDATE | SPLIT_KILL | MY_LARGE_SEGMENTS_UPDATE | ControlType.STREAMING_RESET;
19
+ declare type IParsedData<T extends IPushEvent> = T extends MY_SEGMENTS_UPDATE ? IMySegmentsUpdateData : T extends MY_SEGMENTS_UPDATE_V2 ? IMySegmentsUpdateV2Data : T extends MY_LARGE_SEGMENTS_UPDATE ? IMyLargeSegmentsUpdateData : T extends SEGMENT_UPDATE ? ISegmentUpdateData : T extends SPLIT_UPDATE ? ISplitUpdateData : T extends SPLIT_KILL ? ISplitKillData : undefined;
19
20
  /**
20
21
  * EventEmitter used as Feedback Loop between the SyncManager and PushManager,
21
22
  * where the latter pushes messages and the former consumes it
@@ -29,7 +30,7 @@ export interface IPushEventEmitter extends IEventEmitter {
29
30
  * PushManager
30
31
  */
31
32
  export interface IPushManager extends ITask, IPushEventEmitter {
32
- add(userKey: string, mySegmentsSyncTask: IMySegmentsSyncTask): void;
33
+ add(userKey: string, mySegmentsSyncTask: IMySegmentsSyncTask, myLargeSegmentsSyncTask?: IMySegmentsSyncTask): void;
33
34
  remove(userKey: string): void;
34
35
  }
35
36
  export {};
@@ -90,7 +90,7 @@ export declare type DROPPED = 1;
90
90
  export declare type DEDUPED = 2;
91
91
  export declare type ImpressionDataType = QUEUED | DROPPED | DEDUPED;
92
92
  export declare type EventDataType = QUEUED | DROPPED;
93
- export declare type UpdatesFromSSEEnum = SPLITS | MY_SEGMENT;
93
+ export declare type UpdatesFromSSEEnum = SPLITS | MY_SEGMENT | MY_LARGE_SEGMENT;
94
94
  export declare type SPLITS = 'sp';
95
95
  export declare type IMPRESSIONS = 'im';
96
96
  export declare type IMPRESSIONS_COUNT = 'ic';
@@ -99,7 +99,8 @@ export declare type TELEMETRY = 'te';
99
99
  export declare type TOKEN = 'to';
100
100
  export declare type SEGMENT = 'se';
101
101
  export declare type MY_SEGMENT = 'ms';
102
- export declare type OperationType = SPLITS | IMPRESSIONS | IMPRESSIONS_COUNT | EVENTS | TELEMETRY | TOKEN | SEGMENT | MY_SEGMENT;
102
+ export declare type MY_LARGE_SEGMENT = 'mls';
103
+ export declare type OperationType = SPLITS | IMPRESSIONS | IMPRESSIONS_COUNT | EVENTS | TELEMETRY | TOKEN | SEGMENT | MY_SEGMENT | MY_LARGE_SEGMENT;
103
104
  export declare type LastSync = Partial<Record<OperationType, number | undefined>>;
104
105
  export declare type HttpErrors = Partial<Record<OperationType, {
105
106
  [statusCode: string]: number;
@@ -136,8 +137,9 @@ export declare type TelemetryUsageStats = {
136
137
  mE?: MethodExceptions;
137
138
  };
138
139
  export declare type UpdatesFromSSE = {
139
- sp: number;
140
+ sp?: number;
140
141
  ms?: number;
142
+ mls?: number;
141
143
  };
142
144
  export declare type TelemetryUsageStatsPayload = TelemetryUsageStats & {
143
145
  lS: LastSync;
@@ -151,6 +153,8 @@ export declare type TelemetryUsageStatsPayload = TelemetryUsageStats & {
151
153
  spC?: number;
152
154
  seC?: number;
153
155
  skC?: number;
156
+ lseC?: number;
157
+ lskC?: number;
154
158
  sL?: number;
155
159
  eQ: number;
156
160
  eD: number;
@@ -173,6 +177,7 @@ export declare type RefreshRates = {
173
177
  sp: number;
174
178
  se?: number;
175
179
  ms?: number;
180
+ mls?: number;
176
181
  im: number;
177
182
  ev: number;
178
183
  te: number;
@@ -193,6 +198,7 @@ export declare type TelemetryConfigStats = {
193
198
  };
194
199
  export declare type TelemetryConfigStatsPayload = TelemetryConfigStats & {
195
200
  sE: boolean;
201
+ lE?: boolean;
196
202
  rR: RefreshRates;
197
203
  uO: UrlOverrides;
198
204
  iQ: number;
package/types/types.d.ts CHANGED
@@ -80,6 +80,7 @@ export interface ISettings {
80
80
  metricsRefreshRate?: number;
81
81
  telemetryRefreshRate: number;
82
82
  segmentsRefreshRate: number;
83
+ largeSegmentsRefreshRate: number;
83
84
  offlineRefreshRate: number;
84
85
  eventsPushRate: number;
85
86
  eventsQueueSize: number;
@@ -90,6 +91,7 @@ export interface ISettings {
90
91
  requestTimeoutBeforeReady: number;
91
92
  retriesOnFailureBeforeReady: number;
92
93
  eventsFirstPushWindow: number;
94
+ waitForLargeSegments: boolean;
93
95
  };
94
96
  readonly storage: IStorageSyncFactory | IStorageAsyncFactory;
95
97
  readonly integrations: Array<{
@@ -113,6 +115,7 @@ export interface ISettings {
113
115
  __splitFiltersValidation: ISplitFiltersValidation;
114
116
  localhostMode?: SplitIO.LocalhostFactory;
115
117
  enabled: boolean;
118
+ largeSegmentsEnabled: boolean;
116
119
  flagSpecVersion: string;
117
120
  };
118
121
  readonly runtime: {
@@ -810,6 +813,13 @@ export declare namespace SplitIO {
810
813
  * @default 10
811
814
  */
812
815
  eventsFirstPushWindow?: number;
816
+ /**
817
+ * Whether the SDK should wait for large segments to be ready before emitting SDK_READY event.
818
+ * It only applies if largeSegmentsEnabled is true.
819
+ * @property {number} waitForLargeSegments
820
+ * @default true
821
+ */
822
+ waitForLargeSegments?: boolean;
813
823
  };
814
824
  /**
815
825
  * SDK scheduler settings.
@@ -854,6 +864,13 @@ export declare namespace SplitIO {
854
864
  * @default 60
855
865
  */
856
866
  segmentsRefreshRate?: number;
867
+ /**
868
+ * The SDK polls Split servers for changes to large segment definitions. This parameter controls this polling period in seconds.
869
+ * It only applies if largeSegmentsEnabled is true.
870
+ * @property {number} largeSegmentsRefreshRate
871
+ * @default 60
872
+ */
873
+ largeSegmentsRefreshRate?: number;
857
874
  /**
858
875
  * The SDK posts the queued events data in bulks. This parameter controls the posting rate in seconds.
859
876
  * @property {number} eventsPushRate
@@ -926,6 +943,14 @@ export declare namespace SplitIO {
926
943
  * @property {Object} urls
927
944
  */
928
945
  urls?: UrlSettings;
946
+ sync?: ISharedSettings['sync'] & {
947
+ /**
948
+ * Enables synchronization of large segments.
949
+ * @property {boolean} largeSegmentsEnabled
950
+ * @default false
951
+ */
952
+ largeSegmentsEnabled?: boolean;
953
+ };
929
954
  }
930
955
  /**
931
956
  * Settings interface for SDK instances created on NodeJS.
@@ -53,6 +53,7 @@ export declare const TELEMETRY = "te";
53
53
  export declare const TOKEN = "to";
54
54
  export declare const SEGMENT = "se";
55
55
  export declare const MY_SEGMENT = "ms";
56
+ export declare const MY_LARGE_SEGMENT = "mls";
56
57
  export declare const TREATMENT = "t";
57
58
  export declare const TREATMENTS = "ts";
58
59
  export declare const TREATMENT_WITH_CONFIG = "tc";
@@ -79,3 +80,5 @@ export declare const DISABLED = 0;
79
80
  export declare const ENABLED = 1;
80
81
  export declare const PAUSED = 2;
81
82
  export declare const FLAG_SPEC_VERSION = "1.1";
83
+ export declare const IN_SEGMENT = "IN_SEGMENT";
84
+ export declare const IN_LARGE_SEGMENT = "IN_LARGE_SEGMENT";
@@ -12,6 +12,7 @@ export declare const base: {
12
12
  scheduler: {
13
13
  featuresRefreshRate: number;
14
14
  segmentsRefreshRate: number;
15
+ largeSegmentsRefreshRate: number;
15
16
  telemetryRefreshRate: number;
16
17
  impressionsRefreshRate: number;
17
18
  offlineRefreshRate: number;
@@ -39,6 +40,7 @@ export declare const base: {
39
40
  localhostMode: undefined;
40
41
  enabled: boolean;
41
42
  flagSpecVersion: string;
43
+ largeSegmentsEnabled: boolean;
42
44
  };
43
45
  log: undefined;
44
46
  };
@@ -28,7 +28,7 @@ export interface ISettingsValidationParams {
28
28
  /** Localhost mode validator (`settings.sync.localhostMode`) */
29
29
  localhost?: (settings: ISettings) => ISettings['sync']['localhostMode'];
30
30
  /** User consent validator (`settings.userConsent`) */
31
- consent: (settings: ISettings) => ISettings['userConsent'];
31
+ consent?: (settings: ISettings) => ISettings['userConsent'];
32
32
  /** Flag spec version validation. Configurable by the JS Synchronizer but not by the SDKs */
33
33
  flagSpec?: (settings: ISettings) => ISettings['sync']['flagSpecVersion'];
34
34
  }