namespace OC\Files\Node;
+use OCP\Files\FileInfo;
use OC\Files\Filesystem;
use OC\Files\View;
-use OCP\Files\FileInfo;
use OCP\Util;
class HookConnector {
*/
private $view;
+ /**
+ * @var FileInfo[]
+ */
+ private $deleteMetaCache = [];
+
/**
* HookConnector constructor.
*
public function delete($arguments) {
$node = $this->getNodeForPath($arguments['path']);
+ $this->deleteMetaCache[$node->getPath()] = $node->getFileInfo();
$this->root->emit('\OC\Files', 'preDelete', [$node]);
}
public function postDelete($arguments) {
$node = $this->getNodeForPath($arguments['path']);
+ unset($this->deleteMetaCache[$node->getPath()]);
$this->root->emit('\OC\Files', 'postDelete', [$node]);
}
private function getNodeForPath($path) {
$info = Filesystem::getView()->getFileInfo($path);
if (!$info) {
+
$fullPath = Filesystem::getView()->getAbsolutePath($path);
+ if (isset($this->deleteMetaCache[$fullPath])) {
+ $info = $this->deleteMetaCache[$fullPath];
+ } else {
+ $info = null;
+ }
if (Filesystem::is_dir($path)) {
- return new NonExistingFolder($this->root, $this->view, $fullPath);
+ return new NonExistingFolder($this->root, $this->view, $fullPath, $info);
} else {
- return new NonExistingFile($this->root, $this->view, $fullPath);
+ return new NonExistingFile($this->root, $this->view, $fullPath, $info);
}
}
if ($info->getType() === FileInfo::TYPE_FILE) {
* Class HookConnector
*
* @group DB
- *
+ *
* @package Test\Files\Node
*/
class HookConnector extends TestCase {
$this->assertEquals('/' . $this->userId . '/files/source', $hookSourceNode->getPath());
$this->assertEquals('/' . $this->userId . '/files/target', $hookTargetNode->getPath());
}
+
+ public function testPostDeleteMeta() {
+ $connector = new \OC\Files\Node\HookConnector($this->root, $this->view);
+ $connector->viewToNode();
+ $hookCalled = false;
+ /** @var Node $hookNode */
+ $hookNode = null;
+
+ $this->root->listen('\OC\Files', 'postDelete', function ($node) use (&$hookNode, &$hookCalled) {
+ $hookCalled = true;
+ $hookNode = $node;
+ });
+
+ Filesystem::file_put_contents('test.txt', 'asd');
+ $info = Filesystem::getFileInfo('test.txt');
+ Filesystem::unlink('test.txt');
+
+ $this->assertTrue($hookCalled);
+ $this->assertEquals($hookNode->getId(), $info->getId());
+ }
}