1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-02 02:40:58 +01:00

Update preallocated hosts to use Passphrase credentials

Summary: Depends on D7695.  This updates preallocated hosts to use Passphrase credentials.  Due to the way SSH private key text credentials work (the TempFile disappears before SSH commands can be executed), this only supports file-based private keys at the moment.

Test Plan:
Created a Passphrase credential for a file-based SSH key.  Allocated a resource with:

```
bin/drydock create-resource --blueprint 1 --name "My Linux Host" --attributes platform=linux,host=localhost,port=22,path=/var/drydock,credential=2
```

and successfully leased it.

Reviewers: epriestley, #blessed_reviewers

Reviewed By: epriestley

CC: Korvin, epriestley, aran

Maniphest Tasks: T4111, T1049

Differential Revision: https://secure.phabricator.com/D7697
This commit is contained in:
James Rhodes 2013-12-05 08:17:23 +11:00
parent 1f53017f1f
commit 9c6f6043f0
2 changed files with 27 additions and 20 deletions

View file

@ -41,12 +41,12 @@ final class DrydockPreallocatedHostBlueprintImplementation
// we have all the information we need. // we have all the information we need.
PhutilTypeSpec::checkMap( PhutilTypeSpec::checkMap(
$resource->getAttributesForTypeSpec( $resource->getAttributesForTypeSpec(
array('platform', 'host', 'port', 'user', 'path')), array('platform', 'host', 'port', 'credential', 'path')),
array( array(
'platform' => 'string', 'platform' => 'string',
'host' => 'string', 'host' => 'string',
'port' => 'string', // Value is a string from the command line 'port' => 'string', // Value is a string from the command line
'user' => 'string', 'credential' => 'string',
'path' => 'string', 'path' => 'string',
)); ));
$v_platform = $resource->getAttribute('platform'); $v_platform = $resource->getAttribute('platform');
@ -103,8 +103,7 @@ final class DrydockPreallocatedHostBlueprintImplementation
->setConfiguration(array( ->setConfiguration(array(
'host' => $resource->getAttribute('host'), 'host' => $resource->getAttribute('host'),
'port' => $resource->getAttribute('port'), 'port' => $resource->getAttribute('port'),
'user' => $resource->getAttribute('user'), 'credential' => $resource->getAttribute('credential'),
'ssh-keyfile' => $resource->getAttribute('ssh-keyfile'),
'platform' => $resource->getAttribute('platform'))); 'platform' => $resource->getAttribute('platform')));
} }

View file

@ -22,23 +22,31 @@ final class DrydockSSHCommandInterface extends DrydockCommandInterface {
// NOTE: The "-t -t" is for psuedo-tty allocation so we can "sudo" on some // NOTE: The "-t -t" is for psuedo-tty allocation so we can "sudo" on some
// systems, but maybe more trouble than it's worth? // systems, but maybe more trouble than it's worth?
$keyfile = $this->getConfig('ssh-keyfile'); $credential = id(new PassphraseCredentialQuery())
if (!empty($keyfile)) { ->setViewer(PhabricatorUser::getOmnipotentUser())
return new ExecFuture( ->withIDs(array($this->getConfig('credential')))
'ssh -t -t -o StrictHostKeyChecking=no -p %s -i %s %s@%s -- %s', ->needSecrets(true)
$this->getConfig('port'), ->executeOne();
$this->getConfig('ssh-keyfile'),
$this->getConfig('user'), // FIXME: We can't use text-based SSH files here because the TempFile goes
$this->getConfig('host'), // out of scope after this function ends and thus the file gets removed
$full_command); // before it can be used.
} else { if ($credential->getCredentialType() !==
return new ExecFuture( PassphraseCredentialTypeSSHPrivateKeyFile::CREDENTIAL_TYPE) {
'ssh -t -t -o StrictHostKeyChecking=no -p %s %s@%s -- %s', throw new Exception("Only private key file credentials are supported.");
$this->getConfig('port'),
$this->getConfig('user'),
$this->getConfig('host'),
$full_command);
} }
$ssh_key = PassphraseSSHKey::loadFromPHID(
$credential->getPHID(),
PhabricatorUser::getOmnipotentUser());
return new ExecFuture(
'ssh -t -t -o StrictHostKeyChecking=no -p %s -i %s %s@%s -- %s',
$this->getConfig('port'),
$ssh_key->getKeyfileEnvelope()->openEnvelope(),
$credential->getUsername(),
$this->getConfig('host'),
$full_command);
} }
} }