prebid/Prebid.js

View on GitHub
modules/naveggIdSystem.js

Summary

Maintainability
B
4 hrs
Test Coverage
/**
 * This module adds naveggId to the User ID module
 * The {@link module:modules/userId} module is required
 * @module modules/naveggId
 * @requires module:modules/userId
 */
import { isStr, isPlainObject, logError } from '../src/utils.js';
import { submodule } from '../src/hook.js';
import { ajaxBuilder } from '../src/ajax.js';
import { getStorageManager } from '../src/storageManager.js';
import { MODULE_TYPE_UID } from '../src/activities/modules.js';

/**
 * @typedef {import('../modules/userId/index.js').Submodule} Submodule
 * @typedef {import('../modules/userId/index.js').SubmoduleConfig} SubmoduleConfig
 */

const MODULE_NAME = 'naveggId';
const OLD_NAVEGG_ID = 'nid';
const NAVEGG_ID = 'nvggid';
const BASE_URL = 'https://id.navegg.com/uid/';

export const storage = getStorageManager({moduleType: MODULE_TYPE_UID, moduleName: MODULE_NAME});

function getIdFromAPI() {
  const resp = function (callback) {
    ajaxBuilder()(
      BASE_URL,
      response => {
        if (response) {
          let responseObj;
          try {
            responseObj = JSON.parse(response);
          } catch (error) {
            logError(error);
            const fallbackValue = getNaveggIdFromLocalStorage() || getOldCookie();
            callback(fallbackValue);
          }

          if (responseObj && responseObj[NAVEGG_ID]) {
            callback(responseObj[NAVEGG_ID]);
          } else {
            const fallbackValue = getNaveggIdFromLocalStorage() || getOldCookie();
            callback(fallbackValue);
          }
        }
      },
      error => {
        logError('Navegg ID fetch encountered an error', error);
        const fallbackValue = getNaveggIdFromLocalStorage() || getOldCookie();
        callback(fallbackValue);
      },
      {method: 'GET', withCredentials: false});
  };
  return resp;
}

/**
 * @returns {string | null}
 */
function readNvgIdFromCookie() {
  return storage.cookiesAreEnabled ? (storage.findSimilarCookies('nvg') ? storage.findSimilarCookies('nvg')[0] : null) : null;
}
/**
 * @returns {string | null}
 */
function readNavIdFromCookie() {
  return storage.cookiesAreEnabled() ? (storage.findSimilarCookies('nav') ? storage.findSimilarCookies('nav')[0] : null) : null;
}
/**
 * @returns {string | null}
 */
function readOldNaveggIdFromCookie() {
  return storage.cookiesAreEnabled() ? storage.getCookie(OLD_NAVEGG_ID) : null;
}
/**
 * @returns {string | null}
 */
function getOldCookie() {
  const oldCookie = readOldNaveggIdFromCookie() || readNvgIdFromCookie() || readNavIdFromCookie();
  return oldCookie;
}
/**
 * @returns {string | null}
 */
function getNaveggIdFromLocalStorage() {
  return storage.localStorageIsEnabled() ? storage.getDataFromLocalStorage(NAVEGG_ID) : null;
}

/** @type {Submodule} */
export const naveggIdSubmodule = {
  /**
   * used to link submodule with config
   * @type {string}
   */
  name: MODULE_NAME,
  /**
   * decode the stored id value for passing to bid requests
   * @function
   * @param { Object | string | undefined } value
   * @return { Object | string | undefined }
   */
  decode(value) {
    const naveggIdVal = value ? isStr(value) ? value : isPlainObject(value) ? value.id : undefined : undefined;
    return naveggIdVal ? {
      'naveggId': naveggIdVal.split('|')[0]
    } : undefined;
  },

  /**
   * performs action to obtain id and return a value in the callback's response argument
   * @function
   * @param {SubmoduleConfig} config
   * @return {{id: string | undefined } | undefined}
   */
  getId(config, consentData) {
    const resp = getIdFromAPI()
    return {callback: resp}
  },
  eids: {
    'naveggId': {
      source: 'navegg.com',
      atype: 1
    },
  }
};
submodule('userId', naveggIdSubmodule);