mirror of
https://we.phorge.it/source/phorge.git
synced 2024-12-01 03:02:43 +01:00
150f711cc8
Summary: See D4047. Get rid of this strtolower() junk. Test Plan: ``` $ /bin/drydock lease --type working-copy --attributes repositoryID=12 Acquired Lease 66 ``` Reviewers: btrahan Reviewed By: btrahan CC: aran Maniphest Tasks: T2015 Differential Revision: https://secure.phabricator.com/D4048
79 lines
2 KiB
PHP
79 lines
2 KiB
PHP
<?php
|
|
|
|
final class DrydockManagementLeaseWorkflow
|
|
extends DrydockManagementWorkflow {
|
|
|
|
public function didConstruct() {
|
|
$this
|
|
->setName('lease')
|
|
->setSynopsis('Lease a resource.')
|
|
->setArguments(
|
|
array(
|
|
array(
|
|
'name' => 'type',
|
|
'param' => 'resource_type',
|
|
'help' => 'Resource type.',
|
|
),
|
|
array(
|
|
'name' => 'attributes',
|
|
'param' => 'name=value,...',
|
|
'help' => 'Resource specficiation.',
|
|
),
|
|
));
|
|
}
|
|
|
|
public function execute(PhutilArgumentParser $args) {
|
|
$console = PhutilConsole::getConsole();
|
|
|
|
$resource_type = $args->getArg('type');
|
|
if (!$resource_type) {
|
|
throw new PhutilArgumentUsageException(
|
|
"Specify a resource type with `--type`.");
|
|
}
|
|
|
|
$attributes = $args->getArg('attributes');
|
|
if ($attributes) {
|
|
$options = new PhutilSimpleOptions();
|
|
$options->setCaseSensitive(true);
|
|
$attributes = $options->parse($attributes);
|
|
}
|
|
|
|
$lease = new DrydockLease();
|
|
$lease->setResourceType($resource_type);
|
|
if ($attributes) {
|
|
$lease->setAttributes($attributes);
|
|
}
|
|
$lease->queueForActivation();
|
|
|
|
$root = dirname(phutil_get_library_root('phabricator'));
|
|
$wait = new ExecFuture(
|
|
'php -f %s wait-for-lease --id %s',
|
|
$root.'/scripts/drydock/drydock_control.php',
|
|
$lease->getID());
|
|
|
|
$cursor = 0;
|
|
foreach (Futures(array($wait))->setUpdateInterval(1) as $key => $future) {
|
|
if ($future) {
|
|
$future->resolvex();
|
|
break;
|
|
}
|
|
|
|
$logs = id(new DrydockLogQuery())
|
|
->withLeaseIDs(array($lease->getID()))
|
|
->withAfterID($cursor)
|
|
->setOrder(DrydockLogQuery::ORDER_ID)
|
|
->execute();
|
|
|
|
if ($logs) {
|
|
foreach ($logs as $log) {
|
|
$console->writeErr("%s\n", $log->getMessage());
|
|
}
|
|
$cursor = max(mpull($logs, 'getID'));
|
|
}
|
|
}
|
|
|
|
$console->writeOut("Acquired Lease %s\n", $lease->getID());
|
|
return 0;
|
|
}
|
|
|
|
}
|