/* BetterDiscordApp Entry
* Version: 1.3
* Author: Jiiks | http://jiiks.net
* Date: 27/08/2015 - 15:51
* Last Update: 25/10/2015 - 23:48
* https://github.com/Jiiks/BetterDiscordApp
*/
var _fs = require("fs");
var _config = require("./config.json");
var _utils = require("./utils");
//Use beta javascript
var _beta = false;
var _ipc = require('ipc');
var _version;
var _mainWindow;
var _updater;
var _hash;
var _userDefault = {"cache": null};
var _userConfig = {"cache": null};
var _cacheExpired = false;
var _cacheDays = 0;
var _dataPath;
// OS specific _dataPath
var _os = process.platform;
if (_os == "win32") {
_dataPath = "../BetterDiscordData";
} else if (_os == "darwin") {
_dataPath = "~/Library/Application Support/discord/BetterDiscordData";
}
var _userFile = _dataPath + "/user.json";
function BetterDiscord(mainWindow) {
_mainWindow = mainWindow;
_version = _config.Core.Version;
_utils = new _utils.Utils(mainWindow);
}
BetterDiscord.prototype.getUtils = function() {
return _utils;
};
BetterDiscord.prototype.init = function() {
var self = this;
//Check emotedata cache
this.getUtils().log("Checking cache");
try {
if(!_fs.existsSync(_dataPath)) {
_fs.mkdirSync(_dataPath);
}
if(!_fs.existsSync(_userFile)) {
_fs.writeFileSync(_userFile, JSON.stringify(_userDefault));
}
if(_fs.existsSync(_userFile)) {
_userConfig = JSON.parse(_fs.readFileSync(_userFile));
}
if(_userConfig.cache == null) {
_userDefault.cache = new Date();
_userConfig = _userDefault;
_fs.writeFileSync(_userFile, JSON.stringify(_userConfig));
_cacheExpired = true;
} else {
var curDate = new Date();
var cacheDate = new Date(_userConfig.cache);
if(Math.abs(curDate.getDate() - cacheDate.getDate()) > _cacheDays) {
_cacheExpired = true;
_userConfig.cache = curDate;
_fs.writeFileSync(_userFile, JSON.stringify(_userConfig));
}
}
}catch(err) { _cacheExpired = true; console.log(err); }
this.getUtils().log("Cache expired: " + _cacheExpired);
//Get latest commit hash
this.getUtils().getHash(_beta, function(hash) {
_hash = hash;
self.getUtils().log("Latest Hash: " + _hash);
//Get updater
self.getUtils().download("raw.githubusercontent.com", "/Jiiks/BetterDiscordApp/"+hash+"/updater.json", function(updater) {
_updater = JSON.parse(updater);
self.getUtils().log("Latest Version: " + _updater.LatestVersion);
self.getUtils().log("CDN: " + _updater.CDN);
self.start();
});
});
};
BetterDiscord.prototype.start = function() {
var self = this;
console.log("BetterDiscord: init");
self.getUtils().getWebContents().on('dom-ready', function() {
if(_updater.LatestVersion > _version) {
self.getUtils().execJs('alert("An update for BetterDiscord is available(v'+ _updater.LatestVersion +')! Download the latest version from GitHub!")');
}
//Create loading element
self.getUtils().execJs('var loadingNode = document.createElement("DIV");');
self.getUtils().execJs('loadingNode.innerHTML = \'
BetterDiscord - Loading Libraries : \'');
self.getUtils().execJs('var flex = document.getElementsByClassName("flex-vertical flex-spacer")[0]; flex.appendChild(loadingNode);');
//Create ipc
self.getUtils().execJs("var betterDiscordIPC = require('ipc');");
//ipc listener
_ipc.on('asynchronous-message', function(event, arg){
switch(arg) {
//jQuery loaded, load jQuery cookie
case 'loaded-jquery':
self.getUtils().updateLoading("Loading Resources(jQuery Cookie)", 10, 100);
self.getUtils().injectJavaScriptSync("//cdnjs.cloudflare.com/ajax/libs/jquery-cookie/1.4.1/jquery.cookie.min.js", "loaded-jquery-cookie");
break;
//jQuery cookie loaded, load css
case 'loaded-jquery-cookie':
self.getUtils().updateLoading("Loading Resources(css)", 20, 100);
//TODO make this nicer
// self.getUtils().injectStylesheetSync(_updater.CDN + "/Jiiks/BetterDiscordApp/" + _hash + "/css/main.min.css", "loaded-css");
self.getUtils().execJs('function injectMainCss() { $(\'head\').append( \'\' ) }');
self.getUtils().execJs('injectMainCss();');
self.getUtils().sendIcpAsync("loaded-css");
break;
//Css loaded, load main javascript
case 'loaded-css':
self.getUtils().updateLoading("Loading Resources(js)", 30, 100);
self.getUtils().injectJavaScriptSync("//" + _updater.CDN + "/Jiiks/BetterDiscordApp/"+_hash+"/js/main.min.js", "loaded-js");
break;
//Main javascript loaded, load public servers
case 'loaded-js':
self.getUtils().updateLoading("Loading Resources(Public Servers)", 40, 100);
self.getUtils().download("raw.githubusercontent.com", "/Jiiks/BetterDiscordApp/"+_hash+"/serverlist.json", function(data) {
self.getUtils().execJs('var publicServers = '+data+';');
self.getUtils().execJs('var ps = '+data+';');
self.getUtils().sendIcpAsync("loaded-publicservers");
});
break;
//Public Servers loaded, load global twitch emotes
case 'loaded-publicservers':
self.getUtils().updateLoading("Loading Resources(Twitch Global Emotedata)", 50, 100);
var tgExists = false;
try {
tgExists = _fs.existsSync(_dataPath + "/emotes_twitch_global.json");
}catch(err) { console.log(err); }
if(tgExists && !_cacheExpired) {
try {
self.getUtils().log("Reading Twitch global emotes from file");
var emotedata = _fs.readFileSync(_dataPath + "/emotes_twitch_global.json", "utf8");
JSON.parse(emotedata);
emotedata = emotedata.replace(/\$/g, "\\$").replace(/'/g, "\\'").replace(/"/g, "\\\"");
self.getUtils().execJs('var emotesTwitch = JSON.parse(\''+emotedata+'\');');
self.getUtils().sendIcpAsync("loaded-emotedata-twitchglobal");
break;
}catch(err) { console.log(err); }
}
self.getUtils().log("Downloading Twitch global emotes");
self.getUtils().downloadHttp("http://twitchemotes.com/api_cache/v2/global.json", function(emotedata) {
try {
self.getUtils().log("Writing Twitch global emotes to file");
_fs.writeFileSync(_dataPath + "/emotes_twitch_global.json", emotedata, "utf8");
}catch(err) {}
emotedata = emotedata.replace(/\$/g, "\\$").replace(/'/g, "\\'").replace(/"/g, "\\\"");
self.getUtils().execJs('var emotesTwitch = JSON.parse(\''+emotedata+'\');');
self.getUtils().sendIcpAsync("loaded-emotedata-twitchglobal");
});
break;
//Global twitch emotes loaded, load sub emotes
case 'loaded-emotedata-twitchglobal':
self.getUtils().updateLoading("Loading Resources(Twitch Subscriber Emotedata)", 60, 100);
var tsExists = false;
try {
tsExists = _fs.existsSync(_dataPath + "/emotes_twitch_sub.json");
}catch(err) { console.log(err); }
if(tsExists && !_cacheExpired) {
try {
self.getUtils().log("Reading Twitch sub emotes from file");
var tsEmotedata = _fs.readFileSync(_dataPath + "/emotes_twitch_sub.json", "utf8");
JSON.parse(tsEmotedata);
self.getUtils().execJs('var subEmotesTwitch = '+tsEmotedata+';');
self.getUtils().sendIcpAsync("loaded-emotedata-twitchsubs");
break;
}catch(err) { console.log(err); }
}
self.getUtils().log("Downloading Twitch sub emotes");
self.getUtils().downloadHttp("http://twitchemotes.com/api_cache/v2/subscriber.json", function(emotedata) {
self.getUtils().updateLoading("Parsing Resources(Twitch Subscriber Emotedata)", 70, 100);
//Since there's so many sub emotes, parse them to a simple object.
//Input: {"channel":{"emotes":["emote":emoteid]}}
//Output: {"emote":emoteid}
emotedata = JSON.parse(emotedata);
var emoteData = {};
var channels = emotedata["channels"];
for(var channel in channels) {
var emotes = channels[channel]["emotes"];
for(var i = 0 ; i < emotes.length ; i++) {
var code = emotes[i]["code"];
var id = emotes[i]["image_id"]
emoteData[code] = id;
}
}
try {
self.getUtils().log("Writing Twitch sub emotes to file");
_fs.writeFile(_dataPath + "/emotes_twitch_sub.json", JSON.stringify(emoteData), "utf8");
}catch(err) { console.log(err); }
self.getUtils().execJs('var subEmotesTwitch = '+JSON.stringify(emoteData)+';');
self.getUtils().sendIcpAsync("loaded-emotedata-twitchsubs");
});
break;
//Twitch sub emotes loaded, load ffz emotes
case 'loaded-emotedata-twitchsubs':
var ffzExists = false;
try {
ffzExists = _fs.existsSync(_dataPath + "/emotes_ffz.json");
}catch(err) { console.log(err); }
if(ffzExists && !_cacheExpired) {
try {
self.getUtils().log("Reading FFZ emotes from file");
var ffzEmotedata = _fs.readFileSync(_dataPath + "/emotes_ffz.json", "utf8");
JSON.parse(ffzEmotedata);
self.getUtils().execJs('var emotesFfz = JSON.parse(\''+ffzEmotedata+'\');');
self.getUtils().sendIcpAsync("loaded-emotedata-ffz");
break;
}catch(err) { console.log(err); }
}
self.getUtils().log("Downloading FFZ emotes");
self.getUtils().updateLoading("Loading Resources(FFZ Emotedata)", 80, 100);
self.getUtils().download(_updater.CDN , "/Jiiks/BetterDiscordApp/"+_hash+"/emotedata_ffz.json", function(emotedata) {
try {
self.getUtils().log("Writing FFZ emotes to file");
_fs.writeFileSync(_dataPath + "/emotes_ffz.json", emotedata, "utf8");
}catch(err) { console.log(err); }
self.getUtils().execJs('var emotesFfz = JSON.parse(\''+emotedata+'\');');
self.getUtils().sendIcpAsync("loaded-emotedata-ffz");
});
break;
//Ffz emotes loaded, load bttv emotes
case 'loaded-emotedata-ffz':
self.getUtils().updateLoading("Loading Resources(BTTV Emotedata)", 85, 100);
var bttvExists = false;
try {
bttvExists = _fs.existsSync(_dataPath + "/emotes_bttv.json");
}catch(err) { console.log(err); }
if(bttvExists && !_cacheExpired) {
try {
self.getUtils().log("Loading BTTV emotes from file");
var bttvEmotedata = _fs.readFileSync(_dataPath + "/emotes_bttv.json", "utf8");
JSON.parse(bttvEmotedata);
self.getUtils().execJs("var emotesBTTV = " + bttvEmotedata + ";");
self.getUtils().sendIcpAsync("loaded-emotedata-bttv");
break;
}catch(err) { console.log(err); }
}
self.getUtils().log("Downloading BTTV emotes");
self.getUtils().download("api.betterttv.net", "/emotes", function(emotedata) {
self.getUtils().updateLoading("Parsing Resource(BTTV Emotedata)", 90, 100);
var emoteData = {};
emotedata = JSON.parse(emotedata);
for(var emote in emotedata.emotes) {
var e = emotedata.emotes[emote];
var url = e.url;
var code = e.regex;
emoteData[code] = url;
}
try {
self.getUtils().log("Writing BTTV emotes to file");
_fs.writeFileSync(_dataPath + "/emotes_bttv.json", JSON.stringify(emoteData), "utf8");
}catch(err) { console.log(err); }
self.getUtils().execJs('var emotesBTTV = '+JSON.stringify(emoteData) +';');
self.getUtils().sendIcpAsync("loaded-emotedata-bttv");
});
break;
//Bttv emotes loaded
case 'loaded-emotedata-bttv':
self.getUtils().sendIcpAsync("start-betterdiscord");
break;
//Start BetterDiscord
case 'start-betterdiscord':
self.getUtils().updateLoading("Starting Up", 100, 100);
self.getUtils().execJs('var mainCore; var startBda = function() { mainCore = new Core(); mainCore.init(); }; startBda();');
//Remove loading node
setTimeout(function() {
self.getUtils().execJs('$("#bd-status").parent().parent().hide();');
}, 2000);
break;
}
});
self.getUtils().execJs('var version = "'+_version+'"');
//Load jQuery
self.getUtils().updateLoading("Loading Resources(jQuery)", 0, 100);
self.getUtils().injectJavaScriptSync("//ajax.googleapis.com/ajax/libs/jquery/2.0.0/jquery.min.js", "loaded-jquery");
});
};
exports.BetterDiscord = BetterDiscord;