mirror of
https://github.com/azures04/crafatar.git
synced 2026-03-21 23:41:18 +01:00
don't process invalid requests
This commit is contained in:
parent
3fe6be935b
commit
dd9574c19b
@ -1,41 +1,46 @@
|
|||||||
var express = require('express');
|
var express = require('express');
|
||||||
var router = express.Router();
|
var router = express.Router();
|
||||||
var skins = require('../skins');
|
var skins = require('../skins');
|
||||||
var fs = require('fs')
|
var fs = require('fs');
|
||||||
|
|
||||||
|
var valid_uuid = /^[0-9a-f]{32}$/;
|
||||||
|
|
||||||
/* GET home page. */
|
/* GET home page. */
|
||||||
router.get('/:uuid/:size?', function(req, res) {
|
router.get('/:uuid/:size?', function(req, res) {
|
||||||
//res.render('index', { title: 'Express' });
|
//res.render('index', { title: 'Express' });
|
||||||
//res.send("uuid is set to " + req.param("uuid"));
|
//res.send("uuid is set to " + req.param("uuid"));
|
||||||
//console.log(req.param('size'))
|
//console.log(req.param('size'))
|
||||||
var uuid = req.param('uuid')
|
var uuid = req.param('uuid');
|
||||||
var size = req.param('size')
|
var size = req.param('size') || 180;
|
||||||
if (size == null) {
|
console.log(uuid);
|
||||||
size = 180;
|
if (valid_uuid.test(uuid)) {
|
||||||
}
|
var filename = 'skins/' + uuid + ".png";
|
||||||
var filename = 'skins/' + uuid + ".png";
|
if (fs.existsSync(filename)) {
|
||||||
if (fs.existsSync(filename)) {
|
skins.extract_face(filename, size, function() {
|
||||||
skins.extract_face(filename, size, function() {
|
skins.extract_face(filename, size, function(data) {
|
||||||
skins.extract_face(filename, size, function(data) {
|
res.writeHead(200, {'Content-Type': 'image/png'});
|
||||||
res.writeHead(200, {'Content-Type': 'image/png'});
|
res.end(data);
|
||||||
res.end(data);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
skins.get_profile(uuid, function(profile) {
|
|
||||||
var skinurl = skins.skin_url(profile);
|
|
||||||
if (skinurl) {
|
|
||||||
skins.skin_file(skinurl, filename, function() {
|
|
||||||
skins.extract_face(filename, size, function(data) {
|
|
||||||
res.writeHead(200, {'Content-Type': 'image/png'});
|
|
||||||
res.end(data);
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
} else {
|
});
|
||||||
res.status(404) // HTTP status 404: NotFound
|
} else {
|
||||||
.send('404 Not found')
|
skins.get_profile(uuid, function(profile) {
|
||||||
}
|
var skinurl = skins.skin_url(profile);
|
||||||
});
|
if (skinurl) {
|
||||||
|
skins.skin_file(skinurl, filename, function() {
|
||||||
|
skins.extract_face(filename, size, function(data) {
|
||||||
|
res.writeHead(200, {'Content-Type': 'image/png'});
|
||||||
|
res.end(data);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
res.status(404) // HTTP status 404: NotFound
|
||||||
|
.send('404 Not found');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
res.status(422) // "Unprocessable Entity", valid request, but semantically erroneous: https://tools.ietf.org/html/rfc4918#page-78
|
||||||
|
.send("422 Invlid UUID");
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user