add post_* hooks to filesystem for write, create, delete, rename and copy

remotes/origin/stable
Robin Appelman 14 years ago
parent 80257558af
commit 07f2fcf7ec
  1. 103
      lib/filesystem.php

@ -30,10 +30,15 @@
* Hooks provided:
* read(path)
* write(path, &run)
* post_write(path)
* create(path, &run) (when a file is created, both create and write will be emited in that order)
* post_create(path)
* delete(path, &run)
* post_delete(path)
* rename(oldpath,newpath, &run)
* post_rename(oldpath,newpath)
* copy(oldpath,newpath, &run) (if the newpath doesn't exists yes, copy, create and write will be emited in that order)
* post_rename(oldpath,newpath)
*
* the &run parameter can be set to false to prevent the operation from occuring
*/
@ -231,7 +236,10 @@ class OC_FILESYSTEM{
OC_HOOK::emit( 'OC_FILESYSTEM', 'write', array( 'path' => $path, 'run' => &$run));
}
if($run){
return $storage->mkdir(self::getInternalPath($path));
$result=$storage->mkdir(self::getInternalPath($path));
OC_HOOK::emit( 'OC_FILESYSTEM', 'post_create', array( 'path' => $path));
OC_HOOK::emit( 'OC_FILESYSTEM', 'post_write', array( 'path' => $path));
return $result;
}
}
}
@ -240,7 +248,9 @@ class OC_FILESYSTEM{
$run=true;
OC_HOOK::emit( 'OC_FILESYSTEM', 'delete', array( 'path' => $path, 'run' => &$run));
if($run){
return $storage->rmdir(self::getInternalPath($path));
$result=$storage->rmdir(self::getInternalPath($path));
OC_HOOK::emit( 'OC_FILESYSTEM', 'post_delete', array( 'path' => $path));
return $result;
}
}
}
@ -332,14 +342,20 @@ class OC_FILESYSTEM{
static public function file_put_contents($path,$data){
if(self::canWrite($path) and $storage=self::getStorage($path)){
$run=true;
if(!self::file_exists($path)){
$exists=self::file_exists($path);
if(!$exists){
OC_HOOK::emit( 'OC_FILESYSTEM', 'create', array( 'path' => $path, 'run' => &$run));
}
if($run){
OC_HOOK::emit( 'OC_FILESYSTEM', 'write', array( 'path' => $path, 'run' => &$run));
}
if($run){
return $storage->file_put_contents(self::getInternalPath($path),$data);
$result=$storage->file_put_contents(self::getInternalPath($path),$data);
if(!$exists){
OC_HOOK::emit( 'OC_FILESYSTEM', 'post_create', array( 'path' => $path));
}
OC_HOOK::emit( 'OC_FILESYSTEM', 'post_write', array( 'path' => $path));
return $result;
}
}
}
@ -348,7 +364,9 @@ class OC_FILESYSTEM{
$run=true;
OC_HOOK::emit( 'OC_FILESYSTEM', 'delete', array( 'path' => $path, 'run' => &$run));
if($run){
return $storage->unlink(self::getInternalPath($path));
$result=$storage->unlink(self::getInternalPath($path));
OC_HOOK::emit( 'OC_FILESYSTEM', 'post_delete', array( 'path' => $path));
return $result;
}
}
}
@ -361,14 +379,15 @@ class OC_FILESYSTEM{
$mp2=self::getMountPoint($path2);
if($mp1==$mp2){
if($storage=self::getStorage($path1)){
return $storage->rename(self::getInternalPath($path1),self::getInternalPath($path2));
$result=$storage->rename(self::getInternalPath($path1),self::getInternalPath($path2));
}
}elseif($storage1=self::getStorage($path1) and $storage2=self::getStorage($path2)){
$tmpFile=$storage1->toTmpFile(self::getInternalPath($path1));
$result=$storage2->fromTmpFile(self::getInternalPath($path2));
$storage1->unlink(self::getInternalPath($path1));
return $result;
}
OC_HOOK::emit( 'OC_FILESYSTEM', 'post_rename', array( 'oldpath' => $path1, 'newpath'=>$path2));
return $result;
}
}
}
@ -376,7 +395,8 @@ class OC_FILESYSTEM{
if(self::canRead($path1) and self::canWrite($path2)){
$run=true;
OC_HOOK::emit( 'OC_FILESYSTEM', 'copy', array( 'oldpath' => $path1 ,'newpath'=>$path2, 'run' => &$run));
if($run and !self::file_exists($path2)){
$exists=self::file_exists($path2);
if($run and !$exists){
OC_HOOK::emit( 'OC_FILESYSTEM', 'create', array( 'path' => $path2, 'run' => &$run));
}
if($run){
@ -387,12 +407,18 @@ class OC_FILESYSTEM{
$mp2=self::getMountPoint($path2);
if($mp1==$mp2){
if($storage=self::getStorage($path1)){
return $storage->copy(self::getInternalPath($path1),self::getInternalPath($path2));
$result=$storage->copy(self::getInternalPath($path1),self::getInternalPath($path2));
}
}elseif($storage1=self::getStorage($path1) and $storage2=self::getStorage($path2)){
$tmpFile=$storage1->toTmpFile(self::getInternalPath($path1));
return $storage2->fromTmpFile(self::getInternalPath($path2));
$result=$storage2->fromTmpFile(self::getInternalPath($path2));
}
OC_HOOK::emit( 'OC_FILESYSTEM', 'post_copy', array( 'oldpath' => $path1 ,'newpath'=>$path2));
if(!$exists){
OC_HOOK::emit( 'OC_FILESYSTEM', 'post_create', array( 'path' => $path));
}
OC_HOOK::emit( 'OC_FILESYSTEM', 'post_write', array( 'path' => $path));
return $result;
}
}
}
@ -401,6 +427,8 @@ class OC_FILESYSTEM{
if($allowed){
if($storage=self::getStorage($path)){
$run=true;
$exists=self::file_exists($path);
$write=false;
switch($mode){
case 'r':
OC_HOOK::emit( 'OC_FILESYSTEM', 'read', array( 'path' => $path));
@ -410,26 +438,33 @@ class OC_FILESYSTEM{
case 'x+':
case 'a+':
OC_HOOK::emit( 'OC_FILESYSTEM', 'read', array( 'path' => $path));
if(!self::file_exists($path)){
OC_HOOK::emit( 'OC_FILESYSTEM', 'create', array( 'path' => $path));
}
if($run){
OC_HOOK::emit( 'OC_FILESYSTEM', 'write', array( 'path' => $path, 'run' => &$run));
}
$write=true;
break;
case 'w':
case 'x':
case 'a':
if(!self::file_exists($path)){
OC_HOOK::emit( 'OC_FILESYSTEM', 'create', array( 'path' => $path));
}
if($run){
OC_HOOK::emit( 'OC_FILESYSTEM', 'write', array( 'path' => $path, 'run' => &$run));
}
$write=true;
break;
}
if($write){
if(!$exists){
OC_HOOK::emit( 'OC_FILESYSTEM', 'create', array( 'path' => $path));
}
if($run){
OC_HOOK::emit( 'OC_FILESYSTEM', 'write', array( 'path' => $path, 'run' => &$run));
}
}
if($run){
return $storage->fopen(self::getInternalPath($path),$mode);
$result=$storage->fopen(self::getInternalPath($path),$mode);
if($write){
if(!$exists){
OC_HOOK::emit( 'OC_FILESYSTEM', 'post_create', array( 'path' => $path));
}
if($run){
OC_HOOK::emit( 'OC_FILESYSTEM', 'post_write', array( 'path' => $path));
}
}
return $result;
}
}
}
@ -443,28 +478,42 @@ class OC_FILESYSTEM{
static public function fromTmpFile($tmpFile,$path){
if(self::canWrite($path) and $storage=self::getStorage($path)){
$run=true;
if(!self::file_exists($path)){
$exists=self::file_exists($path);
if(!$exists){
OC_HOOK::emit( 'OC_FILESYSTEM', 'create', array( 'path' => $path, 'run' => &$run));
}
if($run){
OC_HOOK::emit( 'OC_FILESYSTEM', 'write', array( 'path' => $path, 'run' => &$run));
}
if($run){
return $storage->fromTmpFile($tmpFile,self::getInternalPath($path));
$result=$storage->fromTmpFile($tmpFile,self::getInternalPath($path));
if(!$exists){
OC_HOOK::emit( 'OC_FILESYSTEM', 'post_create', array( 'path' => $path));
}
OC_HOOK::emit( 'OC_FILESYSTEM', 'post_write', array( 'path' => $path));
return $result;
}
}
}
static public function fromUploadedFile($tmpFile,$path){
error_log('upload');
if(self::canWrite($path) and $storage=self::getStorage($path)){
$run=true;
if($run and !self::file_exists($path)){
$exists=self::file_exists($path);
if(!$exists){
OC_HOOK::emit( 'OC_FILESYSTEM', 'create', array( 'path' => $path, 'run' => &$run));
}
if($run){
OC_HOOK::emit( 'OC_FILESYSTEM', 'write', array( 'path' => $path, 'run' => &$run));
}
error_log('upload2');
if($run){
return $storage->fromUploadedFile($tmpFile,self::getInternalPath($path));
$result=$storage->fromUploadedFile($tmpFile,self::getInternalPath($path));
if(!$exists){
OC_HOOK::emit( 'OC_FILESYSTEM', 'post_create', array( 'path' => $path));
}
OC_HOOK::emit( 'OC_FILESYSTEM', 'post_write', array( 'path' => $path));
return $result;
}
}
}

Loading…
Cancel
Save