diff --git a/src/main/java/org/gcube/dataanalysis/dataminer/poolmanager/service/ProductionPublishingJob.java b/src/main/java/org/gcube/dataanalysis/dataminer/poolmanager/service/ProductionPublishingJob.java index 46d16bd..97d1f80 100644 --- a/src/main/java/org/gcube/dataanalysis/dataminer/poolmanager/service/ProductionPublishingJob.java +++ b/src/main/java/org/gcube/dataanalysis/dataminer/poolmanager/service/ProductionPublishingJob.java @@ -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,26 +21,33 @@ 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())); + } - + // int ret = this.executeAnsibleWorker( // createWorker(this.algorithm, this.prodCluster, false, "gcube")); @@ -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; + } + + + } diff --git a/src/main/java/org/gcube/dataanalysis/dataminer/poolmanager/service/StagingJob.java b/src/main/java/org/gcube/dataanalysis/dataminer/poolmanager/service/StagingJob.java index e2b5690..283e42c 100644 --- a/src/main/java/org/gcube/dataanalysis/dataminer/poolmanager/service/StagingJob.java +++ b/src/main/java/org/gcube/dataanalysis/dataminer/poolmanager/service/StagingJob.java @@ -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; + } + } diff --git a/src/main/java/org/gcube/dataanalysis/dataminer/poolmanager/util/CheckPermission.java b/src/main/java/org/gcube/dataanalysis/dataminer/poolmanager/util/CheckPermission.java index 9a39a48..af53b42 100644 --- a/src/main/java/org/gcube/dataanalysis/dataminer/poolmanager/util/CheckPermission.java +++ b/src/main/java/org/gcube/dataanalysis/dataminer/poolmanager/util/CheckPermission.java @@ -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; } diff --git a/src/main/java/org/gcube/dataanalysis/dataminer/poolmanager/util/NotificationHelper.java b/src/main/java/org/gcube/dataanalysis/dataminer/poolmanager/util/NotificationHelper.java index 068a3b9..a6a1284 100644 --- a/src/main/java/org/gcube/dataanalysis/dataminer/poolmanager/util/NotificationHelper.java +++ b/src/main/java/org/gcube/dataanalysis/dataminer/poolmanager/util/NotificationHelper.java @@ -17,6 +17,10 @@ public class NotificationHelper { private String getSubjectHeader() { 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();