File Source: viewrequestsbyhouraction.java

         /* 
    P/P   *  Method: net.sourceforge.pebble.web.action.ViewRequestsByHourAction__static_init
          */
     1  /*
     2   * Copyright (c) 2003-2006, Simon Brown
     3   * All rights reserved.
     4   *
     5   * Redistribution and use in source and binary forms, with or without
     6   * modification, are permitted provided that the following conditions are met:
     7   *
     8   *   - Redistributions of source code must retain the above copyright
     9   *     notice, this list of conditions and the following disclaimer.
    10   *
    11   *   - Redistributions in binary form must reproduce the above copyright
    12   *     notice, this list of conditions and the following disclaimer in
    13   *     the documentation and/or other materials provided with the
    14   *     distribution.
    15   *
    16   *   - Neither the name of Pebble nor the names of its contributors may
    17   *     be used to endorse or promote products derived from this software
    18   *     without specific prior written permission.
    19   *
    20   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
    21   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
    22   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
    23   * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
    24   * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
    25   * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
    26   * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
    27   * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
    28   * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
    29   * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
    30   * POSSIBILITY OF SUCH DAMAGE.
    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  
         /* 
    P/P   *  Method: void net.sourceforge.pebble.web.action.ViewRequestsByHourAction()
          */
    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   * Gets the a breakdown of the requests for each hour of the day.
    50   *
    51   * @author    Simon Brown
    52   */
    53  public class ViewRequestsByHourAction extends AbstractLogAction {
    54  
    55    protected Log getLog(HttpServletRequest request, HttpServletResponse response) throws ServletException {
             /* 
    P/P       *  Method: Log getLog(HttpServletRequest, HttpServletResponse)
              * 
              *  Preconditions:
              *    request != null
              *    this.model != null
              *    this.model.data != null
              * 
              *  Postconditions:
              *    return_value != null
              *    init'ed(new ArrayList(Log#1) num objects)
              *    new ArrayList(getLog#1*) num objects <= 1
              *    new ArrayList(getLog#2*) num objects <= 1
              *    new HashSet(getLog#1*) num objects <= 1
              *    new Log(getLog#2*) num objects == new HashSet(getLog#1*) num objects
              *    new Log(getLog#1*) num objects <= 1
              *    init'ed(new Log(getLog#1*).blog)
              *    new Log(getLog#1*).logEntries != null
              *    new Log(getLog#2*).blog != null
              *    ...
              */
    56      return super.getLog(request, response);    //To change body of overridden methods use File | Settings | File Templates.
    57    }
    58  
    59    /**
    60     * Peforms the processing associated with this action.
    61     *
    62     * @param request  the HttpServletRequest instance
    63     * @param response the HttpServletResponse instance
    64     * @return the name of the next view
    65     */
    66    public View process(HttpServletRequest request, HttpServletResponse response) throws ServletException {
             /* 
    P/P       *  Method: View process(HttpServletRequest, HttpServletResponse)
              * 
              *  Preconditions:
              *    request != null
              *    this.model != null
              *    this.model.data != null
              * 
              *  Presumptions:
              *    java.util.Calendar:get(...)@80 in 0..23
              *    java.util.Collections:unmodifiableCollection(...)@72 != null
              *    java.util.HashMap:get(...)@63 != null
              *    java.util.Iterator:next(...)@77 != null
              *    log.logEntries@77 != null
              *    ...
              * 
              *  Postconditions:
              *    return_value == &new RequestsByHourView(process#5)
              *    new RequestsByHourView(process#5) num objects == 1
              * 
              *  Test Vectors:
              *    java.lang.String:indexOf(...)@85: {0..232-1}, {-231..-1}
              *    java.lang.String:indexOf(...)@86: {0..232-1}, {-231..-1}
              *    java.lang.String:indexOf(...)@87: {0..232-1}, {-231..-1}
              *    java.lang.String:indexOf(...)@88: {0..232-1}, {-231..-1}
              *    java.util.Iterator:hasNext(...)@77: {1}, {0}
              */
    67      Blog blog = (Blog)getModel().get(Constants.BLOG_KEY);
    68      Log log = getLog(request, response);
    69  
    70      // work out requests per hour
    71      int[] requestsPerHour = new int[24];
    72      Set<String>[] uniqueIpsPerHourAsSet = new Set[24];
    73      for (int hour = 0; hour < 24; hour++) {
    74        requestsPerHour[hour] = 0;
    75        uniqueIpsPerHourAsSet[hour] = new HashSet<String>();
    76      }
    77      for (LogEntry logEntry : log.getLogEntries()) {
    78        Calendar logTime = blog.getCalendar();
    79        logTime.setTime(logEntry.getDate());
    80        int hour = logTime.get(Calendar.HOUR_OF_DAY);
+   81        requestsPerHour[hour] = requestsPerHour[hour]+1;
    82        uniqueIpsPerHourAsSet[hour].add(logEntry.getHost());
    83  
+   84        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      int[] uniqueIpsPerHour = new int[24];
    94      for (int hour = 0; hour < 24; hour++) {
    95        uniqueIpsPerHour[hour] = uniqueIpsPerHourAsSet[hour].size();
    96      }
    97  
    98      getModel().put("logAction", "viewRequestsByHour");
    99      getModel().put("totalRequests", log.getTotalLogEntries());
   100      getModel().put("requestsPerHour", requestsPerHour);
   101      getModel().put("uniqueIpsPerHour", uniqueIpsPerHour);
   102  
   103      return new RequestsByHourView();
   104    }
   105  
   106  }








SofCheck Inspector Build Version : 2.22510
viewrequestsbyhouraction.java 2010-Jun-25 19:40:34
viewrequestsbyhouraction.class 2010-Jul-19 20:23:38