mirror of
https://github.com/maierfelix/POGOserver.git
synced 2026-04-25 15:29:09 -05:00
Update
- Updater finally works - Removed two unneeded libs - Updated version
This commit is contained in:
parent
35e4b93974
commit
dce9ecbc37
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "POGOServer",
|
"name": "POGOServer",
|
||||||
"version": "0.2.7",
|
"version": "0.2.8",
|
||||||
"description": "",
|
"description": "",
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
|
|
@ -29,10 +29,9 @@
|
||||||
"pogo-asset-downloader": "^0.2.1",
|
"pogo-asset-downloader": "^0.2.1",
|
||||||
"node-pogo-protos": "^1.3.0",
|
"node-pogo-protos": "^1.3.0",
|
||||||
"path": "^0.12.7",
|
"path": "^0.12.7",
|
||||||
"rimraf": "^2.5.4",
|
|
||||||
"directory-tree": "^1.1.0",
|
"directory-tree": "^1.1.0",
|
||||||
"nodegit": "^0.14.1",
|
"nodegit": "^0.14.1",
|
||||||
"fs-exists-sync": "^0.1.0"
|
"fs-extra": "^0.30.0"
|
||||||
},
|
},
|
||||||
"devDependencies": {}
|
"devDependencies": {}
|
||||||
}
|
}
|
||||||
|
|
@ -2,8 +2,6 @@ import fs from "fs";
|
||||||
|
|
||||||
import * as CFG from "../cfg";
|
import * as CFG from "../cfg";
|
||||||
|
|
||||||
import updater from "../updater";
|
|
||||||
|
|
||||||
const helpMessage = fs.readFileSync(".help", "utf8");
|
const helpMessage = fs.readFileSync(".help", "utf8");
|
||||||
|
|
||||||
export function processCommand(cmd, data) {
|
export function processCommand(cmd, data) {
|
||||||
|
|
@ -41,9 +39,7 @@ export function processCommand(cmd, data) {
|
||||||
this.print(`Saved ${length} player${length === 1 ? "": "s"} into database!`);
|
this.print(`Saved ${length} player${length === 1 ? "": "s"} into database!`);
|
||||||
break;
|
break;
|
||||||
case "/update":
|
case "/update":
|
||||||
updater().then(() => {
|
eval(fs.readFileSync("update.js", "utf8"));
|
||||||
// bla
|
|
||||||
});
|
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
this.print(`${cmd} is not a valid command!`, 31);
|
this.print(`${cmd} is not a valid command!`, 31);
|
||||||
|
|
|
||||||
84
update.js
Normal file
84
update.js
Normal file
|
|
@ -0,0 +1,84 @@
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
var fs = require("fs");
|
||||||
|
var fse = require("fs-extra");
|
||||||
|
var git = require("nodegit");
|
||||||
|
var dirTree = require("directory-tree");
|
||||||
|
|
||||||
|
let tmpDir = "./tmp";
|
||||||
|
let cloneDir = JSON.parse(fs.readFileSync("./package.json")).repository.url;
|
||||||
|
|
||||||
|
let ignore = [".git", "cfg.js", "updater.js"];
|
||||||
|
|
||||||
|
function skip() {
|
||||||
|
return new Promise((resolve) => {
|
||||||
|
fse.removeSync(tmpDir);
|
||||||
|
console.log(`Skipped update to version ${newVersion}`);
|
||||||
|
resolve();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function updateProject() {
|
||||||
|
return new Promise((resolve) => {
|
||||||
|
let newFiles = dirTree("./tmp");
|
||||||
|
recurse(newFiles.children);
|
||||||
|
resolve();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function recurse(parent) {
|
||||||
|
for (let key in parent) {
|
||||||
|
let name = parent[key].name;
|
||||||
|
if (ignore.indexOf(name) > -1) continue;
|
||||||
|
let isDir = parent[key].hasOwnProperty("children");
|
||||||
|
try {
|
||||||
|
if (!isDir) {
|
||||||
|
fse.outputFileSync(parent[key].path.substring(4), fs.readFileSync(parent[key].path));
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
recurse(parent[key].children);
|
||||||
|
}
|
||||||
|
} catch (e) { console.log(e); }
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
(function() {
|
||||||
|
return new Promise((resolve) => {
|
||||||
|
console.log("Preparing to update..");
|
||||||
|
setTimeout(() => {
|
||||||
|
fse.removeSync(tmpDir);
|
||||||
|
let currentVersion = JSON.parse(fs.readFileSync("./package.json")).version;
|
||||||
|
console.log(`Your current version is ${currentVersion}!`);
|
||||||
|
setTimeout(() => {
|
||||||
|
console.log("Fetching latest version..");
|
||||||
|
git.Clone(cloneDir, tmpDir).then((res, rofl) => {
|
||||||
|
let newVersion = null;
|
||||||
|
try {
|
||||||
|
newVersion = JSON.parse(fs.readFileSync(`${tmpDir}/package.json`)).version;
|
||||||
|
} catch (e) {
|
||||||
|
console.log("Version check failed!");
|
||||||
|
return resolve();
|
||||||
|
}
|
||||||
|
if (currentVersion === newVersion) {
|
||||||
|
console.log(`You are already running the latest version ${currentVersion}!`);
|
||||||
|
skip().then(resolve);
|
||||||
|
return void 0;
|
||||||
|
}
|
||||||
|
else if (currentVersion > newVersion) {
|
||||||
|
console.log(`Your version ${currentVersion} is newer than ${newVersion}!`);
|
||||||
|
skip().then(resolve);
|
||||||
|
return void 0;
|
||||||
|
}
|
||||||
|
console.log(`Latest version is ${newVersion}`);
|
||||||
|
console.log(`Updating to version ${newVersion}`);
|
||||||
|
updateProject().then(() => {
|
||||||
|
fse.removeSync(tmpDir);
|
||||||
|
console.log("Update successfully completed, please restart!");
|
||||||
|
resolve();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}, 2e3);
|
||||||
|
|
||||||
|
}, 1e3);
|
||||||
|
});
|
||||||
|
})();
|
||||||
93
updater.js
93
updater.js
|
|
@ -1,93 +0,0 @@
|
||||||
import fs from "fs";
|
|
||||||
import rimraf from "rimraf";
|
|
||||||
import git from "nodegit";
|
|
||||||
import dirTree from "directory-tree";
|
|
||||||
import exists from "fs-exists-sync";
|
|
||||||
|
|
||||||
let tmpDir = "./tmp";
|
|
||||||
let cloneDir = JSON.parse(fs.readFileSync("./package.json")).repository.url;
|
|
||||||
|
|
||||||
let ignore = [".git", "cfg.js"];
|
|
||||||
|
|
||||||
function deleteFolder(path) {
|
|
||||||
return new Promise((resolve) => {
|
|
||||||
try {
|
|
||||||
rimraf(path, (error) => {
|
|
||||||
resolve();
|
|
||||||
});
|
|
||||||
} catch (e) { console.log(e); }
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
function deleteFile(path) {
|
|
||||||
if (exists(path)) {
|
|
||||||
fs.unlinkSync(path);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function skip() {
|
|
||||||
return new Promise((resolve) => {
|
|
||||||
deleteFolder(tmpDir).then(() => {
|
|
||||||
console.log(`Skipped update to version ${newVersion}`);
|
|
||||||
resolve();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
function updateProject() {
|
|
||||||
return new Promise((resolve) => {
|
|
||||||
let newFiles = dirTree("./tmp");
|
|
||||||
// only walk root tree
|
|
||||||
for (let node of newFiles.children) {
|
|
||||||
let name = node.name;
|
|
||||||
if (ignore.indexOf(name) > -1) continue;
|
|
||||||
let isDir = node.hasOwnProperty("children");
|
|
||||||
if (isDir) console.log("Path: ", name);
|
|
||||||
else console.log("File: ", name);
|
|
||||||
if (isDir) deleteFolder(name);
|
|
||||||
else deleteFile(name);
|
|
||||||
};
|
|
||||||
resolve();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
export function update() {
|
|
||||||
return new Promise((resolve) => {
|
|
||||||
console.log("Preparing to update..");
|
|
||||||
setTimeout(() => {
|
|
||||||
deleteFolder(tmpDir).then(() => {
|
|
||||||
let currentVersion = JSON.parse(fs.readFileSync("./package.json")).version;
|
|
||||||
console.log(`Your current version is ${currentVersion}!`);
|
|
||||||
setTimeout(() => {
|
|
||||||
console.log("Fetching latest version..");
|
|
||||||
git.Clone(cloneDir, tmpDir).then((res, rofl) => {
|
|
||||||
let newVersion = null;
|
|
||||||
try {
|
|
||||||
newVersion = JSON.parse(fs.readFileSync(`${tmpDir}/package.json`)).version;
|
|
||||||
} catch (e) {
|
|
||||||
console.log("Version check failed!");
|
|
||||||
return resolve();
|
|
||||||
}
|
|
||||||
if (currentVersion === newVersion) {
|
|
||||||
console.log(`You are already running the latest version ${currentVersion}!`);
|
|
||||||
skip().then(resolve);
|
|
||||||
return void 0;
|
|
||||||
}
|
|
||||||
else if (currentVersion > newVersion) {
|
|
||||||
console.log(`Your version ${currentVersion} is newer than ${newVersion}!`);
|
|
||||||
skip().then(resolve);
|
|
||||||
return void 0;
|
|
||||||
}
|
|
||||||
console.log(`Updating to version ${newVersion}`);
|
|
||||||
updateProject().then(() => {
|
|
||||||
deleteFolder(tmpDir).then(() => {
|
|
||||||
console.log("Update successfully completed, please restart!");
|
|
||||||
resolve();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}, 2e3);
|
|
||||||
});
|
|
||||||
}, 1e3);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
Loading…
Reference in New Issue
Block a user