diff options
author | Minteck <contact@minteck.org> | 2021-12-04 10:58:59 +0100 |
---|---|---|
committer | Minteck <contact@minteck.org> | 2021-12-04 10:58:59 +0100 |
commit | e618c3f52c1c4ae161650679cda24eecbba579bb (patch) | |
tree | a160a9f18847be1be73fb1c2ac2bc25b1e756e27 /server | |
parent | bce13ee94deb2a4914784bb4268dc1d7bc0f11ed (diff) | |
download | rainbow-e618c3f52c1c4ae161650679cda24eecbba579bb.tar.gz rainbow-e618c3f52c1c4ae161650679cda24eecbba579bb.tar.bz2 rainbow-e618c3f52c1c4ae161650679cda24eecbba579bb.zip |
Code is now more cute!
Diffstat (limited to 'server')
-rw-r--r-- | server/gitea.js | 115 | ||||
-rw-r--r-- | server/http.js | 9 |
2 files changed, 8 insertions, 116 deletions
diff --git a/server/gitea.js b/server/gitea.js deleted file mode 100644 index 6b52b72..0000000 --- a/server/gitea.js +++ /dev/null @@ -1,115 +0,0 @@ -global.log = require('./log')
-global.serverRoot = __dirname + "/..";
-global.fs = require('fs')
-log.info("Reading configuration...")
-global.config = require('../global/config.json')
-global.mpws = require('./version');
-
-log.verbose("Initializing Gitea projects refresh...")
-
-function get(url) {
- return {
- stdout: require('child_process').execSync("curl -s -A \"Sattelite/" + mpws.version + "\" -X GET \"https://source.minteck.org/" + url + "\" -H \"accept: application/json\" -H \"authorization: Basic " + fs.readFileSync(serverRoot + "/auth.txt").toString().trim() + "\"")
- };
-}
-
-function giteaRefresh() {
- giteaDataTmp = [];
- repos = [];
-
- log.info("Refreshing Gitea cache...")
-
- orgs_raw = JSON.parse(get("/api/v1/orgs").stdout.toString());
-
- let orgs = [];
- for (let org of orgs_raw) {
- orgs.push(org.username);
- }
-
- log.verbose("Found " + orgs.length + " orgs");
-
- let orgs_mtk = [];
- for (let org of orgs) {
- log.verbose("Gathering members of '" + org + "'...");
- members_raw = JSON.parse(get("/api/v1/orgs/" + org + "/members").stdout.toString());
-
- let members = [];
- for (let member of members_raw) {
- members.push(member.login);
- }
-
- log.verbose("Has " + members.length + " members");
-
- if (members.includes("minteck")) {
- log.verbose("Includes Minteck, adding to list");
- orgs_mtk.push(org);
- } else {
- log.verbose("Doesn't include Minteck, not adding to list");
- }
- }
-
- log.verbose("Minteck part of " + orgs_mtk.length + "/" + orgs.length + " orgs, exclusing themself");
-
- log.verbose("Gathering personal projects");
- personal_raw = JSON.parse(get("/api/v1/users/minteck/repos").stdout.toString());
-
- for (let repo of personal_raw) {
- repos.push(repo.full_name);
- }
-
- for (let org of orgs_mtk) {
- log.verbose("Gathering projects from '" + org + "'");
-
- org_projects_raw = JSON.parse(get("/api/v1/users/" + org + "/repos").stdout.toString());
-
- for (let repo of org_projects_raw) {
- repos.push(repo.full_name);
- }
- }
-
- log.verbose("Found " + repos.length + " projects: " + repos.join(", "));
-
- for (let repo of repos) {
- thisRepo = {};
-
- log.verbose("Gathering info about " + repo);
- repo_data = JSON.parse(get('/api/v1/repos/' + repo).stdout.toString());
-
- if (!repo_data.empty && !repo_data.private && !repo_data.internal && !repo_data.archived && repo_data.full_name !== "minteck/minteck") {
- thisRepo.name = repo_data.full_name.trim() !== "" ? repo_data.full_name : null;
- thisRepo.id = repo_data.full_name.trim() !== "" ? repo_data.full_name : null;
- thisRepo.icon = repo_data.avatar_url.trim() !== "" ? repo_data.avatar_url : null;
- thisRepo.description = repo_data.description.trim() !== "" ? repo_data.description : null;
- thisRepo.size = repo_data.size;
- thisRepo.website = repo_data.website.trim() !== "" ? repo_data.website : null;
- thisRepo.update = new Date(repo_data.updated_at) - 1 + 1;
-
- sattelite_data = JSON.parse(get("/api/v1/repos/" + repo + "/contents/SatteliteGiteaData.txt").stdout.toString());
-
- if (!sattelite_data.documentation_url) {
- thisRepo.name = Buffer.from(sattelite_data.content, "base64").toString();
- }
-
- giteaDataTmp.push(thisRepo);
- }
- }
-
- fs.writeFileSync("../global/gitea.json", JSON.stringify(giteaDataTmp, null, 4));
- log.info("Gitea cache successfully refreshed");
-}
-
-setInterval(() => {
- try {
- giteaRefresh()
- } catch (e) {
- log.error("Gitea projects refresh failed: " + e.message)
- }
-}, 3600000)
-
-setTimeout(() => {
- try {
- giteaRefresh()
- } catch (e) {
- log.error("Gitea projects refresh failed: " + e.message)
- }
-}, 1000)
\ No newline at end of file diff --git a/server/http.js b/server/http.js index c679d95..465b726 100644 --- a/server/http.js +++ b/server/http.js @@ -14,6 +14,8 @@ module.exports.start = function () { http.createServer(function (req, res) { global.res = res; req.url_orig = req.url; + req.url_arg = req.url.split("?")[1]; + req.url = req.url.split("?")[0]; if (req.headers["x-forwarded-for"]) { global.address = req.headers["x-forwarded-for"]; @@ -140,7 +142,12 @@ module.exports.start = function () { 'Set-Cookie': '__mpws_request=' + year + month + day + hour + min + sec }); try { - require('ejs').renderFile(wwwdata + req.url, {wwwdata, private, req, res, slang, lang}, (err, str) => { + if (typeof req.url_arg === "string") { + get = require('querystring').parse(require('url').parse(req.url_orig).query); + } else { + get = {}; + } + require('ejs').renderFile(wwwdata + req.url, {wwwdata, private, req, res, slang, lang, get, fs: require('fs'), child_process: require('child_process')}, (err, str) => { if (err) throw err; res.write(str); res.end(); |