GUACAMOLE-1: Rename Basic* to File* for default authentication provider. Deprecate "basic-user-mapping" property.

This commit is contained in:
Michael Jumper
2016-03-22 14:50:02 -07:00
parent cbe3387d92
commit 8590a0a492
11 changed files with 32 additions and 55 deletions

View File

@@ -1,27 +0,0 @@
/*
* 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.
*/
/**
* Classes related to parsing the user-mapping.xml file.
*/
package org.apache.guacamole.auth.basic;

View File

@@ -20,7 +20,7 @@
* THE SOFTWARE. * THE SOFTWARE.
*/ */
package org.apache.guacamole.auth; package org.apache.guacamole.auth.file;
import java.io.UnsupportedEncodingException; import java.io.UnsupportedEncodingException;
import java.security.MessageDigest; import java.security.MessageDigest;

View File

@@ -20,10 +20,8 @@
* THE SOFTWARE. * THE SOFTWARE.
*/ */
package org.apache.guacamole.auth.basic; package org.apache.guacamole.auth.file;
import org.apache.guacamole.auth.Authorization;
import org.apache.guacamole.auth.UserMapping;
import org.apache.guacamole.xml.TagHandler; import org.apache.guacamole.xml.TagHandler;
import org.apache.guacamole.protocol.GuacamoleConfiguration; import org.apache.guacamole.protocol.GuacamoleConfiguration;
import org.xml.sax.Attributes; import org.xml.sax.Attributes;

View File

@@ -20,9 +20,8 @@
* THE SOFTWARE. * THE SOFTWARE.
*/ */
package org.apache.guacamole.auth.basic; package org.apache.guacamole.auth.file;
import org.apache.guacamole.auth.Authorization;
import org.apache.guacamole.xml.TagHandler; import org.apache.guacamole.xml.TagHandler;
import org.apache.guacamole.protocol.GuacamoleConfiguration; import org.apache.guacamole.protocol.GuacamoleConfiguration;
import org.xml.sax.Attributes; import org.xml.sax.Attributes;

View File

