4 * @task autoplan Autoplans
6 final class HarbormasterBuildPlan
extends HarbormasterDAO
8 PhabricatorApplicationTransactionInterface
,
9 PhabricatorPolicyInterface
,
10 PhabricatorSubscribableInterface
,
11 PhabricatorNgramsInterface
,
12 PhabricatorConduitResultInterface
,
13 PhabricatorProjectInterface
,
14 PhabricatorPolicyCodexInterface
{
17 protected $planStatus;
18 protected $planAutoKey;
19 protected $viewPolicy;
20 protected $editPolicy;
21 protected $properties = array();
23 const STATUS_ACTIVE
= 'active';
24 const STATUS_DISABLED
= 'disabled';
26 private $buildSteps = self
::ATTACHABLE
;
28 public static function initializeNewBuildPlan(PhabricatorUser
$actor) {
29 $app = id(new PhabricatorApplicationQuery())
31 ->withClasses(array('PhabricatorHarbormasterApplication'))
34 $view_policy = $app->getPolicy(
35 HarbormasterBuildPlanDefaultViewCapability
::CAPABILITY
);
36 $edit_policy = $app->getPolicy(
37 HarbormasterBuildPlanDefaultEditCapability
::CAPABILITY
);
39 return id(new HarbormasterBuildPlan())
41 ->setPlanStatus(self
::STATUS_ACTIVE
)
42 ->attachBuildSteps(array())
43 ->setViewPolicy($view_policy)
44 ->setEditPolicy($edit_policy);
47 protected function getConfiguration() {
49 self
::CONFIG_AUX_PHID
=> true,
50 self
::CONFIG_SERIALIZATION
=> array(
51 'properties' => self
::SERIALIZATION_JSON
,
53 self
::CONFIG_COLUMN_SCHEMA
=> array(
55 'planStatus' => 'text32',
56 'planAutoKey' => 'text32?',
58 self
::CONFIG_KEY_SCHEMA
=> array(
59 'key_status' => array(
60 'columns' => array('planStatus'),
63 'columns' => array('name'),
65 'key_planautokey' => array(
66 'columns' => array('planAutoKey'),
70 ) + parent
::getConfiguration();
73 public function generatePHID() {
74 return PhabricatorPHID
::generateNewPHID(
75 HarbormasterBuildPlanPHIDType
::TYPECONST
);
78 public function attachBuildSteps(array $steps) {
79 assert_instances_of($steps, 'HarbormasterBuildStep');
80 $this->buildSteps
= $steps;
84 public function getBuildSteps() {
85 return $this->assertAttached($this->buildSteps
);
88 public function isDisabled() {
89 return ($this->getPlanStatus() == self
::STATUS_DISABLED
);
92 public function getURI() {
94 '/harbormaster/plan/%s/',
98 public function getObjectName() {
99 return pht('Plan %d', $this->getID());
102 public function getPlanProperty($key, $default = null) {
103 return idx($this->properties
, $key, $default);
106 public function setPlanProperty($key, $value) {
107 $this->properties
[$key] = $value;
112 /* -( Autoplans )---------------------------------------------------------- */
115 public function isAutoplan() {
116 return ($this->getPlanAutoKey() !== null);
120 public function getAutoplan() {
121 if (!$this->isAutoplan()) {
125 return HarbormasterBuildAutoplan
::getAutoplan($this->getPlanAutoKey());
129 public function canRunManually() {
130 if ($this->isAutoplan()) {
137 public function getName() {
138 $autoplan = $this->getAutoplan();
140 return $autoplan->getAutoplanName();
143 return parent
::getName();
146 public function hasRunCapability(PhabricatorUser
$viewer) {
148 $this->assertHasRunCapability($viewer);
150 } catch (PhabricatorPolicyException
$ex) {
155 public function canRunWithoutEditCapability() {
156 $runnable = HarbormasterBuildPlanBehavior
::BEHAVIOR_RUNNABLE
;
157 $if_viewable = HarbormasterBuildPlanBehavior
::RUNNABLE_IF_VIEWABLE
;
159 $option = HarbormasterBuildPlanBehavior
::getBehavior($runnable)
160 ->getPlanOption($this);
162 return ($option->getKey() === $if_viewable);
165 public function assertHasRunCapability(PhabricatorUser
$viewer) {
166 if ($this->canRunWithoutEditCapability()) {
167 $capability = PhabricatorPolicyCapability
::CAN_VIEW
;
169 $capability = PhabricatorPolicyCapability
::CAN_EDIT
;
172 PhabricatorPolicyFilter
::requireCapability(
179 /* -( PhabricatorSubscribableInterface )----------------------------------- */
182 public function isAutomaticallySubscribed($phid) {
187 /* -( PhabricatorApplicationTransactionInterface )------------------------- */
190 public function getApplicationTransactionEditor() {
191 return new HarbormasterBuildPlanEditor();
194 public function getApplicationTransactionTemplate() {
195 return new HarbormasterBuildPlanTransaction();
198 /* -( PhabricatorPolicyInterface )----------------------------------------- */
201 public function getCapabilities() {
203 PhabricatorPolicyCapability
::CAN_VIEW
,
204 PhabricatorPolicyCapability
::CAN_EDIT
,
208 public function getPolicy($capability) {
209 switch ($capability) {
210 case PhabricatorPolicyCapability
::CAN_VIEW
:
211 if ($this->isAutoplan()) {
212 return PhabricatorPolicies
::getMostOpenPolicy();
214 return $this->getViewPolicy();
215 case PhabricatorPolicyCapability
::CAN_EDIT
:
216 if ($this->isAutoplan()) {
217 return PhabricatorPolicies
::POLICY_NOONE
;
219 return $this->getEditPolicy();
223 public function hasAutomaticCapability($capability, PhabricatorUser
$viewer) {
227 public function describeAutomaticCapability($capability) {
230 switch ($capability) {
231 case PhabricatorPolicyCapability
::CAN_EDIT
:
232 if ($this->isAutoplan()) {
234 'This is an autoplan (a builtin plan provided by an application) '.
235 'so it can not be edited.');
244 /* -( PhabricatorNgramsInterface )----------------------------------------- */
247 public function newNgrams() {
249 id(new HarbormasterBuildPlanNameNgrams())
250 ->setValue($this->getName()),
255 /* -( PhabricatorConduitResultInterface )---------------------------------- */
258 public function getFieldSpecificationsForConduit() {
260 id(new PhabricatorConduitSearchFieldSpecification())
263 ->setDescription(pht('The name of this build plan.')),
264 id(new PhabricatorConduitSearchFieldSpecification())
266 ->setType('map<string, wild>')
267 ->setDescription(pht('The current status of this build plan.')),
268 id(new PhabricatorConduitSearchFieldSpecification())
269 ->setKey('behaviors')
270 ->setType('map<string, string>')
271 ->setDescription(pht('Behavior configuration for the build plan.')),
275 public function getFieldValuesForConduit() {
276 $behavior_map = array();
278 $behaviors = HarbormasterBuildPlanBehavior
::newPlanBehaviors();
279 foreach ($behaviors as $behavior) {
280 $option = $behavior->getPlanOption($this);
282 $behavior_map[$behavior->getKey()] = array(
283 'value' => $option->getKey(),
288 'name' => $this->getName(),
290 'value' => $this->getPlanStatus(),
292 'behaviors' => $behavior_map,
296 public function getConduitSearchAttachments() {
301 /* -( PhabricatorPolicyCodexInterface )------------------------------------ */
304 public function newPolicyCodex() {
305 return new HarbormasterBuildPlanPolicyCodex();