]> source.dussan.org Git - nextcloud-server.git/commitdiff
simple file encryption wip
authorRobin Appelman <icewind1991@gmail.com>
Sat, 22 Oct 2011 12:11:15 +0000 (14:11 +0200)
committerRobin Appelman <icewind@owncloud.com>
Tue, 21 Feb 2012 19:48:48 +0000 (20:48 +0100)
apps/files_encryption/lib/cryptstream.php
apps/files_encryption/lib/proxy.php

index e4544313f6351870d98b8c8dda7244561ab4bf8d..7fbfeaa7a86a48cfc2d19853f34a9e8755c5f8d2 100644 (file)
@@ -29,9 +29,12 @@ class OC_CryptStream{
 
        public function stream_open($path, $mode, $options, &$opened_path){
                $path=str_replace('crypt://','',$path);
-               $this->source=OC_FileSystem::fopen($path.'.enc',$mode);
+               OC_Log::write('files_encryption','open encrypted '.$path. ' in '.$mode,OC_Log::DEBUG);
+               OC_FileProxy::$enabled=false;//disable fileproxies so we can open the source file
+               $this->source=OC_FileSystem::fopen($path,$mode);
+               OC_FileProxy::$enabled=true;
                if(!is_resource($this->source)){
-                       OC_Log::write('files_encryption','failed to open '.$path.'.enc',OC_Log::ERROR);
+                       OC_Log::write('files_encryption','failed to open '.$path,OC_Log::ERROR);
                }
                return is_resource($this->source);
        }
index f7a991a344b35cd9e7167207467b2f535038c22c..053ac786c3392f484209bd1900825e7c30af6d23 100644 (file)
@@ -28,7 +28,6 @@
 class OC_FileProxy_Encryption extends OC_FileProxy{
        public function preFile_put_contents($path,&$data){
                if(substr($path,-4)=='.enc'){
-                       OC_Log::write('files_encryption','file put contents',OC_Log::DEBUG);
                        if (is_resource($data)) {
                                $newData='';
                                while(!feof($data)){
@@ -44,27 +43,33 @@ class OC_FileProxy_Encryption extends OC_FileProxy{
        
        public function postFile_get_contents($path,$data){
                if(substr($path,-4)=='.enc'){
-                       OC_Log::write('files_encryption','file get contents',OC_Log::DEBUG);
                        return OC_Crypt::blockDecrypt($data);
                }
        }
        
        public function postFopen($path,&$result){
                if(substr($path,-4)=='.enc'){
-                       OC_Log::write('files_encryption','fopen',OC_Log::DEBUG);
+                       $meta=stream_get_meta_data($result);
                        fclose($result);
-                       $result=fopen('crypt://'.substr($path,0,-4));//remove the .enc extention so we don't catch the fopen request made by cryptstream
+                       OC_log::write('file_encryption','mode: '.$meta['mode']);
+                       $result=fopen('crypt://'.$path,$meta['mode']);
                }
        }
        
        public function preReadFile($path){
                if(substr($path,-4)=='.enc'){
-                       OC_Log::write('files_encryption','readline',OC_Log::DEBUG);
-                       $stream=fopen('crypt://'.substr($path,0,-4));
+                       $stream=fopen('crypt://'.$path,'r');
                        while(!feof($stream)){
                                print(fread($stream,8192));
                        }
                        return false;//cancel the original request
                }
        }
+       
+       public function postGetMimeType($path,$result){
+               if(substr($path,-4)=='.enc'){
+                       return 'text/plain';
+               }
+               return $result;
+       }
 }