mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-10-26 08:42:29 +01:00 
			
		
		
		
	CLOUDSTACK-10213: Allow specify SSH key lengh (#2389)
SSH keys generated by the ACS are only 1024 bit (RSA). The common standard is now at least 2048 bit.
This commit is contained in:
		
							parent
							
								
									981286f93c
								
							
						
					
					
						commit
						0d0fa5e306
					
				| @ -696,6 +696,8 @@ public class ManagementServerImpl extends ManagerBase implements ManagementServe | ||||
| 
 | ||||
|     static final ConfigKey<Integer> vmPasswordLength = new ConfigKey<Integer>("Advanced", Integer.class, "vm.password.length", "6", | ||||
|                                                                                       "Specifies the length of a randomly generated password", false); | ||||
|     static final ConfigKey<Integer> sshKeyLength = new ConfigKey<Integer>("Advanced", Integer.class, "ssh.key.length", | ||||
|             "2048", "Specifies custom SSH key length (bit)", true, ConfigKey.Scope.Global); | ||||
|     @Inject | ||||
|     public AccountManager _accountMgr; | ||||
|     @Inject | ||||
| @ -3051,7 +3053,7 @@ public class ManagementServerImpl extends ManagerBase implements ManagementServe | ||||
| 
 | ||||
|     @Override | ||||
|     public ConfigKey<?>[] getConfigKeys() { | ||||
|         return new ConfigKey<?>[] {vmPasswordLength}; | ||||
|         return new ConfigKey<?>[] {vmPasswordLength, sshKeyLength}; | ||||
|     } | ||||
| 
 | ||||
|     protected class EventPurgeTask extends ManagedContextRunnable { | ||||
| @ -3583,7 +3585,7 @@ public class ManagementServerImpl extends ManagerBase implements ManagementServe | ||||
|             throw new InvalidParameterValueException("A key pair with name '" + cmd.getName() + "' already exists."); | ||||
|         } | ||||
| 
 | ||||
|         final SSHKeysHelper keys = new SSHKeysHelper(); | ||||
|         final SSHKeysHelper keys = new SSHKeysHelper(sshKeyLength.value()); | ||||
| 
 | ||||
|         final String name = cmd.getName(); | ||||
|         final String publicKey = keys.getPublicKey(); | ||||
|  | ||||
| @ -43,9 +43,9 @@ public class SSHKeysHelper { | ||||
|         return sb.toString(); | ||||
|     } | ||||
| 
 | ||||
|     public SSHKeysHelper() { | ||||
|     public SSHKeysHelper(Integer keyLength) { | ||||
|         try { | ||||
|             keyPair = KeyPair.genKeyPair(new JSch(), KeyPair.RSA); | ||||
|             keyPair = KeyPair.genKeyPair(new JSch(), KeyPair.RSA, keyLength); | ||||
|         } catch (JSchException e) { | ||||
|             e.printStackTrace(); | ||||
|         } | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user