Load proxy settings though external *.properties files
[phpeclipse.git] / archive / net.sourceforge.phpeclipse.wiki / src / net / sourceforge / phpeclipse / wiki / editor / WikiEditorPlugin.java
index 099922a..915af72 100644 (file)
@@ -1,6 +1,7 @@
 package net.sourceforge.phpeclipse.wiki.editor;
 
 import java.io.IOException;
+import java.io.InputStream;
 import java.lang.reflect.InvocationTargetException;
 import java.lang.reflect.Method;
 import java.net.MalformedURLException;
@@ -8,9 +9,11 @@ import java.net.URL;
 import java.sql.SQLException;
 import java.text.MessageFormat;
 import java.util.ArrayList;
+import java.util.Enumeration;
 import java.util.Hashtable;
 import java.util.List;
 import java.util.MissingResourceException;
+import java.util.PropertyResourceBundle;
 import java.util.ResourceBundle;
 
 import net.sourceforge.phpeclipse.wiki.actions.mediawiki.config.IWikipedia;
@@ -24,6 +27,7 @@ import org.eclipse.core.runtime.CoreException;
 import org.eclipse.core.runtime.IExtension;
 import org.eclipse.core.runtime.IPluginDescriptor;
 import org.eclipse.core.runtime.IStatus;
+import org.eclipse.core.runtime.Path;
 import org.eclipse.core.runtime.Platform;
 import org.eclipse.core.runtime.Status;
 import org.eclipse.jface.dialogs.MessageDialog;
@@ -48,10 +52,13 @@ public class WikiEditorPlugin extends AbstractUIPlugin {
   public final static String AUTOMATICALLY_CREATED = "<!-- automatically created -->";
 
   public final static String WP_EXTENSION = "wp";
+
   public final static String XML_START_1 = "<?xml version=\"1.0\" encoding=\"";
-  public final static String XML_START_2 = "\" ?>\n"
-    + "<mediawiki version=\"0.1\">\n";
-  public final static String XML_END ="\n</mediawiki>";
+
+  public final static String XML_START_2 = "\" ?>\n" + "<mediawiki version=\"0.1\">\n";
+
+  public final static String XML_END = "\n</mediawiki>";
+
   public static final String PREFIX_LOAD = "Load ";
 
   public static final String PREFIX_STORE = "Store ";
@@ -129,11 +136,21 @@ public class WikiEditorPlugin extends AbstractUIPlugin {
   public final static String LOCAL_CSS_URL = "__local_css_url";
 
   public final static String EXPORT_CSS_URL = "__export_css_url";
+
   public final static String PREF_STRING_CONFIGURATIONS = "__configurations4";
-  
+
   public final static String CONSOLE_OUTPUT = "__console_output";
 
+  public final static String HTTP_TIMEOUT = "http.timeout";
+
+  public final static String HTTP_PROXYHOST = "http.proxyHost";
+
+  public final static String HTTP_PROXYPORT = "http.proxyPort";
+
+  public final static String HTTP_PROXYUSERNAME = "http.proxyUserName";
+
+  public final static String HTTP_PROXYPASSWORD = "http.proxyPassword";
+
   public final static String CONFIG_MEMENTO = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>" + "<configurations>"
       + "<config name=\"Google Search\" type-id=\"HTTP Query\" url=\"http://www.google.com/search?q=$text.selection\"/>"
       + "<config name=\"Koders.com Search\" type-id=\"HTTP Query\" url=\"http://koders.com/?s=$text.selection\"/>"
@@ -319,6 +336,17 @@ public class WikiEditorPlugin extends AbstractUIPlugin {
     return fTemplateStore;
   }
 
+  private static boolean isDefined(String test) {
+    if (test != null && test.length() > 0) {
+      for (int i = 0; i < test.length(); i++) {
+        if (!Character.isWhitespace(test.charAt(i))) {
+          return false;
+        }
+      }
+    }
+    return true;
+  }
+
   /*
    * (non-Javadoc)
    * 
@@ -327,6 +355,80 @@ public class WikiEditorPlugin extends AbstractUIPlugin {
   protected void initializeDefaultPreferences(IPreferenceStore store) {
     store.setDefault(PREF_STRING_CONFIGURATIONS, CONFIG_MEMENTO);
     store.setDefault(CONSOLE_OUTPUT, "true");
+
+    String operatingSystem = Platform.getOS();
+    // operatingSystem ==> maxosx, linux, solaris, win32,...
+    try {
+      InputStream is = getDefault().openStream(new Path("prefs/default_" + operatingSystem + ".properties"));
+      PropertyResourceBundle resourceBundle = new PropertyResourceBundle(is);
+
+      String key = HTTP_TIMEOUT;
+      try {
+        String timeout = resourceBundle.getString(key);
+        int val = Integer.parseInt(timeout);
+        if (val > 0) {
+          val *= 1000;
+        } else {
+          val = 30000;
+        }
+        store.setDefault(key, Integer.toString(val));
+      } catch (Exception e) {
+        store.setDefault(key, "30000"); // 30 seconds timeout
+      }
+
+      key = HTTP_PROXYHOST;
+      try {
+        String proxyHost = resourceBundle.getString(key);
+        if (isDefined(proxyHost)) {
+          store.setDefault(key, proxyHost);
+        } else {
+          store.setDefault(key, System.getProperty(key, ""));
+        }
+      } catch (Exception e) {
+        store.setDefault(key, System.getProperty(key, ""));
+      }
+
+      key = HTTP_PROXYPORT;
+      try {
+        String proxyPort = resourceBundle.getString(key);
+        if (isDefined(proxyPort)) {
+          // check for integer parse exception:
+          Integer.parseInt(proxyPort);
+          store.setDefault(key, proxyPort);
+        } else {
+          store.setDefault(key, System.getProperty(key, "80"));
+        }
+      } catch (Exception e) {
+        store.setDefault(key, System.getProperty(key, "80"));
+      }
+
+      key = HTTP_PROXYUSERNAME;
+      try {
+        String proxyUserName = resourceBundle.getString(key);
+        if (isDefined(proxyUserName)) {
+          store.setDefault(key, proxyUserName);
+        } else {
+          store.setDefault(key, System.getProperty(key, ""));
+        }
+      } catch (Exception e) {
+        store.setDefault(key, System.getProperty(key, ""));
+      }
+
+      key = HTTP_PROXYPASSWORD;
+      try {
+        String proxyPassWord = resourceBundle.getString(key);
+        if (isDefined(proxyPassWord)) {
+          store.setDefault(key, proxyPassWord);
+        } else {
+          store.setDefault(key, System.getProperty(key, ""));
+        }
+      } catch (Exception e) {
+        store.setDefault(key, System.getProperty(key, ""));
+      }
+      
+    } catch (Exception e) {
+    }
+
   }
 
   /*
@@ -381,7 +483,7 @@ public class WikiEditorPlugin extends AbstractUIPlugin {
 
   public void reportError(String title, String message) {
     try {
-//      Shell shell = PlatformUI.getWorkbench().getActiveWorkbenchWindow().getShell();
+      //      Shell shell = PlatformUI.getWorkbench().getActiveWorkbenchWindow().getShell();
       MessageDialog.openError(null, title, message);
     } catch (RuntimeException e) {
       log(e.getLocalizedMessage(), e);