posthog-node 5.0.0-alpha.1 → 5.0.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 (65) hide show
  1. package/CHANGELOG.md +40 -0
  2. package/lib/edge/index.cjs +3567 -0
  3. package/lib/edge/index.cjs.map +1 -0
  4. package/lib/edge/index.mjs +3541 -0
  5. package/lib/edge/index.mjs.map +1 -0
  6. package/lib/index.d.ts +938 -810
  7. package/lib/{index.cjs.js → node/index.cjs} +3241 -3326
  8. package/lib/node/index.cjs.map +1 -0
  9. package/lib/{index.esm.js → node/index.mjs} +3242 -3324
  10. package/lib/node/index.mjs.map +1 -0
  11. package/package.json +33 -6
  12. package/index.ts +0 -3
  13. package/lib/index.cjs.js.map +0 -1
  14. package/lib/index.esm.js.map +0 -1
  15. package/lib/posthog-core/src/eventemitter.d.ts +0 -8
  16. package/lib/posthog-core/src/featureFlagUtils.d.ts +0 -34
  17. package/lib/posthog-core/src/index.d.ts +0 -242
  18. package/lib/posthog-core/src/lz-string.d.ts +0 -8
  19. package/lib/posthog-core/src/storage-memory.d.ts +0 -6
  20. package/lib/posthog-core/src/types.d.ts +0 -422
  21. package/lib/posthog-core/src/utils.d.ts +0 -19
  22. package/lib/posthog-core/src/vendor/uuidv7.d.ts +0 -179
  23. package/lib/posthog-node/index.d.ts +0 -3
  24. package/lib/posthog-node/src/crypto-helpers.d.ts +0 -3
  25. package/lib/posthog-node/src/crypto.d.ts +0 -2
  26. package/lib/posthog-node/src/error-tracking.d.ts +0 -12
  27. package/lib/posthog-node/src/extensions/error-tracking/autocapture.d.ts +0 -3
  28. package/lib/posthog-node/src/extensions/error-tracking/context-lines.d.ts +0 -6
  29. package/lib/posthog-node/src/extensions/error-tracking/error-conversion.d.ts +0 -2
  30. package/lib/posthog-node/src/extensions/error-tracking/reduceable-cache.d.ts +0 -12
  31. package/lib/posthog-node/src/extensions/error-tracking/stack-trace.d.ts +0 -15
  32. package/lib/posthog-node/src/extensions/error-tracking/type-checking.d.ts +0 -7
  33. package/lib/posthog-node/src/extensions/error-tracking/types.d.ts +0 -57
  34. package/lib/posthog-node/src/extensions/express.d.ts +0 -17
  35. package/lib/posthog-node/src/extensions/sentry-integration.d.ts +0 -51
  36. package/lib/posthog-node/src/feature-flags.d.ts +0 -84
  37. package/lib/posthog-node/src/lazy.d.ts +0 -23
  38. package/lib/posthog-node/src/posthog-node.d.ts +0 -91
  39. package/lib/posthog-node/src/types.d.ts +0 -203
  40. package/lib/posthog-node/test/test-utils.d.ts +0 -17
  41. package/src/crypto-helpers.ts +0 -36
  42. package/src/crypto.ts +0 -22
  43. package/src/error-tracking.ts +0 -67
  44. package/src/extensions/error-tracking/autocapture.ts +0 -65
  45. package/src/extensions/error-tracking/context-lines.ts +0 -425
  46. package/src/extensions/error-tracking/error-conversion.ts +0 -262
  47. package/src/extensions/error-tracking/reduceable-cache.ts +0 -39
  48. package/src/extensions/error-tracking/stack-trace.ts +0 -269
  49. package/src/extensions/error-tracking/type-checking.ts +0 -40
  50. package/src/extensions/error-tracking/types.ts +0 -65
  51. package/src/extensions/express.ts +0 -37
  52. package/src/extensions/sentry-integration.ts +0 -196
  53. package/src/feature-flags.ts +0 -863
  54. package/src/lazy.ts +0 -55
  55. package/src/posthog-node.ts +0 -567
  56. package/src/types.ts +0 -231
  57. package/test/crypto.spec.ts +0 -36
  58. package/test/extensions/error-conversion.spec.ts +0 -44
  59. package/test/extensions/sentry-integration.spec.ts +0 -162
  60. package/test/feature-flags.decide.spec.ts +0 -378
  61. package/test/feature-flags.spec.ts +0 -4681
  62. package/test/lazy.spec.ts +0 -71
  63. package/test/posthog-node.spec.ts +0 -1341
  64. package/test/test-utils.ts +0 -106
  65. package/tsconfig.json +0 -7
