Return-Path: X-Original-To: archive-asf-public-internal@cust-asf2.ponee.io Delivered-To: archive-asf-public-internal@cust-asf2.ponee.io Received: from cust-asf.ponee.io (cust-asf.ponee.io [163.172.22.183]) by cust-asf2.ponee.io (Postfix) with ESMTP id C4DA1200C31 for ; Wed, 8 Mar 2017 18:12:47 +0100 (CET) Received: by cust-asf.ponee.io (Postfix) id C3A7B160B73; Wed, 8 Mar 2017 17:12:47 +0000 (UTC) Delivered-To: archive-asf-public@cust-asf.ponee.io Received: from mail.apache.org (hermes.apache.org [140.211.11.3]) by cust-asf.ponee.io (Postfix) with SMTP id 6E6C2160B93 for ; Wed, 8 Mar 2017 18:12:45 +0100 (CET) Received: (qmail 58048 invoked by uid 500); 8 Mar 2017 17:12:44 -0000 Mailing-List: contact commits-help@airavata.apache.org; run by ezmlm Precedence: bulk List-Help: List-Unsubscribe: List-Post: List-Id: Reply-To: dev@airavata.apache.org Delivered-To: mailing list commits@airavata.apache.org Received: (qmail 55532 invoked by uid 99); 8 Mar 2017 17:12:42 -0000 Received: from git1-us-west.apache.org (HELO git1-us-west.apache.org) (140.211.11.23) by apache.org (qpsmtpd/0.29) with ESMTP; Wed, 08 Mar 2017 17:12:42 +0000 Received: by git1-us-west.apache.org (ASF Mail Server at git1-us-west.apache.org, from userid 33) id 5B943E0061; Wed, 8 Mar 2017 17:12:42 +0000 (UTC) Content-Type: text/plain; charset="us-ascii" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit From: machristie@apache.org To: commits@airavata.apache.org Date: Wed, 08 Mar 2017 17:13:08 -0000 Message-Id: <6b95e3653017466283f33b23f5929832@git.apache.org> In-Reply-To: <5665158a135b4fa6a3201742712b416f@git.apache.org> References: <5665158a135b4fa6a3201742712b416f@git.apache.org> X-Mailer: ASF-Git Admin Mailer Subject: [28/45] airavata git commit: adding Airavata custom email parser archived-at: Wed, 08 Mar 2017 17:12:48 -0000 adding Airavata custom email parser Project: http://git-wip-us.apache.org/repos/asf/airavata/repo Commit: http://git-wip-us.apache.org/repos/asf/airavata/commit/3c453aea Tree: http://git-wip-us.apache.org/repos/asf/airavata/tree/3c453aea Diff: http://git-wip-us.apache.org/repos/asf/airavata/diff/3c453aea Branch: refs/heads/ansible-testing-0.17 Commit: 3c453aeac578f309b03ce37c91bab5518bce08b5 Parents: e34722a Author: scnakandala Authored: Thu Mar 2 14:20:57 2017 -0500 Committer: scnakandala Committed: Thu Mar 2 14:20:57 2017 -0500 ---------------------------------------------------------------------- .../email/parser/AiravataCustomMailParser.java | 72 ++++++++++++++++++++ 1 file changed, 72 insertions(+) ---------------------------------------------------------------------- http://git-wip-us.apache.org/repos/asf/airavata/blob/3c453aea/modules/gfac/gfac-impl/src/main/java/org/apache/airavata/gfac/monitor/email/parser/AiravataCustomMailParser.java ---------------------------------------------------------------------- diff --git a/modules/gfac/gfac-impl/src/main/java/org/apache/airavata/gfac/monitor/email/parser/AiravataCustomMailParser.java b/modules/gfac/gfac-impl/src/main/java/org/apache/airavata/gfac/monitor/email/parser/AiravataCustomMailParser.java new file mode 100644 index 0000000..8810814 --- /dev/null +++ b/modules/gfac/gfac-impl/src/main/java/org/apache/airavata/gfac/monitor/email/parser/AiravataCustomMailParser.java @@ -0,0 +1,72 @@ +/* + * + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you 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.apache.airavata.gfac.monitor.email.parser; + +import org.apache.airavata.common.exception.AiravataException; +import org.apache.airavata.gfac.core.monitor.EmailParser; +import org.apache.airavata.gfac.core.monitor.JobStatusResult; +import org.apache.airavata.model.status.JobState; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +import javax.mail.Message; +import javax.mail.MessagingException; +import java.util.regex.Matcher; +import java.util.regex.Pattern; + +public class AiravataCustomMailParser implements EmailParser { + + private static final Logger log = LoggerFactory.getLogger(SLURMEmailParser.class); + + private static final String REGEX = "[a-zA-Z]*_[a-z]*=(?<" + JOBID + ">\\d*)[ ]*[a-zA-Z]*=(?<" + + JOBNAME + ">[a-zA-Z0-9-]*)[ ]*[a-zA-Z]*=(?<" + STATUS + ">[a-zA-Z]*).*"; + + public static final String COMPLETED = "COMPLETED"; + private static final Pattern pattern = Pattern.compile(REGEX); + + @Override + public JobStatusResult parseEmail(Message message) throws MessagingException, AiravataException { + JobStatusResult jobStatusResult = new JobStatusResult(); + parseSubject(message.getSubject(), jobStatusResult); + return jobStatusResult; + } + + private void parseSubject(String subject, JobStatusResult jobStatusResult) throws MessagingException { + Matcher matcher = pattern.matcher(subject); + if (matcher.find()) { + jobStatusResult.setJobId(matcher.group(JOBID)); + jobStatusResult.setJobName(matcher.group(JOBNAME)); + jobStatusResult.setState(getJobState(matcher.group(STATUS))); + } else { + log.error("[EJM]: No matched found for subject -> " + subject); + } + } + + private JobState getJobState(String state) { + switch (state.trim()) { + case COMPLETED: + return JobState.COMPLETE; + default: + log.error("[EJM]: Job State " + state + " isn't handle by Airavata custom parser"); + return JobState.UNKNOWN; + } + } +} \ No newline at end of file