You are viewing a plain text version of this content. The canonical link for it is here.
Posted to scm@geronimo.apache.org by am...@apache.org on 2005/10/31 17:27:00 UTC
svn commit: r329847 -
/geronimo/trunk/modules/system/src/java/org/apache/geronimo/system/main/WebAppUtil.java
Author: ammulder
Date: Mon Oct 31 08:26:58 2005
New Revision: 329847
URL: http://svn.apache.org/viewcvs?rev=329847&view=rev
Log:
Whoops -- forgot the new file
Added:
geronimo/trunk/modules/system/src/java/org/apache/geronimo/system/main/WebAppUtil.java (with props)
Added: geronimo/trunk/modules/system/src/java/org/apache/geronimo/system/main/WebAppUtil.java
URL: http://svn.apache.org/viewcvs/geronimo/trunk/modules/system/src/java/org/apache/geronimo/system/main/WebAppUtil.java?rev=329847&view=auto
==============================================================================
--- geronimo/trunk/modules/system/src/java/org/apache/geronimo/system/main/WebAppUtil.java (added)
+++ geronimo/trunk/modules/system/src/java/org/apache/geronimo/system/main/WebAppUtil.java Mon Oct 31 08:26:58 2005
@@ -0,0 +1,71 @@
+/**
+ *
+ * Copyright 2003-2004 The Apache Software Foundation
+ *
+ * Licensed under the Apache License, Version 2.0 (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.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.geronimo.system.main;
+
+import org.apache.geronimo.kernel.Kernel;
+import org.apache.geronimo.gbean.GBeanQuery;
+
+import javax.management.ObjectName;
+import java.util.Map;
+import java.util.HashMap;
+import java.util.Set;
+import java.util.Iterator;
+
+/**
+ * Utility functions for dealing with web applications
+ *
+ * @version $Rev: 263979 $ $Date: 2005-08-28 21:02:11 -0400 (Sun, 28 Aug 2005) $
+ */
+public class WebAppUtil {
+ /**
+ * Generates a Map where the keys are web container object names (as Strings)
+ * and the values are URLs (as Strings) to connect to a web app running in
+ * the matching container (though the web app context needs to be added to
+ * the end to be complete).
+ *
+ * NOTE: same as a method in geronimo-jsr88 CommandSupport, but neither
+ * module should obviously be dependent on the other and it's not
+ * clear that this belongs in geronimo-common
+ */
+ public static Map mapContainersToURLs(Kernel kernel) throws Exception {
+ Map containers = new HashMap();
+ Set set = kernel.listGBeans(new GBeanQuery(null, "org.apache.geronimo.management.geronimo.WebManager"));
+ for (Iterator it = set.iterator(); it.hasNext();) {
+ ObjectName mgrName = (ObjectName) it.next();
+ String[] cntNames = (String[]) kernel.getAttribute(mgrName, "containers");
+ for (int i = 0; i < cntNames.length; i++) {
+ String cntName = cntNames[i];
+ String[] cncNames = (String[]) kernel.invoke(mgrName, "getConnectorsForContainer", new Object[]{cntName}, new String[]{"java.lang.String"});
+ Map map = new HashMap();
+ for (int j = 0; j < cncNames.length; j++) {
+ ObjectName cncName = ObjectName.getInstance(cncNames[j]);
+ String protocol = (String) kernel.getAttribute(cncName, "protocol");
+ String url = (String) kernel.getAttribute(cncName, "connectUrl");
+ map.put(protocol, url);
+ }
+ String urlPrefix = "";
+ if((urlPrefix = (String) map.get("HTTP")) == null) {
+ if((urlPrefix = (String) map.get("HTTPS")) == null) {
+ urlPrefix = (String) map.get("AJP");
+ }
+ }
+ containers.put(cntName, urlPrefix);
+ }
+ }
+ return containers;
+ }
+}
Propchange: geronimo/trunk/modules/system/src/java/org/apache/geronimo/system/main/WebAppUtil.java
------------------------------------------------------------------------------
svn:eol-style = native