Correctly emit create/update hooks when a large file is being created/update

after being uploaded in .part files

Fix #8131
This commit is contained in:
Joas Schilling 2014-04-09 16:47:51 +02:00
parent 4fa9e46d2b
commit c1caaa6241
1 changed files with 31 additions and 0 deletions

View File

@ -393,6 +393,7 @@ class View {
) {
$path1 = $this->getRelativePath($absolutePath1);
$path2 = $this->getRelativePath($absolutePath2);
$exists = $this->file_exists($path2);
if ($path1 == null or $path2 == null) {
return false;
@ -400,6 +401,23 @@ class View {
$run = true;
if ($this->shouldEmitHooks() && (Cache\Scanner::isPartialFile($path1) && !Cache\Scanner::isPartialFile($path2))) {
// if it was a rename from a part file to a regular file it was a write and not a rename operation
if (!$exists) {
\OC_Hook::emit(
Filesystem::CLASSNAME, Filesystem::signal_create,
array(
Filesystem::signal_param_path => $this->getHookPath($path2),
Filesystem::signal_param_run => &$run
)
);
} else {
\OC_Hook::emit(
Filesystem::CLASSNAME, Filesystem::signal_update,
array(
Filesystem::signal_param_path => $this->getHookPath($path2),
Filesystem::signal_param_run => &$run,
)
);
}
\OC_Hook::emit(
Filesystem::CLASSNAME, Filesystem::signal_write,
array(
@ -463,6 +481,19 @@ class View {
if ($this->shouldEmitHooks() && (Cache\Scanner::isPartialFile($path1) && !Cache\Scanner::isPartialFile($path2)) && $result !== false) {
// if it was a rename from a part file to a regular file it was a write and not a rename operation
Updater::writeHook(array('path' => $this->getHookPath($path2)));
if (!$exists) {
\OC_Hook::emit(
Filesystem::CLASSNAME,
Filesystem::signal_post_create,
array(Filesystem::signal_param_path => $this->getHookPath($path2))
);
} else {
\OC_Hook::emit(
Filesystem::CLASSNAME,
Filesystem::signal_post_update,
array(Filesystem::signal_param_path => $this->getHookPath($path2))
);
}
\OC_Hook::emit(
Filesystem::CLASSNAME,
Filesystem::signal_post_write,