mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-04 11:51:02 +01:00
Validate resource attributes for preallocated hosts before executing leases
Summary: This prevents issues when the user hasn't provided the appropriate attributes for a preallocated host. Test Plan: Attempted to lease against a resource with omitted attributes, got an exception thrown before any SSH commands occurred. Reviewers: epriestley, #blessed_reviewers Reviewed By: epriestley CC: Korvin, epriestley, aran Maniphest Tasks: T1049 Differential Revision: https://secure.phabricator.com/D7695
This commit is contained in:
parent
1965bf9e52
commit
1f53017f1f
2 changed files with 22 additions and 3 deletions
|
@ -37,6 +37,21 @@ final class DrydockPreallocatedHostBlueprintImplementation
|
||||||
DrydockResource $resource,
|
DrydockResource $resource,
|
||||||
DrydockLease $lease) {
|
DrydockLease $lease) {
|
||||||
|
|
||||||
|
// Because preallocated resources are manually created, we should verify
|
||||||
|
// we have all the information we need.
|
||||||
|
PhutilTypeSpec::checkMap(
|
||||||
|
$resource->getAttributesForTypeSpec(
|
||||||
|
array('platform', 'host', 'port', 'user', 'path')),
|
||||||
|
array(
|
||||||
|
'platform' => 'string',
|
||||||
|
'host' => 'string',
|
||||||
|
'port' => 'string', // Value is a string from the command line
|
||||||
|
'user' => 'string',
|
||||||
|
'path' => 'string',
|
||||||
|
));
|
||||||
|
$v_platform = $resource->getAttribute('platform');
|
||||||
|
$v_path = $resource->getAttribute('path');
|
||||||
|
|
||||||
// Similar to DrydockLocalHostBlueprint, we create a folder
|
// Similar to DrydockLocalHostBlueprint, we create a folder
|
||||||
// on the remote host that the lease can use.
|
// on the remote host that the lease can use.
|
||||||
|
|
||||||
|
@ -46,18 +61,18 @@ final class DrydockPreallocatedHostBlueprintImplementation
|
||||||
// the platform we're currently running on, not the platform we are
|
// the platform we're currently running on, not the platform we are
|
||||||
// remoting to.
|
// remoting to.
|
||||||
$separator = '/';
|
$separator = '/';
|
||||||
if ($lease->getAttribute('platform') === 'windows') {
|
if ($v_platform === 'windows') {
|
||||||
$separator = '\\';
|
$separator = '\\';
|
||||||
}
|
}
|
||||||
|
|
||||||
// Clean up the directory path a little.
|
// Clean up the directory path a little.
|
||||||
$base_path = rtrim($resource->getAttribute('path'), '/');
|
$base_path = rtrim($v_path, '/');
|
||||||
$base_path = rtrim($base_path, '\\');
|
$base_path = rtrim($base_path, '\\');
|
||||||
$full_path = $base_path.$separator.$lease_id;
|
$full_path = $base_path.$separator.$lease_id;
|
||||||
|
|
||||||
$cmd = $lease->getInterface('command');
|
$cmd = $lease->getInterface('command');
|
||||||
|
|
||||||
if ($lease->getAttribute('platform') !== 'windows') {
|
if ($v_platform !== 'windows') {
|
||||||
$cmd->execx('mkdir %s', $full_path);
|
$cmd->execx('mkdir %s', $full_path);
|
||||||
} else {
|
} else {
|
||||||
// Windows is terrible. The mkdir command doesn't even support putting
|
// Windows is terrible. The mkdir command doesn't even support putting
|
||||||
|
|
|
@ -35,6 +35,10 @@ final class DrydockResource extends DrydockDAO
|
||||||
return idx($this->attributes, $key, $default);
|
return idx($this->attributes, $key, $default);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getAttributesForTypeSpec(array $attribute_names) {
|
||||||
|
return array_select_keys($this->attributes, $attribute_names);
|
||||||
|
}
|
||||||
|
|
||||||
public function setAttribute($key, $value) {
|
public function setAttribute($key, $value) {
|
||||||
$this->attributes[$key] = $value;
|
$this->attributes[$key] = $value;
|
||||||
return $this;
|
return $this;
|
||||||
|
|
Loading…
Reference in a new issue