mirror of
https://we.phorge.it/source/phorge.git
synced 2024-11-13 10:22:42 +01:00
ba16df0fed
Summary: //(this diff used to be about applying policies to blueprints)// This restructures Drydock so that blueprints are instances in the DB, with an associated implementation class. Thus resources now have a `blueprintPHID` instead of `blueprintClass` and DrydockBlueprint becomes a DAO. The old DrydockBlueprint is renamed to DrydockBlueprintImplementation, and the DrydockBlueprint DAO has a `blueprintClass` column on it. This now just implements CAN_VIEW and CAN_EDIT policies for blueprints, although they are probably not enforced in all of the places they could be. Test Plan: Used the `create-resource` and `lease` commands. Closed resources and leases in the UI. Clicked around the new and old lists to make sure everything is still working. Reviewers: epriestley, #blessed_reviewers Reviewed By: epriestley CC: Korvin, epriestley, aran Maniphest Tasks: T4111, T2015 Differential Revision: https://secure.phabricator.com/D7638
108 lines
2.7 KiB
PHP
108 lines
2.7 KiB
PHP
<?php
|
|
|
|
final class DrydockWorkingCopyBlueprintImplementation
|
|
extends DrydockBlueprintImplementation {
|
|
|
|
public function isEnabled() {
|
|
return true;
|
|
}
|
|
|
|
public function getDescription() {
|
|
return pht('Allocates out working copies of repositories.');
|
|
}
|
|
|
|
protected function canAllocateLease(
|
|
DrydockResource $resource,
|
|
DrydockLease $lease) {
|
|
|
|
$resource_repo = $resource->getAttribute('repositoryID');
|
|
$lease_repo = $lease->getAttribute('repositoryID');
|
|
|
|
return ($resource_repo && $lease_repo && ($resource_repo == $lease_repo));
|
|
}
|
|
|
|
protected function shouldAllocateLease(
|
|
DrydockResource $resource,
|
|
DrydockLease $lease,
|
|
array $other_leases) {
|
|
|
|
return !$other_leases;
|
|
}
|
|
|
|
protected function executeAllocateResource(DrydockLease $lease) {
|
|
$repository_id = $lease->getAttribute('repositoryID');
|
|
if (!$repository_id) {
|
|
throw new Exception(
|
|
"Lease is missing required 'repositoryID' attribute.");
|
|
}
|
|
|
|
// TODO: (T603) Figure out the interaction between policies and
|
|
// Drydock.
|
|
$repository = id(new PhabricatorRepository())->load($repository_id);
|
|
|
|
if (!$repository) {
|
|
throw new Exception(
|
|
"Repository '{$repository_id}' does not exist!");
|
|
}
|
|
|
|
switch ($repository->getVersionControlSystem()) {
|
|
case PhabricatorRepositoryType::REPOSITORY_TYPE_GIT:
|
|
break;
|
|
default:
|
|
throw new Exception("Unsupported VCS!");
|
|
}
|
|
|
|
$host_lease = id(new DrydockLease())
|
|
->setResourceType('host')
|
|
->waitUntilActive();
|
|
|
|
$path = $host_lease->getAttribute('path').$repository->getCallsign();
|
|
|
|
$this->log(
|
|
pht('Cloning %s into %s....', $repository->getCallsign(), $path));
|
|
|
|
$cmd = $host_lease->getInterface('command');
|
|
$cmd->execx(
|
|
'git clone --origin origin %s %s',
|
|
$repository->getRemoteURI(),
|
|
$path);
|
|
|
|
$this->log(pht('Complete.'));
|
|
|
|
$resource = $this->newResourceTemplate(
|
|
'Working Copy ('.$repository->getCallsign().')');
|
|
$resource->setStatus(DrydockResourceStatus::STATUS_OPEN);
|
|
$resource->setAttribute('lease.host', $host_lease->getID());
|
|
$resource->setAttribute('path', $path);
|
|
$resource->setAttribute('repositoryID', $repository->getID());
|
|
$resource->save();
|
|
|
|
return $resource;
|
|
}
|
|
|
|
protected function executeAcquireLease(
|
|
DrydockResource $resource,
|
|
DrydockLease $lease) {
|
|
return;
|
|
}
|
|
|
|
public function getType() {
|
|
return 'working-copy';
|
|
}
|
|
|
|
public function getInterface(
|
|
DrydockResource $resource,
|
|
DrydockLease $lease,
|
|
$type) {
|
|
|
|
switch ($type) {
|
|
case 'command':
|
|
return $this
|
|
->loadLease($resource->getAttribute('lease.host'))
|
|
->getInterface($type);
|
|
}
|
|
|
|
throw new Exception("No interface of type '{$type}'.");
|
|
}
|
|
|
|
}
|