Files
I2P_in_Private_Browsing_Mod…/background.js

499 lines
14 KiB
JavaScript
Raw Normal View History

2020-06-22 21:49:14 -04:00
var titlepref = chrome.i18n.getMessage('titlePreface');
var titleprefpriv = chrome.i18n.getMessage('titlePrefacePrivate');
var webpref = chrome.i18n.getMessage('webPreface');
var webprefpriv = chrome.i18n.getMessage('webPrefacePrivate');
var routerpref = chrome.i18n.getMessage('routerPreface');
var routerprefpriv = chrome.i18n.getMessage('routerPrefacePrivate');
var mailpref = chrome.i18n.getMessage('mailPreface');
var mailprefpriv = chrome.i18n.getMessage('mailPrefacePrivate');
var torrentpref = chrome.i18n.getMessage('torrentPreface');
var torrentprefpriv = chrome.i18n.getMessage('torrentPrefacePrivate');
var tunnelpref = chrome.i18n.getMessage('i2ptunnelPreface');
var tunnelprefpriv = chrome.i18n.getMessage('i2ptunnelPrefacePrivate');
var localpref = chrome.i18n.getMessage('localPreface');
var localprefpriv = chrome.i18n.getMessage('localPrefacePrivate');
var extensionpref = chrome.i18n.getMessage('extensionPreface');
var muwirepref = chrome.i18n.getMessage('muwirePreface');
2019-11-24 17:14:43 -05:00
function onContextsGot(contexts) {
2019-10-06 15:18:10 -04:00
var ids = [];
for (let context of contexts) {
2020-01-14 14:49:48 -05:00
console.log(`Name : ${context.name}`);
2019-10-06 15:18:10 -04:00
ids.push(context.name);
}
2020-06-22 21:49:14 -04:00
console.log('Checking new contexts');
if (ids.indexOf(titlepref) == -1) {
2019-12-24 16:51:38 -05:00
browser.contextualIdentities
.create({
name: titlepref,
2020-06-22 21:49:14 -04:00
color: 'orange',
icon: 'fingerprint'
2019-12-24 16:51:38 -05:00
})
.then(onCreated, onNotCreated);
2019-10-06 15:18:10 -04:00
}
if (ids.indexOf(webpref) == -1) {
2019-12-24 16:51:38 -05:00
browser.contextualIdentities
.create({
name: webpref,
2020-06-22 21:49:14 -04:00
color: 'red',
icon: 'circle'
2019-12-24 16:51:38 -05:00
})
.then(onCreated, onNotCreated);
}
if (ids.indexOf(routerpref) == -1) {
2019-12-24 16:51:38 -05:00
browser.contextualIdentities
.create({
name: routerpref,
2020-06-22 21:49:14 -04:00
color: 'blue',
icon: 'briefcase'
2019-12-24 16:51:38 -05:00
})
.then(onCreated, onNotCreated);
2019-10-06 22:11:23 -04:00
}
if (ids.indexOf(tunnelpref) == -1) {
2019-12-24 16:51:38 -05:00
browser.contextualIdentities
.create({
name: tunnelpref,
2020-06-22 21:49:14 -04:00
color: 'green',
icon: 'tree'
2019-12-24 16:51:38 -05:00
})
.then(onCreated, onNotCreated);
2019-11-11 16:34:41 -05:00
}
if (ids.indexOf(mailpref) == -1) {
2019-12-24 16:51:38 -05:00
browser.contextualIdentities
.create({
name: mailpref,
2020-06-22 21:49:14 -04:00
color: 'yellow',
icon: 'briefcase'
2019-12-24 16:51:38 -05:00
})
.then(onCreated, onNotCreated);
2019-11-11 16:34:41 -05:00
}
if (ids.indexOf(torrentpref) == -1) {
2019-12-24 16:51:38 -05:00
browser.contextualIdentities
.create({
name: torrentpref,
2020-06-22 21:49:14 -04:00
color: 'purple',
icon: 'chill'
2019-12-24 16:51:38 -05:00
})
.then(onCreated, onNotCreated);
2019-11-11 16:34:41 -05:00
}
if (ids.indexOf(localpref) == -1) {
browser.contextualIdentities
.create({
name: localpref,
2020-06-22 21:49:14 -04:00
color: 'red',
icon: 'fence'
})
.then(onCreated, onNotCreated);
}
if (ids.indexOf(localpref) == -1) {
browser.contextualIdentities
.create({
name: muwirepref,
2020-06-22 21:49:14 -04:00
color: 'turquoise',
icon: 'gift'
})
.then(onCreated, onNotCreated);
}
}
function onContextsError() {
2020-06-22 21:49:14 -04:00
console.log('Error finding contextual identities, is the API enabled?');
}
2019-10-28 01:11:16 -04:00
function onCreated(context) {
2020-06-22 21:49:14 -04:00
console.log(' ID:', context.cookieStoreId, 'created.');
2019-10-28 01:11:16 -04:00
}
function onNotCreated(context) {
2020-06-22 21:49:14 -04:00
console.log('ID:', context.cookieStoreId, 'not created.');
}
browser.contextualIdentities.query({}).then(onContextsGot, onContextsError);
2019-06-17 19:17:11 -04:00
2019-11-24 04:13:12 -05:00
var gettingInfo = browser.runtime.getPlatformInfo();
gettingInfo.then(got => {
2020-06-22 21:49:14 -04:00
if (got.os != 'android') {
2019-11-24 04:13:12 -05:00
browser.windows.onCreated.addListener(themeWindow);
browser.windows.onFocusChanged.addListener(themeWindow);
browser.windows.onRemoved.addListener(themeWindow);
browser.tabs.onUpdated.addListener(themeWindowByTab);
browser.tabs.onActivated.addListener(themeWindowByTab);
}
});
2019-02-05 10:53:26 -05:00
2019-10-28 01:11:16 -04:00
function themeWindowByTab(tabId) {
function tabWindow(tab) {
var gettingPlatformInfo = browser.runtime.getPlatformInfo();
gettingPlatformInfo.then(got => {
2020-06-22 21:49:14 -04:00
if (got.os == 'android') {
let getwindow = browser.tabs.get(tab.tabId);
2019-11-24 04:13:12 -05:00
getwindow.then(themeWindow);
} else {
let getwindow = browser.windows.get(tab.windowId);
2019-11-24 04:13:12 -05:00
getwindow.then(themeWindow);
}
});
2019-10-28 01:11:16 -04:00
}
2020-06-22 21:49:14 -04:00
if (typeof tabId === 'number') {
let tab = browser.tabs.get(tabId);
2019-10-28 01:11:16 -04:00
tab.then(tabWindow);
} else {
tabWindow(tabId);
}
2019-10-07 22:51:53 -04:00
}
function isEmpty(obj) {
if (obj === undefined || obj === null) {
return true;
}
for (var key in obj) {
if (obj.hasOwnProperty(key)) {
return false;
}
}
return true;
}
2019-02-05 10:53:26 -05:00
function themeWindow(window) {
2019-10-06 15:18:10 -04:00
// Check if the window is in private browsing
function onThemeError() {
2020-09-22 00:59:38 -04:00
console.log('theme color set error');
}
2019-10-06 15:18:10 -04:00
function logTabs(tabInfo) {
2019-11-24 17:14:43 -05:00
function onContextGotTheme(context) {
if (context.name == titlepref) {
2020-06-22 21:49:14 -04:00
console.log('Active in I2P window');
2019-10-06 15:18:10 -04:00
if (window.incognito) {
2019-11-24 04:13:12 -05:00
browser.theme.update(window.id, {
2019-10-06 15:18:10 -04:00
colors: {
frame: '#363A68',
toolbar: '#363A68'
2019-10-06 15:18:10 -04:00
}
});
} else {
2019-11-24 04:13:12 -05:00
browser.theme.update(window.id, {
2019-10-06 15:18:10 -04:00
colors: {
frame: '#363A68',
toolbar: '#363A68'
}
2019-10-06 15:18:10 -04:00
});
2019-07-10 02:29:38 -04:00
}
2020-02-26 13:03:09 -05:00
browser.pageAction.setPopup({
tabId: tabInfo[0].id,
2020-06-22 21:49:14 -04:00
popup: 'security.html'
2020-02-26 13:03:09 -05:00
});
2020-02-26 13:00:51 -05:00
//console.log("(background) tabinfo", tabInfo[0].id)
2020-02-26 13:03:09 -05:00
browser.pageAction.show(tabInfo[0].id);
} else if (context.name == routerpref) {
2020-06-22 21:49:14 -04:00
console.log('Active in Router Console window');
2019-10-08 19:10:13 -04:00
if (window.incognito) {
2019-11-24 04:13:12 -05:00
browser.theme.update(window.id, {
2019-10-08 19:10:13 -04:00
colors: {
frame: '#4456B7',
toolbar: '#4456B7'
2019-10-08 19:10:13 -04:00
}
});
} else {
2019-11-24 04:13:12 -05:00
browser.theme.update(window.id, {
2019-10-08 19:10:13 -04:00
colors: {
frame: '#4456B7',
toolbar: '#4456B7'
2019-10-08 19:10:13 -04:00
}
});
}
} else if (context.name == tunnelpref) {
2020-06-22 21:49:14 -04:00
console.log('Active in Hidden Services Manager window');
2019-11-11 16:34:41 -05:00
if (window.incognito) {
2019-11-24 04:13:12 -05:00
browser.theme.update(window.id, {
2019-11-11 16:34:41 -05:00
colors: {
frame: '#4456B7',
toolbar: '#4456B7'
2019-11-11 16:34:41 -05:00
}
});
} else {
2019-11-24 04:13:12 -05:00
browser.theme.update(window.id, {
2019-11-11 16:34:41 -05:00
colors: {
frame: '#4456B7',
toolbar: '#4456B7'
2019-11-11 16:34:41 -05:00
}
});
}
} else if (context.name == mailpref) {
2020-06-22 21:49:14 -04:00
console.log('Active in Web Mail window');
2019-11-11 16:34:41 -05:00
if (window.incognito) {
2019-11-24 04:13:12 -05:00
browser.theme.update(window.id, {
2019-11-11 16:34:41 -05:00
colors: {
frame: '#4456B7',
toolbar: '#4456B7'
2019-11-11 16:34:41 -05:00
}
});
} else {
2019-11-24 04:13:12 -05:00
browser.theme.update(window.id, {
2019-11-11 16:34:41 -05:00
colors: {
frame: '#4456B7',
toolbar: '#4456B7'
2019-11-11 16:34:41 -05:00
}
});
}
} else if (context.name == torrentpref) {
2020-06-22 21:49:14 -04:00
console.log('Active in Bittorrent window');
2019-11-11 16:34:41 -05:00
if (window.incognito) {
2019-11-24 04:13:12 -05:00
browser.theme.update(window.id, {
2019-11-11 16:34:41 -05:00
colors: {
frame: '#4456B7',
toolbar: '#4456B7'
2019-11-11 16:34:41 -05:00
}
});
} else {
2019-11-24 04:13:12 -05:00
browser.theme.update(window.id, {
2019-11-11 16:34:41 -05:00
colors: {
frame: '#4456B7',
toolbar: '#4456B7'
2019-11-11 16:34:41 -05:00
}
});
}
2019-10-06 15:18:10 -04:00
}
2019-07-10 02:29:38 -04:00
}
if (
2020-06-22 21:49:14 -04:00
tabInfo[0].cookieStoreId != 'firefox-default' &&
tabInfo[0].cookieStoreId != 'firefox-private'
) {
2019-12-24 16:51:38 -05:00
browser.contextualIdentities
.get(tabInfo[0].cookieStoreId)
.then(onContextGotTheme, onThemeError);
2020-09-22 00:59:38 -04:00
}else {
console.log('Not active in I2P window');
function unSetTheme(them) {
console.log('unsetting theme', them);
if (Object.keys(them).length > 0) {
browser.theme.update(window.id, them.originalTheme);
}else {
2020-09-22 01:42:02 -04:00
browser.theme.update(window.id, {
colors: {
frame: null,
toolbar: null
}
});
2020-09-22 00:59:38 -04:00
}
}
browser.storage.local.get('originalTheme').then(unSetTheme, onError);
2019-10-07 22:51:53 -04:00
}
2019-10-06 15:18:10 -04:00
}
var querying = browser.tabs.query({
currentWindow: true,
active: true
});
querying.then(logTabs, onThemeError);
2019-02-05 10:53:26 -05:00
}
2019-02-07 20:14:57 -05:00
function setTitle(window) {
// Check if the window is in private browsing
function onContextError() {
2020-06-22 21:49:14 -04:00
console.log('Context Error');
}
2019-10-06 15:18:10 -04:00
function logTabs(tabInfo) {
2019-11-24 17:14:43 -05:00
function onContextGotTitle(context) {
if (context.name == titlepref) {
2020-06-22 21:49:14 -04:00
console.log('Active in I2P window');
2019-11-11 16:34:41 -05:00
if (window.incognito) {
2019-11-24 04:13:12 -05:00
browser.windows.update(window.id, {
2020-06-22 21:49:14 -04:00
titlePreface: titleprefpriv + ': '
2019-11-11 16:34:41 -05:00
});
} else {
2019-11-24 04:13:12 -05:00
browser.windows.update(window.id, {
2020-06-22 21:49:14 -04:00
titlePreface: titlepref + ': '
2019-11-11 16:34:41 -05:00
});
}
} else if (context.name == webpref) {
2020-06-22 21:49:14 -04:00
console.log('Active in Web window');
2019-11-11 16:34:41 -05:00
if (window.incognito) {
2019-11-24 04:13:12 -05:00
browser.windows.update(window.id, {
2020-06-22 21:49:14 -04:00
titlePreface: webprefpriv + ' - '
2019-11-11 16:34:41 -05:00
});
} else {
2019-11-24 04:13:12 -05:00
browser.windows.update(window.id, {
2020-06-22 21:49:14 -04:00
titlePreface: webpref + ' - '
2019-11-11 16:34:41 -05:00
});
}
} else if (context.name == routerpref) {
2020-06-22 21:49:14 -04:00
console.log('Active in Router Console window');
2019-11-11 16:34:41 -05:00
if (window.incognito) {
2019-11-24 04:13:12 -05:00
browser.windows.update(window.id, {
2020-06-22 21:49:14 -04:00
titlePreface: titleprefpriv + ' - ' + routerprefpriv + ': '
2019-11-11 16:34:41 -05:00
});
} else {
2019-11-24 04:13:12 -05:00
browser.windows.update(window.id, {
2020-06-22 21:49:14 -04:00
titlePreface: titlepref + ' - ' + routerpref + ': '
2019-11-11 16:34:41 -05:00
});
}
} else if (context.name == tunnelpref) {
2020-06-22 21:49:14 -04:00
console.log('Active in Hidden Services Manager window');
2019-11-11 16:34:41 -05:00
if (window.incognito) {
2019-11-24 04:13:12 -05:00
browser.windows.update(window.id, {
2020-06-22 21:49:14 -04:00
titlePreface: titleprefpriv + ' - ' + tunnelprefpriv + ': '
2019-11-11 16:34:41 -05:00
});
} else {
2019-11-24 04:13:12 -05:00
browser.windows.update(window.id, {
2020-06-22 21:49:14 -04:00
titlePreface: titlepref + ' - ' + tunnelpref + ': '
2019-11-11 16:34:41 -05:00
});
}
} else if (context.name == mailpref) {
2020-06-22 21:49:14 -04:00
console.log('Active in I2P Web Mail window');
2019-11-11 16:34:41 -05:00
if (window.incognito) {
2019-11-24 04:13:12 -05:00
browser.windows.update(window.id, {
2020-06-22 21:49:14 -04:00
titlePreface: titleprefpriv + ' - ' + mailprefpriv + ': '
2019-11-11 16:34:41 -05:00
});
} else {
2019-11-24 04:13:12 -05:00
browser.windows.update(window.id, {
2020-06-22 21:49:14 -04:00
titlePreface: titlepref + ' - ' + mailpref + ': '
2019-11-11 16:34:41 -05:00
});
}
} else if (context.name == torrentpref) {
2020-06-22 21:49:14 -04:00
console.log('Active in I2P Torrent window');
2019-10-06 15:18:10 -04:00
if (window.incognito) {
2019-11-24 04:13:12 -05:00
browser.windows.update(window.id, {
2020-06-22 21:49:14 -04:00
titlePreface: titleprefpriv + ' - ' + torrentprefpriv + ': '
2019-10-06 15:18:10 -04:00
});
} else {
2019-11-24 04:13:12 -05:00
browser.windows.update(window.id, {
2020-06-22 21:49:14 -04:00
titlePreface: titlepref + ' - ' + torrentpref + ': '
2019-10-06 15:18:10 -04:00
});
}
} else if (context.name == localpref) {
2020-06-22 21:49:14 -04:00
console.log('Active in Localhost window');
if (window.incognito) {
browser.windows.update(window.id, {
2020-06-22 21:49:14 -04:00
titlePreface: localprefpriv + ' - ' + localprefpriv + ': '
});
} else {
browser.windows.update(window.id, {
2020-06-22 21:49:14 -04:00
titlePreface: localpref + ' - ' + localpref + ': '
});
}
2019-10-06 15:18:10 -04:00
}
2019-07-10 02:29:38 -04:00
}
if (
2020-06-22 21:49:14 -04:00
tabInfo[0].cookieStoreId != 'firefox-default' &&
tabInfo[0].cookieStoreId != 'firefox-private'
) {
2019-12-24 16:51:38 -05:00
browser.contextualIdentities
.get(tabInfo[0].cookieStoreId)
.then(onContextGotTitle, onContextError);
2019-12-24 11:21:07 -05:00
} else if (window.incognito) {
2019-12-24 16:51:38 -05:00
browser.windows.update(window.id, {
2020-06-22 21:49:14 -04:00
titlePreface: ''
2019-12-24 16:51:38 -05:00
});
} else {
browser.windows.update(window.id, {
2020-06-22 21:49:14 -04:00
titlePreface: ''
2019-12-24 16:51:38 -05:00
});
}
2019-10-06 15:18:10 -04:00
}
var querying = browser.tabs.query({
currentWindow: true,
active: true
});
querying.then(logTabs, onContextError);
}
2019-02-07 20:14:57 -05:00
var gettingListenerInfo = browser.runtime.getPlatformInfo();
gettingListenerInfo.then(got => {
function onPlatformError() {
2020-06-22 21:49:14 -04:00
console.log('Error finding platform info');
}
2020-06-22 21:49:14 -04:00
if (got.os != 'android') {
browser.tabs.onCreated.addListener(() => {
var getting = browser.windows.getCurrent({
populate: true
});
getting.then(setTitle, onPlatformError);
});
browser.tabs.onActivated.addListener(() => {
var getting = browser.windows.getCurrent({
populate: true
});
getting.then(setTitle, onPlatformError);
});
2019-11-24 04:32:35 -05:00
}
2019-02-07 20:14:57 -05:00
});
2020-01-13 15:22:02 -05:00
function handleUpdated(updateInfo) {
2020-09-22 00:59:38 -04:00
function maybeSet(them){
console.log("original theme found:", them, Object.keys(them).length)
if ((Object.keys(them).length == 0) || them.originalTheme.colors == null && them.originalTheme.images == null && them.originalTheme.properties == null) {
if (updateInfo.theme.colors.frame != '#4456B7' && updateInfo.theme.colors.frame != '#363A68') {
function onSet(){
console.log("stored theme:", updateInfo.theme)
}
if (updateInfo.theme.colors != null || updateInfo.theme.images != null || updateInfo.theme.properties != null ) {
console.log("storing theme:", updateInfo.theme)
browser.storage.local.set({"originalTheme": updateInfo.theme}).then(onSet, onError)
}
}
}else{
console.log("keeping stored theme:", them)
}
}
2020-09-22 00:59:38 -04:00
browser.storage.local.get("originalTheme").then(maybeSet, onError);
}
browser.theme.onUpdated.addListener(handleUpdated);
2020-02-26 13:00:51 -05:00
function handleClick() {
console.log("Opening page action");
browser.pageAction.openPopup();
}
browser.pageAction.onClicked.addListener(handleClick);
2020-03-05 23:25:08 -05:00
async function certCheck(details) {
if (details.url.startsWith("https")) {
console.log("(cert) https site", details.url);
} else {
return;
}
if (!details.url.includes(".i2p")) {
return;
}
var tabs = await browser.tabs.query({ active: true });
if (tabs == null) {
return;
}
console.log("(cert) checking cert", tabs);
for (tab in tabs) {
if (details.url == tabs[tab].url) {
console.log("(cert) right tab", tabs[tab].id);
try {
let securityInfo = await browser.webRequest.getSecurityInfo(
details.requestId,
{ certificateChain: true }
);
console.log("(cert) state is complete", securityInfo);
console.log("(cert) certificates", securityInfo.certificates);
} catch (error) {
console.error(error);
}
}
}
}
// Listen for onHeaderReceived for the target page.
// Set "blocking" and "responseHeaders".
browser.webRequest.onHeadersReceived.addListener(
certCheck,
{ urls: ["<all_urls>"] },
["blocking", "responseHeaders"]
);