mirror of
https://we.phorge.it/source/phorge.git
synced 2025-03-29 04:28:12 +01:00
Summary: Ref T1049. This generally simplifies things. The steps which don't support variables generally don't make sense to support varaibles anyway. Test Plan: Edited some steps. Reviewers: btrahan Reviewed By: btrahan Subscribers: epriestley Maniphest Tasks: T1049 Differential Revision: https://secure.phabricator.com/D8588
194 lines
5.8 KiB
PHP
194 lines
5.8 KiB
PHP
<?php
|
|
|
|
final class HarbormasterStepEditController
|
|
extends HarbormasterController {
|
|
|
|
private $id;
|
|
|
|
public function willProcessRequest(array $data) {
|
|
$this->id = idx($data, 'id');
|
|
}
|
|
|
|
public function processRequest() {
|
|
$request = $this->getRequest();
|
|
$viewer = $request->getUser();
|
|
|
|
$this->requireApplicationCapability(
|
|
HarbormasterCapabilityManagePlans::CAPABILITY);
|
|
|
|
$step = id(new HarbormasterBuildStepQuery())
|
|
->setViewer($viewer)
|
|
->withIDs(array($this->id))
|
|
->executeOne();
|
|
if (!$step) {
|
|
return new Aphront404Response();
|
|
}
|
|
|
|
$plan = $step->getBuildPlan();
|
|
|
|
$implementation = $step->getStepImplementation();
|
|
$implementation->validateSettingDefinitions();
|
|
$settings = $implementation->getSettings();
|
|
|
|
$errors = array();
|
|
if ($request->isFormPost()) {
|
|
foreach ($implementation->getSettingDefinitions() as $name => $opt) {
|
|
$readable_name = $this->getReadableName($name, $opt);
|
|
$value = $this->getValueFromRequest($request, $name, $opt['type']);
|
|
|
|
// TODO: This won't catch any validation issues unless the field
|
|
// is missing completely. How should we check if the user is
|
|
// required to enter an integer?
|
|
if ($value === null) {
|
|
$errors[] = $readable_name.' is not valid.';
|
|
} else {
|
|
$step->setDetail($name, $value);
|
|
}
|
|
}
|
|
|
|
if (!$errors) {
|
|
$step->save();
|
|
return id(new AphrontRedirectResponse())
|
|
->setURI($this->getApplicationURI('plan/'.$plan->getID().'/'));
|
|
}
|
|
}
|
|
|
|
$form = id(new AphrontFormView())
|
|
->setUser($viewer);
|
|
|
|
// We need to render out all of the fields for the settings that
|
|
// the implementation has.
|
|
foreach ($implementation->getSettingDefinitions() as $name => $opt) {
|
|
if ($request->isFormPost()) {
|
|
$value = $this->getValueFromRequest($request, $name, $opt['type']);
|
|
} else {
|
|
$value = $settings[$name];
|
|
}
|
|
|
|
switch ($opt['type']) {
|
|
case BuildStepImplementation::SETTING_TYPE_STRING:
|
|
case BuildStepImplementation::SETTING_TYPE_INTEGER:
|
|
$control = id(new AphrontFormTextControl())
|
|
->setLabel($this->getReadableName($name, $opt))
|
|
->setName($name)
|
|
->setValue($value);
|
|
break;
|
|
case BuildStepImplementation::SETTING_TYPE_BOOLEAN:
|
|
$control = id(new AphrontFormCheckboxControl())
|
|
->setLabel($this->getReadableName($name, $opt))
|
|
->setName($name)
|
|
->setValue($value);
|
|
break;
|
|
case BuildStepImplementation::SETTING_TYPE_ARTIFACT:
|
|
$filter = $opt['artifact_type'];
|
|
$available_artifacts =
|
|
BuildStepImplementation::loadAvailableArtifacts(
|
|
$plan,
|
|
$step,
|
|
$filter);
|
|
$options = array();
|
|
foreach ($available_artifacts as $key => $type) {
|
|
$options[$key] = $key;
|
|
}
|
|
$control = id(new AphrontFormSelectControl())
|
|
->setLabel($this->getReadableName($name, $opt))
|
|
->setName($name)
|
|
->setValue($value)
|
|
->setOptions($options);
|
|
break;
|
|
default:
|
|
throw new Exception("Unable to render field with unknown type.");
|
|
}
|
|
|
|
if (isset($opt['description'])) {
|
|
$control->setCaption($opt['description']);
|
|
}
|
|
|
|
$form->appendChild($control);
|
|
}
|
|
|
|
$form->appendChild(
|
|
id(new AphrontFormSubmitControl())
|
|
->setValue(pht('Save Build Step'))
|
|
->addCancelButton(
|
|
$this->getApplicationURI('plan/'.$plan->getID().'/')));
|
|
|
|
$box = id(new PHUIObjectBoxView())
|
|
->setHeaderText('Edit Step: '.$implementation->getName())
|
|
->setValidationException(null)
|
|
->setForm($form);
|
|
|
|
$crumbs = $this->buildApplicationCrumbs();
|
|
$id = $plan->getID();
|
|
$crumbs->addTextCrumb(
|
|
pht("Plan %d", $id),
|
|
$this->getApplicationURI("plan/{$id}/"));
|
|
$crumbs->addTextCrumb(pht('Edit Step'));
|
|
|
|
$variables = $this->renderBuildVariablesTable();
|
|
|
|
return $this->buildApplicationPage(
|
|
array(
|
|
$crumbs,
|
|
$box,
|
|
$variables,
|
|
),
|
|
array(
|
|
'title' => $implementation->getName(),
|
|
'device' => true,
|
|
));
|
|
}
|
|
|
|
public function getReadableName($name, $opt) {
|
|
$readable_name = $name;
|
|
if (isset($opt['name'])) {
|
|
$readable_name = $opt['name'];
|
|
}
|
|
return $readable_name;
|
|
}
|
|
|
|
public function getValueFromRequest(AphrontRequest $request, $name, $type) {
|
|
switch ($type) {
|
|
case BuildStepImplementation::SETTING_TYPE_STRING:
|
|
case BuildStepImplementation::SETTING_TYPE_ARTIFACT:
|
|
return $request->getStr($name);
|
|
break;
|
|
case BuildStepImplementation::SETTING_TYPE_INTEGER:
|
|
return $request->getInt($name);
|
|
break;
|
|
case BuildStepImplementation::SETTING_TYPE_BOOLEAN:
|
|
return $request->getBool($name);
|
|
break;
|
|
default:
|
|
throw new Exception("Unsupported setting type '".$type."'.");
|
|
}
|
|
}
|
|
|
|
private function renderBuildVariablesTable() {
|
|
$viewer = $this->getRequest()->getUser();
|
|
|
|
$variables = HarbormasterBuild::getAvailableBuildVariables();
|
|
ksort($variables);
|
|
|
|
$rows = array();
|
|
$rows[] = pht(
|
|
'The following variables can be used in most fields. To reference '.
|
|
'a variable, use `${name}` in a field.');
|
|
$rows[] = pht('| Variable | Description |');
|
|
$rows[] = '|---|---|';
|
|
foreach ($variables as $name => $description) {
|
|
$rows[] = '| `'.$name.'` | '.$description.' |';
|
|
}
|
|
$rows = implode("\n", $rows);
|
|
|
|
$form = id(new AphrontFormView())
|
|
->setUser($viewer)
|
|
->appendRemarkupInstructions($rows);
|
|
|
|
return id(new PHUIObjectBoxView())
|
|
->setHeaderText(pht('Build Variables'))
|
|
->appendChild($form);
|
|
}
|
|
|
|
|
|
}
|