Correct a parameter order swap in "diffusion.historyquery" for Mercurial
[phabricator.git] / src / applications / settings / setting / PhabricatorSelectSetting.php
blobbccf450454402c5d21d969184b14e89bd3d9b8d0
1 <?php
3 abstract class PhabricatorSelectSetting
4 extends PhabricatorSetting {
6 abstract protected function getSelectOptions();
8 final protected function newCustomEditField($object) {
9 $setting_key = $this->getSettingKey();
10 $default_value = $object->getDefaultValue($setting_key);
12 $options = $this->getSelectOptions();
14 if (isset($options[$default_value])) {
15 $default_label = pht('Default (%s)', $options[$default_value]);
16 } else {
17 $default_label = pht('Default (Unknown, "%s")', $default_value);
20 if (empty($options[''])) {
21 $options = array(
22 '' => $default_label,
23 ) + $options;
26 return $this->newEditField($object, new PhabricatorSelectEditField())
27 ->setOptions($options);
30 public function assertValidValue($value) {
31 // This is a slightly stricter check than the transaction check. It's
32 // OK for empty string to go through transactions because it gets converted
33 // to null later, but we shouldn't be reading the empty string from
34 // storage.
35 if ($value === null) {
36 return;
39 if (!strlen($value)) {
40 throw new Exception(
41 pht(
42 'Empty string is not a valid setting for "%s".',
43 $this->getSettingName()));
46 $this->validateTransactionValue($value);
49 final public function validateTransactionValue($value) {
50 if (!strlen($value)) {
51 return;
54 $options = $this->getSelectOptions();
56 if (!isset($options[$value])) {
57 throw new Exception(
58 pht(
59 'Value "%s" is not valid for setting "%s": valid values are %s.',
60 $value,
61 $this->getSettingName(),
62 implode(', ', array_keys($options))));
65 return;
68 public function getTransactionNewValue($value) {
69 if (!strlen($value)) {
70 return null;
73 return (string)$value;