mirror of
https://we.phorge.it/source/phorge.git
synced 2024-11-16 03:42:41 +01:00
b2890eeb0e
Summary: These are all unambiguously unextensible. Issues I hit: - Maniphest Change/Diff controllers, just consolidated them. - Some search controllers incorrectly extend from "Search" but should extend from "SearchBase". This has no runtime effects. - D1836 introduced a closure, which we don't handle correctly (somewhat on purpose; we target PHP 5.2). See T962. Test Plan: Ran "testEverythingImplemented" unit test to identify classes extending from `final` classes. Resolved issues. Reviewers: btrahan Reviewed By: btrahan CC: aran, epriestley Maniphest Tasks: T795 Differential Revision: https://secure.phabricator.com/D1843
92 lines
2.5 KiB
PHP
92 lines
2.5 KiB
PHP
<?php
|
|
|
|
/*
|
|
* Copyright 2012 Facebook, Inc.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
final class DifferentialSubscribeController extends DifferentialController {
|
|
|
|
private $id;
|
|
private $action;
|
|
|
|
public function willProcessRequest(array $data) {
|
|
$this->id = $data['id'];
|
|
$this->action = $data['action'];
|
|
}
|
|
|
|
public function processRequest() {
|
|
|
|
$request = $this->getRequest();
|
|
$user = $request->getUser();
|
|
|
|
$revision = id(new DifferentialRevision())->load($this->id);
|
|
if (!$revision) {
|
|
return new Aphront404Response();
|
|
}
|
|
|
|
if (!$request->isFormPost()) {
|
|
$dialog = new AphrontDialogView();
|
|
|
|
switch ($this->action) {
|
|
case 'add':
|
|
$button = 'Subscribe';
|
|
$title = 'Subscribe to Revision';
|
|
$prompt = 'Really subscribe to this revision?';
|
|
break;
|
|
case 'rem':
|
|
$button = 'Unsubscribe';
|
|
$title = 'Unsubscribe from Revision';
|
|
// TODO: Once herald is in, add a notice about not getting any more
|
|
// herald notifications.
|
|
$prompt = 'Really unsubscribe from this revision?';
|
|
break;
|
|
default:
|
|
return new Aphront400Response();
|
|
}
|
|
|
|
$dialog
|
|
->setUser($user)
|
|
->setTitle($title)
|
|
->appendChild('<p>'.$prompt.'</p>')
|
|
->setSubmitURI($request->getRequestURI())
|
|
->addSubmitButton($button)
|
|
->addCancelButton('/D'.$revision->getID());
|
|
|
|
return id(new AphrontDialogResponse())->setDialog($dialog);
|
|
}
|
|
|
|
$revision->loadRelationships();
|
|
$phid = $user->getPHID();
|
|
|
|
switch ($this->action) {
|
|
case 'add':
|
|
DifferentialRevisionEditor::addCCAndUpdateRevision(
|
|
$revision,
|
|
$phid,
|
|
$phid);
|
|
break;
|
|
case 'rem':
|
|
DifferentialRevisionEditor::removeCCAndUpdateRevision(
|
|
$revision,
|
|
$phid,
|
|
$phid);
|
|
break;
|
|
default:
|
|
return new Aphront400Response();
|
|
}
|
|
|
|
return id(new AphrontRedirectResponse())->setURI('/D'.$revision->getID());
|
|
}
|
|
}
|