1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2024-11-27 09:12:41 +01:00

Simplify and improve PhabricatorCustomField APIs

Summary:
Ref T1703. Ref T3718. The `PhabricatorCustomFieldList` seems like a pretty good idea. Move more code into it to make it harder to get wrong.

Also the sequencing on old/new values for these transactions was a bit off; fix that up.

Test Plan: Edited standard and custom profile fields.

Reviewers: btrahan

Reviewed By: btrahan

CC: aran

Maniphest Tasks: T1703, T3718

Differential Revision: https://secure.phabricator.com/D6751
This commit is contained in:
epriestley 2013-08-14 09:40:42 -07:00
parent 74de24909b
commit 938b63aaa9
7 changed files with 57 additions and 28 deletions

View file

@ -97,10 +97,9 @@ final class PhabricatorPeopleProfileController
->setUser($viewer) ->setUser($viewer)
->setObject($user); ->setObject($user);
$fields = PhabricatorCustomField::getObjectFields( $field_list = PhabricatorCustomField::getObjectFields(
$user, $user,
PhabricatorCustomField::ROLE_VIEW); PhabricatorCustomField::ROLE_VIEW);
$field_list = new PhabricatorCustomFieldList($fields);
$field_list->appendFieldsToPropertyList($user, $viewer, $view); $field_list->appendFieldsToPropertyList($user, $viewer, $view);
return $view; return $view;

View file

@ -32,20 +32,15 @@ final class PhabricatorPeopleProfileEditController
$profile_uri = '/p/'.$user->getUsername().'/'; $profile_uri = '/p/'.$user->getUsername().'/';
$fields = PhabricatorCustomField::getObjectFields( $field_list = PhabricatorCustomField::getObjectFields(
$user, $user,
PhabricatorCustomField::ROLE_EDIT); PhabricatorCustomField::ROLE_EDIT);
$field_list = new PhabricatorCustomFieldList($fields); $field_list->readFieldsFromStorage($user);
if ($request->isFormPost()) { if ($request->isFormPost()) {
$xactions = array(); $xactions = $field_list->buildFieldTransactionsFromRequest(
foreach ($fields as $field) { new PhabricatorUserTransaction(),
$field->readValueFromRequest($request); $request);
$xactions[] = id(new PhabricatorUserTransaction())
->setTransactionType(PhabricatorTransactions::TYPE_CUSTOMFIELD)
->setMetadataValue('customfield:key', $field->getFieldKey())
->setNewValue($field->getNewValueForApplicationTransactions());
}
$editor = id(new PhabricatorUserProfileEditor()) $editor = id(new PhabricatorUserProfileEditor())
->setActor($viewer) ->setActor($viewer)
@ -56,8 +51,6 @@ final class PhabricatorPeopleProfileEditController
$editor->applyTransactions($user, $xactions); $editor->applyTransactions($user, $xactions);
return id(new AphrontRedirectResponse())->setURI($profile_uri); return id(new AphrontRedirectResponse())->setURI($profile_uri);
} else {
$field_list->readFieldsFromStorage($user);
} }
$title = pht('Edit Profile'); $title = pht('Edit Profile');

View file

@ -850,8 +850,8 @@ EOBODY;
return $this->customFields[$role]; return $this->customFields[$role];
} }
public function attachCustomFields($role, array $fields) { public function attachCustomFields($role, PhabricatorCustomFieldList $list) {
$this->customFields[$role] = $fields; $this->customFields[$role] = $list;
return $this; return $this;
} }

View file

