vwo-fme-node-sdk 1.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.
- package/CONTRIBUTING.md +46 -0
- package/LICENSE +202 -0
- package/NOTICE +18 -0
- package/README.md +52 -0
- package/dist/VWO.d.ts +9 -0
- package/dist/VWO.js +100 -0
- package/dist/VWO.js.map +1 -0
- package/dist/VWOBuilder.d.ts +48 -0
- package/dist/VWOBuilder.js +173 -0
- package/dist/VWOBuilder.js.map +1 -0
- package/dist/VWOClient.d.ts +20 -0
- package/dist/VWOClient.js +249 -0
- package/dist/VWOClient.js.map +1 -0
- package/dist/api/GetFlag.d.ts +19 -0
- package/dist/api/GetFlag.js +394 -0
- package/dist/api/GetFlag.js.map +1 -0
- package/dist/api/GetVariable.d.ts +0 -0
- package/dist/api/GetVariable.js +1 -0
- package/dist/api/GetVariable.js.map +1 -0
- package/dist/api/GetVariables.d.ts +0 -0
- package/dist/api/GetVariables.js +1 -0
- package/dist/api/GetVariables.js.map +1 -0
- package/dist/api/SetAttribute.d.ts +7 -0
- package/dist/api/SetAttribute.js +62 -0
- package/dist/api/SetAttribute.js.map +1 -0
- package/dist/api/Track.js +76 -0
- package/dist/api/Track.js.map +1 -0
- package/dist/api/TrackEvent.d.ts +8 -0
- package/dist/api/TrackEvent.js +78 -0
- package/dist/api/TrackEvent.js.map +1 -0
- package/dist/constants/index.d.ts +24 -0
- package/dist/constants/index.js +31 -0
- package/dist/constants/index.js.map +1 -0
- package/dist/constants/url.d.ts +6 -0
- package/dist/constants/url.js +10 -0
- package/dist/constants/url.js.map +1 -0
- package/dist/decision-maker/index.js +75 -0
- package/dist/decision-maker/index.js.map +1 -0
- package/dist/decorators/StorageDecorator.d.ts +12 -0
- package/dist/decorators/StorageDecorator.js +119 -0
- package/dist/decorators/StorageDecorator.js.map +1 -0
- package/dist/enums/ApiEnum.d.ts +4 -0
- package/dist/enums/ApiEnum.js +9 -0
- package/dist/enums/ApiEnum.js.map +1 -0
- package/dist/enums/EventEnum.d.ts +4 -0
- package/dist/enums/EventEnum.js +9 -0
- package/dist/enums/EventEnum.js.map +1 -0
- package/dist/enums/HeadersEnum.d.ts +4 -0
- package/dist/enums/HeadersEnum.js +9 -0
- package/dist/enums/HeadersEnum.js.map +1 -0
- package/dist/enums/HooksEnum.d.ts +7 -0
- package/dist/enums/HooksEnum.js +8 -0
- package/dist/enums/HooksEnum.js.map +1 -0
- package/dist/enums/LogLevelEnum.d.ts +7 -0
- package/dist/enums/LogLevelEnum.js +12 -0
- package/dist/enums/LogLevelEnum.js.map +1 -0
- package/dist/enums/StatusEnum.d.ts +4 -0
- package/dist/enums/StorageEnum.d.ts +8 -0
- package/dist/enums/StorageEnum.js +13 -0
- package/dist/enums/StorageEnum.js.map +1 -0
- package/dist/enums/UrlEnum.d.ts +13 -0
- package/dist/enums/UrlEnum.js +18 -0
- package/dist/enums/UrlEnum.js.map +1 -0
- package/dist/enums/campaignTypeEnum.d.ts +5 -0
- package/dist/enums/campaignTypeEnum.js +10 -0
- package/dist/enums/campaignTypeEnum.js.map +1 -0
- package/dist/enums/logMessages/DbugLogMessageEnum.js +1 -0
- package/dist/enums/logMessages/DbugLogMessageEnum.js.map +1 -0
- package/dist/enums/logMessages/DebugLogMessageEnum.d.ts +3 -0
- package/dist/enums/logMessages/ErorLogMessageEnum.js +1 -0
- package/dist/enums/logMessages/ErorLogMessageEnum.js.map +1 -0
- package/dist/enums/logMessages/ErrorLogMessageEnum.d.ts +3 -0
- package/dist/enums/logMessages/debugLogMessageEnum.js +8 -0
- package/dist/enums/logMessages/debugLogMessageEnum.js.map +1 -0
- package/dist/enums/logMessages/errorLogMessageEnum.js +8 -0
- package/dist/enums/logMessages/errorLogMessageEnum.js.map +1 -0
- package/dist/enums/statusEnum.js +9 -0
- package/dist/enums/statusEnum.js.map +1 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/logger/core/logManager.js +97 -0
- package/dist/logger/core/logManager.js.map +1 -0
- package/dist/logger/core/transportManager.js +60 -0
- package/dist/logger/core/transportManager.js.map +1 -0
- package/dist/logger/enums/logLevelEnum.js +12 -0
- package/dist/logger/enums/logLevelEnum.js.map +1 -0
- package/dist/logger/index.js +8 -0
- package/dist/logger/index.js.map +1 -0
- package/dist/logger/logMessageBuilder.js +43 -0
- package/dist/logger/logMessageBuilder.js.map +1 -0
- package/dist/logger/logger.js +10 -0
- package/dist/logger/logger.js.map +1 -0
- package/dist/logger/transports/consoleTransport.js +32 -0
- package/dist/logger/transports/consoleTransport.js.map +1 -0
- package/dist/models/CampaignModel.d.ts +32 -0
- package/dist/models/CampaignModel.js +149 -0
- package/dist/models/CampaignModel.js.map +1 -0
- package/dist/models/FeatureModel.d.ts +20 -0
- package/dist/models/FeatureModel.js +72 -0
- package/dist/models/FeatureModel.js.map +1 -0
- package/dist/models/ImpactCampaignModel.d.ts +7 -0
- package/dist/models/ImpactCampaignModel.js +21 -0
- package/dist/models/ImpactCampaignModel.js.map +1 -0
- package/dist/models/MetricModel.d.ts +12 -0
- package/dist/models/MetricModel.js +25 -0
- package/dist/models/MetricModel.js.map +1 -0
- package/dist/models/RuleModel.d.ts +11 -0
- package/dist/models/RuleModel.js +29 -0
- package/dist/models/RuleModel.js.map +1 -0
- package/dist/models/SettingsModel.d.ts +28 -0
- package/dist/models/SettingsModel.js +70 -0
- package/dist/models/SettingsModel.js.map +1 -0
- package/dist/models/VariableModel.d.ts +18 -0
- package/dist/models/VariableModel.js +38 -0
- package/dist/models/VariableModel.js.map +1 -0
- package/dist/models/VariationModel.d.ts +29 -0
- package/dist/models/VariationModel.js +80 -0
- package/dist/models/VariationModel.js.map +1 -0
- package/dist/models/schemas/SettingsSchemaValidation.d.ts +13 -0
- package/dist/models/schemas/SettingsSchemaValidation.js +70 -0
- package/dist/models/schemas/SettingsSchemaValidation.js.map +1 -0
- package/dist/modules/decision-maker/index.d.ts +38 -0
- package/dist/modules/decision-maker/index.js +67 -0
- package/dist/modules/decision-maker/index.js.map +1 -0
- package/dist/modules/logger/core/logManager.d.ts +40 -0
- package/dist/modules/logger/core/logManager.js +97 -0
- package/dist/modules/logger/core/logManager.js.map +1 -0
- package/dist/modules/logger/core/transportManager.d.ts +22 -0
- package/dist/modules/logger/core/transportManager.js +60 -0
- package/dist/modules/logger/core/transportManager.js.map +1 -0
- package/dist/modules/logger/enums/logLevelEnum.d.ts +7 -0
- package/dist/modules/logger/enums/logLevelEnum.js +12 -0
- package/dist/modules/logger/enums/logLevelEnum.js.map +1 -0
- package/dist/modules/logger/index.d.ts +2 -0
- package/dist/modules/logger/index.js +8 -0
- package/dist/modules/logger/index.js.map +1 -0
- package/dist/modules/logger/logMessageBuilder.d.ts +21 -0
- package/dist/modules/logger/logMessageBuilder.js +43 -0
- package/dist/modules/logger/logMessageBuilder.js.map +1 -0
- package/dist/modules/logger/logger.d.ts +7 -0
- package/dist/modules/logger/logger.js +10 -0
- package/dist/modules/logger/logger.js.map +1 -0
- package/dist/modules/logger/transports/consoleTransport.d.ts +12 -0
- package/dist/modules/logger/transports/consoleTransport.js +32 -0
- package/dist/modules/logger/transports/consoleTransport.js.map +1 -0
- package/dist/modules/networking/client/networkClient.d.ts +7 -0
- package/dist/modules/networking/client/networkClient.js +117 -0
- package/dist/modules/networking/client/networkClient.js.map +1 -0
- package/dist/modules/networking/client/networkClientInterface.d.ts +6 -0
- package/dist/modules/networking/client/networkClientInterface.js +3 -0
- package/dist/modules/networking/client/networkClientInterface.js.map +1 -0
- package/dist/modules/networking/handlers/requestHandler.d.ts +5 -0
- package/dist/modules/networking/handlers/requestHandler.js +29 -0
- package/dist/modules/networking/handlers/requestHandler.js.map +1 -0
- package/dist/modules/networking/index.d.ts +6 -0
- package/dist/modules/networking/index.js +14 -0
- package/dist/modules/networking/index.js.map +1 -0
- package/dist/modules/networking/manager/networkManager.d.ts +16 -0
- package/dist/modules/networking/manager/networkManager.js +72 -0
- package/dist/modules/networking/manager/networkManager.js.map +1 -0
- package/dist/modules/networking/models/globalRequestModel.d.ts +22 -0
- package/dist/modules/networking/models/globalRequestModel.js +51 -0
- package/dist/modules/networking/models/globalRequestModel.js.map +1 -0
- package/dist/modules/networking/models/requestModel.d.ts +32 -0
- package/dist/modules/networking/models/requestModel.js +128 -0
- package/dist/modules/networking/models/requestModel.js.map +1 -0
- package/dist/modules/networking/models/responseModel.d.ts +15 -0
- package/dist/modules/networking/models/responseModel.js +34 -0
- package/dist/modules/networking/models/responseModel.js.map +1 -0
- package/dist/modules/segmentor/core/segmentationManger.d.ts +10 -0
- package/dist/modules/segmentor/core/segmentationManger.js +68 -0
- package/dist/modules/segmentor/core/segmentationManger.js.map +1 -0
- package/dist/modules/segmentor/enums/segmentOperandRegexEnum.d.ts +10 -0
- package/dist/modules/segmentor/enums/segmentOperandRegexEnum.js +15 -0
- package/dist/modules/segmentor/enums/segmentOperandRegexEnum.js.map +1 -0
- package/dist/modules/segmentor/enums/segmentOperandValueEnum.d.ts +8 -0
- package/dist/modules/segmentor/enums/segmentOperandValueEnum.js +13 -0
- package/dist/modules/segmentor/enums/segmentOperandValueEnum.js.map +1 -0
- package/dist/modules/segmentor/enums/segmentOperatorValueEnum.d.ts +15 -0
- package/dist/modules/segmentor/enums/segmentOperatorValueEnum.js +20 -0
- package/dist/modules/segmentor/enums/segmentOperatorValueEnum.js.map +1 -0
- package/dist/modules/segmentor/evaluators/segmentEvaluator.d.ts +15 -0
- package/dist/modules/segmentor/evaluators/segmentEvaluator.js +379 -0
- package/dist/modules/segmentor/evaluators/segmentEvaluator.js.map +1 -0
- package/dist/modules/segmentor/evaluators/segmentOperandEvaluator.d.ts +12 -0
- package/dist/modules/segmentor/evaluators/segmentOperandEvaluator.js +248 -0
- package/dist/modules/segmentor/evaluators/segmentOperandEvaluator.js.map +1 -0
- package/dist/modules/segmentor/index.d.ts +3 -0
- package/dist/modules/segmentor/index.js +8 -0
- package/dist/modules/segmentor/index.js.map +1 -0
- package/dist/modules/segmentor/segmentation.d.ts +5 -0
- package/dist/modules/segmentor/segmentation.js +3 -0
- package/dist/modules/segmentor/segmentation.js.map +1 -0
- package/dist/modules/segmentor/utils/SegmentUtil.d.ts +2 -0
- package/dist/modules/segmentor/utils/SegmentUtil.js +26 -0
- package/dist/modules/segmentor/utils/SegmentUtil.js.map +1 -0
- package/dist/modules/storage/connector.d.ts +14 -0
- package/dist/modules/storage/connector.js +10 -0
- package/dist/modules/storage/connector.js.map +1 -0
- package/dist/modules/storage/connectors/index.d.ts +0 -0
- package/dist/modules/storage/connectors/index.js +3 -0
- package/dist/modules/storage/connectors/index.js.map +1 -0
- package/dist/modules/storage/connectors/memoryConnector.d.ts +26 -0
- package/dist/modules/storage/connectors/memoryConnector.js +103 -0
- package/dist/modules/storage/connectors/memoryConnector.js.map +1 -0
- package/dist/modules/storage/connectors/redisConnector.d.ts +0 -0
- package/dist/modules/storage/connectors/redisConnector.js +181 -0
- package/dist/modules/storage/connectors/redisConnector.js.map +1 -0
- package/dist/modules/storage/index.d.ts +1 -0
- package/dist/modules/storage/index.js +6 -0
- package/dist/modules/storage/index.js.map +1 -0
- package/dist/modules/storage/storage.d.ts +10 -0
- package/dist/modules/storage/storage.js +50 -0
- package/dist/modules/storage/storage.js.map +1 -0
- package/dist/networking/client/networkClient.js +117 -0
- package/dist/networking/client/networkClient.js.map +1 -0
- package/dist/networking/client/networkClientInterface.js +3 -0
- package/dist/networking/client/networkClientInterface.js.map +1 -0
- package/dist/networking/handlers/requestHandler.js +29 -0
- package/dist/networking/handlers/requestHandler.js.map +1 -0
- package/dist/networking/index.js +14 -0
- package/dist/networking/index.js.map +1 -0
- package/dist/networking/manager/networkManager.js +72 -0
- package/dist/networking/manager/networkManager.js.map +1 -0
- package/dist/networking/models/globalRequestModel.js +51 -0
- package/dist/networking/models/globalRequestModel.js.map +1 -0
- package/dist/networking/models/requestModel.js +107 -0
- package/dist/networking/models/requestModel.js.map +1 -0
- package/dist/networking/models/responseModel.js +34 -0
- package/dist/networking/models/responseModel.js.map +1 -0
- package/dist/segmentor/core/segmentationManger.js +25 -0
- package/dist/segmentor/core/segmentationManger.js.map +1 -0
- package/dist/segmentor/enums/segmentOperandRegexEnum.js +15 -0
- package/dist/segmentor/enums/segmentOperandRegexEnum.js.map +1 -0
- package/dist/segmentor/enums/segmentOperandValueEnum.js +13 -0
- package/dist/segmentor/enums/segmentOperandValueEnum.js.map +1 -0
- package/dist/segmentor/enums/segmentOperatorValueEnum.js +12 -0
- package/dist/segmentor/enums/segmentOperatorValueEnum.js.map +1 -0
- package/dist/segmentor/evaluators/segmentEvaluator.js +52 -0
- package/dist/segmentor/evaluators/segmentEvaluator.js.map +1 -0
- package/dist/segmentor/evaluators/segmentOperandEvaluator.js +158 -0
- package/dist/segmentor/evaluators/segmentOperandEvaluator.js.map +1 -0
- package/dist/segmentor/index.js +8 -0
- package/dist/segmentor/index.js.map +1 -0
- package/dist/segmentor/segmentation.js +3 -0
- package/dist/segmentor/segmentation.js.map +1 -0
- package/dist/segmentor/utils/SegmentUtil.js +27 -0
- package/dist/segmentor/utils/SegmentUtil.js.map +1 -0
- package/dist/services/CampaignDecisionService.d.ts +44 -0
- package/dist/services/CampaignDecisionService.js +175 -0
- package/dist/services/CampaignDecisionService.js.map +1 -0
- package/dist/services/HooksManager.d.ts +27 -0
- package/dist/services/HooksManager.js +40 -0
- package/dist/services/HooksManager.js.map +1 -0
- package/dist/services/SettingsManager.d.ts +21 -0
- package/dist/services/SettingsManager.js +168 -0
- package/dist/services/SettingsManager.js.map +1 -0
- package/dist/services/StorageService.d.ts +5 -0
- package/dist/services/StorageService.js +94 -0
- package/dist/services/StorageService.js.map +1 -0
- package/dist/services/UrlService.d.ts +13 -0
- package/dist/services/UrlService.js +37 -0
- package/dist/services/UrlService.js.map +1 -0
- package/dist/types/common.d.ts +2 -0
- package/dist/types/common.js +3 -0
- package/dist/types/common.js.map +1 -0
- package/dist/utils/CampaignUtil.d.ts +23 -0
- package/dist/utils/CampaignUtil.js +228 -0
- package/dist/utils/CampaignUtil.js.map +1 -0
- package/dist/utils/DataTypeUtil.d.ts +17 -0
- package/dist/utils/DataTypeUtil.js +86 -0
- package/dist/utils/DataTypeUtil.js.map +1 -0
- package/dist/utils/DecisionUtil.d.ts +4 -0
- package/dist/utils/DecisionUtil.js +197 -0
- package/dist/utils/DecisionUtil.js.map +1 -0
- package/dist/utils/FunctionUtil.d.ts +13 -0
- package/dist/utils/FunctionUtil.js +121 -0
- package/dist/utils/FunctionUtil.js.map +1 -0
- package/dist/utils/LogMessageUtil.d.ts +16 -0
- package/dist/utils/LogMessageUtil.js +53 -0
- package/dist/utils/LogMessageUtil.js.map +1 -0
- package/dist/utils/MegUtil.d.ts +7 -0
- package/dist/utils/MegUtil.js +413 -0
- package/dist/utils/MegUtil.js.map +1 -0
- package/dist/utils/NetworkUtil.d.ts +140 -0
- package/dist/utils/NetworkUtil.js +238 -0
- package/dist/utils/NetworkUtil.js.map +1 -0
- package/dist/utils/PromiseUtil.d.ts +1 -0
- package/dist/utils/PromiseUtil.js +13 -0
- package/dist/utils/PromiseUtil.js.map +1 -0
- package/dist/utils/SettingsUtil.d.ts +2 -0
- package/dist/utils/SettingsUtil.js +17 -0
- package/dist/utils/SettingsUtil.js.map +1 -0
- package/dist/utils/UuidUtil.d.ts +2 -0
- package/dist/utils/UuidUtil.js +30 -0
- package/dist/utils/UuidUtil.js.map +1 -0
- package/dist/utils/WebServiceUtil.d.ts +4 -0
- package/dist/utils/WebServiceUtil.js +93 -0
- package/dist/utils/WebServiceUtil.js.map +1 -0
- package/dist/utils/logMessageBuilder.d.ts +21 -0
- package/dist/utils/logMessageBuilder.js +43 -0
- package/dist/utils/logMessageBuilder.js.map +1 -0
- package/lib/VWO.ts +55 -0
- package/lib/VWOBuilder.ts +237 -0
- package/lib/VWOClient.ts +321 -0
- package/lib/api/GetFlag.ts +458 -0
- package/lib/api/GetVariable.ts +0 -0
- package/lib/api/GetVariables.ts +0 -0
- package/lib/api/SetAttribute.ts +33 -0
- package/lib/api/TrackEvent.ts +52 -0
- package/lib/constants/index.ts +35 -0
- package/lib/constants/url.ts +7 -0
- package/lib/decorators/StorageDecorator.ts +98 -0
- package/lib/enums/ApiEnum.ts +4 -0
- package/lib/enums/EventEnum.ts +4 -0
- package/lib/enums/HeadersEnum.ts +4 -0
- package/lib/enums/HooksEnum.ts +11 -0
- package/lib/enums/LogLevelEnum.ts +7 -0
- package/lib/enums/StatusEnum.ts +4 -0
- package/lib/enums/StorageEnum.ts +8 -0
- package/lib/enums/UrlEnum.ts +13 -0
- package/lib/enums/campaignTypeEnum.ts +5 -0
- package/lib/enums/logMessages/DebugLogMessageEnum.ts +3 -0
- package/lib/enums/logMessages/ErrorLogMessageEnum.ts +3 -0
- package/lib/index.ts +1 -0
- package/lib/models/CampaignModel.ts +176 -0
- package/lib/models/FeatureModel.ts +81 -0
- package/lib/models/ImpactCampaignModel.ts +20 -0
- package/lib/models/MetricModel.ts +31 -0
- package/lib/models/RuleModel.ts +35 -0
- package/lib/models/SettingsModel.ts +95 -0
- package/lib/models/VariableModel.ts +51 -0
- package/lib/models/VariationModel.ts +101 -0
- package/lib/models/schemas/SettingsSchemaValidation.ts +83 -0
- package/lib/modules/decision-maker/index.ts +65 -0
- package/lib/modules/logger/core/logManager.ts +113 -0
- package/lib/modules/logger/core/transportManager.ts +76 -0
- package/lib/modules/logger/enums/logLevelEnum.ts +7 -0
- package/lib/modules/logger/index.ts +2 -0
- package/lib/modules/logger/logMessageBuilder.ts +60 -0
- package/lib/modules/logger/logger.ts +7 -0
- package/lib/modules/logger/transports/consoleTransport.ts +37 -0
- package/lib/modules/networking/client/networkClient.ts +128 -0
- package/lib/modules/networking/client/networkClientInterface.ts +8 -0
- package/lib/modules/networking/handlers/requestHandler.ts +28 -0
- package/lib/modules/networking/index.ts +6 -0
- package/lib/modules/networking/manager/networkManager.ts +77 -0
- package/lib/modules/networking/models/globalRequestModel.ts +69 -0
- package/lib/modules/networking/models/requestModel.ts +164 -0
- package/lib/modules/networking/models/responseModel.ts +40 -0
- package/lib/modules/segmentor/core/segmentationManger.ts +22 -0
- package/lib/modules/segmentor/enums/segmentOperandRegexEnum.ts +10 -0
- package/lib/modules/segmentor/enums/segmentOperandValueEnum.ts +8 -0
- package/lib/modules/segmentor/enums/segmentOperatorValueEnum.ts +15 -0
- package/lib/modules/segmentor/evaluators/segmentEvaluator.ts +239 -0
- package/lib/modules/segmentor/evaluators/segmentOperandEvaluator.ts +199 -0
- package/lib/modules/segmentor/index.ts +3 -0
- package/lib/modules/segmentor/segmentation.ts +6 -0
- package/lib/modules/segmentor/utils/SegmentUtil.ts +23 -0
- package/lib/modules/storage/connector.ts +25 -0
- package/lib/modules/storage/connectors/index.ts +2 -0
- package/lib/modules/storage/connectors/memoryConnector.ts +115 -0
- package/lib/modules/storage/connectors/redisConnector.ts +180 -0
- package/lib/modules/storage/index.ts +1 -0
- package/lib/modules/storage/storage.ts +48 -0
- package/lib/services/CampaignDecisionService.ts +160 -0
- package/lib/services/HooksManager.ts +50 -0
- package/lib/services/SettingsManager.ts +167 -0
- package/lib/services/StorageService.ts +53 -0
- package/lib/services/UrlService.ts +50 -0
- package/lib/types/common.ts +13 -0
- package/lib/utils/CampaignUtil.ts +236 -0
- package/lib/utils/DataTypeUtil.ts +87 -0
- package/lib/utils/DecisionUtil.ts +180 -0
- package/lib/utils/FunctionUtil.ts +105 -0
- package/lib/utils/LogMessageUtil.ts +52 -0
- package/lib/utils/MegUtil.ts +408 -0
- package/lib/utils/NetworkUtil.ts +262 -0
- package/lib/utils/PromiseUtil.ts +10 -0
- package/lib/utils/SettingsUtil.ts +18 -0
- package/lib/utils/UuidUtil.ts +33 -0
- package/lib/utils/WebServiceUtil.ts +60 -0
- package/lib/utils/logMessageBuilder.ts +60 -0
- package/package.json +70 -0
|
@@ -0,0 +1,237 @@
|
|
|
1
|
+
import { dynamic } from './types/common';
|
|
2
|
+
|
|
3
|
+
import { SegmentationManager } from './modules/segmentor';
|
|
4
|
+
import { NetworkManager } from './modules/networking';
|
|
5
|
+
import { LogManager } from './modules/logger';
|
|
6
|
+
|
|
7
|
+
import { Storage } from './modules/storage';
|
|
8
|
+
|
|
9
|
+
import { SettingsManager } from './services/SettingsManager';
|
|
10
|
+
import { VWOClient } from './VWOClient';
|
|
11
|
+
import { processSettings } from './utils/SettingsUtil';
|
|
12
|
+
import { SettingsModel } from './models/SettingsModel';
|
|
13
|
+
// import { BatchEventsQueue } from './services/batchEventsQueue';
|
|
14
|
+
// import { DimensionModel } from './types/types';
|
|
15
|
+
import { Constants } from './constants';
|
|
16
|
+
// import { AnalyticsEvent } from './services/analyticsEvent';
|
|
17
|
+
|
|
18
|
+
import { Deferred } from './utils/PromiseUtil';
|
|
19
|
+
// import { getRandomUUID } from './utils/UuidUtil';
|
|
20
|
+
import { cloneObject } from './utils/FunctionUtil';
|
|
21
|
+
import { isObject, isBoolean, isNumber, isFunction } from './utils/DataTypeUtil' ;
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
interface IVWOBuilder {
|
|
25
|
+
settings: SettingsModel;
|
|
26
|
+
storage: Storage;
|
|
27
|
+
logManager: LogManager;
|
|
28
|
+
isSettingsFetchInProgress: boolean;
|
|
29
|
+
|
|
30
|
+
build(settings: SettingsModel): VWOClient;
|
|
31
|
+
|
|
32
|
+
fetchSettings(): Promise<SettingsModel>;
|
|
33
|
+
setSettingsManager(): this;
|
|
34
|
+
setSettings(settings: SettingsModel): void;
|
|
35
|
+
getSettings(force: boolean): Promise<dynamic>;
|
|
36
|
+
setStorage(): this;
|
|
37
|
+
setNetworkManager(): this;
|
|
38
|
+
initBatching(): this;
|
|
39
|
+
initPolling(): this;
|
|
40
|
+
setAnalyticsCallback(): this;
|
|
41
|
+
setLogger(): this;
|
|
42
|
+
setSegmentation(): this;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
export class VWOBuilder implements IVWOBuilder {
|
|
46
|
+
readonly apiKey: string;
|
|
47
|
+
readonly options: Record<string, any>;
|
|
48
|
+
|
|
49
|
+
private settingFileManager: SettingsManager;
|
|
50
|
+
|
|
51
|
+
settings: SettingsModel;
|
|
52
|
+
storage: Storage;
|
|
53
|
+
logManager: LogManager;
|
|
54
|
+
originalSettings: dynamic;
|
|
55
|
+
isSettingsFetchInProgress: boolean;
|
|
56
|
+
|
|
57
|
+
constructor(options: Record<string, dynamic>) {
|
|
58
|
+
this.options = options;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
setNetworkManager(): this {
|
|
62
|
+
const networkInstance = NetworkManager.Instance;
|
|
63
|
+
networkInstance.attachClient(this.options?.network?.client);
|
|
64
|
+
networkInstance.getConfig().setDevelopmentMode(this.options?.isDevelopmentMode);
|
|
65
|
+
return this;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
setSegmentation(): this {
|
|
69
|
+
SegmentationManager.Instance.attachEvaluator(this.options?.segmentation);
|
|
70
|
+
return this;
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
fetchSettings(force?: boolean): Promise<SettingsModel> {
|
|
74
|
+
const deferredObject = new Deferred();
|
|
75
|
+
|
|
76
|
+
// If one call is in progress, wait for it to complete and use the response
|
|
77
|
+
if (!this.isSettingsFetchInProgress) {
|
|
78
|
+
this.isSettingsFetchInProgress = true;
|
|
79
|
+
this.settingFileManager.getSettings(force).then((settings: SettingsModel) => {
|
|
80
|
+
this.originalSettings = settings;
|
|
81
|
+
|
|
82
|
+
this.isSettingsFetchInProgress = false;
|
|
83
|
+
deferredObject.resolve(settings);
|
|
84
|
+
});
|
|
85
|
+
|
|
86
|
+
return deferredObject.promise;
|
|
87
|
+
} else {
|
|
88
|
+
// DO not send multiple calls in parallel to fetch settings
|
|
89
|
+
return this.fetchSettings(force);
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
setSettings(settings: Record<string, any> | string): void {
|
|
94
|
+
LogManager.Instance.debug('API - setSettings called');
|
|
95
|
+
this.originalSettings = settings;
|
|
96
|
+
this.settings = cloneObject(settings);
|
|
97
|
+
this.settings = processSettings(this.settings);
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
getSettings(force?: boolean): Promise<SettingsModel> {
|
|
101
|
+
const deferredObject = new Deferred();
|
|
102
|
+
|
|
103
|
+
if (!force && this.settings) {
|
|
104
|
+
LogManager.Instance.info('Using already fetched and cached settings');
|
|
105
|
+
deferredObject.resolve(this.settings);
|
|
106
|
+
} else {
|
|
107
|
+
this.fetchSettings(force).then((settings: SettingsModel) => {
|
|
108
|
+
deferredObject.resolve(settings);
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
return deferredObject.promise;
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
setStorage(): this {
|
|
115
|
+
if (this.options.storage) {
|
|
116
|
+
this.storage = Storage.Instance.attachConnector(this.options.storage);
|
|
117
|
+
} else {
|
|
118
|
+
this.storage = null;
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
return this;
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
setSettingsManager(): this {
|
|
125
|
+
this.settingFileManager = new SettingsManager(this.options);
|
|
126
|
+
|
|
127
|
+
return this;
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
setLogger(): this {
|
|
131
|
+
this.logManager = new LogManager(
|
|
132
|
+
this.options.logger || {
|
|
133
|
+
defaultTransport: true,
|
|
134
|
+
level: 'debug'
|
|
135
|
+
}
|
|
136
|
+
);
|
|
137
|
+
return this;
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
setAnalyticsCallback(): this {
|
|
141
|
+
if (!isObject(this.options.analyticsEvent)) {
|
|
142
|
+
// TODO: add logging here
|
|
143
|
+
return this;
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
if (!isFunction(this.options.analyticsEvent.eventCallback)) {
|
|
147
|
+
// TODO: add logging here
|
|
148
|
+
return this;
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
if (
|
|
152
|
+
this.options.analyticsEvent.isBatchingSupported &&
|
|
153
|
+
!isBoolean(this.options.analyticsEvent.isBatchingSupported)
|
|
154
|
+
) {
|
|
155
|
+
// TODO:- add logging here
|
|
156
|
+
return this;
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
// AnalyticsEvent.Instance.attachCallback(
|
|
160
|
+
// this.options.analyticsEvent.eventCallback,
|
|
161
|
+
// this.options.analyticsEvent.isBatchingSupported
|
|
162
|
+
// );
|
|
163
|
+
return this;
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
initBatching(): this {
|
|
167
|
+
if (!isObject(this.options.batchEvents)) {
|
|
168
|
+
// TODO:- add logging here
|
|
169
|
+
return this;
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
if (
|
|
173
|
+
isObject(this.options.batchEvents) &&
|
|
174
|
+
(!(
|
|
175
|
+
(isNumber(this.options.batchEvents.eventsPerRequest) &&
|
|
176
|
+
this.options.batchEvents.eventsPerRequest > 0 &&
|
|
177
|
+
this.options.batchEvents.eventsPerRequest <= Constants.MAX_EVENTS_PER_REQUEST) ||
|
|
178
|
+
(isNumber(this.options.batchEvents.requestTimeInterval) && this.options.batchEvents.requestTimeInterval >= 1)
|
|
179
|
+
) ||
|
|
180
|
+
!isFunction(this.options.batchEvents.flushCallback))
|
|
181
|
+
) {
|
|
182
|
+
LogManager.Instance.error('Invalid batchEvents config');
|
|
183
|
+
// throw new Error('Invalid batchEvents config');
|
|
184
|
+
return this;
|
|
185
|
+
}
|
|
186
|
+
|
|
187
|
+
// BatchEventsQueue.Instance.setBatchConfig(this.options.batchEvents, this.options.apiKey); // TODO
|
|
188
|
+
|
|
189
|
+
return this;
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
initPolling(): this {
|
|
193
|
+
if (!this.options.pollInterval) {
|
|
194
|
+
// TODO: Add logging here
|
|
195
|
+
return this;
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
if (this.options.pollInterval && !isNumber(this.options.pollInterval)) {
|
|
199
|
+
// TODO: Add logging here
|
|
200
|
+
return this;
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
if (this.options.pollInterval && this.options.pollInterval < 0) {
|
|
204
|
+
// TODO: Add logging here
|
|
205
|
+
LogManager.Instance.error('Poll interval should be greater than 1');
|
|
206
|
+
return this;
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
this.checkAndPoll(this.options.pollInterval);
|
|
210
|
+
|
|
211
|
+
return this;
|
|
212
|
+
}
|
|
213
|
+
|
|
214
|
+
build(settings: SettingsModel): VWOClient {
|
|
215
|
+
return new VWOClient(settings, this.options);
|
|
216
|
+
}
|
|
217
|
+
|
|
218
|
+
checkAndPoll(pollingInterval: number): void {
|
|
219
|
+
setInterval(() => {
|
|
220
|
+
this.getSettings(true)
|
|
221
|
+
.then((latestSettingsFile: SettingsModel) => {
|
|
222
|
+
const lastSettingsFile = JSON.stringify(this.originalSettings);
|
|
223
|
+
const stringifiedLatestSettingsFile = JSON.stringify(latestSettingsFile);
|
|
224
|
+
if (stringifiedLatestSettingsFile !== lastSettingsFile) {
|
|
225
|
+
this.originalSettings = latestSettingsFile;
|
|
226
|
+
const clonedSettings = cloneObject(latestSettingsFile);
|
|
227
|
+
this.settings = processSettings(clonedSettings);
|
|
228
|
+
// TODO: Add Logging:- Settings file updated
|
|
229
|
+
}
|
|
230
|
+
})
|
|
231
|
+
.catch(() => {
|
|
232
|
+
// TODO:- Add logging:- Polling failed
|
|
233
|
+
LogManager.Instance.error('Error while fetching VWO settings with polling');
|
|
234
|
+
});
|
|
235
|
+
}, pollingInterval * 1000); // converting seconds to milliseconds
|
|
236
|
+
}
|
|
237
|
+
}
|
package/lib/VWOClient.ts
ADDED
|
@@ -0,0 +1,321 @@
|
|
|
1
|
+
// import { processSettings } from './utils/settingsUtil';
|
|
2
|
+
import { Storage } from './modules/storage';
|
|
3
|
+
import { LogManager } from './modules/logger';
|
|
4
|
+
|
|
5
|
+
import { FlagApi } from './api/GetFlag';
|
|
6
|
+
import { TrackApi } from './api/TrackEvent';
|
|
7
|
+
import { SetAttributeApi } from './api/SetAttribute';
|
|
8
|
+
|
|
9
|
+
// import { VWOBuilder } from './VWOBuilder';
|
|
10
|
+
import { SettingsModel } from './models/SettingsModel';
|
|
11
|
+
import { DebugLogMessageEnum } from './enums/logMessages/DebugLogMessageEnum';
|
|
12
|
+
|
|
13
|
+
import { ErrorLogMessageEnum } from './enums/logMessages/ErrorLogMessageEnum';
|
|
14
|
+
import { VariableModel } from './models/VariableModel';
|
|
15
|
+
import { SettingsSchema } from './models/schemas/SettingsSchemaValidation';
|
|
16
|
+
import { dynamic } from './types/common';
|
|
17
|
+
// import { BatchEventsQueue } from './services/batchEventsQueue';
|
|
18
|
+
|
|
19
|
+
import { isString, isObject, getType, isBoolean, isNumber, isUndefined, isArray, isNull } from './utils/DataTypeUtil';
|
|
20
|
+
import { buildMessage } from './utils/LogMessageUtil';
|
|
21
|
+
import { addLInkedCampaignsToSettings } from './utils/FunctionUtil';
|
|
22
|
+
import { Deferred } from './utils/PromiseUtil';
|
|
23
|
+
import UrlService from './services/UrlService';
|
|
24
|
+
import { setVariationAllocation } from './utils/CampaignUtil';
|
|
25
|
+
import { CampaignModel } from './models/CampaignModel';
|
|
26
|
+
import HooksManager from './services/HooksManager';
|
|
27
|
+
|
|
28
|
+
interface IVWOClient {
|
|
29
|
+
// readonly apiKey: string;
|
|
30
|
+
readonly options?: any;
|
|
31
|
+
settings: SettingsModel;
|
|
32
|
+
// vwoProvider: VWOBuilder;
|
|
33
|
+
|
|
34
|
+
// onceReady(): Promise<Record<string, dynamic>>;
|
|
35
|
+
|
|
36
|
+
// getSettings(force: boolean): SettingsModel | Promise<SettingsModel>;
|
|
37
|
+
|
|
38
|
+
getFlag(featureKey: string, context: any): Record<any, any>;
|
|
39
|
+
// getVariable(featureKey: string, variableSpecifier: dynamic, key?: string): Promise<VariableModel>;
|
|
40
|
+
// getVariables(featureKey: string): Promise<Array<VariableModel>>;
|
|
41
|
+
trackEvent(eventName: string, eventProperties: Record<string, dynamic>, context: any): Promise<Record<string, boolean>>;
|
|
42
|
+
setAttribute(attributeKey: string, attributeValue: string, context: any): void
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
export class VWOClient implements IVWOClient {
|
|
46
|
+
// readonly apiKey: string;
|
|
47
|
+
|
|
48
|
+
settings: SettingsModel;
|
|
49
|
+
storage: Storage;
|
|
50
|
+
|
|
51
|
+
constructor(
|
|
52
|
+
settings: SettingsModel,
|
|
53
|
+
options: any
|
|
54
|
+
// userId: string,
|
|
55
|
+
// properties: Record<string, dynamic>,
|
|
56
|
+
// dimensions: DimensionModel
|
|
57
|
+
) {
|
|
58
|
+
// this.vwoProvider = vwoProvider;
|
|
59
|
+
|
|
60
|
+
// LogManager.Instance.debug(`VWO Client initialized with userId:${userId}`);
|
|
61
|
+
this.options = options;
|
|
62
|
+
this.settings = new SettingsModel(settings);
|
|
63
|
+
UrlService.init({
|
|
64
|
+
collectionPrefix: this.settings.getCollectionPrefix(),
|
|
65
|
+
webServiceUrl: options?.webService?.url,
|
|
66
|
+
});
|
|
67
|
+
for (let i = 0; i < this.settings.getCampaigns().length; i++) {
|
|
68
|
+
let campaign = this.settings.getCampaigns()[i];
|
|
69
|
+
setVariationAllocation(campaign);
|
|
70
|
+
this.settings.getCampaigns()[i] = campaign;
|
|
71
|
+
}
|
|
72
|
+
addLInkedCampaignsToSettings(this.settings);
|
|
73
|
+
LogManager.Instance.info('VWO Client initialized');
|
|
74
|
+
return this;
|
|
75
|
+
}
|
|
76
|
+
options?: Record<string, any>;
|
|
77
|
+
|
|
78
|
+
/* onceReady(): Promise<SettingsModel> {
|
|
79
|
+
try {
|
|
80
|
+
const deferredObject = new Deferred();
|
|
81
|
+
|
|
82
|
+
this.vwoProvider.getSettings(false).then(settings => {
|
|
83
|
+
this.settings = cloneObject(settings);
|
|
84
|
+
this.settings = processSettings(this.settings);
|
|
85
|
+
|
|
86
|
+
LogManager.Instance.info('VWO Client ready for use');
|
|
87
|
+
|
|
88
|
+
deferredObject.resolve(settings);
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
return deferredObject.promise;
|
|
92
|
+
} catch (err) {
|
|
93
|
+
LogManager.Instance.error('VWO Client failed to be ready');
|
|
94
|
+
}
|
|
95
|
+
} */
|
|
96
|
+
|
|
97
|
+
/* setSettings(settings: Record<string, dynamic>): void {
|
|
98
|
+
const apiName = 'setSettings';
|
|
99
|
+
|
|
100
|
+
try {
|
|
101
|
+
if (!isObject(settings)) {
|
|
102
|
+
LogManager.Instance.debug(`settings passed to setSettings API is not of valid type. Got ${getType(settings)}`);
|
|
103
|
+
throw new TypeError('TypeError: settings should be an object');
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
this.vwoProvider.setSettings(settings);
|
|
107
|
+
} catch (err) {
|
|
108
|
+
LogManager.Instance.error(
|
|
109
|
+
buildMessage(ErrorLogMessageEnum.API_THROW_ERROR, {
|
|
110
|
+
apiName,
|
|
111
|
+
err
|
|
112
|
+
})
|
|
113
|
+
);
|
|
114
|
+
}
|
|
115
|
+
} */
|
|
116
|
+
|
|
117
|
+
/* getSettings(force = false): Promise<SettingsModel> {
|
|
118
|
+
const apiName = 'getSettings';
|
|
119
|
+
const deferredObject = new Deferred();
|
|
120
|
+
|
|
121
|
+
try {
|
|
122
|
+
if (!isBoolean(force)) {
|
|
123
|
+
LogManager.Instance.debug(`force passed to getSettings API is not of valid type. Got ${getType(force)}`);
|
|
124
|
+
throw new TypeError('TypeError: force should be a boolean');
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
this.vwoProvider.getSettings(force).then(() => {
|
|
128
|
+
deferredObject.resolve(this.vwoProvider.originalSettings);
|
|
129
|
+
});
|
|
130
|
+
} catch (err) {
|
|
131
|
+
LogManager.Instance.error(
|
|
132
|
+
buildMessage(ErrorLogMessageEnum.API_THROW_ERROR, {
|
|
133
|
+
apiName,
|
|
134
|
+
err
|
|
135
|
+
})
|
|
136
|
+
);
|
|
137
|
+
|
|
138
|
+
deferredObject.resolve(null);
|
|
139
|
+
}
|
|
140
|
+
return deferredObject.promise;
|
|
141
|
+
} */
|
|
142
|
+
|
|
143
|
+
getFlag(featureKey: string, context: any): Record<any, any> {
|
|
144
|
+
const apiName = 'getFlag';
|
|
145
|
+
const deferredObject = new Deferred();
|
|
146
|
+
const hookManager = new HooksManager(this.options);
|
|
147
|
+
try {
|
|
148
|
+
LogManager.Instance.debug(
|
|
149
|
+
buildMessage(DebugLogMessageEnum.API_CALLED, {
|
|
150
|
+
apiName,
|
|
151
|
+
}),
|
|
152
|
+
);
|
|
153
|
+
|
|
154
|
+
if (!isString(featureKey)) {
|
|
155
|
+
LogManager.Instance.debug(
|
|
156
|
+
`featureKey passed to ${apiName} API is not of valid type. Got ${getType(featureKey)}`,
|
|
157
|
+
);
|
|
158
|
+
throw new TypeError('TypeError: variableSpecifier should be a string');
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
if (!this.settings) {
|
|
162
|
+
//|| !new SettingsSchema().isSettingsValid(this.settings)) {
|
|
163
|
+
LogManager.Instance.debug(`settings are not valid. Got ${getType(this.settings)}`);
|
|
164
|
+
throw new Error('Invalid Settings');
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
if (!context?.user?.id) {
|
|
168
|
+
LogManager.Instance.error('User ID is not valid. Not able to get flag');
|
|
169
|
+
throw new Error('Invalid context');
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
new FlagApi().get(featureKey, this.settings, context, hookManager).then((data: any) => {
|
|
173
|
+
deferredObject.resolve(data);
|
|
174
|
+
});
|
|
175
|
+
|
|
176
|
+
return deferredObject.promise;
|
|
177
|
+
} catch (err) {
|
|
178
|
+
LogManager.Instance.error(
|
|
179
|
+
buildMessage(ErrorLogMessageEnum.API_THROW_ERROR, {
|
|
180
|
+
apiName,
|
|
181
|
+
err,
|
|
182
|
+
}),
|
|
183
|
+
);
|
|
184
|
+
|
|
185
|
+
return deferredObject.resolve({});
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
// getVariable(variableSpecifier: dynamic, key?: string, featureKey = ''): Promise<VariableModel> {
|
|
190
|
+
// const apiName = 'getVariable';
|
|
191
|
+
// const deferredObject = new Deferred();
|
|
192
|
+
|
|
193
|
+
// try {
|
|
194
|
+
// LogManager.Instance.debug(
|
|
195
|
+
// buildMessage(DebugLogMessageEnum.API_CALLED, {
|
|
196
|
+
// apiName,
|
|
197
|
+
// }),
|
|
198
|
+
// );
|
|
199
|
+
|
|
200
|
+
// if (!(isString(variableSpecifier) || isNumber(variableSpecifier))) {
|
|
201
|
+
// LogManager.Instance.debug(
|
|
202
|
+
// `variableSpecifier passed to getVariable API is not of valid type. Got ${getType(variableSpecifier)}`,
|
|
203
|
+
// );
|
|
204
|
+
// throw new TypeError('TypeError: variableSpecifier should be a string|number');
|
|
205
|
+
// }
|
|
206
|
+
|
|
207
|
+
// if (!this.settings || !new SettingsSchema().isSettingsValid(this.settings)) {
|
|
208
|
+
// LogManager.Instance.debug(`settings are not valid. Got ${getType(this.settings)}`);
|
|
209
|
+
// throw new Error('Invalid Settings');
|
|
210
|
+
// }
|
|
211
|
+
|
|
212
|
+
// // new VariableApi()
|
|
213
|
+
// // .get(featureKey, variableSpecifier, key || null, this.settings, this.user.getUser())
|
|
214
|
+
// // .then((variable: VariableModel) => {
|
|
215
|
+
// // deferredObject.resolve(variable);
|
|
216
|
+
// // });
|
|
217
|
+
|
|
218
|
+
// return deferredObject.promise;
|
|
219
|
+
// } catch (err) {
|
|
220
|
+
// LogManager.Instance.error(
|
|
221
|
+
// buildMessage(ErrorLogMessageEnum.API_THROW_ERROR, {
|
|
222
|
+
// apiName,
|
|
223
|
+
// err,
|
|
224
|
+
// }),
|
|
225
|
+
// );
|
|
226
|
+
|
|
227
|
+
// return deferredObject.resolve(null);
|
|
228
|
+
// }
|
|
229
|
+
// }
|
|
230
|
+
|
|
231
|
+
// getVariables(featureKey = ''): Promise<Array<VariableModel>> {
|
|
232
|
+
// const apiName = 'getVariables';
|
|
233
|
+
// const deferredObject = new Deferred();
|
|
234
|
+
|
|
235
|
+
// try {
|
|
236
|
+
// LogManager.Instance.debug(
|
|
237
|
+
// buildMessage(DebugLogMessageEnum.API_CALLED, {
|
|
238
|
+
// apiName,
|
|
239
|
+
// }),
|
|
240
|
+
// );
|
|
241
|
+
|
|
242
|
+
// if (!this.settings || !new SettingsSchema().isSettingsValid(this.settings)) {
|
|
243
|
+
// LogManager.Instance.debug(`settings are not valid. Got ${getType(this.settings)}`);
|
|
244
|
+
// throw new Error('Invalid Settings');
|
|
245
|
+
// }
|
|
246
|
+
|
|
247
|
+
// // new VariableApi().getAll(featureKey, this.settings, this.user.getUser()).then(variableList => {
|
|
248
|
+
// // deferredObject.resolve(variableList);
|
|
249
|
+
// // });
|
|
250
|
+
|
|
251
|
+
// return deferredObject.promise;
|
|
252
|
+
// } catch (err) {
|
|
253
|
+
// LogManager.Instance.error(
|
|
254
|
+
// buildMessage(ErrorLogMessageEnum.API_THROW_ERROR, {
|
|
255
|
+
// apiName,
|
|
256
|
+
// err,
|
|
257
|
+
// }),
|
|
258
|
+
// );
|
|
259
|
+
|
|
260
|
+
// return deferredObject.resolve([]);
|
|
261
|
+
// }
|
|
262
|
+
// }
|
|
263
|
+
|
|
264
|
+
trackEvent(
|
|
265
|
+
eventName: string,
|
|
266
|
+
eventProperties: Record<string, dynamic> = {},
|
|
267
|
+
context: any,
|
|
268
|
+
): Promise<Record<string, boolean>> {
|
|
269
|
+
const apiName = 'trackEvent';
|
|
270
|
+
const hookManager = new HooksManager(this.options);
|
|
271
|
+
try {
|
|
272
|
+
LogManager.Instance.debug(
|
|
273
|
+
buildMessage(DebugLogMessageEnum.API_CALLED, {
|
|
274
|
+
apiName,
|
|
275
|
+
}),
|
|
276
|
+
);
|
|
277
|
+
|
|
278
|
+
if (!isString(eventName)) {
|
|
279
|
+
LogManager.Instance.debug(`eventName passed to track API is not of valid type. Got ${getType(eventName)}`);
|
|
280
|
+
throw new TypeError('TypeError: eventName should be a string');
|
|
281
|
+
}
|
|
282
|
+
|
|
283
|
+
if (!isObject(eventProperties)) {
|
|
284
|
+
LogManager.Instance.debug(
|
|
285
|
+
`eventProperties passed to track API is not of valid type. Got ${getType(eventProperties)}`,
|
|
286
|
+
);
|
|
287
|
+
// throw new TypeError('TypeError: eventProperties should be an object');
|
|
288
|
+
}
|
|
289
|
+
|
|
290
|
+
if (!this.settings) {
|
|
291
|
+
// || !new SettingsSchema().isSettingsValid(this.settings)) {
|
|
292
|
+
LogManager.Instance.debug(`settings are not valid. Got ${getType(this.settings)}`);
|
|
293
|
+
throw new Error('Invalid Settings');
|
|
294
|
+
}
|
|
295
|
+
if (!context?.user?.id) {
|
|
296
|
+
LogManager.Instance.error('User ID is not valid. Not able to track event');
|
|
297
|
+
throw new Error('Invalid context');
|
|
298
|
+
}
|
|
299
|
+
|
|
300
|
+
return new TrackApi().track(this.settings, eventName, eventProperties, context, hookManager);
|
|
301
|
+
} catch (err) {
|
|
302
|
+
LogManager.Instance.error(
|
|
303
|
+
buildMessage(ErrorLogMessageEnum.API_THROW_ERROR, {
|
|
304
|
+
apiName,
|
|
305
|
+
err,
|
|
306
|
+
}),
|
|
307
|
+
);
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
|
|
311
|
+
setAttribute(attributeKey: string, attributeValue: string, context: any): void {
|
|
312
|
+
if (!isString(attributeKey) || !isString(attributeValue) || !isString(context?.user?.id)) {
|
|
313
|
+
LogManager.Instance.error(
|
|
314
|
+
`Paramters passed to setAttribute API are not valid. Please check`,
|
|
315
|
+
);
|
|
316
|
+
|
|
317
|
+
return;
|
|
318
|
+
}
|
|
319
|
+
new SetAttributeApi().setAttribute(this.settings, attributeKey, attributeValue, context);
|
|
320
|
+
}
|
|
321
|
+
}
|