@statsig/client-core 0.0.1-beta.26 → 0.0.1-beta.28

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@statsig/client-core",
3
- "version": "0.0.1-beta.26",
3
+ "version": "0.0.1-beta.28",
4
4
  "dependencies": {},
5
5
  "type": "commonjs",
6
6
  "main": "./src/index.js",
package/src/SessionID.js CHANGED
@@ -30,7 +30,6 @@ exports.SessionID = {
30
30
  var _a;
31
31
  let session = SESSION_ID_MAP[sdkKey];
32
32
  const now = Date.now();
33
- let sessionChanged = false;
34
33
  if (session == null) {
35
34
  let tempSession = yield _loadFromStorage(sdkKey);
36
35
  if (tempSession == null) {
@@ -39,7 +38,6 @@ exports.SessionID = {
39
38
  startTime: now,
40
39
  lastUpdate: now,
41
40
  };
42
- sessionChanged = true;
43
41
  }
44
42
  session = tempSession;
45
43
  SESSION_ID_MAP[sdkKey] = session;
@@ -55,14 +53,11 @@ exports.SessionID = {
55
53
  now - session.lastUpdate > MAX_SESSION_IDLE_TIME) {
56
54
  session.sessionID = (0, UUID_1.getUUID)();
57
55
  session.startTime = now;
58
- sessionChanged = true;
59
56
  }
60
57
  session.lastUpdate = now;
61
58
  _persistToStorage(session, sdkKey);
62
59
  sessionState.idleTimeoutID = exports.SessionID._resetTimeout(sessionState, sessionState.idleTimeoutID, MAX_SESSION_IDLE_TIME);
63
- if (sessionChanged) {
64
- sessionState.ageTimeoutID = exports.SessionID._resetTimeout(sessionState, sessionState.ageTimeoutID, MAX_SESSION_AGE);
65
- }
60
+ sessionState.ageTimeoutID = exports.SessionID._resetTimeout(sessionState, sessionState.ageTimeoutID, MAX_SESSION_AGE - (now - session.startTime));
66
61
  SESSION_ID_MAP[sdkKey] = session;
67
62
  SESSION_STATE_MAP[sdkKey] = sessionState;
68
63
  PROMISE_MAP[sdkKey] = null;
@@ -59,6 +59,7 @@ export declare abstract class StatsigClientBase<TAdapter extends EvaluationsData
59
59
  * @see {@link on} for subscribing to events.
60
60
  */
61
61
  off<T extends StatsigClientEventName>(event: T, listener: StatsigClientEventCallback<T>): void;
62
+ __on<T extends StatsigClientEventName>(event: T, listener: StatsigClientEventCallback<T>): void;
62
63
  protected _emit(event: StatsigClientEvent): void;
63
64
  protected _setStatus(newStatus: StatsigLoadingStatus, values: DataAdapterResult | null): void;
64
65
  protected _enqueueExposure(name: string, exposure: StatsigEventInternal, options?: EvaluationOptionsCommon): void;
@@ -105,6 +105,10 @@ class StatsigClientBase {
105
105
  }
106
106
  }
107
107
  }
108
+ __on(event, listener) {
109
+ listener.__isInternal = true;
110
+ this.on(event, listener);
111
+ }
108
112
  _emit(event) {
109
113
  var _a;
110
114
  const barrier = (listener) => {
@@ -112,6 +116,10 @@ class StatsigClientBase {
112
116
  listener(event);
113
117
  }
114
118
  catch (error) {
119
+ if (listener.__isInternal === true) {
120
+ this._errorBoundary.logError(`_emit:${event.name}`, error);
121
+ return;
122
+ }
115
123
  Log_1.Log.error(`An error occurred in a StatsigClientEvent listener. This is not an issue with Statsig.`, event);
116
124
  }
117
125
  };
@@ -60,5 +60,9 @@ export interface StatsigClientEventEmitterInterface {
60
60
  readonly loadingStatus: StatsigLoadingStatus;
61
61
  on<T extends StatsigClientEventName>(event: T, listener: StatsigClientEventCallback<T>): void;
62
62
  off<T extends StatsigClientEventName>(event: T, listener: StatsigClientEventCallback<T>): void;
63
+ /**
64
+ * (Statsig Use Only) - Same as .on() but logs errors to sdk_exception
65
+ */
66
+ __on<T extends StatsigClientEventName>(event: T, listener: StatsigClientEventCallback<T>): void;
63
67
  }
64
68
  export {};
@@ -1,3 +1,4 @@
1
+ export declare const SDK_VERSION = "0.0.1-beta.28";
1
2
  export type StatsigMetadata = {
2
3
  readonly [key: string]: string | undefined;
3
4
  readonly appVersion?: string;
@@ -1,9 +1,9 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.StatsigMetadataProvider = void 0;
4
- const SDK_VERSION = '0.0.1-beta.26';
3
+ exports.StatsigMetadataProvider = exports.SDK_VERSION = void 0;
4
+ exports.SDK_VERSION = '0.0.1-beta.28';
5
5
  let metadata = {
6
- sdkVersion: SDK_VERSION,
6
+ sdkVersion: exports.SDK_VERSION,
7
7
  sdkType: 'js-mono', // js-mono is overwritten by Precomp and OnDevice clients
8
8
  };
9
9
  exports.StatsigMetadataProvider = {
@@ -1,10 +1,6 @@
1
1
  import type { StatsigEnvironment } from './StatsigOptionsCommon';
2
2
  type StatsigUserPrimitives = string | number | boolean | Array<string> | undefined;
3
- export type StatsigUser = ({
4
- userID: string;
5
- } | {
6
- customIDs: Record<string, string>;
7
- }) & {
3
+ export type StatsigUser = {
8
4
  userID?: string;
9
5
  customIDs?: Record<string, string>;
10
6
  email?: string;
@@ -6,7 +6,7 @@ class VisibilityChangeObserver {
6
6
  return this._current === 'foreground';
7
7
  }
8
8
  static add(listener) {
9
- this._listeners.push(listener);
9
+ this._listeners.unshift(listener);
10
10
  }
11
11
  static remove(listener) {
12
12
  const index = this._listeners.indexOf(listener);
package/src/index.js CHANGED
@@ -21,6 +21,7 @@ const EventLogger_1 = require("./EventLogger");
21
21
  Object.defineProperty(exports, "EventLogger", { enumerable: true, get: function () { return EventLogger_1.EventLogger; } });
22
22
  const Log_1 = require("./Log");
23
23
  Object.defineProperty(exports, "Log", { enumerable: true, get: function () { return Log_1.Log; } });
24
+ const StatsigMetadata_1 = require("./StatsigMetadata");
24
25
  const StorageProvider_1 = require("./StorageProvider");
25
26
  Object.defineProperty(exports, "Storage", { enumerable: true, get: function () { return StorageProvider_1.Storage; } });
26
27
  const UUID_1 = require("./UUID");
@@ -56,4 +57,5 @@ __exportStar(require("./VisibilityChangeObserver"), exports);
56
57
  __STATSIG__ = Object.assign(Object.assign({}, (__STATSIG__ !== null && __STATSIG__ !== void 0 ? __STATSIG__ : {})), { EventLogger: EventLogger_1.EventLogger,
57
58
  Log: Log_1.Log,
58
59
  getUUID: UUID_1.getUUID,
59
- Storage: StorageProvider_1.Storage });
60
+ Storage: StorageProvider_1.Storage,
61
+ SDK_VERSION: StatsigMetadata_1.SDK_VERSION });