Public API for a society manager application

event-controller.js 11KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336
  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. var society_controller = require("./society-controller.js");
  6. module.exports = {
  7. create_event: function (soc_name, event, auth, complete) {
  8. var self = this;
  9. permissions_controller.user_can_manage_soc_events(auth, soc_name, function (manageable) {
  10. if (manageable) {
  11. user_controller.get_user_from_auth(auth, function(organiser) {
  12. if (event.end > event.start && event.start > Date.now()) {
  13. self.get_random_event_id(function(event_id) {
  14. event_query = "event:" + event_id;
  15. soc_query = "society:" + soc_name.toLowerCase();
  16. self.invite_all(soc_name, event_id);
  17. redis.hset(event_query, "name", event.name);
  18. redis.hset(event_query, "location", event.location);
  19. redis.hset(event_query, "society", soc_name);
  20. redis.hset(event_query, "start", event.start);
  21. redis.hset(event_query, "end", event.end);
  22. redis.hset(event_query, "details", event.details);
  23. redis.hset(event_query, "organiser", organiser);
  24. redis.hset(event_query, "id", event_id);
  25. redis.hget(soc_query, "events", function (err, events) {
  26. redis.hset(soc_query, "events", JSON.stringify(JSON.parse(events).concat(event_id)));
  27. });
  28. complete({
  29. "success": 1,
  30. "event": {
  31. "id": event_id,
  32. "name": event.name,
  33. "organiser": organiser,
  34. "location": event.location,
  35. "society": soc_name,
  36. "start": event.start,
  37. "end": event.end,
  38. "details": event.details
  39. },
  40. "error": 0
  41. })
  42. });
  43. } else {
  44. complete({
  45. "success": 0,
  46. "error": 2
  47. })
  48. }
  49. });
  50. } else {
  51. complete({
  52. "success": 0,
  53. "error": 1
  54. });
  55. }
  56. });
  57. },
  58. invite_all: function (soc_name, event_id) {
  59. society_controller.get_society(soc_name, function (response) {
  60. response.society.users.map(function (user) {
  61. user_controller.get_raw_user(user, function (userdata) {
  62. redis.hset("user:" + user, "pending_events", JSON.stringify(JSON.parse(userdata.pending_events).concat(event_id)));
  63. });
  64. });
  65. });
  66. },
  67. get_event: function (event_id, auth, complete, preauth) {
  68. redis.hgetall("event:" + event_id, function (err, event) {
  69. if (preauth) {
  70. complete({
  71. "event": event,
  72. "error": 0
  73. });
  74. return;
  75. }
  76. permissions_controller.user_is_in_society(auth, event.society, function (canview) {
  77. if (canview) {
  78. complete({
  79. "event": event,
  80. "error": 0
  81. });
  82. } else {
  83. complete({
  84. "event": {},
  85. "error": 1
  86. });
  87. }
  88. });
  89. });
  90. },
  91. get_all_soc_events: function (soc_name, auth, complete) {
  92. var self = this;
  93. permissions_controller.user_is_in_society(auth, soc_name, function (canview) {
  94. if (canview) {
  95. society_controller.get_society(soc_name, function (response) {
  96. var events = response.society.events;
  97. var event_objs = [];
  98. for (var ii = 0; ii < events.length; ii++) {
  99. self.get_event(events[ii], "", function(response) {
  100. event_objs.push(response.event);
  101. if (event_objs.length === events.length) {
  102. complete({
  103. "events": event_objs,
  104. "error": 0
  105. });
  106. }
  107. }, true);
  108. }
  109. });
  110. } else {
  111. complete({
  112. "events": [],
  113. "error": 1
  114. })
  115. }
  116. });
  117. },
  118. get_random_event_id: function (complete) {
  119. var tmp_id = Math.floor(Math.random() * (1000000000-1)+1);
  120. this.event_exists(tmp_id, function (exists) {
  121. if (exists) {
  122. get_random_event_id(complete);
  123. } else {
  124. complete(String(tmp_id));
  125. }
  126. });
  127. },
  128. event_exists: function (event_id, complete) {
  129. redis.hget("event:" + event_id, "name", function (err, result) {
  130. complete(!!result);
  131. });
  132. },
  133. accept_event: function (event_id, auth, complete) {
  134. user_controller.get_user_from_auth(auth, function (username) {
  135. if (username) {
  136. user_controller.get_raw_user(username, function (userdata) {
  137. var pending_events = JSON.parse(userdata.pending_events);
  138. var declined_events = JSON.parse(userdata.declined_events);
  139. var accepted_events = JSON.parse(userdata.accepted_events);
  140. if (pending_events.indexOf(event_id) > -1) {
  141. pending_events.splice(pending_events.indexOf(event_id), 1);
  142. accepted_events.push(event_id);
  143. redis.hset("user:" + username, "pending_events", JSON.stringify(pending_events));
  144. redis.hset("user:" + username, "accepted_events", JSON.stringify(accepted_events));
  145. complete({
  146. "success": 1,
  147. "error": 0
  148. });
  149. } else if (declined_events.indexOf(event_id) > -1) {
  150. declined_events.splice(declined_events.indexOf(event_id), 1);
  151. accepted_events.push(event_id);
  152. redis.hset("user:" + username, "declined_events", JSON.stringify(declined_events));
  153. redis.hset("user:" + username, "accepted_events", JSON.stringify(accepted_events));
  154. complete({
  155. "success": 1,
  156. "error": 0
  157. });
  158. } else {
  159. complete({
  160. "success": 0,
  161. "error": 2
  162. });
  163. }
  164. });
  165. } else {
  166. complete({
  167. "success": 0,
  168. "error": 1
  169. });
  170. }
  171. });
  172. },
  173. decline_event: function (event_id, auth, complete) {
  174. user_controller.get_user_from_auth(auth, function (username) {
  175. if (username) {
  176. user_controller.get_raw_user(username, function (userdata) {
  177. var pending_events = JSON.parse(userdata.pending_events);
  178. var declined_events = JSON.parse(userdata.declined_events);
  179. var accepted_events = JSON.parse(userdata.accepted_events);
  180. if (pending_events.indexOf(event_id) > -1) {
  181. pending_events.splice(pending_events.indexOf(event_id), 1);
  182. declined_events.push(event_id);
  183. redis.hset("user:" + username, "pending_events", JSON.stringify(pending_events));
  184. redis.hset("user:" + username, "declined_events", JSON.stringify(declined_events));
  185. complete({
  186. "success": 1,
  187. "error": 0
  188. });
  189. } else if (accepted_events.indexOf(event_id) > -1) {
  190. accepted_events.splice(accepted_events.indexOf(event_id), 1);
  191. declined_events.push(event_id);
  192. redis.hset("user:" + username, "accepted_events", JSON.stringify(accepted_events));
  193. redis.hset("user:" + username, "declined_events", JSON.stringify(declined_events));
  194. complete({
  195. "success": 1,
  196. "error": 0
  197. });
  198. } else {
  199. complete({
  200. "success": 0,
  201. "error": 2
  202. });
  203. }
  204. });
  205. } else {
  206. complete({
  207. "success": 0,
  208. "error": 1
  209. });
  210. }
  211. });
  212. },
  213. get_all_pending_events: function (auth, complete) {
  214. var self = this;
  215. user_controller.get_user_from_auth(auth, function (username) {
  216. if (username) {
  217. user_controller.get_raw_user(username, function (userdata) {
  218. var pending_events = JSON.parse(userdata.pending_events);
  219. var pending_events_objs = [];
  220. pending_events.map(function (event_id) {
  221. self.get_event(event_id, "", function (response) {
  222. response.event.id = event_id;
  223. pending_events_objs.push(response.event);
  224. if (pending_events_objs.length === pending_events.length) {
  225. pending_events_objs.sort(function (a,b) {
  226. if (a.start < b.start) {
  227. return -1;
  228. }
  229. if (a.start > b.start) {
  230. return 1;
  231. }
  232. return 0;
  233. });
  234. complete({
  235. "pending_events": pending_events_objs,
  236. "error": 0
  237. });
  238. }
  239. }, true);
  240. })
  241. });
  242. } else {
  243. complete({
  244. "pending_events": [],
  245. "error": 1
  246. });
  247. }
  248. });
  249. },
  250. get_all_accepted_events: function (auth, complete) {
  251. var self = this;
  252. user_controller.get_user_from_auth(auth, function (username) {
  253. if (username) {
  254. user_controller.get_public_user_info(username, function (data) {
  255. var accepted_events = data.user.accepted_events;
  256. var accepted_events_objs = [];
  257. accepted_events.map(function (event_id) {
  258. self.get_event(event_id, "", function (response) {
  259. response.event.id = event_id;
  260. accepted_events_objs.push(response.event);
  261. if (accepted_events_objs.length === accepted_events.length) {
  262. accepted_events_objs.sort(function (a,b) {
  263. if (a.start < b.start) {
  264. return -1;
  265. }
  266. if (a.start > b.start) {
  267. return 1;
  268. }
  269. return 0;
  270. });
  271. complete({
  272. "accepted_events": accepted_events_objs,
  273. "error": 0
  274. });
  275. }
  276. }, true);
  277. });
  278. });
  279. } else {
  280. complete({
  281. "accepted_events": [],
  282. "error": 1
  283. });
  284. }
  285. });
  286. },
  287. get_all_declined_events: function (auth, complete) {
  288. var self = this;
  289. user_controller.get_user_from_auth(auth, function (username) {
  290. if (username) {
  291. user_controller.get_public_user_info(username, function (data) {
  292. var declined_events = data.user.declined_events;
  293. var declined_events_objs = [];
  294. declined_events.map(function (event_id) {
  295. self.get_event(event_id, "", function (response) {
  296. response.event.id = event_id;
  297. declined_events_objs.push(response.event);
  298. if (declined_events_objs.length === declined_events.length) {
  299. declined_events_objs.sort(function (a,b) {
  300. if (a.start < b.start) {
  301. return -1;
  302. }
  303. if (a.start > b.start) {
  304. return 1;
  305. }
  306. return 0;
  307. });
  308. complete({
  309. "declined_events": declined_events_objs,
  310. "error": 0
  311. });
  312. }
  313. }, true);
  314. });
  315. });
  316. } else {
  317. complete({
  318. "declined_events": [],
  319. "error": 1
  320. });
  321. }
  322. });
  323. }
  324. }