| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081 | 
							- var logging = require("../logging");
 
- var helpers = require("../helpers");
 
- var config = require("../config");
 
- var skins = require("../skins");
 
- var cache = require("../cache");
 
- var path = require("path");
 
- function handle_default(img_status, userId, size, def, err, callback) {
 
-   if (def && def !== "steve" && def !== "alex") {
 
-     callback({
 
-       status: img_status,
 
-       redirect: def,
 
-       err: err
 
-     });
 
-   } else {
 
-     def = def || skins.default_skin(userId);
 
-     skins.resize_img(path.join(__dirname, "..", "public", "images", def + ".png"), size, function(resize_err, image) {
 
-       callback({
 
-         status: img_status,
 
-         body: image,
 
-         type: "image/png",
 
-         hash: def,
 
-         err: resize_err || err
 
-       });
 
-     });
 
-   }
 
- }
 
- // GET avatar request
 
- module.exports = function(req, callback) {
 
-   var userId = (req.url.path_list[1] || "").split(".")[0];
 
-   var size = parseInt(req.url.query.size) || config.default_size;
 
-   var def = req.url.query.default;
 
-   var helm = req.url.query.hasOwnProperty("helm");
 
-   // Prevent app from crashing/freezing
 
-   if (size < config.min_size || size > config.max_size) {
 
-     // "Unprocessable Entity", valid request, but semantically erroneous:
 
-     // https://tools.ietf.org/html/rfc4918#page-78
 
-     callback({
 
-       status: -2,
 
-       body: "Invalid Size"
 
-     });
 
-     return;
 
-   } else if (!helpers.id_valid(userId)) {
 
-     callback({
 
-       status: -2,
 
-       body: "Invalid userid"
 
-     });
 
-     return;
 
-   }
 
-   // strip dashes
 
-   userId = userId.replace(/-/g, "");
 
-   try {
 
-     helpers.get_avatar(req.id, userId, helm, size, function(err, status, image, hash) {
 
-       if (err) {
 
-         logging.error(req.id, err);
 
-         if (err.code === "ENOENT") {
 
-           // no such file
 
-           cache.remove_hash(req.id, userId);
 
-         }
 
-       }
 
-       if (image) {
 
-         callback({
 
-           status: status,
 
-           body: image,
 
-           type: "image/png",
 
-           err: err,
 
-           hash: hash
 
-         });
 
-       } else {
 
-         handle_default(status, userId, size, def, err, callback);
 
-       }
 
-     });
 
-   } catch(e) {
 
-     logging.error(req.id, "error:", e.stack);
 
-     handle_default(-1, userId, size, def, e, callback);
 
-   }
 
- };
 
 
  |