mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-10 14:51:06 +01:00
Don't store empty drafts
Summary: We have lots of empty drafts in DB. Test Plan: Wrote revision comment, deleted it, checked db. Reviewers: epriestley Reviewed By: epriestley CC: aran, Korvin Differential Revision: https://secure.phabricator.com/D3591
This commit is contained in:
parent
6b9b1d4f95
commit
3d6a3e28fa
5 changed files with 35 additions and 30 deletions
|
@ -75,7 +75,7 @@ final class PhabricatorAuditPreviewController
|
||||||
->setAuthorPHID($comment->getActorPHID())
|
->setAuthorPHID($comment->getActorPHID())
|
||||||
->setDraftKey('diffusion-audit-'.$this->id)
|
->setDraftKey('diffusion-audit-'.$this->id)
|
||||||
->setDraft($comment->getContent())
|
->setDraft($comment->getContent())
|
||||||
->replace();
|
->replaceOrDelete();
|
||||||
|
|
||||||
return id(new AphrontAjaxResponse())
|
return id(new AphrontAjaxResponse())
|
||||||
->setContent($view->render());
|
->setContent($view->render());
|
||||||
|
|
|
@ -66,17 +66,20 @@ final class DifferentialCommentPreviewController
|
||||||
$view->setPreview(true);
|
$view->setPreview(true);
|
||||||
$view->setTargetDiff(null);
|
$view->setTargetDiff(null);
|
||||||
|
|
||||||
$draft = new PhabricatorDraft();
|
$metadata = array(
|
||||||
$draft
|
'reviewers' => $reviewers,
|
||||||
|
'ccs' => $ccs,
|
||||||
|
);
|
||||||
|
if ($action != DifferentialAction::ACTION_COMMENT) {
|
||||||
|
$metadata['action'] = $action;
|
||||||
|
}
|
||||||
|
|
||||||
|
id(new PhabricatorDraft())
|
||||||
->setAuthorPHID($author_phid)
|
->setAuthorPHID($author_phid)
|
||||||
->setDraftKey('differential-comment-'.$this->id)
|
->setDraftKey('differential-comment-'.$this->id)
|
||||||
->setDraft($comment->getContent())
|
->setDraft($comment->getContent())
|
||||||
->setMetadata(array(
|
->setMetadata($metadata)
|
||||||
'action' => $action,
|
->replaceOrDelete();
|
||||||
'reviewers' => $reviewers,
|
|
||||||
'ccs' => $ccs,
|
|
||||||
))
|
|
||||||
->replace();
|
|
||||||
|
|
||||||
return id(new AphrontAjaxResponse())
|
return id(new AphrontAjaxResponse())
|
||||||
->setContent($view->render());
|
->setContent($view->render());
|
||||||
|
|
|
@ -31,4 +31,17 @@ final class PhabricatorDraft extends PhabricatorDraftDAO {
|
||||||
) + parent::getConfiguration();
|
) + parent::getConfiguration();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function replaceOrDelete() {
|
||||||
|
if ($this->draft == '' && !array_filter($this->metadata)) {
|
||||||
|
queryfx(
|
||||||
|
$this->establishConnection('w'),
|
||||||
|
'DELETE FROM %T WHERE authorPHID = %s AND draftKey = %s',
|
||||||
|
$this->getTableName(),
|
||||||
|
$this->authorPHID,
|
||||||
|
$this->draftKey);
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
return parent::replace();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -39,18 +39,11 @@ final class ManiphestTransactionPreviewController extends ManiphestController {
|
||||||
return new Aphront404Response();
|
return new Aphront404Response();
|
||||||
}
|
}
|
||||||
|
|
||||||
$draft = id(new PhabricatorDraft())->loadOneWhere(
|
id(new PhabricatorDraft())
|
||||||
'authorPHID = %s AND draftKey = %s',
|
->setAuthorPHID($user->getPHID())
|
||||||
$user->getPHID(),
|
->setDraftKey($task->getPHID())
|
||||||
$task->getPHID());
|
->setDraft($comments)
|
||||||
if (!$draft) {
|
->replaceOrDelete();
|
||||||
$draft = new PhabricatorDraft();
|
|
||||||
$draft->setAuthorPHID($user->getPHID());
|
|
||||||
$draft->setDraftKey($task->getPHID());
|
|
||||||
}
|
|
||||||
$draft->setDraft($comments);
|
|
||||||
$draft->save();
|
|
||||||
|
|
||||||
|
|
||||||
$action = $request->getStr('action');
|
$action = $request->getStr('action');
|
||||||
|
|
||||||
|
|
|
@ -29,15 +29,11 @@ final class PhrictionDocumentPreviewController
|
||||||
|
|
||||||
$draft_key = $request->getStr('draftkey');
|
$draft_key = $request->getStr('draftkey');
|
||||||
if ($draft_key) {
|
if ($draft_key) {
|
||||||
$table = new PhabricatorDraft();
|
id(new PhabricatorDraft())
|
||||||
queryfx(
|
->setAuthorPHID($request->getUser()->getPHID())
|
||||||
$table->establishConnection('w'),
|
->setDraftKey($draft_key)
|
||||||
'INSERT INTO %T (authorPHID, draftKey, draft) VALUES (%s, %s, %s)
|
->setDraft($document)
|
||||||
ON DUPLICATE KEY UPDATE draft = VALUES(draft)',
|
->replaceOrDelete();
|
||||||
$table->getTableName(),
|
|
||||||
$request->getUser()->getPHID(),
|
|
||||||
$draft_key,
|
|
||||||
$document);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$content_obj = new PhrictionContent();
|
$content_obj = new PhrictionContent();
|
||||||
|
|
Loading…
Reference in a new issue