mirror of
https://we.phorge.it/source/phorge.git
synced 2024-11-13 10:22:42 +01:00
d6b882a804
Summary: Ref T6822. Test Plan: `grep` Reviewers: epriestley, #blessed_reviewers Reviewed By: epriestley, #blessed_reviewers Subscribers: hach-que, Korvin, epriestley Maniphest Tasks: T6822 Differential Revision: https://secure.phabricator.com/D11370
65 lines
1.4 KiB
PHP
65 lines
1.4 KiB
PHP
<?php
|
|
|
|
final class DifferentialDraft extends DifferentialDAO {
|
|
|
|
protected $objectPHID;
|
|
protected $authorPHID;
|
|
protected $draftKey;
|
|
|
|
protected function getConfiguration() {
|
|
return array(
|
|
self::CONFIG_COLUMN_SCHEMA => array(
|
|
'draftKey' => 'text64',
|
|
),
|
|
self::CONFIG_KEY_SCHEMA => array(
|
|
'key_unique' => array(
|
|
'columns' => array('objectPHID', 'authorPHID', 'draftKey'),
|
|
'unique' => true,
|
|
),
|
|
),
|
|
) + parent::getConfiguration();
|
|
}
|
|
|
|
public static function markHasDraft(
|
|
$author_phid,
|
|
$object_phid,
|
|
$draft_key) {
|
|
try {
|
|
id(new DifferentialDraft())
|
|
->setObjectPHID($object_phid)
|
|
->setAuthorPHID($author_phid)
|
|
->setDraftKey($draft_key)
|
|
->save();
|
|
} catch (AphrontDuplicateKeyQueryException $ex) {
|
|
// no worries
|
|
}
|
|
}
|
|
|
|
public static function deleteHasDraft(
|
|
$author_phid,
|
|
$object_phid,
|
|
$draft_key) {
|
|
$draft = id(new DifferentialDraft())->loadOneWhere(
|
|
'objectPHID = %s AND authorPHID = %s AND draftKey = %s',
|
|
$object_phid,
|
|
$author_phid,
|
|
$draft_key);
|
|
if ($draft) {
|
|
$draft->delete();
|
|
}
|
|
}
|
|
|
|
public static function deleteAllDrafts(
|
|
$author_phid,
|
|
$object_phid) {
|
|
|
|
$drafts = id(new DifferentialDraft())->loadAllWhere(
|
|
'objectPHID = %s AND authorPHID = %s',
|
|
$object_phid,
|
|
$author_phid);
|
|
foreach ($drafts as $draft) {
|
|
$draft->delete();
|
|
}
|
|
}
|
|
|
|
}
|