2011-12-08 19:04:56 +00:00
< ? php
2012-01-08 10:01:25 +00:00
/**
* ownCloud - gallery application
*
* @ author Bartek Przybylski
2012-03-09 15:28:26 +00:00
* @ copyright 2012 Bartek Przybylski < bartek @ alefzero . eu >
*
2012-01-08 10:01:25 +00:00
* 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 .
2012-03-09 15:28:26 +00:00
*
2012-01-08 10:01:25 +00:00
* This library is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
2012-03-11 15:49:21 +00:00
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
2012-01-08 10:01:25 +00:00
* GNU AFFERO GENERAL PUBLIC LICENSE for more details .
2012-03-09 15:28:26 +00:00
*
2012-01-08 10:01:25 +00:00
* You should have received a copy of the GNU Lesser General Public
2012-03-11 15:49:21 +00:00
* License along with this library . If not , see < http :// www . gnu . org / licenses />.
2012-03-09 15:28:26 +00:00
*
2012-01-08 10:01:25 +00:00
*/
2011-12-21 20:55:52 +00:00
class OC_Gallery_Album {
2012-01-07 23:14:34 +00:00
public static function create ( $owner , $name , $path ){
2012-05-03 11:06:08 +00:00
$stmt = OCP\DB :: prepare ( 'INSERT INTO *PREFIX*gallery_albums (uid_owner, album_name, album_path, parent_path) VALUES (?, ?, ?, ?)' );
2012-03-11 15:49:21 +00:00
$stmt -> execute ( array ( $owner , $name , $path , self :: getParentPath ( $path )));
2011-12-21 20:55:52 +00:00
}
2012-02-03 20:38:44 +00:00
2012-03-11 15:49:21 +00:00
public static function cleanup () {
2012-05-01 16:50:31 +00:00
$albums = self :: find ( OCP\USER :: getUser ());
2012-03-11 15:49:21 +00:00
while ( $r = $albums -> fetchRow ()) {
OC_Gallery_Photo :: removeByAlbumId ( $r [ 'album_id' ]);
2012-05-01 16:50:31 +00:00
self :: remove ( OCP\USER :: getUser (), $r [ 'album_name' ]);
2012-03-11 15:49:21 +00:00
}
}
2012-03-04 17:28:41 +00:00
2012-03-11 15:49:21 +00:00
public static function getParentPath ( $path ) {
return $path === '/' ? '' : dirname ( $path );
}
2012-03-04 17:28:41 +00:00
2012-03-11 15:49:21 +00:00
public static function remove ( $owner , $name = null , $path = null , $parent = null ) {
$sql = 'DELETE FROM *PREFIX*gallery_albums WHERE uid_owner LIKE ?' ;
2011-12-21 20:55:52 +00:00
$args = array ( $owner );
if ( ! is_null ( $name )){
2012-03-11 15:49:21 +00:00
$sql .= ' AND album_name LIKE ?' ;
2011-12-21 20:55:52 +00:00
$args [] = $name ;
2012-03-11 15:49:21 +00:00
}
if ( ! is_null ( $path )){
$sql .= ' AND album_path LIKE ?' ;
$args [] = $path ;
}
if ( ! is_null ( $parent )){
$sql .= ' AND parent_path LIKE ?' ;
$args [] = $parent ;
}
2012-05-03 11:06:08 +00:00
$stmt = OCP\DB :: prepare ( $sql );
2011-12-21 20:55:52 +00:00
return $stmt -> execute ( $args );
}
2012-01-14 13:59:18 +00:00
2012-03-11 15:49:21 +00:00
public static function removeByName ( $owner , $name ) { self :: remove ( $ownmer , $name ); }
public static function removeByPath ( $owner , $path ) { self :: remove ( $owner , null , $path ); }
public static function removeByParentPath ( $owner , $parent ) { self :: remove ( $owner , null , null , $parent ); }
2011-12-21 20:55:52 +00:00
2012-03-11 15:49:21 +00:00
public static function find ( $owner , $name = null , $path = null , $parent = null ){
2011-12-08 19:04:56 +00:00
$sql = 'SELECT * FROM *PREFIX*gallery_albums WHERE uid_owner = ?' ;
$args = array ( $owner );
if ( ! is_null ( $name )){
$sql .= ' AND album_name = ?' ;
$args [] = $name ;
2012-03-11 15:49:21 +00:00
}
if ( ! is_null ( $path )){
$sql .= ' AND album_path = ?' ;
$args [] = $path ;
}
if ( ! is_null ( $parent )){
$sql .= ' AND parent_path = ?' ;
$args [] = $parent ;
}
2012-05-09 15:40:59 +00:00
$order = OCP\Config :: getUserValue ( $owner , 'gallery' , 'order' , 'ASC' );
2012-03-11 15:49:21 +00:00
$sql .= ' ORDER BY album_name ' . $order ;
2012-01-17 19:12:26 +00:00
2012-05-03 11:06:08 +00:00
$stmt = OCP\DB :: prepare ( $sql );
2011-12-08 19:04:56 +00:00
return $stmt -> execute ( $args );
}
2012-01-07 23:14:34 +00:00
2012-03-11 15:49:21 +00:00
public static function changePath ( $oldname , $newname , $owner ) {
2012-05-03 11:06:08 +00:00
$stmt = OCP\DB :: prepare ( 'UPDATE *PREFIX*gallery_albums SET album_path=? WHERE uid_owner=? AND album_path=?' );
2012-03-11 15:49:21 +00:00
$stmt -> execute ( array ( $newname , $owner , $oldname ));
}
2012-01-14 12:52:24 +00:00
2012-03-11 15:49:21 +00:00
public static function changeThumbnailPath ( $oldname , $newname ) {
2012-05-09 20:47:57 +00:00
$view = OCP\App :: getStorage ( 'gallery' );
$view -> rename ( $oldname . '.png' , $newname . '.png' );
2012-03-11 15:49:21 +00:00
}
2012-01-14 12:52:24 +00:00
2012-03-11 15:49:21 +00:00
public static function getAlbumSize ( $id ){
2012-05-09 15:40:59 +00:00
$sql = 'SELECT COUNT(*) as size FROM *PREFIX*gallery_photos WHERE album_id = ?' ;
$stmt = OCP\DB :: prepare ( $sql );
$result = $stmt -> execute ( array ( $id )) -> fetchRow ();
return $result [ 'size' ];
2012-03-11 15:49:21 +00:00
}
2012-03-17 22:41:10 +00:00
2012-05-09 15:40:59 +00:00
public static function getIntermediateGallerySize ( $path ) {
$path .= '%' ;
$sql = 'SELECT COUNT(*) as size FROM *PREFIX*gallery_photos photos, *PREFIX*gallery_albums albums WHERE photos.album_id = albums.album_id AND uid_owner = ? AND file_path LIKE ?' ;
$stmt = OCP\DB :: prepare ( $sql );
$result = $stmt -> execute ( array ( OCP\USER :: getUser (), $path )) -> fetchRow ();
return $result [ 'size' ];
}
2011-12-08 19:04:56 +00:00
}