diff --git a/extensions/chromium/runet-censorship-bypass/extension/00-init-apis.js b/extensions/chromium/runet-censorship-bypass/extension/00-init-apis.js index deeea8e..f7d0a64 100644 --- a/extensions/chromium/runet-censorship-bypass/extension/00-init-apis.js +++ b/extensions/chromium/runet-censorship-bypass/extension/00-init-apis.js @@ -1,5 +1,18 @@ 'use strict'; +const IF_DEBUG = true; + +if (!IF_DEBUG) { + // I believe logging objects precludes them from being GCed. + // I also don't remove logs for sake of client-side troubleshooting + // (though no one sent me logs so far). + ['log', 'warn', 'error'].forEach( (meth) => { + const _meth = window.console[meth].bind(console); + window.console[meth] = function(...args) { _meth(...args.map((a) => '' + a)) } + }); +} + + window.utils = { areSettingsNotControlledFor(details) { diff --git a/extensions/chromium/runet-censorship-bypass/extension/11-api-error-handlers.js b/extensions/chromium/runet-censorship-bypass/extension/11-api-error-handlers.js index e523b0f..7aa0c55 100644 --- a/extensions/chromium/runet-censorship-bypass/extension/11-api-error-handlers.js +++ b/extensions/chromium/runet-censorship-bypass/extension/11-api-error-handlers.js @@ -82,8 +82,7 @@ const json = JSON.stringify(err, errorJsonReplacer, 0); openAndFocus( - //'https://rebrand.ly/ac-error/?' + btoa(encodeURIComponent(json)) - 'https://anticensorship-russia.tk/error/?' + json + 'http://rebrand.ly/ac-error/?json=' + encodeURIComponent(json) + '&version=' + chrome.runtime.getManifest().version ); }, @@ -137,8 +136,11 @@ mayNotifyVoid( id, title, errOrMessage, - icon = 'default-128.png', - context = extName + { + icon = 'default-128.png', + context = extName, + ifSticky = true + } ) { if ( !this.isOn(id) ) { @@ -152,7 +154,7 @@ title: title, message: message, contextMessage: context, - requireInteraction: true, + requireInteraction: ifSticky, type: 'basic', iconUrl: './icons/' + icon, appIconMaskUrl: './icons/default-mask-128.png', @@ -168,7 +170,7 @@ console.warn(name + ':GLOBAL ERROR', errEvent); this.mayNotifyVoid('ext-error', 'Ошибка расширения', errEvent, - 'ext-error-128.png'); + {icon: 'ext-error-128.png'}); }); @@ -230,7 +232,7 @@ // TOOD: add "view pac script at this line" button. handlers.mayNotifyVoid('pac-error', 'Ошибка PAC!', details.error + '\n' + details.details, - 'pac-error-128.png' + {icon: 'pac-error-128.png'} ); }); @@ -244,7 +246,7 @@ noCon, chrome.i18n.getMessage('noControl'), chrome.i18n.getMessage('which'), - 'no-control-128.png' + {icon:'no-control-128.png', ifSticky: false} ); } else { chrome.notifications.clear( noCon ); diff --git a/extensions/chromium/runet-censorship-bypass/extension/12-api-sync-pac-script-with-pac-provider.js b/extensions/chromium/runet-censorship-bypass/extension/12-api-sync-pac-script-with-pac-provider.js index 399f198..dd67a4a 100644 --- a/extensions/chromium/runet-censorship-bypass/extension/12-api-sync-pac-script-with-pac-provider.js +++ b/extensions/chromium/runet-censorship-bypass/extension/12-api-sync-pac-script-with-pac-provider.js @@ -21,22 +21,22 @@ { // Private namespace starts. - function mandatory() { + const mandatory = function mandatory() { throw new TypeError('Missing required argument. ' + 'Be explicit if you swallow errors.'); - } + }; - function throwIfError(err) { + const throwIfError = function throwIfError(err) { if(err) { throw err; } - } + }; - function asyncLogGroup(...args) { + const asyncLogGroup = function asyncLogGroup(...args) { const cb = args.pop(); if(!(cb && typeof(cb) === 'function')) { @@ -51,13 +51,13 @@ }; - } + }; - function checkChromeError(betterStack) { + const checkChromeError = function checkChromeError(betterStack) { // Chrome API calls your cb in a context different from the point of API // method invokation. - const err = chrome.runtime.lastError || chrome.extension.lastError || null; + const err = chrome.runtime.lastError || chrome.extension.lastError; if (err) { const args = ['API returned error:', err]; if (betterStack) { @@ -67,9 +67,9 @@ } return err; - } + }; - function chromified(cb = mandatory(), ...replaceArgs) { + const chromified = function chromified(cb = mandatory(), ...replaceArgs) { const stack = (new Error()).stack; // Take error first callback and convert it to chrome api callback. @@ -84,57 +84,355 @@ }; - } + }; + + class Clarification { + + constructor(message = mandatory(), prevClarification) { + + this.message = message; + if (prevClarification) { + this.prev = prevClarification; + } + + } + + }; + + const clarify = function clarify(err = mandatory(), message = mandatory(), {data} = {}) { + + err.clarification = new Clarification(message, err.clarification); + if (data) { + err.clarification.data = data; + } + return err; + + }; + + class Warning { + + constructor(message) { + + clarify(this, message); + + } + + }; + + + const setPacAsync = function setPacAsync( + pacData = mandatory(), cb = throwIfError + ) { + + const config = { + mode: 'pac_script', + pacScript: { + mandatory: false, + data: pacData, + }, + }; + console.log('Setting chrome proxy settings...'); + chrome.proxy.settings.set( {value: config}, () => { + + const err = checkChromeError(); + if (err) { + return cb(err); + } + chrome.proxy.settings.get({}, (details) => { + + if ( window.utils.areSettingsNotControlledFor( details ) ) { + + console.warn('Failed, other extension is in control.'); + return cb( + null, null, + [new Warning( window.utils.messages.whichExtensionHtml() )] + ); + + } + console.log('Successfuly set PAC in proxy settings..'); + cb(); + }); + + }); + + }; + + const clarifyErrorThen = function clarifyFetchErrorThen(message, cb) { + + return (err, ...args) => cb( clarify(err || {}, message), ...args ); + + }; + + const clarifyFetchErrorThen = (cb) => clarifyErrorThen('Что-то не так с сетью, проверьте соединение.', cb); + + const ifModifiedSince = function ifModifiedSince(url = mandatory(), lastModified = mandatory(), cb = mandatory()) { + + const wasModified = new Date(0).toUTCString(); + const notModifiedCode = 304; + fetch(url, { + method: 'HEAD', + headers: new Headers({ + 'If-Modified-Since': lastModified + }) + }).then( + (res) => { + cb( + null, + res.status === notModifiedCode ? + false : + (res.headers.get('Last-Modified') || wasModified) + ); + }, + clarifyFetchErrorThen((err) => cb(err, wasModified)) + ); + + }; + + const httpGet = function httpGet(url, cb = mandatory()) { + + const start = Date.now(); + fetch(url, {cache: 'no-store'}).then( + (res) => { + + const textCb = + (err) => res.text().then( (text) => cb(err, text), cb ); + + const status = res.status; + if ( !( status >= 200 && status < 300 || status === 304 ) ) { + return textCb( + clarify( + res, + 'Получен ответ с неудачным HTTP-кодом ' + status + '.' + ) + ); + } + + console.log('GETed with success:', url, Date.now() - start); + textCb(); + + }, + clarifyFetchErrorThen(cb) + ); + + }; + + const getIpsFor = function getIpsFor(host = mandatory(), cb = mandatory()) { + + const types = [1, 28]; + const promises = types.map( + (type) => new Promise((resolve) => + httpGet( + 'https://dns.google.com/resolve?type=' + type + '&name=' + host, + (err, res) => { + + if (res) { + try { + res = JSON.parse(res); + console.log('Json parsed.'); + if (err || res.Status) { + const msg = ['Answer', 'Comment', 'Status'] + .filter( (prop) => res[prop] ) + .map( (prop) => prop + ': ' + JSON.stringify( res[prop] ) ) + .join(', \n'); + clarify(err, 'Сервер (json): ' + msg, {data: res}); + } else { + res = res.Answer || []; + res = res.filter( + (record) => types.includes(record.type) + ); + } + } catch(e) { + err = clarify(e, 'Сервер (текст): ' + res, err ? {data: err} : null) + } + } + resolve([err, res]); + + } + ) + ) + ); + Promise.all(promises).then( + ([[v4err, v4res], [v6err, v6res]]) => { + + if(v4err) { + return cb(v4err, v4res); + } + const ips = v4res; + let warns = null; + if (!v6err) { + ips.push(...v6res); + } else { + warns = [v6err]; + } + cb(null, ips, warns); + + } + ); + + }; + + const updatePacProxyIps = function updatePacProxyIps(provider, cb = throwIfError) { + + cb = asyncLogGroup( + 'Getting IP for '+ provider.proxyHosts.join(', ') + '...', + cb + ); + let failure = { + errors: {}, + }; + let hostsProcessed = 0; + provider.proxyHosts.forEach( + (proxyHost) => getIpsFor( + proxyHost, + (err, ips, warns) => { + + if (!err) { + provider.proxyIps = provider.proxyIps || {}; + ips.forEach( + (ip) => provider.proxyIps[ip] = proxyHost + ); + } + if (err || warns) { + failure.errors[proxyHost] = err || warns; + } + + if ( ++hostsProcessed < provider.proxyHosts.length ) { + return; + } + // All hosts were processed. + const errorsCount = Object.keys(failure.errors).length; + if (!errorsCount) { + return cb(); + } + clarify( + failure, + 'Не удалось получить один или несколько IP адресов для' + + ' прокси-серверов. Иконка для уведомления об обходе' + + ' блокировок может не отображаться.' + ); + errorsCount === hostsProcessed + ? cb(failure) + : cb(null, null, [failure]) + } + ) + ); + + }; + + const setPacScriptFromProviderAsync = function setPacScriptFromProviderAsync( + provider = mandatory(), lastModified = mandatory(), cb = throwIfError + ) { + + const pacUrl = provider.pacUrls[0]; + cb = asyncLogGroup( + 'Getting PAC script from provider...', pacUrl, + cb + ); + + ifModifiedSince(pacUrl, lastModified, (err, newLastModified) => { + + if (!newLastModified) { + return cb( + null, + {lastModified}, + [new Warning('Ваш PAC-скрипт не нуждается в обновлении. Его дата: ' + lastModified)] + ); + } + + // Employ all urls, the latter are fallbacks for the former. + let pacDataPromise = Promise.reject(); + for(const url of provider.pacUrls) { + + pacDataPromise = pacDataPromise.catch( + (err) => new Promise( + (resolve, reject) => httpGet( + url, + (newErr, pacData) => newErr ? reject(newErr) : resolve(pacData) + ) + ) + ); + + } + + pacDataPromise.then( + (pacData) => { + + setPacAsync( + pacData, + (err, res) => cb( + err, + Object.assign(res || {}, {lastModified: newLastModified}) + ) + ); + + }, + clarifyErrorThen( + 'Не удалось скачать PAC-скрипт с адресов: [ ' + + provider.pacUrls.join(' , ') + ' ].', + cb + ) + ); + + }); + + }; window.apis.antiCensorRu = { version: chrome.runtime.getManifest().version, + throwAsync() { throw new Error('ABC') }, // TODO: delete + pacProviders: { Антизапрет: { + label: 'Антизапрет', + desc: 'Альтернативный PAC-скрипт от стороннего разработчика.' + + ' Блокировка определяется по доменному имени,' + + ' для некоторых провайдеров есть автоопредление.' + + '
Страница проекта.', + pacUrls: ['https://antizapret.prostovpn.org/proxy.pac'], proxyHosts: ['proxy.antizapret.prostovpn.org'], proxyIps: { '195.123.209.38': 'proxy.antizapret.prostovpn.org', '137.74.171.91': 'proxy.antizapret.prostovpn.org', '51.15.39.201': 'proxy.antizapret.prostovpn.org', - '2a02:27ac::10': 'proxy.antizapret.prostovpn.org', '2001:bc8:4700:2300::1:d07': 'proxy.antizapret.prostovpn.org', + '2a02:27ac::10': 'proxy.antizapret.prostovpn.org', }, }, - Антиценз: { - pacUrls: ['https://config.anticenz.org/proxy.pac'], - proxyHosts: ['gw2.anticenz.org'], - proxyIps: { - '5.196.220.114': 'gw2.anticenz.org', - }, - }, - Оба_и_на_свитчах: { + Антицензорити: { + label: 'Антицензорити', + desc: 'Основной PAC-скрипт от автора расширения.' + + ' Блокировка определятся по доменному имени или IP адресу. Работает на switch-ах.' + + '
Страница проекта.', + /* - Don't use in system configs! Because Win does poor caching. - Url is encoded to counter abuse. + Don't use in system configs! Because Windows does poor caching. + Some urls are encoded to counter abuse. Version: 0.17 */ pacUrls: [ - // Cloud Flare - '\x68\x74\x74\x70\x73\x3a\x2f\x2f\x61\x6e\x74\x69\x63\x65\x6e\x73\x6f\x72\x73\x68\x69\x70\x2d\x72\x75\x73\x73\x69\x61\x2e\x74\x6b\x2f\x67\x65\x6e\x65\x72\x61\x74\x65\x64\x2d\x70\x61\x63\x2d\x73\x63\x72\x69\x70\x74\x73\x2f\x6f\x6e\x2d\x73\x77\x69\x74\x63\x68\x65\x73\x2d\x30\x2e\x31\x37\x2e\x70\x61\x63', - // GitHub - '\x68\x74\x74\x70\x73\x3a\x2f\x2f\x72\x61\x77\x2e\x67\x69\x74\x68\x75\x62\x75\x73\x65\x72\x63\x6f\x6e\x74\x65\x6e\x74\x2e\x63\x6f\x6d\x2f\x61\x6e\x74\x69\x63\x65\x6e\x73\x6f\x72\x73\x68\x69\x70\x2d\x72\x75\x73\x73\x69\x61\x2f\x67\x65\x6e\x65\x72\x61\x74\x65\x64\x2d\x70\x61\x63\x2d\x73\x63\x72\x69\x70\x74\x73\x2f\x6d\x61\x73\x74\x65\x72\x2f\x6f\x6e\x2d\x73\x77\x69\x74\x63\x68\x65\x73\x2d\x30\x2e\x31\x37\x2e\x70\x61\x63', - // Google Drive + // Official, Cloud Flare with caching: + 'https://anticensorship-russia.tk/generated-pac-scripts/anticensority.pac', + // GitHub.io: + '\x68\x74\x74\x70\x73\x3a\x2f\x2f\x61\x6e\x74\x69\x63\x65\x6e\x73\x6f\x72\x73\x68\x69\x70\x2d\x72\x75\x73\x73\x69\x61\x2e\x67\x69\x74\x68\x75\x62\x2e\x69\x6f\x2f\x67\x65\x6e\x65\x72\x61\x74\x65\x64\x2d\x70\x61\x63\x2d\x73\x63\x72\x69\x70\x74\x73\x2f\x61\x6e\x74\x69\x63\x65\x6e\x73\x6f\x72\x69\x74\x79\x2e\x70\x61\x63', + // GitHub repo: + '\x68\x74\x74\x70\x73\x3a\x2f\x2f\x72\x61\x77\x2e\x67\x69\x74\x68\x75\x62\x75\x73\x65\x72\x63\x6f\x6e\x74\x65\x6e\x74\x2e\x63\x6f\x6d\x2f\x61\x6e\x74\x69\x63\x65\x6e\x73\x6f\x72\x73\x68\x69\x70\x2d\x72\x75\x73\x73\x69\x61\x2f\x67\x65\x6e\x65\x72\x61\x74\x65\x64\x2d\x70\x61\x63\x2d\x73\x63\x72\x69\x70\x74\x73\x2f\x6d\x61\x73\x74\x65\x72\x2f\x61\x6e\x74\x69\x63\x65\x6e\x73\x6f\x72\x69\x74\x79\x2e\x70\x61\x63', + // Google Drive (0.17): '\x68\x74\x74\x70\x73\x3a\x2f\x2f\x64\x72\x69\x76\x65\x2e\x67\x6f\x6f\x67\x6c\x65\x2e\x63\x6f\x6d\x2f\x75\x63\x3f\x65\x78\x70\x6f\x72\x74\x3d\x64\x6f\x77\x6e\x6c\x6f\x61\x64\x26\x69\x64\x3d\x30\x42\x2d\x5a\x43\x56\x53\x76\x75\x4e\x57\x66\x30\x54\x44\x46\x52\x4f\x47\x35\x46\x62\x55\x39\x4f\x64\x44\x67'], - proxyHosts: ['proxy.antizapret.prostovpn.org', 'gw2.anticenz.org'], + proxyHosts: ['proxy.antizapret.prostovpn.org'], proxyIps: { '195.123.209.38': 'proxy.antizapret.prostovpn.org', '137.74.171.91': 'proxy.antizapret.prostovpn.org', '51.15.39.201': 'proxy.antizapret.prostovpn.org', - '2a02:27ac::10': 'proxy.antizapret.prostovpn.org', '2001:bc8:4700:2300::1:d07': 'proxy.antizapret.prostovpn.org', - '5.196.220.114': 'gw2.anticenz.org', + '2a02:27ac::10': 'proxy.antizapret.prostovpn.org', }, }, }, - _currentPacProviderKey: 'Оба_и_на_свитчах', + _currentPacProviderKey: 'Антицензорити', /* Is it the first time extension installed? Do something, e.g. initiate PAC sync. @@ -181,7 +479,7 @@ return this._currentPacProviderKey; }, - setCurrentPacProviderKey(newKey, lastModified = new Date().toUTCString()) { + setCurrentPacProviderKey(newKey = mandatory(), lastModified = new Date().toUTCString()) { this.mustBeKey(newKey); this._currentPacProviderKey = newKey; @@ -237,11 +535,7 @@ if (key === null) { // No pac provider set. - return cb({ - clarification: { - message: 'Сперва выберите PAC-провайдера.', - }, - }); + return clarifyErrorThen('Сперва выберите PAC-провайдера.', cb); } const pacProvider = this.getPacProvider(key); @@ -250,43 +544,40 @@ (resolve, reject) => setPacScriptFromProviderAsync( pacProvider, this.getLastModifiedForKey(key), - (err, res) => { + (err, res, warns) => { - if (res && res.ifPacSet) { + if (!err) { this.setCurrentPacProviderKey(key, res.lastModified); this.lastPacUpdateStamp = Date.now(); this.ifFirstInstall = false; this.setAlarms(); } - resolve([err, res]); + resolve([err, null, warns]); } ) ); - const ipsPromise = new Promise( + const ipsErrorPromise = new Promise( (resolve, reject) => updatePacProxyIps( pacProvider, - (ipsError) => { - - if (ipsError && ipsError.clarification) { - ipsError.clarification.ifNotCritical = true; - } - resolve([ipsError]); - - } + resolve ) ); - Promise.all([pacSetPromise, ipsPromise]).then( - ([[pacErr, pacRes], [ipsErr]]) => { + Promise.all([pacSetPromise, ipsErrorPromise]).then( + ([[pacErr, pacRes, pacWarns], ipsErr]) => { if (pacErr && ipsErr) { return cb(pacErr, pacRes); } + let warns = [...(pacWarns || []), ipsErr].filter( (_) => _ ); + if (!warns.length) { + warns = null; + } this.pushToStorageAsync( - (pushErr) => cb(pacErr || ipsErr || pushErr, pacRes) + (pushErr) => cb(pacErr || pushErr, null, warns) ); }, @@ -407,33 +698,55 @@ console.log('Storage on init:', oldStorage); antiCensorRu.ifFirstInstall = Object.keys(oldStorage).length === 0; - if (!antiCensorRu.ifFirstInstall) { - // LAUNCH, RELOAD, UPDATE - // Use old or migrate to default. - antiCensorRu._currentPacProviderKey = - oldStorage._currentPacProviderKey || null; - antiCensorRu.lastPacUpdateStamp = - oldStorage.lastPacUpdateStamp || antiCensorRu.lastPacUpdateStamp; - antiCensorRu._currentPacProviderLastModified = - oldStorage._currentPacProviderLastModified - || antiCensorRu._currentPacProviderLastModified; - console.log( - 'Last PAC update was on', - new Date(antiCensorRu.lastPacUpdateStamp).toLocaleString('ru-RU') - ); - } else { + if (antiCensorRu.ifFirstInstall) { // INSTALL console.log('Installing...'); return chrome.runtime.openOptionsPage(); } + // LAUNCH, RELOAD, UPDATE + // Use old or migrate to default. + antiCensorRu._currentPacProviderKey = + oldStorage._currentPacProviderKey || null; + antiCensorRu.lastPacUpdateStamp = + oldStorage.lastPacUpdateStamp || antiCensorRu.lastPacUpdateStamp; + antiCensorRu._currentPacProviderLastModified = + oldStorage._currentPacProviderLastModified + || antiCensorRu._currentPacProviderLastModified; + console.log( + 'Last PAC update was on', + new Date(antiCensorRu.lastPacUpdateStamp).toLocaleString('ru-RU') + ); + + const ifUpdating = antiCensorRu.version !== oldStorage.version; + console.log('IF_UPD?', ifUpdating, antiCensorRu.version, 'vs', oldStorage.version); + + const pushOnUpdate = () => ifUpdating ? antiCensorRu.pushToStorageAsync() : null; + + if (!ifUpdating) { + // LAUNCH, RELOAD, ENABLE + antiCensorRu.pacProviders = oldStorage.pacProviders; + console.log('Extension launched, reloaded or enabled.'); + } else { + // UPDATE & MIGRATION + const key = antiCensorRu._currentPacProviderKey; + if ( + key !== null && + !Object.keys(antiCensorRu.pacProviders).includes(key) + ) { + antiCensorRu._currentPacProviderKey = 'Антицензорити' + } + console.log('Extension updated.'); + } + if (!antiCensorRu.getPacProvider()) { /* In case of UPDATE: 1. new providers will still be shown. 2. new version won't be pushed to storage */ - return console.log('No PAC provider set. Do nothing.'); + console.log('No PAC provider set. Do nothing.'); + return pushOnUpdate(); } /* @@ -446,306 +759,24 @@ const ifAlarmTriggered = antiCensorRu.setAlarms(); - if (antiCensorRu.version === oldStorage.version) { - // LAUNCH, RELOAD, ENABLE - antiCensorRu.pacProviders = oldStorage.pacProviders; - return console.log('Extension launched, reloaded or enabled.'); - } - - // UPDATE & MIGRATION - console.log('Extension updated.'); if (!ifAlarmTriggered) { - antiCensorRu.pushToStorageAsync(); + return pushOnUpdate(); } /* History of Changes to Storage (Migration Guide) ----------------------------------------------- - Version 0.0.0.10 - * Added this.version - * PacProvider.proxyIps changed from {ip -> Boolean} to {ip -> hostname} - Version 0.0.0.8-9 - * Changed storage.ifNotInstalled to storage.ifFirstInstall - * Added storage.lastPacUpdateStamp + Version 0.0.0.17: + * "Антиценз" removed. + * "Оба_и_на_свитчах" renamed to "Антицензорити". + Version 0.0.0.10: + * Added this.version. + * PacProvider.proxyIps changed from {ip -> Boolean} to {ip -> hostname}. + Version 0.0.0.8-9: + * Changed storage.ifNotInstalled to storage.ifFirstInstall. + * Added storage.lastPacUpdateStamp. **/ }); - /* - * result.ifPacSet is true if PAC was set (maybe with non-critical errors). - * */ - function setPacAsync( - {pacData = mandatory(), pacUrl = mandatory()}, - cb = throwIfError - ) { - - const config = { - mode: 'pac_script', - pacScript: { - mandatory: false, - data: pacData, - }, - }; - console.log('Setting chrome proxy settings...'); - chrome.proxy.settings.set( {value: config}, async () => { - - let err = checkChromeError(); - let asciiErr; - if (err) { - if (err.message.startsWith('\'pacScript.data\' supports only ASCII')) { - asciiErr = err; - asciiErr.clarification = {ifNotCritical: true}; - err = await new Promise((resolve) => { - - chrome.proxy.settings.set({ - value: { - mode: 'pac_script', - pacScript: { - url: pacUrl, - }, - }, - }, - () => resolve( checkChromeError() ) - ); - - }); - - } - if (err) { - return cb(err); - } - } - chrome.proxy.settings.get({}, (details) => { - - if ( window.utils.areSettingsNotControlledFor( details ) ) { - console.warn('Failed, other extension is in control.'); - return cb({clarification: { - message: window.utils.messages.whichExtensionHtml(), - }}); - } - console.log('Successfuly set PAC in proxy settings..'); - cb(asciiErr, {ifPacSet: true}); - }); - - }); - - } - - function clarifyFetchErrorThen(cb) { - - return (err) => { - - err.clarification = { - message: 'Что-то не так с сетью, проверьте соединение.', - }; - return cb(err); - - } - - } - - function ifModifiedSince(url, lastModified = mandatory(), cb = mandatory()) { - - const nowModified = new Date(0).toUTCString(); - fetch(url, { - method: 'HEAD', - headers: new Headers({ - 'If-Modified-Since': lastModified - }) - }).then( - (res) => { - cb(null, res.status === 304 ? false : (res.headers.get('Last-Modified') || nowModified) ); - }, - clarifyFetchErrorThen((err) => cb(err, nowModified)) - ); - - } - - function httpGet(url, cb = mandatory()) { - - const start = Date.now(); - fetch(url, {cache: 'no-store'}).then( - (res) => { - - const textCb = - (err) => res.text().then( (text) => cb(err, text), cb ); - const status = res.status; - if ( !( status >= 200 && status < 300 || status === 304 ) ) { - res.clarification = { - message: 'Получен ответ с неудачным HTTP-кодом ' + status + '.', - }; - return textCb(res); - } - console.log('GETed with success:', url, Date.now() - start); - textCb(); - - }, - clarifyFetchErrorThen(cb) - ); - - } - - function getIpsFor(host, cb = mandatory()) { - - const types = [1, 28]; - const promises = types.map( - (type) => new Promise((resolve) => - httpGet( - 'https://dns.google.com/resolve?type=' + type + '&name=' + host, - (err, res) => { - - if (res) { - try { - res = JSON.parse(res); - console.log('Json parsed.'); - if (err || res.Status) { - const msg = ['Answer', 'Comment', 'Status'] - .filter( (prop) => res[prop] ) - .map( (prop) => prop + ': ' + JSON.stringify( res[prop] ) ) - .join(', \n'); - err.clarification.message += ' Сервер (json): ' + msg; - err.data = err.data || res; - } else { - res = res.Answer || []; - res = res.filter( - (record) => types.includes(record.type) - ); - } - } catch(e) { - err = e || err || {clarification: {message: ''}}; - err.clarification = err.clarification || {message: ''}; - err.clarification.message = ( - err.clarification.message - + ' Сервер (текст): '+ res - ).trim(); - err.data = err.data || res; - } - } - resolve([err, res]); - - } - ) - ) - ); - Promise.all(promises).then( - ([[v4err, v4res], [v6err, v6res]]) => { - - if(v4err) { - return cb(v4err, v4res); - } - const ips = v4res; - if (!v6err) { - ips.push(...v6res); - } else { - v6err.clarification.ifNotCritical = true; - console.warn(v6err); - } - cb(v6err, ips); - - } - ); - - } - - function updatePacProxyIps(provider, cb = throwIfError) { - - cb = asyncLogGroup( - 'Getting IP for '+ provider.proxyHosts.join(', ') + '...', - cb - ); - let failure = { - clarification: { - message: 'Не удалось получить один или несколько IP адресов для' + - ' прокси-серверов. Иконка для уведомления об обходе блокировок ' + - 'может не отображаться.', - }, - errors: {}, - }; - let i = 0; - provider.proxyHosts.forEach( - (proxyHost) => getIpsFor( - proxyHost, - (err, ips) => { - - if (!err || err.clarification.ifNotCritical) { - provider.proxyIps = provider.proxyIps || {}; - ips.forEach( - (ip) => provider.proxyIps[ip] = proxyHost - ); - } else { - failure.errors[proxyHost] = err; - } - - if ( ++i === provider.proxyHosts.length ) { - failure = Object.keys(failure.errors).length ? failure : null; - cb(failure, provider.proxyIps); - } - } - ) - ); - - } - - /* - * result.ifPacSet is true if PAC was set. - **/ - function setPacScriptFromProviderAsync(provider = mandatory(), lastModified = mandatory(), cb = throwIfError) { - - const pacUrl = provider.pacUrls[0]; - cb = asyncLogGroup( - 'Getting PAC script from provider...', pacUrl, - cb - ); - - ifModifiedSince(pacUrl, lastModified, (err, newLastModified) => { - - if (!newLastModified) { - return cb( - {clarification: { - message: 'Ваш PAC-скрипт не нуждается в обновлении. Его дата: ' + lastModified, - ifNotCritical: true, - }} - ); - } - - // Employ all urls, the latter are fallbacks for the former. - let pacDataPromise = Promise.reject(); - for(const url of provider.pacUrls) { - - pacDataPromise = pacDataPromise.catch( - (err) => new Promise( - (resolve, reject) => httpGet( - url, - (newErr, pacData) => newErr ? reject(newErr) : resolve(pacData) - ) - ) - ); - - } - - pacDataPromise.then( - (pacData) => { - - setPacAsync( - {pacData, pacUrl}, - (err, res) => cb( err, Object.assign(res || {}, {lastModified: newLastModified}) ) - ); - - }, - (err) => { - - err.clarification = { - message: 'Не удалось скачать PAC-скрипт с адресов: [ ' - + provider.pacUrls.join(' , ') + ' ].', - prev: err.clarification, - }; - return cb(err); - - } - ); - - }); - - } - } diff --git a/extensions/chromium/runet-censorship-bypass/extension/40-context-menus.js b/extensions/chromium/runet-censorship-bypass/extension/40-context-menus.js index 2db6a12..16ff1cd 100644 --- a/extensions/chromium/runet-censorship-bypass/extension/40-context-menus.js +++ b/extensions/chromium/runet-censorship-bypass/extension/40-context-menus.js @@ -11,7 +11,7 @@ }); createMenuLinkEntry( - 'Сайт доступен из-за границы? Is up?', + 'Сайт доступен из-за границы?', (tab) => `data:text/html;charset=utf8,Запрашиваю...
@@ -42,8 +42,8 @@ ); createMenuLinkEntry( - 'У меня проблемы с расширением!', - (tab) => 'https://rebrand.ly/ac-support' + 'Руководство / Помощь / Ссылки', + (tab) => 'https://rebrand.ly/ac-wiki' ); } diff --git a/extensions/chromium/runet-censorship-bypass/extension/manifest.json b/extensions/chromium/runet-censorship-bypass/extension/manifest.json index 23a89ea..ff2dd1a 100755 --- a/extensions/chromium/runet-censorship-bypass/extension/manifest.json +++ b/extensions/chromium/runet-censorship-bypass/extension/manifest.json @@ -1,7 +1,7 @@ { "manifest_version": 2, - "name": "__MSG_extName__ 0.17", + "name": "__MSG_extName__ 0.16", "default_locale": "ru", "description": "__MSG_extDesc__", "version": "0.0.0.17", diff --git a/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/font-awesome/css/font-awesome.min.css b/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/font-awesome/css/font-awesome.min.css new file mode 100644 index 0000000..540440c --- /dev/null +++ b/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/font-awesome/css/font-awesome.min.css @@ -0,0 +1,4 @@ +/*! + * Font Awesome 4.7.0 by @davegandy - http://fontawesome.io - @fontawesome + * License - http://fontawesome.io/license (Font: SIL OFL 1.1, CSS: MIT License) + */@font-face{font-family:'FontAwesome';src:url('../fonts/fontawesome-webfont.eot?v=4.7.0');src:url('../fonts/fontawesome-webfont.eot?#iefix&v=4.7.0') format('embedded-opentype'),url('../fonts/fontawesome-webfont.woff2?v=4.7.0') format('woff2'),url('../fonts/fontawesome-webfont.woff?v=4.7.0') format('woff'),url('../fonts/fontawesome-webfont.ttf?v=4.7.0') format('truetype'),url('../fonts/fontawesome-webfont.svg?v=4.7.0#fontawesomeregular') format('svg');font-weight:normal;font-style:normal}.fa{display:inline-block;font:normal normal normal 14px/1 FontAwesome;font-size:inherit;text-rendering:auto;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.fa-lg{font-size:1.33333333em;line-height:.75em;vertical-align:-15%}.fa-2x{font-size:2em}.fa-3x{font-size:3em}.fa-4x{font-size:4em}.fa-5x{font-size:5em}.fa-fw{width:1.28571429em;text-align:center}.fa-ul{padding-left:0;margin-left:2.14285714em;list-style-type:none}.fa-ul>li{position:relative}.fa-li{position:absolute;left:-2.14285714em;width:2.14285714em;top:.14285714em;text-align:center}.fa-li.fa-lg{left:-1.85714286em}.fa-border{padding:.2em .25em .15em;border:solid .08em #eee;border-radius:.1em}.fa-pull-left{float:left}.fa-pull-right{float:right}.fa.fa-pull-left{margin-right:.3em}.fa.fa-pull-right{margin-left:.3em}.pull-right{float:right}.pull-left{float:left}.fa.pull-left{margin-right:.3em}.fa.pull-right{margin-left:.3em}.fa-spin{-webkit-animation:fa-spin 2s infinite linear;animation:fa-spin 2s infinite linear}.fa-pulse{-webkit-animation:fa-spin 1s infinite steps(8);animation:fa-spin 1s infinite steps(8)}@-webkit-keyframes fa-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}100%{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}@keyframes fa-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}100%{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}.fa-rotate-90{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=1)";-webkit-transform:rotate(90deg);-ms-transform:rotate(90deg);transform:rotate(90deg)}.fa-rotate-180{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=2)";-webkit-transform:rotate(180deg);-ms-transform:rotate(180deg);transform:rotate(180deg)}.fa-rotate-270{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=3)";-webkit-transform:rotate(270deg);-ms-transform:rotate(270deg);transform:rotate(270deg)}.fa-flip-horizontal{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=0, mirror=1)";-webkit-transform:scale(-1, 1);-ms-transform:scale(-1, 1);transform:scale(-1, 1)}.fa-flip-vertical{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=2, mirror=1)";-webkit-transform:scale(1, -1);-ms-transform:scale(1, -1);transform:scale(1, -1)}:root .fa-rotate-90,:root .fa-rotate-180,:root .fa-rotate-270,:root .fa-flip-horizontal,:root .fa-flip-vertical{filter:none}.fa-stack{position:relative;display:inline-block;width:2em;height:2em;line-height:2em;vertical-align:middle}.fa-stack-1x,.fa-stack-2x{position:absolute;left:0;width:100%;text-align:center}.fa-stack-1x{line-height:inherit}.fa-stack-2x{font-size:2em}.fa-inverse{color:#fff}.fa-glass:before{content:"\f000"}.fa-music:before{content:"\f001"}.fa-search:before{content:"\f002"}.fa-envelope-o:before{content:"\f003"}.fa-heart:before{content:"\f004"}.fa-star:before{content:"\f005"}.fa-star-o:before{content:"\f006"}.fa-user:before{content:"\f007"}.fa-film:before{content:"\f008"}.fa-th-large:before{content:"\f009"}.fa-th:before{content:"\f00a"}.fa-th-list:before{content:"\f00b"}.fa-check:before{content:"\f00c"}.fa-remove:before,.fa-close:before,.fa-times:before{content:"\f00d"}.fa-search-plus:before{content:"\f00e"}.fa-search-minus:before{content:"\f010"}.fa-power-off:before{content:"\f011"}.fa-signal:before{content:"\f012"}.fa-gear:before,.fa-cog:before{content:"\f013"}.fa-trash-o:before{content:"\f014"}.fa-home:before{content:"\f015"}.fa-file-o:before{content:"\f016"}.fa-clock-o:before{content:"\f017"}.fa-road:before{content:"\f018"}.fa-download:before{content:"\f019"}.fa-arrow-circle-o-down:before{content:"\f01a"}.fa-arrow-circle-o-up:before{content:"\f01b"}.fa-inbox:before{content:"\f01c"}.fa-play-circle-o:before{content:"\f01d"}.fa-rotate-right:before,.fa-repeat:before{content:"\f01e"}.fa-refresh:before{content:"\f021"}.fa-list-alt:before{content:"\f022"}.fa-lock:before{content:"\f023"}.fa-flag:before{content:"\f024"}.fa-headphones:before{content:"\f025"}.fa-volume-off:before{content:"\f026"}.fa-volume-down:before{content:"\f027"}.fa-volume-up:before{content:"\f028"}.fa-qrcode:before{content:"\f029"}.fa-barcode:before{content:"\f02a"}.fa-tag:before{content:"\f02b"}.fa-tags:before{content:"\f02c"}.fa-book:before{content:"\f02d"}.fa-bookmark:before{content:"\f02e"}.fa-print:before{content:"\f02f"}.fa-camera:before{content:"\f030"}.fa-font:before{content:"\f031"}.fa-bold:before{content:"\f032"}.fa-italic:before{content:"\f033"}.fa-text-height:before{content:"\f034"}.fa-text-width:before{content:"\f035"}.fa-align-left:before{content:"\f036"}.fa-align-center:before{content:"\f037"}.fa-align-right:before{content:"\f038"}.fa-align-justify:before{content:"\f039"}.fa-list:before{content:"\f03a"}.fa-dedent:before,.fa-outdent:before{content:"\f03b"}.fa-indent:before{content:"\f03c"}.fa-video-camera:before{content:"\f03d"}.fa-photo:before,.fa-image:before,.fa-picture-o:before{content:"\f03e"}.fa-pencil:before{content:"\f040"}.fa-map-marker:before{content:"\f041"}.fa-adjust:before{content:"\f042"}.fa-tint:before{content:"\f043"}.fa-edit:before,.fa-pencil-square-o:before{content:"\f044"}.fa-share-square-o:before{content:"\f045"}.fa-check-square-o:before{content:"\f046"}.fa-arrows:before{content:"\f047"}.fa-step-backward:before{content:"\f048"}.fa-fast-backward:before{content:"\f049"}.fa-backward:before{content:"\f04a"}.fa-play:before{content:"\f04b"}.fa-pause:before{content:"\f04c"}.fa-stop:before{content:"\f04d"}.fa-forward:before{content:"\f04e"}.fa-fast-forward:before{content:"\f050"}.fa-step-forward:before{content:"\f051"}.fa-eject:before{content:"\f052"}.fa-chevron-left:before{content:"\f053"}.fa-chevron-right:before{content:"\f054"}.fa-plus-circle:before{content:"\f055"}.fa-minus-circle:before{content:"\f056"}.fa-times-circle:before{content:"\f057"}.fa-check-circle:before{content:"\f058"}.fa-question-circle:before{content:"\f059"}.fa-info-circle:before{content:"\f05a"}.fa-crosshairs:before{content:"\f05b"}.fa-times-circle-o:before{content:"\f05c"}.fa-check-circle-o:before{content:"\f05d"}.fa-ban:before{content:"\f05e"}.fa-arrow-left:before{content:"\f060"}.fa-arrow-right:before{content:"\f061"}.fa-arrow-up:before{content:"\f062"}.fa-arrow-down:before{content:"\f063"}.fa-mail-forward:before,.fa-share:before{content:"\f064"}.fa-expand:before{content:"\f065"}.fa-compress:before{content:"\f066"}.fa-plus:before{content:"\f067"}.fa-minus:before{content:"\f068"}.fa-asterisk:before{content:"\f069"}.fa-exclamation-circle:before{content:"\f06a"}.fa-gift:before{content:"\f06b"}.fa-leaf:before{content:"\f06c"}.fa-fire:before{content:"\f06d"}.fa-eye:before{content:"\f06e"}.fa-eye-slash:before{content:"\f070"}.fa-warning:before,.fa-exclamation-triangle:before{content:"\f071"}.fa-plane:before{content:"\f072"}.fa-calendar:before{content:"\f073"}.fa-random:before{content:"\f074"}.fa-comment:before{content:"\f075"}.fa-magnet:before{content:"\f076"}.fa-chevron-up:before{content:"\f077"}.fa-chevron-down:before{content:"\f078"}.fa-retweet:before{content:"\f079"}.fa-shopping-cart:before{content:"\f07a"}.fa-folder:before{content:"\f07b"}.fa-folder-open:before{content:"\f07c"}.fa-arrows-v:before{content:"\f07d"}.fa-arrows-h:before{content:"\f07e"}.fa-bar-chart-o:before,.fa-bar-chart:before{content:"\f080"}.fa-twitter-square:before{content:"\f081"}.fa-facebook-square:before{content:"\f082"}.fa-camera-retro:before{content:"\f083"}.fa-key:before{content:"\f084"}.fa-gears:before,.fa-cogs:before{content:"\f085"}.fa-comments:before{content:"\f086"}.fa-thumbs-o-up:before{content:"\f087"}.fa-thumbs-o-down:before{content:"\f088"}.fa-star-half:before{content:"\f089"}.fa-heart-o:before{content:"\f08a"}.fa-sign-out:before{content:"\f08b"}.fa-linkedin-square:before{content:"\f08c"}.fa-thumb-tack:before{content:"\f08d"}.fa-external-link:before{content:"\f08e"}.fa-sign-in:before{content:"\f090"}.fa-trophy:before{content:"\f091"}.fa-github-square:before{content:"\f092"}.fa-upload:before{content:"\f093"}.fa-lemon-o:before{content:"\f094"}.fa-phone:before{content:"\f095"}.fa-square-o:before{content:"\f096"}.fa-bookmark-o:before{content:"\f097"}.fa-phone-square:before{content:"\f098"}.fa-twitter:before{content:"\f099"}.fa-facebook-f:before,.fa-facebook:before{content:"\f09a"}.fa-github:before{content:"\f09b"}.fa-unlock:before{content:"\f09c"}.fa-credit-card:before{content:"\f09d"}.fa-feed:before,.fa-rss:before{content:"\f09e"}.fa-hdd-o:before{content:"\f0a0"}.fa-bullhorn:before{content:"\f0a1"}.fa-bell:before{content:"\f0f3"}.fa-certificate:before{content:"\f0a3"}.fa-hand-o-right:before{content:"\f0a4"}.fa-hand-o-left:before{content:"\f0a5"}.fa-hand-o-up:before{content:"\f0a6"}.fa-hand-o-down:before{content:"\f0a7"}.fa-arrow-circle-left:before{content:"\f0a8"}.fa-arrow-circle-right:before{content:"\f0a9"}.fa-arrow-circle-up:before{content:"\f0aa"}.fa-arrow-circle-down:before{content:"\f0ab"}.fa-globe:before{content:"\f0ac"}.fa-wrench:before{content:"\f0ad"}.fa-tasks:before{content:"\f0ae"}.fa-filter:before{content:"\f0b0"}.fa-briefcase:before{content:"\f0b1"}.fa-arrows-alt:before{content:"\f0b2"}.fa-group:before,.fa-users:before{content:"\f0c0"}.fa-chain:before,.fa-link:before{content:"\f0c1"}.fa-cloud:before{content:"\f0c2"}.fa-flask:before{content:"\f0c3"}.fa-cut:before,.fa-scissors:before{content:"\f0c4"}.fa-copy:before,.fa-files-o:before{content:"\f0c5"}.fa-paperclip:before{content:"\f0c6"}.fa-save:before,.fa-floppy-o:before{content:"\f0c7"}.fa-square:before{content:"\f0c8"}.fa-navicon:before,.fa-reorder:before,.fa-bars:before{content:"\f0c9"}.fa-list-ul:before{content:"\f0ca"}.fa-list-ol:before{content:"\f0cb"}.fa-strikethrough:before{content:"\f0cc"}.fa-underline:before{content:"\f0cd"}.fa-table:before{content:"\f0ce"}.fa-magic:before{content:"\f0d0"}.fa-truck:before{content:"\f0d1"}.fa-pinterest:before{content:"\f0d2"}.fa-pinterest-square:before{content:"\f0d3"}.fa-google-plus-square:before{content:"\f0d4"}.fa-google-plus:before{content:"\f0d5"}.fa-money:before{content:"\f0d6"}.fa-caret-down:before{content:"\f0d7"}.fa-caret-up:before{content:"\f0d8"}.fa-caret-left:before{content:"\f0d9"}.fa-caret-right:before{content:"\f0da"}.fa-columns:before{content:"\f0db"}.fa-unsorted:before,.fa-sort:before{content:"\f0dc"}.fa-sort-down:before,.fa-sort-desc:before{content:"\f0dd"}.fa-sort-up:before,.fa-sort-asc:before{content:"\f0de"}.fa-envelope:before{content:"\f0e0"}.fa-linkedin:before{content:"\f0e1"}.fa-rotate-left:before,.fa-undo:before{content:"\f0e2"}.fa-legal:before,.fa-gavel:before{content:"\f0e3"}.fa-dashboard:before,.fa-tachometer:before{content:"\f0e4"}.fa-comment-o:before{content:"\f0e5"}.fa-comments-o:before{content:"\f0e6"}.fa-flash:before,.fa-bolt:before{content:"\f0e7"}.fa-sitemap:before{content:"\f0e8"}.fa-umbrella:before{content:"\f0e9"}.fa-paste:before,.fa-clipboard:before{content:"\f0ea"}.fa-lightbulb-o:before{content:"\f0eb"}.fa-exchange:before{content:"\f0ec"}.fa-cloud-download:before{content:"\f0ed"}.fa-cloud-upload:before{content:"\f0ee"}.fa-user-md:before{content:"\f0f0"}.fa-stethoscope:before{content:"\f0f1"}.fa-suitcase:before{content:"\f0f2"}.fa-bell-o:before{content:"\f0a2"}.fa-coffee:before{content:"\f0f4"}.fa-cutlery:before{content:"\f0f5"}.fa-file-text-o:before{content:"\f0f6"}.fa-building-o:before{content:"\f0f7"}.fa-hospital-o:before{content:"\f0f8"}.fa-ambulance:before{content:"\f0f9"}.fa-medkit:before{content:"\f0fa"}.fa-fighter-jet:before{content:"\f0fb"}.fa-beer:before{content:"\f0fc"}.fa-h-square:before{content:"\f0fd"}.fa-plus-square:before{content:"\f0fe"}.fa-angle-double-left:before{content:"\f100"}.fa-angle-double-right:before{content:"\f101"}.fa-angle-double-up:before{content:"\f102"}.fa-angle-double-down:before{content:"\f103"}.fa-angle-left:before{content:"\f104"}.fa-angle-right:before{content:"\f105"}.fa-angle-up:before{content:"\f106"}.fa-angle-down:before{content:"\f107"}.fa-desktop:before{content:"\f108"}.fa-laptop:before{content:"\f109"}.fa-tablet:before{content:"\f10a"}.fa-mobile-phone:before,.fa-mobile:before{content:"\f10b"}.fa-circle-o:before{content:"\f10c"}.fa-quote-left:before{content:"\f10d"}.fa-quote-right:before{content:"\f10e"}.fa-spinner:before{content:"\f110"}.fa-circle:before{content:"\f111"}.fa-mail-reply:before,.fa-reply:before{content:"\f112"}.fa-github-alt:before{content:"\f113"}.fa-folder-o:before{content:"\f114"}.fa-folder-open-o:before{content:"\f115"}.fa-smile-o:before{content:"\f118"}.fa-frown-o:before{content:"\f119"}.fa-meh-o:before{content:"\f11a"}.fa-gamepad:before{content:"\f11b"}.fa-keyboard-o:before{content:"\f11c"}.fa-flag-o:before{content:"\f11d"}.fa-flag-checkered:before{content:"\f11e"}.fa-terminal:before{content:"\f120"}.fa-code:before{content:"\f121"}.fa-mail-reply-all:before,.fa-reply-all:before{content:"\f122"}.fa-star-half-empty:before,.fa-star-half-full:before,.fa-star-half-o:before{content:"\f123"}.fa-location-arrow:before{content:"\f124"}.fa-crop:before{content:"\f125"}.fa-code-fork:before{content:"\f126"}.fa-unlink:before,.fa-chain-broken:before{content:"\f127"}.fa-question:before{content:"\f128"}.fa-info:before{content:"\f129"}.fa-exclamation:before{content:"\f12a"}.fa-superscript:before{content:"\f12b"}.fa-subscript:before{content:"\f12c"}.fa-eraser:before{content:"\f12d"}.fa-puzzle-piece:before{content:"\f12e"}.fa-microphone:before{content:"\f130"}.fa-microphone-slash:before{content:"\f131"}.fa-shield:before{content:"\f132"}.fa-calendar-o:before{content:"\f133"}.fa-fire-extinguisher:before{content:"\f134"}.fa-rocket:before{content:"\f135"}.fa-maxcdn:before{content:"\f136"}.fa-chevron-circle-left:before{content:"\f137"}.fa-chevron-circle-right:before{content:"\f138"}.fa-chevron-circle-up:before{content:"\f139"}.fa-chevron-circle-down:before{content:"\f13a"}.fa-html5:before{content:"\f13b"}.fa-css3:before{content:"\f13c"}.fa-anchor:before{content:"\f13d"}.fa-unlock-alt:before{content:"\f13e"}.fa-bullseye:before{content:"\f140"}.fa-ellipsis-h:before{content:"\f141"}.fa-ellipsis-v:before{content:"\f142"}.fa-rss-square:before{content:"\f143"}.fa-play-circle:before{content:"\f144"}.fa-ticket:before{content:"\f145"}.fa-minus-square:before{content:"\f146"}.fa-minus-square-o:before{content:"\f147"}.fa-level-up:before{content:"\f148"}.fa-level-down:before{content:"\f149"}.fa-check-square:before{content:"\f14a"}.fa-pencil-square:before{content:"\f14b"}.fa-external-link-square:before{content:"\f14c"}.fa-share-square:before{content:"\f14d"}.fa-compass:before{content:"\f14e"}.fa-toggle-down:before,.fa-caret-square-o-down:before{content:"\f150"}.fa-toggle-up:before,.fa-caret-square-o-up:before{content:"\f151"}.fa-toggle-right:before,.fa-caret-square-o-right:before{content:"\f152"}.fa-euro:before,.fa-eur:before{content:"\f153"}.fa-gbp:before{content:"\f154"}.fa-dollar:before,.fa-usd:before{content:"\f155"}.fa-rupee:before,.fa-inr:before{content:"\f156"}.fa-cny:before,.fa-rmb:before,.fa-yen:before,.fa-jpy:before{content:"\f157"}.fa-ruble:before,.fa-rouble:before,.fa-rub:before{content:"\f158"}.fa-won:before,.fa-krw:before{content:"\f159"}.fa-bitcoin:before,.fa-btc:before{content:"\f15a"}.fa-file:before{content:"\f15b"}.fa-file-text:before{content:"\f15c"}.fa-sort-alpha-asc:before{content:"\f15d"}.fa-sort-alpha-desc:before{content:"\f15e"}.fa-sort-amount-asc:before{content:"\f160"}.fa-sort-amount-desc:before{content:"\f161"}.fa-sort-numeric-asc:before{content:"\f162"}.fa-sort-numeric-desc:before{content:"\f163"}.fa-thumbs-up:before{content:"\f164"}.fa-thumbs-down:before{content:"\f165"}.fa-youtube-square:before{content:"\f166"}.fa-youtube:before{content:"\f167"}.fa-xing:before{content:"\f168"}.fa-xing-square:before{content:"\f169"}.fa-youtube-play:before{content:"\f16a"}.fa-dropbox:before{content:"\f16b"}.fa-stack-overflow:before{content:"\f16c"}.fa-instagram:before{content:"\f16d"}.fa-flickr:before{content:"\f16e"}.fa-adn:before{content:"\f170"}.fa-bitbucket:before{content:"\f171"}.fa-bitbucket-square:before{content:"\f172"}.fa-tumblr:before{content:"\f173"}.fa-tumblr-square:before{content:"\f174"}.fa-long-arrow-down:before{content:"\f175"}.fa-long-arrow-up:before{content:"\f176"}.fa-long-arrow-left:before{content:"\f177"}.fa-long-arrow-right:before{content:"\f178"}.fa-apple:before{content:"\f179"}.fa-windows:before{content:"\f17a"}.fa-android:before{content:"\f17b"}.fa-linux:before{content:"\f17c"}.fa-dribbble:before{content:"\f17d"}.fa-skype:before{content:"\f17e"}.fa-foursquare:before{content:"\f180"}.fa-trello:before{content:"\f181"}.fa-female:before{content:"\f182"}.fa-male:before{content:"\f183"}.fa-gittip:before,.fa-gratipay:before{content:"\f184"}.fa-sun-o:before{content:"\f185"}.fa-moon-o:before{content:"\f186"}.fa-archive:before{content:"\f187"}.fa-bug:before{content:"\f188"}.fa-vk:before{content:"\f189"}.fa-weibo:before{content:"\f18a"}.fa-renren:before{content:"\f18b"}.fa-pagelines:before{content:"\f18c"}.fa-stack-exchange:before{content:"\f18d"}.fa-arrow-circle-o-right:before{content:"\f18e"}.fa-arrow-circle-o-left:before{content:"\f190"}.fa-toggle-left:before,.fa-caret-square-o-left:before{content:"\f191"}.fa-dot-circle-o:before{content:"\f192"}.fa-wheelchair:before{content:"\f193"}.fa-vimeo-square:before{content:"\f194"}.fa-turkish-lira:before,.fa-try:before{content:"\f195"}.fa-plus-square-o:before{content:"\f196"}.fa-space-shuttle:before{content:"\f197"}.fa-slack:before{content:"\f198"}.fa-envelope-square:before{content:"\f199"}.fa-wordpress:before{content:"\f19a"}.fa-openid:before{content:"\f19b"}.fa-institution:before,.fa-bank:before,.fa-university:before{content:"\f19c"}.fa-mortar-board:before,.fa-graduation-cap:before{content:"\f19d"}.fa-yahoo:before{content:"\f19e"}.fa-google:before{content:"\f1a0"}.fa-reddit:before{content:"\f1a1"}.fa-reddit-square:before{content:"\f1a2"}.fa-stumbleupon-circle:before{content:"\f1a3"}.fa-stumbleupon:before{content:"\f1a4"}.fa-delicious:before{content:"\f1a5"}.fa-digg:before{content:"\f1a6"}.fa-pied-piper-pp:before{content:"\f1a7"}.fa-pied-piper-alt:before{content:"\f1a8"}.fa-drupal:before{content:"\f1a9"}.fa-joomla:before{content:"\f1aa"}.fa-language:before{content:"\f1ab"}.fa-fax:before{content:"\f1ac"}.fa-building:before{content:"\f1ad"}.fa-child:before{content:"\f1ae"}.fa-paw:before{content:"\f1b0"}.fa-spoon:before{content:"\f1b1"}.fa-cube:before{content:"\f1b2"}.fa-cubes:before{content:"\f1b3"}.fa-behance:before{content:"\f1b4"}.fa-behance-square:before{content:"\f1b5"}.fa-steam:before{content:"\f1b6"}.fa-steam-square:before{content:"\f1b7"}.fa-recycle:before{content:"\f1b8"}.fa-automobile:before,.fa-car:before{content:"\f1b9"}.fa-cab:before,.fa-taxi:before{content:"\f1ba"}.fa-tree:before{content:"\f1bb"}.fa-spotify:before{content:"\f1bc"}.fa-deviantart:before{content:"\f1bd"}.fa-soundcloud:before{content:"\f1be"}.fa-database:before{content:"\f1c0"}.fa-file-pdf-o:before{content:"\f1c1"}.fa-file-word-o:before{content:"\f1c2"}.fa-file-excel-o:before{content:"\f1c3"}.fa-file-powerpoint-o:before{content:"\f1c4"}.fa-file-photo-o:before,.fa-file-picture-o:before,.fa-file-image-o:before{content:"\f1c5"}.fa-file-zip-o:before,.fa-file-archive-o:before{content:"\f1c6"}.fa-file-sound-o:before,.fa-file-audio-o:before{content:"\f1c7"}.fa-file-movie-o:before,.fa-file-video-o:before{content:"\f1c8"}.fa-file-code-o:before{content:"\f1c9"}.fa-vine:before{content:"\f1ca"}.fa-codepen:before{content:"\f1cb"}.fa-jsfiddle:before{content:"\f1cc"}.fa-life-bouy:before,.fa-life-buoy:before,.fa-life-saver:before,.fa-support:before,.fa-life-ring:before{content:"\f1cd"}.fa-circle-o-notch:before{content:"\f1ce"}.fa-ra:before,.fa-resistance:before,.fa-rebel:before{content:"\f1d0"}.fa-ge:before,.fa-empire:before{content:"\f1d1"}.fa-git-square:before{content:"\f1d2"}.fa-git:before{content:"\f1d3"}.fa-y-combinator-square:before,.fa-yc-square:before,.fa-hacker-news:before{content:"\f1d4"}.fa-tencent-weibo:before{content:"\f1d5"}.fa-qq:before{content:"\f1d6"}.fa-wechat:before,.fa-weixin:before{content:"\f1d7"}.fa-send:before,.fa-paper-plane:before{content:"\f1d8"}.fa-send-o:before,.fa-paper-plane-o:before{content:"\f1d9"}.fa-history:before{content:"\f1da"}.fa-circle-thin:before{content:"\f1db"}.fa-header:before{content:"\f1dc"}.fa-paragraph:before{content:"\f1dd"}.fa-sliders:before{content:"\f1de"}.fa-share-alt:before{content:"\f1e0"}.fa-share-alt-square:before{content:"\f1e1"}.fa-bomb:before{content:"\f1e2"}.fa-soccer-ball-o:before,.fa-futbol-o:before{content:"\f1e3"}.fa-tty:before{content:"\f1e4"}.fa-binoculars:before{content:"\f1e5"}.fa-plug:before{content:"\f1e6"}.fa-slideshare:before{content:"\f1e7"}.fa-twitch:before{content:"\f1e8"}.fa-yelp:before{content:"\f1e9"}.fa-newspaper-o:before{content:"\f1ea"}.fa-wifi:before{content:"\f1eb"}.fa-calculator:before{content:"\f1ec"}.fa-paypal:before{content:"\f1ed"}.fa-google-wallet:before{content:"\f1ee"}.fa-cc-visa:before{content:"\f1f0"}.fa-cc-mastercard:before{content:"\f1f1"}.fa-cc-discover:before{content:"\f1f2"}.fa-cc-amex:before{content:"\f1f3"}.fa-cc-paypal:before{content:"\f1f4"}.fa-cc-stripe:before{content:"\f1f5"}.fa-bell-slash:before{content:"\f1f6"}.fa-bell-slash-o:before{content:"\f1f7"}.fa-trash:before{content:"\f1f8"}.fa-copyright:before{content:"\f1f9"}.fa-at:before{content:"\f1fa"}.fa-eyedropper:before{content:"\f1fb"}.fa-paint-brush:before{content:"\f1fc"}.fa-birthday-cake:before{content:"\f1fd"}.fa-area-chart:before{content:"\f1fe"}.fa-pie-chart:before{content:"\f200"}.fa-line-chart:before{content:"\f201"}.fa-lastfm:before{content:"\f202"}.fa-lastfm-square:before{content:"\f203"}.fa-toggle-off:before{content:"\f204"}.fa-toggle-on:before{content:"\f205"}.fa-bicycle:before{content:"\f206"}.fa-bus:before{content:"\f207"}.fa-ioxhost:before{content:"\f208"}.fa-angellist:before{content:"\f209"}.fa-cc:before{content:"\f20a"}.fa-shekel:before,.fa-sheqel:before,.fa-ils:before{content:"\f20b"}.fa-meanpath:before{content:"\f20c"}.fa-buysellads:before{content:"\f20d"}.fa-connectdevelop:before{content:"\f20e"}.fa-dashcube:before{content:"\f210"}.fa-forumbee:before{content:"\f211"}.fa-leanpub:before{content:"\f212"}.fa-sellsy:before{content:"\f213"}.fa-shirtsinbulk:before{content:"\f214"}.fa-simplybuilt:before{content:"\f215"}.fa-skyatlas:before{content:"\f216"}.fa-cart-plus:before{content:"\f217"}.fa-cart-arrow-down:before{content:"\f218"}.fa-diamond:before{content:"\f219"}.fa-ship:before{content:"\f21a"}.fa-user-secret:before{content:"\f21b"}.fa-motorcycle:before{content:"\f21c"}.fa-street-view:before{content:"\f21d"}.fa-heartbeat:before{content:"\f21e"}.fa-venus:before{content:"\f221"}.fa-mars:before{content:"\f222"}.fa-mercury:before{content:"\f223"}.fa-intersex:before,.fa-transgender:before{content:"\f224"}.fa-transgender-alt:before{content:"\f225"}.fa-venus-double:before{content:"\f226"}.fa-mars-double:before{content:"\f227"}.fa-venus-mars:before{content:"\f228"}.fa-mars-stroke:before{content:"\f229"}.fa-mars-stroke-v:before{content:"\f22a"}.fa-mars-stroke-h:before{content:"\f22b"}.fa-neuter:before{content:"\f22c"}.fa-genderless:before{content:"\f22d"}.fa-facebook-official:before{content:"\f230"}.fa-pinterest-p:before{content:"\f231"}.fa-whatsapp:before{content:"\f232"}.fa-server:before{content:"\f233"}.fa-user-plus:before{content:"\f234"}.fa-user-times:before{content:"\f235"}.fa-hotel:before,.fa-bed:before{content:"\f236"}.fa-viacoin:before{content:"\f237"}.fa-train:before{content:"\f238"}.fa-subway:before{content:"\f239"}.fa-medium:before{content:"\f23a"}.fa-yc:before,.fa-y-combinator:before{content:"\f23b"}.fa-optin-monster:before{content:"\f23c"}.fa-opencart:before{content:"\f23d"}.fa-expeditedssl:before{content:"\f23e"}.fa-battery-4:before,.fa-battery:before,.fa-battery-full:before{content:"\f240"}.fa-battery-3:before,.fa-battery-three-quarters:before{content:"\f241"}.fa-battery-2:before,.fa-battery-half:before{content:"\f242"}.fa-battery-1:before,.fa-battery-quarter:before{content:"\f243"}.fa-battery-0:before,.fa-battery-empty:before{content:"\f244"}.fa-mouse-pointer:before{content:"\f245"}.fa-i-cursor:before{content:"\f246"}.fa-object-group:before{content:"\f247"}.fa-object-ungroup:before{content:"\f248"}.fa-sticky-note:before{content:"\f249"}.fa-sticky-note-o:before{content:"\f24a"}.fa-cc-jcb:before{content:"\f24b"}.fa-cc-diners-club:before{content:"\f24c"}.fa-clone:before{content:"\f24d"}.fa-balance-scale:before{content:"\f24e"}.fa-hourglass-o:before{content:"\f250"}.fa-hourglass-1:before,.fa-hourglass-start:before{content:"\f251"}.fa-hourglass-2:before,.fa-hourglass-half:before{content:"\f252"}.fa-hourglass-3:before,.fa-hourglass-end:before{content:"\f253"}.fa-hourglass:before{content:"\f254"}.fa-hand-grab-o:before,.fa-hand-rock-o:before{content:"\f255"}.fa-hand-stop-o:before,.fa-hand-paper-o:before{content:"\f256"}.fa-hand-scissors-o:before{content:"\f257"}.fa-hand-lizard-o:before{content:"\f258"}.fa-hand-spock-o:before{content:"\f259"}.fa-hand-pointer-o:before{content:"\f25a"}.fa-hand-peace-o:before{content:"\f25b"}.fa-trademark:before{content:"\f25c"}.fa-registered:before{content:"\f25d"}.fa-creative-commons:before{content:"\f25e"}.fa-gg:before{content:"\f260"}.fa-gg-circle:before{content:"\f261"}.fa-tripadvisor:before{content:"\f262"}.fa-odnoklassniki:before{content:"\f263"}.fa-odnoklassniki-square:before{content:"\f264"}.fa-get-pocket:before{content:"\f265"}.fa-wikipedia-w:before{content:"\f266"}.fa-safari:before{content:"\f267"}.fa-chrome:before{content:"\f268"}.fa-firefox:before{content:"\f269"}.fa-opera:before{content:"\f26a"}.fa-internet-explorer:before{content:"\f26b"}.fa-tv:before,.fa-television:before{content:"\f26c"}.fa-contao:before{content:"\f26d"}.fa-500px:before{content:"\f26e"}.fa-amazon:before{content:"\f270"}.fa-calendar-plus-o:before{content:"\f271"}.fa-calendar-minus-o:before{content:"\f272"}.fa-calendar-times-o:before{content:"\f273"}.fa-calendar-check-o:before{content:"\f274"}.fa-industry:before{content:"\f275"}.fa-map-pin:before{content:"\f276"}.fa-map-signs:before{content:"\f277"}.fa-map-o:before{content:"\f278"}.fa-map:before{content:"\f279"}.fa-commenting:before{content:"\f27a"}.fa-commenting-o:before{content:"\f27b"}.fa-houzz:before{content:"\f27c"}.fa-vimeo:before{content:"\f27d"}.fa-black-tie:before{content:"\f27e"}.fa-fonticons:before{content:"\f280"}.fa-reddit-alien:before{content:"\f281"}.fa-edge:before{content:"\f282"}.fa-credit-card-alt:before{content:"\f283"}.fa-codiepie:before{content:"\f284"}.fa-modx:before{content:"\f285"}.fa-fort-awesome:before{content:"\f286"}.fa-usb:before{content:"\f287"}.fa-product-hunt:before{content:"\f288"}.fa-mixcloud:before{content:"\f289"}.fa-scribd:before{content:"\f28a"}.fa-pause-circle:before{content:"\f28b"}.fa-pause-circle-o:before{content:"\f28c"}.fa-stop-circle:before{content:"\f28d"}.fa-stop-circle-o:before{content:"\f28e"}.fa-shopping-bag:before{content:"\f290"}.fa-shopping-basket:before{content:"\f291"}.fa-hashtag:before{content:"\f292"}.fa-bluetooth:before{content:"\f293"}.fa-bluetooth-b:before{content:"\f294"}.fa-percent:before{content:"\f295"}.fa-gitlab:before{content:"\f296"}.fa-wpbeginner:before{content:"\f297"}.fa-wpforms:before{content:"\f298"}.fa-envira:before{content:"\f299"}.fa-universal-access:before{content:"\f29a"}.fa-wheelchair-alt:before{content:"\f29b"}.fa-question-circle-o:before{content:"\f29c"}.fa-blind:before{content:"\f29d"}.fa-audio-description:before{content:"\f29e"}.fa-volume-control-phone:before{content:"\f2a0"}.fa-braille:before{content:"\f2a1"}.fa-assistive-listening-systems:before{content:"\f2a2"}.fa-asl-interpreting:before,.fa-american-sign-language-interpreting:before{content:"\f2a3"}.fa-deafness:before,.fa-hard-of-hearing:before,.fa-deaf:before{content:"\f2a4"}.fa-glide:before{content:"\f2a5"}.fa-glide-g:before{content:"\f2a6"}.fa-signing:before,.fa-sign-language:before{content:"\f2a7"}.fa-low-vision:before{content:"\f2a8"}.fa-viadeo:before{content:"\f2a9"}.fa-viadeo-square:before{content:"\f2aa"}.fa-snapchat:before{content:"\f2ab"}.fa-snapchat-ghost:before{content:"\f2ac"}.fa-snapchat-square:before{content:"\f2ad"}.fa-pied-piper:before{content:"\f2ae"}.fa-first-order:before{content:"\f2b0"}.fa-yoast:before{content:"\f2b1"}.fa-themeisle:before{content:"\f2b2"}.fa-google-plus-circle:before,.fa-google-plus-official:before{content:"\f2b3"}.fa-fa:before,.fa-font-awesome:before{content:"\f2b4"}.fa-handshake-o:before{content:"\f2b5"}.fa-envelope-open:before{content:"\f2b6"}.fa-envelope-open-o:before{content:"\f2b7"}.fa-linode:before{content:"\f2b8"}.fa-address-book:before{content:"\f2b9"}.fa-address-book-o:before{content:"\f2ba"}.fa-vcard:before,.fa-address-card:before{content:"\f2bb"}.fa-vcard-o:before,.fa-address-card-o:before{content:"\f2bc"}.fa-user-circle:before{content:"\f2bd"}.fa-user-circle-o:before{content:"\f2be"}.fa-user-o:before{content:"\f2c0"}.fa-id-badge:before{content:"\f2c1"}.fa-drivers-license:before,.fa-id-card:before{content:"\f2c2"}.fa-drivers-license-o:before,.fa-id-card-o:before{content:"\f2c3"}.fa-quora:before{content:"\f2c4"}.fa-free-code-camp:before{content:"\f2c5"}.fa-telegram:before{content:"\f2c6"}.fa-thermometer-4:before,.fa-thermometer:before,.fa-thermometer-full:before{content:"\f2c7"}.fa-thermometer-3:before,.fa-thermometer-three-quarters:before{content:"\f2c8"}.fa-thermometer-2:before,.fa-thermometer-half:before{content:"\f2c9"}.fa-thermometer-1:before,.fa-thermometer-quarter:before{content:"\f2ca"}.fa-thermometer-0:before,.fa-thermometer-empty:before{content:"\f2cb"}.fa-shower:before{content:"\f2cc"}.fa-bathtub:before,.fa-s15:before,.fa-bath:before{content:"\f2cd"}.fa-podcast:before{content:"\f2ce"}.fa-window-maximize:before{content:"\f2d0"}.fa-window-minimize:before{content:"\f2d1"}.fa-window-restore:before{content:"\f2d2"}.fa-times-rectangle:before,.fa-window-close:before{content:"\f2d3"}.fa-times-rectangle-o:before,.fa-window-close-o:before{content:"\f2d4"}.fa-bandcamp:before{content:"\f2d5"}.fa-grav:before{content:"\f2d6"}.fa-etsy:before{content:"\f2d7"}.fa-imdb:before{content:"\f2d8"}.fa-ravelry:before{content:"\f2d9"}.fa-eercast:before{content:"\f2da"}.fa-microchip:before{content:"\f2db"}.fa-snowflake-o:before{content:"\f2dc"}.fa-superpowers:before{content:"\f2dd"}.fa-wpexplorer:before{content:"\f2de"}.fa-meetup:before{content:"\f2e0"}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);border:0}.sr-only-focusable:active,.sr-only-focusable:focus{position:static;width:auto;height:auto;margin:0;overflow:visible;clip:auto} diff --git a/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/font-awesome/fonts/FontAwesome.otf b/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/font-awesome/fonts/FontAwesome.otf new file mode 100644 index 0000000..401ec0f Binary files /dev/null and b/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/font-awesome/fonts/FontAwesome.otf differ diff --git a/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/font-awesome/fonts/fontawesome-webfont.eot b/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/font-awesome/fonts/fontawesome-webfont.eot new file mode 100644 index 0000000..e9f60ca Binary files /dev/null and b/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/font-awesome/fonts/fontawesome-webfont.eot differ diff --git a/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/font-awesome/fonts/fontawesome-webfont.svg b/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/font-awesome/fonts/fontawesome-webfont.svg new file mode 100644 index 0000000..855c845 --- /dev/null +++ b/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/font-awesome/fonts/fontawesome-webfont.svg @@ -0,0 +1,2671 @@ + + + + +Created by FontForge 20120731 at Mon Oct 24 17:37:40 2016 + By ,,, +Copyright Dave Gandy 2016. All rights reserved. + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/font-awesome/fonts/fontawesome-webfont.ttf b/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/font-awesome/fonts/fontawesome-webfont.ttf new file mode 100644 index 0000000..35acda2 Binary files /dev/null and b/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/font-awesome/fonts/fontawesome-webfont.ttf differ diff --git a/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/font-awesome/fonts/fontawesome-webfont.woff b/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/font-awesome/fonts/fontawesome-webfont.woff new file mode 100644 index 0000000..400014a Binary files /dev/null and b/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/font-awesome/fonts/fontawesome-webfont.woff differ diff --git a/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/font-awesome/fonts/fontawesome-webfont.woff2 b/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/font-awesome/fonts/fontawesome-webfont.woff2 new file mode 100644 index 0000000..4d13fc6 Binary files /dev/null and b/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/font-awesome/fonts/fontawesome-webfont.woff2 differ diff --git a/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/index.html b/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/index.html index eb755da..22bb727 100755 --- a/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/index.html +++ b/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/index.html @@ -2,7 +2,11 @@ Выбор провайдера PAC + diff --git a/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/index.js b/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/index.js index 998f916..e6a8ec0 100755 --- a/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/index.js +++ b/extensions/chromium/runet-censorship-bypass/extension/pages/choose-pac-provider/index.js @@ -68,33 +68,43 @@ chrome.runtime.getBackgroundPage( (backgroundPage) => }; const checkChosenProvider = () => currentProviderRadio().checked = true; - const showError = (err) => { + const showErrors = (err, warns) => { - let clarification = err.clarification; - const ifNotCritical = clarification && clarification.ifNotCritical; - let message = err.message || ''; + warns = warns || []; + const warning = warns + .map( (w) => '✘ ' + (w.clarification && w.clarification.message || w.message || '') ) + .join('
'); - while( clarification ) { - message = (clarification && (clarification.message + ' ')) + message; - clarification = clarification.prev; + let message = ''; + if (err) { + let clarification = err.clarification; + message = err.message || ''; + + while( clarification ) { + message = (clarification && (clarification.message + ' ')) + message; + clarification = clarification.prev; + } } message = message.trim(); + if (warning) { + message += ' ' + warning; + } setStatusTo( ` - ${ifNotCritical ? 'Некритичная ошибка.' : 'Ошибка!'} + ${err ? '🔥 Ошибка!' : 'Некритичная ошибка.'}
${message} - - [Ещё подробнее] - ` + ${err ? '[Ещё подробнее]' : ''}` ); - getStatus().querySelector('.link-button').onclick = function() { + if (err) { + getStatus().querySelector('.link-button').onclick = function() { - errorHandlers.viewErrorVoid(err); - return false; + errorHandlers.viewErrorVoid(err); + return false; - }; + }; + } }; @@ -111,14 +121,13 @@ chrome.runtime.getBackgroundPage( (backgroundPage) => setStatusTo(beforeStatus); enableDisableInputs(); - operation((err) => { - if (err) { - showError(err); - if (err.clarification && err.clarification.ifNotCritical) { - onSuccess && onSuccess(); - } + operation((err, res, warns) => { + if (err || warns) { + showErrors(err, warns); } else { setStatusTo(afterStatus); + } + if (!err) { onSuccess && onSuccess(); } enableDisableInputs(); @@ -131,12 +140,20 @@ chrome.runtime.getBackgroundPage( (backgroundPage) => for( const providerKey of Object.keys(antiCensorRu.pacProviders).sort() ) { + const provider = antiCensorRu.getPacProvider(providerKey); const li = document.createElement('li'); + li.className = 'provider'; li.innerHTML = ` - + [обновить]`; + id="update-${providerKey}"> [обновить] +
+   +
${provider.desc}
+
${provider.desc}
+
+ ` li.querySelector('.link-button').onclick = () => { conduct(