mirror of
https://we.phorge.it/source/phorge.git
synced 2025-02-20 10:48:40 +01:00
Summary: This has been replaced by `PolicyCodex` after D16830. Also: - Rebuild Celerity map to fix grumpy unit test. - Fix one issue on the policy exception workflow to accommodate the new code. Test Plan: - `arc unit --everything` - Viewed policy explanations. - Viewed policy errors. Reviewers: chad Reviewed By: chad Subscribers: hach-que, PHID-OPKG-gm6ozazyms6q6i22gyam Differential Revision: https://secure.phabricator.com/D16831
100 lines
2.4 KiB
PHP
100 lines
2.4 KiB
PHP
<?php
|
|
|
|
final class PhabricatorFileChunk extends PhabricatorFileDAO
|
|
implements
|
|
PhabricatorPolicyInterface,
|
|
PhabricatorDestructibleInterface {
|
|
|
|
protected $chunkHandle;
|
|
protected $byteStart;
|
|
protected $byteEnd;
|
|
protected $dataFilePHID;
|
|
|
|
private $dataFile = self::ATTACHABLE;
|
|
|
|
protected function getConfiguration() {
|
|
return array(
|
|
self::CONFIG_TIMESTAMPS => false,
|
|
self::CONFIG_COLUMN_SCHEMA => array(
|
|
'chunkHandle' => 'bytes12',
|
|
'byteStart' => 'uint64',
|
|
'byteEnd' => 'uint64',
|
|
'dataFilePHID' => 'phid?',
|
|
),
|
|
self::CONFIG_KEY_SCHEMA => array(
|
|
'key_file' => array(
|
|
'columns' => array('chunkHandle', 'byteStart', 'byteEnd'),
|
|
),
|
|
'key_data' => array(
|
|
'columns' => array('dataFilePHID'),
|
|
),
|
|
),
|
|
) + parent::getConfiguration();
|
|
}
|
|
|
|
public static function newChunkHandle() {
|
|
$seed = Filesystem::readRandomBytes(64);
|
|
return PhabricatorHash::digestForIndex($seed);
|
|
}
|
|
|
|
public static function initializeNewChunk($handle, $start, $end) {
|
|
return id(new PhabricatorFileChunk())
|
|
->setChunkHandle($handle)
|
|
->setByteStart($start)
|
|
->setByteEnd($end);
|
|
}
|
|
|
|
public function attachDataFile(PhabricatorFile $file = null) {
|
|
$this->dataFile = $file;
|
|
return $this;
|
|
}
|
|
|
|
public function getDataFile() {
|
|
return $this->assertAttached($this->dataFile);
|
|
}
|
|
|
|
|
|
/* -( PhabricatorPolicyInterface )----------------------------------------- */
|
|
|
|
|
|
public function getCapabilities() {
|
|
return array(
|
|
PhabricatorPolicyCapability::CAN_VIEW,
|
|
);
|
|
}
|
|
|
|
|
|
public function getPolicy($capability) {
|
|
// These objects are low-level and only accessed through the storage
|
|
// engine, so policies are mostly just in place to let us use the common
|
|
// query infrastructure.
|
|
return PhabricatorPolicies::getMostOpenPolicy();
|
|
}
|
|
|
|
|
|
public function hasAutomaticCapability($capability, PhabricatorUser $viewer) {
|
|
return false;
|
|
}
|
|
|
|
|
|
/* -( PhabricatorDestructibleInterface )----------------------------------- */
|
|
|
|
|
|
public function destroyObjectPermanently(
|
|
PhabricatorDestructionEngine $engine) {
|
|
|
|
$data_phid = $this->getDataFilePHID();
|
|
if ($data_phid) {
|
|
$data_file = id(new PhabricatorFileQuery())
|
|
->setViewer($engine->getViewer())
|
|
->withPHIDs(array($data_phid))
|
|
->executeOne();
|
|
if ($data_file) {
|
|
$engine->destroyObject($data_file);
|
|
}
|
|
}
|
|
|
|
$this->delete();
|
|
}
|
|
|
|
}
|