/******************************************************************************* * This file is part of OpenNMS(R). * * Copyright (C) 2006-2011 The OpenNMS Group, Inc. * OpenNMS(R) is Copyright (C) 1999-2011 The OpenNMS Group, Inc. * * OpenNMS(R) is a registered trademark of The OpenNMS Group, Inc. * * OpenNMS(R) 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, either version 3 of the License, * or (at your option) any later version. * * OpenNMS(R) 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 OpenNMS(R). If not, see: * http://www.gnu.org/licenses/ * * For more information contact: * OpenNMS(R) Licensing <license@opennms.org> * http://www.opennms.org/ * http://www.opennms.com/ *******************************************************************************/ package org.opennms.web.controller; import java.util.Collection; import java.util.HashMap; import java.util.Map; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.extremecomponents.table.context.Context; import org.extremecomponents.table.context.HttpServletRequestContext; import org.extremecomponents.table.limit.Limit; import org.extremecomponents.table.limit.LimitFactory; import org.extremecomponents.table.limit.TableLimit; import org.extremecomponents.table.limit.TableLimitFactory; import org.opennms.netmgt.model.OnmsOutage; import org.opennms.web.svclayer.outage.OutagesFilteringView; import org.opennms.web.svclayer.outage.OutageListBuilder; import org.opennms.web.svclayer.outage.OutageService; import org.springframework.web.servlet.ModelAndView; import org.springframework.web.servlet.mvc.UrlFilenameViewController; /** * <p>OutageAllController class.</p> * * @author ranger * @version $Id: $ * @since 1.8.1 */ public class OutageAllController extends UrlFilenameViewController { OutageService m_outageService; OutageListBuilder m_cview = new OutageListBuilder(); Collection<OnmsOutage> foundOutages; Collection<OnmsOutage> viewOutages; private String m_successView; // private OutageService outageService; // BEAN Setter private static final int ROW_LIMIT = 25; /** * <p>setOutageService</p> * * @param service a {@link org.opennms.web.svclayer.outage.OutageService} object. */ public void setOutageService(OutageService service) { m_outageService = service; } // public Map referenceData(HttpServletRequest request) throws Exception { /** {@inheritDoc} */ @Override protected ModelAndView handleRequestInternal(HttpServletRequest request, HttpServletResponse reply) { Context context = new HttpServletRequestContext(request); LimitFactory limitFactory = new TableLimitFactory(context, "tabledata"); Limit limit = new TableLimit(limitFactory); OutagesFilteringView m_filterService = new OutagesFilteringView(); String searchFilter = m_filterService.filterQuery(request); Map<String, Object> myModel = new HashMap<String, Object>(); if (searchFilter.equals("")) { searchFilter = " AND 1=1 "; } Integer totalRows = m_outageService.outageCountFiltered(searchFilter); limit.setRowAttributes(totalRows, ROW_LIMIT); if (limit.getPage() == 1) { // no offset set myModel.put("rowStart", 0); context.setRequestAttribute("rowStart", 0); context.setRequestAttribute("rowEnd", ROW_LIMIT); myModel.put("rowEnd", ROW_LIMIT); if (limit.getSort().getProperty() == null) { foundOutages = m_outageService.getOutagesByRange(0, ROW_LIMIT, "iflostservice", "asc", searchFilter); } else { foundOutages = m_outageService.getOutagesByRange(0, ROW_LIMIT, limit.getSort().getProperty(), limit .getSort().getSortOrder(), searchFilter); } myModel.put("begin", 0); myModel.put("end", ROW_LIMIT); } else { Integer rowstart = null; Integer rowend = null; //quirky situation... - as we started on 0 (zero) rowstart = ((limit.getPage() * ROW_LIMIT +1 ) - ROW_LIMIT); rowend = ( ROW_LIMIT); myModel.put("begin", rowstart); myModel.put("end", rowend); if (limit.getSort().getProperty() == null) { foundOutages = m_outageService.getOutagesByRange( rowstart, rowend, "iflostservice", "asc",searchFilter); } else { foundOutages = m_outageService.getOutagesByRange(rowstart, rowend, limit.getSort().getProperty(), limit .getSort().getSortOrder(),searchFilter); } } Collection<Map<String,Object>> theTable = m_cview.theTable(foundOutages); myModel.put("searchfilter",searchFilter); myModel.put("tabledata", theTable); myModel.put("totalRows", totalRows); myModel.put("suffix",request.getQueryString()); return new ModelAndView(getSuccessView(), myModel); // return new ModelAndView("displayAllOutages" + getSuffix(), myModel); } /** * <p>setSuccessView</p> * * @param successView a {@link java.lang.String} object. */ public void setSuccessView(String successView) { m_successView = successView; } /** * <p>getSuccessView</p> * * @return a {@link java.lang.String} object. */ public String getSuccessView() { return m_successView; } }