You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@karaf.apache.org by jb...@apache.org on 2013/11/05 15:19:15 UTC

svn commit: r1539006 - in /karaf/branches/karaf-2.x: management/mbeans/dev/src/main/java/org/apache/karaf/management/mbeans/dev/ management/mbeans/dev/src/main/java/org/apache/karaf/management/mbeans/dev/internal/ shell/dev/src/main/java/org/apache/kar...

Author: jbonofre
Date: Tue Nov  5 14:19:15 2013
New Revision: 1539006

URL: http://svn.apache.org/r1539006
Log:
[KARAF-2474] Improve the DevMBean with system properties operations

Modified:
    karaf/branches/karaf-2.x/management/mbeans/dev/src/main/java/org/apache/karaf/management/mbeans/dev/DevMBean.java
    karaf/branches/karaf-2.x/management/mbeans/dev/src/main/java/org/apache/karaf/management/mbeans/dev/internal/DevMBeanImpl.java
    karaf/branches/karaf-2.x/shell/dev/src/main/java/org/apache/karaf/shell/dev/SystemProperty.java

Modified: karaf/branches/karaf-2.x/management/mbeans/dev/src/main/java/org/apache/karaf/management/mbeans/dev/DevMBean.java
URL: http://svn.apache.org/viewvc/karaf/branches/karaf-2.x/management/mbeans/dev/src/main/java/org/apache/karaf/management/mbeans/dev/DevMBean.java?rev=1539006&r1=1539005&r2=1539006&view=diff
==============================================================================
--- karaf/branches/karaf-2.x/management/mbeans/dev/src/main/java/org/apache/karaf/management/mbeans/dev/DevMBean.java (original)
+++ karaf/branches/karaf-2.x/management/mbeans/dev/src/main/java/org/apache/karaf/management/mbeans/dev/DevMBean.java Tue Nov  5 14:19:15 2013
@@ -13,6 +13,8 @@
  */
 package org.apache.karaf.management.mbeans.dev;
 
+import java.util.Map;
+
 /**
  * MBean providing dev actions.
  */
@@ -46,4 +48,29 @@ public interface DevMBean {
      */
     void restart(boolean clean) throws Exception;
 
+    /**
+     * Get system (and eventually OSGi) properties.
+     *
+     * @param unset if true, show the OSGi properties even if unset.
+     * @param dumpToFile if true, dump system properties into a file (in the data folder)
+     * @return the system properties
+     */
+    Map getProperties(boolean unset, boolean dumpToFile) throws Exception;
+
+    /**
+     * Get the value of a property.
+     * @param key the system property key.
+     * @return the system property value.
+     */
+    String getProperty(String key);
+
+    /**
+     * Set the value of a system property.
+     *
+     * @param key the system property key.
+     * @param value the system property value.
+     * @param persistent if true, persist the new value to the etc/system.properties file.
+     */
+    void setProperty(String key, String value, boolean persistent) throws Exception;
+
 }

Modified: karaf/branches/karaf-2.x/management/mbeans/dev/src/main/java/org/apache/karaf/management/mbeans/dev/internal/DevMBeanImpl.java
URL: http://svn.apache.org/viewvc/karaf/branches/karaf-2.x/management/mbeans/dev/src/main/java/org/apache/karaf/management/mbeans/dev/internal/DevMBeanImpl.java?rev=1539006&r1=1539005&r2=1539006&view=diff
==============================================================================
--- karaf/branches/karaf-2.x/management/mbeans/dev/src/main/java/org/apache/karaf/management/mbeans/dev/internal/DevMBeanImpl.java (original)
+++ karaf/branches/karaf-2.x/management/mbeans/dev/src/main/java/org/apache/karaf/management/mbeans/dev/internal/DevMBeanImpl.java Tue Nov  5 14:19:15 2013
@@ -16,14 +16,14 @@ package org.apache.karaf.management.mbea
 import org.apache.felix.utils.properties.Properties;
 import org.apache.karaf.management.mbeans.dev.DevMBean;
 import org.osgi.framework.BundleContext;
+import org.osgi.framework.Constants;
 
 import javax.management.NotCompliantMBeanException;
 import javax.management.StandardMBean;
 import java.io.File;
