aboutsummaryrefslogtreecommitdiff
path: root/hooks/update.js
diff options
context:
space:
mode:
Diffstat (limited to 'hooks/update.js')
-rw-r--r--hooks/update.js222
1 files changed, 121 insertions, 101 deletions
diff --git a/hooks/update.js b/hooks/update.js
index d049d13..e2d4b8a 100644
--- a/hooks/update.js
+++ b/hooks/update.js
@@ -1,102 +1,122 @@
-/*
- * MIT License
- *
- * Copyright (c) 2022- Minteck
- *
- * Permission is hereby granted, free of charge, to any person obtaining a copy
- * of this software and associated documentation files (the "Software"), to deal
- * in the Software without restriction, including without limitation the rights
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- * copies of the Software, and to permit persons to whom the Software is
- * furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in all
- * copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- * SOFTWARE.
- *
- */
-
-module.exports = async () => {
- const spinner = ora("Fetching package lists...").start();
- let list = (await axios.get("https://twipkg.cdn.minteck.org/packages.json")).data;
-
- if (fs.existsSync(home + "/repository")) {
- fs.rmSync(home + "/repository", { recursive: true });
- }
- fs.mkdirSync(home + "/repository");
-
- fs.writeFileSync(home + "/repository/list.json", JSON.stringify(list));
-
- let index = 0;
- for (let pkg of list) {
- spinner.text = "Fetching package lists... " + Math.round((index / list.length) * 100) + "%";
- let dir = pkg.substring(0, 1).replace(/[^a-zA-Z0-9]/gm, "#");
- try {
- let pack = (await axios.get("https://twipkg.cdn.minteck.org/" + dir + "/" + pkg + ".json")).data;
-
- let verdata = (await axios.get(pack.version)).data;
- pack.verdata = {
- latest: verdata.commit.short_id,
- publisher: {
- name: verdata.commit.author_name,
- email: verdata.commit.author_email
- },
- date: verdata.commit.created_at
- }
-
- if (typeof pack.pointrelease === "string") {
- pack.verdata.latest = pack.pointrelease;
- }
-
- let signRaw = { error: "404 Not Found" };
- try {
- signRaw = (await axios.get(pack.signature.replace("{version}", verdata.commit.id))).data;
- } catch (e) {}
- pack.sign = {
- signed: false,
- verified: false,
- key: null,
- signer: {
- name: null,
- email: null
- }
- }
- if (signRaw.error !== "404 Not Found") {
- pack.sign.signed = true;
- if (signRaw.verification_status === "verified") {
- pack.sign.verified = true;
- } else {
- pack.sign.verified = false;
- }
- if (signRaw.gpg_key_user_name) {
- pack.sign.signer.name = signRaw.gpg_key_user_name;
- }
- if (signRaw.gpg_key_user_email) {
- pack.sign.signer.email = signRaw.gpg_key_user_email;
- }
- if (signRaw.gpg_key_primary_keyid) {
- pack.sign.key = signRaw.gpg_key_primary_keyid;
- }
- }
-
- if (!fs.existsSync(home + "/repository/" + dir)) {
- fs.mkdirSync(home + "/repository/" + dir);
- }
- fs.writeFileSync(home + "/repository/" + dir + "/" + pkg + ".json", JSON.stringify(pack));
- } catch (e) {
- console.log("\n" + c.yellow("warn:") + " package '" + pkg + "' is not available on the repository yet");
- }
-
- index++;
- }
-
- spinner.succeed("Fetching package lists... done");
- //process.exit();
+/*
+ * MIT License
+ *
+ * Copyright (c) 2022- Minteck
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
+ * of this software and associated documentation files (the "Software"), to deal
+ * in the Software without restriction, including without limitation the rights
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+ * copies of the Software, and to permit persons to whom the Software is
+ * furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in all
+ * copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+ * SOFTWARE.
+ *
+ */
+
+module.exports = async () => {
+ let oldPercentage = -1;
+ let oldPercTime = new Date();
+ let timePerPerc = -1;
+ let timePerPercData = [];
+ let eta = -1;
+
+ const spinner = ora("Fetching package lists...").start();
+ let list = (await axios.get("https://twipkg.cdn.minteck.org/packages.json")).data;
+
+ if (fs.existsSync(home + "/repository")) {
+ fs.rmSync(home + "/repository", { recursive: true });
+ }
+ fs.mkdirSync(home + "/repository");
+
+ fs.writeFileSync(home + "/repository/list.json", JSON.stringify(list));
+
+ let index = 0;
+ for (let pkg of list) {
+ if ((index / list.length) * 100 !== oldPercentage) {
+ timePerPercData.push(oldPercTime - new Date());
+ timePerPerc = timePerPercData.reduce((x, y) => x + y) / timePerPercData.length;
+ eta = -((timePerPerc * (100 - ((index / list.length) * 100))) / 1000);
+ oldPercTime = new Date();
+ }
+ if (eta > 1) {
+ if (eta > 60) {
+ spinner.text = "Fetching package lists... " + Math.round((index / list.length) * 100) + "%, " + Math.round(eta / 60) + " minute" + (Math.round(eta / 60) > 1 ? "s" : "");
+ } else {
+ spinner.text = "Fetching package lists... " + Math.round((index / list.length) * 100) + "%, " + Math.round(eta) + " second" + (Math.round(eta) > 1 ? "s" : "");
+ }
+ } else {
+ spinner.text = "Fetching package lists... " + Math.round((index / list.length) * 100) + "%";
+ }
+ let dir = pkg.substring(0, 1).replace(/[^a-zA-Z0-9]/gm, "#");
+ try {
+ let pack = (await axios.get("https://twipkg.cdn.minteck.org/" + dir + "/" + pkg + ".json")).data;
+
+ let verdata = (await axios.get(pack.version)).data;
+ pack.verdata = {
+ latest: verdata.commit.short_id,
+ publisher: {
+ name: verdata.commit.author_name,
+ email: verdata.commit.author_email
+ },
+ date: verdata.commit.created_at
+ }
+
+ if (typeof pack.pointrelease === "string") {
+ pack.verdata.latest = pack.pointrelease;
+ }
+
+ let signRaw = { error: "404 Not Found" };
+ try {
+ signRaw = (await axios.get(pack.signature.replace("{version}", verdata.commit.id))).data;
+ } catch (e) {}
+ pack.sign = {
+ signed: false,
+ verified: false,
+ key: null,
+ signer: {
+ name: null,
+ email: null
+ }
+ }
+ if (signRaw.error !== "404 Not Found") {
+ pack.sign.signed = true;
+ if (signRaw.verification_status === "verified") {
+ pack.sign.verified = true;
+ } else {
+ pack.sign.verified = false;
+ }
+ if (signRaw.gpg_key_user_name) {
+ pack.sign.signer.name = signRaw.gpg_key_user_name;
+ }
+ if (signRaw.gpg_key_user_email) {
+ pack.sign.signer.email = signRaw.gpg_key_user_email;
+ }
+ if (signRaw.gpg_key_primary_keyid) {
+ pack.sign.key = signRaw.gpg_key_primary_keyid;
+ }
+ }
+
+ if (!fs.existsSync(home + "/repository/" + dir)) {
+ fs.mkdirSync(home + "/repository/" + dir);
+ }
+ fs.writeFileSync(home + "/repository/" + dir + "/" + pkg + ".json", JSON.stringify(pack));
+ } catch (e) {
+ console.log("\n" + c.yellow("warn:") + " package '" + pkg + "' is not available on the repository yet");
+ }
+
+ index++;
+ }
+
+ spinner.succeed("Fetching package lists... done");
+ //process.exit();
} \ No newline at end of file