@ -125,8 +125,9 @@ abstract class PhabricatorApplicationTransactionEditor
} }
return $old_edges; return $old_edges;
case PhabricatorTransactions::TYPE_CUSTOMFIELD: case PhabricatorTransactions::TYPE_CUSTOMFIELD:
$field = $this->getCustomFieldForTransaction($object, $xaction); // NOTE: Custom fields have their old value pre-populated when they are
return $field->getOldValueForApplicationTransactions(); // built by PhabricatorCustomFieldList.
return $xaction->getOldValue();
default: default:
return $this->getCustomTransactionOldValue($object, $xaction); return $this->getCustomTransactionOldValue($object, $xaction);
} }
@ -585,10 +586,14 @@ abstract class PhabricatorApplicationTransactionEditor
throw new Exception( throw new Exception(
"You can not apply transactions which already have commentVersions!"); "You can not apply transactions which already have commentVersions!");
} }
$custom_field_type = PhabricatorTransactions::TYPE_CUSTOMFIELD;
if ($xaction->getTransactionType() != $custom_field_type) {
if ($xaction->getOldValue() !== null) { if ($xaction->getOldValue() !== null) {
throw new Exception( throw new Exception(
"You can not apply transactions which already have oldValue!"); "You can not apply transactions which already have oldValue!");
} }
}
$type = $xaction->getTransactionType(); $type = $xaction->getTransactionType();
if (empty($types[$type])) { if (empty($types[$type])) {

View file

@ -49,7 +49,7 @@ abstract class PhabricatorCustomField {
$role) { $role) {
try { try {
$fields = $object->getCustomFields($role); $field_list = $object->getCustomFields($role);
} catch (PhabricatorCustomFieldNotAttachedException $ex) { } catch (PhabricatorCustomFieldNotAttachedException $ex) {
$base_class = $object->getCustomFieldBaseClass(); $base_class = $object->getCustomFieldBaseClass();
@ -73,10 +73,11 @@ abstract class PhabricatorCustomField {
$field->setObject($object); $field->setObject($object);
} }
$object->attachCustomFields($role, $fields); $field_list = new PhabricatorCustomFieldList($fields);
$object->attachCustomFields($role, $field_list);
} }
return $fields; return $field_list;
} }
@ -87,7 +88,7 @@ abstract class PhabricatorCustomField {
PhabricatorCustomFieldInterface $object, PhabricatorCustomFieldInterface $object,
$role, $role,
$field_key) { $field_key) {
return idx(self::getObjectFields($object, $role), $field_key); return idx(self::getObjectFields($object, $role)->getFields(), $field_key);
} }

View file

@ -16,6 +16,9 @@ final class PhabricatorCustomFieldList extends Phobject {
$this->fields = $fields; $this->fields = $fields;
} }
public function getFields() {
return $this->fields;
}
/** /**
* Read stored values for all fields which support storage. * Read stored values for all fields which support storage.
@ -120,4 +123,32 @@ final class PhabricatorCustomFieldList extends Phobject {
} }
} }
public function buildFieldTransactionsFromRequest(
PhabricatorApplicationTransaction $template,
AphrontRequest $request) {
$xactions = array();
$role = PhabricatorCustomField::ROLE_APPLICATIONTRANSACTIONS;
foreach ($this->fields as $field) {
if (!$field->shouldEnableForRole($role)) {
continue;
}
$old_value = $field->getOldValueForApplicationTransactions();
$field->readValueFromRequest($request);
$xaction = id(clone $template)
->setTransactionType(PhabricatorTransactions::TYPE_CUSTOMFIELD)
->setMetadataValue('customfield:key', $field->getFieldKey())
->setOldValue($old_value)
->setNewValue($field->getNewValueForApplicationTransactions());
$xactions[] = $xaction;
}
return $xactions;
}
} }

View file

@ -5,7 +5,7 @@ interface PhabricatorCustomFieldInterface {
public function getCustomFieldBaseClass(); public function getCustomFieldBaseClass();
public function getCustomFieldSpecificationForRole($role); public function getCustomFieldSpecificationForRole($role);
public function getCustomFields($role); public function getCustomFields($role);
public function attachCustomFields($role, array $fields); public function attachCustomFields($role, PhabricatorCustomFieldList $list);
} }
@ -33,8 +33,8 @@ interface PhabricatorCustomFieldInterface {
return $this->customFields[$role]; return $this->customFields[$role];
} }
public function attachCustomFields($role, array $fields) { public function attachCustomFields($role, PhabricatorCustomFieldList $list) {
$this->customFields[$role] = $fields; $this->customFields[$role] = $list;
return $this; return $this;
} }