git-svn-id: https://svn.d4science.research-infrastructures.eu/gcube/trunk/data-analysis/dataminer-pool-manager@151222 82a268e6-3cf1-43bd-a215-b396298e98cf
This commit is contained in:
parent
23f461784b
commit
b4e78ca39a
|
@ -1,11 +1,18 @@
|
|||
package org.gcube.dataanalysis.dataminer.poolmanager.service;
|
||||
|
||||
import java.io.File;
|
||||
import java.io.FileNotFoundException;
|
||||
import java.io.PrintWriter;
|
||||
import java.io.UnsupportedEncodingException;
|
||||
|
||||
import org.gcube.common.authorization.library.provider.SecurityTokenProvider;
|
||||
import org.gcube.common.scope.api.ScopeProvider;
|
||||
import org.gcube.dataanalysis.dataminer.poolmanager.datamodel.Algorithm;
|
||||
import org.gcube.dataanalysis.dataminer.poolmanager.datamodel.Cluster;
|
||||
import org.gcube.dataanalysis.dataminer.poolmanager.util.CheckPermission;
|
||||
import org.gcube.dataanalysis.dataminer.poolmanager.util.NotificationHelper;
|
||||
import org.gcube.dataanalysis.dataminer.poolmanager.util.SVNUpdater;
|
||||
import org.gcube.dataanalysis.dataminer.poolmanager.util.SendMail;
|
||||
|
||||
public class ProductionPublishingJob extends DMPMJob {
|
||||
|
||||
|
@ -14,23 +21,30 @@ public class ProductionPublishingJob extends DMPMJob {
|
|||
private String targetVREName;
|
||||
private String targetVREToken;
|
||||
|
||||
public ProductionPublishingJob(SVNUpdater svnUpdater, Algorithm algorithm, /*Cluster prodCluster,*/ String targetVREName, String targetVREToken) {
|
||||
public ProductionPublishingJob(SVNUpdater svnUpdater, Algorithm algorithm, /*Cluster prodCluster,*/ String targetVREName, String targetVREToken) throws FileNotFoundException, UnsupportedEncodingException {
|
||||
super(svnUpdater);
|
||||
this.algorithm = algorithm;
|
||||
//this.prodCluster = prodCluster;
|
||||
this.targetVREName = targetVREName;
|
||||
this.targetVREToken = targetVREToken;
|
||||
|
||||
|
||||
this.jobLogs = new File(System.getProperty("user.home") + File.separator + "dataminer-pool-manager" + File.separator + "jobs");
|
||||
this.jobLogs.mkdirs();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void execute() {
|
||||
SendMail sm = new SendMail();
|
||||
NotificationHelper nh = new NotificationHelper();
|
||||
try {
|
||||
|
||||
if (CheckPermission.apply(targetVREToken,targetVREName)){
|
||||
|
||||
//this.svnUpdater.updateProdDeps(this.algorithm);
|
||||
|
||||
this.svnUpdater.updateSVNProdAlgorithmList(this.algorithm, this.targetVREName, this.algorithm.getFullname(), "Prod");
|
||||
this.getStatus(9);
|
||||
sm.sendNotification(nh.getSuccessSubjectRelease() + " for "+this.algorithm.getName()+ " algorithm", nh.getSuccessBodyRelease(this.buildInfo()));
|
||||
|
||||
}
|
||||
|
||||
|
@ -43,5 +57,34 @@ public class ProductionPublishingJob extends DMPMJob {
|
|||
}
|
||||
|
||||
|
||||
public String getStatus(int exitstatus) throws FileNotFoundException, UnsupportedEncodingException {
|
||||
|
||||
File m = new File(this.jobLogs + File.separator + this.id);
|
||||
PrintWriter writer = new PrintWriter(m, "UTF-8");
|
||||
|
||||
String response = "";
|
||||
|
||||
if (exitstatus == 9) {
|
||||
response = "SVN REPOSITORY CORRECTLY UPDATED; THE CRON JOB WILL INSTALL THE ALGORITHM "+ this.algorithm.getName() + " IN THE VRE" + targetVREName;
|
||||
writer.println(response);
|
||||
writer.close();
|
||||
}
|
||||
|
||||
return response;
|
||||
}
|
||||
|
||||
|
||||
public String buildInfo(){
|
||||
return
|
||||
"\n"+
|
||||
"\n"+
|
||||
"User: "+this.algorithm.getFullname()+"\n"+
|
||||
"Algorithm name: "+this.algorithm.getName()+"\n"+
|
||||
"Caller VRE: "+ScopeProvider.instance.get()+"\n"+
|
||||
"Target VRE: "+ targetVREToken;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
}
|
||||
|
|
|
@ -66,7 +66,7 @@ public class StagingJob extends DMPMJob {
|
|||
message += "\n" + n;
|
||||
}
|
||||
|
||||
sm.sendNotification(nh.getFailedSubject(), nh.getFailedBody(message));
|
||||
sm.sendNotification(nh.getFailedSubject() +" for "+this.algorithm.getName()+ " algorithm", nh.getFailedBody(this.buildInfo()+message));
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -75,7 +75,7 @@ public class StagingJob extends DMPMJob {
|
|||
|
||||
if (ret != 0) {
|
||||
this.getStatus(2);
|
||||
sm.sendNotification(nh.getFailedSubject(), nh.getFailedBody("Installation failed. Return code=" + ret));
|
||||
sm.sendNotification(nh.getFailedSubject() + " for "+this.algorithm.getName()+ " algorithm", nh.getFailedBody(this.buildInfo()+"Installation failed. Return code=" + ret));
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -92,12 +92,13 @@ public class StagingJob extends DMPMJob {
|
|||
this.algorithm.getFullname(), "Proto");
|
||||
|
||||
this.getStatus(9);
|
||||
sm.sendNotification(nh.getSuccessSubject(), nh.getSuccessBody());
|
||||
sm.sendNotification(nh.getSuccessSubject() + "for "+this.algorithm.getName()+ " algorithm", nh.getSuccessBody(this.buildInfo()));
|
||||
return;
|
||||
} else
|
||||
this.getStatus(2);
|
||||
sm.sendNotification(nh.getFailedSubject(),
|
||||
sm.sendNotification(nh.getFailedSubject() + " for "+this.algorithm.getName()+ " algorithm",
|
||||
nh.getFailedBody(
|
||||
this.buildInfo()+"\n"+
|
||||
"Installation completed but DataMiner Interface not working correctly or files "
|
||||
+ this.algorithm.getName() + ".jar and " + this.algorithm.getName()
|
||||
+ "_interface.jar not availables at the expected path"));
|
||||
|
@ -136,4 +137,17 @@ public class StagingJob extends DMPMJob {
|
|||
return response;
|
||||
}
|
||||
|
||||
|
||||
public String buildInfo(){
|
||||
ServiceConfiguration a = new ServiceConfiguration();
|
||||
return
|
||||
"\n"+
|
||||
"\n"+
|
||||
"User: "+this.algorithm.getFullname()+"\n"+
|
||||
"Algorithm name: "+this.algorithm.getName()+"\n"+
|
||||
"Staging DataMiner Host: "+ a.getStagingHost()+
|
||||
"Caller VRE: "+rProtoVREName+
|
||||
"Target VRE: "+rProtoVREName;
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -17,10 +17,10 @@ public class CheckPermission {
|
|||
|
||||
AuthorizationEntry entry = authorizationService().get(VREToken);
|
||||
if (entry.getContext().equals(vre)) {
|
||||
System.out.println("OK!");
|
||||
System.out.println("Authorization OK!");
|
||||
return true;
|
||||
}
|
||||
|
||||
System.out.println("Not a valid token recognized for the VRE: "+vre);
|
||||
return false;
|
||||
|
||||
}
|
||||
|
|
|
@ -18,6 +18,10 @@ public class NotificationHelper {
|
|||
return "[DataMinerGhostInstallationRequestReport]";
|
||||
}
|
||||
|
||||
private String getSubjectHeaderRelease() {
|
||||
return "[DataMinerReleaseInstallationRequestReport]";
|
||||
}
|
||||
|
||||
private boolean isError() {
|
||||
return this.executionException!=null;
|
||||
}
|
||||
|
@ -30,13 +34,23 @@ public class NotificationHelper {
|
|||
return this.getSubjectHeader()+" is SUCCESS";
|
||||
}
|
||||
|
||||
public String getSuccessSubjectRelease() {
|
||||
return this.getSubjectHeaderRelease()+" is SUCCESS";
|
||||
}
|
||||
|
||||
|
||||
public String getFailedSubjectRelease() {
|
||||
return this.getSubjectHeaderRelease()+" is FAILED";
|
||||
}
|
||||
|
||||
|
||||
public String getFailedSubject() {
|
||||
return String.format(this.getSubjectHeader()+" is FAILED");
|
||||
}
|
||||
|
||||
public String getSuccessBody() {
|
||||
public String getSuccessBody(String info) {
|
||||
String message = String.format("The installation of the algorithm in the ghost dataminer is completed successfully.");
|
||||
message+="\n\nYou can retrieve experiment results under the '/DataMiner' e-Infrastructure Workspace folder or from the DataMiner interface.";
|
||||
message+="\n\nYou can retrieve experiment results under the '/DataMiner' e-Infrastructure Workspace folder or from the DataMiner interface.\n\n"+ info;
|
||||
return message;
|
||||
}
|
||||
|
||||
|
@ -46,6 +60,12 @@ public class NotificationHelper {
|
|||
return body;
|
||||
}
|
||||
|
||||
public String getSuccessBodyRelease(String info) {
|
||||
String message = String.format("SVN REPOSITORY CORRECTLY UPDATED.");
|
||||
message+="\n\n The CRON job will install the algorithm in the target VRE \n\n"+ info;
|
||||
return message;
|
||||
}
|
||||
|
||||
// public String getSubject() {
|
||||
// if(this.isError()) {
|
||||
// return this.getFailedSubject();
|
||||
|
|
Loading…
Reference in New Issue