|  | @@ -12,81 +12,48 @@ var human_status = {
 | 
	
		
			
				|  |  |    "-1": "error"
 | 
	
		
			
				|  |  |  };
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +function handle_default(http_status, img_status, userId, size, def, callback) {
 | 
	
		
			
				|  |  | +  if (def && def !== "steve" && def !== "alex") {
 | 
	
		
			
				|  |  | +    callback(http_status, img_status, def);
 | 
	
		
			
				|  |  | +  } else {
 | 
	
		
			
				|  |  | +    def = def || skins.default_skin(userId);
 | 
	
		
			
				|  |  | +    skins.resize_img("public/images/" + def + ".png", size, function(err, image) {
 | 
	
		
			
				|  |  | +      callback(http_status, img_status, image);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +  }
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  // GET avatar request
 | 
	
		
			
				|  |  | -module.exports = function(req, res) {
 | 
	
		
			
				|  |  | -  var start = new Date();
 | 
	
		
			
				|  |  | +module.exports = function(req, callback) {
 | 
	
		
			
				|  |  |    var userId = (req.url.path_list[2] || "").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");
 | 
	
		
			
				|  |  |    var etag = null;
 | 
	
		
			
				|  |  | -  var rid = req.id;
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -  function sendimage(rid, http_status, img_status, image) {
 | 
	
		
			
				|  |  | -    logging.log(rid, "status:", http_status);
 | 
	
		
			
				|  |  | -    res.writeHead(http_status, {
 | 
	
		
			
				|  |  | -      "Content-Type": "image/png",
 | 
	
		
			
				|  |  | -      "Cache-Control": "max-age=" + config.browser_cache_time + ", public",
 | 
	
		
			
				|  |  | -      "Response-Time": new Date() - start,
 | 
	
		
			
				|  |  | -      "X-Storage-Type": human_status[img_status],
 | 
	
		
			
				|  |  | -      "X-Request-ID": rid,
 | 
	
		
			
				|  |  | -      "Access-Control-Allow-Origin": "*",
 | 
	
		
			
				|  |  | -      "Etag": '"' + etag + '"'
 | 
	
		
			
				|  |  | -    });
 | 
	
		
			
				|  |  | -    res.end(http_status === 304 ? null : image);
 | 
	
		
			
				|  |  | -  }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -  function handle_default(rid, http_status, img_status, userId) {
 | 
	
		
			
				|  |  | -    if (def && def !== "steve" && def !== "alex") {
 | 
	
		
			
				|  |  | -      logging.log(rid, "status: 301");
 | 
	
		
			
				|  |  | -      res.writeHead(301, {
 | 
	
		
			
				|  |  | -        "Cache-Control": "max-age=" + config.browser_cache_time + ", public",
 | 
	
		
			
				|  |  | -        "Response-Time": new Date() - start,
 | 
	
		
			
				|  |  | -        "X-Storage-Type": human_status[img_status],
 | 
	
		
			
				|  |  | -        "X-Request-ID": rid,
 | 
	
		
			
				|  |  | -        "Access-Control-Allow-Origin": "*",
 | 
	
		
			
				|  |  | -        "Location": def
 | 
	
		
			
				|  |  | -      });
 | 
	
		
			
				|  |  | -      res.end();
 | 
	
		
			
				|  |  | -    } else {
 | 
	
		
			
				|  |  | -      def = def || skins.default_skin(userId);
 | 
	
		
			
				|  |  | -      skins.resize_img("public/images/" + def + ".png", size, function(err, image) {
 | 
	
		
			
				|  |  | -        sendimage(rid, http_status, img_status, image);
 | 
	
		
			
				|  |  | -      });
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |    // 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
 | 
	
		
			
				|  |  | -    res.writeHead(422, {
 | 
	
		
			
				|  |  | -      "Content-Type": "text/plain",
 | 
	
		
			
				|  |  | -      "Response-Time": new Date() - start
 | 
	
		
			
				|  |  | -    });
 | 
	
		
			
				|  |  | -    res.end("Invalid Size");
 | 
	
		
			
				|  |  | +    callback(422, 0, "Invalid Size");
 | 
	
		
			
				|  |  |      return;
 | 
	
		
			
				|  |  |    } else if (!helpers.id_valid(userId)) {
 | 
	
		
			
				|  |  | -    res.writeHead(422, {
 | 
	
		
			
				|  |  | -      "Content-Type": "text/plain",
 | 
	
		
			
				|  |  | -      "Response-Time": new Date() - start
 | 
	
		
			
				|  |  | -    });
 | 
	
		
			
				|  |  | -    res.end("Invalid ID");
 | 
	
		
			
				|  |  | +    callback(422, 0, "Invalid ID");
 | 
	
		
			
				|  |  |      return;
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |    // strip dashes
 | 
	
		
			
				|  |  |    userId = userId.replace(/-/g, "");
 | 
	
		
			
				|  |  | -  logging.debug(rid, "userid:", userId);
 | 
	
		
			
				|  |  | +  logging.debug(req.id, "userid:", userId);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |    try {
 | 
	
		
			
				|  |  | -    helpers.get_avatar(rid, userId, helm, size, function(err, status, image, hash) {
 | 
	
		
			
				|  |  | -      logging.log(rid, "storage type:", human_status[status]);
 | 
	
		
			
				|  |  | +    helpers.get_avatar(req.id, userId, helm, size, function(err, status, image, hash) {
 | 
	
		
			
				|  |  | +      logging.log(req.id, "storage type:", human_status[status]);
 | 
	
		
			
				|  |  |        if (err) {
 | 
	
		
			
				|  |  | -        logging.error(rid, err);
 | 
	
		
			
				|  |  | +        logging.error(req.id, err);
 | 
	
		
			
				|  |  |          if (err.code === "ENOENT") {
 | 
	
		
			
				|  |  |            // no such file
 | 
	
		
			
				|  |  | -          cache.remove_hash(rid, userId);
 | 
	
		
			
				|  |  | +          cache.remove_hash(req.id, userId);
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |        }
 | 
	
		
			
				|  |  |        etag = image && hash && hash.substr(0, 32) || "none";
 | 
	
	
		
			
				|  | @@ -96,15 +63,15 @@ module.exports = function(req, res) {
 | 
	
		
			
				|  |  |          if (err) {
 | 
	
		
			
				|  |  |            http_status = 503;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        logging.debug(rid, "etag:", req.headers["if-none-match"]);
 | 
	
		
			
				|  |  | -        logging.debug(rid, "matches:", matches);
 | 
	
		
			
				|  |  | -        sendimage(rid, matches ? 304 : http_status, status, image);
 | 
	
		
			
				|  |  | +        logging.debug(req.id, "etag:", req.headers["if-none-match"]);
 | 
	
		
			
				|  |  | +        logging.debug(req.id, "matches:", matches);
 | 
	
		
			
				|  |  | +        callback(matches ? 304 : http_status, status, image);
 | 
	
		
			
				|  |  |        } else {
 | 
	
		
			
				|  |  | -        handle_default(rid, matches ? 304 : 200, status, userId);
 | 
	
		
			
				|  |  | +        handle_default(matches ? 304 : 200, status, userId, size, def, callback);
 | 
	
		
			
				|  |  |        }
 | 
	
		
			
				|  |  |      });
 | 
	
		
			
				|  |  |    } catch(e) {
 | 
	
		
			
				|  |  | -    logging.error(rid, "error:", e.stack);
 | 
	
		
			
				|  |  | -    handle_default(rid, 500, -1, userId);
 | 
	
		
			
				|  |  | +    logging.error(req.id, "error:", e.stack);
 | 
	
		
			
				|  |  | +    handle_default(500, -1, userId, size, def, callback);
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |  };
 |