@@ -1,8 +0,0 @@
1
- export declare class SimpleEventEmitter {
2
- events: {
3
- [key: string]: ((...args: any[]) => void)[];
4
- };
5
- constructor();
6
- on(event: string, listener: (...args: any[]) => void): () => void;
7
- emit(event: string, payload: any): void;
8
- }
@@ -1,34 +0,0 @@
1
- import { FeatureFlagDetail, FeatureFlagValue, PostHogDecideResponse, PostHogV3DecideResponse, PostHogV4DecideResponse, PartialWithRequired, PostHogFeatureFlagsResponse } from './types';
2
- export declare const normalizeDecideResponse: (decideResponse: PartialWithRequired<PostHogV4DecideResponse, 'flags'> | PartialWithRequired<PostHogV3DecideResponse, 'featureFlags' | 'featureFlagPayloads'>) => PostHogFeatureFlagsResponse;
3
- /**
4
- * Get the flag values from the flags v4 response.
5
- * @param flags - The flags
6
- * @returns The flag values
7
- */
8
- export declare const getFlagValuesFromFlags: (flags: PostHogDecideResponse['flags']) => PostHogDecideResponse['featureFlags'];
9
- /**
10
- * Get the payloads from the flags v4 response.
11
- * @param flags - The flags
12
- * @returns The payloads
13
- */
14
- export declare const getPayloadsFromFlags: (flags: PostHogDecideResponse['flags']) => PostHogDecideResponse['featureFlagPayloads'];
15
- /**
16
- * Get the flag details from the legacy v3 flags and payloads. As such, it will lack the reason, id, version, and description.
17
- * @param decideResponse - The decide response
18
- * @returns The flag details
19
- */
20
- export declare const getFlagDetailsFromFlagsAndPayloads: (decideResponse: PostHogFeatureFlagsResponse) => PostHogDecideResponse['flags'];
21
- export declare const getFeatureFlagValue: (detail: FeatureFlagDetail | undefined) => FeatureFlagValue | undefined;
22
- export declare const parsePayload: (response: any) => any;
23
- /**
24
- * Get the normalized flag details from the flags and payloads.
25
- * This is used to convert things like boostrap and stored feature flags and payloads to the v4 format.
26
- * This helps us ensure backwards compatibility.
27
- * If a key exists in the featureFlagPayloads that is not in the featureFlags, we treat it as a true feature flag.
28
- *
29
- * @param featureFlags - The feature flags
30
- * @param featureFlagPayloads - The feature flag payloads
31
- * @returns The normalized flag details
32
- */
33
- export declare const createDecideResponseFromFlagsAndPayloads: (featureFlags: PostHogV3DecideResponse['featureFlags'], featureFlagPayloads: PostHogV3DecideResponse['featureFlagPayloads']) => PostHogFeatureFlagsResponse;
34
- export declare const updateFlagValue: (flag: FeatureFlagDetail, value: FeatureFlagValue) => FeatureFlagDetail;
@@ -1,242 +0,0 @@
1
- import { PostHogFetchOptions, PostHogFetchResponse, PostHogAutocaptureElement, PostHogDecideResponse, PostHogCoreOptions, PostHogEventProperties, PostHogPersistedProperty, PostHogCaptureOptions, JsonType, PostHogRemoteConfig, FeatureFlagValue, PostHogFeatureFlagDetails, FeatureFlagDetail, SurveyResponse } from './types';
2
- import { RetriableOptions } from './utils';
3
- import { LZString } from './lz-string';
4
- import { SimpleEventEmitter } from './eventemitter';
5
- export * as utils from './utils';
6
- export declare abstract class PostHogCoreStateless {
7
- readonly apiKey: string;
8
- readonly host: string;
9
- readonly flushAt: number;
10
- readonly preloadFeatureFlags: boolean;
11
- readonly disableSurveys: boolean;
12
- private maxBatchSize;
13
- private maxQueueSize;
14
- private flushInterval;
15
- private flushPromise;
16
- private requestTimeout;
17
- private featureFlagsRequestTimeoutMs;
18
- private remoteConfigRequestTimeoutMs;
19
- private captureMode;
20
- private removeDebugCallback?;
21
- private disableGeoip;
22
- private historicalMigration;
23
- protected disabled: boolean;
24
- private defaultOptIn;
25
- private pendingPromises;
26
- protected _events: SimpleEventEmitter;
27
- protected _flushTimer?: any;
28
- protected _retryOptions: RetriableOptions;
29
- protected _initPromise: Promise<void>;
30
- protected _isInitialized: boolean;
31
- protected _remoteConfigResponsePromise?: Promise<PostHogRemoteConfig | undefined>;
32
- abstract fetch(url: string, options: PostHogFetchOptions): Promise<PostHogFetchResponse>;
33
- abstract getLibraryId(): string;
34
- abstract getLibraryVersion(): string;
35
- abstract getCustomUserAgent(): string | void;
36
- abstract getPersistedProperty<T>(key: PostHogPersistedProperty): T | undefined;
37
- abstract setPersistedProperty<T>(key: PostHogPersistedProperty, value: T | null): void;
38
- constructor(apiKey: string, options?: PostHogCoreOptions);
39
- protected logMsgIfDebug(fn: () => void): void;
40
- protected wrap(fn: () => void): void;
41
- protected getCommonEventProperties(): any;
42
- get optedOut(): boolean;
43
- optIn(): Promise<void>;
44
- optOut(): Promise<void>;
45
- on(event: string, cb: (...args: any[]) => void): () => void;
46
- debug(enabled?: boolean): void;
47
- get isDebug(): boolean;
48
- get isDisabled(): boolean;
49
- private buildPayload;
50
- protected addPendingPromise<T>(promise: Promise<T>): Promise<T>;
51
- /***
52
- *** TRACKING
53
- ***/
54
- protected identifyStateless(distinctId: string, properties?: PostHogEventProperties, options?: PostHogCaptureOptions): void;
55
- protected captureStateless(distinctId: string, event: string, properties?: {
56
- [key: string]: any;
57
- }, options?: PostHogCaptureOptions): void;
58
- protected aliasStateless(alias: string, distinctId: string, properties?: {
59
- [key: string]: any;
60
- }, options?: PostHogCaptureOptions): void;
61
- /***
62
- *** GROUPS
63
- ***/
64
- protected groupIdentifyStateless(groupType: string, groupKey: string | number, groupProperties?: PostHogEventProperties, options?: PostHogCaptureOptions, distinctId?: string, eventProperties?: PostHogEventProperties): void;
65
- protected getRemoteConfig(): Promise<PostHogRemoteConfig | undefined>;
66
- /***
67
- *** FEATURE FLAGS
68
- ***/
69
- protected getDecide(distinctId: string, groups?: Record<string, string | number>, personProperties?: Record<string, string>, groupProperties?: Record<string, Record<string, string>>, extraPayload?: Record<string, any>): Promise<PostHogDecideResponse | undefined>;
70
- protected getFeatureFlagStateless(key: string, distinctId: string, groups?: Record<string, string>, personProperties?: Record<string, string>, groupProperties?: Record<string, Record<string, string>>, disableGeoip?: boolean): Promise<{
71
- response: FeatureFlagValue | undefined;
72
- requestId: string | undefined;
73
- }>;
74
- protected getFeatureFlagDetailStateless(key: string, distinctId: string, groups?: Record<string, string>, personProperties?: Record<string, string>, groupProperties?: Record<string, Record<string, string>>, disableGeoip?: boolean): Promise<{
75
- response: FeatureFlagDetail | undefined;
76
- requestId: string | undefined;
77
- } | undefined>;
78
- protected getFeatureFlagPayloadStateless(key: string, distinctId: string, groups?: Record<string, string>, personProperties?: Record<string, string>, groupProperties?: Record<string, Record<string, string>>, disableGeoip?: boolean): Promise<JsonType | undefined>;
79
- protected getFeatureFlagPayloadsStateless(distinctId: string, groups?: Record<string, string>, personProperties?: Record<string, string>, groupProperties?: Record<string, Record<string, string>>, disableGeoip?: boolean, flagKeysToEvaluate?: string[]): Promise<PostHogDecideResponse['featureFlagPayloads'] | undefined>;
80
- protected getFeatureFlagsStateless(distinctId: string, groups?: Record<string, string | number>, personProperties?: Record<string, string>, groupProperties?: Record<string, Record<string, string>>, disableGeoip?: boolean, flagKeysToEvaluate?: string[]): Promise<{
81
- flags: PostHogDecideResponse['featureFlags'] | undefined;
82
- payloads: PostHogDecideResponse['featureFlagPayloads'] | undefined;
83
- requestId: PostHogDecideResponse['requestId'] | undefined;
84
- }>;
85
- protected getFeatureFlagsAndPayloadsStateless(distinctId: string, groups?: Record<string, string | number>, personProperties?: Record<string, string>, groupProperties?: Record<string, Record<string, string>>, disableGeoip?: boolean, flagKeysToEvaluate?: string[]): Promise<{
86
- flags: PostHogDecideResponse['featureFlags'] | undefined;
87
- payloads: PostHogDecideResponse['featureFlagPayloads'] | undefined;
88
- requestId: PostHogDecideResponse['requestId'] | undefined;
89
- }>;
90
- protected getFeatureFlagDetailsStateless(distinctId: string, groups?: Record<string, string | number>, personProperties?: Record<string, string>, groupProperties?: Record<string, Record<string, string>>, disableGeoip?: boolean, flagKeysToEvaluate?: string[]): Promise<PostHogFeatureFlagDetails | undefined>;
91
- /***
92
- *** SURVEYS
93
- ***/
94
- getSurveysStateless(): Promise<SurveyResponse['surveys']>;
95
- /***
96
- *** SUPER PROPERTIES
97
- ***/
98
- private _props;
99
- protected get props(): PostHogEventProperties;
100
- protected set props(val: PostHogEventProperties | undefined);
101
- register(properties: {
102
- [key: string]: any;
103
- }): Promise<void>;
104
- unregister(property: string): Promise<void>;
105
- /***
106
- *** QUEUEING AND FLUSHING
107
- ***/
108
- protected enqueue(type: string, _message: any, options?: PostHogCaptureOptions): void;
109
- private clearFlushTimer;
110
- /**
111
- * Helper for flushing the queue in the background
112
- * Avoids unnecessary promise errors
113
- */
114
- private flushBackground;
115
- flush(): Promise<any[]>;
116
- protected getCustomHeaders(): {
117
- [key: string]: string;
118
- };
119
- private _flush;
120
- private fetchWithRetry;
121
- shutdown(shutdownTimeoutMs?: number): Promise<void>;
122
- }
123
- export declare abstract class PostHogCore extends PostHogCoreStateless {
124
- private sendFeatureFlagEvent;
125
- private flagCallReported;
126
- protected _decideResponsePromise?: Promise<PostHogDecideResponse | undefined>;
127
- protected _sessionExpirationTimeSeconds: number;
128
- protected sessionProps: PostHogEventProperties;
129
- constructor(apiKey: string, options?: PostHogCoreOptions);
130
- protected setupBootstrap(options?: Partial<PostHogCoreOptions>): void;
131
- private clearProps;
132
- on(event: string, cb: (...args: any[]) => void): () => void;
133
- reset(propertiesToKeep?: PostHogPersistedProperty[]): void;
134
- protected getCommonEventProperties(): any;
135
- private enrichProperties;
136
- /**
137
- * * @returns {string} The stored session ID for the current session. This may be an empty string if the client is not yet fully initialized.
138
- */
139
- getSessionId(): string;
140
- resetSessionId(): void;
141
- /**
142
- * * @returns {string} The stored anonymous ID. This may be an empty string if the client is not yet fully initialized.
143
- */
144
- getAnonymousId(): string;
145
- /**
146
- * * @returns {string} The stored distinct ID. This may be an empty string if the client is not yet fully initialized.
147
- */
148
- getDistinctId(): string;
149
- registerForSession(properties: {
150
- [key: string]: any;
151
- }): void;
152
- unregisterForSession(property: string): void;
153
- /***
154
- *** TRACKING
155
- ***/
156
- identify(distinctId?: string, properties?: PostHogEventProperties, options?: PostHogCaptureOptions): void;
157
- capture(event: string, properties?: {
158
- [key: string]: any;
159
- }, options?: PostHogCaptureOptions): void;
160
- alias(alias: string): void;
161
- autocapture(eventType: string, elements: PostHogAutocaptureElement[], properties?: PostHogEventProperties, options?: PostHogCaptureOptions): void;
162
- /***
163
- *** GROUPS
164
- ***/
165
- groups(groups: {
166
- [type: string]: string | number;
167
- }): void;
168
- group(groupType: string, groupKey: string | number, groupProperties?: PostHogEventProperties, options?: PostHogCaptureOptions): void;
169
- groupIdentify(groupType: string, groupKey: string | number, groupProperties?: PostHogEventProperties, options?: PostHogCaptureOptions): void;
170
- /***
171
- * PROPERTIES
172
- ***/
173
- setPersonPropertiesForFlags(properties: {
174
- [type: string]: string;
175
- }): void;
176
- resetPersonPropertiesForFlags(): void;
177
- /** @deprecated - Renamed to setPersonPropertiesForFlags */
178
- personProperties(properties: {
179
- [type: string]: string;
180
- }): void;
181
- setGroupPropertiesForFlags(properties: {
182
- [type: string]: Record<string, string>;
183
- }): void;
184
- resetGroupPropertiesForFlags(): void;
185
- /** @deprecated - Renamed to setGroupPropertiesForFlags */
186
- groupProperties(properties: {
187
- [type: string]: Record<string, string>;
188
- }): void;
189
- private remoteConfigAsync;
190
- /***
191
- *** FEATURE FLAGS
192
- ***/
193
- private decideAsync;
194
- private cacheSessionReplay;
195
- private _remoteConfigAsync;
196
- private _decideAsync;
197
- private setKnownFeatureFlagDetails;
198
- private getKnownFeatureFlagDetails;
199
- private getKnownFeatureFlags;
200
- private getKnownFeatureFlagPayloads;
201
- private getBootstrappedFeatureFlagDetails;
202
- private setBootstrappedFeatureFlagDetails;
203
- private getBootstrappedFeatureFlags;
204
- private getBootstrappedFeatureFlagPayloads;
205
- getFeatureFlag(key: string): FeatureFlagValue | undefined;
206
- getFeatureFlagPayload(key: string): JsonType | undefined;
207
- getFeatureFlagPayloads(): PostHogDecideResponse['featureFlagPayloads'] | undefined;
208
- getFeatureFlags(): PostHogDecideResponse['featureFlags'] | undefined;
209
- getFeatureFlagDetails(): PostHogFeatureFlagDetails | undefined;
210
- getFeatureFlagsAndPayloads(): {
211
- flags: PostHogDecideResponse['featureFlags'] | undefined;
212
- payloads: PostHogDecideResponse['featureFlagPayloads'] | undefined;
213
- };
214
- isFeatureEnabled(key: string): boolean | undefined;
215
- reloadFeatureFlags(cb?: (err?: Error, flags?: PostHogDecideResponse['featureFlags']) => void): void;
216
- reloadRemoteConfigAsync(): Promise<PostHogRemoteConfig | undefined>;
217
- reloadFeatureFlagsAsync(sendAnonDistinctId?: boolean): Promise<PostHogDecideResponse['featureFlags'] | undefined>;
218
- onFeatureFlags(cb: (flags: PostHogDecideResponse['featureFlags']) => void): () => void;
219
- onFeatureFlag(key: string, cb: (value: FeatureFlagValue) => void): () => void;
220
- overrideFeatureFlag(flags: PostHogDecideResponse['featureFlags'] | null): Promise<void>;
221
- /***
222
- *** ERROR TRACKING
223
- ***/
224
- captureException(error: unknown, additionalProperties?: {
225
- [key: string]: any;
226
- }): void;
227
- /**
228
- * Capture written user feedback for a LLM trace. Numeric values are converted to strings.
229
- * @param traceId The trace ID to capture feedback for.
230
- * @param userFeedback The feedback to capture.
231
- */
232
- captureTraceFeedback(traceId: string | number, userFeedback: string): void;
233
- /**
234
- * Capture a metric for a LLM trace. Numeric values are converted to strings.
235
- * @param traceId The trace ID to capture the metric for.
236
- * @param metricName The name of the metric to capture.
237
- * @param metricValue The value of the metric to capture.
238
- */
239
- captureTraceMetric(traceId: string | number, metricName: string, metricValue: string | number | boolean): void;
240
- }
241
- export * from './types';
242
- export { LZString };
@@ -1,8 +0,0 @@
1
- export declare const LZString: {
2
- compressToBase64: (input: any) => string;
3
- decompressFromBase64: (input: any) => any;
4
- compress: (uncompressed: any) => any;
5
- _compress: (uncompressed: any, bitsPerChar: any, getCharFromInt: any) => any;
6
- decompress: (compressed: any) => any;
7
- _decompress: (length: any, resetValue: any, getNextValue: any) => any;
8
- };
@@ -1,6 +0,0 @@
1
- import { PostHogPersistedProperty } from './types';
2
- export declare class PostHogMemoryStorage {
3
- private _memoryStorage;
4
- getProperty(key: PostHogPersistedProperty): any | undefined;
5
- setProperty(key: PostHogPersistedProperty, value: any | null): void;
6
- }