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