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