|
|
@@ -1,5 +1,7 @@
|
|
1
|
1
|
var Redis = require("ioredis");
|
|
2
|
2
|
var redis = new Redis();
|
|
|
3
|
+var permissions_controller = require("./permissions-controller.js");
|
|
|
4
|
+var user_controller = require("./user-controller.js");
|
|
3
|
5
|
|
|
4
|
6
|
module.exports = {
|
|
5
|
7
|
get_society: function (soc_name, complete) {
|
|
|
@@ -31,26 +33,50 @@ module.exports = {
|
|
31
|
33
|
redis.hget(soc_query, "name", function (err, result) {
|
|
32
|
34
|
if (result) {
|
|
33
|
35
|
complete({"success": 0,
|
|
34
|
|
- "error": 2});
|
|
|
36
|
+ "error": 2});
|
|
35
|
37
|
} else {
|
|
36
|
38
|
redis.get("auth-key:" + auth, function (err,result) {
|
|
37
|
39
|
var username = result;
|
|
|
40
|
+ var user_query = "user:" + username;
|
|
|
41
|
+ var users_exist = true;
|
|
38
|
42
|
if (admins.indexOf(result) !== -1) {
|
|
39
|
43
|
redis.hset(soc_query, "name", society_name);
|
|
40
|
44
|
redis.hset(soc_query, "admins", admins_str);
|
|
41
|
45
|
redis.hset(soc_query, "description", description);
|
|
42
|
46
|
redis.hset(soc_query, "users", admins_str);
|
|
43
|
|
- complete({"success": 1,
|
|
44
|
|
- "society" : {
|
|
45
|
|
- "name": society_name,
|
|
46
|
|
- "admins": admins,
|
|
47
|
|
- "description": description,
|
|
48
|
|
- "users": admins
|
|
49
|
|
- },
|
|
50
|
|
- "error": 0});
|
|
|
47
|
+ admins.map(function (admin_name) {
|
|
|
48
|
+ user_controller.user_exists(admin_name, function (exists) {
|
|
|
49
|
+ if (!exists) {
|
|
|
50
|
+ users_exist = false;
|
|
|
51
|
+ }
|
|
|
52
|
+ });
|
|
|
53
|
+ });
|
|
|
54
|
+ if (users_exist) {
|
|
|
55
|
+ admins.map(function (admin_name) {
|
|
|
56
|
+ redis.hget("user:" + admin_name, "societies", function (err, result) {
|
|
|
57
|
+ if (result) {
|
|
|
58
|
+ redis.hset("user:" + admin_name, "societies", result.concat(society_name));
|
|
|
59
|
+ } else {
|
|
|
60
|
+ redis.hset("user:" + admin_name, "societies", [society_name]);
|
|
|
61
|
+ }
|
|
|
62
|
+ });
|
|
|
63
|
+ });
|
|
|
64
|
+ complete({"success": 1,
|
|
|
65
|
+ "society" : {
|
|
|
66
|
+ "name": society_name,
|
|
|
67
|
+ "admins": admins,
|
|
|
68
|
+ "description": description,
|
|
|
69
|
+ "users": admins
|
|
|
70
|
+ },
|
|
|
71
|
+ "error": 0});
|
|
|
72
|
+
|
|
|
73
|
+ } else {
|
|
|
74
|
+ complete({"success": 0,
|
|
|
75
|
+ "error": 4});
|
|
|
76
|
+ }
|
|
51
|
77
|
} else {
|
|
52
|
78
|
complete({"success": 0,
|
|
53
|
|
- "error": 3});
|
|
|
79
|
+ "error": 3});
|
|
54
|
80
|
}
|
|
55
|
81
|
});
|
|
56
|
82
|
}
|
|
|
@@ -78,10 +104,35 @@ module.exports = {
|
|
78
|
104
|
},
|
|
79
|
105
|
|
|
80
|
106
|
join_society: function (soc_name, auth, complete) {
|
|
81
|
|
-
|
|
|
107
|
+ permissions_controller.user_is_in_society(auth, soc_name, function (user_in_soc) {
|
|
|
108
|
+ if (user_in_soc) {
|
|
|
109
|
+ complete({
|
|
|
110
|
+ "success": 0,
|
|
|
111
|
+ "error": 1
|
|
|
112
|
+ });
|
|
|
113
|
+ } else {
|
|
|
114
|
+ user_controller.get_user_from_auth(auth, function (username) {
|
|
|
115
|
+ user_query = "user:" + username;
|
|
|
116
|
+ redis.hget(user_query, "societies", function (err, result) {
|
|
|
117
|
+ if (result) {
|
|
|
118
|
+ redis.hset(user_query, "societies", result.concat(society_name));
|
|
|
119
|
+ } else {
|
|
|
120
|
+ redis.hset(user_query, "societies", [society_name]);
|
|
|
121
|
+ }
|
|
|
122
|
+ });
|
|
|
123
|
+ redis.hget("society:" + soc_name, "users", function (err, users_result) {
|
|
|
124
|
+ redis.hset("society" + soc_name, users_result.concat(username));
|
|
|
125
|
+ });
|
|
|
126
|
+ });
|
|
|
127
|
+ complete({
|
|
|
128
|
+ "success": 1,
|
|
|
129
|
+ "error": 0
|
|
|
130
|
+ });
|
|
|
131
|
+ }
|
|
|
132
|
+ });
|
|
82
|
133
|
},
|
|
83
|
134
|
|
|
84
|
135
|
leave_society: function (soc_name, auth, complete) {
|
|
85
|
|
-
|
|
|
136
|
+ permissions_controller.user_is_in_society(auth, soc_name, function)
|
|
86
|
137
|
}
|
|
87
|
138
|
}
|