All Downloads are FREE. Search and download functionalities are using the official Maven repository.

weka.experiment.remote.policy Maven / Gradle / Ivy

/* 
 * Necessary permissions for remote engines 
 *
 * Start Experimenter in directory /home/johndoe/remote_engine:
 *
 * java \
 *   -classpath /path to weka/weka.jar:/path to database jar/ \
 *   -Djava.rmi.server.codebase=file:/path to weka jar/weka.jar \
 *   weka.gui.experiment.Experimenter
 *
 * Start remote engine on remote machine: 
 * - cd to /path to dir containing remoteEngine.jar
 * - start engine
 *   java -Xmx256m \
 *     -classpath remoteEngine.jar:/path to database jar/:/path to weka/weka.jar \
 *     -Djava.security.policy=remote.policy \
 *      weka.experiment.RemoteEngine &
 *
 * Note:
 * replace  with actual jar filename, e.g., mysql.jar
 *
 * Version: $Revision: 13922 $
 */

grant {

  // allow the remote engine to replace the context class loader.
  // This enables the unloading of types from the remote engine
  permission java.lang.RuntimePermission
    "setContextClassLoader";

  // allow the remote engine access to environment variables
  permission java.lang.RuntimePermission
    "getenv.*";

  // allow the remote engine access to the class loader
  permission java.lang.RuntimePermission
    "getClassLoader";

  // the following three permissions allow the MLRClassifier
  // (from the RPlugin package) to work properly. They can be
  // omitted if you don't plan on using RPlugin with the remote
  // servers
  permission java.lang.RuntimePermission
    "createClassLoader";

  permission java.lang.RuntimePermission
    "accessDeclaredMembers";

  permission java.lang.reflect.ReflectPermission
    "suppressAccessChecks”;

  // file permission for data sets
  permission java.io.FilePermission
    "/path_to_data_sets/-", "read";

  // file permissions for downloading classes from client file url's
  //  permission java.io.FilePermission
  //	     "/joe user's path to weka classes/-", "read";
  //  permission java.io.FilePermission
  //	     "/jill user's path to weka classes/-", "read";

  // connect to or accept connections from unprivaleged ports and the http port
  permission java.net.SocketPermission 
    "*:1024-65535", "connect,accept,listen,resolve";
  permission java.net.SocketPermission 
    "*:80", "connect";

  // file permission to load server classes from remoteEngine.jar.
  // only needed if RemoteEngine_Skel.class/_Stub.class are going to
  // be downloaded by clients (ie, if these files are not already in the
  // client's classpath). Normally this doesn't need to be changed.
  permission java.io.FilePermission
    "/path_to_dir_containing_remoteEngine.jar/-", "read";

  // read write for properties
  permission java.util.PropertyPermission 
    "*", "read,write";
  
  // allow thread-based schemes to execute
  permission java.lang.RuntimePermission
    "modifyThread";
};






© 2015 - 2025 Weber Informatics LLC | Privacy Policy