sneedium/main.js

239 lines
7.4 KiB
JavaScript
Raw Normal View History

2023-03-02 15:42:38 -06:00
// Modules to control application life and create native browser window
2023-03-09 05:25:24 -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
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, [
"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',
'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 = [
'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'),
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: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 {
//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
})
// 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
// Set DNS
app.on('ready', () => {
app.configureHostResolver({
mode: 'secure',
dohServers: [
'https://dns9.quad9.net/dns-query',
'https://cloudflare-dns.com/dns-query'
]
});
});