Public API for a society manager application

society-controller.js 4.3KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. var Redis = require("ioredis");
  2. var redis = new Redis();
  3. var permissions_controller = require("./permissions-controller.js");
  4. var user_controller = require("./user-controller.js");
  5. module.exports = {
  6. get_society: function (soc_name, complete) {
  7. redis.hgetall("society:" + soc_name, function (err, result) {
  8. if (result.name) {
  9. result.users = JSON.parse(result.users);
  10. result.admins = JSON.parse(result.admins);
  11. complete({
  12. "society": result,
  13. "error": 0
  14. })
  15. } else {
  16. complete({
  17. "society": {},
  18. "error": 1
  19. })
  20. }
  21. });
  22. },
  23. create_society: function (soc_name, admins, description, auth, complete) {
  24. var society_name = decodeURIComponent(soc_name);
  25. var soc_query = "society:" + society_name;
  26. admins = decodeURIComponent(admins);
  27. description = decodeURIComponent(description);
  28. var admins_str = admins;
  29. admins = JSON.parse(admins);
  30. redis.hget(soc_query, "name", function (err, result) {
  31. if (result) {
  32. complete({"success": 0,
  33. "error": 2});
  34. } else {
  35. redis.get("auth-key:" + auth, function (err,result) {
  36. var username = result;
  37. var user_query = "user:" + username;
  38. var users_exist = true;
  39. if (admins.indexOf(result) !== -1) {
  40. redis.hset(soc_query, "name", society_name);
  41. redis.hset(soc_query, "admins", admins_str);
  42. redis.hset(soc_query, "description", description);
  43. redis.hset(soc_query, "users", admins_str);
  44. admins.map(function (admin_name) {
  45. user_controller.user_exists(admin_name, function (exists) {
  46. if (!exists) {
  47. users_exist = false;
  48. }
  49. });
  50. });
  51. if (users_exist) {
  52. admins.map(function (admin_name) {
  53. redis.hget("user:" + admin_name, "societies", function (err, result) {
  54. if (result) {
  55. redis.hset("user:" + admin_name, "societies", result.concat(society_name));
  56. } else {
  57. redis.hset("user:" + admin_name, "societies", [society_name]);
  58. }
  59. });
  60. });
  61. complete({"success": 1,
  62. "society" : {
  63. "name": society_name,
  64. "admins": admins,
  65. "description": description,
  66. "users": admins
  67. },
  68. "error": 0});
  69. } else {
  70. complete({"success": 0,
  71. "error": 4});
  72. }
  73. } else {
  74. complete({"success": 0,
  75. "error": 3});
  76. }
  77. });
  78. }
  79. });
  80. },
  81. get_user_list: function (soc_name, complete) {
  82. this.get_society(soc_name, function (result) {
  83. if (result.society.name) {
  84. complete(result.society.users);
  85. } else {
  86. complete([]);
  87. }
  88. });
  89. },
  90. get_admin_list: function (soc_name, complete) {
  91. this.get_society(soc_name, function (result) {
  92. if (result.society.name) {
  93. complete(result.society.admins);
  94. } else {
  95. complete([]);
  96. }
  97. })
  98. },
  99. join_society: function (soc_name, auth, complete) {
  100. permissions_controller.user_is_in_society(auth, soc_name, function (user_in_soc) {
  101. if (user_in_soc) {
  102. complete({
  103. "success": 0,
  104. "error": 1
  105. });
  106. } else {
  107. user_controller.get_user_from_auth(auth, function (username) {
  108. user_query = "user:" + username;
  109. redis.hget(user_query, "societies", function (err, result) {
  110. if (result) {
  111. redis.hset(user_query, "societies", result.concat(society_name));
  112. } else {
  113. redis.hset(user_query, "societies", [society_name]);
  114. }
  115. });
  116. redis.hget("society:" + soc_name, "users", function (err, users_result) {
  117. redis.hset("society" + soc_name, users_result.concat(username));
  118. });
  119. });
  120. complete({
  121. "success": 1,
  122. "error": 0
  123. });
  124. }
  125. });
  126. },
  127. leave_society: function (soc_name, auth, complete) {
  128. permissions_controller.user_is_in_society(auth, soc_name, function)
  129. }
  130. }