package railo.runtime.monitor;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import railo.commons.lang.ExceptionUtil;
import railo.runtime.PageContext;
import railo.runtime.config.ConfigServer;
import railo.runtime.config.ConfigWeb;
public class ActionMonitorCollectorImpl implements ActionMonitorCollector {
private List<ActionMonitor> monitors;
@Override
public void addMonitor(ConfigServer cs,Object oMonitor, String name, boolean log) throws IOException {
ActionMonitor monitor;
try {
monitor = (ActionMonitor) oMonitor;
} catch (Throwable t) {
throw ExceptionUtil.toIOException(t);
}
monitor.init(cs,name,log);
if(monitors==null) monitors=new ArrayList<ActionMonitor>();
monitors.add(monitor);
}
/**
* logs certain action within a Request
* @param pc
* @param ar
* @throws IOException
*/
public void log(PageContext pc, String type, String label, long executionTime, Object data) {
if(monitors==null) return ;
Iterator<ActionMonitor> it = monitors.iterator();
while(it.hasNext()){
try {
it.next().log(pc, type, label, executionTime, data);
} catch (Throwable t) {
t.printStackTrace();
}
}
}
public void log(ConfigWeb config, String type, String label, long executionTime, Object data) {
if(monitors==null) return ;
Iterator<ActionMonitor> it = monitors.iterator();
while(it.hasNext()){
try {
it.next().log(config, type, label, executionTime, data);
} catch (Throwable t) {
t.printStackTrace();
}
}
}
@Override
public Object getActionMonitor(String name) {
Iterator<ActionMonitor> it = monitors.iterator();
ActionMonitor am;
while(it.hasNext()){
am = it.next();
if(name.equalsIgnoreCase(am.getName())) return am;
}
return null;
}
}