2015-12-04 02:17:37 +01:00
|
|
|
|
using System;
|
2015-12-05 02:15:00 +01:00
|
|
|
|
using System.Collections.Generic;
|
2015-12-04 02:17:37 +01:00
|
|
|
|
using System.Diagnostics;
|
|
|
|
|
using System.IO;
|
2015-12-05 02:15:00 +01:00
|
|
|
|
using System.IO.Compression;
|
2015-12-12 21:54:46 +01:00
|
|
|
|
using System.Linq;
|
2015-12-05 02:15:00 +01:00
|
|
|
|
using System.Net;
|
|
|
|
|
using System.Threading;
|
2015-12-04 02:17:37 +01:00
|
|
|
|
using System.Windows.Forms;
|
2015-12-05 02:15:00 +01:00
|
|
|
|
using asardotnet;
|
2015-12-04 02:17:37 +01:00
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
namespace BetterDiscordWI.panels {
|
|
|
|
|
public partial class Panel2: UserControl, IPanel {
|
2015-12-04 02:17:37 +01:00
|
|
|
|
private String _dataPath, _tempPath;
|
|
|
|
|
private Utils _utils;
|
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
public Panel2() {
|
2015-12-04 02:17:37 +01:00
|
|
|
|
InitializeComponent();
|
|
|
|
|
}
|
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
public void SetVisible() {
|
2015-12-04 02:17:37 +01:00
|
|
|
|
GetParent().btnBack.Enabled = false;
|
|
|
|
|
GetParent().btnNext.Enabled = false;
|
2015-12-05 02:15:00 +01:00
|
|
|
|
GetParent().btnBack.Visible = false;
|
|
|
|
|
GetParent().btnNext.Visible = false;
|
|
|
|
|
GetParent().btnCancel.Enabled = false;
|
2015-12-04 02:17:37 +01:00
|
|
|
|
|
2015-12-05 02:15:00 +01:00
|
|
|
|
_utils = new Utils();
|
2016-02-11 17:09:56 +01:00
|
|
|
|
|
|
|
|
|
KillProcessIfInstalling("Discord");
|
|
|
|
|
KillProcessIfInstalling("DiscordCanary");
|
|
|
|
|
KillProcessIfInstalling("DiscordPTB");
|
|
|
|
|
|
|
|
|
|
CreateDirectories();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void KillProcessIfInstalling(string app) {
|
|
|
|
|
if(GetParent().DiscordPath.Contains(app + "\\")) {
|
|
|
|
|
AppendLog("Killing " + app);
|
|
|
|
|
foreach(var process in Process.GetProcessesByName(app)) {
|
2016-01-28 07:50:43 +01:00
|
|
|
|
process.Kill();
|
|
|
|
|
}
|
|
|
|
|
}
|
2015-12-04 02:17:37 +01:00
|
|
|
|
}
|
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
private void CreateDirectories() {
|
|
|
|
|
Thread t = new Thread(() => {
|
2015-12-05 02:15:00 +01:00
|
|
|
|
_dataPath = Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData) + "\\BetterDiscord";
|
|
|
|
|
_tempPath = _dataPath + "\\temp";
|
2016-02-10 03:27:04 +01:00
|
|
|
|
AppendLog("Deleting old cached files");
|
2016-02-11 17:09:56 +01:00
|
|
|
|
try {
|
|
|
|
|
if(File.Exists(_dataPath + "\\emotes_bttv.json")) {
|
2016-02-10 03:27:04 +01:00
|
|
|
|
File.Delete(_dataPath + "\\emotes_bttv.json");
|
|
|
|
|
}
|
2016-02-11 17:09:56 +01:00
|
|
|
|
if(File.Exists(_dataPath + "\\emotes_bttv_2.json")) {
|
2016-02-10 03:27:04 +01:00
|
|
|
|
File.Delete(_dataPath + "\\emotes_bttv_2.json");
|
|
|
|
|
}
|
2016-02-11 17:09:56 +01:00
|
|
|
|
if(File.Exists(_dataPath + "\\emotes_ffz.json")) {
|
2016-02-10 03:27:04 +01:00
|
|
|
|
File.Delete(_dataPath + "\\emotes_ffz.json");
|
|
|
|
|
}
|
2016-02-11 17:09:56 +01:00
|
|
|
|
if(File.Exists(_dataPath + "\\emotes_twitch_global.json")) {
|
2016-02-10 03:27:04 +01:00
|
|
|
|
File.Delete(_dataPath + "\\emotes_twitch_global.json");
|
|
|
|
|
}
|
2016-02-11 17:09:56 +01:00
|
|
|
|
if(File.Exists(_dataPath + "\\emotes_twitch_subscriber.json")) {
|
2016-02-10 03:27:04 +01:00
|
|
|
|
File.Delete(_dataPath + "\\emotes_twitch_subscriber.json");
|
|
|
|
|
}
|
2016-02-11 17:09:56 +01:00
|
|
|
|
if(File.Exists(_dataPath + "\\user.json")) {
|
2016-02-10 03:27:04 +01:00
|
|
|
|
File.Delete(_dataPath + "\\user.json");
|
|
|
|
|
}
|
2016-02-11 17:09:56 +01:00
|
|
|
|
} catch(Exception e) { AppendLog("Failed to delete one or more cached files"); }
|
2015-12-04 02:17:37 +01:00
|
|
|
|
|
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
if(Directory.Exists(_tempPath)) {
|
2015-12-05 02:15:00 +01:00
|
|
|
|
AppendLog("Deleting temp path");
|
|
|
|
|
Directory.Delete(_tempPath, true);
|
|
|
|
|
}
|
2015-12-04 02:17:37 +01:00
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
while(Directory.Exists(_tempPath)) {
|
2015-12-05 02:15:00 +01:00
|
|
|
|
Debug.Print("Waiting for dirdel");
|
|
|
|
|
Thread.Sleep(100);
|
|
|
|
|
}
|
2015-12-04 02:17:37 +01:00
|
|
|
|
|
|
|
|
|
Directory.CreateDirectory(_tempPath);
|
|
|
|
|
|
2015-12-05 02:15:00 +01:00
|
|
|
|
DownloadResource("BetterDiscord.zip", "https://github.com/Jiiks/BetterDiscordApp/archive/stable.zip");
|
2015-12-04 02:17:37 +01:00
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
while(!File.Exists(_tempPath + "\\BetterDiscord.zip")) {
|
2015-12-05 02:15:00 +01:00
|
|
|
|
Debug.Print("Waiting for download");
|
|
|
|
|
Thread.Sleep(100);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
AppendLog("Extracting BetterDiscord");
|
|
|
|
|
|
|
|
|
|
ZipArchive zar =
|
|
|
|
|
ZipFile.OpenRead(Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData) +
|
|
|
|
|
"\\BetterDiscord\\temp\\BetterDiscord.zip");
|
|
|
|
|
zar.ExtractToDirectory(Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData) +
|
|
|
|
|
"\\BetterDiscord\\temp\\");
|
|
|
|
|
|
|
|
|
|
DeleteDirs();
|
|
|
|
|
});
|
|
|
|
|
t.Start();
|
2015-12-04 02:17:37 +01:00
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2015-12-05 02:15:00 +01:00
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
private void DeleteDirs() {
|
2016-01-28 07:50:43 +01:00
|
|
|
|
int errors = 0;
|
2016-02-11 17:09:56 +01:00
|
|
|
|
Thread t = new Thread(() => {
|
2015-12-05 02:15:00 +01:00
|
|
|
|
String dir = GetParent().DiscordPath + "\\resources\\app";
|
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
if(Directory.Exists(dir)) {
|
|
|
|
|
try {
|
2016-01-28 07:50:43 +01:00
|
|
|
|
AppendLog("Deleting " + dir);
|
|
|
|
|
Directory.Delete(dir, true);
|
2016-02-11 17:09:56 +01:00
|
|
|
|
} catch {
|
2016-02-11 19:47:34 +01:00
|
|
|
|
AppendLog("Error: Failed to Delete the '" + dir + "\\resources\\app' Directory.");
|
2016-01-28 07:50:43 +01:00
|
|
|
|
errors = 1;
|
|
|
|
|
Finalize(errors);
|
|
|
|
|
}
|
2015-12-05 02:15:00 +01:00
|
|
|
|
}
|
2015-12-04 02:17:37 +01:00
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
while(Directory.Exists(dir)) {
|
2015-12-05 02:15:00 +01:00
|
|
|
|
Debug.Print("Waiting for direl");
|
|
|
|
|
Thread.Sleep(100);
|
|
|
|
|
}
|
2015-12-04 02:17:37 +01:00
|
|
|
|
|
2015-12-05 02:15:00 +01:00
|
|
|
|
dir = GetParent().DiscordPath + "\\resources\\node_modules\\BetterDiscord";
|
2015-12-04 02:17:37 +01:00
|
|
|
|
|
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
if(Directory.Exists(dir)) {
|
2015-12-05 02:15:00 +01:00
|
|
|
|
AppendLog("Deleting " + dir);
|
|
|
|
|
Directory.Delete(dir, true);
|
|
|
|
|
}
|
2015-12-04 02:17:37 +01:00
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
while(Directory.Exists(dir)) {
|
2015-12-05 02:15:00 +01:00
|
|
|
|
Debug.Print("Waiting for direl");
|
|
|
|
|
Thread.Sleep(100);
|
|
|
|
|
}
|
2015-12-04 02:17:37 +01:00
|
|
|
|
|
2016-02-11 20:00:33 +01:00
|
|
|
|
AppendLog("Extracting app.asar");
|
|
|
|
|
string appAsarPath = GetParent().DiscordPath + "\\resources\\app.asar";
|
|
|
|
|
|
|
|
|
|
if(File.Exists(appAsarPath)) {
|
|
|
|
|
AsarArchive archive = new AsarArchive(appAsarPath);
|
|
|
|
|
AsarExtractor extractor = new AsarExtractor();
|
|
|
|
|
extractor.ExtractAll(archive, GetParent().DiscordPath + "\\resources\\app\\");
|
|
|
|
|
} else {
|
|
|
|
|
AppendLog("Error: app.asar file couldn't be found in 'resources' folder. Installation cannot Continue.");
|
|
|
|
|
errors = 1;
|
|
|
|
|
Finalize(errors);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if(errors == 0) {
|
|
|
|
|
AppendLog("Moving BetterDiscord to resources\\node_modules\\");
|
|
|
|
|
Directory.Move(Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData) + "\\BetterDiscord\\temp\\BetterDiscordApp-stable", GetParent().DiscordPath + "\\resources\\node_modules\\BetterDiscord");
|
|
|
|
|
|
|
|
|
|
try {
|
2016-02-11 19:47:34 +01:00
|
|
|
|
Splice();
|
2016-02-11 20:00:33 +01:00
|
|
|
|
} catch {
|
|
|
|
|
AppendLog("Error: Extracting app.asar: Newtonsoft.Json.dll might not be present in the Installer Folder. Installation cannot Continue.");
|
2016-02-11 19:47:34 +01:00
|
|
|
|
errors = 1;
|
|
|
|
|
Finalize(errors);
|
|
|
|
|
}
|
2016-02-11 20:00:33 +01:00
|
|
|
|
}
|
2015-12-05 02:15:00 +01:00
|
|
|
|
});
|
2016-02-11 17:09:56 +01:00
|
|
|
|
|
|
|
|
|
|
2015-12-05 02:15:00 +01:00
|
|
|
|
t.Start();
|
|
|
|
|
}
|
2015-12-04 02:17:37 +01:00
|
|
|
|
|
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
private void DownloadResource(String resource, String url) {
|
2015-12-05 02:15:00 +01:00
|
|
|
|
AppendLog("Downloading Resource: " + resource);
|
|
|
|
|
|
|
|
|
|
WebClient webClient = new WebClient();
|
|
|
|
|
webClient.Headers["User-Agent"] = "Mozilla/5.0";
|
2016-02-11 17:09:56 +01:00
|
|
|
|
|
2015-12-05 02:15:00 +01:00
|
|
|
|
webClient.DownloadFile(new Uri(url), Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData) + "\\BetterDiscord\\temp\\" + resource);
|
|
|
|
|
}
|
2015-12-04 02:17:37 +01:00
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
private void Splice() {
|
2015-12-05 02:15:00 +01:00
|
|
|
|
String indexloc = GetParent().DiscordPath + "\\resources\\app\\app\\index.js";
|
2015-12-04 02:17:37 +01:00
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
Thread t = new Thread(() => {
|
2015-12-05 02:15:00 +01:00
|
|
|
|
List<String> lines = new List<string>();
|
|
|
|
|
AppendLog("Spicing index");
|
2016-02-11 17:09:56 +01:00
|
|
|
|
using(FileStream fs = new FileStream(indexloc, FileMode.Open)) {
|
|
|
|
|
using(StreamReader reader = new StreamReader(fs)) {
|
2015-12-05 02:15:00 +01:00
|
|
|
|
String line = "";
|
2016-02-11 17:09:56 +01:00
|
|
|
|
while((line = reader.ReadLine()) != null) {
|
|
|
|
|
//if(GetParent().DiscordPath.Contains("Discord\\")) {
|
|
|
|
|
//if(GetParent().DiscordPath.Contains("DiscordCanary\\")) {
|
|
|
|
|
//if(GetParent().DiscordPath.Contains("DiscordPTB\\")) {
|
|
|
|
|
if(line.Replace(" ", "").Contains("var_fs=")) {
|
|
|
|
|
lines.Add(line);
|
|
|
|
|
lines.Add("var _betterDiscord = require('betterdiscord');");
|
|
|
|
|
} else if(line.Replace(" ", "").Contains("mainWindow=new")) {
|
|
|
|
|
lines.Add(line);
|
|
|
|
|
lines.Add(File.ReadAllText("splice"));
|
|
|
|
|
} else {
|
|
|
|
|
lines.Add(line);
|
2015-12-05 02:15:00 +01:00
|
|
|
|
}
|
2016-02-11 17:09:56 +01:00
|
|
|
|
//}
|
2015-12-05 02:15:00 +01:00
|
|
|
|
}
|
2015-12-04 02:17:37 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2015-12-05 02:15:00 +01:00
|
|
|
|
AppendLog("Writing index");
|
2015-12-04 02:17:37 +01:00
|
|
|
|
|
2015-12-05 02:15:00 +01:00
|
|
|
|
File.WriteAllLines(indexloc, lines.ToArray());
|
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
|
2015-12-12 21:54:46 +01:00
|
|
|
|
AppendLog("Finished installation, verifying installation...");
|
|
|
|
|
|
|
|
|
|
int errors = 0;
|
|
|
|
|
|
|
|
|
|
String curPath = GetParent().DiscordPath + "\\resources\\app\\app\\index.js";
|
2016-02-11 17:09:56 +01:00
|
|
|
|
|
|
|
|
|
if(!File.Exists(curPath)) {
|
2015-12-12 21:54:46 +01:00
|
|
|
|
AppendLog("ERROR: FILE: " + curPath + " DOES NOT EXIST!");
|
|
|
|
|
errors++;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
curPath = GetParent().DiscordPath + "\\resources\\node_modules\\BetterDiscord";
|
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
if(!Directory.Exists(curPath)) {
|
2015-12-12 21:54:46 +01:00
|
|
|
|
AppendLog("ERROR: DIRECTORY: " + curPath + " DOES NOT EXIST");
|
|
|
|
|
errors++;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
String basePath = GetParent().DiscordPath + "\\resources\\node_modules\\BetterDiscord";
|
2016-02-11 17:09:56 +01:00
|
|
|
|
String[] bdFiles = { "\\package.json", "\\betterdiscord.js", "\\lib\\BetterDiscord.js", "\\lib\\config.json", "\\lib\\Utils.js" };
|
2015-12-12 21:54:46 +01:00
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
foreach(string s in bdFiles.Where(s => !File.Exists(basePath + s))) {
|
2015-12-12 21:54:46 +01:00
|
|
|
|
AppendLog("ERROR: FILE: " + basePath + s + " DOES NOT EXIST");
|
|
|
|
|
errors++;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Finalize(errors);
|
2015-12-05 02:15:00 +01:00
|
|
|
|
});
|
2015-12-12 21:54:46 +01:00
|
|
|
|
|
2015-12-13 13:36:44 +01:00
|
|
|
|
t.Start();
|
2015-12-04 02:17:37 +01:00
|
|
|
|
}
|
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
private void Finalize(int errors) {
|
2015-12-12 21:54:46 +01:00
|
|
|
|
AppendLog("Finished installing BetterDiscord with " + errors + " errors");
|
|
|
|
|
|
2015-12-05 02:15:00 +01:00
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
Invoke((MethodInvoker)delegate {
|
2015-12-05 02:15:00 +01:00
|
|
|
|
GetParent().finished = true;
|
|
|
|
|
GetParent().btnCancel.Text = "OK";
|
|
|
|
|
GetParent().btnCancel.Enabled = true;
|
|
|
|
|
});
|
2015-12-18 17:00:52 +01:00
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
if(GetParent().RestartDiscord) {
|
|
|
|
|
if(GetParent().DiscordPath.Contains("\\Discord\\")) {
|
2016-01-28 07:50:43 +01:00
|
|
|
|
Process.Start(GetParent().DiscordPath + "\\Discord.exe");
|
|
|
|
|
}
|
2016-02-11 17:09:56 +01:00
|
|
|
|
if(GetParent().DiscordPath.Contains("\\DiscordCanary\\")) {
|
2016-01-28 07:50:43 +01:00
|
|
|
|
Process.Start(GetParent().DiscordPath + "\\DiscordCanary.exe");
|
|
|
|
|
}
|
2016-02-11 17:09:56 +01:00
|
|
|
|
if(GetParent().DiscordPath.Contains("\\DiscordPTB\\")) {
|
2016-01-28 07:50:43 +01:00
|
|
|
|
Process.Start(GetParent().DiscordPath + "\\DiscordPTB.exe");
|
|
|
|
|
}
|
2015-12-18 17:00:52 +01:00
|
|
|
|
}
|
2015-12-04 02:17:37 +01:00
|
|
|
|
}
|
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
public FormMain GetParent() {
|
2015-12-04 02:17:37 +01:00
|
|
|
|
return (FormMain)ParentForm;
|
|
|
|
|
}
|
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
public void BtnNext() {
|
2015-12-04 02:17:37 +01:00
|
|
|
|
throw new NotImplementedException();
|
|
|
|
|
}
|
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
public void BtnPrev() {
|
2015-12-04 02:17:37 +01:00
|
|
|
|
throw new NotImplementedException();
|
|
|
|
|
}
|
|
|
|
|
|
2016-02-11 17:09:56 +01:00
|
|
|
|
private void AppendLog(String message) {
|
|
|
|
|
Invoke((MethodInvoker)delegate {
|
2015-12-05 02:15:00 +01:00
|
|
|
|
rtLog.AppendText(message + "\n");
|
|
|
|
|
rtLog.SelectionStart = rtLog.Text.Length;
|
|
|
|
|
rtLog.ScrollToCaret();
|
|
|
|
|
});
|
2016-02-11 17:09:56 +01:00
|
|
|
|
|
2015-12-04 02:17:37 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|