UI initial implementation.
[validation.git] / ui / src / main / java / org / akraino / validation / ui / service / JenkinsJobNotificationService.java
diff --git a/ui/src/main/java/org/akraino/validation/ui/service/JenkinsJobNotificationService.java b/ui/src/main/java/org/akraino/validation/ui/service/JenkinsJobNotificationService.java
new file mode 100644 (file)
index 0000000..0a50ad8
--- /dev/null
@@ -0,0 +1,57 @@
+/*
+ * Copyright (c) 2019 AT&T Intellectual Property. All rights reserved.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License"); you may
+ * not use this file except in compliance with the License. You may obtain
+ * a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+ * implied. See the License for the specific language governing
+ * permissions and limitations under the License.
+ */
+package org.akraino.validation.ui.service;
+
+import org.akraino.validation.ui.data.JnksJobNotify;
+import org.akraino.validation.ui.data.SubmissionStatus;
+import org.akraino.validation.ui.entity.Submission;
+import org.akraino.validation.ui.service.utils.SubmissionHelper;
+import org.apache.log4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+
+@Service
+@Transactional
+public class JenkinsJobNotificationService {
+
+    @Autowired
+    private SubmissionHelper submissionHelper;
+
+    @Autowired
+    private SubmissionService submissionService;
+
+    private static final Logger LOGGER = Logger.getLogger(JenkinsJobNotificationService.class);
+
+    public void handle(JnksJobNotify jnksJobNotify) {
+        String jenkinsJobName = System.getenv("jenkins_job_name");
+        if (!jenkinsJobName.equals(jnksJobNotify.getName())) {
+            return;
+        }
+        Submission submission = submissionService.getSubmission(Integer.toString(jnksJobNotify.getSubmissionId()));
+        if (submission == null) {
+            LOGGER.debug("No related submission was found.");
+            return;
+        }
+        submission.setNexusResultUrl(System.getenv("nexus_results_url") + "/"
+                + submission.getBlueprintInstance().getTimeslot().getLab().name().toLowerCase() + "-blu-val"
+                + "/job/validation/" + String.valueOf(jnksJobNotify.getbuildNumber()));
+        LOGGER.info("Updating submission with id: " + submission.getSubmissionId());
+        submission.setSubmissionStatus(SubmissionStatus.Completed);
+        submissionHelper.saveSubmission(submission);
+    }
+
+}