From a051aace376492a48c10615106dda222a7136300 Mon Sep 17 00:00:00 2001 From: 1024x2 Date: Thu, 1 Nov 2018 21:16:16 +0000 Subject: new fancy webpack stuff --- src/api.js | 260 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ src/cli.js | 126 ++++++++++++++++++++++++++++ src/install.js | 21 +++++ src/pkg93.js | 62 ++++++++++++++ 4 files changed, 469 insertions(+) create mode 100644 src/api.js create mode 100644 src/cli.js create mode 100644 src/install.js create mode 100644 src/pkg93.js (limited to 'src') diff --git a/src/api.js b/src/api.js new file mode 100644 index 0000000..8acc8e2 --- /dev/null +++ b/src/api.js @@ -0,0 +1,260 @@ +var errbar = "[---------------------------------------------------] ERR! !"; +// thanks robbie! sauce: https://gist.github.com/robbie0630/e1386fb10676598e7d60d4f406a41042 +// NOTE: this is a modified version +var _abarpkg93uses = (width, percent) => { + if (percent > 1) percent = 1; + let barwidth = width - 9; + let ticker = "\\"; + switch (Math.floor(percent * 100) % 4) { + case 1: + ticker = "|"; + break; + case 2: + ticker = "/"; + break; + case 3: + ticker = "-"; + break; + default: + ticker = "\\"; + break; + } + ticker = Math.floor(percent) == 1 ? "✔️" : ticker; + let pbar = "["; + for (let i = 0; i < Math.floor(percent*barwidth); ++i) pbar += "="; + pbar += ""; + for (let i = 0; i < Math.ceil((1-percent)*barwidth); ++i) pbar += "-"; + pbar += "] " + Math.floor(percent * 100) + "% " + ticker.padStart(4 - (percent * 100).toFixed().length); + return pbar; +}; + +var pkg93 = { + getConfig: function() { + try { + return JSON.parse(localStorage[".pkg93/config.json"]); + } catch (err) { + return err; + } + }, + pull: async function(cli) { + cli = cli || {log: (i) => {$log(i);}}; + var config = pkg93.getConfig(); + config.pkglist = []; + return new Promise(async (res, rej) => { + for (let source of config.repos) { + await new Promise(async (reso) => { + try { + cli.log("GET " + source + "/repo.json"); + var bardiv = cli.log(_abarpkg93uses(60, 0)); + var xhr = new XMLHttpRequest(); + xhr.open("GET", source + "/repo.json", true); + xhr.onprogress = e => { + bardiv.innerHTML = _abarpkg93uses(60, e.loaded / e.total); + }; + xhr.onerror = () => { + bardiv.innerHTML = errbar; + cli.log("ERR Fatal error while retriving package.json."); + if (xhr.status != 0) { + cli.log("ERR " + xhr.status + " " + xhr.statusText); + } + }; + xhr.onload = () => { + try { + var json = JSON.parse(xhr.responseText); + cli.log("NAME " + json.name); + cli.log("MSG " + json.msg); + for (let item of json.packages) { + try { + config.pkglist.push(item + "@" + source); + cli.log("OK " + item + "@" + source); + } catch (err) { + cli.log("ERR " + err.message); + } + } + reso(); + } catch (err) { + console.error(err); + cli.log("ERR " + err.message); + rej(); + } + }; + xhr.send(); + } catch (err) { + cli.log("ERR " + err.message); + rej(); + } + }); + } + localStorage[".pkg93/config.json"] = JSON.stringify(config); + res(); + }); + }, + get: async function(pkg, version, cli) { + cli = cli || {log: (i) => {$log(i);}}; + version = version || "latest"; + var config = pkg93.getConfig(); + cli.log("SRCH " + pkg); + var index = config.pkglist.findIndex(function(string) { + return string.split("@")[0] == pkg; + }); + if (index < 0) { + cli.log("ERR Not found."); + return false; + } else { + cli.log("OK Found!"); + var pkgname = config.pkglist[index].split("@")[0]; + var pkgsource = config.pkglist[index].split("@")[1]; + var dest = pkgsource + "/" + pkgname + "/package.json"; + cli.log("GET " + dest); + var bardiv = cli.log(_abarpkg93uses(60, 0)); + var xhr = new XMLHttpRequest(); + xhr.open("GET", dest, true); + xhr.onprogress = e => { + try { + bardiv.innerHTML = _abarpkg93uses(60, e.loaded / e.total); + } catch (err) { + // fail silently + } + }; + return new Promise((res, rej) => { + xhr.onerror = () => { + bardiv.innerHTML = errbar; + cli.log("ERR Fatal error while retriving package.json."); + if (xhr.status == 0) { + cli.log("ERR " + xhr.status + " " + xhr.statusText); + } + rej(); + }; + xhr.onload = () => { + try { + cli.log("DONE " + dest); + var json = JSON.parse(xhr.responseText); + localStorage[".pkg93/packages/" + pkgname + ".json"] = JSON.stringify(json); + if (!json.versions) { + cli.log("WARN This package does not support versioning, using latest\n version instead."); + } else { + version = (version == "latest") ? json.versions[0] : version; + } + var dest2 = pkgsource + "/" + pkgname + "/" + (json.versions ? version + "/" : "") + json.inject; + cli.log("GET " + dest2); + var bardiv2 = cli.log(_abarpkg93uses(60, 0)); + var xhr2 = new XMLHttpRequest(); + xhr2.open("GET", dest2, true); + xhr2.onprogress = e => { + try { + bardiv2.innerHTML = _abarpkg93uses(60, e.loaded / e.total); + } catch (err) { + // fail silently + } + }; + xhr2.onerror = () => { + bardiv2.innerHTML = errbar; + cli.log("ERR Fatal error while retriving " + dest2); + if (xhr2.status != 0) { + cli.log("ERR " + xhr2.status + " " + xhr2.statusText); + } + rej(); + }; + xhr2.onload = async () => { + try { + if (xhr2.status != 200) { + throw new Error("Got status " + xhr2.status + " from server."); + } + cli.log("DONE " + dest2); + var script = xhr2.responseText; + localStorage[".pkg93/packages/" + pkgname + ".js"] = script; + eval(script); + if (json.uninstall) { + // no xhr this time + var uninst = await (await (fetch(pkgsource + "/" + pkgname + "/" + (json.versions ? version + "/" : "") + json.uninstall))).text(); + localStorage[".pkg93/packages/" + pkgname + ".rm.js"] = uninst; + } + if (!config.installed.includes(pkgname)) { + config.installed.push(pkgname); + } + localStorage[".pkg93/config.json"] = JSON.stringify(config); + res(); + // can i go home now + } catch (err) { + cli.log("ERR " + err.message); + rej(err); + } + }; + xhr2.send(); + } catch (err) { + cli.log("ERR " + err.message); + rej(err); + } + }; + try { + xhr.send(); + } catch (err) { + cli.log("ERR " + err.message); + rej(err); + } + }); + } + }, + rm: function(pkg, cli) { + cli = cli || {log: (i) => {$log(i);}}; + var config = pkg93.getConfig(); + var index = config.installed.indexOf(pkg); + if (index < 0) { + cli.log("ERR Not found."); + return false; + } else if (localStorage[".pkg93/packages/" + pkg + ".rm.js"]) { + eval(localStorage[".pkg93/packages/" + pkg + ".rm.js"]); // Typing eval makes me feel dirty. + delete le._apps[config.installed[index]]; + delete localStorage[".pkg93/packages/" + pkg + ".rm.js"]; + delete localStorage[".pkg93/packages/" + pkg + ".js"]; + delete localStorage[".pkg93/packages/" + pkg + ".json"]; + config.installed.splice(index, 1); + cli.log("OK Removed!"); + return true; + } else { + try { + delete le._apps[config.installed[index]]; + delete localStorage[".pkg93/packages/" + config.installed[index] + ".js"]; + delete localStorage[".pkg93/packages/" + config.installed[index] + ".json"]; + config.installed.splice(index, 1); + cli.log("OK Removed!"); + localStorage[".pkg93/config.json"] = JSON.stringify(config); + return true; + } catch (err) { + cli.log("ERR " + err.message); + return false; + } + } + }, + pkgInfo: async function(pkg, onlineOnly) { + var config = pkg93.getConfig(); + try { + if (localStorage[".pkg93/packages/" + pkg + ".json"] && !onlineOnly) { + return JSON.parse(localStorage[".pkg93/packages/" + pkg + ".json"]); + } else { + var index = config.pkglist.findIndex(function(string) { + return string.split("@")[0] == pkg; + }); + if (index < 0) { + return false; + } else { + var pkgname = config.pkglist[index].split("@")[0]; + var pkgsource = config.pkglist[index].split("@")[1]; + var json = await (await (fetch(pkgsource + "/" + pkgname + "/package.json"))).json(); + localStorage[".pkg93/packages/" + pkgname + ".json"] = JSON.stringify(json); // save it for later + return json; + } + } + } catch (err) { + console.error("[pkg93] " + err.stack); + return err; + } + }, + shutUp: { + log: ()=>{}, + arg: {arguments:[]} + }, + version: "v2.0.0beta2" +}; + +export { pkg93 }; diff --git a/src/cli.js b/src/cli.js new file mode 100644 index 0000000..a9e800b --- /dev/null +++ b/src/cli.js @@ -0,0 +1,126 @@ +async function _pkg93execdonotcallplsusetheapi(cli) { + pkg93.version = "v2.0.0beta2"; + var protect = ["3d", "acid", "acidbox", "ansi", "anthology", "arena93", "bananamp", "base64", "bytebeat", "calc", "castlegafa", "catex", "cd", "clear", "clearhist", "clippy", "code", "contact", "crazy", "defrag", "dmg", "do a barrel roll", "doctor", "download", "find", "font", "format", "fullscreen", "fx", "gameoflife", "glitch", "global thermonuclear war", "gravity", "hampster", "hello", "help", "hexed", "history", "hl3", "hydra", "ie6", "iframe", "img", "info", "js", "key", "killall", "layer", "lenna", "lisa", "ls", "manifesto", "marburg", "messenger", "mines", "necronomicoin", "pd", "piskel", "pkg93", "pony", "potato", "progressquest", "pwd", "reboot", "robby", "rotate", "shutdown", "skifree", "solitude", "speech", "starwars", "superplayer", "takethis", "terminal", "textarea", "tree", "trollbox", "vega", "virtualpc", "vm", "wat", "whatif", "whois", "win", "zkype", "peng"]; + var args = cli.arg.arguments; + var help = `pkg93 ${pkg93.version} +Usage: pkg93 [command] + +List of Commands +pull Updates package listing +get [package] Installs a package +rm [package] Uninstalls a package +add-repo [url] Adds a repository +rm-repo [id] Removes a repository +info [pkg] Gets information on a package +ls [pkgs|installed|repos] Lists packages, installed + packages or repositories. + +Color meanings +Executing OK Error Warning Info + +If you find my software useful, consider donating here. +`; + if (localStorage[".pkg93/config.json"] === undefined) { + localStorage[".pkg93/config.json"] = "{\"repos\": [\"https://1024x2.xyz/main-repo\"], \"installed\": [], \"pkglist\": []}"; + } + if (localStorage[".pkg93/packages/"] === undefined) { + localStorage[".pkg93/packages/"] = ""; + } + localStorage[".pkg93/README.txt"] = "WARNING!\nThis folder contains important data about pkg93. Do not edit anything in here unless you want pkg93 to not work!\n\n~1024x2"; + var config = pkg93.getConfig(); + if (args.length === 0) { + cli.log(help); + } else if (args[0] == "pull") { + await pkg93.pull(cli); + } else if (args[0] == "get") { + if (args.length < 2) { + cli.log("ERR No package specified."); + } else if (protect.includes(args[1])) { + cli.log("ERR You're trying to modify a pre-installed Windows93 app.\n Don't do that!"); + } else { + var name = args[1].split("@")[0]; + var version = args[1].split("@")[1]; + await pkg93.get(name, version, cli); + } + } else if (args[0] == "rm") { + if (args.length < 2) { + cli.log("ERR No package specified."); + } else if (protect.includes(args[1])) { + cli.log("ERR You're trying to modify a pre-installed Windows93 app.\n Don't do that!"); + } else { + pkg93.rm(args[1], cli); + } + } else if (args[0] == "add-repo") { + if (args.length < 2) { + cli.log("ERR No repository specified."); + } else { + try { + config.repos.push(args[1]); // well, that was easy + localStorage[".pkg93/config.json"] = JSON.stringify(config); + cli.log("OK Done!\n Run \"pkg93 pull\" to update the package listing."); + } catch (err) { + cli.log("ERR " + err.message); + } + } + } else if (args[0] == "rm-repo") { + if (args.length < 2) { + cli.log("ERR No repository specified."); + } else { + try { + config.repos.splice(parseInt(args[1]), 1); + localStorage[".pkg93/config.json"] = JSON.stringify(config); + cli.log("OK Done!\n Run \"pkg93 pull\" to update the package listing."); + } catch (err) { + cli.log("ERR " + err.message); + } + } + } else if (args[0] == "ls") { + if (args[1] == "pkgs") { + cli.log(config.pkglist.join("\n")); + } else if (args[1] == "installed") { + cli.log(config.installed.join("\n")); + } else if (args[1] == "repos") { + var lerepos = ""; + for (let index in config.repos) { + lerepos += "[" + index + "] " + config.repos[index] + "
"; + } + cli.log(lerepos); + } else { + cli.log("ERR You must select either pkgs, installed, or repos."); + } + } else if (args[0] == "info") { + if (args.length > 2) { + cli.log("ERR No package specified."); + } else { + try { + var pkgInfo = await pkg93.pkgInfo(args[1]); + if (pkgInfo instanceof Error) { + // There's a Error in my pkgInfo! + throw pkgInfo; + } + if (!pkgInfo) { + cli.log("ERR Package not found."); + } else { + var description = pkgInfo.description ? pkgInfo.description : "None!"; + var vers = pkgInfo.versions ? pkgInfo.versions.join(", ") : "None!"; + cli.log(`${args[1]} +Description: ${description} +Versions: ${vers}`); + } + } catch (err) { + cli.log("ERR Error while getting package info.\n" + err.stack); + } + } + } else if (args[0] == "help") { + cli.log(help); + } else if (args[0] == "wtf") { + // for teh lulz + new Audio("/c/sys/sounds/QUACK.ogg").play(); + var wtf = ["mudkipz", "pkg93", "memes", "linux", "javascript", "git", "cpu", "windows93", "discord", "kirb", "apt93", "delays", /* those last 2 go well together */ "trash", "kernel panic", "bash", "package manager", "recusion"]; + cli.log("WTF? " + wtf[Math.floor(Math.random() * wtf.length)] + " + " + wtf[Math.floor(Math.random() * wtf.length)] + " = " + wtf[Math.floor(Math.random() * wtf.length)]); + } else { + cli.log("ERR Invalid command. Type \"pkg93\" without any arguments for help."); + } +} + +export { _pkg93execdonotcallplsusetheapi }; diff --git a/src/install.js b/src/install.js new file mode 100644 index 0000000..cf728d5 --- /dev/null +++ b/src/install.js @@ -0,0 +1,21 @@ +import pkg93code from "!raw-loader!../dist/pkg93.js"; + +$alert({ + msg: "Welcome to teh pkg93 installer, what do you want to do?", + title: "pkg93 installer", + btnOk: "Install/upgrade pkg93", + btnCancel: "Run away", + img: "//cdn.rawgit.com/1024x2/pkg93/70039c02/pkg.png" +}, function(isOK) { + if (isOK) { + var _main = `i=setInterval(()=>{try{if(le){clearInterval(i);${pkg93code}}}catch(err){console.error(err)}},5000);`; + localStorage["boot/pkg93.js"] = _main; + eval(_main); + $alert({ + msg: "pkg93 has installed successfully!", + title: "pkg93 installer", + btnOk: "kthxbai", + img: "//cdn.rawgit.com/1024x2/pkg93/70039c02/pkg.png" + }); + } +}); diff --git a/src/pkg93.js b/src/pkg93.js new file mode 100644 index 0000000..725d447 --- /dev/null +++ b/src/pkg93.js @@ -0,0 +1,62 @@ +import { pkg93 } from "./api.js"; +import { _pkg93execdonotcallplsusetheapi } from "./cli.js"; + +window.pkg93 = pkg93; + +async function wrap(f) { + var originalPrompt = this.cli.prompt.innerHTML; + var originalOnenter = this.cli.onenter; + try { + this.cli.prompt.innerHTML = ""; + this.cli.onenter = () => false; + var lastLog = $log(""); + await f({ + log: (...args) => { + var newLog = $log(...args); + newLog.parentElement.insertBefore(newLog, lastLog.nextSibling); + lastLog = newLog; + return newLog; + }, + arg: this.arg + }); + } catch (err) { + console.error(err); + this.cli.prompt.innerHTML = originalPrompt; + this.cli.onenter = originalOnenter; + } finally { + this.cli.prompt.innerHTML = originalPrompt; + this.cli.onenter = originalOnenter; + } +} + +console.group("[pkg93]"); +console.log("%c[pkg93]%c Injecting packages...", "font-weight:bold", "font-weight:normal"); +try { + if (localStorage[".pkg93/config.json"] === undefined) { + console.log("%c[pkg93]%c You seem new. Creating config...", "font-weight:bold", "font-weight:normal"); + localStorage[".pkg93/config.json"] = `{"repos": ["https://1024x2.xyz/main-repo"], "installed": [], "pkglist": []}`; + } + var config = JSON.parse(localStorage[".pkg93/config.json"]); + for (let pkg of config.installed) { + eval(localStorage[".pkg93/packages/" + pkg + ".js"]); + } +} catch (err) { + console.error("%c[pkg93]%c Couldn't load pkg93!", "font-weight:bold", "font-weight:normal"); + console.error("%c[pkg93]%c %o", "font-weight:bold", "font-weight:normal", err); + $alert({ + title: "Couldn't load pkg93!", + msg: "
" + (err.stack || err.toString()) + "
", + img: "/c/sys/skins/w93/error.png", + icon: "//cdn.rawgit.com/1024x2/pkg93/70039c02/pkg.png" + }); +} +console.log("%c[pkg93]%c Done!", "font-weight:bold", "font-weight:normal"); +console.groupEnd(); + +le._apps.pkg93 = { + exec: function() { wrap.call(this, _pkg93execdonotcallplsusetheapi); }, + icon: "//cdn.rawgit.com/pkg93/pkg93/70039c02/pkg.png", + terminal: true, + hascli: true, + categories: "Network;Utility;Settings;PackageManager" +}; -- cgit v1.2.3