/******************************************************************************* * Copyright (c) 2011 The Board of Trustees of the Leland Stanford Junior University * as Operator of the SLAC National Accelerator Laboratory. * Copyright (c) 2011 Brookhaven National Laboratory. * EPICS archiver appliance is distributed subject to a Software License Agreement found * in file LICENSE that is included with this distribution. *******************************************************************************/ package org.epics.archiverappliance.etl; import java.io.IOException; import java.util.HashMap; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.log4j.Logger; import org.epics.archiverappliance.common.BPLAction; import org.epics.archiverappliance.common.BasicDispatcher; import org.epics.archiverappliance.common.GetVersion; import org.epics.archiverappliance.common.ProcessMetricsReport; import org.epics.archiverappliance.config.ConfigService; import org.epics.archiverappliance.etl.bpl.ConsolidatePBFilesForOnePV; import org.epics.archiverappliance.etl.bpl.DeletePV; import org.epics.archiverappliance.etl.bpl.GetLastKnownEventTimeStamp; import org.epics.archiverappliance.etl.bpl.PauseArchivingPV; import org.epics.archiverappliance.etl.bpl.reports.ApplianceMetrics; import org.epics.archiverappliance.etl.bpl.reports.ApplianceMetricsDetails; import org.epics.archiverappliance.etl.bpl.reports.InstanceReportDetails; import org.epics.archiverappliance.etl.bpl.reports.PVDetails; import org.epics.archiverappliance.etl.bpl.reports.PVsByStorageConsumed; import org.epics.archiverappliance.etl.bpl.reports.StorageDetailsForAppliance; import org.epics.archiverappliance.etl.bpl.reports.StorageMetricsForAppliance; /** * The main business logic servlet for ETL. All BPLActions are registered here. * @author mshankar * */ @SuppressWarnings("serial") public class BPLServlet extends HttpServlet { private static final Logger logger = Logger.getLogger(BPLServlet.class); private static HashMap<String, Class<? extends BPLAction>> getActions = new HashMap<String, Class<? extends BPLAction>>(); static { getActions.put("/getPVDetails", PVDetails.class); getActions.put("/getApplianceMetrics", ApplianceMetrics.class); getActions.put("/getApplianceMetricsForAppliance", ApplianceMetricsDetails.class); getActions.put("/getStorageMetricsForAppliance", StorageMetricsForAppliance.class); getActions.put("/getStorageDetailsForAppliance", StorageDetailsForAppliance.class); getActions.put("/getPVsByStorageConsumed", PVsByStorageConsumed.class); getActions.put("/getInstanceMetricsForAppliance", InstanceReportDetails.class); getActions.put("/getLastKnownEvent", GetLastKnownEventTimeStamp.class); getActions.put("/consolidateDataForPV", ConsolidatePBFilesForOnePV.class); getActions.put("/pauseArchivingPV", PauseArchivingPV.class); getActions.put("/deletePV", DeletePV.class); getActions.put("/getProcessMetrics", ProcessMetricsReport.class); getActions.put("/getVersion", GetVersion.class); } @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { BasicDispatcher.dispatch(req, resp, configService, getActions); } private static HashMap<String, Class<? extends BPLAction>> postActions = new HashMap<String, Class<? extends BPLAction>>(); static { postActions.put("/pauseArchivingPV", PauseArchivingPV.class); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { logger.info("Beginning POST request into ETL servlet " + req.getPathInfo()); BasicDispatcher.dispatch(req, resp, configService, postActions); } @Override public void init() throws ServletException { super.init(); configService = (ConfigService) getServletConfig().getServletContext().getAttribute(ConfigService.CONFIG_SERVICE_NAME); logger.info("Done initializing ETL servlet"); } private ConfigService configService; }