helpers.js 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. var networking = require('./networking');
  2. var logging = require('./logging');
  3. var config = require('./config');
  4. var cache = require('./cache');
  5. var skins = require('./skins');
  6. // 0098cb60-fa8e-427c-b299-793cbd302c9a
  7. var valid_uuid = /^([0-9a-f-]{32,36}|[a-zA-Z0-9_]{1,16})$/; // uuid|username
  8. var hash_pattern = /[0-9a-f]+$/;
  9. function get_hash(url) {
  10. return hash_pattern.exec(url)[0].toLowerCase();
  11. }
  12. // requests skin for +uuid+ and extracts face/helm if image hash in +details+ changed
  13. // callback contains error, image hash
  14. function store_images(uuid, details, callback) {
  15. // get skin_url for +uuid+
  16. networking.get_skin_url(uuid, function(err, skin_url) {
  17. if (err) {
  18. callback(err, null);
  19. } else {
  20. if (skin_url) {
  21. logging.log(uuid + " " + skin_url);
  22. // set file paths
  23. var hash = get_hash(skin_url);
  24. if (details && details.hash == hash) {
  25. // hash hasn't changed
  26. logging.log(uuid + " hash has not changed");
  27. cache.update_timestamp(uuid, hash);
  28. callback(null, hash);
  29. } else {
  30. // hash has changed
  31. logging.log(uuid + " new hash: " + hash);
  32. var facepath = __dirname + '/../' + config.faces_dir + hash + ".png";
  33. var helmpath = __dirname + '/../' + config.helms_dir + hash + ".png";
  34. // download skin, extract face/helm
  35. networking.skin_file(skin_url, facepath, helmpath, function(err) {
  36. if (err) {
  37. callback(err, null);
  38. } else {
  39. cache.save_hash(uuid, hash);
  40. callback(null, hash);
  41. }
  42. });
  43. }
  44. } else {
  45. // profile found, but has no skin
  46. cache.save_hash(uuid, null);
  47. callback(null, null);
  48. }
  49. }
  50. });
  51. }
  52. var exp = {};
  53. // returns true if the +uuid+ is a valid uuid or username
  54. // the uuid may be not exist, however
  55. exp.uuid_valid = function(uuid) {
  56. return valid_uuid.test(uuid);
  57. };
  58. // decides whether to get an image from disk or to download it
  59. // callback contains error, status, hash
  60. // the status gives information about how the image was received
  61. // -1: "error"
  62. // 0: "none" - cached as null
  63. // 1: "cached" - found on disk
  64. // 2: "downloaded" - profile downloaded, skin downloaded from mojang servers
  65. // 3: "checked" - profile re-downloaded (was too old), but it has either not changed or has no skin
  66. exp.get_image_hash = function(uuid, callback) {
  67. cache.get_details(uuid, function(err, details) {
  68. if (err) {
  69. callback(err, -1, null);
  70. } else {
  71. if (details && details.time + config.local_cache_time * 1000 >= new Date().getTime()) {
  72. // uuid known + recently updated
  73. logging.log(uuid + " uuid known & recently updated");
  74. callback(null, (details.hash ? 1 : 0), details.hash);
  75. } else {
  76. logging.log(uuid + " uuid not known or too old");
  77. store_images(uuid, details, function(err, hash) {
  78. if (err) {
  79. callback(err, -1, details && details.hash);
  80. } else {
  81. logging.log(uuid + " hash: " + hash);
  82. var oldhash = details && details.hash;
  83. var status = hash !== oldhash ? 2 : 3;
  84. callback(null, status, hash);
  85. }
  86. });
  87. }
  88. }
  89. });
  90. };
  91. // handles requests for +uuid+ images with +size+
  92. // callback contains error, status, image buffer
  93. // image is the user's face+helm when helm is true, or the face otherwise
  94. // for status, see get_image_hash
  95. exp.get_avatar = function(uuid, helm, size, callback) {
  96. logging.log("\nrequest: " + uuid);
  97. exp.get_image_hash(uuid, function(err, status, hash) {
  98. if (hash) {
  99. var filepath = __dirname + '/../' + (helm ? config.helms_dir : config.faces_dir) + hash + ".png";
  100. skins.resize_img(filepath, size, function(img_err, result) {
  101. if (img_err) {
  102. callback(img_err, -1, null);
  103. } else {
  104. // we might have a hash although an error occured
  105. // (e.g. Mojang servers not reachable, using outdated hash)
  106. callback(err, (err ? -1 : status), result);
  107. }
  108. });
  109. } else {
  110. // hash is null when uuid has no skin
  111. callback(err, status, null);
  112. }
  113. });
  114. };
  115. module.exports = exp;