@@ -20,7 +20,7 @@
* THE SOFTWARE. * THE SOFTWARE.
*/ */
package org.apache.guacamole.auth.basic; package org.apache.guacamole.auth.file;
import java.io.BufferedInputStream; import java.io.BufferedInputStream;
import java.io.File; import java.io.File;
@@ -29,13 +29,10 @@ import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.util.Map; import java.util.Map;
import org.apache.guacamole.GuacamoleException; import org.apache.guacamole.GuacamoleException;
import org.apache.guacamole.GuacamoleException;
import org.apache.guacamole.environment.Environment; import org.apache.guacamole.environment.Environment;
import org.apache.guacamole.environment.LocalEnvironment; import org.apache.guacamole.environment.LocalEnvironment;
import org.apache.guacamole.net.auth.Credentials; import org.apache.guacamole.net.auth.Credentials;
import org.apache.guacamole.net.auth.simple.SimpleAuthenticationProvider; import org.apache.guacamole.net.auth.simple.SimpleAuthenticationProvider;
import org.apache.guacamole.auth.Authorization;
import org.apache.guacamole.auth.UserMapping;
import org.apache.guacamole.xml.DocumentHandler; import org.apache.guacamole.xml.DocumentHandler;
import org.apache.guacamole.properties.FileGuacamoleProperty; import org.apache.guacamole.properties.FileGuacamoleProperty;
import org.apache.guacamole.protocol.GuacamoleConfiguration; import org.apache.guacamole.protocol.GuacamoleConfiguration;
@@ -53,12 +50,12 @@ import org.xml.sax.helpers.XMLReaderFactory;
* *
* @author Michael Jumper, Michal Kotas * @author Michael Jumper, Michal Kotas
*/ */
public class BasicFileAuthenticationProvider extends SimpleAuthenticationProvider { public class FileAuthenticationProvider extends SimpleAuthenticationProvider {
/** /**
* Logger for this class. * Logger for this class.
*/ */
private final Logger logger = LoggerFactory.getLogger(BasicFileAuthenticationProvider.class); private final Logger logger = LoggerFactory.getLogger(FileAuthenticationProvider.class);
/** /**
* The time the user mapping file was last modified. If the file has never * The time the user mapping file was last modified. If the file has never
@@ -78,8 +75,12 @@ public class BasicFileAuthenticationProvider extends SimpleAuthenticationProvide
private final Environment environment; private final Environment environment;
/** /**
* The XML file to read the user mapping from. * The XML file to read the user mapping from. This property has been
* deprecated, as the name "basic" is ridiculous, and providing for
* configurable user-mapping.xml locations is unnecessary complexity. Use
* GUACAMOLE_HOME/user-mapping.xml instead.
*/ */
@Deprecated
public static final FileGuacamoleProperty BASIC_USER_MAPPING = new FileGuacamoleProperty() { public static final FileGuacamoleProperty BASIC_USER_MAPPING = new FileGuacamoleProperty() {
@Override @Override
@@ -88,10 +89,9 @@ public class BasicFileAuthenticationProvider extends SimpleAuthenticationProvide
}; };
/** /**
* The default filename to use for the user mapping, if not defined within * The filename to use for the user mapping.
* guacamole.properties.
*/ */
public static final String DEFAULT_USER_MAPPING = "user-mapping.xml"; public static final String USER_MAPPING_FILENAME = "user-mapping.xml";
/** /**
* Creates a new BasicFileAuthenticationProvider that authenticates users * Creates a new BasicFileAuthenticationProvider that authenticates users
@@ -101,7 +101,7 @@ public class BasicFileAuthenticationProvider extends SimpleAuthenticationProvide
* If a required property is missing, or an error occurs while parsing * If a required property is missing, or an error occurs while parsing
* a property. * a property.
*/ */
public BasicFileAuthenticationProvider() throws GuacamoleException { public FileAuthenticationProvider() throws GuacamoleException {
environment = new LocalEnvironment(); environment = new LocalEnvironment();
} }
@@ -120,14 +120,22 @@ public class BasicFileAuthenticationProvider extends SimpleAuthenticationProvide
* A UserMapping containing all authorization data within the user * A UserMapping containing all authorization data within the user
* mapping XML file, or null if the file cannot be found/parsed. * mapping XML file, or null if the file cannot be found/parsed.
*/ */
@SuppressWarnings("deprecation") // We must continue to use the "basic-user-mapping" property until it is truly no longer supported
private UserMapping getUserMapping() { private UserMapping getUserMapping() {
// Get user mapping file, defaulting to GUACAMOLE_HOME/user-mapping.xml // Get user mapping file, defaulting to GUACAMOLE_HOME/user-mapping.xml
File userMappingFile; File userMappingFile;
try { try {
// Continue supporting deprecated property, but warn in the logs
userMappingFile = environment.getProperty(BASIC_USER_MAPPING); userMappingFile = environment.getProperty(BASIC_USER_MAPPING);
if (userMappingFile != null)
logger.warn("The \"basic-user-mapping\" property is deprecated. Please use the \"GUACAMOLE_HOME/user-mapping.xml\" file instead.");
// Read user mapping from GUACAMOLE_HOME
if (userMappingFile == null) if (userMappingFile == null)
userMappingFile = new File(environment.getGuacamoleHome(), DEFAULT_USER_MAPPING); userMappingFile = new File(environment.getGuacamoleHome(), USER_MAPPING_FILENAME);
} }
// Abort if property cannot be parsed // Abort if property cannot be parsed

View File

@@ -20,7 +20,7 @@
* THE SOFTWARE. * THE SOFTWARE.
*/ */
package org.apache.guacamole.auth.basic; package org.apache.guacamole.auth.file;
import org.apache.guacamole.xml.TagHandler; import org.apache.guacamole.xml.TagHandler;
import org.apache.guacamole.protocol.GuacamoleConfiguration; import org.apache.guacamole.protocol.GuacamoleConfiguration;

View File

@@ -20,7 +20,7 @@
* THE SOFTWARE. * THE SOFTWARE.
*/ */
package org.apache.guacamole.auth.basic; package org.apache.guacamole.auth.file;
import org.apache.guacamole.xml.TagHandler; import org.apache.guacamole.xml.TagHandler;
import org.apache.guacamole.protocol.GuacamoleConfiguration; import org.apache.guacamole.protocol.GuacamoleConfiguration;

View File

@@ -20,7 +20,7 @@
* THE SOFTWARE. * THE SOFTWARE.
*/ */
package org.apache.guacamole.auth; package org.apache.guacamole.auth.file;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;

View File

@@ -20,9 +20,8 @@
* THE SOFTWARE. * THE SOFTWARE.
*/ */
package org.apache.guacamole.auth.basic; package org.apache.guacamole.auth.file;
import org.apache.guacamole.auth.UserMapping;
import org.apache.guacamole.xml.TagHandler; import org.apache.guacamole.xml.TagHandler;
import org.xml.sax.Attributes; import org.xml.sax.Attributes;
import org.xml.sax.SAXException; import org.xml.sax.SAXException;

View File

@@ -21,8 +21,8 @@
*/ */
/** /**
* Classes which drive the default, basic authentication of the Guacamole * Classes which drive the default, file-based authentication of the Guacamole
* web application. * web application.
*/ */
package org.apache.guacamole.auth; package org.apache.guacamole.auth.file;

View File

@@ -32,7 +32,7 @@ import java.util.Collection;
import java.util.Collections; import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import org.apache.guacamole.auth.basic.BasicFileAuthenticationProvider; import org.apache.guacamole.auth.file.FileAuthenticationProvider;
import org.apache.guacamole.GuacamoleException; import org.apache.guacamole.GuacamoleException;
import org.apache.guacamole.GuacamoleServerException; import org.apache.guacamole.GuacamoleServerException;
import org.apache.guacamole.environment.Environment; import org.apache.guacamole.environment.Environment;
@@ -426,8 +426,8 @@ public class ExtensionModule extends ServletModule {
// Load all extensions // Load all extensions
loadExtensions(javaScriptResources, cssResources); loadExtensions(javaScriptResources, cssResources);
// Always bind basic auth last // Always bind default file-driven auth last
bindAuthenticationProvider(BasicFileAuthenticationProvider.class); bindAuthenticationProvider(FileAuthenticationProvider.class);
// Dynamically generate app.js and app.css from extensions // Dynamically generate app.js and app.css from extensions
serve("/app.js").with(new ResourceServlet(new SequenceResource(javaScriptResources))); serve("/app.js").with(new ResourceServlet(new SequenceResource(javaScriptResources)));