Coverage Report - org.jtheque.core.managers.event.EventManager
 
Classes in this File Line Coverage Branch Coverage Complexity
EventManager
0 %
0/55
0 %
0/12
1.7
 
 1  
 package org.jtheque.core.managers.event;
 2  
 
 3  
 import org.jdom.Element;
 4  
 import org.jtheque.core.managers.AbstractManager;
 5  
 import org.jtheque.core.managers.Managers;
 6  
 import org.jtheque.core.utils.file.XMLException;
 7  
 import org.jtheque.core.utils.file.XMLReader;
 8  
 import org.jtheque.core.utils.file.XMLWriter;
 9  
 import org.jtheque.utils.io.FileUtils;
 10  
 
 11  
 import java.io.File;
 12  
 import java.util.ArrayList;
 13  
 import java.util.Collection;
 14  
 import java.util.Date;
 15  
 import java.util.HashMap;
 16  
 import java.util.Map;
 17  
 import java.util.Set;
 18  
 
 19  
 /*
 20  
  * This file is part of JTheque.
 21  
  *
 22  
  * JTheque is free software: you can redistribute it and/or modify
 23  
  * it under the terms of the GNU General Public License as published by
 24  
  * the Free Software Foundation, either version 3 of the License.
 25  
  *
 26  
  * JTheque is distributed in the hope that it will be useful,
 27  
  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 28  
  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 29  
  * GNU General Public License for more details.
 30  
  *
 31  
  * You should have received a copy of the GNU General Public License
 32  
  * along with JTheque.  If not, see <http://www.gnu.org/licenses/>.
 33  
  */
 34  
 
 35  
 /**
 36  
  * An event manager implementation.
 37  
  *
 38  
  * @author Baptiste Wicht
 39  
  */
 40  0
 public final class EventManager extends AbstractManager implements IEventManager {
 41  0
     private final Map<String, Collection<EventLog>> logs = new HashMap<String, Collection<EventLog>>(10);
 42  
 
 43  
     @Override
 44  
     public void preInit() {
 45  0
         importFromXML();
 46  0
     }
 47  
 
 48  
     @Override
 49  
     public void close(){
 50  0
         saveXML();
 51  0
     }
 52  
 
 53  
     @Override
 54  
     public Set<String> getLogs() {
 55  0
         return logs.keySet();
 56  
     }
 57  
 
 58  
     @Override
 59  
     public Collection<EventLog> getEventLogs(String log) {
 60  0
         return logs.get(log);
 61  
     }
 62  
 
 63  
     @Override
 64  
     public void addEventLog(String log, EventLog event) {
 65  0
         if (!logs.containsKey(log)) {
 66  0
             logs.put(log, new ArrayList<EventLog>(25));
 67  
         }
 68  
 
 69  0
         event.setLog(log);
 70  
 
 71  0
         logs.get(log).add(event);
 72  0
     }
 73  
 
 74  
     /**
 75  
      * Import from XML.
 76  
      */
 77  
     private void importFromXML() {
 78  0
         File f = new File(Managers.getCore().getFolders().getApplicationFolder(), "/core/logs.xml");
 79  
 
 80  0
         if (!f.exists()) {
 81  0
             createEmptyEventFile(f);
 82  
         }
 83  
 
 84  0
         XMLReader reader = new XMLReader();
 85  
 
 86  
         try {
 87  0
             reader.openFile(f);
 88  
 
 89  0
             for (Object currentNode : reader.getNodes("log", reader.getRootElement())) {
 90  0
                 String name = reader.readString("@name", currentNode);
 91  
 
 92  0
                 Collection<Element> elements = reader.getNodes("event", currentNode);
 93  
 
 94  0
                 logs.put(name, new ArrayList<EventLog>(elements.size()));
 95  
 
 96  0
                 for (Element element : elements) {
 97  0
                     EventLog log = readLog(reader, name, element);
 98  
 
 99  0
                     logs.get(name).add(log);
 100  0
                 }
 101  0
             }
 102  0
         } catch (XMLException e) {
 103  0
             getLogger().error(e);
 104  
         } finally {
 105  0
             FileUtils.close(reader);
 106  0
         }
 107  0
     }
 108  
 
 109  
     /**
 110  
      * Create an empty event file.
 111  
      *
 112  
      * @param f The file.
 113  
      */
 114  
     private static void createEmptyEventFile(File f) {
 115  0
         XMLWriter writer = new XMLWriter("logs");
 116  
 
 117  0
         writer.write(f.getAbsolutePath());
 118  0
     }
 119  
 
 120  
     /**
 121  
      * Read the log from the XML.
 122  
      *
 123  
      * @param reader  The reader to use.
 124  
      * @param name    The name of the log.
 125  
      * @param element The element to read the log from.
 126  
      * @return The EventLog.
 127  
      * @throws XMLException If an error occurs during the xml reading.
 128  
      */
 129  
     private static EventLog readLog(XMLReader reader, String name, Object element) throws XMLException {
 130  0
         EventLog log = new EventLog(
 131  
                 EventLevel.get(reader.readInt("level", element)),
 132  
                 new Date(reader.readLong("date", element)),
 133  
                 reader.readString("source", element),
 134  
                 reader.readString("title", element));
 135  
 
 136  0
         log.setDetailsKey(reader.readString("details", element));
 137  0
         log.setLog(name);
 138  
 
 139  0
         return log;
 140  
     }
 141  
 
 142  
     /**
 143  
      * Save the events to XML.
 144  
      */
 145  
     private void saveXML() {
 146  0
         XMLWriter writer = new XMLWriter("logs");
 147  
 
 148  0
         for (Map.Entry<String, Collection<EventLog>> entry : logs.entrySet()) {
 149  0
             writer.add("log");
 150  
 
 151  0
             writer.addAttribute("name", entry.getKey());
 152  
 
 153  0
             writeEvents(writer, entry.getValue());
 154  
 
 155  0
             writer.switchToParent();
 156  
         }
 157  
 
 158  0
         writer.write(Managers.getCore().getFolders().getApplicationFolder().getAbsolutePath() + "/core/logs.xml");
 159  0
     }
 160  
 
 161  
     /**
 162  
      * Write the events to the XML file.
 163  
      *
 164  
      * @param writer The writer to use.
 165  
      * @param logs   The logs to write.
 166  
      */
 167  
     private static void writeEvents(XMLWriter writer, Iterable<EventLog> logs) {
 168  0
         for (EventLog log : logs) {
 169  0
             writer.add("event");
 170  
 
 171  0
             writer.addOnly("level", Integer.toString(log.getLevel().intValue()));
 172  0
             writer.addOnly("date", Long.toString(log.getDate().getTime()));
 173  0
             writer.addOnly("source", log.getSource());
 174  0
             writer.addOnly("title", log.getTitleKey());
 175  
 
 176  0
             writer.switchToParent();
 177  
         }
 178  0
     }
 179  
 }