From f041ee5363ec8e1368a9dae95da02912c810efe8 Mon Sep 17 00:00:00 2001 From: mkendall07 Date: Fri, 18 Jan 2019 16:28:42 -0500 Subject: [PATCH 1/2] add description to RD module --- src/refererDetection.js | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/src/refererDetection.js b/src/refererDetection.js index fb0b1dbeebb..2d48ca1b414 100644 --- a/src/refererDetection.js +++ b/src/refererDetection.js @@ -1,3 +1,12 @@ +/** + * The referer detection module attempts to gather referer information from the current page that prebid.js resides in. + * The information that it tries to collect includes: + * The detected top url in the nav bar, + * Whether it was able to reach the top most window (if for example it was embedded in several iframes), + * The number of iframes it was embedded in if applicable, + * A list of the domains of each embedded window if applicable. + */ + import { logWarn } from './utils'; export function detectReferer(win) { From 944b94398839623de0b826541a7cee562a8f2d50 Mon Sep 17 00:00:00 2001 From: Jaimin Panchal Date: Mon, 28 Jan 2019 10:36:08 -0500 Subject: [PATCH 2/2] adding some more comments to private functions --- src/refererDetection.js | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/src/refererDetection.js b/src/refererDetection.js index 2d48ca1b414..2acb0b68716 100644 --- a/src/refererDetection.js +++ b/src/refererDetection.js @@ -5,11 +5,16 @@ * Whether it was able to reach the top most window (if for example it was embedded in several iframes), * The number of iframes it was embedded in if applicable, * A list of the domains of each embedded window if applicable. + * Canonical URL which refers to an HTML link element, with the attribute of rel="canonical", found in the element of your webpage */ import { logWarn } from './utils'; export function detectReferer(win) { + /** + * Returns number of frames to reach top from current frame where prebid.js sits + * @returns {Array} levels + */ function getLevels() { let levels = walkUpWindows(); let ancestors = getAncestorOrigins(); @@ -22,6 +27,11 @@ export function detectReferer(win) { return levels; } + /** + * This function would return a read-only array of hostnames for all the parent frames. + * win.location.ancestorOrigins is only supported in webkit browsers. For non-webkit browsers it will return undefined. + * @returns {(undefined|Array)} Ancestor origins or undefined + */ function getAncestorOrigins() { try { if (!win.location.ancestorOrigins) { @@ -33,6 +43,11 @@ export function detectReferer(win) { } } + /** + * This function would try to get referer and urls for all parent frames in case of win.location.ancestorOrigins undefined. + * @param {Array} levels + * @returns {Object} urls for all parent frames and top most detected referer url + */ function getPubUrlStack(levels) { let stack = []; let defUrl = null; @@ -87,6 +102,10 @@ export function detectReferer(win) { }; } + /** + * This function returns canonical URL which refers to an HTML link element, with the attribute of rel="canonical", found in the element of your webpage + * @param {Object} doc document + */ function getCanonicalUrl(doc) { try { let element = doc.querySelector("link[rel='canonical']"); @@ -98,6 +117,9 @@ export function detectReferer(win) { return null; } + /** + * Walk up to the top of the window to detect origin, number of iframes, ancestor origins and canonical url + */ function walkUpWindows() { let acc = []; let currentWindow; @@ -144,6 +166,7 @@ export function detectReferer(win) { * @property {boolean} reachedTop whether prebid was able to walk upto top window or not * @property {number} numIframes number of iframes * @property {string} stack comma separated urls of all origins + * @property {string} canonicalUrl canonical URL refers to an HTML link element, with the attribute of rel="canonical", found in the element of your webpage */ /**