Summary: Mostly applies a new call spacing rule; also a few things that have slipped through via pull requests and such Test Plan: `find src/ -type f -name '*.php' | xargs -n16 arc lint --output summary --apply-patches` Reviewers: chad Reviewed By: chad CC: aran Differential Revision: https://secure.phabricator.com/D5002
52 lines
1.3 KiB
PHP
52 lines
1.3 KiB
PHP
<?php
|
|
|
|
final class PhabricatorCalendarDeleteStatusController
|
|
extends PhabricatorCalendarController {
|
|
|
|
private $id;
|
|
|
|
public function willProcessRequest(array $data) {
|
|
$this->id = idx($data, 'id');
|
|
}
|
|
|
|
public function processRequest() {
|
|
$request = $this->getRequest();
|
|
$user = $request->getUser();
|
|
$status = id(new PhabricatorUserStatus())
|
|
->loadOneWhere('id = %d', $this->id);
|
|
|
|
if (!$status) {
|
|
return new Aphront404Response();
|
|
}
|
|
if ($status->getUserPHID() != $user->getPHID()) {
|
|
return new Aphront403Response();
|
|
}
|
|
|
|
if ($request->isFormPost()) {
|
|
$status->delete();
|
|
$uri = new PhutilURI($this->getApplicationURI());
|
|
$uri->setQueryParams(
|
|
array(
|
|
'deleted' => true,
|
|
));
|
|
return id(new AphrontRedirectResponse())
|
|
->setURI($uri);
|
|
}
|
|
|
|
$dialog = new AphrontDialogView();
|
|
$dialog->setUser($user);
|
|
$dialog->setTitle(pht('Really delete status?'));
|
|
$dialog->appendChild(phutil_tag(
|
|
'p',
|
|
array(),
|
|
pht('Permanently delete this status? This action can not be undone.')));
|
|
$dialog->addSubmitButton(pht('Delete'));
|
|
$dialog->addCancelButton(
|
|
$this->getApplicationURI('status/edit/'.$status->getID().'/'));
|
|
|
|
return id(new AphrontDialogResponse())->setDialog($dialog);
|
|
|
|
}
|
|
|
|
}
|