2023-03-02 15:42:38 -06:00
|
|
|
// Modules to control application life and create native browser window
|
2024-11-25 14:26:46 -06:00
|
|
|
const {app, BrowserWindow, session, ipcMain} = require('electron')
|
2023-03-02 15:42:38 -06:00
|
|
|
const path = require('path')
|
2023-03-03 08:30:52 -06:00
|
|
|
const fetch = require("cross-fetch")
|
2023-03-09 04:04:28 -06:00
|
|
|
const { ElectronChromeExtensions } = require('electron-chrome-extensions')
|
2024-11-21 14:08:59 -06:00
|
|
|
const { ElectronBlocker } = require('@ghostery/adblocker-electron');
|
2024-08-13 15:36:09 -05:00
|
|
|
const http = require('http');
|
2024-11-21 14:57:11 -06:00
|
|
|
const fs = require('fs');
|
2024-08-13 15:36:09 -05:00
|
|
|
const { createProxy } = require('proxy');
|
2024-11-21 14:57:11 -06:00
|
|
|
const buildChromeContextMenu = require('electron-chrome-context-menu').default
|
|
|
|
var extensions
|
2024-11-25 14:07:39 -06:00
|
|
|
var mic
|
|
|
|
var cam
|
2024-11-21 14:57:11 -06:00
|
|
|
app.on('web-contents-created', (event, webContents) => {
|
|
|
|
webContents.on('context-menu', (e, params) => {
|
|
|
|
const menu = buildChromeContextMenu({
|
|
|
|
params,
|
|
|
|
webContents,
|
|
|
|
openLink: (url, disposition) => {
|
|
|
|
webContents.loadURL(url)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
menu.popup()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2023-03-02 18:20:58 -06:00
|
|
|
|
2023-03-09 05:25:24 -06:00
|
|
|
ipcMain.on('windowmaker', (event, arg) => {
|
|
|
|
createWindow();
|
|
|
|
})
|
|
|
|
|
2024-08-13 17:33:06 -05:00
|
|
|
const proxy = createProxy(http.createServer());
|
|
|
|
proxy.listen(3129)
|
2024-11-21 13:55:06 -06:00
|
|
|
//Function to enable AD Blocking...
|
2024-08-12 15:16:12 -05:00
|
|
|
let blocker = undefined
|
|
|
|
async function enableGoodies(s) {
|
|
|
|
blocker = await ElectronBlocker.fromLists(fetch, [
|
2024-11-25 14:02:23 -06:00
|
|
|
"https://github.com/uBlockOrigin/uAssets/raw/refs/heads/master/filters/ubol-filters.txt",
|
2024-08-12 15:16:12 -05:00
|
|
|
'https://easylist.to/easylist/easylist.txt',
|
|
|
|
'https://secure.fanboy.co.nz/fanboy-annoyance.txt',
|
|
|
|
'https://easylist.to/easylist/easyprivacy.txt',
|
|
|
|
'https://easylist-downloads.adblockplus.org/antiadblockfilters.txt',
|
|
|
|
'https://raw.githubusercontent.com/hoshsadiq/adblock-nocoin-list/master/nocoin.txt',
|
2024-11-25 14:02:23 -06:00
|
|
|
'https://cdn.jsdelivr.net/gh/hagezi/dns-blocklists@latest/adblock/pro.plus.txt',
|
|
|
|
"https://github.com/yokoffing/filterlists/raw/refs/heads/main/youtube_clear_view.txt",
|
|
|
|
"https://pgl.yoyo.org/as/serverlist.php?showintro=0;hostformat=adblock",
|
|
|
|
"https://github.com/uBlockOrigin/uAssets/raw/refs/heads/master/filters/unbreak.txt",
|
|
|
|
"https://github.com/uBlockOrigin/uAssets/raw/refs/heads/master/filters/quick-fixes.txt",
|
|
|
|
"https://github.com/uBlockOrigin/uAssets/raw/refs/heads/master/filters/privacy.txt",
|
|
|
|
"https://github.com/uBlockOrigin/uAssets/raw/refs/heads/master/filters/badware.txt",
|
|
|
|
"https://github.com/uBlockOrigin/uAssets/raw/refs/heads/master/filters/filters.txt"
|
2024-08-12 15:16:12 -05:00
|
|
|
])
|
|
|
|
blocker.enableBlockingInSession(s);
|
|
|
|
}
|
2023-03-02 15:42:38 -06:00
|
|
|
|
2024-08-14 10:03:19 -05:00
|
|
|
// 0.0.0.0 day fix
|
|
|
|
const locals = [
|
2024-08-14 10:34:58 -05:00
|
|
|
'0.0.0.0', '127.0.0.1', '192.168', '.local', '.example', '.staging', 'fe80::', '::1'
|
2024-08-14 10:03:19 -05:00
|
|
|
];
|
|
|
|
|
|
|
|
// Function to check if a URL is restricted
|
|
|
|
function isLocal(url) {
|
|
|
|
return locals.some(local => url.includes(local));
|
|
|
|
}
|
|
|
|
|
2024-08-12 15:16:12 -05:00
|
|
|
function createWindow () {
|
2024-11-21 15:04:35 -06:00
|
|
|
try {
|
|
|
|
extensions = new ElectronChromeExtensions()
|
|
|
|
} catch {
|
|
|
|
console.log("Creating a new window in the same extension session...")
|
|
|
|
}
|
2023-03-02 15:42:38 -06:00
|
|
|
const mainWindow = new BrowserWindow({
|
2024-08-13 14:35:15 -05:00
|
|
|
width: 1100,
|
2023-03-02 15:42:38 -06:00
|
|
|
height: 600,
|
2024-08-13 14:35:15 -05:00
|
|
|
minWidth: 1100,
|
|
|
|
minHeight: 600,
|
2023-03-02 15:42:38 -06:00
|
|
|
webPreferences: {
|
2023-03-02 17:26:33 -06:00
|
|
|
preload: path.join(__dirname, 'preload.js'),
|
2023-03-03 08:51:48 -06:00
|
|
|
webviewTag: true,
|
2023-03-09 04:04:28 -06:00
|
|
|
devTools: false,
|
2024-11-21 14:57:11 -06:00
|
|
|
nodeIntegration: false,
|
2023-03-09 04:04:28 -06:00
|
|
|
sandbox: true,
|
|
|
|
contextIsolation: true
|
2023-03-02 15:42:38 -06:00
|
|
|
}
|
|
|
|
})
|
|
|
|
|
2024-11-21 15:04:35 -06:00
|
|
|
const homePath = app.getPath('home');
|
|
|
|
const extensionsDir = path.join(homePath, 'SneedExtensions');
|
2024-11-21 14:57:11 -06:00
|
|
|
|
|
|
|
if (!fs.existsSync(extensionsDir)) {
|
|
|
|
fs.mkdirSync(extensionsDir, { recursive: true });
|
|
|
|
}
|
|
|
|
|
|
|
|
const extensionFolders = fs.readdirSync(extensionsDir, { withFileTypes: true })
|
|
|
|
.filter(dirent => dirent.isDirectory())
|
|
|
|
.map(dirent => path.join(extensionsDir, dirent.name));
|
|
|
|
|
|
|
|
for (const extensionPath of extensionFolders) {
|
|
|
|
extensions.loadExtension(extensionPath);
|
|
|
|
}
|
|
|
|
|
2024-11-21 14:02:51 -06:00
|
|
|
extensions.addTab(mainWindow.webContents, mainWindow)
|
2023-03-17 19:59:06 -05:00
|
|
|
mainWindow.setMinimumSize(1000, 300)
|
2023-03-03 08:51:48 -06:00
|
|
|
|
2023-03-03 08:30:52 -06:00
|
|
|
|
|
|
|
const toBlock = [
|
2023-03-09 07:26:19 -06:00
|
|
|
"*://*.doubleclick.*",
|
2023-03-09 06:33:42 -06:00
|
|
|
"*://s.innovid.com/*",
|
2023-03-03 08:30:52 -06:00
|
|
|
"*://partner.googleadservices.com/*",
|
|
|
|
"*://*.googlesyndication.com/*",
|
|
|
|
"*://*.google-analytics.com/*",
|
|
|
|
"*://creative.ak.fbcdn.net/*",
|
|
|
|
"*://*.adbrite.com/*",
|
|
|
|
"*://*.exponential.com/*",
|
|
|
|
"*://*.quantserve.com/*",
|
|
|
|
"*://*.scorecardresearch.com/*",
|
|
|
|
"*://*.zedo.com/*",
|
|
|
|
"*://*.a-ads.com/*",
|
|
|
|
"*://*.777partner.com/*",
|
|
|
|
"*://*.77tracking.com/*",
|
|
|
|
"*://*.abc-ads.com/*",
|
|
|
|
"*://*.aaxads.com/*",
|
|
|
|
"*://*.adizio.com/*",
|
|
|
|
"*://*.adjix.com/*",
|
|
|
|
"*://*.adjug.com/*",
|
|
|
|
"*://*.adjuggler.com/*",
|
|
|
|
"*://*.trafficjunky.net/*",
|
|
|
|
"*://*.trafficleader.com/*",
|
2023-03-09 05:34:38 -06:00
|
|
|
"*://*.trafficrouter.io/*",
|
2023-03-09 05:39:31 -06:00
|
|
|
"*://*.monerominer.rocks/*",
|
2023-03-09 06:33:42 -06:00
|
|
|
"*://*.2mdn.net/*",
|
2023-03-09 05:39:31 -06:00
|
|
|
"*.exe",
|
2023-03-09 06:56:22 -06:00
|
|
|
"*.vbs",
|
2023-03-09 07:26:19 -06:00
|
|
|
"*://*.googlesyndication.*",
|
|
|
|
"*pixels*",
|
|
|
|
"*telemetry*",
|
|
|
|
"*analytics*",
|
2023-03-09 07:39:59 -06:00
|
|
|
"*://ads.*.com*",
|
|
|
|
"*ae/us/audience*",
|
|
|
|
"*/api/v*/science*",
|
|
|
|
"*/api/v*/typing*"
|
2023-03-03 08:30:52 -06:00
|
|
|
]
|
|
|
|
|
2023-03-09 06:56:22 -06:00
|
|
|
const regexPatterns = [
|
2023-03-09 07:41:28 -06:00
|
|
|
"r[0-100]+---sn-.*\.googlevideo\.com$/g",
|
|
|
|
"r[0-100]+-sn-.*\.googlevideo\.com$/g"
|
2023-03-09 06:56:22 -06:00
|
|
|
]
|
|
|
|
|
2023-03-03 08:30:52 -06:00
|
|
|
function containsAD(url) {
|
|
|
|
var i;
|
|
|
|
for (i = 0; i < toBlock.length; i++) {
|
2023-03-09 06:56:22 -06:00
|
|
|
let regex = toBlock[i].replace(/\*/g, "[^ ]*");
|
|
|
|
if (url.match(regex)) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i = 0; i < regexPatterns.length; i++) {
|
|
|
|
let regex = regexPatterns[i]
|
2023-03-03 08:30:52 -06:00
|
|
|
if (url.match(regex)) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2024-08-13 15:36:09 -05:00
|
|
|
session.defaultSession.setProxy({
|
|
|
|
proxyRules: 'http=localhost:3129;https=localhost:3129',
|
|
|
|
proxyBypassRules: '<local>'
|
|
|
|
})
|
|
|
|
|
2023-03-03 08:30:52 -06:00
|
|
|
session.defaultSession.webRequest.onBeforeRequest((details, callback) => {
|
2023-03-09 06:56:22 -06:00
|
|
|
if (containsAD(details.url)) {
|
2023-03-03 08:30:52 -06:00
|
|
|
return callback({cancel: true})
|
|
|
|
}
|
2024-08-14 10:03:19 -05:00
|
|
|
|
|
|
|
const url = new URL(details.url);
|
|
|
|
const hostname = url.hostname;
|
|
|
|
const isLocalDomain = isLocal(hostname);
|
|
|
|
|
|
|
|
// Check if the request is to a local domain
|
|
|
|
if (isLocalDomain) {
|
|
|
|
// Check if the request is initiated by a remote domain
|
|
|
|
const initiator = details.initiator ? new URL(details.initiator).hostname : '';
|
|
|
|
const isInitiatorLocal = isLocal(initiator);
|
|
|
|
|
|
|
|
if (initiator && !isInitiatorLocal) {
|
|
|
|
console.log(`[W] Local domain is being accessed by external source (${initiator}), don't allow!`);
|
|
|
|
callback({ cancel: true }); // Block request to local domains from remote sources
|
|
|
|
} else {
|
2024-08-14 10:34:58 -05:00
|
|
|
//console.log("Local domain is not being accessed by external source, allow..."); // debug
|
2024-08-14 10:03:19 -05:00
|
|
|
callback({ cancel: false }); // Allow request
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
//console.log("Request is not to a local domain, allow..."); //debug
|
|
|
|
callback({ cancel: false }); // Allow non-local requests
|
|
|
|
}
|
2023-03-03 08:30:52 -06:00
|
|
|
})
|
2023-03-09 05:25:24 -06:00
|
|
|
|
2023-03-02 15:42:38 -06:00
|
|
|
// and load the index.html of the app.
|
|
|
|
mainWindow.loadFile('index.html')
|
|
|
|
|
2023-03-09 05:25:24 -06:00
|
|
|
|
|
|
|
return mainWindow;
|
2023-03-02 15:42:38 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
// This method will be called when Electron has finished
|
|
|
|
// initialization and is ready to create browser windows.
|
|
|
|
// Some APIs can only be used after this event occurs.
|
|
|
|
app.whenReady().then(() => {
|
2023-03-09 05:25:24 -06:00
|
|
|
let x = createWindow()
|
2024-08-12 15:16:12 -05:00
|
|
|
enableGoodies().then()
|
2023-03-02 15:42:38 -06:00
|
|
|
app.on('activate', function () {
|
|
|
|
// On macOS it's common to re-create a window in the app when the
|
|
|
|
// dock icon is clicked and there are no other windows open.
|
|
|
|
if (BrowserWindow.getAllWindows().length === 0) createWindow()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
// Quit when all windows are closed, except on macOS. There, it's common
|
|
|
|
// for applications and their menu bar to stay active until the user quits
|
|
|
|
// explicitly with Cmd + Q.
|
|
|
|
app.on('window-all-closed', function () {
|
2024-11-21 14:08:59 -06:00
|
|
|
if (process.platform !== 'darwin') { app.quit() }
|
2023-03-02 15:42:38 -06:00
|
|
|
})
|
|
|
|
|
2024-11-25 14:07:39 -06:00
|
|
|
|
2023-03-02 15:42:38 -06:00
|
|
|
// In this file you can include the rest of your app's specific main process
|
2023-03-03 09:17:55 -06:00
|
|
|
// code. You can also put them in separate files and require them here.
|
2024-08-13 15:36:09 -05:00
|
|
|
|
2024-11-25 14:07:39 -06:00
|
|
|
// Set DNS and enable mic/cam
|
2024-08-13 15:36:09 -05:00
|
|
|
app.on('ready', () => {
|
|
|
|
app.configureHostResolver({
|
|
|
|
mode: 'secure',
|
|
|
|
dohServers: [
|
|
|
|
'https://dns9.quad9.net/dns-query',
|
|
|
|
'https://cloudflare-dns.com/dns-query'
|
|
|
|
]
|
|
|
|
});
|
|
|
|
});
|