Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   * JBoss, Home of Professional Open Source.
   * Copyright 2006, Red Hat Middleware LLC, and individual contributors
   * as indicated by the @author tags. See the copyright.txt file in the
   * distribution for a full listing of individual contributors.
   *
   * This is free software; you can redistribute it and/or modify it
   * under the terms of the GNU Lesser General Public License as
   * published by the Free Software Foundation; either version 2.1 of
  * the License, or (at your option) any later version.
  *
  * This software is distributed in the hope that it will be useful,
  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  * Lesser General Public License for more details.
  *
  * You should have received a copy of the GNU Lesser General Public
  * License along with this software; if not, write to the Free
  * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
  * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
  */
 package org.jboss.ws.common.monitoring;
 
 import java.util.List;
 import java.util.Map;
 import java.util.Set;
 
 
Keeps the last received records in memory and allows user to search / get statistics on them.

Author(s):
alessio.soldano@jboss.com
Since:
12-Dec-2007
 
 {
    private static final long serialVersionUID = 5180978625780333738L;
    
    private Map<StringList<Record>> recentRecords = Collections.synchronizedMap(new HashMap<StringList<Record>>());
    private volatile int size = 0;
    private volatile int maxSize = 50;
 
    public MemoryBufferRecorder()
    {
       this. = "MemoryBufferRecorder";
    }
 
    @Override
    public void processRecord(Record record)
    {
       synchronized ()
       {
          List<Recordlist = .get(record.getGroupID());
          if (list == null)
          {
             list = new LinkedList<Record>();
             .put(record.getGroupID(), list);
             while ( > )
             {
                this.deleteOldestRecord();
             }
             .offer(record.getGroupID());
             ++;
          }
          list.add(record);
       }
    }
    
 
    private void deleteOldestRecord()
    {
       String id = .poll();
       if (id != null)
       {
          .remove(id);
          --;
       }
    }
 
    private Map<StringList<Record>> getRecentRecords()
    {
       synchronized ()
       {
          return new HashMap<StringList<Record>>();
       }
   }
   public Set<StringgetClientHosts()
   {
      Map<StringList<Record>> map = this.getRecentRecords();
      Set<Stringhosts = new HashSet<String>();
      for (List<Recordlist : map.values())
      {
         for (Record record : list)
         {
            if (..equals(record.getMessageType()) && record.getSourceHost() != null)
            {
               hosts.add(record.getSourceHost());
            }
         }
      }
      return hosts;
   }
   public Map<StringList<Record>> getMatchingRecords(RecordFilter[] filters)
   {
      Map<StringList<Record>> map = this.getRecentRecords();
      Map<StringList<Record>> result = new HashMap<StringList<Record>>();
      for (List<Recordlist : map.values())
      {
         for (Record record : list)
         {
            boolean match = true;
            for (int i = 0; i < filters.length && matchi++)
            {
               match = match && filters[i].match(record);
            }
            if (match)
            {
               result.put(record.getGroupID(), list);
               break;
            }
         }
      }
      return result;
   }
   public Map<StringList<Record>> getRecordsByClientHost(String clientHost)
   {
      RecordFilter[] filters = new RecordFilter[1];
      filters[0] = new HostFilter(clientHosttrue);
      return this.getMatchingRecords(filters);
   }
   
   public String getRecordsByClientHostAsHTMLTable(boolean groupRecordsboolean showDetailsString clientHost)
   {
      return toHtml(groupRecordsshowDetailsthis.getRecordsByClientHost(clientHost));
   }
   public Map<StringList<Record>> getRecordsByOperation(String namespaceString localPart)
   {
      RecordFilter[] filters = new RecordFilter[1];
      filters[0] = new OperationFilter(new QName(namespacelocalPart));
      return this.getMatchingRecords(filters);
   }
   
   public String getRecordsByOperationAsHTMLTable(boolean groupRecordsboolean showDetailsString namespaceString localPart)
   {
      return toHtml(groupRecordsshowDetailsthis.getRecordsByOperation(namespacelocalPart));
   }
   public int getMaxSize()
   {
      return ;
   }
   public void setMaxSize(int maxSize)
   {
      synchronized ()
      {
         while (maxSize < )
         {
            this.deleteOldestRecord();
         }
         this. = maxSize;
      }
   }
   public int getSize()
   {
      return ;
   }
   
   public String getRecordsAsHTMLTable(boolean groupRecordsboolean showDetails)
   {
      Map<String,List<Record>> records = this.getRecentRecords();
      return toHtml(groupRecordsshowDetailsrecords);
   }
   
   private String toHtml(boolean groupRecordsboolean showDetailsMap<StringList<Record>> records)
   {
      StringBuilder sb = new StringBuilder();
      sb.append("</pre></span>");
      if (!groupRecords)
         openTable(sbshowDetails);
      for (Entry<StringList<Record>> e : records.entrySet()) {
         if (groupRecords)
            openTable(sbshowDetails);
         for (Record record : e.getValue())
         {
            appendRecordRow(sbrecordshowDetails);
         }
         if (groupRecords)
            closeTable(sb);
      }
      if (!groupRecords)
         closeTable(sb);
      sb.append("<pre><span class='OpResult'>");
      return sb.toString();
   }
   
   private void openTable(StringBuilder sbboolean showDetails)
   {
      sb.append("<table border='1'><tr class='AttributesHeader'><th>Group ID</th><th>Type</th><th>Date</th><th>From</th><th>To</th><th>Operation</th>");
      if (showDetails)
         sb.append("<th>Headers</th><th>Envelope</th>");
      sb.append("</tr><tr>");
   }
   
   private void closeTable(StringBuilder sb)
   {
      sb.append("</tr></table><br />");
   }
   
   private void appendRecordRow(StringBuilder sbRecord recordboolean showDetails) {
      sb.append("<tr><td><pre>");
      sb.append(record.getGroupID() != null ? record.getGroupID() : "[Not available]");
      sb.append("</pre></td>");
      sb.append("<td><pre>");
      sb.append(record.getMessageType() != null ? record.getMessageType() : "[Not available]");
      sb.append("</pre></td>");
      sb.append("<td><pre>");
      sb.append(record.getDate() != null ? record.getDate() : "[Not available]");
      sb.append("</pre></td>");
      sb.append("<td><pre>");
      sb.append(record.getSourceHost() != null ? record.getSourceHost() : "[Not available]");
      sb.append("</pre></td>");
      sb.append("<td><pre>");
      sb.append(record.getDestinationHost() != null ? record.getDestinationHost() : "[Not available]");
      sb.append("</pre></td>");
      sb.append("<td><pre>");
      sb.append(record.getOperation() != null ? record.getOperation() : "[Not available]");
      sb.append("</pre></td>");
      if (showDetails)
      {
         sb.append("<td><pre>");
         if (record.getHeaders() != null)
         {
            for (String headerName : record.getHeaders().keySet())
            {
               sb.append(headerName);
               sb.append(": ");
               sb.append(record.getHeaders().get(headerName));
               sb.append("<br />");
            }
         }
         else
            sb.append("[Not available]");
         sb.append("</pre></td>");
         sb.append("<td><pre>");
         sb.append(record.getEnvelope() != null ? record.getEnvelope().replaceAll("<""&lt;").replaceAll(">""&gt;") : "[Not available]");
         sb.append("</pre></td>");
      }
      sb.append("</tr>");
   }
   
   public Object clone() throws CloneNotSupportedException
   {
      MemoryBufferRecorder cl = (MemoryBufferRecorder)super.clone();
      cl.recentRecords = Collections.synchronizedMap(new HashMap<StringList<Record>>());
      synchronized (this.)
      {
         for (String key : this..keySet())
         {
            List<Recordlist = new LinkedList<Record>();
            for (Record record : this..get(key))
            {
               list.add(record);
            }
            cl.recentRecords.put(keylist);
         }
         cl.recentRecordGroups = new ConcurrentLinkedQueue<String>();
         for (String id : this.)
         {
            cl.recentRecordGroups.add(id);
         }
      }
      cl.maxSize = this.;
      cl.size = this.;
      return cl;
   }
New to GrepCode? Check out our FAQ X