perimeterx-js-core 0.24.4 → 0.26.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/lib/cjs/action/Action.js +15 -0
- package/lib/cjs/action/ActionPriorityOrder.js +4 -0
- package/lib/cjs/action/utils.js +20 -0
- package/lib/cjs/activities/HttpActivityClient.js +61 -1
- package/lib/cjs/activities/HttpBatchedActivityClient.js +7 -0
- package/lib/cjs/activities/utils.js +128 -62
- package/lib/cjs/additional_activity_handler/AdditionalActivityHandlerUtils.js +6 -0
- package/lib/cjs/blocker/BlockerBase.js +14 -0
- package/lib/cjs/blocker/JsonBlockerBase.js +5 -0
- package/lib/cjs/blocker/utils.js +13 -0
- package/lib/cjs/config/ConfigurationBase.js +26 -6
- package/lib/cjs/config/index.js +0 -1
- package/lib/cjs/config/remote_config/RemoteConfigUtils.js +12 -2
- package/lib/cjs/config/remote_config/index.js +2 -2
- package/lib/cjs/config/remote_config/manager/DefaultRemoteConfigManager.js +191 -0
- package/lib/cjs/config/remote_config/manager/index.js +18 -0
- package/lib/cjs/config/remote_config/model/index.js +1 -1
- package/lib/cjs/config/remote_config/update_parser/DefaultNotifyRemoteConfigUpdateParser.js +139 -0
- package/lib/cjs/config/remote_config/update_parser/index.js +18 -0
- package/lib/cjs/context/DefaultContext.js +26 -4
- package/lib/cjs/context/SerializedContext.js +6 -1
- package/lib/cjs/context/interfaces/RemoteConfigUpdateData.js +2 -0
- package/lib/cjs/context/interfaces/index.js +1 -0
- package/lib/cjs/enforcer/EnforcerBase.js +77 -32
- package/lib/cjs/enforcer/IPostEnforcer.js +2 -0
- package/lib/cjs/enforcer/index.js +1 -0
- package/lib/cjs/enforcer/utils.js +34 -38
- package/lib/cjs/{phase/flow → flow}/EndEnforcerFlow.js +13 -7
- package/lib/cjs/{phase/flow → flow}/EnforceFlow.js +10 -15
- package/lib/cjs/{phase/flow → flow}/FilterFlow.js +12 -12
- package/lib/cjs/flow/Flow.js +60 -0
- package/lib/cjs/flow/IFlow.js +2 -0
- package/lib/cjs/{phase/flow → flow}/PostEnforceFlow.js +6 -6
- package/lib/cjs/{phase/flow → flow}/index.js +2 -0
- package/lib/cjs/index.js +1 -0
- package/lib/cjs/phase/impl/AdditionalActivityHandlerPhase.js +3 -0
- package/lib/cjs/phase/impl/ClearLogsPhase.js +3 -0
- package/lib/cjs/phase/impl/CompositePhase.js +9 -0
- package/lib/cjs/phase/impl/CreateBlockResponsePhase.js +16 -0
- package/lib/cjs/phase/impl/DecideActionPhase.js +11 -0
- package/lib/cjs/phase/impl/EnrichContextFromRequestPhase.js +13 -9
- package/lib/cjs/phase/impl/EnrichContextFromResponsePhase.js +4 -0
- package/lib/cjs/phase/impl/FilterPhase.js +4 -0
- package/lib/cjs/phase/impl/FirstPartyPhase.js +5 -0
- package/lib/cjs/phase/impl/IdentifyRemoteConfigNotifyRequestPhase.js +80 -0
- package/lib/cjs/phase/impl/IdentifyTelemetryRequestPhase.js +5 -0
- package/lib/cjs/phase/impl/ModifyIncomingRequestPhase.js +5 -0
- package/lib/cjs/phase/impl/ModifyOutgoingResponsePhase.js +5 -0
- package/lib/cjs/phase/impl/ParseTokenPhase.js +14 -7
- package/lib/cjs/phase/impl/PreflightPhase.js +4 -0
- package/lib/cjs/phase/impl/RiskApiPhase.js +18 -7
- package/lib/cjs/phase/impl/{SendAsyncActivitiesOnResponsePhase.js → SendAsyncActivitiesPhase.js} +15 -8
- package/lib/cjs/phase/impl/SendLogsPhase.js +3 -0
- package/lib/cjs/phase/impl/SendTelemetryActivityPhase.js +3 -0
- package/lib/cjs/phase/impl/UpdateRemoteConfigPhase.js +10 -14
- package/lib/cjs/phase/impl/index.js +3 -3
- package/lib/cjs/phase/index.js +0 -1
- package/lib/cjs/products/credential_intelligence/endpoint/login_successful/BodyLoginSuccessfulParser.js +1 -1
- package/lib/cjs/products/credential_intelligence/endpoint/login_successful/LoginSuccessfulParserFactory.js +5 -2
- package/lib/cjs/products/credential_intelligence/endpoint/matcher/CredentialIntelligenceEndpointMatcherFactory.js +3 -1
- package/lib/cjs/risk_api/client/GetRiskApiClientV2.js +80 -0
- package/lib/cjs/risk_api/client/PostRiskApiClientV2.js +3 -3
- package/lib/cjs/risk_api/client/PostRiskApiClientV3.js +3 -3
- package/lib/cjs/risk_api/client/abstract/IRiskApiClient.js +2 -0
- package/lib/cjs/risk_api/client/abstract/PostRiskApiClientBase.js +43 -0
- package/lib/cjs/risk_api/client/{PostRiskApiClientBase.js → abstract/RiskApiClientBase.js} +22 -69
- package/lib/cjs/risk_api/client/abstract/index.js +19 -0
- package/lib/cjs/risk_api/client/index.js +2 -2
- package/lib/cjs/risk_api/index.js +1 -0
- package/lib/cjs/risk_api/model/GetRiskRequestHeaders.js +185 -0
- package/lib/cjs/risk_api/model/GetRiskResponseHeaders.js +16 -0
- package/lib/cjs/risk_api/model/index.js +2 -0
- package/lib/cjs/{phase/impl/SendAsyncActivitiesOnRequestPhase.js → risk_api/risk_response/PostRiskResponseBase.js} +26 -30
- package/lib/cjs/risk_api/risk_response/RiskResponseBase.js +11 -8
- package/lib/cjs/risk_api/risk_response/index.js +1 -0
- package/lib/cjs/risk_api/risk_response/serialize/SerializedRiskResponse.js +5 -1
- package/lib/cjs/risk_api/risk_response/v2/GetRiskResponseV2.js +80 -0
- package/lib/cjs/risk_api/risk_response/v2/{DefaultRiskResponseV2.js → PostRiskResponseV2.js} +10 -10
- package/lib/cjs/risk_api/risk_response/v2/index.js +2 -1
- package/lib/cjs/risk_api/risk_response/v3/{DefaultRiskResponseV3.js → PostRiskResponseV3.js} +10 -10
- package/lib/cjs/risk_api/risk_response/v3/index.js +1 -1
- package/lib/cjs/risk_api/utils.js +36 -0
- package/lib/cjs/telemetry/DefaultTelemetry.js +12 -9
- package/lib/cjs/utils/constants.js +1 -1
- package/lib/cjs/utils/utils.js +1 -19
- package/lib/esm/action/Action.js +15 -0
- package/lib/esm/action/ActionPriorityOrder.js +4 -0
- package/lib/esm/action/utils.js +20 -0
- package/lib/esm/activities/HttpActivityClient.js +61 -1
- package/lib/esm/activities/HttpBatchedActivityClient.js +7 -0
- package/lib/esm/activities/utils.js +128 -63
- package/lib/esm/additional_activity_handler/AdditionalActivityHandlerUtils.js +6 -0
- package/lib/esm/blocker/BlockerBase.js +14 -0
- package/lib/esm/blocker/JsonBlockerBase.js +5 -0
- package/lib/esm/blocker/utils.js +13 -0
- package/lib/esm/config/ConfigurationBase.js +23 -8
- package/lib/esm/config/index.js +0 -1
- package/lib/esm/config/remote_config/RemoteConfigUtils.js +11 -2
- package/lib/esm/config/remote_config/index.js +2 -2
- package/lib/esm/config/remote_config/manager/DefaultRemoteConfigManager.js +87 -0
- package/lib/esm/config/remote_config/manager/index.js +2 -0
- package/lib/esm/config/remote_config/model/index.js +1 -1
- package/lib/esm/config/remote_config/update_parser/DefaultNotifyRemoteConfigUpdateParser.js +60 -0
- package/lib/esm/config/remote_config/update_parser/index.js +2 -0
- package/lib/esm/context/DefaultContext.js +23 -6
- package/lib/esm/context/SerializedContext.js +7 -2
- package/lib/esm/context/interfaces/RemoteConfigUpdateData.js +1 -0
- package/lib/esm/context/interfaces/index.js +1 -0
- package/lib/esm/enforcer/EnforcerBase.js +46 -6
- package/lib/esm/enforcer/IPostEnforcer.js +1 -0
- package/lib/esm/enforcer/index.js +1 -0
- package/lib/esm/enforcer/utils.js +32 -17
- package/lib/esm/flow/EndEnforcerFlow.js +18 -0
- package/lib/esm/flow/EnforceFlow.js +14 -0
- package/lib/esm/{phase/flow → flow}/FilterFlow.js +8 -8
- package/lib/esm/flow/Flow.js +56 -0
- package/lib/esm/flow/IFlow.js +1 -0
- package/lib/esm/flow/PostEnforceFlow.js +10 -0
- package/lib/esm/{phase/flow → flow}/index.js +2 -0
- package/lib/esm/index.js +1 -0
- package/lib/esm/logger/LoggerBase.js +1 -1
- package/lib/esm/phase/impl/AdditionalActivityHandlerPhase.js +3 -0
- package/lib/esm/phase/impl/ClearLogsPhase.js +3 -0
- package/lib/esm/phase/impl/CompositePhase.js +9 -0
- package/lib/esm/phase/impl/CreateBlockResponsePhase.js +16 -1
- package/lib/esm/phase/impl/DecideActionPhase.js +11 -0
- package/lib/esm/phase/impl/EnrichContextFromRequestPhase.js +9 -0
- package/lib/esm/phase/impl/EnrichContextFromResponsePhase.js +4 -0
- package/lib/esm/phase/impl/FilterPhase.js +4 -0
- package/lib/esm/phase/impl/FirstPartyPhase.js +5 -0
- package/lib/esm/phase/impl/IdentifyRemoteConfigNotifyRequestPhase.js +29 -0
- package/lib/esm/phase/impl/IdentifyTelemetryRequestPhase.js +5 -0
- package/lib/esm/phase/impl/ModifyIncomingRequestPhase.js +5 -0
- package/lib/esm/phase/impl/ModifyOutgoingResponsePhase.js +5 -0
- package/lib/esm/phase/impl/ParseTokenPhase.js +15 -8
- package/lib/esm/phase/impl/PreflightPhase.js +4 -0
- package/lib/esm/phase/impl/RiskApiPhase.js +19 -8
- package/lib/esm/phase/impl/SendAsyncActivitiesPhase.js +16 -0
- package/lib/esm/phase/impl/SendLogsPhase.js +3 -0
- package/lib/esm/phase/impl/SendTelemetryActivityPhase.js +3 -0
- package/lib/esm/phase/impl/UpdateRemoteConfigPhase.js +9 -13
- package/lib/esm/phase/impl/index.js +3 -3
- package/lib/esm/phase/index.js +0 -1
- package/lib/esm/products/credential_intelligence/endpoint/login_successful/BodyLoginSuccessfulParser.js +1 -1
- package/lib/esm/products/credential_intelligence/endpoint/login_successful/LoginSuccessfulParserFactory.js +5 -2
- package/lib/esm/products/credential_intelligence/endpoint/matcher/CredentialIntelligenceEndpointMatcherFactory.js +2 -1
- package/lib/esm/risk_api/client/GetRiskApiClientV2.js +57 -0
- package/lib/esm/risk_api/client/PostRiskApiClientV2.js +3 -3
- package/lib/esm/risk_api/client/PostRiskApiClientV3.js +3 -3
- package/lib/esm/risk_api/client/abstract/IRiskApiClient.js +1 -0
- package/lib/esm/risk_api/client/abstract/PostRiskApiClientBase.js +18 -0
- package/lib/esm/risk_api/client/{PostRiskApiClientBase.js → abstract/RiskApiClientBase.js} +10 -49
- package/lib/esm/risk_api/client/abstract/index.js +3 -0
- package/lib/esm/risk_api/client/index.js +2 -2
- package/lib/esm/risk_api/index.js +1 -0
- package/lib/esm/risk_api/model/GetRiskRequestHeaders.js +182 -0
- package/lib/esm/risk_api/model/GetRiskResponseHeaders.js +13 -0
- package/lib/esm/risk_api/model/index.js +2 -0
- package/lib/esm/risk_api/risk_response/PostRiskResponseBase.js +6 -0
- package/lib/esm/risk_api/risk_response/RiskResponseBase.js +5 -1
- package/lib/esm/risk_api/risk_response/index.js +1 -0
- package/lib/esm/risk_api/risk_response/serialize/SerializedRiskResponse.js +5 -1
- package/lib/esm/risk_api/risk_response/v2/GetRiskResponseV2.js +52 -0
- package/lib/esm/risk_api/risk_response/v2/{DefaultRiskResponseV2.js → PostRiskResponseV2.js} +2 -2
- package/lib/esm/risk_api/risk_response/v2/index.js +2 -1
- package/lib/esm/risk_api/risk_response/v3/{DefaultRiskResponseV3.js → PostRiskResponseV3.js} +2 -2
- package/lib/esm/risk_api/risk_response/v3/index.js +1 -1
- package/lib/esm/risk_api/utils.js +23 -0
- package/lib/esm/telemetry/DefaultTelemetry.js +13 -10
- package/lib/esm/utils/constants.js +1 -1
- package/lib/esm/utils/utils.js +0 -16
- package/lib/types/action/Action.d.ts +15 -0
- package/lib/types/action/ActionData.d.ts +3 -0
- package/lib/types/action/ActionPriorityOrder.d.ts +4 -0
- package/lib/types/action/Decision.d.ts +9 -0
- package/lib/types/action/ProductAction.d.ts +3 -0
- package/lib/types/action/utils.d.ts +20 -0
- package/lib/types/activities/HttpActivityClient.d.ts +57 -1
- package/lib/types/activities/HttpBatchedActivityClient.d.ts +7 -0
- package/lib/types/activities/IActivityClient.d.ts +4 -1
- package/lib/types/activities/model/AsyncActivity.d.ts +3 -0
- package/lib/types/activities/model/AsyncActivityDetails.d.ts +12 -0
- package/lib/types/activities/model/CommonActivityDetails.d.ts +3 -0
- package/lib/types/activities/utils.d.ts +14 -0
- package/lib/types/additional_activity_handler/AdditionalActivityHandlerUtils.d.ts +6 -0
- package/lib/types/blocker/BlockerBase.d.ts +21 -0
- package/lib/types/blocker/IBlocker.d.ts +8 -0
- package/lib/types/blocker/IConditionalBlocker.d.ts +4 -0
- package/lib/types/blocker/JsonBlockerBase.d.ts +12 -0
- package/lib/types/blocker/model/BlockData.d.ts +3 -0
- package/lib/types/blocker/utils.d.ts +13 -0
- package/lib/types/config/ConfigurationBase.d.ts +25 -2
- package/lib/types/config/IConfiguration.d.ts +7 -2
- package/lib/types/config/index.d.ts +0 -1
- package/lib/types/config/params/CoreConfigurationParams.d.ts +22 -1
- package/lib/types/config/params/RemoteConfigurationParams.d.ts +3 -0
- package/lib/types/config/params/StaticConfigurationParams.d.ts +3 -0
- package/lib/types/config/remote_config/RemoteConfigUtils.d.ts +2 -1
- package/lib/types/config/remote_config/index.d.ts +2 -2
- package/lib/types/config/remote_config/manager/DefaultRemoteConfigManager.d.ts +23 -0
- package/lib/types/config/remote_config/manager/IRemoteConfigManager.d.ts +7 -0
- package/lib/types/config/remote_config/manager/index.d.ts +2 -0
- package/lib/types/config/remote_config/model/RemoteConfigNotifyRequestPayload.d.ts +3 -0
- package/lib/types/config/remote_config/model/index.d.ts +1 -1
- package/lib/types/config/remote_config/service_client/HttpRemoteConfigServiceClient.d.ts +2 -2
- package/lib/types/config/remote_config/service_client/IRemoteConfigServiceClient.d.ts +2 -2
- package/lib/types/config/remote_config/storage_client/IRemoteConfigStorageClient.d.ts +1 -1
- package/lib/types/config/remote_config/update_parser/DefaultNotifyRemoteConfigUpdateParser.d.ts +22 -0
- package/lib/types/config/remote_config/update_parser/IRemoteConfigUpdateParser.d.ts +5 -0
- package/lib/types/config/remote_config/update_parser/index.d.ts +2 -0
- package/lib/types/context/ContextJson.d.ts +6 -2
- package/lib/types/context/DefaultContext.d.ts +9 -3
- package/lib/types/context/SerializedContext.d.ts +7 -2
- package/lib/types/context/interfaces/IContext.d.ts +4 -3
- package/lib/types/context/interfaces/RemoteConfigUpdateData.d.ts +4 -0
- package/lib/types/context/interfaces/index.d.ts +1 -0
- package/lib/types/custom_parameters/CustomParameters.d.ts +3 -0
- package/lib/types/enforcer/EnforcerBase.d.ts +50 -13
- package/lib/types/enforcer/EnforcerOptions.d.ts +3 -2
- package/lib/types/enforcer/IEnforcer.d.ts +1 -2
- package/lib/types/enforcer/IPostEnforcer.d.ts +3 -0
- package/lib/types/enforcer/index.d.ts +1 -0
- package/lib/types/enforcer/utils.d.ts +7 -1
- package/lib/types/first_party/IFirstParty.d.ts +1 -1
- package/lib/types/flow/EndEnforcerFlow.d.ts +8 -0
- package/lib/types/flow/EnforceFlow.d.ts +8 -0
- package/lib/types/flow/FilterFlow.d.ts +11 -0
- package/lib/types/flow/Flow.d.ts +13 -0
- package/lib/types/flow/IFlow.d.ts +57 -0
- package/lib/types/flow/PostEnforceFlow.d.ts +6 -0
- package/lib/types/{phase/flow → flow}/index.d.ts +2 -0
- package/lib/types/index.d.ts +1 -0
- package/lib/types/logger/ILogger.d.ts +4 -0
- package/lib/types/logger/LoggerBase.d.ts +1 -1
- package/lib/types/phase/IPhase.d.ts +9 -0
- package/lib/types/phase/PhaseResult.d.ts +11 -0
- package/lib/types/phase/impl/AdditionalActivityHandlerPhase.d.ts +3 -0
- package/lib/types/phase/impl/ClearLogsPhase.d.ts +3 -0
- package/lib/types/phase/impl/CompositePhase.d.ts +9 -0
- package/lib/types/phase/impl/CreateBlockResponsePhase.d.ts +11 -1
- package/lib/types/phase/impl/DecideActionPhase.d.ts +11 -0
- package/lib/types/phase/impl/EnrichContextFromRequestPhase.d.ts +9 -0
- package/lib/types/phase/impl/EnrichContextFromResponsePhase.d.ts +4 -0
- package/lib/types/phase/impl/FilterPhase.d.ts +4 -0
- package/lib/types/phase/impl/FirstPartyPhase.d.ts +5 -0
- package/lib/types/phase/impl/IdentifyRemoteConfigNotifyRequestPhase.d.ts +14 -0
- package/lib/types/phase/impl/IdentifyTelemetryRequestPhase.d.ts +5 -0
- package/lib/types/phase/impl/ModifyIncomingRequestPhase.d.ts +5 -0
- package/lib/types/phase/impl/ModifyOutgoingResponsePhase.d.ts +5 -0
- package/lib/types/phase/impl/ParseTokenPhase.d.ts +3 -0
- package/lib/types/phase/impl/PreflightPhase.d.ts +4 -0
- package/lib/types/phase/impl/RiskApiPhase.d.ts +5 -0
- package/lib/types/phase/impl/{SendAsyncActivitiesOnResponsePhase.d.ts → SendAsyncActivitiesPhase.d.ts} +5 -2
- package/lib/types/phase/impl/SendLogsPhase.d.ts +3 -0
- package/lib/types/phase/impl/SendTelemetryActivityPhase.d.ts +3 -0
- package/lib/types/phase/impl/UpdateRemoteConfigPhase.d.ts +6 -5
- package/lib/types/phase/impl/index.d.ts +3 -3
- package/lib/types/phase/index.d.ts +0 -1
- package/lib/types/products/credential_intelligence/endpoint/CredentialEndpointConfiguration.d.ts +1 -1
- package/lib/types/products/credential_intelligence/endpoint/login_successful/BodyLoginSuccessfulParser.d.ts +1 -1
- package/lib/types/products/interfaces/IProduct.d.ts +28 -0
- package/lib/types/products/interfaces/ProductDataType.d.ts +1 -1
- package/lib/types/risk_api/client/GetRiskApiClientV2.d.ts +15 -0
- package/lib/types/risk_api/client/PostRiskApiClientV2.d.ts +1 -1
- package/lib/types/risk_api/client/PostRiskApiClientV3.d.ts +2 -2
- package/lib/types/risk_api/client/{IRiskApiClient.d.ts → abstract/IRiskApiClient.d.ts} +1 -1
- package/lib/types/risk_api/client/abstract/PostRiskApiClientBase.d.ts +8 -0
- package/lib/types/risk_api/client/abstract/RiskApiClientBase.d.ts +26 -0
- package/lib/types/risk_api/client/abstract/index.d.ts +3 -0
- package/lib/types/risk_api/client/index.d.ts +2 -2
- package/lib/types/risk_api/index.d.ts +1 -0
- package/lib/types/risk_api/model/GetRiskRequestHeaders.d.ts +17 -0
- package/lib/types/risk_api/model/GetRiskResponseHeaders.d.ts +3 -0
- package/lib/types/risk_api/model/index.d.ts +2 -0
- package/lib/types/risk_api/risk_response/IRiskResponse.d.ts +2 -0
- package/lib/types/risk_api/risk_response/PostRiskResponseBase.d.ts +7 -0
- package/lib/types/risk_api/risk_response/RiskResponseBase.d.ts +3 -1
- package/lib/types/risk_api/risk_response/index.d.ts +1 -0
- package/lib/types/risk_api/risk_response/serialize/SerializedRiskResponse.d.ts +1 -0
- package/lib/types/risk_api/risk_response/v2/GetRiskResponseV2.d.ts +11 -0
- package/lib/types/risk_api/risk_response/v2/{DefaultRiskResponseV2.d.ts → PostRiskResponseV2.d.ts} +2 -2
- package/lib/types/risk_api/risk_response/v2/index.d.ts +2 -1
- package/lib/types/risk_api/risk_response/v3/{DefaultRiskResponseV3.d.ts → PostRiskResponseV3.d.ts} +2 -2
- package/lib/types/risk_api/risk_response/v3/index.d.ts +1 -1
- package/lib/types/risk_api/utils.d.ts +69 -0
- package/lib/types/telemetry/model/TelemetryActivity.d.ts +1 -1
- package/lib/types/utils/constants.d.ts +1 -1
- package/lib/types/utils/utils.d.ts +0 -5
- package/package.json +13 -13
- package/lib/cjs/config/ConfigurationBuilderBase.js +0 -135
- package/lib/cjs/config/remote_config/DefaultRemoteConfigUpdater.js +0 -200
- package/lib/esm/config/ConfigurationBuilderBase.js +0 -66
- package/lib/esm/config/remote_config/DefaultRemoteConfigUpdater.js +0 -99
- package/lib/esm/phase/flow/EndEnforcerFlow.js +0 -12
- package/lib/esm/phase/flow/EnforceFlow.js +0 -18
- package/lib/esm/phase/flow/PostEnforceFlow.js +0 -10
- package/lib/esm/phase/impl/SendAsyncActivitiesOnRequestPhase.js +0 -16
- package/lib/esm/phase/impl/SendAsyncActivitiesOnResponsePhase.js +0 -10
- package/lib/types/config/ConfigurationBuilderBase.d.ts +0 -13
- package/lib/types/config/remote_config/DefaultRemoteConfigUpdater.d.ts +0 -34
- package/lib/types/config/remote_config/IRemoteConfigUpdater.d.ts +0 -6
- package/lib/types/config/remote_config/model/RemoteConfigUpdateRequestData.d.ts +0 -3
- package/lib/types/phase/flow/EndEnforcerFlow.d.ts +0 -8
- package/lib/types/phase/flow/EnforceFlow.d.ts +0 -8
- package/lib/types/phase/flow/FilterFlow.d.ts +0 -11
- package/lib/types/phase/flow/PostEnforceFlow.d.ts +0 -6
- package/lib/types/phase/impl/SendAsyncActivitiesOnRequestPhase.d.ts +0 -10
- package/lib/types/risk_api/client/PostRiskApiClientBase.d.ts +0 -40
- /package/lib/cjs/config/remote_config/{IRemoteConfigUpdater.js → manager/IRemoteConfigManager.js} +0 -0
- /package/lib/cjs/config/remote_config/model/{RemoteConfigUpdateRequestData.js → RemoteConfigNotifyRequestPayload.js} +0 -0
- /package/lib/cjs/{risk_api/client/IRiskApiClient.js → config/remote_config/update_parser/IRemoteConfigUpdateParser.js} +0 -0
- /package/lib/esm/config/remote_config/{IRemoteConfigUpdater.js → manager/IRemoteConfigManager.js} +0 -0
- /package/lib/esm/config/remote_config/model/{RemoteConfigUpdateRequestData.js → RemoteConfigNotifyRequestPayload.js} +0 -0
- /package/lib/esm/{risk_api/client/IRiskApiClient.js → config/remote_config/update_parser/IRemoteConfigUpdateParser.js} +0 -0
|
@@ -18,6 +18,6 @@ __exportStar(require("./constants.js"), exports);
|
|
|
18
18
|
__exportStar(require("./model/index.js"), exports);
|
|
19
19
|
__exportStar(require("./service_client/index.js"), exports);
|
|
20
20
|
__exportStar(require("./storage_client/index.js"), exports);
|
|
21
|
-
__exportStar(require("./
|
|
22
|
-
__exportStar(require("./
|
|
21
|
+
__exportStar(require("./manager/index.js"), exports);
|
|
22
|
+
__exportStar(require("./update_parser/index.js"), exports);
|
|
23
23
|
__exportStar(require("./RemoteConfigUtils.js"), exports);
|
|
@@ -0,0 +1,191 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
12
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
13
|
+
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
14
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
15
|
+
function step(op) {
|
|
16
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
17
|
+
while (g && (g = 0, op[0] && (_ = 0)), _) try {
|
|
18
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
19
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
20
|
+
switch (op[0]) {
|
|
21
|
+
case 0: case 1: t = op; break;
|
|
22
|
+
case 4: _.label++; return { value: op[1], done: false };
|
|
23
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
24
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
25
|
+
default:
|
|
26
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
27
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
28
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
29
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
30
|
+
if (t[2]) _.ops.pop();
|
|
31
|
+
_.trys.pop(); continue;
|
|
32
|
+
}
|
|
33
|
+
op = body.call(thisArg, _);
|
|
34
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
35
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
exports.DefaultRemoteConfigManager = void 0;
|
|
40
|
+
var utils_1 = require("../../../utils/index.js");
|
|
41
|
+
var constants_1 = require("../constants.js");
|
|
42
|
+
var DefaultRemoteConfigManager = /** @class */ (function () {
|
|
43
|
+
function DefaultRemoteConfigManager(config, options) {
|
|
44
|
+
this.config = config;
|
|
45
|
+
this.serviceClient = options.serviceClient;
|
|
46
|
+
this.storageClient = options.storageClient;
|
|
47
|
+
}
|
|
48
|
+
DefaultRemoteConfigManager.prototype.loadRemoteConfig = function () {
|
|
49
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
50
|
+
var remoteConfigData, e_1;
|
|
51
|
+
return __generator(this, function (_a) {
|
|
52
|
+
switch (_a.label) {
|
|
53
|
+
case 0:
|
|
54
|
+
if (!this.config.remoteConfigId || !this.config.remoteConfigAuthToken) {
|
|
55
|
+
this.config.logger.debug('no remote config id or auth token provided, skipping remote config load');
|
|
56
|
+
return [2 /*return*/];
|
|
57
|
+
}
|
|
58
|
+
_a.label = 1;
|
|
59
|
+
case 1:
|
|
60
|
+
_a.trys.push([1, 3, , 4]);
|
|
61
|
+
return [4 /*yield*/, this.loadRemoteConfigData()];
|
|
62
|
+
case 2:
|
|
63
|
+
remoteConfigData = _a.sent();
|
|
64
|
+
if (!!(remoteConfigData === null || remoteConfigData === void 0 ? void 0 : remoteConfigData.version) && remoteConfigData.version > this.config.remoteConfigVersion) {
|
|
65
|
+
this.config.setRemoteConfigData(remoteConfigData);
|
|
66
|
+
}
|
|
67
|
+
return [3 /*break*/, 4];
|
|
68
|
+
case 3:
|
|
69
|
+
e_1 = _a.sent();
|
|
70
|
+
this.config.logger.debug("caught error loading remote config: ".concat(e_1));
|
|
71
|
+
return [3 /*break*/, 4];
|
|
72
|
+
case 4: return [2 /*return*/];
|
|
73
|
+
}
|
|
74
|
+
});
|
|
75
|
+
});
|
|
76
|
+
};
|
|
77
|
+
DefaultRemoteConfigManager.prototype.loadRemoteConfigData = function () {
|
|
78
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
79
|
+
var remoteConfigData;
|
|
80
|
+
return __generator(this, function (_a) {
|
|
81
|
+
switch (_a.label) {
|
|
82
|
+
case 0: return [4 /*yield*/, this.storageClient.load()];
|
|
83
|
+
case 1:
|
|
84
|
+
remoteConfigData = _a.sent();
|
|
85
|
+
if (!remoteConfigData) {
|
|
86
|
+
this.config.logger.debug('unable to load remote config from storage');
|
|
87
|
+
return [2 /*return*/, null];
|
|
88
|
+
}
|
|
89
|
+
if (!this.isValidRemoteConfigId(remoteConfigData.id)) {
|
|
90
|
+
this.config.logger.debug("remote config ID in static config does not match ID found in storage ".concat(remoteConfigData.id));
|
|
91
|
+
return [2 /*return*/, null];
|
|
92
|
+
}
|
|
93
|
+
return [2 /*return*/, remoteConfigData];
|
|
94
|
+
}
|
|
95
|
+
});
|
|
96
|
+
});
|
|
97
|
+
};
|
|
98
|
+
DefaultRemoteConfigManager.prototype.isValidRemoteConfigId = function (remoteConfigId) {
|
|
99
|
+
return remoteConfigId === this.config.remoteConfigId;
|
|
100
|
+
};
|
|
101
|
+
DefaultRemoteConfigManager.prototype.shouldUpdateRemoteConfig = function (context) {
|
|
102
|
+
return context.remoteConfigUpdateData.shouldUpdate;
|
|
103
|
+
};
|
|
104
|
+
DefaultRemoteConfigManager.prototype.updateRemoteConfig = function (context) {
|
|
105
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
106
|
+
var desiredVersion, remoteConfigData, e_2;
|
|
107
|
+
var _a;
|
|
108
|
+
return __generator(this, function (_b) {
|
|
109
|
+
switch (_b.label) {
|
|
110
|
+
case 0:
|
|
111
|
+
desiredVersion = (_a = context.remoteConfigUpdateData.desiredVersion) !== null && _a !== void 0 ? _a : 0;
|
|
112
|
+
return [4 /*yield*/, this.fetchRemoteConfigData(desiredVersion, context)];
|
|
113
|
+
case 1:
|
|
114
|
+
remoteConfigData = _b.sent();
|
|
115
|
+
if (!remoteConfigData) {
|
|
116
|
+
return [2 /*return*/];
|
|
117
|
+
}
|
|
118
|
+
_b.label = 2;
|
|
119
|
+
case 2:
|
|
120
|
+
_b.trys.push([2, 4, , 5]);
|
|
121
|
+
return [4 /*yield*/, this.storageClient.save(remoteConfigData)];
|
|
122
|
+
case 3:
|
|
123
|
+
_b.sent();
|
|
124
|
+
context.logger.debug("successfully updated remote config to version ".concat(remoteConfigData.version));
|
|
125
|
+
return [3 /*break*/, 5];
|
|
126
|
+
case 4:
|
|
127
|
+
e_2 = _b.sent();
|
|
128
|
+
context.logger.debug("unable to save remote config version ".concat(remoteConfigData.version, " to storage: ").concat(e_2), {
|
|
129
|
+
errorType: constants_1.WRITE_REMOTE_CONFIG_ERROR_NAME,
|
|
130
|
+
});
|
|
131
|
+
return [3 /*break*/, 5];
|
|
132
|
+
case 5: return [2 /*return*/];
|
|
133
|
+
}
|
|
134
|
+
});
|
|
135
|
+
});
|
|
136
|
+
};
|
|
137
|
+
DefaultRemoteConfigManager.prototype.fetchRemoteConfigData = function (desiredVersion, context) {
|
|
138
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
139
|
+
var _a, remoteConfigMaxFetchAttempts, remoteConfigRetryIntervalMs, i, remoteConfigData, e_3;
|
|
140
|
+
return __generator(this, function (_b) {
|
|
141
|
+
switch (_b.label) {
|
|
142
|
+
case 0:
|
|
143
|
+
_b.trys.push([0, 7, , 8]);
|
|
144
|
+
_a = this.config, remoteConfigMaxFetchAttempts = _a.remoteConfigMaxFetchAttempts, remoteConfigRetryIntervalMs = _a.remoteConfigRetryIntervalMs;
|
|
145
|
+
i = 0;
|
|
146
|
+
_b.label = 1;
|
|
147
|
+
case 1:
|
|
148
|
+
if (!(i < remoteConfigMaxFetchAttempts)) return [3 /*break*/, 6];
|
|
149
|
+
return [4 /*yield*/, this.serviceClient.fetch({ version: desiredVersion })];
|
|
150
|
+
case 2:
|
|
151
|
+
remoteConfigData = _b.sent();
|
|
152
|
+
if (!(!!remoteConfigData && remoteConfigData.version >= desiredVersion)) return [3 /*break*/, 3];
|
|
153
|
+
return [2 /*return*/, remoteConfigData];
|
|
154
|
+
case 3: return [4 /*yield*/, this.sleepBetweenFetchAttempts(remoteConfigRetryIntervalMs)];
|
|
155
|
+
case 4:
|
|
156
|
+
_b.sent();
|
|
157
|
+
_b.label = 5;
|
|
158
|
+
case 5:
|
|
159
|
+
i++;
|
|
160
|
+
return [3 /*break*/, 1];
|
|
161
|
+
case 6:
|
|
162
|
+
context.logger.debug("unable to fetch remote config version ".concat(desiredVersion, " or higher: reached ").concat(remoteConfigMaxFetchAttempts, " fetch attempts"), {
|
|
163
|
+
errorType: constants_1.WRITE_REMOTE_CONFIG_ERROR_NAME,
|
|
164
|
+
});
|
|
165
|
+
return [3 /*break*/, 8];
|
|
166
|
+
case 7:
|
|
167
|
+
e_3 = _b.sent();
|
|
168
|
+
context.logger.debug("unable to fetch remote config version ".concat(desiredVersion, " or higher: ").concat(e_3), {
|
|
169
|
+
errorType: constants_1.WRITE_REMOTE_CONFIG_ERROR_NAME,
|
|
170
|
+
});
|
|
171
|
+
return [3 /*break*/, 8];
|
|
172
|
+
case 8: return [2 /*return*/, null];
|
|
173
|
+
}
|
|
174
|
+
});
|
|
175
|
+
});
|
|
176
|
+
};
|
|
177
|
+
DefaultRemoteConfigManager.prototype.sleepBetweenFetchAttempts = function (ms) {
|
|
178
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
179
|
+
return __generator(this, function (_a) {
|
|
180
|
+
switch (_a.label) {
|
|
181
|
+
case 0: return [4 /*yield*/, (0, utils_1.sleep)(ms)];
|
|
182
|
+
case 1:
|
|
183
|
+
_a.sent();
|
|
184
|
+
return [2 /*return*/];
|
|
185
|
+
}
|
|
186
|
+
});
|
|
187
|
+
});
|
|
188
|
+
};
|
|
189
|
+
return DefaultRemoteConfigManager;
|
|
190
|
+
}());
|
|
191
|
+
exports.DefaultRemoteConfigManager = DefaultRemoteConfigManager;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./IRemoteConfigManager.js"), exports);
|
|
18
|
+
__exportStar(require("./DefaultRemoteConfigManager.js"), exports);
|
|
@@ -15,4 +15,4 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./RemoteConfigData.js"), exports);
|
|
18
|
-
__exportStar(require("./
|
|
18
|
+
__exportStar(require("./RemoteConfigNotifyRequestPayload.js"), exports);
|
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
12
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
13
|
+
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
14
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
15
|
+
function step(op) {
|
|
16
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
17
|
+
while (g && (g = 0, op[0] && (_ = 0)), _) try {
|
|
18
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
19
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
20
|
+
switch (op[0]) {
|
|
21
|
+
case 0: case 1: t = op; break;
|
|
22
|
+
case 4: _.label++; return { value: op[1], done: false };
|
|
23
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
24
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
25
|
+
default:
|
|
26
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
27
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
28
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
29
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
30
|
+
if (t[2]) _.ops.pop();
|
|
31
|
+
_.trys.pop(); continue;
|
|
32
|
+
}
|
|
33
|
+
op = body.call(thisArg, _);
|
|
34
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
35
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
exports.DefaultNotifyRemoteConfigUpdateParser = void 0;
|
|
40
|
+
var utils_1 = require("../../../utils/index.js");
|
|
41
|
+
var constants_1 = require("../constants.js");
|
|
42
|
+
var http_1 = require("../../../http/index.js");
|
|
43
|
+
var DefaultNotifyRemoteConfigUpdateParser = /** @class */ (function () {
|
|
44
|
+
function DefaultNotifyRemoteConfigUpdateParser(config, options) {
|
|
45
|
+
var _a;
|
|
46
|
+
this.config = config;
|
|
47
|
+
this.timestampHmacHeaderValidator =
|
|
48
|
+
(_a = options.timestampHmacHeaderValidator) !== null && _a !== void 0 ? _a : new utils_1.DefaultTimestampHmacHeaderValidator(config, config.remoteConfigAuthToken, options.base64Utils, options.hmacUtils);
|
|
49
|
+
}
|
|
50
|
+
DefaultNotifyRemoteConfigUpdateParser.prototype.isUpdateRequest = function (_a) {
|
|
51
|
+
return __awaiter(this, arguments, void 0, function (_b) {
|
|
52
|
+
var request = _b.requestData.request;
|
|
53
|
+
return __generator(this, function (_c) {
|
|
54
|
+
return [2 /*return*/, (request.method === http_1.HttpMethod.POST &&
|
|
55
|
+
request.headers.get(utils_1.PUSH_DATA_FEATURE_HEADER_NAME) === constants_1.REMOTE_CONFIG_PUSH_DATA_FEATURE_NAME &&
|
|
56
|
+
!!request.headers.get(utils_1.PUSH_DATA_HMAC_HEADER_NAME))];
|
|
57
|
+
});
|
|
58
|
+
});
|
|
59
|
+
};
|
|
60
|
+
DefaultNotifyRemoteConfigUpdateParser.prototype.parseUpdate = function (context) {
|
|
61
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
62
|
+
var updateData, desiredVersion;
|
|
63
|
+
return __generator(this, function (_a) {
|
|
64
|
+
switch (_a.label) {
|
|
65
|
+
case 0: return [4 /*yield*/, this.isNotifyRequestValid(context)];
|
|
66
|
+
case 1:
|
|
67
|
+
if (!(_a.sent())) {
|
|
68
|
+
return [2 /*return*/, { shouldUpdate: false }];
|
|
69
|
+
}
|
|
70
|
+
updateData = { shouldUpdate: true };
|
|
71
|
+
return [4 /*yield*/, this.getDesiredRemoteConfigVersion(context)];
|
|
72
|
+
case 2:
|
|
73
|
+
desiredVersion = _a.sent();
|
|
74
|
+
context.logger.debug("got notify request for remote config version ".concat(desiredVersion));
|
|
75
|
+
if (desiredVersion) {
|
|
76
|
+
updateData.desiredVersion = desiredVersion;
|
|
77
|
+
}
|
|
78
|
+
return [2 /*return*/, updateData];
|
|
79
|
+
}
|
|
80
|
+
});
|
|
81
|
+
});
|
|
82
|
+
};
|
|
83
|
+
DefaultNotifyRemoteConfigUpdateParser.prototype.isNotifyRequestValid = function (context) {
|
|
84
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
85
|
+
var timestampHmacHeader, isValid, _a;
|
|
86
|
+
return __generator(this, function (_b) {
|
|
87
|
+
switch (_b.label) {
|
|
88
|
+
case 0:
|
|
89
|
+
timestampHmacHeader = context.requestData.request.headers.get(utils_1.PUSH_DATA_HMAC_HEADER_NAME);
|
|
90
|
+
_a = !!timestampHmacHeader;
|
|
91
|
+
if (!_a) return [3 /*break*/, 2];
|
|
92
|
+
return [4 /*yield*/, this.timestampHmacHeaderValidator.isValid(timestampHmacHeader, context.logger)];
|
|
93
|
+
case 1:
|
|
94
|
+
_a = (_b.sent());
|
|
95
|
+
_b.label = 2;
|
|
96
|
+
case 2:
|
|
97
|
+
isValid = _a;
|
|
98
|
+
if (!isValid) {
|
|
99
|
+
context.logger.debug("invalid remote config notify request hmac header received: ".concat(timestampHmacHeader), {
|
|
100
|
+
errorType: constants_1.WRITE_REMOTE_CONFIG_ERROR_NAME,
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
return [2 /*return*/, isValid];
|
|
104
|
+
}
|
|
105
|
+
});
|
|
106
|
+
});
|
|
107
|
+
};
|
|
108
|
+
DefaultNotifyRemoteConfigUpdateParser.prototype.getDesiredRemoteConfigVersion = function (context) {
|
|
109
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
110
|
+
var notifyRequestPayload, e_1;
|
|
111
|
+
return __generator(this, function (_a) {
|
|
112
|
+
switch (_a.label) {
|
|
113
|
+
case 0:
|
|
114
|
+
_a.trys.push([0, 2, , 3]);
|
|
115
|
+
return [4 /*yield*/, context.requestData.request.json()];
|
|
116
|
+
case 1:
|
|
117
|
+
notifyRequestPayload = _a.sent();
|
|
118
|
+
return [3 /*break*/, 3];
|
|
119
|
+
case 2:
|
|
120
|
+
e_1 = _a.sent();
|
|
121
|
+
context.logger.debug("could not parse update request body: ".concat(e_1), {
|
|
122
|
+
errorType: constants_1.WRITE_REMOTE_CONFIG_ERROR_NAME,
|
|
123
|
+
});
|
|
124
|
+
return [2 /*return*/, null];
|
|
125
|
+
case 3:
|
|
126
|
+
if (!(notifyRequestPayload === null || notifyRequestPayload === void 0 ? void 0 : notifyRequestPayload.version)) {
|
|
127
|
+
context.logger.debug("no version on update request body: ".concat(notifyRequestPayload), {
|
|
128
|
+
errorType: constants_1.WRITE_REMOTE_CONFIG_ERROR_NAME,
|
|
129
|
+
});
|
|
130
|
+
return [2 /*return*/, null];
|
|
131
|
+
}
|
|
132
|
+
return [2 /*return*/, notifyRequestPayload.version];
|
|
133
|
+
}
|
|
134
|
+
});
|
|
135
|
+
});
|
|
136
|
+
};
|
|
137
|
+
return DefaultNotifyRemoteConfigUpdateParser;
|
|
138
|
+
}());
|
|
139
|
+
exports.DefaultNotifyRemoteConfigUpdateParser = DefaultNotifyRemoteConfigUpdateParser;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./DefaultNotifyRemoteConfigUpdateParser.js"), exports);
|
|
18
|
+
__exportStar(require("./IRemoteConfigUpdateParser.js"), exports);
|
|
@@ -12,7 +12,6 @@ var __assign = (this && this.__assign) || function () {
|
|
|
12
12
|
};
|
|
13
13
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
14
14
|
exports.DefaultContext = void 0;
|
|
15
|
-
var config_1 = require("../config/index.js");
|
|
16
15
|
var blocker_1 = require("../blocker/index.js");
|
|
17
16
|
var pxhd_1 = require("../pxhd/index.js");
|
|
18
17
|
var risk_token_1 = require("../risk_token/index.js");
|
|
@@ -21,8 +20,13 @@ var http_1 = require("../http/index.js");
|
|
|
21
20
|
var utils_1 = require("../utils/index.js");
|
|
22
21
|
var action_1 = require("../action/index.js");
|
|
23
22
|
var logger_1 = require("../logger/index.js");
|
|
23
|
+
/**
|
|
24
|
+
* The default implementation of the request context which uses the incoming HTTP request and enforcer configuration
|
|
25
|
+
* to populate the context with relevant data.
|
|
26
|
+
*/
|
|
24
27
|
var DefaultContext = /** @class */ (function () {
|
|
25
28
|
function DefaultContext(config, request, options) {
|
|
29
|
+
this._shouldSendLogs = false;
|
|
26
30
|
this.enforcerStartTime = Date.now();
|
|
27
31
|
this.config = config;
|
|
28
32
|
this.urlUtils = options.urlUtils;
|
|
@@ -40,8 +44,10 @@ var DefaultContext = /** @class */ (function () {
|
|
|
40
44
|
this.pxdeVerified = false;
|
|
41
45
|
this.action = action_1.Action.TRIGGER_RISK_API;
|
|
42
46
|
this.reasons = {};
|
|
43
|
-
this.
|
|
44
|
-
|
|
47
|
+
this.remoteConfigUpdateData = {
|
|
48
|
+
shouldUpdate: false,
|
|
49
|
+
};
|
|
50
|
+
this.shouldSendLogs = this.isHeaderBasedLoggerRequest(config, request);
|
|
45
51
|
this.logger = this.createContextLogger(config, this.shouldSendLogs);
|
|
46
52
|
this.requestData = this.createRequestData(config, request, options.cookieParser);
|
|
47
53
|
this.tokenOrigin = this.getTokenOrigin(request);
|
|
@@ -50,6 +56,22 @@ var DefaultContext = /** @class */ (function () {
|
|
|
50
56
|
}
|
|
51
57
|
this.shouldSendTelemetry = false;
|
|
52
58
|
}
|
|
59
|
+
Object.defineProperty(DefaultContext.prototype, "shouldSendLogs", {
|
|
60
|
+
get: function () {
|
|
61
|
+
return this._shouldSendLogs;
|
|
62
|
+
},
|
|
63
|
+
set: function (shouldSendLogs) {
|
|
64
|
+
if (this._shouldSendLogs === shouldSendLogs) {
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
this._shouldSendLogs = shouldSendLogs;
|
|
68
|
+
if (this.logger) {
|
|
69
|
+
this.logger.shouldSaveLogs = shouldSendLogs;
|
|
70
|
+
}
|
|
71
|
+
},
|
|
72
|
+
enumerable: false,
|
|
73
|
+
configurable: true
|
|
74
|
+
});
|
|
53
75
|
Object.defineProperty(DefaultContext.prototype, "isMobile", {
|
|
54
76
|
get: function () {
|
|
55
77
|
return this.tokenOrigin === risk_token_1.TokenOrigin.HEADER;
|
|
@@ -145,7 +167,7 @@ var DefaultContext = /** @class */ (function () {
|
|
|
145
167
|
action: this.action,
|
|
146
168
|
reasons: this.reasons,
|
|
147
169
|
isMobile: this.isMobile,
|
|
148
|
-
|
|
170
|
+
remoteConfigUpdateData: this.remoteConfigUpdateData,
|
|
149
171
|
productData: this.productData,
|
|
150
172
|
requestData: __assign(__assign({}, this.requestData), { request: undefined, url: this.requestData.url.href }),
|
|
151
173
|
requestId: this.requestId,
|
|
@@ -15,6 +15,11 @@ exports.SerializedContext = void 0;
|
|
|
15
15
|
var logger_1 = require("../logger/index.js");
|
|
16
16
|
var risk_token_1 = require("../risk_token/index.js");
|
|
17
17
|
var risk_api_1 = require("../risk_api/index.js");
|
|
18
|
+
/**
|
|
19
|
+
* Implements the `IContext` interface based an already serialized `ContextJson`. This class does not extract data from the
|
|
20
|
+
* incoming request, but rather uses already-extracted data from the `ContextJson` (likely returned from the `DefaultContext.toJSON()`
|
|
21
|
+
* function) and fills in the gaps using the other parameters.
|
|
22
|
+
*/
|
|
18
23
|
var SerializedContext = /** @class */ (function () {
|
|
19
24
|
function SerializedContext(config, contextJson, request, urlUtils) {
|
|
20
25
|
var _a;
|
|
@@ -22,7 +27,7 @@ var SerializedContext = /** @class */ (function () {
|
|
|
22
27
|
this.reasons = contextJson.reasons;
|
|
23
28
|
this.isMobile = contextJson.isMobile;
|
|
24
29
|
this.requestId = contextJson.requestId;
|
|
25
|
-
this.
|
|
30
|
+
this.remoteConfigUpdateData = contextJson.remoteConfigUpdateData;
|
|
26
31
|
this.logger = this.createLogger(config, contextJson.shouldSendLogs, (_a = contextJson.logger) === null || _a === void 0 ? void 0 : _a.logs);
|
|
27
32
|
this.productData = contextJson.productData;
|
|
28
33
|
this.requestData = this.createRequestData(contextJson, request, urlUtils);
|
|
@@ -20,5 +20,6 @@ __exportStar(require("./MobileData.js"), exports);
|
|
|
20
20
|
__exportStar(require("./TokenData.js"), exports);
|
|
21
21
|
__exportStar(require("./TlsData.js"), exports);
|
|
22
22
|
__exportStar(require("./ServerData.js"), exports);
|
|
23
|
+
__exportStar(require("./RemoteConfigUpdateData.js"), exports);
|
|
23
24
|
__exportStar(require("./IContext.js"), exports);
|
|
24
25
|
__exportStar(require("./ReadonlyContext.js"), exports);
|