LocalCDN-Firefox-Chrome-Brave/modules/internal/helpers.js

434 lines
12 KiB
JavaScript

/**
* Internal Helper Module
* Belongs to Decentraleyes/LocalCDN.
*
* @author Thomas Rientjes
* @author nobody42
* @since 2017-10-26
* @license MPL 2.0
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
* You can obtain one at http://mozilla.org/MPL/2.0/.
*/
'use strict';
/**
* Helpers
*/
var helpers = {};
/**
* Public Methods
*/
helpers.insertI18nContentIntoDocument = function (document) {
let scriptDirection, i18nElements;
scriptDirection = helpers.determineScriptDirection(navigator.language);
i18nElements = document.querySelectorAll('[data-i18n-content]');
i18nElements.forEach(function (i18nElement) {
let i18nMessageName = i18nElement.getAttribute('data-i18n-content');
i18nElement.innerText = chrome.i18n.getMessage(i18nMessageName);
i18nElement.setAttribute('dir', scriptDirection);
});
};
helpers.insertI18nTitlesIntoDocument = function (document) {
let scriptDirection, i18nElements;
scriptDirection = helpers.determineScriptDirection(navigator.language);
i18nElements = document.querySelectorAll('[data-i18n-title]');
i18nElements.forEach(function (i18nElement) {
let i18nMessageName = i18nElement.getAttribute('data-i18n-title');
i18nElement.setAttribute('title', chrome.i18n.getMessage(i18nMessageName));
i18nElement.setAttribute('dir', scriptDirection);
});
};
helpers.languageIsFullySupported = function (language) {
let languageSupported, supportedLanguages;
languageSupported = false;
supportedLanguages = [
'ar', 'bg', 'zh', 'cs', 'da', 'nl', 'en', 'eo', 'et', 'fi',
'fr', 'de', 'el', 'he', 'hu', 'is', 'id', 'it', 'ja', 'ko',
'nb', 'pl', 'pt', 'ro', 'ru', 'es', 'sv', 'tr'
];
for (let supportedLanguage of supportedLanguages) {
if (language.search(supportedLanguage) !== -1) {
languageSupported = true;
}
}
return languageSupported;
};
helpers.normalizeDomain = function (domain) {
domain = domain.toLowerCase().trim();
if (domain.startsWith(Address.WWW_PREFIX)) {
domain = domain.slice(Address.WWW_PREFIX.length);
}
return domain;
};
helpers.extractDomainFromUrl = function (url = '', normalize) {
let extractedDomain;
try {
extractedDomain = new URL(url).host;
} catch (exception) {
extractedDomain = null;
}
if (url.startsWith(Address.CHROME)) {
extractedDomain = null;
}
if (extractedDomain === '') {
extractedDomain = null;
}
if (extractedDomain !== null && normalize === true) {
extractedDomain = helpers.normalizeDomain(extractedDomain);
}
return extractedDomain;
};
helpers.extractFilenameFromPath = function (path) {
let pathSegments, filename;
pathSegments = path.split('/');
filename = pathSegments[pathSegments.length - 1];
return filename;
};
helpers.generateRandomHexString = function (length) {
let randomValues, randomHexString;
randomValues = crypto.getRandomValues(new Uint8Array(length));
randomHexString = '';
for (let value of randomValues) {
// eslint-disable-next-line no-bitwise
let hexValue = (0 ^ value & 15 >> 0 / 4).toString(16);
randomHexString += hexValue;
}
return randomHexString;
};
helpers.determineCdnName = function (domainName) {
switch (domainName) {
case 'ajax.googleapis.com':
return 'Google Hosted Libraries';
case 'ajax.aspnetcdn.com':
return 'Microsoft Ajax CDN';
case 'ajax.microsoft.com':
return 'Microsoft Ajax CDN [Deprecated]';
case 'cdnjs.cloudflare.com':
return 'CDNJS (Cloudflare)';
case 'code.jquery.com':
return 'jQuery CDN (MaxCDN)';
case 'cdn.jsdelivr.net':
return 'jsDelivr (Cloudflare)';
case 'yastatic.net':
return 'Yandex CDN';
case 'yandex.st':
return 'Yandex CDN [Deprecated]';
case 'apps.bdimg.com':
return 'Baidu CDN';
case 'libs.baidu.com':
return 'Baidu CDN [Deprecated]';
case 'lib.sinaapp.com':
return 'Sina Public Resources';
case 'upcdn.b0.upaiyun.com':
return 'UpYun Library';
case 'cdn.bootcss.com':
return 'BootCDN';
case 'sdn.geekzu.org':
return 'Geekzu Public Service [Mirror]';
case 'ajax.proxy.ustclug.org':
return 'USTC Linux User Group [Mirror]';
case 'unpkg.com':
return 'UNPKG (Cloudflare)';
case 'stackpath.bootstrapcdn.com':
return 'StackPath BootstrapCDN';
case 'maxcdn.bootstrapcdn.com':
return 'MaxCDN Bootstrap CDN';
case 'use.fontawesome.com':
return 'Font Awesome CDN';
case 'ajax.cloudflare.com':
return 'Cloudflare CDN';
case 'akamai-webcdn.kgstatic.net':
return 'Akamai WebCDN';
default:
return 'Unknown';
}
};
helpers.determineResourceName = function (filename) {
switch (filename) {
case 'angular.min.jsm':
return 'AngularJS';
case 'angular-animate.min.jsm':
return 'AngularJS Animate';
case 'angular-cookies.min.jsm':
return 'AngularJS Cookies';
case 'angular-sanitize.min.jsm':
return 'AngularJS Sanitize';
case 'angular-touch.min.jsm':
return 'AngularJS Touch';
case 'animate.cssm':
return 'Animate CSS'
case 'backbone-min.jsm':
return 'Backbone.js';
case 'bootstrap.min.cssm':
return 'Bootstrap CSS';
case 'bootstrap.min.jsm':
return 'Bootstrap JS';
case 'bootstrap-slider.min.jsm':
return 'bootstrap-slider JS';
case 'bootstrap-slider.min.cssm':
return 'bootstrap-slider CSS';
case 'dojo.jsm':
return 'Dojo';
case 'ember.min.jsm':
return 'Ember.js';
case 'ext-core.jsm':
return 'Ext Core';
case 'font-awesome.min.cssm':
return 'Font Awesome';
case 'all.cssm':
return 'Font Awesome';
case 'jquery.min.jsm':
return 'jQuery';
case 'jquery-ui.min.jsm':
return 'jQuery UI';
case 'jquery.validate.min.jsm':
return 'jQuery jeditable';
case 'jquery.jeditable.min.jsm':
return 'jQuery Validation Plugin';
case 'lazysizes.min.jsm':
return 'lazysizes';
case 'lozad.min.jsm':
return 'lozad.js';
case 'modernizr.min.jsm':
return 'Modernizr';
case 'moment.min.jsm':
return 'Modernizr';
case 'mootools-yui-compressed.jsm':
return 'MooTools';
case 'p2p-media-loader-core.min.jsm':
return 'P2P Media Loader Core';
case 'page.min.jsm':
return 'page.js';
case 'prototype.jsm':
return 'Prototype';
case 'rocket-loader.min.jsm':
return 'Rocket Loader';
case 'rickshaw.min.jsm':
return 'rickshaw JS';
case 'rickshaw.min.cssm':
return 'rickshaw CSS';
case 'scriptaculous.jsm':
return 'Scriptaculous';
case 'swfobject.jsm':
return 'SWFObject';
case 'toastr.min.cssm':
return 'toastr.js';
case 'toastr.min.jsm':
return 'toastr.js';
case 'underscore-min.jsm':
return 'Underscore.js';
case 'webfont.jsm':
return 'Web Font Loader';
case 'vue.jsm':
return 'Vue.js';
case 'wow.min.jsm':
return 'WOW';
default:
return 'Unknown';
}
};
helpers.determineBundle = function (path = '') {
if (path.includes('findify')) {
return 'Findify';
} else {
return '';
}
};
helpers.determineScriptDirection = function (language) {
let rightToLeftLanguages, scriptDirection;
rightToLeftLanguages = ['ar', 'he'];
if (rightToLeftLanguages.indexOf(language) === -1) {
scriptDirection = 'ltr';
} else {
scriptDirection = 'rtl';
}
return scriptDirection;
};
helpers.formatNumber = function (number) {
if (typeof number === 'number') {
return number.toLocaleString();
}
};
helpers.formatVersion = function (version) {
if (version.indexOf('beta') === -1) {
return version;
} else {
return 'BETA';
}
};
helpers.setLastVersion = function (type, version) {
let requestVersion;
if(version != null && version != undefined) {
requestVersion = version.toString();
}
if (type.includes('/angularjs/1.')) {
version = '1.7.9';
} else if (type.includes('/animate.css/3.')) {
version = '3.7.2';
} else if (type.includes('/backbone.js/0.')) {
version = '0.9.10';
} else if (type.includes('/backbone.js/1.')) {
version = '1.4.0';
} else if (type.includes('/bootstrap.js/3.')) {
version = '3.3.7';
} else if (type.includes('/bootstrap.js/4.')) {
version = '4.4.1';
} else if (type.includes('/bootstrap.css/3.')) {
version = '3.3.7';
} else if (type.includes('/bootstrap.css/4.')) {
version = '4.4.1';
} else if (type.includes('/bootstrap-slider/10.')) {
version = '10.6.2';
} else if (type.includes('/d3/3.')) {
version = '3.5.17';
} else if (type.includes('/dojo/1.')) {
version = '1.14.1';
} else if (type.includes('/ember.js/1.')) {
version = '1.13.13';
} else if (type.includes('/ember.js/2.')) {
version = '2.18.2';
} else if (type.includes('/ember.js/3.')) {
version = '3.12.3';
} else if (type.includes('/ext-core/3.')) {
version = '3.1.0';
} else if (type.includes('findify')) {
version = '6.9.15';
} else if (type.includes('/fontawesome/3.')) {
version = '3.2.1';
} else if (type.includes('/fontawesome/4.')) {
version = '4.7.0';
} else if (type.includes('/fontawesome/5.')) {
version = '5.7.2';
} else if (type.includes('/jquery/1.')) {
version = ( helpers.compareVersion('1.8.3', requestVersion )) ? '1.8.3' : '1.12.4';
} else if (type.includes('/jquery/2.')) {
version = '2.2.4';
} else if (type.includes('/jquery/3.')) {
version = '3.4.1';
} else if (type.includes('/jqueryui/1.')) {
version = '1.11.4';
} else if (type.includes('/jquery-validate/1.')) {
version = '1.19.1';
} else if (type.includes('/jquery-jeditable/1.')) {
version = '1.8.0';
} else if (type.includes('/lazysizes/4.')) {
version = '4.1.8';
} else if (type.includes('lozad')) {
version = '1.14.0';
} else if (type.includes('/modernizr/2.')) {
version = '2.8.3';
} else if (type.includes('/moment.js/2.')) {
version = '2.24.0';
} else if (type.includes('/mootools/1.')) {
version = '1.6.0';
} else if (type.includes('p2p-media-loader-core')) {
version = '0.6.2';
} else if (type.includes('/page.js/1.')) {
version = '1.7.1';
} else if (type.includes('/prototype/1.')) {
version = '1.7.3.0';
} else if (type.includes('/rickshaw/1.')) {
version = '1.6.6';
} else if (type.includes('/scriptaculous/1.')) {
version = '1.9.0';
} else if (type.includes('/swfobject/2.')) {
version = '2.2';
} else if (type.includes('/twitter-bootstrap/3.')) {
version = '3.4.1';
} else if (type.includes('/toastr.js/2.')) {
version = '2.1.4';
} else if (type.includes('/underscore.js/1.')) {
version = '1.9.1';
} else if (type.includes('/vue/1.')) {
version = '1.0.28';
} else if (type.includes('webfont')) {
version = '1.6.28';
} else if (type.includes('/wow/1.')) {
version = '1.1.2';
}
return version;
};
helpers.compareVersion = function (v1, v2) {
/**
* compareVersion( '1.5.7' , '1.5.8' ) is TRUE
* compareVersion( '1.5.8' , '1.5.7' ) is FALSE
* compareVersion( '1.5.7' , '1.5.7' ) is TRUE
*/
v1 = v1.split('.');
v2 = v2.split('.');
const k = Math.min(v1.length, v2.length);
for (let i = 0; i < k; ++ i) {
v1[i] = parseInt(v1[i], 10);
v2[i] = parseInt(v2[i], 10);
if (v1[i] > v2[i]) return true;
if (v1[i] < v2[i]) return false;
}
return v1.length == v2.length ? true: (v1.length < v2.length ? false : true);
}