pineafan | 1c83724 | 2022-08-04 22:04:24 +0100 | [diff] [blame] | 1 | import fs from "fs"; |
pineafan | 1c83724 | 2022-08-04 22:04:24 +0100 | [diff] [blame] | 2 | import * as readLine from "node:readline/promises"; |
| 3 | |
PineaFan | 100df68 | 2023-01-02 13:26:08 +0000 | [diff] [blame] | 4 | const defaultDict: Record<string, string | string[] | boolean> = { |
Skyler Grey | 11236ba | 2022-08-08 21:13:33 +0100 | [diff] [blame] | 5 | developmentToken: "Your development bot token (Used for testing in one server, rather than production)", |
Skyler Grey | 75ea917 | 2022-08-06 10:22:23 +0100 | [diff] [blame] | 6 | developmentGuildID: "Your development guild ID", |
| 7 | enableDevelopment: true, |
| 8 | token: "Your bot token", |
Skyler Grey | 11236ba | 2022-08-08 21:13:33 +0100 | [diff] [blame] | 9 | managementGuildID: "Your management guild ID (Used for running management commands on the bot)", |
Skyler Grey | 75ea917 | 2022-08-06 10:22:23 +0100 | [diff] [blame] | 10 | owners: [], |
PineaFan | 100df68 | 2023-01-02 13:26:08 +0000 | [diff] [blame] | 11 | commandsFolder: "Your built commands folder (usually dist/commands)", |
| 12 | eventsFolder: "Your built events folder (usually dist/events)", |
PineaFan | a00db1b | 2023-01-02 15:32:54 +0000 | [diff] [blame] | 13 | messageContextFolder: "Your built message context folder (usually dist/context/messages)", |
| 14 | userContextFolder: "Your built user context folder (usually dist/context/users)", |
Skyler Grey | 75ea917 | 2022-08-06 10:22:23 +0100 | [diff] [blame] | 15 | verifySecret: |
| 16 | "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)", |
| 17 | mongoUrl: "Your Mongo connection string, e.g. mongodb://127.0.0.1:27017", |
Skyler Grey | 11236ba | 2022-08-08 21:13:33 +0100 | [diff] [blame] | 18 | baseUrl: "Your website where buttons such as Verify and Role menu will link to, e.g. https://example.com", |
Skyler Grey | 75ea917 | 2022-08-06 10:22:23 +0100 | [diff] [blame] | 19 | pastebinApiKey: "An API key for pastebin (optional)", |
| 20 | pastebinUsername: "Your pastebin username (optional)", |
pineafan | 3a02ea3 | 2022-08-11 21:35:04 +0100 | [diff] [blame] | 21 | pastebinPassword: "Your pastebin password (optional)", |
| 22 | rapidApiKey: "Your RapidAPI key (optional), used for Unscan" |
pineafan | 1c83724 | 2022-08-04 22:04:24 +0100 | [diff] [blame] | 23 | }; |
| 24 | |
| 25 | const readline = readLine.createInterface({ |
| 26 | input: process.stdin, |
| 27 | output: process.stdout |
| 28 | }); |
| 29 | |
| 30 | async function getInput(prompt: string): Promise<string> { |
| 31 | process.stdout.write(prompt); |
| 32 | |
| 33 | const answer = await readline.question(prompt); |
| 34 | return answer.toString(); |
| 35 | } |
| 36 | |
Skyler Grey | 75ea917 | 2022-08-06 10:22:23 +0100 | [diff] [blame] | 37 | export default async function (walkthrough = false) { |
pineafan | 1c83724 | 2022-08-04 22:04:24 +0100 | [diff] [blame] | 38 | if (walkthrough) { |
Skyler Grey | 11236ba | 2022-08-08 21:13:33 +0100 | [diff] [blame] | 39 | console.log("\x1b[33m🛈 Entering walkthrough mode for any missing values."); |
| 40 | console.log(" \x1b[2mIf you don't want to enter a value, just hit enter.\x1b[0m\n"); |
pineafan | 1c83724 | 2022-08-04 22:04:24 +0100 | [diff] [blame] | 41 | |
| 42 | // let toUse = await getInput("\x1b[36m[Installing packages] Use Yarn or NPM? \x1b[0m(\x1b[32my\x1b[0m/\x1b[31mN\x1b[0m) > "); |
| 43 | // toUse = toUse.toLowerCase() === "y" ? "yarn install" : "npm i"; |
| 44 | // if ((await getInput(`\x1b[36m[Installing packages] Run ${toUse}? \x1b[0m(\x1b[32mY\x1b[0m/\x1b[31mn\x1b[0m) > `)).toLowerCase() !== "n") { |
| 45 | // console.log(`\x1b[32m[Installing packages] Running ${toUse}...\x1b[0m`); |
| 46 | // await exec(toUse); |
| 47 | // console.log(`\x1b[32m[Installing packages] Installed\x1b[0m`); |
| 48 | // } else { |
| 49 | // console.log("\x1b[32m[Installing packages] Skipping...\x1b[0m"); |
| 50 | // } |
| 51 | } |
| 52 | |
| 53 | let json; |
| 54 | let out = true; |
| 55 | try { |
| 56 | json = JSON.parse(fs.readFileSync("./src/config/main.json", "utf8")); |
| 57 | } catch (e) { |
| 58 | console.log("\x1b[31mâš No main.json found, creating one."); |
Skyler Grey | 11236ba | 2022-08-08 21:13:33 +0100 | [diff] [blame] | 59 | console.log(" \x1b[2mYou can edit src/config/main.json directly using template written to the file.\x1b[0m\n"); |
pineafan | 1c83724 | 2022-08-04 22:04:24 +0100 | [diff] [blame] | 60 | out = false; |
| 61 | json = {}; |
| 62 | } |
| 63 | for (const key in defaultDict) { |
| 64 | if (!json[key]) { |
| 65 | if (walkthrough) { |
| 66 | switch (key) { |
Skyler Grey | 75ea917 | 2022-08-06 10:22:23 +0100 | [diff] [blame] | 67 | case "enableDevelopment": { |
| 68 | json[key] = |
| 69 | ( |
| 70 | (await getInput( |
| 71 | "\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) > " |
| 72 | )) || "Y" |
| 73 | ).toLowerCase() === "y"; |
| 74 | break; |
pineafan | 1c83724 | 2022-08-04 22:04:24 +0100 | [diff] [blame] | 75 | } |
Skyler Grey | 75ea917 | 2022-08-06 10:22:23 +0100 | [diff] [blame] | 76 | case "owners": { |
| 77 | let chosen = "!"; |
| 78 | const toWrite = []; |
| 79 | while (chosen !== "") { |
| 80 | chosen = await getInput( |
| 81 | "\x1b[36mEnter an owner ID \x1b[0m(\x1b[35mleave blank to finish\x1b[0m) > " |
| 82 | ); |
| 83 | if (chosen !== "") { |
| 84 | toWrite.push(chosen); |
| 85 | } |
| 86 | } |
| 87 | json[key] = toWrite; |
| 88 | break; |
| 89 | } |
| 90 | default: { |
Skyler Grey | 11236ba | 2022-08-08 21:13:33 +0100 | [diff] [blame] | 91 | json[key] = await getInput(`\x1b[36m${key} \x1b[0m(\x1b[35m${defaultDict[key]}\x1b[0m) > `); |
Skyler Grey | 75ea917 | 2022-08-06 10:22:23 +0100 | [diff] [blame] | 92 | } |
pineafan | 1c83724 | 2022-08-04 22:04:24 +0100 | [diff] [blame] | 93 | } |
Skyler Grey | 75ea917 | 2022-08-06 10:22:23 +0100 | [diff] [blame] | 94 | } else { |
| 95 | json[key] = defaultDict[key]; |
pineafan | 1c83724 | 2022-08-04 22:04:24 +0100 | [diff] [blame] | 96 | } |
pineafan | 1c83724 | 2022-08-04 22:04:24 +0100 | [diff] [blame] | 97 | } |
| 98 | } |
Skyler Grey | 11236ba | 2022-08-08 21:13:33 +0100 | [diff] [blame] | 99 | if (walkthrough && !json.mongoUrl) json.mongoUrl = "mongodb://127.0.0.1:27017"; |
pineafan | 1c83724 | 2022-08-04 22:04:24 +0100 | [diff] [blame] | 100 | if (!json.mongoUrl.endsWith("/")) json.mongoUrl += "/"; |
| 101 | if (!json.baseUrl.endsWith("/")) json.baseUrl += "/"; |
| 102 | let hosts; |
| 103 | try { |
| 104 | hosts = fs.readFileSync("/etc/hosts", "utf8").toString().split("\n"); |
| 105 | } catch (e) { |
Skyler Grey | 75ea917 | 2022-08-06 10:22:23 +0100 | [diff] [blame] | 106 | return console.log( |
| 107 | "\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)" |
| 108 | ); |
pineafan | 1c83724 | 2022-08-04 22:04:24 +0100 | [diff] [blame] | 109 | } |
Skyler Grey | 75ea917 | 2022-08-06 10:22:23 +0100 | [diff] [blame] | 110 | let localhost = hosts.find((line) => line.split(" ")[1] === "localhost"); |
| 111 | if (localhost) { |
| 112 | localhost = localhost.split(" ")[0]; |
| 113 | } else { |
| 114 | localhost = "127.0.0.1"; |
| 115 | } |
pineafan | 1c83724 | 2022-08-04 22:04:24 +0100 | [diff] [blame] | 116 | json.mongoUrl = json.mongoUrl.replace("localhost", localhost); |
| 117 | json.baseUrl = json.baseUrl.replace("localhost", localhost); |
| 118 | |
| 119 | fs.writeFileSync("./src/config/main.json", JSON.stringify(json, null, 4)); |
| 120 | |
| 121 | if (walkthrough) { |
| 122 | console.log("\x1b[32m✓ All properties added.\x1b[0m"); |
| 123 | } |
| 124 | return out; |
| 125 | } |