baseaction.java

来自「jGossip是一个简单而功能强大的Java论坛软件(消息板)」· Java 代码 · 共 272 行

JAVA
272
字号
/*
 * $$Id: BaseAction.java,v 1.17 2004/06/28 20:26:29 bel70 Exp $$
 *
 * ***** BEGIN LICENSE BLOCK *****
 * The contents of this file are subject to the Mozilla Public License
 * Version 1.1 (the "License"); you may not use this file except in
 * compliance with the License. You may obtain a copy of the License
 * at http://www.mozilla.org/MPL/
 *
 * Software distributed under the License is distributed on an "AS IS"
 * basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
 * the License for the specific language governing rights and
 * limitations under the License.
 *
 * The Original Code is JGossip forum code.
 *
 * The Initial Developer of the Original Code is the JResearch, Org.
 * Portions created by the Initial Developer are Copyright (C) 2004
 * the Initial Developer. All Rights Reserved.
 *
 * Contributor(s):
 *              Dmitry Belov <bel@jresearch.org>
 *
 * ***** END LICENSE BLOCK ***** */
/*
 * Created on 09.05.2003
 *
 */
package org.jresearch.gossip.actions;

import org.apache.commons.logging.Log;

import org.apache.struts.action.Action;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;
import org.apache.struts.util.MessageResources;

import org.jresearch.gossip.IConst;
import org.jresearch.gossip.beans.user.EntryList;
import org.jresearch.gossip.beans.user.User;
import org.jresearch.gossip.dao.ForumDAO;
import org.jresearch.gossip.exception.JGossipException;
import org.jresearch.gossip.exception.SystemException;
import org.jresearch.gossip.log.ForumLog;

import java.sql.SQLException;

import java.util.Date;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

import javax.sql.DataSource;


/**
 * DOCUMENT ME!
 *
 * @author Bel
 */
public abstract class BaseAction extends Action {
    private int accessLevel;
    public Log forumLogger = ForumLog.getInstance().getForumLogger();

    /**
     * DOCUMENT ME!
     *
     * @param request DOCUMENT ME!
     * @param mess DOCUMENT ME!
     * @param append DOCUMENT ME!
     */
    public void log(HttpServletRequest request, String mess, String append) {
        HttpSession session = request.getSession();
        User user = (User) session.getAttribute(IConst.SESSION.USER_KEY);
        MessageResources messages = getResources(request);

        StringBuffer sb = new StringBuffer();
        sb.append(request.getRemoteAddr());
        sb.append(" User:");
        sb.append((user.getName() == null) ? "<anonimous>" : user.getName());
        sb.append(" ");
        sb.append(messages.getMessage(mess));
        sb.append(" ");
        sb.append(append);
        forumLogger.info(sb.toString());
    }

    /**
     * DOCUMENT ME!
     *
     * @param session DOCUMENT ME!
     * @param key DOCUMENT ME!
     * @param arg0 DOCUMENT ME!
     * @param arg1 DOCUMENT ME!
     */
    public void setStatusMessage(HttpServletRequest request, String key, String arg0,
        String arg1) {
        	
        MessageResources messages=getResources(request);
        String message=	messages.getMessage(super.getLocale(request),key,arg0,arg1);
		request.getSession().setAttribute(IConst.SESSION.STATUS_MESSAGE, message);
    }

    /**
     * DOCUMENT ME!
     *
     * @param session DOCUMENT ME!
     * @param key DOCUMENT ME!
     * @param arg0 DOCUMENT ME!
     */
    public void setStatusMessage(HttpServletRequest request, String key, String arg0) {
        setStatusMessage(request, key, arg0, "");
    }

    /**
     * DOCUMENT ME!
     *
     * @param session DOCUMENT ME!
     * @param key DOCUMENT ME!
     */
    public void setStatusMessage(HttpServletRequest request, String key) {
        setStatusMessage(request, key, "");
    }

    /**
     * DOCUMENT ME!
     *
     * @param request DOCUMENT ME!
     * @param mess DOCUMENT ME!
     */
    public void log(HttpServletRequest request, String mess) {
        log(request, mess, "");
    }

