mirror of https://github.com/apache/jclouds.git
Merge pull request #112 from ahgittin/682-admin-access-username-collision
682 admin access username collision
This commit is contained in:
commit
572e05d631
|
@ -35,6 +35,7 @@ import org.jclouds.scriptbuilder.domain.StatementList;
|
|||
import org.jclouds.scriptbuilder.statements.ssh.SshStatements;
|
||||
|
||||
import com.google.common.base.Function;
|
||||
import com.google.common.base.Preconditions;
|
||||
import com.google.common.base.Supplier;
|
||||
import com.google.common.base.Throwables;
|
||||
import com.google.common.collect.ImmutableList;
|
||||
|
@ -46,17 +47,26 @@ import com.google.inject.ImplementedBy;
|
|||
* Controls the administrative access to a node. By default, it will perform the following:
|
||||
*
|
||||
* <ul>
|
||||
* <li>setup a new admin user which folks should use as opposed to the built-in vcloud account</li>
|
||||
* <ul>
|
||||
* <li>associate a random password to account</li>
|
||||
* <ul>
|
||||
* <li>securely ( use sha 512 on client side and literally rewrite the shadow entry, rather than
|
||||
* pass password to OS in a script )</li>
|
||||
* <li>setup a new admin user which folks should use as opposed to any built-in account</li>
|
||||
* <ul>
|
||||
* <li>associate a random (or given) password to that account
|
||||
* <ul>
|
||||
* <li>securely (using sha 512 on client side and literally rewriting the shadow entry,
|
||||
* rather than sending password plaintext to OS in a script)</li>
|
||||
* <li>but note password access is often blocked in any case, see below</li>
|
||||
* </ul>
|
||||
* <li>associate the users' ssh public key with the account for login</li>
|
||||
* <li>associate it with the os group wheel</li>
|
||||
* </ul>
|
||||
* <li>set up sudoers for password-less access to root for this user (shouldGrantSudo)</li>
|
||||
* <ul>
|
||||
* <li>creating os group wheel and assigning the new admin user to it</li>
|
||||
* <li>create (overwriting) sudoers file to grant root access for wheel members</li>
|
||||
* </ul>
|
||||
* <li>reset password for the user logging in (e.g. root, because root password is
|
||||
* sometimes known to the provider), securely and randomly as described above (resetLoginPassword)</li>
|
||||
* <li>lockdown sshd_config for no root login, nor passwords allowed (lockSsh)</li>
|
||||
* </ul>
|
||||
* <li>associate the users' ssh public key with the account for login</li> <li>
|
||||
* associate it with the os group wheel</li> </ul> <li>create os group wheel</li> <li>add sudoers
|
||||
* for nopassword access to root by group wheel</li> <li>reset root password securely</li> <li>
|
||||
* lockdown sshd_config for no root login, nor passwords allowed</li> </ul>
|
||||
*
|
||||
* @author Adrian Cole
|
||||
*/
|
||||
|
@ -335,6 +345,8 @@ public class AdminAccess implements Statement {
|
|||
if (family == OsFamily.WINDOWS)
|
||||
throw new UnsupportedOperationException("windows not yet implemented");
|
||||
checkNotNull(config.getAdminUsername(), "adminUsername");
|
||||
Preconditions.checkArgument(!"root".equals(config.getAdminUsername()), "cannot create admin user 'root'; " +
|
||||
"ensure jclouds is not running as root, or specify an explicit non-root username in AdminAccess");
|
||||
checkNotNull(config.getAdminPassword(), "adminPassword");
|
||||
checkNotNull(config.getAdminPublicKey(), "adminPublicKey");
|
||||
checkNotNull(config.getAdminPrivateKey(), "adminPrivateKey");
|
||||
|
|
|
@ -51,9 +51,9 @@ public class DefaultConfiguration implements Configuration {
|
|||
@Override
|
||||
public Map<String, String> get() {
|
||||
try {
|
||||
return ImmutableMap.of("public",
|
||||
Files.toString(new File(System.getProperty("user.home") + "/.ssh/id_rsa.pub"), UTF_8), "private",
|
||||
Files.toString(new File(System.getProperty("user.home") + "/.ssh/id_rsa"), UTF_8));
|
||||
return ImmutableMap.of(
|
||||
"public", Files.toString(new File(System.getProperty("user.home") + "/.ssh/id_rsa.pub"), UTF_8),
|
||||
"private", Files.toString(new File(System.getProperty("user.home") + "/.ssh/id_rsa"), UTF_8));
|
||||
} catch (IOException e) {
|
||||
return SshKeys.generate();
|
||||
}
|
||||
|
|
|
@ -43,6 +43,13 @@ import com.google.common.collect.Lists;
|
|||
import com.google.inject.Inject;
|
||||
|
||||
/**
|
||||
* Creates a statement that will add a given user to a machine ("login"), with optional
|
||||
* password, groups, private key, and authorized keys.
|
||||
* <p>
|
||||
* This is supported on most *nix environments. Not currently supported on Windows.
|
||||
* <p>
|
||||
* Note that some places where this is used may have stricter requirements on the parameters
|
||||
* (for example {@link AdminAccess} requires password and keys).
|
||||
*
|
||||
* @author Adrian Cole
|
||||
*/
|
||||
|
@ -65,11 +72,13 @@ public class UserAdd implements Statement {
|
|||
return this;
|
||||
}
|
||||
|
||||
/** the username of the user to add (not the login to use when performing the add) */
|
||||
public UserAdd.Builder login(String login) {
|
||||
this.login = login;
|
||||
return this;
|
||||
}
|
||||
|
||||
/** the password to add for the user (not the password to use when logging in to perform the add) */
|
||||
public UserAdd.Builder password(String password) {
|
||||
this.password = password;
|
||||
return this;
|
||||
|
|
|
@ -76,4 +76,16 @@ public class AdminAccessTest {
|
|||
public void testCreateWheelWindowsNotSupported() {
|
||||
AdminAccess.standard().init(TestConfiguration.INSTANCE).render(OsFamily.WINDOWS);
|
||||
}
|
||||
|
||||
@Test(expectedExceptions=IllegalArgumentException.class)
|
||||
//for issue 682
|
||||
public void testRootNotAllowed() throws IOException {
|
||||
TestConfiguration.INSTANCE.reset();
|
||||
try {
|
||||
AdminAccess.builder().adminUsername("root").build().init(TestConfiguration.INSTANCE).render(OsFamily.UNIX);
|
||||
} finally {
|
||||
TestConfiguration.INSTANCE.reset();
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue