| 1 |  |  | 
            
  
    | 2 |  |  | 
            
  
    | 3 |  |  | 
            
  
    | 4 |  |  | 
            
  
    | 5 |  |  | 
            
  
    | 6 |  |  | 
            
  
    | 7 |  |  | 
            
  
    | 8 |  |  | 
            
  
    | 9 |  |  | 
            
  
    | 10 |  |  | 
            
  
    | 11 |  |  | 
            
  
    | 12 |  |  | 
            
  
    | 13 |  |  | 
            
  
    | 14 |  |  | 
            
  
    | 15 |  |  | 
            
  
    | 16 |  |  | 
            
  
    | 17 |  |  | 
            
  
    | 18 |  |  | 
            
  
    | 19 |  |  | 
            
  
    | 20 |  |  | 
            
  
    | 21 |  |  | 
            
  
    | 22 |  |  | 
            
  
    | 23 |  |  | 
            
  
    | 24 |  |  | 
            
  
    | 25 |  |  | 
            
  
    | 26 |  |  | 
            
  
    | 27 |  |  | 
            
  
    | 28 |  |  | 
            
  
    | 29 |  |  | 
            
  
    | 30 |  |  | 
            
  
    | 31 |  |  | 
            
  
    | 32 |  | package net.sourceforge.pebble.web.action; | 
            
  
    | 33 |  |  | 
            
  
    | 34 |  | import net.sourceforge.pebble.Constants; | 
            
  
    | 35 |  | import net.sourceforge.pebble.domain.Blog; | 
            
  
    | 36 |  | import net.sourceforge.pebble.logging.Log; | 
            
  
    | 37 |  | import net.sourceforge.pebble.logging.LogEntry; | 
            
  
    | 38 |  | import net.sourceforge.pebble.web.view.View; | 
            
  
    | 39 |  | import net.sourceforge.pebble.web.view.impl.RequestsByHourView; | 
            
  
    | 40 |  |  | 
            
  
    | 41 |  | import javax.servlet.ServletException; | 
            
  
    | 42 |  | import javax.servlet.http.HttpServletRequest; | 
            
  
    | 43 |  | import javax.servlet.http.HttpServletResponse; | 
            
  
    | 44 |  | import java.util.Calendar; | 
            
  
    | 45 |  | import java.util.HashSet; | 
            
  
    | 46 |  | import java.util.Set; | 
            
  
    | 47 |  |  | 
            
  
    | 48 |  |  | 
            
  
    | 49 |  |  | 
            
  
    | 50 |  |  | 
            
  
    | 51 |  | @author | 
            
  
    | 52 |  |  | 
               
        |  |  | 
           
           |  | 0% | Uncovered Elements: 31 (31) | Complexity: 10 | Complexity Density: 0,43 |  | 
  
  
    | 53 |  | public class ViewRequestsByHourAction extends AbstractLogAction { | 
            
  
    | 54 |  |  | 
               
        |  |  | 
           
           |  | 0% | Uncovered Elements: 1 (1) | Complexity: 1 | Complexity Density: 1 |  | 
  
  
    | 55 | 0 |  protected Log getLog(HttpServletRequest request, HttpServletResponse response) throws ServletException {... | 
            
  
    | 56 | 0 | return super.getLog(request, response); | 
            
  
    | 57 |  | } | 
            
  
    | 58 |  |  | 
            
  
    | 59 |  |  | 
            
  
    | 60 |  |  | 
            
  
    | 61 |  |  | 
            
  
    | 62 |  | @param | 
            
  
    | 63 |  | @param | 
            
  
    | 64 |  | @return | 
            
  
    | 65 |  |  | 
               
        |  |  | 
           
           |  | 0% | Uncovered Elements: 28 (28) | Complexity: 9 | Complexity Density: 0,41 |  | 
  
  
    | 66 | 0 |  public View process(HttpServletRequest request, HttpServletResponse response) throws ServletException {... | 
            
  
    | 67 | 0 | Blog blog = (Blog)getModel().get(Constants.BLOG_KEY); | 
            
  
    | 68 | 0 | Log log = getLog(request, response); | 
            
  
    | 69 |  |  | 
            
  
    | 70 |  |  | 
            
  
    | 71 | 0 | int[] requestsPerHour = new int[24]; | 
            
  
    | 72 | 0 | Set<String>[] uniqueIpsPerHourAsSet = new Set[24]; | 
            
  
    | 73 | 0 | for (int hour = 0; hour < 24; hour++) { | 
            
  
    | 74 | 0 | requestsPerHour[hour] = 0; | 
            
  
    | 75 | 0 | uniqueIpsPerHourAsSet[hour] = new HashSet<String>(); | 
            
  
    | 76 |  | } | 
            
  
    | 77 | 0 | for (LogEntry logEntry : log.getLogEntries()) { | 
            
  
    | 78 | 0 | Calendar logTime = blog.getCalendar(); | 
            
  
    | 79 | 0 | logTime.setTime(logEntry.getDate()); | 
            
  
    | 80 | 0 | int hour = logTime.get(Calendar.HOUR_OF_DAY); | 
            
  
    | 81 | 0 | requestsPerHour[hour] = requestsPerHour[hour]+1; | 
            
  
    | 82 | 0 | uniqueIpsPerHourAsSet[hour].add(logEntry.getHost()); | 
            
  
    | 83 |  |  | 
            
  
    | 84 | 0 | if (logEntry.getRequestUri() != null && | 
            
  
    | 85 |  | logEntry.getRequestUri().indexOf("rss.xml") > -1 || | 
            
  
    | 86 |  | logEntry.getRequestUri().indexOf("feed.xml") > -1 || | 
            
  
    | 87 |  | logEntry.getRequestUri().indexOf("feed.action") > -1 || | 
            
  
    | 88 |  | logEntry.getRequestUri().indexOf("rdf.xml") > -1 || | 
            
  
    | 89 |  | logEntry.getRequestUri().indexOf("atom.xml") > -1) { | 
            
  
    | 90 |  | } | 
            
  
    | 91 |  | } | 
            
  
    | 92 |  |  | 
            
  
    | 93 | 0 | int[] uniqueIpsPerHour = new int[24]; | 
            
  
    | 94 | 0 | for (int hour = 0; hour < 24; hour++) { | 
            
  
    | 95 | 0 | uniqueIpsPerHour[hour] = uniqueIpsPerHourAsSet[hour].size(); | 
            
  
    | 96 |  | } | 
            
  
    | 97 |  |  | 
            
  
    | 98 | 0 | getModel().put("logAction", "viewRequestsByHour"); | 
            
  
    | 99 | 0 | getModel().put("totalRequests", log.getTotalLogEntries()); | 
            
  
    | 100 | 0 | getModel().put("requestsPerHour", requestsPerHour); | 
            
  
    | 101 | 0 | getModel().put("uniqueIpsPerHour", uniqueIpsPerHour); | 
            
  
    | 102 |  |  | 
            
  
    | 103 | 0 | return new RequestsByHourView(); | 
            
  
    | 104 |  | } | 
            
  
    | 105 |  |  | 
            
  
    | 106 |  | } |