@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.
Files changed (58) hide show
  1. package/dist/__tests__/mocks/TestMetadataProvider.d.ts +4 -2
  2. package/dist/__tests__/mocks/TestMetadataProvider.d.ts.map +1 -1
  3. package/dist/__tests__/mocks/TestMetadataProvider.js +9 -3
  4. package/dist/__tests__/mocks/TestMetadataProvider.js.map +1 -1
  5. package/dist/generic/RegisterForStartup.d.ts +228 -0
  6. package/dist/generic/RegisterForStartup.d.ts.map +1 -0
  7. package/dist/generic/RegisterForStartup.js +233 -0
  8. package/dist/generic/RegisterForStartup.js.map +1 -0
  9. package/dist/generic/baseEngine.d.ts +191 -8
  10. package/dist/generic/baseEngine.d.ts.map +1 -1
  11. package/dist/generic/baseEngine.js +360 -14
  12. package/dist/generic/baseEngine.js.map +1 -1
  13. package/dist/generic/baseEngineRegistry.d.ts +247 -0
  14. package/dist/generic/baseEngineRegistry.d.ts.map +1 -0
  15. package/dist/generic/baseEngineRegistry.js +470 -0
  16. package/dist/generic/baseEngineRegistry.js.map +1 -0
  17. package/dist/generic/entityInfo.d.ts +50 -0
  18. package/dist/generic/entityInfo.d.ts.map +1 -1
  19. package/dist/generic/entityInfo.js +56 -0
  20. package/dist/generic/entityInfo.js.map +1 -1
  21. package/dist/generic/graphqlTypeNames.d.ts +90 -0
  22. package/dist/generic/graphqlTypeNames.d.ts.map +1 -0
  23. package/dist/generic/graphqlTypeNames.js +119 -0
  24. package/dist/generic/graphqlTypeNames.js.map +1 -0
  25. package/dist/generic/interfaces.d.ts +234 -3
  26. package/dist/generic/interfaces.d.ts.map +1 -1
  27. package/dist/generic/interfaces.js.map +1 -1
  28. package/dist/generic/localCacheManager.d.ts +388 -0
  29. package/dist/generic/localCacheManager.d.ts.map +1 -0
  30. package/dist/generic/localCacheManager.js +856 -0
  31. package/dist/generic/localCacheManager.js.map +1 -0
  32. package/dist/generic/providerBase.d.ts +227 -13
  33. package/dist/generic/providerBase.d.ts.map +1 -1
  34. package/dist/generic/providerBase.js +751 -6
  35. package/dist/generic/providerBase.js.map +1 -1
  36. package/dist/generic/queryInfo.d.ts +18 -0
  37. package/dist/generic/queryInfo.d.ts.map +1 -1
  38. package/dist/generic/queryInfo.js +18 -0
  39. package/dist/generic/queryInfo.js.map +1 -1
  40. package/dist/generic/queryInfoInterfaces.d.ts +17 -0
  41. package/dist/generic/queryInfoInterfaces.d.ts.map +1 -1
  42. package/dist/generic/runQuery.d.ts +30 -0
  43. package/dist/generic/runQuery.d.ts.map +1 -1
  44. package/dist/generic/runQuery.js +13 -0
  45. package/dist/generic/runQuery.js.map +1 -1
  46. package/dist/generic/telemetryManager.d.ts +628 -0
  47. package/dist/generic/telemetryManager.d.ts.map +1 -0
  48. package/dist/generic/telemetryManager.js +1011 -0
  49. package/dist/generic/telemetryManager.js.map +1 -0
  50. package/dist/index.d.ts +5 -0
  51. package/dist/index.d.ts.map +1 -1
  52. package/dist/index.js +5 -0
  53. package/dist/index.js.map +1 -1
  54. package/dist/views/runView.d.ts +25 -0
  55. package/dist/views/runView.d.ts.map +1 -1
  56. package/dist/views/runView.js +4 -5
  57. package/dist/views/runView.js.map +1 -1
  58. 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":"AAAA,OAAO,EAAE,aAAa,EAAwC,MAAM,wBAAwB,CAAC;AAI7F;;GAEG;AACH,MAAM,WAAW,sBAAsB;IACnC;;OAEG;IACH,SAAS,EAAE,MAAM,CAAC;IAClB;;OAEG;IACH,QAAQ,EAAE,OAAO,CAAC;IAClB;;OAEG;IACH,YAAY,EAAE,IAAI,CAAC;IACnB;;OAEG;IACH,YAAY,EAAE,IAAI,GAAG,IAAI,CAAC;IAC1B;;OAEG;IACH,QAAQ,EAAE,OAAO,CAAC;IAClB;;OAEG;IACH,oBAAoB,EAAE,MAAM,CAAC;IAC7B;;OAEG;IACH,SAAS,EAAE,MAAM,CAAC;CACrB;AAED;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAC9B;;OAEG;IACH,YAAY,EAAE,MAAM,CAAC;IACrB;;OAEG;IACH,aAAa,EAAE,MAAM,CAAC;IACtB;;OAEG;IACH,yBAAyB,EAAE,MAAM,CAAC;IAClC;;OAEG;IACH,WAAW,EAAE,sBAAsB,EAAE,CAAC;CACzC;AAED;;;;;;;;;;;;;;;;;;;GAmBG;AACH,qBAAa,kBAAmB,SAAQ,aAAa,CAAC,kBAAkB,CAAC;IACrE,OAAO,CAAC,QAAQ,CAAkD;IAElE;;;OAGG;IACH,OAAO,CAAC,gBAAgB,CAAkC;IAE1D;;;OAGG;IACH,OAAO,CAAC,mBAAmB,CAAuC;IAElE;;;;OAIG;IACH,OAAO,CAAC,wBAAwB,CAAkC;IAElE;;OAEG;IACH,WAAkB,QAAQ,IAAI,kBAAkB,CAE/C;IAED,SAAS;IAYT;;;OAGG;IACI,wBAAwB,IAAI,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC;IAQxD;;;;;;OAMG;IACI,cAAc,CAAC,MAAM,EAAE,OAAO,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI;IAyBhE;;;;OAIG;IACI,gBAAgB,CAAC,MAAM,EAAE,OAAO,GAAG,IAAI;IAK9C;;;;;OAKG;IACI,SAAS,CAAC,CAAC,EAAE,SAAS,EAAE,MAAM,GAAG,CAAC,GAAG,IAAI;IAKhD;;;;OAIG;IACI,aAAa,IAAI,OAAO,EAAE;IAIjC;;;;;OAKG;IACI,aAAa,CAAC,SAAS,EAAE,MAAM,GAAG,sBAAsB,GAAG,IAAI;IAItE;;;;OAIG;IACI,cAAc,IAAI,iBAAiB;IAkB1C;;;;OAIG;IACU,iBAAiB,IAAI,OAAO,CAAC,MAAM,CAAC;IAoBjD;;;;OAIG;IACI,kBAAkB,CAAC,MAAM,EAAE,OAAO,GAAG,IAAI;IAchD;;OAEG;IACI,cAAc,IAAI,MAAM,EAAE;IAIjC;;OAEG;IACI,YAAY,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO;IAI/C;;OAEG;IACI,KAAK,IAAI,IAAI;IAIpB;;OAEG;IACH,OAAO,CAAC,iBAAiB;IAOzB;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAOxB;;OAEG;IACH,OAAO,CAAC,oBAAoB;IAmC5B;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAqBxB;;OAEG;IACH,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,qBAAqB,CAAO;IAEpD;;;OAGG;IACH,OAAO,CAAC,iBAAiB;IAQzB;;OAEG;IACH,OAAO,CAAC,cAAc;IA2BtB;;;OAGG;IACH,OAAO,CAAC,cAAc;IA8BtB;;OAEG;IACH,OAAO,CAAC,iBAAiB;IAuBzB;;OAEG;IACI,cAAc,IAAI,IAAI;IAQ7B;;;;;;OAMG;IACI,gBAAgB,CAAC,eAAe,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,IAAI;IAiB1E;;;;;;;;OAQG;IACI,iBAAiB,CAAC,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,GAAG,IAAI;IAerE;;;;;OAKG;IACI,uBAAuB,CAAC,UAAU,EAAE,MAAM,GAAG,MAAM,EAAE;IAK5D;;;;OAIG;IACI,4BAA4B,IAAI,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC;IAU5D;;;OAGG;IACI,uBAAuB,IAAI,IAAI;CAGzC"}