163 lines
4.6 KiB
JavaScript
163 lines
4.6 KiB
JavaScript
const express = require('express');
|
|
const path = require('path');
|
|
const fs = require("fs")
|
|
const timeout = require('connect-timeout')
|
|
let api = true;
|
|
let gdicons = fs.readdirSync('./icons/iconkit')
|
|
const compression = require('compression');
|
|
const app = express();
|
|
app.use(compression());
|
|
app.use(express.json());
|
|
app.use(express.urlencoded({extended: true}));
|
|
app.use(timeout('25s'));
|
|
app.use(haltOnTimedout)
|
|
app.set('json spaces', 2)
|
|
|
|
app.modules = {}
|
|
fs.readdirSync('./api').forEach(x => {
|
|
app.modules[x.split('.')[0]] = require('./api/' + x)
|
|
})
|
|
|
|
app.secret = 'Wmfd2893gb7'
|
|
|
|
const secrets = require("./misc/secretStuff.json")
|
|
app.id = secrets.id
|
|
app.gjp = secrets.gjp
|
|
//these are the only two things in secretStuff.json, both are only used for level leaderboards
|
|
|
|
function haltOnTimedout (req, res, next) {
|
|
if (!req.timedout) next()
|
|
}
|
|
|
|
app.parseResponse = function (responseBody, splitter) {
|
|
if (!responseBody || responseBody == "-1") return {};
|
|
let response = responseBody.split('#')[0].split(splitter || ':');
|
|
let res = {};
|
|
for (let i = 0; i < response.length; i += 2) {
|
|
res[response[i]] = response[i + 1]}
|
|
return res }
|
|
|
|
//xss bad
|
|
app.clean = function(text) {if (typeof text != "string") return text; else return text.replace(/&/g, "&").replace(/</g, "<").replace(/>/g, ">").replace(/=/g, "=").replace(/"/g, """).replace(/'/g, "'")}
|
|
|
|
console.log("Site online!")
|
|
|
|
app.use('/assets', express.static(__dirname + '/assets', {maxAge: "7d"}));
|
|
app.use('/css', express.static(__dirname + '/assets/css'));
|
|
app.use('/objects', express.static(__dirname + '/assets/objects', {maxAge: "7d"}));
|
|
app.use('/blocks', express.static(__dirname + '/assets/blocks', {maxAge: "7d"}));
|
|
app.use('/gauntlets', express.static(__dirname + '/assets/gauntlets', {maxAge: "7d"}));
|
|
app.use('/difficulty', express.static(__dirname + '/assets/gdfaces', {maxAge: "7d"}));
|
|
app.use('/iconkitbuttons', express.static(__dirname + '/assets/iconkitbuttons', {maxAge: "7d"}));
|
|
app.use('/gdicon', express.static(__dirname + '/icons/iconkit', {maxAge: "7d"}));
|
|
|
|
app.get("/api", function(req, res) {
|
|
res.sendFile(__dirname + "/html/api.html")
|
|
})
|
|
|
|
app.get("/gauntlets", function(req, res) {
|
|
res.sendFile(__dirname + "/html/gauntlets.html")
|
|
})
|
|
|
|
app.get("/mappacks", function(req, res) {
|
|
res.sendFile(__dirname + "/html/mappacks.html")
|
|
})
|
|
|
|
app.get("/search", function(req, res) {
|
|
res.sendFile(__dirname + "/html/filters.html")
|
|
})
|
|
|
|
app.get("/leaderboard", function(req, res) {
|
|
res.sendFile(__dirname + "/html/leaderboard.html")
|
|
})
|
|
|
|
app.get("/profile/:id", function(req, res) {
|
|
app.modules.profile(app, req, res)
|
|
})
|
|
|
|
app.get("/comments/:id", function(req, res) {
|
|
res.sendFile(__dirname + "/html/comments.html")
|
|
})
|
|
|
|
app.get("/search/:text", function(req, res) {
|
|
res.sendFile(__dirname + "/html/search.html")
|
|
})
|
|
|
|
app.get("/analyze/:id", async function(req, res) {
|
|
res.sendFile(__dirname + "/html/analyze.html")
|
|
})
|
|
|
|
app.get("/icon/:text", function(req, res) {
|
|
app.modules.icon(app, req, res)
|
|
})
|
|
|
|
app.get("/iconkit/:text", function(req, res) {
|
|
app.modules.icon(app, req, res)
|
|
})
|
|
|
|
app.get("/api/level/:id", async function(req, res) {
|
|
app.modules.level(app, req, res, api)
|
|
})
|
|
|
|
app.get("/api/analyze/:id", async function(req, res) {
|
|
app.modules.level(app, req, res, api, true)
|
|
})
|
|
|
|
app.get("/api/profile/:id", function(req, res) {
|
|
app.modules.profile(app, req, res, api)
|
|
})
|
|
|
|
app.get("/api/comments/:id", function(req, res) {
|
|
app.modules.comments(app, req, res, api)
|
|
})
|
|
|
|
app.get("/api/search/:text", function(req, res) {
|
|
app.modules.search(app, req, res, api)
|
|
})
|
|
|
|
app.get("/api/leaderboardLevel/:id", function(req, res) {
|
|
app.modules.leaderboardLevel(app, req, res, api)
|
|
})
|
|
|
|
app.get("/api/leaderboard", function(req, res, api) {
|
|
if (req.query.hasOwnProperty("accurate")) app.modules.accurateLeaderboard(app, req, res)
|
|
else return app.modules.leaderboard(app, req, res)
|
|
})
|
|
|
|
app.get("/api/mappacks", async function(req, res) {
|
|
res.send(require('./misc/mapPacks.json'))
|
|
})
|
|
|
|
app.get("/api/credits", function(req, res) {
|
|
res.send(require('./misc/credits.json'))
|
|
})
|
|
|
|
app.get("/iconkit", function(req, res) {
|
|
res.sendFile(__dirname + "/html/iconkit.html")
|
|
})
|
|
|
|
app.get("/icon", function(req, res) {
|
|
res.sendFile(__dirname + "/html/iconkit.html")
|
|
})
|
|
|
|
app.get('/api/icons', function(req, res) {
|
|
res.send(gdicons);
|
|
});
|
|
|
|
app.get("/api/:anythingelse", async function(req, res) {
|
|
res.send('-1')
|
|
})
|
|
|
|
app.get("/:id", function(req, res) {
|
|
app.modules.level(app, req, res)
|
|
})
|
|
|
|
app.get("/", function(req, res) {
|
|
res.sendFile(__dirname + "/html/home.html")
|
|
})
|
|
|
|
app.get('*', function(req, res) {
|
|
res.redirect('/search/404%20')
|
|
});
|
|
|
|
app.listen(2000);
|