2013-01-16 18:08:13 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
final class PhabricatorDiffusionConfigOptions
|
|
|
|
extends PhabricatorApplicationConfigOptions {
|
|
|
|
|
|
|
|
public function getName() {
|
|
|
|
return pht('Diffusion');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getDescription() {
|
|
|
|
return pht('Configure Diffusion repository browsing.');
|
|
|
|
}
|
|
|
|
|
2015-02-02 19:17:25 +01:00
|
|
|
public function getFontIcon() {
|
|
|
|
return 'fa-code';
|
|
|
|
}
|
|
|
|
|
2015-02-09 22:10:56 +01:00
|
|
|
public function getGroup() {
|
|
|
|
return 'apps';
|
|
|
|
}
|
|
|
|
|
2013-01-16 18:08:13 +01:00
|
|
|
public function getOptions() {
|
|
|
|
return array(
|
|
|
|
$this->newOption(
|
|
|
|
'metamta.diffusion.subject-prefix',
|
|
|
|
'string',
|
|
|
|
'[Diffusion]')
|
|
|
|
->setDescription(pht('Subject prefix for Diffusion mail.')),
|
|
|
|
$this->newOption(
|
|
|
|
'metamta.diffusion.reply-handler-domain',
|
|
|
|
'string',
|
|
|
|
null)
|
2015-02-13 20:00:09 +01:00
|
|
|
->setLocked(true)
|
2013-01-16 18:08:13 +01:00
|
|
|
->setDescription(
|
|
|
|
pht(
|
|
|
|
'See {{metamta.maniphest.reply-handler}}. This does the same '.
|
|
|
|
'thing, but affects Diffusion.')),
|
|
|
|
$this->newOption(
|
|
|
|
'metamta.diffusion.reply-handler',
|
|
|
|
'class',
|
|
|
|
'PhabricatorAuditReplyHandler')
|
2015-02-13 20:00:09 +01:00
|
|
|
->setLocked(true)
|
2013-01-16 18:08:13 +01:00
|
|
|
->setBaseClass('PhabricatorMailReplyHandler')
|
|
|
|
->setDescription(pht('Override mail reply handler class.')),
|
|
|
|
$this->newOption(
|
|
|
|
'metamta.diffusion.attach-patches',
|
|
|
|
'bool',
|
|
|
|
false)
|
|
|
|
->setBoolOptions(
|
|
|
|
array(
|
2014-06-09 20:36:49 +02:00
|
|
|
pht('Attach Patches'),
|
|
|
|
pht('Do Not Attach Patches'),
|
2013-01-16 18:08:13 +01:00
|
|
|
))
|
|
|
|
->setDescription(pht(
|
|
|
|
'Set this to true if you want patches to be attached to commit '.
|
|
|
|
'notifications from Diffusion.')),
|
|
|
|
$this->newOption('metamta.diffusion.inline-patches', 'int', 0)
|
|
|
|
->setSummary(pht('Include patches in Diffusion mail as body text.'))
|
|
|
|
->setDescription(
|
|
|
|
pht(
|
|
|
|
'To include patches in Diffusion email bodies, set this to a '.
|
|
|
|
'positive integer. Patches will be inlined if they are at most '.
|
|
|
|
'that many lines. By default, patches are not inlined.')),
|
|
|
|
$this->newOption('metamta.diffusion.byte-limit', 'int', 1024 * 1024)
|
|
|
|
->setDescription(pht('Hard byte limit on including patches in email.')),
|
|
|
|
$this->newOption('metamta.diffusion.time-limit', 'int', 60)
|
|
|
|
->setDescription(pht('Hard time limit on generating patches.')),
|
2013-01-19 02:53:52 +01:00
|
|
|
$this->newOption(
|
|
|
|
'audit.can-author-close-audit',
|
|
|
|
'bool',
|
|
|
|
false)
|
|
|
|
->setBoolOptions(
|
|
|
|
array(
|
2014-06-09 20:36:49 +02:00
|
|
|
pht('Enable Closing Audits'),
|
|
|
|
pht('Disable Closing Audits'),
|
2013-01-19 02:53:52 +01:00
|
|
|
))
|
|
|
|
->setDescription(pht('Controls whether Author can Close Audits.')),
|
2013-04-20 06:56:13 +02:00
|
|
|
|
|
|
|
$this->newOption('bugtraq.url', 'string', '')
|
|
|
|
->addExample('https://bugs.php.net/%BUGID%', pht('PHP bugs'))
|
|
|
|
->addExample('/%BUGID%', pht('Local Maniphest URL'))
|
|
|
|
->setDescription(pht(
|
|
|
|
'URL of external bug tracker used by Diffusion. %s will be '.
|
|
|
|
'substituted by the bug ID.',
|
|
|
|
'%BUGID%')),
|
2013-09-13 20:48:00 +02:00
|
|
|
$this->newOption('bugtraq.logregex', 'list<regex>', array())
|
|
|
|
->addExample(array('/\B#([1-9]\d*)\b/'), pht('Issue #123'))
|
2013-08-06 18:29:22 +02:00
|
|
|
->addExample(
|
2013-09-13 20:48:00 +02:00
|
|
|
array('/[Ii]ssues?:?(\s*,?\s*#\d+)+/', '/(\d+)/'),
|
2013-08-06 18:29:22 +02:00
|
|
|
pht('Issue #123, #456'))
|
2013-09-13 20:48:00 +02:00
|
|
|
->addExample(array('/(?<!#)\b(T[1-9]\d*)\b/'), pht('Task T123'))
|
2013-09-18 19:13:00 +02:00
|
|
|
->addExample('/[A-Z]{2,}-\d+/', pht('JIRA-1234'))
|
2013-04-20 06:56:13 +02:00
|
|
|
->setDescription(pht(
|
|
|
|
'Regular expression to link external bug tracker. See '.
|
|
|
|
'http://tortoisesvn.net/docs/release/TortoiseSVN_en/'.
|
|
|
|
'tsvn-dug-bugtracker.html for further explanation.')),
|
2013-11-01 16:34:11 +01:00
|
|
|
$this->newOption('diffusion.allow-http-auth', 'bool', false)
|
|
|
|
->setBoolOptions(
|
|
|
|
array(
|
|
|
|
pht('Allow HTTP Basic Auth'),
|
|
|
|
pht('Disable HTTP Basic Auth'),
|
|
|
|
))
|
|
|
|
->setSummary(pht('Enable HTTP Basic Auth for repositories.'))
|
|
|
|
->setDescription(
|
|
|
|
pht(
|
|
|
|
"Phabricator can serve repositories over HTTP, using HTTP basic ".
|
|
|
|
"auth.\n\n".
|
|
|
|
"Because HTTP basic auth is less secure than SSH auth, it is ".
|
|
|
|
"disabled by default. You can enable it here if you'd like to use ".
|
|
|
|
"it anyway. There's nothing fundamentally insecure about it as ".
|
|
|
|
"long as Phabricator uses HTTPS, but it presents a much lower ".
|
|
|
|
"barrier to attackers than SSH does.\n\n".
|
|
|
|
"Consider using SSH for authenticated access to repositories ".
|
2013-11-02 01:35:43 +01:00
|
|
|
"instead of HTTP.")),
|
|
|
|
$this->newOption('diffusion.ssh-user', 'string', null)
|
2015-02-18 19:51:14 +01:00
|
|
|
->setLocked(true)
|
2013-11-02 01:35:43 +01:00
|
|
|
->setSummary(pht('Login username for SSH connections to repositories.'))
|
|
|
|
->setDescription(
|
|
|
|
pht(
|
|
|
|
'When constructing clone URIs to show to users, Diffusion will '.
|
|
|
|
'fill in this login username. If you have configured a VCS user '.
|
|
|
|
'like `git`, you should provide it here.')),
|
2013-12-11 21:11:13 +01:00
|
|
|
$this->newOption('diffusion.ssh-port', 'int', null)
|
2015-02-18 19:51:14 +01:00
|
|
|
->setLocked(true)
|
2013-12-11 21:11:13 +01:00
|
|
|
->setSummary(pht('Port for SSH connections to repositories.'))
|
|
|
|
->setDescription(
|
|
|
|
pht(
|
|
|
|
'When constructing clone URIs to show to users, Diffusion by '.
|
|
|
|
'default will not display a port assuming the default for your '.
|
|
|
|
'VCS. Explicitly declare when running on a non-standard port.')),
|
2015-02-18 19:51:14 +01:00
|
|
|
$this->newOption('diffusion.ssh-host', 'string', null)
|
|
|
|
->setLocked(true)
|
|
|
|
->setSummary(pht('Host for SSH connections to repositories.'))
|
|
|
|
->setDescription(
|
|
|
|
pht(
|
|
|
|
'If you accept Phabricator SSH traffic on a different host '.
|
|
|
|
'from web traffic (for example, if you use different SSH and '.
|
|
|
|
'web load balancers), you can set the SSH hostname here. This '.
|
|
|
|
'is an advanced option.')),
|
2013-01-16 18:08:13 +01:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|