package org.nemesis.forum.webapp.admin.action;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.apache.struts.action.ActionError;
import org.apache.struts.action.ActionErrors;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;
import org.nemesis.forum.Forum;
import org.nemesis.forum.ForumFactory;
import org.nemesis.forum.ForumThread;
public class SetThreadApprovedAction extends BaseAction {
static protected Log log =LogFactory.getLog(SetThreadApprovedAction.class);
public ActionForward execute(ActionMapping mapping,
ActionForm form,
HttpServletRequest request,
HttpServletResponse response)
throws Exception {
//check logon
checkUser(request);
ActionErrors errors = new ActionErrors();
try {
ForumFactory forumFactory = ForumFactory.getInstance(getAuthToken(request));
Forum forum = forumFactory.getForum(Integer.parseInt(request.getParameter("id")));
//check permission
checkPermission(request,OperationConstants.LIST_FORUM_CONTENT,forum);
ForumThread t=forum.getThread(Integer.parseInt(request.getParameter("threadID")));
t.setApproved(!t.isApproved());
t.getRootMessage().setApproved(t.isApproved());
} catch (Exception e) {
String eid=this.getClass().getName()+"_"+System.currentTimeMillis();
log.error("eid:"+eid +"\nsessionID" +request.getSession().getId(),e) ;
errors.add("general", new ActionError("error.general","error id:"+eid));
}
if (!errors.isEmpty()) {
saveErrors(request, errors);
return mapping.findForward("cancel");
}
return mapping.findForward("success");
}
}