mirror of https://github.com/clickscodes/nucleus
parent
63fc5e244d
commit
1c83724004
@ -0,0 +1,103 @@
|
|||||||
|
import fs from "fs";
|
||||||
|
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
||||||
|
// @ts-ignore
|
||||||
|
import * as readLine from "node:readline/promises";
|
||||||
|
|
||||||
|
const defaultDict = {
|
||||||
|
"developmentToken": "Your development bot token (Used for testing in one server, rather than production)",
|
||||||
|
"developmentGuildID": "Your development guild ID",
|
||||||
|
"enableDevelopment": true,
|
||||||
|
"token": "Your bot token",
|
||||||
|
"managementGuildID": "Your management guild ID (Used for running management commands on the bot)",
|
||||||
|
"owners": [],
|
||||||
|
"verifySecret": "If using verify, enter a code here which matches the secret sent back by your website. You can use a random code if you do not have one already. (Optional)",
|
||||||
|
"mongoUrl": "Your Mongo connection string, e.g. mongodb://127.0.0.1:27017",
|
||||||
|
"baseUrl": "Your website where buttons such as Verify and Role menu will link to, e.g. https://example.com",
|
||||||
|
"pastebinApiKey": "An API key for pastebin (optional)",
|
||||||
|
"pastebinUsername": "Your pastebin username (optional)",
|
||||||
|
"pastebinPassword": "Your pastebin password (optional)"
|
||||||
|
};
|
||||||
|
|
||||||
|
const readline = readLine.createInterface({
|
||||||
|
input: process.stdin,
|
||||||
|
output: process.stdout
|
||||||
|
});
|
||||||
|
|
||||||
|
async function getInput(prompt: string): Promise<string> {
|
||||||
|
process.stdout.write(prompt);
|
||||||
|
|
||||||
|
const answer = await readline.question(prompt);
|
||||||
|
return answer.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
export default async function(walkthrough = false) {
|
||||||
|
if (walkthrough) {
|
||||||
|
console.log("\x1b[33m🛈 Entering walkthrough mode for any missing values.");
|
||||||
|
console.log(" \x1b[2mIf you don't want to enter a value, just hit enter.\x1b[0m\n");
|
||||||
|
|
||||||
|
// let toUse = await getInput("\x1b[36m[Installing packages] Use Yarn or NPM? \x1b[0m(\x1b[32my\x1b[0m/\x1b[31mN\x1b[0m) > ");
|
||||||
|
// toUse = toUse.toLowerCase() === "y" ? "yarn install" : "npm i";
|
||||||
|
// if ((await getInput(`\x1b[36m[Installing packages] Run ${toUse}? \x1b[0m(\x1b[32mY\x1b[0m/\x1b[31mn\x1b[0m) > `)).toLowerCase() !== "n") {
|
||||||
|
// console.log(`\x1b[32m[Installing packages] Running ${toUse}...\x1b[0m`);
|
||||||
|
// await exec(toUse);
|
||||||
|
// console.log(`\x1b[32m[Installing packages] Installed\x1b[0m`);
|
||||||
|
// } else {
|
||||||
|
// console.log("\x1b[32m[Installing packages] Skipping...\x1b[0m");
|
||||||
|
// }
|
||||||
|
}
|
||||||
|
|
||||||
|
let json;
|
||||||
|
let out = true;
|
||||||
|
try {
|
||||||
|
json = JSON.parse(fs.readFileSync("./src/config/main.json", "utf8"));
|
||||||
|
} catch (e) {
|
||||||
|
console.log("\x1b[31m⚠ No main.json found, creating one.");
|
||||||
|
console.log(" \x1b[2mYou can edit src/config/main.json directly using template written to the file.\x1b[0m\n");
|
||||||
|
out = false;
|
||||||
|
json = {};
|
||||||
|
}
|
||||||
|
for (const key in defaultDict) {
|
||||||
|
if (!json[key]) {
|
||||||
|
if (walkthrough) {
|
||||||
|
switch (key) {
|
||||||
|
case "enableDevelopment": {
|
||||||
|
json[key] = (await getInput("\x1b[36mEnable development mode? This registers commands in a single server making it easier to test\x1b[0m(\x1b[32mY\x1b[0m/\x1b[31mn\x1b[0m) > ") || "Y").toLowerCase() === "y"; break;
|
||||||
|
} case "owners": {
|
||||||
|
let chosen = "!";
|
||||||
|
const toWrite = [];
|
||||||
|
while (chosen !== "") {
|
||||||
|
chosen = await getInput("\x1b[36mEnter an owner ID \x1b[0m(\x1b[35mleave blank to finish\x1b[0m) > ");
|
||||||
|
if (chosen !== "") { toWrite.push(chosen); }
|
||||||
|
}
|
||||||
|
json[key] = toWrite; break;
|
||||||
|
} default: {
|
||||||
|
json[key] = await getInput(`\x1b[36m${key} \x1b[0m(\x1b[35m${defaultDict[key]}\x1b[0m) > `);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else { json[key] = defaultDict[key]; }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (walkthrough && !json.mongoUrl) json.mongoUrl = "mongodb://127.0.0.1:27017";
|
||||||
|
if (!json.mongoUrl.endsWith("/")) json.mongoUrl += "/";
|
||||||
|
if (!json.baseUrl.endsWith("/")) json.baseUrl += "/";
|
||||||
|
let hosts;
|
||||||
|
try {
|
||||||
|
hosts = fs.readFileSync("/etc/hosts", "utf8").toString().split("\n");
|
||||||
|
} catch (e) {
|
||||||
|
return console.log("\x1b[31m⚠ No /etc/hosts found. Please ensure the file exists and is readable. (Windows is not supported, Mac and Linux users should not experience this error)");
|
||||||
|
}
|
||||||
|
let localhost = hosts.find(line => line.split(" ")[1] === "localhost");
|
||||||
|
if (localhost) { localhost = localhost.split(" ")[0]; }
|
||||||
|
else { localhost = "127.0.0.1"; }
|
||||||
|
json.mongoUrl = json.mongoUrl.replace("localhost", localhost);
|
||||||
|
json.baseUrl = json.baseUrl.replace("localhost", localhost);
|
||||||
|
|
||||||
|
fs.writeFileSync("./src/config/main.json", JSON.stringify(json, null, 4));
|
||||||
|
|
||||||
|
if (walkthrough) {
|
||||||
|
console.log("\x1b[32m✓ All properties added.\x1b[0m");
|
||||||
|
}
|
||||||
|
return out;
|
||||||
|
}
|
||||||
Loading…
Reference in new issue