final injector fix: change variables to prevent conflicts

This commit is contained in:
Cynthia Foxwell 2017-12-09 12:01:25 -07:00
parent 56fe97be96
commit 380151f43a

View file

@ -18,17 +18,17 @@ let cyn_ver = 1;
let electron = require("electron").remote; let electron = require("electron").remote;
let remote = electron; let remote = electron;
let _fs = require("fs"); let __fs = require("fs");
let fs = require("original-fs"); let _fs = require("original-fs");
let win = electron.getCurrentWindow(); let _win = electron.getCurrentWindow();
var cacheclear = function () { var cacheclear = function () {
win.webContents.session.clearCache(function(){}); _win.webContents.session.clearCache(function(){});
} }
var cleanup = function () { var cleanup = function () {
win.loadURL('https://canary.discordapp.com/channels/@me'); _win.loadURL('https://canary.discordapp.com/channels/@me');
} }
var setup = function () { var setup = function () {
@ -78,27 +78,27 @@ var setup = function () {
} }
var endpoint_setup = function () { var endpoint_setup = function () {
var settings = JSON.parse(fs.readFileSync(settingsjson(), "UTF8")); var settings = JSON.parse(_fs.readFileSync(settingsjson(), "UTF8"));
settings.WEBAPP_ENDPOINT="https://cynergy.cynfoxwell.cf"; settings.WEBAPP_ENDPOINT="https://cynergy.cynfoxwell.cf";
fs.writeFileSync(settingsjson(), JSON.stringify(settings)); _fs.writeFileSync(settingsjson(), JSON.stringify(settings));
}; };
var endpoint_restore = function () { var endpoint_restore = function () {
var settings = JSON.parse(fs.readFileSync(settingsjson(), "UTF8")); var settings = JSON.parse(_fs.readFileSync(settingsjson(), "UTF8"));
settings.WEBAPP_ENDPOINT=null; settings.WEBAPP_ENDPOINT=null;
fs.writeFileSync(settingsjson(), JSON.stringify(settings)); _fs.writeFileSync(settingsjson(), JSON.stringify(settings));
}; };
var asarpwn = function() { var asarpwn = function() {
var bdata = new Buffer(fs.readFileSync(remote.app.getAppPath())); var bdata = new Buffer(_fs.readFileSync(remote.app.getAppPath()));
bdata.write(`mainWindow.webContents.on('dom-ready', function () {require('${approot().split('app.asar')[0].replace(/\\/g,"/") + '/cynergy/i.js'}').x(mainWindow)});//`, bdata.indexOf("mainWindow.webContents.on('dom-ready', function () {});\x0A\x0A // Prevent navigation whe")); bdata.write(`mainWindow.webContents.on('dom-ready', function () {require('${approot().split('app.asar')[0].replace(/\\/g,"/") + '/cynergy/i.js'}').x(mainWindow)});//`, bdata.indexOf("mainWindow.webContents.on('dom-ready', function () {});\x0A\x0A // Prevent navigation whe"));
fs.writeFileSync(remote.app.getAppPath(), bdata); _fs.writeFileSync(remote.app.getAppPath(), bdata);
}; };
var asarunpwn = function() { var asarunpwn = function() {
logging = document.getElementById('logger'); logging = document.getElementById('logger');
logging.innerText += "\nUndoing asarpwn...\n"; logging.innerText += "\nUndoing asarpwn...\n";
var bdata = new Buffer(fs.readFileSync(remote.app.getAppPath())); var bdata = new Buffer(_fs.readFileSync(remote.app.getAppPath()));
try{ try{
bdata.write("mainWindow.webContents.on('dom-ready', function () {});\x0A\x0A // Prevent navigation whe", bdata.indexOf("mainWindow.webContents.on('dom-ready', function () {require('../i').x(mainWindow)});//")); bdata.write("mainWindow.webContents.on('dom-ready', function () {});\x0A\x0A // Prevent navigation whe", bdata.indexOf("mainWindow.webContents.on('dom-ready', function () {require('../i').x(mainWindow)});//"));
}catch(e){} }catch(e){}
@ -111,7 +111,7 @@ var asarunpwn = function() {
try{ try{
bdata.write("mainWindow.webContents.on('dom-ready', function () {});\x0A\x0A // Prevent navigation whe", bdata.indexOf(`mainWindow.webContents.on('dom-ready', function () {require('${approot().split('app.asar')[0].replace(/\\/g,"/") + '/cynergy/i.js'}').x(mainWindow)});//`)); bdata.write("mainWindow.webContents.on('dom-ready', function () {});\x0A\x0A // Prevent navigation whe", bdata.indexOf(`mainWindow.webContents.on('dom-ready', function () {require('${approot().split('app.asar')[0].replace(/\\/g,"/") + '/cynergy/i.js'}').x(mainWindow)});//`));
}catch(e){} }catch(e){}
fs.writeFileSync(remote.app.getAppPath(), bdata); _fs.writeFileSync(remote.app.getAppPath(), bdata);
} }
var data = function () { var data = function () {
@ -131,24 +131,24 @@ var asar = function () {
} }
var dropfiles = function () { var dropfiles = function () {
if (!fs.existsSync(approot().split('app.asar')[0] + '/cynergy')){ if (!_fs.existsSync(approot().split('app.asar')[0] + '/cynergy')){
fs.mkdirSync(approot().split('app.asar')[0] + '/cynergy'); _fs.mkdirSync(approot().split('app.asar')[0] + '/cynergy');
} }
if (!fs.existsSync(approot().split('app.asar')[0] + '/cynergy/styles')){ if (!_fs.existsSync(approot().split('app.asar')[0] + '/cynergy/styles')){
fs.mkdirSync(approot().split('app.asar')[0] + '/cynergy/styles'); _fs.mkdirSync(approot().split('app.asar')[0] + '/cynergy/styles');
} }
if (!fs.existsSync(approot().split('app.asar')[0] + '/cynergy/plugins')){ if (!_fs.existsSync(approot().split('app.asar')[0] + '/cynergy/plugins')){
fs.mkdirSync(approot().split('app.asar')[0] + '/cynergy/plugins'); _fs.mkdirSync(approot().split('app.asar')[0] + '/cynergy/plugins');
} }
if (!fs.existsSync(approot().split('app.asar')[0] + '/cynergy/lib')){ if (!_fs.existsSync(approot().split('app.asar')[0] + '/cynergy/lib')){
fs.mkdirSync(approot().split('app.asar')[0] + '/cynergy/lib'); _fs.mkdirSync(approot().split('app.asar')[0] + '/cynergy/lib');
} }
var license = 'BeautifulDiscord\n\nThe MIT License (MIT)\n\nCopyright (c) 2016 leovoel\n\nPermission is hereby granted, free of charge, to any person obtaining a\ncopy of this software and associated documentation files (the "Software"),\nto deal in the Software without restriction, including without limitation\nthe rights to use, copy, modify, merge, publish, distribute, sublicense,\nand/or sell copies of the Software, and to permit persons to whom the\nSoftware is furnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS\nOR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING\nFROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER\nDEALINGS IN THE SOFTWARE.'; var license = 'BeautifulDiscord\n\nThe MIT License (MIT)\n\nCopyright (c) 2016 leovoel\n\nPermission is hereby granted, free of charge, to any person obtaining a\ncopy of this software and associated documentation files (the "Software"),\nto deal in the Software without restriction, including without limitation\nthe rights to use, copy, modify, merge, publish, distribute, sublicense,\nand/or sell copies of the Software, and to permit persons to whom the\nSoftware is furnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS\nOR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING\nFROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER\nDEALINGS IN THE SOFTWARE.';
// blob of bullshit for i.js start // blob of bullshit for i.js start
// imports/helper definitions // imports/helper definitions
var ec = `fs=require("original-fs");var el=require("electron").remote;var win=el.getCurrentWindow();var app=el.app;var _cyn_data="${approot().split("app.asar")[0].replace(/\\/g,"/")+"/cynergy/"}";`; var ec = `var fs=require("original-fs");var el=require("electron").remote;var win=el.getCurrentWindow();var app=el.app;var _cyn_data="${approot().split("app.asar")[0].replace(/\\/g,"/")+"/cynergy/"}";`;
// restart function // restart function
var rs = 'var _cyn_restart=function(){app.relaunch();app.quit()}'; var rs = 'var _cyn_restart=function(){app.relaunch();app.quit()}';
// cache clear function // cache clear function
@ -156,30 +156,30 @@ var dropfiles = function () {
// continue to discord function // continue to discord function
var ct = 'var _cyn_continue=function(){win.loadURL("https://canary.discordapp.com/channels/@me")}'; var ct = 'var _cyn_continue=function(){win.loadURL("https://canary.discordapp.com/channels/@me")}';
// bootstrap // bootstrap
var pl = `fs=require("original-fs");exports.x=function(win){win.webContents.executeJavaScript('${ec}var _cynergy_ver=${cyn_ver};${rs};${cc};${ct};if(window.location.hostname.includes("discordapp.com")){require(_cyn_data + "/main")}');}`; var pl = `var fs=require("original-fs");exports.x=function(win){win.webContents.executeJavaScript('${ec}var _cynergy_ver=${cyn_ver};${rs};${cc};${ct};if(window.location.hostname.includes("discordapp.com")){require(_cyn_data + "/main")}');}`;
// end i.js cyst // end i.js cyst
fs.writeFileSync(approot().split('app.asar')[0] + '/cynergy/i.js', pl); _fs.writeFileSync(approot().split('app.asar')[0] + '/cynergy/i.js', pl);
fs.writeFileSync(approot().split('app.asar')[0] + '/cynergy/p.js', '// todo'); _fs.writeFileSync(approot().split('app.asar')[0] + '/cynergy/p.js', '// todo');
try try
{ {
fs.readFileSync(approot().split('app.asar')[0] + '/cynergy/autoexec.js'); _fs.readFileSync(approot().split('app.asar')[0] + '/cynergy/autoexec.js');
} }
catch(e) catch(e)
{ {
fs.writeFileSync(approot().split('app.asar')[0] + '/cynergy/autoexec.js', 'setupCSS(_cyn_data + "/cynergy/styles/style.css");\nconsole.log("Hello, world!");'); _fs.writeFileSync(approot().split('app.asar')[0] + '/cynergy/autoexec.js', 'setupCSS(_cyn_data + "/cynergy/styles/style.css");\nconsole.log("Hello, world!");');
} }
/*try /*try
{ {
fs.readFileSync(data() + 'style.css'); _fs.readFileSync(data() + 'style.css');
} }
catch(e) catch(e)
{ {
var client = new XMLHttpRequest(); var client = new XMLHttpRequest();
client.open('GET', 'http://apo.wds.us/default.css'); client.open('GET', 'http://apo.wds.us/default.css');
client.onreadystatechange = function() { client.onreadystatechange = function() {
fs.writeFileSync(data() + 'style.css', client.responseText); _fs.writeFileSync(data() + 'style.css', client.responseText);
} }
client.send(); client.send();
}*/ }*/
@ -187,24 +187,24 @@ var dropfiles = function () {
eclient.open('GET', 'https://cynergy.cynfoxwell.cf/libs/epapi.js'); eclient.open('GET', 'https://cynergy.cynfoxwell.cf/libs/epapi.js');
eclient.onreadystatechange = function() { eclient.onreadystatechange = function() {
if (eclient.readyState === 4) { if (eclient.readyState === 4) {
fs.writeFileSync(approot().split('app.asar')[0] + '/cynergy/epapi.js', eclient.responseText); _fs.writeFileSync(approot().split('app.asar')[0] + '/cynergy/epapi.js', eclient.responseText);
} }
} }
eclient.send(); eclient.send();
var mclient = new XMLHttpRequest(); var mclient = new XMLHttpRequest();
mclient.open('GET', 'https://cynergy.cynfoxwell.cf/libs/main.js'); mclient.open('GET', 'https://cynergy.cynfoxwell.cf/libs/main.js');
mclient.onreadystatechange = function() { mclient.onreadystatechange = function() {
fs.writeFileSync(approot().split('app.asar')[0] + '/cynergy/main.js', mclient.responseText); _fs.writeFileSync(approot().split('app.asar')[0] + '/cynergy/main.js', mclient.responseText);
} }
mclient.send(); mclient.send();
var lclient = new XMLHttpRequest(); var lclient = new XMLHttpRequest();
lclient.open('GET', 'https://cynergy.cynfoxwell.cf/libs/linq.js'); lclient.open('GET', 'https://cynergy.cynfoxwell.cf/libs/linq.js');
lclient.onreadystatechange = function() { lclient.onreadystatechange = function() {
fs.writeFileSync(approot().split('app.asar')[0] + '/cynergy/lib/linq.js', lclient.responseText); _fs.writeFileSync(approot().split('app.asar')[0] + '/cynergy/lib/linq.js', lclient.responseText);
} }
lclient.send(); lclient.send();
fs.writeFileSync(approot().split('app.asar')[0] + '/cynergy/legal.txt', license); _fs.writeFileSync(approot().split('app.asar')[0] + '/cynergy/legal.txt', license);
fs.writeFileSync(approot().split('app.asar')[0] + '/cynergy/styles/style.css', "/* custom css here */"); _fs.writeFileSync(approot().split('app.asar')[0] + '/cynergy/styles/style.css', "/* custom css here */");
} }
var crash = function () { var crash = function () {