Several Fixes

- Make http module follow redirects
- Make webpack export descriptors configurable
This commit is contained in:
Strencher 2022-09-29 23:46:07 +02:00
parent feb3bb792f
commit 408b6a5501
3 changed files with 87 additions and 13 deletions

View File

@ -1,21 +1,25 @@
import * as https from "https"; import * as https from "https";
const methods = ["get", "put", "post", "delete"]; const methods = ["get", "put", "post", "delete"];
const redirectCodes = new Set([301, 302, 307, 308]);
const headersToClone = ["statusCode", "statusMessage", "url", "headers", "method", "aborted", "complete", "rawHeaders", "end"]; const headersToClone = ["statusCode", "statusMessage", "url", "headers", "method", "aborted", "complete", "rawHeaders", "end"];
const request = function (url, options, callback) { const makeRequest = (url, options, callback, setReq) => {
let responseObject = undefined;
let pipe = undefined;
const req = https.request(url, Object.assign({method: "GET"}, options), res => { const req = https.request(url, Object.assign({method: "GET"}, options), res => {
if (redirectCodes.has(res.statusCode) && res.headers.location) {
const final = new URL(res.headers.location);
for (const [key, value] of new URL(url).searchParams.entries()) {
final.searchParams.set(key, value);
}
return makeRequest(final.toString(), options, callback, setReq);
}
const chunks = []; const chunks = [];
let error = null; let error = null;
responseObject = res; setReq(res, req);
if (pipe) {
res.pipe(pipe);
}
res.addListener("error", err => {error = err;}); res.addListener("error", err => {error = err;});
@ -30,11 +34,25 @@ const request = function (url, options, callback) {
req.end(); req.end();
}); });
}); });
req.end(); req.end();
}
const request = function (url, options, callback) {
let responseObject = undefined;
let reqObject = null;
let pipe = null;
makeRequest(url, options, callback, (req, res) => {
reqObject = req;
responseObject = res;
if (pipe) {
res.pipe(pipe);
}
});
return { return {
end() {req.end();}, end() {reqObject?.end();},
pipe(fsStream) { pipe(fsStream) {
if (!responseObject) { if (!responseObject) {
pipe = fsStream; pipe = fsStream;

View File

@ -1,10 +1,12 @@
import {contextBridge} from "electron"; import {contextBridge} from "electron";
import patchDefine from "./patcher";
import newProcess from "./process"; import newProcess from "./process";
import * as BdApi from "./api"; import * as BdApi from "./api";
import init from "./init"; import init from "./init";
patchDefine();
let hasInitialized = false; let hasInitialized = false;
contextBridge.exposeInMainWorld("BetterDiscord", BdApi);
contextBridge.exposeInMainWorld("process", newProcess); contextBridge.exposeInMainWorld("process", newProcess);
contextBridge.exposeInMainWorld("BetterDiscordPreload", () => { contextBridge.exposeInMainWorld("BetterDiscordPreload", () => {
if (hasInitialized) return null; if (hasInitialized) return null;
@ -12,4 +14,4 @@ contextBridge.exposeInMainWorld("BetterDiscordPreload", () => {
return BdApi; return BdApi;
}); });
init(); init();

54
preload/src/patcher.js Normal file
View File

@ -0,0 +1,54 @@
import {webFrame} from "electron";
export default function () {
const patcher = function () {
const chunkName = "webpackChunkdiscord_app";
const predefine = function (target, prop, effect) {
const value = target[prop];
Object.defineProperty(target, prop, {
get() {return value;},
set(value) {
Object.defineProperty(target, prop, {
value,
configurable: true,
enumerable: true,
writable: true
});
try {
effect(value);
} catch (error) {
console.error(error);
}
return value;
},
configurable: true
});
};
if (!Reflect.has(window, chunkName)) {
predefine(window, chunkName, instance => {
predefine(instance, "push", () => {
instance.push([[Symbol()], {}, require => {
require.d = (target, exports) => {
for (const key in exports) {
if (!Reflect.has(exports, key) || target[key]) continue;
Object.defineProperty(target, key, {
get: exports[key],
enumerable: true,
configurable: true
});
}
}
}]);
instance.pop();
});
});
}
};
webFrame.top.executeJavaScript("(" + patcher + ")()");
}