File Source: viewrequestsbytypeaction.java

         /* 
    P/P   *  Method: net.sourceforge.pebble.web.action.ViewRequestsByTypeAction__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.logging.Request;
    39  import net.sourceforge.pebble.web.view.View;
    40  import net.sourceforge.pebble.web.view.impl.RequestsByTypeView;
    41  
         /* 
    P/P   *  Method: void net.sourceforge.pebble.web.action.ViewRequestsByTypeAction()
          */
    42  import javax.servlet.ServletException;
    43  import javax.servlet.http.HttpServletRequest;
    44  import javax.servlet.http.HttpServletResponse;
    45  import java.util.Collection;
    46  import java.util.HashSet;
    47  import java.util.Set;
    48  
    49  /**
    50   * Gets the statistics for the specified time period.
    51   *
    52   * @author    Simon Brown
    53   */
    54  public class ViewRequestsByTypeAction extends AbstractLogAction {
    55  
    56    /**
    57     * Peforms the processing associated with this action.
    58     *
    59     * @param request  the HttpServletRequest instance
    60     * @param response the HttpServletResponse instance
    61     * @return the name of the next view
    62     */
    63    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:
              *    aRequest.logEntries@77 != null
              *    java.util.Iterator:next(...)@76 != null
              *    java.util.Iterator:next(...)@77 != null
              *    java.util.Iterator:next(...)@83 != null
              *    java.util.Iterator:next(...)@88 != null
              *    ...
              * 
              *  Postconditions:
              *    return_value == &new RequestsByTypeView(process#5)
              *    new RequestsByTypeView(process#5) num objects == 1
              * 
              *  Test Vectors:
              *    aRequest.fileDownload@77: {0}, {1}
              *    aRequest.newsFeed@77: {0}, {1}
              *    aRequest.pageView@77: {0}, {1}
              *    java.util.Iterator:hasNext(...)@76: {1}, {0}
              *    java.util.Iterator:hasNext(...)@77: {1}, {0}
              *    java.util.Iterator:hasNext(...)@83: {1}, {0}
              *    java.util.Iterator:hasNext(...)@88: {1}, {0}
              *    java.util.Iterator:hasNext(...)@93: {1}, {0}
              */
+   64      Blog blog = (Blog)getModel().get(Constants.BLOG_KEY);
    65      Log log = getLog(request, response);
    66  
    67      Collection<Request> requests = log.getRequests();
    68      Set<String> uniqueIps = new HashSet<String>();
    69      Set<String> uniqueIpsForNewsFeeds = new HashSet<String>();
    70      Set<String> uniqueIpsForPageViews = new HashSet<String>();
    71      Set<String> uniqueIpsForFileDownloads = new HashSet<String>();
    72      int totalNewsFeedRequests = 0;
    73      int totalPageViews = 0;
    74      int totalFileDownloads = 0;
    75  
    76      for (Request aRequest : requests) {
    77        for (LogEntry logEntry : aRequest.getLogEntries()) {
    78          uniqueIps.add(logEntry.getHost());
    79        }
    80  
    81        if (aRequest.isNewsFeed()) {
    82          totalNewsFeedRequests += aRequest.getCount();
    83          for (LogEntry logEntry : aRequest.getLogEntries()) {
    84            uniqueIpsForNewsFeeds.add(logEntry.getHost());
    85          }
    86        } else if (aRequest.isPageView()) {
    87          totalPageViews += aRequest.getCount();
    88          for (LogEntry logEntry : aRequest.getLogEntries()) {
    89            uniqueIpsForPageViews.add(logEntry.getHost());
    90          }
    91        } else if (aRequest.isFileDownload()) {
    92          totalFileDownloads += aRequest.getCount();
    93          for (LogEntry logEntry : aRequest.getLogEntries()) {
    94            uniqueIpsForFileDownloads.add(logEntry.getHost());
    95          }
    96        }
    97      }
    98  
    99      getModel().put("logAction", "viewRequestsByType");
   100      getModel().put("totalRequests", log.getTotalLogEntries());
   101      getModel().put("uniqueIps", uniqueIps.size());
   102      getModel().put("totalNewsfeedRequests", totalNewsFeedRequests);
   103      getModel().put("uniqueIpsForNewsFeeds", uniqueIpsForNewsFeeds.size());
   104      getModel().put("totalPageViews", totalPageViews);
   105      getModel().put("uniqueIpsForPageViews", uniqueIpsForPageViews.size());
   106      getModel().put("totalFileDownloads", totalFileDownloads);
   107      getModel().put("uniqueIpsForFileDownloads", uniqueIpsForFileDownloads.size());
   108  
   109      return new RequestsByTypeView();
   110    }
   111  
   112  }








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