/* * RHQ Management Platform * Copyright (C) 2005-2008 Red Hat, Inc. * All rights reserved. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation version 2 of the License. * * This program 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ package org.rhq.plugins.iis; import java.util.Set; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.hyperic.sigar.win32.Pdh; import org.rhq.core.domain.measurement.AvailabilityType; import org.rhq.core.domain.measurement.DataType; import org.rhq.core.domain.measurement.MeasurementDataNumeric; import org.rhq.core.domain.measurement.MeasurementReport; import org.rhq.core.domain.measurement.MeasurementScheduleRequest; import org.rhq.core.domain.measurement.calltime.CallTimeData; import org.rhq.core.pluginapi.inventory.InvalidPluginConfigurationException; import org.rhq.core.pluginapi.inventory.ResourceComponent; import org.rhq.core.pluginapi.inventory.ResourceContext; import org.rhq.core.pluginapi.measurement.MeasurementFacet; import org.rhq.core.pluginapi.util.ResponseTimeConfiguration; /** * @author Greg Hinkle * @author Joseph Marques */ public class IISVHostComponent implements ResourceComponent<IISServerComponent<?>>, MeasurementFacet { private ResourceContext<IISServerComponent<?>> resourceContext; private IISResponseTimeDelegate responseTimeDelegate; private Log log = LogFactory.getLog(IISVHostComponent.class); public void start(ResourceContext<IISServerComponent<?>> resourceContext) throws InvalidPluginConfigurationException, Exception { this.resourceContext = resourceContext; String logDirectory = getLogDirectory(); // String collectionTZ = getResponseTimeCollectionTimeZone(); String logFormat = getResponseTimeLogFormat(); ResponseTimeConfiguration responseTimeConfiguration = getResponseTimeConfiguration(); if (logFormat == null) { throw new InvalidPluginConfigurationException("The 'responseTimeLogFormat' property must be specified."); } responseTimeDelegate = new IISResponseTimeDelegate(logDirectory, logFormat, responseTimeConfiguration /*,collectionTZ.equals("true")*/); } public void stop() { } public AvailabilityType getAvailability() { return AvailabilityType.UP; } // public String getResponseTimeCollectionTimeZone() { // return resourceContext.getPluginConfiguration().getSimpleValue("responseTimeCollectionTZ", "true"); // } public String getResponseTimeLogFormat() { // date time c-ip cs-method cs-uri-stem sc-status time-taken return resourceContext.getPluginConfiguration().getSimpleValue("responseTimeLogFormat", null); } public String getLogDirectory() { return resourceContext.getPluginConfiguration().getSimpleValue("logDirectory", null); } public String getSiteName() { return this.resourceContext.getPluginConfiguration().getSimpleValue("siteName", null); } public ResponseTimeConfiguration getResponseTimeConfiguration() { return new ResponseTimeConfiguration(resourceContext.getPluginConfiguration()); } public void getValues(MeasurementReport report, Set<MeasurementScheduleRequest> metrics) throws Exception { String propertyBase = "\\Web Service(" + getSiteName() + ")\\"; Pdh pdh = new Pdh(); for (MeasurementScheduleRequest request : metrics) { if (request.getDataType() == DataType.CALLTIME) { log.debug("Calltime MeasurementScheduleRequest: " + request); CallTimeData callTimeData = new CallTimeData(request); this.responseTimeDelegate.parseLogs(callTimeData); report.addData(callTimeData); } else { double value = pdh.getRawValue(propertyBase + request.getName()); report.addData(new MeasurementDataNumeric(request, value)); } } } }