    /**
     * DOCUMENT ME!
     *
     * @param request DOCUMENT ME!
     *
     * @return DOCUMENT ME!
     */
    public boolean haveAccess(HttpServletRequest request) {
        HttpSession session = request.getSession();
        User user = (User) session.getAttribute(IConst.SESSION.USER_KEY);
        boolean access = (user.getStatus() >= this.accessLevel);

        if (!access) {
            ForumLog.getInstance().getForumLogger().warn(request.getRemoteAddr() +
                " " + user.getName() + " " +
                getResources(request).getMessage("logs.LOG27") + " " +
                request.getRequestURI());
        }

        return access;
    }

    /**
     * DOCUMENT ME!
     *
     * @param request DOCUMENT ME!
     *
     * @return DOCUMENT ME!
     */
    public DataSource getDataSource(HttpServletRequest request) {
        return (DataSource) request.getSession().getServletContext()
                                   .getAttribute(IConst.CONTEXT.DS_KEY);
    }

    /**
     * DOCUMENT ME!
     *
     * @param mapping DOCUMENT ME!
     * @param form DOCUMENT ME!
     * @param request DOCUMENT ME!
     * @param response DOCUMENT ME!
     *
     * @return DOCUMENT ME!
     *
     * @throws Exception DOCUMENT ME!
     */
    public ActionForward execute(ActionMapping mapping, ActionForm form,
        HttpServletRequest request, HttpServletResponse response)
        throws Exception {
        HttpSession session = request.getSession();
        MessageResources messages = getResources(request);

        if (!haveAccess(request)) {
            return (mapping.findForward("jgossip-denied"));
        }

        ActionForward forward = this.process(mapping, form, request, response);
        afterProcess(mapping, form, request, response);
        request.setAttribute(IConst.REQUEST.REQUEST_URI, request.getRequestURI());

        ForumDAO forumDAO = ForumDAO.getInstance();

        if (session.getAttribute(IConst.SESSION.LAST_UPDATE_DATE) == null) {
            session.setAttribute(IConst.SESSION.LAST_UPDATE_DATE, new Date());
        }

        try {
            forumDAO.setDataSource(getDataSource(request));

            EntryList elist = new EntryList();
            forumDAO.fillEntryList(elist);
            request.setAttribute(IConst.REQUEST.ENTRY_LIST, elist);

            if ((session.getAttribute(IConst.SESSION.GROUPS_KEY) == null) ||
                    (((Date) session.getAttribute(
                        IConst.SESSION.LAST_UPDATE_DATE)).before(
                        (Date) getServlet().getServletContext().getAttribute(IConst.CONTEXT.LAST_UPDATE_DATE)))) {
                User user = (User) session.getAttribute(IConst.SESSION.USER_KEY);
                session.setAttribute(IConst.SESSION.GROUPS_KEY,
                    forumDAO.getGroups(user.getStatus(), false));
                session.setAttribute(IConst.SESSION.LAST_UPDATE_DATE, new Date());
            }
        } catch (SQLException sqle) {
            getServlet().log("Connection.process", sqle);
            throw new SystemException(sqle);
        }

        return (forward);
    }

    /**
     * DOCUMENT ME!
     *
     * @param mapping DOCUMENT ME!
     * @param form DOCUMENT ME!
     * @param request DOCUMENT ME!
     * @param response DOCUMENT ME!
     */
    public void afterProcess(ActionMapping mapping, ActionForm form,
        HttpServletRequest request, HttpServletResponse response) {
    }

    /**
     * DOCUMENT ME!
     *
     * @param mapping DOCUMENT ME!
     * @param form DOCUMENT ME!
     * @param request DOCUMENT ME!
     * @param response DOCUMENT ME!
     *
     * @return DOCUMENT ME!
     * @throws SystemException
     */
    public abstract ActionForward process(ActionMapping mapping,
        ActionForm form, HttpServletRequest request,
        HttpServletResponse response) throws JGossipException;

    /**
     * DOCUMENT ME!
     *
     * @return
     */
    public int getAccessLevel() {
        return accessLevel;
    }

    /**
     * DOCUMENT ME!
     *
     * @param i
     */
    public void setAccessLevel(int i) {
        accessLevel = i;
    }
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?