This commit is contained in:
Nunzio Andrea Galante 2017-07-07 12:52:56 +00:00
parent 910857b0bc
commit ae5f8df1a7
2 changed files with 65 additions and 25 deletions

View File

@ -41,6 +41,11 @@
</dependency>
<dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpclient</artifactId>
<version>4.3.4</version>
</dependency>
<dependency>

View File

@ -7,6 +7,10 @@ import java.util.LinkedList;
import java.util.List;
import org.apache.activemq.transport.stomp.Stomp.Headers.Send;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.util.EntityUtils;
import org.gcube.common.authorization.client.exceptions.ObjectNotFound;
import org.gcube.common.authorization.library.AuthorizationEntry;
import org.gcube.common.authorization.library.provider.SecurityTokenProvider;
@ -44,7 +48,7 @@ public class SendMail extends StandardLocalInfraAlgorithm {
// put the sender, the recipients, subject and body of the mail here
subject = URLEncoder.encode(subject, "UTF-8");
body = URLEncoder.encode(body, "UTF-8");
String requestParameters = "&sender=dataminer&recipients=" + this.getAdmins()/*this.username(SecurityTokenProvider.instance.get())*/ + "&subject=" + subject + "&body="
String requestParameters = "&sender=dataminer&recipients=" + this.getAdmins() + "&subject=" + subject + "&body="
+ body;
String response = HttpRequest.sendPostRequest(requestForMessage, requestParameters);
@ -68,30 +72,60 @@ public class SendMail extends StandardLocalInfraAlgorithm {
return entry.getClientInfo().getId();
}
public String retrieveAdminRole() throws Exception {
// public String retrieveAdminRole() throws Exception {
// String serviceAddress = InfraRetrieval.findEmailingSystemAddress(ScopeProvider.instance.get());
//
// if (!serviceAddress.endsWith("/"))
// serviceAddress = serviceAddress + "/";
//
// String requestForMessage = serviceAddress + "2/users/get-usernames-by-global-role";
// requestForMessage = requestForMessage.replace("https://", "http://").replace(":80", "");
// String requestParameters = "&role-name=Administrator" + "&gcube-token=" + SecurityTokenProvider.instance.get();
//
// String response = HttpRequest.sendGetRequest(requestForMessage, requestParameters);
// System.out.println(response.toString());
//
// if (response == null) {
// Exception e = new Exception("Error in querying the recipient");
// throw e;
// }
// return response;
//
// }
public String getAdminRoles() throws Exception{
// discover social gcore endpoint
//GcoreEndpointReader ep = new GcoreEndpointReader(ScopeProvider.instance.get());
String serviceAddress = InfraRetrieval.findEmailingSystemAddress(ScopeProvider.instance.get());
if (!serviceAddress.endsWith("/"))
serviceAddress = serviceAddress + "/";
String requestForMessage = serviceAddress + "2/users/get-usernames-by-global-role";
requestForMessage = requestForMessage.replace("https://", "http://").replace(":80", "");
String requestParameters = "role-name=Administrator" + "&gcube-token=" + SecurityTokenProvider.instance.get();
String response = HttpRequest.sendGetRequest(requestForMessage, requestParameters);
System.out.println(response.toString());
if (response == null) {
Exception e = new Exception("Error in querying the recipient");
throw e;
}
return response;
//String serviceAddress = ep.getResourceEntyName();//"https://socialnetworking1.d4science.org/social-networking-library-ws/rest/";
serviceAddress = serviceAddress.endsWith("/") ? serviceAddress : serviceAddress + "/";
serviceAddress+= "2/users/get-usernames-by-global-role?";
serviceAddress+= "role-name=Administrator" + "&gcube-token=" + SecurityTokenProvider.instance.get();
System.out.println("Url is " + serviceAddress);
CloseableHttpClient client = HttpClientBuilder.create().build();
HttpGet getReq = new HttpGet(serviceAddress);
getReq.setHeader("accept", "application/json");
getReq.setHeader("content-type", "application/json");
System.out.println(EntityUtils.toString(client.execute(getReq).getEntity()));
return EntityUtils.toString(client.execute(getReq).getEntity());
}
public String getAdmins() throws Exception {
List<String> s = new LinkedList<String>();
JSONObject obj = new JSONObject(this.retrieveAdminRole());
JSONObject obj = new JSONObject(this.getAdminRoles());
JSONArray data = obj.getJSONArray("result");
if (data != null) {
String[] names = new String[data.length()];
@ -101,7 +135,6 @@ public class SendMail extends StandardLocalInfraAlgorithm {
}
s.add(this.username(SecurityTokenProvider.instance.get()));
}
return s.toString().replace("[", "").replace("]", "");
}
@ -136,18 +169,20 @@ public class SendMail extends StandardLocalInfraAlgorithm {
}
public static void main(String[] args) throws Exception {
ScopeProvider.instance.set("/d4science.research-infrastructures.eu/gCubeApps/RPrototypingLab");
SecurityTokenProvider.instance.set("3a23bfa4-4dfe-44fc-988f-194b91071dd2-843339462");
ScopeProvider.instance.set("/d4science.research-infrastructures.eu/gCubeApps/RPrototypingLab");
SecurityTokenProvider.instance.set("3a23bfa4-4dfe-44fc-988f-194b91071dd2-843339462");
//ScopeProvider.instance.set("/gcube/devNext");
//SecurityTokenProvider.instance.set("708e7eb8-11a7-4e9a-816b-c9ed7e7e99fe-98187548");
//SecurityTokenProvider.instance.set("aa6eec71-fe07-43ab-bd1c-f03df293e430-98187548");
NotificationHelper nh = new NotificationHelper();
SendMail sm = new SendMail();
sm.sendNotification(nh.getFailedSubject(), nh.getFailedBody("test failed"));
// sm.username(SecurityTokenProvider.instance.get());
// sm.retrieveAdminRole();
//sm.retrieveAdminRole();
//sm.getAdminRoles();
//System.out.println(sm.getAdmins());
//System.out.println(sm.getAdmins());
// sm.sendNotification("test", "test");
}