2017-03-03 19:10:02 +01:00
|
|
|
package org.gcube.dataanalysis.dataminer.poolmanager.rest;
|
|
|
|
|
2017-07-27 15:32:36 +02:00
|
|
|
|
2017-05-09 18:38:15 +02:00
|
|
|
import java.io.IOException;
|
|
|
|
import java.net.MalformedURLException;
|
|
|
|
import java.net.URL;
|
|
|
|
import java.net.UnknownHostException;
|
|
|
|
import java.util.List;
|
|
|
|
import java.util.Set;
|
2017-05-09 17:10:03 +02:00
|
|
|
|
2017-05-12 17:32:14 +02:00
|
|
|
import javax.ws.rs.GET;
|
|
|
|
import javax.ws.rs.Path;
|
|
|
|
import javax.ws.rs.Produces;
|
|
|
|
import javax.ws.rs.QueryParam;
|
|
|
|
|
2017-06-19 18:34:44 +02:00
|
|
|
import org.gcube.common.authorization.client.exceptions.ObjectNotFound;
|
|
|
|
import org.gcube.common.authorization.library.provider.SecurityTokenProvider;
|
|
|
|
import org.gcube.common.scope.api.ScopeProvider;
|
2017-05-12 17:32:14 +02:00
|
|
|
import org.gcube.dataanalysis.dataminer.poolmanager.datamodel.Algorithm;
|
|
|
|
import org.gcube.dataanalysis.dataminer.poolmanager.service.DataminerPoolManager;
|
|
|
|
import org.gcube.dataanalysis.dataminer.poolmanager.util.AlgorithmBuilder;
|
|
|
|
import org.slf4j.Logger;
|
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
import org.tmatesoft.svn.core.SVNException;
|
|
|
|
|
2017-03-03 19:10:02 +01:00
|
|
|
@Path("/")
|
2017-12-20 12:01:01 +01:00
|
|
|
public class RestPoolManager implements PoolManager
|
|
|
|
{
|
2017-07-26 21:21:07 +02:00
|
|
|
//@Context ServletContext context;
|
2017-03-03 19:10:02 +01:00
|
|
|
|
2017-11-08 16:12:38 +01:00
|
|
|
private final Logger logger;
|
|
|
|
private DataminerPoolManager service;
|
2017-07-26 21:21:07 +02:00
|
|
|
|
|
|
|
//@Context
|
2017-09-20 18:51:21 +02:00
|
|
|
//private ApplicationContext context = ContextProvider.get();
|
2017-07-26 21:21:07 +02:00
|
|
|
|
2017-12-20 12:01:01 +01:00
|
|
|
public RestPoolManager()
|
|
|
|
{
|
2017-11-08 16:12:38 +01:00
|
|
|
this.logger = LoggerFactory.getLogger(RestPoolManager.class);
|
|
|
|
this.service = new DataminerPoolManager();
|
|
|
|
|
|
|
|
}
|
2017-07-26 21:21:07 +02:00
|
|
|
|
2017-05-10 11:11:17 +02:00
|
|
|
|
2017-04-06 10:59:46 +02:00
|
|
|
@GET
|
2017-05-09 18:38:15 +02:00
|
|
|
@Path("/algorithm/stage")
|
2017-04-06 10:59:46 +02:00
|
|
|
@Produces("text/plain")
|
2017-05-12 19:11:12 +02:00
|
|
|
public String stageAlgorithm(
|
2017-07-31 13:21:47 +02:00
|
|
|
@QueryParam("algorithmPackageURL") String algorithmPackageURL,
|
2017-08-29 17:43:31 +02:00
|
|
|
@QueryParam("targetVRE") String targetVRE,
|
|
|
|
@QueryParam("category") String category,
|
|
|
|
@QueryParam("algorithm_type") String algorithm_type) throws IOException, InterruptedException {
|
2017-11-08 16:12:38 +01:00
|
|
|
this.logger.debug("Stage algorithm method called");
|
2017-07-26 21:21:07 +02:00
|
|
|
Algorithm algo = AlgorithmBuilder.create(algorithmPackageURL);
|
2017-09-20 18:51:21 +02:00
|
|
|
//String env = context.application().getInitParameter("Environment");
|
|
|
|
return this.service.stageAlgorithm(algo,targetVRE,category,algorithm_type/*,env*/);
|
2017-04-06 10:59:46 +02:00
|
|
|
}
|
2017-05-09 18:38:15 +02:00
|
|
|
|
|
|
|
|
2017-04-06 10:59:46 +02:00
|
|
|
@GET
|
2017-05-09 18:38:15 +02:00
|
|
|
@Path("/algorithm/add")
|
2017-04-06 10:59:46 +02:00
|
|
|
@Produces("text/plain")
|
2017-05-12 19:11:12 +02:00
|
|
|
public String publishAlgorithm(
|
|
|
|
@QueryParam("algorithmPackageURL") String algorithmPackageURL,
|
2017-08-29 17:43:31 +02:00
|
|
|
//@QueryParam("targetVREToken") String targetVREToken,
|
|
|
|
@QueryParam("targetVRE") String targetVRE,
|
|
|
|
@QueryParam("category") String category,
|
|
|
|
@QueryParam("algorithm_type") String algorithm_type) throws IOException, InterruptedException {
|
2017-11-08 16:12:38 +01:00
|
|
|
this.logger.debug("Publish algorithm method called");
|
2017-07-05 17:50:42 +02:00
|
|
|
Algorithm algo = AlgorithmBuilder.create(algorithmPackageURL);
|
2017-09-20 18:51:21 +02:00
|
|
|
//String env = context.application().getInitParameter("Environment");
|
|
|
|
return this.service.publishAlgorithm(algo, /*targetVREToken,*/ targetVRE,category,algorithm_type/*,env*/);
|
2017-04-06 10:59:46 +02:00
|
|
|
}
|
|
|
|
|
2017-05-09 18:38:15 +02:00
|
|
|
/*
|
|
|
|
* /scopes/<scope> POST // add an algorithm to all dataminers in the scope
|
|
|
|
* /hosts/<hostname> POST // add an algorithm to the given host
|
|
|
|
*/
|
2017-04-06 10:59:46 +02:00
|
|
|
|
2017-03-03 19:10:02 +01:00
|
|
|
@GET
|
|
|
|
@Path("/log")
|
|
|
|
@Produces("text/plain")
|
|
|
|
public String getLogById(@QueryParam("logUrl") String logUrl) throws IOException {
|
|
|
|
// TODO Auto-generated method stub
|
2017-11-08 16:12:38 +01:00
|
|
|
this.logger.debug("Get log by id method called");
|
|
|
|
this.logger.debug("Returning Log =" + logUrl);
|
2017-05-12 17:32:14 +02:00
|
|
|
return service.getLogById(logUrl);
|
2017-03-03 19:10:02 +01:00
|
|
|
}
|
|
|
|
|
2017-05-15 18:44:37 +02:00
|
|
|
|
2017-07-13 18:13:18 +02:00
|
|
|
@GET
|
|
|
|
@Path("/monitor")
|
|
|
|
@Produces("text/plain")
|
|
|
|
public String getMonitorById(@QueryParam("logUrl") String logUrl) throws IOException {
|
|
|
|
// TODO Auto-generated method stub
|
2017-11-08 16:12:38 +01:00
|
|
|
this.logger.debug("Get monitor by id method called");
|
|
|
|
this.logger.debug("Returning Log =" + logUrl);
|
2017-07-13 18:13:18 +02:00
|
|
|
return service.getMonitorById(logUrl);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2017-05-15 18:44:37 +02:00
|
|
|
@Override
|
2017-03-03 19:10:02 +01:00
|
|
|
public Algorithm extractAlgorithm(String url) throws IOException {
|
|
|
|
// TODO Auto-generated method stub
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2017-06-19 18:34:44 +02:00
|
|
|
public static void main(String[] args) throws ObjectNotFound, Exception {
|
|
|
|
|
|
|
|
|
2017-06-30 15:49:04 +02:00
|
|
|
// System.out.println(System.getProperty("user.home")+File.separator+"/gcube/dataminer-pool-manager");
|
2017-05-12 17:32:14 +02:00
|
|
|
// // ProxySelector.setDefault(new
|
|
|
|
// // PropertiesBasedProxySelector("/home/ngalante/.proxy-settings"));
|
|
|
|
//
|
2017-07-17 23:52:54 +02:00
|
|
|
// 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");
|
|
|
|
|
|
|
|
|
2017-06-19 18:34:44 +02:00
|
|
|
|
2017-07-06 14:54:04 +02:00
|
|
|
// AuthorizationEntry entry = authorizationService().get("708e7eb8-11a7-4e9a-816b-c9ed7e7e99fe-98187548");
|
|
|
|
// System.out.println(entry.getContext());
|
2017-06-19 18:34:44 +02:00
|
|
|
|
|
|
|
|
2017-07-05 17:50:42 +02:00
|
|
|
RestPoolManager a = new RestPoolManager();
|
2017-06-19 18:34:44 +02:00
|
|
|
|
2017-07-17 23:52:54 +02:00
|
|
|
a.stageAlgorithm("http://data-d.d4science.org/TSt3cUpDTG1teUJMemxpcXplVXYzV1lBelVHTTdsYjlHbWJQNStIS0N6Yz0");
|
2017-05-12 17:32:14 +02:00
|
|
|
// //a.publishAlgorithm("http://data.d4science.org/MnovRjZIdGV5WlB0WXE5NVNaZnRoRVg0SU8xZWpWQlFHbWJQNStIS0N6Yz0", "708e7eb8-11a7-4e9a-816b-c9ed7e7e99fe-98187548","/gcube/devNext/NextNext");
|
|
|
|
// // PoolManager aa = new DataminerPoolManager();
|
|
|
|
//
|
2017-04-06 10:59:46 +02:00
|
|
|
|
|
|
|
}
|
2017-05-12 18:26:58 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//Production Testing
|
|
|
|
/*
|
|
|
|
stageAlgorithm(Rproto caller token,pacchetto, category)
|
2017-05-12 19:11:12 +02:00
|
|
|
http://node2-d-d4s.d4science.org:8080/dataminer-pool-manager-1.0.0-SNAPSHOT/rest/algorithm/stage?gcube-token=3a23bfa4-4dfe-44fc-988f-194b91071dd2-843339462&algorithmPackageURL=http://data.d4science.org/dENQTTMxdjNZcGRpK0NHd2pvU0owMFFzN0VWemw3Zy9HbWJQNStIS0N6Yz0&category=ICHTHYOP_MODEL
|
2017-05-12 18:26:58 +02:00
|
|
|
|
|
|
|
publishAlgorithm(Rproto caller token, pacchetto, category, target token, target prod vre)
|
2017-05-16 16:50:07 +02:00
|
|
|
node2-d-d4s.d4science.org:8080/dataminer-pool-manager-1.0.0-SNAPSHOT/rest/algorithm/add?gcube-token=708e7eb8-11a7-4e9a-816b-c9ed7e7e99fe-98187548&algorithmPackageURL=http://data.d4science.org/dENQTTMxdjNZcGRpK0NHd2pvU0owMFFzN0VWemw3Zy9HbWJQNStIS0N6Yz0&category=ICHTHYOP_MODEL&targetVREToken=3a23bfa4-4dfe-44fc-988f-194b91071dd2-843339462&targetVRE=/d4science.research-infrastructures.eu/gCubeApps/RPrototypingLab
|
2017-05-12 18:26:58 +02:00
|
|
|
|
|
|
|
getLogById(Rproto caller token, logid)
|
2017-05-12 19:11:12 +02:00
|
|
|
http://node2-d-d4s.d4science.org:8080/dataminer-pool-manager-1.0.0-SNAPSHOT/rest/log?gcube-token=3a23bfa4-4dfe-44fc-988f-194b91071dd2-843339462&logUrl=
|
2017-05-12 18:26:58 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
//dev Testing
|
|
|
|
/*
|
2017-05-16 16:50:07 +02:00
|
|
|
stageAlgorithm(dev_caller_vre_token,pacchetto, category)
|
|
|
|
http://node2-d-d4s.d4science.org:8080/dataminer-pool-manager-1.0.0-SNAPSHOT/rest/algorithm/stage?gcube-token=708e7eb8-11a7-4e9a-816b-c9ed7e7e99fe-98187548&algorithmPackageURL=http://data.d4science.org/dENQTTMxdjNZcGRpK0NHd2pvU0owMFFzN0VWemw3Zy9HbWJQNStIS0N6Yz0&category=ICHTHYOP_MODEL
|
2017-05-12 18:26:58 +02:00
|
|
|
|
2017-05-16 16:50:07 +02:00
|
|
|
publishAlgorithm(dev_caller_vre_token, pacchetto, category, target token, target prod vre)
|
|
|
|
http://node2-d-d4s.d4science.org:8080/dataminer-pool-manager-1.0.0-SNAPSHOT/rest/log?gcube-token=708e7eb8-11a7-4e9a-816b-c9ed7e7e99fe-98187548&logUrl=450bb7f9-9e38-4bde-8f4d-f3296f95deba
|
2017-05-12 18:26:58 +02:00
|
|
|
|
2017-05-16 16:50:07 +02:00
|
|
|
getLogById(dev_caller_vre_token, logid)
|
|
|
|
http://node2-d-d4s.d4science.org:8080/dataminer-pool-manager-1.0.0-SNAPSHOT/rest/log?gcube-token=708e7eb8-11a7-4e9a-816b-c9ed7e7e99fe-98187548&logUrl=426c8e35-a624-4710-b612-c90929c32c27 */
|
2017-05-12 18:26:58 +02:00
|
|
|
|
2017-03-29 16:06:46 +02:00
|
|
|
|
2017-03-03 19:10:02 +01:00
|
|
|
@Override
|
|
|
|
public void getLogId(Algorithm algo, String vre) {
|
|
|
|
// TODO Auto-generated method stub
|
|
|
|
|
2017-04-06 10:59:46 +02:00
|
|
|
}
|
2017-03-03 19:10:02 +01:00
|
|
|
|
|
|
|
@Override
|
|
|
|
public String getScriptFromURL(URL logId) throws IOException {
|
|
|
|
// TODO Auto-generated method stub
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2017-04-22 19:24:33 +02:00
|
|
|
|
|
|
|
|
2017-03-03 19:10:02 +01:00
|
|
|
@Override
|
2017-04-22 19:24:33 +02:00
|
|
|
public URL getURLfromWorkerLog(String logUrl) throws MalformedURLException, UnknownHostException {
|
2017-03-03 19:10:02 +01:00
|
|
|
// TODO Auto-generated method stub
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2017-04-06 10:59:46 +02:00
|
|
|
@Override
|
2017-04-22 19:24:33 +02:00
|
|
|
public void addAlgToIs(Algorithm algo) {
|
2017-04-06 10:59:46 +02:00
|
|
|
// TODO Auto-generated method stub
|
2017-04-22 19:24:33 +02:00
|
|
|
|
2017-04-06 10:59:46 +02:00
|
|
|
}
|
2017-03-03 19:10:02 +01:00
|
|
|
|
|
|
|
@Override
|
2017-04-22 19:24:33 +02:00
|
|
|
public Set<Algorithm> getAlgoFromIs() {
|
2017-03-03 19:10:02 +01:00
|
|
|
// TODO Auto-generated method stub
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2017-04-22 19:24:33 +02:00
|
|
|
|
2017-03-29 16:06:46 +02:00
|
|
|
@Override
|
2017-04-22 19:24:33 +02:00
|
|
|
public List<String> updateSVN(String file, List<String> ldep) throws SVNException {
|
2017-03-29 16:06:46 +02:00
|
|
|
// TODO Auto-generated method stub
|
2017-04-22 19:24:33 +02:00
|
|
|
return null;
|
2017-03-29 16:06:46 +02:00
|
|
|
}
|
|
|
|
|
2017-04-22 19:24:33 +02:00
|
|
|
|
2017-03-29 16:06:46 +02:00
|
|
|
@Override
|
2017-05-09 17:10:03 +02:00
|
|
|
public String addAlgorithmToHost(Algorithm algo, String host, boolean test)
|
|
|
|
throws IOException, InterruptedException {
|
2017-03-29 16:06:46 +02:00
|
|
|
// TODO Auto-generated method stub
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2017-04-06 10:59:46 +02:00
|
|
|
|
2017-04-05 17:14:18 +02:00
|
|
|
@Override
|
2017-05-09 17:10:03 +02:00
|
|
|
public String addAlgorithmToVRE(Algorithm algo, String vre, boolean test)
|
2017-04-22 19:24:33 +02:00
|
|
|
throws IOException, InterruptedException {
|
2017-04-05 17:14:18 +02:00
|
|
|
// TODO Auto-generated method stub
|
|
|
|
return null;
|
|
|
|
}
|
2017-05-09 17:10:03 +02:00
|
|
|
|
|
|
|
|
2017-07-31 13:21:47 +02:00
|
|
|
@Override
|
|
|
|
public String stageAlgorithm(String algorithmPackageURL) throws IOException, InterruptedException {
|
|
|
|
// TODO Auto-generated method stub
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-08-29 17:43:31 +02:00
|
|
|
@Override
|
|
|
|
public String publishAlgorithm(String algorithmPackageURL, String targetVREToken, String targetVRE)
|
|
|
|
throws IOException, InterruptedException {
|
|
|
|
// TODO Auto-generated method stub
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2017-07-18 14:58:56 +02:00
|
|
|
|
2017-07-05 17:50:42 +02:00
|
|
|
|
|
|
|
|
2017-05-09 17:10:03 +02:00
|
|
|
|
2017-03-03 19:10:02 +01:00
|
|
|
}
|