-import java.io.IOException;
-import java.io.InputStream;
-import java.io.PrintWriter;
-import java.util.Scanner;
+import java.io.PrintStream;
+import java.text.SimpleDateFormat;
+import java.util.*;
 
 /**
  * Implementation of the DevMBean.
@@ -78,4 +78,108 @@ public class DevMBeanImpl extends Standa
         bundleContext.getBundle(0).stop();
     }
 
+    public Map getProperties(boolean unset, boolean dumpToFile) throws Exception {
+        Map<String, String> result = new HashMap<String, String>();
+
+        java.util.Properties props = (java.util.Properties) System.getProperties().clone();
+
+        String def = null;
+        if (unset) {
+            def = "unset";
+        }
+
+        setProperty(props, Constants.FRAMEWORK_BEGINNING_STARTLEVEL, def);
+        setProperty(props, Constants.FRAMEWORK_BOOTDELEGATION, def);
+        setProperty(props, Constants.FRAMEWORK_BUNDLE_PARENT, def);
+        setProperty(props, Constants.FRAMEWORK_BUNDLE_PARENT_APP, def);
+        setProperty(props, Constants.FRAMEWORK_BUNDLE_PARENT_BOOT, def);
+        setProperty(props, Constants.FRAMEWORK_BUNDLE_PARENT_EXT, def);
+        setProperty(props, Constants.FRAMEWORK_BUNDLE_PARENT_FRAMEWORK, def);
+        setProperty(props, Constants.FRAMEWORK_EXECPERMISSION, def);
+        setProperty(props, Constants.FRAMEWORK_EXECUTIONENVIRONMENT, def);
+        setProperty(props, Constants.FRAMEWORK_LANGUAGE, def);
+        setProperty(props, Constants.FRAMEWORK_LIBRARY_EXTENSIONS, def);
+        setProperty(props, Constants.FRAMEWORK_OS_NAME, def);
+        setProperty(props, Constants.FRAMEWORK_OS_VERSION, def);
+        setProperty(props, Constants.FRAMEWORK_PROCESSOR, def);
+        setProperty(props, Constants.FRAMEWORK_SECURITY, def);
+        setProperty(props, Constants.FRAMEWORK_SECURITY_OSGI, def);
+        setProperty(props, Constants.FRAMEWORK_STORAGE, def);
+        setProperty(props, Constants.FRAMEWORK_STORAGE_CLEAN_ONFIRSTINIT, def);
+        setProperty(props, Constants.FRAMEWORK_SYSTEMPACKAGES, def);
+        setProperty(props, Constants.FRAMEWORK_SYSTEMPACKAGES_EXTRA, def);
+        setProperty(props, Constants.FRAMEWORK_VENDOR, def);
+        setProperty(props, Constants.FRAMEWORK_VERSION, def);
+        setProperty(props, Constants.FRAMEWORK_WINDOWSYSTEM, def);
+
+        setProperty(props, Constants.SUPPORTS_BOOTCLASSPATH_EXTENSION, def);
+        setProperty(props, Constants.SUPPORTS_FRAMEWORK_EXTENSION, def);
+        setProperty(props, Constants.SUPPORTS_FRAMEWORK_FRAGMENT, def);
+        setProperty(props, Constants.SUPPORTS_FRAMEWORK_REQUIREBUNDLE, def);
+
+        if (dumpToFile) {
+            PrintStream ps = new PrintStream(new File(bundleContext.getProperty("karaf.data"), "dump-properties-" + java.lang.System.currentTimeMillis() + ".properties"));
+            ps.println("#Dump of the System and OSGi properties");
+            ps.println("#Dump execute at " + new SimpleDateFormat().format(new Date()));
+            printOrderedProperties(props, ps);
+            ps.flush();
+            ps.close();
+        } else {
+            printOrderedProperties(props, result);
+        }
+
+        return result;
+    }
+
+    private void printOrderedProperties(java.util.Properties props, PrintStream out) {
+        Set<Object> keys = props.keySet();
+        Vector<String> order = new Vector<String>(keys.size());
+        for (Iterator<Object> i = keys.iterator(); i.hasNext(); ) {
+            Object str = (Object) i.next();
+            order.add((String) str);
+        }
+        Collections.sort(order);
+        for (Iterator<String> i = order.iterator(); i.hasNext(); ) {
+            String key = (String) i.next();
+            out.println(key + "=" + props.getProperty(key));
+        }
+    }
+
+    private void printOrderedProperties(java.util.Properties props, Map<String, String> result) {
+        Set<Object> keys = props.keySet();
+        Vector<String> order = new Vector<String>(keys.size());
+        for (Iterator<Object> i = keys.iterator(); i.hasNext(); ) {
+            Object str = (Object) i.next();
+            order.add((String) str);
+        }
+        Collections.sort(order);
+        for (Iterator<String> i = order.iterator(); i.hasNext(); ) {
+            String key = (String) i.next();
+            result.put(key, props.getProperty(key));
+        }
+    }
+
+    private void setProperty(java.util.Properties props, String key, String def) {
+        String val = bundleContext.getProperty(key);
+        if (val == null && def != null) {
+            props.setProperty(key, def);
+        } else if (val != null) {
+            props.setProperty(key, val);
+        }
+    }
+
+    public String getProperty(String key) {
+        return System.getProperty(key);
+    }
+
+    public void setProperty(String key, String value, boolean persistent) throws Exception {
+        if (persistent) {
+            String base = System.getProperty("karaf.base");
+            Properties props = new Properties(new File(base, "etc/system.properties"));
+            props.put(key, value);
+            props.save();
+        }
+        System.setProperty(key, value);
+    }
+
 }

Modified: karaf/branches/karaf-2.x/shell/dev/src/main/java/org/apache/karaf/shell/dev/SystemProperty.java
URL: http://svn.apache.org/viewvc/karaf/branches/karaf-2.x/shell/dev/src/main/java/org/apache/karaf/shell/dev/SystemProperty.java?rev=1539006&r1=1539005&r2=1539006&view=diff
==============================================================================
--- karaf/branches/karaf-2.x/shell/dev/src/main/java/org/apache/karaf/shell/dev/SystemProperty.java (original)
+++ karaf/branches/karaf-2.x/shell/dev/src/main/java/org/apache/karaf/shell/dev/SystemProperty.java Tue Nov  5 14:19:15 2013
@@ -96,7 +96,6 @@ public class SystemProperty extends Osgi
                 ps.flush();
                 ps.close();
             } else {
-                System.out.println("OSGi and System properties: ");
                 printOrderedProperties(props, System.out);
             }