/** * 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; }