KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > org > objectweb > jonas > webapp > jonasadmin > jonasserver > JonasServerRunGCAction


1 /**
2  * JOnAS: Java(TM) Open Application Server
3  * Copyright (C) 1999 Bull S.A.
4  * Contact: jonas-team@objectweb.org
5  *
6  * This library is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public
8  * License as published by the Free Software Foundation; either
9  * version 2.1 of the License, or any later version.
10  *
11  * This library is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with this library; if not, write to the Free Software
18  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
19  * USA
20  *
21  * --------------------------------------------------------------------------
22  * $Id: JonasServerRunGCAction.java,v 1.6 2005/04/20 11:58:42 danesa Exp $
23  * --------------------------------------------------------------------------
24  */

25
26 package org.objectweb.jonas.webapp.jonasadmin.jonasserver;
27
28 import java.io.IOException JavaDoc;
29
30 import javax.management.ObjectName JavaDoc;
31 import javax.servlet.ServletException JavaDoc;
32 import javax.servlet.http.HttpServletRequest JavaDoc;
33 import javax.servlet.http.HttpServletResponse JavaDoc;
34
35 import org.apache.struts.action.ActionForm;
36 import org.apache.struts.action.ActionForward;
37 import org.apache.struts.action.ActionMapping;
38 import org.objectweb.jonas.jmx.J2eeObjectName;
39 import org.objectweb.jonas.jmx.JonasManagementRepr;
40 import org.objectweb.jonas.webapp.jonasadmin.JonasBaseAction;
41
42 /**
43  * @author Michel-Ange Anton
44  */

45
46 public class JonasServerRunGCAction extends JonasBaseAction {
47
48 // --------------------------------------------------------- Public Methods
49

50     /**
51      * Process the specified HTTP request, and create the corresponding HTTP
52      * response (or forward to another web component that will create it).
53      * Return an <code>ActionForward</code> instance describing where and how
54      * control should be forwarded, or <code>null</code> if the response has
55      * already been completed.
56      *
57      * @param p_Mapping The ActionMapping used to select this instance
58      * @param p_Form The optional ActionForm bean for this request (if any)
59      * @param p_Request The HTTP request we are processing
60      * @param p_Response The HTTP response we are creating
61      *
62      * @return An <code>ActionForward</code> instance or <code>null</code>
63      *
64      * @exception IOException if an input/output error occurs
65      * @exception ServletException if a servlet exception occurs
66      */

67     public ActionForward executeAction(ActionMapping p_Mapping, ActionForm p_Form
68         , HttpServletRequest JavaDoc p_Request, HttpServletResponse JavaDoc p_Response)
69         throws IOException JavaDoc, ServletException JavaDoc {
70         // Object name used
71
ObjectName JavaDoc oObjectName = null;
72         try {
73             oObjectName = J2eeObjectName.J2EEServer(m_WhereAreYou.getCurrentDomainName()
74                 , m_WhereAreYou.getCurrentJonasServerName());
75             // call method
76
JonasManagementRepr.invoke(oObjectName, "runGC", null, null);
77         }
78         catch (Throwable JavaDoc t) {
79             addGlobalError(t);
80             saveErrors(p_Request, m_Errors);
81             return (p_Mapping.findForward("Global Error"));
82         }
83
84         // Forward to the jsp.
85
return (p_Mapping.findForward("JonasServer"));
86     }
87 }
88
Popular Tags