Disable the webext if the bridge is unreachable

This commit is contained in:
Arlo Breault 2019-09-25 22:23:14 -04:00
parent 19bc6d8858
commit 685c3bd262
2 changed files with 29 additions and 8 deletions

View file

@ -31,6 +31,20 @@ class WebExtUI extends UI {
this.setEnabled(false); this.setEnabled(false);
return; return;
} }
(new Promise((resolve, reject) => {
const ws = WS.makeWebsocket(config.relayAddr);
ws.onopen = () => {
resolve();
ws.close();
};
ws.onerror = () => {
this.missingFeature = 'popupBridgeUnreachable';
this.setEnabled(false);
reject('Could not connect to bridge.');
ws.close();
};
}))
.then(() => {
chrome.storage.local.get("snowflake-enabled", (result) => { chrome.storage.local.get("snowflake-enabled", (result) => {
let enabled = this.enabled; let enabled = this.enabled;
if (result['snowflake-enabled'] !== void 0) { if (result['snowflake-enabled'] !== void 0) {
@ -40,6 +54,10 @@ class WebExtUI extends UI {
} }
this.setEnabled(enabled); this.setEnabled(enabled);
}); });
})
.catch((e) => {
log(e);
});
} }
postActive() { postActive() {

View file

@ -23,6 +23,9 @@
"popupWebRTCOff": { "popupWebRTCOff": {
"message": "WebRTC feature is not detected." "message": "WebRTC feature is not detected."
}, },
"popupBridgeUnreachable": {
"message": "Could not connect to the bridge."
},
"popupDescOn": { "popupDescOn": {
"message": "Number of users your Snowflake has helped circumvent censorship in the last 24 hours: $1" "message": "Number of users your Snowflake has helped circumvent censorship in the last 24 hours: $1"
}, },