-
Notifications
You must be signed in to change notification settings - Fork 7
Expand file tree
/
Copy pathfromObjectSyncTask.ts
More file actions
97 lines (89 loc) · 3.02 KB
/
fromObjectSyncTask.ts
File metadata and controls
97 lines (89 loc) · 3.02 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
import { forOwn } from '../../../utils/lang';
import { IReadinessManager } from '../../../readiness/types';
import { IStorageSync } from '../../../storages/types';
import { ISplitsParser } from '../splitsParser/types';
import { ISplit, ISplitPartial } from '../../../dtos/types';
import { syncTaskFactory } from '../../syncTask';
import { ISyncTask } from '../../types';
import { ISettings } from '../../../types';
import { CONTROL } from '../../../utils/constants';
import { SDK_SPLITS_ARRIVED, SDK_SEGMENTS_ARRIVED, SDK_SPLITS_CACHE_LOADED } from '../../../readiness/constants';
import { SYNC_OFFLINE_DATA, ERROR_SYNC_OFFLINE_LOADING } from '../../../logger/constants';
/**
* Offline equivalent of `splitChangesUpdaterFactory`
*/
export function fromObjectUpdaterFactory(
splitsParser: ISplitsParser,
storage: Pick<IStorageSync, 'splits' | 'validateCache'>,
readiness: IReadinessManager,
settings: ISettings,
): () => Promise<boolean> {
const log = settings.log, splitsCache = storage.splits;
let startingUp = true;
return function objectUpdater() {
const splits: ISplit[] = [];
let loadError = null;
let splitsMock: false | Record<string, ISplitPartial> = {};
try {
splitsMock = splitsParser(settings);
} catch (err) {
loadError = err;
log.error(ERROR_SYNC_OFFLINE_LOADING, [err]);
}
if (!loadError && splitsMock) {
log.debug(SYNC_OFFLINE_DATA, [JSON.stringify(splitsMock)]);
forOwn(splitsMock, (val, name) => {
// @ts-ignore Split changeNumber and seed is undefined in localhost mode
splits.push({
name,
status: 'ACTIVE',
killed: false,
trafficAllocation: 100,
defaultTreatment: CONTROL,
conditions: val.conditions || [],
configurations: val.configurations,
trafficTypeName: val.trafficTypeName
});
});
return Promise.all([
splitsCache.clear(), // required to sync removed splits from mock
splitsCache.update(splits, [], Date.now())
]).then(() => {
readiness.splits.emit(SDK_SPLITS_ARRIVED);
if (startingUp) {
startingUp = false;
Promise.resolve(storage.validateCache ? storage.validateCache() : false).then((isCacheLoaded) => {
// Emits SDK_READY_FROM_CACHE
if (isCacheLoaded) readiness.splits.emit(SDK_SPLITS_CACHE_LOADED);
// Emits SDK_READY
readiness.segments.emit(SDK_SEGMENTS_ARRIVED);
});
}
return true;
});
} else {
return Promise.resolve(true);
}
};
}
/**
* PollingManager in Offline mode
*/
export function fromObjectSyncTaskFactory(
splitsParser: ISplitsParser,
storage: Pick<IStorageSync, 'splits' | 'validateCache'>,
readiness: IReadinessManager,
settings: ISettings
): ISyncTask<[], boolean> {
return syncTaskFactory(
settings.log,
fromObjectUpdaterFactory(
splitsParser,
storage,
readiness,
settings,
),
settings.scheduler.offlineRefreshRate,
'offlineUpdater',
);
}