X-Git-Url: http://wamblee.org/gitweb/?a=blobdiff_plain;f=crawler%2Fkiss%2Fsrc%2Forg%2Fwamblee%2Fcrawler%2Fkiss%2Fmain%2FProgramConfigurationParser.java;h=fc41cde40aae4340b1f338f523a875433fdcc875;hb=5fd0e77da019c4636a1b5c2c9b043801f6cab175;hp=c16f4f93df34043fe9fde22297cff6cc81559944;hpb=59528dfd9877eca88ab0426bac6c26b2d6fe886d;p=utils diff --git a/crawler/kiss/src/org/wamblee/crawler/kiss/main/ProgramConfigurationParser.java b/crawler/kiss/src/org/wamblee/crawler/kiss/main/ProgramConfigurationParser.java index c16f4f93..fc41cde4 100644 --- a/crawler/kiss/src/org/wamblee/crawler/kiss/main/ProgramConfigurationParser.java +++ b/crawler/kiss/src/org/wamblee/crawler/kiss/main/ProgramConfigurationParser.java @@ -30,9 +30,7 @@ import org.wamblee.conditions.AndCondition; import org.wamblee.conditions.Condition; import org.wamblee.conditions.PropertyRegexCondition; import org.wamblee.crawler.kiss.guide.Program; -import org.wamblee.crawler.kiss.notification.MailNotifier; -import org.wamblee.crawler.kiss.notification.MailServer; -import org.wamblee.crawler.kiss.notification.Notifier; +import org.wamblee.xml.XslTransformer; /** * Parse the configuration of desired programs. @@ -42,14 +40,6 @@ class ProgramConfigurationParser { private static final int DEFAULT_PRIORITY = 1; - private static final String ELEM_PASSWORD = "password"; - - private static final String ELEM_USERNAME = "username"; - - private static final String ELEM_PORT = "port"; - - private static final String ELEM_HOST = "host"; - // Formatting configuration. private static final String ELEM_FORMAT = "format"; @@ -57,18 +47,6 @@ class ProgramConfigurationParser { private static final String ELEM_HTML = "html"; - // Mail server configuration. - - private static final String ELEM_NOTIFICATION = "notification"; - - private static final String ELEM_SMTP = "smtp"; - - private static final String ELEM_SUBJECT = "subject"; - - private static final String ELEM_TO = "to"; - - private static final String ELEM_FROM = "from"; - // Configuration of interesting programs. private static final String ELEM_PROGRAM = "program"; @@ -84,12 +62,12 @@ class ProgramConfigurationParser { private static final String ACTION_NOTIFY = "notify"; private List _filters; + + private XslTransformer _transformer; - private Notifier _notifier; - - ProgramConfigurationParser() { + ProgramConfigurationParser(XslTransformer aTransformer) { _filters = null; - _notifier = null; + _transformer = aTransformer; } /** @@ -147,56 +125,11 @@ class ProgramConfigurationParser { filters.add(new ProgramFilter(condition, action)); } _filters = filters; - - Element notifier = root.element(ELEM_NOTIFICATION); - _notifier = parseNotifier(notifier); - } catch (DocumentException e) { throw new RuntimeException("Error parsing program configuraiton", e); } } - /** - * Parses the notifier - * - * @return Notifier - */ - private Notifier parseNotifier(Element aNotifier) { - String from = aNotifier.elementTextTrim(ELEM_FROM); - String to = aNotifier.elementTextTrim(ELEM_TO); - String subject = aNotifier.elementTextTrim(ELEM_SUBJECT); - - Element smtp = aNotifier.element(ELEM_SMTP); - MailServer server = parseMailServer(smtp); - - Element format = aNotifier.element(ELEM_FORMAT); - String htmlXslt = format.elementTextTrim(ELEM_HTML); - String textXslt = format.elementTextTrim(ELEM_TEXT); - - return new MailNotifier(from, to, subject, htmlXslt, textXslt, server); - } - - /** - * Parses the mail server from the XML. - * - * @param aSmtp - * Mail server configuration. - * @return Mail server. - */ - private MailServer parseMailServer(Element aSmtp) { - String host = aSmtp.elementTextTrim(ELEM_HOST); - Element portElem = aSmtp.element(ELEM_PORT); - int port = DEFAULT_SMTP_PORT; - if (portElem != null) { - port = Integer.valueOf(portElem.getTextTrim()); - } - String username = aSmtp.elementTextTrim(ELEM_USERNAME); - String password = aSmtp.elementTextTrim(ELEM_PASSWORD); - - MailServer server = new MailServer(host, port, username, password); - return server; - } - /** * Returns the list of program filters. * @@ -205,13 +138,4 @@ class ProgramConfigurationParser { public List getFilters() { return _filters; } - - /** - * Returns the notifier to use. - * - * @return Notifier. - */ - public Notifier getNotifier() { - return _notifier; - } }