/**
* Copyright (c) 2012, Andy Janata
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without modification, are permitted
* provided that the following conditions are met:
*
* * Redistributions of source code must retain the above copyright notice, this list of conditions
* and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright notice, this list of
* conditions and the following disclaimer in the documentation and/or other materials provided
* with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
* FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY
* WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package net.socialgamer.cah.handlers;
import java.util.HashMap;
import java.util.Map;
import javax.servlet.http.HttpSession;
import net.socialgamer.cah.Constants.AjaxResponse;
import net.socialgamer.cah.Constants.ErrorCode;
import net.socialgamer.cah.Constants.ReturnableData;
import net.socialgamer.cah.RequestWrapper;
/**
* Implementations of this interface MUST also have a public static final String OP. There will be
* compile errors if they do not.
*
* @author Andy Janata (ajanata@socialgamer.net)
*/
public abstract class Handler {
/**
* Handle a request.
*
* @param request
* The request parameters.
* @param session
* The client's session.
* @return Response data.
*/
public abstract Map<ReturnableData, Object> handle(RequestWrapper request,
HttpSession session);
/**
* Get a data set for an error response.
*
* @param errorCode
* The error code.
* @return The data to return as the result of the request.
*/
protected static Map<ReturnableData, Object> error(final ErrorCode errorCode) {
final Map<ReturnableData, Object> data = new HashMap<ReturnableData, Object>();
data.put(AjaxResponse.ERROR, Boolean.TRUE);
data.put(AjaxResponse.ERROR_CODE, errorCode.toString());
return data;
}
/**
* Get a data set for an error response, with extra error information.
* @param errorCode The error code.
* @param extraData Additional data to return with the error.
* @return The data to return as the result of the request.
*/
protected static Map<ReturnableData, Object> error(final ErrorCode errorCode,
final Map<ReturnableData, Object> extraData) {
final Map<ReturnableData, Object> data = error(errorCode);
data.putAll(extraData);
return data;
}
/**
* Clean up after this Handler. Currently, this means using reflection to see if the concrete
* Handler implementation had a field of type Session (Hibernate), and closing it if it does and
* did not already close it.
*/
public final void cleanUp() {
// this actually breaks stuff, I'll have to think it through later.
// for (final Field field : this.getClass().getDeclaredFields()) {
// if (field.getType() == Session.class) {
// try {
// // This Handler had a Hibernate Session. Try to close it if it wasn't already closed.
// // This is extremely dirty but also extremely awesome to not have problems if it is
// // forgotten.
// field.setAccessible(true);
// final Session session = (Session) field.get(this);
// if (session.isOpen()) {
// session.close();
// logger.log(Level.INFO, "Closing unclosed Hibernate Session in "
// + this.getClass().getName());
// }
// } catch (final Exception e) {
// // Something prevented us from ignoring access control check, so we can't close the
// // session. Log about it and continue.
// e.printStackTrace();
// logger.log(Level.SEVERE, "Unable to reflect and get Hibernate Session from "
// + this.getClass().getName());
// logger.log(Level.SEVERE, e.toString());
// }
// }
// }
}
}