mirror of
https://we.phorge.it/source/phorge.git
synced 2025-02-26 21:49:08 +01:00
Summary: Ref T4029. Much like D10756 this does the bare minimum to get things in there. I have a sticky with "TODOs" about moving the error-checking business logic into the editor in both cases. Up next - move actions... Test Plan: deleted a document and it worked! verified proper feed story. Reviewers: epriestley Reviewed By: epriestley Subscribers: shadowhand, Korvin, epriestley Maniphest Tasks: T4029 Differential Revision: https://secure.phabricator.com/D10761
77 lines
2.3 KiB
PHP
77 lines
2.3 KiB
PHP
<?php
|
|
|
|
final class PhrictionDeleteController extends PhrictionController {
|
|
|
|
private $id;
|
|
|
|
public function willProcessRequest(array $data) {
|
|
$this->id = $data['id'];
|
|
}
|
|
|
|
public function processRequest() {
|
|
$request = $this->getRequest();
|
|
$user = $request->getUser();
|
|
|
|
$document = id(new PhrictionDocumentQuery())
|
|
->setViewer($user)
|
|
->withIDs(array($this->id))
|
|
->needContent(true)
|
|
->requireCapabilities(
|
|
array(
|
|
PhabricatorPolicyCapability::CAN_EDIT,
|
|
PhabricatorPolicyCapability::CAN_VIEW,
|
|
))
|
|
->executeOne();
|
|
if (!$document) {
|
|
return new Aphront404Response();
|
|
}
|
|
|
|
$e_text = null;
|
|
$disallowed_states = array(
|
|
PhrictionDocumentStatus::STATUS_DELETED => true, // Silly
|
|
PhrictionDocumentStatus::STATUS_MOVED => true, // Makes no sense
|
|
PhrictionDocumentStatus::STATUS_STUB => true, // How could they?
|
|
);
|
|
if (isset($disallowed_states[$document->getStatus()])) {
|
|
$e_text = pht(
|
|
'An already moved or deleted document can not be deleted.');
|
|
}
|
|
|
|
$document_uri = PhrictionDocument::getSlugURI($document->getSlug());
|
|
|
|
if (!$e_text && $request->isFormPost()) {
|
|
$xactions = array();
|
|
$xactions[] = id(new PhrictionTransaction())
|
|
->setTransactionType(PhrictionTransaction::TYPE_DELETE)
|
|
->setNewValue(true);
|
|
|
|
$editor = id(new PhrictionTransactionEditor())
|
|
->setActor($user)
|
|
->setContentSourceFromRequest($request)
|
|
->setContinueOnNoEffect(true)
|
|
->applyTransactions($document, $xactions);
|
|
|
|
return id(new AphrontRedirectResponse())->setURI($document_uri);
|
|
}
|
|
|
|
if ($e_text) {
|
|
$dialog = id(new AphrontDialogView())
|
|
->setUser($user)
|
|
->setTitle(pht('Can not delete document!'))
|
|
->appendChild($e_text)
|
|
->addCancelButton($document_uri);
|
|
} else {
|
|
$dialog = id(new AphrontDialogView())
|
|
->setUser($user)
|
|
->setTitle(pht('Delete Document?'))
|
|
->appendChild(
|
|
pht('Really delete this document? You can recover it later by '.
|
|
'reverting to a previous version.'))
|
|
->addSubmitButton(pht('Delete'))
|
|
->addCancelButton($document_uri);
|
|
}
|
|
|
|
return id(new AphrontDialogResponse())->setDialog($dialog);
|
|
}
|
|
|
|
}
|