@memberjunction/core 2.128.0 → 2.129.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.
- package/dist/__tests__/mocks/TestMetadataProvider.d.ts +4 -2
- package/dist/__tests__/mocks/TestMetadataProvider.d.ts.map +1 -1
- package/dist/__tests__/mocks/TestMetadataProvider.js +9 -3
- package/dist/__tests__/mocks/TestMetadataProvider.js.map +1 -1
- package/dist/generic/RegisterForStartup.d.ts +228 -0
- package/dist/generic/RegisterForStartup.d.ts.map +1 -0
- package/dist/generic/RegisterForStartup.js +233 -0
- package/dist/generic/RegisterForStartup.js.map +1 -0
- package/dist/generic/baseEngine.d.ts +191 -8
- package/dist/generic/baseEngine.d.ts.map +1 -1
- package/dist/generic/baseEngine.js +360 -14
- package/dist/generic/baseEngine.js.map +1 -1
- package/dist/generic/baseEngineRegistry.d.ts +247 -0
- package/dist/generic/baseEngineRegistry.d.ts.map +1 -0
- package/dist/generic/baseEngineRegistry.js +470 -0
- package/dist/generic/baseEngineRegistry.js.map +1 -0
- package/dist/generic/entityInfo.d.ts +50 -0
- package/dist/generic/entityInfo.d.ts.map +1 -1
- package/dist/generic/entityInfo.js +56 -0
- package/dist/generic/entityInfo.js.map +1 -1
- package/dist/generic/graphqlTypeNames.d.ts +90 -0
- package/dist/generic/graphqlTypeNames.d.ts.map +1 -0
- package/dist/generic/graphqlTypeNames.js +119 -0
- package/dist/generic/graphqlTypeNames.js.map +1 -0
- package/dist/generic/interfaces.d.ts +234 -3
- package/dist/generic/interfaces.d.ts.map +1 -1
- package/dist/generic/interfaces.js.map +1 -1
- package/dist/generic/localCacheManager.d.ts +388 -0
- package/dist/generic/localCacheManager.d.ts.map +1 -0
- package/dist/generic/localCacheManager.js +856 -0
- package/dist/generic/localCacheManager.js.map +1 -0
- package/dist/generic/providerBase.d.ts +227 -13
- package/dist/generic/providerBase.d.ts.map +1 -1
- package/dist/generic/providerBase.js +751 -6
- package/dist/generic/providerBase.js.map +1 -1
- package/dist/generic/queryInfo.d.ts +18 -0
- package/dist/generic/queryInfo.d.ts.map +1 -1
- package/dist/generic/queryInfo.js +18 -0
- package/dist/generic/queryInfo.js.map +1 -1
- package/dist/generic/queryInfoInterfaces.d.ts +17 -0
- package/dist/generic/queryInfoInterfaces.d.ts.map +1 -1
- package/dist/generic/runQuery.d.ts +30 -0
- package/dist/generic/runQuery.d.ts.map +1 -1
- package/dist/generic/runQuery.js +13 -0
- package/dist/generic/runQuery.js.map +1 -1
- package/dist/generic/telemetryManager.d.ts +628 -0
- package/dist/generic/telemetryManager.d.ts.map +1 -0
- package/dist/generic/telemetryManager.js +1011 -0
- package/dist/generic/telemetryManager.js.map +1 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +5 -0
- package/dist/index.js.map +1 -1
- package/dist/views/runView.d.ts +25 -0
- package/dist/views/runView.d.ts.map +1 -1
- package/dist/views/runView.js +4 -5
- package/dist/views/runView.js.map +1 -1
- package/package.json +2 -2
|
@@ -0,0 +1,247 @@
|
|
|
1
|
+
import { BaseSingleton } from '@memberjunction/global';
|
|
2
|
+
/**
|
|
3
|
+
* Information about a registered engine instance
|
|
4
|
+
*/
|
|
5
|
+
export interface EngineRegistrationInfo {
|
|
6
|
+
/**
|
|
7
|
+
* The constructor/class name of the engine
|
|
8
|
+
*/
|
|
9
|
+
className: string;
|
|
10
|
+
/**
|
|
11
|
+
* Reference to the engine instance
|
|
12
|
+
*/
|
|
13
|
+
instance: unknown;
|
|
14
|
+
/**
|
|
15
|
+
* When the engine was registered
|
|
16
|
+
*/
|
|
17
|
+
registeredAt: Date;
|
|
18
|
+
/**
|
|
19
|
+
* When the engine was last loaded/configured
|
|
20
|
+
*/
|
|
21
|
+
lastLoadedAt: Date | null;
|
|
22
|
+
/**
|
|
23
|
+
* Whether the engine is currently loaded
|
|
24
|
+
*/
|
|
25
|
+
isLoaded: boolean;
|
|
26
|
+
/**
|
|
27
|
+
* Estimated memory usage in bytes (if calculable)
|
|
28
|
+
*/
|
|
29
|
+
estimatedMemoryBytes: number;
|
|
30
|
+
/**
|
|
31
|
+
* Number of data items loaded in the engine
|
|
32
|
+
*/
|
|
33
|
+
itemCount: number;
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Memory statistics for all registered engines
|
|
37
|
+
*/
|
|
38
|
+
export interface EngineMemoryStats {
|
|
39
|
+
/**
|
|
40
|
+
* Total number of registered engines
|
|
41
|
+
*/
|
|
42
|
+
totalEngines: number;
|
|
43
|
+
/**
|
|
44
|
+
* Number of engines that are currently loaded
|
|
45
|
+
*/
|
|
46
|
+
loadedEngines: number;
|
|
47
|
+
/**
|
|
48
|
+
* Total estimated memory across all engines
|
|
49
|
+
*/
|
|
50
|
+
totalEstimatedMemoryBytes: number;
|
|
51
|
+
/**
|
|
52
|
+
* Per-engine breakdown
|
|
53
|
+
*/
|
|
54
|
+
engineStats: EngineRegistrationInfo[];
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* BaseEngineRegistry is a central registry for tracking all BaseEngine instances.
|
|
58
|
+
*
|
|
59
|
+
* It provides:
|
|
60
|
+
* - Registration and tracking of engine singletons
|
|
61
|
+
* - Memory usage estimation across all engines
|
|
62
|
+
* - Cross-engine data sharing coordination
|
|
63
|
+
* - Bulk operations (refresh all, invalidate all)
|
|
64
|
+
*
|
|
65
|
+
* @example
|
|
66
|
+
* ```typescript
|
|
67
|
+
* // Register an engine (typically done automatically by BaseEngine)
|
|
68
|
+
* BaseEngineRegistry.Instance.RegisterEngine(MyEngine.Instance);
|
|
69
|
+
*
|
|
70
|
+
* // Get memory stats
|
|
71
|
+
* const stats = BaseEngineRegistry.Instance.GetMemoryStats();
|
|
72
|
+
* console.log(`Total engines: ${stats.totalEngines}`);
|
|
73
|
+
* console.log(`Total memory: ${(stats.totalEstimatedMemoryBytes / 1024 / 1024).toFixed(2)} MB`);
|
|
74
|
+
* ```
|
|
75
|
+
*/
|
|
76
|
+
export declare class BaseEngineRegistry extends BaseSingleton<BaseEngineRegistry> {
|
|
77
|
+
private _engines;
|
|
78
|
+
/**
|
|
79
|
+
* Cache of estimated bytes per row for each entity type.
|
|
80
|
+
* This avoids re-sampling the same entity type multiple times during a session.
|
|
81
|
+
*/
|
|
82
|
+
private _entitySizeCache;
|
|
83
|
+
/**
|
|
84
|
+
* Tracks which engines have loaded which entities.
|
|
85
|
+
* Key: entity name, Value: Set of engine class names
|
|
86
|
+
*/
|
|
87
|
+
private _entityLoadTracking;
|
|
88
|
+
/**
|
|
89
|
+
* Tracks which engine instances have already recorded their entity loads.
|
|
90
|
+
* Uses WeakSet so engine instances can be garbage collected when no longer in use.
|
|
91
|
+
* This prevents false positive warnings when a subclass and base class share the same singleton.
|
|
92
|
+
*/
|
|
93
|
+
private _recordedEngineInstances;
|
|
94
|
+
/**
|
|
95
|
+
* Returns the singleton instance of BaseEngineRegistry
|
|
96
|
+
*/
|
|
97
|
+
static get Instance(): BaseEngineRegistry;
|
|
98
|
+
protected constructor();
|
|
99
|
+
/**
|
|
100
|
+
* Returns the entity load tracking data as a Map suitable for TelemetryAnalyzerContext.
|
|
101
|
+
* Key: entity name, Value: array of engine class names that have loaded this entity.
|
|
102
|
+
*/
|
|
103
|
+
GetEntityLoadTrackingMap(): Map<string, string[]>;
|
|
104
|
+
/**
|
|
105
|
+
* Register an engine instance with the registry.
|
|
106
|
+
* This is typically called automatically by BaseEngine during Config().
|
|
107
|
+
*
|
|
108
|
+
* @param engine - The engine instance to register
|
|
109
|
+
* @param className - Optional class name override (uses constructor name by default)
|
|
110
|
+
*/
|
|
111
|
+
RegisterEngine(engine: unknown, className?: string): void;
|
|
112
|
+
/**
|
|
113
|
+
* Unregister an engine from the registry
|
|
114
|
+
*
|
|
115
|
+
* @param engine - The engine instance to unregister
|
|
116
|
+
*/
|
|
117
|
+
UnregisterEngine(engine: unknown): void;
|
|
118
|
+
/**
|
|
119
|
+
* Get a registered engine by class name
|
|
120
|
+
*
|
|
121
|
+
* @param className - The class name of the engine
|
|
122
|
+
* @returns The engine instance or null if not found
|
|
123
|
+
*/
|
|
124
|
+
GetEngine<T>(className: string): T | null;
|
|
125
|
+
/**
|
|
126
|
+
* Get all registered engines
|
|
127
|
+
*
|
|
128
|
+
* @returns Array of all registered engine instances
|
|
129
|
+
*/
|
|
130
|
+
GetAllEngines(): unknown[];
|
|
131
|
+
/**
|
|
132
|
+
* Get registration info for a specific engine
|
|
133
|
+
*
|
|
134
|
+
* @param className - The class name of the engine
|
|
135
|
+
* @returns The registration info or null if not found
|
|
136
|
+
*/
|
|
137
|
+
GetEngineInfo(className: string): EngineRegistrationInfo | null;
|
|
138
|
+
/**
|
|
139
|
+
* Get memory statistics for all registered engines
|
|
140
|
+
*
|
|
141
|
+
* @returns Memory statistics object
|
|
142
|
+
*/
|
|
143
|
+
GetMemoryStats(): EngineMemoryStats;
|
|
144
|
+
/**
|
|
145
|
+
* Refresh all loaded engines
|
|
146
|
+
*
|
|
147
|
+
* @returns Number of engines refreshed
|
|
148
|
+
*/
|
|
149
|
+
RefreshAllEngines(): Promise<number>;
|
|
150
|
+
/**
|
|
151
|
+
* Notify the registry that an engine has been loaded/configured
|
|
152
|
+
*
|
|
153
|
+
* @param engine - The engine that was loaded
|
|
154
|
+
*/
|
|
155
|
+
NotifyEngineLoaded(engine: unknown): void;
|
|
156
|
+
/**
|
|
157
|
+
* Get a list of all engine class names
|
|
158
|
+
*/
|
|
159
|
+
GetEngineNames(): string[];
|
|
160
|
+
/**
|
|
161
|
+
* Check if an engine is registered
|
|
162
|
+
*/
|
|
163
|
+
IsRegistered(className: string): boolean;
|
|
164
|
+
/**
|
|
165
|
+
* Clear all registrations (use with caution, primarily for testing)
|
|
166
|
+
*/
|
|
167
|
+
Reset(): void;
|
|
168
|
+
/**
|
|
169
|
+
* Check if an engine is loaded by looking for a 'Loaded' property
|
|
170
|
+
*/
|
|
171
|
+
private CheckEngineLoaded;
|
|
172
|
+
/**
|
|
173
|
+
* Check if an engine has a RefreshAllItems method
|
|
174
|
+
*/
|
|
175
|
+
private HasRefreshMethod;
|
|
176
|
+
/**
|
|
177
|
+
* Estimate memory usage of an engine by examining its data properties
|
|
178
|
+
*/
|
|
179
|
+
private EstimateEngineMemory;
|
|
180
|
+
/**
|
|
181
|
+
* Count the number of data items in an engine
|
|
182
|
+
*/
|
|
183
|
+
private CountEngineItems;
|
|
184
|
+
/**
|
|
185
|
+
* Default bytes per row when we can't sample (fallback)
|
|
186
|
+
*/
|
|
187
|
+
private static readonly DEFAULT_BYTES_PER_ROW;
|
|
188
|
+
/**
|
|
189
|
+
* Estimate the size of an array in bytes by sampling the first row.
|
|
190
|
+
* Uses a cache to avoid re-sampling the same entity type multiple times.
|
|
191
|
+
*/
|
|
192
|
+
private EstimateArraySize;
|
|
193
|
+
/**
|
|
194
|
+
* Get the estimated bytes per row for an item, using cache when possible.
|
|
195
|
+
*/
|
|
196
|
+
private GetBytesPerRow;
|
|
197
|
+
/**
|
|
198
|
+
* Sample a single item to estimate its size in bytes.
|
|
199
|
+
* For BaseEntity objects, uses GetAll() to get plain field values.
|
|
200
|
+
*/
|
|
201
|
+
private SampleItemSize;
|
|
202
|
+
/**
|
|
203
|
+
* Estimate the size of a single value in bytes.
|
|
204
|
+
*/
|
|
205
|
+
private EstimateValueSize;
|
|
206
|
+
/**
|
|
207
|
+
* Clear the entity size cache (useful if schema changes)
|
|
208
|
+
*/
|
|
209
|
+
ClearSizeCache(): void;
|
|
210
|
+
/**
|
|
211
|
+
* Records that an engine has loaded a specific entity.
|
|
212
|
+
* If another engine has already loaded this entity, a warning is queued.
|
|
213
|
+
*
|
|
214
|
+
* @param engineClassName - The class name of the engine loading the entity
|
|
215
|
+
* @param entityName - The name of the entity being loaded
|
|
216
|
+
*/
|
|
217
|
+
RecordEntityLoad(engineClassName: string, entityName: string): void;
|
|
218
|
+
/**
|
|
219
|
+
* Records that an engine has loaded multiple entities.
|
|
220
|
+
* Convenience method for batch recording.
|
|
221
|
+
* Uses instance identity to prevent false positives when a subclass and base class
|
|
222
|
+
* share the same singleton (e.g., AIEngine extends AIEngineBase).
|
|
223
|
+
*
|
|
224
|
+
* @param engine - The engine instance that loaded the entities
|
|
225
|
+
* @param entityNames - Array of entity names being loaded
|
|
226
|
+
*/
|
|
227
|
+
RecordEntityLoads(engine: object, entityNames: string[]): void;
|
|
228
|
+
/**
|
|
229
|
+
* Gets a list of engines that have loaded a specific entity.
|
|
230
|
+
*
|
|
231
|
+
* @param entityName - The name of the entity
|
|
232
|
+
* @returns Array of engine class names that have loaded this entity
|
|
233
|
+
*/
|
|
234
|
+
GetEnginesLoadingEntity(entityName: string): string[];
|
|
235
|
+
/**
|
|
236
|
+
* Gets all entities that have been loaded by multiple engines.
|
|
237
|
+
*
|
|
238
|
+
* @returns Map of entity name to array of engine class names
|
|
239
|
+
*/
|
|
240
|
+
GetRedundantlyLoadedEntities(): Map<string, string[]>;
|
|
241
|
+
/**
|
|
242
|
+
* Clears entity load tracking data.
|
|
243
|
+
* Useful for testing or when engines are being reconfigured.
|
|
244
|
+
*/
|
|
245
|
+
ClearEntityLoadTracking(): void;
|
|
246
|
+
}
|
|
247
|
+
//# sourceMappingURL=baseEngineRegistry.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"baseEngineRegistry.d.ts","sourceRoot":"","sources":["../../src/generic/baseEngineRegistry.ts"],"names":[],"mappings":"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"}
|