mirror of
https://github.com/anticensority/runet-censorship-bypass.git
synced 2024-11-24 02:13:43 +03:00
Better error and promise rejections handling
This commit is contained in:
parent
3b891f82b4
commit
05c6deadf8
|
@ -81,7 +81,7 @@ window.antiCensorRu = {
|
||||||
return chrome.storage.local.clear(
|
return chrome.storage.local.clear(
|
||||||
() => chrome.storage.local.set(
|
() => chrome.storage.local.set(
|
||||||
onlySettable,
|
onlySettable,
|
||||||
() => cb && cb(chrome.runtime.lastError, onlySettable)
|
chromified(cb, onlySettable)
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -90,15 +90,18 @@ window.antiCensorRu = {
|
||||||
pullFromStorage(cb) {
|
pullFromStorage(cb) {
|
||||||
|
|
||||||
chrome.storage.local.get(null, (storage) => {
|
chrome.storage.local.get(null, (storage) => {
|
||||||
|
|
||||||
|
const err = checkChromeError();
|
||||||
|
if (!err) {
|
||||||
console.log('Pulled from storage:', storage);
|
console.log('Pulled from storage:', storage);
|
||||||
for(const key of Object.keys(storage)) {
|
for(const key of Object.keys(storage)) {
|
||||||
this[key] = storage[key];
|
this[key] = storage[key];
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
console.log('Synced with storage, any callback?', !!cb);
|
console.log('Synced with storage, any callback?', !!cb);
|
||||||
if (cb) {
|
return cb && cb(err, storage);
|
||||||
cb(chrome.runtime.lastError, storage);
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -109,39 +112,51 @@ window.antiCensorRu = {
|
||||||
return cb({clarification:{message:'Сперва выберите PAC-провайдера.'}});
|
return cb({clarification:{message:'Сперва выберите PAC-провайдера.'}});
|
||||||
}
|
}
|
||||||
|
|
||||||
var pacSetPromise = new Promise(
|
const pacSetPromise = new Promise(
|
||||||
(resolve, reject) => setPacScriptFromProvider(
|
(resolve, reject) => setPacScriptFromProvider(
|
||||||
this.pacProvider,
|
this.pacProvider,
|
||||||
(err, res) => {
|
(err, res) => {
|
||||||
|
|
||||||
if (err) {
|
if (!err) {
|
||||||
return reject(err);
|
|
||||||
}
|
|
||||||
|
|
||||||
this.lastPacUpdateStamp = Date.now();
|
this.lastPacUpdateStamp = Date.now();
|
||||||
this.ifFirstInstall = false;
|
this.ifFirstInstall = false;
|
||||||
this.setAlarms();
|
this.setAlarms();
|
||||||
|
}
|
||||||
|
|
||||||
|
return resolve([err, res]);
|
||||||
|
|
||||||
return resolve(res);
|
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
return updatePacProxyIps(
|
const ipsPromise = new Promise(
|
||||||
|
(resolve, reject) => updatePacProxyIps(
|
||||||
this.pacProvider,
|
this.pacProvider,
|
||||||
(ipsError) => {
|
(ipsError) => {
|
||||||
|
|
||||||
if (ipsError && ipsError.clarification) {
|
if (ipsError && ipsError.clarification) {
|
||||||
ipsError.clarification.ifNotCritical = true;
|
ipsError.clarification.ifNotCritical = true;
|
||||||
}
|
}
|
||||||
pacSetPromise.then(
|
return resolve([ipsError]);
|
||||||
(res) => this.pushToStorage(
|
|
||||||
(pushError) => pushError ? cb(pushError) : cb(ipsError, res)
|
}
|
||||||
),
|
|
||||||
cb
|
|
||||||
)
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
Promise.all([pacSetPromise, ipsPromise]).then(
|
||||||
|
([[pacErr, pacRes], [ipsErr]]) => {
|
||||||
|
|
||||||
|
if (pacErr && ipsErr) {
|
||||||
|
return cb(pacErr, pacRes);
|
||||||
|
}
|
||||||
|
return cb(pacErr || ipsErr);
|
||||||
|
this.pushToStorage(
|
||||||
|
(pushErr) => cb(pacErr || ipsErr || pushErr, pacRes)
|
||||||
|
);
|
||||||
|
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_pacUpdatePeriodInMinutes: 4*60,
|
_pacUpdatePeriodInMinutes: 4*60,
|
||||||
|
@ -168,6 +183,7 @@ window.antiCensorRu = {
|
||||||
|
|
||||||
installPac(key, cb) {
|
installPac(key, cb) {
|
||||||
|
|
||||||
|
console.log('Installing PAC');
|
||||||
if(typeof(key) === 'function') {
|
if(typeof(key) === 'function') {
|
||||||
cb = key;
|
cb = key;
|
||||||
key = undefined;
|
key = undefined;
|
||||||
|
@ -178,6 +194,7 @@ window.antiCensorRu = {
|
||||||
}
|
}
|
||||||
|
|
||||||
return this.syncWithPacProvider(cb);
|
return this.syncWithPacProvider(cb);
|
||||||
|
|
||||||
},
|
},
|
||||||
|
|
||||||
clearPac(cb) {
|
clearPac(cb) {
|
||||||
|
@ -188,8 +205,13 @@ window.antiCensorRu = {
|
||||||
{},
|
{},
|
||||||
() => {
|
() => {
|
||||||
|
|
||||||
|
const err = checkChromeError();
|
||||||
|
if (err) {
|
||||||
|
return cb(err);
|
||||||
|
}
|
||||||
this.currentPacProviderKey = undefined;
|
this.currentPacProviderKey = undefined;
|
||||||
return this.pushToStorage(cb);
|
return this.pushToStorage(cb);
|
||||||
|
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
@ -274,27 +296,59 @@ chrome.storage.local.get(null, (oldStorage) => {
|
||||||
**/
|
**/
|
||||||
});
|
});
|
||||||
|
|
||||||
function asyncLogGroup() {
|
function asyncLogGroup(...args) {
|
||||||
|
|
||||||
const args = [].slice.apply(arguments);
|
|
||||||
const cb = args.pop() || (() => {});
|
const cb = args.pop() || (() => {});
|
||||||
console.group.apply(console, args);
|
console.group.apply(console, args);
|
||||||
return function() {
|
return function(...cbArgs) {
|
||||||
|
|
||||||
console.groupEnd();
|
console.groupEnd();
|
||||||
console.log('Group finished.');
|
console.log('Group finished.');
|
||||||
return cb.apply(this, arguments);
|
return cb.apply(this, cbArgs);
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
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;
|
||||||
|
if (err) {
|
||||||
|
const args = ['API returned error:', err];
|
||||||
|
if (betterStack) {
|
||||||
|
args.push('\n' + betterStack);
|
||||||
|
}
|
||||||
|
console.warn.apply(console, args);
|
||||||
|
}
|
||||||
|
return err;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function chromified(cb, ...replaceArgs) {
|
||||||
|
|
||||||
|
const stack = (new Error()).stack;
|
||||||
|
// Take error first callback and covert it to chrome api callback.
|
||||||
|
return function(...args) {
|
||||||
|
|
||||||
|
if (replaceArgs.length) {
|
||||||
|
args = replaceArgs;
|
||||||
|
}
|
||||||
|
const err = checkChromeError(stack);
|
||||||
|
return cb && cb.call(this, err, ...args);
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
function httpGet(url, cb) {
|
function httpGet(url, cb) {
|
||||||
|
|
||||||
const start = Date.now();
|
const start = Date.now();
|
||||||
return fetch(url).then(
|
return fetch(url).then(
|
||||||
(res) => {
|
(res) => {
|
||||||
|
|
||||||
const textCb = (err) => cb && res.text().then( text => cb(err, text), cb );
|
const textCb =
|
||||||
|
(err) => cb && res.text()
|
||||||
|
.then( (text) => cb(err, text), cb );
|
||||||
const status = res.status;
|
const status = res.status;
|
||||||
if ( !( status >= 200 && status < 300 || status === 304 ) ) {
|
if ( !( status >= 200 && status < 300 || status === 304 ) ) {
|
||||||
res.clarification = {message: 'Получен ответ с неудачным HTTP-кодом ' + status + '.'};
|
res.clarification = {message: 'Получен ответ с неудачным HTTP-кодом ' + status + '.'};
|
||||||
|
@ -302,11 +356,13 @@ function httpGet(url, cb) {
|
||||||
}
|
}
|
||||||
console.log('GETed with success:', url, Date.now() - start);
|
console.log('GETed with success:', url, Date.now() - start);
|
||||||
return textCb();
|
return textCb();
|
||||||
|
|
||||||
},
|
},
|
||||||
(err) => {
|
(err) => {
|
||||||
|
|
||||||
err.clarification = {message: 'Что-то не так с сетью, проверьте соединение.'};
|
err.clarification = {message: 'Что-то не так с сетью, проверьте соединение.'};
|
||||||
return cb && cb(err);
|
return cb && cb(err);
|
||||||
|
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -457,9 +513,6 @@ function setPacScriptFromProvider(provider, cb) {
|
||||||
return cb(err);
|
return cb(err);
|
||||||
}
|
}
|
||||||
|
|
||||||
console.log('Clearing chrome proxy settings...');
|
|
||||||
return chrome.proxy.settings.clear({}, () => {
|
|
||||||
|
|
||||||
const config = {
|
const config = {
|
||||||
mode: 'pac_script',
|
mode: 'pac_script',
|
||||||
pacScript: {
|
pacScript: {
|
||||||
|
@ -468,8 +521,22 @@ function setPacScriptFromProvider(provider, cb) {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
console.log('Setting chrome proxy settings...');
|
console.log('Setting chrome proxy settings...');
|
||||||
chrome.proxy.settings.set( {value: config}, cb );
|
chrome.proxy.settings.set( {value: config}, chromified(cb) );
|
||||||
});
|
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
window.addEventListener('error', (err) => {
|
||||||
|
|
||||||
|
console.error('Global error');
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
window.addEventListener('unhandledrejection', (event) => {
|
||||||
|
|
||||||
|
console.warn('Unhandled rejection. Throwing error.');
|
||||||
|
event.preventDefault();
|
||||||
|
throw event.reason;
|
||||||
|
|
||||||
|
});
|
||||||
|
|
|
@ -96,7 +96,12 @@ chrome.runtime.getBackgroundPage( backgroundPage => {
|
||||||
enableDisableInputs();
|
enableDisableInputs();
|
||||||
setStatusTo('Установка...');
|
setStatusTo('Установка...');
|
||||||
antiCensorRu.installPac(pacKey, (err) => {
|
antiCensorRu.installPac(pacKey, (err) => {
|
||||||
if (err) {
|
|
||||||
|
backgroundPage.console.log('Popup callback...');
|
||||||
|
if (!err) {
|
||||||
|
setStatusTo('PAC-скрипт установлен.');
|
||||||
|
}
|
||||||
|
else {
|
||||||
var ifNotCritical = err.clarification && err.clarification.ifNotCritical;
|
var ifNotCritical = err.clarification && err.clarification.ifNotCritical;
|
||||||
|
|
||||||
var message = '';
|
var message = '';
|
||||||
|
@ -127,8 +132,7 @@ chrome.runtime.getBackgroundPage( backgroundPage => {
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
};
|
};
|
||||||
} else
|
}
|
||||||
setStatusTo('PAC-скрипт установлен.');
|
|
||||||
enableDisableInputs();
|
enableDisableInputs();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user