Revision 62369
Added by Argiro Kokogiannaki over 1 year ago
ManagerUtils.java | ||
---|---|---|
8 | 8 |
import java.io.StringReader; |
9 | 9 |
import java.net.HttpURLConnection; |
10 | 10 |
import java.net.URL; |
11 |
import java.util.Arrays; |
|
11 | 12 |
import java.util.List; |
12 | 13 |
|
13 | 14 |
public class ManagerUtils { |
14 | 15 |
private static String registryAPIForManagerEmails; |
15 |
private static String closedRegistryAPIForManagerEmails; |
|
16 |
private static String sessionCookieName; |
|
17 |
private static String sessionCookieDomain; |
|
18 | 16 |
private String id; |
19 | 17 |
private String email; |
20 | 18 |
private String name; |
... | ... | |
56 | 54 |
this.memberSince = memberSince; |
57 | 55 |
} |
58 | 56 |
|
59 |
public static String getSessionCookieName() { |
|
60 |
return sessionCookieName; |
|
61 |
} |
|
62 |
|
|
63 |
public static void setSessionCookieName(String sessionCookieName) { |
|
64 |
ManagerUtils.sessionCookieName = sessionCookieName; |
|
65 |
} |
|
66 |
|
|
67 |
public static String getSessionCookieDomain() { |
|
68 |
return sessionCookieDomain; |
|
69 |
} |
|
70 |
|
|
71 |
public static void setSessionCookieDomain(String sessionCookieDomain) { |
|
72 |
ManagerUtils.sessionCookieDomain = sessionCookieDomain; |
|
73 |
} |
|
74 |
|
|
75 |
public static String getClosedRegistryAPIForManagerEmails() { |
|
76 |
return closedRegistryAPIForManagerEmails; |
|
77 |
} |
|
78 |
|
|
79 |
public static void setClosedRegistryAPIForManagerEmails(String closedRegistryAPIForManagerEmails) { |
|
80 |
ManagerUtils.closedRegistryAPIForManagerEmails = closedRegistryAPIForManagerEmails; |
|
81 |
} |
|
82 |
|
|
83 |
public List<ManagerUtils> getManagersByEmail(String community, String sessionId) { |
|
57 |
public List<ManagerUtils> getManagersByEmail(String community) { |
|
84 | 58 |
String url = registryAPIForManagerEmails.replace("{community}", community); |
85 |
URL obj = null; |
|
86 |
String responseStr = null; |
|
87 |
log.debug("Registry url is " + url); |
|
88 | 59 |
|
89 |
try { |
|
90 |
obj = new URL(url); |
|
91 |
HttpURLConnection con = (HttpURLConnection) obj.openConnection(); |
|
92 |
con.setRequestProperty("Cookie",sessionCookieName + "="+sessionId + "; domain="+ sessionCookieDomain+"; path=/;"); |
|
93 |
log.debug("Get manager emails from registry response code is: " + con.getResponseCode()); |
|
94 |
if (con.getResponseCode() != 200) { |
|
95 |
return null; |
|
96 |
} |
|
97 |
BufferedReader in = new BufferedReader(new InputStreamReader(con.getInputStream())); |
|
98 |
StringBuffer response = new StringBuffer(); |
|
99 |
String inputLine; |
|
100 |
while ((inputLine = in.readLine()) != null) { |
|
101 |
response.append(inputLine).append("\n"); |
|
102 |
} |
|
103 |
in.close(); |
|
104 |
responseStr = response.toString(); |
|
105 |
} catch (Exception e) { |
|
106 |
log.error("An error occured while trying to fetch manager emails from registry ", e); |
|
107 |
return null; |
|
108 |
} |
|
109 |
return json2ManagerUtils(responseStr); |
|
110 |
} |
|
111 |
public List<ManagerUtils> getManagersByEmailNoSession(String community) { |
|
112 |
String url = "http://mpagasas.di.uoa.gr:8080/dnet-role-management/admin/community/"+community+"?name=false"; |
|
113 | 60 |
URL obj = null; |
114 | 61 |
String responseStr = null; |
115 | 62 |
log.debug("Registry url is " + url); |
... | ... | |
162 | 109 |
List<ManagerUtils> managerUtilsList = null; |
163 | 110 |
|
164 | 111 |
try { |
165 |
managersResponse = gson.fromJson(br, ManagersResponse.class);
|
|
166 |
managerUtilsList = managersResponse.getResponse();
|
|
167 |
}catch(Exception e){
|
|
112 |
ManagerUtils[] testCase = gson.fromJson(br, ManagerUtils[].class);
|
|
113 |
managerUtilsList = Arrays.asList(testCase);
|
|
114 |
}catch(Throwable e){
|
|
168 | 115 |
log.debug("Error in parsing json response. Given json is : "+json, e); |
116 |
e.printStackTrace(); |
|
169 | 117 |
return null; |
170 | 118 |
} |
171 | 119 |
|
172 |
log.debug("Original response.........: "+managersResponse.toString());
|
|
120 |
log.debug("Original response.........: "+managerUtilsList.size());
|
|
173 | 121 |
|
174 | 122 |
|
175 | 123 |
|
176 | 124 |
return managerUtilsList; |
177 | 125 |
} |
178 | 126 |
|
179 |
public Boolean isCommunityManager(String communityId, String userMail, String sessionId) {
|
|
180 |
List<ManagerUtils> managerUtils = this.getManagersByEmail(communityId, sessionId);
|
|
127 |
public Boolean isCommunityManager(String communityId, String userMail) { |
|
128 |
List<ManagerUtils> managerUtils = this.getManagersByEmail(communityId); |
|
181 | 129 |
if(managerUtils != null) { |
182 | 130 |
for(ManagerUtils manager : managerUtils) { |
183 | 131 |
if(manager.getEmail() != null && manager.getEmail().equals(userMail)) { |
Also available in: Unified diff
Clean up code use only the method to get managers without session cookie
add more checks if community is enabled for notifications or not