/**
* Copyright (c) 2014, the Railo Company Ltd.
* Copyright (c) 2015, Lucee Assosication Switzerland
*
* This library 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 library 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 library. If not, see <http://www.gnu.org/licenses/>.
*
*/
package lucee.runtime.monitor;
import java.io.IOException;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import lucee.commons.lang.ExceptionUtil;
import lucee.runtime.PageContext;
import lucee.runtime.config.ConfigServer;
import lucee.runtime.config.ConfigWeb;
public class ActionMonitorCollectorRefImpl implements ActionMonitorCollector {
private List<ActionMonitor> monitors=new ArrayList<ActionMonitor>();
private Method init;
private Method logc;
private Method getName;
private Method logpc;
@Override
public void addMonitor(ConfigServer cs,ActionMonitor monitor, String name, boolean log) throws IOException {
monitor=init(monitor,cs,name,log);
if(monitor!=null)monitors.add(monitor);
}
@Override
public void log(PageContext pc, String type, String label, long executionTime, Object data) {
Iterator<ActionMonitor> it = monitors.iterator();
while(it.hasNext()){
log(it.next(),pc, type, label, executionTime, data);
}
}
@Override
public void log(ConfigWeb config, String type, String label, long executionTime, Object data) {
Iterator<ActionMonitor> it = monitors.iterator();
while(it.hasNext()){
log(it.next(),config, type, label, executionTime, data);
}
}
@Override
public ActionMonitor getActionMonitor(String name) {
Iterator<ActionMonitor> it = monitors.iterator();
ActionMonitor am;
while(it.hasNext()){
am = it.next();
if(name.equalsIgnoreCase(getName(am))) return am;
}
return null;
}
private String getName(Object am) {
if(getName==null){
try {
getName=am.getClass().getMethod("getName", new Class[]{});
}
catch(Throwable t) {
ExceptionUtil.rethrowIfNecessary(t);
return null;
}
}
try {
return (String) getName.invoke(am, new Object[]{});
}
catch(Throwable t) {ExceptionUtil.rethrowIfNecessary(t);}
return null;
}
private void log(Object monitor, PageContext pc, String type, String label, long executionTime, Object data) {
if(logpc==null){
try {
logpc=monitor.getClass().getMethod("log", new Class[]{PageContext.class,String.class,String.class,long.class,Object.class});
}
catch(Throwable t) {
ExceptionUtil.rethrowIfNecessary(t);
return;
}
}
try {
logpc.invoke(monitor, new Object[]{pc,type,label,executionTime,data});
}
catch(Throwable t) {ExceptionUtil.rethrowIfNecessary(t);}
}
private void log(Object monitor, ConfigWeb config, String type, String label, long executionTime, Object data) {
if(logc==null){
try {
logc=monitor.getClass().getMethod("log", new Class[]{ConfigWeb.class,String.class,String.class,long.class,Object.class});
}
catch(Throwable t) {
ExceptionUtil.rethrowIfNecessary(t);
return;
}
}
try {
logc.invoke(monitor, new Object[]{config,type,label,executionTime,data});
}
catch(Throwable t) {ExceptionUtil.rethrowIfNecessary(t);}
}
private ActionMonitor init(ActionMonitor monitor, ConfigServer cs, String name, boolean log) {
if(init==null){
try {
init=monitor.getClass().getMethod("init", new Class[]{ConfigServer.class,String.class,boolean.class});
}
catch(Throwable t) {
ExceptionUtil.rethrowIfNecessary(t);
return null;
}
}
try {
return (ActionMonitor)init.invoke(monitor, new Object[]{cs,name,log});
}
catch(Throwable t) {
ExceptionUtil.rethrowIfNecessary(t);
return null;
}
}
}