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