diff --git a/index.js b/index.js index 9c8ab8e..9785e2f 100644 --- a/index.js +++ b/index.js @@ -6,6 +6,11 @@ const port = process.env.SERVER_PORT || 3000; app.use(express.json()); app.set("trust proxy", 1); +app.use((req, res, next) => { + console.log(`[${new Date().toLocaleString()}] ${req.ip} ${req.method} ${req.url}`); + next(); +}) + var rateLimits = {}; @@ -14,6 +19,7 @@ app.get("/", (req, res) => { res.sendFile(__dirname + "/static/index.html") }); + app.post("/", async (req, res) => { // Impliment a rate limit of 25 requests per minute const ip = req.ip; @@ -108,6 +114,7 @@ app.post("/", async (req, res) => { try { let response = await fetch("https://assetdelivery.roblox.com/v1/assets/batch", options); let json = await response.json(); + //console.log(JSON.stringify(json, null, 2)); // Build the response object const responses = req.body.data.reduce((acc, item, index) => { const assetId = item; @@ -119,6 +126,14 @@ app.post("/", async (req, res) => { message: codes[errorCode].message, additional: codes[errorCode].description }; + } else if (json[index].assetTypeId !== 3) { + // Return 415, the asset isnt audio + acc[assetId] = { + status: "failure", + code: 415, + message: codes[415].message, + additional: codes[415].description + }; } else { acc[assetId] = { status: "success",