mirror of
				https://github.com/gyurix1968/guacamole-client.git
				synced 2025-10-31 09:03:21 +00:00 
			
		
		
		
	GUACAMOLE-1: Refactor org.glyptodon package/groupId to org.apache.
This commit is contained in:
		| @@ -0,0 +1,154 @@ | ||||
| /* | ||||
|  * Copyright (C) 2013 Glyptodon LLC | ||||
|  *  | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  *  | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  *  | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  */ | ||||
|  | ||||
| package org.apache.guacamole.environment; | ||||
|  | ||||
| import java.io.File; | ||||
| import java.util.Map; | ||||
| import org.apache.guacamole.GuacamoleException; | ||||
| import org.apache.guacamole.properties.BooleanGuacamoleProperty; | ||||
| import org.apache.guacamole.properties.GuacamoleProperty; | ||||
| import org.apache.guacamole.properties.IntegerGuacamoleProperty; | ||||
| import org.apache.guacamole.properties.StringGuacamoleProperty; | ||||
| import org.apache.guacamole.protocols.ProtocolInfo; | ||||
|  | ||||
| /** | ||||
|  * The environment of an arbitrary Guacamole instance, describing available | ||||
|  * protocols, configuration parameters, and the GUACAMOLE_HOME directory. | ||||
|  * | ||||
|  * @author Michael Jumper | ||||
|  */ | ||||
| public interface Environment { | ||||
|  | ||||
|     /** | ||||
|      * The hostname of the server where guacd (the Guacamole proxy server) is | ||||
|      * running. | ||||
|      */ | ||||
|     public static final StringGuacamoleProperty GUACD_HOSTNAME = new StringGuacamoleProperty() { | ||||
|  | ||||
|         @Override | ||||
|         public String getName() { return "guacd-hostname"; } | ||||
|  | ||||
|     }; | ||||
|  | ||||
|     /** | ||||
|      * The port that guacd (the Guacamole proxy server) is listening on. | ||||
|      */ | ||||
|     public static final IntegerGuacamoleProperty GUACD_PORT = new IntegerGuacamoleProperty() { | ||||
|  | ||||
|         @Override | ||||
|         public String getName() { return "guacd-port"; } | ||||
|  | ||||
|     }; | ||||
|  | ||||
|     /** | ||||
|      * Whether guacd requires SSL/TLS on connections. | ||||
|      */ | ||||
|     public static final BooleanGuacamoleProperty GUACD_SSL = new BooleanGuacamoleProperty() { | ||||
|  | ||||
|         @Override | ||||
|         public String getName() { return "guacd-ssl"; } | ||||
|  | ||||
|     }; | ||||
|  | ||||
|     /** | ||||
|      * Returns the Guacamole home directory as determined when this Environment | ||||
|      * object was created. The Guacamole home directory is found by checking, in | ||||
|      * order: the guacamole.home system property, the GUACAMOLE_HOME environment | ||||
|      * variable, and finally the .guacamole directory in the home directory of | ||||
|      * the user running the servlet container. | ||||
|      * | ||||
|      * @return The File representing the Guacamole home directory, which may | ||||
|      *         or may not exist, and may turn out to not be a directory. | ||||
|      */ | ||||
|     public File getGuacamoleHome(); | ||||
|  | ||||
|     /** | ||||
|      * Returns a map of all available protocols, where each key is the name of | ||||
|      * that protocol as would be passed to guacd during connection. | ||||
|      * | ||||
|      * @return A map of all available protocols. | ||||
|      */ | ||||
|     public Map<String, ProtocolInfo> getProtocols(); | ||||
|  | ||||
|     /** | ||||
|      * Returns the protocol having the given name. The name must be the | ||||
|      * protocol name as would be passed to guacd during connection. | ||||
|      * | ||||
|      * @param name The name of the protocol. | ||||
|      * @return The protocol having the given name, or null if no such | ||||
|      *         protocol is registered. | ||||
|      */ | ||||
|     public ProtocolInfo getProtocol(String name); | ||||
|  | ||||
|     /** | ||||
|      * Given a GuacamoleProperty, parses and returns the value set for that | ||||
|      * property in guacamole.properties, if any. | ||||
|      * | ||||
|      * @param <Type> The type that the given property is parsed into. | ||||
|      * @param property The property to read from guacamole.properties. | ||||
|      * @return The parsed value of the property as read from | ||||
|      *         guacamole.properties. | ||||
|      * @throws GuacamoleException If an error occurs while parsing the value | ||||
|      *                            for the given property in | ||||
|      *                            guacamole.properties. | ||||
|      */ | ||||
|     public <Type> Type getProperty(GuacamoleProperty<Type> property) | ||||
|             throws GuacamoleException; | ||||
|  | ||||
|     /** | ||||
|      * Given a GuacamoleProperty, parses and returns the value set for that | ||||
|      * property in guacamole.properties, if any. If no value is found, the | ||||
|      * provided default value is returned. | ||||
|      * | ||||
|      * @param <Type> The type that the given property is parsed into. | ||||
|      * @param property The property to read from guacamole.properties. | ||||
|      * @param defaultValue The value to return if no value was given in | ||||
|      *                     guacamole.properties. | ||||
|      * @return The parsed value of the property as read from | ||||
|      *         guacamole.properties, or the provided default value if no value | ||||
|      *         was found. | ||||
|      * @throws GuacamoleException If an error occurs while parsing the value | ||||
|      *                            for the given property in | ||||
|      *                            guacamole.properties. | ||||
|      */ | ||||
|     public <Type> Type getProperty(GuacamoleProperty<Type> property, | ||||
|             Type defaultValue) throws GuacamoleException; | ||||
|  | ||||
|     /** | ||||
|      * Given a GuacamoleProperty, parses and returns the value set for that | ||||
|      * property in guacamole.properties. An exception is thrown if the value | ||||
|      * is not provided. | ||||
|      * | ||||
|      * @param <Type> The type that the given property is parsed into. | ||||
|      * @param property The property to read from guacamole.properties. | ||||
|      * @return The parsed value of the property as read from | ||||
|      *         guacamole.properties. | ||||
|      * @throws GuacamoleException If an error occurs while parsing the value | ||||
|      *                            for the given property in | ||||
|      *                            guacamole.properties, or if the property is | ||||
|      *                            not specified. | ||||
|      */ | ||||
|     public <Type> Type getRequiredProperty(GuacamoleProperty<Type> property) | ||||
|             throws GuacamoleException; | ||||
|  | ||||
| } | ||||
| @@ -0,0 +1,321 @@ | ||||
| /* | ||||
|  * Copyright (C) 2013 Glyptodon LLC | ||||
|  *  | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  *  | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  *  | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  */ | ||||
|  | ||||
| package org.apache.guacamole.environment; | ||||
|  | ||||
| import java.io.File; | ||||
| import java.io.FileInputStream; | ||||
| import java.io.FilenameFilter; | ||||
| import java.io.IOException; | ||||
| import java.io.InputStream; | ||||
| import java.util.HashMap; | ||||
| import java.util.Map; | ||||
| import java.util.Properties; | ||||
| import org.codehaus.jackson.map.ObjectMapper; | ||||
| import org.apache.guacamole.GuacamoleException; | ||||
| import org.apache.guacamole.GuacamoleServerException; | ||||
| import org.apache.guacamole.properties.GuacamoleProperty; | ||||
| import org.apache.guacamole.protocols.ProtocolInfo; | ||||
| import org.slf4j.Logger; | ||||
| import org.slf4j.LoggerFactory; | ||||
|  | ||||
| /** | ||||
|  * The environment of the locally-running Guacamole instance, describing | ||||
|  * available protocols, configuration parameters, and the GUACAMOLE_HOME | ||||
|  * directory. | ||||
|  * | ||||
|  * @author Michael Jumper | ||||
|  */ | ||||
| public class LocalEnvironment implements Environment { | ||||
|  | ||||
|     /** | ||||
|      * Logger for this class. | ||||
|      */ | ||||
|     private static final Logger logger = LoggerFactory.getLogger(LocalEnvironment.class); | ||||
|  | ||||
|     /** | ||||
|      * Array of all known protocol names. | ||||
|      */ | ||||
|     private static final String[] KNOWN_PROTOCOLS = new String[]{ | ||||
|         "vnc", "rdp", "ssh", "telnet"}; | ||||
|  | ||||
|     /** | ||||
|      * All properties read from guacamole.properties. | ||||
|      */ | ||||
|     private final Properties properties; | ||||
|  | ||||
|     /** | ||||
|      * The location of GUACAMOLE_HOME, which may not truly exist. | ||||
|      */ | ||||
|     private final File guacHome; | ||||
|  | ||||
|     /** | ||||
|      * The map of all available protocols. | ||||
|      */ | ||||
|     private final Map<String, ProtocolInfo> availableProtocols; | ||||
|  | ||||
|     /** | ||||
|      * The Jackson parser for parsing JSON files. | ||||
|      */ | ||||
|     private static final ObjectMapper mapper = new ObjectMapper(); | ||||
|  | ||||
|     /** | ||||
|      * Creates a new Environment, initializing that environment based on the | ||||
|      * location of GUACAMOLE_HOME and the contents of guacamole.properties. | ||||
|      *  | ||||
|      * @throws GuacamoleException If an error occurs while determining the | ||||
|      *                            environment of this Guacamole instance. | ||||
|      */ | ||||
|     public LocalEnvironment() throws GuacamoleException { | ||||
|  | ||||
|         // Determine location of GUACAMOLE_HOME | ||||
|         guacHome = findGuacamoleHome(); | ||||
|  | ||||
|         // Read properties | ||||
|         properties = new Properties(); | ||||
|         try { | ||||
|  | ||||
|             InputStream stream = null; | ||||
|  | ||||
|             // If not a directory, load from classpath | ||||
|             if (!guacHome.isDirectory()) | ||||
|                 stream = LocalEnvironment.class.getResourceAsStream("/guacamole.properties"); | ||||
|  | ||||
|             // Otherwise, try to load from file | ||||
|             else { | ||||
|                 File propertiesFile = new File(guacHome, "guacamole.properties"); | ||||
|                 if (propertiesFile.exists()) | ||||
|                     stream = new FileInputStream(propertiesFile); | ||||
|             } | ||||
|  | ||||
|             // Load properties from stream, if any, always closing stream when done | ||||
|             if (stream != null) { | ||||
|                 try { properties.load(stream); } | ||||
|                 finally { stream.close(); } | ||||
|             } | ||||
|  | ||||
|             // Notify if we're proceeding without guacamole.properties | ||||
|             else | ||||
|                 logger.info("No guacamole.properties file found within GUACAMOLE_HOME or the classpath. Using defaults."); | ||||
|  | ||||
|         } | ||||
|         catch (IOException e) { | ||||
|             logger.warn("The guacamole.properties file within GUACAMOLE_HOME cannot be read: {}", e.getMessage()); | ||||
|             logger.debug("Error reading guacamole.properties.", e); | ||||
|         } | ||||
|  | ||||
|         // Read all protocols | ||||
|         availableProtocols = readProtocols(); | ||||
|  | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Locates the Guacamole home directory by checking, in order: | ||||
|      * the guacamole.home system property, the GUACAMOLE_HOME environment | ||||
|      * variable, and finally the .guacamole directory in the home directory of | ||||
|      * the user running the servlet container. | ||||
|      * | ||||
|      * @return The File representing the Guacamole home directory, which may | ||||
|      *         or may not exist, and may turn out to not be a directory. | ||||
|      */ | ||||
|     private static File findGuacamoleHome() { | ||||
|  | ||||
|         // Attempt to find Guacamole home | ||||
|         File guacHome; | ||||
|  | ||||
|         // Use system property by default | ||||
|         String desiredDir = System.getProperty("guacamole.home"); | ||||
|  | ||||
|         // Failing that, try the GUACAMOLE_HOME environment variable | ||||
|         if (desiredDir == null) desiredDir = System.getenv("GUACAMOLE_HOME"); | ||||
|  | ||||
|         // If successful, use explicitly specified directory | ||||
|         if (desiredDir != null) | ||||
|             guacHome = new File(desiredDir); | ||||
|  | ||||
|         // If not explicitly specified, use ~/.guacamole | ||||
|         else | ||||
|             guacHome = new File(System.getProperty("user.home"), ".guacamole"); | ||||
|  | ||||
|         // Return discovered directory | ||||
|         return guacHome; | ||||
|  | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Parses the given JSON file, returning the parsed ProtocolInfo. The JSON | ||||
|      * format is conveniently and intentionally identical to a serialized | ||||
|      * ProtocolInfo object, which is identical to the JSON format used by the | ||||
|      * protocol REST service built into the Guacamole web application. | ||||
|      * | ||||
|      * @param input | ||||
|      *     An input stream containing JSON describing the forms and parameters | ||||
|      *     associated with a protocol supported by Guacamole. | ||||
|      * | ||||
|      * @return | ||||
|      *     A new ProtocolInfo object which contains the forms and parameters | ||||
|      *     described by the JSON file parsed. | ||||
|      * | ||||
|      * @throws IOException | ||||
|      *     If an error occurs while parsing the JSON file. | ||||
|      */ | ||||
|     private ProtocolInfo readProtocol(InputStream input) | ||||
|             throws IOException { | ||||
|         return mapper.readValue(input, ProtocolInfo.class); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Reads through all pre-defined protocols and any protocols within the | ||||
|      * "protocols" subdirectory of GUACAMOLE_HOME, returning a map containing | ||||
|      * each of these protocols. The key of each entry will be the name of that | ||||
|      * protocol, as would be passed to guacd during connection. | ||||
|      * | ||||
|      * @return | ||||
|      *     A map of all available protocols. | ||||
|      */ | ||||
|     private Map<String, ProtocolInfo> readProtocols() { | ||||
|  | ||||
|         // Map of all available protocols | ||||
|         Map<String, ProtocolInfo> protocols = new HashMap<String, ProtocolInfo>(); | ||||
|  | ||||
|         // Get protcols directory | ||||
|         File protocol_directory = new File(getGuacamoleHome(), "protocols"); | ||||
|  | ||||
|         // Read protocols from directory if it exists | ||||
|         if (protocol_directory.isDirectory()) { | ||||
|  | ||||
|             // Get all JSON files | ||||
|             File[] files = protocol_directory.listFiles( | ||||
|                 new FilenameFilter() { | ||||
|  | ||||
|                     @Override | ||||
|                     public boolean accept(File file, String string) { | ||||
|                         return string.endsWith(".json"); | ||||
|                     } | ||||
|  | ||||
|                 } | ||||
|             ); | ||||
|  | ||||
|             // Warn if directory contents are not available | ||||
|             if (files == null) { | ||||
|                 logger.error("Unable to read contents of \"{}\".", protocol_directory.getAbsolutePath()); | ||||
|                 files = new File[0]; | ||||
|             } | ||||
|              | ||||
|             // Load each protocol from each file | ||||
|             for (File file : files) { | ||||
|  | ||||
|                 try { | ||||
|  | ||||
|                     // Parse protocol | ||||
|                     FileInputStream stream = new FileInputStream(file); | ||||
|                     ProtocolInfo protocol = readProtocol(stream); | ||||
|                     stream.close(); | ||||
|  | ||||
|                     // Store protocol | ||||
|                     protocols.put(protocol.getName(), protocol); | ||||
|  | ||||
|                 } | ||||
|                 catch (IOException e) { | ||||
|                     logger.error("Unable to read connection parameter information from \"{}\": {}", file.getAbsolutePath(), e.getMessage()); | ||||
|                     logger.debug("Error reading protocol JSON.", e); | ||||
|                 } | ||||
|  | ||||
|             } | ||||
|  | ||||
|         } | ||||
|  | ||||
|         // If known protocols are not already defined, read from classpath | ||||
|         for (String protocol : KNOWN_PROTOCOLS) { | ||||
|  | ||||
|             // If protocol not defined yet, attempt to load from classpath | ||||
|             if (!protocols.containsKey(protocol)) { | ||||
|  | ||||
|                 InputStream stream = LocalEnvironment.class.getResourceAsStream( | ||||
|                         "/org/apache/guacamole/protocols/" | ||||
|                         + protocol + ".json"); | ||||
|  | ||||
|                 // Parse JSON if available | ||||
|                 if (stream != null) { | ||||
|                     try { | ||||
|                         protocols.put(protocol, readProtocol(stream)); | ||||
|                     } | ||||
|                     catch (IOException e) { | ||||
|                         logger.error("Unable to read pre-defined connection parameter information for protocol \"{}\": {}", protocol, e.getMessage()); | ||||
|                         logger.debug("Error reading pre-defined protocol JSON.", e); | ||||
|                     } | ||||
|                 } | ||||
|  | ||||
|             } | ||||
|  | ||||
|         } | ||||
|  | ||||
|         // Protocols map now fully populated | ||||
|         return protocols; | ||||
|  | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public File getGuacamoleHome() { | ||||
|         return guacHome; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public <Type> Type getProperty(GuacamoleProperty<Type> property) throws GuacamoleException { | ||||
|         return property.parseValue(properties.getProperty(property.getName())); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public <Type> Type getProperty(GuacamoleProperty<Type> property, | ||||
|             Type defaultValue) throws GuacamoleException { | ||||
|  | ||||
|         Type value = getProperty(property); | ||||
|         if (value == null) | ||||
|             return defaultValue; | ||||
|  | ||||
|         return value; | ||||
|  | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public <Type> Type getRequiredProperty(GuacamoleProperty<Type> property) | ||||
|             throws GuacamoleException { | ||||
|  | ||||
|         Type value = getProperty(property); | ||||
|         if (value == null) | ||||
|             throw new GuacamoleServerException("Property " + property.getName() + " is required."); | ||||
|  | ||||
|         return value; | ||||
|  | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public Map<String, ProtocolInfo> getProtocols() { | ||||
|         return availableProtocols; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public ProtocolInfo getProtocol(String name) { | ||||
|         return availableProtocols.get(name); | ||||
|     } | ||||
|  | ||||
| } | ||||
		Reference in New Issue
	
	Block a user