/**
* Copyright (c) 2000-present Liferay, Inc. All rights reserved.
*
* 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.
*/
package com.liferay.portal.monitoring.internal.servlet.taglib;
import com.liferay.portal.configuration.metatype.bnd.util.ConfigurableUtil;
import com.liferay.portal.kernel.monitoring.DataSample;
import com.liferay.portal.kernel.monitoring.DataSampleThreadLocal;
import com.liferay.portal.kernel.monitoring.RequestStatus;
import com.liferay.portal.kernel.servlet.taglib.BaseDynamicInclude;
import com.liferay.portal.kernel.servlet.taglib.DynamicInclude;
import com.liferay.portal.kernel.util.HtmlUtil;
import com.liferay.portal.kernel.util.ListUtil;
import com.liferay.portal.kernel.util.StringBundler;
import com.liferay.portal.monitoring.configuration.MonitoringConfiguration;
import com.liferay.portal.monitoring.constants.MonitoringWebKeys;
import com.liferay.portal.monitoring.internal.statistics.portal.PortalRequestDataSample;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.List;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.osgi.service.component.annotations.Activate;
import org.osgi.service.component.annotations.Component;
import org.osgi.service.component.annotations.Modified;
/**
* @author Michael C. Han
*/
@Component(
configurationPid = "com.liferay.portal.monitoring.configuration.MonitoringConfiguration",
enabled = false, immediate = true, service = DynamicInclude.class
)
public class MonitoringBottomDynamicInclude extends BaseDynamicInclude {
@Override
public void include(
HttpServletRequest request, HttpServletResponse response,
String key)
throws IOException {
if (!_monitoringConfiguration.monitorPortalRequest()) {
return;
}
PortalRequestDataSample portalRequestDataSample =
(PortalRequestDataSample)request.getAttribute(
MonitoringWebKeys.PORTAL_REQUEST_DATA_SAMPLE);
if (portalRequestDataSample != null) {
portalRequestDataSample.capture(RequestStatus.SUCCESS);
portalRequestDataSample.setStatusCode(response.getStatus());
DataSampleThreadLocal.addDataSample(portalRequestDataSample);
}
List<DataSample> dataSamples = DataSampleThreadLocal.getDataSamples();
if (!_monitoringConfiguration.showPerRequestDataSample() ||
ListUtil.isEmpty(dataSamples)) {
return;
}
StringBundler sb = new StringBundler(dataSamples.size() * 2 + 2);
sb.append("<!--\n");
for (DataSample curDataSample : dataSamples) {
sb.append(HtmlUtil.escape(curDataSample.toString()));
sb.append("\n");
}
sb.append("-->");
PrintWriter printWriter = response.getWriter();
printWriter.println(sb);
}
@Override
public void register(DynamicIncludeRegistry dynamicIncludeRegistry) {
dynamicIncludeRegistry.register("/html/common/themes/bottom.jsp#post");
}
@Activate
@Modified
protected void activate(Map<String, Object> properties) {
_monitoringConfiguration = ConfigurableUtil.createConfigurable(
MonitoringConfiguration.class, properties);
}
private volatile MonitoringConfiguration _monitoringConfiguration;
}