From 2f8199c746bfe1e31a551857bf5c171201772229 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Thomas=20Rame=CC=81?= Date: Thu, 9 Jun 2022 18:33:43 +0200 Subject: [PATCH] refactor(mdw): scope more precisely the URL try/catch to let malformed params throw an error --- .../format-firebase-dynamic-links.ts | 130 +++++++++--------- src/middlewares/set-utm-parameters.ts | 45 +++--- 2 files changed, 89 insertions(+), 86 deletions(-) diff --git a/src/middlewares/format-firebase-dynamic-links.ts b/src/middlewares/format-firebase-dynamic-links.ts index 6ca6d5a..b4542ee 100644 --- a/src/middlewares/format-firebase-dynamic-links.ts +++ b/src/middlewares/format-firebase-dynamic-links.ts @@ -63,93 +63,93 @@ export function FormatFirebaseDynamicLinksMiddleware( options: FormatFirebaseDynamicLinksOptions ): Middleware { return (properties, element, next) => { + let url: URL; try { - const url = new URL(properties.href); - let androidStoreUrl: URL | undefined; - let iosStoreUrl: URL | undefined; + url = new URL(properties.href); + } catch (err) { + // In case it's not a valid format the middleware is skipped without affecting next ones + return next(); + } - const dynamicLink = new URL(options.dynamicLinkBase); - dynamicLink.searchParams.set('link', properties.href); + let androidStoreUrl: URL | undefined; + let iosStoreUrl: URL | undefined; - if (options.android) { - dynamicLink.searchParams.set('apn', options.android.storeId); + const dynamicLink = new URL(options.dynamicLinkBase); + dynamicLink.searchParams.set('link', properties.href); - if (options.android.storeLink) { - androidStoreUrl = new URL(options.android.storeLink); - } + if (options.android) { + dynamicLink.searchParams.set('apn', options.android.storeId); + + if (options.android.storeLink) { + androidStoreUrl = new URL(options.android.storeLink); } + } - if (options.ios) { - dynamicLink.searchParams.set('isi', options.ios.storeId); - dynamicLink.searchParams.set('ibi', options.ios.bundleId); + if (options.ios) { + dynamicLink.searchParams.set('isi', options.ios.storeId); + dynamicLink.searchParams.set('ibi', options.ios.bundleId); - if (options.ios.storeLink) { - iosStoreUrl = new URL(options.ios.storeLink); - } - - if (options.ios.nativeScheme) { - dynamicLink.searchParams.set('ius', options.ios.nativeScheme); - } + if (options.ios.storeLink) { + iosStoreUrl = new URL(options.ios.storeLink); + } - dynamicLink.searchParams.set( - 'efr', - options.ios.skipAppPreviewPage || '1' - ); + if (options.ios.nativeScheme) { + dynamicLink.searchParams.set('ius', options.ios.nativeScheme); } - if ( - options.injectUtmParamsInDynamicLink || - options.injectUtmParamsInFallback - ) { - const urlParams = url.searchParams; + dynamicLink.searchParams.set( + 'efr', + options.ios.skipAppPreviewPage || '1' + ); + } - // Get UTM parameters from the original link - Object.values(FirebaseUtmParamEnum).forEach(utmKey => { - const utmValue = urlParams.get(utmKey); + if ( + options.injectUtmParamsInDynamicLink || + options.injectUtmParamsInFallback + ) { + const urlParams = url.searchParams; - if (utmValue) { - if (options.injectUtmParamsInDynamicLink) { - dynamicLink.searchParams.set(utmKey, utmValue); - } + // Get UTM parameters from the original link + Object.values(FirebaseUtmParamEnum).forEach(utmKey => { + const utmValue = urlParams.get(utmKey); - if (options.injectUtmParamsInFallback) { - if (androidStoreUrl) { - androidStoreUrl.searchParams.set(utmKey, utmValue); - } + if (utmValue) { + if (options.injectUtmParamsInDynamicLink) { + dynamicLink.searchParams.set(utmKey, utmValue); + } - if (iosStoreUrl) { - iosStoreUrl.searchParams.set(utmKey, utmValue); - } + if (options.injectUtmParamsInFallback) { + if (androidStoreUrl) { + androidStoreUrl.searchParams.set(utmKey, utmValue); } - } - }); - } - // Fallback link (after UTM manipulations because they can be affected) - if (options.usePlatformLinkAsFallback !== false) { - if ((platform as any).os.family === 'iOS' && iosStoreUrl) { - dynamicLink.searchParams.set('ofl', iosStoreUrl.toString()); - } else if ( - (platform as any).os.family === 'Android' && - androidStoreUrl - ) { - dynamicLink.searchParams.set('ofl', androidStoreUrl.toString()); + if (iosStoreUrl) { + iosStoreUrl.searchParams.set(utmKey, utmValue); + } + } } - } + }); + } - if (options.overrideParams) { - for (const [paramKey, paramValue] of Object.entries( - options.overrideParams - )) { - dynamicLink.searchParams.set(paramKey, paramValue); - } + // Fallback link (after UTM manipulations because they can be affected) + if (options.usePlatformLinkAsFallback !== false) { + if ((platform as any).os.family === 'iOS' && iosStoreUrl) { + dynamicLink.searchParams.set('ofl', iosStoreUrl.toString()); + } else if ((platform as any).os.family === 'Android' && androidStoreUrl) { + dynamicLink.searchParams.set('ofl', androidStoreUrl.toString()); } + } - properties.href = dynamicLink.toString(); - } catch (err) { - // In case it's not a valid format the middleware is skipped without affecting next ones + if (options.overrideParams) { + for (const [paramKey, paramValue] of Object.entries( + options.overrideParams + )) { + dynamicLink.searchParams.set(paramKey, paramValue); + } } + properties.href = dynamicLink.toString(); + next(); }; } diff --git a/src/middlewares/set-utm-parameters.ts b/src/middlewares/set-utm-parameters.ts index f7713c7..be04d15 100644 --- a/src/middlewares/set-utm-parameters.ts +++ b/src/middlewares/set-utm-parameters.ts @@ -39,35 +39,38 @@ export function SetUtmParametersMiddleware( options: SetUtmParametersOptions ): Middleware { return (properties, element, next) => { + let url: URL; try { - const url = new URL(properties.href); - const urlParams = url.searchParams; - let existingUtmParams: boolean = false; + url = new URL(properties.href); + } catch (err) { + // In case it's not a valid format the middleware is skipped without affecting next ones + return next(); + } - Object.values(UtmParamEnum).forEach(utmKey => { - if (urlParams.has(utmKey)) { - if ( - options.forceIfPresent !== undefined && - options.forceIfPresent === true - ) { - urlParams.delete(utmKey); - } else { - existingUtmParams = true; - } - } - }); + const urlParams = url.searchParams; + let existingUtmParams: boolean = false; - if (!existingUtmParams) { - for (const [utmKey, utmValue] of Object.entries(options.params)) { - urlParams.set(utmKey, utmValue); + Object.values(UtmParamEnum).forEach(utmKey => { + if (urlParams.has(utmKey)) { + if ( + options.forceIfPresent !== undefined && + options.forceIfPresent === true + ) { + urlParams.delete(utmKey); + } else { + existingUtmParams = true; } } + }); - properties.href = url.toString(); - } catch (err) { - // In case it's not a valid format the middleware is skipped without affecting next ones + if (!existingUtmParams) { + for (const [utmKey, utmValue] of Object.entries(options.params)) { + urlParams.set(utmKey, utmValue); + } } + properties.href = url.toString(); + next(); }; }