@openfeature/web-sdk 0.3.6-experimental → 0.3.7-experimental

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/dist/esm/index.js CHANGED
@@ -433,7 +433,16 @@ var require_events = __commonJS({
433
433
  }
434
434
  });
435
435
 
436
- // ../shared/src/types.ts
436
+ // ../shared/src/errors/open-feature-error-abstract.ts
437
+ var OpenFeatureError = class extends Error {
438
+ constructor(message) {
439
+ super(message);
440
+ Object.setPrototypeOf(this, OpenFeatureError.prototype);
441
+ this.name = "OpenFeatureError";
442
+ }
443
+ };
444
+
445
+ // ../shared/src/evaluation/evaluation.ts
437
446
  var StandardResolutionReasons = {
438
447
  /**
439
448
  * The resolved value was the result of a dynamic evaluation, such as a rule or specific user-targeting.
@@ -480,21 +489,6 @@ var ErrorCode = /* @__PURE__ */ ((ErrorCode2) => {
480
489
  ErrorCode2["GENERAL"] = "GENERAL";
481
490
  return ErrorCode2;
482
491
  })(ErrorCode || {});
483
- var ProviderStatus = /* @__PURE__ */ ((ProviderStatus2) => {
484
- ProviderStatus2["NOT_READY"] = "NOT_READY";
485
- ProviderStatus2["READY"] = "READY";
486
- ProviderStatus2["ERROR"] = "ERROR";
487
- return ProviderStatus2;
488
- })(ProviderStatus || {});
489
-
490
- // ../shared/src/errors/open-feature-error-abstract.ts
491
- var OpenFeatureError = class extends Error {
492
- constructor(message) {
493
- super(message);
494
- Object.setPrototypeOf(this, OpenFeatureError.prototype);
495
- this.name = "OpenFeatureError";
496
- }
497
- };
498
492
 
499
493
  // ../shared/src/errors/general-error.ts
500
494
  var GeneralError = class extends OpenFeatureError {
@@ -556,8 +550,16 @@ var InvalidContextError = class extends OpenFeatureError {
556
550
  }
557
551
  };
558
552
 
559
- // ../shared/src/logger.ts
560
- var LOG_LEVELS = ["error", "warn", "info", "debug"];
553
+ // ../shared/src/events/events.ts
554
+ var ProviderEvents = /* @__PURE__ */ ((ProviderEvents2) => {
555
+ ProviderEvents2["Ready"] = "PROVIDER_READY";
556
+ ProviderEvents2["Error"] = "PROVIDER_ERROR";
557
+ ProviderEvents2["ConfigurationChanged"] = "PROVIDER_CONFIGURATION_CHANGED";
558
+ ProviderEvents2["Stale"] = "PROVIDER_STALE";
559
+ return ProviderEvents2;
560
+ })(ProviderEvents || {});
561
+
562
+ // ../shared/src/logger/default-logger.ts
561
563
  var DefaultLogger = class {
562
564
  error(...args) {
563
565
  console.error(...args);
@@ -570,6 +572,9 @@ var DefaultLogger = class {
570
572
  debug() {
571
573
  }
572
574
  };
575
+
576
+ // ../shared/src/logger/safe-logger.ts
577
+ var LOG_LEVELS = ["error", "warn", "info", "debug"];
573
578
  var SafeLogger = class {
574
579
  constructor(logger) {
575
580
  this.fallbackLogger = new DefaultLogger();
@@ -607,26 +612,8 @@ var SafeLogger = class {
607
612
  }
608
613
  };
609
614
 
610
- // ../shared/src/no-op-transaction-context-propagator.ts
611
- var NoopTransactionContextPropagator = class {
612
- getTransactionContext() {
613
- return {};
614
- }
615
- setTransactionContext(_, callback) {
616
- callback();
617
- }
618
- };
619
- var NOOP_TRANSACTION_CONTEXT_PROPAGATOR = new NoopTransactionContextPropagator();
620
-
621
- // ../shared/src/events.ts
615
+ // ../shared/src/events/open-feature-event-emitter.ts
622
616
  var import_events = __toESM(require_events());
623
- var ProviderEvents = /* @__PURE__ */ ((ProviderEvents2) => {
624
- ProviderEvents2["Ready"] = "PROVIDER_READY";
625
- ProviderEvents2["Error"] = "PROVIDER_ERROR";
626
- ProviderEvents2["ConfigurationChanged"] = "PROVIDER_CONFIGURATION_CHANGED";
627
- ProviderEvents2["Stale"] = "PROVIDER_STALE";
628
- return ProviderEvents2;
629
- })(ProviderEvents || {});
630
617
  var OpenFeatureEventEmitter = class {
631
618
  constructor(globalLogger) {
632
619
  this.globalLogger = globalLogger;
@@ -674,6 +661,25 @@ var OpenFeatureEventEmitter = class {
674
661
  }
675
662
  };
676
663
 
664
+ // ../shared/src/provider/provider.ts
665
+ var ProviderStatus = /* @__PURE__ */ ((ProviderStatus2) => {
666
+ ProviderStatus2["NOT_READY"] = "NOT_READY";
667
+ ProviderStatus2["READY"] = "READY";
668
+ ProviderStatus2["ERROR"] = "ERROR";
669
+ return ProviderStatus2;
670
+ })(ProviderStatus || {});
671
+
672
+ // ../shared/src/transaction-context/no-op-transaction-context-propagator.ts
673
+ var NoopTransactionContextPropagator = class {
674
+ getTransactionContext() {
675
+ return {};
676
+ }
677
+ setTransactionContext(_, callback) {
678
+ callback();
679
+ }
680
+ };
681
+ var NOOP_TRANSACTION_CONTEXT_PROPAGATOR = new NoopTransactionContextPropagator();
682
+
677
683
  // ../shared/src/type-guards.ts
678
684
  function isString(value) {
679
685
  return typeof value === "string";
@@ -696,6 +702,7 @@ function isDefined(input) {
696
702
  // ../shared/src/open-feature.ts
697
703
  var OpenFeatureCommonAPI = class {
698
704
  constructor() {
705
+ this._hooks = [];
699
706
  this._transactionContextPropagator = NOOP_TRANSACTION_CONTEXT_PROPAGATOR;
700
707
  this._context = {};
701
708
  this._logger = new DefaultLogger();
@@ -704,6 +711,17 @@ var OpenFeatureCommonAPI = class {
704
711
  this._clientProviders = /* @__PURE__ */ new Map();
705
712
  this._clientEvents = /* @__PURE__ */ new Map();
706
713
  }
714
+ addHooks(...hooks) {
715
+ this._hooks = [...this._hooks, ...hooks];
716
+ return this;
717
+ }
718
+ getHooks() {
719
+ return this._hooks;
720
+ }
721
+ clearHooks() {
722
+ this._hooks = [];
723
+ return this;
724
+ }
707
725
  setLogger(logger) {
708
726
  this._logger = new SafeLogger(logger);
709
727
  return this;
@@ -715,9 +733,6 @@ var OpenFeatureCommonAPI = class {
715
733
  get providerMetadata() {
716
734
  return this._defaultProvider.metadata;
717
735
  }
718
- getContext() {
719
- return this._context;
720
- }
721
736
  /**
722
737
  * Adds a handler for the given provider event type.
723
738
  * The handlers are called in the order they have been added.
@@ -816,7 +831,12 @@ var OpenFeatureCommonAPI = class {
816
831
  const namedProviders = [...this._clientProviders.keys()];
817
832
  const eventEmitterNames = [...this._clientEvents.keys()].filter(isDefined);
818
833
  const unboundEmitterNames = eventEmitterNames.filter((name) => !namedProviders.includes(name));
819
- return unboundEmitterNames.map((name) => this._clientEvents.get(name)).filter(isDefined);
834
+ return [
835
+ // all unbound, named emitters
836
+ ...unboundEmitterNames.map((name) => this._clientEvents.get(name)),
837
+ // the default emitter
838
+ this._clientEvents.get(void 0)
839
+ ].filter(isDefined);
820
840
  }
821
841
  transferListeners(oldProvider, newProvider, clientName, emitters) {
822
842
  var _a;
@@ -892,7 +912,7 @@ var OpenFeatureCommonAPI = class {
892
912
  }
893
913
  };
894
914
 
895
- // src/no-op-provider.ts
915
+ // src/provider/no-op-provider.ts
896
916
  var REASON_NO_OP = "No-op";
897
917
  var NoopFeatureProvider = class {
898
918
  constructor() {
@@ -931,7 +951,6 @@ var OpenFeatureAPI = class extends OpenFeatureCommonAPI {
931
951
  // eslint-disable-next-line @typescript-eslint/no-empty-function
932
952
  constructor() {
933
953
  super();
934
- this._hooks = [];
935
954
  this._defaultProvider = NOOP_PROVIDER;
936
955
  }
937
956
  /**
@@ -948,21 +967,6 @@ var OpenFeatureAPI = class extends OpenFeatureCommonAPI {
948
967
  _globalThis[GLOBAL_OPENFEATURE_API_KEY] = instance;
949
968
  return instance;
950
969
  }
951
- setLogger(logger) {
952
- this._logger = new SafeLogger(logger);
953
- return this;
954
- }
955
- addHooks(...hooks) {
956
- this._hooks = [...this._hooks, ...hooks];
957
- return this;
958
- }
959
- getHooks() {
960
- return this._hooks;
961
- }
962
- clearHooks() {
963
- this._hooks = [];
964
- return this;
965
- }
966
970
  setContext(context) {
967
971
  return __async(this, null, function* () {
968
972
  var _a, _b;
@@ -971,6 +975,9 @@ var OpenFeatureAPI = class extends OpenFeatureCommonAPI {
971
975
  yield (_b = (_a = this._defaultProvider) == null ? void 0 : _a.onContextChange) == null ? void 0 : _b.call(_a, oldContext, context);
972
976
  });
973
977
  }
978
+ getContext() {
979
+ return this._context;
980
+ }
974
981
  /**
975
982
  * A factory function for creating new named OpenFeature clients. Clients can contain
976
983
  * their own state (e.g. logger, hook, context). Multiple clients can be used
@@ -995,7 +1002,7 @@ var OpenFeatureAPI = class extends OpenFeatureCommonAPI {
995
1002
  };
996
1003
  var OpenFeature = OpenFeatureAPI.getInstance();
997
1004
 
998
- // src/client.ts
1005
+ // src/client/open-feature-client.ts
999
1006
  var OpenFeatureClient = class {
1000
1007
  constructor(providerAccessor, emitterAccessor, globalLogger, options) {
1001
1008
  this.providerAccessor = providerAccessor;
@@ -1181,6 +1188,7 @@ export {
1181
1188
  FlagNotFoundError,
1182
1189
  GeneralError,
1183
1190
  InvalidContextError,
1191
+ LOG_LEVELS,
1184
1192
  NOOP_PROVIDER,
1185
1193
  NOOP_TRANSACTION_CONTEXT_PROPAGATOR,
1186
1194
  OpenFeature,
@@ -1195,6 +1203,10 @@ export {
1195
1203
  SafeLogger,
1196
1204
  StandardResolutionReasons,
1197
1205
  TargetingKeyMissingError,
1198
- TypeMismatchError
1206
+ TypeMismatchError,
1207
+ isObject,
1208
+ isString,
1209
+ objectOrUndefined,
1210
+ stringOrUndefined
1199
1211
  };
1200
1212
  //# sourceMappingURL=index.js.map