2012-07-10 22:56:22 +00:00
< ? php
/**
* ownCloud
*
* @ author Michael Gapczynski
* @ copyright 2012 Michael Gapczynski mtgap @ owncloud . com
*
* This library is free software ; you can redistribute it and / or
* modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
* License as published by the Free Software Foundation ; either
* version 3 of the License , or any later version .
*
* This library is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU AFFERO GENERAL PUBLIC LICENSE for more details .
*
* You should have received a copy of the GNU Affero General Public
* License along with this library . If not , see < http :// www . gnu . org / licenses />.
*/
2012-08-06 15:27:13 +00:00
class OC_Share_Backend_File implements OCP\Share_Backend_File_Dependent {
2012-07-10 22:56:22 +00:00
2012-07-24 00:08:05 +00:00
const FORMAT_SHARED_STORAGE = 0 ;
2012-07-10 22:56:22 +00:00
const FORMAT_FILE_APP = 1 ;
const FORMAT_FILE_APP_ROOT = 2 ;
const FORMAT_OPENDIR = 3 ;
2012-08-06 15:27:13 +00:00
public function isValidSource ( $item , $uid ) {
// if (OC_Filesystem::file_exists($item)) {
return true ;
// }
// return false;
}
public function getFilePath ( $item , $uid ) {
return $item ;
2012-07-10 22:56:22 +00:00
}
public function generateTarget ( $item , $uid , $exclude = null ) {
// TODO Make sure target path doesn't exist already
2012-08-06 15:27:13 +00:00
return $item ;
2012-07-10 22:56:22 +00:00
}
public function formatItems ( $items , $format , $parameters = null ) {
if ( $format == self :: FORMAT_OPENDIR ) {
$files = array ();
foreach ( $items as $file ) {
$files [] = basename ( $file [ 'file_target' ]);
}
return $files ;
2012-07-24 00:08:05 +00:00
} else if ( $format == self :: FORMAT_SHARED_STORAGE ) {
$id = $items [ key ( $items )][ 'file_source' ];
$query = OCP\DB :: prepare ( 'SELECT path FROM *PREFIX*fscache WHERE id = ?' );
$result = $query -> execute ( array ( $id )) -> fetchAll ();
if ( isset ( $result [ 0 ][ 'path' ])) {
return array ( 'path' => $result [ 0 ][ 'path' ], 'permissions' => $items [ key ( $items )][ 'permissions' ]);
}
return false ;
2012-07-10 22:56:22 +00:00
} else {
$shares = array ();
$ids = array ();
foreach ( $items as $item ) {
$shares [ $item [ 'file_source' ]] = $item ;
$ids [] = $item [ 'file_source' ];
}
$ids = " ' " . implode ( " ',' " , $ids ) . " ' " ;
2012-07-24 00:08:05 +00:00
if ( $format == self :: FORMAT_FILE_APP ) {
2012-07-10 22:56:22 +00:00
$query = OCP\DB :: prepare ( 'SELECT id, path, name, ctime, mtime, mimetype, size, encrypted, versioned, writable FROM *PREFIX*fscache WHERE id IN (' . $ids . ')' );
$result = $query -> execute ();
$files = array ();
while ( $file = $result -> fetchRow ()) {
// Set target path
$file [ 'path' ] = $shares [ $file [ 'id' ]][ 'file_target' ];
$file [ 'name' ] = basename ( $file [ 'path' ]);
2012-07-25 20:33:08 +00:00
$file [ 'directory' ] = $parameters [ 'folder' ];
$file [ 'type' ] = ( $file [ 'mimetype' ] == 'httpd/unix-directory' ) ? 'dir' : 'file' ;
$permissions = $shares [ $file [ 'id' ]][ 'permissions' ];
if ( $file [ 'type' ] == 'file' ) {
// Remove Create permission if type is file
$permissions &= ~ OCP\Share :: PERMISSION_CREATE ;
}
$file [ 'permissions' ] = $permissions ;
2012-07-10 22:56:22 +00:00
$files [] = $file ;
}
return $files ;
} else if ( $format == self :: FORMAT_FILE_APP_ROOT ) {
$query = OCP\DB :: prepare ( 'SELECT id, path, name, ctime, mtime, mimetype, size, encrypted, versioned, writable FROM *PREFIX*fscache WHERE id IN (' . $ids . ')' );
$result = $query -> execute ();
$mtime = 0 ;
$size = 0 ;
while ( $file = $result -> fetchRow ()) {
if ( $file [ 'mtime' ] > $mtime ) {
$mtime = $file [ 'mtime' ];
}
$size += $file [ 'size' ];
}
2012-07-25 20:33:08 +00:00
return array ( 0 => array ( 'name' => 'Shared' , 'mtime' => $mtime , 'mimetype' => 'httpd/unix-directory' , 'size' => $size , 'writable' => false , 'type' => 'dir' , 'directory' => '' , 'permissions' => OCP\Share :: PERMISSION_READ ));
2012-07-10 22:56:22 +00:00
}
}
return array ();
}
2012-07-24 00:08:05 +00:00
}