01: /**
02: * JOnAS: Java(TM) Open Application Server
03: * Copyright (C) 1999 Bull S.A.
04: * Contact: jonas-team@objectweb.org
05: *
06: * This library is free software; you can redistribute it and/or
07: * modify it under the terms of the GNU Lesser General Public
08: * License as published by the Free Software Foundation; either
09: * 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: JonasServerStopAction.java 9680 2006-10-06 12:08:33Z danesa $
23: * --------------------------------------------------------------------------
24: */package org.objectweb.jonas.webapp.jonasadmin.jonasserver;
25:
26: import java.io.IOException;
27:
28: import javax.management.ObjectName;
29: import javax.servlet.ServletException;
30: import javax.servlet.http.HttpServletRequest;
31: import javax.servlet.http.HttpServletResponse;
32:
33: import org.apache.struts.action.ActionForm;
34: import org.apache.struts.action.ActionForward;
35: import org.apache.struts.action.ActionMapping;
36: import org.objectweb.jonas.jmx.J2eeObjectName;
37: import org.objectweb.jonas.jmx.JonasManagementRepr;
38: import org.objectweb.jonas.webapp.jonasadmin.JonasBaseAction;
39:
40: /**
41: * @author Michel-Ange Anton
42: */
43: public class JonasServerStopAction extends JonasBaseAction {
44:
45: // --------------------------------------------------------- Public Methods
46:
47: /**
48: * Process the specified HTTP request, and create the corresponding HTTP
49: * response (or forward to another web component that will create it).
50: * Return an <code>ActionForward</code> instance describing where and how
51: * control should be forwarded, or <code>null</code> if the response has
52: * already been completed.
53: *
54: * @param pMapping The ActionMapping used to select this instance
55: * @param pForm The optional ActionForm bean for this request (if any)
56: * @param pRequest The HTTP request we are processing
57: * @param pResponse The HTTP response we are creating
58: *
59: * @return An <code>ActionForward</code> instance or <code>null</code>
60: *
61: * @exception IOException if an input/output error occurs
62: * @exception ServletException if a servlet exception occurs
63: */
64: public ActionForward executeAction(ActionMapping pMapping,
65: ActionForm pForm, HttpServletRequest pRequest,
66: HttpServletResponse pResponse) throws IOException,
67: ServletException {
68: try {
69: // Object name used
70: String serverName = m_WhereAreYou
71: .getCurrentJonasServerName();
72: ObjectName oObjectName = J2eeObjectName.J2EEServer(
73: m_WhereAreYou.getCurrentDomainName(), serverName);
74: // call method
75: JonasManagementRepr.invoke(oObjectName, "stop", null, null,
76: serverName);
77: } catch (Throwable t) {
78: addGlobalError(t);
79: saveErrors(pRequest, m_Errors);
80: return (pMapping.findForward("Global Error"));
81: }
82:
83: // Forward to the jsp.
84: return (pMapping.findForward("JonasServer"));
85: }
86: }
|